@foi/design-system 0.0.4 → 0.0.7
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/README.md +8 -0
- package/dist/DatePicker.utils-ytCEcs6T.js +2680 -0
- package/dist/DatePicker.utils-ytCEcs6T.js.map +1 -0
- package/dist/RadioGroup-D2s7AY6E.js +325 -0
- package/dist/RadioGroup-D2s7AY6E.js.map +1 -0
- package/dist/RadioGroup.context-zJGC5Sjc.js +395 -0
- package/dist/RadioGroup.context-zJGC5Sjc.js.map +1 -0
- package/dist/Switch-CBpbDGqG.js +3830 -0
- package/dist/Switch-CBpbDGqG.js.map +1 -0
- package/dist/ThemeProvider-oFEpvMxv.js +37 -0
- package/dist/ThemeProvider-oFEpvMxv.js.map +1 -0
- package/dist/atoms.d.ts +18 -0
- package/dist/atoms.mjs +3 -0
- package/dist/emotion-react-jsx-runtime.browser.esm-BFNmScj4.js +992 -0
- package/dist/emotion-react-jsx-runtime.browser.esm-BFNmScj4.js.map +1 -0
- package/dist/hocs.d.ts +2 -0
- package/dist/hocs.mjs +2 -0
- package/dist/hooks.d.ts +2 -0
- package/dist/hooks.mjs +2 -0
- package/dist/index.mjs +6 -8654
- package/dist/molecules.d.ts +6 -0
- package/dist/molecules.mjs +2 -0
- package/dist/theme-DEqiATmv.js +436 -0
- package/dist/theme-DEqiATmv.js.map +1 -0
- package/dist/theme.d.ts +1 -0
- package/dist/theme.mjs +2 -0
- package/dist/useStateCallback-D9fqdxiO.js +26 -0
- package/dist/useStateCallback-D9fqdxiO.js.map +1 -0
- package/dist/utilities/cleaner/input.d.ts +1 -0
- package/dist/utilities/formatter/date.d.ts +3 -0
- package/dist/utilities/formatter/input.d.ts +1 -0
- package/dist/utilities/formatter/number.d.ts +2 -0
- package/dist/utilities/formatter/strings.d.ts +2 -0
- package/dist/utilities/regex/input.d.ts +4 -0
- package/dist/utilities/validator/input.d.ts +1 -0
- package/dist/utilities.d.ts +7 -0
- package/dist/utilities.mjs +23 -0
- package/dist/utilities.mjs.map +1 -0
- package/package.json +25 -1
- package/dist/index.mjs.map +0 -1
|
@@ -0,0 +1,395 @@
|
|
|
1
|
+
import { i as e, n as t, r as n } from "./emotion-react-jsx-runtime.browser.esm-BFNmScj4.js";
|
|
2
|
+
import { r } from "./theme-DEqiATmv.js";
|
|
3
|
+
import i, { createContext as a, useContext as o, useState as s } from "react";
|
|
4
|
+
import { css as c } from "@emotion/react";
|
|
5
|
+
import { useController as l } from "react-hook-form";
|
|
6
|
+
import u from "@mui/icons-material/CheckOutlined";
|
|
7
|
+
//#region src/hocs/ThemeProvider/interfaces/Components.interface.ts
|
|
8
|
+
var d = /* @__PURE__ */ function(e) {
|
|
9
|
+
return e.BUTTON = "BUTTON", e.ICONBUTTON = "ICONBUTTON", e.INPUT = "INPUT", e.CHECKBOX = "CHECKBOX", e.SELECT = "SELECT", e.SELECTMENU = "SELECTMENU", e.SWITCH = "SWITCH", e.SLIDER = "SLIDER", e.DATEPICKER = "DATEPICKER", e.DATEPICKERMENU = "DATEPICKERMENU", e.CHECKBOXGROUP = "CHECKBOXGROUP", e.CHECKBOXTREE = "CHECKBOXTREE", e.RADIOGROUP = "RADIOGROUP", e.RADIO = "RADIO", e;
|
|
10
|
+
}({}), f = (e, t) => `
|
|
11
|
+
// BACKGROUNDS
|
|
12
|
+
${r(e, "background-color", `--CHECKBOX-EVENTS-${t}-BACKGROUND-COLOR`)}
|
|
13
|
+
`, p = (e, t) => `
|
|
14
|
+
// BORDERS
|
|
15
|
+
${r(e, "border-color", `--CHECKBOX-EVENTS-${t}-BORDER-COLOR`)}
|
|
16
|
+
${r(e, "border-width", `--CHECKBOX-EVENTS-${t}-BORDER-WIDTH`)}
|
|
17
|
+
${r(e, "border-style", `--CHECKBOX-EVENTS-${t}-BORDER-STYLE`)}
|
|
18
|
+
`, m = (e, t) => `
|
|
19
|
+
// OUTLINE
|
|
20
|
+
${r(e, "outline-color", `--CHECKBOX-EVENTS-${t}-OUTLINE-COLOR`)}
|
|
21
|
+
${r(e, "outline-width", `--CHECKBOX-EVENTS-${t}-OUTLINE-WIDTH`)}
|
|
22
|
+
${r(e, "outline-style", `--CHECKBOX-EVENTS-${t}-OUTLINE-STYLE`)}
|
|
23
|
+
${r(e, "outline-offset", `--CHECKBOX-EVENTS-${t}-OUTLINE-OFFSET`)}
|
|
24
|
+
`, h = (e, t) => `
|
|
25
|
+
// SHADOW
|
|
26
|
+
${r(e, "background-color", `--CHECKBOX-EVENTS-${t}-SHADOW-COLOR`)}
|
|
27
|
+
`, g = (e, t) => `
|
|
28
|
+
// UTILS
|
|
29
|
+
> svg > path {
|
|
30
|
+
${r(e, "fill", `--CHECKBOX-EVENTS-${t}-ICON-COLOR`)};
|
|
31
|
+
}
|
|
32
|
+
`, _ = (e, t) => `
|
|
33
|
+
// TYPOGRAPHY
|
|
34
|
+
.--CHECKBOX-label {
|
|
35
|
+
${r(e, "color", `--CHECKBOX-EVENTS-${t}-COLOR-PRIMARY`)}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
~ .--CHECKBOX-helperText {
|
|
39
|
+
${r(e, "color", `--CHECKBOX-EVENTS-${t}-COLOR-SECONDARY`)}
|
|
40
|
+
}
|
|
41
|
+
`, v = (e) => c`
|
|
42
|
+
&.--CHECKBOX {
|
|
43
|
+
display: flex;
|
|
44
|
+
flex-direction: column;
|
|
45
|
+
gap: 8px;
|
|
46
|
+
width: fit-content;
|
|
47
|
+
|
|
48
|
+
.--CHECKBOX-container {
|
|
49
|
+
display: flex;
|
|
50
|
+
flex-direction: row;
|
|
51
|
+
gap: 12px;
|
|
52
|
+
align-items: center;
|
|
53
|
+
cursor: pointer;
|
|
54
|
+
|
|
55
|
+
// ENABLED
|
|
56
|
+
${_(e, "ENABLED")};
|
|
57
|
+
|
|
58
|
+
// VALUE
|
|
59
|
+
&:has(.--CHECKBOX-inputField:checked) {
|
|
60
|
+
${_(e, "VALUE")};
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// HOVER
|
|
64
|
+
&:hover {
|
|
65
|
+
${_(e, "HOVER")};
|
|
66
|
+
|
|
67
|
+
.--CHECKBOX-checkbox .--CHECKBOX-span {
|
|
68
|
+
&:before {
|
|
69
|
+
opacity: 1;
|
|
70
|
+
${h(e, "HOVER")};
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
// ACTIVE
|
|
76
|
+
&:has(.--CHECKBOX-inputField.--CHECKBOX-active, .--CHECKBOX-inputField:active) {
|
|
77
|
+
${_(e, "ACTIVE")};
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
// FOCUS-VISIBLE
|
|
81
|
+
&:has(.--CHECKBOX-inputField:focus-visible) {
|
|
82
|
+
${_(e, "FOCUS")};
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// ERROR
|
|
86
|
+
&:has(.--CHECKBOX-inputField.--CHECKBOX-error) {
|
|
87
|
+
${_(e, "ERROR")};
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
// ERROR + VALUE
|
|
91
|
+
&:has(.--CHECKBOX-inputField.--CHECKBOX-error:checked) {
|
|
92
|
+
${_(e, "ERROR_VALUE")};
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// ERROR + HOVER
|
|
96
|
+
&:hover:has(.--CHECKBOX-inputField.--CHECKBOX-error) {
|
|
97
|
+
${_(e, "ERROR_HOVER")};
|
|
98
|
+
|
|
99
|
+
.--CHECKBOX-checkbox .--CHECKBOX-span {
|
|
100
|
+
&:before {
|
|
101
|
+
opacity: 1;
|
|
102
|
+
${h(e, "ERROR_HOVER")};
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// ERROR + ACTIVE
|
|
108
|
+
&:has(.--CHECKBOX-inputField.--CHECKBOX-error:active),
|
|
109
|
+
&:has(.--CHECKBOX-inputField.--CHECKBOX-error.--CHECKBOX-active) {
|
|
110
|
+
${_(e, "ERROR_ACTIVE")};
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
// ERROR + FOCUS
|
|
114
|
+
&:has(.--CHECKBOX-inputField.--CHECKBOX-error:focus-visible) {
|
|
115
|
+
${_(e, "ERROR_FOCUS")};
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// DISABLED
|
|
119
|
+
&:has(.--CHECKBOX-inputField:disabled) {
|
|
120
|
+
pointer-events: none;
|
|
121
|
+
${_(e, "DISABLED")};
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// DISABLED + VALUE
|
|
125
|
+
&:has(.--CHECKBOX-inputField:disabled:checked) {
|
|
126
|
+
${_(e, "DISABLED_VALUE")};
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
.--CHECKBOX-checkbox {
|
|
130
|
+
position: relative;
|
|
131
|
+
display: inline-flex;
|
|
132
|
+
width: 24px;
|
|
133
|
+
height: 24px;
|
|
134
|
+
isolation: isolate;
|
|
135
|
+
|
|
136
|
+
.--CHECKBOX-inputField {
|
|
137
|
+
cursor: pointer;
|
|
138
|
+
position: absolute;
|
|
139
|
+
opacity: 0;
|
|
140
|
+
width: 100%;
|
|
141
|
+
height: 100%;
|
|
142
|
+
z-index: 2;
|
|
143
|
+
margin: 0;
|
|
144
|
+
-webkit-tap-highlight-color: transparent;
|
|
145
|
+
|
|
146
|
+
~ .--CHECKBOX-span > svg {
|
|
147
|
+
visibility: hidden;
|
|
148
|
+
}
|
|
149
|
+
&:checked ~ .--CHECKBOX-span > svg,
|
|
150
|
+
&:indeterminate ~ .--CHECKBOX-span > svg {
|
|
151
|
+
visibility: visible;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
// ENABLED
|
|
155
|
+
~ .--CHECKBOX-span {
|
|
156
|
+
${f(e, "ENABLED")};
|
|
157
|
+
${p(e, "ENABLED")};
|
|
158
|
+
${g(e, "ENABLED")};
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
// VALUE
|
|
162
|
+
&:checked ~ .--CHECKBOX-span {
|
|
163
|
+
${f(e, "VALUE")};
|
|
164
|
+
${p(e, "VALUE")};
|
|
165
|
+
${g(e, "VALUE")};
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
// INDETERMINATE (same appearance as VALUE)
|
|
169
|
+
&:indeterminate ~ .--CHECKBOX-span {
|
|
170
|
+
${f(e, "VALUE")};
|
|
171
|
+
${p(e, "VALUE")};
|
|
172
|
+
${g(e, "VALUE")};
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
// HOVER
|
|
176
|
+
// Is at the container level
|
|
177
|
+
|
|
178
|
+
// ACTIVE
|
|
179
|
+
&.--CHECKBOX-active ~ .--CHECKBOX-span,
|
|
180
|
+
&:active ~ .--CHECKBOX-span {
|
|
181
|
+
&:before {
|
|
182
|
+
opacity: 1;
|
|
183
|
+
${h(e, "ACTIVE")};
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
// FOCUS
|
|
188
|
+
&:focus-visible ~ .--CHECKBOX-span {
|
|
189
|
+
outline: none;
|
|
190
|
+
${m(e, "FOCUS")};
|
|
191
|
+
${g(e, "FOCUS")};
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
// ERROR
|
|
195
|
+
&.--CHECKBOX-error ~ .--CHECKBOX-span {
|
|
196
|
+
${f(e, "ERROR")};
|
|
197
|
+
${p(e, "ERROR")};
|
|
198
|
+
${g(e, "ERROR")};
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
// ERROR + VALUE
|
|
202
|
+
&.--CHECKBOX-error:checked ~ .--CHECKBOX-span {
|
|
203
|
+
${f(e, "ERROR_VALUE")};
|
|
204
|
+
${p(e, "ERROR_VALUE")};
|
|
205
|
+
${g(e, "ERROR_VALUE")};
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
// ERROR + VALUE
|
|
209
|
+
// Is at the container level
|
|
210
|
+
|
|
211
|
+
// ERROR + ACTIVE
|
|
212
|
+
&.--CHECKBOX-error:active ~ .--CHECKBOX-span,
|
|
213
|
+
&.--CHECKBOX-error.--CHECKBOX-active ~ .--CHECKBOX-span {
|
|
214
|
+
&:before {
|
|
215
|
+
opacity: 1;
|
|
216
|
+
${h(e, "ERROR_ACTIVE")};
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// ERROR + FOCUS
|
|
221
|
+
&.--CHECKBOX-error:focus-visible ~ .--CHECKBOX-span {
|
|
222
|
+
${m(e, "ERROR_FOCUS")};
|
|
223
|
+
${g(e, "ERROR_FOCUS")};
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
// DISABLED
|
|
227
|
+
&:disabled ~ .--CHECKBOX-span {
|
|
228
|
+
${f(e, "DISABLED")};
|
|
229
|
+
${p(e, "DISABLED")};
|
|
230
|
+
${g(e, "DISABLED")};
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
// DISABLED + VALUE
|
|
234
|
+
&:disabled:checked ~ .--CHECKBOX-span {
|
|
235
|
+
${f(e, "DISABLED_VALUE")};
|
|
236
|
+
${p(e, "DISABLED_VALUE")};
|
|
237
|
+
${g(e, "DISABLED_VALUE")};
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
.--CHECKBOX-span {
|
|
242
|
+
width: 24px;
|
|
243
|
+
height: 24px;
|
|
244
|
+
${r(e, "border-radius", "--CHECKBOX-ROOT-BORDER-RADIUS")};
|
|
245
|
+
position: absolute;
|
|
246
|
+
box-sizing: border-box;
|
|
247
|
+
display: flex;
|
|
248
|
+
align-items: center;
|
|
249
|
+
justify-content: center;
|
|
250
|
+
transition:
|
|
251
|
+
background-color 150ms ease-in-out,
|
|
252
|
+
border-color 150ms ease-in-out;
|
|
253
|
+
|
|
254
|
+
> svg {
|
|
255
|
+
width: 100%;
|
|
256
|
+
height: auto;
|
|
257
|
+
z-index: 1;
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
&:before {
|
|
261
|
+
content: '';
|
|
262
|
+
position: absolute;
|
|
263
|
+
width: 36px;
|
|
264
|
+
height: 36px;
|
|
265
|
+
border-radius: 50%;
|
|
266
|
+
opacity: 0;
|
|
267
|
+
transition: opacity 150ms ease-in-out;
|
|
268
|
+
z-index: -1;
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
.--CHECKBOX-label {
|
|
274
|
+
// FONT
|
|
275
|
+
font-family: ${e["--FONTFAMILY-PRIMARY"]};
|
|
276
|
+
font-size: 0.875rem;
|
|
277
|
+
font-weight: 500;
|
|
278
|
+
line-height: 1;
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
.--CHECKBOX-helperText {
|
|
283
|
+
// FONT
|
|
284
|
+
font-family: ${e["--FONTFAMILY-PRIMARY"]};
|
|
285
|
+
font-size: 13px;
|
|
286
|
+
line-height: 16px;
|
|
287
|
+
margin-left: 14px;
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
`, y = a(null), b = a(null), x = "--CHECKBOX", S = i.forwardRef(({ label: e, icon: r = /* @__PURE__ */ t(u, {}), helperText: i, showErrorText: a = !0, className: o, style: c = {}, disabled: l, checked: d, onChecked: f, error: p, onKeyDown: m, onKeyUp: h, onBlur: g, ..._ }, y) => {
|
|
291
|
+
let [b, S] = s(!1);
|
|
292
|
+
return /* @__PURE__ */ n("div", {
|
|
293
|
+
className: [
|
|
294
|
+
x,
|
|
295
|
+
b ? `${x}-active` : "",
|
|
296
|
+
o || ""
|
|
297
|
+
].join(" "),
|
|
298
|
+
css: v(c),
|
|
299
|
+
"data-testid": x,
|
|
300
|
+
children: [/* @__PURE__ */ n("label", {
|
|
301
|
+
className: `${x}-container`,
|
|
302
|
+
children: [/* @__PURE__ */ n("div", {
|
|
303
|
+
className: `${x}-checkbox`,
|
|
304
|
+
children: [/* @__PURE__ */ t("input", {
|
|
305
|
+
className: [
|
|
306
|
+
`${x}-inputField`,
|
|
307
|
+
b ? `${x}-active` : "",
|
|
308
|
+
a && p && `${x}-error`
|
|
309
|
+
].join(" "),
|
|
310
|
+
type: "checkbox",
|
|
311
|
+
checked: d,
|
|
312
|
+
disabled: l,
|
|
313
|
+
onChange: (e) => f(e.target.checked),
|
|
314
|
+
onKeyDown: (e) => {
|
|
315
|
+
(e.key === "Enter" || e.key === "Space") && S(!0), m?.(e);
|
|
316
|
+
},
|
|
317
|
+
onKeyUp: (e) => {
|
|
318
|
+
(e.key === "Enter" || e.key === "Space") && (S(!1), f(!d)), h?.(e);
|
|
319
|
+
},
|
|
320
|
+
onBlur: () => {
|
|
321
|
+
S(!1), g?.({});
|
|
322
|
+
},
|
|
323
|
+
ref: y,
|
|
324
|
+
"data-testid": `${x}-inputField`,
|
|
325
|
+
..._
|
|
326
|
+
}), /* @__PURE__ */ t("span", {
|
|
327
|
+
className: `${x}-span`,
|
|
328
|
+
"data-testid": `${x}-icon`,
|
|
329
|
+
children: r
|
|
330
|
+
})]
|
|
331
|
+
}), /* @__PURE__ */ t("span", {
|
|
332
|
+
className: `${x}-label`,
|
|
333
|
+
"data-testid": `${x}-label`,
|
|
334
|
+
children: e
|
|
335
|
+
})]
|
|
336
|
+
}), (i || a) && /* @__PURE__ */ n("span", {
|
|
337
|
+
className: `${x}-helperText`,
|
|
338
|
+
"data-testid": `${x}-helperText`,
|
|
339
|
+
children: [i && (!p || !a) && i, a && p && p.message]
|
|
340
|
+
})]
|
|
341
|
+
});
|
|
342
|
+
});
|
|
343
|
+
S.displayName = "CheckboxBase";
|
|
344
|
+
var C = ({ name: e, control: n, ...r }) => {
|
|
345
|
+
let { field: i, fieldState: a } = l({
|
|
346
|
+
control: n,
|
|
347
|
+
name: e
|
|
348
|
+
}), [o, c] = s(i.value || !1), u = a.error, d = (e) => {
|
|
349
|
+
i.onChange(e), c(e), u && i.onBlur();
|
|
350
|
+
};
|
|
351
|
+
return /* @__PURE__ */ t(S, {
|
|
352
|
+
...r,
|
|
353
|
+
name: e,
|
|
354
|
+
checked: o,
|
|
355
|
+
onChecked: d,
|
|
356
|
+
onBlur: () => i.onBlur(),
|
|
357
|
+
error: u
|
|
358
|
+
});
|
|
359
|
+
}, w = (e) => {
|
|
360
|
+
let n = o(y), r = o(b), i = n ?? r;
|
|
361
|
+
if (typeof e.checked == "boolean" && !e.control) {
|
|
362
|
+
let { checked: n, onChecked: r, name: i, control: a, ...o } = e;
|
|
363
|
+
return /* @__PURE__ */ t(S, {
|
|
364
|
+
...o,
|
|
365
|
+
name: i,
|
|
366
|
+
checked: n,
|
|
367
|
+
onChecked: r ?? (() => {})
|
|
368
|
+
});
|
|
369
|
+
}
|
|
370
|
+
if (i) {
|
|
371
|
+
let { value: n, name: r, control: a, ...o } = e, s = n ?? r ?? "", c = i.checkedValues.includes(s);
|
|
372
|
+
return /* @__PURE__ */ t(S, {
|
|
373
|
+
...o,
|
|
374
|
+
name: r,
|
|
375
|
+
value: s,
|
|
376
|
+
checked: c,
|
|
377
|
+
onChecked: (e) => i.onChange(s, e),
|
|
378
|
+
disabled: o.disabled ?? i.disabled,
|
|
379
|
+
error: i.error,
|
|
380
|
+
showErrorText: !1,
|
|
381
|
+
helperText: void 0
|
|
382
|
+
});
|
|
383
|
+
}
|
|
384
|
+
return /* @__PURE__ */ t(C, { ...e });
|
|
385
|
+
}, T = ({ theme: n, ...r }) => {
|
|
386
|
+
let { componentStyles: i } = e([d.CHECKBOX], n);
|
|
387
|
+
return /* @__PURE__ */ t(w, {
|
|
388
|
+
...r,
|
|
389
|
+
style: i
|
|
390
|
+
});
|
|
391
|
+
}, E = a(null);
|
|
392
|
+
//#endregion
|
|
393
|
+
export { d as a, y as i, T as n, b as r, E as t };
|
|
394
|
+
|
|
395
|
+
//# sourceMappingURL=RadioGroup.context-zJGC5Sjc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RadioGroup.context-zJGC5Sjc.js","names":[],"sources":["../src/hocs/ThemeProvider/interfaces/Components.interface.ts","../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":["export enum Component {\n // atoms\n BUTTON = 'BUTTON',\n ICONBUTTON = 'ICONBUTTON',\n INPUT = 'INPUT',\n CHECKBOX = 'CHECKBOX',\n SELECT = 'SELECT',\n SELECTMENU = 'SELECTMENU',\n SWITCH = 'SWITCH',\n SLIDER = 'SLIDER',\n DATEPICKER = 'DATEPICKER',\n DATEPICKERMENU = 'DATEPICKERMENU',\n\n // molecules\n CHECKBOXGROUP = 'CHECKBOXGROUP',\n CHECKBOXTREE = 'CHECKBOXTREE',\n RADIOGROUP = 'RADIOGROUP',\n\n // atoms\n RADIO = 'RADIO',\n}\n","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 > svg > path {\n ${getStyle(theme, 'fill', `--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 > svg {\n visibility: hidden;\n }\n &:checked ~ .--CHECKBOX-span > svg,\n &:indeterminate ~ .--CHECKBOX-span > svg {\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 > svg {\n width: 100%;\n height: auto;\n z-index: 1;\n }\n\n &:before {\n content: '';\n position: absolute;\n width: 36px;\n height: 36px;\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 CheckOutlinedIcon from '@mui/icons-material/CheckOutlined';\n\nconst CLASS = '--CHECKBOX';\n\n/** @internal Headless presentational layer shared by all checkbox variants. */\nexport const CheckboxBase = React.forwardRef<HTMLInputElement, CheckboxBaseProps>(\n (\n {\n label,\n icon = <CheckOutlinedIcon />,\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 ...rest\n}: CheckboxStyleProps<TFieldValues>) => {\n const { componentStyles } = useCreateComponentStyles([Component.CHECKBOX], theme);\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}\n\nexport const RadioGroupContext = createContext<RadioGroupContextValue | null>(null);\n"],"mappings":"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"}
|