dothtml 6.0.0-beta.16 → 6.0.0-beta.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build_module/constants.d.ts +1 -0
- package/build_module/constants.js +2 -0
- package/build_module/constants.js.map +1 -0
- package/build_module/css/css-props.d.ts +7 -0
- package/build_module/css/css-props.js +22 -0
- package/build_module/css/css-props.js.map +1 -0
- package/build_module/css/css.d.ts +0 -0
- package/build_module/css/css.js +1 -0
- package/build_module/css/css.js.map +1 -0
- package/build_module/css/format-css-type.d.ts +4 -0
- package/build_module/css/format-css-type.js +38 -0
- package/build_module/css/format-css-type.js.map +1 -0
- package/build_module/decoration/component.d.ts +13 -0
- package/build_module/decoration/component.js +44 -0
- package/build_module/decoration/component.js.map +1 -0
- package/build_module/decoration/use-styles.d.ts +13 -0
- package/build_module/decoration/use-styles.js +19 -0
- package/build_module/decoration/use-styles.js.map +1 -0
- package/build_module/dot.d.ts +3 -0
- package/build_module/dot.js +377 -0
- package/build_module/dot.js.map +1 -0
- package/build_module/helpers/render-css.d.ts +2 -0
- package/build_module/helpers/render-css.js +19 -0
- package/build_module/helpers/render-css.js.map +1 -0
- package/build_module/helpers.d.ts +3 -0
- package/build_module/helpers.js +50 -0
- package/build_module/helpers.js.map +1 -0
- package/build_module/index.d.ts +7 -0
- package/build_module/index.js +5 -0
- package/build_module/index.js.map +1 -0
- package/build_module/reactive.d.ts +46 -0
- package/build_module/reactive.js +150 -0
- package/build_module/reactive.js.map +1 -0
- package/build_module/v-dom-node.d.ts +0 -0
- package/build_module/v-dom-node.js +1 -0
- package/build_module/v-dom-node.js.map +1 -0
- package/build_module/v-meta-nodes/attribute-v-node.d.ts +12 -0
- package/build_module/v-meta-nodes/attribute-v-node.js +48 -0
- package/build_module/v-meta-nodes/attribute-v-node.js.map +1 -0
- package/build_module/v-meta-nodes/style-v-node.d.ts +16 -0
- package/build_module/v-meta-nodes/style-v-node.js +86 -0
- package/build_module/v-meta-nodes/style-v-node.js.map +1 -0
- package/build_module/v-meta-nodes/v-meta-node.d.ts +5 -0
- package/build_module/v-meta-nodes/v-meta-node.js +3 -0
- package/build_module/v-meta-nodes/v-meta-node.js.map +1 -0
- package/build_module/v-style-nodes/base-v-style.d.ts +14 -0
- package/build_module/v-style-nodes/base-v-style.js +116 -0
- package/build_module/v-style-nodes/base-v-style.js.map +1 -0
- package/build_module/v-style-nodes/css-function-builder-v-style.d.ts +20 -0
- package/build_module/v-style-nodes/css-function-builder-v-style.js +71 -0
- package/build_module/v-style-nodes/css-function-builder-v-style.js.map +1 -0
- package/build_module/v-style-nodes/filter-v-style.d.ts +13 -0
- package/build_module/v-style-nodes/filter-v-style.js +35 -0
- package/build_module/v-style-nodes/filter-v-style.js.map +1 -0
- package/build_module/v-style-nodes/transform-v-style.d.ts +28 -0
- package/build_module/v-style-nodes/transform-v-style.js +76 -0
- package/build_module/v-style-nodes/transform-v-style.js.map +1 -0
- package/build_module/v-style-nodes/v-style.d.ts +6 -0
- package/build_module/v-style-nodes/v-style.js +6 -0
- package/build_module/v-style-nodes/v-style.js.map +1 -0
- package/build_module/vdom-nodes/collection-vdom.d.ts +24 -0
- package/build_module/vdom-nodes/collection-vdom.js +154 -0
- package/build_module/vdom-nodes/collection-vdom.js.map +1 -0
- package/build_module/vdom-nodes/component-vdom.d.ts +14 -0
- package/build_module/vdom-nodes/component-vdom.js +61 -0
- package/build_module/vdom-nodes/component-vdom.js.map +1 -0
- package/build_module/vdom-nodes/conditional-vdom.d.ts +14 -0
- package/build_module/vdom-nodes/conditional-vdom.js +97 -0
- package/build_module/vdom-nodes/conditional-vdom.js.map +1 -0
- package/build_module/vdom-nodes/container-vdom.d.ts +25 -0
- package/build_module/vdom-nodes/container-vdom.js +97 -0
- package/build_module/vdom-nodes/container-vdom.js.map +1 -0
- package/build_module/vdom-nodes/element-vdom.d.ts +21 -0
- package/build_module/vdom-nodes/element-vdom.js +127 -0
- package/build_module/vdom-nodes/element-vdom.js.map +1 -0
- package/build_module/vdom-nodes/html-vdom.d.ts +13 -0
- package/build_module/vdom-nodes/html-vdom.js +53 -0
- package/build_module/vdom-nodes/html-vdom.js.map +1 -0
- package/build_module/vdom-nodes/text-vdom.d.ts +11 -0
- package/build_module/vdom-nodes/text-vdom.js +37 -0
- package/build_module/vdom-nodes/text-vdom.js.map +1 -0
- package/build_module/vdom-nodes/vdom.d.ts +7 -0
- package/build_module/vdom-nodes/vdom.js +28 -0
- package/build_module/vdom-nodes/vdom.js.map +1 -0
- package/package.json +4 -3
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { DOT_VDOM_PROP_NAME } from "./constants";
|
|
2
|
+
export function removeNodesBetween(start, end) {
|
|
3
|
+
if (start.parentNode !== end.parentNode) {
|
|
4
|
+
throw new Error("Start and end nodes must have the same parent.");
|
|
5
|
+
}
|
|
6
|
+
let current = start.nextSibling;
|
|
7
|
+
while (current && current !== end) {
|
|
8
|
+
const next = current.nextSibling;
|
|
9
|
+
if (current[DOT_VDOM_PROP_NAME]) {
|
|
10
|
+
current[DOT_VDOM_PROP_NAME]._unrender();
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
current.parentNode?.removeChild(current);
|
|
14
|
+
}
|
|
15
|
+
current = next;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export function deepEqual(obj1, obj2, visited = new Map()) {
|
|
19
|
+
if (obj1 === obj2) {
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
if (obj1 == null || obj2 == null || typeof obj1 !== 'object' || typeof obj2 !== 'object') {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
if (visited.has(obj1)) {
|
|
26
|
+
return visited.get(obj1) === obj2;
|
|
27
|
+
}
|
|
28
|
+
visited.set(obj1, obj2);
|
|
29
|
+
if (Array.isArray(obj1) && Array.isArray(obj2)) {
|
|
30
|
+
if (obj1.length !== obj2.length) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
for (const prop in obj1) {
|
|
35
|
+
if (!obj2.hasOwnProperty(prop)) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
if (!deepEqual(obj1[prop], obj2[prop], visited)) {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
for (const prop in obj2) {
|
|
43
|
+
if (!obj1.hasOwnProperty(prop)) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
export var floatRegex = new RegExp("[-+]?[0-9]*\\.?[0-9]+(?:[eE][-+]?[0-9]+)?", "g");
|
|
50
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD,MAAM,UAAU,kBAAkB,CAAC,KAAW,EAAE,GAAS;IAExD,IAAI,KAAK,CAAC,UAAU,KAAK,GAAG,CAAC,UAAU,EAAE;QACxC,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;KAClE;IAED,IAAI,OAAO,GAAc,KAAK,CAAC,WAAW,CAAC;IAG3C,OAAO,OAAO,IAAI,OAAO,KAAK,GAAG,EAAE;QAClC,MAAM,IAAI,GAAc,OAAO,CAAC,WAAW,CAAC;QAG5C,IAAG,OAAO,CAAC,kBAAkB,CAAC,EAAC;YAC9B,OAAO,CAAC,kBAAkB,CAAC,CAAC,SAAS,EAAE,CAAC;SACxC;aACG;YACH,OAAO,CAAC,UAAU,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;SACzC;QACD,OAAO,GAAG,IAAI,CAAC;KACf;AACF,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,IAAS,EAAE,IAAS,EAAE,OAAO,GAAG,IAAI,GAAG,EAAE;IAC/D,IAAI,IAAI,KAAK,IAAI,EAAE;QACf,OAAO,IAAI,CAAC;KACf;IAED,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QACtF,OAAO,KAAK,CAAC;KAChB;IAGD,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACnB,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC;KACrC;IACD,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAExB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QAC5C,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE;YAC7B,OAAO,KAAK,CAAC;SAChB;KACJ;IAED,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE;QACrB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;YAC5B,OAAO,KAAK,CAAC;SAChB;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,EAAE;YAC7C,OAAO,KAAK,CAAC;SAChB;KACJ;IAED,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE;QACrB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;YAC5B,OAAO,KAAK,CAAC;SAChB;KACJ;IAED,OAAO,IAAI,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,IAAI,UAAU,GAAG,IAAI,MAAM,CAAC,2CAA2C,EAAE,GAAG,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAIA,OAAO,GAAG,MAAM,OAAO,CAAC;AACxB,GAAG,CAAC,OAAO,GAAG,OAAO,CAAC;AAUtB,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC;AAEjB,OAAO,EAAE,GAAG,EAAE,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { IReactive } from "dothtml-interfaces";
|
|
2
|
+
import ElementVdom from "./vdom-nodes/element-vdom";
|
|
3
|
+
import { TextVdom } from "./vdom-nodes/text-vdom";
|
|
4
|
+
import { HtmlVdom } from "./vdom-nodes/html-vdom";
|
|
5
|
+
import { ConditionalVdom } from "./vdom-nodes/conditional-vdom";
|
|
6
|
+
import CollectionVdom from "./vdom-nodes/collection-vdom";
|
|
7
|
+
import VStyle from "./v-style-nodes/v-style";
|
|
8
|
+
import VMetaNode from "./v-meta-nodes/v-meta-node";
|
|
9
|
+
export default class Reactive<Ti = any, To = Ti> implements IReactive<Ti, To> {
|
|
10
|
+
_value: Ti;
|
|
11
|
+
private _cachedLastValue;
|
|
12
|
+
key: string;
|
|
13
|
+
observingTextNodes: Record<number, TextVdom>;
|
|
14
|
+
observingHtmlNodes: Record<number, HtmlVdom>;
|
|
15
|
+
observingAttributes: Record<number, {
|
|
16
|
+
element: ElementVdom;
|
|
17
|
+
attribute: string;
|
|
18
|
+
}>;
|
|
19
|
+
observingAttributeCollectionss: Record<number, VMetaNode>;
|
|
20
|
+
observingCollections: Record<number, {
|
|
21
|
+
collection: CollectionVdom;
|
|
22
|
+
key?: string;
|
|
23
|
+
}>;
|
|
24
|
+
observingConditionals: Record<number, ConditionalVdom>;
|
|
25
|
+
observingStyles: Record<number, {
|
|
26
|
+
prop: string;
|
|
27
|
+
vStyle: VStyle;
|
|
28
|
+
}>;
|
|
29
|
+
observingCallbacks: Record<number, (value: To) => void>;
|
|
30
|
+
constructor();
|
|
31
|
+
getValue(): To;
|
|
32
|
+
setValue(v: Ti): void;
|
|
33
|
+
private updater;
|
|
34
|
+
transform?: (input: Ti) => To;
|
|
35
|
+
nextId: number;
|
|
36
|
+
subscribeText(node: TextVdom): number;
|
|
37
|
+
subscribeHtml(node: HtmlVdom): number;
|
|
38
|
+
subscribeAttr(node: ElementVdom, attributeName: string): number;
|
|
39
|
+
subscribeAttrCollection(collection: VMetaNode): number;
|
|
40
|
+
subscribeStyle(vStyle: VStyle, propName: string): number;
|
|
41
|
+
subscribeCollection(node: CollectionVdom): number;
|
|
42
|
+
subscribeCond(node: ConditionalVdom): number;
|
|
43
|
+
subscribeCallback(callback: (value: To) => void): number;
|
|
44
|
+
detachBinding(id: number): void;
|
|
45
|
+
updateObservers(): void;
|
|
46
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
const TEXT_OFFSET = 0;
|
|
2
|
+
const HTML_OFFSET = 1;
|
|
3
|
+
const ATTR_OFFSET = 2;
|
|
4
|
+
const ATTR_COLLECTION_OFFSET = 3;
|
|
5
|
+
const STYLE_OFFSET = 4;
|
|
6
|
+
const COND_OFFSET = 5;
|
|
7
|
+
const ARRAY_OFFSET = 6;
|
|
8
|
+
const CB_OFFSET = 7;
|
|
9
|
+
const CATEGORIES = CB_OFFSET + 1;
|
|
10
|
+
export default class Reactive {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.observingTextNodes = {};
|
|
13
|
+
this.observingHtmlNodes = {};
|
|
14
|
+
this.observingAttributes = {};
|
|
15
|
+
this.observingAttributeCollectionss = {};
|
|
16
|
+
this.observingCollections = {};
|
|
17
|
+
this.observingConditionals = {};
|
|
18
|
+
this.observingStyles = {};
|
|
19
|
+
this.observingCallbacks = {};
|
|
20
|
+
this.nextId = 1;
|
|
21
|
+
}
|
|
22
|
+
getValue() {
|
|
23
|
+
return this.transform ? this.transform(this._value) : this._value;
|
|
24
|
+
}
|
|
25
|
+
setValue(v) {
|
|
26
|
+
this._value = v;
|
|
27
|
+
let newValue = this.getValue();
|
|
28
|
+
if (this._cachedLastValue != newValue) {
|
|
29
|
+
this._cachedLastValue = newValue;
|
|
30
|
+
this.updater(newValue);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
updater(value) {
|
|
34
|
+
for (let o in this.observingTextNodes) {
|
|
35
|
+
let n = this.observingTextNodes[o];
|
|
36
|
+
n.textNode.textContent = value ?? "";
|
|
37
|
+
}
|
|
38
|
+
for (let o in this.observingHtmlNodes) {
|
|
39
|
+
let n = this.observingHtmlNodes[o];
|
|
40
|
+
n.updateHtml(value);
|
|
41
|
+
}
|
|
42
|
+
for (let o in this.observingAttributes) {
|
|
43
|
+
let a = this.observingAttributes[o];
|
|
44
|
+
a.element.setAttr(a.attribute, this);
|
|
45
|
+
}
|
|
46
|
+
for (let o in this.observingAttributeCollectionss) {
|
|
47
|
+
let a = this.observingAttributeCollectionss[o];
|
|
48
|
+
a.update();
|
|
49
|
+
}
|
|
50
|
+
for (let o in this.observingStyles) {
|
|
51
|
+
let s = this.observingStyles[o];
|
|
52
|
+
s.vStyle.updateProp(s.prop, value);
|
|
53
|
+
}
|
|
54
|
+
for (let o in this.observingCollections) {
|
|
55
|
+
let c = this.observingCollections[o];
|
|
56
|
+
c.collection.updateList();
|
|
57
|
+
}
|
|
58
|
+
for (let o in this.observingConditionals) {
|
|
59
|
+
let a = this.observingConditionals[o];
|
|
60
|
+
a.updateConditions();
|
|
61
|
+
}
|
|
62
|
+
for (let o in this.observingCallbacks) {
|
|
63
|
+
let cb = this.observingCallbacks[o];
|
|
64
|
+
cb(value);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
subscribeText(node) {
|
|
68
|
+
let id = TEXT_OFFSET + CATEGORIES * this.nextId++;
|
|
69
|
+
this.observingTextNodes[id] = node;
|
|
70
|
+
return id;
|
|
71
|
+
}
|
|
72
|
+
subscribeHtml(node) {
|
|
73
|
+
let id = HTML_OFFSET + CATEGORIES * this.nextId++;
|
|
74
|
+
this.observingHtmlNodes[id] = node;
|
|
75
|
+
return id;
|
|
76
|
+
}
|
|
77
|
+
subscribeAttr(node, attributeName) {
|
|
78
|
+
let id = ATTR_OFFSET + CATEGORIES * this.nextId++;
|
|
79
|
+
this.observingAttributes[id] = { element: node, attribute: attributeName };
|
|
80
|
+
return id;
|
|
81
|
+
}
|
|
82
|
+
subscribeAttrCollection(collection) {
|
|
83
|
+
let id = ATTR_COLLECTION_OFFSET + CATEGORIES * this.nextId++;
|
|
84
|
+
this.observingAttributeCollectionss[id] = collection;
|
|
85
|
+
return id;
|
|
86
|
+
}
|
|
87
|
+
subscribeStyle(vStyle, propName) {
|
|
88
|
+
let id = STYLE_OFFSET + CATEGORIES * this.nextId++;
|
|
89
|
+
this.observingStyles[id] = { prop: propName, vStyle: vStyle };
|
|
90
|
+
return id;
|
|
91
|
+
}
|
|
92
|
+
subscribeCollection(node) {
|
|
93
|
+
let id = ARRAY_OFFSET + CATEGORIES * this.nextId++;
|
|
94
|
+
this.observingCollections[id] = { collection: node, key: null };
|
|
95
|
+
return id;
|
|
96
|
+
}
|
|
97
|
+
subscribeCond(node) {
|
|
98
|
+
let id = COND_OFFSET + CATEGORIES * this.nextId++;
|
|
99
|
+
this.observingConditionals[id] = node;
|
|
100
|
+
return id;
|
|
101
|
+
}
|
|
102
|
+
subscribeCallback(callback) {
|
|
103
|
+
let id = CB_OFFSET + CATEGORIES * this.nextId++;
|
|
104
|
+
this.observingCallbacks[id] = callback;
|
|
105
|
+
return id;
|
|
106
|
+
}
|
|
107
|
+
detachBinding(id) {
|
|
108
|
+
let category = id % CATEGORIES;
|
|
109
|
+
switch (category) {
|
|
110
|
+
case TEXT_OFFSET: {
|
|
111
|
+
delete this.observingTextNodes[id];
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
case ATTR_OFFSET: {
|
|
115
|
+
delete this.observingAttributes[id];
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
case ATTR_COLLECTION_OFFSET: {
|
|
119
|
+
delete this.observingAttributeCollectionss[id];
|
|
120
|
+
break;
|
|
121
|
+
}
|
|
122
|
+
case STYLE_OFFSET: {
|
|
123
|
+
delete this.observingStyles[id];
|
|
124
|
+
break;
|
|
125
|
+
}
|
|
126
|
+
case HTML_OFFSET: {
|
|
127
|
+
delete this.observingHtmlNodes[id];
|
|
128
|
+
break;
|
|
129
|
+
}
|
|
130
|
+
case ARRAY_OFFSET: {
|
|
131
|
+
delete this.observingCollections[id];
|
|
132
|
+
break;
|
|
133
|
+
}
|
|
134
|
+
case COND_OFFSET: {
|
|
135
|
+
delete this.observingConditionals[id];
|
|
136
|
+
break;
|
|
137
|
+
}
|
|
138
|
+
case CB_OFFSET: {
|
|
139
|
+
delete this.observingCallbacks[id];
|
|
140
|
+
break;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
updateObservers() {
|
|
145
|
+
let updatedValue = this.getValue();
|
|
146
|
+
this._cachedLastValue = updatedValue;
|
|
147
|
+
this.updater(updatedValue);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=reactive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reactive.js","sourceRoot":"","sources":["../src/reactive.ts"],"names":[],"mappings":"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"}
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=v-dom-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"v-dom-node.js","sourceRoot":"","sources":["../src/v-dom-node.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import Reactive from "../reactive";
|
|
2
|
+
import VMetaNode from "./v-meta-node";
|
|
3
|
+
export default class AttributeVNode extends VMetaNode {
|
|
4
|
+
attr: string;
|
|
5
|
+
value: Record<string, string | Reactive>;
|
|
6
|
+
target: HTMLElement;
|
|
7
|
+
observables: Record<number, Reactive>;
|
|
8
|
+
constructor(attrName: any, attrValue: any);
|
|
9
|
+
render(target: HTMLElement): void;
|
|
10
|
+
update(): void;
|
|
11
|
+
unrender(): void;
|
|
12
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import Reactive from "../reactive";
|
|
2
|
+
import VMetaNode from "./v-meta-node";
|
|
3
|
+
export default class AttributeVNode extends VMetaNode {
|
|
4
|
+
constructor(attrName, attrValue) {
|
|
5
|
+
super();
|
|
6
|
+
this.observables = {};
|
|
7
|
+
this.attr = attrName;
|
|
8
|
+
this.value = attrValue;
|
|
9
|
+
}
|
|
10
|
+
render(target) {
|
|
11
|
+
this.target = target;
|
|
12
|
+
{
|
|
13
|
+
for (let k in this.value) {
|
|
14
|
+
let v = this.value[k];
|
|
15
|
+
if (v && v instanceof Reactive) {
|
|
16
|
+
let id = v.subscribeAttrCollection(this);
|
|
17
|
+
this.observables[id] = v;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
{
|
|
22
|
+
this.update();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
update() {
|
|
26
|
+
if (!this.target)
|
|
27
|
+
return;
|
|
28
|
+
let tokens = [];
|
|
29
|
+
for (let k in this.value) {
|
|
30
|
+
let v = this.value[k];
|
|
31
|
+
if (v) {
|
|
32
|
+
if (!(v instanceof Reactive) || v.getValue()) {
|
|
33
|
+
tokens.push(k);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
this.target.setAttribute(this.attr, tokens.join(" "));
|
|
38
|
+
}
|
|
39
|
+
unrender() {
|
|
40
|
+
this.target = null;
|
|
41
|
+
for (let o in this.observables) {
|
|
42
|
+
let v = this.observables[o];
|
|
43
|
+
v.detachBinding(Number(o));
|
|
44
|
+
}
|
|
45
|
+
this.observables = {};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=attribute-v-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attribute-v-node.js","sourceRoot":"","sources":["../../src/v-meta-nodes/attribute-v-node.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,aAAa,CAAC;AACnC,OAAO,SAAS,MAAM,eAAe,CAAC;AAMtC,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,SAAS;IAQpD,YAAY,QAAQ,EAAE,SAAS;QAC9B,KAAK,EAAE,CAAC;QAHT,gBAAW,GAA6B,EAAE,CAAC;QAI1C,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACxB,CAAC;IAED,MAAM,CAAC,MAAmB;QACzB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QAErB;YACC,KAAI,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,EAAC;gBACvB,IAAI,CAAC,GAAI,IAAI,CAAC,KAAa,CAAC,CAAC,CAAC,CAAC;gBAC/B,IAAG,CAAC,IAAI,CAAC,YAAY,QAAQ,EAAC;oBAC7B,IAAI,EAAE,GAAG,CAAC,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;oBACzC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;iBACzB;aACD;SACD;QAED;YACC,IAAI,CAAC,MAAM,EAAE,CAAC;SACd;IACF,CAAC;IAED,MAAM;QACL,IAAG,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QAExB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAI,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,EAAC;YACvB,IAAI,CAAC,GAAI,IAAI,CAAC,KAAa,CAAC,CAAC,CAAC,CAAC;YAC/B,IAAG,CAAC,EAAC;gBACJ,IAAG,CAAC,CAAC,CAAC,YAAY,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAC;oBAC3C,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACf;aACD;SACD;QACD,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QAEnB,KAAI,IAAI,CAAC,IAAI,IAAI,CAAC,WAAW,EAAC;YAC7B,IAAI,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YAC5B,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;SAC3B;QAED,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACvB,CAAC;CACD"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { IDotCss } from "dothtml-interfaces";
|
|
2
|
+
import Reactive from "../reactive";
|
|
3
|
+
import VMetaNode from "./v-meta-node";
|
|
4
|
+
export default class StyleVNode extends VMetaNode {
|
|
5
|
+
target: NodeListOf<Element> | HTMLElement | string;
|
|
6
|
+
document: Document;
|
|
7
|
+
shadowRoot: ShadowRoot;
|
|
8
|
+
styleValue: IDotCss;
|
|
9
|
+
observables: Array<Reactive>;
|
|
10
|
+
observableIds: Array<number>;
|
|
11
|
+
constructor(styleValue: IDotCss);
|
|
12
|
+
render(target: HTMLElement | string, document?: Document, shadowRoot?: ShadowRoot): void;
|
|
13
|
+
update(): void;
|
|
14
|
+
unrender(): void;
|
|
15
|
+
toString(): void;
|
|
16
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import cssProps from "../css/css-props";
|
|
2
|
+
import Reactive from "../reactive";
|
|
3
|
+
import VMetaNode from "./v-meta-node";
|
|
4
|
+
export default class StyleVNode extends VMetaNode {
|
|
5
|
+
constructor(styleValue) {
|
|
6
|
+
super();
|
|
7
|
+
this.observables = [];
|
|
8
|
+
this.observableIds = [];
|
|
9
|
+
this.styleValue = styleValue;
|
|
10
|
+
{
|
|
11
|
+
for (let prop in this.styleValue) {
|
|
12
|
+
let value = this.styleValue[prop];
|
|
13
|
+
if (value instanceof Reactive) {
|
|
14
|
+
this.observables.push(value);
|
|
15
|
+
}
|
|
16
|
+
else if (typeof value === "object") {
|
|
17
|
+
for (let k in value) {
|
|
18
|
+
let v = value[k];
|
|
19
|
+
if (v instanceof Reactive) {
|
|
20
|
+
this.observables.push(v);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
render(target, document = window.document, shadowRoot) {
|
|
28
|
+
this.target = target;
|
|
29
|
+
this.document = document;
|
|
30
|
+
this.shadowRoot = shadowRoot;
|
|
31
|
+
{
|
|
32
|
+
for (let i in this.observables) {
|
|
33
|
+
let observable = this.observables[i];
|
|
34
|
+
let id = observable.subscribeAttrCollection(this);
|
|
35
|
+
this.observableIds.push(id);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
this.update();
|
|
39
|
+
}
|
|
40
|
+
update() {
|
|
41
|
+
let allStylesToApply = [];
|
|
42
|
+
for (let prop in this.styleValue) {
|
|
43
|
+
let cssValue;
|
|
44
|
+
{
|
|
45
|
+
let value = this.styleValue[prop];
|
|
46
|
+
if (value instanceof Reactive) {
|
|
47
|
+
cssValue = value.getValue();
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
cssValue = `${value}`;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
let cssType, cssProp;
|
|
54
|
+
{
|
|
55
|
+
let registeredProp = cssProps[prop];
|
|
56
|
+
if (registeredProp) {
|
|
57
|
+
cssType = cssProps[prop].type;
|
|
58
|
+
cssProp = cssProps[prop].cssName;
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
cssType = "custom";
|
|
62
|
+
cssProp = prop;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
allStylesToApply.push({ cssProp, cssValue });
|
|
66
|
+
}
|
|
67
|
+
if (this.target instanceof HTMLElement) {
|
|
68
|
+
for (let i in allStylesToApply) {
|
|
69
|
+
let assignment = allStylesToApply[i];
|
|
70
|
+
this.target.style[assignment.cssProp] = assignment.cssValue;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
else if (typeof this.target === "string") {
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
unrender() {
|
|
77
|
+
for (let i in this.observableIds) {
|
|
78
|
+
let id = this.observableIds[i];
|
|
79
|
+
let observable = this.observables[i];
|
|
80
|
+
observable.detachBinding(id);
|
|
81
|
+
}
|
|
82
|
+
this.observables.length = 0;
|
|
83
|
+
}
|
|
84
|
+
toString() { }
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=style-v-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"style-v-node.js","sourceRoot":"","sources":["../../src/v-meta-nodes/style-v-node.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"v-meta-node.js","sourceRoot":"","sources":["../../src/v-meta-nodes/v-meta-node.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,OAAgB,SAAS;CAItC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import VStyle from "./v-style";
|
|
2
|
+
export default class BaseVStyle extends VStyle {
|
|
3
|
+
private readonly _isBase;
|
|
4
|
+
private props;
|
|
5
|
+
private subscriptions;
|
|
6
|
+
private renderedSubBuilders;
|
|
7
|
+
private selector;
|
|
8
|
+
private target;
|
|
9
|
+
_render(target: HTMLElement): void;
|
|
10
|
+
_unrender(): void;
|
|
11
|
+
renderAndSetPropValue(prop: any, value: any): void;
|
|
12
|
+
updateProp(prop: string, value: string): void;
|
|
13
|
+
setProp(propName: any, value: any): any;
|
|
14
|
+
}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import Reactive from "../reactive";
|
|
2
|
+
import FilterVStyle from "./filter-v-style";
|
|
3
|
+
import TransformVStyle from "./transform-v-style";
|
|
4
|
+
import VStyle from "./v-style";
|
|
5
|
+
export default class BaseVStyle extends VStyle {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
this._isBase = false;
|
|
9
|
+
this.props = [];
|
|
10
|
+
this.subscriptions = {};
|
|
11
|
+
this.renderedSubBuilders = [];
|
|
12
|
+
}
|
|
13
|
+
_render(target) {
|
|
14
|
+
this.target = target;
|
|
15
|
+
for (let i = 0; i < this.props.length; i++) {
|
|
16
|
+
let P = this.props[i];
|
|
17
|
+
this.renderAndSetPropValue(P.prop, P.value);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
_unrender() {
|
|
21
|
+
for (let i = 0; i < this.renderedSubBuilders.length; i++) {
|
|
22
|
+
let sb = this.renderedSubBuilders[i];
|
|
23
|
+
sb._unrender();
|
|
24
|
+
}
|
|
25
|
+
this.renderedSubBuilders.length = 0;
|
|
26
|
+
for (let s in this.subscriptions) {
|
|
27
|
+
let P = this.subscriptions[s];
|
|
28
|
+
P.detachBinding(Number(s));
|
|
29
|
+
}
|
|
30
|
+
this.subscriptions = {};
|
|
31
|
+
this.target = null;
|
|
32
|
+
}
|
|
33
|
+
renderAndSetPropValue(prop, value) {
|
|
34
|
+
if (value instanceof Reactive) {
|
|
35
|
+
let id = value.subscribeStyle(this, prop);
|
|
36
|
+
this.subscriptions[id] = value;
|
|
37
|
+
this.updateProp(prop, value.getValue());
|
|
38
|
+
}
|
|
39
|
+
else if (value instanceof VStyle) {
|
|
40
|
+
this.renderedSubBuilders.push(value);
|
|
41
|
+
value._render(this.target);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
this.updateProp(prop, value);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
updateProp(prop, value) {
|
|
48
|
+
if (this.target) {
|
|
49
|
+
this.target.style[prop] = value;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
setProp(propName, value) {
|
|
53
|
+
if (this._isBase) {
|
|
54
|
+
let newStyle = new BaseVStyle();
|
|
55
|
+
return newStyle.setProp(propName, value);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
if (value && value.call && value.apply) {
|
|
59
|
+
let builder;
|
|
60
|
+
switch (propName) {
|
|
61
|
+
case "transform": {
|
|
62
|
+
builder = new TransformVStyle(propName);
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
case "filter":
|
|
66
|
+
case "backdrop-filter": {
|
|
67
|
+
builder = new FilterVStyle(propName);
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
default: throw new Error(`${propName} does not have a builder.`);
|
|
71
|
+
}
|
|
72
|
+
value(builder);
|
|
73
|
+
value = builder;
|
|
74
|
+
if (this.target) {
|
|
75
|
+
this.renderedSubBuilders.push(builder);
|
|
76
|
+
builder._render(this.target);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
if (this.target) {
|
|
81
|
+
let observerId = value.subscribeStyle(this, propName);
|
|
82
|
+
this.subscriptions[observerId] = value;
|
|
83
|
+
this.renderAndSetPropValue(propName, value);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
this.props.push({ prop: propName, value: value });
|
|
87
|
+
return this;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
{
|
|
92
|
+
const _allProps = {
|
|
93
|
+
"color": "color|background-Color|border-Bottom-Color|border-Color|border-Left-Color|border-Right-Color|border-Top-Color|text-Decoration-Color|outline-Color|column-Rule-Color",
|
|
94
|
+
"length": "background-Size|block-Size|border-Bottom-Left-Radius|border-Bottom-Right-Radius|border-Bottom-Width|border-Image-Width|border-Left-Width|border-Radius|border-Right-Width|border-Top-Left-Radius|border-Top-Right-Radius|border-Top-Width|border-Width|bottom|gap|height|left|margin|margin-Bottom|margin-Left|margin-Right|margin-Top|max-Height|max-Width|min-Height|min-Width|padding|padding-Bottom|padding-Left|padding-Right|padding-Top|right|top|width|line-Height|flex-Basis|font-Size|text-Indent",
|
|
95
|
+
"url": "background-Image|border-Image|list-Style-Image|content|image-Orientation",
|
|
96
|
+
"transformation": "transform",
|
|
97
|
+
"filter": "filter|backdrop-Filter",
|
|
98
|
+
"misc": "all|appearance|aspect-Ratio|opacity|background|background-Attachment|background-Blend-Mode|background-Position|background-Repeat|background-Clip|background-Origin|border|border-Bottom|border-Bottom-Style|border-Image-Outset|border-Image-Repeat|border-Image-Slice|border-Image-Source|border-Left|border-Left-Style|border-Right|border-Right-Style|border-Style|border-Top|border-Top-Style|box-Decoration-Break|box-Shadow|clear|clip|display|float|overflow|box|overflow-X|overflow-Y|position|visibility|vertical-Align|z-Index|align-Content|align-Items|align-Self|flex|flex-Basis|flex-Direction|flex-Flow|flex-Grow|flex-Shrink|flex-Wrap|grid|grid-Area|grid-Auto-Columns|grid-auto-Rows|grid-Column|grid-Column-End|grid-Column-Gap|grid-Column-Start|grid-Gap|grid-Row|grid-Row-End|grid-Row-Gap|grid-Row-Start|grid-Template|grid-Template-Areas|grid-Template-Columns|grid-Template-Rows|justify-Content|order|hanging-Punctuation|hyphens|letter-Spacing|line-Break|overflow-Wrap|tab-Size|text-Align|text-Align-Last|text-Combine-Upright|text-Justify|text-Transform|white-Space|word-Break|word-Spacing|word-Wrap|text-Decoration|text-Decoration-Line|text-Decoration-Style|text-Shadow|text-Underline-Position|font|font-Family|font-Feature-Settings|font-Kerning|font-Language-Override|font-Size-Adjust|font-Stretch|font-Style|font-Synthesis|font-Variant|font-Variant-Alternates|font-Variant-Caps|font-Variant-East-Asian|font-Variant-Ligatures|font-Variant-Numeric|font-Variant-Position|font-Weight|direction|text-Orientation|text-Combine-Upright|unicode-Bidi|user-Select|writing-Mode|border-Collapse|border-Spacing|caption-Side|empty-Cells|table-Layout|counter-Increment|counter-Reset|list-Style|list-Style-Position|list-Style-Type|animation|animation-Delay|animation-Direction|animation-Duration|animation-Fill-Mode|animation-Iteration-Count|animation-Name|animation-Play-State|animation-Timing-Function|backface-Visibility|perspective2d|perspective-Origin|transform-Origin|transform-Style|transition|transition-Property|transition-Duration|transition-Timing-Function|transition-Delay|box-Sizing|cursor|ime-Mode|nav-Down|nav-Index|nav-Left|nav-Right|nav-Up|outline|outline-Offset|outline-Style|outline-Width|resize|text-Overflow|break-After|break-Before|break-Inside|column-Count|column-Fill|column-Gap|column-Rule|column-Rule-Style|column-Rule-Width|column-Span|column-Width|columns|widows|orphans|page-Break-After|page-Break-Before|page-Break-Inside|marks|quotes|image-Rendering|image-Resolution|object-Fit|object-Position|mask|mask-Type|mark|mark-After|mark-Before|phonemes|rest|rest-After|rest-Before|voice-Balance|voice-Duration|voice-Pitch|voice-Pitch-Range|voice-Rate|voice-Stress|voice-Volume|marquee-Direction|marquee-Play-Count|marquee-Speed|marquee-Style|pointer-Events",
|
|
99
|
+
};
|
|
100
|
+
for (let k in _allProps) {
|
|
101
|
+
let str = _allProps[k];
|
|
102
|
+
let props = str.split("|");
|
|
103
|
+
let types = k.split("|");
|
|
104
|
+
for (let t in types) {
|
|
105
|
+
for (let i = 0; i < props.length; i++) {
|
|
106
|
+
let pName = props[i];
|
|
107
|
+
let cssName = pName.toLowerCase();
|
|
108
|
+
let jsName = pName.split("-").join("");
|
|
109
|
+
BaseVStyle.prototype[jsName] = function () {
|
|
110
|
+
return this.setProp(cssName, ...arguments);
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
//# sourceMappingURL=base-v-style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-v-style.js","sourceRoot":"","sources":["../../src/v-style-nodes/base-v-style.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,aAAa,CAAC;AACnC,OAAO,YAAY,MAAM,kBAAkB,CAAC;AAC5C,OAAO,eAAe,MAAM,qBAAqB,CAAC;AAClD,OAAO,MAAM,MAAM,WAAW,CAAC;AAW/B,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,MAAM;IAA9C;;QAIkB,YAAO,GAAG,KAAK,CAAC;QACzB,UAAK,GAAyD,EAAE,CAAC;QACjE,kBAAa,GAA6B,EAAE,CAAC;QAC7C,wBAAmB,GAAkB,EAAE,CAAC;IA0GjD,CAAC;IApGA,OAAO,CAAC,MAAmB;QAC1B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;YACzC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAEtB,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;SAC5C;IACF,CAAC;IACD,SAAS;QAIR,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;YACvD,IAAI,EAAE,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;YACrC,EAAE,CAAC,SAAS,EAAE,CAAC;SACf;QAED,IAAI,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,CAAC;QAGpC,KAAI,IAAI,CAAC,IAAI,IAAI,CAAC,aAAa,EAAC;YAC/B,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YAE9B,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;SAC3B;QAED,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAExB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,qBAAqB,CAAC,IAAI,EAAE,KAAK;QAChC,IAAG,KAAK,YAAY,QAAQ,EAAC;YAC5B,IAAI,EAAE,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC;YAE/B,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;SACxC;aACI,IAAG,KAAK,YAAY,MAAM,EAAC;YAC/B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC3B;aACG;YACH,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;SAC7B;IAEF,CAAC;IAED,UAAU,CAAC,IAAY,EAAE,KAAa;QAErC,IAAG,IAAI,CAAC,MAAM,EAAC;YACd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;SAChC;IACF,CAAC;IAED,OAAO,CAAC,QAAQ,EAAE,KAAK;QACtB,IAAG,IAAI,CAAC,OAAO,EAAC;YACf,IAAI,QAAQ,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,OAAO,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;SACzC;aACG;YAEH,IAAG,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,KAAK,EAAC;gBACrC,IAAI,OAAe,CAAC;gBACpB,QAAO,QAAQ,EAAC;oBACf,KAAK,WAAW,CAAC,CAAA;wBAChB,OAAO,GAAG,IAAI,eAAe,CAAC,QAAQ,CAAC,CAAC;wBACxC,MAAM;qBACN;oBACD,KAAK,QAAQ,CAAC;oBACd,KAAK,iBAAiB,CAAC,CAAA;wBACtB,OAAO,GAAG,IAAI,YAAY,CAAC,QAAQ,CAAC,CAAC;wBACrC,MAAM;qBACN;oBACD,OAAO,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,QAAQ,2BAA2B,CAAC,CAAC;iBACjE;gBAED,KAAK,CAAC,OAAO,CAAC,CAAC;gBAEf,KAAK,GAAG,OAAO,CAAC;gBAEhB,IAAG,IAAI,CAAC,MAAM,EAAC;oBACd,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBACvC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;iBAC7B;aACD;iBACG;gBACH,IAAG,IAAI,CAAC,MAAM,EAAC;oBACd,IAAI,UAAU,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;oBACtD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC;oBAEvC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;iBAC5C;aACD;YAED,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAC,CAAC,CAAC;YAEhD,OAAO,IAAI,CAAC;SACZ;IACF,CAAC;CACD;AAED;IAKC,MAAM,SAAS,GAAG;QACjB,OAAO,EAAE,qKAAqK;QAC9K,QAAQ,EAAE,6eAA6e;QAEvf,KAAK,EAAE,0EAA0E;QACjF,gBAAgB,EAAE,WAAW;QAC7B,QAAQ,EAAE,wBAAwB;QAClC,MAAM,EAAE,4sFAA4sF;KAEptF,CAAA;IAED,KAAI,IAAI,CAAC,IAAI,SAAS,EAAC;QACtB,IAAI,GAAG,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QACvB,IAAI,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE3B,IAAI,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEzB,KAAI,IAAI,CAAC,IAAI,KAAK,EAAC;YAElB,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;gBACpC,IAAI,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBACrB,IAAI,OAAO,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;gBAClC,IAAI,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAEvC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG;oBAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC,CAAC;gBAC5C,CAAC,CAAA;aACD;SACD;KACD;CACD"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import Reactive from "../reactive";
|
|
2
|
+
import VStyle from "./v-style";
|
|
3
|
+
export default abstract class CssFunctionBuilderVStyle extends VStyle {
|
|
4
|
+
simpleValue: string;
|
|
5
|
+
funcs: Array<{
|
|
6
|
+
func: string;
|
|
7
|
+
args: Array<{
|
|
8
|
+
v: number | boolean | string | Reactive;
|
|
9
|
+
f: (v: number | boolean | string | Reactive) => string;
|
|
10
|
+
}>;
|
|
11
|
+
}>;
|
|
12
|
+
readonly propName: string;
|
|
13
|
+
subscriptions: Record<number, Reactive>;
|
|
14
|
+
target: HTMLElement;
|
|
15
|
+
constructor(propName: string);
|
|
16
|
+
_render(target: HTMLElement): void;
|
|
17
|
+
_unrender(): void;
|
|
18
|
+
updateProp(prop: string, value: string): void;
|
|
19
|
+
appendFunction(filter: string, args: any): this;
|
|
20
|
+
}
|