@domql/element 2.4.0 → 2.4.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 (61) hide show
  1. package/cache/index.js +3 -0
  2. package/cache/options.js +3 -0
  3. package/dist/cjs/cache/index.js +24 -0
  4. package/dist/cjs/cache/options.js +24 -0
  5. package/dist/cjs/methods/index.js +186 -0
  6. package/dist/cjs/{set.js → methods/set.js} +24 -24
  7. package/dist/cjs/methods/v2.js +109 -0
  8. package/dist/cjs/mixins/attr.js +42 -0
  9. package/dist/cjs/mixins/classList.js +73 -0
  10. package/dist/cjs/mixins/content.js +75 -0
  11. package/dist/cjs/{define.js → mixins/data.js} +14 -12
  12. package/dist/cjs/mixins/html.js +35 -0
  13. package/dist/cjs/{index.js → mixins/index.js} +23 -15
  14. package/dist/cjs/mixins/registry.js +89 -0
  15. package/dist/cjs/mixins/state.js +40 -0
  16. package/dist/cjs/{tree.js → mixins/style.js} +11 -9
  17. package/dist/cjs/mixins/text.js +60 -0
  18. package/dist/cjs/props/create.js +77 -0
  19. package/dist/cjs/props/ignore.js +24 -0
  20. package/dist/cjs/props/index.js +21 -0
  21. package/dist/cjs/props/inherit.js +52 -0
  22. package/dist/cjs/props/update.js +37 -0
  23. package/dist/cjs/test/create.test.js +51 -0
  24. package/dist/cjs/test/set.test.js +9 -0
  25. package/dist/cjs/test/update.test.js +8 -0
  26. package/dist/cjs/utils/component.js +133 -0
  27. package/dist/cjs/utils/extendUtils.js +144 -0
  28. package/dist/cjs/utils/index.js +20 -0
  29. package/dist/cjs/utils/object.js +142 -0
  30. package/methods/index.js +165 -0
  31. package/methods/set.js +41 -0
  32. package/methods/v2.js +82 -0
  33. package/mixins/attr.js +23 -0
  34. package/mixins/classList.js +48 -0
  35. package/mixins/content.js +47 -0
  36. package/mixins/data.js +21 -0
  37. package/mixins/html.js +20 -0
  38. package/mixins/index.js +23 -0
  39. package/mixins/registry.js +66 -0
  40. package/mixins/state.js +20 -0
  41. package/mixins/style.js +14 -0
  42. package/mixins/text.js +41 -0
  43. package/package.json +5 -4
  44. package/props/create.js +60 -0
  45. package/props/ignore.js +3 -0
  46. package/props/index.js +6 -0
  47. package/props/inherit.js +34 -0
  48. package/props/update.js +17 -0
  49. package/test/create.test.js +61 -0
  50. package/test/set.test.js +13 -0
  51. package/test/update.test.js +13 -0
  52. package/utils/component.js +112 -0
  53. package/utils/extendUtils.js +118 -0
  54. package/utils/index.js +5 -0
  55. package/utils/object.js +141 -0
  56. package/dist/cjs/applyParam.js +0 -41
  57. package/dist/cjs/create.js +0 -262
  58. package/dist/cjs/extend.js +0 -87
  59. package/dist/cjs/iterate.js +0 -108
  60. package/dist/cjs/node.js +0 -85
  61. package/dist/cjs/update.js +0 -223
@@ -0,0 +1,133 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var component_exports = {};
20
+ __export(component_exports, {
21
+ addAdditionalExtend: () => addAdditionalExtend,
22
+ applyComponentFromContext: () => applyComponentFromContext,
23
+ applyKeyComponentAsExtend: () => applyKeyComponentAsExtend,
24
+ applyVariant: () => applyVariant,
25
+ checkIfKeyIsComponent: () => checkIfKeyIsComponent,
26
+ extendizeByKey: () => extendizeByKey,
27
+ hasVariantProp: () => hasVariantProp,
28
+ isVariant: () => isVariant,
29
+ overwriteVariant: () => overwriteVariant
30
+ });
31
+ module.exports = __toCommonJS(component_exports);
32
+ var import_utils = require("@domql/utils");
33
+ var import_extend = require("../extend");
34
+ const ENV = "development";
35
+ const checkIfKeyIsComponent = (key) => {
36
+ const isFirstKeyString = (0, import_utils.isString)(key);
37
+ if (!isFirstKeyString)
38
+ return;
39
+ const firstCharKey = key.slice(0, 1);
40
+ return /^[A-Z]*$/.test(firstCharKey);
41
+ };
42
+ const addAdditionalExtend = (newExtend, element) => {
43
+ const { extend } = element;
44
+ const preserveExtend = (0, import_utils.isArray)(extend) ? extend : [extend];
45
+ return {
46
+ ...element,
47
+ extend: [newExtend].concat(preserveExtend)
48
+ };
49
+ };
50
+ const extendizeByKey = (element, parent, key) => {
51
+ const { tag, extend, props, state, childExtend, childProps, on } = element;
52
+ const hasComponentAttrs = tag || extend || childExtend || props || state || on;
53
+ const componentKey = key.includes("_") ? key.split("_")[0] : key.includes(".") ? key.split(".")[0] : key;
54
+ const extendKey = componentKey || key;
55
+ if (!hasComponentAttrs || childProps) {
56
+ return {
57
+ extend: extendKey,
58
+ props: { ...element }
59
+ };
60
+ } else if (!extend || extend === true) {
61
+ return {
62
+ ...element,
63
+ extend: extendKey
64
+ };
65
+ } else if (extend) {
66
+ addAdditionalExtend(extendKey, element);
67
+ } else if ((0, import_utils.isFunction)(element)) {
68
+ return {
69
+ extend: extendKey,
70
+ props: { ...(0, import_utils.exec)(element, parent) }
71
+ };
72
+ }
73
+ };
74
+ const applyKeyComponentAsExtend = (element, parent, key) => {
75
+ return extendizeByKey(element, parent, key) || element;
76
+ };
77
+ const applyComponentFromContext = (element, parent, options) => {
78
+ const { context } = element;
79
+ const { components } = context;
80
+ const { extend } = element;
81
+ const execExtend = (0, import_utils.exec)(extend, element);
82
+ if ((0, import_utils.isString)(execExtend)) {
83
+ if (components[execExtend])
84
+ element.extend = components[execExtend];
85
+ else {
86
+ if ((ENV === "test" || ENV === "development") && options.verbose) {
87
+ console.warn(execExtend, "is not in library", components, element);
88
+ console.warn("replacing with ", {});
89
+ }
90
+ element.extend = {};
91
+ }
92
+ }
93
+ };
94
+ const isVariant = (param) => {
95
+ if (!(0, import_utils.isString)(param))
96
+ return;
97
+ const firstCharKey = param.slice(0, 1);
98
+ return firstCharKey === ".";
99
+ };
100
+ const hasVariantProp = (element) => {
101
+ const { props } = element;
102
+ if ((0, import_utils.isObject)(props) && (0, import_utils.isString)(props.variant))
103
+ return true;
104
+ };
105
+ const overwriteVariant = (element, variant, variantProps) => {
106
+ let variantElement = element[variant];
107
+ if (!variantElement)
108
+ return;
109
+ const props = (0, import_utils.isObject)(variantProps) ? variantProps : {};
110
+ if ((0, import_utils.isString)(variantElement)) {
111
+ variantElement = {
112
+ extend: [{ props }, variantElement]
113
+ };
114
+ } else if (variantElement.extend) {
115
+ variantElement = addAdditionalExtend({ props }, variantElement);
116
+ }
117
+ return (0, import_utils.overwriteDeep)(element, (0, import_extend.applyExtend)(variantElement));
118
+ };
119
+ const applyVariant = (element) => {
120
+ const { props } = element;
121
+ if (!hasVariantProp(element))
122
+ return element;
123
+ const { variant } = props;
124
+ overwriteVariant(element, `.${variant}`);
125
+ const elKeys = Object.keys(element).filter((key) => isVariant(key));
126
+ elKeys.forEach((variant2) => {
127
+ const slicedVariantElementKey = variant2.slice(1);
128
+ const variantElementProps = props[slicedVariantElementKey];
129
+ if (variantElementProps)
130
+ overwriteVariant(element, variant2, variantElementProps);
131
+ });
132
+ return element;
133
+ };
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var extendUtils_exports = {};
20
+ __export(extendUtils_exports, {
21
+ cloneAndMergeArrayExtend: () => cloneAndMergeArrayExtend,
22
+ deepCloneExtend: () => deepCloneExtend,
23
+ deepExtend: () => deepExtend,
24
+ deepMergeExtend: () => deepMergeExtend,
25
+ extendCachedRegistry: () => extendCachedRegistry,
26
+ extendStackRegistry: () => extendStackRegistry,
27
+ extractArrayExtend: () => extractArrayExtend,
28
+ flattenExtend: () => flattenExtend,
29
+ generateHash: () => generateHash,
30
+ getExtendMerged: () => getExtendMerged,
31
+ getExtendStack: () => getExtendStack,
32
+ getExtendStackRegistry: () => getExtendStackRegistry,
33
+ getHashedExtend: () => getHashedExtend,
34
+ jointStacks: () => jointStacks,
35
+ replaceStringsWithComponents: () => replaceStringsWithComponents,
36
+ setHashedExtend: () => setHashedExtend
37
+ });
38
+ module.exports = __toCommonJS(extendUtils_exports);
39
+ var import_utils = require("@domql/utils");
40
+ const generateHash = () => Math.random().toString(36).substring(2);
41
+ const extendStackRegistry = {};
42
+ const extendCachedRegistry = {};
43
+ const getHashedExtend = (extend) => {
44
+ return extendStackRegistry[extend.__hash];
45
+ };
46
+ const setHashedExtend = (extend, stack) => {
47
+ const hash = generateHash();
48
+ if (!(0, import_utils.isString)(extend)) {
49
+ extend.__hash = hash;
50
+ }
51
+ extendStackRegistry[hash] = stack;
52
+ return stack;
53
+ };
54
+ const getExtendStackRegistry = (extend, stack) => {
55
+ if (extend.__hash) {
56
+ return stack.concat(getHashedExtend(extend));
57
+ }
58
+ return setHashedExtend(extend, stack);
59
+ };
60
+ const extractArrayExtend = (extend, stack) => {
61
+ extend.forEach((each) => flattenExtend(each, stack));
62
+ return stack;
63
+ };
64
+ const deepExtend = (extend, stack) => {
65
+ const extendOflattenExtend = extend.extend;
66
+ if (extendOflattenExtend) {
67
+ flattenExtend(extendOflattenExtend, stack);
68
+ }
69
+ return stack;
70
+ };
71
+ const flattenExtend = (extend, stack) => {
72
+ if (!extend)
73
+ return stack;
74
+ if ((0, import_utils.isArray)(extend))
75
+ return extractArrayExtend(extend, stack);
76
+ stack.push(extend);
77
+ if (extend.extend)
78
+ deepExtend(extend, stack);
79
+ return stack;
80
+ };
81
+ const deepCloneExtend = (obj) => {
82
+ const o = {};
83
+ for (const prop in obj) {
84
+ if (["parent", "node", "__element"].indexOf(prop) > -1)
85
+ continue;
86
+ const objProp = obj[prop];
87
+ if ((0, import_utils.isObject)(objProp)) {
88
+ o[prop] = deepCloneExtend(objProp);
89
+ } else if ((0, import_utils.isArray)(objProp)) {
90
+ o[prop] = objProp.map((x) => x);
91
+ } else
92
+ o[prop] = objProp;
93
+ }
94
+ return o;
95
+ };
96
+ const deepMergeExtend = (element, extend) => {
97
+ for (const e in extend) {
98
+ if (["parent", "node", "__element"].indexOf(e) > -1)
99
+ continue;
100
+ const elementProp = element[e];
101
+ const extendProp = extend[e];
102
+ if (elementProp === void 0) {
103
+ element[e] = extendProp;
104
+ } else if ((0, import_utils.isObject)(elementProp) && (0, import_utils.isObject)(extendProp)) {
105
+ deepMergeExtend(elementProp, extendProp);
106
+ } else if ((0, import_utils.isArray)(elementProp) && (0, import_utils.isArray)(extendProp)) {
107
+ element[e] = elementProp.concat(extendProp);
108
+ } else if ((0, import_utils.isArray)(elementProp) && (0, import_utils.isObject)(extendProp)) {
109
+ const obj = deepMergeExtend({}, elementProp);
110
+ element[e] = deepMergeExtend(obj, extendProp);
111
+ } else if (elementProp === void 0 && (0, import_utils.isFunction)(extendProp)) {
112
+ element[e] = extendProp;
113
+ }
114
+ }
115
+ return element;
116
+ };
117
+ const cloneAndMergeArrayExtend = (stack) => {
118
+ return stack.reduce((a, c) => {
119
+ return deepMergeExtend(a, deepCloneExtend(c));
120
+ }, {});
121
+ };
122
+ const replaceStringsWithComponents = (stack, components) => {
123
+ return stack.map((v) => {
124
+ if ((0, import_utils.isString)(v))
125
+ return components[v];
126
+ else
127
+ return v;
128
+ });
129
+ };
130
+ const jointStacks = (extendStack, childExtendStack) => {
131
+ return [].concat(extendStack.slice(0, 1)).concat(childExtendStack.slice(0, 1)).concat(extendStack.slice(1)).concat(childExtendStack.slice(1));
132
+ };
133
+ const getExtendStack = (extend) => {
134
+ if (!extend)
135
+ return [];
136
+ if (extend.__hash)
137
+ return getHashedExtend(extend) || [];
138
+ const stack = flattenExtend(extend, []);
139
+ return getExtendStackRegistry(extend, stack);
140
+ };
141
+ const getExtendMerged = (extend) => {
142
+ const stack = getExtendStack(extend);
143
+ return cloneAndMergeArrayExtend(stack);
144
+ };
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __copyProps = (to, from, except, desc) => {
7
+ if (from && typeof from === "object" || typeof from === "function") {
8
+ for (let key of __getOwnPropNames(from))
9
+ if (!__hasOwnProp.call(to, key) && key !== except)
10
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
11
+ }
12
+ return to;
13
+ };
14
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
16
+ var utils_exports = {};
17
+ module.exports = __toCommonJS(utils_exports);
18
+ __reExport(utils_exports, require("./object"), module.exports);
19
+ __reExport(utils_exports, require("./extendUtils"), module.exports);
20
+ __reExport(utils_exports, require("./component"), module.exports);
@@ -0,0 +1,142 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var object_exports = {};
20
+ __export(object_exports, {
21
+ METHODS_EXL: () => METHODS_EXL,
22
+ clone: () => clone,
23
+ deepClone: () => deepClone,
24
+ deepMerge: () => deepMerge,
25
+ flattenRecursive: () => flattenRecursive,
26
+ mergeAndCloneIfArray: () => mergeAndCloneIfArray,
27
+ mergeArray: () => mergeArray,
28
+ mergeIfExisted: () => mergeIfExisted,
29
+ overwrite: () => overwrite,
30
+ overwriteDeep: () => overwriteDeep,
31
+ overwriteShallow: () => overwriteShallow
32
+ });
33
+ module.exports = __toCommonJS(object_exports);
34
+ var import_utils = require("@domql/utils");
35
+ var import_state = require("@domql/state");
36
+ var import_props = require("../props");
37
+ var import_methods = require("../methods");
38
+ const METHODS_EXL = (0, import_utils.joinArrays)(
39
+ ["node", "state", "context", "extend"],
40
+ import_methods.METHODS,
41
+ import_state.IGNORE_STATE_PARAMS,
42
+ import_props.IGNORE_PROPS_PARAMS
43
+ );
44
+ const deepMerge = (element, extend, exclude = METHODS_EXL) => {
45
+ for (const e in extend) {
46
+ if (exclude.includes(e))
47
+ continue;
48
+ const elementProp = element[e];
49
+ const extendProp = extend[e];
50
+ if (elementProp === void 0) {
51
+ element[e] = extendProp;
52
+ } else if ((0, import_utils.isObjectLike)(elementProp) && (0, import_utils.isObject)(extendProp)) {
53
+ deepMerge(elementProp, extendProp);
54
+ }
55
+ }
56
+ return element;
57
+ };
58
+ const clone = (obj, exclude = METHODS_EXL) => {
59
+ const o = {};
60
+ for (const e in obj) {
61
+ if (exclude.includes(e))
62
+ continue;
63
+ o[e] = obj[e];
64
+ }
65
+ return o;
66
+ };
67
+ const deepClone = (obj, exclude = METHODS_EXL) => {
68
+ const o = (0, import_utils.isArray)(obj) ? [] : {};
69
+ for (const e in obj) {
70
+ if (exclude.includes(e))
71
+ continue;
72
+ let objProp = obj[e];
73
+ if (e === "extend" && (0, import_utils.isArray)(objProp)) {
74
+ objProp = mergeArray(objProp, exclude);
75
+ }
76
+ if ((0, import_utils.isObjectLike)(objProp)) {
77
+ o[e] = deepClone(objProp, exclude);
78
+ } else
79
+ o[e] = objProp;
80
+ }
81
+ return o;
82
+ };
83
+ const overwrite = (element, params, options) => {
84
+ const changes = {};
85
+ const { __ref } = element;
86
+ const { __exec, __cached } = __ref;
87
+ for (const e in params) {
88
+ if (e === "props" || e === "state" || e === "__ref")
89
+ continue;
90
+ const elementProp = element[e];
91
+ const paramsProp = params[e];
92
+ if (paramsProp !== void 0) {
93
+ __cached[e] = changes[e] = elementProp;
94
+ element[e] = paramsProp;
95
+ }
96
+ if (options.cleanExec)
97
+ delete __exec[e];
98
+ }
99
+ return changes;
100
+ };
101
+ const overwriteShallow = (obj, params, exclude = METHODS_EXL) => {
102
+ for (const e in params) {
103
+ if (exclude.includes(e))
104
+ continue;
105
+ obj[e] = params[e];
106
+ }
107
+ return obj;
108
+ };
109
+ const overwriteDeep = (obj, params, exclude = METHODS_EXL) => {
110
+ for (const e in params) {
111
+ if (exclude.includes(e))
112
+ continue;
113
+ const objProp = obj[e];
114
+ const paramsProp = params[e];
115
+ if ((0, import_utils.isObjectLike)(objProp) && (0, import_utils.isObjectLike)(paramsProp)) {
116
+ overwriteDeep(objProp, paramsProp);
117
+ } else if (paramsProp !== void 0) {
118
+ obj[e] = paramsProp;
119
+ }
120
+ }
121
+ return obj;
122
+ };
123
+ const mergeIfExisted = (a, b) => {
124
+ if ((0, import_utils.isObjectLike)(a) && (0, import_utils.isObjectLike)(b))
125
+ return deepMerge(a, b);
126
+ return a || b;
127
+ };
128
+ const mergeArray = (arr, exclude = ["parent", "node", "__element", "state", "context", "__ref"]) => {
129
+ return arr.reduce((a, c) => deepMerge(a, deepClone(c, exclude)), {});
130
+ };
131
+ const mergeAndCloneIfArray = (obj) => {
132
+ return (0, import_utils.isArray)(obj) ? mergeArray(obj) : deepClone(obj);
133
+ };
134
+ const flattenRecursive = (param, prop, stack = []) => {
135
+ const objectized = mergeAndCloneIfArray(param);
136
+ stack.push(objectized);
137
+ const extendOfExtend = objectized[prop];
138
+ if (extendOfExtend)
139
+ flattenRecursive(extendOfExtend, prop, stack);
140
+ delete objectized[prop];
141
+ return stack;
142
+ };
@@ -0,0 +1,165 @@
1
+ 'use strict'
2
+
3
+ import { isDefined, isFunction, isObjectLike, isProduction } from '@domql/utils'
4
+ import { TREE } from '../tree'
5
+ import { parseFilters, registry } from '../mixins'
6
+
7
+ // TODO: update these files
8
+ export const spotByPath = function (path) {
9
+ const element = this
10
+ const arr = [].concat(path)
11
+ let active = TREE[arr[0]]
12
+
13
+ if (!arr || !arr.length) return console.log(arr, 'on', element.key, 'is undefined')
14
+
15
+ while (active.key === arr[0]) {
16
+ arr.shift()
17
+ if (!arr.length) break
18
+ active = active[arr[0]]
19
+ if (!active) return
20
+ }
21
+
22
+ return active
23
+ }
24
+
25
+ // TODO: update these files
26
+ export const lookup = function (key) {
27
+ const element = this
28
+ let { parent } = element
29
+
30
+ while (parent.key !== key) {
31
+ if (parent[key]) return parent[key]
32
+ parent = parent.parent
33
+ if (!parent) return
34
+ }
35
+
36
+ return parent
37
+ }
38
+
39
+ export const remove = function (params) {
40
+ const element = this
41
+ if (isFunction(element.node.remove)) element.node.remove()
42
+ else if (!isProduction()) {
43
+ console.warn('This item cant be removed')
44
+ element.log()
45
+ }
46
+ delete element.parent[element.key]
47
+ }
48
+
49
+ export const get = function (param) {
50
+ const element = this
51
+ return element[param]
52
+ }
53
+
54
+ export const setProps = function (param, options) {
55
+ const element = this
56
+ if (!param || !element.props) return
57
+ element.update({ props: param }, options)
58
+ return element
59
+ }
60
+
61
+ // export const set = function () {
62
+ // }
63
+
64
+ // export const update = function () {
65
+ // }
66
+
67
+ export const defineSetter = (element, key, get, set) =>
68
+ Object.defineProperty(element, key, { get, set })
69
+
70
+ export const keys = function () {
71
+ const element = this
72
+ const keys = []
73
+ for (const param in element) {
74
+ if (registry[param] && !parseFilters.elementKeys.includes(param)) { continue }
75
+ keys.push(param)
76
+ }
77
+ return keys
78
+ }
79
+
80
+ export const parse = function (excl = []) {
81
+ const element = this
82
+ const obj = {}
83
+ const keyList = keys.call(element)
84
+ keyList.forEach(v => {
85
+ if (excl.includes(v)) return
86
+ let val = element[v]
87
+ if (v === 'state') {
88
+ if (element.__ref && element.__ref.__hasRootState) return
89
+ if (isFunction(val && val.parse)) val = val.parse()
90
+ } else if (v === 'props') {
91
+ const { __element, update, ...props } = element[v]
92
+ obj[v] = props
93
+ } else if (isDefined(val)) obj[v] = val
94
+ })
95
+ return obj
96
+ }
97
+
98
+ export const parseDeep = function (excl = []) {
99
+ const element = this
100
+ const obj = parse.call(element, excl)
101
+ for (const v in obj) {
102
+ if (excl.includes(v)) return
103
+ if (isObjectLike(obj[v])) { obj[v] = parseDeep.call(obj[v], excl) }
104
+ }
105
+ return obj
106
+ }
107
+
108
+ export const log = function (...args) {
109
+ const element = this
110
+ const { __ref } = element
111
+ console.group(element.key)
112
+ if (args.length) {
113
+ args.forEach(v => console.log(`%c${v}:\n`, 'font-weight: bold', element[v]))
114
+ } else {
115
+ console.log(__ref.path)
116
+ const keys = element.keys()
117
+ keys.forEach(v => console.log(`%c${v}:\n`, 'font-weight: bold', element[v]))
118
+ }
119
+ console.groupEnd(element.key)
120
+ return element
121
+ }
122
+
123
+ export const nextElement = function () {
124
+ const element = this
125
+ const { key, parent } = element
126
+ const { __children } = parent.__ref
127
+
128
+ const currentIndex = __children.indexOf(key)
129
+ const nextChild = __children[currentIndex + 1]
130
+
131
+ return parent[nextChild]
132
+ }
133
+
134
+ export const previousElement = function (el) {
135
+ const element = el || this
136
+ const { key, parent } = element
137
+ const { __children } = parent.__ref
138
+
139
+ if (!__children) return
140
+
141
+ const currentIndex = __children.indexOf(key)
142
+ return parent[__children[currentIndex - 1]]
143
+ }
144
+
145
+ export const METHODS = [
146
+ 'set',
147
+ 'update',
148
+ 'remove',
149
+ 'updateContent',
150
+ 'removeContent',
151
+ 'lookup',
152
+ 'spotByPath',
153
+ 'keys',
154
+ 'parse',
155
+ 'setProps',
156
+ 'parseDeep',
157
+ 'if',
158
+ 'log',
159
+ 'nextElement',
160
+ 'previousElement'
161
+ ]
162
+
163
+ export const isMethod = function (param) {
164
+ return METHODS.includes(param)
165
+ }
package/methods/set.js ADDED
@@ -0,0 +1,41 @@
1
+ 'use strict'
2
+
3
+ import { isDevelopment } from '@domql/utils'
4
+
5
+ import set from '../set'
6
+ import update from '../update'
7
+
8
+ import {
9
+ lookup,
10
+ setProps,
11
+ remove,
12
+ spotByPath,
13
+ log,
14
+ keys,
15
+ parse,
16
+ parseDeep,
17
+ nextElement,
18
+ previousElement
19
+ } from './'
20
+
21
+ import { removeContent, updateContent } from '../mixins/content'
22
+
23
+ export const addMethods = (element, parent) => {
24
+ const proto = {
25
+ set: set.bind(element),
26
+ update: update.bind(element),
27
+ remove: remove.bind(element),
28
+ updateContent: updateContent.bind(element),
29
+ removeContent: removeContent.bind(element),
30
+ setProps: setProps.bind(element),
31
+ lookup: lookup.bind(element),
32
+ spotByPath: spotByPath.bind(element),
33
+ parse: parse.bind(element),
34
+ parseDeep: parseDeep.bind(element),
35
+ keys: keys.bind(element),
36
+ nextElement: nextElement.bind(element),
37
+ previousElement: previousElement.bind(element)
38
+ }
39
+ if (isDevelopment()) proto.log = log.bind(element)
40
+ Object.setPrototypeOf(element, proto)
41
+ }