x-prop-tree 0.7.40 → 0.7.42

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.
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiAdaptSlotSelect(changeEvent: ChangeEvent): {
4
- renderUiAdaptSlotSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiAdaptSlotSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiColorPicker(changeEvent: ChangeEvent): {
4
- renderUiColorPicker: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiColorPicker: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiCompSelect(changeEvent: ChangeEvent): {
4
- renderUiCompSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiCompSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,5 +1,5 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiDummy(changeEvent: ChangeEvent): {
4
- renderUiDummy: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => undefined;
4
+ renderUiDummy: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => undefined;
5
5
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiJsonEditor(changeEvent: ChangeEvent): {
4
- renderUiJsonEditor: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiJsonEditor: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiMultiTypes(changeEvent: ChangeEvent): {
4
- renderUiMultiTypes: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiMultiTypes: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiNumInput(changeEvent: ChangeEvent): {
4
- renderUiNumInput: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiNumInput: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { Ref, VNode } from 'vue';
2
2
  import { ZProperty } from 'x-runtime-lib';
3
- import { PropertyStateMap } from '@/utils';
4
- export declare function useUiProperty(propertyStates: Ref<PropertyStateMap>, entryHeight: Ref<string>, entryValueWidth: Ref<string>): {
3
+ import { PropertyState } from '@/utils';
4
+ export declare function useUiProperty(propertyState: Ref<PropertyState>, entryHeight: Ref<string>, entryValueWidth: Ref<string>): {
5
5
  renderProperty: (keys: (string | number)[], property: ZProperty, node: VNode) => VNode<import("vue").RendererNode, import("vue").RendererElement, {
6
6
  [key: string]: any;
7
7
  }>;
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiSelect(changeEvent: ChangeEvent): {
4
- renderUiSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiSlotSelect(changeEvent: ChangeEvent): {
4
- renderUiSlotSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiSlotSelect: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiStrInput(changeEvent: ChangeEvent): {
4
- renderUiStrInput: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiStrInput: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
@@ -1,7 +1,7 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  import { ChangeEvent } from '@/utils';
3
3
  export declare function useUiSwitch(changeEvent: ChangeEvent): {
4
- renderUiSwitch: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex?: number, isBranch?: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
4
+ renderUiSwitch: (keys: (string | number)[], property: ZProperty, object: any, arrayIndex: number | undefined, isBranch: boolean) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
5
5
  [key: string]: any;
6
6
  }>;
7
7
  };
package/dist/index.js CHANGED
@@ -1,12 +1,28 @@
1
- import { a as cloneDeep_default, i as isEqual_default, n as setCollapse, r as tidyList, t as getListEntry } from "./vendor.gmzhs72f.js";
2
- import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, createVNode, defineComponent, h, inject, isRef, mergeModels, mergeProps, normalizeStyle, onBeforeUnmount, onMounted, onUnmounted, openBlock, provide, reactive, ref, renderList, renderSlot, resolveComponent, resolveDirective, toDisplayString, unref, useId, useModel, useTemplateRef, watch, watchEffect, withCtx, withDirectives, withKeys, withModifiers } from "vue";
1
+ import { a as cloneDeep_default, i as isEqual_default, n as setCollapse$1, r as tidyList, t as getListEntry } from "./vendor.gmzhs72f.js";
2
+ import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, createVNode, defineComponent, h, inject, isRef, mergeModels, mergeProps, normalizeStyle, onBeforeUnmount, onMounted, onUnmounted, openBlock, provide, ref, renderList, renderSlot, resolveComponent, resolveDirective, toDisplayString, unref, useId, useModel, useTemplateRef, watch, watchEffect, withCtx, withDirectives, withKeys, withModifiers } from "vue";
3
3
  import { useI18n } from "vue-i18n";
4
4
  import { eventBus, globalObjects, injectDark, injectLocale, openNumberDlg, openPromptDlg, useColor, useSystem, useViewStack } from "x-essential-lib";
5
5
  import { getElement, getPropertyDefault, getTag, makeSlotId, parsePercentStr, parsePixelStr, pkgs } from "x-runtime-lib";
6
6
  import { globalState } from "x-state-lib";
7
7
  import { useDisplay } from "vuetify";
8
8
  import { XBlockly } from "x-block-lib";
9
- const isBranchChildrenMap = (e) => !(e instanceof Array), isBranchChildrenArray = (e) => e instanceof Array, isPropertyCompatible = (e, m) => {
9
+ function isCollapse(e, m) {
10
+ let g = e.value;
11
+ for (let e of m) {
12
+ if (!g.children[e]) return !0;
13
+ g = g.children[e];
14
+ }
15
+ return g.collapse;
16
+ }
17
+ function setCollapse(e, m, g) {
18
+ let _ = e.value;
19
+ for (let e of m) _.children[e] || (_.children[e] = {
20
+ collapse: !0,
21
+ children: {}
22
+ }), _ = _.children[e];
23
+ _.collapse = g;
24
+ }
25
+ const isPropertyCompatible = (e, m) => {
10
26
  let g = (e, m) => {
11
27
  if (e.ui !== m.ui || e.array !== m.array) return !1;
12
28
  if (e.ui || m.ui) return !0;
@@ -21,28 +37,28 @@ const isBranchChildrenMap = (e) => !(e instanceof Array), isBranchChildrenArray
21
37
  name: "",
22
38
  children: e
23
39
  };
24
- return m.forEach((e) => {
25
- if (typeof e != "number") {
26
- if (!g) {
27
- console.assert(!1, `unpkgProp invalid property keys=${m}`);
28
- return;
29
- }
30
- if (g.ui) {
31
- console.assert(!1, `unpkgProp property ui must be invalid keys=${m}`);
32
- return;
33
- }
34
- g = g.children.find((m) => m.key === e);
40
+ for (let e of m) {
41
+ if (!g) {
42
+ console.assert(!1, `invalid property keys=${m}`);
43
+ break;
44
+ }
45
+ if (g.ui) {
46
+ console.assert(!1, `property ui must be invalid keys=${m}`);
47
+ break;
35
48
  }
36
- }), g;
49
+ typeof e != "number" && (g = g.children.find((m) => m.key === e));
50
+ }
51
+ return g;
37
52
  }, unpkgObject = (e, m) => {
38
53
  let g = e;
39
- return m.forEach((e) => {
54
+ for (let e of m) {
40
55
  if (!g) {
41
- console.assert(!1, `unpkgObject object must be valid keys=${m}`);
42
- return;
56
+ console.assert(!1, `object must be valid keys=${m}`);
57
+ break;
43
58
  }
44
59
  g = g[e];
45
- }), g;
60
+ }
61
+ return g;
46
62
  }, getModelValue = (e, m, g, _, v, y) => {
47
63
  if (v !== void 0) if (y) {
48
64
  if (g[m.key] === void 0) {
@@ -70,86 +86,136 @@ const isBranchChildrenMap = (e) => !(e instanceof Array), isBranchChildrenArray
70
86
  let y = _;
71
87
  (m.ui === "switch" || m.ui === "select" || m.ui === "colorPicker" || m.ui === "multiTypes" || m.ui === "selectComp" || m.ui === "selectSlot" || m.ui === "selectAdaptSlot") && (_ || (y = void 0)), y !== g[m.key] && (g[m.key] = y, v(e, g[m.key]));
72
88
  }
73
- }, isPropertyStateChildrenMap = (e) => !(e instanceof Array), isPropertyStateChildrenArray = (e) => e instanceof Array;
89
+ };
74
90
  var propertyStateIgnores = [["basic", "id"], ["basic", "name"]], isPropertyStateIgnored = (e) => propertyStateIgnores.find((g) => isEqual_default(e, g));
75
- const execProperty = (m, g, _, v, y, b, x) => (m = cloneDeep_default(m), b === void 0 ? m.push(g.key) : (m.push(b), x && m.push(g.key)), isPropertyStateIgnored(m) ? (v.change = !1, v.change) : g.ui ? g.array && v.children && isPropertyStateChildrenArray(v.children) ? execPropertyLeafArray(m, g, _, v, y, b, x) : execPropertyLeafScalar(g, _, v, b, x) : g.array ? execPropertyBranchArray(m, g, _, v, y, b, x) : execPropertyBranchScalar(m, g, _, v, y, b, x));
91
+ const execProperty = (m, g, _, v, y, b, x) => (m = cloneDeep_default(m), b === void 0 ? m.push(g.key) : (m.push(b), x && m.push(g.key)), isPropertyStateIgnored(m) ? (v.change = !1, v.warning = !1, {
92
+ change: v.change,
93
+ warning: v.warning
94
+ }) : g.ui ? g.array && v.children ? execPropertyLeafArray(m, g, _, v, y, b, x) : execPropertyLeafScalar(g, _, v, b, x) : g.array ? execPropertyBranchArray(m, g, _, v, y, b, x) : execPropertyBranchScalar(m, g, _, v, y, b, x));
76
95
  var execPropertyBranchArray = (e, g, _, v, y, b, x) => {
77
- if (g.ui) return console.assert(!1, "execPropertyBranchArray property ui must be invalid"), !1;
78
- if (!g.array) return console.assert(!1, "execPropertyBranchArray property array must be valid"), !1;
79
- if (!v.children || !isPropertyStateChildrenArray(v.children)) return console.assert(!1, "execPropertyBranchArray state children must be array"), !1;
96
+ if (g.ui) return console.assert(!1, "execPropertyBranchArray property ui must be invalid"), {
97
+ change: !1,
98
+ warning: !1
99
+ };
100
+ if (!g.array) return console.assert(!1, "execPropertyBranchArray property array must be valid"), {
101
+ change: !1,
102
+ warning: !1
103
+ };
80
104
  let S;
81
- b !== void 0 && !x ? (_[b] instanceof Array || (_[b] = getPropertyDefault(g), y?.(e, _[b])), S = _[b]) : (_[g.key] instanceof Array || (_[g.key] = getPropertyDefault(g), y?.(e, _[g.key])), S = _[g.key]), v.change = !1;
105
+ b !== void 0 && !x ? (_[b] instanceof Array || (_[b] = getPropertyDefault(g), y?.(e, _[b])), S = _[b]) : (_[g.key] instanceof Array || (_[g.key] = getPropertyDefault(g), y?.(e, _[g.key])), S = _[g.key]);
82
106
  for (let m = 0; m < S.length; m++) {
83
- v.children.push({
107
+ v.children[m] = {
84
108
  change: !1,
109
+ warning: !1,
85
110
  children: {}
86
- });
111
+ };
87
112
  let _ = v.children[m];
88
- g.children.forEach((g) => {
89
- if (!_.children || !isPropertyStateChildrenMap(_.children)) {
90
- console.assert(!1);
91
- return;
92
- }
93
- _.children[g.key] = {
113
+ for (let b of g.children) {
114
+ _.children[b.key] = {
94
115
  change: !1,
95
- children: g.array ? [] : {}
96
- }, execProperty(e, g, S[m], _.children[g.key], y, m, !0) && (_.change = !0), _.change && (v.change = !0);
97
- });
116
+ warning: !1,
117
+ children: {}
118
+ };
119
+ let { change: g, warning: x } = execProperty(e, b, S[m], _.children[b.key], y, m, !0);
120
+ !_.change && g && (_.change = g), !_.change && x && (_.warning = x), !v.change && _.change && (v.change = _.change), !v.warning && _.warning && (v.warning = _.warning);
121
+ }
98
122
  }
99
- return v.change ||= !isEqual_default(S, getPropertyDefault(g)), v.change;
123
+ return v.change ||= !isEqual_default(S, getPropertyDefault(g)), {
124
+ change: v.change,
125
+ warning: v.warning
126
+ };
100
127
  }, execPropertyBranchScalar = (e, m, g, _, v, y, b) => {
101
- if (m.ui) return console.assert(!1, "execPropertyBranchScalar property ui must be invalid"), !1;
102
- if (m.array) return console.assert(!1, "execPropertyBranchScalar property array must be invalid"), !1;
103
- if (!_.children || !isPropertyStateChildrenMap(_.children)) return console.assert(!1, "execPropertyBranchScalar state children must be map"), !1;
128
+ if (m.ui) return console.assert(!1, "execPropertyBranchScalar property ui must be invalid"), {
129
+ change: !1,
130
+ warning: !1
131
+ };
132
+ if (m.array) return console.assert(!1, "execPropertyBranchScalar property array must be invalid"), {
133
+ change: !1,
134
+ warning: !1
135
+ };
104
136
  let x;
105
- y !== void 0 && !b ? (g[y] || (g[y] = {}), x = g[y]) : (g[m.key] || (g[m.key] = {}), x = g[m.key]), _.change = !1;
137
+ y !== void 0 && !b ? (g[y] || (g[y] = {}), x = g[y]) : (g[m.key] || (g[m.key] = {}), x = g[m.key]);
106
138
  for (let g = 0; g < m.children.length; g++) {
107
139
  let y = m.children[g];
108
140
  _.children[y.key] = {
109
141
  change: !1,
110
- children: y.array ? [] : {}
111
- }, execProperty(e, y, x, _.children[y.key], v) && (_.change = !0);
142
+ warning: !1,
143
+ children: {}
144
+ };
145
+ let { change: b, warning: S } = execProperty(e, y, x, _.children[y.key], v);
146
+ !_.change && b && (_.change = b), !_.warning && S && (_.warning = S);
112
147
  }
113
- return _.change;
148
+ return {
149
+ change: _.change,
150
+ warning: _.change
151
+ };
114
152
  }, execPropertyLeafArray = (e, g, _, v, y, b, x) => {
115
- if (!g.ui) return console.assert(!1, "execPropertyLeafArray property ui must be valid"), !1;
116
- if (!g.array) return console.assert(!1, "execPropertyLeafArray property aray must be valid"), !1;
117
- if (!v.children || !isPropertyStateChildrenArray(v.children)) return console.assert(!1, "execPropertyLeafArray state children must be array"), !1;
118
- let S;
119
- b !== void 0 && !x ? (_[b] instanceof Array || (_[b] = getPropertyDefault(g), y?.(e, _[b])), S = _[b]) : (_[g.key] instanceof Array || (_[g.key] = getPropertyDefault(g), y?.(e, _[g.key])), S = _[g.key]), v.change = !1;
120
- for (let m = 0; m < S.length; m++) v.children[m] = {
153
+ if (!g.ui) return console.assert(!1, "execPropertyLeafArray property ui must be valid"), {
121
154
  change: !1,
122
- children: {}
123
- }, execProperty(e, g, S, v.children[m], y, m, !1) && (v.change = !0);
124
- return v.change ||= !isEqual_default(S, getPropertyDefault(g)), v.change;
155
+ warning: !1
156
+ };
157
+ if (!g.array) return console.assert(!1, "execPropertyLeafArray property aray must be valid"), {
158
+ change: !1,
159
+ warning: !1
160
+ };
161
+ let S;
162
+ b !== void 0 && !x ? (_[b] instanceof Array || (_[b] = getPropertyDefault(g), y?.(e, _[b])), S = _[b]) : (_[g.key] instanceof Array || (_[g.key] = getPropertyDefault(g), y?.(e, _[g.key])), S = _[g.key]);
163
+ for (let m = 0; m < S.length; m++) {
164
+ v.children[m] = {
165
+ change: !1,
166
+ warning: !1,
167
+ children: {}
168
+ };
169
+ let { change: _, warning: b } = execProperty(e, g, S, v.children[m], y, m, !1);
170
+ !v.change && _ && (v.change = _), !v.warning && b && (v.warning = b);
171
+ }
172
+ return v.change ||= !isEqual_default(S, getPropertyDefault(g)), {
173
+ change: v.change,
174
+ warning: v.warning
175
+ };
125
176
  }, execPropertyLeafScalar = (e, g, _, v, y) => {
126
- if (!e.ui) return console.assert(!1, "execPropertyLeafScalar property ui must be valid"), !1;
177
+ if (!e.ui) return console.assert(!1, "execPropertyLeafScalar property ui must be valid"), {
178
+ change: !1,
179
+ warning: !1
180
+ };
127
181
  let b;
128
- return b = v !== void 0 && !y ? g[v] : g[e.key], _.change = !isEqual_default(b, getPropertyDefault(e, !0)), _.change;
182
+ return b = v !== void 0 && !y ? g[v] : g[e.key], _.change = !isEqual_default(b, getPropertyDefault(e, !0)), {
183
+ change: _.change,
184
+ warning: _.warning
185
+ };
129
186
  };
130
187
  const rebuildPropertyState = (e, m, g, _) => {
131
188
  if (m.length <= 0 || !g) {
132
- e.value = {};
189
+ e.value = {
190
+ change: !1,
191
+ warning: !1,
192
+ children: {}
193
+ };
133
194
  return;
134
195
  }
135
- let v = {};
136
- m.forEach((e) => {
137
- v[e.key] = {
138
- change: !1,
139
- children: e.array ? [] : {}
140
- }, execProperty([], e, g, v[e.key], _);
141
- }), e.value = v;
142
- }, isPropertyChanged = (e, m) => {
143
- let g = {
196
+ let v = {
144
197
  change: !1,
145
- children: e
198
+ warning: !1,
199
+ children: {}
146
200
  };
147
- return m.forEach((e) => {
148
- if (!g || !g.children) return console.assert(!1, `isPropChanged state must be valid keys=${m}`), !1;
149
- typeof e == "string" ? isPropertyStateChildrenMap(g.children) && (g = g.children[e]) : isPropertyStateChildrenArray(g.children) && (g = g.children[e]);
150
- }), g?.change ?? !1;
201
+ for (let e of m) {
202
+ let m = {
203
+ change: !1,
204
+ warning: !1,
205
+ children: {}
206
+ };
207
+ v.children[e.key] = m, execProperty([], e, g, m, _);
208
+ }
209
+ e.value = v;
210
+ }, isPropertyChanged = (e, m) => {
211
+ let g = e;
212
+ for (let e of m) {
213
+ if (!g.children[e]) return !1;
214
+ g = g.children[e];
215
+ }
216
+ return g.change;
151
217
  };
152
- var versionKey = Symbol(), configKey = Symbol(), objectKey = Symbol(), propertyStatesKey = Symbol(), changeEventKey = Symbol(), compListKey = Symbol(), slotListKey = Symbol(), adaptSlotListKey = Symbol();
218
+ var versionKey = Symbol(), configKey = Symbol(), objectKey = Symbol(), propertyStateKey = Symbol(), changeEventKey = Symbol(), compListKey = Symbol(), slotListKey = Symbol(), adaptSlotListKey = Symbol();
153
219
  function provideVersion(e) {
154
220
  provide(versionKey, e);
155
221
  }
@@ -168,11 +234,11 @@ function provideObject(e) {
168
234
  function injectObject() {
169
235
  return inject(objectKey);
170
236
  }
171
- function providePropertyStates(e) {
172
- provide(propertyStatesKey, e);
237
+ function providePropertyState(e) {
238
+ provide(propertyStateKey, e);
173
239
  }
174
- function injectPropertyStates() {
175
- return inject(propertyStatesKey);
240
+ function injectPropertyState() {
241
+ return inject(propertyStateKey);
176
242
  }
177
243
  function provideChangeEvent(e) {
178
244
  provide(changeEventKey, e);
@@ -201,7 +267,7 @@ function injectAdaptSlotList() {
201
267
  var menu_default = /* @__PURE__ */ defineComponent({
202
268
  __name: "index",
203
269
  setup(e) {
204
- let { t: m } = useI18n(), g = injectConfig(), _ = injectObject(), v = injectPropertyStates(), S = injectChangeEvent(), w = ref(0), D = ref(0), O = ref([]), k = computed(() => [w.value, D.value]), j = (e) => {
270
+ let { t: m } = useI18n(), g = injectConfig(), _ = injectObject(), v = injectPropertyState(), S = injectChangeEvent(), w = ref(0), D = ref(0), O = ref([]), k = computed(() => [w.value, D.value]), j = (e) => {
205
271
  (() => !(O.value.length <= 0 || !isPropertyChanged(v.value, O.value)))() && e.push({
206
272
  title: m("x-prop-tree.reset"),
207
273
  func: () => {
@@ -253,7 +319,9 @@ var menu_default = /* @__PURE__ */ defineComponent({
253
319
  if (!e) return !1;
254
320
  try {
255
321
  let { property: m } = JSON.parse(e);
256
- return m ? isPropertyCompatible(m, unpkgProperty(g.value, O.value)) : !1;
322
+ if (!m) return !1;
323
+ let _ = unpkgProperty(g.value, O.value);
324
+ return _ ? isPropertyCompatible(m, _) : !1;
257
325
  } catch (e) {
258
326
  console.error(e);
259
327
  }
@@ -475,7 +543,7 @@ function useCompList() {
475
543
  position: b,
476
544
  group: _
477
545
  });
478
- tidyList(v, !0), e.value = v;
546
+ e.value = tidyList(v, !0);
479
547
  }, g, v = () => {
480
548
  clearTimeout(g), g = window.setTimeout(() => {
481
549
  m(), g && v();
@@ -593,7 +661,7 @@ var _hoisted_1$17 = { class: "text-subtitle-2 ml-1" }, _hoisted_2$5 = { class: "
593
661
  setup(e) {
594
662
  let { nameList: m } = useSystem(), _ = useModel(e, "modelValue"), b = useModel(e, "open"), w = injectAdaptSlotList(), T = (e) => {
595
663
  let m = getListEntry(w, e);
596
- m && setCollapse(w, e, !m.collapse);
664
+ m && setCollapse$1(w, e, !m.collapse);
597
665
  }, E = (e) => {
598
666
  _.value = e, b.value = !1;
599
667
  };
@@ -848,7 +916,7 @@ var _hoisted_1$17 = { class: "text-subtitle-2 ml-1" }, _hoisted_2$5 = { class: "
848
916
  setup(e) {
849
917
  let { nameList: m } = useSystem(), _ = useModel(e, "modelValue"), b = useModel(e, "open"), w = injectCompList(), T = (e) => {
850
918
  let m = getListEntry(w, e);
851
- m && setCollapse(w, e, !m.collapse);
919
+ m && setCollapse$1(w, e, !m.collapse);
852
920
  }, E = (e) => {
853
921
  _.value = e, b.value = !1, eventBus.emit("refreshDepends");
854
922
  };
@@ -1721,48 +1789,56 @@ var propTree_default = /* @__PURE__ */ defineComponent({
1721
1789
  },
1722
1790
  emits: ["change"],
1723
1791
  setup(m, { emit: g }) {
1724
- let { t: _ } = useI18n(), { backgroundColor1: v } = useColor(), b = m, x = g, S = ref("20px"), w = ref("56px"), T = ref("200px"), D = reactive({}), k = ref({}), A = (e, m) => {
1725
- rebuildPropertyState(k, b.config, b.object), x("change", e, m);
1726
- };
1727
- watch([() => b.config, () => b.object], () => {
1728
- rebuildPropertyState(k, b.config, b.object, (e, m) => {
1729
- x("change", e, m);
1730
- });
1731
- }, { immediate: !0 });
1732
- let j = ref(b.version);
1733
- provideVersion(j), watch(() => b.version, () => {
1734
- j.value = b.version;
1792
+ let { t: _ } = useI18n(), { backgroundColor1: v } = useColor(), b = m, x = g, S = ref("20px"), w = ref("56px"), T = ref("200px"), D = ref(b.version);
1793
+ provideVersion(D), watch(() => b.version, () => {
1794
+ D.value = b.version;
1735
1795
  });
1736
- let M = ref(b.type);
1796
+ let k = ref(b.type);
1737
1797
  watch(() => b.type, () => {
1738
- M.value = b.type;
1798
+ k.value = b.type;
1739
1799
  });
1740
- let N = ref(b.subtype);
1800
+ let A = ref(b.subtype);
1741
1801
  watch(() => b.subtype, () => {
1742
- N.value = b.subtype;
1802
+ A.value = b.subtype;
1803
+ });
1804
+ let j = ref(b.config);
1805
+ provideConfig(j), watch(() => b.config, () => {
1806
+ j.value = b.config;
1743
1807
  });
1744
- let P = ref(b.config);
1745
- provideConfig(P), watch(() => b.config, () => {
1746
- P.value = b.config;
1808
+ let M = ref(b.object);
1809
+ provideObject(M), watch(() => b.object, () => {
1810
+ M.value = b.object;
1747
1811
  });
1748
- let F = ref(b.object);
1749
- provideObject(F), watch(() => b.object, () => {
1750
- F.value = b.object;
1751
- }), providePropertyStates(k), provideChangeEvent(A), useCompList(), useSlotList(), useAdaptSlotList(j, M, N);
1752
- let { renderProperty: I } = useUiProperty(k, w, T), { renderUiDummy: L } = useUiDummy(A), { renderUiStrInput: R } = useUiStrInput(A), { renderUiNumInput: z } = useUiNumInput(A), { renderUiSwitch: B } = useUiSwitch(A), { renderUiSelect: V } = useUiSelect(A), { renderUiColorPicker: H } = useUiColorPicker(A), { renderUiJsonEditor: U } = useUiJsonEditor(A), { renderUiMultiTypes: W } = useUiMultiTypes(A), { renderUiCompSelect: G } = useUiCompSelect(A), { renderUiSlotSelect: K } = useUiSlotSelect(A), { renderUiAdaptSlotSelect: q } = useUiAdaptSlotSelect(A), J = (m, g, _, v, y, b) => (m = cloneDeep_default(m), y === void 0 ? m.push(g.key) : (m.push(y), b && m.push(g.key)), g.ui ? g.array && v ? Z(m, g, _, v, y, b) : Q(m, g, _, y, b) : g.array ? Y(m, g, _, v, y, b) : X(m, g, _, v, y, b)), Y = (e, m, g, v, y, b) => {
1812
+ let N = ref({
1813
+ collapse: !0,
1814
+ children: {}
1815
+ }), P = ref({
1816
+ change: !1,
1817
+ warning: !1,
1818
+ children: {}
1819
+ });
1820
+ providePropertyState(P);
1821
+ let F = (e, m) => {
1822
+ rebuildPropertyState(P, b.config, b.object), x("change", e, m);
1823
+ };
1824
+ provideChangeEvent(F), watch([() => b.config, () => b.object], () => {
1825
+ rebuildPropertyState(P, b.config, b.object, (e, m) => {
1826
+ x("change", e, m);
1827
+ });
1828
+ }, { immediate: !0 }), useCompList(), useSlotList(), useAdaptSlotList(D, k, A);
1829
+ let { renderProperty: I } = useUiProperty(P, w, T), { renderUiDummy: L } = useUiDummy(F), { renderUiStrInput: R } = useUiStrInput(F), { renderUiNumInput: z } = useUiNumInput(F), { renderUiSwitch: B } = useUiSwitch(F), { renderUiSelect: V } = useUiSelect(F), { renderUiColorPicker: H } = useUiColorPicker(F), { renderUiJsonEditor: U } = useUiJsonEditor(F), { renderUiMultiTypes: W } = useUiMultiTypes(F), { renderUiCompSelect: G } = useUiCompSelect(F), { renderUiSlotSelect: K } = useUiSlotSelect(F), { renderUiAdaptSlotSelect: q } = useUiAdaptSlotSelect(F), J = (m, g, _, v, y, b) => (m = cloneDeep_default(m), v === void 0 ? m.push(g.key) : (m.push(v), y && m.push(g.key)), g.ui ? g.array && !b ? Z(m, g, _, v, y) : Q(m, g, _, v, y) : g.array ? Y(m, g, _, v, y) : X(m, g, _, v, y)), Y = (e, m, g, v, y) => {
1753
1830
  if (m.ui) return console.assert(!1), h("div", "renderBranchArray property ui must be invalid");
1754
1831
  if (!m.array) return console.assert(!1), h("div", "renderBranchArray property array must be valid");
1755
- if (!v) return console.assert(!1), h("div", "renderBranchArray branch must be valid");
1756
- let x;
1757
- y !== void 0 && !b ? (g[y] instanceof Array || (g[y] = getPropertyDefault(m), A(e, g[m.key])), x = g[y]) : (g[m.key] instanceof Array || (g[m.key] = getPropertyDefault(m), A(e, g[m.key])), x = g[m.key]);
1758
- let C = _(m.name);
1759
- v.collapse && isPropertyChanged(k.value, e) && (C += " *");
1760
- let w = h(title_default, {
1761
- title: C,
1762
- collapse: v.collapse,
1832
+ let b;
1833
+ v !== void 0 && !y ? (g[v] instanceof Array || (g[v] = getPropertyDefault(m), F(e, g[m.key])), b = g[v]) : (g[m.key] instanceof Array || (g[m.key] = getPropertyDefault(m), F(e, g[m.key])), b = g[m.key]);
1834
+ let x = _(m.name);
1835
+ isCollapse(N, e) && isPropertyChanged(P.value, e) && (x += " *");
1836
+ let C = h(title_default, {
1837
+ title: x,
1838
+ collapse: isCollapse(N, e),
1763
1839
  hasCreate: !0,
1764
- onCollapse: (e) => {
1765
- v.collapse = e;
1840
+ onCollapse: (m) => {
1841
+ setCollapse(N, e, m);
1766
1842
  },
1767
1843
  onMenu: (m, g) => {
1768
1844
  eventBus.emit("propTreeMenu", {
@@ -1772,84 +1848,60 @@ var propTree_default = /* @__PURE__ */ defineComponent({
1772
1848
  });
1773
1849
  },
1774
1850
  onCreate: () => {
1775
- x.push({}), A(e, x);
1851
+ b.push({}), F(e, b);
1776
1852
  }
1777
- }), T = h("div", { style: { paddingLeft: S.value } }, (() => {
1853
+ }), w = h("div", { style: { paddingLeft: S.value } }, (() => {
1778
1854
  let g = [];
1779
- for (let _ = 0; _ < x.length; _++) {
1780
- if (!isBranchChildrenArray(v.children)) {
1781
- console.assert(!1);
1782
- break;
1783
- }
1784
- v.children[_] || v.children.push({
1785
- collapse: !0,
1786
- children: {}
1787
- });
1788
- let y = [...e, _], b = v.children[_], C = `[${_ + 1}]`;
1789
- v.children[_].collapse && isPropertyChanged(k.value, y) && (C += " *");
1790
- let w = h(title_default, {
1791
- title: C,
1792
- collapse: v.children[_].collapse,
1855
+ for (let _ = 0; _ < b.length; _++) {
1856
+ let v = [...e, _], y = `[${_ + 1}]`;
1857
+ isCollapse(N, [...e, _]) && isPropertyChanged(P.value, v) && (y += " *");
1858
+ let x = h(title_default, {
1859
+ title: y,
1860
+ collapse: isCollapse(N, [...e, _]),
1793
1861
  hasDelete: !0,
1794
1862
  index: _,
1795
- onCollapse: (e) => {
1796
- if (!isBranchChildrenArray(v.children)) {
1797
- console.assert(!1);
1798
- return;
1799
- }
1800
- v.children[_].collapse = e;
1863
+ onCollapse: (m) => {
1864
+ setCollapse(N, [...e, _], m);
1801
1865
  },
1802
1866
  onMenu: (e, m) => {
1803
1867
  eventBus.emit("propTreeMenu", {
1804
1868
  x: e,
1805
1869
  y: m,
1806
- keys: y
1870
+ keys: v
1807
1871
  });
1808
1872
  },
1809
1873
  onDelete: (m) => {
1810
- if (!isBranchChildrenArray(v.children)) {
1811
- console.assert(!1);
1812
- return;
1813
- }
1814
- v.children.splice(m, 1), x.splice(m, 1), A(e, x);
1874
+ b.splice(m, 1), F(e, b);
1815
1875
  }
1816
1876
  });
1817
- g.push(w);
1818
- let T = h("div", { style: { paddingLeft: S.value } }, (() => {
1877
+ g.push(x);
1878
+ let C = h("div", { style: { paddingLeft: S.value } }, (() => {
1819
1879
  let g = [];
1820
- return m.children.forEach((m) => {
1821
- if (!isBranchChildrenMap(b.children)) {
1822
- console.assert(!1);
1823
- return;
1824
- }
1825
- b.children[m.key] || (b.children[m.key] = {
1826
- collapse: !0,
1827
- children: m.array ? [] : {}
1828
- });
1829
- let v = J(e, m, x[_], b.children[m.key], _, !0);
1830
- g.push(v);
1831
- }), g;
1880
+ for (let v of m.children) {
1881
+ let m = J(e, v, b[_], _, !0);
1882
+ g.push(m);
1883
+ }
1884
+ return g;
1832
1885
  })());
1833
- v.children[_].collapse || g.push(T);
1886
+ isCollapse(N, [...e, _]) || g.push(C);
1834
1887
  }
1835
1888
  return g;
1836
1889
  })());
1837
1890
  return h("div", { style: { marginBottom: "1px" } }, (() => {
1838
- let e = [];
1839
- return e.push(w), v.collapse || e.push(T), e;
1891
+ let m = [];
1892
+ return m.push(C), isCollapse(N, e) || m.push(w), m;
1840
1893
  })());
1841
- }, X = (e, m, g, v, y, b) => {
1894
+ }, X = (e, m, g, v, y) => {
1842
1895
  if (m.ui) return console.assert(!1), h("div", "renderBranchScalar property ui must be invalid");
1843
1896
  if (m.array) return console.assert(!1), h("div", "renderBranchScalar property array must be invalid");
1844
- if (!v) return console.assert(!1), h("div", "renderBranchScalar branch must be valid");
1845
- let x = _(m.name);
1846
- v.collapse && isPropertyChanged(k.value, e) && (x += " *");
1847
- let C = h(title_default, {
1848
- title: x,
1849
- collapse: v.collapse,
1850
- hasDelete: y !== void 0 && !b,
1851
- onCollapse: (e) => {
1852
- v.collapse = e;
1897
+ let b = _(m.name);
1898
+ isCollapse(N, e) && isPropertyChanged(P.value, e) && (b += " *");
1899
+ let x = h(title_default, {
1900
+ title: b,
1901
+ collapse: isCollapse(N, e),
1902
+ hasDelete: v !== void 0 && !y,
1903
+ onCollapse: (m) => {
1904
+ setCollapse(N, e, m);
1853
1905
  },
1854
1906
  onMenu: (m, g) => {
1855
1907
  eventBus.emit("propTreeMenu", {
@@ -1859,41 +1911,33 @@ var propTree_default = /* @__PURE__ */ defineComponent({
1859
1911
  });
1860
1912
  },
1861
1913
  onDelete: () => {
1862
- y === void 0 || b || (g.splice(y, 1), A(e.slice(0, -1), g));
1914
+ v === void 0 || y || (g.splice(v, 1), F(e.slice(0, -1), g));
1863
1915
  }
1864
- }), w = h("div", { style: { paddingLeft: S.value } }, (() => {
1916
+ }), C = h("div", { style: { paddingLeft: S.value } }, (() => {
1865
1917
  let _ = [];
1866
- return m.children.forEach((y) => {
1867
- if (!isBranchChildrenMap(v.children)) {
1868
- console.assert(!1);
1869
- return;
1870
- }
1871
- v.children[y.key] || (v.children[y.key] = {
1872
- collapse: !0,
1873
- children: !y.ui && y.array ? [] : {}
1874
- });
1875
- let b = J(e, y, (() => (typeof g[m.key] != "object" && (g[m.key] = {}, A(e, g[m.key])), g[m.key]))(), v.children[y.key]);
1876
- _.push(b);
1877
- }), _;
1918
+ for (let v of m.children) {
1919
+ let y = J(e, v, (() => (typeof g[m.key] != "object" && (g[m.key] = {}, F(e, g[m.key])), g[m.key]))(), void 0, !1);
1920
+ _.push(y);
1921
+ }
1922
+ return _;
1878
1923
  })());
1879
1924
  return h("div", { style: { marginBottom: "1px" } }, (() => {
1880
- let e = [];
1881
- return e.push(C), v.collapse || e.push(w), e;
1925
+ let m = [];
1926
+ return m.push(x), isCollapse(N, e) || m.push(C), m;
1882
1927
  })());
1883
- }, Z = (e, m, g, v, y, b) => {
1928
+ }, Z = (e, m, g, v, y) => {
1884
1929
  if (!m.ui) return console.assert(!1), h("div", "renderLeafArray property ui must be valid");
1885
1930
  if (!m.array) return console.assert(!1), h("div", "renderLeafArray property array must be valid");
1886
- if (!v) return console.assert(!1), h("div", "renderLeafArray branch must be valid");
1887
- let x;
1888
- y !== void 0 && !b ? (g[y] instanceof Array || (g[y] = getPropertyDefault(m), A(e, g[y])), x = g[y]) : (g[m.key] instanceof Array || (g[m.key] = getPropertyDefault(m), A(e, g[m.key])), x = g[m.key]);
1889
- let C = _(m.name);
1890
- v.collapse && isPropertyChanged(k.value, e) && (C += " *");
1891
- let w = h(title_default, {
1892
- title: C,
1893
- collapse: v.collapse,
1931
+ let b;
1932
+ v !== void 0 && !y ? (g[v] instanceof Array || (g[v] = getPropertyDefault(m), F(e, g[v])), b = g[v]) : (g[m.key] instanceof Array || (g[m.key] = getPropertyDefault(m), F(e, g[m.key])), b = g[m.key]);
1933
+ let x = _(m.name);
1934
+ isCollapse(N, e) && isPropertyChanged(P.value, e) && (x += " *");
1935
+ let C = h(title_default, {
1936
+ title: x,
1937
+ collapse: isCollapse(N, e),
1894
1938
  hasCreate: !0,
1895
- onCollapse: (e) => {
1896
- v.collapse = e;
1939
+ onCollapse: (m) => {
1940
+ setCollapse(N, e, m);
1897
1941
  },
1898
1942
  onMenu: (m, g) => {
1899
1943
  eventBus.emit("propTreeMenu", {
@@ -1903,19 +1947,19 @@ var propTree_default = /* @__PURE__ */ defineComponent({
1903
1947
  });
1904
1948
  },
1905
1949
  onCreate: () => {
1906
- x.push(getPropertyDefault(m, !0)), A(e, x);
1950
+ b.push(getPropertyDefault(m, !0)), F(e, b);
1907
1951
  }
1908
- }), T = h("div", { style: { paddingLeft: S.value } }, (() => {
1952
+ }), w = h("div", { style: { paddingLeft: S.value } }, (() => {
1909
1953
  let g = [];
1910
- for (let _ = 0; _ < x.length; _++) {
1911
- let v = J(e, m, x, void 0, _, !1);
1954
+ for (let _ = 0; _ < b.length; _++) {
1955
+ let v = J(e, m, b, _, !1, !0);
1912
1956
  g.push(v);
1913
1957
  }
1914
1958
  return g;
1915
1959
  })());
1916
1960
  return h("div", { style: { marginBottom: "1px" } }, (() => {
1917
- let e = [];
1918
- return e.push(w), v.collapse || e.push(T), e;
1961
+ let m = [];
1962
+ return m.push(C), isCollapse(N, e) || m.push(w), m;
1919
1963
  })());
1920
1964
  }, Q = (e, m, g, _, v) => {
1921
1965
  if (!m.ui) return console.assert(!1), h("div", "renderLeafScalar property ui must be valid");
@@ -1926,29 +1970,13 @@ var propTree_default = /* @__PURE__ */ defineComponent({
1926
1970
  style: { background: v.value }
1927
1971
  }, (() => {
1928
1972
  let e = [];
1929
- if (b.unique && b.config.length > 0 && b.object) {
1930
- D[b.unique] || (D[b.unique] = {});
1931
- let m = D[b.unique];
1932
- b.config.forEach((g) => {
1933
- m[g.key] || (m[g.key] = {
1934
- collapse: !0,
1935
- children: !g.ui && g.array ? [] : {}
1936
- });
1937
- let _ = J([], g, b.object, m[g.key]);
1938
- e.push(_);
1939
- });
1973
+ if (b.unique && b.config.length > 0 && b.object) for (let m of b.config) {
1974
+ let g = J([], m, b.object, void 0, !1);
1975
+ e.push(g);
1940
1976
  }
1941
1977
  return e;
1942
1978
  })());
1943
- return (e, m) => (openBlock(), createElementBlock(Fragment, null, [createVNode($), createVNode(menu_default, {
1944
- config: b.config,
1945
- object: b.object,
1946
- "property-states": k.value
1947
- }, null, 8, [
1948
- "config",
1949
- "object",
1950
- "property-states"
1951
- ])], 64));
1979
+ return (e, m) => (openBlock(), createElementBlock(Fragment, null, [createVNode($), createVNode(menu_default)], 64));
1952
1980
  }
1953
1981
  }), install = (e) => {
1954
1982
  e.component("XPropTree", propTree_default);
@@ -0,0 +1,9 @@
1
+ import { Ref } from 'vue';
2
+ export type CollapseState = {
3
+ collapse: boolean;
4
+ children: {
5
+ [key: string | number]: CollapseState;
6
+ };
7
+ };
8
+ export declare function isCollapse(root: Ref<CollapseState>, keys: (string | number)[]): boolean;
9
+ export declare function setCollapse(root: Ref<CollapseState>, keys: (string | number)[], collapse: boolean): void;
@@ -1,4 +1,4 @@
1
- export * from './branch';
1
+ export * from './collapseState';
2
2
  export * from './copyPaste';
3
3
  export * from './misc';
4
4
  export * from './propertyState';
@@ -1,15 +1,6 @@
1
1
  import { ZProperty } from 'x-runtime-lib';
2
2
  export type ChangeEvent = (keys: (string | number)[], value: unknown) => void;
3
- export declare const unpkgProperty: (properties: ZProperty[], keys: (string | number)[]) => {
4
- array?: false;
5
- } & {
6
- ui?: undefined;
7
- children: ZProperty[];
8
- default?: undefined;
9
- } & {
10
- key: string;
11
- name: string;
12
- };
3
+ export declare const unpkgProperty: (properties: ZProperty[], keys: (string | number)[]) => ZProperty | undefined;
13
4
  export declare const unpkgObject: (root: any, keys: (string | number)[]) => any;
14
- export declare const getModelValue: (keys: (string | number)[], property: ZProperty, object: any, changeEvent: ChangeEvent, arrayIndex?: number, isBranch?: boolean) => any;
15
- export declare const setModelValue: (keys: (string | number)[], property: ZProperty, object: any, val: unknown, changeEvent: ChangeEvent, arrayIndex?: number, isBranch?: boolean) => void;
5
+ export declare const getModelValue: (keys: (string | number)[], property: ZProperty, object: any, changeEvent: ChangeEvent, arrayIndex: number | undefined, isBranch: boolean) => any;
6
+ export declare const setModelValue: (keys: (string | number)[], property: ZProperty, object: any, val: unknown, changeEvent: ChangeEvent, arrayIndex: number | undefined, isBranch: boolean) => void;
@@ -1,16 +1,16 @@
1
1
  import { Ref } from 'vue';
2
2
  import { ZProperty } from 'x-runtime-lib';
3
3
  import { ChangeEvent } from './misc';
4
- export type PropertyState = {
4
+ interface PropertyStateBase {
5
5
  change: boolean;
6
- children?: PropertyStateMap | PropertyStateArray;
7
- };
8
- export type PropertyStateMap = {
9
- [key: string]: PropertyState;
10
- };
11
- export type PropertyStateArray = PropertyState[];
12
- export declare const isPropertyStateChildrenMap: (children: PropertyStateMap | PropertyStateArray) => children is PropertyStateMap;
13
- export declare const isPropertyStateChildrenArray: (children: PropertyStateMap | PropertyStateArray) => children is PropertyStateArray;
14
- export declare const execProperty: (keys: (string | number)[], property: ZProperty, object: any, state: PropertyState, changeEvent?: ChangeEvent, arrayIndex?: number, isBranch?: boolean) => boolean;
15
- export declare const rebuildPropertyState: (propertyStates: Ref<PropertyStateMap>, config: ZProperty[], object: any, changeEvent?: ChangeEvent) => void;
16
- export declare const isPropertyChanged: (propertyStates: PropertyStateMap, keys: (string | number)[]) => boolean;
6
+ warning: string | boolean;
7
+ }
8
+ export interface PropertyState extends PropertyStateBase {
9
+ children: {
10
+ [key: string]: PropertyState;
11
+ };
12
+ }
13
+ export declare const execProperty: (keys: (string | number)[], property: ZProperty, object: any, state: PropertyState, changeEvent?: ChangeEvent, arrayIndex?: number, isBranch?: boolean) => PropertyStateBase;
14
+ export declare const rebuildPropertyState: (root: Ref<PropertyState>, config: ZProperty[], object: any, changeEvent?: ChangeEvent) => void;
15
+ export declare const isPropertyChanged: (root: PropertyState, keys: (string | number)[]) => boolean;
16
+ export {};
@@ -2,7 +2,7 @@ import { Ref } from 'vue';
2
2
  import { ListEntry } from 'x-group-list';
3
3
  import { ZProperty } from 'x-runtime-lib';
4
4
  import { ChangeEvent } from './misc';
5
- import { PropertyStateMap } from './propertyState';
5
+ import { PropertyState } from './propertyState';
6
6
  export declare function provideVersion(version: Ref<string>): void;
7
7
  export declare function injectVersion(): Ref<string>;
8
8
  export declare function provideType(type: Ref<string>): void;
@@ -13,8 +13,8 @@ export declare function provideConfig(config: Ref<ZProperty[]>): void;
13
13
  export declare function injectConfig(): Ref<ZProperty[]>;
14
14
  export declare function provideObject(object: Ref<any>): void;
15
15
  export declare function injectObject(): Ref<any>;
16
- export declare function providePropertyStates(propertyStates: Ref<PropertyStateMap>): void;
17
- export declare function injectPropertyStates(): Ref<PropertyStateMap>;
16
+ export declare function providePropertyState(propertyState: Ref<PropertyState>): void;
17
+ export declare function injectPropertyState(): Ref<PropertyState>;
18
18
  export declare function provideChangeEvent(changeEvent: ChangeEvent): void;
19
19
  export declare function injectChangeEvent(): ChangeEvent;
20
20
  export declare function provideCompList(compList: Ref<ListEntry[]>): void;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "x-prop-tree",
3
3
  "private": false,
4
- "version": "0.7.40",
4
+ "version": "0.7.42",
5
5
  "type": "module",
6
6
  "module": "dist/index.js",
7
7
  "types": "dist/index.d.ts",
@@ -23,39 +23,39 @@
23
23
  },
24
24
  "dependencies": {
25
25
  "lodash-es": "^4.17.23",
26
- "vue": "^3.5.27",
26
+ "vue": "^3.5.29",
27
27
  "vue-i18n": "^11.2.8",
28
- "vuetify": "^3.11.8"
28
+ "vuetify": "^4.0.0"
29
29
  },
30
30
  "peerDependencies": {
31
- "x-block-lib": "^0.10.3",
32
- "x-essential-lib": "^0.9.25",
33
- "x-group-list": "^0.4.10",
34
- "x-runtime-lib": "^0.8.213",
35
- "x-state-lib": "^0.3.39"
31
+ "x-block-lib": "^0.10.6",
32
+ "x-essential-lib": "^0.9.26",
33
+ "x-group-list": "^0.4.11",
34
+ "x-runtime-lib": "^0.8.216",
35
+ "x-state-lib": "^0.3.40"
36
36
  },
37
37
  "devDependencies": {
38
- "@eslint/js": "^9.39.2",
38
+ "@eslint/js": "^10.0.1",
39
39
  "@types/lodash-es": "^4.17.12",
40
- "@types/node": "^25.2.0",
40
+ "@types/node": "^25.3.0",
41
41
  "@vitejs/plugin-vue": "^6.0.4",
42
- "eslint": "^9.39.2",
42
+ "eslint": "^10.0.2",
43
43
  "eslint-config-prettier": "^10.1.8",
44
44
  "eslint-plugin-prettier": "^5.5.5",
45
- "eslint-plugin-vue": "^10.7.0",
45
+ "eslint-plugin-vue": "^10.8.0",
46
46
  "globals": "^17.3.0",
47
47
  "husky": "^9.1.7",
48
48
  "lint-staged": "^16.2.7",
49
49
  "prettier": "3.8.1",
50
50
  "sass": "^1.97.3",
51
51
  "typescript": "^5.9.3",
52
- "typescript-eslint": "^8.54.0",
52
+ "typescript-eslint": "^8.56.1",
53
53
  "vite": "npm:rolldown-vite@7.3.1",
54
54
  "vite-plugin-css-injected-by-js": "^3.5.2",
55
55
  "vite-plugin-vuetify": "^2.1.3",
56
- "vue-eslint-parser": "^10.2.0",
57
- "vue-router": "^5.0.2",
58
- "vue-tsc": "^3.2.4"
56
+ "vue-eslint-parser": "^10.4.0",
57
+ "vue-router": "^5.0.3",
58
+ "vue-tsc": "^3.2.5"
59
59
  },
60
60
  "overrides": {
61
61
  "vite": "npm:rolldown-vite@7.3.1"
@@ -1,15 +0,0 @@
1
- export type Branch = {
2
- collapse: boolean;
3
- children: BranchMap | BranchArray;
4
- };
5
- export type BranchMap = {
6
- [key: string]: Branch;
7
- };
8
- export type BranchArray = Branch[];
9
- export type Branchs = {
10
- [key: string]: {
11
- [key: string]: Branch;
12
- };
13
- };
14
- export declare const isBranchChildrenMap: (children: BranchMap | BranchArray) => children is BranchMap;
15
- export declare const isBranchChildrenArray: (children: BranchMap | BranchArray) => children is BranchArray;