be.doeraene.webcomponents.ui5.SegmentedButton.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of web-components-ui5_sjs1_3 Show documentation
Show all versions of web-components-ui5_sjs1_3 Show documentation
Laminar bindings for the web-component library UI5 from SAP
package be.doeraene.webcomponents.ui5
import be.doeraene.webcomponents.ui5.configkeys.{ButtonDesign, ColourScheme, IconName, SegmentedButtonMode}
import be.doeraene.webcomponents.ui5.eventtypes.{HasDetail, HasSelectedItem, HasSelectedItems}
import be.doeraene.webcomponents.ui5.internal.Slot
import com.raquo.laminar.codecs.{BooleanAsAttrPresenceCodec, StringAsIsCodec}
import com.raquo.laminar.api.L.*
import com.raquo.laminar.tags.CustomHtmlTag
import com.raquo.laminar.keys.HtmlAttr
import com.raquo.laminar.nodes.ReactiveHtmlElement
import org.scalajs.dom
import scala.scalajs.js
import scala.scalajs.js.annotation.{JSImport, JSName}
import be.doeraene.webcomponents.WebComponent
/** The ui5-segmented-button shows a group of items. When the user clicks or taps one of the items, it stays in a
* pressed state. It automatically resizes the items to fit proportionally within the component. When no width is set,
* the component uses the available width.
*
* @see
* the doc for more
* information.
*/
object SegmentedButton extends WebComponent {
@js.native
trait RawElement extends js.Object {
def selectedItem: SegmentedButtonItem.Ref = js.native
@JSName("selectedItems")
def selectedItemsJS: js.Array[SegmentedButtonItem.Ref] = js.native
}
object RawElement {
extension (elem: RawElement) {
def selectedItems: Vector[SegmentedButtonItem.Ref] = elem.selectedItemsJS.toVector
}
}
@js.native
@JSImport("@ui5/webcomponents/dist/SegmentedButton.js", JSImport.Default)
object RawImport extends js.Object
// object-s are lazy so you need to actually use them in your code to prevent dead code elimination
used(RawImport)
type Ref = dom.html.Element with RawElement
protected val tag: CustomHtmlTag[Ref] = CustomHtmlTag("ui5-segmented-button")
lazy val accessibleName: HtmlAttr[String] = htmlAttr("accessible-name", StringAsIsCodec)
lazy val mode: HtmlAttr[SegmentedButtonMode] = htmlAttr("mode", SegmentedButtonMode.AsStringCodec)
object slots {}
object events {
val onSelectionChange: EventProp[
dom.Event with HasDetail[HasSelectedItem[SegmentedButtonItem.Ref] with HasSelectedItems[SegmentedButtonItem.Ref]]
] =
new EventProp("selection-change")
}
def item: SegmentedButtonItem.type = SegmentedButtonItem
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy