@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.
- package/cache/index.js +3 -0
- package/cache/options.js +3 -0
- package/dist/cjs/cache/index.js +24 -0
- package/dist/cjs/cache/options.js +24 -0
- package/dist/cjs/methods/index.js +186 -0
- package/dist/cjs/{set.js → methods/set.js} +24 -24
- package/dist/cjs/methods/v2.js +109 -0
- package/dist/cjs/mixins/attr.js +42 -0
- package/dist/cjs/mixins/classList.js +73 -0
- package/dist/cjs/mixins/content.js +75 -0
- package/dist/cjs/{define.js → mixins/data.js} +14 -12
- package/dist/cjs/mixins/html.js +35 -0
- package/dist/cjs/{index.js → mixins/index.js} +23 -15
- package/dist/cjs/mixins/registry.js +89 -0
- package/dist/cjs/mixins/state.js +40 -0
- package/dist/cjs/{tree.js → mixins/style.js} +11 -9
- package/dist/cjs/mixins/text.js +60 -0
- package/dist/cjs/props/create.js +77 -0
- package/dist/cjs/props/ignore.js +24 -0
- package/dist/cjs/props/index.js +21 -0
- package/dist/cjs/props/inherit.js +52 -0
- package/dist/cjs/props/update.js +37 -0
- package/dist/cjs/test/create.test.js +51 -0
- package/dist/cjs/test/set.test.js +9 -0
- package/dist/cjs/test/update.test.js +8 -0
- package/dist/cjs/utils/component.js +133 -0
- package/dist/cjs/utils/extendUtils.js +144 -0
- package/dist/cjs/utils/index.js +20 -0
- package/dist/cjs/utils/object.js +142 -0
- package/methods/index.js +165 -0
- package/methods/set.js +41 -0
- package/methods/v2.js +82 -0
- package/mixins/attr.js +23 -0
- package/mixins/classList.js +48 -0
- package/mixins/content.js +47 -0
- package/mixins/data.js +21 -0
- package/mixins/html.js +20 -0
- package/mixins/index.js +23 -0
- package/mixins/registry.js +66 -0
- package/mixins/state.js +20 -0
- package/mixins/style.js +14 -0
- package/mixins/text.js +41 -0
- package/package.json +5 -4
- package/props/create.js +60 -0
- package/props/ignore.js +3 -0
- package/props/index.js +6 -0
- package/props/inherit.js +34 -0
- package/props/update.js +17 -0
- package/test/create.test.js +61 -0
- package/test/set.test.js +13 -0
- package/test/update.test.js +13 -0
- package/utils/component.js +112 -0
- package/utils/extendUtils.js +118 -0
- package/utils/index.js +5 -0
- package/utils/object.js +141 -0
- package/dist/cjs/applyParam.js +0 -41
- package/dist/cjs/create.js +0 -262
- package/dist/cjs/extend.js +0 -87
- package/dist/cjs/iterate.js +0 -108
- package/dist/cjs/node.js +0 -85
- 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
|
+
};
|
package/methods/index.js
ADDED
|
@@ -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
|
+
}
|