|
|
@ -1,199 +1,347 @@ |
|
|
|
/* |
|
|
|
|
|
|
|
* Copyright 2020-2021 JetBrains s.r.o. and respective authors and developers. |
|
|
|
|
|
|
|
* Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE.txt file. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@file:Suppress("UNUSED", "NOTHING_TO_INLINE") |
|
|
|
@file:Suppress("UNUSED", "NOTHING_TO_INLINE") |
|
|
|
package org.jetbrains.compose.web.css |
|
|
|
package org.jetbrains.compose.web.css |
|
|
|
|
|
|
|
|
|
|
|
import org.w3c.dom.HTMLElement |
|
|
|
import kotlinx.browser.window |
|
|
|
import org.w3c.dom.css.* |
|
|
|
import org.w3c.dom.DOMMatrix |
|
|
|
|
|
|
|
import org.w3c.dom.DOMMatrixReadOnly |
|
|
|
|
|
|
|
import org.w3c.dom.Element |
|
|
|
|
|
|
|
import org.w3c.dom.css.CSSRule |
|
|
|
|
|
|
|
import org.w3c.dom.css.CSSRuleList |
|
|
|
|
|
|
|
import org.w3c.dom.css.CSSStyleRule |
|
|
|
|
|
|
|
import org.w3c.dom.css.ElementCSSInlineStyle |
|
|
|
import org.w3c.dom.css.StyleSheet |
|
|
|
import org.w3c.dom.css.StyleSheet |
|
|
|
|
|
|
|
|
|
|
|
actual external interface CSSStyleValue |
|
|
|
inline val StyleSheet.cssRules |
|
|
|
|
|
|
|
get() = this.asDynamic().cssRules.unsafeCast<CSSRuleList>() |
|
|
|
|
|
|
|
|
|
|
|
external interface CSSKeywordValueJS : CSSStyleValue { |
|
|
|
inline fun StyleSheet.deleteRule(index: Int) { |
|
|
|
val value: String |
|
|
|
this.asDynamic().deleteRule(index) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@JsName("CSSKeywordValueActual") |
|
|
|
inline val CSSStyleRule.styleMap |
|
|
|
actual interface CSSKeywordValue : CSSKeywordValueJS, CSSStyleValue { |
|
|
|
get() = this.asDynamic().styleMap.unsafeCast<StylePropertyMap>() |
|
|
|
actual override val value: String |
|
|
|
|
|
|
|
|
|
|
|
inline operator fun CSSRuleList.get(index: Int): CSSRule { |
|
|
|
|
|
|
|
return this.asDynamic()[index].unsafeCast<CSSRule>() |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual companion object { |
|
|
|
fun StyleSheet.insertRule(cssRule: String, index: Int? = null): Int { |
|
|
|
actual inline operator fun invoke(value: String): CSSKeywordValue = |
|
|
|
return if (index != null) { |
|
|
|
CSSKeywordValueKT(value) |
|
|
|
this.asDynamic().insertRule(cssRule, index).unsafeCast<Int>() |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
this.asDynamic().insertRule(cssRule).unsafeCast<Int>() |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual interface StylePropertyValue { |
|
|
|
val ElementCSSInlineStyle.attributeStyleMap |
|
|
|
actual interface String: StylePropertyValue |
|
|
|
get() = this.asDynamic().attributeStyleMap.unsafeCast<StylePropertyMap>() |
|
|
|
actual interface Number: StylePropertyValue |
|
|
|
|
|
|
|
actual interface StyleValue: StylePropertyValue, CSSStyleValue |
|
|
|
|
|
|
|
actual companion object { |
|
|
|
|
|
|
|
actual inline operator fun invoke(value: kotlin.String): String = value.unsafeCast<String>() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
actual inline operator fun invoke(value: kotlin.Number): Number = value.unsafeCast<Number>() |
|
|
|
external interface CSSStyleValue { |
|
|
|
|
|
|
|
// toString() : string |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual inline operator fun invoke(value: CSSStyleValue): StyleValue = value.unsafeCast<StyleValue>() |
|
|
|
@JsName("CSSStyleValue") |
|
|
|
|
|
|
|
open external class CSSStyleValueJS : CSSStyleValue { |
|
|
|
|
|
|
|
companion object { |
|
|
|
|
|
|
|
fun parse(property: String, cssText: String): CSSStyleValue |
|
|
|
|
|
|
|
fun parseAll(property: String, cssText: String): Array<CSSStyleValue> |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// type CSSNumeric = number | CSSNumericValue |
|
|
|
external class CSSVariableReferenceValue( |
|
|
|
actual interface CSSNumeric { |
|
|
|
variable: String, |
|
|
|
actual interface Number : CSSNumeric |
|
|
|
fallback: CSSUnparsedValue? = definedExternally |
|
|
|
actual interface NumericValue : CSSNumeric, CSSNumericValue |
|
|
|
) { |
|
|
|
actual companion object { |
|
|
|
val variable: String |
|
|
|
actual inline operator fun invoke(value: kotlin.Number): Number = value.unsafeCast<Number>() |
|
|
|
val fallback: CSSUnparsedValue? |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual inline operator fun invoke(value: CSSNumericValue): NumericValue = value.unsafeCast<NumericValue>() |
|
|
|
// type CSSUnparsedSegment = String | CSSVariableReferenceValue |
|
|
|
|
|
|
|
interface CSSUnparsedSegment { |
|
|
|
|
|
|
|
companion object { |
|
|
|
|
|
|
|
operator fun invoke(value: String) = value.unsafeCast<CSSUnparsedSegment>() |
|
|
|
|
|
|
|
operator fun invoke(value: CSSVariableReferenceValue) = |
|
|
|
|
|
|
|
value.unsafeCast<CSSUnparsedSegment>() |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual external interface CSSMathValue : CSSNumericValue { |
|
|
|
fun CSSUnparsedSegment.asString() = this.asDynamic() as? String |
|
|
|
@JsName("operator") |
|
|
|
fun CSSUnparsedSegment.asCSSVariableReferenceValue() = |
|
|
|
actual val strOperator: String |
|
|
|
this.asDynamic() as? CSSVariableReferenceValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSUnparsedValue(members: Array<CSSUnparsedSegment>) : CSSStyleValue { |
|
|
|
|
|
|
|
// TODO: [Symbol.iterator]() : IterableIterator<CSSUnparsedSegment> |
|
|
|
|
|
|
|
fun forEach(handler: (CSSUnparsedSegment) -> Unit) |
|
|
|
|
|
|
|
val length: Int |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// readonly [index: number]: CSSUnparsedSegment |
|
|
|
|
|
|
|
operator fun get(index: Int): CSSUnparsedSegment |
|
|
|
|
|
|
|
operator fun set(index: Int, value: CSSUnparsedSegment) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual val CSSMathValue.operator: CSSMathOperator |
|
|
|
external interface CSSKeywordValue : CSSStyleValue { |
|
|
|
get() = CSSMathOperator.valueOf(this.strOperator) |
|
|
|
val value: String |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual external class CSSNumericArray { |
|
|
|
@JsName("CSSKeywordValue") |
|
|
|
actual fun forEach(handler: (CSSNumericValue) -> Unit) |
|
|
|
external class CSSKeywordValueJS(value: String) : CSSKeywordValue { |
|
|
|
|
|
|
|
override val value: String |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual val length: Int |
|
|
|
// type CSSNumberish = number | CSSNumericValue |
|
|
|
|
|
|
|
interface CSSNumberish { |
|
|
|
|
|
|
|
companion object { |
|
|
|
|
|
|
|
operator fun invoke(value: Number) = value.unsafeCast<CSSNumberish>() |
|
|
|
|
|
|
|
operator fun invoke(value: CSSNumericValue) = |
|
|
|
|
|
|
|
value.unsafeCast<CSSNumberish>() |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual operator fun get(index: Int): CSSNumericValue |
|
|
|
fun CSSNumberish.asNumber() = this.asDynamic() as? Number |
|
|
|
|
|
|
|
fun CSSNumberish.asCSSNumericValue(): CSSNumericValue? = this.asDynamic() as? CSSNumericValueJS |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// declare enum CSSNumericBaseType { |
|
|
|
|
|
|
|
// 'length', |
|
|
|
|
|
|
|
// 'angle', |
|
|
|
|
|
|
|
// 'time', |
|
|
|
|
|
|
|
// 'frequency', |
|
|
|
|
|
|
|
// 'resolution', |
|
|
|
|
|
|
|
// 'flex', |
|
|
|
|
|
|
|
// 'percent', |
|
|
|
|
|
|
|
// } |
|
|
|
|
|
|
|
enum class CSSNumericBaseType(val value: String) { |
|
|
|
|
|
|
|
@JsName("_length") |
|
|
|
|
|
|
|
length("length"), |
|
|
|
|
|
|
|
angle("angle"), |
|
|
|
|
|
|
|
time("time"), |
|
|
|
|
|
|
|
frequency("frequency"), |
|
|
|
|
|
|
|
resolution("resolution"), |
|
|
|
|
|
|
|
flex("flex"), |
|
|
|
|
|
|
|
percent("percent") |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual external interface CSSMathSum : CSSMathValue { |
|
|
|
external interface CSSNumericType { |
|
|
|
actual val values: CSSNumericArray |
|
|
|
val length: Number |
|
|
|
|
|
|
|
val angle: Number |
|
|
|
|
|
|
|
val time: Number |
|
|
|
|
|
|
|
val frequency: Number |
|
|
|
|
|
|
|
val resolution: Number |
|
|
|
|
|
|
|
val flex: Number |
|
|
|
|
|
|
|
val percent: Number |
|
|
|
|
|
|
|
// percentHint: CSSNumericBaseType |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual interface CSSNumericType { |
|
|
|
val CSSNumericType.percentHint |
|
|
|
actual val length: Number |
|
|
|
get() = CSSNumericBaseType.valueOf(this.asDynamic().percentHint) |
|
|
|
actual val angle: Number |
|
|
|
// set(value) { this.asDynamic().percentHint = value.value } |
|
|
|
actual val time: Number |
|
|
|
|
|
|
|
actual val frequency: Number |
|
|
|
external interface CSSNumericValue : CSSStyleValue { |
|
|
|
actual val resolution: Number |
|
|
|
fun add(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
actual val flex: Number |
|
|
|
fun sub(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
actual val percent: Number |
|
|
|
fun mul(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
@JsName("percentHint") |
|
|
|
fun div(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
actual val strPercentHint: String |
|
|
|
fun min(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
fun max(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun equals(vararg values: CSSNumberish): Boolean |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun to(unit: String): CSSUnitValue |
|
|
|
|
|
|
|
fun toSum(vararg units: String): CSSMathSum |
|
|
|
|
|
|
|
fun type(): CSSNumericType |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual val CSSNumericType.percentHint: CSSNumericBaseType |
|
|
|
abstract external class CSSNumericValueJS : CSSNumericValue { |
|
|
|
get() = CSSNumericBaseType.valueOf(this.strPercentHint) |
|
|
|
override fun add(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
override fun sub(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
override fun mul(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
override fun div(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
override fun min(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
override fun max(vararg values: CSSNumberish): CSSNumericValue |
|
|
|
|
|
|
|
|
|
|
|
actual external interface CSSNumericValue : CSSStyleValue |
|
|
|
override fun equals(vararg values: CSSNumberish): Boolean |
|
|
|
|
|
|
|
|
|
|
|
actual external interface CSSUnitValue : CSSNumericValue { |
|
|
|
override fun to(unit: String): CSSUnitValue |
|
|
|
actual val value: Number |
|
|
|
override fun toSum(vararg units: String): CSSMathSum |
|
|
|
actual val unit: String |
|
|
|
override fun type(): CSSNumericType |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
companion object { |
|
|
|
|
|
|
|
fun parse(cssText: String): CSSNumericValue |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
actual external interface CSSTypedOM { |
|
|
|
external interface CSSUnitValue : CSSNumericValue { |
|
|
|
actual fun number(value: Number): CSSnumberValue |
|
|
|
val value: Number |
|
|
|
actual fun percent(value: Number): CSSpercentValue |
|
|
|
val unit: String |
|
|
|
actual fun em(value: Number): CSSemValue |
|
|
|
|
|
|
|
actual fun ex(value: Number): CSSexValue |
|
|
|
|
|
|
|
actual fun ch(value: Number): CSSchValue |
|
|
|
|
|
|
|
actual fun ic(value: Number): CSSicValue |
|
|
|
|
|
|
|
actual fun rem(value: Number): CSSremValue |
|
|
|
|
|
|
|
actual fun lh(value: Number): CSSlhValue |
|
|
|
|
|
|
|
actual fun rlh(value: Number): CSSrlhValue |
|
|
|
|
|
|
|
actual fun vw(value: Number): CSSvwValue |
|
|
|
|
|
|
|
actual fun vh(value: Number): CSSvhValue |
|
|
|
|
|
|
|
actual fun vi(value: Number): CSSviValue |
|
|
|
|
|
|
|
actual fun vb(value: Number): CSSvbValue |
|
|
|
|
|
|
|
actual fun vmin(value: Number): CSSvminValue |
|
|
|
|
|
|
|
actual fun vmax(value: Number): CSSvmaxValue |
|
|
|
|
|
|
|
actual fun cm(value: Number): CSScmValue |
|
|
|
|
|
|
|
actual fun mm(value: Number): CSSmmValue |
|
|
|
|
|
|
|
actual fun Q(value: Number): CSSQValue |
|
|
|
|
|
|
|
actual fun pt(value: Number): CSSptValue |
|
|
|
|
|
|
|
actual fun pc(value: Number): CSSpcValue |
|
|
|
|
|
|
|
actual fun px(value: Number): CSSpxValue |
|
|
|
|
|
|
|
actual fun deg(value: Number): CSSdegValue |
|
|
|
|
|
|
|
actual fun grad(value: Number): CSSgradValue |
|
|
|
|
|
|
|
actual fun rad(value: Number): CSSradValue |
|
|
|
|
|
|
|
actual fun turn(value: Number): CSSturnValue |
|
|
|
|
|
|
|
actual fun s(value: Number): CSSsValue |
|
|
|
|
|
|
|
actual fun ms(value: Number): CSSmsValue |
|
|
|
|
|
|
|
actual fun Hz(value: Number): CSSHzValue |
|
|
|
|
|
|
|
actual fun kHz(value: Number): CSSkHzValue |
|
|
|
|
|
|
|
actual fun dpi(value: Number): CSSdpiValue |
|
|
|
|
|
|
|
actual fun dpcm(value: Number): CSSdpcmValue |
|
|
|
|
|
|
|
actual fun dppx(value: Number): CSSdppxValue |
|
|
|
|
|
|
|
actual fun fr(value: Number): CSSfrValue |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external interface CSSTypedUnitValue<T> : CSSNumericValue { |
|
|
|
|
|
|
|
val value: Number |
|
|
|
|
|
|
|
val unit: T |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
class StylePropertyMapKT(private val style: CSSStyleDeclaration, private val clearFn: () -> Unit): StylePropertyMap { |
|
|
|
@JsName("CSSUnitValue") |
|
|
|
override fun set(property: String, value: StylePropertyValue) { |
|
|
|
external class CSSUnitValueJS(value: Number, unit: String) : CSSNumericValueJS, CSSUnitValue { |
|
|
|
style.setProperty(property, value.toString()) |
|
|
|
override val value: Number |
|
|
|
|
|
|
|
override val unit: String |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
override fun append(property: String, value: StylePropertyValue) { |
|
|
|
// declare enum CSSMathOperator { |
|
|
|
val oldValues = style.getPropertyValue(property) |
|
|
|
// 'sum', |
|
|
|
if (oldValues == undefined) { |
|
|
|
// 'product', |
|
|
|
style.setProperty(property, value.toString()) |
|
|
|
// 'negate', |
|
|
|
} else { |
|
|
|
// 'invert', |
|
|
|
val newValues = listOf(oldValues, value) |
|
|
|
// 'min', |
|
|
|
style.setProperty(property, newValues.joinToString(", ")) |
|
|
|
// 'max', |
|
|
|
|
|
|
|
// 'clamp', |
|
|
|
|
|
|
|
// } |
|
|
|
|
|
|
|
enum class CSSMathOperator(val value: String) { |
|
|
|
|
|
|
|
sum("sum"), |
|
|
|
|
|
|
|
product("product"), |
|
|
|
|
|
|
|
negate("negate"), |
|
|
|
|
|
|
|
invert("invert"), |
|
|
|
|
|
|
|
min("min"), |
|
|
|
|
|
|
|
max("max"), |
|
|
|
|
|
|
|
clamp("clamp") |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
open external class CSSMathValue : CSSNumericValueJS { |
|
|
|
|
|
|
|
// readonly operator: CSSMathOperator |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
override fun delete(property: String) { |
|
|
|
val CSSMathValue.operator |
|
|
|
style.removeProperty(property) |
|
|
|
get() = CSSMathOperator.valueOf(this.asDynamic().operator) |
|
|
|
|
|
|
|
// set(value) { this.asDynamic().operator = value.value } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSMathSum(vararg args: CSSNumberish) : CSSMathValue { |
|
|
|
|
|
|
|
val values: CSSNumericArray |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
override fun clear() { |
|
|
|
external class CSSMathProduct(vararg args: CSSNumberish) : CSSMathValue { |
|
|
|
clearFn() |
|
|
|
val values: CSSNumericArray |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
override fun has(property: String): Boolean { |
|
|
|
external class CSSMathNegate(arg: CSSNumberish) : CSSMathValue { |
|
|
|
return style.getPropertyValue(property) as String? != null |
|
|
|
val value: CSSNumericValue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSMathInvert(arg: CSSNumberish) : CSSMathValue { |
|
|
|
|
|
|
|
val value: CSSNumericValue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun Any.polyfillStylePropertyMap(jsFieldName: String, style: CSSStyleDeclaration, clearFn: () -> Unit): StylePropertyMap { |
|
|
|
external class CSSMathMin(vararg args: CSSNumberish) : CSSMathValue { |
|
|
|
val styleMap = this.asDynamic()[jsFieldName] |
|
|
|
val values: CSSNumericArray |
|
|
|
if (styleMap == undefined) { |
|
|
|
|
|
|
|
val newStyleMap = StylePropertyMapKT(style, clearFn).also { |
|
|
|
|
|
|
|
this.asDynamic()[jsFieldName] = it |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
this.asDynamic()[jsFieldName] = newStyleMap |
|
|
|
|
|
|
|
return newStyleMap |
|
|
|
external class CSSMathMax(vararg args: CSSNumberish) : CSSMathValue { |
|
|
|
|
|
|
|
val values: CSSNumericArray |
|
|
|
} |
|
|
|
} |
|
|
|
return styleMap.unsafeCast<StylePropertyMap>() |
|
|
|
|
|
|
|
|
|
|
|
// TODO(yavanosta) : conflict with base class properties |
|
|
|
|
|
|
|
// Since there is no support for this class in any browser, it's better |
|
|
|
|
|
|
|
// wait for the implementation. |
|
|
|
|
|
|
|
// declare class CSSMathClamp extends CSSMathValue { |
|
|
|
|
|
|
|
// constructor(min: CSSNumberish, val: CSSNumberish, max: CSSNumberish) |
|
|
|
|
|
|
|
// readonly min: CSSNumericValue |
|
|
|
|
|
|
|
// readonly val: CSSNumericValue |
|
|
|
|
|
|
|
// readonly max: CSSNumericValue |
|
|
|
|
|
|
|
// } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSNumericArray { |
|
|
|
|
|
|
|
// TODO: [Symbol.iterator]() : IterableIterator<CSSNumericValue> |
|
|
|
|
|
|
|
fun forEach(handler: (CSSNumericValue) -> Unit) |
|
|
|
|
|
|
|
val length: Int |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// readonly [index: number]: CSSNumericValue |
|
|
|
|
|
|
|
operator fun get(index: Int): CSSNumericValue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSTransformValue(transforms: Array<CSSTransformComponent>) : CSSStyleValue { |
|
|
|
|
|
|
|
// [Symbol.iterator]() : IterableIterator<CSSTransformComponent> |
|
|
|
|
|
|
|
fun forEach(handler: (CSSTransformComponent) -> Unit) |
|
|
|
|
|
|
|
val length: Int |
|
|
|
|
|
|
|
|
|
|
|
inline val StyleSheet.cssRules |
|
|
|
// [index: number]: CSSTransformComponent |
|
|
|
get() = this.asDynamic().cssRules.unsafeCast<CSSRuleList>() |
|
|
|
operator fun get(index: Int): CSSTransformComponent |
|
|
|
|
|
|
|
operator fun set(index: Int, value: CSSTransformComponent) |
|
|
|
|
|
|
|
val is2D: Boolean |
|
|
|
|
|
|
|
fun toMatrix(): DOMMatrix |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
open external class CSSTransformComponent { |
|
|
|
|
|
|
|
val is2D: Boolean |
|
|
|
|
|
|
|
fun toMatrix(): DOMMatrix |
|
|
|
|
|
|
|
// toString() : string |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
inline fun StyleSheet.deleteRule(index: Int) { |
|
|
|
external class CSSTranslate( |
|
|
|
this.asDynamic().deleteRule(index) |
|
|
|
x: CSSNumericValue, |
|
|
|
|
|
|
|
y: CSSNumericValue, |
|
|
|
|
|
|
|
z: CSSNumericValue? = definedExternally |
|
|
|
|
|
|
|
) : CSSTransformComponent { |
|
|
|
|
|
|
|
val x: CSSNumericValue |
|
|
|
|
|
|
|
val y: CSSNumericValue |
|
|
|
|
|
|
|
val z: CSSNumericValue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun StyleSheet.insertRule(cssRule: String, index: Int? = null): Int { |
|
|
|
external class CSSRotate(angle: CSSNumericValue) : CSSTransformComponent { |
|
|
|
return if (index != null) { |
|
|
|
constructor(x: CSSNumberish, y: CSSNumberish, z: CSSNumberish, angle: CSSNumericValue) |
|
|
|
this.asDynamic().insertRule(cssRule, index).unsafeCast<Int>() |
|
|
|
|
|
|
|
} else { |
|
|
|
val x: CSSNumberish |
|
|
|
this.asDynamic().insertRule(cssRule).unsafeCast<Int>() |
|
|
|
val y: CSSNumberish |
|
|
|
|
|
|
|
val z: CSSNumberish |
|
|
|
|
|
|
|
val angle: CSSNumericValue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSScale( |
|
|
|
|
|
|
|
x: CSSNumberish, |
|
|
|
|
|
|
|
y: CSSNumberish, |
|
|
|
|
|
|
|
z: CSSNumberish? = definedExternally |
|
|
|
|
|
|
|
) : CSSTransformComponent { |
|
|
|
|
|
|
|
val x: CSSNumberish |
|
|
|
|
|
|
|
val y: CSSNumberish |
|
|
|
|
|
|
|
val z: CSSNumberish |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSSkew(ax: CSSNumericValue, ay: CSSNumericValue) : CSSTransformComponent { |
|
|
|
|
|
|
|
val ax: CSSNumericValue |
|
|
|
|
|
|
|
val ay: CSSNumericValue |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
inline operator fun CSSRuleList.get(index: Int): CSSRule { |
|
|
|
external class CSSSkewX(ax: CSSNumericValue) : CSSTransformComponent { |
|
|
|
return this.asDynamic()[index].unsafeCast<CSSRule>() |
|
|
|
val ax: CSSNumericValue |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSSkewY(ay: CSSNumericValue) : CSSTransformComponent { |
|
|
|
|
|
|
|
val ay: CSSNumericValue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Note that skew(x,y) is *not* the same as skewX(x) skewY(y), |
|
|
|
|
|
|
|
thus the separate interfaces for all three. */ |
|
|
|
|
|
|
|
|
|
|
|
external interface StylePropertyMapReadOnly { |
|
|
|
external class CSSPerspective(length: CSSNumericValue) : CSSTransformComponent { |
|
|
|
|
|
|
|
val length: CSSNumericValue |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSMatrixComponent( |
|
|
|
|
|
|
|
matrix: DOMMatrixReadOnly, |
|
|
|
|
|
|
|
options: CSSMatrixComponentOptions? = definedExternally |
|
|
|
|
|
|
|
) : CSSTransformComponent { |
|
|
|
|
|
|
|
val matrix: DOMMatrix |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external interface CSSMatrixComponentOptions { |
|
|
|
|
|
|
|
val is2D: Boolean |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSSImageValue : CSSStyleValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
open external class StylePropertyMapReadOnly { |
|
|
|
|
|
|
|
// TODO: [Symbol.iterator]() : IterableIterator<[string, CSSStyleValue[]]> |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun get(property: String): CSSStyleValue? // CSSStyleValue | undefined |
|
|
|
|
|
|
|
fun getAll(property: String): Array<CSSStyleValue> |
|
|
|
fun has(property: String): Boolean |
|
|
|
fun has(property: String): Boolean |
|
|
|
|
|
|
|
val size: Number |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun StylePropertyMapReadOnly.forEach(handler: (String, Array<CSSStyleValue>) -> Unit) { |
|
|
|
fun StylePropertyMapReadOnly.forEach(handler: (String, Array<CSSStyleValue>) -> Unit) { |
|
|
@ -205,24 +353,82 @@ fun StylePropertyMapReadOnly.forEach(handler: (String, Array<CSSStyleValue>) -> |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
external interface StylePropertyMap : StylePropertyMapReadOnly { |
|
|
|
// CSSStyleValue | string |
|
|
|
fun set(property: String, value: StylePropertyValue) |
|
|
|
interface StylePropertyValue { |
|
|
|
fun append(property: String, value: StylePropertyValue) |
|
|
|
companion object { |
|
|
|
fun delete(property: String) |
|
|
|
operator fun invoke(value: String) = value.unsafeCast<StylePropertyValue>() |
|
|
|
fun clear() |
|
|
|
operator fun invoke(value: Number) = value.unsafeCast<StylePropertyValue>() |
|
|
|
|
|
|
|
operator fun invoke(value: CSSStyleValue) = value.unsafeCast<StylePropertyValue>() |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@JsName("CSS") |
|
|
|
fun StylePropertyValue.asString() = this.asDynamic() as? String |
|
|
|
external val CSSJS: CSSTypedOM |
|
|
|
fun StylePropertyValue.asNumber() = this.asDynamic() as? Number |
|
|
|
|
|
|
|
fun StylePropertyValue.asCSSStyleValue(): CSSStyleValue? = this.asDynamic() as? CSSStyleValueJS |
|
|
|
const val useNativeCSSTypedOM = true |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
actual val CSS: CSSTypedOM = if (useNativeCSSTypedOM && CSSJS != undefined && CSSJS.asDynamic().px != undefined) { |
|
|
|
external class StylePropertyMap : StylePropertyMapReadOnly { |
|
|
|
CSSJS |
|
|
|
fun set(property: String, vararg values: StylePropertyValue) |
|
|
|
} else CSSKT |
|
|
|
fun append(property: String, vararg values: StylePropertyValue) |
|
|
|
|
|
|
|
fun delete(property: String) |
|
|
|
|
|
|
|
fun clear() |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
val CSSStyleRule.styleMap: StylePropertyMap |
|
|
|
inline fun Element.computedStyleMap(): StylePropertyMapReadOnly = |
|
|
|
get() = polyfillStylePropertyMap(if (useNativeCSSTypedOM) "styleMap" else "styleMapKT", this.style) { cssText = "" } |
|
|
|
this.asDynamic().computedStyleMap().unsafeCast<StylePropertyMapReadOnly>() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
external class CSS { |
|
|
|
|
|
|
|
companion object { |
|
|
|
|
|
|
|
fun number(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun percent(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// <length> |
|
|
|
|
|
|
|
fun em(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun ex(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun ch(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun ic(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun rem(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun lh(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun rlh(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun vw(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun vh(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun vi(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun vb(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun vmin(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun vmax(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun cm(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun mm(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun Q(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// function _in(value: Number) : CSSUnitValue |
|
|
|
|
|
|
|
// export |
|
|
|
|
|
|
|
// { _in as in } |
|
|
|
|
|
|
|
fun pt(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun pc(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun px(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// <angle> |
|
|
|
|
|
|
|
fun deg(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun grad(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun rad(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun turn(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// <time> |
|
|
|
|
|
|
|
fun s(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun ms(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// <frequency> |
|
|
|
|
|
|
|
fun Hz(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun kHz(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// <resolution> |
|
|
|
|
|
|
|
fun dpi(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun dpcm(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
fun dppx(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// <flex> |
|
|
|
|
|
|
|
fun fr(value: Number): CSSUnitValue |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
val HTMLElement.attributeStyleMap: StylePropertyMap |
|
|
|
@Suppress("unused") |
|
|
|
get() = polyfillStylePropertyMap(if (useNativeCSSTypedOM) "attributeStyleMap" else "attributeStyleMapKT", this.style) { removeAttribute("style") } |
|
|
|
val cssTypedOMPolyfill = CSSTypedOMPolyfill.default(window) |
|
|
|