@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,165 @@
|
|
|
1
|
+
import { Settings as e } from "../../../node_modules/lucide-react/dist/esm/icons/settings.esm.js";
|
|
2
|
+
import { useIsMobile as t } from "../../../hooks/useMediaQuery.esm.js";
|
|
3
|
+
import { Modal as n } from "../../modal/Modal.esm.js";
|
|
4
|
+
import { ColumnSettingsTable as r } from "./ColumnSettingsTable.esm.js";
|
|
5
|
+
import { useId as ee, useState as i } from "react";
|
|
6
|
+
import { jsx as a, jsxs as o } from "react/jsx-runtime";
|
|
7
|
+
import { motion as te } from "motion/react";
|
|
8
|
+
import { FloatingPortal as s, autoUpdate as c, flip as l, offset as u, shift as d, size as f, useClick as p, useDismiss as ne, useFloating as re, useInteractions as m, useRole as h } from "@floating-ui/react";
|
|
9
|
+
import g from "react-hot-toast";
|
|
10
|
+
//#region src/components/table/components/ColumnPresetSelector.tsx
|
|
11
|
+
var _ = 500, v = 12, y = 5, b = [
|
|
12
|
+
1,
|
|
13
|
+
2,
|
|
14
|
+
3
|
|
15
|
+
];
|
|
16
|
+
function x({ columns: x, columnGroups: S, activePreset: C, columnOrder: w, hiddenColumns: T, columnWidths: E, isDirty: D, hasPreset: O, onApplyPreset: k, onSaveActivePreset: A, onResetActivePreset: j, onColumnOrderChange: M, onHiddenColumnsChange: N, onSetColumnWidth: P, className: F = "" }) {
|
|
17
|
+
let I = x.filter((e) => !e.excludeFromPreset), L = new Set(x.filter((e) => e.excludeFromPreset).map((e) => e.key)), [R, z] = i(!1), B = t(), V = ee(), { refs: H, floatingStyles: U, context: W } = re({
|
|
18
|
+
open: !B && R,
|
|
19
|
+
onOpenChange: z,
|
|
20
|
+
placement: "bottom-start",
|
|
21
|
+
whileElementsMounted: c,
|
|
22
|
+
middleware: [
|
|
23
|
+
u(y),
|
|
24
|
+
l(),
|
|
25
|
+
d({ padding: v }),
|
|
26
|
+
f({ apply({ availableWidth: e, elements: t }) {
|
|
27
|
+
let n = Math.min(_, e);
|
|
28
|
+
Object.assign(t.floating.style, {
|
|
29
|
+
width: `${n}px`,
|
|
30
|
+
maxWidth: `${_}px`
|
|
31
|
+
});
|
|
32
|
+
} })
|
|
33
|
+
]
|
|
34
|
+
}), { getReferenceProps: G, getFloatingProps: K } = m([
|
|
35
|
+
p(W),
|
|
36
|
+
ne(W),
|
|
37
|
+
h(W, { role: "dialog" })
|
|
38
|
+
]), q = (e) => {
|
|
39
|
+
C !== e && (k(e), z(!1), g.success(`프리셋 ${e}을(를) 적용했어요.`));
|
|
40
|
+
}, J = (e) => {
|
|
41
|
+
let t = w.map((e, t) => ({
|
|
42
|
+
key: e,
|
|
43
|
+
index: t
|
|
44
|
+
})).filter(({ key: e }) => L.has(e)), n = [...e];
|
|
45
|
+
t.sort((e, t) => e.index - t.index).forEach(({ key: e, index: t }) => {
|
|
46
|
+
let r = Math.min(t, n.length);
|
|
47
|
+
n.splice(r, 0, e);
|
|
48
|
+
}), M(n);
|
|
49
|
+
}, Y = (e, t) => {
|
|
50
|
+
if (t) N(T.filter((t) => t !== e));
|
|
51
|
+
else {
|
|
52
|
+
if (w.length - L.size - T.filter((e) => !L.has(e)).length <= 1) {
|
|
53
|
+
g.error("최소 1개 이상의 컬럼은 표시되어야 해요.");
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
N([...T, e]);
|
|
57
|
+
}
|
|
58
|
+
}, X = () => {
|
|
59
|
+
if (!A()) {
|
|
60
|
+
g.error("저장할 수 없는 상태예요.");
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
z(!1), g.success(`프리셋 ${C}에 저장했어요.`);
|
|
64
|
+
}, Z = () => {
|
|
65
|
+
j(), z(!1), g.success(`프리셋 ${C}을(를) 초기화했어요.`);
|
|
66
|
+
}, Q = w.filter((e) => !L.has(e)), $ = T.filter((e) => !L.has(e));
|
|
67
|
+
return /* @__PURE__ */ o("div", {
|
|
68
|
+
className: `inline-flex ${F}`,
|
|
69
|
+
children: [
|
|
70
|
+
/* @__PURE__ */ o("div", {
|
|
71
|
+
className: "inline-flex h-7.5 items-center gap-0 rounded-full bg-bg-base-secondary p-0.75 sm:h-8.5",
|
|
72
|
+
role: "group",
|
|
73
|
+
"aria-label": "컬럼 프리셋 선택",
|
|
74
|
+
children: [
|
|
75
|
+
/* @__PURE__ */ o("button", {
|
|
76
|
+
ref: H.setReference,
|
|
77
|
+
...B ? {
|
|
78
|
+
type: "button",
|
|
79
|
+
onClick: () => z((e) => !e),
|
|
80
|
+
"aria-label": "테이블 프리셋 설정",
|
|
81
|
+
title: D ? "저장하지 않은 변경이 있어요" : "테이블 프리셋 설정",
|
|
82
|
+
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"
|
|
83
|
+
} : G({
|
|
84
|
+
type: "button",
|
|
85
|
+
"aria-label": "테이블 프리셋 설정",
|
|
86
|
+
title: D ? "저장하지 않은 변경이 있어요" : "테이블 프리셋 설정",
|
|
87
|
+
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"
|
|
88
|
+
}),
|
|
89
|
+
children: [/* @__PURE__ */ a(e, { className: "h-3 w-3 sm:h-3.5 sm:w-3.5" }), D && /* @__PURE__ */ a("span", {
|
|
90
|
+
"aria-hidden": "true",
|
|
91
|
+
className: "absolute top-0.5 right-0.5 h-1.5 w-1.5 rounded-full bg-brand-blue-secondary"
|
|
92
|
+
})]
|
|
93
|
+
}),
|
|
94
|
+
/* @__PURE__ */ a("span", {
|
|
95
|
+
"aria-hidden": "true",
|
|
96
|
+
className: "ml-0.5 mr-1.5 h-4 w-px bg-bg-base-tertiary sm:h-4.5"
|
|
97
|
+
}),
|
|
98
|
+
b.map((e) => {
|
|
99
|
+
let t = C === e;
|
|
100
|
+
return /* @__PURE__ */ o("button", {
|
|
101
|
+
type: "button",
|
|
102
|
+
onClick: () => q(e),
|
|
103
|
+
"aria-pressed": t,
|
|
104
|
+
title: t ? "현재 활성화된 프리셋이에요" : O(e) ? `프리셋 ${e} 적용` : `프리셋 ${e} 기본값으로 초기화`,
|
|
105
|
+
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"}`,
|
|
106
|
+
children: [t && /* @__PURE__ */ a(te.span, {
|
|
107
|
+
layoutId: `preset-active-${V}`,
|
|
108
|
+
className: "absolute inset-0 rounded-full bg-white shadow-sm dark:bg-bg-base-tertiary",
|
|
109
|
+
transition: {
|
|
110
|
+
type: "spring",
|
|
111
|
+
stiffness: 500,
|
|
112
|
+
damping: 38
|
|
113
|
+
}
|
|
114
|
+
}), /* @__PURE__ */ o("span", {
|
|
115
|
+
className: "relative",
|
|
116
|
+
children: [/* @__PURE__ */ a("span", {
|
|
117
|
+
className: "hidden sm:inline",
|
|
118
|
+
children: "프리셋"
|
|
119
|
+
}), e]
|
|
120
|
+
})]
|
|
121
|
+
}, e);
|
|
122
|
+
})
|
|
123
|
+
]
|
|
124
|
+
}),
|
|
125
|
+
!B && R && /* @__PURE__ */ a(s, { children: /* @__PURE__ */ a("div", {
|
|
126
|
+
ref: H.setFloating,
|
|
127
|
+
style: U,
|
|
128
|
+
...K(),
|
|
129
|
+
className: "z-50 overflow-hidden rounded-lg border-2 border-neutral-200 shadow-lg dark:border-neutral-700",
|
|
130
|
+
children: /* @__PURE__ */ a(r, {
|
|
131
|
+
num: String(C),
|
|
132
|
+
columns: I,
|
|
133
|
+
columnGroups: S,
|
|
134
|
+
columnOrder: Q,
|
|
135
|
+
hiddenColumns: $,
|
|
136
|
+
columnWidths: E,
|
|
137
|
+
onOrderChange: J,
|
|
138
|
+
onHiddenChange: Y,
|
|
139
|
+
onSetColumnWidth: P,
|
|
140
|
+
onSave: X,
|
|
141
|
+
onReset: Z
|
|
142
|
+
})
|
|
143
|
+
}) }),
|
|
144
|
+
B && /* @__PURE__ */ a(n, {
|
|
145
|
+
isOpen: R,
|
|
146
|
+
onClose: () => z(!1),
|
|
147
|
+
title: `프리셋 ${C} 설정`,
|
|
148
|
+
children: /* @__PURE__ */ a(r, {
|
|
149
|
+
num: String(C),
|
|
150
|
+
columns: I,
|
|
151
|
+
columnOrder: Q,
|
|
152
|
+
hiddenColumns: $,
|
|
153
|
+
columnWidths: E,
|
|
154
|
+
onOrderChange: J,
|
|
155
|
+
onHiddenChange: Y,
|
|
156
|
+
onSetColumnWidth: P,
|
|
157
|
+
onSave: X,
|
|
158
|
+
onReset: Z
|
|
159
|
+
})
|
|
160
|
+
})
|
|
161
|
+
]
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
//#endregion
|
|
165
|
+
export { x as ColumnPresetSelector };
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
const e=require("../../../node_modules/lucide-react/dist/esm/icons/grip-vertical.cjs.js"),t=require("../../../node_modules/lucide-react/dist/esm/icons/rotate-ccw.cjs.js"),n=require("../../../node_modules/lucide-react/dist/esm/icons/save.cjs.js"),r=require("../../table-checkbox/TableCheckbox.cjs.js"),i=require("../column-group-utils.cjs.js");let a=require("react"),o=require("react/jsx-runtime"),s=require("@dnd-kit/core"),c=require("@dnd-kit/sortable"),l=require("@dnd-kit/utilities");function u({slot:t,index:n,isHidden:i,width:a,onHiddenChange:s,onSetColumnWidth:u}){let{attributes:f,listeners:p,setNodeRef:m,transform:h,transition:g,isDragging:_}=(0,c.useSortable)({id:t.key}),v={transform:l.CSS.Transform.toString(h),transition:g,opacity:_?.5:1},y=typeof t.header==`string`?t.header:t.key,b=t.kind===`group`;return(0,o.jsxs)(`tr`,{ref:m,style:v,className:`
|
|
2
|
+
border-b border-neutral-200 dark:border-neutral-700 transition-colors
|
|
3
|
+
${i?`bg-neutral-100 text-neutral-400 dark:bg-neutral-800 dark:text-neutral-500`:`bg-white text-neutral-900 hover:bg-neutral-50 dark:bg-neutral-800 dark:text-neutral-100 dark:hover:bg-neutral-700`}
|
|
4
|
+
`,children:[(0,o.jsx)(`td`,{className:`w-10 px-2 py-2 text-center cursor-grab active:cursor-grabbing`,...f,...p,children:(0,o.jsx)(e.GripVertical,{size:16,className:`text-neutral-400 dark:text-neutral-500 mx-auto`})}),(0,o.jsxs)(`td`,{className:`px-2 py-2 text-sm whitespace-nowrap`,children:[y,b&&(0,o.jsxs)(`span`,{className:`ml-1.5 text-xs text-neutral-500 dark:text-neutral-400`,children:[`(그룹 · `,t.leafColumns.length,`개)`]})]}),(0,o.jsx)(`td`,{className:`w-14 px-2 py-2 text-center text-sm`,children:n+1}),(0,o.jsx)(`td`,{className:`w-20 px-2 py-2 text-center text-sm tabular-nums`,children:b?(0,o.jsx)(`span`,{className:`text-neutral-400 dark:text-neutral-500`,children:`—`}):u?(0,o.jsx)(d,{columnKey:t.key,width:a,onSetColumnWidth:u}):(0,o.jsx)(`span`,{className:`text-neutral-500 dark:text-neutral-400`,children:a?`${a}px`:`—`})}),(0,o.jsx)(`td`,{className:`w-14 px-2 py-2 text-center`,children:(0,o.jsx)(`div`,{className:`flex justify-center`,children:(0,o.jsx)(r.TableCheckbox,{checked:i,onChange:e=>s(t.key,!e),ariaLabel:`${y} 숨김`})})})]})}function d({columnKey:e,width:t,onSetColumnWidth:n}){let[r,i]=(0,a.useState)(t?String(t):``);return(0,a.useEffect)(()=>{i(t?String(t):``)},[t]),(0,o.jsx)(`input`,{type:`text`,inputMode:`numeric`,pattern:`[0-9]*`,value:r,placeholder:`auto`,onChange:e=>i(e.target.value.replace(/[^0-9]/g,``)),onBlur:()=>{if(r===``){n(e,0);return}let t=Number(r);if(!Number.isFinite(t)||t<=0){n(e,0),i(``);return}n(e,Math.max(20,Math.floor(t)))},onKeyDown:e=>{e.key===`Enter`?(e.preventDefault(),e.target.blur()):e.key===`Escape`&&(i(t?String(t):``),e.target.blur())},"aria-label":`${e} 컬럼 너비 (px)`,className:`w-16 rounded border border-neutral-300 bg-white px-1.5 py-0.5 text-center text-xs tabular-nums text-neutral-700 transition-colors hover:border-primary-300 focus:border-primary-500 focus:outline-hidden focus-visible:ring-2 focus-visible:ring-primary-200 dark:border-neutral-600 dark:bg-neutral-700 dark:text-neutral-100`})}function f({columns:e,columnGroups:r,columnOrder:a,hiddenColumns:l,columnWidths:d,num:f,onOrderChange:p,onHiddenChange:m,onSetColumnWidth:h,onSave:g,onReset:_}){let v=(0,s.useSensors)((0,s.useSensor)(s.PointerSensor,{activationConstraint:{distance:5}}),(0,s.useSensor)(s.KeyboardSensor,{coordinateGetter:c.sortableKeyboardCoordinates})),y=i.buildColumnSlots(e,r),b=new Map(y.map(e=>[e.key,e])),x=a.map(e=>b.get(e)).filter(e=>!!e);return(0,o.jsxs)(`div`,{className:`w-full overflow-y-auto bg-white dark:bg-neutral-800 text-neutral-900 dark:text-neutral-100`,style:{maxHeight:500},children:[(0,o.jsxs)(`div`,{className:`sticky top-0 bg-neutral-50 dark:bg-neutral-900 px-4 py-3 font-semibold z-10 border-b border-neutral-200 dark:border-neutral-700`,children:[(0,o.jsx)(`span`,{className:`text-base`,children:`컬럼 설정`}),(0,o.jsxs)(`span`,{className:`ml-2 text-sm text-neutral-500 dark:text-neutral-400`,children:[`프리셋 `,f]})]}),(0,o.jsx)(s.DndContext,{sensors:v,collisionDetection:s.closestCenter,onDragEnd:e=>{let{active:t,over:n}=e;if(!n||t.id===n.id)return;let r=a.indexOf(String(t.id)),i=a.indexOf(String(n.id));r===-1||i===-1||p((0,c.arrayMove)(a,r,i))},children:(0,o.jsxs)(`table`,{className:`w-full`,children:[(0,o.jsx)(`thead`,{className:`bg-neutral-50 dark:bg-neutral-900 sticky top-12 z-10`,children:(0,o.jsxs)(`tr`,{className:`border-y border-neutral-200 dark:border-neutral-700 font-bold`,children:[(0,o.jsx)(`th`,{className:`w-10 px-2 py-2`}),(0,o.jsx)(`th`,{className:`px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200 whitespace-nowrap`,children:`컬럼명`}),(0,o.jsx)(`th`,{className:`w-14 px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200`,children:`순서`}),(0,o.jsx)(`th`,{className:`w-20 px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200`,children:`너비`}),(0,o.jsx)(`th`,{className:`w-14 px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200`,children:`숨김`})]})}),(0,o.jsx)(`tbody`,{children:(0,o.jsx)(c.SortableContext,{items:a,strategy:c.verticalListSortingStrategy,children:x.map((e,t)=>(0,o.jsx)(u,{slot:e,index:t,isHidden:l.includes(e.key),width:d[e.key],onHiddenChange:m,onSetColumnWidth:h},e.key))})})]})}),(0,o.jsxs)(`div`,{className:`sticky bottom-0 bg-white dark:bg-neutral-800 border-t border-neutral-200 dark:border-neutral-700 px-4 py-3 flex justify-end gap-2 z-10`,children:[(0,o.jsxs)(`button`,{type:`button`,onClick:_,className:`px-3 py-1 border border-neutral-300 dark:border-neutral-600 text-neutral-700 dark:text-neutral-200 rounded text-sm hover:bg-neutral-50 dark:hover:bg-neutral-700 transition-colors flex items-center gap-1`,children:[(0,o.jsx)(t.RotateCcw,{size:12}),(0,o.jsx)(`span`,{className:`text-xs`,children:`초기화`})]}),(0,o.jsxs)(`button`,{type:`button`,onClick:g,className:`px-3 py-1 bg-primary-500 text-white rounded transition-colors flex items-center gap-1 hover:bg-primary-600`,children:[(0,o.jsx)(n.Save,{size:12}),(0,o.jsx)(`span`,{className:`text-xs`,children:`저장`})]})]})]})}exports.ColumnSettingsTable=f;
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
import { GripVertical as e } from "../../../node_modules/lucide-react/dist/esm/icons/grip-vertical.esm.js";
|
|
2
|
+
import { RotateCcw as t } from "../../../node_modules/lucide-react/dist/esm/icons/rotate-ccw.esm.js";
|
|
3
|
+
import { Save as n } from "../../../node_modules/lucide-react/dist/esm/icons/save.esm.js";
|
|
4
|
+
import { TableCheckbox as r } from "../../table-checkbox/TableCheckbox.esm.js";
|
|
5
|
+
import { buildColumnSlots as i } from "../column-group-utils.esm.js";
|
|
6
|
+
import { useEffect as a, useState as o } from "react";
|
|
7
|
+
import { jsx as s, jsxs as c } from "react/jsx-runtime";
|
|
8
|
+
import { DndContext as l, KeyboardSensor as u, PointerSensor as d, closestCenter as f, useSensor as p, useSensors as m } from "@dnd-kit/core";
|
|
9
|
+
import { SortableContext as h, arrayMove as g, sortableKeyboardCoordinates as _, useSortable as v, verticalListSortingStrategy as y } from "@dnd-kit/sortable";
|
|
10
|
+
import { CSS as b } from "@dnd-kit/utilities";
|
|
11
|
+
function x({ slot: t, index: n, isHidden: i, width: a, onHiddenChange: o, onSetColumnWidth: l }) {
|
|
12
|
+
let { attributes: u, listeners: d, setNodeRef: f, transform: p, transition: m, isDragging: h } = v({ id: t.key }), g = {
|
|
13
|
+
transform: b.Transform.toString(p),
|
|
14
|
+
transition: m,
|
|
15
|
+
opacity: h ? .5 : 1
|
|
16
|
+
}, _ = typeof t.header == "string" ? t.header : t.key, y = t.kind === "group";
|
|
17
|
+
return /* @__PURE__ */ c("tr", {
|
|
18
|
+
ref: f,
|
|
19
|
+
style: g,
|
|
20
|
+
className: `
|
|
21
|
+
border-b border-neutral-200 dark:border-neutral-700 transition-colors
|
|
22
|
+
${i ? "bg-neutral-100 text-neutral-400 dark:bg-neutral-800 dark:text-neutral-500" : "bg-white text-neutral-900 hover:bg-neutral-50 dark:bg-neutral-800 dark:text-neutral-100 dark:hover:bg-neutral-700"}
|
|
23
|
+
`,
|
|
24
|
+
children: [
|
|
25
|
+
/* @__PURE__ */ s("td", {
|
|
26
|
+
className: "w-10 px-2 py-2 text-center cursor-grab active:cursor-grabbing",
|
|
27
|
+
...u,
|
|
28
|
+
...d,
|
|
29
|
+
children: /* @__PURE__ */ s(e, {
|
|
30
|
+
size: 16,
|
|
31
|
+
className: "text-neutral-400 dark:text-neutral-500 mx-auto"
|
|
32
|
+
})
|
|
33
|
+
}),
|
|
34
|
+
/* @__PURE__ */ c("td", {
|
|
35
|
+
className: "px-2 py-2 text-sm whitespace-nowrap",
|
|
36
|
+
children: [_, y && /* @__PURE__ */ c("span", {
|
|
37
|
+
className: "ml-1.5 text-xs text-neutral-500 dark:text-neutral-400",
|
|
38
|
+
children: [
|
|
39
|
+
"(그룹 · ",
|
|
40
|
+
t.leafColumns.length,
|
|
41
|
+
"개)"
|
|
42
|
+
]
|
|
43
|
+
})]
|
|
44
|
+
}),
|
|
45
|
+
/* @__PURE__ */ s("td", {
|
|
46
|
+
className: "w-14 px-2 py-2 text-center text-sm",
|
|
47
|
+
children: n + 1
|
|
48
|
+
}),
|
|
49
|
+
/* @__PURE__ */ s("td", {
|
|
50
|
+
className: "w-20 px-2 py-2 text-center text-sm tabular-nums",
|
|
51
|
+
children: y ? /* @__PURE__ */ s("span", {
|
|
52
|
+
className: "text-neutral-400 dark:text-neutral-500",
|
|
53
|
+
children: "—"
|
|
54
|
+
}) : l ? /* @__PURE__ */ s(S, {
|
|
55
|
+
columnKey: t.key,
|
|
56
|
+
width: a,
|
|
57
|
+
onSetColumnWidth: l
|
|
58
|
+
}) : /* @__PURE__ */ s("span", {
|
|
59
|
+
className: "text-neutral-500 dark:text-neutral-400",
|
|
60
|
+
children: a ? `${a}px` : "—"
|
|
61
|
+
})
|
|
62
|
+
}),
|
|
63
|
+
/* @__PURE__ */ s("td", {
|
|
64
|
+
className: "w-14 px-2 py-2 text-center",
|
|
65
|
+
children: /* @__PURE__ */ s("div", {
|
|
66
|
+
className: "flex justify-center",
|
|
67
|
+
children: /* @__PURE__ */ s(r, {
|
|
68
|
+
checked: i,
|
|
69
|
+
onChange: (e) => o(t.key, !e),
|
|
70
|
+
ariaLabel: `${_} 숨김`
|
|
71
|
+
})
|
|
72
|
+
})
|
|
73
|
+
})
|
|
74
|
+
]
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
function S({ columnKey: e, width: t, onSetColumnWidth: n }) {
|
|
78
|
+
let [r, i] = o(t ? String(t) : "");
|
|
79
|
+
return a(() => {
|
|
80
|
+
i(t ? String(t) : "");
|
|
81
|
+
}, [t]), /* @__PURE__ */ s("input", {
|
|
82
|
+
type: "text",
|
|
83
|
+
inputMode: "numeric",
|
|
84
|
+
pattern: "[0-9]*",
|
|
85
|
+
value: r,
|
|
86
|
+
placeholder: "auto",
|
|
87
|
+
onChange: (e) => i(e.target.value.replace(/[^0-9]/g, "")),
|
|
88
|
+
onBlur: () => {
|
|
89
|
+
if (r === "") {
|
|
90
|
+
n(e, 0);
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
let t = Number(r);
|
|
94
|
+
if (!Number.isFinite(t) || t <= 0) {
|
|
95
|
+
n(e, 0), i("");
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
n(e, Math.max(20, Math.floor(t)));
|
|
99
|
+
},
|
|
100
|
+
onKeyDown: (e) => {
|
|
101
|
+
e.key === "Enter" ? (e.preventDefault(), e.target.blur()) : e.key === "Escape" && (i(t ? String(t) : ""), e.target.blur());
|
|
102
|
+
},
|
|
103
|
+
"aria-label": `${e} 컬럼 너비 (px)`,
|
|
104
|
+
className: "w-16 rounded border border-neutral-300 bg-white px-1.5 py-0.5 text-center text-xs tabular-nums text-neutral-700 transition-colors hover:border-primary-300 focus:border-primary-500 focus:outline-hidden focus-visible:ring-2 focus-visible:ring-primary-200 dark:border-neutral-600 dark:bg-neutral-700 dark:text-neutral-100"
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
function C({ columns: e, columnGroups: r, columnOrder: a, hiddenColumns: o, columnWidths: v, num: b, onOrderChange: S, onHiddenChange: C, onSetColumnWidth: w, onSave: T, onReset: E }) {
|
|
108
|
+
let D = m(p(d, { activationConstraint: { distance: 5 } }), p(u, { coordinateGetter: _ })), O = i(e, r), k = new Map(O.map((e) => [e.key, e])), A = a.map((e) => k.get(e)).filter((e) => !!e);
|
|
109
|
+
return /* @__PURE__ */ c("div", {
|
|
110
|
+
className: "w-full overflow-y-auto bg-white dark:bg-neutral-800 text-neutral-900 dark:text-neutral-100",
|
|
111
|
+
style: { maxHeight: 500 },
|
|
112
|
+
children: [
|
|
113
|
+
/* @__PURE__ */ c("div", {
|
|
114
|
+
className: "sticky top-0 bg-neutral-50 dark:bg-neutral-900 px-4 py-3 font-semibold z-10 border-b border-neutral-200 dark:border-neutral-700",
|
|
115
|
+
children: [/* @__PURE__ */ s("span", {
|
|
116
|
+
className: "text-base",
|
|
117
|
+
children: "컬럼 설정"
|
|
118
|
+
}), /* @__PURE__ */ c("span", {
|
|
119
|
+
className: "ml-2 text-sm text-neutral-500 dark:text-neutral-400",
|
|
120
|
+
children: ["프리셋 ", b]
|
|
121
|
+
})]
|
|
122
|
+
}),
|
|
123
|
+
/* @__PURE__ */ s(l, {
|
|
124
|
+
sensors: D,
|
|
125
|
+
collisionDetection: f,
|
|
126
|
+
onDragEnd: (e) => {
|
|
127
|
+
let { active: t, over: n } = e;
|
|
128
|
+
if (!n || t.id === n.id) return;
|
|
129
|
+
let r = a.indexOf(String(t.id)), i = a.indexOf(String(n.id));
|
|
130
|
+
r === -1 || i === -1 || S(g(a, r, i));
|
|
131
|
+
},
|
|
132
|
+
children: /* @__PURE__ */ c("table", {
|
|
133
|
+
className: "w-full",
|
|
134
|
+
children: [/* @__PURE__ */ s("thead", {
|
|
135
|
+
className: "bg-neutral-50 dark:bg-neutral-900 sticky top-12 z-10",
|
|
136
|
+
children: /* @__PURE__ */ c("tr", {
|
|
137
|
+
className: "border-y border-neutral-200 dark:border-neutral-700 font-bold",
|
|
138
|
+
children: [
|
|
139
|
+
/* @__PURE__ */ s("th", { className: "w-10 px-2 py-2" }),
|
|
140
|
+
/* @__PURE__ */ s("th", {
|
|
141
|
+
className: "px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200 whitespace-nowrap",
|
|
142
|
+
children: "컬럼명"
|
|
143
|
+
}),
|
|
144
|
+
/* @__PURE__ */ s("th", {
|
|
145
|
+
className: "w-14 px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200",
|
|
146
|
+
children: "순서"
|
|
147
|
+
}),
|
|
148
|
+
/* @__PURE__ */ s("th", {
|
|
149
|
+
className: "w-20 px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200",
|
|
150
|
+
children: "너비"
|
|
151
|
+
}),
|
|
152
|
+
/* @__PURE__ */ s("th", {
|
|
153
|
+
className: "w-14 px-2 py-2 text-center text-sm font-medium text-neutral-700 dark:text-neutral-200",
|
|
154
|
+
children: "숨김"
|
|
155
|
+
})
|
|
156
|
+
]
|
|
157
|
+
})
|
|
158
|
+
}), /* @__PURE__ */ s("tbody", { children: /* @__PURE__ */ s(h, {
|
|
159
|
+
items: a,
|
|
160
|
+
strategy: y,
|
|
161
|
+
children: A.map((e, t) => /* @__PURE__ */ s(x, {
|
|
162
|
+
slot: e,
|
|
163
|
+
index: t,
|
|
164
|
+
isHidden: o.includes(e.key),
|
|
165
|
+
width: v[e.key],
|
|
166
|
+
onHiddenChange: C,
|
|
167
|
+
onSetColumnWidth: w
|
|
168
|
+
}, e.key))
|
|
169
|
+
}) })]
|
|
170
|
+
})
|
|
171
|
+
}),
|
|
172
|
+
/* @__PURE__ */ c("div", {
|
|
173
|
+
className: "sticky bottom-0 bg-white dark:bg-neutral-800 border-t border-neutral-200 dark:border-neutral-700 px-4 py-3 flex justify-end gap-2 z-10",
|
|
174
|
+
children: [/* @__PURE__ */ c("button", {
|
|
175
|
+
type: "button",
|
|
176
|
+
onClick: E,
|
|
177
|
+
className: "px-3 py-1 border border-neutral-300 dark:border-neutral-600 text-neutral-700 dark:text-neutral-200 rounded text-sm hover:bg-neutral-50 dark:hover:bg-neutral-700 transition-colors flex items-center gap-1",
|
|
178
|
+
children: [/* @__PURE__ */ s(t, { size: 12 }), /* @__PURE__ */ s("span", {
|
|
179
|
+
className: "text-xs",
|
|
180
|
+
children: "초기화"
|
|
181
|
+
})]
|
|
182
|
+
}), /* @__PURE__ */ c("button", {
|
|
183
|
+
type: "button",
|
|
184
|
+
onClick: T,
|
|
185
|
+
className: "px-3 py-1 bg-primary-500 text-white rounded transition-colors flex items-center gap-1 hover:bg-primary-600",
|
|
186
|
+
children: [/* @__PURE__ */ s(n, { size: 12 }), /* @__PURE__ */ s("span", {
|
|
187
|
+
className: "text-xs",
|
|
188
|
+
children: "저장"
|
|
189
|
+
})]
|
|
190
|
+
})]
|
|
191
|
+
})
|
|
192
|
+
]
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
//#endregion
|
|
196
|
+
export { C as ColumnSettingsTable };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e=require("../../../node_modules/lucide-react/dist/esm/icons/keyboard.cjs.js");let t=require("react/jsx-runtime");function n({onKeyDown:n}){return(0,t.jsxs)(`button`,{type:`button`,onKeyDown:n,title:`키보드로 페이지 이동 (포커스 후 ← / → 키)`,"aria-label":`키보드로 페이지 이동 활성화`,className:`group/kbd inline-flex items-center gap-0 rounded border border-neutral-300 bg-white px-1.5 py-1 text-neutral-500 transition-[color,background-color,border-color,gap] duration-200 hover:border-primary-300 hover:text-primary-600 focus:gap-1.5 focus:border-primary-500 focus:bg-primary-50 focus:text-primary-700 focus:outline-hidden focus-visible:ring-2 focus-visible:ring-primary-200 dark:border-neutral-600 dark:bg-neutral-800 dark:text-neutral-400 dark:hover:border-primary-400 dark:focus:bg-primary-950/40 dark:focus:text-primary-300 pointer-coarse:hidden`,children:[(0,t.jsx)(e.Keyboard,{className:`h-3.5 w-3.5 shrink-0`,"aria-hidden":`true`}),(0,t.jsx)(`span`,{className:`grid grid-cols-[0fr] overflow-hidden text-xs tabular-nums opacity-0 transition-[grid-template-columns,opacity] duration-200 group-focus/kbd:grid-cols-[1fr] group-focus/kbd:opacity-100`,children:(0,t.jsx)(`span`,{className:`min-w-0 whitespace-nowrap`,children:`← / → 키로 이동 중`})})]})}exports.KeyboardNavButton=n;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Keyboard as e } from "../../../node_modules/lucide-react/dist/esm/icons/keyboard.esm.js";
|
|
2
|
+
import { jsx as t, jsxs as n } from "react/jsx-runtime";
|
|
3
|
+
//#region src/components/table/components/KeyboardNavButton.tsx
|
|
4
|
+
function r({ onKeyDown: r }) {
|
|
5
|
+
return /* @__PURE__ */ n("button", {
|
|
6
|
+
type: "button",
|
|
7
|
+
onKeyDown: r,
|
|
8
|
+
title: "키보드로 페이지 이동 (포커스 후 ← / → 키)",
|
|
9
|
+
"aria-label": "키보드로 페이지 이동 활성화",
|
|
10
|
+
className: "group/kbd inline-flex items-center gap-0 rounded border border-neutral-300 bg-white px-1.5 py-1 text-neutral-500 transition-[color,background-color,border-color,gap] duration-200 hover:border-primary-300 hover:text-primary-600 focus:gap-1.5 focus:border-primary-500 focus:bg-primary-50 focus:text-primary-700 focus:outline-hidden focus-visible:ring-2 focus-visible:ring-primary-200 dark:border-neutral-600 dark:bg-neutral-800 dark:text-neutral-400 dark:hover:border-primary-400 dark:focus:bg-primary-950/40 dark:focus:text-primary-300 pointer-coarse:hidden",
|
|
11
|
+
children: [/* @__PURE__ */ t(e, {
|
|
12
|
+
className: "h-3.5 w-3.5 shrink-0",
|
|
13
|
+
"aria-hidden": "true"
|
|
14
|
+
}), /* @__PURE__ */ t("span", {
|
|
15
|
+
className: "grid grid-cols-[0fr] overflow-hidden text-xs tabular-nums opacity-0 transition-[grid-template-columns,opacity] duration-200 group-focus/kbd:grid-cols-[1fr] group-focus/kbd:opacity-100",
|
|
16
|
+
children: /* @__PURE__ */ t("span", {
|
|
17
|
+
className: "min-w-0 whitespace-nowrap",
|
|
18
|
+
children: "← / → 키로 이동 중"
|
|
19
|
+
})
|
|
20
|
+
})]
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
//#endregion
|
|
24
|
+
export { r as KeyboardNavButton };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
let e=require("react"),t=require("react/jsx-runtime");function n({currentPage:n,totalPages:r,onPageChange:i,className:a=``,"data-testid":o}){let[s,c]=(0,e.useState)(``),l=e=>{let t=e.replace(/[^0-9]/g,``);if(t===``){c(``);return}let n=Number(t);if(n<=0){c(``);return}c(String(Math.min(r,n)))},u=()=>{if(s===``)return;let e=Number(s),t=Math.max(1,Math.min(r,Math.floor(e)));t!==n&&i(t),c(``)},d=e=>{e.key===`Enter`?(e.preventDefault(),u()):e.key===`Escape`&&(c(``),e.target.blur())},f=String(r).length,p=f<=2?`w-12`:f===3?`w-14`:`w-16`;return(0,t.jsxs)(`label`,{className:`flex items-center gap-1 text-sm text-neutral-600 dark:text-neutral-300 ${a}`,children:[(0,t.jsx)(`span`,{className:`text-neutral-500`,children:`이동`}),(0,t.jsx)(`input`,{type:`text`,inputMode:`numeric`,pattern:`[0-9]*`,maxLength:f,value:s,placeholder:String(n),onChange:e=>l(e.target.value),onKeyDown:d,onBlur:u,"aria-label":`페이지 번호 입력 (1-${r})`,"data-testid":o,className:`${p} rounded border border-neutral-300 bg-white px-2 py-0.5 text-center tabular-nums text-neutral-700 transition-colors hover:border-primary-300 focus:border-primary-500 focus:outline-hidden focus-visible:ring-2 focus-visible:ring-primary-200 dark:border-neutral-600 dark:bg-neutral-800 dark:text-neutral-200 dark:hover:border-primary-400`}),(0,t.jsxs)(`span`,{className:`text-neutral-500 tabular-nums`,children:[`/ `,r.toLocaleString()]})]})}exports.PageJumpInput=n;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { useState as e } from "react";
|
|
2
|
+
import { jsx as t, jsxs as n } from "react/jsx-runtime";
|
|
3
|
+
//#region src/components/table/components/PageJumpInput.tsx
|
|
4
|
+
function r({ currentPage: r, totalPages: i, onPageChange: a, className: o = "", "data-testid": s }) {
|
|
5
|
+
let [c, l] = e(""), u = (e) => {
|
|
6
|
+
let t = e.replace(/[^0-9]/g, "");
|
|
7
|
+
if (t === "") {
|
|
8
|
+
l("");
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
let n = Number(t);
|
|
12
|
+
if (n <= 0) {
|
|
13
|
+
l("");
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
l(String(Math.min(i, n)));
|
|
17
|
+
}, d = () => {
|
|
18
|
+
if (c === "") return;
|
|
19
|
+
let e = Number(c), t = Math.max(1, Math.min(i, Math.floor(e)));
|
|
20
|
+
t !== r && a(t), l("");
|
|
21
|
+
}, f = (e) => {
|
|
22
|
+
e.key === "Enter" ? (e.preventDefault(), d()) : e.key === "Escape" && (l(""), e.target.blur());
|
|
23
|
+
}, p = String(i).length, m = p <= 2 ? "w-12" : p === 3 ? "w-14" : "w-16";
|
|
24
|
+
return /* @__PURE__ */ n("label", {
|
|
25
|
+
className: `flex items-center gap-1 text-sm text-neutral-600 dark:text-neutral-300 ${o}`,
|
|
26
|
+
children: [
|
|
27
|
+
/* @__PURE__ */ t("span", {
|
|
28
|
+
className: "text-neutral-500",
|
|
29
|
+
children: "이동"
|
|
30
|
+
}),
|
|
31
|
+
/* @__PURE__ */ t("input", {
|
|
32
|
+
type: "text",
|
|
33
|
+
inputMode: "numeric",
|
|
34
|
+
pattern: "[0-9]*",
|
|
35
|
+
maxLength: p,
|
|
36
|
+
value: c,
|
|
37
|
+
placeholder: String(r),
|
|
38
|
+
onChange: (e) => u(e.target.value),
|
|
39
|
+
onKeyDown: f,
|
|
40
|
+
onBlur: d,
|
|
41
|
+
"aria-label": `페이지 번호 입력 (1-${i})`,
|
|
42
|
+
"data-testid": s,
|
|
43
|
+
className: `${m} rounded border border-neutral-300 bg-white px-2 py-0.5 text-center tabular-nums text-neutral-700 transition-colors hover:border-primary-300 focus:border-primary-500 focus:outline-hidden focus-visible:ring-2 focus-visible:ring-primary-200 dark:border-neutral-600 dark:bg-neutral-800 dark:text-neutral-200 dark:hover:border-primary-400`
|
|
44
|
+
}),
|
|
45
|
+
/* @__PURE__ */ n("span", {
|
|
46
|
+
className: "text-neutral-500 tabular-nums",
|
|
47
|
+
children: ["/ ", i.toLocaleString()]
|
|
48
|
+
})
|
|
49
|
+
]
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
//#endregion
|
|
53
|
+
export { r as PageJumpInput };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e=require("../../../node_modules/lucide-react/dist/esm/icons/chevron-left.cjs.js"),t=require("../../../node_modules/lucide-react/dist/esm/icons/chevron-right.cjs.js"),n=require("../../../node_modules/lucide-react/dist/esm/icons/chevrons-left.cjs.js"),r=require("../../../node_modules/lucide-react/dist/esm/icons/chevrons-right.cjs.js");let i=require("react"),a=require("react/jsx-runtime");var o=[9,7,5,3,1],s=16,c=`px-0.5 text-xs text-text-tertiary font-mono @min-[640px]/pagebar:px-1 @min-[640px]/pagebar:text-sm`,l=`inline-flex h-7 min-w-6 items-center justify-center rounded-md px-1.5 font-mono text-xs tabular-nums transition-colors @min-[640px]/pagebar:h-8 @min-[640px]/pagebar:min-w-7 @min-[640px]/pagebar:px-2 @min-[640px]/pagebar:text-sm`,u=`text-text-disabled hover:bg-bg-base-secondary hover:text-text-secondary`,d=`font-bold text-text-secondary`,f=`outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary-500`,p=`disabled:cursor-not-allowed disabled:opacity-30 disabled:hover:bg-transparent disabled:hover:text-text-tertiary`;function m({active:e=!1,className:t=``,children:n,...r}){return(0,a.jsx)(`button`,{type:`button`,"aria-current":e?`page`:void 0,className:`${l} ${e?d:u} ${f} ${p} ${t}`,...r,children:n})}function h(e,t,n){let r=Math.floor(n/2),i=Math.max(1,e-r),a=Math.min(t,i+n-1);a-i<n-1&&(i=Math.max(1,a-n+1));let o=[];for(let e=i;e<=a;e++)o.push(e);return o}function g(e,t){let n=t<=28?4:8,r=t<=28,i=r?24:28,a=r?7:8;return e.reduce((e,t)=>{let n=String(t).length;return e+Math.max(i,i+(n-1)*a)},0)+n*Math.max(0,e.length-1)+s*2+24}function _(e,t,n,r,i,a){let s=e-r,c=o.filter(e=>e<=a);for(let e of c)if(g(h(t,n,e),i)<=s)return e;return 1}function v({currentPage:e,totalPages:t,pages:n,onPageChange:r,testId:i}){if(n.length===0)return null;let o=n[0]>1,s=n[n.length-1]<t;return(0,a.jsxs)(a.Fragment,{children:[o&&(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(m,{active:e===1,onClick:()=>r(1),"data-testid":i?`${i}-page-1`:void 0,children:`1`}),n[0]>2&&(0,a.jsx)(`span`,{className:c,children:`…`})]}),n.map(t=>(0,a.jsx)(m,{active:e===t,onClick:()=>r(t),"data-testid":i?`${i}-page-${t}`:void 0,children:t},t)),s&&(0,a.jsxs)(a.Fragment,{children:[n[n.length-1]<t-1&&(0,a.jsx)(`span`,{className:c,children:`…`}),(0,a.jsx)(m,{active:e===t,onClick:()=>r(t),"data-testid":i?`${i}-page-${t}`:void 0,children:t})]})]})}function y({currentPage:o,totalPages:s,onPageChange:c,hasPreviousPage:l,hasNextPage:u,maxPageButtons:d=9,className:f=``,"data-testid":p,...g}){let y=(0,i.useRef)(null),[b,x]=(0,i.useState)(d);if((0,i.useLayoutEffect)(()=>{let e=y.current;if(!e)return;let t=e.parentElement;if(!t)return;let n=()=>{let e=t.offsetWidth,n=e<640,r=n?28:32,i=n?4:8,a=_(e,o,s,r*4+i*5,r,d);x(e=>e===a?e:a)};n();let r=new ResizeObserver(n);return r.observe(t),()=>r.disconnect()},[o,s,d]),s<1)return null;if(s===1)return(0,a.jsx)(`div`,{ref:y,className:`flex items-center justify-center gap-1 sm:gap-2 ${f}`,"data-testid":p,...g,children:(0,a.jsx)(m,{active:!0,disabled:!0,"data-testid":p?`${p}-page-1`:void 0,children:`1`})});let S=h(o,s,b);return(0,a.jsxs)(`div`,{ref:y,className:`flex items-center justify-center gap-1 sm:gap-2 ${f}`,"data-testid":p,...g,children:[(0,a.jsx)(m,{disabled:o===1,onClick:()=>c(1),"data-testid":p?`${p}-first`:void 0,"aria-label":`첫 페이지`,children:(0,a.jsx)(n.ChevronsLeft,{className:`h-3.5 w-3.5`,"aria-hidden":`true`})}),(0,a.jsx)(m,{disabled:l===!1||o===1,onClick:()=>c(o-1),"data-testid":p?`${p}-prev`:void 0,"aria-label":`이전 페이지`,children:(0,a.jsx)(e.ChevronLeft,{className:`h-3.5 w-3.5`,"aria-hidden":`true`})}),(0,a.jsx)(v,{currentPage:o,totalPages:s,pages:S,onPageChange:c,testId:p}),(0,a.jsx)(m,{disabled:u===!1||o===s,onClick:()=>c(o+1),"data-testid":p?`${p}-next`:void 0,"aria-label":`다음 페이지`,children:(0,a.jsx)(t.ChevronRight,{className:`h-3.5 w-3.5`,"aria-hidden":`true`})}),(0,a.jsx)(m,{disabled:o===s,onClick:()=>c(s),"data-testid":p?`${p}-last`:void 0,"aria-label":`마지막 페이지`,children:(0,a.jsx)(r.ChevronsRight,{className:`h-3.5 w-3.5`,"aria-hidden":`true`})})]})}exports.Pagination=y;
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { ChevronLeft as e } from "../../../node_modules/lucide-react/dist/esm/icons/chevron-left.esm.js";
|
|
2
|
+
import { ChevronRight as t } from "../../../node_modules/lucide-react/dist/esm/icons/chevron-right.esm.js";
|
|
3
|
+
import { ChevronsLeft as n } from "../../../node_modules/lucide-react/dist/esm/icons/chevrons-left.esm.js";
|
|
4
|
+
import { ChevronsRight as r } from "../../../node_modules/lucide-react/dist/esm/icons/chevrons-right.esm.js";
|
|
5
|
+
import { useLayoutEffect as i, useRef as a, useState as o } from "react";
|
|
6
|
+
import { Fragment as s, jsx as c, jsxs as l } from "react/jsx-runtime";
|
|
7
|
+
//#region src/components/table/components/Pagination.tsx
|
|
8
|
+
var u = [
|
|
9
|
+
9,
|
|
10
|
+
7,
|
|
11
|
+
5,
|
|
12
|
+
3,
|
|
13
|
+
1
|
|
14
|
+
], d = 16, f = "px-0.5 text-xs text-text-tertiary font-mono @min-[640px]/pagebar:px-1 @min-[640px]/pagebar:text-sm", p = "inline-flex h-7 min-w-6 items-center justify-center rounded-md px-1.5 font-mono text-xs tabular-nums transition-colors @min-[640px]/pagebar:h-8 @min-[640px]/pagebar:min-w-7 @min-[640px]/pagebar:px-2 @min-[640px]/pagebar:text-sm", m = "text-text-disabled hover:bg-bg-base-secondary hover:text-text-secondary", h = "font-bold text-text-secondary", g = "outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary-500", _ = "disabled:cursor-not-allowed disabled:opacity-30 disabled:hover:bg-transparent disabled:hover:text-text-tertiary";
|
|
15
|
+
function v({ active: e = !1, className: t = "", children: n, ...r }) {
|
|
16
|
+
return /* @__PURE__ */ c("button", {
|
|
17
|
+
type: "button",
|
|
18
|
+
"aria-current": e ? "page" : void 0,
|
|
19
|
+
className: `${p} ${e ? h : m} ${g} ${_} ${t}`,
|
|
20
|
+
...r,
|
|
21
|
+
children: n
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
function y(e, t, n) {
|
|
25
|
+
let r = Math.floor(n / 2), i = Math.max(1, e - r), a = Math.min(t, i + n - 1);
|
|
26
|
+
a - i < n - 1 && (i = Math.max(1, a - n + 1));
|
|
27
|
+
let o = [];
|
|
28
|
+
for (let e = i; e <= a; e++) o.push(e);
|
|
29
|
+
return o;
|
|
30
|
+
}
|
|
31
|
+
function b(e, t) {
|
|
32
|
+
let n = t <= 28 ? 4 : 8, r = t <= 28, i = r ? 24 : 28, a = r ? 7 : 8;
|
|
33
|
+
return e.reduce((e, t) => {
|
|
34
|
+
let n = String(t).length;
|
|
35
|
+
return e + Math.max(i, i + (n - 1) * a);
|
|
36
|
+
}, 0) + n * Math.max(0, e.length - 1) + d * 2 + 24;
|
|
37
|
+
}
|
|
38
|
+
function x(e, t, n, r, i, a) {
|
|
39
|
+
let o = e - r, s = u.filter((e) => e <= a);
|
|
40
|
+
for (let e of s) if (b(y(t, n, e), i) <= o) return e;
|
|
41
|
+
return 1;
|
|
42
|
+
}
|
|
43
|
+
function S({ currentPage: e, totalPages: t, pages: n, onPageChange: r, testId: i }) {
|
|
44
|
+
if (n.length === 0) return null;
|
|
45
|
+
let a = n[0] > 1, o = n[n.length - 1] < t;
|
|
46
|
+
return /* @__PURE__ */ l(s, { children: [
|
|
47
|
+
a && /* @__PURE__ */ l(s, { children: [/* @__PURE__ */ c(v, {
|
|
48
|
+
active: e === 1,
|
|
49
|
+
onClick: () => r(1),
|
|
50
|
+
"data-testid": i ? `${i}-page-1` : void 0,
|
|
51
|
+
children: "1"
|
|
52
|
+
}), n[0] > 2 && /* @__PURE__ */ c("span", {
|
|
53
|
+
className: f,
|
|
54
|
+
children: "…"
|
|
55
|
+
})] }),
|
|
56
|
+
n.map((t) => /* @__PURE__ */ c(v, {
|
|
57
|
+
active: e === t,
|
|
58
|
+
onClick: () => r(t),
|
|
59
|
+
"data-testid": i ? `${i}-page-${t}` : void 0,
|
|
60
|
+
children: t
|
|
61
|
+
}, t)),
|
|
62
|
+
o && /* @__PURE__ */ l(s, { children: [n[n.length - 1] < t - 1 && /* @__PURE__ */ c("span", {
|
|
63
|
+
className: f,
|
|
64
|
+
children: "…"
|
|
65
|
+
}), /* @__PURE__ */ c(v, {
|
|
66
|
+
active: e === t,
|
|
67
|
+
onClick: () => r(t),
|
|
68
|
+
"data-testid": i ? `${i}-page-${t}` : void 0,
|
|
69
|
+
children: t
|
|
70
|
+
})] })
|
|
71
|
+
] });
|
|
72
|
+
}
|
|
73
|
+
function C({ currentPage: s, totalPages: u, onPageChange: d, hasPreviousPage: f, hasNextPage: p, maxPageButtons: m = 9, className: h = "", "data-testid": g, ..._ }) {
|
|
74
|
+
let b = a(null), [C, w] = o(m);
|
|
75
|
+
if (i(() => {
|
|
76
|
+
let e = b.current;
|
|
77
|
+
if (!e) return;
|
|
78
|
+
let t = e.parentElement;
|
|
79
|
+
if (!t) return;
|
|
80
|
+
let n = () => {
|
|
81
|
+
let e = t.offsetWidth, n = e < 640, r = n ? 28 : 32, i = n ? 4 : 8, a = x(e, s, u, r * 4 + i * 5, r, m);
|
|
82
|
+
w((e) => e === a ? e : a);
|
|
83
|
+
};
|
|
84
|
+
n();
|
|
85
|
+
let r = new ResizeObserver(n);
|
|
86
|
+
return r.observe(t), () => r.disconnect();
|
|
87
|
+
}, [
|
|
88
|
+
s,
|
|
89
|
+
u,
|
|
90
|
+
m
|
|
91
|
+
]), u < 1) return null;
|
|
92
|
+
if (u === 1) return /* @__PURE__ */ c("div", {
|
|
93
|
+
ref: b,
|
|
94
|
+
className: `flex items-center justify-center gap-1 sm:gap-2 ${h}`,
|
|
95
|
+
"data-testid": g,
|
|
96
|
+
..._,
|
|
97
|
+
children: /* @__PURE__ */ c(v, {
|
|
98
|
+
active: !0,
|
|
99
|
+
disabled: !0,
|
|
100
|
+
"data-testid": g ? `${g}-page-1` : void 0,
|
|
101
|
+
children: "1"
|
|
102
|
+
})
|
|
103
|
+
});
|
|
104
|
+
let T = y(s, u, C);
|
|
105
|
+
return /* @__PURE__ */ l("div", {
|
|
106
|
+
ref: b,
|
|
107
|
+
className: `flex items-center justify-center gap-1 sm:gap-2 ${h}`,
|
|
108
|
+
"data-testid": g,
|
|
109
|
+
..._,
|
|
110
|
+
children: [
|
|
111
|
+
/* @__PURE__ */ c(v, {
|
|
112
|
+
disabled: s === 1,
|
|
113
|
+
onClick: () => d(1),
|
|
114
|
+
"data-testid": g ? `${g}-first` : void 0,
|
|
115
|
+
"aria-label": "첫 페이지",
|
|
116
|
+
children: /* @__PURE__ */ c(n, {
|
|
117
|
+
className: "h-3.5 w-3.5",
|
|
118
|
+
"aria-hidden": "true"
|
|
119
|
+
})
|
|
120
|
+
}),
|
|
121
|
+
/* @__PURE__ */ c(v, {
|
|
122
|
+
disabled: f === !1 || s === 1,
|
|
123
|
+
onClick: () => d(s - 1),
|
|
124
|
+
"data-testid": g ? `${g}-prev` : void 0,
|
|
125
|
+
"aria-label": "이전 페이지",
|
|
126
|
+
children: /* @__PURE__ */ c(e, {
|
|
127
|
+
className: "h-3.5 w-3.5",
|
|
128
|
+
"aria-hidden": "true"
|
|
129
|
+
})
|
|
130
|
+
}),
|
|
131
|
+
/* @__PURE__ */ c(S, {
|
|
132
|
+
currentPage: s,
|
|
133
|
+
totalPages: u,
|
|
134
|
+
pages: T,
|
|
135
|
+
onPageChange: d,
|
|
136
|
+
testId: g
|
|
137
|
+
}),
|
|
138
|
+
/* @__PURE__ */ c(v, {
|
|
139
|
+
disabled: p === !1 || s === u,
|
|
140
|
+
onClick: () => d(s + 1),
|
|
141
|
+
"data-testid": g ? `${g}-next` : void 0,
|
|
142
|
+
"aria-label": "다음 페이지",
|
|
143
|
+
children: /* @__PURE__ */ c(t, {
|
|
144
|
+
className: "h-3.5 w-3.5",
|
|
145
|
+
"aria-hidden": "true"
|
|
146
|
+
})
|
|
147
|
+
}),
|
|
148
|
+
/* @__PURE__ */ c(v, {
|
|
149
|
+
disabled: s === u,
|
|
150
|
+
onClick: () => d(u),
|
|
151
|
+
"data-testid": g ? `${g}-last` : void 0,
|
|
152
|
+
"aria-label": "마지막 페이지",
|
|
153
|
+
children: /* @__PURE__ */ c(r, {
|
|
154
|
+
className: "h-3.5 w-3.5",
|
|
155
|
+
"aria-hidden": "true"
|
|
156
|
+
})
|
|
157
|
+
})
|
|
158
|
+
]
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
//#endregion
|
|
162
|
+
export { C as Pagination };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e=require("../../select/Select.cjs.js"),t=require("./KeyboardNavButton.cjs.js"),n=require("./PageJumpInput.cjs.js"),r=require("./Pagination.cjs.js");let i=require("react/jsx-runtime");var a=[30,50,100];function o({currentPage:o,totalPages:s,onPageChange:c,pageSize:l,pageSizeOptions:u=a,onPageSizeChange:d,hasPreviousPage:f,hasNextPage:p,totalElements:m,showTotalCount:h=!0,enablePageJump:g=!0,enableKeyboardPagination:_=!0,"data-testid":v}){let y=f??o>1,b=p??o<s,x=e=>{_&&(e.altKey||e.metaKey||e.ctrlKey||e.shiftKey||(e.key===`ArrowLeft`&&y?(e.preventDefault(),c(o-1)):e.key===`ArrowRight`&&b&&(e.preventDefault(),c(o+1))))};return(0,i.jsxs)(`nav`,{"aria-label":`페이지 네비게이션`,className:`@container/pagebar group/footer flex flex-wrap items-center justify-between gap-x-3 gap-y-2 shrink-0`,children:[(0,i.jsxs)(`div`,{className:`flex flex-wrap items-center gap-x-3 gap-y-2 text-sm text-neutral-600 dark:text-neutral-300`,children:[h&&m!==void 0&&(0,i.jsxs)(`span`,{children:[`총 `,m.toLocaleString(),`건`]}),d&&l!==void 0&&(0,i.jsxs)(`div`,{className:`flex items-center gap-1`,children:[(0,i.jsx)(`span`,{className:`text-neutral-500`,children:`페이지당`}),(0,i.jsx)(`div`,{className:`w-20`,children:(0,i.jsx)(e.Select,{variant:`box`,selectSize:`mini`,value:String(l),onChange:e=>d(Number(e)),options:u.map(e=>({value:String(e),label:String(e)})),placeholder:`선택`,"data-testid":v?`${v}-page-size`:void 0})})]}),(0,i.jsx)(`div`,{className:`contents @min-[640px]/pagebar:hidden`,children:g&&s>1&&(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.PageJumpInput,{currentPage:o,totalPages:s,onPageChange:c,"data-testid":v?`${v}-page-jump`:void 0}),_&&(0,i.jsx)(t.KeyboardNavButton,{onKeyDown:x})]})})]}),(0,i.jsxs)(`div`,{className:`flex items-center gap-3 @min-[640px]/pagebar:flex-1 @min-[640px]/pagebar:justify-end @max-[639px]/pagebar:w-full @max-[639px]/pagebar:justify-center`,children:[(0,i.jsx)(`div`,{className:`hidden @min-[640px]/pagebar:contents`,children:g&&s>1&&(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.PageJumpInput,{currentPage:o,totalPages:s,onPageChange:c,"data-testid":v?`${v}-page-jump`:void 0}),_&&(0,i.jsx)(t.KeyboardNavButton,{onKeyDown:x})]})}),(0,i.jsx)(r.Pagination,{currentPage:o,totalPages:s,onPageChange:c,hasPreviousPage:y,hasNextPage:b,"data-testid":v?`${v}-pagination`:void 0})]})]})}exports.PaginationFooter=o;
|