@thewrong/ui 0.1.0 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_virtual/_rolldown/runtime.cjs.js +1 -0
- package/dist/components/_shared/form-size-tokens.cjs.js +1 -0
- package/dist/components/_shared/form-size-tokens.esm.js +29 -0
- package/dist/components/action-toast/ActionToast.cjs.js +1 -0
- package/dist/components/action-toast/ActionToast.esm.js +228 -0
- package/dist/components/animated-height/AnimatedHeight.cjs.js +1 -0
- package/dist/components/animated-height/AnimatedHeight.esm.js +36 -0
- package/dist/components/badge/Badge.cjs.js +1 -0
- package/dist/components/badge/Badge.esm.js +30 -0
- package/dist/components/badge/utils.cjs.js +1 -0
- package/dist/components/badge/utils.esm.js +38 -0
- package/dist/components/button/Button.cjs.js +1 -0
- package/dist/components/button/Button.esm.js +84 -0
- package/dist/components/button/utils.cjs.js +1 -0
- package/dist/components/button/utils.esm.js +38 -0
- package/dist/components/checkbox/Checkbox.cjs.js +1 -0
- package/dist/components/checkbox/Checkbox.esm.js +68 -0
- package/dist/components/checkbox/utils.cjs.js +1 -0
- package/dist/components/checkbox/utils.esm.js +44 -0
- package/dist/components/collapsible/Collapsible.cjs.js +1 -0
- package/dist/components/collapsible/Collapsible.esm.js +19 -0
- package/dist/components/date-input/DateInput.cjs.js +1 -0
- package/dist/components/date-input/DateInput.esm.js +39 -0
- package/dist/components/date-picker/date-picker.cjs.js +1 -0
- package/dist/components/date-picker/date-picker.esm.js +231 -0
- package/dist/components/date-picker/date-range-picker.cjs.js +1 -0
- package/dist/components/date-picker/date-range-picker.esm.js +287 -0
- package/dist/components/date-picker/month-picker.cjs.js +1 -0
- package/dist/components/date-picker/month-picker.esm.js +147 -0
- package/dist/components/drawer/Drawer.cjs.js +1 -0
- package/dist/components/drawer/Drawer.esm.js +113 -0
- package/dist/components/info-tooltip/InfoTooltip.cjs.js +1 -0
- package/dist/components/info-tooltip/InfoTooltip.esm.js +24 -0
- package/dist/components/input/Input.cjs.js +1 -0
- package/dist/components/input/Input.esm.js +95 -0
- package/dist/components/input/PasswordInput.cjs.js +1 -0
- package/dist/components/input/PasswordInput.esm.js +29 -0
- package/dist/components/input/format.cjs.js +1 -0
- package/dist/components/input/format.esm.js +33 -0
- package/dist/components/input/utils.cjs.js +1 -0
- package/dist/components/input/utils.esm.js +23 -0
- package/dist/components/loading-spinner/LoadingSpinner.cjs.js +1 -0
- package/dist/components/loading-spinner/LoadingSpinner.esm.js +47 -0
- package/dist/components/modal/Modal.cjs.js +1 -0
- package/dist/components/modal/Modal.esm.js +137 -0
- package/dist/components/modal/ModalSubView.cjs.js +1 -0
- package/dist/components/modal/ModalSubView.esm.js +91 -0
- package/dist/components/modal/StandardModal.cjs.js +1 -0
- package/dist/components/modal/StandardModal.esm.js +54 -0
- package/dist/components/page-title/PageTitle.cjs.js +1 -0
- package/dist/components/page-title/PageTitle.esm.js +16 -0
- package/dist/components/popover/Popover.cjs.js +1 -0
- package/dist/components/popover/Popover.esm.js +57 -0
- package/dist/components/search-box/ExactMatchToggle.cjs.js +1 -0
- package/dist/components/search-box/ExactMatchToggle.esm.js +27 -0
- package/dist/components/search-box/SearchBox.cjs.js +1 -0
- package/dist/components/search-box/SearchBox.esm.js +154 -0
- package/dist/components/search-box/SearchBoxChips.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxChips.esm.js +36 -0
- package/dist/components/search-box/SearchBoxDateRange.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxDateRange.esm.js +57 -0
- package/dist/components/search-box/SearchBoxDateSingle.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxDateSingle.esm.js +37 -0
- package/dist/components/search-box/SearchBoxField.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxField.esm.js +48 -0
- package/dist/components/search-box/SearchBoxFloatingInput.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxFloatingInput.esm.js +38 -0
- package/dist/components/search-box/SearchBoxFloatingSelect.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxFloatingSelect.esm.js +74 -0
- package/dist/components/search-box/SearchBoxMonth.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxMonth.esm.js +35 -0
- package/dist/components/search-box/SearchBoxMultiSelect.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxMultiSelect.esm.js +78 -0
- package/dist/components/search-box/SearchBoxSheetContext.cjs.js +1 -0
- package/dist/components/search-box/SearchBoxSheetContext.esm.js +5 -0
- package/dist/components/search-box/dateRangePresets.cjs.js +1 -0
- package/dist/components/search-box/dateRangePresets.esm.js +59 -0
- package/dist/components/search-box/parseDateRange.cjs.js +1 -0
- package/dist/components/search-box/parseDateRange.esm.js +21 -0
- package/dist/components/search-box/parseSearchValues.cjs.js +1 -0
- package/dist/components/search-box/parseSearchValues.esm.js +15 -0
- package/dist/components/search-box/useSearchBoxState.cjs.js +1 -0
- package/dist/components/search-box/useSearchBoxState.esm.js +87 -0
- package/dist/components/select/MultiSelect.cjs.js +1 -0
- package/dist/components/select/MultiSelect.esm.js +277 -0
- package/dist/components/select/Select.cjs.js +1 -0
- package/dist/components/select/Select.esm.js +308 -0
- package/dist/components/select/loading-dots.cjs.js +1 -0
- package/dist/components/select/loading-dots.esm.js +23 -0
- package/dist/components/switch/Switch.cjs.js +1 -0
- package/dist/components/switch/Switch.esm.js +36 -0
- package/dist/components/switch/utils.cjs.js +1 -0
- package/dist/components/switch/utils.esm.js +39 -0
- package/dist/components/table/accordion-table.cjs.js +1 -0
- package/dist/components/table/accordion-table.esm.js +418 -0
- package/dist/components/table/column-group-utils.cjs.js +1 -0
- package/dist/components/table/column-group-utils.esm.js +53 -0
- package/dist/components/table/components/ColumnPresetSelector.cjs.js +1 -0
- package/dist/components/table/components/ColumnPresetSelector.esm.js +165 -0
- package/dist/components/table/components/ColumnSettingsTable.cjs.js +4 -0
- package/dist/components/table/components/ColumnSettingsTable.esm.js +196 -0
- package/dist/components/table/components/KeyboardNavButton.cjs.js +1 -0
- package/dist/components/table/components/KeyboardNavButton.esm.js +24 -0
- package/dist/components/table/components/PageJumpInput.cjs.js +1 -0
- package/dist/components/table/components/PageJumpInput.esm.js +53 -0
- package/dist/components/table/components/Pagination.cjs.js +1 -0
- package/dist/components/table/components/Pagination.esm.js +162 -0
- package/dist/components/table/components/PaginationFooter.cjs.js +1 -0
- package/dist/components/table/components/PaginationFooter.esm.js +80 -0
- package/dist/components/table/components/SortableHeaderCell.cjs.js +1 -0
- package/dist/components/table/components/SortableHeaderCell.esm.js +30 -0
- package/dist/components/table/hooks/useColumnPresets.cjs.js +1 -0
- package/dist/components/table/hooks/useColumnPresets.esm.js +165 -0
- package/dist/components/table/hooks/useColumnResize.cjs.js +1 -0
- package/dist/components/table/hooks/useColumnResize.esm.js +106 -0
- package/dist/components/table/hooks/useFillEmptyRows.cjs.js +1 -0
- package/dist/components/table/hooks/useFillEmptyRows.esm.js +49 -0
- package/dist/components/table/hooks/useInfiniteScroll.cjs.js +1 -0
- package/dist/components/table/hooks/useInfiniteScroll.esm.js +32 -0
- package/dist/components/table/hooks/useTableColumnState.cjs.js +1 -0
- package/dist/components/table/hooks/useTableColumnState.esm.js +46 -0
- package/dist/components/table/hooks/useTableDragSelection.cjs.js +1 -0
- package/dist/components/table/hooks/useTableDragSelection.esm.js +76 -0
- package/dist/components/table/hooks/useTableSort.cjs.js +1 -0
- package/dist/components/table/hooks/useTableSort.esm.js +30 -0
- package/dist/components/table/hooks/useVirtualTable.cjs.js +1 -0
- package/dist/components/table/hooks/useVirtualTable.esm.js +18 -0
- package/dist/components/table/mini-table.cjs.js +1 -0
- package/dist/components/table/mini-table.esm.js +126 -0
- package/dist/components/table/paginated-mini-table.cjs.js +1 -0
- package/dist/components/table/paginated-mini-table.esm.js +31 -0
- package/dist/components/table/paginated-table.cjs.js +1 -0
- package/dist/components/table/paginated-table.esm.js +31 -0
- package/dist/components/table/table.cjs.js +1 -0
- package/dist/components/table/table.esm.js +342 -0
- package/dist/components/table/utils.cjs.js +37 -0
- package/dist/components/table/utils.esm.js +16 -0
- package/dist/components/table-checkbox/TableCheckbox.cjs.js +1 -0
- package/dist/components/table-checkbox/TableCheckbox.esm.js +39 -0
- package/dist/components/table-page-layout/TablePageLayout.cjs.js +1 -0
- package/dist/components/table-page-layout/TablePageLayout.esm.js +37 -0
- package/dist/components/textarea/Textarea.cjs.js +1 -0
- package/dist/components/textarea/Textarea.esm.js +62 -0
- package/dist/components/toast/ToastProvider.cjs.js +1 -0
- package/dist/components/toast/ToastProvider.esm.js +82 -0
- package/dist/components/toast/index.esm.js +3 -0
- package/dist/components/toolbar/Toolbar.cjs.js +1 -0
- package/dist/components/toolbar/Toolbar.esm.js +148 -0
- package/dist/components/tooltip/Tooltip.cjs.js +1 -0
- package/dist/components/tooltip/Tooltip.esm.js +39 -0
- package/dist/hooks/useBottomSheetDrag.cjs.js +1 -0
- package/dist/hooks/useBottomSheetDrag.esm.js +17 -0
- package/dist/hooks/useClickOutside.cjs.js +1 -0
- package/dist/hooks/useClickOutside.esm.js +20 -0
- package/dist/hooks/useMediaQuery.cjs.js +1 -0
- package/dist/hooks/useMediaQuery.esm.js +15 -0
- package/dist/hooks/useScrollLock.cjs.js +1 -0
- package/dist/hooks/useScrollLock.esm.js +16 -0
- package/dist/hooks.cjs.js +1 -0
- package/dist/hooks.esm.js +5 -0
- package/dist/index.cjs.js +1 -40
- package/dist/index.esm.js +58 -0
- package/dist/lib/Portal.cjs.js +1 -0
- package/dist/lib/Portal.esm.js +11 -0
- package/dist/lib/column-preset-storage.cjs.js +1 -0
- package/dist/lib/column-preset-storage.esm.js +123 -0
- package/dist/lib/overlay-stack.cjs.js +1 -0
- package/dist/lib/overlay-stack.esm.js +28 -0
- package/dist/lib/utils.cjs.js +1 -0
- package/dist/lib/utils.esm.js +11 -0
- package/dist/node_modules/clsx/dist/clsx.cjs.js +1 -0
- package/dist/node_modules/clsx/dist/clsx.esm.js +16 -0
- package/dist/node_modules/lucide-react/dist/esm/Icon.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/Icon.esm.js +23 -0
- package/dist/node_modules/lucide-react/dist/esm/context.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/context.esm.js +6 -0
- package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.esm.js +17 -0
- package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.esm.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/arrow-left.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/arrow-left.esm.js +10 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/calendar.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/calendar.esm.js +25 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/check.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/check.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-left.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-left.esm.js +10 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-right.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-right.esm.js +10 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.esm.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.esm.js +19 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/eye-off.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/eye-off.esm.js +21 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/eye.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/eye.esm.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/grip-vertical.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/grip-vertical.esm.js +41 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/info.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/info.esm.js +19 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/keyboard.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/keyboard.esm.js +45 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/list-filter.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/list-filter.esm.js +17 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/minus.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/minus.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/rotate-ccw.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/rotate-ccw.esm.js +10 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/save.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/save.esm.js +17 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/search.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/search.esm.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/settings.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/settings.esm.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.esm.js +17 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/wrench.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/wrench.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/x.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/x.esm.js +10 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/hasA11yProp.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/hasA11yProp.esm.js +7 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/mergeClasses.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/mergeClasses.esm.js +4 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toCamelCase.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toCamelCase.esm.js +4 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toKebabCase.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toKebabCase.esm.js +4 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toPascalCase.cjs.js +1 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toPascalCase.esm.js +8 -0
- package/dist/node_modules/tailwind-merge/dist/bundle-mjs.cjs.js +1 -0
- package/dist/node_modules/tailwind-merge/dist/bundle-mjs.esm.js +1714 -0
- package/dist/node_modules/use-debounce/dist/index.module.cjs.js +1 -0
- package/dist/node_modules/use-debounce/dist/index.module.esm.js +70 -0
- package/dist/src/components/action-toast/ActionToast.d.ts +6 -1
- package/dist/src/components/button/Button.d.ts +16 -0
- package/dist/src/components/drawer/Drawer.d.ts +6 -1
- package/dist/src/components/info-tooltip/InfoTooltip.d.ts +7 -0
- package/dist/src/components/loading-spinner/LoadingSpinner.d.ts +7 -0
- package/dist/src/components/modal/Modal.d.ts +7 -1
- package/dist/src/components/popover/Popover.d.ts +19 -1
- package/dist/src/components/tooltip/Tooltip.d.ts +10 -0
- package/dist/ui.css +1 -1
- package/llms.txt +91 -0
- package/package.json +10 -4
- package/dist/index.es.js +0 -8066
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
//#region src/components/switch/utils.ts
|
|
2
|
+
var e = {
|
|
3
|
+
small: {
|
|
4
|
+
track: "h-5 w-9",
|
|
5
|
+
thumb: "h-3.5 w-3.5",
|
|
6
|
+
translate: "peer-checked:translate-x-4"
|
|
7
|
+
},
|
|
8
|
+
medium: {
|
|
9
|
+
track: "h-6 w-11",
|
|
10
|
+
thumb: "h-4.5 w-4.5",
|
|
11
|
+
translate: "peer-checked:translate-x-5"
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
function t(t, n) {
|
|
15
|
+
let { track: r } = e[t];
|
|
16
|
+
return n ? [
|
|
17
|
+
"relative inline-flex shrink-0 items-center rounded-full",
|
|
18
|
+
r,
|
|
19
|
+
"bg-bg-disabled cursor-not-allowed"
|
|
20
|
+
].join(" ") : [
|
|
21
|
+
"relative inline-flex shrink-0 items-center rounded-full cursor-pointer",
|
|
22
|
+
r,
|
|
23
|
+
"bg-neutral-200 dark:bg-neutral-700",
|
|
24
|
+
"peer-checked:bg-primary-500",
|
|
25
|
+
"peer-focus-visible:ring-2 peer-focus-visible:ring-primary-300 peer-focus-visible:ring-offset-2 peer-focus-visible:ring-offset-bg-card",
|
|
26
|
+
"transition-colors duration-200 ease-out"
|
|
27
|
+
].join(" ");
|
|
28
|
+
}
|
|
29
|
+
function n(t) {
|
|
30
|
+
let { thumb: n, translate: r } = e[t];
|
|
31
|
+
return [
|
|
32
|
+
"pointer-events-none absolute left-[3px] top-[3px] inline-block rounded-full bg-white shadow-sm",
|
|
33
|
+
n,
|
|
34
|
+
r,
|
|
35
|
+
"transition-transform duration-200 ease-out"
|
|
36
|
+
].join(" ");
|
|
37
|
+
}
|
|
38
|
+
//#endregion
|
|
39
|
+
export { n as getSwitchThumbClasses, t as getSwitchTrackClasses };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e=require("../checkbox/Checkbox.cjs.js"),t=require("../../node_modules/lucide-react/dist/esm/icons/chevron-right.cjs.js"),n=require("../loading-spinner/LoadingSpinner.cjs.js"),r=require("../select/Select.cjs.js"),i=require("./components/SortableHeaderCell.cjs.js"),a=require("./hooks/useColumnResize.cjs.js"),o=require("./hooks/useFillEmptyRows.cjs.js"),ee=require("./hooks/useTableSort.cjs.js"),s=require("./utils.cjs.js"),c=require("./components/KeyboardNavButton.cjs.js"),l=require("./components/PageJumpInput.cjs.js"),te=require("./components/Pagination.cjs.js");let u=require("react"),d=require("react/jsx-runtime"),f=require("@dnd-kit/core"),p=require("@dnd-kit/sortable");var ne=[30,50,100],m=36,h=(0,u.forwardRef)((h,g)=>{let{data:_,columns:v,rowHeight:y,loading:re=!1,emptyMessage:ie=`데이터가 없어요`,onRowClick:ae,selectedRows:b=[],onRowSelect:x,enableRowSelection:S=!1,enableSelectAll:C=!1,rowCompare:w,enableSorting:T=!1,serverSideSorting:E=!1,onSortChange:oe,initialSort:se,variant:ce=`default`,size:le=`medium`,stickyHeader:D=!0,height:O,maxHeight:k,currentPage:A,totalPages:j,onPageChange:M,pageSize:N,pageSizeOptions:ue=ne,onPageSizeChange:P,totalElements:F,storageKey:de,columnState:I,fillEmptyRows:L=!0,enableKeyboardPagination:R=!0,expandable:z,className:B=``,"data-testid":V,...H}=h,U=!!z,W=z?.stickyDetail??!0,{sort:fe,sortedData:G}=ee.useTableSort({initialSort:se,serverSide:E,onSort:oe||void 0}),K=(0,u.useMemo)(()=>!T||E?_:G(_,(e,t)=>{let n=v.find(e=>e.key===t);if(n?.accessor){let r=n.accessor(e);return typeof r==`string`||typeof r==`number`?r:e[t]}return e[t]}),[_,T,E,fe,G,v]),q=(0,u.useRef)(null),J=(0,u.useRef)(null),Y=(0,u.useRef)(null),X=(0,u.useRef)(null),[pe,me]=(0,u.useState)(0),he=!!I,ge=(0,f.useSensors)((0,f.useSensor)(f.PointerSensor,{activationConstraint:{distance:5}}),(0,f.useSensor)(f.KeyboardSensor,{coordinateGetter:p.sortableKeyboardCoordinates})),_e=e=>{let{active:t,over:n}=e;if(!I||!n||t.id===n.id||v.find(e=>e.key===n.id)?.excludeFromPreset)return;let r=I.columnOrder,i=r.indexOf(String(t.id)),a=r.indexOf(String(n.id));i===-1||a===-1||I.onColumnOrderChange((0,p.arrayMove)(r,i,a))},Z=(0,u.useMemo)(()=>{if(!I)return v.filter(e=>!e.hidden);let e=new Map(v.map(e=>[e.key,e])),t=new Set(I.hiddenColumns);return I.columnOrder.map(t=>e.get(t)).filter(e=>!!e).filter(e=>!e.hidden&&!t.has(e.key))},[v,I]),{handleMouseDown:ve,handleDoubleClick:ye,getColumnWidth:Q,measureRef:be}=a.useColumnResize({columns:Z,data:K,getCellContent:(e,t)=>{let n=Z.find(e=>e.key===t);return n?.accessor?n.accessor(e):e[t]},tableRef:q,...I?{controlledWidths:I.columnWidths,onColumnWidthsChange:I.onColumnWidthsChange}:{storageKey:de}}),xe=s.getTableBaseClasses(),Se=s.getTableVariantClasses(ce),Ce=s.getTableSizeClasses(le),we=(0,u.useMemo)(()=>{let e={};return O&&(e.height=typeof O==`number`?`${O}px`:O),k&&(e.maxHeight=typeof k==`number`?`${k}px`:k),e},[O,k]),{emptyRowCount:Te,measuredRowHeight:Ee}=o.useFillEmptyRows({enabled:L,containerRef:J,theadRef:Y,tbodyRef:X,excludeRowsSelector:`tr:not([data-empty-row]):not([data-expanded-row])`,remainingMode:`tbody-height`,observeTbody:!0,deps:[K,Z]});(0,u.useLayoutEffect)(()=>{if(!W||!U)return;let e=J.current;if(!e)return;let t=()=>{me(t=>t===e.clientWidth?t:e.clientWidth)};t();let n=new ResizeObserver(t);return n.observe(e),()=>n.disconnect()},[W,U]);let De=e=>{e.altKey||e.metaKey||e.ctrlKey||e.shiftKey||(e.key===`ArrowLeft`&&A>1?(e.preventDefault(),M(A-1)):e.key===`ArrowRight`&&A<j&&(e.preventDefault(),M(A+1)))},$=e=>!S||b.length===0?!1:w?b.some(t=>w(t,e)):b.some(t=>t===e),Oe=(0,u.useMemo)(()=>!S||!C||K.length===0?!1:K.every(e=>$(e)),[S,C,K,$]),ke=()=>{!S||!x||(Oe?K.forEach(e=>{$(e)&&x(e,!1)}):K.forEach(e=>{$(e)||x(e,!0)}))},Ae=(e,t)=>{let n=[s.getStripedRowClasses(t)];return $(e)&&n.push(s.getSelectedRowClasses()),(ae||U)&&n.push(s.getHoverableRowClasses()),n.join(` `)},je=!!P||F!==void 0||typeof j==`number`&&j>0,Me=e=>{z&&z.onToggle(z.getRowId(e))},Ne=(e,t)=>{U&&(e.key===` `||e.key===`Enter`)&&(e.preventDefault(),Me(t))},Pe=(S&&C?1:0)+ +!!U+Z.length+1;return re?(0,d.jsx)(`div`,{ref:g,className:`flex items-center justify-center p-8 flex-1 ${B}`,style:we,"data-testid":V,...H,children:(0,d.jsx)(n.LoadingSpinner,{message:`데이터를 불러오는 중이에요...`,className:`min-h-0`})}):(0,d.jsxs)(`div`,{ref:g,className:`relative flex flex-col min-h-0 ${B}`,style:we,"data-testid":V,...H,children:[(0,d.jsx)(`div`,{ref:be,className:`absolute invisible whitespace-nowrap`,style:{top:`-9999px`,left:`-9999px`}}),(0,d.jsxs)(`div`,{className:`flex flex-1 flex-col min-h-0`,children:[(0,d.jsx)(`div`,{ref:J,className:`overflow-auto flex-1 bg-[#f9fafb] dark:bg-slate-900/50`,children:K.length===0?(0,d.jsx)(`div`,{className:`flex items-center justify-center p-8 h-full`,children:(0,d.jsx)(`p`,{className:`text-neutral-600 dark:text-neutral-400`,children:ie})}):(0,d.jsx)(f.DndContext,{sensors:ge,collisionDetection:f.closestCenter,onDragEnd:_e,children:(0,d.jsxs)(`table`,{ref:q,className:`${xe} ${Se} ${Ce}`,style:{tableLayout:`fixed`,minWidth:`100%`,width:`100%`},children:[(0,d.jsxs)(`colgroup`,{children:[S&&C&&(0,d.jsx)(`col`,{style:{width:`48px`}}),U&&(0,d.jsx)(`col`,{style:{width:`${m}px`}}),Z.map(e=>(0,d.jsx)(`col`,{"data-col-key":e.key,style:{width:Q(e.key,e.width)}},e.key)),(0,d.jsx)(`col`,{style:{width:`100%`}})]}),(0,d.jsx)(`thead`,{ref:Y,className:s.getTableHeaderClasses(),style:{position:D?`sticky`:`relative`,top:D?0:void 0,zIndex:D?10:void 0,backgroundColor:D?`white`:void 0},children:(0,d.jsxs)(`tr`,{children:[S&&C&&(0,d.jsx)(`th`,{className:`${s.getTableHeaderCellClasses()} ${s.getColumnAlignClasses(`center`)} border-r-0 w-12`,children:(0,d.jsx)(e.Checkbox.Circle,{id:`accordion-table-select-all`,size:20,checked:Oe,onCheckedChange:ke})}),U&&(0,d.jsx)(`th`,{"aria-hidden":`true`,className:`${s.getTableHeaderCellClasses()} border-r-0`,style:{width:`${m}px`}}),(0,d.jsx)(p.SortableContext,{items:Z.map(e=>e.key),strategy:p.horizontalListSortingStrategy,children:Z.map(e=>{let t=!he||e.excludeFromPreset===!0;return(0,d.jsxs)(i.SortableHeaderCell,{id:e.key,disabled:t,as:`th`,className:`${s.getTableHeaderCellClasses()} ${s.getColumnAlignClasses(`center`)} bg-white ${e.sticky?`sticky left-0 z-20 bg-white dark:bg-neutral-800`:``} ${e.hideOnMobile?`hidden md:table-cell`:``} relative`,style:{width:Q(e.key,e.width),minWidth:e.minWidth||50},children:[(0,d.jsx)(`div`,{className:`flex items-center justify-center w-full pr-1 select-none`,children:(0,d.jsx)(`span`,{children:e.header})}),e.excludeFromPreset!==!0&&(0,d.jsx)(`div`,{className:`absolute right-0 top-0 h-full w-4 cursor-col-resize hover:bg-primary-500/30 active:bg-primary-500/50 z-50`,onPointerDown:e=>e.stopPropagation(),onMouseDown:t=>{t.preventDefault(),t.stopPropagation(),ve(e.key,t)},onDoubleClick:t=>{t.preventDefault(),t.stopPropagation(),ye(e.key,t)},onClick:e=>{e.preventDefault(),e.stopPropagation()},style:{touchAction:`none`},title:`드래그하여 너비 조절, 더블 클릭하여 자동 조절`})]},e.key)})}),(0,d.jsx)(`th`,{"aria-hidden":`true`,className:`bg-white border-b border-l border-[#f2f3f5] dark:border-neutral-700 dark:bg-neutral-800`})]})}),(0,d.jsxs)(`tbody`,{ref:X,children:[K.map((n,r)=>{let i=$(n),a=z?z.getRowId(n):void 0,o=z?z.expandedIds.has(a):!1;return(0,d.jsxs)(u.Fragment,{children:[(0,d.jsxs)(`tr`,{className:Ae(n,r),onClick:e=>{let t=e.target;if(t!==e.currentTarget){let n=t.closest(`button, a, input, select, textarea, label`);if(n&&e.currentTarget.contains(n))return}ae?.(n,r),U&&Me(n)},onKeyDown:e=>Ne(e,n),tabIndex:U?0:void 0,role:U?`button`:void 0,"aria-expanded":U?o:void 0,style:y?{height:`${y}px`}:void 0,children:[S&&C&&(0,d.jsx)(`td`,{className:`${s.getTableCellClasses()} ${s.getColumnAlignClasses(`center`)} border-r-0 w-12`,onClick:e=>e.stopPropagation(),children:(0,d.jsx)(e.Checkbox.Circle,{size:20,checked:i,onCheckedChange:e=>x?.(n,e)})}),U&&(0,d.jsx)(`td`,{className:`${s.getTableCellClasses()} ${s.getColumnAlignClasses(`center`)} border-r-0`,style:{width:`${m}px`},children:(0,d.jsx)(t.ChevronRight,{"aria-hidden":`true`,className:`mx-auto h-4 w-4 text-neutral-500 transition-transform duration-200 ${o?`rotate-90`:``}`})}),Z.map((e,t)=>{let r=e.accessor?e.accessor(n):n[e.key],i=t===Z.length-1&&!S;return(0,d.jsx)(`td`,{className:`${s.getTableCellClasses()} ${s.getColumnAlignClasses(e.align)} ${i?`border-r-0`:``} ${e.sticky?`sticky left-0 z-10 bg-inherit`:``} ${e.hideOnMobile?`hidden md:table-cell`:``}`,style:{width:Q(e.key,e.width),minWidth:e.minWidth||50,...y?{height:`${y}px`,maxHeight:`${y}px`,overflow:`hidden`}:{}},children:r},e.key)}),(0,d.jsx)(`td`,{"aria-hidden":`true`,className:`border-b border-l border-[#f2f3f5] dark:border-neutral-700 bg-transparent`})]}),U&&(0,d.jsx)(`tr`,{"data-expanded-row":!0,className:`bg-[#f9fafb] dark:bg-slate-900/50`,children:(0,d.jsx)(`td`,{colSpan:Pe,className:`p-0 border-b border-[#f2f3f5] dark:border-neutral-700`,children:(0,d.jsx)(`div`,{className:W?`sticky left-0`:void 0,style:W&&pe>0?{width:`${pe}px`}:void 0,children:(0,d.jsx)(`div`,{className:`grid transition-[grid-template-rows,opacity] duration-200 ease-out`,style:{gridTemplateRows:o?`1fr`:`0fr`,opacity:+!!o},"aria-hidden":!o,children:(0,d.jsx)(`div`,{className:`overflow-hidden`,children:z.renderRow(n)})})})})})]},r)}),L&&Array.from({length:Te}).map((e,t)=>{let n=K.length+t,r=y??Ee??void 0;return(0,d.jsxs)(`tr`,{"data-empty-row":!0,"aria-hidden":`true`,className:s.getStripedRowClasses(n),style:r?{height:`${r}px`}:void 0,children:[S&&C&&(0,d.jsx)(`td`,{className:`${s.getTableCellClasses()} border-r-0 w-12`,style:r?{height:`${r}px`}:void 0}),U&&(0,d.jsx)(`td`,{className:`${s.getTableCellClasses()} border-r-0`,style:{width:`${m}px`,...r?{height:`${r}px`}:{}}}),Z.map((e,t)=>{let n=t===Z.length-1&&!S;return(0,d.jsx)(`td`,{className:`${s.getTableCellClasses()} ${n?`border-r-0`:``} ${e.hideOnMobile?`hidden md:table-cell`:``}`,style:{width:Q(e.key,e.width),minWidth:e.minWidth||50,...r?{height:`${r}px`}:{}}},e.key)}),(0,d.jsx)(`td`,{"aria-hidden":`true`,className:`border-b border-l border-[#f2f3f5] dark:border-neutral-700 bg-transparent`,style:r?{height:`${r}px`}:void 0})]},`empty-${t}`)})]})]})})}),je&&(0,d.jsxs)(`nav`,{"aria-label":`페이지 네비게이션`,className:`@container/pagebar group/footer flex flex-wrap items-center justify-between gap-x-3 gap-y-2 border-t border-neutral-200 px-4 py-2 shrink-0 dark:border-neutral-700`,children:[(0,d.jsxs)(`div`,{className:`flex flex-wrap items-center gap-x-3 gap-y-2 text-sm text-neutral-600 dark:text-neutral-300`,children:[F!==void 0&&(0,d.jsxs)(`span`,{children:[`총 `,F.toLocaleString(),`건`]}),P&&N!==void 0&&(0,d.jsxs)(`div`,{className:`flex items-center gap-1`,children:[(0,d.jsx)(`span`,{className:`text-neutral-500`,children:`페이지당`}),(0,d.jsx)(`div`,{className:`w-20`,children:(0,d.jsx)(r.Select,{variant:`box`,selectSize:`mini`,value:String(N),onChange:e=>P(Number(e)),options:ue.map(e=>({value:String(e),label:String(e)})),"data-testid":V?`${V}-page-size`:void 0})})]}),(0,d.jsx)(`div`,{className:`contents @min-[640px]/pagebar:hidden`,children:j!==void 0&&A!==void 0&&M&&j>1&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(l.PageJumpInput,{currentPage:A,totalPages:j,onPageChange:M,"data-testid":V?`${V}-page-jump`:void 0}),R&&(0,d.jsx)(c.KeyboardNavButton,{onKeyDown:De})]})})]}),(0,d.jsxs)(`div`,{className:`flex items-center gap-3`,children:[(0,d.jsx)(`div`,{className:`hidden @min-[640px]/pagebar:contents`,children:j!==void 0&&A!==void 0&&M&&j>1&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(l.PageJumpInput,{currentPage:A,totalPages:j,onPageChange:M,"data-testid":V?`${V}-page-jump`:void 0}),R&&(0,d.jsx)(c.KeyboardNavButton,{onKeyDown:De})]})}),j!==void 0&&A!==void 0&&M&&(0,d.jsx)(te.Pagination,{currentPage:A,totalPages:j,onPageChange:M,hasPreviousPage:A>1,hasNextPage:A<j,"data-testid":V?`${V}-pagination`:void 0})]})]})]})]})});h.displayName=`AccordionTable`,exports.AccordionTable=h;
|
|
@@ -0,0 +1,418 @@
|
|
|
1
|
+
import { Checkbox as e } from "../checkbox/Checkbox.esm.js";
|
|
2
|
+
import { ChevronRight as t } from "../../node_modules/lucide-react/dist/esm/icons/chevron-right.esm.js";
|
|
3
|
+
import { LoadingSpinner as n } from "../loading-spinner/LoadingSpinner.esm.js";
|
|
4
|
+
import { Select as r } from "../select/Select.esm.js";
|
|
5
|
+
import { SortableHeaderCell as i } from "./components/SortableHeaderCell.esm.js";
|
|
6
|
+
import { useColumnResize as a } from "./hooks/useColumnResize.esm.js";
|
|
7
|
+
import { useFillEmptyRows as o } from "./hooks/useFillEmptyRows.esm.js";
|
|
8
|
+
import { useTableSort as ee } from "./hooks/useTableSort.esm.js";
|
|
9
|
+
import { getColumnAlignClasses as s, getHoverableRowClasses as te, getSelectedRowClasses as ne, getStripedRowClasses as c, getTableBaseClasses as re, getTableCellClasses as l, getTableHeaderCellClasses as u, getTableHeaderClasses as ie, getTableSizeClasses as ae, getTableVariantClasses as oe } from "./utils.esm.js";
|
|
10
|
+
import { KeyboardNavButton as d } from "./components/KeyboardNavButton.esm.js";
|
|
11
|
+
import { PageJumpInput as f } from "./components/PageJumpInput.esm.js";
|
|
12
|
+
import { Pagination as se } from "./components/Pagination.esm.js";
|
|
13
|
+
import { Fragment as ce, forwardRef as p, useLayoutEffect as le, useMemo as m, useRef as h, useState as ue } from "react";
|
|
14
|
+
import { Fragment as de, jsx as g, jsxs as _ } from "react/jsx-runtime";
|
|
15
|
+
import { DndContext as fe, KeyboardSensor as pe, PointerSensor as me, closestCenter as he, useSensor as v, useSensors as ge } from "@dnd-kit/core";
|
|
16
|
+
import { SortableContext as _e, arrayMove as ve, horizontalListSortingStrategy as ye, sortableKeyboardCoordinates as be } from "@dnd-kit/sortable";
|
|
17
|
+
//#region src/components/table/accordion-table.tsx
|
|
18
|
+
var xe = [
|
|
19
|
+
30,
|
|
20
|
+
50,
|
|
21
|
+
100
|
|
22
|
+
], y = 36, b = p((p, b) => {
|
|
23
|
+
let { data: x, columns: S, rowHeight: C, loading: Se = !1, emptyMessage: Ce = "데이터가 없어요", onRowClick: w, selectedRows: T = [], onRowSelect: E, enableRowSelection: D = !1, enableSelectAll: O = !1, rowCompare: we, enableSorting: k = !1, serverSideSorting: A = !1, onSortChange: Te, initialSort: Ee, variant: De = "default", size: Oe = "medium", stickyHeader: j = !0, height: M, maxHeight: N, currentPage: P, totalPages: F, onPageChange: I, pageSize: L, pageSizeOptions: ke = xe, onPageSizeChange: R, totalElements: z, storageKey: Ae, columnState: B, fillEmptyRows: V = !0, enableKeyboardPagination: H = !0, expandable: U, className: W = "", "data-testid": G, ...K } = p, q = !!U, J = U?.stickyDetail ?? !0, { sort: je, sortedData: Me } = ee({
|
|
24
|
+
initialSort: Ee,
|
|
25
|
+
serverSide: A,
|
|
26
|
+
onSort: Te || void 0
|
|
27
|
+
}), Y = m(() => !k || A ? x : Me(x, (e, t) => {
|
|
28
|
+
let n = S.find((e) => e.key === t);
|
|
29
|
+
if (n?.accessor) {
|
|
30
|
+
let r = n.accessor(e);
|
|
31
|
+
return typeof r == "string" || typeof r == "number" ? r : e[t];
|
|
32
|
+
}
|
|
33
|
+
return e[t];
|
|
34
|
+
}), [
|
|
35
|
+
x,
|
|
36
|
+
k,
|
|
37
|
+
A,
|
|
38
|
+
je,
|
|
39
|
+
Me,
|
|
40
|
+
S
|
|
41
|
+
]), Ne = h(null), X = h(null), Pe = h(null), Fe = h(null), [Ie, Le] = ue(0), Re = !!B, ze = ge(v(me, { activationConstraint: { distance: 5 } }), v(pe, { coordinateGetter: be })), Be = (e) => {
|
|
42
|
+
let { active: t, over: n } = e;
|
|
43
|
+
if (!B || !n || t.id === n.id || S.find((e) => e.key === n.id)?.excludeFromPreset) return;
|
|
44
|
+
let r = B.columnOrder, i = r.indexOf(String(t.id)), a = r.indexOf(String(n.id));
|
|
45
|
+
i === -1 || a === -1 || B.onColumnOrderChange(ve(r, i, a));
|
|
46
|
+
}, Z = m(() => {
|
|
47
|
+
if (!B) return S.filter((e) => !e.hidden);
|
|
48
|
+
let e = new Map(S.map((e) => [e.key, e])), t = new Set(B.hiddenColumns);
|
|
49
|
+
return B.columnOrder.map((t) => e.get(t)).filter((e) => !!e).filter((e) => !e.hidden && !t.has(e.key));
|
|
50
|
+
}, [S, B]), { handleMouseDown: Ve, handleDoubleClick: He, getColumnWidth: Q, measureRef: Ue } = a({
|
|
51
|
+
columns: Z,
|
|
52
|
+
data: Y,
|
|
53
|
+
getCellContent: (e, t) => {
|
|
54
|
+
let n = Z.find((e) => e.key === t);
|
|
55
|
+
return n?.accessor ? n.accessor(e) : e[t];
|
|
56
|
+
},
|
|
57
|
+
tableRef: Ne,
|
|
58
|
+
...B ? {
|
|
59
|
+
controlledWidths: B.columnWidths,
|
|
60
|
+
onColumnWidthsChange: B.onColumnWidthsChange
|
|
61
|
+
} : { storageKey: Ae }
|
|
62
|
+
}), We = re(), Ge = oe(De), Ke = ae(Oe), qe = m(() => {
|
|
63
|
+
let e = {};
|
|
64
|
+
return M && (e.height = typeof M == "number" ? `${M}px` : M), N && (e.maxHeight = typeof N == "number" ? `${N}px` : N), e;
|
|
65
|
+
}, [M, N]), { emptyRowCount: Je, measuredRowHeight: Ye } = o({
|
|
66
|
+
enabled: V,
|
|
67
|
+
containerRef: X,
|
|
68
|
+
theadRef: Pe,
|
|
69
|
+
tbodyRef: Fe,
|
|
70
|
+
excludeRowsSelector: "tr:not([data-empty-row]):not([data-expanded-row])",
|
|
71
|
+
remainingMode: "tbody-height",
|
|
72
|
+
observeTbody: !0,
|
|
73
|
+
deps: [Y, Z]
|
|
74
|
+
});
|
|
75
|
+
le(() => {
|
|
76
|
+
if (!J || !q) return;
|
|
77
|
+
let e = X.current;
|
|
78
|
+
if (!e) return;
|
|
79
|
+
let t = () => {
|
|
80
|
+
Le((t) => t === e.clientWidth ? t : e.clientWidth);
|
|
81
|
+
};
|
|
82
|
+
t();
|
|
83
|
+
let n = new ResizeObserver(t);
|
|
84
|
+
return n.observe(e), () => n.disconnect();
|
|
85
|
+
}, [J, q]);
|
|
86
|
+
let Xe = (e) => {
|
|
87
|
+
e.altKey || e.metaKey || e.ctrlKey || e.shiftKey || (e.key === "ArrowLeft" && P > 1 ? (e.preventDefault(), I(P - 1)) : e.key === "ArrowRight" && P < F && (e.preventDefault(), I(P + 1)));
|
|
88
|
+
}, $ = (e) => !D || T.length === 0 ? !1 : we ? T.some((t) => we(t, e)) : T.some((t) => t === e), Ze = m(() => !D || !O || Y.length === 0 ? !1 : Y.every((e) => $(e)), [
|
|
89
|
+
D,
|
|
90
|
+
O,
|
|
91
|
+
Y,
|
|
92
|
+
$
|
|
93
|
+
]), Qe = () => {
|
|
94
|
+
!D || !E || (Ze ? Y.forEach((e) => {
|
|
95
|
+
$(e) && E(e, !1);
|
|
96
|
+
}) : Y.forEach((e) => {
|
|
97
|
+
$(e) || E(e, !0);
|
|
98
|
+
}));
|
|
99
|
+
}, $e = (e, t) => {
|
|
100
|
+
let n = [c(t)];
|
|
101
|
+
return $(e) && n.push(ne()), (w || q) && n.push(te()), n.join(" ");
|
|
102
|
+
}, et = !!R || z !== void 0 || typeof F == "number" && F > 0, tt = (e) => {
|
|
103
|
+
U && U.onToggle(U.getRowId(e));
|
|
104
|
+
}, nt = (e, t) => {
|
|
105
|
+
q && (e.key === " " || e.key === "Enter") && (e.preventDefault(), tt(t));
|
|
106
|
+
}, rt = (D && O ? 1 : 0) + +!!q + Z.length + 1;
|
|
107
|
+
return Se ? /* @__PURE__ */ g("div", {
|
|
108
|
+
ref: b,
|
|
109
|
+
className: `flex items-center justify-center p-8 flex-1 ${W}`,
|
|
110
|
+
style: qe,
|
|
111
|
+
"data-testid": G,
|
|
112
|
+
...K,
|
|
113
|
+
children: /* @__PURE__ */ g(n, {
|
|
114
|
+
message: "데이터를 불러오는 중이에요...",
|
|
115
|
+
className: "min-h-0"
|
|
116
|
+
})
|
|
117
|
+
}) : /* @__PURE__ */ _("div", {
|
|
118
|
+
ref: b,
|
|
119
|
+
className: `relative flex flex-col min-h-0 ${W}`,
|
|
120
|
+
style: qe,
|
|
121
|
+
"data-testid": G,
|
|
122
|
+
...K,
|
|
123
|
+
children: [/* @__PURE__ */ g("div", {
|
|
124
|
+
ref: Ue,
|
|
125
|
+
className: "absolute invisible whitespace-nowrap",
|
|
126
|
+
style: {
|
|
127
|
+
top: "-9999px",
|
|
128
|
+
left: "-9999px"
|
|
129
|
+
}
|
|
130
|
+
}), /* @__PURE__ */ _("div", {
|
|
131
|
+
className: "flex flex-1 flex-col min-h-0",
|
|
132
|
+
children: [/* @__PURE__ */ g("div", {
|
|
133
|
+
ref: X,
|
|
134
|
+
className: "overflow-auto flex-1 bg-[#f9fafb] dark:bg-slate-900/50",
|
|
135
|
+
children: Y.length === 0 ? /* @__PURE__ */ g("div", {
|
|
136
|
+
className: "flex items-center justify-center p-8 h-full",
|
|
137
|
+
children: /* @__PURE__ */ g("p", {
|
|
138
|
+
className: "text-neutral-600 dark:text-neutral-400",
|
|
139
|
+
children: Ce
|
|
140
|
+
})
|
|
141
|
+
}) : /* @__PURE__ */ g(fe, {
|
|
142
|
+
sensors: ze,
|
|
143
|
+
collisionDetection: he,
|
|
144
|
+
onDragEnd: Be,
|
|
145
|
+
children: /* @__PURE__ */ _("table", {
|
|
146
|
+
ref: Ne,
|
|
147
|
+
className: `${We} ${Ge} ${Ke}`,
|
|
148
|
+
style: {
|
|
149
|
+
tableLayout: "fixed",
|
|
150
|
+
minWidth: "100%",
|
|
151
|
+
width: "100%"
|
|
152
|
+
},
|
|
153
|
+
children: [
|
|
154
|
+
/* @__PURE__ */ _("colgroup", { children: [
|
|
155
|
+
D && O && /* @__PURE__ */ g("col", { style: { width: "48px" } }),
|
|
156
|
+
q && /* @__PURE__ */ g("col", { style: { width: `${y}px` } }),
|
|
157
|
+
Z.map((e) => /* @__PURE__ */ g("col", {
|
|
158
|
+
"data-col-key": e.key,
|
|
159
|
+
style: { width: Q(e.key, e.width) }
|
|
160
|
+
}, e.key)),
|
|
161
|
+
/* @__PURE__ */ g("col", { style: { width: "100%" } })
|
|
162
|
+
] }),
|
|
163
|
+
/* @__PURE__ */ g("thead", {
|
|
164
|
+
ref: Pe,
|
|
165
|
+
className: ie(),
|
|
166
|
+
style: {
|
|
167
|
+
position: j ? "sticky" : "relative",
|
|
168
|
+
top: j ? 0 : void 0,
|
|
169
|
+
zIndex: j ? 10 : void 0,
|
|
170
|
+
backgroundColor: j ? "white" : void 0
|
|
171
|
+
},
|
|
172
|
+
children: /* @__PURE__ */ _("tr", { children: [
|
|
173
|
+
D && O && /* @__PURE__ */ g("th", {
|
|
174
|
+
className: `${u()} ${s("center")} border-r-0 w-12`,
|
|
175
|
+
children: /* @__PURE__ */ g(e.Circle, {
|
|
176
|
+
id: "accordion-table-select-all",
|
|
177
|
+
size: 20,
|
|
178
|
+
checked: Ze,
|
|
179
|
+
onCheckedChange: Qe
|
|
180
|
+
})
|
|
181
|
+
}),
|
|
182
|
+
q && /* @__PURE__ */ g("th", {
|
|
183
|
+
"aria-hidden": "true",
|
|
184
|
+
className: `${u()} border-r-0`,
|
|
185
|
+
style: { width: `${y}px` }
|
|
186
|
+
}),
|
|
187
|
+
/* @__PURE__ */ g(_e, {
|
|
188
|
+
items: Z.map((e) => e.key),
|
|
189
|
+
strategy: ye,
|
|
190
|
+
children: Z.map((e) => {
|
|
191
|
+
let t = !Re || e.excludeFromPreset === !0;
|
|
192
|
+
return /* @__PURE__ */ _(i, {
|
|
193
|
+
id: e.key,
|
|
194
|
+
disabled: t,
|
|
195
|
+
as: "th",
|
|
196
|
+
className: `${u()} ${s("center")} bg-white ${e.sticky ? "sticky left-0 z-20 bg-white dark:bg-neutral-800" : ""} ${e.hideOnMobile ? "hidden md:table-cell" : ""} relative`,
|
|
197
|
+
style: {
|
|
198
|
+
width: Q(e.key, e.width),
|
|
199
|
+
minWidth: e.minWidth || 50
|
|
200
|
+
},
|
|
201
|
+
children: [/* @__PURE__ */ g("div", {
|
|
202
|
+
className: "flex items-center justify-center w-full pr-1 select-none",
|
|
203
|
+
children: /* @__PURE__ */ g("span", { children: e.header })
|
|
204
|
+
}), e.excludeFromPreset !== !0 && /* @__PURE__ */ g("div", {
|
|
205
|
+
className: "absolute right-0 top-0 h-full w-4 cursor-col-resize hover:bg-primary-500/30 active:bg-primary-500/50 z-50",
|
|
206
|
+
onPointerDown: (e) => e.stopPropagation(),
|
|
207
|
+
onMouseDown: (t) => {
|
|
208
|
+
t.preventDefault(), t.stopPropagation(), Ve(e.key, t);
|
|
209
|
+
},
|
|
210
|
+
onDoubleClick: (t) => {
|
|
211
|
+
t.preventDefault(), t.stopPropagation(), He(e.key, t);
|
|
212
|
+
},
|
|
213
|
+
onClick: (e) => {
|
|
214
|
+
e.preventDefault(), e.stopPropagation();
|
|
215
|
+
},
|
|
216
|
+
style: { touchAction: "none" },
|
|
217
|
+
title: "드래그하여 너비 조절, 더블 클릭하여 자동 조절"
|
|
218
|
+
})]
|
|
219
|
+
}, e.key);
|
|
220
|
+
})
|
|
221
|
+
}),
|
|
222
|
+
/* @__PURE__ */ g("th", {
|
|
223
|
+
"aria-hidden": "true",
|
|
224
|
+
className: "bg-white border-b border-l border-[#f2f3f5] dark:border-neutral-700 dark:bg-neutral-800"
|
|
225
|
+
})
|
|
226
|
+
] })
|
|
227
|
+
}),
|
|
228
|
+
/* @__PURE__ */ _("tbody", {
|
|
229
|
+
ref: Fe,
|
|
230
|
+
children: [Y.map((n, r) => {
|
|
231
|
+
let i = $(n), a = U ? U.getRowId(n) : void 0, o = U ? U.expandedIds.has(a) : !1;
|
|
232
|
+
return /* @__PURE__ */ _(ce, { children: [/* @__PURE__ */ _("tr", {
|
|
233
|
+
className: $e(n, r),
|
|
234
|
+
onClick: (e) => {
|
|
235
|
+
let t = e.target;
|
|
236
|
+
if (t !== e.currentTarget) {
|
|
237
|
+
let n = t.closest("button, a, input, select, textarea, label");
|
|
238
|
+
if (n && e.currentTarget.contains(n)) return;
|
|
239
|
+
}
|
|
240
|
+
w?.(n, r), q && tt(n);
|
|
241
|
+
},
|
|
242
|
+
onKeyDown: (e) => nt(e, n),
|
|
243
|
+
tabIndex: q ? 0 : void 0,
|
|
244
|
+
role: q ? "button" : void 0,
|
|
245
|
+
"aria-expanded": q ? o : void 0,
|
|
246
|
+
style: C ? { height: `${C}px` } : void 0,
|
|
247
|
+
children: [
|
|
248
|
+
D && O && /* @__PURE__ */ g("td", {
|
|
249
|
+
className: `${l()} ${s("center")} border-r-0 w-12`,
|
|
250
|
+
onClick: (e) => e.stopPropagation(),
|
|
251
|
+
children: /* @__PURE__ */ g(e.Circle, {
|
|
252
|
+
size: 20,
|
|
253
|
+
checked: i,
|
|
254
|
+
onCheckedChange: (e) => E?.(n, e)
|
|
255
|
+
})
|
|
256
|
+
}),
|
|
257
|
+
q && /* @__PURE__ */ g("td", {
|
|
258
|
+
className: `${l()} ${s("center")} border-r-0`,
|
|
259
|
+
style: { width: `${y}px` },
|
|
260
|
+
children: /* @__PURE__ */ g(t, {
|
|
261
|
+
"aria-hidden": "true",
|
|
262
|
+
className: `mx-auto h-4 w-4 text-neutral-500 transition-transform duration-200 ${o ? "rotate-90" : ""}`
|
|
263
|
+
})
|
|
264
|
+
}),
|
|
265
|
+
Z.map((e, t) => {
|
|
266
|
+
let r = e.accessor ? e.accessor(n) : n[e.key], i = t === Z.length - 1 && !D;
|
|
267
|
+
return /* @__PURE__ */ g("td", {
|
|
268
|
+
className: `${l()} ${s(e.align)} ${i ? "border-r-0" : ""} ${e.sticky ? "sticky left-0 z-10 bg-inherit" : ""} ${e.hideOnMobile ? "hidden md:table-cell" : ""}`,
|
|
269
|
+
style: {
|
|
270
|
+
width: Q(e.key, e.width),
|
|
271
|
+
minWidth: e.minWidth || 50,
|
|
272
|
+
...C ? {
|
|
273
|
+
height: `${C}px`,
|
|
274
|
+
maxHeight: `${C}px`,
|
|
275
|
+
overflow: "hidden"
|
|
276
|
+
} : {}
|
|
277
|
+
},
|
|
278
|
+
children: r
|
|
279
|
+
}, e.key);
|
|
280
|
+
}),
|
|
281
|
+
/* @__PURE__ */ g("td", {
|
|
282
|
+
"aria-hidden": "true",
|
|
283
|
+
className: "border-b border-l border-[#f2f3f5] dark:border-neutral-700 bg-transparent"
|
|
284
|
+
})
|
|
285
|
+
]
|
|
286
|
+
}), q && /* @__PURE__ */ g("tr", {
|
|
287
|
+
"data-expanded-row": !0,
|
|
288
|
+
className: "bg-[#f9fafb] dark:bg-slate-900/50",
|
|
289
|
+
children: /* @__PURE__ */ g("td", {
|
|
290
|
+
colSpan: rt,
|
|
291
|
+
className: "p-0 border-b border-[#f2f3f5] dark:border-neutral-700",
|
|
292
|
+
children: /* @__PURE__ */ g("div", {
|
|
293
|
+
className: J ? "sticky left-0" : void 0,
|
|
294
|
+
style: J && Ie > 0 ? { width: `${Ie}px` } : void 0,
|
|
295
|
+
children: /* @__PURE__ */ g("div", {
|
|
296
|
+
className: "grid transition-[grid-template-rows,opacity] duration-200 ease-out",
|
|
297
|
+
style: {
|
|
298
|
+
gridTemplateRows: o ? "1fr" : "0fr",
|
|
299
|
+
opacity: +!!o
|
|
300
|
+
},
|
|
301
|
+
"aria-hidden": !o,
|
|
302
|
+
children: /* @__PURE__ */ g("div", {
|
|
303
|
+
className: "overflow-hidden",
|
|
304
|
+
children: U.renderRow(n)
|
|
305
|
+
})
|
|
306
|
+
})
|
|
307
|
+
})
|
|
308
|
+
})
|
|
309
|
+
})] }, r);
|
|
310
|
+
}), V && Array.from({ length: Je }).map((e, t) => {
|
|
311
|
+
let n = Y.length + t, r = C ?? Ye ?? void 0;
|
|
312
|
+
return /* @__PURE__ */ _("tr", {
|
|
313
|
+
"data-empty-row": !0,
|
|
314
|
+
"aria-hidden": "true",
|
|
315
|
+
className: c(n),
|
|
316
|
+
style: r ? { height: `${r}px` } : void 0,
|
|
317
|
+
children: [
|
|
318
|
+
D && O && /* @__PURE__ */ g("td", {
|
|
319
|
+
className: `${l()} border-r-0 w-12`,
|
|
320
|
+
style: r ? { height: `${r}px` } : void 0
|
|
321
|
+
}),
|
|
322
|
+
q && /* @__PURE__ */ g("td", {
|
|
323
|
+
className: `${l()} border-r-0`,
|
|
324
|
+
style: {
|
|
325
|
+
width: `${y}px`,
|
|
326
|
+
...r ? { height: `${r}px` } : {}
|
|
327
|
+
}
|
|
328
|
+
}),
|
|
329
|
+
Z.map((e, t) => {
|
|
330
|
+
let n = t === Z.length - 1 && !D;
|
|
331
|
+
return /* @__PURE__ */ g("td", {
|
|
332
|
+
className: `${l()} ${n ? "border-r-0" : ""} ${e.hideOnMobile ? "hidden md:table-cell" : ""}`,
|
|
333
|
+
style: {
|
|
334
|
+
width: Q(e.key, e.width),
|
|
335
|
+
minWidth: e.minWidth || 50,
|
|
336
|
+
...r ? { height: `${r}px` } : {}
|
|
337
|
+
}
|
|
338
|
+
}, e.key);
|
|
339
|
+
}),
|
|
340
|
+
/* @__PURE__ */ g("td", {
|
|
341
|
+
"aria-hidden": "true",
|
|
342
|
+
className: "border-b border-l border-[#f2f3f5] dark:border-neutral-700 bg-transparent",
|
|
343
|
+
style: r ? { height: `${r}px` } : void 0
|
|
344
|
+
})
|
|
345
|
+
]
|
|
346
|
+
}, `empty-${t}`);
|
|
347
|
+
})]
|
|
348
|
+
})
|
|
349
|
+
]
|
|
350
|
+
})
|
|
351
|
+
})
|
|
352
|
+
}), et && /* @__PURE__ */ _("nav", {
|
|
353
|
+
"aria-label": "페이지 네비게이션",
|
|
354
|
+
className: "@container/pagebar group/footer flex flex-wrap items-center justify-between gap-x-3 gap-y-2 border-t border-neutral-200 px-4 py-2 shrink-0 dark:border-neutral-700",
|
|
355
|
+
children: [/* @__PURE__ */ _("div", {
|
|
356
|
+
className: "flex flex-wrap items-center gap-x-3 gap-y-2 text-sm text-neutral-600 dark:text-neutral-300",
|
|
357
|
+
children: [
|
|
358
|
+
z !== void 0 && /* @__PURE__ */ _("span", { children: [
|
|
359
|
+
"총 ",
|
|
360
|
+
z.toLocaleString(),
|
|
361
|
+
"건"
|
|
362
|
+
] }),
|
|
363
|
+
R && L !== void 0 && /* @__PURE__ */ _("div", {
|
|
364
|
+
className: "flex items-center gap-1",
|
|
365
|
+
children: [/* @__PURE__ */ g("span", {
|
|
366
|
+
className: "text-neutral-500",
|
|
367
|
+
children: "페이지당"
|
|
368
|
+
}), /* @__PURE__ */ g("div", {
|
|
369
|
+
className: "w-20",
|
|
370
|
+
children: /* @__PURE__ */ g(r, {
|
|
371
|
+
variant: "box",
|
|
372
|
+
selectSize: "mini",
|
|
373
|
+
value: String(L),
|
|
374
|
+
onChange: (e) => R(Number(e)),
|
|
375
|
+
options: ke.map((e) => ({
|
|
376
|
+
value: String(e),
|
|
377
|
+
label: String(e)
|
|
378
|
+
})),
|
|
379
|
+
"data-testid": G ? `${G}-page-size` : void 0
|
|
380
|
+
})
|
|
381
|
+
})]
|
|
382
|
+
}),
|
|
383
|
+
/* @__PURE__ */ g("div", {
|
|
384
|
+
className: "contents @min-[640px]/pagebar:hidden",
|
|
385
|
+
children: F !== void 0 && P !== void 0 && I && F > 1 && /* @__PURE__ */ _(de, { children: [/* @__PURE__ */ g(f, {
|
|
386
|
+
currentPage: P,
|
|
387
|
+
totalPages: F,
|
|
388
|
+
onPageChange: I,
|
|
389
|
+
"data-testid": G ? `${G}-page-jump` : void 0
|
|
390
|
+
}), H && /* @__PURE__ */ g(d, { onKeyDown: Xe })] })
|
|
391
|
+
})
|
|
392
|
+
]
|
|
393
|
+
}), /* @__PURE__ */ _("div", {
|
|
394
|
+
className: "flex items-center gap-3",
|
|
395
|
+
children: [/* @__PURE__ */ g("div", {
|
|
396
|
+
className: "hidden @min-[640px]/pagebar:contents",
|
|
397
|
+
children: F !== void 0 && P !== void 0 && I && F > 1 && /* @__PURE__ */ _(de, { children: [/* @__PURE__ */ g(f, {
|
|
398
|
+
currentPage: P,
|
|
399
|
+
totalPages: F,
|
|
400
|
+
onPageChange: I,
|
|
401
|
+
"data-testid": G ? `${G}-page-jump` : void 0
|
|
402
|
+
}), H && /* @__PURE__ */ g(d, { onKeyDown: Xe })] })
|
|
403
|
+
}), F !== void 0 && P !== void 0 && I && /* @__PURE__ */ g(se, {
|
|
404
|
+
currentPage: P,
|
|
405
|
+
totalPages: F,
|
|
406
|
+
onPageChange: I,
|
|
407
|
+
hasPreviousPage: P > 1,
|
|
408
|
+
hasNextPage: P < F,
|
|
409
|
+
"data-testid": G ? `${G}-pagination` : void 0
|
|
410
|
+
})]
|
|
411
|
+
})]
|
|
412
|
+
})]
|
|
413
|
+
})]
|
|
414
|
+
});
|
|
415
|
+
});
|
|
416
|
+
b.displayName = "AccordionTable";
|
|
417
|
+
//#endregion
|
|
418
|
+
export { b as AccordionTable };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
function e(e,t=[]){if(t.length===0)return e.map(e=>({kind:`column`,key:e.key,header:e.header,leafColumns:[e],hideOnMobile:e.hideOnMobile}));let n=new Map(e.map(e=>[e.key,e])),r=new Map;for(let e of t)for(let t of e.columnKeys)r.set(t,e.key);let i=[],a=new Set;for(let o of e){let e=r.get(o.key);if(e){if(a.has(e))continue;a.add(e);let r=t.find(t=>t.key===e);if(!r)continue;let o=r.columnKeys.map(e=>n.get(e)).filter(e=>!!e);i.push({kind:`group`,key:r.key,header:r.header,leafColumns:o,hideOnMobile:r.hideOnMobile,group:r})}else i.push({kind:`column`,key:o.key,header:o.header,leafColumns:[o],hideOnMobile:o.hideOnMobile})}return i}function t(e){return e.map(e=>e.key)}function n(e,t,n){let r=new Map(e.map(e=>[e.key,e])),i=new Set(t),a=t.map(e=>r.get(e)).filter(e=>!!e),o=e.filter(e=>!i.has(e.key));return[...a,...o].filter(e=>!(n.has(e.key)||e.kind===`column`&&e.leafColumns[0].hidden))}function r(e){return e.flatMap(e=>e.leafColumns)}function i(e){return e.some(e=>e.kind===`group`)}exports.applyColumnState=n,exports.buildColumnSlots=e,exports.flattenLeafColumns=r,exports.getDefaultSlotOrder=t,exports.hasGroupSlot=i;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
//#region src/components/table/column-group-utils.ts
|
|
2
|
+
function e(e, t = []) {
|
|
3
|
+
if (t.length === 0) return e.map((e) => ({
|
|
4
|
+
kind: "column",
|
|
5
|
+
key: e.key,
|
|
6
|
+
header: e.header,
|
|
7
|
+
leafColumns: [e],
|
|
8
|
+
hideOnMobile: e.hideOnMobile
|
|
9
|
+
}));
|
|
10
|
+
let n = new Map(e.map((e) => [e.key, e])), r = /* @__PURE__ */ new Map();
|
|
11
|
+
for (let e of t) for (let t of e.columnKeys) r.set(t, e.key);
|
|
12
|
+
let i = [], a = /* @__PURE__ */ new Set();
|
|
13
|
+
for (let o of e) {
|
|
14
|
+
let e = r.get(o.key);
|
|
15
|
+
if (e) {
|
|
16
|
+
if (a.has(e)) continue;
|
|
17
|
+
a.add(e);
|
|
18
|
+
let r = t.find((t) => t.key === e);
|
|
19
|
+
if (!r) continue;
|
|
20
|
+
let o = r.columnKeys.map((e) => n.get(e)).filter((e) => !!e);
|
|
21
|
+
i.push({
|
|
22
|
+
kind: "group",
|
|
23
|
+
key: r.key,
|
|
24
|
+
header: r.header,
|
|
25
|
+
leafColumns: o,
|
|
26
|
+
hideOnMobile: r.hideOnMobile,
|
|
27
|
+
group: r
|
|
28
|
+
});
|
|
29
|
+
} else i.push({
|
|
30
|
+
kind: "column",
|
|
31
|
+
key: o.key,
|
|
32
|
+
header: o.header,
|
|
33
|
+
leafColumns: [o],
|
|
34
|
+
hideOnMobile: o.hideOnMobile
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
return i;
|
|
38
|
+
}
|
|
39
|
+
function t(e) {
|
|
40
|
+
return e.map((e) => e.key);
|
|
41
|
+
}
|
|
42
|
+
function n(e, t, n) {
|
|
43
|
+
let r = new Map(e.map((e) => [e.key, e])), i = new Set(t), a = t.map((e) => r.get(e)).filter((e) => !!e), o = e.filter((e) => !i.has(e.key));
|
|
44
|
+
return [...a, ...o].filter((e) => !(n.has(e.key) || e.kind === "column" && e.leafColumns[0].hidden));
|
|
45
|
+
}
|
|
46
|
+
function r(e) {
|
|
47
|
+
return e.flatMap((e) => e.leafColumns);
|
|
48
|
+
}
|
|
49
|
+
function i(e) {
|
|
50
|
+
return e.some((e) => e.kind === "group");
|
|
51
|
+
}
|
|
52
|
+
//#endregion
|
|
53
|
+
export { n as applyColumnState, e as buildColumnSlots, r as flattenLeafColumns, t as getDefaultSlotOrder, i as hasGroupSlot };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e=require("../../../_virtual/_rolldown/runtime.cjs.js"),t=require("../../../node_modules/lucide-react/dist/esm/icons/settings.cjs.js"),n=require("../../../hooks/useMediaQuery.cjs.js"),r=require("../../modal/Modal.cjs.js"),i=require("./ColumnSettingsTable.cjs.js");let a=require("react"),o=require("react/jsx-runtime"),s=require("motion/react"),c=require("@floating-ui/react"),l=require("react-hot-toast");l=e.__toESM(l,1);var u=500,d=12,f=5,p=[1,2,3];function m({columns:e,columnGroups:m,activePreset:h,columnOrder:g,hiddenColumns:_,columnWidths:v,isDirty:y,hasPreset:b,onApplyPreset:x,onSaveActivePreset:S,onResetActivePreset:C,onColumnOrderChange:w,onHiddenColumnsChange:T,onSetColumnWidth:E,className:D=``}){let O=e.filter(e=>!e.excludeFromPreset),k=new Set(e.filter(e=>e.excludeFromPreset).map(e=>e.key)),[A,j]=(0,a.useState)(!1),M=n.useIsMobile(),N=(0,a.useId)(),{refs:P,floatingStyles:F,context:I}=(0,c.useFloating)({open:!M&&A,onOpenChange:j,placement:`bottom-start`,whileElementsMounted:c.autoUpdate,middleware:[(0,c.offset)(f),(0,c.flip)(),(0,c.shift)({padding:d}),(0,c.size)({apply({availableWidth:e,elements:t}){let n=Math.min(u,e);Object.assign(t.floating.style,{width:`${n}px`,maxWidth:`${u}px`})}})]}),{getReferenceProps:L,getFloatingProps:R}=(0,c.useInteractions)([(0,c.useClick)(I),(0,c.useDismiss)(I),(0,c.useRole)(I,{role:`dialog`})]),z=e=>{h!==e&&(x(e),j(!1),l.default.success(`프리셋 ${e}을(를) 적용했어요.`))},B=e=>{let t=g.map((e,t)=>({key:e,index:t})).filter(({key:e})=>k.has(e)),n=[...e];t.sort((e,t)=>e.index-t.index).forEach(({key:e,index:t})=>{let r=Math.min(t,n.length);n.splice(r,0,e)}),w(n)},V=(e,t)=>{if(t)T(_.filter(t=>t!==e));else{if(g.length-k.size-_.filter(e=>!k.has(e)).length<=1){l.default.error(`최소 1개 이상의 컬럼은 표시되어야 해요.`);return}T([..._,e])}},H=()=>{if(!S()){l.default.error(`저장할 수 없는 상태예요.`);return}j(!1),l.default.success(`프리셋 ${h}에 저장했어요.`)},U=()=>{C(),j(!1),l.default.success(`프리셋 ${h}을(를) 초기화했어요.`)},W=g.filter(e=>!k.has(e)),G=_.filter(e=>!k.has(e));return(0,o.jsxs)(`div`,{className:`inline-flex ${D}`,children:[(0,o.jsxs)(`div`,{className:`inline-flex h-7.5 items-center gap-0 rounded-full bg-bg-base-secondary p-0.75 sm:h-8.5`,role:`group`,"aria-label":`컬럼 프리셋 선택`,children:[(0,o.jsxs)(`button`,{ref:P.setReference,...M?{type:`button`,onClick:()=>j(e=>!e),"aria-label":`테이블 프리셋 설정`,title:y?`저장하지 않은 변경이 있어요`:`테이블 프리셋 설정`,className:`relative ml-1 flex h-6 w-6 items-center justify-center rounded-full text-text-secondary transition-colors hover:text-text-primary sm:h-7 sm:w-7`}:L({type:`button`,"aria-label":`테이블 프리셋 설정`,title:y?`저장하지 않은 변경이 있어요`:`테이블 프리셋 설정`,className:`relative ml-1 flex h-6 w-6 items-center justify-center rounded-full text-text-secondary transition-colors hover:text-text-primary sm:h-7 sm:w-7`}),children:[(0,o.jsx)(t.Settings,{className:`h-3 w-3 sm:h-3.5 sm:w-3.5`}),y&&(0,o.jsx)(`span`,{"aria-hidden":`true`,className:`absolute top-0.5 right-0.5 h-1.5 w-1.5 rounded-full bg-brand-blue-secondary`})]}),(0,o.jsx)(`span`,{"aria-hidden":`true`,className:`ml-0.5 mr-1.5 h-4 w-px bg-bg-base-tertiary sm:h-4.5`}),p.map(e=>{let t=h===e;return(0,o.jsxs)(`button`,{type:`button`,onClick:()=>z(e),"aria-pressed":t,title:t?`현재 활성화된 프리셋이에요`:b(e)?`프리셋 ${e} 적용`:`프리셋 ${e} 기본값으로 초기화`,className:`relative inline-flex h-6 w-8 items-center justify-center rounded-full px-2.5 py-1 text-sm font-medium transition-colors sm:h-7 sm:w-20 ${t?`text-text-primary`:`text-text-secondary`}`,children:[t&&(0,o.jsx)(s.motion.span,{layoutId:`preset-active-${N}`,className:`absolute inset-0 rounded-full bg-white shadow-sm dark:bg-bg-base-tertiary`,transition:{type:`spring`,stiffness:500,damping:38}}),(0,o.jsxs)(`span`,{className:`relative`,children:[(0,o.jsx)(`span`,{className:`hidden sm:inline`,children:`프리셋`}),e]})]},e)})]}),!M&&A&&(0,o.jsx)(c.FloatingPortal,{children:(0,o.jsx)(`div`,{ref:P.setFloating,style:F,...R(),className:`z-50 overflow-hidden rounded-lg border-2 border-neutral-200 shadow-lg dark:border-neutral-700`,children:(0,o.jsx)(i.ColumnSettingsTable,{num:String(h),columns:O,columnGroups:m,columnOrder:W,hiddenColumns:G,columnWidths:v,onOrderChange:B,onHiddenChange:V,onSetColumnWidth:E,onSave:H,onReset:U})})}),M&&(0,o.jsx)(r.Modal,{isOpen:A,onClose:()=>j(!1),title:`프리셋 ${h} 설정`,children:(0,o.jsx)(i.ColumnSettingsTable,{num:String(h),columns:O,columnOrder:W,hiddenColumns:G,columnWidths:v,onOrderChange:B,onHiddenChange:V,onSetColumnWidth:E,onSave:H,onReset:U})})]})}exports.ColumnPresetSelector=m;
|