aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/kotlin/pl/treksoft/kvision/html/Canvas.kt91
-rw-r--r--src/test/kotlin/test/pl/treksoft/kvision/html/CanvasSpec.kt47
2 files changed, 138 insertions, 0 deletions
diff --git a/src/main/kotlin/pl/treksoft/kvision/html/Canvas.kt b/src/main/kotlin/pl/treksoft/kvision/html/Canvas.kt
new file mode 100644
index 00000000..450042a2
--- /dev/null
+++ b/src/main/kotlin/pl/treksoft/kvision/html/Canvas.kt
@@ -0,0 +1,91 @@
+/*
+ * Copyright (c) 2017-present Robert Jaros
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+package pl.treksoft.kvision.html
+
+import com.github.snabbdom.VNode
+import org.w3c.dom.CanvasRenderingContext2D
+import org.w3c.dom.HTMLCanvasElement
+import pl.treksoft.kvision.core.Container
+import pl.treksoft.kvision.core.StringPair
+import pl.treksoft.kvision.core.Widget
+
+/**
+ * Canvas component.
+ *
+ * @constructor
+ * @param canvasWidth the width of the canvas
+ * @param canvasHeight the height of the canvas
+ * @param classes a set of CSS class names
+ */
+open class Canvas(
+ canvasWidth: Int? = null, canvasHeight: Int? = null, classes: Set<String> = setOf()
+) : Widget(classes) {
+ /**
+ * The width of the canvas.
+ */
+ var canvasWidth by refreshOnUpdate(canvasWidth)
+ /**
+ * The height of the canvas.
+ */
+ var canvasHeight by refreshOnUpdate(canvasHeight)
+
+ /**
+ * The canvas rendering context.
+ */
+ lateinit var context2D: CanvasRenderingContext2D
+
+ override fun render(): VNode {
+ return render("canvas")
+ }
+
+ override fun getSnAttrs(): List<StringPair> {
+ val pr = super.getSnAttrs().toMutableList()
+ canvasWidth?.let {
+ pr.add("width" to it.toString())
+ }
+ canvasHeight?.let {
+ pr.add("height" to it.toString())
+ }
+ return pr
+ }
+
+ override fun afterInsert(node: VNode) {
+ context2D = (node.elm as HTMLCanvasElement).getContext("2d") as CanvasRenderingContext2D
+ }
+
+ companion object {
+ /**
+ * DSL builder extension function.
+ *
+ * It takes the same parameters as the constructor of the built component.
+ */
+ fun Container.canvas(
+ canvasWidth: Int? = null, canvasHeight: Int? = null, classes: Set<String> = setOf(),
+ init: (Canvas.() -> Unit)? = null
+ ): Canvas {
+ val canvas =
+ Canvas(canvasWidth, canvasHeight, classes).apply { init?.invoke(this) }
+ this.add(canvas)
+ return canvas
+ }
+ }
+}
diff --git a/src/test/kotlin/test/pl/treksoft/kvision/html/CanvasSpec.kt b/src/test/kotlin/test/pl/treksoft/kvision/html/CanvasSpec.kt
new file mode 100644
index 00000000..a896d9e5
--- /dev/null
+++ b/src/test/kotlin/test/pl/treksoft/kvision/html/CanvasSpec.kt
@@ -0,0 +1,47 @@
+/*
+ * Copyright (c) 2017-present Robert Jaros
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+package test.pl.treksoft.kvision.html
+
+import pl.treksoft.kvision.html.Canvas
+import pl.treksoft.kvision.panel.Root
+import test.pl.treksoft.kvision.DomSpec
+import kotlin.browser.document
+import kotlin.test.Test
+
+class CanvasSpec : DomSpec {
+
+ @Test
+ fun render() {
+ run {
+ val root = Root("test", true)
+ val canvas = Canvas(800, 600)
+ root.add(canvas)
+ val element = document.getElementById("test")
+ assertEqualsHtml(
+ "<canvas width=\"800\" height=\"600\"></iframe>",
+ element?.innerHTML,
+ "Should render correct canvas"
+ )
+ }
+ }
+
+}