dothtml 5.2.11 → 6.0.0-beta.2

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 (130) hide show
  1. package/build_module/constants.d.ts +1 -0
  2. package/build_module/constants.js +2 -0
  3. package/build_module/constants.js.map +1 -0
  4. package/build_module/decoration/component.d.ts +25 -0
  5. package/build_module/decoration/component.js +32 -0
  6. package/build_module/decoration/component.js.map +1 -0
  7. package/build_module/decoration/style.d.ts +0 -0
  8. package/build_module/decoration/style.js +1 -0
  9. package/build_module/decoration/style.js.map +1 -0
  10. package/build_module/dot.d.ts +3 -0
  11. package/build_module/dot.js +514 -0
  12. package/build_module/dot.js.map +1 -0
  13. package/build_module/helpers.d.ts +2 -0
  14. package/build_module/helpers.js +49 -0
  15. package/build_module/helpers.js.map +1 -0
  16. package/build_module/index.d.ts +7 -0
  17. package/build_module/index.js +5 -0
  18. package/build_module/index.js.map +1 -0
  19. package/build_module/reactive.d.ts +37 -0
  20. package/build_module/reactive.js +120 -0
  21. package/build_module/reactive.js.map +1 -0
  22. package/build_module/v-dom-node.d.ts +0 -0
  23. package/build_module/v-dom-node.js +1 -0
  24. package/build_module/v-dom-node.js.map +1 -0
  25. package/build_module/vdom-nodes/collection-vdom.d.ts +24 -0
  26. package/build_module/vdom-nodes/collection-vdom.js +154 -0
  27. package/build_module/vdom-nodes/collection-vdom.js.map +1 -0
  28. package/build_module/vdom-nodes/component-vdom.d.ts +14 -0
  29. package/build_module/vdom-nodes/component-vdom.js +60 -0
  30. package/build_module/vdom-nodes/component-vdom.js.map +1 -0
  31. package/build_module/vdom-nodes/conditional-vdom.d.ts +14 -0
  32. package/build_module/vdom-nodes/conditional-vdom.js +97 -0
  33. package/build_module/vdom-nodes/conditional-vdom.js.map +1 -0
  34. package/build_module/vdom-nodes/container-vdom.d.ts +23 -0
  35. package/build_module/vdom-nodes/container-vdom.js +85 -0
  36. package/build_module/vdom-nodes/container-vdom.js.map +1 -0
  37. package/build_module/vdom-nodes/element-vdom.d.ts +18 -0
  38. package/build_module/vdom-nodes/element-vdom.js +88 -0
  39. package/build_module/vdom-nodes/element-vdom.js.map +1 -0
  40. package/build_module/vdom-nodes/html-vdom.d.ts +13 -0
  41. package/build_module/vdom-nodes/html-vdom.js +53 -0
  42. package/build_module/vdom-nodes/html-vdom.js.map +1 -0
  43. package/build_module/vdom-nodes/text-vdom.d.ts +11 -0
  44. package/build_module/vdom-nodes/text-vdom.js +37 -0
  45. package/build_module/vdom-nodes/text-vdom.js.map +1 -0
  46. package/build_module/vdom-nodes/vdom.d.ts +7 -0
  47. package/build_module/vdom-nodes/vdom.js +28 -0
  48. package/build_module/vdom-nodes/vdom.js.map +1 -0
  49. package/package.json +26 -19
  50. package/lib/arg-callback-obj.d.ts +0 -29
  51. package/lib/arg-callback-obj.js +0 -64
  52. package/lib/arg-callback-obj.js.map +0 -1
  53. package/lib/built-in-components/nav-link.d.ts +0 -8
  54. package/lib/built-in-components/nav-link.js +0 -24
  55. package/lib/built-in-components/nav-link.js.map +0 -1
  56. package/lib/built-in-components/router.d.ts +0 -57
  57. package/lib/built-in-components/router.js +0 -282
  58. package/lib/built-in-components/router.js.map +0 -1
  59. package/lib/component.d.ts +0 -82
  60. package/lib/component.js +0 -329
  61. package/lib/component.js.map +0 -1
  62. package/lib/dot-util.d.ts +0 -26
  63. package/lib/dot-util.js +0 -62
  64. package/lib/dot-util.js.map +0 -1
  65. package/lib/dot.d.ts +0 -5
  66. package/lib/dot.js +0 -1122
  67. package/lib/dot.js.map +0 -1
  68. package/lib/dothtml.d.ts +0 -29
  69. package/lib/dothtml.js +0 -15
  70. package/lib/dothtml.js.map +0 -1
  71. package/lib/err.d.ts +0 -2
  72. package/lib/err.js +0 -26
  73. package/lib/err.js.map +0 -1
  74. package/lib/event-bus.d.ts +0 -10
  75. package/lib/event-bus.js +0 -37
  76. package/lib/event-bus.js.map +0 -1
  77. package/lib/i-dot.d.ts +0 -689
  78. package/lib/i-dot.js +0 -3
  79. package/lib/i-dot.js.map +0 -1
  80. package/lib/node-polyfill.d.ts +0 -2
  81. package/lib/node-polyfill.js +0 -14
  82. package/lib/node-polyfill.js.map +0 -1
  83. package/lib/observable-array.d.ts +0 -49
  84. package/lib/observable-array.js +0 -274
  85. package/lib/observable-array.js.map +0 -1
  86. package/lib/pages/home-page.d.ts +0 -9
  87. package/lib/pages/home-page.js +0 -24
  88. package/lib/pages/home-page.js.map +0 -1
  89. package/lib/styling/css-types.ts/css-angle.d.ts +0 -7
  90. package/lib/styling/css-types.ts/css-angle.js +0 -22
  91. package/lib/styling/css-types.ts/css-angle.js.map +0 -1
  92. package/lib/styling/css-types.ts/css-color.d.ts +0 -9
  93. package/lib/styling/css-types.ts/css-color.js +0 -824
  94. package/lib/styling/css-types.ts/css-color.js.map +0 -1
  95. package/lib/styling/css-types.ts/css-complex.d.ts +0 -7
  96. package/lib/styling/css-types.ts/css-complex.js +0 -23
  97. package/lib/styling/css-types.ts/css-complex.js.map +0 -1
  98. package/lib/styling/css-types.ts/css-data-type.d.ts +0 -5
  99. package/lib/styling/css-types.ts/css-data-type.js +0 -9
  100. package/lib/styling/css-types.ts/css-data-type.js.map +0 -1
  101. package/lib/styling/css-types.ts/css-filter.d.ts +0 -22
  102. package/lib/styling/css-types.ts/css-filter.js +0 -121
  103. package/lib/styling/css-types.ts/css-filter.js.map +0 -1
  104. package/lib/styling/css-types.ts/css-length.d.ts +0 -7
  105. package/lib/styling/css-types.ts/css-length.js +0 -24
  106. package/lib/styling/css-types.ts/css-length.js.map +0 -1
  107. package/lib/styling/css-types.ts/css-number.d.ts +0 -6
  108. package/lib/styling/css-types.ts/css-number.js +0 -17
  109. package/lib/styling/css-types.ts/css-number.js.map +0 -1
  110. package/lib/styling/css-types.ts/css-percentage.d.ts +0 -5
  111. package/lib/styling/css-types.ts/css-percentage.js +0 -13
  112. package/lib/styling/css-types.ts/css-percentage.js.map +0 -1
  113. package/lib/styling/css-types.ts/css-transform.d.ts +0 -38
  114. package/lib/styling/css-types.ts/css-transform.js +0 -183
  115. package/lib/styling/css-types.ts/css-transform.js.map +0 -1
  116. package/lib/styling/css-types.ts/css-unknown.d.ts +0 -6
  117. package/lib/styling/css-types.ts/css-unknown.js +0 -17
  118. package/lib/styling/css-types.ts/css-unknown.js.map +0 -1
  119. package/lib/styling/css-types.ts/css-url.d.ts +0 -6
  120. package/lib/styling/css-types.ts/css-url.js +0 -45
  121. package/lib/styling/css-types.ts/css-url.js.map +0 -1
  122. package/lib/styling/i-dotcss.d.ts +0 -1085
  123. package/lib/styling/i-dotcss.js +0 -3
  124. package/lib/styling/i-dotcss.js.map +0 -1
  125. package/lib/styling/style-builder.d.ts +0 -24
  126. package/lib/styling/style-builder.js +0 -815
  127. package/lib/styling/style-builder.js.map +0 -1
  128. package/lib/styling/unit-function-tables.d.ts +0 -10
  129. package/lib/styling/unit-function-tables.js +0 -27
  130. package/lib/styling/unit-function-tables.js.map +0 -1
@@ -0,0 +1,85 @@
1
+ import CollectionVdom from "./collection-vdom";
2
+ import { ConditionalVdom } from "./conditional-vdom";
3
+ import ElementVdom from "./element-vdom";
4
+ import { HtmlVdom } from "./html-vdom";
5
+ import { TextVdom } from "./text-vdom";
6
+ import { Vdom } from "./vdom";
7
+ import { ComponentVdom } from "./component-vdom";
8
+ export class ContainerVdom extends Vdom {
9
+ constructor() {
10
+ super();
11
+ this._children = [];
12
+ this._parent = null;
13
+ }
14
+ _addChild(content) {
15
+ this._children.push(content);
16
+ if (this._parent && this._parent instanceof ElementVdom && this._parent.element)
17
+ content._render(this._parent.element);
18
+ return this;
19
+ }
20
+ _render(node) {
21
+ for (let c = 0; c < this._children.length; c++) {
22
+ this._children[c]._render(node);
23
+ }
24
+ }
25
+ _unrender() {
26
+ for (let c = 0; c < this._children.length; c++) {
27
+ this._children[c]._unrender();
28
+ }
29
+ }
30
+ html(c) {
31
+ let hn = new HtmlVdom(c);
32
+ return this._addChild(hn);
33
+ }
34
+ text(c) {
35
+ let tn = new TextVdom(c);
36
+ return this._addChild(tn);
37
+ }
38
+ mount(c) {
39
+ let cn = new ComponentVdom(c);
40
+ return this._addChild(cn);
41
+ }
42
+ when(condition, then) {
43
+ let condNode = new ConditionalVdom();
44
+ let thenContainer;
45
+ if (then instanceof ContainerVdom) {
46
+ thenContainer = then;
47
+ }
48
+ else {
49
+ thenContainer = new ContainerVdom();
50
+ let textVdom = new TextVdom(then);
51
+ thenContainer._addChild(textVdom);
52
+ then = thenContainer;
53
+ }
54
+ condNode.addCondition(condition, then);
55
+ this._addChild(condNode);
56
+ return this;
57
+ }
58
+ otherwiseWhen(condition, then, seal = false) {
59
+ let condNode = this._children[this._children.length - 1];
60
+ if (condNode instanceof ConditionalVdom) {
61
+ let thenContainer;
62
+ if (then instanceof ContainerVdom) {
63
+ thenContainer = then;
64
+ }
65
+ else {
66
+ thenContainer = new ContainerVdom();
67
+ let textVdom = new TextVdom(then);
68
+ thenContainer._addChild(textVdom);
69
+ then = thenContainer;
70
+ }
71
+ condNode.addCondition(condition, then, seal);
72
+ }
73
+ else {
74
+ throw new Error("Can't branch off of a non-conditional node.");
75
+ }
76
+ return this;
77
+ }
78
+ otherwise(then) { return this.otherwiseWhen(true, then, true); }
79
+ each(collection, callback) {
80
+ let collectionVdom = new CollectionVdom(collection, callback);
81
+ this._addChild(collectionVdom);
82
+ return this;
83
+ }
84
+ }
85
+ //# 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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"}
@@ -0,0 +1,18 @@
1
+ import { ContainerVdom } from "./container-vdom";
2
+ import { Vdom } from "./vdom";
3
+ export default class ElementVdom extends Vdom {
4
+ children: ContainerVdom;
5
+ element: HTMLElement;
6
+ tag: string;
7
+ private attributes;
8
+ private events;
9
+ private attributeObserverIds;
10
+ constructor(tag: string);
11
+ _render(node: HTMLElement): void;
12
+ _unrender(): void;
13
+ toString(): string;
14
+ setAttr(attr: any, value: any): void;
15
+ private renderAttr;
16
+ addEventListener(event: string, callback: (e: Event) => void): void;
17
+ private renderEvent;
18
+ }
@@ -0,0 +1,88 @@
1
+ import { DOT_VDOM_PROP_NAME } from "../constants";
2
+ import Reactive from "../reactive";
3
+ import { ContainerVdom } from "./container-vdom";
4
+ import { Vdom } from "./vdom";
5
+ export default class ElementVdom extends Vdom {
6
+ constructor(tag) {
7
+ super();
8
+ this.children = null;
9
+ this.tag = null;
10
+ this.attributes = {};
11
+ this.events = [];
12
+ this.attributeObserverIds = [];
13
+ this.tag = tag;
14
+ this.children = new ContainerVdom();
15
+ this.children._parent = this;
16
+ }
17
+ _render(node) {
18
+ this.element = node.ownerDocument.createElement(this.tag);
19
+ this.element[DOT_VDOM_PROP_NAME] = this;
20
+ for (let a in this.attributes) {
21
+ this.renderAttr(a, this.attributes[a], this.element);
22
+ }
23
+ node.appendChild(this.element);
24
+ for (let i = 0; i < this.events.length; i++) {
25
+ let e = this.events[i];
26
+ this.renderEvent(e.name, e.callback);
27
+ }
28
+ if (this.children) {
29
+ this.children._render(this.element);
30
+ }
31
+ }
32
+ _unrender() {
33
+ this.children._unrender();
34
+ this.element.parentNode?.removeChild(this.element);
35
+ this.element = null;
36
+ for (let i = 0; i < this.attributeObserverIds.length; i++) {
37
+ let item = this.attributeObserverIds[i];
38
+ item.observable.detachBinding(item.id);
39
+ }
40
+ this.attributeObserverIds.length = 0;
41
+ }
42
+ toString() {
43
+ if (this.element) {
44
+ return this.element.outerHTML;
45
+ }
46
+ else {
47
+ return super.toString();
48
+ }
49
+ }
50
+ setAttr(attr, value) {
51
+ this.attributes[attr] = value;
52
+ if (this.element) {
53
+ this.renderAttr(attr, value, this.element);
54
+ }
55
+ }
56
+ renderAttr(attr, value, node) {
57
+ if (typeof value === "string" || typeof value === "number") {
58
+ node.setAttribute(attr, `${value}`);
59
+ }
60
+ else if (typeof value === "boolean" || value == null || value == undefined) {
61
+ if (value)
62
+ node.setAttribute(attr, `${value}`);
63
+ else
64
+ node.removeAttribute(attr);
65
+ }
66
+ else if (value instanceof Reactive) {
67
+ this.renderAttr(attr, value.getValue(), node);
68
+ let id = value.subscribeAttr(this, attr);
69
+ this.attributeObserverIds.push({ id: id, observable: value });
70
+ if (attr == "value" || attr == "checked") {
71
+ this.element.addEventListener("input", (e) => {
72
+ value.setValue(this.element[attr]);
73
+ });
74
+ }
75
+ }
76
+ else {
77
+ }
78
+ }
79
+ addEventListener(event, callback) {
80
+ this.events.push({ name: event, callback: callback });
81
+ if (this.element)
82
+ this.renderEvent(event, callback);
83
+ }
84
+ renderEvent(e, callback) {
85
+ this.element.addEventListener(e.toLowerCase(), callback);
86
+ }
87
+ }
88
+ //# 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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"}
@@ -0,0 +1,13 @@
1
+ import Reactive from "../reactive";
2
+ import { Vdom } from "./vdom";
3
+ export declare class HtmlVdom extends Vdom {
4
+ beforeNode: Node;
5
+ afterNode: Node;
6
+ html: string | Reactive;
7
+ observerId: number;
8
+ constructor(html: string | Reactive);
9
+ updateHtml(html: any): void;
10
+ _render(target: HTMLElement): void;
11
+ _unrender(): void;
12
+ toString(): any;
13
+ }
@@ -0,0 +1,53 @@
1
+ import { removeNodesBetween } from "../helpers";
2
+ import Reactive from "../reactive";
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 Reactive) {
23
+ html = this.html.getValue();
24
+ this.observerId = this.html.subscribeHtml(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 Reactive) {
45
+ this.html.detachBinding(this.observerId);
46
+ this.observerId = 0;
47
+ }
48
+ }
49
+ toString() {
50
+ return this.html instanceof Reactive ? this.html.getValue() : this.html;
51
+ }
52
+ }
53
+ //# 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":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,QAAQ,MAAM,aAAa,CAAC;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,MAAM,OAAO,QAAS,SAAQ,IAAI;IAQjC,YAAY,IAAqB;QAChC,KAAK,EAAE,CAAC;QAHT,eAAU,GAAW,CAAC,CAAC;QAItB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IAClB,CAAC;IAED,UAAU,CAAC,IAAI;QACd,IAAG,IAAI,CAAC,UAAU,EAAC;YAClB,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAGpD,IAAI,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YAEtB,OAAO,IAAI,CAAC,UAAU,EAAE;gBACvB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;aAC3E;SACD;IACF,CAAC;IAED,OAAO,CAAC,MAAmB;QAC1B,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,IAAG,IAAI,CAAC,IAAI,YAAY,QAAQ,EAAC;YAChC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAChD;aACG;YACH,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;SACjB;QAED,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,aAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;QAC1D,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,aAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACnC,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,SAAS;QACR,IAAG,IAAI,CAAC,UAAU,EAAC;YAClB,IAAI,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YAG3C,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAEpD,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACnC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACtB;QAED,IAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,YAAY,QAAQ,EAAC;YACnD,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACzC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;SACpB;IACF,CAAC;IAED,QAAQ;QACP,OAAO,IAAI,CAAC,IAAI,YAAY,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;IACzE,CAAC;CACD"}
@@ -0,0 +1,11 @@
1
+ import Reactive from "../reactive";
2
+ import { Vdom } from "./vdom";
3
+ export declare class TextVdom extends Vdom {
4
+ text: string | boolean | number | Reactive;
5
+ textNode: Node;
6
+ observerId: number;
7
+ constructor(text: string | boolean | number | Reactive);
8
+ _render(node: HTMLElement): void;
9
+ _unrender(): void;
10
+ toString(): string;
11
+ }
@@ -0,0 +1,37 @@
1
+ import Reactive from "../reactive";
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 Reactive) {
12
+ this.textNode = node.ownerDocument.createTextNode(this.text.getValue() ?? "");
13
+ this.observerId = this.text.subscribeText(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 Reactive) {
26
+ this.text.detachBinding(this.observerId);
27
+ this.observerId = 0;
28
+ }
29
+ }
30
+ toString() {
31
+ let temp = document.createTextNode((this.text instanceof Reactive ? this.text.getValue() : this.text) ?? "");
32
+ let div = document.createElement("div");
33
+ div.appendChild(temp);
34
+ return div.innerHTML;
35
+ }
36
+ }
37
+ //# 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,QAAQ,MAAM,aAAa,CAAC;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAI9B,MAAM,OAAO,QAAS,SAAQ,IAAI;IAMjC,YAAY,IAAoC;QAC/C,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,QAAQ,EAAC;YAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;YAC9E,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAChD;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,QAAQ,EAAC;YACnD,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACzC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;SACpB;IACF,CAAC;IAED,QAAQ;QACP,IAAI,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,YAAY,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAC7G,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"}
@@ -0,0 +1,7 @@
1
+ export declare abstract class Vdom {
2
+ abstract _render(target: HTMLElement): any;
3
+ abstract _unrender(): any;
4
+ toString(): string;
5
+ _renderBefore(reference: Node): void;
6
+ _renderAfter(reference: Node): void;
7
+ }
@@ -0,0 +1,28 @@
1
+ export class Vdom {
2
+ toString() {
3
+ let el = document.createElement("div");
4
+ this._render(el);
5
+ return el.innerHTML;
6
+ }
7
+ _renderBefore(reference) {
8
+ let dummy = reference.ownerDocument.createElement("div");
9
+ this._render(dummy);
10
+ while (dummy.childNodes.length > 0) {
11
+ let cn = dummy.childNodes[0];
12
+ cn.parentElement.removeChild(cn);
13
+ reference.parentElement.insertBefore(cn, reference);
14
+ }
15
+ }
16
+ _renderAfter(reference) {
17
+ if (reference.nextSibling) {
18
+ this._renderBefore(reference.nextSibling);
19
+ }
20
+ else {
21
+ let temp = reference.ownerDocument.createTextNode("");
22
+ reference.parentElement.appendChild(temp);
23
+ this._renderBefore(temp);
24
+ temp.parentElement.removeChild(temp);
25
+ }
26
+ }
27
+ }
28
+ //# 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;IAMzB,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"}
package/package.json CHANGED
@@ -1,28 +1,17 @@
1
1
  {
2
2
  "name": "dothtml",
3
- "version": "5.2.11",
3
+ "version": "6.0.0-beta.2",
4
4
  "description": "DOThtml is a client-side web building framework written in TypeScript.",
5
- "main": "./lib/dothtml.js",
6
- "exports": "./lib/dothtml.js",
7
- "types": "./lib/dothtml.d.ts",
5
+ "main": "./build_module/dothtml.js",
6
+ "exports": "./build_module/index.js",
7
+ "types": "./build_module/dothtml.d.ts",
8
8
  "files": [
9
- "lib/**/*"
9
+ "build_module/**/*"
10
10
  ],
11
11
  "scripts": {
12
12
  "test": "npm run build & jest",
13
- "build": "tsc --declaration"
14
- },
15
- "devDependencies": {
16
- "@babel/preset-env": "^7.14.5",
17
- "@testing-library/jest-dom": "^5.13.0",
18
- "@types/node": "^18.14.2",
19
- "copyfiles": "^2.4.1",
20
- "esm": "^3.2.25",
21
- "jest": "^29.5.0",
22
- "jest-environment-jsdom": "^29.5.0",
23
- "ts-jest": "^29.0.5",
24
- "ts-node": "^10.9.1",
25
- "typescript": "^5.0.2"
13
+ "build": "tsc --declaration",
14
+ "buildumd": "webpack"
26
15
  },
27
16
  "repository": {
28
17
  "type": "git",
@@ -46,5 +35,23 @@
46
35
  "bugs": {
47
36
  "url": "https://github.com/JSideris/DOThtml/issues"
48
37
  },
49
- "homepage": "https://github.com/JSideris/DOThtml#readme"
38
+ "homepage": "https://dothtml.org/",
39
+ "devDependencies": {
40
+ "@babel/preset-env": "^7.14.5",
41
+ "@testing-library/jest-dom": "^5.13.0",
42
+ "@types/jest": "^29.5.11",
43
+ "@types/node": "^18.14.2",
44
+ "copyfiles": "^2.4.1",
45
+ "esm": "^3.2.25",
46
+ "jest": "^29.5.0",
47
+ "jest-environment-jsdom": "^29.5.0",
48
+ "ts-jest": "^29.0.5",
49
+ "ts-node": "^10.9.1",
50
+ "typescript": "^5.0.2",
51
+ "webpack": "^5.89.0",
52
+ "webpack-cli": "^5.1.4"
53
+ },
54
+ "dependencies": {
55
+ "dothtml-interfaces": "^0.1.31"
56
+ }
50
57
  }
@@ -1,29 +0,0 @@
1
- import { IDotDocument } from "./i-dot";
2
- export declare abstract class ArgCallback {
3
- el: Element;
4
- f: (content?: any, index?: number) => string;
5
- constructor(element: Element, value: (content?: any, index?: number) => string);
6
- abstract updateContent(dot: IDotDocument, propVal?: any): any;
7
- }
8
- export declare class AttrArgCallback extends ArgCallback {
9
- attr: string;
10
- constructor(element: Element, attributeName: string, value: (content?: any) => string);
11
- updateContent(dot: any): void;
12
- }
13
- export declare class ContentArgCallback extends ArgCallback {
14
- constructor(element: Element, content: () => string);
15
- updateContent(dot: any, propVal: string): void;
16
- }
17
- export declare class ArrayArgCallback extends ArgCallback {
18
- dotTarget: IDotDocument;
19
- constructor(dotTarget: any, content: any);
20
- updateContent(): void;
21
- }
22
- export declare class ConditionalArgCallback extends ArgCallback {
23
- startNode: Node;
24
- endNode: Node;
25
- condition: () => boolean | boolean;
26
- lastValue: boolean;
27
- constructor(startNode: any, endNode: any, content: any, condition: any);
28
- updateContent(dot: any): void;
29
- }
@@ -1,64 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ConditionalArgCallback = exports.ArrayArgCallback = exports.ContentArgCallback = exports.AttrArgCallback = exports.ArgCallback = void 0;
4
- class ArgCallback {
5
- constructor(element, value) {
6
- this.el = element;
7
- this.f = value;
8
- }
9
- }
10
- exports.ArgCallback = ArgCallback;
11
- class AttrArgCallback extends ArgCallback {
12
- constructor(element, attributeName, value) {
13
- super(element, value);
14
- this.attr = attributeName;
15
- }
16
- updateContent(dot) {
17
- this.el.setAttribute(this.attr, this.f());
18
- }
19
- }
20
- exports.AttrArgCallback = AttrArgCallback;
21
- class ContentArgCallback extends ArgCallback {
22
- constructor(element, content) {
23
- super(element, content);
24
- }
25
- updateContent(dot, propVal) {
26
- dot(this.el).empty().h(this.f(propVal));
27
- }
28
- }
29
- exports.ContentArgCallback = ContentArgCallback;
30
- class ArrayArgCallback extends ArgCallback {
31
- constructor(dotTarget, content) {
32
- super(null, content);
33
- this.dotTarget = dotTarget;
34
- }
35
- updateContent() { }
36
- }
37
- exports.ArrayArgCallback = ArrayArgCallback;
38
- class ConditionalArgCallback extends ArgCallback {
39
- constructor(startNode, endNode, content, condition) {
40
- super(null, content);
41
- this.startNode = startNode;
42
- this.endNode = endNode;
43
- this.condition = condition;
44
- this.lastValue = undefined; // This will be set by the calling code - after the object is added to __currentArgCallback.
45
- }
46
- updateContent(dot) {
47
- if (this.lastValue != !!this.condition()) {
48
- this.lastValue = !this.lastValue;
49
- if (this.lastValue) {
50
- dot._appendOrCreateDocument(this.f, this.endNode.parentNode, this.endNode);
51
- }
52
- else {
53
- do {
54
- var e = this.startNode.nextSibling;
55
- if (e && e != this.endNode) {
56
- e.parentNode.removeChild(e);
57
- }
58
- } while (this.startNode.nextSibling && this.startNode.nextSibling != this.endNode);
59
- }
60
- }
61
- }
62
- }
63
- exports.ConditionalArgCallback = ConditionalArgCallback;
64
- //# sourceMappingURL=arg-callback-obj.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"arg-callback-obj.js","sourceRoot":"","sources":["../src/arg-callback-obj.ts"],"names":[],"mappings":";;;AAEA,MAAsB,WAAW;IAI7B,YAAY,OAAgB,EAAE,KAA8C;QACxE,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC;QAClB,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC;IACnB,CAAC;CAGJ;AAVD,kCAUC;AAED,MAAa,eAAgB,SAAQ,WAAW;IAE5C,YAAY,OAAgB,EAAE,aAAqB,EAAE,KAA8B;QAC/E,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACtB,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;IAC9B,CAAC;IAED,aAAa,CAAC,GAAG;QACb,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;IAC9C,CAAC;CACJ;AAVD,0CAUC;AAED,MAAa,kBAAmB,SAAQ,WAAW;IAC/C,YAAY,OAAgB,EAAE,OAAmB;QAC7C,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC5B,CAAC;IAED,aAAa,CAAC,GAAG,EAAE,OAAe;QAC9B,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5C,CAAC;CACJ;AARD,gDAQC;AAED,MAAa,gBAAiB,SAAQ,WAAW;IAE7C,YAAY,SAAS,EAAE,OAAO;QAC1B,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACrB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,CAAC;IAED,aAAa,KAAG,CAAC;CACpB;AARD,4CAQC;AAED,MAAa,sBAAuB,SAAQ,WAAW;IAKnD,YAAY,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS;QAC9C,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACrB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC,4FAA4F;IAC5H,CAAC;IAED,aAAa,CAAC,GAAG;QACb,IAAG,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,EAAC;YACpC,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,IAAG,IAAI,CAAC,SAAS,EAAC;gBACd,GAAG,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;aAC9E;iBACI;gBACD,GAAE;oBACE,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;oBACnC,IAAG,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,EAAC;wBACtB,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;qBAC/B;iBACJ,QAAO,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,IAAI,CAAC,OAAO,EAAC;aACpF;SACJ;IACL,CAAC;CACJ;AA7BD,wDA6BC"}
@@ -1,8 +0,0 @@
1
- import Component from "../component";
2
- import { DotContent } from "../i-dot";
3
- export declare class NavLink extends Component {
4
- content: DotContent;
5
- hRef: string;
6
- constructor(content: DotContent, href: string);
7
- builder(): import("../i-dot").IDotA;
8
- }
@@ -1,24 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.NavLink = void 0;
7
- const component_1 = __importDefault(require("../component"));
8
- const dot_1 = __importDefault(require("../dot"));
9
- // TODO: make text and links mutable by making them properties.
10
- class NavLink extends component_1.default {
11
- constructor(content, href) {
12
- super();
13
- this.content = content;
14
- this.hRef = href;
15
- }
16
- builder() {
17
- return dot_1.default.a(this.content).hRef(this.hRef).onClick(e => {
18
- e.preventDefault();
19
- dot_1.default.navigate(this.hRef);
20
- });
21
- }
22
- }
23
- exports.NavLink = NavLink;
24
- //# sourceMappingURL=nav-link.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"nav-link.js","sourceRoot":"","sources":["../../src/built-in-components/nav-link.ts"],"names":[],"mappings":";;;;;;AAAA,6DAAqC;AACrC,iDAAyB;AAGzB,+DAA+D;AAC/D,MAAa,OAAQ,SAAQ,mBAAS;IAGrC,YAAY,OAAmB,EAAE,IAAY;QAC5C,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IAClB,CAAC;IAED,OAAO;QACN,OAAO,aAAG,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACtD,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,aAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;IACJ,CAAC;CACD;AAfD,0BAeC"}
@@ -1,57 +0,0 @@
1
- import Component from "../component";
2
- interface RouterParams {
3
- autoNavigate: boolean;
4
- onNavigateInit: Function;
5
- onError: Function;
6
- onResponse: Function;
7
- onComplete: Function;
8
- routes: Array<{
9
- path: string;
10
- }>;
11
- }
12
- export default class DotRouter extends Component {
13
- static allRouters: {
14
- [key: string]: DotRouter;
15
- };
16
- static routerId: number;
17
- static mayRedirect: boolean;
18
- static _get(url: any, success: any, fail: any): void;
19
- static routerEventSet: boolean;
20
- static setupPopupFunction(): void;
21
- id: number;
22
- outlet: Element;
23
- navId: number;
24
- currentRoute: string;
25
- currentParams: RouterParams;
26
- params: RouterParams;
27
- routesAndSegments: Array<{
28
- path: string;
29
- segments: string[];
30
- }>;
31
- constructor(params: RouterParams);
32
- /**
33
- * TODO: convert to interface.
34
- * @param {Object} params - Parameters.
35
- * @param {Array.<{path: string, title: string, component: Object}>} params.routes - Array of routes.
36
- * @param {boolean} params.autoNavigate - Router will automatically navigate when outlet is created.
37
- * @param {Function} params.onNavigateInit - Occurs before any request is sent, and before the router outlet is emptied.
38
- * @param {Function} params.onError - Occurs in the event of an HTTP error.
39
- * @param {Function} params.onResponse - Occurs after a successful HTTP response, but before rendering.
40
- * @param {Function} params.onComplete - Occurs after an uncancelled route completes without an error.
41
- */
42
- builder(): import("../i-dot").IDotElementDocument<import("../i-dot").IDotGenericElement>;
43
- registered(): void;
44
- ready(): void;
45
- deleting(): void;
46
- navigate(path: string, noHistory?: boolean, force?: boolean): {
47
- cancel: () => void;
48
- element: Element;
49
- httpResponse: any;
50
- isNew: boolean;
51
- params: any;
52
- path: string;
53
- title: any;
54
- wasCancelled: boolean;
55
- };
56
- }
57
- export {};