@foi/design-system 0.0.17 → 0.0.19

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 (112) hide show
  1. package/README.md +658 -63
  2. package/dist/{DatePicker.utils-ytCEcs6T.js → DatePicker.utils-BAUVa26Q.js} +2 -2
  3. package/dist/{DatePicker.utils-ytCEcs6T.js.map → DatePicker.utils-BAUVa26Q.js.map} +1 -1
  4. package/dist/{emotion-react-jsx-runtime.browser.esm-Ch-DwUYg.js → IconButton-C3x-E-ot.js} +458 -248
  5. package/dist/IconButton-C3x-E-ot.js.map +1 -0
  6. package/dist/{RadioGroup-DzEJw4WJ.js → RadioGroup-Cvt9MtvM.js} +71 -71
  7. package/dist/{RadioGroup-DzEJw4WJ.js.map → RadioGroup-Cvt9MtvM.js.map} +1 -1
  8. package/dist/RadioGroup.context-v_CCYB7_.js +392 -0
  9. package/dist/RadioGroup.context-v_CCYB7_.js.map +1 -0
  10. package/dist/{Switch-oAVuMb0V.js → Switch-6eNmT34-.js} +315 -315
  11. package/dist/{Switch-oAVuMb0V.js.map → Switch-6eNmT34-.js.map} +1 -1
  12. package/dist/{ThemeProvider-C47pyWG6.js → ThemeProvider-C_PzAJz3.js} +11 -6
  13. package/dist/{ThemeProvider-C47pyWG6.js.map → ThemeProvider-C_PzAJz3.js.map} +1 -1
  14. package/dist/Toast-_9W7YGxS.js +146 -0
  15. package/dist/Toast-_9W7YGxS.js.map +1 -0
  16. package/dist/atoms.mjs +4 -3
  17. package/dist/components/atoms/Button/Button.interface.d.ts +1 -1
  18. package/dist/components/atoms/Checkbox/Checkbox.interface.d.ts +3 -3
  19. package/dist/components/atoms/Chip/Chip.d.ts +4 -0
  20. package/dist/components/atoms/Chip/Chip.emotion.d.ts +2 -0
  21. package/dist/components/atoms/Chip/Chip.interface.d.ts +14 -0
  22. package/dist/components/atoms/Chip/index.d.ts +5 -0
  23. package/dist/components/atoms/DatePicker/DatePicker.interface.d.ts +2 -2
  24. package/dist/components/atoms/DatePicker/DatePickerMenu/DatePickerMenu.interface.d.ts +3 -3
  25. package/dist/components/atoms/IconButton/IconButton.interface.d.ts +2 -2
  26. package/dist/components/atoms/NumberField/NumberField.interface.d.ts +2 -2
  27. package/dist/components/atoms/Radio/Radio.interface.d.ts +2 -2
  28. package/dist/components/atoms/Select/Select.interface.d.ts +2 -2
  29. package/dist/components/atoms/Select/SelectMenu/SelectMenu.interface.d.ts +1 -1
  30. package/dist/components/atoms/Slider/Slider.interface.d.ts +4 -4
  31. package/dist/components/atoms/Switch/Switch.interface.d.ts +1 -1
  32. package/dist/components/atoms/TextField/TextField.interface.d.ts +2 -2
  33. package/dist/components/molecules/CheckboxGroup/CheckboxGroup.interface.d.ts +2 -2
  34. package/dist/components/molecules/CheckboxTree/CheckboxTree.interface.d.ts +2 -2
  35. package/dist/components/molecules/Modal/Modal.interface.d.ts +4 -4
  36. package/dist/components/molecules/RadioGroup/RadioGroup.interface.d.ts +2 -2
  37. package/dist/components/molecules/Toast/Toast.context.d.ts +2 -0
  38. package/dist/components/molecules/Toast/Toast.d.ts +4 -0
  39. package/dist/components/molecules/Toast/Toast.emotion.d.ts +4 -0
  40. package/dist/components/molecules/Toast/Toast.hook.d.ts +1 -0
  41. package/dist/components/molecules/Toast/Toast.interface.d.ts +33 -0
  42. package/dist/components/molecules/Toast/Toast.provider.d.ts +3 -0
  43. package/dist/components/molecules/Toast/index.d.ts +3 -0
  44. package/dist/components/organisms/DataGrid/DataGrid.interface.d.ts +3 -3
  45. package/dist/components/organisms/DataGrid/DataGridMenu/DataGridMenu.interface.d.ts +1 -1
  46. package/dist/hocs/ThemeProvider/ThemeProvider.interface.d.ts +6 -0
  47. package/dist/hocs/ThemeProvider/components/{Button.d.ts → atoms/Button.d.ts} +1 -1
  48. package/dist/hocs/ThemeProvider/components/{Checkbox.d.ts → atoms/Checkbox.d.ts} +1 -1
  49. package/dist/hocs/ThemeProvider/components/atoms/Chip.d.ts +13 -0
  50. package/dist/hocs/ThemeProvider/components/{DatePicker.d.ts → atoms/DatePicker.d.ts} +1 -1
  51. package/dist/hocs/ThemeProvider/components/{DatePickerMenu.d.ts → atoms/DatePickerMenu.d.ts} +1 -1
  52. package/dist/hocs/ThemeProvider/components/{IconButton.d.ts → atoms/IconButton.d.ts} +1 -1
  53. package/dist/hocs/ThemeProvider/components/{NumberField.d.ts → atoms/NumberField.d.ts} +1 -1
  54. package/dist/hocs/ThemeProvider/components/{Pagination.d.ts → atoms/Pagination.d.ts} +1 -1
  55. package/dist/hocs/ThemeProvider/components/{PaginationMenu.d.ts → atoms/PaginationMenu.d.ts} +1 -1
  56. package/dist/hocs/ThemeProvider/components/{Radio.d.ts → atoms/Radio.d.ts} +1 -1
  57. package/dist/hocs/ThemeProvider/components/{Select.d.ts → atoms/Select.d.ts} +1 -1
  58. package/dist/hocs/ThemeProvider/components/{SelectMenu.d.ts → atoms/SelectMenu.d.ts} +1 -1
  59. package/dist/hocs/ThemeProvider/components/{Slider.d.ts → atoms/Slider.d.ts} +1 -1
  60. package/dist/hocs/ThemeProvider/components/{Switch.d.ts → atoms/Switch.d.ts} +1 -1
  61. package/dist/hocs/ThemeProvider/components/{TextField.d.ts → atoms/TextField.d.ts} +1 -1
  62. package/dist/hocs/ThemeProvider/components/index.d.ts +23 -17
  63. package/dist/hocs/ThemeProvider/components/{CheckboxGroup.d.ts → molecules/CheckboxGroup.d.ts} +1 -1
  64. package/dist/hocs/ThemeProvider/components/{CheckboxTree.d.ts → molecules/CheckboxTree.d.ts} +1 -1
  65. package/dist/hocs/ThemeProvider/components/{Modal.d.ts → molecules/Modal.d.ts} +1 -1
  66. package/dist/hocs/ThemeProvider/components/{RadioGroup.d.ts → molecules/RadioGroup.d.ts} +1 -1
  67. package/dist/hocs/ThemeProvider/components/molecules/Toast.d.ts +16 -0
  68. package/dist/hocs/ThemeProvider/components/{DataGrid.d.ts → organisms/DataGrid.d.ts} +1 -1
  69. package/dist/hocs/ThemeProvider/components/{DataGridMenu.d.ts → organisms/DataGridMenu.d.ts} +1 -1
  70. package/dist/hocs/ThemeProvider/interfaces/Components.interface.d.ts +2 -0
  71. package/dist/hocs.mjs +1 -1
  72. package/dist/hooks.d.ts +2 -0
  73. package/dist/hooks.mjs +2 -1
  74. package/dist/index.d.ts +2 -0
  75. package/dist/index.mjs +247 -239
  76. package/dist/index.mjs.map +1 -1
  77. package/dist/molecules.d.ts +2 -0
  78. package/dist/molecules.mjs +3 -2
  79. package/dist/theme/dark/components/atoms/Chip.d.ts +13 -0
  80. package/dist/theme/dark/components/index.d.ts +287 -266
  81. package/dist/theme/dark/components/{Modal.d.ts → molecules/Modal.d.ts} +0 -3
  82. package/dist/theme/dark/components/molecules/Toast.d.ts +17 -0
  83. package/dist/theme/dark/index.d.ts +287 -266
  84. package/dist/theme/index.d.ts +287 -266
  85. package/dist/{theme-D01EcUA9.js → theme-BjrtNRDQ.js} +231 -222
  86. package/dist/theme-BjrtNRDQ.js.map +1 -0
  87. package/dist/theme.mjs +1 -1
  88. package/dist/utilities.mjs +1 -1
  89. package/package.json +1 -1
  90. package/dist/RadioGroup.context-Bu218uUX.js +0 -601
  91. package/dist/RadioGroup.context-Bu218uUX.js.map +0 -1
  92. package/dist/emotion-react-jsx-runtime.browser.esm-Ch-DwUYg.js.map +0 -1
  93. package/dist/theme-D01EcUA9.js.map +0 -1
  94. /package/dist/theme/dark/components/{Button.d.ts → atoms/Button.d.ts} +0 -0
  95. /package/dist/theme/dark/components/{Checkbox.d.ts → atoms/Checkbox.d.ts} +0 -0
  96. /package/dist/theme/dark/components/{DatePicker.d.ts → atoms/DatePicker.d.ts} +0 -0
  97. /package/dist/theme/dark/components/{DatePickerMenu.d.ts → atoms/DatePickerMenu.d.ts} +0 -0
  98. /package/dist/theme/dark/components/{IconButton.d.ts → atoms/IconButton.d.ts} +0 -0
  99. /package/dist/theme/dark/components/{NumberField.d.ts → atoms/NumberField.d.ts} +0 -0
  100. /package/dist/theme/dark/components/{Pagination.d.ts → atoms/Pagination.d.ts} +0 -0
  101. /package/dist/theme/dark/components/{PaginationMenu.d.ts → atoms/PaginationMenu.d.ts} +0 -0
  102. /package/dist/theme/dark/components/{Radio.d.ts → atoms/Radio.d.ts} +0 -0
  103. /package/dist/theme/dark/components/{Select.d.ts → atoms/Select.d.ts} +0 -0
  104. /package/dist/theme/dark/components/{SelectMenu.d.ts → atoms/SelectMenu.d.ts} +0 -0
  105. /package/dist/theme/dark/components/{Slider.d.ts → atoms/Slider.d.ts} +0 -0
  106. /package/dist/theme/dark/components/{Switch.d.ts → atoms/Switch.d.ts} +0 -0
  107. /package/dist/theme/dark/components/{TextField.d.ts → atoms/TextField.d.ts} +0 -0
  108. /package/dist/theme/dark/components/{CheckboxGroup.d.ts → molecules/CheckboxGroup.d.ts} +0 -0
  109. /package/dist/theme/dark/components/{CheckboxTree.d.ts → molecules/CheckboxTree.d.ts} +0 -0
  110. /package/dist/theme/dark/components/{RadioGroup.d.ts → molecules/RadioGroup.d.ts} +0 -0
  111. /package/dist/theme/dark/components/{DataGrid.d.ts → organisms/DataGrid.d.ts} +0 -0
  112. /package/dist/theme/dark/components/{DataGridMenu.d.ts → organisms/DataGridMenu.d.ts} +0 -0
@@ -0,0 +1,392 @@
1
+ import { a as e, i as t, n, o as r, s as i } from "./IconButton-C3x-E-ot.js";
2
+ import { r as a } from "./theme-BjrtNRDQ.js";
3
+ import o, { createContext as s, useContext as c, useState as l } from "react";
4
+ import { css as u } from "@emotion/react";
5
+ import { useController as d } from "react-hook-form";
6
+ //#region src/components/atoms/Checkbox/Checkbox.emotion.ts
7
+ var f = (e, t) => `
8
+ // BACKGROUNDS
9
+ ${a(e, "background-color", `--CHECKBOX-EVENTS-${t}-BACKGROUND-COLOR`)}
10
+ `, p = (e, t) => `
11
+ // BORDERS
12
+ ${a(e, "border-color", `--CHECKBOX-EVENTS-${t}-BORDER-COLOR`)}
13
+ ${a(e, "border-width", `--CHECKBOX-EVENTS-${t}-BORDER-WIDTH`)}
14
+ ${a(e, "border-style", `--CHECKBOX-EVENTS-${t}-BORDER-STYLE`)}
15
+ `, m = (e, t) => `
16
+ // OUTLINE
17
+ ${a(e, "outline-color", `--CHECKBOX-EVENTS-${t}-OUTLINE-COLOR`)}
18
+ ${a(e, "outline-width", `--CHECKBOX-EVENTS-${t}-OUTLINE-WIDTH`)}
19
+ ${a(e, "outline-style", `--CHECKBOX-EVENTS-${t}-OUTLINE-STYLE`)}
20
+ ${a(e, "outline-offset", `--CHECKBOX-EVENTS-${t}-OUTLINE-OFFSET`)}
21
+ `, h = (e, t) => `
22
+ // SHADOW
23
+ ${a(e, "background-color", `--CHECKBOX-EVENTS-${t}-SHADOW-COLOR`)}
24
+ `, g = (e, t) => `
25
+ // UTILS
26
+ > span {
27
+ ${a(e, "color", `--CHECKBOX-EVENTS-${t}-ICON-COLOR`)};
28
+ }
29
+ `, _ = (e, t) => `
30
+ // TYPOGRAPHY
31
+ .--CHECKBOX-label {
32
+ ${a(e, "color", `--CHECKBOX-EVENTS-${t}-COLOR-PRIMARY`)}
33
+ }
34
+
35
+ ~ .--CHECKBOX-helperText {
36
+ ${a(e, "color", `--CHECKBOX-EVENTS-${t}-COLOR-SECONDARY`)}
37
+ }
38
+ `, v = (e) => u`
39
+ &.--CHECKBOX {
40
+ display: flex;
41
+ flex-direction: column;
42
+ gap: 8px;
43
+ width: fit-content;
44
+
45
+ .--CHECKBOX-container {
46
+ display: flex;
47
+ flex-direction: row;
48
+ gap: 12px;
49
+ align-items: center;
50
+ cursor: pointer;
51
+
52
+ // ENABLED
53
+ ${_(e, "ENABLED")};
54
+
55
+ // VALUE
56
+ &:has(.--CHECKBOX-inputField:checked) {
57
+ ${_(e, "VALUE")};
58
+ }
59
+
60
+ // HOVER
61
+ &:hover {
62
+ ${_(e, "HOVER")};
63
+
64
+ .--CHECKBOX-checkbox .--CHECKBOX-span {
65
+ &:before {
66
+ opacity: 1;
67
+ ${h(e, "HOVER")};
68
+ }
69
+ }
70
+ }
71
+
72
+ // ACTIVE
73
+ &:has(.--CHECKBOX-inputField.--CHECKBOX-active, .--CHECKBOX-inputField:active) {
74
+ ${_(e, "ACTIVE")};
75
+ }
76
+
77
+ // FOCUS-VISIBLE
78
+ &:has(.--CHECKBOX-inputField:focus-visible) {
79
+ ${_(e, "FOCUS")};
80
+ }
81
+
82
+ // ERROR
83
+ &:has(.--CHECKBOX-inputField.--CHECKBOX-error) {
84
+ ${_(e, "ERROR")};
85
+ }
86
+
87
+ // ERROR + VALUE
88
+ &:has(.--CHECKBOX-inputField.--CHECKBOX-error:checked) {
89
+ ${_(e, "ERROR_VALUE")};
90
+ }
91
+
92
+ // ERROR + HOVER
93
+ &:hover:has(.--CHECKBOX-inputField.--CHECKBOX-error) {
94
+ ${_(e, "ERROR_HOVER")};
95
+
96
+ .--CHECKBOX-checkbox .--CHECKBOX-span {
97
+ &:before {
98
+ opacity: 1;
99
+ ${h(e, "ERROR_HOVER")};
100
+ }
101
+ }
102
+ }
103
+
104
+ // ERROR + ACTIVE
105
+ &:has(.--CHECKBOX-inputField.--CHECKBOX-error:active),
106
+ &:has(.--CHECKBOX-inputField.--CHECKBOX-error.--CHECKBOX-active) {
107
+ ${_(e, "ERROR_ACTIVE")};
108
+ }
109
+
110
+ // ERROR + FOCUS
111
+ &:has(.--CHECKBOX-inputField.--CHECKBOX-error:focus-visible) {
112
+ ${_(e, "ERROR_FOCUS")};
113
+ }
114
+
115
+ // DISABLED
116
+ &:has(.--CHECKBOX-inputField:disabled) {
117
+ pointer-events: none;
118
+ ${_(e, "DISABLED")};
119
+ }
120
+
121
+ // DISABLED + VALUE
122
+ &:has(.--CHECKBOX-inputField:disabled:checked) {
123
+ ${_(e, "DISABLED_VALUE")};
124
+ }
125
+
126
+ .--CHECKBOX-checkbox {
127
+ position: relative;
128
+ display: inline-flex;
129
+ width: 24px;
130
+ height: 24px;
131
+ isolation: isolate;
132
+
133
+ .--CHECKBOX-inputField {
134
+ cursor: pointer;
135
+ position: absolute;
136
+ opacity: 0;
137
+ width: 100%;
138
+ height: 100%;
139
+ z-index: 2;
140
+ margin: 0;
141
+ -webkit-tap-highlight-color: transparent;
142
+
143
+ ~ .--CHECKBOX-span > span {
144
+ visibility: hidden;
145
+ }
146
+ &:checked ~ .--CHECKBOX-span > span,
147
+ &:indeterminate ~ .--CHECKBOX-span > span {
148
+ visibility: visible;
149
+ }
150
+
151
+ // ENABLED
152
+ ~ .--CHECKBOX-span {
153
+ ${f(e, "ENABLED")};
154
+ ${p(e, "ENABLED")};
155
+ ${g(e, "ENABLED")};
156
+ }
157
+
158
+ // VALUE
159
+ &:checked ~ .--CHECKBOX-span {
160
+ ${f(e, "VALUE")};
161
+ ${p(e, "VALUE")};
162
+ ${g(e, "VALUE")};
163
+ }
164
+
165
+ // INDETERMINATE (same appearance as VALUE)
166
+ &:indeterminate ~ .--CHECKBOX-span {
167
+ ${f(e, "VALUE")};
168
+ ${p(e, "VALUE")};
169
+ ${g(e, "VALUE")};
170
+ }
171
+
172
+ // HOVER
173
+ // Is at the container level
174
+
175
+ // ACTIVE
176
+ &.--CHECKBOX-active ~ .--CHECKBOX-span,
177
+ &:active ~ .--CHECKBOX-span {
178
+ &:before {
179
+ opacity: 1;
180
+ ${h(e, "ACTIVE")};
181
+ }
182
+ }
183
+
184
+ // FOCUS
185
+ &:focus-visible ~ .--CHECKBOX-span {
186
+ outline: none;
187
+ ${m(e, "FOCUS")};
188
+ ${g(e, "FOCUS")};
189
+ }
190
+
191
+ // ERROR
192
+ &.--CHECKBOX-error ~ .--CHECKBOX-span {
193
+ ${f(e, "ERROR")};
194
+ ${p(e, "ERROR")};
195
+ ${g(e, "ERROR")};
196
+ }
197
+
198
+ // ERROR + VALUE
199
+ &.--CHECKBOX-error:checked ~ .--CHECKBOX-span {
200
+ ${f(e, "ERROR_VALUE")};
201
+ ${p(e, "ERROR_VALUE")};
202
+ ${g(e, "ERROR_VALUE")};
203
+ }
204
+
205
+ // ERROR + VALUE
206
+ // Is at the container level
207
+
208
+ // ERROR + ACTIVE
209
+ &.--CHECKBOX-error:active ~ .--CHECKBOX-span,
210
+ &.--CHECKBOX-error.--CHECKBOX-active ~ .--CHECKBOX-span {
211
+ &:before {
212
+ opacity: 1;
213
+ ${h(e, "ERROR_ACTIVE")};
214
+ }
215
+ }
216
+
217
+ // ERROR + FOCUS
218
+ &.--CHECKBOX-error:focus-visible ~ .--CHECKBOX-span {
219
+ ${m(e, "ERROR_FOCUS")};
220
+ ${g(e, "ERROR_FOCUS")};
221
+ }
222
+
223
+ // DISABLED
224
+ &:disabled ~ .--CHECKBOX-span {
225
+ ${f(e, "DISABLED")};
226
+ ${p(e, "DISABLED")};
227
+ ${g(e, "DISABLED")};
228
+ }
229
+
230
+ // DISABLED + VALUE
231
+ &:disabled:checked ~ .--CHECKBOX-span {
232
+ ${f(e, "DISABLED_VALUE")};
233
+ ${p(e, "DISABLED_VALUE")};
234
+ ${g(e, "DISABLED_VALUE")};
235
+ }
236
+ }
237
+
238
+ .--CHECKBOX-span {
239
+ width: 24px;
240
+ height: 24px;
241
+ ${a(e, "border-radius", "--CHECKBOX-ROOT-BORDER-RADIUS")};
242
+ position: absolute;
243
+ box-sizing: border-box;
244
+ display: flex;
245
+ align-items: center;
246
+ justify-content: center;
247
+ transition:
248
+ background-color 150ms ease-in-out,
249
+ border-color 150ms ease-in-out;
250
+
251
+ > span {
252
+ width: 100%;
253
+ height: auto;
254
+ z-index: 1;
255
+ }
256
+
257
+ &:before {
258
+ content: '';
259
+ position: absolute;
260
+ width: 32px;
261
+ height: 32px;
262
+ border-radius: 50%;
263
+ opacity: 0;
264
+ transition: opacity 150ms ease-in-out;
265
+ z-index: -1;
266
+ }
267
+ }
268
+ }
269
+
270
+ .--CHECKBOX-label {
271
+ // FONT
272
+ font-family: ${e["--FONTFAMILY-PRIMARY"]};
273
+ font-size: 0.875rem;
274
+ font-weight: 500;
275
+ line-height: 1;
276
+ }
277
+ }
278
+
279
+ .--CHECKBOX-helperText {
280
+ // FONT
281
+ font-family: ${e["--FONTFAMILY-PRIMARY"]};
282
+ font-size: 13px;
283
+ line-height: 16px;
284
+ margin-left: 14px;
285
+ }
286
+ }
287
+ `, y = s(null), b = s(null), x = "--CHECKBOX", S = o.forwardRef(({ label: r, icon: i = /* @__PURE__ */ t(n, { name: "check" }), helperText: a, showErrorText: o = !0, className: s, style: c = {}, disabled: u, checked: d, onChecked: f, error: p, onKeyDown: m, onKeyUp: h, onBlur: g, ..._ }, y) => {
288
+ let [b, S] = l(!1);
289
+ return /* @__PURE__ */ e("div", {
290
+ className: [
291
+ x,
292
+ b ? `${x}-active` : "",
293
+ s || ""
294
+ ].join(" "),
295
+ css: v(c),
296
+ "data-testid": x,
297
+ children: [/* @__PURE__ */ e("label", {
298
+ className: `${x}-container`,
299
+ children: [/* @__PURE__ */ e("div", {
300
+ className: `${x}-checkbox`,
301
+ children: [/* @__PURE__ */ t("input", {
302
+ className: [
303
+ `${x}-inputField`,
304
+ b ? `${x}-active` : "",
305
+ o && p && `${x}-error`
306
+ ].join(" "),
307
+ type: "checkbox",
308
+ checked: d,
309
+ disabled: u,
310
+ onChange: (e) => f(e.target.checked),
311
+ onKeyDown: (e) => {
312
+ (e.key === "Enter" || e.key === "Space") && S(!0), m?.(e);
313
+ },
314
+ onKeyUp: (e) => {
315
+ (e.key === "Enter" || e.key === "Space") && (S(!1), f(!d)), h?.(e);
316
+ },
317
+ onBlur: () => {
318
+ S(!1), g?.({});
319
+ },
320
+ ref: y,
321
+ "data-testid": `${x}-inputField`,
322
+ ..._
323
+ }), /* @__PURE__ */ t("span", {
324
+ className: `${x}-span`,
325
+ "data-testid": `${x}-icon`,
326
+ children: i
327
+ })]
328
+ }), /* @__PURE__ */ t("span", {
329
+ className: `${x}-label`,
330
+ "data-testid": `${x}-label`,
331
+ children: r
332
+ })]
333
+ }), (a || o) && /* @__PURE__ */ e("span", {
334
+ className: `${x}-helperText`,
335
+ "data-testid": `${x}-helperText`,
336
+ children: [a && (!p || !o) && a, o && p && p.message]
337
+ })]
338
+ });
339
+ });
340
+ S.displayName = "CheckboxBase";
341
+ var C = ({ name: e, control: n, ...r }) => {
342
+ let { field: i, fieldState: a } = d({
343
+ control: n,
344
+ name: e
345
+ }), [o, s] = l(i.value || !1), c = a.error, u = (e) => {
346
+ i.onChange(e), s(e), c && i.onBlur();
347
+ };
348
+ return /* @__PURE__ */ t(S, {
349
+ ...r,
350
+ name: e,
351
+ checked: o,
352
+ onChecked: u,
353
+ onBlur: () => i.onBlur(),
354
+ error: c
355
+ });
356
+ }, w = (e) => {
357
+ let n = c(y), r = c(b), i = n ?? r;
358
+ if (typeof e.checked == "boolean" && !e.control) {
359
+ let { checked: n, onChecked: r, name: i, control: a, ...o } = e;
360
+ return /* @__PURE__ */ t(S, {
361
+ ...o,
362
+ name: i,
363
+ checked: n,
364
+ onChecked: r ?? (() => {})
365
+ });
366
+ }
367
+ if (i) {
368
+ let { value: n, name: r, control: a, ...o } = e, s = n ?? r ?? "", c = i.checkedValues.includes(s);
369
+ return /* @__PURE__ */ t(S, {
370
+ ...o,
371
+ name: r,
372
+ value: s,
373
+ checked: c,
374
+ onChecked: (e) => i.onChange(s, e),
375
+ disabled: o.disabled ?? i.disabled,
376
+ error: i.error,
377
+ showErrorText: !1,
378
+ helperText: void 0
379
+ });
380
+ }
381
+ return /* @__PURE__ */ t(C, { ...e });
382
+ }, T = ({ theme: e, variant: n = "default", ...a }) => {
383
+ let { componentStyles: o } = i([r.CHECKBOX], e, n.toUpperCase());
384
+ return /* @__PURE__ */ t(w, {
385
+ ...a,
386
+ style: o
387
+ });
388
+ }, E = s(null);
389
+ //#endregion
390
+ export { y as i, T as n, b as r, E as t };
391
+
392
+ //# sourceMappingURL=RadioGroup.context-v_CCYB7_.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioGroup.context-v_CCYB7_.js","names":[],"sources":["../src/components/atoms/Checkbox/Checkbox.emotion.ts","../src/components/molecules/CheckboxGroup/CheckboxGroup.context.ts","../src/components/molecules/CheckboxTree/CheckboxTree.context.ts","../src/components/atoms/Checkbox/Checkbox.tsx","../src/components/atoms/Checkbox/index.tsx","../src/components/atoms/Radio/RadioGroup.context.ts"],"sourcesContent":["import { css } from '@emotion/react';\nimport { getStyle } from '@utilities/emotion/styles';\n\nconst background = (theme: Record<string, string>, event: string): string => `\n // BACKGROUNDS \n ${getStyle(theme, 'background-color', `--CHECKBOX-EVENTS-${event}-BACKGROUND-COLOR`)}\n`;\n\nconst border = (theme: Record<string, string>, event: string): string => `\n // BORDERS\n ${getStyle(theme, 'border-color', `--CHECKBOX-EVENTS-${event}-BORDER-COLOR`)}\n ${getStyle(theme, 'border-width', `--CHECKBOX-EVENTS-${event}-BORDER-WIDTH`)}\n ${getStyle(theme, 'border-style', `--CHECKBOX-EVENTS-${event}-BORDER-STYLE`)}\n`;\n\nconst outline = (theme: Record<string, string>, event: string): string => ` \n // OUTLINE\n ${getStyle(theme, 'outline-color', `--CHECKBOX-EVENTS-${event}-OUTLINE-COLOR`)}\n ${getStyle(theme, 'outline-width', `--CHECKBOX-EVENTS-${event}-OUTLINE-WIDTH`)}\n ${getStyle(theme, 'outline-style', `--CHECKBOX-EVENTS-${event}-OUTLINE-STYLE`)}\n ${getStyle(theme, 'outline-offset', `--CHECKBOX-EVENTS-${event}-OUTLINE-OFFSET`)}\n`;\n\nconst shadow = (theme: Record<string, string>, event: string): string => ` \n // SHADOW\n ${getStyle(theme, 'background-color', `--CHECKBOX-EVENTS-${event}-SHADOW-COLOR`)}\n`;\n\nconst icon = (theme: Record<string, string>, event: string): string => `\n // UTILS\n > span {\n ${getStyle(theme, 'color', `--CHECKBOX-EVENTS-${event}-ICON-COLOR`)};\n }\n`;\n\nconst label = (theme: Record<string, string>, event: string): string => `\n // TYPOGRAPHY\n .--CHECKBOX-label {\n ${getStyle(theme, 'color', `--CHECKBOX-EVENTS-${event}-COLOR-PRIMARY`)}\n }\n\n ~ .--CHECKBOX-helperText {\n ${getStyle(theme, 'color', `--CHECKBOX-EVENTS-${event}-COLOR-SECONDARY`)}\n }\n`;\n\nconst Style = (theme: Record<string, string>) => css`\n &.--CHECKBOX {\n display: flex;\n flex-direction: column;\n gap: 8px;\n width: fit-content;\n\n .--CHECKBOX-container {\n display: flex;\n flex-direction: row;\n gap: 12px;\n align-items: center;\n cursor: pointer;\n\n // ENABLED\n ${label(theme, 'ENABLED')};\n\n // VALUE\n &:has(.--CHECKBOX-inputField:checked) {\n ${label(theme, 'VALUE')};\n }\n\n // HOVER\n &:hover {\n ${label(theme, 'HOVER')};\n\n .--CHECKBOX-checkbox .--CHECKBOX-span {\n &:before {\n opacity: 1;\n ${shadow(theme, 'HOVER')};\n }\n }\n }\n\n // ACTIVE\n &:has(.--CHECKBOX-inputField.--CHECKBOX-active, .--CHECKBOX-inputField:active) {\n ${label(theme, 'ACTIVE')};\n }\n\n // FOCUS-VISIBLE\n &:has(.--CHECKBOX-inputField:focus-visible) {\n ${label(theme, 'FOCUS')};\n }\n\n // ERROR\n &:has(.--CHECKBOX-inputField.--CHECKBOX-error) {\n ${label(theme, 'ERROR')};\n }\n\n // ERROR + VALUE\n &:has(.--CHECKBOX-inputField.--CHECKBOX-error:checked) {\n ${label(theme, 'ERROR_VALUE')};\n }\n\n // ERROR + HOVER\n &:hover:has(.--CHECKBOX-inputField.--CHECKBOX-error) {\n ${label(theme, 'ERROR_HOVER')};\n\n .--CHECKBOX-checkbox .--CHECKBOX-span {\n &:before {\n opacity: 1;\n ${shadow(theme, 'ERROR_HOVER')};\n }\n }\n }\n\n // ERROR + ACTIVE\n &:has(.--CHECKBOX-inputField.--CHECKBOX-error:active),\n &:has(.--CHECKBOX-inputField.--CHECKBOX-error.--CHECKBOX-active) {\n ${label(theme, 'ERROR_ACTIVE')};\n }\n\n // ERROR + FOCUS\n &:has(.--CHECKBOX-inputField.--CHECKBOX-error:focus-visible) {\n ${label(theme, 'ERROR_FOCUS')};\n }\n\n // DISABLED\n &:has(.--CHECKBOX-inputField:disabled) {\n pointer-events: none;\n ${label(theme, 'DISABLED')};\n }\n\n // DISABLED + VALUE\n &:has(.--CHECKBOX-inputField:disabled:checked) {\n ${label(theme, 'DISABLED_VALUE')};\n }\n\n .--CHECKBOX-checkbox {\n position: relative;\n display: inline-flex;\n width: 24px;\n height: 24px;\n isolation: isolate;\n\n .--CHECKBOX-inputField {\n cursor: pointer;\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n z-index: 2;\n margin: 0;\n -webkit-tap-highlight-color: transparent;\n\n ~ .--CHECKBOX-span > span {\n visibility: hidden;\n }\n &:checked ~ .--CHECKBOX-span > span,\n &:indeterminate ~ .--CHECKBOX-span > span {\n visibility: visible;\n }\n\n // ENABLED\n ~ .--CHECKBOX-span {\n ${background(theme, 'ENABLED')};\n ${border(theme, 'ENABLED')};\n ${icon(theme, 'ENABLED')};\n }\n\n // VALUE\n &:checked ~ .--CHECKBOX-span {\n ${background(theme, 'VALUE')};\n ${border(theme, 'VALUE')};\n ${icon(theme, 'VALUE')};\n }\n\n // INDETERMINATE (same appearance as VALUE)\n &:indeterminate ~ .--CHECKBOX-span {\n ${background(theme, 'VALUE')};\n ${border(theme, 'VALUE')};\n ${icon(theme, 'VALUE')};\n }\n\n // HOVER\n // Is at the container level\n\n // ACTIVE\n &.--CHECKBOX-active ~ .--CHECKBOX-span,\n &:active ~ .--CHECKBOX-span {\n &:before {\n opacity: 1;\n ${shadow(theme, 'ACTIVE')};\n }\n }\n\n // FOCUS\n &:focus-visible ~ .--CHECKBOX-span {\n outline: none;\n ${outline(theme, 'FOCUS')};\n ${icon(theme, 'FOCUS')};\n }\n\n // ERROR\n &.--CHECKBOX-error ~ .--CHECKBOX-span {\n ${background(theme, 'ERROR')};\n ${border(theme, 'ERROR')};\n ${icon(theme, 'ERROR')};\n }\n\n // ERROR + VALUE\n &.--CHECKBOX-error:checked ~ .--CHECKBOX-span {\n ${background(theme, 'ERROR_VALUE')};\n ${border(theme, 'ERROR_VALUE')};\n ${icon(theme, 'ERROR_VALUE')};\n }\n\n // ERROR + VALUE\n // Is at the container level\n\n // ERROR + ACTIVE\n &.--CHECKBOX-error:active ~ .--CHECKBOX-span,\n &.--CHECKBOX-error.--CHECKBOX-active ~ .--CHECKBOX-span {\n &:before {\n opacity: 1;\n ${shadow(theme, 'ERROR_ACTIVE')};\n }\n }\n\n // ERROR + FOCUS\n &.--CHECKBOX-error:focus-visible ~ .--CHECKBOX-span {\n ${outline(theme, 'ERROR_FOCUS')};\n ${icon(theme, 'ERROR_FOCUS')};\n }\n\n // DISABLED\n &:disabled ~ .--CHECKBOX-span {\n ${background(theme, 'DISABLED')};\n ${border(theme, 'DISABLED')};\n ${icon(theme, 'DISABLED')};\n }\n\n // DISABLED + VALUE\n &:disabled:checked ~ .--CHECKBOX-span {\n ${background(theme, 'DISABLED_VALUE')};\n ${border(theme, 'DISABLED_VALUE')};\n ${icon(theme, 'DISABLED_VALUE')};\n }\n }\n\n .--CHECKBOX-span {\n width: 24px;\n height: 24px;\n ${getStyle(theme, 'border-radius', '--CHECKBOX-ROOT-BORDER-RADIUS')};\n position: absolute;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n background-color 150ms ease-in-out,\n border-color 150ms ease-in-out;\n\n > span {\n width: 100%;\n height: auto;\n z-index: 1;\n }\n\n &:before {\n content: '';\n position: absolute;\n width: 32px;\n height: 32px;\n border-radius: 50%;\n opacity: 0;\n transition: opacity 150ms ease-in-out;\n z-index: -1;\n }\n }\n }\n\n .--CHECKBOX-label {\n // FONT\n font-family: ${theme['--FONTFAMILY-PRIMARY']};\n font-size: 0.875rem;\n font-weight: 500;\n line-height: 1;\n }\n }\n\n .--CHECKBOX-helperText {\n // FONT\n font-family: ${theme['--FONTFAMILY-PRIMARY']};\n font-size: 13px;\n line-height: 16px;\n margin-left: 14px;\n }\n }\n`;\n\nexport default Style;\n","import { createContext } from 'react';\n\nexport interface CheckboxGroupContextValue {\n /** Array of currently checked option values */\n checkedValues: string[];\n /** Toggle a value in/out of the checked array */\n onChange: (value: string, checked: boolean) => void;\n /** Group-level disabled state */\n disabled?: boolean;\n /** Group-level validation error */\n error?: { message?: string };\n}\n\nexport const CheckboxGroupContext = createContext<CheckboxGroupContextValue | null>(null);\n","import { createContext } from 'react';\n\nexport interface CheckboxTreeContextValue {\n /** Array of currently checked option values */\n checkedValues: string[];\n /** Toggle a value in/out of the checked array */\n onChange: (value: string, checked: boolean) => void;\n /** Tree-level disabled state */\n disabled?: boolean;\n /** Tree-level validation error */\n error?: { message?: string };\n}\n\nexport const CheckboxTreeContext = createContext<CheckboxTreeContextValue | null>(null);\n","import React, { useState, useContext } from 'react';\n// Component Base\nimport emotion from './Checkbox.emotion';\nimport type { CheckboxProps, CheckboxBaseProps } from './Checkbox.interface';\nimport { CheckboxGroupContext } from '../../molecules/CheckboxGroup/CheckboxGroup.context';\nimport { CheckboxTreeContext } from '../../molecules/CheckboxTree/CheckboxTree.context';\n// External Libraries\nimport { useController, type FieldValues, type FieldPath } from 'react-hook-form';\n// Custom Components\nimport Icon from '@components/atoms/Icon';\n\nconst CLASS = '--CHECKBOX';\n\n/**\n * Headless presentational layer for the checkbox.\n * Accepts `checked` and `onChecked` directly — use this when you need a controlled checkbox outside of React Hook Form.\n */\nexport const CheckboxBase = React.forwardRef<HTMLInputElement, CheckboxBaseProps>(\n (\n {\n label,\n icon = <Icon name='check' />,\n helperText,\n showErrorText = true,\n className,\n style = {},\n disabled,\n checked,\n onChecked,\n error,\n onKeyDown,\n onKeyUp,\n onBlur,\n ...rest\n }: CheckboxBaseProps,\n ref,\n ) => {\n const [isActive, setIsActive] = useState(false);\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (event.key === 'Enter' || event.key === 'Space') setIsActive(true);\n onKeyDown?.(event);\n };\n\n const handleKeyUp = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (event.key === 'Enter' || event.key === 'Space') {\n setIsActive(false);\n onChecked(!checked);\n }\n onKeyUp?.(event);\n };\n\n const handleBlur = () => {\n setIsActive(false);\n onBlur?.({} as React.FocusEvent<HTMLInputElement>);\n };\n\n return (\n <div\n className={[CLASS, isActive ? `${CLASS}-active` : '', className || ''].join(' ')}\n css={emotion(style)}\n data-testid={CLASS}\n >\n <label className={`${CLASS}-container`}>\n <div className={`${CLASS}-checkbox`}>\n <input\n className={[\n `${CLASS}-inputField`,\n isActive ? `${CLASS}-active` : '',\n showErrorText && error && `${CLASS}-error`,\n ].join(' ')}\n type='checkbox'\n checked={checked}\n disabled={disabled}\n onChange={e => onChecked(e.target.checked)}\n onKeyDown={handleKeyDown}\n onKeyUp={handleKeyUp}\n onBlur={handleBlur}\n ref={ref}\n data-testid={`${CLASS}-inputField`}\n {...rest}\n />\n <span className={`${CLASS}-span`} data-testid={`${CLASS}-icon`}>\n {icon}\n </span>\n </div>\n <span className={`${CLASS}-label`} data-testid={`${CLASS}-label`}>\n {label}\n </span>\n </label>\n {(helperText || showErrorText) && (\n <span className={`${CLASS}-helperText`} data-testid={`${CLASS}-helperText`}>\n {helperText && (!error || !showErrorText) && helperText}\n {showErrorText && error && error.message}\n </span>\n )}\n </div>\n );\n },\n);\n\nCheckboxBase.displayName = 'CheckboxBase';\n\nconst CheckboxRHF = <TFieldValues extends FieldValues = FieldValues>({\n name,\n control,\n ...rest\n}: CheckboxProps<TFieldValues>) => {\n const { field, fieldState } = useController({ control: control!, name: name! as FieldPath<TFieldValues> });\n const [value, setValue] = useState<boolean>(field.value || false);\n const errorText = fieldState.error;\n\n const onChecked = (checked: boolean) => {\n field.onChange(checked);\n setValue(checked);\n if (errorText) field.onBlur();\n };\n\n return (\n <CheckboxBase\n {...rest}\n name={name}\n checked={value}\n onChecked={onChecked}\n onBlur={() => field.onBlur()}\n error={errorText}\n />\n );\n};\n\nconst Checkbox = <TFieldValues extends FieldValues = FieldValues>(props: CheckboxProps<TFieldValues>) => {\n const groupCtx = useContext(CheckboxGroupContext);\n const treeCtx = useContext(CheckboxTreeContext);\n const ctx = groupCtx ?? treeCtx;\n\n if (typeof props.checked === 'boolean' && !props.control) {\n const { checked, onChecked, name, control, ...rest } = props;\n return <CheckboxBase {...rest} name={name} checked={checked} onChecked={onChecked ?? (() => {})} />;\n }\n\n if (ctx) {\n const { value, name, control, ...rest } = props;\n const itemValue = (value as string) ?? name ?? '';\n const checked = ctx.checkedValues.includes(itemValue);\n\n return (\n <CheckboxBase\n {...rest}\n name={name}\n value={itemValue}\n checked={checked}\n onChecked={c => ctx.onChange(itemValue, c)}\n disabled={rest.disabled ?? ctx.disabled}\n error={ctx.error}\n showErrorText={false}\n helperText={undefined}\n />\n );\n }\n\n return <CheckboxRHF {...props} />;\n};\n\nexport default Checkbox;\n","import { useCreateComponentStyles } from '@hocs/ThemeProvider/useThemeProvider.hook';\nimport { Component } from '@hocs/ThemeProvider/interfaces';\nimport type { CheckboxStyleProps } from './Checkbox.interface';\nimport type { FieldValues } from 'react-hook-form';\nimport CheckboxBase from './Checkbox';\n\nconst Checkbox = <TFieldValues extends FieldValues = FieldValues>({\n theme,\n variant = 'default',\n ...rest\n}: CheckboxStyleProps<TFieldValues>) => {\n const { componentStyles } = useCreateComponentStyles([Component.CHECKBOX], theme, variant.toUpperCase());\n\n return <CheckboxBase {...rest} style={componentStyles} />;\n};\n\nexport default Checkbox;\n","import { createContext } from 'react';\n\nexport interface RadioGroupContextValue {\n /** The name attribute shared by all radios in this group */\n name: string;\n /** The currently selected value */\n selectedValue: string;\n /** Select a value */\n onChange: (value: string) => void;\n /** Group-level disabled state */\n disabled?: boolean;\n /** Group-level validation error */\n error?: { message?: string };\n /** Value of the first non-disabled Radio child — used to implement roving tabindex */\n firstValue: string;\n}\n\nexport const RadioGroupContext = createContext<RadioGroupContextValue | null>(null);\n"],"mappings":";;;;;;AAGA,IAAM,KAAc,GAA+B,MAA0B;;IAEzE,EAAS,GAAO,oBAAoB,qBAAqB,EAAM,mBAAmB,CAAC;GAGjF,KAAU,GAA+B,MAA0B;;IAErE,EAAS,GAAO,gBAAgB,qBAAqB,EAAM,eAAe,CAAC;IAC3E,EAAS,GAAO,gBAAgB,qBAAqB,EAAM,eAAe,CAAC;IAC3E,EAAS,GAAO,gBAAgB,qBAAqB,EAAM,eAAe,CAAC;GAGzE,KAAW,GAA+B,MAA0B;;IAEtE,EAAS,GAAO,iBAAiB,qBAAqB,EAAM,gBAAgB,CAAC;IAC7E,EAAS,GAAO,iBAAiB,qBAAqB,EAAM,gBAAgB,CAAC;IAC7E,EAAS,GAAO,iBAAiB,qBAAqB,EAAM,gBAAgB,CAAC;IAC7E,EAAS,GAAO,kBAAkB,qBAAqB,EAAM,iBAAiB,CAAC;GAG7E,KAAU,GAA+B,MAA0B;;IAErE,EAAS,GAAO,oBAAoB,qBAAqB,EAAM,eAAe,CAAC;GAG7E,KAAQ,GAA+B,MAA0B;;;MAGjE,EAAS,GAAO,SAAS,qBAAqB,EAAM,aAAa,CAAC;;GAIlE,KAAS,GAA+B,MAA0B;;;MAGlE,EAAS,GAAO,SAAS,qBAAqB,EAAM,gBAAgB,CAAC;;;;MAIrE,EAAS,GAAO,SAAS,qBAAqB,EAAM,kBAAkB,CAAC;;GAIvE,KAAS,MAAkC,CAAG;;;;;;;;;;;;;;;QAe5C,EAAM,GAAO,UAAU,CAAC;;;;UAItB,EAAM,GAAO,QAAQ,CAAC;;;;;UAKtB,EAAM,GAAO,QAAQ,CAAC;;;;;cAKlB,EAAO,GAAO,QAAQ,CAAC;;;;;;;UAO3B,EAAM,GAAO,SAAS,CAAC;;;;;UAKvB,EAAM,GAAO,QAAQ,CAAC;;;;;UAKtB,EAAM,GAAO,QAAQ,CAAC;;;;;UAKtB,EAAM,GAAO,cAAc,CAAC;;;;;UAK5B,EAAM,GAAO,cAAc,CAAC;;;;;cAKxB,EAAO,GAAO,cAAc,CAAC;;;;;;;;UAQjC,EAAM,GAAO,eAAe,CAAC;;;;;UAK7B,EAAM,GAAO,cAAc,CAAC;;;;;;UAM5B,EAAM,GAAO,WAAW,CAAC;;;;;UAKzB,EAAM,GAAO,iBAAiB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cA8B3B,EAAW,GAAO,UAAU,CAAC;cAC7B,EAAO,GAAO,UAAU,CAAC;cACzB,EAAK,GAAO,UAAU,CAAC;;;;;cAKvB,EAAW,GAAO,QAAQ,CAAC;cAC3B,EAAO,GAAO,QAAQ,CAAC;cACvB,EAAK,GAAO,QAAQ,CAAC;;;;;cAKrB,EAAW,GAAO,QAAQ,CAAC;cAC3B,EAAO,GAAO,QAAQ,CAAC;cACvB,EAAK,GAAO,QAAQ,CAAC;;;;;;;;;;;gBAWnB,EAAO,GAAO,SAAS,CAAC;;;;;;;cAO1B,EAAQ,GAAO,QAAQ,CAAC;cACxB,EAAK,GAAO,QAAQ,CAAC;;;;;cAKrB,EAAW,GAAO,QAAQ,CAAC;cAC3B,EAAO,GAAO,QAAQ,CAAC;cACvB,EAAK,GAAO,QAAQ,CAAC;;;;;cAKrB,EAAW,GAAO,cAAc,CAAC;cACjC,EAAO,GAAO,cAAc,CAAC;cAC7B,EAAK,GAAO,cAAc,CAAC;;;;;;;;;;;gBAWzB,EAAO,GAAO,eAAe,CAAC;;;;;;cAMhC,EAAQ,GAAO,cAAc,CAAC;cAC9B,EAAK,GAAO,cAAc,CAAC;;;;;cAK3B,EAAW,GAAO,WAAW,CAAC;cAC9B,EAAO,GAAO,WAAW,CAAC;cAC1B,EAAK,GAAO,WAAW,CAAC;;;;;cAKxB,EAAW,GAAO,iBAAiB,CAAC;cACpC,EAAO,GAAO,iBAAiB,CAAC;cAChC,EAAK,GAAO,iBAAiB,CAAC;;;;;;;YAOhC,EAAS,GAAO,iBAAiB,gCAAgC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBA+BvD,EAAM,wBAAwB;;;;;;;;;qBAShC,EAAM,wBAAwB;;;;;;GCpRtC,IAAuB,EAAgD,KAAK,ECA5E,IAAsB,EAA+C,KAAK,ECFjF,IAAQ,cAMD,IAAe,EAAM,YAE9B,EACE,UACA,UAAO,kBAAC,GAAD,EAAM,MAAK,SAAU,CAAA,EAC5B,eACA,mBAAgB,IAChB,cACA,WAAQ,EAAE,EACV,aACA,YACA,cACA,UACA,cACA,YACA,WACA,GAAG,KAEL,MACG;CACH,IAAM,CAAC,GAAU,KAAe,EAAS,GAAM;CAoB/C,OACE,kBAAC,OAAD;EACE,WAAW;GAAC;GAAO,IAAW,GAAG,EAAM,WAAW;GAAI,KAAa;GAAG,CAAC,KAAK,IAAI;EAChF,KAAK,EAAQ,EAAM;EACnB,eAAa;YAHf,CAKE,kBAAC,SAAD;GAAO,WAAW,GAAG,EAAM;aAA3B,CACE,kBAAC,OAAD;IAAK,WAAW,GAAG,EAAM;cAAzB,CACE,kBAAC,SAAD;KACE,WAAW;MACT,GAAG,EAAM;MACT,IAAW,GAAG,EAAM,WAAW;MAC/B,KAAiB,KAAS,GAAG,EAAM;MACpC,CAAC,KAAK,IAAI;KACX,MAAK;KACI;KACC;KACV,WAAU,MAAK,EAAU,EAAE,OAAO,QAAQ;KAC1C,YApCa,MAAiD;MAEtE,CADI,EAAM,QAAQ,WAAW,EAAM,QAAQ,YAAS,EAAY,GAAK,EACrE,IAAY,EAAM;;KAmCV,UAhCW,MAAiD;MAKpE,CAJI,EAAM,QAAQ,WAAW,EAAM,QAAQ,aACzC,EAAY,GAAM,EAClB,EAAU,CAAC,EAAQ,GAErB,IAAU,EAAM;;KA4BR,cAzBe;MAEvB,AADA,EAAY,GAAM,EAClB,IAAS,EAAE,CAAuC;;KAwBrC;KACL,eAAa,GAAG,EAAM;KACtB,GAAI;KACJ,CAAA,EACF,kBAAC,QAAD;KAAM,WAAW,GAAG,EAAM;KAAQ,eAAa,GAAG,EAAM;eACrD;KACI,CAAA,CACH;OACN,kBAAC,QAAD;IAAM,WAAW,GAAG,EAAM;IAAS,eAAa,GAAG,EAAM;cACtD;IACI,CAAA,CACD;OACN,KAAc,MACd,kBAAC,QAAD;GAAM,WAAW,GAAG,EAAM;GAAc,eAAa,GAAG,EAAM;aAA9D,CACG,MAAe,CAAC,KAAS,CAAC,MAAkB,GAC5C,KAAiB,KAAS,EAAM,QAC5B;KAEL;;EAGX;AAED,EAAa,cAAc;AAE3B,IAAM,KAA+D,EACnE,SACA,YACA,GAAG,QAC8B;CACjC,IAAM,EAAE,UAAO,kBAAe,EAAc;EAAW;EAAgB;EAAkC,CAAC,EACpG,CAAC,GAAO,KAAY,EAAkB,EAAM,SAAS,GAAM,EAC3D,IAAY,EAAW,OAEvB,KAAa,MAAqB;EAGtC,AAFA,EAAM,SAAS,EAAQ,EACvB,EAAS,EAAQ,EACb,KAAW,EAAM,QAAQ;;CAG/B,OACE,kBAAC,GAAD;EACE,GAAI;EACE;EACN,SAAS;EACE;EACX,cAAc,EAAM,QAAQ;EAC5B,OAAO;EACP,CAAA;GAIA,KAA4D,MAAuC;CACvG,IAAM,IAAW,EAAW,EAAqB,EAC3C,IAAU,EAAW,EAAoB,EACzC,IAAM,KAAY;CAExB,IAAI,OAAO,EAAM,WAAY,aAAa,CAAC,EAAM,SAAS;EACxD,IAAM,EAAE,YAAS,cAAW,SAAM,YAAS,GAAG,MAAS;EACvD,OAAO,kBAAC,GAAD;GAAc,GAAI;GAAY;GAAe;GAAS,WAAW,YAAoB;GAAO,CAAA;;CAGrG,IAAI,GAAK;EACP,IAAM,EAAE,UAAO,SAAM,YAAS,GAAG,MAAS,GACpC,IAAa,KAAoB,KAAQ,IACzC,IAAU,EAAI,cAAc,SAAS,EAAU;EAErD,OACE,kBAAC,GAAD;GACE,GAAI;GACE;GACN,OAAO;GACE;GACT,YAAW,MAAK,EAAI,SAAS,GAAW,EAAE;GAC1C,UAAU,EAAK,YAAY,EAAI;GAC/B,OAAO,EAAI;GACX,eAAe;GACf,YAAY,KAAA;GACZ,CAAA;;CAIN,OAAO,kBAAC,GAAD,EAAa,GAAI,GAAS,CAAA;GC1J7B,KAA4D,EAChE,UACA,aAAU,WACV,GAAG,QACmC;CACtC,IAAM,EAAE,uBAAoB,EAAyB,CAAC,EAAU,SAAS,EAAE,GAAO,EAAQ,aAAa,CAAC;CAExG,OAAO,kBAAC,GAAD;EAAc,GAAI;EAAM,OAAO;EAAmB,CAAA;GCI9C,IAAoB,EAA6C,KAAK"}