Form 6 Input Types

String input

val inputField = new F6StringField().label("Name")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc => fs_4.apply(s"Your name is ${inputField.currentValue}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

(Optional) String input

val inputField = new F6StringOptField().label("Name")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc => fs_4.apply(s"Your name is ${inputField.currentValue.getOrElse("[None provided]")}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6RawHtmlField(p.apply("(Experiment with submitting an empty input)"))
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

(Experiment with submitting an empty input)

(Optional) Double input

val inputField = new F6DoubleOptField().label("Your height")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc => fs_4.apply(s"Your input is: ${inputField.currentValue.getOrElse("[None provided]")}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6RawHtmlField(p.apply("(Experiment with submitting an empty input)"))
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

(Experiment with submitting an empty input)

Double input

val inputField = new F6DoubleField().label("Your height")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc => fs_4.apply(s"Your input is: ${inputField.currentValue}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6RawHtmlField(p.apply("(Experiment with submitting an empty input)"))
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

(Experiment with submitting an empty input)

(Optional) Int input

val inputField = new F6IntOptField().label("Your age")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc => fs_4.apply(s"Your input is: ${inputField.currentValue.getOrElse("[None provided]")}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6RawHtmlField(p.apply("(Experiment with submitting an empty input)"))
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

(Experiment with submitting an empty input)

java.time.LocalDate input

val inputField = new F6DateOptField().label("Date")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Selected date is ${inputField.currentValue.map(_.format(DateTimeFormatter.ofPattern("dd MMM yyyy"))).getOrElse("[None selected]")}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

java.time.LocalDateTime input

val inputField = new F6DateTimeOptField().label("Date/time")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Selected date/time is ${inputField.currentValue.map(_.format(DateTimeFormatter.ofPattern("HH:mm dd MMM yyyy"))).getOrElse("[None selected]")}"))

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

Textarea

val inputField = new F6StringOptTextareaField().rows(6).label("Your message")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Your message:") ++
          pre.apply(inputField.currentValue.getOrElse("[No message provided]"))
      )

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

Select (Optional)

val colors: List[Color] = List(
  java.awt.Color.WHITE
  , java.awt.Color.LIGHT_GRAY
  , java.awt.Color.GRAY
  , java.awt.Color.DARK_GRAY
  , java.awt.Color.BLACK
  , java.awt.Color.RED
  , java.awt.Color.PINK
  , java.awt.Color.ORANGE
  , java.awt.Color.YELLOW
  , java.awt.Color.GREEN
  , java.awt.Color.MAGENTA
  , java.awt.Color.CYAN
  , java.awt.Color.BLUE
)
val inputField = new F6SelectOptField[Color]().optionsValid(colors).label("Color")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Your selection:") ++
          pre.apply(inputField.currentValue.map(_.toString).getOrElse("[None selected]"))
      )

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

Select (one always must be selected)

val colors: List[Color] = List(
  java.awt.Color.WHITE
  , java.awt.Color.LIGHT_GRAY
  , java.awt.Color.GRAY
  , java.awt.Color.DARK_GRAY
  , java.awt.Color.BLACK
  , java.awt.Color.RED
  , java.awt.Color.PINK
  , java.awt.Color.ORANGE
  , java.awt.Color.YELLOW
  , java.awt.Color.GREEN
  , java.awt.Color.MAGENTA
  , java.awt.Color.CYAN
  , java.awt.Color.BLUE
)
val inputField = new F6SelectField[Color](colors).label("Color")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Your selection:") ++
          pre.apply(inputField.currentValue.toString)
      )

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

Multi Select

val continents: List[String] = List(
  "Asia"
  , "Africa"
  , "North America"
  , "South America"
  , "Antarctica"
  , "Europe"
  , "Australia"
)
val inputField = new F6MultiSelectField().options(continents).label("Continents").size(10)

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Your selected continents:") ++
          pre.apply(inputField.currentValue.mkString(", "))
      )

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

Checkbox


val inputField = new F6CheckboxField().label("Has driving license")

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Your selection:") ++
          pre.apply(inputField.currentValue.toString)
      )

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}

Enum-based


object OutputState extends Enumeration {
  val High, Low, HighZ = Value
}

val inputField = EnumField.Nullable(OutputState).label("Output State").option2String(_.map(_.toString).getOrElse("--"))

div.border.p_2.rounded.apply {
  new DefaultForm6() {
    override def postSave()(implicit fsc: FSContext): Js =
      BSModal5.verySimple("Your input", "Done")(modal => implicit fsc =>
        fs_4.apply(s"Your selection:") ++
          pre.apply(inputField.currentValue.toString)
      )

    override lazy val rootField: F6Field = F6VerticalField()(
      inputField
      , new F6SaveButtonField(implicit fsc => BSBtn().BtnPrimary.lbl("Submit").btn.d_block)
    )
  }.render()
}