dothtml 6.0.0-beta.45 → 6.0.0-beta.47

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.
Files changed (152) hide show
  1. package/build_module/constants.js +2 -0
  2. package/build_module/constants.js.map +1 -0
  3. package/build_module/css/css-props.js +79 -0
  4. package/build_module/css/css-props.js.map +1 -0
  5. package/{dist/build_module → build_module}/css/format-css-type.d.ts +4 -3
  6. package/build_module/css/format-css-type.js +80 -0
  7. package/build_module/css/format-css-type.js.map +1 -0
  8. package/build_module/decoration/component.d.ts +4 -0
  9. package/build_module/decoration/component.js +35 -0
  10. package/build_module/decoration/component.js.map +1 -0
  11. package/build_module/dot.js +404 -0
  12. package/build_module/dot.js.map +1 -0
  13. package/build_module/events/event-manager.d.ts +14 -0
  14. package/build_module/events/event-manager.js +98 -0
  15. package/build_module/events/event-manager.js.map +1 -0
  16. package/build_module/events/synthetic-event.d.ts +17 -0
  17. package/build_module/events/synthetic-event.js +33 -0
  18. package/build_module/events/synthetic-event.js.map +1 -0
  19. package/build_module/helpers/render-stylesheet.js +36 -0
  20. package/build_module/helpers/render-stylesheet.js.map +1 -0
  21. package/build_module/helpers/tools.js +50 -0
  22. package/build_module/helpers/tools.js.map +1 -0
  23. package/build_module/index.d.ts +9 -0
  24. package/build_module/index.js +19 -0
  25. package/build_module/index.js.map +1 -0
  26. package/{dist/build_module → build_module}/reactivity/binding.d.ts +3 -1
  27. package/build_module/reactivity/binding.js +26 -0
  28. package/build_module/reactivity/binding.js.map +1 -0
  29. package/build_module/reactivity/computed.d.ts +18 -0
  30. package/build_module/reactivity/computed.js +106 -0
  31. package/build_module/reactivity/computed.js.map +1 -0
  32. package/build_module/reactivity/priority.d.ts +6 -0
  33. package/build_module/reactivity/priority.js +8 -0
  34. package/build_module/reactivity/priority.js.map +1 -0
  35. package/build_module/reactivity/reactive-attr.js +7 -0
  36. package/build_module/reactivity/reactive-attr.js.map +1 -0
  37. package/build_module/reactivity/reactive-style.js +7 -0
  38. package/build_module/reactivity/reactive-style.js.map +1 -0
  39. package/build_module/reactivity/ref-collection.d.ts +8 -0
  40. package/build_module/reactivity/ref-collection.js +32 -0
  41. package/build_module/reactivity/ref-collection.js.map +1 -0
  42. package/build_module/reactivity/ref.d.ts +7 -0
  43. package/build_module/reactivity/ref.js +35 -0
  44. package/build_module/reactivity/ref.js.map +1 -0
  45. package/build_module/reactivity/scheduler.d.ts +22 -0
  46. package/build_module/reactivity/scheduler.js +124 -0
  47. package/build_module/reactivity/scheduler.js.map +1 -0
  48. package/build_module/reactivity/store.d.ts +14 -0
  49. package/build_module/reactivity/store.js +91 -0
  50. package/build_module/reactivity/store.js.map +1 -0
  51. package/{dist/build_module → build_module}/reactivity/subscription.d.ts +2 -1
  52. package/build_module/reactivity/subscription.js +40 -0
  53. package/build_module/reactivity/subscription.js.map +1 -0
  54. package/{dist/build_module → build_module}/reactivity/watcher.d.ts +6 -3
  55. package/build_module/reactivity/watcher.js +82 -0
  56. package/build_module/reactivity/watcher.js.map +1 -0
  57. package/build_module/routing/helpers.d.ts +2 -0
  58. package/build_module/routing/helpers.js +21 -0
  59. package/build_module/routing/helpers.js.map +1 -0
  60. package/build_module/routing/index.d.ts +5 -0
  61. package/build_module/routing/index.js +6 -0
  62. package/build_module/routing/index.js.map +1 -0
  63. package/build_module/routing/link.d.ts +2 -0
  64. package/build_module/routing/link.js +45 -0
  65. package/build_module/routing/link.js.map +1 -0
  66. package/build_module/routing/router.d.ts +23 -0
  67. package/build_module/routing/router.js +209 -0
  68. package/build_module/routing/router.js.map +1 -0
  69. package/build_module/routing/scroll-manager.d.ts +1 -0
  70. package/build_module/routing/scroll-manager.js +33 -0
  71. package/build_module/routing/scroll-manager.js.map +1 -0
  72. package/build_module/routing/state.d.ts +7 -0
  73. package/build_module/routing/state.js +45 -0
  74. package/build_module/routing/state.js.map +1 -0
  75. package/build_module/v-dom-node.d.ts +0 -0
  76. package/build_module/v-dom-node.js +1 -0
  77. package/build_module/v-dom-node.js.map +1 -0
  78. package/build_module/v-meta-nodes/attribute-v-node.js +53 -0
  79. package/build_module/v-meta-nodes/attribute-v-node.js.map +1 -0
  80. package/build_module/v-meta-nodes/style-v-node.d.ts +26 -0
  81. package/build_module/v-meta-nodes/style-v-node.js +239 -0
  82. package/build_module/v-meta-nodes/style-v-node.js.map +1 -0
  83. package/build_module/v-meta-nodes/v-meta-node.js +3 -0
  84. package/build_module/v-meta-nodes/v-meta-node.js.map +1 -0
  85. package/build_module/v-style-nodes/base-v-style.d.ts +13 -0
  86. package/build_module/v-style-nodes/base-v-style.js +41 -0
  87. package/build_module/v-style-nodes/base-v-style.js.map +1 -0
  88. package/{dist/build_module → build_module}/v-style-nodes/css-function-builder-v-style.d.ts +0 -3
  89. package/build_module/v-style-nodes/css-function-builder-v-style.js +33 -0
  90. package/build_module/v-style-nodes/css-function-builder-v-style.js.map +1 -0
  91. package/build_module/v-style-nodes/filter-v-style.js +35 -0
  92. package/build_module/v-style-nodes/filter-v-style.js.map +1 -0
  93. package/build_module/v-style-nodes/style-sheet-builder.d.ts +9 -0
  94. package/build_module/v-style-nodes/style-sheet-builder.js +55 -0
  95. package/build_module/v-style-nodes/style-sheet-builder.js.map +1 -0
  96. package/build_module/v-style-nodes/transform-v-style.js +76 -0
  97. package/build_module/v-style-nodes/transform-v-style.js.map +1 -0
  98. package/build_module/v-style-nodes/v-style.js +6 -0
  99. package/build_module/v-style-nodes/v-style.js.map +1 -0
  100. package/{dist/build_module → build_module}/vdom-nodes/collection-vdom.d.ts +3 -1
  101. package/build_module/vdom-nodes/collection-vdom.js +174 -0
  102. package/build_module/vdom-nodes/collection-vdom.js.map +1 -0
  103. package/build_module/vdom-nodes/component-context.d.ts +5 -0
  104. package/build_module/vdom-nodes/component-context.js +5 -0
  105. package/build_module/vdom-nodes/component-context.js.map +1 -0
  106. package/build_module/vdom-nodes/component-vdom.d.ts +35 -0
  107. package/build_module/vdom-nodes/component-vdom.js +338 -0
  108. package/build_module/vdom-nodes/component-vdom.js.map +1 -0
  109. package/{dist/build_module → build_module}/vdom-nodes/conditional-vdom.d.ts +1 -0
  110. package/build_module/vdom-nodes/conditional-vdom.js +112 -0
  111. package/build_module/vdom-nodes/conditional-vdom.js.map +1 -0
  112. package/{dist/build_module → build_module}/vdom-nodes/container-vdom.d.ts +6 -2
  113. package/build_module/vdom-nodes/container-vdom.js +163 -0
  114. package/build_module/vdom-nodes/container-vdom.js.map +1 -0
  115. package/{dist/build_module → build_module}/vdom-nodes/element-vdom.d.ts +2 -1
  116. package/build_module/vdom-nodes/element-vdom.js +218 -0
  117. package/build_module/vdom-nodes/element-vdom.js.map +1 -0
  118. package/{dist/build_module → build_module}/vdom-nodes/html-vdom.d.ts +1 -0
  119. package/build_module/vdom-nodes/html-vdom.js +65 -0
  120. package/build_module/vdom-nodes/html-vdom.js.map +1 -0
  121. package/{dist/build_module → build_module}/vdom-nodes/text-vdom.d.ts +1 -0
  122. package/build_module/vdom-nodes/text-vdom.js +40 -0
  123. package/build_module/vdom-nodes/text-vdom.js.map +1 -0
  124. package/{dist/build_module → build_module}/vdom-nodes/vdom.d.ts +2 -0
  125. package/build_module/vdom-nodes/vdom.js +58 -0
  126. package/build_module/vdom-nodes/vdom.js.map +1 -0
  127. package/build_module/window-wrapper.js +39 -0
  128. package/build_module/window-wrapper.js.map +1 -0
  129. package/package.json +58 -64
  130. package/readme.md +32 -26
  131. package/dist/build_module/index.d.ts +0 -7
  132. package/dist/build_module/reactivity/ref.d.ts +0 -5
  133. package/dist/build_module/v-meta-nodes/style-v-node.d.ts +0 -16
  134. package/dist/build_module/v-style-nodes/base-v-style.d.ts +0 -14
  135. package/dist/build_module/vdom-nodes/component-vdom.d.ts +0 -13
  136. package/dist/index.cjs.js +0 -2
  137. package/dist/index.cjs.js.map +0 -1
  138. package/dist/index.esm.js +0 -2
  139. package/dist/index.esm.js.map +0 -1
  140. /package/{dist/build_module → build_module}/constants.d.ts +0 -0
  141. /package/{dist/build_module → build_module}/css/css-props.d.ts +0 -0
  142. /package/{dist/build_module → build_module}/dot.d.ts +0 -0
  143. /package/{dist/build_module → build_module}/helpers/render-stylesheet.d.ts +0 -0
  144. /package/{dist/build_module → build_module}/helpers/tools.d.ts +0 -0
  145. /package/{dist/build_module → build_module}/reactivity/reactive-attr.d.ts +0 -0
  146. /package/{dist/build_module → build_module}/reactivity/reactive-style.d.ts +0 -0
  147. /package/{dist/build_module → build_module}/v-meta-nodes/attribute-v-node.d.ts +0 -0
  148. /package/{dist/build_module → build_module}/v-meta-nodes/v-meta-node.d.ts +0 -0
  149. /package/{dist/build_module → build_module}/v-style-nodes/filter-v-style.d.ts +0 -0
  150. /package/{dist/build_module → build_module}/v-style-nodes/transform-v-style.d.ts +0 -0
  151. /package/{dist/build_module → build_module}/v-style-nodes/v-style.d.ts +0 -0
  152. /package/{dist/build_module → build_module}/window-wrapper.d.ts +0 -0
@@ -0,0 +1,163 @@
1
+ import Watcher from "../reactivity/watcher";
2
+ import CollectionVdom from "./collection-vdom";
3
+ import { ConditionalVdom } from "./conditional-vdom";
4
+ import ElementVdom from "./element-vdom";
5
+ import { HtmlVdom } from "./html-vdom";
6
+ import { TextVdom } from "./text-vdom";
7
+ import { Vdom } from "./vdom";
8
+ import { ComponentVdom } from "./component-vdom";
9
+ import BaseVStyle from "../v-style-nodes/base-v-style";
10
+ function reduceReactive(value) {
11
+ if (value instanceof Watcher)
12
+ return value.bind();
13
+ else
14
+ return value;
15
+ }
16
+ export class ContainerVdom extends Vdom {
17
+ constructor(dot) {
18
+ super();
19
+ this._children = [];
20
+ this._parent = null;
21
+ this._dot = dot;
22
+ }
23
+ _addChild(content) {
24
+ this._children.push(content);
25
+ if (this._parent && this._parent instanceof ElementVdom && this._parent.element)
26
+ content._render(this._parent.element);
27
+ return this;
28
+ }
29
+ _render(node) {
30
+ this._isRendered = true;
31
+ for (let c = 0; c < this._children.length; c++) {
32
+ this._children[c]._render(node);
33
+ }
34
+ }
35
+ _unrender() {
36
+ if (!this._isRendered)
37
+ return;
38
+ this._isRendered = false;
39
+ for (let c = 0; c < this._children.length; c++) {
40
+ this._children[c]._unrender();
41
+ }
42
+ }
43
+ _getNodes() {
44
+ let nodes = [];
45
+ for (let i = 0; i < this._children.length; i++) {
46
+ nodes.push(...this._children[i]._getNodes());
47
+ }
48
+ return nodes;
49
+ }
50
+ attr(A, c) {
51
+ let C = this._children[this._children.length - 1];
52
+ if (C && C instanceof ElementVdom) {
53
+ C.setAttr(A, c);
54
+ }
55
+ else {
56
+ throw new Error(`Invalid node to set ${A} attribute.`);
57
+ }
58
+ }
59
+ html(c) {
60
+ let hn = new HtmlVdom(reduceReactive(c));
61
+ return this._addChild(hn);
62
+ }
63
+ text(c) {
64
+ let tn = new TextVdom(reduceReactive(c));
65
+ return this._addChild(tn);
66
+ }
67
+ md(c) {
68
+ return this.text(reduceReactive(c));
69
+ }
70
+ style(c) {
71
+ if (typeof c === "function") {
72
+ const builder = new BaseVStyle();
73
+ c(builder);
74
+ this.attr("style", builder);
75
+ }
76
+ else {
77
+ this.attr("style", c);
78
+ }
79
+ return this;
80
+ }
81
+ mount(c, attrs) {
82
+ let cn = new ComponentVdom(this._dot, c);
83
+ if (attrs) {
84
+ for (let k in attrs) {
85
+ let val = attrs[k];
86
+ if (k === "ref") {
87
+ cn.setRef(val);
88
+ }
89
+ else if (k.startsWith("on") && typeof val === "function") {
90
+ let eventName = k;
91
+ let modifiers = [];
92
+ if (k.includes(".")) {
93
+ const parts = k.split(".");
94
+ eventName = parts[0];
95
+ modifiers = parts.slice(1);
96
+ }
97
+ cn.addEventListener(eventName.substring(2).toLowerCase(), val, modifiers);
98
+ }
99
+ else {
100
+ if (!c["props"])
101
+ c.props = {};
102
+ c.props[k] = val;
103
+ }
104
+ }
105
+ }
106
+ cn.init();
107
+ let ret = this._addChild(cn);
108
+ return ret;
109
+ }
110
+ when(condition, then) {
111
+ let condNode = new ConditionalVdom();
112
+ let thenContainer;
113
+ if (then instanceof ContainerVdom) {
114
+ thenContainer = then;
115
+ }
116
+ else {
117
+ thenContainer = new ContainerVdom(this._dot);
118
+ let textVdom = new TextVdom(reduceReactive(then));
119
+ thenContainer._addChild(textVdom);
120
+ then = thenContainer;
121
+ }
122
+ condNode.addCondition(reduceReactive(condition), reduceReactive(then));
123
+ this._addChild(condNode);
124
+ return this;
125
+ }
126
+ otherwiseWhen(condition, then, seal = false) {
127
+ let condNode = this._children[this._children.length - 1];
128
+ if (condNode instanceof ConditionalVdom) {
129
+ let thenContainer;
130
+ if (then instanceof ContainerVdom) {
131
+ thenContainer = then;
132
+ }
133
+ else {
134
+ thenContainer = new ContainerVdom(this._dot);
135
+ let textVdom = new TextVdom(reduceReactive(then));
136
+ thenContainer._addChild(textVdom);
137
+ then = thenContainer;
138
+ }
139
+ condNode.addCondition(reduceReactive(condition), reduceReactive(then), seal);
140
+ }
141
+ else {
142
+ throw new Error("Can't branch off of a non-conditional node.");
143
+ }
144
+ return this;
145
+ }
146
+ otherwise(then) { return this.otherwiseWhen(true, then, true); }
147
+ on(event, callback) {
148
+ let C = this._children[this._children.length - 1];
149
+ if (C && (C instanceof ElementVdom || C instanceof ComponentVdom)) {
150
+ C.addEventListener(event, callback);
151
+ }
152
+ else {
153
+ throw new Error(`Invalid node to set ${event} listener.`);
154
+ }
155
+ return this;
156
+ }
157
+ each(collection, callback) {
158
+ let collectionVdom = new CollectionVdom(reduceReactive(collection), callback);
159
+ this._addChild(collectionVdom);
160
+ return this;
161
+ }
162
+ }
163
+ //# sourceMappingURL=container-vdom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"container-vdom.js","sourceRoot":"","sources":["../../src/vdom-nodes/container-vdom.ts"],"names":[],"mappings":"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"}
@@ -20,9 +20,10 @@ export default class ElementVdom extends Vdom {
20
20
  constructor(dot: IDotCore, tag: string);
21
21
  _render(node: HTMLElement): void;
22
22
  _unrender(): void;
23
+ _getNodes(): Node[];
23
24
  toString(): string;
24
25
  setAttr(attr: any, value: any): void;
25
26
  private renderAttr;
26
- addEventListener(event: string, callback: (e: Event) => void): void;
27
+ addEventListener(event: string, callback: (e: any) => void, modifiers?: string[]): void;
27
28
  private renderEvent;
28
29
  }
@@ -0,0 +1,218 @@
1
+ import { DOT_VDOM_PROP_NAME } from "../constants";
2
+ import Watcher from "../reactivity/watcher";
3
+ import AttributeVNode from "../v-meta-nodes/attribute-v-node";
4
+ import StyleVNode from "../v-meta-nodes/style-v-node";
5
+ import { ContainerVdom } from "./container-vdom";
6
+ import { Vdom } from "./vdom";
7
+ import Binding from "../reactivity/binding";
8
+ import ReactiveAttr from "../reactivity/reactive-attr";
9
+ import BaseVStyle from "../v-style-nodes/base-v-style";
10
+ import { EventManager } from "../events/event-manager";
11
+ export class AttributeItem {
12
+ }
13
+ let manualInputAllowed = true;
14
+ export default class ElementVdom extends Vdom {
15
+ constructor(dot, tag) {
16
+ super();
17
+ this.children = null;
18
+ this.tag = null;
19
+ this.attributes = {};
20
+ this.events = [];
21
+ this.attributeObserverIds = [];
22
+ this.childBuilders = [];
23
+ this.attrVNodes = [];
24
+ this.styleVNodes = [];
25
+ this.tag = tag;
26
+ this.children = new ContainerVdom(dot);
27
+ this.children._parent = this;
28
+ }
29
+ _render(node) {
30
+ this.element = node.ownerDocument.createElement(this.tag);
31
+ this.element[DOT_VDOM_PROP_NAME] = this;
32
+ if (this.ref) {
33
+ if (typeof this.ref === "function") {
34
+ this.ref(this.element);
35
+ }
36
+ else {
37
+ this.ref.value = this.element;
38
+ }
39
+ }
40
+ node.appendChild(this.element);
41
+ if (this.children) {
42
+ this.children._render(this.element);
43
+ }
44
+ for (let a in this.attributes) {
45
+ this.renderAttr(a, this.attributes[a], this.element);
46
+ }
47
+ for (let i = 0; i < this.events.length; i++) {
48
+ let e = this.events[i];
49
+ this.renderEvent(e.name, e.callback, e.modifiers);
50
+ }
51
+ }
52
+ _unrender() {
53
+ this.children._unrender();
54
+ if (this.inputListener) {
55
+ this.element.removeEventListener("input", this.inputListener);
56
+ this.inputListener = null;
57
+ }
58
+ const eventManager = EventManager.getForDocument(this.element.ownerDocument);
59
+ for (let i = 0; i < this.events.length; i++) {
60
+ let e = this.events[i];
61
+ eventManager.removeListener(this.element, e.name.toLowerCase(), e.callback);
62
+ }
63
+ this.element.parentNode?.removeChild(this.element);
64
+ for (let i = 0; i < this.childBuilders.length; i++) {
65
+ this.childBuilders[i]._unrender();
66
+ }
67
+ this.childBuilders.length = 0;
68
+ for (let i = 0; i < this.attrVNodes.length; i++) {
69
+ this.attrVNodes[i].unrender();
70
+ }
71
+ this.attrVNodes.length = 0;
72
+ for (let i = 0; i < this.styleVNodes.length; i++) {
73
+ this.styleVNodes[i].unrender();
74
+ }
75
+ this.styleVNodes.length = 0;
76
+ for (let i = 0; i < this.attributeObserverIds.length; i++) {
77
+ let item = this.attributeObserverIds[i];
78
+ item.observable._unsubscribe(item.id);
79
+ }
80
+ this.attributeObserverIds.length = 0;
81
+ if (this.ref) {
82
+ if (typeof this.ref === "function") {
83
+ this.ref(null);
84
+ }
85
+ else {
86
+ this.ref.value = null;
87
+ }
88
+ }
89
+ this.element = null;
90
+ }
91
+ _getNodes() {
92
+ return this.element ? [this.element] : [];
93
+ }
94
+ toString() {
95
+ if (this.element) {
96
+ return this.element.outerHTML;
97
+ }
98
+ else {
99
+ return super.toString();
100
+ }
101
+ }
102
+ setAttr(attr, value) {
103
+ attr = (attr ?? "").toLowerCase();
104
+ const oldVal = this.attributes[attr];
105
+ if (oldVal instanceof StyleVNode) {
106
+ oldVal.unrender();
107
+ const idx = this.styleVNodes.indexOf(oldVal);
108
+ if (idx !== -1)
109
+ this.styleVNodes.splice(idx, 1);
110
+ }
111
+ if (oldVal instanceof AttributeVNode) {
112
+ oldVal.unrender();
113
+ const idx = this.attrVNodes.indexOf(oldVal);
114
+ if (idx !== -1)
115
+ this.attrVNodes.splice(idx, 1);
116
+ }
117
+ if (value && typeof value === "object" && !(value instanceof Array || value instanceof Binding || value instanceof Watcher || value instanceof BaseVStyle)) {
118
+ switch (attr) {
119
+ case "style": {
120
+ value = new StyleVNode(value);
121
+ break;
122
+ }
123
+ case "ref": {
124
+ break;
125
+ }
126
+ default: {
127
+ value = new AttributeVNode(attr, value);
128
+ break;
129
+ }
130
+ }
131
+ }
132
+ if (value instanceof BaseVStyle && attr === "style") {
133
+ value = new StyleVNode(value);
134
+ }
135
+ this.attributes[attr] = value;
136
+ if (this.element) {
137
+ this.renderAttr(attr, value, this.element);
138
+ }
139
+ }
140
+ renderAttr(attr, value, node) {
141
+ if (attr == "ref") {
142
+ this.ref = value;
143
+ if (this.element) {
144
+ if (typeof this.ref === "function") {
145
+ this.ref(this.element);
146
+ }
147
+ else {
148
+ this.ref.value = this.element;
149
+ }
150
+ }
151
+ }
152
+ else if (typeof value === "string" || typeof value === "number") {
153
+ if (attr == "value" && (this.tag.toLowerCase() == "input" || this.tag.toLowerCase() == "textarea" || this.tag.toLowerCase() == "select")) {
154
+ node.value = value ?? "";
155
+ }
156
+ else {
157
+ node.setAttribute(attr, `${value}`);
158
+ }
159
+ }
160
+ else if (typeof value === "boolean" || value == null || value == undefined) {
161
+ if (attr == "checked" && this.tag.toLowerCase() == "input") {
162
+ node.checked = !!value;
163
+ }
164
+ else if (attr == "selected" && this.tag.toLowerCase() == "option") {
165
+ node.selected = !!value;
166
+ }
167
+ if (value)
168
+ node.setAttribute(attr, `${value}`);
169
+ else
170
+ node.removeAttribute(attr);
171
+ }
172
+ else if (value instanceof Array) {
173
+ node.setAttribute(attr, value.join(" "));
174
+ }
175
+ else if (value instanceof Binding) {
176
+ this.renderAttr(attr, value._get(), node);
177
+ let id = value._subscribe(new ReactiveAttr(this, attr));
178
+ this.attributeObserverIds.push({ id: id, observable: value });
179
+ if (attr == "value" || attr == "checked") {
180
+ let timeout = null;
181
+ if (!this.inputListener) {
182
+ this.inputListener = (e) => {
183
+ if (!manualInputAllowed)
184
+ return;
185
+ if (timeout)
186
+ clearTimeout(timeout);
187
+ timeout = setTimeout(() => {
188
+ manualInputAllowed = false;
189
+ value._set(this.element[attr]);
190
+ manualInputAllowed = true;
191
+ timeout = null;
192
+ }, 200);
193
+ };
194
+ this.element.addEventListener("input", this.inputListener);
195
+ }
196
+ }
197
+ }
198
+ else if (value instanceof AttributeVNode) {
199
+ value.render(node);
200
+ this.attrVNodes.push(value);
201
+ }
202
+ else if (value instanceof StyleVNode) {
203
+ value.render(node);
204
+ this.styleVNodes.push(value);
205
+ }
206
+ else {
207
+ }
208
+ }
209
+ addEventListener(event, callback, modifiers = []) {
210
+ this.events.push({ name: event, callback: callback, modifiers: modifiers });
211
+ if (this.element)
212
+ this.renderEvent(event, callback, modifiers);
213
+ }
214
+ renderEvent(e, callback, modifiers = []) {
215
+ EventManager.getForDocument(this.element.ownerDocument).addListener(this.element, e.toLowerCase(), callback, modifiers);
216
+ }
217
+ }
218
+ //# sourceMappingURL=element-vdom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"element-vdom.js","sourceRoot":"","sources":["../../src/vdom-nodes/element-vdom.ts"],"names":[],"mappings":"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"}
@@ -9,5 +9,6 @@ export declare class HtmlVdom extends Vdom {
9
9
  updateHtml(html: any): void;
10
10
  _render(target: HTMLElement): void;
11
11
  _unrender(): void;
12
+ _getNodes(): Node[];
12
13
  toString(): any;
13
14
  }
@@ -0,0 +1,65 @@
1
+ import { removeNodesBetween } from "../helpers/tools";
2
+ import Binding from "../reactivity/binding";
3
+ import { Vdom } from "./vdom";
4
+ export class HtmlVdom extends Vdom {
5
+ constructor(html) {
6
+ super();
7
+ this.observerId = 0;
8
+ this.html = html;
9
+ }
10
+ updateHtml(html) {
11
+ if (this.beforeNode) {
12
+ removeNodesBetween(this.beforeNode, this.afterNode);
13
+ let temp = this.beforeNode.ownerDocument.createElement("div");
14
+ temp.innerHTML = html;
15
+ while (temp.firstChild) {
16
+ this.afterNode.parentElement.insertBefore(temp.firstChild, this.afterNode);
17
+ }
18
+ }
19
+ }
20
+ _render(target) {
21
+ let html = "";
22
+ if (this.html instanceof Binding) {
23
+ html = this.html._get() ?? "";
24
+ this.observerId = this.html._subscribe(this);
25
+ }
26
+ else {
27
+ html = this.html;
28
+ }
29
+ this.beforeNode = target.ownerDocument.createTextNode("");
30
+ this.afterNode = target.ownerDocument.createTextNode("");
31
+ target.appendChild(this.beforeNode);
32
+ target.appendChild(this.afterNode);
33
+ this.updateHtml(html ?? "");
34
+ }
35
+ _unrender() {
36
+ if (this.beforeNode) {
37
+ let parent = this.beforeNode.parentElement;
38
+ removeNodesBetween(this.beforeNode, this.afterNode);
39
+ parent.removeChild(this.beforeNode);
40
+ parent.removeChild(this.afterNode);
41
+ this.beforeNode = null;
42
+ this.afterNode = null;
43
+ }
44
+ if (this.observerId && this.html instanceof Binding) {
45
+ this.html._unsubscribe(this.observerId);
46
+ this.observerId = 0;
47
+ }
48
+ }
49
+ _getNodes() {
50
+ if (!this.beforeNode)
51
+ return [];
52
+ let nodes = [this.beforeNode];
53
+ let curr = this.beforeNode.nextSibling;
54
+ while (curr && curr !== this.afterNode) {
55
+ nodes.push(curr);
56
+ curr = curr.nextSibling;
57
+ }
58
+ nodes.push(this.afterNode);
59
+ return nodes;
60
+ }
61
+ toString() {
62
+ return this.html instanceof Binding ? this.html._get() : this.html;
63
+ }
64
+ }
65
+ //# sourceMappingURL=html-vdom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"html-vdom.js","sourceRoot":"","sources":["../../src/vdom-nodes/html-vdom.ts"],"names":[],"mappings":"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"}
@@ -7,5 +7,6 @@ export declare class TextVdom extends Vdom {
7
7
  constructor(text: string | boolean | number | Binding);
8
8
  _render(node: HTMLElement): void;
9
9
  _unrender(): void;
10
+ _getNodes(): Node[];
10
11
  toString(): string;
11
12
  }
@@ -0,0 +1,40 @@
1
+ import Binding from "../reactivity/binding";
2
+ import { Vdom } from "./vdom";
3
+ export class TextVdom extends Vdom {
4
+ constructor(text) {
5
+ super();
6
+ this.textNode = null;
7
+ this.observerId = 0;
8
+ this.text = text;
9
+ }
10
+ _render(node) {
11
+ if (this.text instanceof Binding) {
12
+ this.textNode = node.ownerDocument.createTextNode(this.text._get() ?? "");
13
+ this.observerId = this.text._subscribe(this);
14
+ }
15
+ else {
16
+ this.textNode = node.ownerDocument.createTextNode(`${this.text ?? ""}`);
17
+ }
18
+ node.appendChild(this.textNode);
19
+ }
20
+ _unrender() {
21
+ if (this.textNode) {
22
+ this.textNode.parentElement.removeChild(this.textNode);
23
+ this.textNode = null;
24
+ }
25
+ if (this.observerId && this.text instanceof Binding) {
26
+ this.text._unsubscribe(this.observerId);
27
+ this.observerId = 0;
28
+ }
29
+ }
30
+ _getNodes() {
31
+ return this.textNode ? [this.textNode] : [];
32
+ }
33
+ toString() {
34
+ let temp = document.createTextNode((this.text instanceof Binding ? this.text._get() : this.text) ?? "");
35
+ let div = document.createElement("div");
36
+ div.appendChild(temp);
37
+ return div.innerHTML;
38
+ }
39
+ }
40
+ //# sourceMappingURL=text-vdom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text-vdom.js","sourceRoot":"","sources":["../../src/vdom-nodes/text-vdom.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAE5C,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAI9B,MAAM,OAAO,QAAS,SAAQ,IAAI;IAMjC,YAAY,IAAmC;QAC9C,KAAK,EAAE,CAAC;QAJT,aAAQ,GAAS,IAAI,CAAC;QACtB,eAAU,GAAG,CAAC,CAAC;QAId,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IAClB,CAAC;IAED,OAAO,CAAC,IAAiB;QACxB,IAAG,IAAI,CAAC,IAAI,YAAY,OAAO,EAAC;YAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YAC1E,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;SAC7C;aACG;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC;SACxE;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAED,SAAS;QACR,IAAG,IAAI,CAAC,QAAQ,EAAC;YAEhB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACvD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACrB;QAED,IAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,YAAY,OAAO,EAAC;YAClD,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;SACpB;IACF,CAAC;IAED,SAAS;QACR,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAC7C,CAAC;IAED,QAAQ;QACP,IAAI,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,YAAY,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACxG,IAAI,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACxC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACtB,OAAO,GAAG,CAAC,SAAS,CAAC;IACtB,CAAC;CACD"}
@@ -1,6 +1,8 @@
1
1
  export declare abstract class Vdom {
2
2
  abstract _render(target: HTMLElement): any;
3
3
  abstract _unrender(): any;
4
+ abstract _getNodes(): Node[];
5
+ _moveBefore(reference: Node, parent?: Node): void;
4
6
  __isRendered: boolean;
5
7
  get _isRendered(): boolean;
6
8
  set _isRendered(value: boolean);
@@ -0,0 +1,58 @@
1
+ export class Vdom {
2
+ constructor() {
3
+ this.__isRendered = false;
4
+ }
5
+ _moveBefore(reference, parent) {
6
+ let nodes = this._getNodes();
7
+ if (nodes.length === 0)
8
+ return;
9
+ let p = reference?.parentElement || parent;
10
+ if (!p)
11
+ throw new Error("Internal Error: Cannot move nodes without a parent.");
12
+ for (let i = 0; i < nodes.length; i++) {
13
+ if (nodes[i] === reference)
14
+ return;
15
+ }
16
+ let fragment = (reference?.ownerDocument || p.ownerDocument || document).createDocumentFragment();
17
+ for (let i = 0; i < nodes.length; i++) {
18
+ fragment.appendChild(nodes[i]);
19
+ }
20
+ p.insertBefore(fragment, reference);
21
+ }
22
+ get _isRendered() {
23
+ return this.__isRendered;
24
+ }
25
+ set _isRendered(value) {
26
+ if (value && this.__isRendered)
27
+ throw new Error("Internal Error: Node is already rendered.");
28
+ if (!value && !this.__isRendered)
29
+ throw new Error("Internal Error: Node is not rendered.");
30
+ this.__isRendered = value;
31
+ }
32
+ toString() {
33
+ let el = document.createElement("div");
34
+ this._render(el);
35
+ return el.innerHTML;
36
+ }
37
+ _renderBefore(reference) {
38
+ let dummy = reference.ownerDocument.createElement("div");
39
+ this._render(dummy);
40
+ while (dummy.childNodes.length > 0) {
41
+ let cn = dummy.childNodes[0];
42
+ cn.parentElement.removeChild(cn);
43
+ reference.parentElement.insertBefore(cn, reference);
44
+ }
45
+ }
46
+ _renderAfter(reference) {
47
+ if (reference.nextSibling) {
48
+ this._renderBefore(reference.nextSibling);
49
+ }
50
+ else {
51
+ let temp = reference.ownerDocument.createTextNode("");
52
+ reference.parentElement.appendChild(temp);
53
+ this._renderBefore(temp);
54
+ temp.parentElement.removeChild(temp);
55
+ }
56
+ }
57
+ }
58
+ //# sourceMappingURL=vdom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vdom.js","sourceRoot":"","sources":["../../src/vdom-nodes/vdom.ts"],"names":[],"mappings":"AAAA,MAAM,OAAgB,IAAI;IAA1B;QAyBC,iBAAY,GAAG,KAAK,CAAC;IAoCtB,CAAC;IArDA,WAAW,CAAC,SAAe,EAAE,MAAa;QACzC,IAAI,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAC7B,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAC/B,IAAI,CAAC,GAAG,SAAS,EAAE,aAAa,IAAI,MAAM,CAAC;QAC3C,IAAI,CAAC,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;QAE/E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACtC,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,SAAS;gBAAE,OAAO;SACnC;QAED,IAAI,QAAQ,GAAG,CAAC,SAAS,EAAE,aAAa,IAAI,CAAC,CAAC,aAAa,IAAI,QAAQ,CAAC,CAAC,sBAAsB,EAAE,CAAC;QAClG,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;YACpC,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;SAC/B;QACD,CAAC,CAAC,YAAY,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IACrC,CAAC;IAGD,IAAI,WAAW;QACd,OAAO,IAAI,CAAC,YAAY,CAAA;IACzB,CAAC;IACD,IAAI,WAAW,CAAC,KAAc;QAC7B,IAAG,KAAK,IAAI,IAAI,CAAC,YAAY;YAAE,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC5F,IAAG,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC1F,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,QAAQ;QACP,IAAI,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACjB,OAAO,EAAE,CAAC,SAAS,CAAC;IACrB,CAAC;IAED,aAAa,CAAC,SAAe;QAC5B,IAAI,KAAK,GAAG,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACzD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACpB,OAAM,KAAK,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAC;YACjC,IAAI,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAC7B,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACjC,SAAS,CAAC,aAAa,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;SACpD;IACF,CAAC;IACD,YAAY,CAAC,SAAe;QAC3B,IAAG,SAAS,CAAC,WAAW,EAAC;YACxB,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;SAC1C;aACG;YACH,IAAI,IAAI,GAAG,SAAS,CAAC,aAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;YACtD,SAAS,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACzB,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SACrC;IACF,CAAC;CACD"}