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