@domql/element 2.5.198 → 3.0.0

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 (150) hide show
  1. package/README.md +1 -1
  2. package/__tests__/checkIfOnUpdate.test.js +103 -0
  3. package/__tests__/children.test.js +213 -0
  4. package/__tests__/define.test.js +75 -0
  5. package/__tests__/inheritStateUpdates.test.js +79 -0
  6. package/__tests__/renderElement.test.js +131 -0
  7. package/__tests__/resetElement.test.js +44 -0
  8. package/__tests__/set.test.js +316 -0
  9. package/__tests__/throughExecProps.test.js +86 -0
  10. package/__tests__/throughInitialDefine.test.js +104 -0
  11. package/__tests__/throughInitialExec.test.js +92 -0
  12. package/__tests__/throughUpdatedDefine.test.js +92 -0
  13. package/__tests__/throughUpdatedExec.test.js +110 -0
  14. package/__tests__/tree.test.js +15 -0
  15. package/__tests__/update.test.js +253 -0
  16. package/children.js +105 -0
  17. package/create.js +125 -255
  18. package/dist/cjs/__tests__/checkIfOnUpdate.test.js +73 -0
  19. package/dist/cjs/__tests__/children.test.js +177 -0
  20. package/dist/cjs/__tests__/define.test.js +75 -0
  21. package/dist/cjs/__tests__/inheritStateUpdates.test.js +62 -0
  22. package/dist/cjs/__tests__/renderElement.test.js +138 -0
  23. package/dist/cjs/__tests__/resetElement.test.js +35 -0
  24. package/dist/cjs/__tests__/set.test.js +256 -0
  25. package/dist/cjs/__tests__/throughExecProps.test.js +62 -0
  26. package/dist/cjs/__tests__/throughInitialDefine.test.js +79 -0
  27. package/dist/cjs/__tests__/throughInitialExec.test.js +73 -0
  28. package/dist/cjs/__tests__/throughUpdatedDefine.test.js +69 -0
  29. package/dist/cjs/__tests__/throughUpdatedExec.test.js +84 -0
  30. package/dist/cjs/__tests__/tree.test.js +11 -0
  31. package/dist/cjs/__tests__/update.test.js +219 -0
  32. package/dist/cjs/children.js +87 -0
  33. package/dist/cjs/create.js +74 -215
  34. package/dist/cjs/define.js +1 -2
  35. package/dist/cjs/index.js +3 -3
  36. package/dist/cjs/iterate.js +37 -30
  37. package/dist/cjs/methods/set.js +26 -25
  38. package/dist/cjs/methods/v2.js +7 -17
  39. package/dist/cjs/mixins/attr.js +7 -10
  40. package/dist/cjs/mixins/classList.js +8 -16
  41. package/dist/cjs/mixins/data.js +2 -4
  42. package/dist/cjs/mixins/html.js +2 -4
  43. package/dist/cjs/mixins/index.js +0 -4
  44. package/dist/cjs/mixins/registry.js +7 -67
  45. package/dist/cjs/mixins/scope.js +2 -3
  46. package/dist/cjs/mixins/state.js +4 -7
  47. package/dist/cjs/mixins/style.js +2 -4
  48. package/dist/cjs/mixins/text.js +5 -8
  49. package/dist/cjs/node.js +34 -30
  50. package/dist/cjs/set.js +112 -47
  51. package/dist/cjs/update.js +123 -92
  52. package/dist/cjs/utils/applyParam.js +3 -4
  53. package/dist/cjs/utils/index.js +8 -4
  54. package/dist/cjs/utils/onlyResolveExtends.js +14 -30
  55. package/dist/esm/__tests__/checkIfOnUpdate.test.js +73 -0
  56. package/dist/esm/__tests__/children.test.js +177 -0
  57. package/dist/esm/__tests__/define.test.js +53 -0
  58. package/dist/esm/__tests__/inheritStateUpdates.test.js +62 -0
  59. package/dist/esm/__tests__/renderElement.test.js +116 -0
  60. package/dist/esm/__tests__/resetElement.test.js +35 -0
  61. package/dist/esm/__tests__/set.test.js +256 -0
  62. package/dist/esm/__tests__/throughExecProps.test.js +62 -0
  63. package/dist/esm/__tests__/throughInitialDefine.test.js +79 -0
  64. package/dist/esm/__tests__/throughInitialExec.test.js +73 -0
  65. package/dist/esm/__tests__/throughUpdatedDefine.test.js +69 -0
  66. package/dist/esm/__tests__/throughUpdatedExec.test.js +84 -0
  67. package/dist/esm/__tests__/tree.test.js +11 -0
  68. package/dist/esm/__tests__/update.test.js +219 -0
  69. package/dist/esm/children.js +81 -0
  70. package/dist/esm/create.js +79 -226
  71. package/dist/esm/define.js +1 -2
  72. package/dist/esm/iterate.js +41 -33
  73. package/dist/esm/methods/set.js +5 -4
  74. package/dist/esm/methods/v2.js +7 -17
  75. package/dist/esm/mixins/attr.js +8 -11
  76. package/dist/esm/mixins/classList.js +8 -16
  77. package/dist/esm/mixins/data.js +3 -5
  78. package/dist/esm/mixins/html.js +2 -4
  79. package/dist/esm/mixins/index.js +0 -4
  80. package/dist/esm/mixins/registry.js +7 -67
  81. package/dist/esm/mixins/scope.js +2 -3
  82. package/dist/esm/mixins/state.js +5 -8
  83. package/dist/esm/mixins/style.js +2 -4
  84. package/dist/esm/mixins/text.js +6 -12
  85. package/dist/esm/node.js +25 -31
  86. package/dist/esm/set.js +112 -47
  87. package/dist/esm/update.js +127 -97
  88. package/dist/esm/utils/applyParam.js +3 -4
  89. package/dist/esm/utils/index.js +4 -3
  90. package/dist/esm/utils/onlyResolveExtends.js +22 -31
  91. package/iterate.js +44 -26
  92. package/methods/set.js +5 -4
  93. package/methods/v2.js +5 -4
  94. package/mixins/attr.js +13 -7
  95. package/mixins/classList.js +7 -2
  96. package/mixins/data.js +1 -1
  97. package/mixins/index.js +1 -6
  98. package/mixins/registry.js +6 -53
  99. package/mixins/scope.js +1 -1
  100. package/mixins/state.js +4 -5
  101. package/mixins/text.js +4 -7
  102. package/node.js +31 -28
  103. package/package.json +7 -6
  104. package/set.js +129 -41
  105. package/update.js +169 -89
  106. package/utils/applyParam.js +7 -4
  107. package/utils/index.js +1 -3
  108. package/utils/onlyResolveExtends.js +27 -16
  109. package/cache/index.js +0 -3
  110. package/cache/options.js +0 -4
  111. package/dist/cjs/cache/index.js +0 -24
  112. package/dist/cjs/cache/options.js +0 -26
  113. package/dist/cjs/extend.js +0 -85
  114. package/dist/cjs/methods/index.js +0 -353
  115. package/dist/cjs/mixins/content.js +0 -74
  116. package/dist/cjs/props/create.js +0 -98
  117. package/dist/cjs/props/ignore.js +0 -24
  118. package/dist/cjs/props/index.js +0 -21
  119. package/dist/cjs/props/inherit.js +0 -53
  120. package/dist/cjs/props/update.js +0 -37
  121. package/dist/cjs/utils/component.js +0 -77
  122. package/dist/cjs/utils/extendUtils.js +0 -142
  123. package/dist/cjs/utils/object.js +0 -179
  124. package/dist/cjs/utils/propEvents.js +0 -41
  125. package/dist/esm/cache/index.js +0 -4
  126. package/dist/esm/cache/options.js +0 -6
  127. package/dist/esm/extend.js +0 -71
  128. package/dist/esm/methods/index.js +0 -333
  129. package/dist/esm/mixins/content.js +0 -54
  130. package/dist/esm/props/create.js +0 -78
  131. package/dist/esm/props/ignore.js +0 -4
  132. package/dist/esm/props/index.js +0 -4
  133. package/dist/esm/props/inherit.js +0 -33
  134. package/dist/esm/props/update.js +0 -17
  135. package/dist/esm/utils/component.js +0 -65
  136. package/dist/esm/utils/extendUtils.js +0 -122
  137. package/dist/esm/utils/object.js +0 -159
  138. package/dist/esm/utils/propEvents.js +0 -21
  139. package/extend.js +0 -90
  140. package/methods/index.js +0 -317
  141. package/mixins/content.js +0 -55
  142. package/props/create.js +0 -87
  143. package/props/ignore.js +0 -3
  144. package/props/index.js +0 -6
  145. package/props/inherit.js +0 -35
  146. package/props/update.js +0 -17
  147. package/utils/component.js +0 -68
  148. package/utils/extendUtils.js +0 -134
  149. package/utils/object.js +0 -172
  150. package/utils/propEvents.js +0 -19
@@ -1,71 +0,0 @@
1
- import { isFunction, exec } from "@domql/utils";
2
- import {
3
- getExtendStack,
4
- jointStacks,
5
- cloneAndMergeArrayExtend,
6
- deepMergeExtend,
7
- fallbackStringExtend
8
- } from "./utils/index.js";
9
- const ENV = "development";
10
- let mainExtend;
11
- const applyExtend = (element, parent, options = {}) => {
12
- if (isFunction(element))
13
- element = exec(element, parent);
14
- const { props, __ref } = element;
15
- let extend = (props == null ? void 0 : props.extends) || element.extends || element.extend;
16
- const variant = props == null ? void 0 : props.variant;
17
- const context = element.context || parent.context;
18
- extend = fallbackStringExtend(extend, context, options, variant);
19
- const extendStack = getExtendStack(extend, context);
20
- if (ENV !== "test" || ENV !== "development")
21
- delete element.extend;
22
- let childExtendStack = [];
23
- if (parent) {
24
- element.parent = parent;
25
- if (!options.ignoreChildExtend && !(props && props.ignoreChildExtend)) {
26
- childExtendStack = getExtendStack(parent.childExtend, context);
27
- const ignoreChildExtendRecursive = props && props.ignoreChildExtendRecursive;
28
- if (parent.childExtendRecursive && !ignoreChildExtendRecursive) {
29
- const canExtendRecursive = element.key !== "__text";
30
- if (canExtendRecursive) {
31
- const childExtendRecursiveStack = getExtendStack(parent.childExtendRecursive, context);
32
- childExtendStack = childExtendStack.concat(childExtendRecursiveStack);
33
- element.childExtendRecursive = parent.childExtendRecursive;
34
- }
35
- }
36
- }
37
- }
38
- const extendLength = extendStack.length;
39
- const childExtendLength = childExtendStack.length;
40
- let stack = [];
41
- if (extendLength && childExtendLength) {
42
- stack = jointStacks(extendStack, childExtendStack);
43
- } else if (extendLength) {
44
- stack = extendStack;
45
- } else if (childExtendLength) {
46
- stack = childExtendStack;
47
- } else if (!context.defaultExtends)
48
- return element;
49
- if (context.defaultExtends) {
50
- if (!mainExtend) {
51
- const defaultOptionsExtend = getExtendStack(context.defaultExtends, context);
52
- mainExtend = cloneAndMergeArrayExtend(defaultOptionsExtend);
53
- delete mainExtend.extend;
54
- }
55
- stack = [].concat(stack, mainExtend);
56
- }
57
- if (__ref)
58
- __ref.__extend = stack;
59
- let mergedExtend = cloneAndMergeArrayExtend(stack);
60
- const COMPONENTS = context && context.components || options.components;
61
- const component = exec(element.component || mergedExtend.component, element);
62
- if (component && COMPONENTS && COMPONENTS[component]) {
63
- const componentExtend = cloneAndMergeArrayExtend(getExtendStack(COMPONENTS[component]));
64
- mergedExtend = deepMergeExtend(componentExtend, mergedExtend);
65
- }
66
- const merged = deepMergeExtend(element, mergedExtend);
67
- return merged;
68
- };
69
- export {
70
- applyExtend
71
- };
@@ -1,333 +0,0 @@
1
- import { triggerEventOn } from "@domql/event";
2
- import { isDefined, isObject, isFunction, isObjectLike, isProduction, removeValueFromArray, deepClone } from "@domql/utils";
3
- import { TREE } from "../tree.js";
4
- import { parseFilters, REGISTRY } from "../mixins/index.js";
5
- const ENV = "development";
6
- function spotByPath(path) {
7
- const element = this;
8
- const arr = [].concat(path);
9
- let active = TREE[arr[0]];
10
- if (!arr || !arr.length)
11
- return console.log(arr, "on", element.key, "is undefined");
12
- while (active.key === arr[0]) {
13
- arr.shift();
14
- if (!arr.length)
15
- break;
16
- active = active[arr[0]];
17
- if (!active)
18
- return;
19
- }
20
- return active;
21
- }
22
- function lookup(param) {
23
- const el = this;
24
- let { parent } = el;
25
- if (isFunction(param)) {
26
- if (parent.state && param(parent, parent.state, parent.context))
27
- return parent;
28
- else if (parent.parent)
29
- return parent.lookup(param);
30
- else
31
- return;
32
- }
33
- if (el[param])
34
- return el[param];
35
- while (parent.param !== param) {
36
- if (parent[param])
37
- return parent[param];
38
- parent = parent.parent;
39
- if (!parent)
40
- return;
41
- }
42
- return parent;
43
- }
44
- function lookdown(param) {
45
- var _a;
46
- const el = this;
47
- const { __ref: ref } = el;
48
- const children = ref.__children;
49
- for (let i = 0; i < children.length; i++) {
50
- const v = children[i];
51
- const childElem = el[v];
52
- if (v === param)
53
- return childElem;
54
- else if (isFunction(param)) {
55
- const exec = param(childElem, childElem.state, childElem.context);
56
- if (childElem.state && exec) {
57
- return childElem;
58
- }
59
- }
60
- const lookdown2 = (_a = childElem == null ? void 0 : childElem.lookdown) == null ? void 0 : _a.call(childElem, param);
61
- if (lookdown2)
62
- return lookdown2;
63
- }
64
- }
65
- function lookdownAll(param, results = []) {
66
- var _a;
67
- const el = this;
68
- const { __ref: ref } = el;
69
- const children = ref.__children;
70
- for (let i = 0; i < children.length; i++) {
71
- const v = children[i];
72
- const childElem = el[v];
73
- if (v === param)
74
- results.push(childElem);
75
- else if (isFunction(param)) {
76
- const exec = param(childElem, childElem.state, childElem.context);
77
- if (childElem.state && exec)
78
- results.push(childElem);
79
- }
80
- (_a = childElem == null ? void 0 : childElem.lookdownAll) == null ? void 0 : _a.call(childElem, param, results);
81
- }
82
- return results.length ? results : void 0;
83
- }
84
- function setNodeStyles(params = {}) {
85
- var _a;
86
- const el = this;
87
- if (!((_a = el.node) == null ? void 0 : _a.style))
88
- return;
89
- for (const param in params) {
90
- const value = params[param];
91
- const childElem = el[param];
92
- if (isObject(value) && childElem)
93
- setNodeStyles.call(childElem, value);
94
- else
95
- el.node.style[param] = value;
96
- }
97
- return el;
98
- }
99
- function remove(opts) {
100
- const element = this;
101
- const beforeRemoveReturns = triggerEventOn("beforeRemove", element, opts);
102
- if (beforeRemoveReturns === false)
103
- return element;
104
- if (isFunction(element.node.remove))
105
- element.node.remove();
106
- else if (!isProduction()) {
107
- console.warn("This item cant be removed");
108
- element.log();
109
- }
110
- delete element.parent[element.key];
111
- if (element.parent.__ref)
112
- element.parent.__ref.__children = removeValueFromArray(element.parent.__ref.__children, element.key);
113
- triggerEventOn("remove", element, opts);
114
- }
115
- function get(param) {
116
- const element = this;
117
- return element[param];
118
- }
119
- function setProps(param, options) {
120
- const element = this;
121
- if (!param || !element.props)
122
- return;
123
- element.update({ props: param }, options);
124
- return element;
125
- }
126
- function getRef() {
127
- return this.__ref;
128
- }
129
- function getPath() {
130
- return this.getRef().path;
131
- }
132
- const defineSetter = (element, key, get2, set) => Object.defineProperty(element, key, { get: get2, set });
133
- function keys() {
134
- const element = this;
135
- const keys2 = [];
136
- for (const param in element) {
137
- if (REGISTRY[param] && !parseFilters.elementKeys.includes(param) || !Object.hasOwnProperty.call(element, param)) {
138
- continue;
139
- }
140
- keys2.push(param);
141
- }
142
- return keys2;
143
- }
144
- function parse(excl = []) {
145
- const element = this;
146
- const obj = {};
147
- const keyList = keys.call(element);
148
- keyList.forEach((v) => {
149
- if (excl.includes(v))
150
- return;
151
- const val = element[v];
152
- if (v === "state") {
153
- if (element.__ref && !element.__ref.__hasRootState)
154
- return;
155
- const parsedVal = isFunction(val && val.parse) ? val.parse() : val;
156
- obj[v] = isFunction(parsedVal) ? parsedVal : JSON.parse(JSON.stringify(parsedVal || {}));
157
- } else if (v === "scope") {
158
- if (element.__ref && !element.__ref.__hasRootScope)
159
- return;
160
- obj[v] = JSON.parse(JSON.stringify(val || {}));
161
- } else if (v === "props") {
162
- const { __element, update, ...props } = element[v];
163
- obj[v] = props;
164
- } else if (isDefined(val) && Object.hasOwnProperty.call(element, v))
165
- obj[v] = val;
166
- });
167
- return obj;
168
- }
169
- function parseDeep(excl = []) {
170
- const element = this;
171
- const obj = parse.call(element, excl);
172
- for (const v in obj) {
173
- if (excl.includes(v))
174
- return;
175
- if (isObjectLike(obj[v])) {
176
- obj[v] = parseDeep.call(obj[v], excl);
177
- }
178
- }
179
- return obj;
180
- }
181
- function verbose(...args) {
182
- if (ENV !== "test" && ENV !== "development")
183
- return;
184
- const element = this;
185
- const { __ref: ref } = element;
186
- console.groupCollapsed(element.key);
187
- if (args.length) {
188
- args.forEach((v) => console.log(`%c${v}:
189
- `, "font-weight: bold", element[v]));
190
- } else {
191
- console.log(ref.path);
192
- const keys2 = element.keys();
193
- keys2.forEach((v) => console.log(`%c${v}:`, "font-weight: bold", element[v]));
194
- }
195
- console.log(element);
196
- console.groupEnd(element.key);
197
- return element;
198
- }
199
- function log(...params) {
200
- if (ENV === "test" || ENV === "development") {
201
- console.log(...params);
202
- }
203
- }
204
- function warn(...params) {
205
- if (ENV === "test" || ENV === "development") {
206
- console.warn(...params);
207
- }
208
- }
209
- function error(...params) {
210
- var _a, _b;
211
- if (ENV === "test" || ENV === "development") {
212
- if ((_a = params[params.length - 1]) == null ? void 0 : _a.debugger)
213
- debugger;
214
- if ((_b = params[params.length - 1]) == null ? void 0 : _b.verbose)
215
- verbose.call(this);
216
- throw new Error(...params);
217
- }
218
- }
219
- function nextElement() {
220
- const element = this;
221
- const { key, parent } = element;
222
- const { __children } = parent.__ref;
223
- const currentIndex = __children.indexOf(key);
224
- const nextChild = __children[currentIndex + 1];
225
- return parent[nextChild];
226
- }
227
- function previousElement(el) {
228
- const element = el || this;
229
- const { key, parent } = element;
230
- const { __children } = parent.__ref;
231
- if (!__children)
232
- return;
233
- const currentIndex = __children.indexOf(key);
234
- return parent[__children[currentIndex - 1]];
235
- }
236
- function variables(obj = {}) {
237
- const element = this;
238
- if (!element.data)
239
- element.data = {};
240
- if (!element.data.varCaches)
241
- element.data.varCaches = {};
242
- const varCaches = element.data.varCaches;
243
- const changes = {};
244
- let changed;
245
- for (const key in obj) {
246
- if (obj[key] !== varCaches[key]) {
247
- changed = true;
248
- changes[key] = obj[key];
249
- }
250
- }
251
- return {
252
- changed: (cb) => {
253
- if (!changed)
254
- return;
255
- const returns = cb(changes, deepClone(varCaches));
256
- for (const key in changes) {
257
- varCaches[key] = changes[key];
258
- }
259
- return returns;
260
- },
261
- timeout: (cb, timeout) => {
262
- if (!changed)
263
- return;
264
- const t = setTimeout(() => {
265
- cb(changes);
266
- clearTimeout(t);
267
- }, timeout);
268
- }
269
- };
270
- }
271
- function call(fnKey, ...args) {
272
- var _a;
273
- const context = this.context;
274
- return (_a = context.utils[fnKey] || context.functions[fnKey] || context.methods[fnKey] || context.snippets[fnKey]) == null ? void 0 : _a.call(this, ...args);
275
- }
276
- const METHODS = [
277
- "set",
278
- "reset",
279
- "update",
280
- "remove",
281
- "updateContent",
282
- "removeContent",
283
- "lookup",
284
- "lookdown",
285
- "lookdownAll",
286
- "getRef",
287
- "getPath",
288
- "setNodeStyles",
289
- "spotByPath",
290
- "keys",
291
- "parse",
292
- "setProps",
293
- "parseDeep",
294
- "variables",
295
- "if",
296
- "log",
297
- "verbose",
298
- "warn",
299
- "error",
300
- "call",
301
- "nextElement",
302
- "previousElement"
303
- ];
304
- function isMethod(param, element) {
305
- var _a, _b;
306
- return METHODS.includes(param) || ((_b = (_a = element == null ? void 0 : element.context) == null ? void 0 : _a.methods) == null ? void 0 : _b[param]);
307
- }
308
- export {
309
- METHODS,
310
- call,
311
- defineSetter,
312
- error,
313
- get,
314
- getPath,
315
- getRef,
316
- isMethod,
317
- keys,
318
- log,
319
- lookdown,
320
- lookdownAll,
321
- lookup,
322
- nextElement,
323
- parse,
324
- parseDeep,
325
- previousElement,
326
- remove,
327
- setNodeStyles,
328
- setProps,
329
- spotByPath,
330
- variables,
331
- verbose,
332
- warn
333
- };
@@ -1,54 +0,0 @@
1
- import { isFunction, setContentKey } from "@domql/utils";
2
- import { set } from "../set.js";
3
- const updateContent = function(params, options) {
4
- const element = this;
5
- const ref = element.__ref;
6
- const contentKey = ref.contentElementKey;
7
- if (!element[contentKey])
8
- return;
9
- if (element[contentKey].update)
10
- element[contentKey].update(params, options);
11
- };
12
- const removeContent = function(el, opts = {}) {
13
- const element = el || this;
14
- const { __ref: ref } = element;
15
- const contentElementKey = setContentKey(element, opts);
16
- if (opts.contentElementKey !== "content")
17
- opts.contentElementKey = "content";
18
- if (element[contentElementKey]) {
19
- if (element[contentElementKey].node && element.node) {
20
- if (element[contentElementKey].tag === "fragment")
21
- element.node.innerHTML = "";
22
- else {
23
- const contentNode = element[contentElementKey].node;
24
- if (contentNode.parentNode === element.node)
25
- element.node.removeChild(element[contentElementKey].node);
26
- }
27
- }
28
- const { __cached } = ref;
29
- if (__cached && __cached[contentElementKey]) {
30
- if (__cached[contentElementKey].tag === "fragment")
31
- __cached[contentElementKey].parent.node.innerHTML = "";
32
- else if (__cached[contentElementKey] && isFunction(__cached[contentElementKey].remove))
33
- __cached[contentElementKey].remove();
34
- }
35
- delete element[contentElementKey];
36
- }
37
- };
38
- function setContent(param, element, node, opts) {
39
- const contentElementKey = setContentKey(element, opts);
40
- if (param && element) {
41
- if (element[contentElementKey].update) {
42
- element[contentElementKey].update({}, opts);
43
- } else {
44
- set.call(element, param, opts);
45
- }
46
- }
47
- }
48
- var content_default = setContent;
49
- export {
50
- content_default as default,
51
- removeContent,
52
- setContent,
53
- updateContent
54
- };
@@ -1,78 +0,0 @@
1
- import { exec, isArray, isObject, deepClone, deepMerge } from "@domql/utils";
2
- import { IGNORE_PROPS_PARAMS } from "./ignore.js";
3
- import { inheritParentProps } from "./inherit.js";
4
- const createPropsStack = (element, parent) => {
5
- const { props, __ref: ref } = element;
6
- const propsStack = ref.__props = inheritParentProps(element, parent);
7
- if (isObject(props))
8
- propsStack.push(props);
9
- else if (props === "inherit" && parent.props)
10
- propsStack.push(parent.props);
11
- else if (props)
12
- propsStack.push(props);
13
- if (isArray(ref.__extend)) {
14
- ref.__extend.forEach((extend) => {
15
- if (extend.props && extend.props !== props)
16
- propsStack.push(extend.props);
17
- });
18
- }
19
- ref.__props = propsStack;
20
- return propsStack;
21
- };
22
- const syncProps = (props, element, opts) => {
23
- element.props = {};
24
- const mergedProps = {};
25
- props.forEach((v) => {
26
- if (IGNORE_PROPS_PARAMS.includes(v))
27
- return;
28
- let execProps;
29
- try {
30
- execProps = exec(v, element);
31
- } catch (e) {
32
- element.error(e, opts);
33
- }
34
- element.props = deepMerge(
35
- mergedProps,
36
- deepClone(execProps, { ignore: IGNORE_PROPS_PARAMS }),
37
- IGNORE_PROPS_PARAMS
38
- );
39
- });
40
- element.props = mergedProps;
41
- const methods = { update: update.bind(element.props), __element: element };
42
- Object.setPrototypeOf(element.props, methods);
43
- return element.props;
44
- };
45
- const createProps = function(element, parent, options) {
46
- const { __ref: ref } = element;
47
- const applyProps = () => {
48
- const propsStack = options.cachedProps || createPropsStack(element, parent);
49
- if (propsStack.length) {
50
- ref.__props = propsStack;
51
- syncProps(propsStack, element);
52
- } else {
53
- ref.__props = options.cachedProps || [];
54
- element.props = {};
55
- }
56
- };
57
- if (ref.__if)
58
- applyProps();
59
- else {
60
- try {
61
- applyProps();
62
- } catch {
63
- element.props = {};
64
- ref.__props = options.cachedProps || [];
65
- }
66
- }
67
- const methods = { update: update.bind(element.props), __element: element };
68
- Object.setPrototypeOf(element.props, methods);
69
- return element;
70
- };
71
- function update(props, options) {
72
- const element = this.__element;
73
- element.update({ props }, options);
74
- }
75
- export {
76
- createProps,
77
- syncProps
78
- };
@@ -1,4 +0,0 @@
1
- const IGNORE_PROPS_PARAMS = ["update", "__element"];
2
- export {
3
- IGNORE_PROPS_PARAMS
4
- };
@@ -1,4 +0,0 @@
1
- export * from "./ignore.js";
2
- export * from "./create.js";
3
- export * from "./inherit.js";
4
- export * from "./update.js";
@@ -1,33 +0,0 @@
1
- import { exec, is, isString } from "@domql/utils";
2
- const objectizeStringProperty = (propValue) => {
3
- if (is(propValue)("string", "number")) {
4
- return { inheritedString: propValue };
5
- }
6
- return propValue;
7
- };
8
- const inheritParentProps = (element, parent) => {
9
- var _a;
10
- let propsStack = [];
11
- const parentProps = exec(parent, parent.state).props;
12
- const matchParent = parent.props && parentProps[element.key];
13
- const matchParentIsString = isString(matchParent);
14
- const matchParentChildProps = parentProps && parentProps.childProps;
15
- if (matchParent) {
16
- if (matchParentIsString) {
17
- const inheritedStringExists = propsStack.filter((v) => v.inheritedString)[0];
18
- if (inheritedStringExists)
19
- inheritedStringExists.inheritedString = matchParent;
20
- else {
21
- propsStack = [].concat(objectizeStringProperty(matchParent), propsStack);
22
- }
23
- } else {
24
- propsStack.push(objectizeStringProperty(matchParent));
25
- }
26
- }
27
- if (matchParentChildProps && !((_a = element == null ? void 0 : element.props) == null ? void 0 : _a.ignoreChildProps))
28
- propsStack.push(matchParentChildProps);
29
- return propsStack;
30
- };
31
- export {
32
- inheritParentProps
33
- };
@@ -1,17 +0,0 @@
1
- import { syncProps } from "./create.js";
2
- import { inheritParentProps } from "./inherit.js";
3
- const updateProps = (newProps, element, parent) => {
4
- const { __ref } = element;
5
- let propsStack = __ref.__props;
6
- const parentProps = inheritParentProps(element, parent);
7
- if (parentProps.length)
8
- propsStack = __ref.__props = [].concat(parentProps, propsStack);
9
- if (newProps)
10
- propsStack = __ref.__props = [].concat(newProps, propsStack);
11
- if (propsStack)
12
- syncProps(propsStack, element);
13
- return element;
14
- };
15
- export {
16
- updateProps
17
- };
@@ -1,65 +0,0 @@
1
- import {
2
- isObject,
3
- isString,
4
- overwriteDeep,
5
- checkIfKeyIsComponent,
6
- addAdditionalExtend,
7
- hasVariantProp,
8
- isVariant
9
- } from "@domql/utils";
10
- import { applyExtend } from "../extend.js";
11
- import { REGISTRY } from "../mixins/index.js";
12
- const createValidDomqlObjectFromSugar = (el, parent, key, options) => {
13
- const newElem = {
14
- props: {},
15
- define: {}
16
- };
17
- const allowedKeys = ["data", "state", "attr", "if"];
18
- for (const k in el) {
19
- const value = el[k];
20
- const isComponent = checkIfKeyIsComponent(k);
21
- const isRegistry = REGISTRY[k];
22
- if (isComponent || isRegistry || allowedKeys.includes(k)) {
23
- newElem[k] = value;
24
- } else {
25
- newElem.props[k] = value;
26
- }
27
- }
28
- return newElem;
29
- };
30
- const overwriteVariant = (element, variant, variantProps) => {
31
- let variantElement = element[variant];
32
- if (!variantElement)
33
- return;
34
- const props = isObject(variantProps) ? variantProps : {};
35
- if (isString(variantElement)) {
36
- variantElement = {
37
- extend: [{ props }, variantElement]
38
- };
39
- } else if (variantElement.extend) {
40
- variantElement = addAdditionalExtend({ props }, variantElement);
41
- }
42
- const extendedVariant = applyExtend(variantElement, element.parent);
43
- const { parent, ...rest } = extendedVariant;
44
- return overwriteDeep(element, rest);
45
- };
46
- const applyVariant = (element) => {
47
- const { props } = element;
48
- if (!hasVariantProp(element))
49
- return element;
50
- const { variant } = props;
51
- overwriteVariant(element, `.${variant}`);
52
- const elKeys = Object.keys(element).filter((key) => isVariant(key));
53
- elKeys.forEach((variant2) => {
54
- const slicedVariantElementKey = variant2.slice(1);
55
- const variantElementProps = props[slicedVariantElementKey];
56
- if (variantElementProps)
57
- overwriteVariant(element, variant2, variantElementProps);
58
- });
59
- return element;
60
- };
61
- export {
62
- applyVariant,
63
- createValidDomqlObjectFromSugar,
64
- overwriteVariant
65
- };