commonMain.jetbrains.datalore.vis.svg.SvgStylableElement.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lets-plot-common Show documentation
Show all versions of lets-plot-common Show documentation
Lets-Plot JVM package without rendering part
/*
* Copyright (c) 2019. JetBrains s.r.o.
* Use of this source code is governed by the MIT license that can be found in the LICENSE file.
*/
package jetbrains.datalore.vis.svg
import jetbrains.datalore.base.observable.property.Property
abstract class SvgStylableElement : SvgElement() {
companion object {
val CLASS: SvgAttributeSpec =
SvgAttributeSpec.createSpec("class")
}
fun classAttribute(): Property {
return getAttribute(CLASS)
}
fun addClass(cl: String): Boolean {
validateClassName(cl)
val attr = classAttribute()
if (attr.get() == null) {
attr.set(cl)
return true
}
if (attr.get()!!.split(" ").contains(cl)) {
return false
}
attr.set(attr.get() + " " + cl)
return true
}
fun removeClass(cl: String): Boolean {
validateClassName(cl)
val attr = classAttribute()
if (attr.get() == null) {
return false
}
val classes = ArrayList(attr.get()!!.split(" "))
val result = classes.remove(cl)
if (result) {
attr.set(buildClassString(classes))
}
return result
}
fun replaceClass(oldClass: String, newClass: String) {
validateClassName(oldClass)
validateClassName(newClass)
val attr = classAttribute()
if (attr.get() == null) {
throw IllegalStateException("Trying to replace class when class is empty")
}
val classes = attr.get()!!.split(" ")
if (!classes.contains(oldClass)) {
throw IllegalStateException("Class attribute does not contain specified oldClass")
}
val mutableClasses = MutableList(classes.size) { i -> classes[i] }
mutableClasses[classes.indexOf(oldClass)] = newClass
attr.set(buildClassString(mutableClasses))
}
fun toggleClass(cl: String): Boolean {
return if (hasClass(cl)) {
removeClass(cl)
false
} else {
addClass(cl)
true
}
}
fun hasClass(cl: String): Boolean {
validateClassName(cl)
val attr = classAttribute()
return attr.get() != null && ArrayList(attr.get()!!.split(" ")).contains(cl)
}
fun fullClass(): String {
val attr = classAttribute()
return if (attr.get() == null) "" else attr.get()!!
}
private fun buildClassString(classes: List): String {
val builder = StringBuilder()
for (className in classes) {
if (builder.isNotEmpty()) {
builder.append(' ')
}
builder.append(className)
}
return builder.toString()
}
private fun validateClassName(cl: String) {
if (cl.contains(" ")) {
throw IllegalArgumentException("Class name cannot contain spaces")
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy