@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.
Files changed (256) hide show
  1. package/dist/_virtual/_rolldown/runtime.cjs.js +1 -0
  2. package/dist/components/_shared/form-size-tokens.cjs.js +1 -0
  3. package/dist/components/_shared/form-size-tokens.esm.js +29 -0
  4. package/dist/components/action-toast/ActionToast.cjs.js +1 -0
  5. package/dist/components/action-toast/ActionToast.esm.js +228 -0
  6. package/dist/components/animated-height/AnimatedHeight.cjs.js +1 -0
  7. package/dist/components/animated-height/AnimatedHeight.esm.js +36 -0
  8. package/dist/components/badge/Badge.cjs.js +1 -0
  9. package/dist/components/badge/Badge.esm.js +30 -0
  10. package/dist/components/badge/utils.cjs.js +1 -0
  11. package/dist/components/badge/utils.esm.js +38 -0
  12. package/dist/components/button/Button.cjs.js +1 -0
  13. package/dist/components/button/Button.esm.js +84 -0
  14. package/dist/components/button/utils.cjs.js +1 -0
  15. package/dist/components/button/utils.esm.js +38 -0
  16. package/dist/components/checkbox/Checkbox.cjs.js +1 -0
  17. package/dist/components/checkbox/Checkbox.esm.js +68 -0
  18. package/dist/components/checkbox/utils.cjs.js +1 -0
  19. package/dist/components/checkbox/utils.esm.js +44 -0
  20. package/dist/components/collapsible/Collapsible.cjs.js +1 -0
  21. package/dist/components/collapsible/Collapsible.esm.js +19 -0
  22. package/dist/components/date-input/DateInput.cjs.js +1 -0
  23. package/dist/components/date-input/DateInput.esm.js +39 -0
  24. package/dist/components/date-picker/date-picker.cjs.js +1 -0
  25. package/dist/components/date-picker/date-picker.esm.js +231 -0
  26. package/dist/components/date-picker/date-range-picker.cjs.js +1 -0
  27. package/dist/components/date-picker/date-range-picker.esm.js +287 -0
  28. package/dist/components/date-picker/month-picker.cjs.js +1 -0
  29. package/dist/components/date-picker/month-picker.esm.js +147 -0
  30. package/dist/components/drawer/Drawer.cjs.js +1 -0
  31. package/dist/components/drawer/Drawer.esm.js +113 -0
  32. package/dist/components/info-tooltip/InfoTooltip.cjs.js +1 -0
  33. package/dist/components/info-tooltip/InfoTooltip.esm.js +24 -0
  34. package/dist/components/input/Input.cjs.js +1 -0
  35. package/dist/components/input/Input.esm.js +95 -0
  36. package/dist/components/input/PasswordInput.cjs.js +1 -0
  37. package/dist/components/input/PasswordInput.esm.js +29 -0
  38. package/dist/components/input/format.cjs.js +1 -0
  39. package/dist/components/input/format.esm.js +33 -0
  40. package/dist/components/input/utils.cjs.js +1 -0
  41. package/dist/components/input/utils.esm.js +23 -0
  42. package/dist/components/loading-spinner/LoadingSpinner.cjs.js +1 -0
  43. package/dist/components/loading-spinner/LoadingSpinner.esm.js +47 -0
  44. package/dist/components/modal/Modal.cjs.js +1 -0
  45. package/dist/components/modal/Modal.esm.js +137 -0
  46. package/dist/components/modal/ModalSubView.cjs.js +1 -0
  47. package/dist/components/modal/ModalSubView.esm.js +91 -0
  48. package/dist/components/modal/StandardModal.cjs.js +1 -0
  49. package/dist/components/modal/StandardModal.esm.js +54 -0
  50. package/dist/components/page-title/PageTitle.cjs.js +1 -0
  51. package/dist/components/page-title/PageTitle.esm.js +16 -0
  52. package/dist/components/popover/Popover.cjs.js +1 -0
  53. package/dist/components/popover/Popover.esm.js +57 -0
  54. package/dist/components/search-box/ExactMatchToggle.cjs.js +1 -0
  55. package/dist/components/search-box/ExactMatchToggle.esm.js +27 -0
  56. package/dist/components/search-box/SearchBox.cjs.js +1 -0
  57. package/dist/components/search-box/SearchBox.esm.js +154 -0
  58. package/dist/components/search-box/SearchBoxChips.cjs.js +1 -0
  59. package/dist/components/search-box/SearchBoxChips.esm.js +36 -0
  60. package/dist/components/search-box/SearchBoxDateRange.cjs.js +1 -0
  61. package/dist/components/search-box/SearchBoxDateRange.esm.js +57 -0
  62. package/dist/components/search-box/SearchBoxDateSingle.cjs.js +1 -0
  63. package/dist/components/search-box/SearchBoxDateSingle.esm.js +37 -0
  64. package/dist/components/search-box/SearchBoxField.cjs.js +1 -0
  65. package/dist/components/search-box/SearchBoxField.esm.js +48 -0
  66. package/dist/components/search-box/SearchBoxFloatingInput.cjs.js +1 -0
  67. package/dist/components/search-box/SearchBoxFloatingInput.esm.js +38 -0
  68. package/dist/components/search-box/SearchBoxFloatingSelect.cjs.js +1 -0
  69. package/dist/components/search-box/SearchBoxFloatingSelect.esm.js +74 -0
  70. package/dist/components/search-box/SearchBoxMonth.cjs.js +1 -0
  71. package/dist/components/search-box/SearchBoxMonth.esm.js +35 -0
  72. package/dist/components/search-box/SearchBoxMultiSelect.cjs.js +1 -0
  73. package/dist/components/search-box/SearchBoxMultiSelect.esm.js +78 -0
  74. package/dist/components/search-box/SearchBoxSheetContext.cjs.js +1 -0
  75. package/dist/components/search-box/SearchBoxSheetContext.esm.js +5 -0
  76. package/dist/components/search-box/dateRangePresets.cjs.js +1 -0
  77. package/dist/components/search-box/dateRangePresets.esm.js +59 -0
  78. package/dist/components/search-box/parseDateRange.cjs.js +1 -0
  79. package/dist/components/search-box/parseDateRange.esm.js +21 -0
  80. package/dist/components/search-box/parseSearchValues.cjs.js +1 -0
  81. package/dist/components/search-box/parseSearchValues.esm.js +15 -0
  82. package/dist/components/search-box/useSearchBoxState.cjs.js +1 -0
  83. package/dist/components/search-box/useSearchBoxState.esm.js +87 -0
  84. package/dist/components/select/MultiSelect.cjs.js +1 -0
  85. package/dist/components/select/MultiSelect.esm.js +277 -0
  86. package/dist/components/select/Select.cjs.js +1 -0
  87. package/dist/components/select/Select.esm.js +308 -0
  88. package/dist/components/select/loading-dots.cjs.js +1 -0
  89. package/dist/components/select/loading-dots.esm.js +23 -0
  90. package/dist/components/switch/Switch.cjs.js +1 -0
  91. package/dist/components/switch/Switch.esm.js +36 -0
  92. package/dist/components/switch/utils.cjs.js +1 -0
  93. package/dist/components/switch/utils.esm.js +39 -0
  94. package/dist/components/table/accordion-table.cjs.js +1 -0
  95. package/dist/components/table/accordion-table.esm.js +418 -0
  96. package/dist/components/table/column-group-utils.cjs.js +1 -0
  97. package/dist/components/table/column-group-utils.esm.js +53 -0
  98. package/dist/components/table/components/ColumnPresetSelector.cjs.js +1 -0
  99. package/dist/components/table/components/ColumnPresetSelector.esm.js +165 -0
  100. package/dist/components/table/components/ColumnSettingsTable.cjs.js +4 -0
  101. package/dist/components/table/components/ColumnSettingsTable.esm.js +196 -0
  102. package/dist/components/table/components/KeyboardNavButton.cjs.js +1 -0
  103. package/dist/components/table/components/KeyboardNavButton.esm.js +24 -0
  104. package/dist/components/table/components/PageJumpInput.cjs.js +1 -0
  105. package/dist/components/table/components/PageJumpInput.esm.js +53 -0
  106. package/dist/components/table/components/Pagination.cjs.js +1 -0
  107. package/dist/components/table/components/Pagination.esm.js +162 -0
  108. package/dist/components/table/components/PaginationFooter.cjs.js +1 -0
  109. package/dist/components/table/components/PaginationFooter.esm.js +80 -0
  110. package/dist/components/table/components/SortableHeaderCell.cjs.js +1 -0
  111. package/dist/components/table/components/SortableHeaderCell.esm.js +30 -0
  112. package/dist/components/table/hooks/useColumnPresets.cjs.js +1 -0
  113. package/dist/components/table/hooks/useColumnPresets.esm.js +165 -0
  114. package/dist/components/table/hooks/useColumnResize.cjs.js +1 -0
  115. package/dist/components/table/hooks/useColumnResize.esm.js +106 -0
  116. package/dist/components/table/hooks/useFillEmptyRows.cjs.js +1 -0
  117. package/dist/components/table/hooks/useFillEmptyRows.esm.js +49 -0
  118. package/dist/components/table/hooks/useInfiniteScroll.cjs.js +1 -0
  119. package/dist/components/table/hooks/useInfiniteScroll.esm.js +32 -0
  120. package/dist/components/table/hooks/useTableColumnState.cjs.js +1 -0
  121. package/dist/components/table/hooks/useTableColumnState.esm.js +46 -0
  122. package/dist/components/table/hooks/useTableDragSelection.cjs.js +1 -0
  123. package/dist/components/table/hooks/useTableDragSelection.esm.js +76 -0
  124. package/dist/components/table/hooks/useTableSort.cjs.js +1 -0
  125. package/dist/components/table/hooks/useTableSort.esm.js +30 -0
  126. package/dist/components/table/hooks/useVirtualTable.cjs.js +1 -0
  127. package/dist/components/table/hooks/useVirtualTable.esm.js +18 -0
  128. package/dist/components/table/mini-table.cjs.js +1 -0
  129. package/dist/components/table/mini-table.esm.js +126 -0
  130. package/dist/components/table/paginated-mini-table.cjs.js +1 -0
  131. package/dist/components/table/paginated-mini-table.esm.js +31 -0
  132. package/dist/components/table/paginated-table.cjs.js +1 -0
  133. package/dist/components/table/paginated-table.esm.js +31 -0
  134. package/dist/components/table/table.cjs.js +1 -0
  135. package/dist/components/table/table.esm.js +342 -0
  136. package/dist/components/table/utils.cjs.js +37 -0
  137. package/dist/components/table/utils.esm.js +16 -0
  138. package/dist/components/table-checkbox/TableCheckbox.cjs.js +1 -0
  139. package/dist/components/table-checkbox/TableCheckbox.esm.js +39 -0
  140. package/dist/components/table-page-layout/TablePageLayout.cjs.js +1 -0
  141. package/dist/components/table-page-layout/TablePageLayout.esm.js +37 -0
  142. package/dist/components/textarea/Textarea.cjs.js +1 -0
  143. package/dist/components/textarea/Textarea.esm.js +62 -0
  144. package/dist/components/toast/ToastProvider.cjs.js +1 -0
  145. package/dist/components/toast/ToastProvider.esm.js +82 -0
  146. package/dist/components/toast/index.esm.js +3 -0
  147. package/dist/components/toolbar/Toolbar.cjs.js +1 -0
  148. package/dist/components/toolbar/Toolbar.esm.js +148 -0
  149. package/dist/components/tooltip/Tooltip.cjs.js +1 -0
  150. package/dist/components/tooltip/Tooltip.esm.js +39 -0
  151. package/dist/hooks/useBottomSheetDrag.cjs.js +1 -0
  152. package/dist/hooks/useBottomSheetDrag.esm.js +17 -0
  153. package/dist/hooks/useClickOutside.cjs.js +1 -0
  154. package/dist/hooks/useClickOutside.esm.js +20 -0
  155. package/dist/hooks/useMediaQuery.cjs.js +1 -0
  156. package/dist/hooks/useMediaQuery.esm.js +15 -0
  157. package/dist/hooks/useScrollLock.cjs.js +1 -0
  158. package/dist/hooks/useScrollLock.esm.js +16 -0
  159. package/dist/hooks.cjs.js +1 -0
  160. package/dist/hooks.esm.js +5 -0
  161. package/dist/index.cjs.js +1 -40
  162. package/dist/index.esm.js +58 -0
  163. package/dist/lib/Portal.cjs.js +1 -0
  164. package/dist/lib/Portal.esm.js +11 -0
  165. package/dist/lib/column-preset-storage.cjs.js +1 -0
  166. package/dist/lib/column-preset-storage.esm.js +123 -0
  167. package/dist/lib/overlay-stack.cjs.js +1 -0
  168. package/dist/lib/overlay-stack.esm.js +28 -0
  169. package/dist/lib/utils.cjs.js +1 -0
  170. package/dist/lib/utils.esm.js +11 -0
  171. package/dist/node_modules/clsx/dist/clsx.cjs.js +1 -0
  172. package/dist/node_modules/clsx/dist/clsx.esm.js +16 -0
  173. package/dist/node_modules/lucide-react/dist/esm/Icon.cjs.js +1 -0
  174. package/dist/node_modules/lucide-react/dist/esm/Icon.esm.js +23 -0
  175. package/dist/node_modules/lucide-react/dist/esm/context.cjs.js +1 -0
  176. package/dist/node_modules/lucide-react/dist/esm/context.esm.js +6 -0
  177. package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.cjs.js +1 -0
  178. package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.esm.js +17 -0
  179. package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.cjs.js +1 -0
  180. package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.esm.js +14 -0
  181. package/dist/node_modules/lucide-react/dist/esm/icons/arrow-left.cjs.js +1 -0
  182. package/dist/node_modules/lucide-react/dist/esm/icons/arrow-left.esm.js +10 -0
  183. package/dist/node_modules/lucide-react/dist/esm/icons/calendar.cjs.js +1 -0
  184. package/dist/node_modules/lucide-react/dist/esm/icons/calendar.esm.js +25 -0
  185. package/dist/node_modules/lucide-react/dist/esm/icons/check.cjs.js +1 -0
  186. package/dist/node_modules/lucide-react/dist/esm/icons/check.esm.js +7 -0
  187. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.cjs.js +1 -0
  188. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.esm.js +7 -0
  189. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.cjs.js +1 -0
  190. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.esm.js +7 -0
  191. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.cjs.js +1 -0
  192. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.esm.js +7 -0
  193. package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-left.cjs.js +1 -0
  194. package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-left.esm.js +10 -0
  195. package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-right.cjs.js +1 -0
  196. package/dist/node_modules/lucide-react/dist/esm/icons/chevrons-right.esm.js +10 -0
  197. package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.cjs.js +1 -0
  198. package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.esm.js +12 -0
  199. package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.cjs.js +1 -0
  200. package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.esm.js +19 -0
  201. package/dist/node_modules/lucide-react/dist/esm/icons/eye-off.cjs.js +1 -0
  202. package/dist/node_modules/lucide-react/dist/esm/icons/eye-off.esm.js +21 -0
  203. package/dist/node_modules/lucide-react/dist/esm/icons/eye.cjs.js +1 -0
  204. package/dist/node_modules/lucide-react/dist/esm/icons/eye.esm.js +12 -0
  205. package/dist/node_modules/lucide-react/dist/esm/icons/grip-vertical.cjs.js +1 -0
  206. package/dist/node_modules/lucide-react/dist/esm/icons/grip-vertical.esm.js +41 -0
  207. package/dist/node_modules/lucide-react/dist/esm/icons/info.cjs.js +1 -0
  208. package/dist/node_modules/lucide-react/dist/esm/icons/info.esm.js +19 -0
  209. package/dist/node_modules/lucide-react/dist/esm/icons/keyboard.cjs.js +1 -0
  210. package/dist/node_modules/lucide-react/dist/esm/icons/keyboard.esm.js +45 -0
  211. package/dist/node_modules/lucide-react/dist/esm/icons/list-filter.cjs.js +1 -0
  212. package/dist/node_modules/lucide-react/dist/esm/icons/list-filter.esm.js +17 -0
  213. package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.cjs.js +1 -0
  214. package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.esm.js +7 -0
  215. package/dist/node_modules/lucide-react/dist/esm/icons/minus.cjs.js +1 -0
  216. package/dist/node_modules/lucide-react/dist/esm/icons/minus.esm.js +7 -0
  217. package/dist/node_modules/lucide-react/dist/esm/icons/rotate-ccw.cjs.js +1 -0
  218. package/dist/node_modules/lucide-react/dist/esm/icons/rotate-ccw.esm.js +10 -0
  219. package/dist/node_modules/lucide-react/dist/esm/icons/save.cjs.js +1 -0
  220. package/dist/node_modules/lucide-react/dist/esm/icons/save.esm.js +17 -0
  221. package/dist/node_modules/lucide-react/dist/esm/icons/search.cjs.js +1 -0
  222. package/dist/node_modules/lucide-react/dist/esm/icons/search.esm.js +12 -0
  223. package/dist/node_modules/lucide-react/dist/esm/icons/settings.cjs.js +1 -0
  224. package/dist/node_modules/lucide-react/dist/esm/icons/settings.esm.js +12 -0
  225. package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.cjs.js +1 -0
  226. package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.esm.js +17 -0
  227. package/dist/node_modules/lucide-react/dist/esm/icons/wrench.cjs.js +1 -0
  228. package/dist/node_modules/lucide-react/dist/esm/icons/wrench.esm.js +7 -0
  229. package/dist/node_modules/lucide-react/dist/esm/icons/x.cjs.js +1 -0
  230. package/dist/node_modules/lucide-react/dist/esm/icons/x.esm.js +10 -0
  231. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/hasA11yProp.cjs.js +1 -0
  232. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/hasA11yProp.esm.js +7 -0
  233. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/mergeClasses.cjs.js +1 -0
  234. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/mergeClasses.esm.js +4 -0
  235. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toCamelCase.cjs.js +1 -0
  236. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toCamelCase.esm.js +4 -0
  237. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toKebabCase.cjs.js +1 -0
  238. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toKebabCase.esm.js +4 -0
  239. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toPascalCase.cjs.js +1 -0
  240. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils/toPascalCase.esm.js +8 -0
  241. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.cjs.js +1 -0
  242. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.esm.js +1714 -0
  243. package/dist/node_modules/use-debounce/dist/index.module.cjs.js +1 -0
  244. package/dist/node_modules/use-debounce/dist/index.module.esm.js +70 -0
  245. package/dist/src/components/action-toast/ActionToast.d.ts +6 -1
  246. package/dist/src/components/button/Button.d.ts +16 -0
  247. package/dist/src/components/drawer/Drawer.d.ts +6 -1
  248. package/dist/src/components/info-tooltip/InfoTooltip.d.ts +7 -0
  249. package/dist/src/components/loading-spinner/LoadingSpinner.d.ts +7 -0
  250. package/dist/src/components/modal/Modal.d.ts +7 -1
  251. package/dist/src/components/popover/Popover.d.ts +19 -1
  252. package/dist/src/components/tooltip/Tooltip.d.ts +10 -0
  253. package/dist/ui.css +1 -1
  254. package/llms.txt +91 -0
  255. package/package.json +10 -4
  256. 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;