@okam/stack-ui 1.43.0 → 1.44.0

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/index341.mjs CHANGED
@@ -1,69 +1,24 @@
1
- import { ListCollection as p } from "./index342.mjs";
2
- import { useMultipleSelectionState as x } from "./index343.mjs";
3
- import { SelectionManager as S } from "./index344.mjs";
4
- import { useMemo as m, useCallback as w, useRef as k, useEffect as C } from "react";
5
- import { useCollection as D } from "./index345.mjs";
6
- function L(e) {
7
- let { filter: t, layoutDelegate: o } = e, r = x(e), f = m(() => e.disabledKeys ? new Set(e.disabledKeys) : /* @__PURE__ */ new Set(), [
8
- e.disabledKeys
9
- ]), v = w((c) => t ? new p(t(c)) : new p(c), [
10
- t
11
- ]), y = m(() => ({
12
- suppressTextValueWarning: e.suppressTextValueWarning
13
- }), [
14
- e.suppressTextValueWarning
15
- ]), n = D(e, v, y), s = m(() => new S(n, r, {
16
- layoutDelegate: o
17
- }), [
18
- n,
19
- r,
20
- o
21
- ]);
22
- return R(n, s), {
23
- collection: n,
24
- disabledKeys: f,
25
- selectionManager: s
26
- };
1
+ import { useId as l } from "./index185.mjs";
2
+ import { isAppleDevice as a } from "./index250.mjs";
3
+ function d(e) {
4
+ return a() ? e.altKey : e.ctrlKey;
27
5
  }
28
- function R(e, t) {
29
- const o = k(null);
30
- C(() => {
31
- if (t.focusedKey != null && !e.getItem(t.focusedKey) && o.current) {
32
- const l = o.current.getItem(t.focusedKey), $ = [
33
- ...o.current.getKeys()
34
- ].map((a) => {
35
- const i = o.current.getItem(a);
36
- return (i == null ? void 0 : i.type) === "item" ? i : null;
37
- }).filter((a) => a !== null), u = [
38
- ...e.getKeys()
39
- ].map((a) => {
40
- const i = e.getItem(a);
41
- return (i == null ? void 0 : i.type) === "item" ? i : null;
42
- }).filter((a) => a !== null);
43
- var r, f;
44
- const K = ((r = $ == null ? void 0 : $.length) !== null && r !== void 0 ? r : 0) - ((f = u == null ? void 0 : u.length) !== null && f !== void 0 ? f : 0);
45
- var v, y, n;
46
- let d = Math.min(K > 1 ? Math.max(((v = l == null ? void 0 : l.index) !== null && v !== void 0 ? v : 0) - K + 1, 0) : (y = l == null ? void 0 : l.index) !== null && y !== void 0 ? y : 0, ((n = u == null ? void 0 : u.length) !== null && n !== void 0 ? n : 0) - 1), b = null, g = !1;
47
- for (; d >= 0; ) {
48
- if (!t.isDisabled(u[d].key)) {
49
- b = u[d];
50
- break;
51
- }
52
- if (d < u.length - 1 && !g) d++;
53
- else {
54
- g = !0;
55
- var s, c;
56
- d > ((s = l == null ? void 0 : l.index) !== null && s !== void 0 ? s : 0) && (d = (c = l == null ? void 0 : l.index) !== null && c !== void 0 ? c : 0), d--;
57
- }
58
- }
59
- t.setFocusedKey(b ? b.key : null);
60
- }
61
- o.current = e;
62
- }, [
63
- e,
64
- t
65
- ]);
6
+ function u(e, t) {
7
+ var o, f;
8
+ let c = `[data-key="${CSS.escape(String(t))}"]`, r = (o = e.current) === null || o === void 0 ? void 0 : o.dataset.collection;
9
+ return r && (c = `[data-collection="${CSS.escape(r)}"]${c}`), (f = e.current) === null || f === void 0 ? void 0 : f.querySelector(c);
10
+ }
11
+ const n = /* @__PURE__ */ new WeakMap();
12
+ function b(e) {
13
+ let t = l();
14
+ return n.set(e, t), t;
15
+ }
16
+ function s(e) {
17
+ return n.get(e);
66
18
  }
67
19
  export {
68
- L as useListState
20
+ s as getCollectionId,
21
+ u as getItemElement,
22
+ d as isNonContiguousSelectionModifier,
23
+ b as useCollectionId
69
24
  };
package/index342.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class o{*[Symbol.iterator](){yield*this.iterable}get size(){return this._size}getKeys(){return this.keyMap.keys()}getKeyBefore(i){let e=this.keyMap.get(i);var t;return e&&(t=e.prevKey)!==null&&t!==void 0?t:null}getKeyAfter(i){let e=this.keyMap.get(i);var t;return e&&(t=e.nextKey)!==null&&t!==void 0?t:null}getFirstKey(){return this.firstKey}getLastKey(){return this.lastKey}getItem(i){var e;return(e=this.keyMap.get(i))!==null&&e!==void 0?e:null}at(i){const e=[...this.getKeys()];return this.getItem(e[i])}getChildren(i){let e=this.keyMap.get(i);return(e==null?void 0:e.childNodes)||[]}constructor(i){this.keyMap=new Map,this.firstKey=null,this.lastKey=null,this.iterable=i;let e=l=>{if(this.keyMap.set(l.key,l),l.childNodes&&l.type==="section")for(let s of l.childNodes)e(s)};for(let l of i)e(l);let t=null,y=0,n=0;for(let[l,s]of this.keyMap)t?(t.nextKey=l,s.prevKey=t.key):(this.firstKey=l,s.prevKey=void 0),s.type==="item"&&(s.index=y++),(s.type==="section"||s.type==="item")&&n++,t=s,t.nextKey=void 0;this._size=n;var r;this.lastKey=(r=t==null?void 0:t.key)!==null&&r!==void 0?r:null}}exports.ListCollection=o;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("react"),s=1e3;function f(r){let{keyboardDelegate:o,selectionManager:c,onTypeSelect:i}=r,e=l.useRef({search:"",timeout:void 0}).current,u=t=>{let a=g(t.key);if(!(!a||t.ctrlKey||t.metaKey||!t.currentTarget.contains(t.target)||e.search.length===0&&a===" ")){if(a===" "&&e.search.trim().length>0&&(t.preventDefault(),"continuePropagation"in t||t.stopPropagation()),e.search+=a,o.getKeyForSearch!=null){let n=o.getKeyForSearch(e.search,c.focusedKey);n==null&&(n=o.getKeyForSearch(e.search)),n!=null&&(c.setFocusedKey(n),i&&i(n))}clearTimeout(e.timeout),e.timeout=setTimeout(()=>{e.search=""},s)}};return{typeSelectProps:{onKeyDownCapture:o.getKeyForSearch?u:void 0}}}function g(r){return r.length===1||!/^[A-Z]/i.test(r)?r:""}exports.useTypeSelect=f;
package/index342.mjs CHANGED
@@ -1,57 +1,32 @@
1
- class a {
2
- *[Symbol.iterator]() {
3
- yield* this.iterable;
4
- }
5
- get size() {
6
- return this._size;
7
- }
8
- getKeys() {
9
- return this.keyMap.keys();
10
- }
11
- getKeyBefore(i) {
12
- let e = this.keyMap.get(i);
13
- var t;
14
- return e && (t = e.prevKey) !== null && t !== void 0 ? t : null;
15
- }
16
- getKeyAfter(i) {
17
- let e = this.keyMap.get(i);
18
- var t;
19
- return e && (t = e.nextKey) !== null && t !== void 0 ? t : null;
20
- }
21
- getFirstKey() {
22
- return this.firstKey;
23
- }
24
- getLastKey() {
25
- return this.lastKey;
26
- }
27
- getItem(i) {
28
- var e;
29
- return (e = this.keyMap.get(i)) !== null && e !== void 0 ? e : null;
30
- }
31
- at(i) {
32
- const e = [
33
- ...this.getKeys()
34
- ];
35
- return this.getItem(e[i]);
36
- }
37
- getChildren(i) {
38
- let e = this.keyMap.get(i);
39
- return (e == null ? void 0 : e.childNodes) || [];
40
- }
41
- constructor(i) {
42
- this.keyMap = /* @__PURE__ */ new Map(), this.firstKey = null, this.lastKey = null, this.iterable = i;
43
- let e = (l) => {
44
- if (this.keyMap.set(l.key, l), l.childNodes && l.type === "section") for (let s of l.childNodes) e(s);
45
- };
46
- for (let l of i) e(l);
47
- let t = null, y = 0, n = 0;
48
- for (let [l, s] of this.keyMap)
49
- t ? (t.nextKey = l, s.prevKey = t.key) : (this.firstKey = l, s.prevKey = void 0), s.type === "item" && (s.index = y++), (s.type === "section" || s.type === "item") && n++, t = s, t.nextKey = void 0;
50
- this._size = n;
51
- var r;
52
- this.lastKey = (r = t == null ? void 0 : t.key) !== null && r !== void 0 ? r : null;
53
- }
1
+ import { useRef as u } from "react";
2
+ const f = 1e3;
3
+ function y(r) {
4
+ let { keyboardDelegate: o, selectionManager: c, onTypeSelect: i } = r, e = u({
5
+ search: "",
6
+ timeout: void 0
7
+ }).current, l = (t) => {
8
+ let a = s(t.key);
9
+ if (!(!a || t.ctrlKey || t.metaKey || !t.currentTarget.contains(t.target) || e.search.length === 0 && a === " ")) {
10
+ if (a === " " && e.search.trim().length > 0 && (t.preventDefault(), "continuePropagation" in t || t.stopPropagation()), e.search += a, o.getKeyForSearch != null) {
11
+ let n = o.getKeyForSearch(e.search, c.focusedKey);
12
+ n == null && (n = o.getKeyForSearch(e.search)), n != null && (c.setFocusedKey(n), i && i(n));
13
+ }
14
+ clearTimeout(e.timeout), e.timeout = setTimeout(() => {
15
+ e.search = "";
16
+ }, f);
17
+ }
18
+ };
19
+ return {
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 ? l : void 0
24
+ }
25
+ };
26
+ }
27
+ function s(r) {
28
+ return r.length === 1 || !/^[A-Z]/i.test(r) ? r : "";
54
29
  }
55
30
  export {
56
- a as ListCollection
31
+ y as useTypeSelect
57
32
  };
package/index343.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("./index351.js"),F=require("./index271.js"),t=require("react");function M(e,o){if(e.size!==o.size)return!1;for(let c of e)if(!o.has(c))return!1;return!0}function R(e){let{selectionMode:o="none",disallowEmptySelection:c=!1,allowDuplicateSelectionEvents:K,selectionBehavior:s="toggle",disabledBehavior:b="all"}=e,r=t.useRef(!1),[,v]=t.useState(!1),u=t.useRef(null),a=t.useRef(null),[,h]=t.useState(null),g=t.useMemo(()=>S(e.selectedKeys),[e.selectedKeys]),w=t.useMemo(()=>S(e.defaultSelectedKeys,new y.Selection),[e.defaultSelectedKeys]),[i,B]=F.useControlledState(g,w,e.onSelectionChange),$=t.useMemo(()=>e.disabledKeys?new Set(e.disabledKeys):new Set,[e.disabledKeys]),[d,n]=t.useState(s);s==="replace"&&d==="toggle"&&typeof i=="object"&&i.size===0&&n("replace");let f=t.useRef(s);return t.useEffect(()=>{s!==f.current&&(n(s),f.current=s)},[s]),{selectionMode:o,disallowEmptySelection:c,selectionBehavior:d,setSelectionBehavior:n,get isFocused(){return r.current},setFocused(l){r.current=l,v(l)},get focusedKey(){return u.current},get childFocusStrategy(){return a.current},setFocusedKey(l,m="first"){u.current=l,a.current=m,h(l)},selectedKeys:i,setSelectedKeys(l){(K||!M(l,i))&&B(l)},disabledKeys:$,disabledBehavior:b}}function S(e,o){return e?e==="all"?"all":new y.Selection(e):o}exports.useMultipleSelectionState=R;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const C=require("./index344.js"),M=require("./index345.js"),$=require("./index346.js"),v=require("react"),m=require("./index347.js");function q(e){let{filter:t,layoutDelegate:n}=e,c=M.useMultipleSelectionState(e),f=v.useMemo(()=>e.disabledKeys?new Set(e.disabledKeys):new Set,[e.disabledKeys]),y=v.useCallback(a=>t?new C.ListCollection(t(a)):new C.ListCollection(a),[t]),S=v.useMemo(()=>({suppressTextValueWarning:e.suppressTextValueWarning}),[e.suppressTextValueWarning]),o=m.useCollection(e,y,S),r=v.useMemo(()=>new $.SelectionManager(o,c,{layoutDelegate:n}),[o,c,n]);return k(o,r),{collection:o,disabledKeys:f,selectionManager:r}}function k(e,t){const n=v.useRef(null);v.useEffect(()=>{if(t.focusedKey!=null&&!e.getItem(t.focusedKey)&&n.current){const l=n.current.getItem(t.focusedKey),g=[...n.current.getKeys()].map(s=>{const i=n.current.getItem(s);return(i==null?void 0:i.type)==="item"?i:null}).filter(s=>s!==null),u=[...e.getKeys()].map(s=>{const i=e.getItem(s);return(i==null?void 0:i.type)==="item"?i:null}).filter(s=>s!==null);var c,f;const b=((c=g==null?void 0:g.length)!==null&&c!==void 0?c:0)-((f=u==null?void 0:u.length)!==null&&f!==void 0?f:0);var y,S,o;let d=Math.min(b>1?Math.max(((y=l==null?void 0:l.index)!==null&&y!==void 0?y:0)-b+1,0):(S=l==null?void 0:l.index)!==null&&S!==void 0?S:0,((o=u==null?void 0:u.length)!==null&&o!==void 0?o:0)-1),K=null,w=!1;for(;d>=0;){if(!t.isDisabled(u[d].key)){K=u[d];break}if(d<u.length-1&&!w)d++;else{w=!0;var r,a;d>((r=l==null?void 0:l.index)!==null&&r!==void 0?r:0)&&(d=(a=l==null?void 0:l.index)!==null&&a!==void 0?a:0),d--}}t.setFocusedKey(K?K.key:null)}n.current=e},[e,t])}exports.useListState=q;
package/index343.mjs CHANGED
@@ -1,57 +1,69 @@
1
- import { Selection as K } from "./index351.mjs";
2
- import { useControlledState as M } from "./index271.mjs";
3
- import { useRef as a, useState as r, useMemo as n, useEffect as x } from "react";
4
- function R(e, s) {
5
- if (e.size !== s.size) return !1;
6
- for (let c of e)
7
- if (!s.has(c)) return !1;
8
- return !0;
9
- }
10
- function C(e) {
11
- let { selectionMode: s = "none", disallowEmptySelection: c = !1, allowDuplicateSelectionEvents: v, selectionBehavior: l = "toggle", disabledBehavior: $ = "all" } = e, d = a(!1), [, h] = r(!1), u = a(null), f = a(null), [, m] = r(null), g = n(() => b(e.selectedKeys), [
12
- e.selectedKeys
13
- ]), w = n(() => b(e.defaultSelectedKeys, new K()), [
14
- e.defaultSelectedKeys
15
- ]), [o, B] = M(g, w, e.onSelectionChange), F = n(() => e.disabledKeys ? new Set(e.disabledKeys) : /* @__PURE__ */ new Set(), [
1
+ import { ListCollection as p } from "./index344.mjs";
2
+ import { useMultipleSelectionState as x } from "./index345.mjs";
3
+ import { SelectionManager as S } from "./index346.mjs";
4
+ import { useMemo as m, useCallback as w, useRef as k, useEffect as C } from "react";
5
+ import { useCollection as D } from "./index347.mjs";
6
+ function L(e) {
7
+ let { filter: t, layoutDelegate: o } = e, r = x(e), f = m(() => e.disabledKeys ? new Set(e.disabledKeys) : /* @__PURE__ */ new Set(), [
16
8
  e.disabledKeys
17
- ]), [S, i] = r(l);
18
- l === "replace" && S === "toggle" && typeof o == "object" && o.size === 0 && i("replace");
19
- let y = a(l);
20
- return x(() => {
21
- l !== y.current && (i(l), y.current = l);
22
- }, [
23
- l
24
- ]), {
25
- selectionMode: s,
26
- disallowEmptySelection: c,
27
- selectionBehavior: S,
28
- setSelectionBehavior: i,
29
- get isFocused() {
30
- return d.current;
31
- },
32
- setFocused(t) {
33
- d.current = t, h(t);
34
- },
35
- get focusedKey() {
36
- return u.current;
37
- },
38
- get childFocusStrategy() {
39
- return f.current;
40
- },
41
- setFocusedKey(t, E = "first") {
42
- u.current = t, f.current = E, m(t);
43
- },
44
- selectedKeys: o,
45
- setSelectedKeys(t) {
46
- (v || !R(t, o)) && B(t);
47
- },
48
- disabledKeys: F,
49
- disabledBehavior: $
9
+ ]), v = w((c) => t ? new p(t(c)) : new p(c), [
10
+ t
11
+ ]), y = m(() => ({
12
+ suppressTextValueWarning: e.suppressTextValueWarning
13
+ }), [
14
+ e.suppressTextValueWarning
15
+ ]), n = D(e, v, y), s = m(() => new S(n, r, {
16
+ layoutDelegate: o
17
+ }), [
18
+ n,
19
+ r,
20
+ o
21
+ ]);
22
+ return R(n, s), {
23
+ collection: n,
24
+ disabledKeys: f,
25
+ selectionManager: s
50
26
  };
51
27
  }
52
- function b(e, s) {
53
- return e ? e === "all" ? "all" : new K(e) : s;
28
+ function R(e, t) {
29
+ const o = k(null);
30
+ C(() => {
31
+ if (t.focusedKey != null && !e.getItem(t.focusedKey) && o.current) {
32
+ const l = o.current.getItem(t.focusedKey), $ = [
33
+ ...o.current.getKeys()
34
+ ].map((a) => {
35
+ const i = o.current.getItem(a);
36
+ return (i == null ? void 0 : i.type) === "item" ? i : null;
37
+ }).filter((a) => a !== null), u = [
38
+ ...e.getKeys()
39
+ ].map((a) => {
40
+ const i = e.getItem(a);
41
+ return (i == null ? void 0 : i.type) === "item" ? i : null;
42
+ }).filter((a) => a !== null);
43
+ var r, f;
44
+ const K = ((r = $ == null ? void 0 : $.length) !== null && r !== void 0 ? r : 0) - ((f = u == null ? void 0 : u.length) !== null && f !== void 0 ? f : 0);
45
+ var v, y, n;
46
+ let d = Math.min(K > 1 ? Math.max(((v = l == null ? void 0 : l.index) !== null && v !== void 0 ? v : 0) - K + 1, 0) : (y = l == null ? void 0 : l.index) !== null && y !== void 0 ? y : 0, ((n = u == null ? void 0 : u.length) !== null && n !== void 0 ? n : 0) - 1), b = null, g = !1;
47
+ for (; d >= 0; ) {
48
+ if (!t.isDisabled(u[d].key)) {
49
+ b = u[d];
50
+ break;
51
+ }
52
+ if (d < u.length - 1 && !g) d++;
53
+ else {
54
+ g = !0;
55
+ var s, c;
56
+ d > ((s = l == null ? void 0 : l.index) !== null && s !== void 0 ? s : 0) && (d = (c = l == null ? void 0 : l.index) !== null && c !== void 0 ? c : 0), d--;
57
+ }
58
+ }
59
+ t.setFocusedKey(b ? b.key : null);
60
+ }
61
+ o.current = e;
62
+ }, [
63
+ e,
64
+ t
65
+ ]);
54
66
  }
55
67
  export {
56
- C as useMultipleSelectionState
68
+ L as useListState
57
69
  };
package/index344.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("./index351.js"),c=require("./index352.js");class h{get selectionMode(){return this.state.selectionMode}get disallowEmptySelection(){return this.state.disallowEmptySelection}get selectionBehavior(){return this.state.selectionBehavior}setSelectionBehavior(t){this.state.setSelectionBehavior(t)}get isFocused(){return this.state.isFocused}setFocused(t){this.state.setFocused(t)}get focusedKey(){return this.state.focusedKey}get childFocusStrategy(){return this.state.childFocusStrategy}setFocusedKey(t,e){(t==null||this.collection.getItem(t))&&this.state.setFocusedKey(t,e)}get selectedKeys(){return this.state.selectedKeys==="all"?new Set(this.getSelectAllKeys()):this.state.selectedKeys}get rawSelection(){return this.state.selectedKeys}isSelected(t){if(this.state.selectionMode==="none")return!1;let e=this.getKey(t);return e==null?!1:this.state.selectedKeys==="all"?this.canSelectItem(e):this.state.selectedKeys.has(e)}get isEmpty(){return this.state.selectedKeys!=="all"&&this.state.selectedKeys.size===0}get isSelectAll(){if(this.isEmpty)return!1;if(this.state.selectedKeys==="all")return!0;if(this._isSelectAll!=null)return this._isSelectAll;let t=this.getSelectAllKeys(),e=this.state.selectedKeys;return this._isSelectAll=t.every(l=>e.has(l)),this._isSelectAll}get firstSelectedKey(){let t=null;for(let l of this.state.selectedKeys){let i=this.collection.getItem(l);(!t||i&&c.compareNodeOrder(this.collection,i,t)<0)&&(t=i)}var e;return(e=t==null?void 0:t.key)!==null&&e!==void 0?e:null}get lastSelectedKey(){let t=null;for(let l of this.state.selectedKeys){let i=this.collection.getItem(l);(!t||i&&c.compareNodeOrder(this.collection,i,t)>0)&&(t=i)}var e;return(e=t==null?void 0:t.key)!==null&&e!==void 0?e:null}get disabledKeys(){return this.state.disabledKeys}get disabledBehavior(){return this.state.disabledBehavior}extendSelection(t){if(this.selectionMode==="none")return;if(this.selectionMode==="single"){this.replaceSelection(t);return}let e=this.getKey(t);if(e==null)return;let l;if(this.state.selectedKeys==="all")l=new n.Selection([e],e,e);else{let s=this.state.selectedKeys;var i;let a=(i=s.anchorKey)!==null&&i!==void 0?i:e;l=new n.Selection(s,a,e);var o;for(let r of this.getKeyRange(a,(o=s.currentKey)!==null&&o!==void 0?o:e))l.delete(r);for(let r of this.getKeyRange(e,a))this.canSelectItem(r)&&l.add(r)}this.state.setSelectedKeys(l)}getKeyRange(t,e){let l=this.collection.getItem(t),i=this.collection.getItem(e);return l&&i?c.compareNodeOrder(this.collection,l,i)<=0?this.getKeyRangeInternal(t,e):this.getKeyRangeInternal(e,t):[]}getKeyRangeInternal(t,e){var l;if(!((l=this.layoutDelegate)===null||l===void 0)&&l.getKeyRange)return this.layoutDelegate.getKeyRange(t,e);let i=[],o=t;for(;o!=null;){let s=this.collection.getItem(o);if(s&&(s.type==="item"||s.type==="cell"&&this.allowsCellSelection)&&i.push(o),o===e)return i;o=this.collection.getKeyAfter(o)}return[]}getKey(t){let e=this.collection.getItem(t);if(!e||e.type==="cell"&&this.allowsCellSelection)return t;for(;e&&e.type!=="item"&&e.parentKey!=null;)e=this.collection.getItem(e.parentKey);return!e||e.type!=="item"?null:e.key}toggleSelection(t){if(this.selectionMode==="none")return;if(this.selectionMode==="single"&&!this.isSelected(t)){this.replaceSelection(t);return}let e=this.getKey(t);if(e==null)return;let l=new n.Selection(this.state.selectedKeys==="all"?this.getSelectAllKeys():this.state.selectedKeys);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)}replaceSelection(t){if(this.selectionMode==="none")return;let e=this.getKey(t);if(e==null)return;let l=this.canSelectItem(e)?new n.Selection([e],e,e):new n.Selection;this.state.setSelectedKeys(l)}setSelectedKeys(t){if(this.selectionMode==="none")return;let e=new n.Selection;for(let l of t){let i=this.getKey(l);if(i!=null&&(e.add(i),this.selectionMode==="single"))break}this.state.setSelectedKeys(e)}getSelectAllKeys(){let t=[],e=l=>{for(;l!=null;){if(this.canSelectItem(l)){var i;let s=this.collection.getItem(l);(s==null?void 0:s.type)==="item"&&t.push(l);var o;s!=null&&s.hasChildNodes&&(this.allowsCellSelection||s.type!=="item")&&e((o=(i=c.getFirstItem(c.getChildNodes(s,this.collection)))===null||i===void 0?void 0:i.key)!==null&&o!==void 0?o:null)}l=this.collection.getKeyAfter(l)}};return e(this.collection.getFirstKey()),t}selectAll(){!this.isSelectAll&&this.selectionMode==="multiple"&&this.state.setSelectedKeys("all")}clearSelection(){!this.disallowEmptySelection&&(this.state.selectedKeys==="all"||this.state.selectedKeys.size>0)&&this.state.setSelectedKeys(new n.Selection)}toggleSelectAll(){this.isSelectAll?this.clearSelection():this.selectAll()}select(t,e){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))}isSelectionEqual(t){if(t===this.state.selectedKeys)return!0;let e=this.selectedKeys;if(t.size!==e.size)return!1;for(let l of t)if(!e.has(l))return!1;for(let l of e)if(!t.has(l))return!1;return!0}canSelectItem(t){var e;if(this.state.selectionMode==="none"||this.state.disabledKeys.has(t))return!1;let l=this.collection.getItem(t);return!(!l||!(l==null||(e=l.props)===null||e===void 0)&&e.isDisabled||l.type==="cell"&&!this.allowsCellSelection)}isDisabled(t){var e,l;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))}isLink(t){var e,l;return!!(!((l=this.collection.getItem(t))===null||l===void 0||(e=l.props)===null||e===void 0)&&e.href)}getItemProps(t){var e;return(e=this.collection.getItem(t))===null||e===void 0?void 0:e.props}withCollection(t){return new h(t,this.state,{allowsCellSelection:this.allowsCellSelection,layoutDelegate:this.layoutDelegate||void 0})}constructor(t,e,l){this.collection=t,this.state=e;var i;this.allowsCellSelection=(i=l==null?void 0:l.allowsCellSelection)!==null&&i!==void 0?i:!1,this._isSelectAll=null,this.layoutDelegate=(l==null?void 0:l.layoutDelegate)||null}}exports.SelectionManager=h;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class o{*[Symbol.iterator](){yield*this.iterable}get size(){return this._size}getKeys(){return this.keyMap.keys()}getKeyBefore(i){let e=this.keyMap.get(i);var t;return e&&(t=e.prevKey)!==null&&t!==void 0?t:null}getKeyAfter(i){let e=this.keyMap.get(i);var t;return e&&(t=e.nextKey)!==null&&t!==void 0?t:null}getFirstKey(){return this.firstKey}getLastKey(){return this.lastKey}getItem(i){var e;return(e=this.keyMap.get(i))!==null&&e!==void 0?e:null}at(i){const e=[...this.getKeys()];return this.getItem(e[i])}getChildren(i){let e=this.keyMap.get(i);return(e==null?void 0:e.childNodes)||[]}constructor(i){this.keyMap=new Map,this.firstKey=null,this.lastKey=null,this.iterable=i;let e=l=>{if(this.keyMap.set(l.key,l),l.childNodes&&l.type==="section")for(let s of l.childNodes)e(s)};for(let l of i)e(l);let t=null,y=0,n=0;for(let[l,s]of this.keyMap)t?(t.nextKey=l,s.prevKey=t.key):(this.firstKey=l,s.prevKey=void 0),s.type==="item"&&(s.index=y++),(s.type==="section"||s.type==="item")&&n++,t=s,t.nextKey=void 0;this._size=n;var r;this.lastKey=(r=t==null?void 0:t.key)!==null&&r!==void 0?r:null}}exports.ListCollection=o;