@yselimcan/ui 0.0.4 → 0.0.5

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.
Files changed (184) hide show
  1. package/dist/index101.js +7 -133
  2. package/dist/index102.js +86 -26
  3. package/dist/index103.js +12 -8
  4. package/dist/index104.js +63 -5
  5. package/dist/index105.js +38 -13
  6. package/dist/index106.js +14 -23
  7. package/dist/index107.js +32 -7
  8. package/dist/index108.js +19 -88
  9. package/dist/index109.js +4 -11
  10. package/dist/index110.js +4 -63
  11. package/dist/index111.js +4 -37
  12. package/dist/index112.js +12 -14
  13. package/dist/index113.js +18 -32
  14. package/dist/index114.js +13 -19
  15. package/dist/index115.js +295 -4
  16. package/dist/index116.js +5 -4
  17. package/dist/index117.js +39 -5
  18. package/dist/index118.js +124 -10
  19. package/dist/index119.js +21 -19
  20. package/dist/index120.js +77 -13
  21. package/dist/index121.js +59 -291
  22. package/dist/index122.js +45 -4
  23. package/dist/index123.js +14 -39
  24. package/dist/index124.js +4 -124
  25. package/dist/index125.js +29 -20
  26. package/dist/index126.js +5 -77
  27. package/dist/index127.js +25 -62
  28. package/dist/index128.js +16 -44
  29. package/dist/index129.js +22 -14
  30. package/dist/index130.js +58 -5
  31. package/dist/index131.js +16 -28
  32. package/dist/index132.js +25 -15
  33. package/dist/index133.js +40 -21
  34. package/dist/index134.js +43 -59
  35. package/dist/index135.js +19 -15
  36. package/dist/index136.js +47 -26
  37. package/dist/index137.js +49 -38
  38. package/dist/index138.js +18 -43
  39. package/dist/index139.js +11 -21
  40. package/dist/index140.js +22 -48
  41. package/dist/index141.js +34 -50
  42. package/dist/index142.js +229 -16
  43. package/dist/index143.js +283 -11
  44. package/dist/index144.js +52 -21
  45. package/dist/index145.js +15 -35
  46. package/dist/index146.js +74 -225
  47. package/dist/index147.js +3 -283
  48. package/dist/index148.js +30 -53
  49. package/dist/index149.js +24 -16
  50. package/dist/index150.js +15 -79
  51. package/dist/index151.js +69 -3
  52. package/dist/index152.js +4 -31
  53. package/dist/index153.js +103 -22
  54. package/dist/index154.js +79 -15
  55. package/dist/index155.js +259 -65
  56. package/dist/index156.js +12 -4
  57. package/dist/index157.js +11 -105
  58. package/dist/index158.js +37 -76
  59. package/dist/index159.js +4 -263
  60. package/dist/index160.js +66 -11
  61. package/dist/index161.js +9 -10
  62. package/dist/index162.js +8 -40
  63. package/dist/index163.js +5 -4
  64. package/dist/index164.js +129 -62
  65. package/dist/index165.js +54 -10
  66. package/dist/index166.js +11 -8
  67. package/dist/index167.js +118 -6
  68. package/dist/index168.js +11 -53
  69. package/dist/index169.js +8 -11
  70. package/dist/index17.js +4 -4
  71. package/dist/index170.js +12 -117
  72. package/dist/index171.js +22 -11
  73. package/dist/index173.js +2 -2
  74. package/dist/index175.js +2 -2
  75. package/dist/index178.js +6 -6
  76. package/dist/index18.js +5 -5
  77. package/dist/index181.js +2 -2
  78. package/dist/index184.js +1 -1
  79. package/dist/index187.js +5 -5
  80. package/dist/index189.js +3 -3
  81. package/dist/index19.js +10 -10
  82. package/dist/index190.js +1 -1
  83. package/dist/index191.js +1 -1
  84. package/dist/index192.js +2 -2
  85. package/dist/index193.js +1 -1
  86. package/dist/index194.js +1 -1
  87. package/dist/index195.js +3 -3
  88. package/dist/index196.js +6 -6
  89. package/dist/index197.js +3 -3
  90. package/dist/index198.js +6 -6
  91. package/dist/index199.js +1 -1
  92. package/dist/index20.js +3 -3
  93. package/dist/index200.js +5 -47
  94. package/dist/index201.js +41 -193
  95. package/dist/index202.js +182 -30
  96. package/dist/index203.js +48 -20
  97. package/dist/index204.js +20 -6
  98. package/dist/index205.js +2 -2
  99. package/dist/index207.js +6 -9
  100. package/dist/index208.js +4 -17
  101. package/dist/index209.js +9 -6
  102. package/dist/index21.js +4 -4
  103. package/dist/index210.js +17 -4
  104. package/dist/index217.js +3 -3
  105. package/dist/index218.js +1 -1
  106. package/dist/index22.js +5 -5
  107. package/dist/index220.js +2 -2
  108. package/dist/index221.js +1 -1
  109. package/dist/index229.js +1 -1
  110. package/dist/index23.js +3 -3
  111. package/dist/index230.js +4 -597
  112. package/dist/index231.js +4 -11
  113. package/dist/index232.js +593 -29
  114. package/dist/index233.js +12 -4
  115. package/dist/index234.js +15 -5
  116. package/dist/index235.js +30 -12
  117. package/dist/index239.js +2 -2
  118. package/dist/index24.js +9 -9
  119. package/dist/index242.js +3 -3
  120. package/dist/index243.js +1 -1
  121. package/dist/index247.js +14 -321
  122. package/dist/index248.js +322 -3
  123. package/dist/index249.js +3 -3
  124. package/dist/index250.js +3 -15
  125. package/dist/index251.js +1 -1
  126. package/dist/index26.js +1 -1
  127. package/dist/index27.js +1 -1
  128. package/dist/index28.js +2 -2
  129. package/dist/index32.js +1 -1
  130. package/dist/index33.js +11 -11
  131. package/dist/index34.js +2 -2
  132. package/dist/index35.js +10 -10
  133. package/dist/index36.js +8 -8
  134. package/dist/index37.js +4 -4
  135. package/dist/index38.js +6 -6
  136. package/dist/index39.js +4 -4
  137. package/dist/index40.js +1 -1
  138. package/dist/index41.js +3 -3
  139. package/dist/index43.js +1 -1
  140. package/dist/index44.js +1 -1
  141. package/dist/index45.js +3 -3
  142. package/dist/index46.js +6 -6
  143. package/dist/index47.js +7 -7
  144. package/dist/index48.js +16 -16
  145. package/dist/index49.js +2 -2
  146. package/dist/index50.js +10 -10
  147. package/dist/index52.js +14 -14
  148. package/dist/index53.js +1 -1
  149. package/dist/index54.js +17 -17
  150. package/dist/index55.js +9 -9
  151. package/dist/index56.js +10 -10
  152. package/dist/index57.js +1 -1
  153. package/dist/index58.js +3 -3
  154. package/dist/index59.js +3 -3
  155. package/dist/index60.js +7 -7
  156. package/dist/index61.js +3 -3
  157. package/dist/index62.js +3 -3
  158. package/dist/index63.js +6 -6
  159. package/dist/index64.js +3 -3
  160. package/dist/index66.js +7 -7
  161. package/dist/index67.js +1 -1
  162. package/dist/index69.js +30 -30
  163. package/dist/index70.js +5 -5
  164. package/dist/index71.js +18 -18
  165. package/dist/index72.js +24 -24
  166. package/dist/index73.js +8 -8
  167. package/dist/index74.js +2 -2
  168. package/dist/index75.js +14 -14
  169. package/dist/index76.js +3 -3
  170. package/dist/index77.js +5 -5
  171. package/dist/index78.js +4 -4
  172. package/dist/index79.js +1 -1
  173. package/dist/index80.js +1 -1
  174. package/dist/index81.js +17 -17
  175. package/dist/index82.js +5 -5
  176. package/dist/index83.js +5 -5
  177. package/dist/index86.js +11 -54
  178. package/dist/index87.js +54 -11
  179. package/dist/index88.js +87 -81
  180. package/dist/index89.js +81 -87
  181. package/dist/index95.js +1 -1
  182. package/dist/index96.js +1 -1
  183. package/dist/styles.css +1 -1
  184. package/package.json +1 -1
package/dist/index131.js CHANGED
@@ -1,32 +1,20 @@
1
1
  "use client";
2
- import * as n from "react";
3
- function d({
4
- controlled: o,
5
- default: s,
6
- name: t,
7
- state: i = "value"
8
- }) {
9
- const {
10
- current: e
11
- } = n.useRef(o !== void 0), [l, c] = n.useState(s), u = e ? o : l;
12
- if (process.env.NODE_ENV !== "production") {
13
- n.useEffect(() => {
14
- e !== (o !== void 0) && console.error([`Base UI: A component is changing the ${e ? "" : "un"}controlled ${i} state of ${t} to be ${e ? "un" : ""}controlled.`, "Elements should not switch from uncontrolled to controlled (or vice versa).", `Decide between using a controlled or uncontrolled ${t} element for the lifetime of the component.`, "The nature of the state is determined during the first render. It's considered controlled if the value is not `undefined`.", "More info: https://fb.me/react-controlled-components"].join(`
15
- `));
16
- }, [i, t, o]);
17
- const {
18
- current: r
19
- } = n.useRef(s);
20
- n.useEffect(() => {
21
- !e && JSON.stringify(r) !== JSON.stringify(s) && console.error([`Base UI: A component is changing the default ${i} state of an uncontrolled ${t} after being initialized. To suppress this warning opt to use a controlled ${t}.`].join(`
22
- `));
23
- }, [JSON.stringify(s)]);
24
- }
25
- const f = n.useCallback((r) => {
26
- e || c(r);
27
- }, []);
28
- return [u, f];
2
+ import * as t from "react";
3
+ import { NOOP as e } from "./index100.js";
4
+ const o = /* @__PURE__ */ t.createContext({
5
+ controlId: void 0,
6
+ setControlId: e,
7
+ labelId: void 0,
8
+ setLabelId: e,
9
+ messageIds: [],
10
+ setMessageIds: e,
11
+ getDescriptionProps: (n) => n
12
+ });
13
+ process.env.NODE_ENV !== "production" && (o.displayName = "LabelableContext");
14
+ function a() {
15
+ return t.useContext(o);
29
16
  }
30
17
  export {
31
- d as useControlled
18
+ o as LabelableContext,
19
+ a as useLabelableContext
32
20
  };
package/dist/index132.js CHANGED
@@ -1,20 +1,30 @@
1
1
  "use client";
2
- import { useIsoLayoutEffect as n } from "./index104.js";
3
- import { useRefWithInit as r } from "./index107.js";
4
- function s(e) {
5
- const t = r(f, e).current;
6
- return t.next = e, n(t.effect), t;
7
- }
8
- function f(e) {
9
- const t = {
10
- current: e,
11
- next: e,
12
- effect: () => {
13
- t.current = t.next;
2
+ import { useIsoLayoutEffect as s } from "./index126.js";
3
+ import { isElement as u } from "./index164.js";
4
+ import { useBaseUiId as m } from "./index109.js";
5
+ import { useLabelableContext as c } from "./index131.js";
6
+ import { NOOP as d } from "./index100.js";
7
+ function x(f = {}) {
8
+ const {
9
+ id: e,
10
+ implicit: o = !1,
11
+ controlRef: r
12
+ } = f, {
13
+ controlId: l,
14
+ setControlId: t
15
+ } = c(), n = m(e);
16
+ return s(() => {
17
+ if (!(!o && !e || t === d)) {
18
+ if (o) {
19
+ const i = r?.current;
20
+ u(i) && i.closest("label") != null ? t(e ?? null) : t(l ?? n);
21
+ } else e && t(e);
22
+ return () => {
23
+ e && t(void 0);
24
+ };
14
25
  }
15
- };
16
- return t;
26
+ }, [e, r, l, t, o, n]), l ?? n;
17
27
  }
18
28
  export {
19
- s as useValueAsRef
29
+ x as useLabelableId
20
30
  };
package/dist/index133.js CHANGED
@@ -1,24 +1,43 @@
1
- import o from "./index94.js";
2
- import * as e from "react";
3
- const n = /* @__PURE__ */ e.createContext(null);
4
- process.env.NODE_ENV !== "production" && (n.displayName = "SelectRootContext");
5
- const c = /* @__PURE__ */ e.createContext(null);
6
- process.env.NODE_ENV !== "production" && (c.displayName = "SelectFloatingContext");
7
- function s() {
8
- const t = e.useContext(n);
9
- if (t === null)
10
- throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: SelectRootContext is missing. Select parts must be placed within <Select.Root>." : o(60));
11
- return t;
12
- }
13
- function i() {
14
- const t = e.useContext(c);
15
- if (t === null)
16
- throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: SelectFloatingContext is missing. Select parts must be placed within <Select.Root>." : o(61));
17
- return t;
1
+ "use client";
2
+ import * as c from "react";
3
+ import { useIsoLayoutEffect as d } from "./index126.js";
4
+ import { AnimationFrame as u } from "./index160.js";
5
+ function g(t, s = !1, f = !1) {
6
+ const [n, r] = c.useState(t && s ? "idle" : void 0), [i, a] = c.useState(t);
7
+ return t && !i && (a(!0), r("starting")), !t && i && n !== "ending" && !f && r("ending"), !t && !i && n === "ending" && r(void 0), d(() => {
8
+ if (!t && i && n !== "ending" && f) {
9
+ const e = u.request(() => {
10
+ r("ending");
11
+ });
12
+ return () => {
13
+ u.cancel(e);
14
+ };
15
+ }
16
+ }, [t, i, n, f]), d(() => {
17
+ if (!t || s)
18
+ return;
19
+ const e = u.request(() => {
20
+ r(void 0);
21
+ });
22
+ return () => {
23
+ u.cancel(e);
24
+ };
25
+ }, [s, t]), d(() => {
26
+ if (!t || !s)
27
+ return;
28
+ t && i && n !== "idle" && r("starting");
29
+ const e = u.request(() => {
30
+ r("idle");
31
+ });
32
+ return () => {
33
+ u.cancel(e);
34
+ };
35
+ }, [s, t, i, r, n]), c.useMemo(() => ({
36
+ mounted: i,
37
+ setMounted: a,
38
+ transitionStatus: n
39
+ }), [i, n]);
18
40
  }
19
41
  export {
20
- c as SelectFloatingContext,
21
- n as SelectRootContext,
22
- i as useSelectFloatingContext,
23
- s as useSelectRootContext
42
+ g as useTransitionStatus
24
43
  };
package/dist/index134.js CHANGED
@@ -1,61 +1,45 @@
1
- "use client";
2
- import s from "./index94.js";
3
- import * as a from "react";
4
- import { DEFAULT_VALIDITY_STATE as n } from "./index153.js";
5
- import { NOOP as e, EMPTY_OBJECT as o } from "./index100.js";
6
- const l = /* @__PURE__ */ a.createContext({
7
- invalid: void 0,
8
- name: void 0,
9
- validityData: {
10
- state: n,
11
- errors: [],
12
- error: "",
13
- value: "",
14
- initialValue: null
15
- },
16
- setValidityData: e,
17
- disabled: void 0,
18
- touched: !1,
19
- setTouched: e,
20
- dirty: !1,
21
- setDirty: e,
22
- filled: !1,
23
- setFilled: e,
24
- focused: !1,
25
- setFocused: e,
26
- validate: () => null,
27
- validationMode: "onSubmit",
28
- validationDebounceTime: 0,
29
- shouldValidateOnChange: () => !1,
30
- state: {
31
- disabled: !1,
32
- valid: null,
33
- touched: !1,
34
- dirty: !1,
35
- filled: !1,
36
- focused: !1
37
- },
38
- markedDirtyRef: {
39
- current: !1
40
- },
41
- validation: {
42
- getValidationProps: (t = o) => t,
43
- getInputValidationProps: (t = o) => t,
44
- inputRef: {
45
- current: null
46
- },
47
- commit: async () => {
48
- }
49
- }
50
- });
51
- process.env.NODE_ENV !== "production" && (l.displayName = "FieldRootContext");
52
- function f(t = !0) {
53
- const i = a.useContext(l);
54
- if (i.setValidityData === e && !t)
55
- throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: FieldRootContext is missing. Field parts must be placed within <Field.Root>." : s(28));
56
- return i;
57
- }
1
+ import { compareItemEquality as n } from "./index138.js";
2
+ import { stringifyAsValue as u } from "./index137.js";
3
+ import { createSelector as r } from "./index204.js";
4
+ const p = {
5
+ id: r((e) => e.id),
6
+ modal: r((e) => e.modal),
7
+ multiple: r((e) => e.multiple),
8
+ items: r((e) => e.items),
9
+ itemToStringLabel: r((e) => e.itemToStringLabel),
10
+ itemToStringValue: r((e) => e.itemToStringValue),
11
+ isItemEqualToValue: r((e) => e.isItemEqualToValue),
12
+ value: r((e) => e.value),
13
+ open: r((e) => e.open),
14
+ mounted: r((e) => e.mounted),
15
+ forceMount: r((e) => e.forceMount),
16
+ transitionStatus: r((e) => e.transitionStatus),
17
+ openMethod: r((e) => e.openMethod),
18
+ activeIndex: r((e) => e.activeIndex),
19
+ selectedIndex: r((e) => e.selectedIndex),
20
+ isActive: r((e, t) => e.activeIndex === t),
21
+ isSelected: r((e, t, l) => {
22
+ const o = e.isItemEqualToValue, i = e.value;
23
+ return e.multiple ? Array.isArray(i) && i.some((s) => n(s, l, o)) : e.selectedIndex === t && e.selectedIndex !== null ? !0 : n(i, l, o);
24
+ }),
25
+ isSelectedByFocus: r((e, t) => e.selectedIndex === t),
26
+ popupProps: r((e) => e.popupProps),
27
+ triggerProps: r((e) => e.triggerProps),
28
+ triggerElement: r((e) => e.triggerElement),
29
+ positionerElement: r((e) => e.positionerElement),
30
+ listElement: r((e) => e.listElement),
31
+ scrollUpArrowVisible: r((e) => e.scrollUpArrowVisible),
32
+ scrollDownArrowVisible: r((e) => e.scrollDownArrowVisible),
33
+ hasScrollArrows: r((e) => e.hasScrollArrows),
34
+ serializedValue: r((e) => {
35
+ const {
36
+ multiple: t,
37
+ value: l,
38
+ itemToStringValue: o
39
+ } = e;
40
+ return t && Array.isArray(l) && l.length === 0 ? "" : u(l, o);
41
+ })
42
+ };
58
43
  export {
59
- l as FieldRootContext,
60
- f as useFieldRootContext
44
+ p as selectors
61
45
  };
package/dist/index135.js CHANGED
@@ -1,20 +1,24 @@
1
1
  "use client";
2
- import * as t from "react";
3
- import { NOOP as e } from "./index100.js";
4
- const o = /* @__PURE__ */ t.createContext({
5
- controlId: void 0,
6
- setControlId: e,
7
- labelId: void 0,
8
- setLabelId: e,
9
- messageIds: [],
10
- setMessageIds: e,
11
- getDescriptionProps: (n) => n
2
+ import * as e from "react";
3
+ import { NOOP as r } from "./index100.js";
4
+ const t = /* @__PURE__ */ e.createContext({
5
+ formRef: {
6
+ current: {
7
+ fields: /* @__PURE__ */ new Map()
8
+ }
9
+ },
10
+ errors: {},
11
+ clearErrors: r,
12
+ validationMode: "onSubmit",
13
+ submitAttemptedRef: {
14
+ current: !1
15
+ }
12
16
  });
13
- process.env.NODE_ENV !== "production" && (o.displayName = "LabelableContext");
14
- function a() {
15
- return t.useContext(o);
17
+ process.env.NODE_ENV !== "production" && (t.displayName = "FormContext");
18
+ function n() {
19
+ return e.useContext(t);
16
20
  }
17
21
  export {
18
- o as LabelableContext,
19
- a as useLabelableContext
22
+ t as FormContext,
23
+ n as useFormContext
20
24
  };
package/dist/index136.js CHANGED
@@ -1,30 +1,51 @@
1
- "use client";
2
- import { useIsoLayoutEffect as s } from "./index104.js";
3
- import { isElement as u } from "./index101.js";
4
- import { useBaseUiId as m } from "./index115.js";
5
- import { useLabelableContext as c } from "./index135.js";
6
- import { NOOP as d } from "./index100.js";
7
- function x(f = {}) {
1
+ import * as p from "react-dom";
2
+ import { useIsoLayoutEffect as r } from "./index126.js";
3
+ import { useStableCallback as D } from "./index127.js";
4
+ import { getCombinedFieldValidityData as v } from "./index209.js";
5
+ import { useFormContext as R } from "./index135.js";
6
+ import { useFieldRootContext as b } from "./index130.js";
7
+ function S(u) {
8
8
  const {
9
- id: e,
10
- implicit: o = !1,
11
- controlRef: r
12
- } = f, {
13
- controlId: l,
14
- setControlId: t
15
- } = c(), n = m(e);
16
- return s(() => {
17
- if (!(!o && !e || t === d)) {
18
- if (o) {
19
- const i = r?.current;
20
- u(i) && i.closest("label") != null ? t(e ?? null) : t(l ?? n);
21
- } else e && t(e);
22
- return () => {
23
- e && t(void 0);
24
- };
25
- }
26
- }, [e, r, l, t, o, n]), l ?? n;
9
+ enabled: l = !0,
10
+ value: a,
11
+ id: t,
12
+ name: f,
13
+ controlRef: d,
14
+ commit: m
15
+ } = u, {
16
+ formRef: n
17
+ } = R(), {
18
+ invalid: s,
19
+ markedDirtyRef: c,
20
+ validityData: o,
21
+ setValidityData: V
22
+ } = b(), i = D(u.getValue);
23
+ r(() => {
24
+ if (!l)
25
+ return;
26
+ let e = a;
27
+ e === void 0 && (e = i()), o.initialValue === null && e !== null && V((y) => ({
28
+ ...y,
29
+ initialValue: e
30
+ }));
31
+ }, [l, V, a, o.initialValue, i]), r(() => {
32
+ !l || !t || n.current.fields.set(t, {
33
+ getValue: i,
34
+ name: f,
35
+ controlRef: d,
36
+ validityData: v(o, s),
37
+ validate() {
38
+ let e = a;
39
+ e === void 0 && (e = i()), c.current = !0, p.flushSync(() => m(e));
40
+ }
41
+ });
42
+ }, [m, d, l, n, i, t, s, c, f, o, a]), r(() => {
43
+ const e = n.current.fields;
44
+ return () => {
45
+ t && e.delete(t);
46
+ };
47
+ }, [n, t]);
27
48
  }
28
49
  export {
29
- x as useLabelableId
50
+ S as useField
30
51
  };
package/dist/index137.js CHANGED
@@ -1,43 +1,54 @@
1
1
  "use client";
2
- import * as c from "react";
3
- import { useIsoLayoutEffect as d } from "./index104.js";
4
- import { AnimationFrame as u } from "./index164.js";
5
- function g(t, s = !1, f = !1) {
6
- const [n, r] = c.useState(t && s ? "idle" : void 0), [i, a] = c.useState(t);
7
- return t && !i && (a(!0), r("starting")), !t && i && n !== "ending" && !f && r("ending"), !t && !i && n === "ending" && r(void 0), d(() => {
8
- if (!t && i && n !== "ending" && f) {
9
- const e = u.request(() => {
10
- r("ending");
11
- });
12
- return () => {
13
- u.cancel(e);
14
- };
2
+ import { serializeValue as c } from "./index206.js";
3
+ function t(n) {
4
+ return n != null && n.length > 0 && typeof n[0] == "object" && n[0] != null && "items" in n[0];
5
+ }
6
+ function e(n, r) {
7
+ if (r && n != null)
8
+ return r(n) ?? "";
9
+ if (n && typeof n == "object") {
10
+ if ("label" in n && n.label != null)
11
+ return String(n.label);
12
+ if ("value" in n)
13
+ return String(n.value);
14
+ }
15
+ return c(n);
16
+ }
17
+ function b(n, r) {
18
+ return r && n != null ? r(n) ?? "" : n && typeof n == "object" && "value" in n && "label" in n ? c(n.value) : c(n);
19
+ }
20
+ function y(n, r, f) {
21
+ if (f && n != null)
22
+ return f(n);
23
+ if (n && typeof n == "object" && "label" in n && n.label != null)
24
+ return n.label;
25
+ if (r && !Array.isArray(r))
26
+ return r[n] ?? e(n, f);
27
+ if (Array.isArray(r)) {
28
+ const o = t(r) ? r.flatMap((l) => l.items) : r;
29
+ if (n == null) {
30
+ const l = o.find((u) => u.value == null);
31
+ return l && l.label != null ? l.label : e(n, f);
15
32
  }
16
- }, [t, i, n, f]), d(() => {
17
- if (!t || s)
18
- return;
19
- const e = u.request(() => {
20
- r(void 0);
21
- });
22
- return () => {
23
- u.cancel(e);
24
- };
25
- }, [s, t]), d(() => {
26
- if (!t || !s)
27
- return;
28
- t && i && n !== "idle" && r("starting");
29
- const e = u.request(() => {
30
- r("idle");
31
- });
32
- return () => {
33
- u.cancel(e);
34
- };
35
- }, [s, t, i, r, n]), c.useMemo(() => ({
36
- mounted: i,
37
- setMounted: a,
38
- transitionStatus: n
39
- }), [i, n]);
33
+ if (typeof n != "object") {
34
+ const l = o.find((u) => u && u.value === n);
35
+ return l && l.label != null ? l.label : e(n, f);
36
+ }
37
+ if ("value" in n) {
38
+ const l = o.find((u) => u && u.value === n.value);
39
+ if (l && l.label != null)
40
+ return l.label;
41
+ }
42
+ }
43
+ return e(n, f);
44
+ }
45
+ function p(n, r) {
46
+ return !Array.isArray(n) || n.length === 0 ? "" : n.map((f) => e(f, r)).join(", ");
40
47
  }
41
48
  export {
42
- g as useTransitionStatus
49
+ t as isGroupedItems,
50
+ p as resolveMultipleLabels,
51
+ y as resolveSelectedLabel,
52
+ e as stringifyAsLabel,
53
+ b as stringifyAsValue
43
54
  };
package/dist/index138.js CHANGED
@@ -1,45 +1,20 @@
1
- import { compareItemEquality as n } from "./index142.js";
2
- import { stringifyAsValue as u } from "./index141.js";
3
- import { createSelector as r } from "./index203.js";
4
- const p = {
5
- id: r((e) => e.id),
6
- modal: r((e) => e.modal),
7
- multiple: r((e) => e.multiple),
8
- items: r((e) => e.items),
9
- itemToStringLabel: r((e) => e.itemToStringLabel),
10
- itemToStringValue: r((e) => e.itemToStringValue),
11
- isItemEqualToValue: r((e) => e.isItemEqualToValue),
12
- value: r((e) => e.value),
13
- open: r((e) => e.open),
14
- mounted: r((e) => e.mounted),
15
- forceMount: r((e) => e.forceMount),
16
- transitionStatus: r((e) => e.transitionStatus),
17
- openMethod: r((e) => e.openMethod),
18
- activeIndex: r((e) => e.activeIndex),
19
- selectedIndex: r((e) => e.selectedIndex),
20
- isActive: r((e, t) => e.activeIndex === t),
21
- isSelected: r((e, t, l) => {
22
- const o = e.isItemEqualToValue, i = e.value;
23
- return e.multiple ? Array.isArray(i) && i.some((s) => n(s, l, o)) : e.selectedIndex === t && e.selectedIndex !== null ? !0 : n(i, l, o);
24
- }),
25
- isSelectedByFocus: r((e, t) => e.selectedIndex === t),
26
- popupProps: r((e) => e.popupProps),
27
- triggerProps: r((e) => e.triggerProps),
28
- triggerElement: r((e) => e.triggerElement),
29
- positionerElement: r((e) => e.positionerElement),
30
- listElement: r((e) => e.listElement),
31
- scrollUpArrowVisible: r((e) => e.scrollUpArrowVisible),
32
- scrollDownArrowVisible: r((e) => e.scrollDownArrowVisible),
33
- hasScrollArrows: r((e) => e.hasScrollArrows),
34
- serializedValue: r((e) => {
35
- const {
36
- multiple: t,
37
- value: l,
38
- itemToStringValue: o
39
- } = e;
40
- return t && Array.isArray(l) && l.length === 0 ? "" : u(l, o);
41
- })
42
- };
1
+ const f = (n, e) => Object.is(n, e);
2
+ function u(n, e, r) {
3
+ return n == null || e == null ? Object.is(n, e) : r(n, e);
4
+ }
5
+ function i(n, e, r) {
6
+ return !n || n.length === 0 ? !1 : n.some((t) => t === void 0 ? !1 : u(t, e, r));
7
+ }
8
+ function d(n, e, r) {
9
+ return !n || n.length === 0 ? -1 : n.findIndex((t) => t === void 0 ? !1 : u(t, e, r));
10
+ }
11
+ function s(n, e, r) {
12
+ return n.filter((t) => !u(t, e, r));
13
+ }
43
14
  export {
44
- p as selectors
15
+ u as compareItemEquality,
16
+ f as defaultItemEquality,
17
+ d as findItemIndex,
18
+ i as itemIncludes,
19
+ s as removeItem
45
20
  };
package/dist/index139.js CHANGED
@@ -1,24 +1,14 @@
1
- "use client";
2
- import * as e from "react";
3
- import { NOOP as r } from "./index100.js";
4
- const t = /* @__PURE__ */ e.createContext({
5
- formRef: {
6
- current: {
7
- fields: /* @__PURE__ */ new Map()
8
- }
9
- },
10
- errors: {},
11
- clearErrors: r,
12
- validationMode: "onSubmit",
13
- submitAttemptedRef: {
14
- current: !1
15
- }
16
- });
17
- process.env.NODE_ENV !== "production" && (t.displayName = "FormContext");
18
- function n() {
19
- return e.useContext(t);
1
+ import * as c from "react";
2
+ import { useIsoLayoutEffect as o } from "./index126.js";
3
+ import { useStableCallback as f } from "./index127.js";
4
+ function u(r, n) {
5
+ const t = c.useRef(r), e = f(n);
6
+ o(() => {
7
+ t.current !== r && e(t.current);
8
+ }, [r, e]), o(() => {
9
+ t.current = r;
10
+ }, [r]);
20
11
  }
21
12
  export {
22
- t as FormContext,
23
- n as useFormContext
13
+ u as useValueChanged
24
14
  };