forked from chandu0101/scalajs-react-components
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1 from dborisenko/react-trello
React trello
- Loading branch information
Showing
12 changed files
with
445 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
51 changes: 51 additions & 0 deletions
51
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/Board.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
package com.dbrsn.scalajs.react.trello | ||
|
||
import com.dbrsn.scalajs.react.macros.tojs.JSMacro | ||
import com.dbrsn.scalajs.react.trello.data._ | ||
import japgolly.scalajs.react.component.Js.{RawMounted, UnmountedWithRawType} | ||
import japgolly.scalajs.react.raw.React.Element | ||
import japgolly.scalajs.react.{Callback, Children, JsComponent} | ||
|
||
import scala.scalajs.js | ||
|
||
final case class Board[Metadata]( | ||
id: js.UndefOr[BoardId] = js.undefined, | ||
actions: js.UndefOr[RawAction] = js.undefined, | ||
data: Data[Metadata], | ||
reducerData: js.UndefOr[Data[Metadata]] = js.undefined, | ||
onDataChange: js.UndefOr[Data[Metadata] => Callback] = js.undefined, | ||
eventBusHandle: js.UndefOr[js.Any => Callback] = js.undefined, | ||
onLaneScroll: js.UndefOr[(Int, LaneId) => Callback] = js.undefined, | ||
onCardClick: js.UndefOr[(CardId, Metadata, LaneId) => Callback] = js.undefined, | ||
onCardDelete: js.UndefOr[(CardId, LaneId) => Callback] = js.undefined, | ||
onCardAdd: js.UndefOr[(Card[Metadata], LaneId) => Callback] = js.undefined, | ||
addCardLink: js.UndefOr[Element] = js.undefined, | ||
onLaneClick: js.UndefOr[LaneId => Callback] = js.undefined, | ||
laneSortFunction: js.UndefOr[(Card[Metadata], Card[Metadata]) => Callback] = js.undefined, | ||
draggable: js.UndefOr[Boolean] = js.undefined, | ||
collapsibleLanes: js.UndefOr[Boolean] = js.undefined, | ||
editable: js.UndefOr[Boolean] = js.undefined, | ||
hideCardDeleteIcon: js.UndefOr[Boolean] = js.undefined, | ||
handleDragStart: js.UndefOr[(CardId, LaneId) => Callback] = js.undefined, | ||
handleDragEnd: js.UndefOr[(CardId, SourceLaneId, TargetLaneId, Int) => Callback] = js.undefined, | ||
handleLaneDragStart: js.UndefOr[LaneId => Callback] = js.undefined, | ||
handleLaneDragEnd: js.UndefOr[(LaneId, Int) => Callback] = js.undefined, | ||
customCardLayout: js.UndefOr[Boolean] = js.undefined, | ||
customLaneHeader: js.UndefOr[Element] = js.undefined, | ||
style: js.UndefOr[RawStyle] = js.undefined, | ||
tagStyle: js.UndefOr[RawStyle] = js.undefined, | ||
laneDraggable: js.UndefOr[Boolean] = js.undefined, | ||
cardDraggable: js.UndefOr[Boolean] = js.undefined, | ||
cardDragClass: js.UndefOr[String] = js.undefined, | ||
laneDragClass: js.UndefOr[String] = js.undefined, | ||
addLaneTitle: js.UndefOr[String] = js.undefined, | ||
addCardTitle: js.UndefOr[String] = js.undefined, | ||
newLaneTemplate: js.UndefOr[Element] = js.undefined, | ||
className: js.UndefOr[String] = js.undefined | ||
) { | ||
def apply(): UnmountedWithRawType[js.Object, Null, RawMounted[js.Object, Null]] = { | ||
val props = JSMacro[Board[Metadata]](this) | ||
val f = JsComponent[js.Object, Children.None, Null](ReactTrello.Board) | ||
f(props) | ||
} | ||
} |
9 changes: 9 additions & 0 deletions
9
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/ReactTrello.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
package com.dbrsn.scalajs.react.trello | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.annotation.JSImport | ||
|
||
object ReactTrello { | ||
@js.native @JSImport("react-trello/dist/components/Board", JSImport.Default) | ||
object Board extends js.Any | ||
} |
53 changes: 53 additions & 0 deletions
53
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/data/Card.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
package com.dbrsn.scalajs.react.trello.data | ||
|
||
import scalacss.internal.StyleS | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.UndefOr | ||
|
||
@js.native | ||
trait Card[Metadata] extends js.Object { | ||
def id: CardId = js.native | ||
def title: String = js.native | ||
def label: String = js.native | ||
def description: String = js.native | ||
def cardStyle: UndefOr[RawStyle] = js.native | ||
def metadata: UndefOr[Metadata] = js.native | ||
} | ||
|
||
object Card { | ||
def apply[Metadata <: js.Any]( | ||
id: CardId, | ||
title: String, | ||
label: String = "", | ||
description: String = "", | ||
cardStyle: UndefOr[RawStyle] = js.undefined, | ||
metadata: UndefOr[Metadata] = js.undefined | ||
): Card[Metadata] = | ||
js.Dynamic | ||
.literal( | ||
id = id, | ||
title = title, | ||
label = label, | ||
description = description, | ||
cardStyle = cardStyle, | ||
metadata = metadata | ||
) | ||
.asInstanceOf[Card[Metadata]] | ||
|
||
def styled[Metadata <: js.Any]( | ||
id: CardId, | ||
title: String, | ||
label: String = "", | ||
description: String = "", | ||
cardStyle: UndefOr[StyleS], | ||
metadata: UndefOr[Metadata] = js.undefined | ||
): Card[Metadata] = apply[Metadata]( | ||
id = id, | ||
title = title, | ||
label = label, | ||
description = description, | ||
cardStyle = cardStyle.map(_.toJsAny), | ||
metadata = metadata | ||
) | ||
} |
14 changes: 14 additions & 0 deletions
14
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/data/Data.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
package com.dbrsn.scalajs.react.trello.data | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.JSConverters._ | ||
|
||
@js.native | ||
trait Data[Metadata] extends js.Object { | ||
def lanes: js.Array[Lane[Metadata]] = js.native | ||
} | ||
|
||
object Data { | ||
def apply[Metadata](lanes: Lane[Metadata]*): Data[Metadata] = | ||
js.Dynamic.literal(lanes = lanes.toJSArray).asInstanceOf[Data[Metadata]] | ||
} |
56 changes: 56 additions & 0 deletions
56
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/data/Lane.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
package com.dbrsn.scalajs.react.trello.data | ||
|
||
import scalacss.internal.StyleS | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.JSConverters._ | ||
import scala.scalajs.js.UndefOr | ||
|
||
@js.native | ||
trait Lane[Metadata] extends js.Object { | ||
def id: LaneId = js.native | ||
def title: String = js.native | ||
def label: String = js.native | ||
def style: UndefOr[RawStyle] = js.native | ||
def cards: js.Array[Card[Metadata]] = js.native | ||
def droppable: Boolean = js.native | ||
} | ||
|
||
object Lane { | ||
def apply[Metadata]( | ||
id: LaneId, | ||
title: String, | ||
label: String = "", | ||
style: UndefOr[RawStyle] = js.undefined, | ||
droppable: Boolean = true | ||
)( | ||
cards: Card[Metadata]* | ||
): Lane[Metadata] = | ||
js.Dynamic | ||
.literal( | ||
id = id, | ||
title = title, | ||
label = label, | ||
style = style, | ||
droppable = droppable, | ||
cards = cards.toJSArray | ||
) | ||
.asInstanceOf[Lane[Metadata]] | ||
|
||
def styled[Metadata]( | ||
id: LaneId, | ||
title: String, | ||
label: String = "", | ||
style: UndefOr[StyleS] = js.undefined, | ||
droppable: Boolean = true | ||
)( | ||
cards: Card[Metadata]* | ||
): Lane[Metadata] = | ||
apply( | ||
id = id, | ||
title = title, | ||
label = label, | ||
style = style.map(_.toJsAny), | ||
droppable = droppable | ||
)(cards: _*) | ||
} |
39 changes: 39 additions & 0 deletions
39
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/data/package.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
package com.dbrsn.scalajs.react.trello | ||
|
||
import com.dbrsn.scalajs.react.trello.data.Tag.@@ | ||
import scalacss.internal.StyleS | ||
|
||
import scala.scalajs.js | ||
|
||
package object data { | ||
type RawAction = js.Any | ||
type RawStyle = js.Any | ||
|
||
object RawStyle { | ||
def empty: RawStyle = new js.Object() | ||
} | ||
|
||
type BoardId = String @@ BoardId.Tag | ||
type CardId = String @@ CardId.Tag | ||
type LaneId = String @@ LaneId.Tag | ||
|
||
type SourceLaneId = LaneId | ||
type TargetLaneId = LaneId | ||
|
||
final def styleS2JsAny(style: StyleS): js.Any = { | ||
val result = js.Dictionary.empty[String] | ||
style.data.values.flatMap(_.avIterator).foreach { property => | ||
// Map CSS property name to react style naming convention. | ||
// For example: padding-top => paddingTop | ||
val propertyName = property.attr.id.split("-") match { | ||
case Array(head, other @ _*) => head + other.map(_.capitalize).mkString | ||
} | ||
result(propertyName) = property.value | ||
} | ||
result | ||
} | ||
|
||
implicit class StyleSOps(val style: StyleS) extends AnyVal { | ||
def toJsAny: js.Any = styleS2JsAny(style) | ||
} | ||
} |
28 changes: 28 additions & 0 deletions
28
react-trello/src/main/scala/com/dbrsn/scalajs/react/trello/data/tags.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
package com.dbrsn.scalajs.react.trello.data | ||
|
||
object Tag { | ||
@inline def apply[U]: Tagger[U] = new Tagger[U] | ||
|
||
trait Tagged[U] | ||
type @@[+T, U] = T with Tagged[U] | ||
|
||
class Tagger[U] { | ||
@inline def apply[T](t: T): T @@ U = t.asInstanceOf[T @@ U] | ||
} | ||
} | ||
|
||
object BoardId { | ||
sealed trait Tag | ||
@inline def apply(id: String): BoardId = Tag[Tag][String](id) | ||
} | ||
|
||
object CardId { | ||
sealed trait Tag | ||
@inline def apply(id: String): CardId = Tag[Tag][String](id) | ||
|
||
} | ||
|
||
object LaneId { | ||
sealed trait Tag | ||
@inline def apply(id: String): LaneId = Tag[Tag][String](id) | ||
} |
Oops, something went wrong.