@owp/core 2.5.20 → 2.5.22
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/dayjs.d.ts +4 -0
- package/dayjs.js +2 -0
- package/dist/_virtual/isBetween.js +8 -0
- package/dist/_virtual/isBetween.js.map +1 -0
- package/dist/_virtual/isBetween2.js +5 -0
- package/dist/_virtual/isBetween2.js.map +1 -0
- package/dist/components/OwpCommonCode/OwpCommonCodeQuerySelector.js +26 -26
- package/dist/components/OwpCommonCode/OwpCommonCodeQuerySelector.js.map +1 -1
- package/dist/components/OwpCommonCode/OwpCommonCodeSelector.js +29 -29
- package/dist/components/OwpCommonCode/OwpCommonCodeSelector.js.map +1 -1
- package/dist/components/OwpMrtTable/OwpMrtTable.js +144 -141
- package/dist/components/OwpMrtTable/OwpMrtTable.js.map +1 -1
- package/dist/components/OwpOptionSelector/OwpOptionSelector.js +20 -20
- package/dist/components/OwpOptionSelector/OwpOptionSelector.js.map +1 -1
- package/dist/components/OwpPageContent/OwpPageContent.js +20 -19
- package/dist/components/OwpPageContent/OwpPageContent.js.map +1 -1
- package/dist/components/OwpPicker/OwpDatePicker.js +216 -235
- package/dist/components/OwpPicker/OwpDatePicker.js.map +1 -1
- package/dist/components/OwpPicker/OwpDateRangePicker.js +21 -21
- package/dist/components/OwpPicker/OwpDateRangePicker.js.map +1 -1
- package/dist/components/OwpPicker/OwpTimePicker.js +310 -340
- package/dist/components/OwpPicker/OwpTimePicker.js.map +1 -1
- package/dist/components/OwpPicker/OwpWeekDatePicker.js +28 -29
- package/dist/components/OwpPicker/OwpWeekDatePicker.js.map +1 -1
- package/dist/components/OwpPicker/OwpYearRangePicker.js +1 -1
- package/dist/components/OwpPicker/OwpYearRangePicker.js.map +1 -1
- package/dist/components/OwpPicker/constants/index.js +21 -6
- package/dist/components/OwpPicker/constants/index.js.map +1 -1
- package/dist/components/OwpPicker/internal/DatePickerInput.js +5 -5
- package/dist/components/OwpPicker/internal/DatePickerInput.js.map +1 -1
- package/dist/components/OwpPicker/utils/index.js +22 -0
- package/dist/components/OwpPicker/utils/index.js.map +1 -0
- package/dist/components/OwpQuerySelector/OwpQuerySelector.js +218 -205
- package/dist/components/OwpQuerySelector/OwpQuerySelector.js.map +1 -1
- package/dist/components/OwpSection/OwpSection.js +118 -111
- package/dist/components/OwpSection/OwpSection.js.map +1 -1
- package/dist/components/OwpSelectorBase/OwpSelectorAutocomplete.js +59 -59
- package/dist/components/OwpSelectorBase/OwpSelectorAutocomplete.js.map +1 -1
- package/dist/components/OwpSelectorBase/OwpSelectorSelect.js +88 -85
- package/dist/components/OwpSelectorBase/OwpSelectorSelect.js.map +1 -1
- package/dist/components/OwpSelectorBase/hooks/useOwpSelectorBase.js +93 -93
- package/dist/components/OwpSelectorBase/hooks/useOwpSelectorBase.js.map +1 -1
- package/dist/components/OwpTable/OwpDataTable.js +329 -317
- package/dist/components/OwpTable/OwpDataTable.js.map +1 -1
- package/dist/components/OwpTable/OwpFieldTable.js +77 -74
- package/dist/components/OwpTable/OwpFieldTable.js.map +1 -1
- package/dist/components/OwpTable/OwpTable.js +66 -219
- package/dist/components/OwpTable/OwpTable.js.map +1 -1
- package/dist/components/OwpTable/internal/OwpTableBase.js +195 -0
- package/dist/components/OwpTable/internal/OwpTableBase.js.map +1 -0
- package/dist/components/OwpTable/internal/OwpTableTotalCount.js +23 -0
- package/dist/components/OwpTable/internal/OwpTableTotalCount.js.map +1 -0
- package/dist/components/OwpTable/internal/defaultTableStyle.js +10 -10
- package/dist/components/OwpTable/internal/defaultTableStyle.js.map +1 -1
- package/dist/components/OwpTable/utils/tableSx.js +9 -0
- package/dist/components/OwpTable/utils/tableSx.js.map +1 -0
- package/dist/components/OwpTextField/OwpTextMaskField.js +95 -86
- package/dist/components/OwpTextField/OwpTextMaskField.js.map +1 -1
- package/dist/components/OwpTreeGrid/OwpTreeGrid.js +1 -1
- package/dist/components/OwpTreeGrid/OwpTreeGrid.js.map +1 -1
- package/dist/components/OwpTreeGrid/internal/hooks/useOwpTreeGridDatePickerEditor.js +164 -179
- package/dist/components/OwpTreeGrid/internal/hooks/useOwpTreeGridDatePickerEditor.js.map +1 -1
- package/dist/components/OwpTreeGrid/internal/treeGridTheme.js +10 -10
- package/dist/components/OwpTreeGrid/internal/treeGridTheme.js.map +1 -1
- package/dist/components/OwpYesNoSelector/OwpYesNoSelector.js.map +1 -1
- package/dist/dayjs.js +18 -0
- package/dist/dayjs.js.map +1 -0
- package/dist/features/themePreview/components/ThemePreviewCanvas.js +22 -22
- package/dist/features/themePreview/components/ThemePreviewCanvas.js.map +1 -1
- package/dist/features/themePreview/configs/table.js +4 -4
- package/dist/features/themePreview/configs/table.js.map +1 -1
- package/dist/features/themePreview/hooks/useThemePreview.js +16 -16
- package/dist/features/themePreview/hooks/useThemePreview.js.map +1 -1
- package/dist/hooks/{useInitCommonCodes.js → internal/useInitCommonCodes.js} +6 -6
- package/dist/hooks/internal/useInitCommonCodes.js.map +1 -0
- package/dist/hooks/internal/useMinimumVisibleState.js +31 -0
- package/dist/hooks/internal/useMinimumVisibleState.js.map +1 -0
- package/dist/hooks/useInitApp.js +17 -14
- package/dist/hooks/useInitApp.js.map +1 -1
- package/dist/hooks.js +49 -51
- package/dist/hooks.js.map +1 -1
- package/dist/index.js +91 -94
- package/dist/node_modules/.pnpm/dayjs@1.11.18/node_modules/dayjs/plugin/isBetween.js +23 -0
- package/dist/node_modules/.pnpm/dayjs@1.11.18/node_modules/dayjs/plugin/isBetween.js.map +1 -0
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/CODE93/constants.js +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/EAN_UPC/constants.js +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/ITF/constants.js +1 -1
- package/dist/types/components/OwpCommonCode/OwpCommonCodeQuerySelector.d.ts +3 -3
- package/dist/types/components/OwpCommonCode/OwpCommonCodeSelector.d.ts +3 -3
- package/dist/types/components/OwpMrtTable/OwpMrtTable.d.ts +1 -0
- package/dist/types/components/OwpOptionSelector/OwpOptionSelector.d.ts +2 -2
- package/dist/types/components/OwpPicker/OwpDatePicker.d.ts +1 -1
- package/dist/types/components/OwpPicker/OwpTimePicker.d.ts +2 -2
- package/dist/types/components/OwpPicker/constants/index.d.ts +15 -0
- package/dist/types/components/OwpPicker/utils/index.d.ts +6 -0
- package/dist/types/components/OwpQuerySelector/OwpQuerySelector.d.ts +1 -1
- package/dist/types/components/OwpQuerySelector/types/types.d.ts +1 -0
- package/dist/types/components/OwpSection/OwpSection.d.ts +9 -3
- package/dist/types/components/OwpSelectorBase/hooks/useOwpSelectorBase.d.ts +1 -1
- package/dist/types/components/OwpSelectorBase/types/types.d.ts +1 -1
- package/dist/types/components/OwpTable/OwpDataTable.d.ts +5 -1
- package/dist/types/components/OwpTable/OwpFieldTable.d.ts +7 -1
- package/dist/types/components/OwpTable/OwpTable.d.ts +6 -38
- package/dist/types/components/OwpTable/internal/OwpTableBase.d.ts +34 -0
- package/dist/types/components/OwpTable/internal/OwpTableTotalCount.d.ts +9 -0
- package/dist/types/components/OwpTable/internal/defaultTableStyle.d.ts +4 -2
- package/dist/types/components/OwpTable/utils/tableSx.d.ts +11 -0
- package/dist/types/components/OwpTextField/OwpTextMaskField.d.ts +3 -3
- package/dist/types/components/OwpYesNoSelector/OwpYesNoSelector.d.ts +1 -1
- package/dist/types/dayjs.d.ts +18 -0
- package/dist/types/hooks/index.d.ts +0 -1
- package/dist/types/hooks/internal/useMinimumVisibleState.d.ts +7 -0
- package/dist/types/utils/dayjsBrowser.d.ts +1 -7
- package/dist/types/utils/formatDateToYmd.d.ts +1 -1
- package/dist/utils/formatDateToYmd.js +3 -3
- package/dist/utils/formatDateToYmd.js.map +1 -1
- package/dist/utils/treeGridExportExcelUtil.js +1 -1
- package/dist/utils/treeGridExportExcelUtil.js.map +1 -1
- package/dist/utils/zipUtil.js +3 -3
- package/dist/utils/zipUtil.js.map +1 -1
- package/package.json +3 -1
- package/dist/hooks/useInitCommonCodes.js.map +0 -1
- package/dist/utils/dayjsBrowser.js +0 -16
- package/dist/utils/dayjsBrowser.js.map +0 -1
- /package/dist/types/hooks/{useInitCommonCodes.d.ts → internal/useInitCommonCodes.d.ts} +0 -0
|
@@ -1,88 +1,90 @@
|
|
|
1
|
-
var
|
|
2
|
-
var n = (a,
|
|
1
|
+
var Z = Object.defineProperty;
|
|
2
|
+
var n = (a, g) => Z(a, "name", { value: g, configurable: !0 });
|
|
3
3
|
import { jsxs as s, jsx as l } from "../../node_modules/.pnpm/@emotion_react@11.14.0_@types_react@19.2.14_react@19.2.4/node_modules/@emotion/react/jsx-runtime/dist/emotion-react-jsx-runtime.browser.esm.js";
|
|
4
|
-
import { useOwpTranslation as
|
|
5
|
-
import { InputLabel as
|
|
6
|
-
import { alpha as
|
|
7
|
-
import { clsx as
|
|
8
|
-
import { useId as
|
|
9
|
-
import { getSelectorAllToken as
|
|
10
|
-
const
|
|
11
|
-
const { t:
|
|
12
|
-
className:
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
helperText: h,
|
|
4
|
+
import { useOwpTranslation as P } from "../../hooks/useOwpTranslation.js";
|
|
5
|
+
import { InputLabel as j, Select as M, MenuItem as u, FormHelperText as N, FormControl as B, Checkbox as H, ListItemText as y, Box as L, Tooltip as ee } from "@mui/material";
|
|
6
|
+
import { alpha as W } from "@mui/material/styles";
|
|
7
|
+
import { clsx as z } from "../../node_modules/.pnpm/clsx@2.1.1/node_modules/clsx/dist/clsx.js";
|
|
8
|
+
import { useId as le, useMemo as _ } from "react";
|
|
9
|
+
import { getSelectorAllToken as F } from "./utils/querySelectorUtils.js";
|
|
10
|
+
const R = { marginLeft: "11px" }, X = /* @__PURE__ */ n((a) => typeof a == "string" || typeof a == "number" ? `${a}` : "", "getSelectorLabelText"), ue = /* @__PURE__ */ n(({ hookResult: a, props: g }) => {
|
|
11
|
+
const { t: h } = P(), {
|
|
12
|
+
className: S,
|
|
13
|
+
disabled: T,
|
|
14
|
+
error: w,
|
|
15
|
+
fullWidth: C,
|
|
16
|
+
helperText: b,
|
|
18
17
|
label: o,
|
|
19
|
-
loading:
|
|
20
|
-
multiple:
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
18
|
+
loading: O,
|
|
19
|
+
multiple: q,
|
|
20
|
+
noOptionsText: D,
|
|
21
|
+
required: k,
|
|
22
|
+
selectProps: r,
|
|
23
|
+
showAllOption: v = !0
|
|
24
|
+
} = g, {
|
|
25
|
+
clearSelection: G,
|
|
26
|
+
isAllSelected: x,
|
|
27
|
+
resolvedOptions: d,
|
|
28
|
+
selectAll: J,
|
|
29
|
+
selectedValueList: m,
|
|
30
|
+
selectMultipleValues: K,
|
|
31
|
+
selectSingleValue: A
|
|
32
|
+
} = a, f = `owp-selector-base-label-${le()}`, Q = d.length > 0, I = !O && !v && !Q, E = D ?? h("Message.조회된 결과가 없습니다."), V = _(
|
|
33
|
+
() => d.filter((e) => m.includes(e.value)).map((e) => e.label),
|
|
34
|
+
[d, m]
|
|
35
|
+
), $ = _(
|
|
36
|
+
() => V.map((e) => X(e)).filter(Boolean),
|
|
37
|
+
[V]
|
|
37
38
|
).join(", ");
|
|
38
|
-
if (!
|
|
39
|
+
if (!q)
|
|
39
40
|
return /* @__PURE__ */ s(
|
|
40
|
-
|
|
41
|
+
B,
|
|
41
42
|
{
|
|
42
|
-
className:
|
|
43
|
-
disabled:
|
|
44
|
-
error:
|
|
45
|
-
fullWidth:
|
|
46
|
-
required:
|
|
43
|
+
className: z("min-w-128", S),
|
|
44
|
+
disabled: T,
|
|
45
|
+
error: w,
|
|
46
|
+
fullWidth: C,
|
|
47
|
+
required: k,
|
|
47
48
|
variant: (r == null ? void 0 : r.variant) ?? "standard",
|
|
48
49
|
children: [
|
|
49
|
-
o ? /* @__PURE__ */ l(
|
|
50
|
+
o ? /* @__PURE__ */ l(j, { shrink: !0, id: f, children: o }) : null,
|
|
50
51
|
/* @__PURE__ */ s(
|
|
51
|
-
|
|
52
|
+
M,
|
|
52
53
|
{
|
|
53
54
|
displayEmpty: !0,
|
|
54
55
|
...r,
|
|
55
|
-
labelId: o ?
|
|
56
|
-
value:
|
|
56
|
+
labelId: o ? f : void 0,
|
|
57
|
+
value: m[0] ?? "",
|
|
57
58
|
onChange: /* @__PURE__ */ n((e) => {
|
|
58
|
-
const
|
|
59
|
-
if (
|
|
60
|
-
|
|
59
|
+
const p = String(e.target.value ?? "");
|
|
60
|
+
if (v && p === "") {
|
|
61
|
+
A("");
|
|
61
62
|
return;
|
|
62
63
|
}
|
|
63
|
-
|
|
64
|
+
A(p);
|
|
64
65
|
}, "onChange"),
|
|
65
66
|
children: [
|
|
66
|
-
|
|
67
|
-
|
|
67
|
+
v ? /* @__PURE__ */ l(u, { value: "", children: h("Common.전체") }) : null,
|
|
68
|
+
I ? /* @__PURE__ */ l(u, { disabled: !0, value: "", children: E }) : null,
|
|
69
|
+
d.map((e) => /* @__PURE__ */ l(u, { disabled: e.disabled, value: e.value, children: e.label }, `owp-selector-base-item-${e.value}`))
|
|
68
70
|
]
|
|
69
71
|
}
|
|
70
72
|
),
|
|
71
|
-
|
|
73
|
+
b ? /* @__PURE__ */ l(N, { sx: R, children: b }) : null
|
|
72
74
|
]
|
|
73
75
|
}
|
|
74
76
|
);
|
|
75
|
-
const
|
|
76
|
-
const
|
|
77
|
-
return /* @__PURE__ */ l(
|
|
78
|
-
/* @__PURE__ */ l(
|
|
77
|
+
const U = /* @__PURE__ */ n((e) => {
|
|
78
|
+
const p = Array.isArray(e) ? e.map((t) => String(t)) : [], c = d.filter((t) => p.includes(t.value)).map((t) => X(t.label)).filter(Boolean), i = x ? 0 : Math.max(c.length - 2, 0), Y = x ? h("Common.전체") : i > 0 ? `${c.slice(0, 2).join(", ")}...` : c.join(", ");
|
|
79
|
+
return /* @__PURE__ */ l(ee, { title: $, placement: "top", disableHoverListener: !$, children: /* @__PURE__ */ s(L, { component: "span", sx: { alignItems: "center", display: "inline-flex", maxWidth: "100%" }, children: [
|
|
80
|
+
/* @__PURE__ */ l(L, { component: "span", sx: { minWidth: 0, overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" }, children: Y }),
|
|
79
81
|
i > 0 ? /* @__PURE__ */ l(
|
|
80
|
-
|
|
82
|
+
L,
|
|
81
83
|
{
|
|
82
84
|
component: "span",
|
|
83
85
|
sx: /* @__PURE__ */ n((t) => ({
|
|
84
|
-
backgroundColor:
|
|
85
|
-
border: `1px solid ${
|
|
86
|
+
backgroundColor: W(t.palette.primary.main, 0.14),
|
|
87
|
+
border: `1px solid ${W(t.palette.primary.main, 0.22)}`,
|
|
86
88
|
borderRadius: 1,
|
|
87
89
|
color: t.palette.primary.dark,
|
|
88
90
|
fontSize: 12,
|
|
@@ -98,55 +100,56 @@ const N = { marginLeft: "11px" }, _ = /* @__PURE__ */ n((a) => typeof a == "stri
|
|
|
98
100
|
] }) });
|
|
99
101
|
}, "renderValue");
|
|
100
102
|
return /* @__PURE__ */ s(
|
|
101
|
-
|
|
103
|
+
B,
|
|
102
104
|
{
|
|
103
|
-
className:
|
|
104
|
-
disabled:
|
|
105
|
-
error:
|
|
106
|
-
fullWidth:
|
|
107
|
-
required:
|
|
105
|
+
className: z("w-128", S),
|
|
106
|
+
disabled: T,
|
|
107
|
+
error: w,
|
|
108
|
+
fullWidth: C,
|
|
109
|
+
required: k,
|
|
108
110
|
variant: (r == null ? void 0 : r.variant) ?? "standard",
|
|
109
111
|
children: [
|
|
110
|
-
o ? /* @__PURE__ */ l(
|
|
112
|
+
o ? /* @__PURE__ */ l(j, { shrink: !0, id: f, children: o }) : null,
|
|
111
113
|
/* @__PURE__ */ s(
|
|
112
|
-
|
|
114
|
+
M,
|
|
113
115
|
{
|
|
114
116
|
displayEmpty: !0,
|
|
115
117
|
...r,
|
|
116
|
-
labelId: o ?
|
|
118
|
+
labelId: o ? f : void 0,
|
|
117
119
|
multiple: !0,
|
|
118
|
-
renderValue:
|
|
119
|
-
value:
|
|
120
|
-
onChange: /* @__PURE__ */ n((e,
|
|
120
|
+
renderValue: U,
|
|
121
|
+
value: m,
|
|
122
|
+
onChange: /* @__PURE__ */ n((e, p) => {
|
|
121
123
|
const c = Array.isArray(e.target.value) ? e.target.value.map((i) => String(i)) : String(e.target.value ?? "").split(",").map((i) => i.trim()).filter(Boolean);
|
|
122
|
-
if (c.includes(
|
|
123
|
-
if (
|
|
124
|
-
|
|
124
|
+
if (c.includes(F())) {
|
|
125
|
+
if (x) {
|
|
126
|
+
G();
|
|
125
127
|
return;
|
|
126
128
|
}
|
|
127
|
-
|
|
129
|
+
J();
|
|
128
130
|
return;
|
|
129
131
|
}
|
|
130
|
-
|
|
132
|
+
K(c);
|
|
131
133
|
}, "onChange"),
|
|
132
134
|
children: [
|
|
133
|
-
|
|
134
|
-
/* @__PURE__ */ l(
|
|
135
|
-
/* @__PURE__ */ l(
|
|
136
|
-
] }),
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
/* @__PURE__ */ l(H, {
|
|
135
|
+
v ? /* @__PURE__ */ s(u, { value: F(), children: [
|
|
136
|
+
/* @__PURE__ */ l(H, { checked: x, size: "small" }),
|
|
137
|
+
/* @__PURE__ */ l(y, { primary: h("Common.전체") })
|
|
138
|
+
] }) : null,
|
|
139
|
+
I ? /* @__PURE__ */ l(u, { disabled: !0, value: "", children: /* @__PURE__ */ l(y, { primary: E }) }) : null,
|
|
140
|
+
d.map((e) => /* @__PURE__ */ s(u, { disabled: e.disabled || O, value: e.value, children: [
|
|
141
|
+
/* @__PURE__ */ l(H, { checked: m.includes(e.value), size: "small" }),
|
|
142
|
+
/* @__PURE__ */ l(y, { primary: e.label })
|
|
140
143
|
] }, `owp-selector-base-item-${e.value}`))
|
|
141
144
|
]
|
|
142
145
|
}
|
|
143
146
|
),
|
|
144
|
-
|
|
147
|
+
b ? /* @__PURE__ */ l(N, { sx: R, children: b }) : null
|
|
145
148
|
]
|
|
146
149
|
}
|
|
147
150
|
);
|
|
148
151
|
}, "OwpSelectorSelect");
|
|
149
152
|
export {
|
|
150
|
-
|
|
153
|
+
ue as OwpSelectorSelect
|
|
151
154
|
};
|
|
152
155
|
//# sourceMappingURL=OwpSelectorSelect.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OwpSelectorSelect.js","sources":["../../../src/components/OwpSelectorBase/OwpSelectorSelect.tsx"],"sourcesContent":["import { useOwpTranslation } from '@/hooks/useOwpTranslation';\nimport {\n Box,\n Checkbox,\n FormControl,\n FormHelperText,\n InputLabel,\n ListItemText,\n MenuItem,\n Select,\n Tooltip,\n type SelectChangeEvent,\n type SelectProps,\n} from '@mui/material';\nimport { alpha } from '@mui/material/styles';\nimport clsx from 'clsx';\nimport { type ReactNode, useId, useMemo } from 'react';\nimport type { OwpSelectorBaseHookResult, OwpSelectorBaseProps } from './types';\nimport { getSelectorAllToken } from './utils';\n\ninterface OwpSelectorSelectProps {\n hookResult: OwpSelectorBaseHookResult;\n props: OwpSelectorBaseProps;\n}\n\nconst SELECT_HELPER_TEXT_SX = { marginLeft: '11px' } as const;\n\n/**\n * 선택 라벨 문자열 변환\n * @param label 선택 라벨\n */\nconst getSelectorLabelText = (label: ReactNode) => {\n return typeof label === 'string' || typeof label === 'number' ? `${label}` : '';\n};\n\n/**\n * Select 기반 공통 선택기\n * @param props Select 렌더링 props\n */\nexport const OwpSelectorSelect = ({ hookResult, props }: OwpSelectorSelectProps) => {\n const { t } = useOwpTranslation();\n const {\n className,\n disableAllValueItem,\n disabled,\n error,\n fullWidth,\n helperText,\n label,\n loading,\n multiple,\n required,\n selectProps,\n } = props;\n const {\n clearSelection,\n isAllSelected,\n resolvedOptions,\n selectAll,\n selectedValueList,\n selectMultipleValues,\n selectSingleValue,\n } = hookResult;\n const labelId = `owp-selector-base-label-${useId()}`;\n const selectedLabelList = useMemo(\n () => resolvedOptions.filter((option) => selectedValueList.includes(option.value)).map((option) => option.label),\n [resolvedOptions, selectedValueList],\n );\n const selectedLabelTextList = useMemo(\n () => selectedLabelList.map((label) => getSelectorLabelText(label)).filter(Boolean),\n [selectedLabelList],\n );\n const selectedTitle = selectedLabelTextList.join(', ');\n\n if (!multiple) {\n return (\n <FormControl\n className={clsx('min-w-128', className)}\n disabled={disabled}\n error={error}\n fullWidth={fullWidth}\n required={required}\n variant={selectProps?.variant ?? 'standard'}\n >\n {label ? (\n <InputLabel shrink id={labelId}>\n {label}\n </InputLabel>\n ) : null}\n <Select\n displayEmpty\n {...(selectProps as SelectProps<unknown>)}\n labelId={label ? labelId : undefined}\n value={(disableAllValueItem ? selectedValueList[0] ?? '' : selectedValueList[0] ?? '') as SelectProps<unknown>['value']}\n onChange={(event) => {\n const nextValue = String(event.target.value ?? '');\n\n if (!disableAllValueItem && nextValue === '') {\n selectSingleValue('');\n return;\n }\n\n selectSingleValue(nextValue);\n }}\n >\n {!disableAllValueItem ? <MenuItem value=\"\">{t('Common.전체')}</MenuItem> : null}\n {resolvedOptions.map((option) => (\n <MenuItem key={`owp-selector-base-item-${option.value}`} disabled={option.disabled} value={option.value}>\n {option.label}\n </MenuItem>\n ))}\n </Select>\n {helperText ? <FormHelperText sx={SELECT_HELPER_TEXT_SX}>{helperText}</FormHelperText> : null}\n </FormControl>\n );\n }\n\n const renderValue = (selected: unknown) => {\n const selectedValues = Array.isArray(selected) ? selected.map((item) => String(item)) : [];\n const visibleLabelTextList = resolvedOptions\n .filter((option) => selectedValues.includes(option.value))\n .map((option) => getSelectorLabelText(option.label))\n .filter(Boolean);\n const hiddenLabelCount = isAllSelected ? 0 : Math.max(visibleLabelTextList.length - 2, 0);\n const displayText = isAllSelected\n ? t('Common.전체')\n : hiddenLabelCount > 0\n ? `${visibleLabelTextList.slice(0, 2).join(', ')}...`\n : visibleLabelTextList.join(', ');\n\n return (\n <Tooltip title={selectedTitle} placement=\"top\" disableHoverListener={!selectedTitle}>\n <Box component=\"span\" sx={{ alignItems: 'center', display: 'inline-flex', maxWidth: '100%' }}>\n <Box component=\"span\" sx={{ minWidth: 0, overflow: 'hidden', textOverflow: 'ellipsis', whiteSpace: 'nowrap' }}>\n {displayText}\n </Box>\n {hiddenLabelCount > 0 ? (\n <Box\n component=\"span\"\n sx={(theme) => ({\n backgroundColor: alpha(theme.palette.primary.main, 0.14),\n border: `1px solid ${alpha(theme.palette.primary.main, 0.22)}`,\n borderRadius: 1,\n color: theme.palette.primary.dark,\n fontSize: 12,\n fontWeight: 600,\n lineHeight: 1.4,\n ml: 0.5,\n px: 0.75,\n py: 0.125,\n })}\n >\n {`+${hiddenLabelCount}`}\n </Box>\n ) : null}\n </Box>\n </Tooltip>\n );\n };\n\n return (\n <FormControl\n className={clsx('w-128', className)}\n disabled={disabled}\n error={error}\n fullWidth={fullWidth}\n required={required}\n variant={selectProps?.variant ?? 'standard'}\n >\n {label ? (\n <InputLabel shrink id={labelId}>\n {label}\n </InputLabel>\n ) : null}\n <Select\n displayEmpty\n {...(selectProps as SelectProps<unknown>)}\n labelId={label ? labelId : undefined}\n multiple\n renderValue={renderValue}\n value={selectedValueList as SelectProps<unknown>['value']}\n onChange={(event: SelectChangeEvent<unknown>, child: ReactNode) => {\n const selectedValues = Array.isArray(event.target.value)\n ? event.target.value.map((item) => String(item))\n : String(event.target.value ?? '')\n .split(',')\n .map((item) => item.trim())\n .filter(Boolean);\n\n if (selectedValues.includes(getSelectorAllToken())) {\n if (isAllSelected) {\n clearSelection();\n return;\n }\n\n selectAll();\n return;\n }\n\n selectMultipleValues(selectedValues);\n void child;\n }}\n >\n {!disableAllValueItem ? (\n <MenuItem value={getSelectorAllToken()}>\n <Checkbox checked={isAllSelected} size=\"small\" />\n <ListItemText primary={t('Common.전체')} />\n </MenuItem>\n ) : null}\n {resolvedOptions.map((option) => (\n <MenuItem key={`owp-selector-base-item-${option.value}`} disabled={option.disabled || loading} value={option.value}>\n <Checkbox checked={selectedValueList.includes(option.value)} size=\"small\" />\n <ListItemText primary={option.label} />\n </MenuItem>\n ))}\n </Select>\n {helperText ? <FormHelperText sx={SELECT_HELPER_TEXT_SX}>{helperText}</FormHelperText> : null}\n </FormControl>\n );\n};\n"],"names":["SELECT_HELPER_TEXT_SX","getSelectorLabelText","__name","label","OwpSelectorSelect","hookResult","props","t","useOwpTranslation","className","disableAllValueItem","disabled","error","fullWidth","helperText","loading","multiple","required","selectProps","clearSelection","isAllSelected","resolvedOptions","selectAll","selectedValueList","selectMultipleValues","selectSingleValue","labelId","useId","selectedLabelList","useMemo","option","selectedTitle","jsxs","FormControl","clsx","InputLabel","Select","event","nextValue","MenuItem","jsx","FormHelperText","renderValue","selected","selectedValues","item","visibleLabelTextList","hiddenLabelCount","displayText","Tooltip","Box","theme","alpha","child","getSelectorAllToken","Checkbox","ListItemText"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"OwpSelectorSelect.js","sources":["../../../src/components/OwpSelectorBase/OwpSelectorSelect.tsx"],"sourcesContent":["import { useOwpTranslation } from '@/hooks/useOwpTranslation';\nimport {\n Box,\n Checkbox,\n FormControl,\n FormHelperText,\n InputLabel,\n ListItemText,\n MenuItem,\n Select,\n Tooltip,\n type SelectChangeEvent,\n type SelectProps,\n} from '@mui/material';\nimport { alpha } from '@mui/material/styles';\nimport clsx from 'clsx';\nimport { type ReactNode, useId, useMemo } from 'react';\nimport type { OwpSelectorBaseHookResult, OwpSelectorBaseProps } from './types';\nimport { getSelectorAllToken } from './utils';\n\ninterface OwpSelectorSelectProps {\n hookResult: OwpSelectorBaseHookResult;\n props: OwpSelectorBaseProps;\n}\n\nconst SELECT_HELPER_TEXT_SX = { marginLeft: '11px' } as const;\n\n/**\n * 선택 라벨 문자열 변환\n * @param label 선택 라벨\n */\nconst getSelectorLabelText = (label: ReactNode) => {\n return typeof label === 'string' || typeof label === 'number' ? `${label}` : '';\n};\n\n/**\n * Select 기반 공통 선택기\n * @param props Select 렌더링 props\n */\nexport const OwpSelectorSelect = ({ hookResult, props }: OwpSelectorSelectProps) => {\n const { t } = useOwpTranslation();\n const {\n className,\n disabled,\n error,\n fullWidth,\n helperText,\n label,\n loading,\n multiple,\n noOptionsText,\n required,\n selectProps,\n showAllOption = true,\n } = props;\n const {\n clearSelection,\n isAllSelected,\n resolvedOptions,\n selectAll,\n selectedValueList,\n selectMultipleValues,\n selectSingleValue,\n } = hookResult;\n const labelId = `owp-selector-base-label-${useId()}`;\n const hasOptions = resolvedOptions.length > 0;\n const shouldShowNoOptions = !loading && !showAllOption && !hasOptions;\n const resolvedNoOptionsText = noOptionsText ?? t('Message.조회된 결과가 없습니다.');\n const selectedLabelList = useMemo(\n () => resolvedOptions.filter((option) => selectedValueList.includes(option.value)).map((option) => option.label),\n [resolvedOptions, selectedValueList],\n );\n const selectedLabelTextList = useMemo(\n () => selectedLabelList.map((label) => getSelectorLabelText(label)).filter(Boolean),\n [selectedLabelList],\n );\n const selectedTitle = selectedLabelTextList.join(', ');\n\n if (!multiple) {\n return (\n <FormControl\n className={clsx('min-w-128', className)}\n disabled={disabled}\n error={error}\n fullWidth={fullWidth}\n required={required}\n variant={selectProps?.variant ?? 'standard'}\n >\n {label ? (\n <InputLabel shrink id={labelId}>\n {label}\n </InputLabel>\n ) : null}\n <Select\n displayEmpty\n {...(selectProps as SelectProps<unknown>)}\n labelId={label ? labelId : undefined}\n value={(selectedValueList[0] ?? '') as SelectProps<unknown>['value']}\n onChange={(event) => {\n const nextValue = String(event.target.value ?? '');\n\n if (showAllOption && nextValue === '') {\n selectSingleValue('');\n return;\n }\n\n selectSingleValue(nextValue);\n }}\n >\n {showAllOption ? <MenuItem value=\"\">{t('Common.전체')}</MenuItem> : null}\n {shouldShowNoOptions ? (\n <MenuItem disabled value=\"\">\n {resolvedNoOptionsText}\n </MenuItem>\n ) : null}\n {resolvedOptions.map((option) => (\n <MenuItem key={`owp-selector-base-item-${option.value}`} disabled={option.disabled} value={option.value}>\n {option.label}\n </MenuItem>\n ))}\n </Select>\n {helperText ? <FormHelperText sx={SELECT_HELPER_TEXT_SX}>{helperText}</FormHelperText> : null}\n </FormControl>\n );\n }\n\n const renderValue = (selected: unknown) => {\n const selectedValues = Array.isArray(selected) ? selected.map((item) => String(item)) : [];\n const visibleLabelTextList = resolvedOptions\n .filter((option) => selectedValues.includes(option.value))\n .map((option) => getSelectorLabelText(option.label))\n .filter(Boolean);\n const hiddenLabelCount = isAllSelected ? 0 : Math.max(visibleLabelTextList.length - 2, 0);\n const displayText = isAllSelected\n ? t('Common.전체')\n : hiddenLabelCount > 0\n ? `${visibleLabelTextList.slice(0, 2).join(', ')}...`\n : visibleLabelTextList.join(', ');\n\n return (\n <Tooltip title={selectedTitle} placement=\"top\" disableHoverListener={!selectedTitle}>\n <Box component=\"span\" sx={{ alignItems: 'center', display: 'inline-flex', maxWidth: '100%' }}>\n <Box component=\"span\" sx={{ minWidth: 0, overflow: 'hidden', textOverflow: 'ellipsis', whiteSpace: 'nowrap' }}>\n {displayText}\n </Box>\n {hiddenLabelCount > 0 ? (\n <Box\n component=\"span\"\n sx={(theme) => ({\n backgroundColor: alpha(theme.palette.primary.main, 0.14),\n border: `1px solid ${alpha(theme.palette.primary.main, 0.22)}`,\n borderRadius: 1,\n color: theme.palette.primary.dark,\n fontSize: 12,\n fontWeight: 600,\n lineHeight: 1.4,\n ml: 0.5,\n px: 0.75,\n py: 0.125,\n })}\n >\n {`+${hiddenLabelCount}`}\n </Box>\n ) : null}\n </Box>\n </Tooltip>\n );\n };\n\n return (\n <FormControl\n className={clsx('w-128', className)}\n disabled={disabled}\n error={error}\n fullWidth={fullWidth}\n required={required}\n variant={selectProps?.variant ?? 'standard'}\n >\n {label ? (\n <InputLabel shrink id={labelId}>\n {label}\n </InputLabel>\n ) : null}\n <Select\n displayEmpty\n {...(selectProps as SelectProps<unknown>)}\n labelId={label ? labelId : undefined}\n multiple\n renderValue={renderValue}\n value={selectedValueList as SelectProps<unknown>['value']}\n onChange={(event: SelectChangeEvent<unknown>, child: ReactNode) => {\n const selectedValues = Array.isArray(event.target.value)\n ? event.target.value.map((item) => String(item))\n : String(event.target.value ?? '')\n .split(',')\n .map((item) => item.trim())\n .filter(Boolean);\n\n if (selectedValues.includes(getSelectorAllToken())) {\n if (isAllSelected) {\n clearSelection();\n return;\n }\n\n selectAll();\n return;\n }\n\n selectMultipleValues(selectedValues);\n void child;\n }}\n >\n {showAllOption ? (\n <MenuItem value={getSelectorAllToken()}>\n <Checkbox checked={isAllSelected} size=\"small\" />\n <ListItemText primary={t('Common.전체')} />\n </MenuItem>\n ) : null}\n {shouldShowNoOptions ? (\n <MenuItem disabled value=\"\">\n <ListItemText primary={resolvedNoOptionsText} />\n </MenuItem>\n ) : null}\n {resolvedOptions.map((option) => (\n <MenuItem key={`owp-selector-base-item-${option.value}`} disabled={option.disabled || loading} value={option.value}>\n <Checkbox checked={selectedValueList.includes(option.value)} size=\"small\" />\n <ListItemText primary={option.label} />\n </MenuItem>\n ))}\n </Select>\n {helperText ? <FormHelperText sx={SELECT_HELPER_TEXT_SX}>{helperText}</FormHelperText> : null}\n </FormControl>\n );\n};\n"],"names":["SELECT_HELPER_TEXT_SX","getSelectorLabelText","__name","label","OwpSelectorSelect","hookResult","props","t","useOwpTranslation","className","disabled","error","fullWidth","helperText","loading","multiple","noOptionsText","required","selectProps","showAllOption","clearSelection","isAllSelected","resolvedOptions","selectAll","selectedValueList","selectMultipleValues","selectSingleValue","labelId","useId","hasOptions","shouldShowNoOptions","resolvedNoOptionsText","selectedLabelList","useMemo","option","selectedTitle","jsxs","FormControl","clsx","InputLabel","Select","event","nextValue","MenuItem","jsx","FormHelperText","renderValue","selected","selectedValues","item","visibleLabelTextList","hiddenLabelCount","displayText","Tooltip","Box","theme","alpha","child","getSelectorAllToken","Checkbox","ListItemText"],"mappings":";;;;;;;;;AAyBA,MAAMA,IAAwB,EAAE,YAAY,OAAA,GAMtCC,IAAuB,gBAAAC,EAAA,CAACC,MACrB,OAAOA,KAAU,YAAY,OAAOA,KAAU,WAAW,GAAGA,CAAK,KAAK,IADlD,yBAQhBC,KAAoB,gBAAAF,EAAA,CAAC,EAAE,YAAAG,GAAY,OAAAC,QAAoC;AAClF,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAA,GACR;AAAA,IACJ,WAAAC;AAAA,IACA,UAAAC;AAAA,IACA,OAAAC;AAAA,IACA,WAAAC;AAAA,IACA,YAAAC;AAAA,IACA,OAAAV;AAAA,IACA,SAAAW;AAAA,IACA,UAAAC;AAAA,IACA,eAAAC;AAAA,IACA,UAAAC;AAAA,IACA,aAAAC;AAAA,IACA,eAAAC,IAAgB;AAAA,EAAA,IACdb,GACE;AAAA,IACJ,gBAAAc;AAAA,IACA,eAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,WAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,sBAAAC;AAAA,IACA,mBAAAC;AAAA,EAAA,IACErB,GACEsB,IAAU,2BAA2BC,GAAA,CAAO,IAC5CC,IAAaP,EAAgB,SAAS,GACtCQ,IAAsB,CAAChB,KAAW,CAACK,KAAiB,CAACU,GACrDE,IAAwBf,KAAiBT,EAAE,uBAAuB,GAClEyB,IAAoBC;AAAA,IACxB,MAAMX,EAAgB,OAAO,CAACY,MAAWV,EAAkB,SAASU,EAAO,KAAK,CAAC,EAAE,IAAI,CAACA,MAAWA,EAAO,KAAK;AAAA,IAC/G,CAACZ,GAAiBE,CAAiB;AAAA,EAAA,GAM/BW,IAJwBF;AAAA,IAC5B,MAAMD,EAAkB,IAAI,CAAC7B,MAAUF,EAAqBE,CAAK,CAAC,EAAE,OAAO,OAAO;AAAA,IAClF,CAAC6B,CAAiB;AAAA,EAAA,EAEwB,KAAK,IAAI;AAErD,MAAI,CAACjB;AACH,WACE,gBAAAqB;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,WAAWC,EAAK,aAAa7B,CAAS;AAAA,QACtC,UAAAC;AAAA,QACA,OAAAC;AAAA,QACA,WAAAC;AAAA,QACA,UAAAK;AAAA,QACA,UAASC,KAAA,gBAAAA,EAAa,YAAW;AAAA,QAEhC,UAAA;AAAA,UAAAf,sBACEoC,GAAA,EAAW,QAAM,IAAC,IAAIZ,GACpB,aACH,IACE;AAAA,UACJ,gBAAAS;AAAA,YAACI;AAAA,YAAA;AAAA,cACC,cAAY;AAAA,cACX,GAAItB;AAAA,cACL,SAASf,IAAQwB,IAAU;AAAA,cAC3B,OAAQH,EAAkB,CAAC,KAAK;AAAA,cAChC,UAAU,gBAAAtB,EAAA,CAACuC,MAAU;AACnB,sBAAMC,IAAY,OAAOD,EAAM,OAAO,SAAS,EAAE;AAEjD,oBAAItB,KAAiBuB,MAAc,IAAI;AACrC,kBAAAhB,EAAkB,EAAE;AACpB;AAAA,gBACF;AAEA,gBAAAA,EAAkBgB,CAAS;AAAA,cAC7B,GATU;AAAA,cAWT,UAAA;AAAA,gBAAAvB,sBAAiBwB,GAAA,EAAS,OAAM,IAAI,UAAApC,EAAE,WAAW,GAAE,IAAc;AAAA,gBACjEuB,sBACEa,GAAA,EAAS,UAAQ,IAAC,OAAM,IACtB,aACH,IACE;AAAA,gBACHrB,EAAgB,IAAI,CAACY,MACpB,gBAAAU,EAACD,GAAA,EAAwD,UAAUT,EAAO,UAAU,OAAOA,EAAO,OAC/F,UAAAA,EAAO,MAAA,GADK,0BAA0BA,EAAO,KAAK,EAErD,CACD;AAAA,cAAA;AAAA,YAAA;AAAA,UAAA;AAAA,UAEFrB,IAAa,gBAAA+B,EAACC,GAAA,EAAe,IAAI7C,GAAwB,aAAW,IAAoB;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAK/F,QAAM8C,IAAc,gBAAA5C,EAAA,CAAC6C,MAAsB;AACzC,UAAMC,IAAiB,MAAM,QAAQD,CAAQ,IAAIA,EAAS,IAAI,CAACE,MAAS,OAAOA,CAAI,CAAC,IAAI,CAAA,GAClFC,IAAuB5B,EAC1B,OAAO,CAACY,MAAWc,EAAe,SAASd,EAAO,KAAK,CAAC,EACxD,IAAI,CAACA,MAAWjC,EAAqBiC,EAAO,KAAK,CAAC,EAClD,OAAO,OAAO,GACXiB,IAAmB9B,IAAgB,IAAI,KAAK,IAAI6B,EAAqB,SAAS,GAAG,CAAC,GAClFE,IAAc/B,IAChBd,EAAE,WAAW,IACb4C,IAAmB,IACjB,GAAGD,EAAqB,MAAM,GAAG,CAAC,EAAE,KAAK,IAAI,CAAC,QAC9CA,EAAqB,KAAK,IAAI;AAEpC,WACE,gBAAAN,EAACS,MAAQ,OAAOlB,GAAe,WAAU,OAAM,sBAAsB,CAACA,GACpE,UAAA,gBAAAC,EAACkB,KAAI,WAAU,QAAO,IAAI,EAAE,YAAY,UAAU,SAAS,eAAe,UAAU,OAAA,GAClF,UAAA;AAAA,MAAA,gBAAAV,EAACU,GAAA,EAAI,WAAU,QAAO,IAAI,EAAE,UAAU,GAAG,UAAU,UAAU,cAAc,YAAY,YAAY,YAChG,UAAAF,GACH;AAAA,MACCD,IAAmB,IAClB,gBAAAP;AAAA,QAACU;AAAA,QAAA;AAAA,UACC,WAAU;AAAA,UACV,IAAI,gBAAApD,EAAA,CAACqD,OAAW;AAAA,YACd,iBAAiBC,EAAMD,EAAM,QAAQ,QAAQ,MAAM,IAAI;AAAA,YACvD,QAAQ,aAAaC,EAAMD,EAAM,QAAQ,QAAQ,MAAM,IAAI,CAAC;AAAA,YAC5D,cAAc;AAAA,YACd,OAAOA,EAAM,QAAQ,QAAQ;AAAA,YAC7B,UAAU;AAAA,YACV,YAAY;AAAA,YACZ,YAAY;AAAA,YACZ,IAAI;AAAA,YACJ,IAAI;AAAA,YACJ,IAAI;AAAA,UAAA,IAVF;AAAA,UAaH,cAAIJ,CAAgB;AAAA,QAAA;AAAA,MAAA,IAErB;AAAA,IAAA,EAAA,CACN,EAAA,CACF;AAAA,EAEJ,GAzCoB;AA2CpB,SACE,gBAAAf;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,WAAWC,EAAK,SAAS7B,CAAS;AAAA,MAClC,UAAAC;AAAA,MACA,OAAAC;AAAA,MACA,WAAAC;AAAA,MACA,UAAAK;AAAA,MACA,UAASC,KAAA,gBAAAA,EAAa,YAAW;AAAA,MAEhC,UAAA;AAAA,QAAAf,sBACEoC,GAAA,EAAW,QAAM,IAAC,IAAIZ,GACpB,aACH,IACE;AAAA,QACJ,gBAAAS;AAAA,UAACI;AAAA,UAAA;AAAA,YACC,cAAY;AAAA,YACX,GAAItB;AAAA,YACL,SAASf,IAAQwB,IAAU;AAAA,YAC3B,UAAQ;AAAA,YACR,aAAAmB;AAAA,YACA,OAAOtB;AAAA,YACP,UAAU,gBAAAtB,EAAA,CAACuC,GAAmCgB,MAAqB;AACjE,oBAAMT,IAAiB,MAAM,QAAQP,EAAM,OAAO,KAAK,IACnDA,EAAM,OAAO,MAAM,IAAI,CAACQ,MAAS,OAAOA,CAAI,CAAC,IAC7C,OAAOR,EAAM,OAAO,SAAS,EAAE,EAC5B,MAAM,GAAG,EACT,IAAI,CAACQ,MAASA,EAAK,KAAA,CAAM,EACzB,OAAO,OAAO;AAErB,kBAAID,EAAe,SAASU,EAAA,CAAqB,GAAG;AAClD,oBAAIrC,GAAe;AACjB,kBAAAD,EAAA;AACA;AAAA,gBACF;AAEA,gBAAAG,EAAA;AACA;AAAA,cACF;AAEA,cAAAE,EAAqBuB,CAAc;AAAA,YAErC,GApBU;AAAA,YAsBT,UAAA;AAAA,cAAA7B,IACC,gBAAAiB,EAACO,GAAA,EAAS,OAAOe,EAAA,GACf,UAAA;AAAA,gBAAA,gBAAAd,EAACe,GAAA,EAAS,SAAStC,GAAe,MAAK,SAAQ;AAAA,gBAC/C,gBAAAuB,EAACgB,GAAA,EAAa,SAASrD,EAAE,WAAW,EAAA,CAAG;AAAA,cAAA,EAAA,CACzC,IACE;AAAA,cACHuB,IACC,gBAAAc,EAACD,GAAA,EAAS,UAAQ,IAAC,OAAM,IACvB,UAAA,gBAAAC,EAACgB,GAAA,EAAa,SAAS7B,EAAA,CAAuB,EAAA,CAChD,IACE;AAAA,cACHT,EAAgB,IAAI,CAACY,MACpB,gBAAAE,EAACO,GAAA,EAAwD,UAAUT,EAAO,YAAYpB,GAAS,OAAOoB,EAAO,OAC3G,UAAA;AAAA,gBAAA,gBAAAU,EAACe,GAAA,EAAS,SAASnC,EAAkB,SAASU,EAAO,KAAK,GAAG,MAAK,SAAQ;AAAA,gBAC1E,gBAAAU,EAACgB,GAAA,EAAa,SAAS1B,EAAO,MAAA,CAAO;AAAA,cAAA,EAAA,GAFxB,0BAA0BA,EAAO,KAAK,EAGrD,CACD;AAAA,YAAA;AAAA,UAAA;AAAA,QAAA;AAAA,QAEFrB,IAAa,gBAAA+B,EAACC,GAAA,EAAe,IAAI7C,GAAwB,aAAW,IAAoB;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAG/F,GAlMiC;"}
|
|
@@ -1,120 +1,120 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
import { useOwpTranslation as
|
|
4
|
-
import { mergeSelectorOptions as
|
|
5
|
-
import { useState as
|
|
6
|
-
const
|
|
7
|
-
allOptions:
|
|
8
|
-
allValueMode:
|
|
9
|
-
defaultValue:
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
value:
|
|
1
|
+
var O = Object.defineProperty;
|
|
2
|
+
var R = (B, s) => O(B, "name", { value: s, configurable: !0 });
|
|
3
|
+
import { useOwpTranslation as w } from "../../../hooks/useOwpTranslation.js";
|
|
4
|
+
import { mergeSelectorOptions as p, joinSelectorValue as U, splitSelectorValue as W, getSelectorAllToken as ee, createSelectorChangeEvent as ne } from "../utils/querySelectorUtils.js";
|
|
5
|
+
import { useState as X, useRef as m, useMemo as a, useCallback as g, useEffect as P } from "react";
|
|
6
|
+
const oe = /* @__PURE__ */ R(({
|
|
7
|
+
allOptions: B,
|
|
8
|
+
allValueMode: s = "joined",
|
|
9
|
+
defaultValue: z,
|
|
10
|
+
multiple: e,
|
|
11
|
+
name: q,
|
|
12
|
+
onChange: F,
|
|
13
|
+
options: G,
|
|
14
|
+
showAllOption: r = !0,
|
|
15
|
+
value: L
|
|
16
16
|
}) => {
|
|
17
|
-
const { t:
|
|
18
|
-
() =>
|
|
19
|
-
),
|
|
20
|
-
|
|
21
|
-
const
|
|
22
|
-
() =>
|
|
23
|
-
[
|
|
24
|
-
), t =
|
|
25
|
-
() =>
|
|
26
|
-
[
|
|
27
|
-
),
|
|
17
|
+
const { t: H } = w(), u = L !== void 0, J = z ?? "", [j, x] = X(z), [v, f] = X(
|
|
18
|
+
() => e && r && (L ?? J) === "" ? "all" : "none"
|
|
19
|
+
), K = m(!1), V = m(L ?? J), d = m(null), E = m(F);
|
|
20
|
+
E.current = F;
|
|
21
|
+
const S = a(
|
|
22
|
+
() => p(G, B),
|
|
23
|
+
[B, G]
|
|
24
|
+
), t = a(
|
|
25
|
+
() => S.filter((n) => !n.disabled).map((n) => n.value),
|
|
26
|
+
[S]
|
|
27
|
+
), Y = a(() => U(t), [t]), c = u ? L : j, Q = a(() => W(c), [c]), I = a(() => e && r && (c == null || c === "") && v === "all" ? t : Q, [t, v, e, c, r, Q]), b = a(() => new Set(I), [I]), C = a(
|
|
28
28
|
() => ({
|
|
29
|
-
label:
|
|
29
|
+
label: H("Common.전체"),
|
|
30
30
|
raw: null,
|
|
31
|
-
value:
|
|
31
|
+
value: ee()
|
|
32
32
|
}),
|
|
33
|
-
[
|
|
34
|
-
),
|
|
35
|
-
() =>
|
|
36
|
-
[
|
|
37
|
-
),
|
|
33
|
+
[H]
|
|
34
|
+
), T = a(
|
|
35
|
+
() => S.filter((n) => b.has(n.value)),
|
|
36
|
+
[S, b]
|
|
37
|
+
), N = a(() => r ? e ? (c == null || c === "") && v === "all" ? !!t.length : s === "empty" ? !!t.length && v === "all" : !!t.length && t.every((n) => b.has(n)) : !!t.length && (c == null || c === "") : !1, [
|
|
38
38
|
t,
|
|
39
|
+
s,
|
|
40
|
+
v,
|
|
41
|
+
e,
|
|
39
42
|
c,
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
(e, S) => {
|
|
47
|
-
var u;
|
|
48
|
-
n && !r && (e === "" ? (g.current = S ?? "none", v(S ?? "none")) : (g.current = null, v("none"))), f || x(e), (u = B.current) == null || u.call(B, en(F, e));
|
|
43
|
+
b,
|
|
44
|
+
r
|
|
45
|
+
]), Z = a(() => !e && N && r ? C : T[0] ?? null, [C, N, e, T, r]), y = e && s === "joined" ? Y : "", o = g(
|
|
46
|
+
(n, i) => {
|
|
47
|
+
var l;
|
|
48
|
+
e && r && (n === "" ? (d.current = i ?? "none", f(i ?? "none")) : (d.current = null, f("none"))), u || x(n), (l = E.current) == null || l.call(E, ne(q, n));
|
|
49
49
|
},
|
|
50
|
-
[
|
|
51
|
-
),
|
|
52
|
-
|
|
53
|
-
}, [
|
|
54
|
-
!
|
|
55
|
-
}, [
|
|
56
|
-
|
|
57
|
-
}, [
|
|
58
|
-
(
|
|
59
|
-
|
|
50
|
+
[u, e, q, r]
|
|
51
|
+
), D = g(() => {
|
|
52
|
+
o(y, e && s === "empty" ? "all" : void 0);
|
|
53
|
+
}, [y, s, o, e]), _ = g(() => {
|
|
54
|
+
!e || !r || (d.current = "all", V.current = "", f("all"), u || x(""));
|
|
55
|
+
}, [u, e, r]), $ = g(() => {
|
|
56
|
+
o("", e ? "none" : void 0);
|
|
57
|
+
}, [o, e]), M = g(
|
|
58
|
+
(n) => {
|
|
59
|
+
o(n);
|
|
60
60
|
},
|
|
61
|
-
[
|
|
62
|
-
),
|
|
63
|
-
(
|
|
64
|
-
const
|
|
65
|
-
if (
|
|
66
|
-
|
|
61
|
+
[o]
|
|
62
|
+
), h = g(
|
|
63
|
+
(n) => {
|
|
64
|
+
const i = n.filter((l) => l !== "");
|
|
65
|
+
if (r && t.length && t.every((l) => i.includes(l))) {
|
|
66
|
+
D();
|
|
67
67
|
return;
|
|
68
68
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
69
|
+
o(
|
|
70
|
+
U(i),
|
|
71
|
+
s === "empty" ? "none" : void 0
|
|
72
72
|
);
|
|
73
73
|
},
|
|
74
|
-
[t,
|
|
74
|
+
[t, s, o, D, r]
|
|
75
75
|
);
|
|
76
|
-
return
|
|
77
|
-
|
|
78
|
-
}, [
|
|
79
|
-
if (
|
|
80
|
-
const
|
|
81
|
-
if (
|
|
82
|
-
const
|
|
83
|
-
|
|
76
|
+
return P(() => {
|
|
77
|
+
u || x(z);
|
|
78
|
+
}, [z, u]), P(() => {
|
|
79
|
+
if (e && r) {
|
|
80
|
+
const n = c ?? "", i = V.current;
|
|
81
|
+
if (n === "") {
|
|
82
|
+
const k = d.current;
|
|
83
|
+
k ? (f(k), d.current = null) : i !== n && f("all"), V.current = n;
|
|
84
84
|
return;
|
|
85
85
|
}
|
|
86
|
-
const
|
|
87
|
-
|
|
86
|
+
const l = W(n), A = !!t.length && t.every((k) => l.includes(k));
|
|
87
|
+
f(A ? "all" : "none"), d.current = null, V.current = n;
|
|
88
88
|
return;
|
|
89
89
|
}
|
|
90
|
-
|
|
91
|
-
}, [t,
|
|
92
|
-
!
|
|
90
|
+
V.current = c ?? "";
|
|
91
|
+
}, [t, e, c, r]), P(() => {
|
|
92
|
+
!e || !r || K.current || u || j !== void 0 && j !== "" || !t.length || (K.current = !0, o(y, e && s === "empty" ? "all" : void 0));
|
|
93
93
|
}, [
|
|
94
|
-
|
|
94
|
+
y,
|
|
95
95
|
t.length,
|
|
96
|
-
c,
|
|
97
|
-
r,
|
|
98
96
|
s,
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
97
|
+
o,
|
|
98
|
+
j,
|
|
99
|
+
u,
|
|
100
|
+
e,
|
|
101
|
+
r
|
|
102
102
|
]), {
|
|
103
|
-
allOption:
|
|
104
|
-
allValue:
|
|
105
|
-
clearSelection:
|
|
106
|
-
isAllSelected:
|
|
107
|
-
resolvedOptions:
|
|
108
|
-
restoreAllSelection:
|
|
109
|
-
selectAll:
|
|
110
|
-
selectedOption:
|
|
111
|
-
selectedOptions:
|
|
112
|
-
selectedValueList:
|
|
113
|
-
selectMultipleValues:
|
|
103
|
+
allOption: C,
|
|
104
|
+
allValue: y,
|
|
105
|
+
clearSelection: $,
|
|
106
|
+
isAllSelected: N,
|
|
107
|
+
resolvedOptions: S,
|
|
108
|
+
restoreAllSelection: _,
|
|
109
|
+
selectAll: D,
|
|
110
|
+
selectedOption: Z,
|
|
111
|
+
selectedOptions: N && e && r ? [C, ...S] : T,
|
|
112
|
+
selectedValueList: I,
|
|
113
|
+
selectMultipleValues: h,
|
|
114
114
|
selectSingleValue: M
|
|
115
115
|
};
|
|
116
116
|
}, "useOwpSelectorBase");
|
|
117
117
|
export {
|
|
118
|
-
|
|
118
|
+
oe as useOwpSelectorBase
|
|
119
119
|
};
|
|
120
120
|
//# sourceMappingURL=useOwpSelectorBase.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useOwpSelectorBase.js","sources":["../../../../src/components/OwpSelectorBase/hooks/useOwpSelectorBase.ts"],"sourcesContent":["import { useOwpTranslation } from '@/hooks/useOwpTranslation';\nimport {\n type OwpSelectorBaseHookResult,\n type OwpSelectorBaseOption,\n type OwpSelectorBaseProps,\n type OwpSelectorEmptyValueMode,\n} from '../types';\nimport {\n createSelectorChangeEvent,\n getSelectorAllToken,\n joinSelectorValue,\n mergeSelectorOptions,\n splitSelectorValue,\n} from '../utils';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\n/**\n * 공통 선택기 상태 훅\n * @param props 공통 선택기 props\n */\nexport const useOwpSelectorBase = ({\n allOptions,\n allValueMode = 'joined',\n defaultValue,\n disableAllValueItem,\n multiple,\n name,\n onChange,\n options,\n value,\n}: OwpSelectorBaseProps): OwpSelectorBaseHookResult => {\n const { t } = useOwpTranslation();\n const isControlled = value !== undefined;\n const normalizedDefaultValue = defaultValue ?? '';\n const [internalValue, setInternalValue] = useState(defaultValue);\n const [emptyValueMode, setEmptyValueMode] = useState<OwpSelectorEmptyValueMode>(() =>\n multiple && !disableAllValueItem && (value ?? normalizedDefaultValue) === ''\n ? 'all'\n : 'none',\n );\n const didInitializeAllValue = useRef(false);\n const previousNormalizedValue = useRef(value ?? normalizedDefaultValue);\n const pendingEmptyValueMode = useRef<OwpSelectorEmptyValueMode | null>(null);\n const onChangeRef = useRef(onChange);\n\n onChangeRef.current = onChange;\n\n const resolvedOptions = useMemo(\n () => mergeSelectorOptions(options, allOptions),\n [allOptions, options],\n );\n const allValueList = useMemo(\n () => resolvedOptions.filter((option) => !option.disabled).map((option) => option.value),\n [resolvedOptions],\n );\n const joinedAllValue = useMemo(() => joinSelectorValue(allValueList), [allValueList]);\n const normalizedValue = isControlled ? value : internalValue;\n const splitValueList = useMemo(() => splitSelectorValue(normalizedValue), [normalizedValue]);\n const selectedValueList = useMemo(() => {\n if (\n multiple &&\n !disableAllValueItem &&\n (normalizedValue == null || normalizedValue === '') &&\n emptyValueMode === 'all'\n ) {\n return allValueList;\n }\n\n return splitValueList;\n }, [allValueList, disableAllValueItem, emptyValueMode, multiple, normalizedValue, splitValueList]);\n const selectedValueSet = useMemo(() => new Set(selectedValueList), [selectedValueList]);\n const allOption = useMemo<OwpSelectorBaseOption<null>>(\n () => ({\n label: t('Common.전체'),\n raw: null,\n value: getSelectorAllToken(),\n }),\n [t],\n );\n const selectedOptions = useMemo(\n () => resolvedOptions.filter((option) => selectedValueSet.has(option.value)),\n [resolvedOptions, selectedValueSet],\n );\n const isAllSelected = useMemo(() => {\n if (disableAllValueItem) {\n return false;\n }\n\n if (!multiple) {\n return normalizedValue == null || normalizedValue === '';\n }\n\n if ((normalizedValue == null || normalizedValue === '') && emptyValueMode === 'all') {\n return true;\n }\n\n if (allValueMode === 'empty') {\n return emptyValueMode === 'all';\n }\n\n return Boolean(allValueList.length) && allValueList.every((item) => selectedValueSet.has(item));\n }, [\n allValueList,\n allValueMode,\n disableAllValueItem,\n emptyValueMode,\n multiple,\n normalizedValue,\n selectedValueSet,\n ]);\n const selectedOption = useMemo(() => {\n if (!multiple && isAllSelected && !disableAllValueItem) {\n return allOption;\n }\n\n return selectedOptions[0] ?? null;\n }, [allOption, disableAllValueItem, isAllSelected, multiple, selectedOptions]);\n const allValue = multiple\n ? allValueMode === 'joined'\n ? joinedAllValue\n : ''\n : '';\n\n const emitChange = useCallback(\n (nextValue: string, nextEmptyMode?: OwpSelectorEmptyValueMode) => {\n if (multiple && !disableAllValueItem) {\n if (nextValue === '') {\n pendingEmptyValueMode.current = nextEmptyMode ?? 'none';\n setEmptyValueMode(nextEmptyMode ?? 'none');\n } else {\n pendingEmptyValueMode.current = null;\n setEmptyValueMode('none');\n }\n }\n\n if (!isControlled) {\n setInternalValue(nextValue);\n }\n\n onChangeRef.current?.(createSelectorChangeEvent(name, nextValue));\n },\n [disableAllValueItem, isControlled, multiple, name],\n );\n\n const selectAll = useCallback(() => {\n emitChange(allValue, multiple && allValueMode === 'empty' ? 'all' : undefined);\n }, [allValue, allValueMode, emitChange, multiple]);\n\n const restoreAllSelection = useCallback(() => {\n if (!multiple || disableAllValueItem) {\n return;\n }\n\n pendingEmptyValueMode.current = 'all';\n previousNormalizedValue.current = '';\n setEmptyValueMode('all');\n\n if (!isControlled) {\n setInternalValue('');\n }\n }, [disableAllValueItem, isControlled, multiple]);\n\n const clearSelection = useCallback(() => {\n emitChange('', multiple ? 'none' : undefined);\n }, [emitChange, multiple]);\n\n const selectSingleValue = useCallback(\n (nextValue: string) => {\n emitChange(nextValue);\n },\n [emitChange],\n );\n\n const selectMultipleValues = useCallback(\n (nextSelectedValueList: string[]) => {\n const normalizedSelectedValueList = nextSelectedValueList.filter((item) => item !== '');\n\n if (\n !disableAllValueItem &&\n Boolean(allValueList.length) &&\n allValueList.every((item) => normalizedSelectedValueList.includes(item))\n ) {\n selectAll();\n return;\n }\n\n emitChange(\n joinSelectorValue(normalizedSelectedValueList),\n allValueMode === 'empty' ? 'none' : undefined,\n );\n },\n [allValueList, allValueMode, disableAllValueItem, emitChange, selectAll],\n );\n\n useEffect(() => {\n if (isControlled) {\n return;\n }\n\n setInternalValue(defaultValue);\n }, [defaultValue, isControlled]);\n\n useEffect(() => {\n if (multiple && !disableAllValueItem) {\n const nextNormalizedValue = normalizedValue ?? '';\n const previousValue = previousNormalizedValue.current;\n\n if (nextNormalizedValue === '') {\n const nextPendingEmptyValueMode = pendingEmptyValueMode.current;\n\n if (nextPendingEmptyValueMode) {\n setEmptyValueMode(nextPendingEmptyValueMode);\n pendingEmptyValueMode.current = null;\n } else if (previousValue !== nextNormalizedValue) {\n setEmptyValueMode('all');\n }\n\n previousNormalizedValue.current = nextNormalizedValue;\n\n return;\n }\n\n const nextSelectedValueList = splitSelectorValue(nextNormalizedValue);\n const isNextAllSelected =\n Boolean(allValueList.length) &&\n allValueList.every((item) => nextSelectedValueList.includes(item));\n\n setEmptyValueMode(isNextAllSelected ? 'all' : 'none');\n pendingEmptyValueMode.current = null;\n previousNormalizedValue.current = nextNormalizedValue;\n\n return;\n }\n\n previousNormalizedValue.current = normalizedValue ?? '';\n }, [allValueList, disableAllValueItem, multiple, normalizedValue]);\n\n useEffect(() => {\n if (\n !multiple ||\n disableAllValueItem ||\n didInitializeAllValue.current ||\n isControlled ||\n (internalValue !== undefined && internalValue !== '') ||\n !allValueList.length\n ) {\n return;\n }\n\n didInitializeAllValue.current = true;\n emitChange(allValue, multiple && allValueMode === 'empty' ? 'all' : undefined);\n }, [\n allValue,\n allValueList.length,\n allValueMode,\n disableAllValueItem,\n emitChange,\n internalValue,\n isControlled,\n multiple,\n ]);\n\n return {\n allOption,\n allValue,\n clearSelection,\n isAllSelected,\n resolvedOptions,\n restoreAllSelection,\n selectAll,\n selectedOption,\n selectedOptions: isAllSelected && multiple && !disableAllValueItem ? [allOption, ...resolvedOptions] : selectedOptions,\n selectedValueList,\n selectMultipleValues,\n selectSingleValue,\n };\n};\n"],"names":["useOwpSelectorBase","__name","allOptions","allValueMode","defaultValue","disableAllValueItem","multiple","name","onChange","options","value","t","useOwpTranslation","isControlled","normalizedDefaultValue","internalValue","setInternalValue","useState","emptyValueMode","setEmptyValueMode","didInitializeAllValue","useRef","previousNormalizedValue","pendingEmptyValueMode","onChangeRef","resolvedOptions","useMemo","mergeSelectorOptions","allValueList","option","joinedAllValue","joinSelectorValue","normalizedValue","splitValueList","splitSelectorValue","selectedValueList","selectedValueSet","allOption","getSelectorAllToken","selectedOptions","isAllSelected","item","selectedOption","allValue","emitChange","useCallback","nextValue","nextEmptyMode","_a","createSelectorChangeEvent","selectAll","restoreAllSelection","clearSelection","selectSingleValue","selectMultipleValues","nextSelectedValueList","normalizedSelectedValueList","useEffect","nextNormalizedValue","previousValue","nextPendingEmptyValueMode","isNextAllSelected"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useOwpSelectorBase.js","sources":["../../../../src/components/OwpSelectorBase/hooks/useOwpSelectorBase.ts"],"sourcesContent":["import { useOwpTranslation } from '@/hooks/useOwpTranslation';\nimport {\n type OwpSelectorBaseHookResult,\n type OwpSelectorBaseOption,\n type OwpSelectorBaseProps,\n type OwpSelectorEmptyValueMode,\n} from '../types';\nimport {\n createSelectorChangeEvent,\n getSelectorAllToken,\n joinSelectorValue,\n mergeSelectorOptions,\n splitSelectorValue,\n} from '../utils';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\n/**\n * 공통 선택기 상태 훅\n * @param props 공통 선택기 props\n */\nexport const useOwpSelectorBase = ({\n allOptions,\n allValueMode = 'joined',\n defaultValue,\n multiple,\n name,\n onChange,\n options,\n showAllOption = true,\n value,\n}: OwpSelectorBaseProps): OwpSelectorBaseHookResult => {\n const { t } = useOwpTranslation();\n const isControlled = value !== undefined;\n const normalizedDefaultValue = defaultValue ?? '';\n const [internalValue, setInternalValue] = useState(defaultValue);\n const [emptyValueMode, setEmptyValueMode] = useState<OwpSelectorEmptyValueMode>(() =>\n multiple && showAllOption && (value ?? normalizedDefaultValue) === ''\n ? 'all'\n : 'none',\n );\n const didInitializeAllValue = useRef(false);\n const previousNormalizedValue = useRef(value ?? normalizedDefaultValue);\n const pendingEmptyValueMode = useRef<OwpSelectorEmptyValueMode | null>(null);\n const onChangeRef = useRef(onChange);\n\n onChangeRef.current = onChange;\n\n const resolvedOptions = useMemo(\n () => mergeSelectorOptions(options, allOptions),\n [allOptions, options],\n );\n const allValueList = useMemo(\n () => resolvedOptions.filter((option) => !option.disabled).map((option) => option.value),\n [resolvedOptions],\n );\n const joinedAllValue = useMemo(() => joinSelectorValue(allValueList), [allValueList]);\n const normalizedValue = isControlled ? value : internalValue;\n const splitValueList = useMemo(() => splitSelectorValue(normalizedValue), [normalizedValue]);\n const selectedValueList = useMemo(() => {\n if (\n multiple &&\n showAllOption &&\n (normalizedValue == null || normalizedValue === '') &&\n emptyValueMode === 'all'\n ) {\n return allValueList;\n }\n\n return splitValueList;\n }, [allValueList, emptyValueMode, multiple, normalizedValue, showAllOption, splitValueList]);\n const selectedValueSet = useMemo(() => new Set(selectedValueList), [selectedValueList]);\n const allOption = useMemo<OwpSelectorBaseOption<null>>(\n () => ({\n label: t('Common.전체'),\n raw: null,\n value: getSelectorAllToken(),\n }),\n [t],\n );\n const selectedOptions = useMemo(\n () => resolvedOptions.filter((option) => selectedValueSet.has(option.value)),\n [resolvedOptions, selectedValueSet],\n );\n const isAllSelected = useMemo(() => {\n if (!showAllOption) {\n return false;\n }\n\n if (!multiple) {\n return Boolean(allValueList.length) && (normalizedValue == null || normalizedValue === '');\n }\n\n if ((normalizedValue == null || normalizedValue === '') && emptyValueMode === 'all') {\n return Boolean(allValueList.length);\n }\n\n if (allValueMode === 'empty') {\n return Boolean(allValueList.length) && emptyValueMode === 'all';\n }\n\n return Boolean(allValueList.length) && allValueList.every((item) => selectedValueSet.has(item));\n }, [\n allValueList,\n allValueMode,\n emptyValueMode,\n multiple,\n normalizedValue,\n selectedValueSet,\n showAllOption,\n ]);\n const selectedOption = useMemo(() => {\n if (!multiple && isAllSelected && showAllOption) {\n return allOption;\n }\n\n return selectedOptions[0] ?? null;\n }, [allOption, isAllSelected, multiple, selectedOptions, showAllOption]);\n const allValue = multiple\n ? allValueMode === 'joined'\n ? joinedAllValue\n : ''\n : '';\n\n const emitChange = useCallback(\n (nextValue: string, nextEmptyMode?: OwpSelectorEmptyValueMode) => {\n if (multiple && showAllOption) {\n if (nextValue === '') {\n pendingEmptyValueMode.current = nextEmptyMode ?? 'none';\n setEmptyValueMode(nextEmptyMode ?? 'none');\n } else {\n pendingEmptyValueMode.current = null;\n setEmptyValueMode('none');\n }\n }\n\n if (!isControlled) {\n setInternalValue(nextValue);\n }\n\n onChangeRef.current?.(createSelectorChangeEvent(name, nextValue));\n },\n [isControlled, multiple, name, showAllOption],\n );\n\n const selectAll = useCallback(() => {\n emitChange(allValue, multiple && allValueMode === 'empty' ? 'all' : undefined);\n }, [allValue, allValueMode, emitChange, multiple]);\n\n const restoreAllSelection = useCallback(() => {\n if (!multiple || !showAllOption) {\n return;\n }\n\n pendingEmptyValueMode.current = 'all';\n previousNormalizedValue.current = '';\n setEmptyValueMode('all');\n\n if (!isControlled) {\n setInternalValue('');\n }\n }, [isControlled, multiple, showAllOption]);\n\n const clearSelection = useCallback(() => {\n emitChange('', multiple ? 'none' : undefined);\n }, [emitChange, multiple]);\n\n const selectSingleValue = useCallback(\n (nextValue: string) => {\n emitChange(nextValue);\n },\n [emitChange],\n );\n\n const selectMultipleValues = useCallback(\n (nextSelectedValueList: string[]) => {\n const normalizedSelectedValueList = nextSelectedValueList.filter((item) => item !== '');\n\n if (\n showAllOption &&\n Boolean(allValueList.length) &&\n allValueList.every((item) => normalizedSelectedValueList.includes(item))\n ) {\n selectAll();\n return;\n }\n\n emitChange(\n joinSelectorValue(normalizedSelectedValueList),\n allValueMode === 'empty' ? 'none' : undefined,\n );\n },\n [allValueList, allValueMode, emitChange, selectAll, showAllOption],\n );\n\n useEffect(() => {\n if (isControlled) {\n return;\n }\n\n setInternalValue(defaultValue);\n }, [defaultValue, isControlled]);\n\n useEffect(() => {\n if (multiple && showAllOption) {\n const nextNormalizedValue = normalizedValue ?? '';\n const previousValue = previousNormalizedValue.current;\n\n if (nextNormalizedValue === '') {\n const nextPendingEmptyValueMode = pendingEmptyValueMode.current;\n\n if (nextPendingEmptyValueMode) {\n setEmptyValueMode(nextPendingEmptyValueMode);\n pendingEmptyValueMode.current = null;\n } else if (previousValue !== nextNormalizedValue) {\n setEmptyValueMode('all');\n }\n\n previousNormalizedValue.current = nextNormalizedValue;\n\n return;\n }\n\n const nextSelectedValueList = splitSelectorValue(nextNormalizedValue);\n const isNextAllSelected =\n Boolean(allValueList.length) &&\n allValueList.every((item) => nextSelectedValueList.includes(item));\n\n setEmptyValueMode(isNextAllSelected ? 'all' : 'none');\n pendingEmptyValueMode.current = null;\n previousNormalizedValue.current = nextNormalizedValue;\n\n return;\n }\n\n previousNormalizedValue.current = normalizedValue ?? '';\n }, [allValueList, multiple, normalizedValue, showAllOption]);\n\n useEffect(() => {\n if (\n !multiple ||\n !showAllOption ||\n didInitializeAllValue.current ||\n isControlled ||\n (internalValue !== undefined && internalValue !== '') ||\n !allValueList.length\n ) {\n return;\n }\n\n didInitializeAllValue.current = true;\n emitChange(allValue, multiple && allValueMode === 'empty' ? 'all' : undefined);\n }, [\n allValue,\n allValueList.length,\n allValueMode,\n emitChange,\n internalValue,\n isControlled,\n multiple,\n showAllOption,\n ]);\n\n return {\n allOption,\n allValue,\n clearSelection,\n isAllSelected,\n resolvedOptions,\n restoreAllSelection,\n selectAll,\n selectedOption,\n selectedOptions: isAllSelected && multiple && showAllOption ? [allOption, ...resolvedOptions] : selectedOptions,\n selectedValueList,\n selectMultipleValues,\n selectSingleValue,\n };\n};\n"],"names":["useOwpSelectorBase","__name","allOptions","allValueMode","defaultValue","multiple","name","onChange","options","showAllOption","value","t","useOwpTranslation","isControlled","normalizedDefaultValue","internalValue","setInternalValue","useState","emptyValueMode","setEmptyValueMode","didInitializeAllValue","useRef","previousNormalizedValue","pendingEmptyValueMode","onChangeRef","resolvedOptions","useMemo","mergeSelectorOptions","allValueList","option","joinedAllValue","joinSelectorValue","normalizedValue","splitValueList","splitSelectorValue","selectedValueList","selectedValueSet","allOption","getSelectorAllToken","selectedOptions","isAllSelected","item","selectedOption","allValue","emitChange","useCallback","nextValue","nextEmptyMode","_a","createSelectorChangeEvent","selectAll","restoreAllSelection","clearSelection","selectSingleValue","selectMultipleValues","nextSelectedValueList","normalizedSelectedValueList","useEffect","nextNormalizedValue","previousValue","nextPendingEmptyValueMode","isNextAllSelected"],"mappings":"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"}
|