aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/pl/treksoft/kvision/progress
diff options
context:
space:
mode:
authorRobert Jaros <rjaros@finn.pl>2019-10-03 19:03:21 +0200
committerRobert Jaros <rjaros@finn.pl>2019-10-03 19:03:21 +0200
commit6b53324c97bfc80ed14dfca6a5dbc879950715b9 (patch)
tree55c7bb7d06e37470795a93e1f542e51ef3f1ace6 /src/main/kotlin/pl/treksoft/kvision/progress
parent22a8d5c35db97d65a90b21d97e6835380191845d (diff)
downloadkvision-6b53324c97bfc80ed14dfca6a5dbc879950715b9.tar.gz
kvision-6b53324c97bfc80ed14dfca6a5dbc879950715b9.tar.bz2
kvision-6b53324c97bfc80ed14dfca6a5dbc879950715b9.zip
Upgrade to Bootstrap 4.
Upgrade to Font Awesome 5. Restructure modules.
Diffstat (limited to 'src/main/kotlin/pl/treksoft/kvision/progress')
-rw-r--r--src/main/kotlin/pl/treksoft/kvision/progress/ProgressBar.kt162
-rw-r--r--src/main/kotlin/pl/treksoft/kvision/progress/ProgressIndicator.kt125
2 files changed, 0 insertions, 287 deletions
diff --git a/src/main/kotlin/pl/treksoft/kvision/progress/ProgressBar.kt b/src/main/kotlin/pl/treksoft/kvision/progress/ProgressBar.kt
deleted file mode 100644
index 4d0f4b93..00000000
--- a/src/main/kotlin/pl/treksoft/kvision/progress/ProgressBar.kt
+++ /dev/null
@@ -1,162 +0,0 @@
-/*
- * 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.progress
-
-import pl.treksoft.kvision.core.Container
-import pl.treksoft.kvision.html.Align
-import pl.treksoft.kvision.panel.SimplePanel
-
-/**
- * The Bootstrap progress bar.
- *
- * @constructor
- * @param progress the current progress
- * @param min the minimal progress
- * @param max the maximal progress
- * @param style the style of the progress bar
- * @param striped determines if the progress bar is striped
- * @param animated determines if the progress bar is animated
- * @param content element text
- * @param rich determines if content can contain HTML code
- * @param align content align
- * @param classes a set of CSS class names
- * @param init an initializer extension function
- */
-open class ProgressBar(
- progress: Int, min: Int = DEFAULT_MIN, max: Int = DEFAULT_MAX, style: ProgressBarStyle? = null,
- striped: Boolean = false, animated: Boolean = false, content: String? = null,
- rich: Boolean = false, align: Align? = null,
- classes: Set<String> = setOf(), init: (ProgressBar.() -> Unit)? = null
-) :
- SimplePanel(classes + "progress") {
-
- /**
- * The current progress.
- */
- var progress
- get() = indicator.progress
- set(value) {
- indicator.progress = value
- }
- /**
- * The minimal progress.
- */
- var min
- get() = indicator.min
- set(value) {
- indicator.min = value
- }
- /**
- * The maximal progress.
- */
- var max
- get() = indicator.max
- set(value) {
- indicator.max = value
- }
- /**
- * The style of the progress bar.
- */
- var style
- get() = indicator.style
- set(value) {
- indicator.style = value
- }
- /**
- * Determines if the progress bar is striped.
- */
- var striped
- get() = indicator.striped
- set(value) {
- indicator.striped = value
- }
- /**
- * Determines if the progress bar is animated.
- */
- var animated
- get() = indicator.animated
- set(value) {
- indicator.animated = value
- }
- /**
- * Text content of the progress bar.
- */
- var content
- get() = indicator.content
- set(value) {
- indicator.content = value
- }
- /**
- * Determines if [content] can contain HTML code.
- */
- var rich
- get() = indicator.rich
- set(value) {
- indicator.rich = value
- }
- /**
- * Text align of the progress bar.
- */
- var align
- get() = indicator.align
- set(value) {
- indicator.align = value
- }
-
- internal val indicator = ProgressIndicator(progress, min, max, style, striped, animated, content, rich, align)
-
- init {
- addInternal(indicator)
-
- @Suppress("LeakingThis")
- init?.invoke(this)
- }
-
- companion object {
- /**
- * DSL builder extension function.
- *
- * It takes the same parameters as the constructor of the built component.
- */
- fun Container.progressBar(
- progress: Int, min: Int = DEFAULT_MIN, max: Int = DEFAULT_MAX, style: ProgressBarStyle? = null,
- striped: Boolean = false, animated: Boolean = false,
- content: String? = null, rich: Boolean = false, align: Align? = null,
- classes: Set<String> = setOf(), init: (ProgressBar.() -> Unit)? = null
- ): ProgressBar {
- val progressBar = ProgressBar(
- progress,
- min,
- max,
- style,
- striped,
- animated,
- content,
- rich,
- align,
- classes
- ).apply { init?.invoke(this) }
- this.add(progressBar)
- return progressBar
- }
- }
-}
diff --git a/src/main/kotlin/pl/treksoft/kvision/progress/ProgressIndicator.kt b/src/main/kotlin/pl/treksoft/kvision/progress/ProgressIndicator.kt
deleted file mode 100644
index 256d15d7..00000000
--- a/src/main/kotlin/pl/treksoft/kvision/progress/ProgressIndicator.kt
+++ /dev/null
@@ -1,125 +0,0 @@
-/*
- * 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.progress
-
-import pl.treksoft.kvision.core.StringBoolPair
-import pl.treksoft.kvision.core.StringPair
-import pl.treksoft.kvision.html.Align
-import pl.treksoft.kvision.html.Div
-import pl.treksoft.kvision.utils.perc
-
-/**
- * Progress bar styles.
- */
-enum class ProgressBarStyle(internal val className: String) {
- SUCCESS("progress-bar-success"),
- INFO("progress-bar-info"),
- WARNING("progress-bar-warning"),
- DANGER("progress-bar-danger")
-}
-
-internal const val DEFAULT_MIN = 0
-internal const val DEFAULT_MAX = 100
-
-
-/**
- * The Bootstrap progress bar indicator.
- *
- * @constructor
- * @param progress the current progress
- * @param min the minimal progress
- * @param max the maximal progress
- * @param style the style of the progress bar indicator
- * @param striped determines if the progress bar indicator is striped
- * @param animated determines if the progress bar indicator is animated
- * @param content element text
- * @param rich determines if [content] can contain HTML code
- * @param align content align
- * @param classes a set of CSS class names
- */
-internal class ProgressIndicator(
- progress: Int, min: Int = DEFAULT_MIN, max: Int = DEFAULT_MAX, style: ProgressBarStyle? = null,
- striped: Boolean = false, animated: Boolean = false,
- content: String? = null, rich: Boolean = false, align: Align? = null,
- classes: Set<String> = setOf()
-) :
- Div(content, rich, align, classes) {
-
- /**
- * The current progress.
- */
- var progress by refreshOnUpdate(progress) { refreshWidth() }
- /**
- * The minimal progress.
- */
- var min by refreshOnUpdate(min) { refreshWidth() }
- /**
- * The maximal progress.
- */
- var max by refreshOnUpdate(max) { refreshWidth() }
- /**
- * The style of the progress indicator.
- */
- var style by refreshOnUpdate(style)
- /**
- * Determines if the progress indicator is striped.
- */
- var striped by refreshOnUpdate(striped)
- /**
- * Determines if the progress indicator is animated.
- */
- var animated by refreshOnUpdate(animated)
-
- init {
- role = "progressbar"
- refreshWidth()
- }
-
- private fun refreshWidth() {
- val value = (if (max - min > 0) (progress - min) * DEFAULT_MAX.toFloat() / (max - min) else 0f).toInt()
- val percent = if (value < 0) 0 else if (value > DEFAULT_MAX) DEFAULT_MAX else value
- width = percent.perc
- }
-
- override fun getSnClass(): List<StringBoolPair> {
- val cl = super.getSnClass().toMutableList()
- cl.add("progress-bar" to true)
- style?.let {
- cl.add(it.className to true)
- }
- if (striped || animated) {
- cl.add("progress-bar-striped" to true)
- }
- if (animated) {
- cl.add("active" to true)
- }
- return cl
- }
-
- override fun getSnAttrs(): List<StringPair> {
- val sn = super.getSnAttrs().toMutableList()
- sn.add("aria-valuenow" to "$progress")
- sn.add("aria-valuemin" to "$min")
- sn.add("aria-valuemax" to "$max")
- return sn
- }
-}