mirror of
				https://github.com/InsanusMokrassar/JSUIKitKBindings.git
				synced 2025-10-26 17:50:17 +00:00 
			
		
		
		
	| @@ -1,5 +1,9 @@ | |||||||
| # Changelog | # Changelog | ||||||
|  |  | ||||||
|  | ## 0.0.39 | ||||||
|  |  | ||||||
|  | * Add support of `Notifications` | ||||||
|  |  | ||||||
| ## 0.0.38 | ## 0.0.38 | ||||||
|  |  | ||||||
| * Add support of `Toggle` | * Add support of `Toggle` | ||||||
|   | |||||||
| @@ -9,4 +9,4 @@ android.enableJetifier=true | |||||||
| # Project data | # Project data | ||||||
|  |  | ||||||
| group=dev.inmo | group=dev.inmo | ||||||
| version=0.0.38 | version=0.0.39 | ||||||
|   | |||||||
| @@ -17,7 +17,7 @@ private class DialogDisposableEffectResult( | |||||||
| ) : DisposableEffectResult { | ) : DisposableEffectResult { | ||||||
|     override fun dispose() { |     override fun dispose() { | ||||||
|         onDispose?.invoke() |         onDispose?.invoke() | ||||||
|         js("UIkit").modal("#${element.id}") ?.hide() |         UIKit.modal("#${element.id}") ?.hide() | ||||||
|         onDisposed?.invoke() |         onDisposed?.invoke() | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -99,9 +99,7 @@ fun Dialog( | |||||||
|             } |             } | ||||||
|             htmlElement.addEventListener("hidden", wrapper) |             htmlElement.addEventListener("hidden", wrapper) | ||||||
|  |  | ||||||
|             val dialog = UIKit.modal("#${htmlElement.id}") |             UIKit.modal("#${htmlElement.id}") ?.show() | ||||||
|             dialog.show() |  | ||||||
|             Unit |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								src/jsMain/kotlin/dev/inmo/jsuikit/elements/Notification.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/jsMain/kotlin/dev/inmo/jsuikit/elements/Notification.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | package dev.inmo.jsuikit.elements | ||||||
|  |  | ||||||
|  | import dev.inmo.jsuikit.modifiers.UIKit | ||||||
|  | import dev.inmo.jsuikit.types.UIKitNotificationParameter | ||||||
|  | import dev.inmo.jsuikit.types.NotificationsGroup | ||||||
|  | import dev.inmo.jsuikit.types.invoke | ||||||
|  | import dev.inmo.jsuikit.utils.Milliseconds | ||||||
|  |  | ||||||
|  | fun Notification( | ||||||
|  |     message: String, | ||||||
|  |     status: UIKitNotificationParameter.Style? = null, | ||||||
|  |     timeout: Milliseconds? = null, | ||||||
|  |     group: NotificationsGroup? = null, | ||||||
|  |     position: UIKitNotificationParameter.Position? = null | ||||||
|  | ) = UIKit.notification.invoke(message, status, timeout, group, position) | ||||||
| @@ -1,4 +1,6 @@ | |||||||
| package dev.inmo.jsuikit.modifiers | package dev.inmo.jsuikit.modifiers | ||||||
|  |  | ||||||
| inline val UIKit | import dev.inmo.jsuikit.types.UIKit | ||||||
|     get() = js("UIkit") |  | ||||||
|  | inline val UIKit: UIKit | ||||||
|  |     get() = js("UIkit").unsafeCast<UIKit>() | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								src/jsMain/kotlin/dev/inmo/jsuikit/types/UIKit.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								src/jsMain/kotlin/dev/inmo/jsuikit/types/UIKit.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | package dev.inmo.jsuikit.types | ||||||
|  |  | ||||||
|  | import org.w3c.dom.Element | ||||||
|  | import kotlin.js.Json | ||||||
|  |  | ||||||
|  | external interface UIKit { | ||||||
|  |     val notification: UIKitNotifications | ||||||
|  |     val modal: UIKitDialogs | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     fun notification(message: String, parameters: Json) | ||||||
|  |     fun notification(element: Element): UIKitNotification? | ||||||
|  |  | ||||||
|  |     fun modal(element: Element): UIKitDialog | ||||||
|  |     fun modal(selector: String): UIKitDialog? | ||||||
|  | } | ||||||
							
								
								
									
										38
									
								
								src/jsMain/kotlin/dev/inmo/jsuikit/types/UIKitDialog.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/jsMain/kotlin/dev/inmo/jsuikit/types/UIKitDialog.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | package dev.inmo.jsuikit.types | ||||||
|  |  | ||||||
|  | import org.w3c.dom.Element | ||||||
|  | import kotlin.js.Promise | ||||||
|  |  | ||||||
|  | external interface UIKitDialogs { | ||||||
|  |     fun alert(text: String): UIKitDialogPromiseAlert | ||||||
|  |     fun confirm(text: String): UIKitDialogPromiseConfirm | ||||||
|  |     fun prompt(title: String): UIKitDialogPromisePrompt | ||||||
|  |     fun prompt(title: String, preset: String): UIKitDialogPromisePrompt | ||||||
|  |     fun dialog(element: Element): UIKitDialog | ||||||
|  | } | ||||||
|  |  | ||||||
|  | external class UIKitDialogPromiseConfirm : Promise<Unit> { | ||||||
|  |     val dialog: UIKitDialog | ||||||
|  |  | ||||||
|  |     fun then( | ||||||
|  |         onConfirm: () -> Unit = definedExternally, | ||||||
|  |         onRejected: () -> Unit = definedExternally, | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | external class UIKitDialogPromisePrompt : Promise<Unit> { | ||||||
|  |     val dialog: UIKitDialog | ||||||
|  |  | ||||||
|  |     fun then(onResult: (data: String?) -> Unit) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | external class UIKitDialogPromiseAlert : Promise<Unit> { | ||||||
|  |     val dialog: UIKitDialog | ||||||
|  |  | ||||||
|  |     fun then(onClose: () -> Unit) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | external interface UIKitDialog { | ||||||
|  |     fun show() | ||||||
|  |     fun hide() | ||||||
|  | } | ||||||
| @@ -0,0 +1,39 @@ | |||||||
|  | package dev.inmo.jsuikit.types | ||||||
|  |  | ||||||
|  | sealed class UIKitNotificationParameter { | ||||||
|  |     abstract val parameterName: String | ||||||
|  |     abstract val parameterValue: String | ||||||
|  |  | ||||||
|  |     sealed class Style(override val parameterValue: String) : UIKitNotificationParameter() { | ||||||
|  |         override val parameterName: String | ||||||
|  |             get() = "status" | ||||||
|  |  | ||||||
|  |         object Primary : Style("primary") | ||||||
|  |         object Success : Style("success") | ||||||
|  |         object Warning : Style("warning") | ||||||
|  |         object Danger : Style("danger") | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     sealed class Position(override val parameterValue: String) : UIKitNotificationParameter() { | ||||||
|  |         override val parameterName: String | ||||||
|  |             get() = "pos" | ||||||
|  |  | ||||||
|  |         sealed class Top(parameterValue: String) : Position("top-$parameterValue") { | ||||||
|  |  | ||||||
|  |             object Left : Top("left") | ||||||
|  |             object Center : Top("center") | ||||||
|  |             object Right : Top("right") | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         sealed class Bottom(parameterValue: String) : Position("bottom-$parameterValue") { | ||||||
|  |  | ||||||
|  |             object Left : Bottom("left") | ||||||
|  |             object Center : Bottom("center") | ||||||
|  |             object Right : Bottom("right") | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,47 @@ | |||||||
|  | package dev.inmo.jsuikit.types | ||||||
|  |  | ||||||
|  | import dev.inmo.jsuikit.modifiers.UIKit | ||||||
|  | import dev.inmo.jsuikit.utils.Milliseconds | ||||||
|  | import org.w3c.dom.Element | ||||||
|  | import kotlin.js.Json | ||||||
|  | import kotlin.js.json | ||||||
|  |  | ||||||
|  | typealias NotificationsGroup = String | ||||||
|  |  | ||||||
|  | external interface UIKitNotifications { | ||||||
|  |  | ||||||
|  |     fun closeAll(group: NotificationsGroup) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | external interface UIKitNotification { | ||||||
|  |     fun close(immediate: Boolean) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | data class UIKitNotificationsParameters( | ||||||
|  |     val status: UIKitNotificationParameter.Style? = null, | ||||||
|  |     val timeout: Milliseconds? = null, | ||||||
|  |     val group: NotificationsGroup? = null, | ||||||
|  |     val position: UIKitNotificationParameter.Position? = null | ||||||
|  | ) { | ||||||
|  |     fun parametersJson() = json( | ||||||
|  |         *listOfNotNull( | ||||||
|  |             status ?.let { it.parameterName to it.parameterValue }, | ||||||
|  |             timeout ?.let { "timeout" to timeout.toString() }, | ||||||
|  |             group ?.let { "group" to it }, | ||||||
|  |             position ?.let { it.parameterName to it.parameterValue }, | ||||||
|  |         ).toTypedArray() | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | operator fun UIKitNotifications.invoke( | ||||||
|  |     message: String, | ||||||
|  |     parameters: UIKitNotificationsParameters | ||||||
|  | ) = UIKit.notification(message, parameters.parametersJson()) | ||||||
|  |  | ||||||
|  | operator fun UIKitNotifications.invoke( | ||||||
|  |     message: String, | ||||||
|  |     status: UIKitNotificationParameter.Style? = null, | ||||||
|  |     timeout: Milliseconds? = null, | ||||||
|  |     group: NotificationsGroup? = null, | ||||||
|  |     position: UIKitNotificationParameter.Position? = null | ||||||
|  | ) = invoke(message, UIKitNotificationsParameters(status, timeout, group, position)) | ||||||
		Reference in New Issue
	
	Block a user