mirror of
https://github.com/InsanusMokrassar/JSUIKitKBindings.git
synced 2024-12-22 00:27:25 +00:00
commit
7c81cea8af
@ -1,5 +1,11 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## 0.5.2
|
||||||
|
|
||||||
|
* More fixes in Dialogs
|
||||||
|
* Badge supported
|
||||||
|
* Inline creation support
|
||||||
|
|
||||||
## 0.5.1
|
## 0.5.1
|
||||||
|
|
||||||
* Fixes in new `Dialog`s
|
* Fixes in new `Dialog`s
|
||||||
|
@ -9,4 +9,4 @@ android.enableJetifier=true
|
|||||||
# Project data
|
# Project data
|
||||||
|
|
||||||
group=dev.inmo
|
group=dev.inmo
|
||||||
version=0.5.1
|
version=0.5.2
|
||||||
|
25
src/jsMain/kotlin/dev/inmo/jsuikit/elements/Badge.kt
Normal file
25
src/jsMain/kotlin/dev/inmo/jsuikit/elements/Badge.kt
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
package dev.inmo.jsuikit.elements
|
||||||
|
|
||||||
|
import androidx.compose.runtime.Composable
|
||||||
|
import dev.inmo.jsuikit.modifiers.UIKitBadge
|
||||||
|
import dev.inmo.jsuikit.modifiers.include
|
||||||
|
import org.jetbrains.compose.web.dom.AttrBuilderContext
|
||||||
|
import org.jetbrains.compose.web.dom.ContentBuilder
|
||||||
|
import org.jetbrains.compose.web.dom.Span
|
||||||
|
import org.jetbrains.compose.web.dom.Text
|
||||||
|
import org.w3c.dom.HTMLSpanElement
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun Badge(
|
||||||
|
text: String,
|
||||||
|
onAfterText: ContentBuilder<HTMLSpanElement>? = null,
|
||||||
|
onBeforeText: ContentBuilder<HTMLSpanElement>? = null,
|
||||||
|
attrs: AttrBuilderContext<HTMLSpanElement>? = null
|
||||||
|
) = Span({
|
||||||
|
include(UIKitBadge)
|
||||||
|
attrs ?.invoke(this)
|
||||||
|
}) {
|
||||||
|
onAfterText ?.invoke(this)
|
||||||
|
Text(text)
|
||||||
|
onBeforeText ?.invoke(this)
|
||||||
|
}
|
@ -54,6 +54,8 @@ fun Dialog(
|
|||||||
|
|
||||||
if (onHidden != null || removeOnHide) {
|
if (onHidden != null || removeOnHide) {
|
||||||
htmlElement.addEventListener("hidden", {
|
htmlElement.addEventListener("hidden", {
|
||||||
|
if (it.target != htmlElement) return@addEventListener
|
||||||
|
|
||||||
onHidden ?.invoke(htmlElement)
|
onHidden ?.invoke(htmlElement)
|
||||||
|
|
||||||
if (removeOnHide) {
|
if (removeOnHide) {
|
||||||
@ -64,6 +66,8 @@ fun Dialog(
|
|||||||
|
|
||||||
onShown ?.let {
|
onShown ?.let {
|
||||||
htmlElement.addEventListener("shown", {
|
htmlElement.addEventListener("shown", {
|
||||||
|
if (it.target != htmlElement) return@addEventListener
|
||||||
|
|
||||||
onShown(htmlElement)
|
onShown(htmlElement)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
18
src/jsMain/kotlin/dev/inmo/jsuikit/elements/Inline.kt
Normal file
18
src/jsMain/kotlin/dev/inmo/jsuikit/elements/Inline.kt
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package dev.inmo.jsuikit.elements
|
||||||
|
|
||||||
|
import androidx.compose.runtime.Composable
|
||||||
|
import dev.inmo.jsuikit.modifiers.UIKitUtility
|
||||||
|
import dev.inmo.jsuikit.modifiers.include
|
||||||
|
import org.jetbrains.compose.web.dom.AttrBuilderContext
|
||||||
|
import org.jetbrains.compose.web.dom.ContentBuilder
|
||||||
|
import org.jetbrains.compose.web.dom.Div
|
||||||
|
import org.w3c.dom.HTMLDivElement
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun Inline(
|
||||||
|
attrBuilderContext: AttrBuilderContext<HTMLDivElement>? = null,
|
||||||
|
contentBuilder: ContentBuilder<HTMLDivElement>
|
||||||
|
) = Div({
|
||||||
|
include(UIKitUtility.Inline)
|
||||||
|
attrBuilderContext ?.invoke(this)
|
||||||
|
}, contentBuilder)
|
@ -0,0 +1,7 @@
|
|||||||
|
package dev.inmo.jsuikit.modifiers
|
||||||
|
|
||||||
|
sealed class UIKitBadge(classname: String) : UIKitModifier {
|
||||||
|
override val classes: Array<String> = arrayOf(classname)
|
||||||
|
|
||||||
|
companion object : UIKitBadge("uk-badge")
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user