@sprawlify/vue 0.0.65 → 0.0.67
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/dist/clean-props-BDv2zb5M.js +9 -0
- package/dist/collapsible-DQfAISmg.js +259 -0
- package/dist/collection-Ba0Aeh5P.js +218 -0
- package/dist/components/accordion/index.d.ts +195 -0
- package/dist/components/accordion/index.js +361 -0
- package/dist/components/angle-slider/index.d.ts +230 -0
- package/dist/components/angle-slider/index.js +371 -0
- package/dist/components/avatar/index.d.ts +116 -0
- package/dist/components/avatar/index.js +177 -0
- package/dist/components/bottom-sheet/index.d.ts +241 -0
- package/dist/components/bottom-sheet/index.js +429 -0
- package/dist/components/carousel/index.d.ts +306 -0
- package/dist/components/carousel/index.js +500 -0
- package/dist/components/checkbox/index.d.ts +273 -0
- package/dist/components/checkbox/index.js +500 -0
- package/dist/components/client-only/index.d.ts +20 -0
- package/dist/components/client-only/index.js +22 -0
- package/dist/components/clipboard/index.d.ts +204 -0
- package/dist/components/clipboard/index.js +297 -0
- package/dist/components/collapsible/index.d.ts +15 -23
- package/dist/components/collapsible/index.js +5 -325
- package/dist/components/collection/index.d.ts +2 -0
- package/dist/components/collection/index.js +4 -0
- package/dist/components/color-picker/index.d.ts +610 -0
- package/dist/components/color-picker/index.js +1127 -0
- package/dist/components/combobox/index.d.ts +618 -0
- package/dist/components/combobox/index.js +802 -0
- package/dist/components/date-picker/index.d.ts +597 -0
- package/dist/components/date-picker/index.js +1110 -0
- package/dist/components/dialog/index.d.ts +270 -0
- package/dist/components/dialog/index.js +433 -0
- package/dist/components/download-trigger/index.d.ts +29 -0
- package/dist/components/download-trigger/index.js +68 -0
- package/dist/components/editable/index.d.ts +288 -0
- package/dist/components/editable/index.js +459 -0
- package/dist/components/field/index.d.ts +326 -0
- package/dist/components/field/index.js +7 -0
- package/dist/components/fieldset/index.d.ts +161 -0
- package/dist/components/fieldset/index.js +7 -0
- package/dist/components/highlight/index.d.ts +35 -0
- package/dist/components/highlight/index.js +57 -0
- package/dist/components/menu/index.d.ts +498 -0
- package/dist/components/menu/index.js +885 -0
- package/dist/components/presence/index.d.ts +3 -0
- package/dist/components/presence/index.js +6 -0
- package/dist/components/select/index.d.ts +430 -0
- package/dist/components/select/index.js +769 -0
- package/dist/{use-forward-expose-BIk4OI3R.js → core-DNndr38p.js} +2 -170
- package/dist/create-split-props-YZ3qgXe_.js +11 -0
- package/dist/factory-BH3WrWd2.js +68 -0
- package/dist/factory-D_ge_w76.d.ts +8 -0
- package/dist/field-DnHnX3Tf.js +501 -0
- package/dist/fieldset-DzhN7Zrg.js +278 -0
- package/dist/{types-BQfkZGpL.d.ts → index-B66Om_3U.d.ts} +1 -9
- package/dist/index-BBHms9-0.d.ts +91 -0
- package/dist/index-CDQghZtv.d.ts +57 -0
- package/dist/index-DqRk-Yea.d.ts +199 -0
- package/dist/index.d.ts +4 -92
- package/dist/index.js +4 -50
- package/dist/presence-CvUnYMZQ.js +105 -0
- package/dist/presence-types-Bv1E60Cw.d.ts +13 -0
- package/dist/providers-B2CNPFg1.js +108 -0
- package/dist/types-Bj-dS2Hc.d.ts +9 -0
- package/dist/use-forward-expose-4p5AGAI3.js +67 -0
- package/dist/use-render-strategy-BkxoN6ll.js +7 -0
- package/dist/use-render-strategy-CHj_pCfT.d.ts +9 -0
- package/dist/utils-B4FuOOE-.js +51 -0
- package/package.json +86 -2
|
@@ -1,327 +1,7 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
1
|
+
import "../../core-DNndr38p.js";
|
|
2
|
+
import "../../providers-B2CNPFg1.js";
|
|
3
|
+
import "../../use-forward-expose-4p5AGAI3.js";
|
|
4
|
+
import "../../factory-BH3WrWd2.js";
|
|
5
|
+
import { a as collapsible_root_default, c as collapsible_context_default, i as collapsible_trigger_default, l as collapsible_content_default, n as collapsibleAnatomy, o as useCollapsible, r as collapsible_indicator_default, s as collapsible_root_provider_default, t as collapsible_exports, u as useCollapsibleContext } from "../../collapsible-DQfAISmg.js";
|
|
6
6
|
|
|
7
|
-
//#region src/utils/dynamic.ts
|
|
8
|
-
const Dynamic = defineComponent({
|
|
9
|
-
name: "Dynamic",
|
|
10
|
-
inheritAttrs: false,
|
|
11
|
-
setup(_, { attrs, slots }) {
|
|
12
|
-
return () => {
|
|
13
|
-
if (!slots.default) return null;
|
|
14
|
-
const children = renderSlotFragments(slots.default());
|
|
15
|
-
const [firstChildren, ...otherChildren] = children;
|
|
16
|
-
if (Object.keys(attrs).length > 0) {
|
|
17
|
-
delete firstChildren.props?.ref;
|
|
18
|
-
const mergedProps = mergeProps$1(attrs, firstChildren.props ?? {});
|
|
19
|
-
const cloned = cloneVNode(firstChildren, mergedProps);
|
|
20
|
-
for (const prop in mergedProps) if (prop.startsWith("on")) {
|
|
21
|
-
cloned.props ||= {};
|
|
22
|
-
cloned.props[prop] = mergedProps[prop];
|
|
23
|
-
}
|
|
24
|
-
return children.length === 1 ? cloned : [cloned, ...otherChildren];
|
|
25
|
-
}
|
|
26
|
-
return children;
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
});
|
|
30
|
-
function renderSlotFragments(children) {
|
|
31
|
-
if (!children) return [];
|
|
32
|
-
return children.flatMap((child) => {
|
|
33
|
-
if (child.type === Fragment) return renderSlotFragments(child.children);
|
|
34
|
-
return [child];
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
//#endregion
|
|
39
|
-
//#region src/components/factory.ts
|
|
40
|
-
const SELF_CLOSING_TAGS = "br, hr, img, input, area, textarea".split(", ");
|
|
41
|
-
const isSelfClosingTag = (tag) => typeof tag === "string" && SELF_CLOSING_TAGS.includes(tag);
|
|
42
|
-
const withAsChild = (component) => {
|
|
43
|
-
return defineComponent({
|
|
44
|
-
name: "Polymorphic",
|
|
45
|
-
inheritAttrs: false,
|
|
46
|
-
props: { asChild: {
|
|
47
|
-
type: Boolean,
|
|
48
|
-
default: false
|
|
49
|
-
} },
|
|
50
|
-
setup(props, { attrs, slots }) {
|
|
51
|
-
if (!props.asChild) return () => h(component, attrs, isSelfClosingTag(component) ? void 0 : slots.default?.());
|
|
52
|
-
return () => h(Dynamic, attrs, slots);
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
};
|
|
56
|
-
function jsxFactory() {
|
|
57
|
-
const cache = /* @__PURE__ */ new Map();
|
|
58
|
-
return new Proxy(withAsChild, {
|
|
59
|
-
apply(_target, _thisArg, argArray) {
|
|
60
|
-
return withAsChild(argArray[0]);
|
|
61
|
-
},
|
|
62
|
-
get(_, element) {
|
|
63
|
-
if (!cache.has(element)) cache.set(element, withAsChild(element));
|
|
64
|
-
return cache.get(element);
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
const sprawlify = jsxFactory();
|
|
69
|
-
|
|
70
|
-
//#endregion
|
|
71
|
-
//#region src/components/collapsible/use-collapsible-context.ts
|
|
72
|
-
const [CollapsibleProvider, useCollapsibleContext] = createContext("CollapsibleContext");
|
|
73
|
-
|
|
74
|
-
//#endregion
|
|
75
|
-
//#region src/components/collapsible/collapsible-content.vue?vue&type=script&setup=true&lang.ts
|
|
76
|
-
var collapsible_content_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
77
|
-
__name: "collapsible-content",
|
|
78
|
-
props: { asChild: {
|
|
79
|
-
type: Boolean,
|
|
80
|
-
required: false
|
|
81
|
-
} },
|
|
82
|
-
setup(__props) {
|
|
83
|
-
const collapsible = useCollapsibleContext();
|
|
84
|
-
useForwardExpose();
|
|
85
|
-
return (_ctx, _cache) => {
|
|
86
|
-
return !unref(collapsible).unmounted ? (openBlock(), createBlock(unref(sprawlify).div, mergeProps({ key: 0 }, unref(collapsible).getContentProps(), { "as-child": __props.asChild }), {
|
|
87
|
-
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
88
|
-
_: 3
|
|
89
|
-
}, 16, ["as-child"])) : createCommentVNode("v-if", true);
|
|
90
|
-
};
|
|
91
|
-
}
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
//#endregion
|
|
95
|
-
//#region src/components/collapsible/collapsible-content.vue
|
|
96
|
-
var collapsible_content_default = collapsible_content_vue_vue_type_script_setup_true_lang_default;
|
|
97
|
-
|
|
98
|
-
//#endregion
|
|
99
|
-
//#region src/components/collapsible/collapsible-context.vue?vue&type=script&setup=true&lang.ts
|
|
100
|
-
var collapsible_context_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
101
|
-
__name: "collapsible-context",
|
|
102
|
-
setup(__props) {
|
|
103
|
-
const collapsible = useCollapsibleContext();
|
|
104
|
-
return (_ctx, _cache) => {
|
|
105
|
-
return renderSlot(_ctx.$slots, "default", normalizeProps(guardReactiveProps(unref(collapsible))));
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
//#endregion
|
|
111
|
-
//#region src/components/collapsible/collapsible-context.vue
|
|
112
|
-
var collapsible_context_default = collapsible_context_vue_vue_type_script_setup_true_lang_default;
|
|
113
|
-
|
|
114
|
-
//#endregion
|
|
115
|
-
//#region src/components/collapsible/collapsible-root-provider.vue?vue&type=script&setup=true&lang.ts
|
|
116
|
-
var collapsible_root_provider_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
117
|
-
__name: "collapsible-root-provider",
|
|
118
|
-
props: {
|
|
119
|
-
value: {
|
|
120
|
-
type: null,
|
|
121
|
-
required: true
|
|
122
|
-
},
|
|
123
|
-
asChild: {
|
|
124
|
-
type: Boolean,
|
|
125
|
-
required: false
|
|
126
|
-
}
|
|
127
|
-
},
|
|
128
|
-
setup(__props) {
|
|
129
|
-
const props = __props;
|
|
130
|
-
const collapsible = computed(() => props.value);
|
|
131
|
-
CollapsibleProvider(collapsible);
|
|
132
|
-
useForwardExpose();
|
|
133
|
-
return (_ctx, _cache) => {
|
|
134
|
-
return openBlock(), createBlock(unref(sprawlify).div, mergeProps(collapsible.value.getRootProps(), { "as-child": __props.asChild }), {
|
|
135
|
-
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
136
|
-
_: 3
|
|
137
|
-
}, 16, ["as-child"]);
|
|
138
|
-
};
|
|
139
|
-
}
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
//#endregion
|
|
143
|
-
//#region src/components/collapsible/collapsible-root-provider.vue
|
|
144
|
-
var collapsible_root_provider_default = collapsible_root_provider_vue_vue_type_script_setup_true_lang_default;
|
|
145
|
-
|
|
146
|
-
//#endregion
|
|
147
|
-
//#region src/utils/clean-props.ts
|
|
148
|
-
const cleanProps = (obj) => {
|
|
149
|
-
const result = {};
|
|
150
|
-
for (const [key, value] of Object.entries(obj)) if (value !== void 0) result[key] = value;
|
|
151
|
-
return result;
|
|
152
|
-
};
|
|
153
|
-
|
|
154
|
-
//#endregion
|
|
155
|
-
//#region src/components/collapsible/use-collapsible.ts
|
|
156
|
-
const useCollapsible = (props = {}, emits) => {
|
|
157
|
-
const id = useId();
|
|
158
|
-
const env = useEnvironmentContext(DEFAULT_ENVIRONMENT);
|
|
159
|
-
const locale = useLocaleContext(DEFAULT_LOCALE);
|
|
160
|
-
const context = computed(() => {
|
|
161
|
-
const localeProps = toValue(props);
|
|
162
|
-
return {
|
|
163
|
-
id,
|
|
164
|
-
dir: locale.value.dir,
|
|
165
|
-
getRootNode: env?.value.getRootNode,
|
|
166
|
-
...cleanProps(localeProps),
|
|
167
|
-
onExitComplete: () => {
|
|
168
|
-
emits?.("exitComplete");
|
|
169
|
-
localeProps.onExitComplete?.();
|
|
170
|
-
},
|
|
171
|
-
onOpenChange: (details) => {
|
|
172
|
-
emits?.("openChange", details);
|
|
173
|
-
emits?.("update:open", details.open);
|
|
174
|
-
localeProps.onOpenChange?.(details);
|
|
175
|
-
}
|
|
176
|
-
};
|
|
177
|
-
});
|
|
178
|
-
const service = useMachine(collapsible.machine, context);
|
|
179
|
-
const api = computed(() => collapsible.connect(service, normalizeProps$1));
|
|
180
|
-
const wasVisible = ref(false);
|
|
181
|
-
watch(() => api.value.visible, () => {
|
|
182
|
-
if (api.value.visible) wasVisible.value = true;
|
|
183
|
-
});
|
|
184
|
-
return computed(() => {
|
|
185
|
-
const localeProps = toValue(props);
|
|
186
|
-
return {
|
|
187
|
-
...api.value,
|
|
188
|
-
unmounted: !api.value.visible && !wasVisible.value && localeProps.lazyMount || localeProps.unmountOnExit && !api.value.visible && wasVisible.value
|
|
189
|
-
};
|
|
190
|
-
});
|
|
191
|
-
};
|
|
192
|
-
|
|
193
|
-
//#endregion
|
|
194
|
-
//#region src/components/collapsible/collapsible-root.vue?vue&type=script&setup=true&lang.ts
|
|
195
|
-
var collapsible_root_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
196
|
-
__name: "collapsible-root",
|
|
197
|
-
props: /* @__PURE__ */ mergeDefaults({
|
|
198
|
-
collapsedHeight: {
|
|
199
|
-
type: [Number, String],
|
|
200
|
-
required: false
|
|
201
|
-
},
|
|
202
|
-
collapsedWidth: {
|
|
203
|
-
type: [Number, String],
|
|
204
|
-
required: false
|
|
205
|
-
},
|
|
206
|
-
defaultOpen: {
|
|
207
|
-
type: Boolean,
|
|
208
|
-
required: false
|
|
209
|
-
},
|
|
210
|
-
disabled: {
|
|
211
|
-
type: Boolean,
|
|
212
|
-
required: false
|
|
213
|
-
},
|
|
214
|
-
id: {
|
|
215
|
-
type: String,
|
|
216
|
-
required: false
|
|
217
|
-
},
|
|
218
|
-
ids: {
|
|
219
|
-
type: Object,
|
|
220
|
-
required: false
|
|
221
|
-
},
|
|
222
|
-
lazyMount: {
|
|
223
|
-
type: Boolean,
|
|
224
|
-
required: false
|
|
225
|
-
},
|
|
226
|
-
open: {
|
|
227
|
-
type: Boolean,
|
|
228
|
-
required: false
|
|
229
|
-
},
|
|
230
|
-
unmountOnExit: {
|
|
231
|
-
type: Boolean,
|
|
232
|
-
required: false
|
|
233
|
-
},
|
|
234
|
-
asChild: {
|
|
235
|
-
type: Boolean,
|
|
236
|
-
required: false
|
|
237
|
-
}
|
|
238
|
-
}, {
|
|
239
|
-
defaultOpen: void 0,
|
|
240
|
-
disabled: void 0,
|
|
241
|
-
lazyMount: void 0,
|
|
242
|
-
open: void 0,
|
|
243
|
-
unmountOnExit: void 0
|
|
244
|
-
}),
|
|
245
|
-
emits: [
|
|
246
|
-
"exitComplete",
|
|
247
|
-
"openChange",
|
|
248
|
-
"update:open"
|
|
249
|
-
],
|
|
250
|
-
setup(__props, { emit: __emit }) {
|
|
251
|
-
const collapsible = useCollapsible(__props, __emit);
|
|
252
|
-
CollapsibleProvider(collapsible);
|
|
253
|
-
useForwardExpose();
|
|
254
|
-
return (_ctx, _cache) => {
|
|
255
|
-
return openBlock(), createBlock(unref(sprawlify).div, mergeProps(unref(collapsible).getRootProps(), { "as-child": __props.asChild }), {
|
|
256
|
-
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
257
|
-
_: 3
|
|
258
|
-
}, 16, ["as-child"]);
|
|
259
|
-
};
|
|
260
|
-
}
|
|
261
|
-
});
|
|
262
|
-
|
|
263
|
-
//#endregion
|
|
264
|
-
//#region src/components/collapsible/collapsible-root.vue
|
|
265
|
-
var collapsible_root_default = collapsible_root_vue_vue_type_script_setup_true_lang_default;
|
|
266
|
-
|
|
267
|
-
//#endregion
|
|
268
|
-
//#region src/components/collapsible/collapsible-trigger.vue?vue&type=script&setup=true&lang.ts
|
|
269
|
-
var collapsible_trigger_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
270
|
-
__name: "collapsible-trigger",
|
|
271
|
-
props: { asChild: {
|
|
272
|
-
type: Boolean,
|
|
273
|
-
required: false
|
|
274
|
-
} },
|
|
275
|
-
setup(__props) {
|
|
276
|
-
const collapsible = useCollapsibleContext();
|
|
277
|
-
useForwardExpose();
|
|
278
|
-
return (_ctx, _cache) => {
|
|
279
|
-
return openBlock(), createBlock(unref(sprawlify).button, mergeProps(unref(collapsible).getTriggerProps(), { "as-child": __props.asChild }), {
|
|
280
|
-
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
281
|
-
_: 3
|
|
282
|
-
}, 16, ["as-child"]);
|
|
283
|
-
};
|
|
284
|
-
}
|
|
285
|
-
});
|
|
286
|
-
|
|
287
|
-
//#endregion
|
|
288
|
-
//#region src/components/collapsible/collapsible-trigger.vue
|
|
289
|
-
var collapsible_trigger_default = collapsible_trigger_vue_vue_type_script_setup_true_lang_default;
|
|
290
|
-
|
|
291
|
-
//#endregion
|
|
292
|
-
//#region src/components/collapsible/collapsible-indicator.vue?vue&type=script&setup=true&lang.ts
|
|
293
|
-
var collapsible_indicator_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
294
|
-
__name: "collapsible-indicator",
|
|
295
|
-
props: { asChild: {
|
|
296
|
-
type: Boolean,
|
|
297
|
-
required: false
|
|
298
|
-
} },
|
|
299
|
-
setup(__props) {
|
|
300
|
-
const collapsible = useCollapsibleContext();
|
|
301
|
-
useForwardExpose();
|
|
302
|
-
return (_ctx, _cache) => {
|
|
303
|
-
return openBlock(), createBlock(unref(sprawlify).div, mergeProps(unref(collapsible).getIndicatorProps(), { "as-child": __props.asChild }), {
|
|
304
|
-
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
305
|
-
_: 3
|
|
306
|
-
}, 16, ["as-child"]);
|
|
307
|
-
};
|
|
308
|
-
}
|
|
309
|
-
});
|
|
310
|
-
|
|
311
|
-
//#endregion
|
|
312
|
-
//#region src/components/collapsible/collapsible-indicator.vue
|
|
313
|
-
var collapsible_indicator_default = collapsible_indicator_vue_vue_type_script_setup_true_lang_default;
|
|
314
|
-
|
|
315
|
-
//#endregion
|
|
316
|
-
//#region src/components/collapsible/collapsible.ts
|
|
317
|
-
var collapsible_exports = /* @__PURE__ */ __exportAll({
|
|
318
|
-
Content: () => collapsible_content_default,
|
|
319
|
-
Context: () => collapsible_context_default,
|
|
320
|
-
Indicator: () => collapsible_indicator_default,
|
|
321
|
-
Root: () => collapsible_root_default,
|
|
322
|
-
RootProvider: () => collapsible_root_provider_default,
|
|
323
|
-
Trigger: () => collapsible_trigger_default
|
|
324
|
-
});
|
|
325
|
-
|
|
326
|
-
//#endregion
|
|
327
7
|
export { collapsible_exports as Collapsible, collapsible_content_default as CollapsibleContent, collapsible_context_default as CollapsibleContext, collapsible_indicator_default as CollapsibleIndicator, collapsible_root_default as CollapsibleRoot, collapsible_root_provider_default as CollapsibleRootProvider, collapsible_trigger_default as CollapsibleTrigger, collapsibleAnatomy, useCollapsible, useCollapsibleContext };
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { C as createGridCollection, S as GridCollectionOptions, _ as CollectionItem, a as UseListCollectionReturn, b as createListCollection, c as UseAsyncListReturn, d as FlatTreeNode, f as TreeCollection, g as createTreeCollection, h as createFileTreeCollection, i as UseListCollectionProps, l as useAsyncList, m as TreeNode, n as UseListSelectionReturn, o as useListCollection, p as TreeCollectionOptions, r as useListSelection, s as UseAsyncListProps, t as UseListSelectionProps, u as FilePathTreeNode, v as CollectionOptions, x as GridCollection, y as ListCollection } from "../../index-DqRk-Yea.js";
|
|
2
|
+
export { CollectionItem, CollectionOptions, FilePathTreeNode, FlatTreeNode, GridCollection, GridCollectionOptions, ListCollection, TreeCollection, TreeCollectionOptions, TreeNode, UseAsyncListProps, UseAsyncListReturn, UseListCollectionProps, UseListCollectionReturn, UseListSelectionProps, UseListSelectionReturn, createFileTreeCollection, createGridCollection, createListCollection, createTreeCollection, useAsyncList, useListCollection, useListSelection };
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import "../../core-DNndr38p.js";
|
|
2
|
+
import { a as createTreeCollection, i as createFileTreeCollection, n as useListCollection, o as createListCollection, r as useAsyncList, s as createGridCollection, t as useListSelection } from "../../collection-Ba0Aeh5P.js";
|
|
3
|
+
|
|
4
|
+
export { createFileTreeCollection, createGridCollection, createListCollection, createTreeCollection, useAsyncList, useListCollection, useListSelection };
|