@okam/stack-ui 1.42.3 → 1.42.4
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/CHANGELOG.md +13 -0
- package/components/Menu/interface.d.ts +7 -1
- package/index153.js +1 -1
- package/index153.mjs +4 -4
- package/index154.js +1 -1
- package/index154.mjs +2 -2
- package/index155.js +1 -1
- package/index155.mjs +1 -1
- package/index156.js +1 -1
- package/index156.mjs +1 -1
- package/index161.js +1 -1
- package/index161.mjs +2 -2
- package/index162.js +1 -1
- package/index162.mjs +15 -14
- package/index163.js +1 -1
- package/index163.mjs +2 -2
- package/index164.js +1 -1
- package/index164.mjs +5 -5
- package/index165.js +1 -1
- package/index165.mjs +3 -3
- package/index172.js +1 -1
- package/index172.mjs +2 -2
- package/index176.js +1 -1
- package/index176.mjs +4 -4
- package/index177.js +1 -1
- package/index177.mjs +1 -1
- package/index178.js +1 -1
- package/index178.mjs +2 -2
- package/index179.js +1 -1
- package/index179.mjs +3 -3
- package/index181.js +1 -1
- package/index181.mjs +3 -3
- package/index232.js +1 -1
- package/index232.mjs +117 -132
- package/index233.js +1 -1
- package/index233.mjs +65 -189
- package/index234.js +1 -1
- package/index234.mjs +378 -19
- package/index235.js +1 -1
- package/index235.mjs +47 -4
- package/index236.js +1 -1
- package/index236.mjs +4 -29
- package/index237.js +1 -1
- package/index237.mjs +23 -48
- package/index238.js +1 -1
- package/index238.mjs +45 -52
- package/index239.js +1 -1
- package/index239.mjs +5 -48
- package/index240.js +1 -1
- package/index240.mjs +22 -95
- package/index241.js +1 -1
- package/index241.mjs +12 -5
- package/index242.js +1 -1
- package/index242.mjs +4 -6
- package/index243.js +1 -1
- package/index243.mjs +13 -40
- package/index244.js +1 -1
- package/index244.mjs +43 -72
- package/index245.js +1 -1
- package/index245.mjs +56 -13
- package/index246.js +1 -1
- package/index246.mjs +40 -67
- package/index247.js +1 -1
- package/index247.mjs +28 -7
- package/index248.js +1 -1
- package/index248.mjs +31 -11
- package/index249.js +1 -1
- package/index249.mjs +13 -46
- package/index250.js +1 -1
- package/index250.mjs +10 -125
- package/index251.js +1 -1
- package/index251.mjs +24 -69
- package/index252.js +1 -1
- package/index252.mjs +8 -380
- package/index253.js +1 -1
- package/index253.mjs +6 -46
- package/index254.js +1 -1
- package/index254.mjs +5 -24
- package/index255.js +1 -1
- package/index255.mjs +7 -24
- package/index256.js +1 -1
- package/index256.mjs +29 -12
- package/index257.js +1 -1
- package/index257.mjs +18 -4
- package/index258.js +1 -1
- package/index258.mjs +13 -14
- package/index259.js +1 -1
- package/index259.mjs +38 -37
- package/index260.js +1 -1
- package/index260.mjs +7 -56
- package/index261.js +1 -1
- package/index261.mjs +16 -27
- package/index262.js +1 -1
- package/index262.mjs +3 -32
- package/index263.js +1 -1
- package/index263.mjs +4 -10
- package/index264.js +1 -1
- package/index264.mjs +19 -9
- package/index265.js +1 -1
- package/index265.mjs +54 -5
- package/index266.js +1 -1
- package/index266.mjs +27 -7
- package/index267.js +1 -1
- package/index267.mjs +136 -25
- package/index268.js +1 -1
- package/index268.mjs +196 -17
- package/index269.js +1 -1
- package/index269.mjs +21 -12
- package/index270.js +1 -1
- package/index270.mjs +47 -41
- package/index271.js +1 -1
- package/index271.mjs +47 -7
- package/index272.js +1 -1
- package/index272.mjs +95 -15
- package/index273.js +1 -1
- package/index273.mjs +72 -3
- package/index274.js +1 -1
- package/index274.mjs +68 -4
- package/index275.js +1 -1
- package/index275.mjs +7 -19
- package/index276.js +1 -1
- package/index276.mjs +11 -27
- package/index277.js +1 -1
- package/index277.mjs +5 -31
- package/index278.js +1 -1
- package/index278.mjs +121 -5
- package/index279.js +1 -1
- package/index279.mjs +43 -121
- package/index280.js +1 -1
- package/index280.mjs +230 -43
- package/index281.js +1 -1
- package/index281.mjs +27 -226
- package/index324.js +1 -1
- package/index324.mjs +63 -7
- package/index325.js +1 -1
- package/index325.mjs +25 -23
- package/index326.js +1 -1
- package/index326.mjs +7 -93
- package/index327.js +1 -1
- package/index327.mjs +27 -62
- package/index328.js +1 -1
- package/index328.mjs +90 -7
- package/index329.js +1 -1
- package/index329.mjs +8 -24
- package/index330.js +1 -1
- package/index330.mjs +25 -33
- package/index331.js +1 -1
- package/index331.mjs +33 -6
- package/index332.js +1 -1
- package/index332.mjs +6 -6
- package/index333.js +1 -1
- package/index333.mjs +6 -50
- package/index334.js +1 -1
- package/index334.mjs +49 -28
- package/index335.js +1 -1
- package/index335.mjs +5 -5
- package/index336.js +1 -1
- package/index336.mjs +20 -65
- package/index337.js +1 -1
- package/index337.mjs +29 -53
- package/index338.js +1 -1
- package/index338.mjs +63 -51
- package/index339.js +1 -1
- package/index339.mjs +43 -271
- package/index340.js +1 -1
- package/index340.mjs +52 -18
- package/index341.js +1 -1
- package/index341.mjs +281 -21
- package/index342.js +1 -1
- package/index342.mjs +20 -29
- package/index346.js +1 -1
- package/index346.mjs +166 -4
- package/index348.js +1 -1
- package/index348.mjs +4 -166
- package/index45.js +1 -1
- package/index45.mjs +68 -63
- package/package.json +1 -1
package/index341.mjs
CHANGED
|
@@ -1,24 +1,284 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
1
|
+
import { Selection as n } from "./index348.mjs";
|
|
2
|
+
import { compareNodeOrder as r, getFirstItem as d, getChildNodes as u } from "./index347.mjs";
|
|
3
|
+
class h {
|
|
4
|
+
/**
|
|
5
|
+
* The type of selection that is allowed in the collection.
|
|
6
|
+
*/
|
|
7
|
+
get selectionMode() {
|
|
8
|
+
return this.state.selectionMode;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Whether the collection allows empty selection.
|
|
12
|
+
*/
|
|
13
|
+
get disallowEmptySelection() {
|
|
14
|
+
return this.state.disallowEmptySelection;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* The selection behavior for the collection.
|
|
18
|
+
*/
|
|
19
|
+
get selectionBehavior() {
|
|
20
|
+
return this.state.selectionBehavior;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Sets the selection behavior for the collection.
|
|
24
|
+
*/
|
|
25
|
+
setSelectionBehavior(t) {
|
|
26
|
+
this.state.setSelectionBehavior(t);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Whether the collection is currently focused.
|
|
30
|
+
*/
|
|
31
|
+
get isFocused() {
|
|
32
|
+
return this.state.isFocused;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Sets whether the collection is focused.
|
|
36
|
+
*/
|
|
37
|
+
setFocused(t) {
|
|
38
|
+
this.state.setFocused(t);
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* The current focused key in the collection.
|
|
42
|
+
*/
|
|
43
|
+
get focusedKey() {
|
|
44
|
+
return this.state.focusedKey;
|
|
45
|
+
}
|
|
46
|
+
/** Whether the first or last child of the focused key should receive focus. */
|
|
47
|
+
get childFocusStrategy() {
|
|
48
|
+
return this.state.childFocusStrategy;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Sets the focused key.
|
|
52
|
+
*/
|
|
53
|
+
setFocusedKey(t, e) {
|
|
54
|
+
(t == null || this.collection.getItem(t)) && this.state.setFocusedKey(t, e);
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* The currently selected keys in the collection.
|
|
58
|
+
*/
|
|
59
|
+
get selectedKeys() {
|
|
60
|
+
return this.state.selectedKeys === "all" ? new Set(this.getSelectAllKeys()) : this.state.selectedKeys;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* The raw selection value for the collection.
|
|
64
|
+
* Either 'all' for select all, or a set of keys.
|
|
65
|
+
*/
|
|
66
|
+
get rawSelection() {
|
|
67
|
+
return this.state.selectedKeys;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Returns whether a key is selected.
|
|
71
|
+
*/
|
|
72
|
+
isSelected(t) {
|
|
73
|
+
if (this.state.selectionMode === "none") return !1;
|
|
74
|
+
let e = this.getKey(t);
|
|
75
|
+
return e == null ? !1 : this.state.selectedKeys === "all" ? this.canSelectItem(e) : this.state.selectedKeys.has(e);
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Whether the selection is empty.
|
|
79
|
+
*/
|
|
80
|
+
get isEmpty() {
|
|
81
|
+
return this.state.selectedKeys !== "all" && this.state.selectedKeys.size === 0;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Whether all items in the collection are selected.
|
|
85
|
+
*/
|
|
86
|
+
get isSelectAll() {
|
|
87
|
+
if (this.isEmpty) return !1;
|
|
88
|
+
if (this.state.selectedKeys === "all") return !0;
|
|
89
|
+
if (this._isSelectAll != null) return this._isSelectAll;
|
|
90
|
+
let t = this.getSelectAllKeys(), e = this.state.selectedKeys;
|
|
91
|
+
return this._isSelectAll = t.every((l) => e.has(l)), this._isSelectAll;
|
|
92
|
+
}
|
|
93
|
+
get firstSelectedKey() {
|
|
94
|
+
let t = null;
|
|
95
|
+
for (let l of this.state.selectedKeys) {
|
|
96
|
+
let s = this.collection.getItem(l);
|
|
97
|
+
(!t || s && r(this.collection, s, t) < 0) && (t = s);
|
|
98
|
+
}
|
|
99
|
+
var e;
|
|
100
|
+
return (e = t == null ? void 0 : t.key) !== null && e !== void 0 ? e : null;
|
|
101
|
+
}
|
|
102
|
+
get lastSelectedKey() {
|
|
103
|
+
let t = null;
|
|
104
|
+
for (let l of this.state.selectedKeys) {
|
|
105
|
+
let s = this.collection.getItem(l);
|
|
106
|
+
(!t || s && r(this.collection, s, t) > 0) && (t = s);
|
|
107
|
+
}
|
|
108
|
+
var e;
|
|
109
|
+
return (e = t == null ? void 0 : t.key) !== null && e !== void 0 ? e : null;
|
|
110
|
+
}
|
|
111
|
+
get disabledKeys() {
|
|
112
|
+
return this.state.disabledKeys;
|
|
113
|
+
}
|
|
114
|
+
get disabledBehavior() {
|
|
115
|
+
return this.state.disabledBehavior;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Extends the selection to the given key.
|
|
119
|
+
*/
|
|
120
|
+
extendSelection(t) {
|
|
121
|
+
if (this.selectionMode === "none") return;
|
|
122
|
+
if (this.selectionMode === "single") {
|
|
123
|
+
this.replaceSelection(t);
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
let e = this.getKey(t);
|
|
127
|
+
if (e == null) return;
|
|
128
|
+
let l;
|
|
129
|
+
if (this.state.selectedKeys === "all") l = new n([
|
|
130
|
+
e
|
|
131
|
+
], e, e);
|
|
132
|
+
else {
|
|
133
|
+
let i = this.state.selectedKeys;
|
|
134
|
+
var s;
|
|
135
|
+
let a = (s = i.anchorKey) !== null && s !== void 0 ? s : e;
|
|
136
|
+
l = new n(i, a, e);
|
|
137
|
+
var o;
|
|
138
|
+
for (let c of this.getKeyRange(a, (o = i.currentKey) !== null && o !== void 0 ? o : e)) l.delete(c);
|
|
139
|
+
for (let c of this.getKeyRange(e, a)) this.canSelectItem(c) && l.add(c);
|
|
140
|
+
}
|
|
141
|
+
this.state.setSelectedKeys(l);
|
|
142
|
+
}
|
|
143
|
+
getKeyRange(t, e) {
|
|
144
|
+
let l = this.collection.getItem(t), s = this.collection.getItem(e);
|
|
145
|
+
return l && s ? r(this.collection, l, s) <= 0 ? this.getKeyRangeInternal(t, e) : this.getKeyRangeInternal(e, t) : [];
|
|
146
|
+
}
|
|
147
|
+
getKeyRangeInternal(t, e) {
|
|
148
|
+
var l;
|
|
149
|
+
if (!((l = this.layoutDelegate) === null || l === void 0) && l.getKeyRange) return this.layoutDelegate.getKeyRange(t, e);
|
|
150
|
+
let s = [], o = t;
|
|
151
|
+
for (; o != null; ) {
|
|
152
|
+
let i = this.collection.getItem(o);
|
|
153
|
+
if (i && (i.type === "item" || i.type === "cell" && this.allowsCellSelection) && s.push(o), o === e) return s;
|
|
154
|
+
o = this.collection.getKeyAfter(o);
|
|
155
|
+
}
|
|
156
|
+
return [];
|
|
157
|
+
}
|
|
158
|
+
getKey(t) {
|
|
159
|
+
let e = this.collection.getItem(t);
|
|
160
|
+
if (!e || e.type === "cell" && this.allowsCellSelection) return t;
|
|
161
|
+
for (; e && e.type !== "item" && e.parentKey != null; ) e = this.collection.getItem(e.parentKey);
|
|
162
|
+
return !e || e.type !== "item" ? null : e.key;
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Toggles whether the given key is selected.
|
|
166
|
+
*/
|
|
167
|
+
toggleSelection(t) {
|
|
168
|
+
if (this.selectionMode === "none") return;
|
|
169
|
+
if (this.selectionMode === "single" && !this.isSelected(t)) {
|
|
170
|
+
this.replaceSelection(t);
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
let e = this.getKey(t);
|
|
174
|
+
if (e == null) return;
|
|
175
|
+
let l = new n(this.state.selectedKeys === "all" ? this.getSelectAllKeys() : this.state.selectedKeys);
|
|
176
|
+
l.has(e) ? l.delete(e) : this.canSelectItem(e) && (l.add(e), l.anchorKey = e, l.currentKey = e), !(this.disallowEmptySelection && l.size === 0) && this.state.setSelectedKeys(l);
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Replaces the selection with only the given key.
|
|
180
|
+
*/
|
|
181
|
+
replaceSelection(t) {
|
|
182
|
+
if (this.selectionMode === "none") return;
|
|
183
|
+
let e = this.getKey(t);
|
|
184
|
+
if (e == null) return;
|
|
185
|
+
let l = this.canSelectItem(e) ? new n([
|
|
186
|
+
e
|
|
187
|
+
], e, e) : new n();
|
|
188
|
+
this.state.setSelectedKeys(l);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Replaces the selection with the given keys.
|
|
192
|
+
*/
|
|
193
|
+
setSelectedKeys(t) {
|
|
194
|
+
if (this.selectionMode === "none") return;
|
|
195
|
+
let e = new n();
|
|
196
|
+
for (let l of t) {
|
|
197
|
+
let s = this.getKey(l);
|
|
198
|
+
if (s != null && (e.add(s), this.selectionMode === "single"))
|
|
199
|
+
break;
|
|
200
|
+
}
|
|
201
|
+
this.state.setSelectedKeys(e);
|
|
202
|
+
}
|
|
203
|
+
getSelectAllKeys() {
|
|
204
|
+
let t = [], e = (l) => {
|
|
205
|
+
for (; l != null; ) {
|
|
206
|
+
if (this.canSelectItem(l)) {
|
|
207
|
+
var s;
|
|
208
|
+
let i = this.collection.getItem(l);
|
|
209
|
+
(i == null ? void 0 : i.type) === "item" && t.push(l);
|
|
210
|
+
var o;
|
|
211
|
+
i != null && i.hasChildNodes && (this.allowsCellSelection || i.type !== "item") && e((o = (s = d(u(i, this.collection))) === null || s === void 0 ? void 0 : s.key) !== null && o !== void 0 ? o : null);
|
|
212
|
+
}
|
|
213
|
+
l = this.collection.getKeyAfter(l);
|
|
214
|
+
}
|
|
215
|
+
};
|
|
216
|
+
return e(this.collection.getFirstKey()), t;
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Selects all items in the collection.
|
|
220
|
+
*/
|
|
221
|
+
selectAll() {
|
|
222
|
+
!this.isSelectAll && this.selectionMode === "multiple" && this.state.setSelectedKeys("all");
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Removes all keys from the selection.
|
|
226
|
+
*/
|
|
227
|
+
clearSelection() {
|
|
228
|
+
!this.disallowEmptySelection && (this.state.selectedKeys === "all" || this.state.selectedKeys.size > 0) && this.state.setSelectedKeys(new n());
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Toggles between select all and an empty selection.
|
|
232
|
+
*/
|
|
233
|
+
toggleSelectAll() {
|
|
234
|
+
this.isSelectAll ? this.clearSelection() : this.selectAll();
|
|
235
|
+
}
|
|
236
|
+
select(t, e) {
|
|
237
|
+
this.selectionMode !== "none" && (this.selectionMode === "single" ? this.isSelected(t) && !this.disallowEmptySelection ? this.toggleSelection(t) : this.replaceSelection(t) : this.selectionBehavior === "toggle" || e && (e.pointerType === "touch" || e.pointerType === "virtual") ? this.toggleSelection(t) : this.replaceSelection(t));
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Returns whether the current selection is equal to the given selection.
|
|
241
|
+
*/
|
|
242
|
+
isSelectionEqual(t) {
|
|
243
|
+
if (t === this.state.selectedKeys) return !0;
|
|
244
|
+
let e = this.selectedKeys;
|
|
245
|
+
if (t.size !== e.size) return !1;
|
|
246
|
+
for (let l of t)
|
|
247
|
+
if (!e.has(l)) return !1;
|
|
248
|
+
for (let l of e)
|
|
249
|
+
if (!t.has(l)) return !1;
|
|
250
|
+
return !0;
|
|
251
|
+
}
|
|
252
|
+
canSelectItem(t) {
|
|
253
|
+
var e;
|
|
254
|
+
if (this.state.selectionMode === "none" || this.state.disabledKeys.has(t)) return !1;
|
|
255
|
+
let l = this.collection.getItem(t);
|
|
256
|
+
return !(!l || !(l == null || (e = l.props) === null || e === void 0) && e.isDisabled || l.type === "cell" && !this.allowsCellSelection);
|
|
257
|
+
}
|
|
258
|
+
isDisabled(t) {
|
|
259
|
+
var e, l;
|
|
260
|
+
return this.state.disabledBehavior === "all" && (this.state.disabledKeys.has(t) || !!(!((l = this.collection.getItem(t)) === null || l === void 0 || (e = l.props) === null || e === void 0) && e.isDisabled));
|
|
261
|
+
}
|
|
262
|
+
isLink(t) {
|
|
263
|
+
var e, l;
|
|
264
|
+
return !!(!((l = this.collection.getItem(t)) === null || l === void 0 || (e = l.props) === null || e === void 0) && e.href);
|
|
265
|
+
}
|
|
266
|
+
getItemProps(t) {
|
|
267
|
+
var e;
|
|
268
|
+
return (e = this.collection.getItem(t)) === null || e === void 0 ? void 0 : e.props;
|
|
269
|
+
}
|
|
270
|
+
withCollection(t) {
|
|
271
|
+
return new h(t, this.state, {
|
|
272
|
+
allowsCellSelection: this.allowsCellSelection,
|
|
273
|
+
layoutDelegate: this.layoutDelegate || void 0
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
constructor(t, e, l) {
|
|
277
|
+
this.collection = t, this.state = e;
|
|
278
|
+
var s;
|
|
279
|
+
this.allowsCellSelection = (s = l == null ? void 0 : l.allowsCellSelection) !== null && s !== void 0 ? s : !1, this._isSelectAll = null, this.layoutDelegate = (l == null ? void 0 : l.layoutDelegate) || null;
|
|
280
|
+
}
|
|
18
281
|
}
|
|
19
282
|
export {
|
|
20
|
-
|
|
21
|
-
u as getItemElement,
|
|
22
|
-
d as isNonContiguousSelectionModifier,
|
|
23
|
-
b as useCollectionId
|
|
283
|
+
h as SelectionManager
|
|
24
284
|
};
|
package/index342.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("./index346.js"),n=require("react");function s(u,l,t){let i=n.useMemo(()=>new d.CollectionBuilder,[]),{children:r,items:o,collection:e}=u;return n.useMemo(()=>{if(e)return e;let c=i.build({children:r,items:o},t);return l(c)},[i,r,o,e,t,l])}exports.useCollection=s;
|
package/index342.mjs
CHANGED
|
@@ -1,32 +1,23 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
function
|
|
4
|
-
let {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
typeSelectProps: {
|
|
21
|
-
// Using a capturing listener to catch the keydown event before
|
|
22
|
-
// other hooks in order to handle the Spacebar event.
|
|
23
|
-
onKeyDownCapture: o.getKeyForSearch ? u : void 0
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
function s(r) {
|
|
28
|
-
return r.length === 1 || !/^[A-Z]/i.test(r) ? r : "";
|
|
1
|
+
import { CollectionBuilder as u } from "./index346.mjs";
|
|
2
|
+
import { useMemo as n } from "react";
|
|
3
|
+
function b(d, l, r) {
|
|
4
|
+
let t = n(() => new u(), []), { children: i, items: o, collection: e } = d;
|
|
5
|
+
return n(() => {
|
|
6
|
+
if (e) return e;
|
|
7
|
+
let c = t.build({
|
|
8
|
+
children: i,
|
|
9
|
+
items: o
|
|
10
|
+
}, r);
|
|
11
|
+
return l(c);
|
|
12
|
+
}, [
|
|
13
|
+
t,
|
|
14
|
+
i,
|
|
15
|
+
o,
|
|
16
|
+
e,
|
|
17
|
+
r,
|
|
18
|
+
l
|
|
19
|
+
]);
|
|
29
20
|
}
|
|
30
21
|
export {
|
|
31
|
-
|
|
22
|
+
b as useCollection
|
|
32
23
|
};
|
package/index346.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("react");class I{build(e,l){return this.context=l,V(()=>this.iterateCollection(e))}*iterateCollection(e){let{children:l,items:u}=e;if(y.isValidElement(l)&&l.type===y.Fragment)yield*this.iterateCollection({children:l.props.children,items:u});else if(typeof l=="function"){if(!u)throw new Error("props.children was a function but props.items is missing");let n=0;for(let r of u)yield*this.getFullNode({value:r,index:n},{renderer:l}),n++}else{let n=[];y.Children.forEach(l,t=>{t&&n.push(t)});let r=0;for(let t of n){let d=this.getFullNode({element:t,index:r},{});for(let m of d)r++,yield m}}}getKey(e,l,u,n){if(e.key!=null)return e.key;if(l.type==="cell"&&l.key!=null)return`${n}${l.key}`;let r=l.value;if(r!=null){var t;let d=(t=r.key)!==null&&t!==void 0?t:r.id;if(d==null)throw new Error("No key found for item");return d}return n?`${n}.${l.index}`:`$.${l.index}`}getChildState(e,l){return{renderer:l.renderer||e.renderer}}*getFullNode(e,l,u,n){if(y.isValidElement(e.element)&&e.element.type===y.Fragment){let i=[];y.Children.forEach(e.element.props.children,f=>{i.push(f)});var r;let s=(r=e.index)!==null&&r!==void 0?r:0;for(const f of i)yield*this.getFullNode({element:f,index:s++},l,u,n);return}let t=e.element;if(!t&&e.value&&l&&l.renderer){let i=this.cache.get(e.value);if(i&&(!i.shouldInvalidate||!i.shouldInvalidate(this.context))){i.index=e.index,i.parentKey=n?n.key:null,yield i;return}t=l.renderer(e.value)}if(y.isValidElement(t)){let i=t.type;if(typeof i!="function"&&typeof i.getCollectionNode!="function"){let c=t.type;throw new Error(`Unknown element <${c}> in collection.`)}let s=i.getCollectionNode(t.props,this.context);var d;let f=(d=e.index)!==null&&d!==void 0?d:0,v=s.next();for(;!v.done&&v.value;){let c=v.value;e.index=f;var m;let C=(m=c.key)!==null&&m!==void 0?m:null;C==null&&(C=c.element?null:this.getKey(t,e,l,u));let S=[...this.getFullNode({...c,key:C,index:f,wrapper:p(e.wrapper,c.wrapper)},this.getChildState(l,c),u?`${u}${t.key}`:t.key,n)];for(let h of S){var x,k;h.value=(k=(x=c.value)!==null&&x!==void 0?x:e.value)!==null&&k!==void 0?k:null,h.value&&this.cache.set(h.value,h);var g;if(e.type&&h.type!==e.type)throw new Error(`Unsupported type <${E(h.type)}> in <${E((g=n==null?void 0:n.type)!==null&&g!==void 0?g:"unknown parent type")}>. Only <${E(e.type)}> is supported.`);f++,yield h}v=s.next(S)}return}if(e.key==null||e.type==null)return;let F=this;var w,b;let $={type:e.type,props:e.props,key:e.key,parentKey:n?n.key:null,value:(w=e.value)!==null&&w!==void 0?w:null,level:n?n.level+1:0,index:e.index,rendered:e.rendered,textValue:(b=e.textValue)!==null&&b!==void 0?b:"","aria-label":e["aria-label"],wrapper:e.wrapper,shouldInvalidate:e.shouldInvalidate,hasChildNodes:e.hasChildNodes||!1,childNodes:V(function*(){if(!e.hasChildNodes||!e.childNodes)return;let i=0;for(let s of e.childNodes()){s.key!=null&&(s.key=`${$.key}${s.key}`);let f=F.getFullNode({...s,index:i},F.getChildState(l,s),$.key,$);for(let v of f)i++,yield v}})};yield $}constructor(){this.cache=new WeakMap}}function V(o){let e=[],l=null;return{*[Symbol.iterator](){for(let u of e)yield u;l||(l=o());for(let u of l)e.push(u),yield u}}}function p(o,e){if(o&&e)return l=>o(e(l));if(o)return o;if(e)return e}function E(o){return o[0].toUpperCase()+o.slice(1)}exports.CollectionBuilder=I;
|
package/index346.mjs
CHANGED
|
@@ -1,8 +1,170 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import y from "react";
|
|
2
|
+
class z {
|
|
3
|
+
build(e, l) {
|
|
4
|
+
return this.context = l, p(() => this.iterateCollection(e));
|
|
4
5
|
}
|
|
6
|
+
*iterateCollection(e) {
|
|
7
|
+
let { children: l, items: u } = e;
|
|
8
|
+
if (y.isValidElement(l) && l.type === y.Fragment) yield* this.iterateCollection({
|
|
9
|
+
children: l.props.children,
|
|
10
|
+
items: u
|
|
11
|
+
});
|
|
12
|
+
else if (typeof l == "function") {
|
|
13
|
+
if (!u) throw new Error("props.children was a function but props.items is missing");
|
|
14
|
+
let n = 0;
|
|
15
|
+
for (let r of u)
|
|
16
|
+
yield* this.getFullNode({
|
|
17
|
+
value: r,
|
|
18
|
+
index: n
|
|
19
|
+
}, {
|
|
20
|
+
renderer: l
|
|
21
|
+
}), n++;
|
|
22
|
+
} else {
|
|
23
|
+
let n = [];
|
|
24
|
+
y.Children.forEach(l, (t) => {
|
|
25
|
+
t && n.push(t);
|
|
26
|
+
});
|
|
27
|
+
let r = 0;
|
|
28
|
+
for (let t of n) {
|
|
29
|
+
let d = this.getFullNode({
|
|
30
|
+
element: t,
|
|
31
|
+
index: r
|
|
32
|
+
}, {});
|
|
33
|
+
for (let m of d)
|
|
34
|
+
r++, yield m;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
getKey(e, l, u, n) {
|
|
39
|
+
if (e.key != null) return e.key;
|
|
40
|
+
if (l.type === "cell" && l.key != null) return `${n}${l.key}`;
|
|
41
|
+
let r = l.value;
|
|
42
|
+
if (r != null) {
|
|
43
|
+
var t;
|
|
44
|
+
let d = (t = r.key) !== null && t !== void 0 ? t : r.id;
|
|
45
|
+
if (d == null) throw new Error("No key found for item");
|
|
46
|
+
return d;
|
|
47
|
+
}
|
|
48
|
+
return n ? `${n}.${l.index}` : `$.${l.index}`;
|
|
49
|
+
}
|
|
50
|
+
getChildState(e, l) {
|
|
51
|
+
return {
|
|
52
|
+
renderer: l.renderer || e.renderer
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
*getFullNode(e, l, u, n) {
|
|
56
|
+
if (y.isValidElement(e.element) && e.element.type === y.Fragment) {
|
|
57
|
+
let i = [];
|
|
58
|
+
y.Children.forEach(e.element.props.children, (s) => {
|
|
59
|
+
i.push(s);
|
|
60
|
+
});
|
|
61
|
+
var r;
|
|
62
|
+
let o = (r = e.index) !== null && r !== void 0 ? r : 0;
|
|
63
|
+
for (const s of i) yield* this.getFullNode({
|
|
64
|
+
element: s,
|
|
65
|
+
index: o++
|
|
66
|
+
}, l, u, n);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
let t = e.element;
|
|
70
|
+
if (!t && e.value && l && l.renderer) {
|
|
71
|
+
let i = this.cache.get(e.value);
|
|
72
|
+
if (i && (!i.shouldInvalidate || !i.shouldInvalidate(this.context))) {
|
|
73
|
+
i.index = e.index, i.parentKey = n ? n.key : null, yield i;
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
t = l.renderer(e.value);
|
|
77
|
+
}
|
|
78
|
+
if (y.isValidElement(t)) {
|
|
79
|
+
let i = t.type;
|
|
80
|
+
if (typeof i != "function" && typeof i.getCollectionNode != "function") {
|
|
81
|
+
let h = t.type;
|
|
82
|
+
throw new Error(`Unknown element <${h}> in collection.`);
|
|
83
|
+
}
|
|
84
|
+
let o = i.getCollectionNode(t.props, this.context);
|
|
85
|
+
var d;
|
|
86
|
+
let s = (d = e.index) !== null && d !== void 0 ? d : 0, v = o.next();
|
|
87
|
+
for (; !v.done && v.value; ) {
|
|
88
|
+
let h = v.value;
|
|
89
|
+
e.index = s;
|
|
90
|
+
var m;
|
|
91
|
+
let b = (m = h.key) !== null && m !== void 0 ? m : null;
|
|
92
|
+
b == null && (b = h.element ? null : this.getKey(t, e, l, u));
|
|
93
|
+
let V = [
|
|
94
|
+
...this.getFullNode({
|
|
95
|
+
...h,
|
|
96
|
+
key: b,
|
|
97
|
+
index: s,
|
|
98
|
+
wrapper: I(e.wrapper, h.wrapper)
|
|
99
|
+
}, this.getChildState(l, h), u ? `${u}${t.key}` : t.key, n)
|
|
100
|
+
];
|
|
101
|
+
for (let c of V) {
|
|
102
|
+
var x, k;
|
|
103
|
+
c.value = (k = (x = h.value) !== null && x !== void 0 ? x : e.value) !== null && k !== void 0 ? k : null, c.value && this.cache.set(c.value, c);
|
|
104
|
+
var w;
|
|
105
|
+
if (e.type && c.type !== e.type) throw new Error(`Unsupported type <${E(c.type)}> in <${E((w = n == null ? void 0 : n.type) !== null && w !== void 0 ? w : "unknown parent type")}>. Only <${E(e.type)}> is supported.`);
|
|
106
|
+
s++, yield c;
|
|
107
|
+
}
|
|
108
|
+
v = o.next(V);
|
|
109
|
+
}
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
if (e.key == null || e.type == null) return;
|
|
113
|
+
let F = this;
|
|
114
|
+
var g, C;
|
|
115
|
+
let $ = {
|
|
116
|
+
type: e.type,
|
|
117
|
+
props: e.props,
|
|
118
|
+
key: e.key,
|
|
119
|
+
parentKey: n ? n.key : null,
|
|
120
|
+
value: (g = e.value) !== null && g !== void 0 ? g : null,
|
|
121
|
+
level: n ? n.level + 1 : 0,
|
|
122
|
+
index: e.index,
|
|
123
|
+
rendered: e.rendered,
|
|
124
|
+
textValue: (C = e.textValue) !== null && C !== void 0 ? C : "",
|
|
125
|
+
"aria-label": e["aria-label"],
|
|
126
|
+
wrapper: e.wrapper,
|
|
127
|
+
shouldInvalidate: e.shouldInvalidate,
|
|
128
|
+
hasChildNodes: e.hasChildNodes || !1,
|
|
129
|
+
childNodes: p(function* () {
|
|
130
|
+
if (!e.hasChildNodes || !e.childNodes) return;
|
|
131
|
+
let i = 0;
|
|
132
|
+
for (let o of e.childNodes()) {
|
|
133
|
+
o.key != null && (o.key = `${$.key}${o.key}`);
|
|
134
|
+
let s = F.getFullNode({
|
|
135
|
+
...o,
|
|
136
|
+
index: i
|
|
137
|
+
}, F.getChildState(l, o), $.key, $);
|
|
138
|
+
for (let v of s)
|
|
139
|
+
i++, yield v;
|
|
140
|
+
}
|
|
141
|
+
})
|
|
142
|
+
};
|
|
143
|
+
yield $;
|
|
144
|
+
}
|
|
145
|
+
constructor() {
|
|
146
|
+
this.cache = /* @__PURE__ */ new WeakMap();
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
function p(f) {
|
|
150
|
+
let e = [], l = null;
|
|
151
|
+
return {
|
|
152
|
+
*[Symbol.iterator]() {
|
|
153
|
+
for (let u of e) yield u;
|
|
154
|
+
l || (l = f());
|
|
155
|
+
for (let u of l)
|
|
156
|
+
e.push(u), yield u;
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
function I(f, e) {
|
|
161
|
+
if (f && e) return (l) => f(e(l));
|
|
162
|
+
if (f) return f;
|
|
163
|
+
if (e) return e;
|
|
164
|
+
}
|
|
165
|
+
function E(f) {
|
|
166
|
+
return f[0].toUpperCase() + f.slice(1);
|
|
5
167
|
}
|
|
6
168
|
export {
|
|
7
|
-
|
|
169
|
+
z as CollectionBuilder
|
|
8
170
|
};
|
package/index348.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class o extends Set{constructor(t,l,i){super(t),t instanceof o?(this.anchorKey=l??t.anchorKey,this.currentKey=i??t.currentKey):(this.anchorKey=l??null,this.currentKey=i??null)}}exports.Selection=o;
|