@qijenchen/design-system 0.1.0-beta.10

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 (507) hide show
  1. package/README.md +163 -0
  2. package/dist/components/Accordion/accordion.d.ts +37 -0
  3. package/dist/components/Accordion/accordion.d.ts.map +1 -0
  4. package/dist/components/Accordion/accordion.js +78 -0
  5. package/dist/components/Accordion/accordion.js.map +1 -0
  6. package/dist/components/Alert/alert.d.ts +47 -0
  7. package/dist/components/Alert/alert.d.ts.map +1 -0
  8. package/dist/components/Alert/alert.js +132 -0
  9. package/dist/components/Alert/alert.js.map +1 -0
  10. package/dist/components/AppShell/_demo-helpers.d.ts +49 -0
  11. package/dist/components/AppShell/_demo-helpers.d.ts.map +1 -0
  12. package/dist/components/AppShell/app-shell.d.ts +76 -0
  13. package/dist/components/AppShell/app-shell.d.ts.map +1 -0
  14. package/dist/components/AppShell/app-shell.js +214 -0
  15. package/dist/components/AppShell/app-shell.js.map +1 -0
  16. package/dist/components/AspectRatio/aspect-ratio.d.ts +40 -0
  17. package/dist/components/AspectRatio/aspect-ratio.d.ts.map +1 -0
  18. package/dist/components/AspectRatio/aspect-ratio.js +23 -0
  19. package/dist/components/AspectRatio/aspect-ratio.js.map +1 -0
  20. package/dist/components/Avatar/avatar.d.ts +85 -0
  21. package/dist/components/Avatar/avatar.d.ts.map +1 -0
  22. package/dist/components/Avatar/avatar.js +195 -0
  23. package/dist/components/Avatar/avatar.js.map +1 -0
  24. package/dist/components/Badge/badge.d.ts +43 -0
  25. package/dist/components/Badge/badge.d.ts.map +1 -0
  26. package/dist/components/Badge/badge.js +69 -0
  27. package/dist/components/Badge/badge.js.map +1 -0
  28. package/dist/components/Breadcrumb/breadcrumb.d.ts +163 -0
  29. package/dist/components/Breadcrumb/breadcrumb.d.ts.map +1 -0
  30. package/dist/components/Breadcrumb/breadcrumb.js +300 -0
  31. package/dist/components/Breadcrumb/breadcrumb.js.map +1 -0
  32. package/dist/components/BulkActionBar/bulk-action-bar.d.ts +46 -0
  33. package/dist/components/BulkActionBar/bulk-action-bar.d.ts.map +1 -0
  34. package/dist/components/BulkActionBar/bulk-action-bar.js +78 -0
  35. package/dist/components/BulkActionBar/bulk-action-bar.js.map +1 -0
  36. package/dist/components/Button/button-group.d.ts +49 -0
  37. package/dist/components/Button/button-group.d.ts.map +1 -0
  38. package/dist/components/Button/button-group.js +46 -0
  39. package/dist/components/Button/button-group.js.map +1 -0
  40. package/dist/components/Button/button.d.ts +203 -0
  41. package/dist/components/Button/button.d.ts.map +1 -0
  42. package/dist/components/Button/button.js +309 -0
  43. package/dist/components/Button/button.js.map +1 -0
  44. package/dist/components/Calendar/calendar.d.ts +81 -0
  45. package/dist/components/Calendar/calendar.d.ts.map +1 -0
  46. package/dist/components/Calendar/calendar.js +282 -0
  47. package/dist/components/Calendar/calendar.js.map +1 -0
  48. package/dist/components/Carousel/carousel.d.ts +61 -0
  49. package/dist/components/Carousel/carousel.d.ts.map +1 -0
  50. package/dist/components/Carousel/carousel.js +276 -0
  51. package/dist/components/Carousel/carousel.js.map +1 -0
  52. package/dist/components/Chart/chart.d.ts +94 -0
  53. package/dist/components/Chart/chart.d.ts.map +1 -0
  54. package/dist/components/Chart/chart.js +233 -0
  55. package/dist/components/Chart/chart.js.map +1 -0
  56. package/dist/components/Checkbox/checkbox-group.d.ts +58 -0
  57. package/dist/components/Checkbox/checkbox-group.d.ts.map +1 -0
  58. package/dist/components/Checkbox/checkbox-group.js +28 -0
  59. package/dist/components/Checkbox/checkbox-group.js.map +1 -0
  60. package/dist/components/Checkbox/checkbox.d.ts +73 -0
  61. package/dist/components/Checkbox/checkbox.d.ts.map +1 -0
  62. package/dist/components/Checkbox/checkbox.js +125 -0
  63. package/dist/components/Checkbox/checkbox.js.map +1 -0
  64. package/dist/components/Chip/chip.d.ts +54 -0
  65. package/dist/components/Chip/chip.d.ts.map +1 -0
  66. package/dist/components/Chip/chip.js +224 -0
  67. package/dist/components/Chip/chip.js.map +1 -0
  68. package/dist/components/CircularProgress/circular-progress.d.ts +40 -0
  69. package/dist/components/CircularProgress/circular-progress.d.ts.map +1 -0
  70. package/dist/components/CircularProgress/circular-progress.js +118 -0
  71. package/dist/components/CircularProgress/circular-progress.js.map +1 -0
  72. package/dist/components/Coachmark/coachmark.d.ts +100 -0
  73. package/dist/components/Coachmark/coachmark.d.ts.map +1 -0
  74. package/dist/components/Coachmark/coachmark.js +107 -0
  75. package/dist/components/Coachmark/coachmark.js.map +1 -0
  76. package/dist/components/Combobox/combobox.d.ts +150 -0
  77. package/dist/components/Combobox/combobox.d.ts.map +1 -0
  78. package/dist/components/Combobox/combobox.js +595 -0
  79. package/dist/components/Combobox/combobox.js.map +1 -0
  80. package/dist/components/Command/command.d.ts +106 -0
  81. package/dist/components/Command/command.d.ts.map +1 -0
  82. package/dist/components/Command/command.js +123 -0
  83. package/dist/components/Command/command.js.map +1 -0
  84. package/dist/components/DataTable/active-editor-controller.d.ts +66 -0
  85. package/dist/components/DataTable/active-editor-controller.d.ts.map +1 -0
  86. package/dist/components/DataTable/cell-registry.d.ts +37 -0
  87. package/dist/components/DataTable/cell-registry.d.ts.map +1 -0
  88. package/dist/components/DataTable/cell-registry.js +377 -0
  89. package/dist/components/DataTable/cell-registry.js.map +1 -0
  90. package/dist/components/DataTable/column-types.d.ts +145 -0
  91. package/dist/components/DataTable/column-types.d.ts.map +1 -0
  92. package/dist/components/DataTable/column-types.js +17 -0
  93. package/dist/components/DataTable/column-types.js.map +1 -0
  94. package/dist/components/DataTable/data-table-column-visibility-panel.d.ts +49 -0
  95. package/dist/components/DataTable/data-table-column-visibility-panel.d.ts.map +1 -0
  96. package/dist/components/DataTable/data-table-filter-panel.d.ts +30 -0
  97. package/dist/components/DataTable/data-table-filter-panel.d.ts.map +1 -0
  98. package/dist/components/DataTable/data-table-interaction-layer.d.ts +78 -0
  99. package/dist/components/DataTable/data-table-interaction-layer.d.ts.map +1 -0
  100. package/dist/components/DataTable/data-table-interaction-layer.js +220 -0
  101. package/dist/components/DataTable/data-table-interaction-layer.js.map +1 -0
  102. package/dist/components/DataTable/data-table-sort-manager.d.ts +19 -0
  103. package/dist/components/DataTable/data-table-sort-manager.d.ts.map +1 -0
  104. package/dist/components/DataTable/data-table.d.ts +181 -0
  105. package/dist/components/DataTable/data-table.d.ts.map +1 -0
  106. package/dist/components/DataTable/data-table.js +1851 -0
  107. package/dist/components/DataTable/data-table.js.map +1 -0
  108. package/dist/components/DataTable/filter-operators.d.ts +116 -0
  109. package/dist/components/DataTable/filter-operators.d.ts.map +1 -0
  110. package/dist/components/DataTable/filter-tree.d.ts +66 -0
  111. package/dist/components/DataTable/filter-tree.d.ts.map +1 -0
  112. package/dist/components/DataTable/lib/column-meta.d.ts +49 -0
  113. package/dist/components/DataTable/lib/column-meta.d.ts.map +1 -0
  114. package/dist/components/DateGrid/date-grid.d.ts +61 -0
  115. package/dist/components/DateGrid/date-grid.d.ts.map +1 -0
  116. package/dist/components/DateGrid/date-grid.js +168 -0
  117. package/dist/components/DateGrid/date-grid.js.map +1 -0
  118. package/dist/components/DatePicker/date-picker.d.ts +119 -0
  119. package/dist/components/DatePicker/date-picker.d.ts.map +1 -0
  120. package/dist/components/DatePicker/date-picker.js +743 -0
  121. package/dist/components/DatePicker/date-picker.js.map +1 -0
  122. package/dist/components/DescriptionList/description-list.d.ts +60 -0
  123. package/dist/components/DescriptionList/description-list.d.ts.map +1 -0
  124. package/dist/components/DescriptionList/description-list.js +77 -0
  125. package/dist/components/DescriptionList/description-list.js.map +1 -0
  126. package/dist/components/Dialog/dialog.d.ts +54 -0
  127. package/dist/components/Dialog/dialog.d.ts.map +1 -0
  128. package/dist/components/Dialog/dialog.js +151 -0
  129. package/dist/components/Dialog/dialog.js.map +1 -0
  130. package/dist/components/DropdownMenu/dropdown-menu.d.ts +111 -0
  131. package/dist/components/DropdownMenu/dropdown-menu.d.ts.map +1 -0
  132. package/dist/components/DropdownMenu/dropdown-menu.js +288 -0
  133. package/dist/components/DropdownMenu/dropdown-menu.js.map +1 -0
  134. package/dist/components/Empty/empty.d.ts +40 -0
  135. package/dist/components/Empty/empty.d.ts.map +1 -0
  136. package/dist/components/Empty/empty.js +66 -0
  137. package/dist/components/Empty/empty.js.map +1 -0
  138. package/dist/components/Field/field-context.d.ts +77 -0
  139. package/dist/components/Field/field-context.d.ts.map +1 -0
  140. package/dist/components/Field/field-context.js +37 -0
  141. package/dist/components/Field/field-context.js.map +1 -0
  142. package/dist/components/Field/field-types.d.ts +5 -0
  143. package/dist/components/Field/field-types.d.ts.map +1 -0
  144. package/dist/components/Field/field-types.js +13 -0
  145. package/dist/components/Field/field-types.js.map +1 -0
  146. package/dist/components/Field/field-wrapper.d.ts +17 -0
  147. package/dist/components/Field/field-wrapper.d.ts.map +1 -0
  148. package/dist/components/Field/field-wrapper.js +252 -0
  149. package/dist/components/Field/field-wrapper.js.map +1 -0
  150. package/dist/components/Field/field.d.ts +127 -0
  151. package/dist/components/Field/field.d.ts.map +1 -0
  152. package/dist/components/Field/field.js +295 -0
  153. package/dist/components/Field/field.js.map +1 -0
  154. package/dist/components/FieldControlGroup/field-control-group.d.ts +74 -0
  155. package/dist/components/FieldControlGroup/field-control-group.d.ts.map +1 -0
  156. package/dist/components/FieldControlGroup/field-control-group.js +62 -0
  157. package/dist/components/FieldControlGroup/field-control-group.js.map +1 -0
  158. package/dist/components/FileItem/file-item.d.ts +44 -0
  159. package/dist/components/FileItem/file-item.d.ts.map +1 -0
  160. package/dist/components/FileItem/file-item.js +202 -0
  161. package/dist/components/FileItem/file-item.js.map +1 -0
  162. package/dist/components/FileUpload/file-upload.d.ts +97 -0
  163. package/dist/components/FileUpload/file-upload.d.ts.map +1 -0
  164. package/dist/components/FileUpload/file-upload.js +231 -0
  165. package/dist/components/FileUpload/file-upload.js.map +1 -0
  166. package/dist/components/FileViewer/file-viewer-types.d.ts +73 -0
  167. package/dist/components/FileViewer/file-viewer-types.d.ts.map +1 -0
  168. package/dist/components/FileViewer/file-viewer.d.ts +82 -0
  169. package/dist/components/FileViewer/file-viewer.d.ts.map +1 -0
  170. package/dist/components/FileViewer/file-viewer.js +752 -0
  171. package/dist/components/FileViewer/file-viewer.js.map +1 -0
  172. package/dist/components/FileViewer/image-renderer.d.ts +9 -0
  173. package/dist/components/FileViewer/image-renderer.d.ts.map +1 -0
  174. package/dist/components/FileViewer/image-renderer.js +165 -0
  175. package/dist/components/FileViewer/image-renderer.js.map +1 -0
  176. package/dist/components/HoverCard/hover-card.d.ts +30 -0
  177. package/dist/components/HoverCard/hover-card.d.ts.map +1 -0
  178. package/dist/components/HoverCard/hover-card.js +61 -0
  179. package/dist/components/HoverCard/hover-card.js.map +1 -0
  180. package/dist/components/Input/input.d.ts +72 -0
  181. package/dist/components/Input/input.d.ts.map +1 -0
  182. package/dist/components/Input/input.js +148 -0
  183. package/dist/components/Input/input.js.map +1 -0
  184. package/dist/components/LinkInput/link-input.d.ts +46 -0
  185. package/dist/components/LinkInput/link-input.d.ts.map +1 -0
  186. package/dist/components/LinkInput/link-input.js +215 -0
  187. package/dist/components/LinkInput/link-input.js.map +1 -0
  188. package/dist/components/Menu/menu-item.d.ts +83 -0
  189. package/dist/components/Menu/menu-item.d.ts.map +1 -0
  190. package/dist/components/Menu/menu-item.js +209 -0
  191. package/dist/components/Menu/menu-item.js.map +1 -0
  192. package/dist/components/NameCard/name-card.d.ts +85 -0
  193. package/dist/components/NameCard/name-card.d.ts.map +1 -0
  194. package/dist/components/NameCard/name-card.js +153 -0
  195. package/dist/components/NameCard/name-card.js.map +1 -0
  196. package/dist/components/Notice/notice.d.ts +69 -0
  197. package/dist/components/Notice/notice.d.ts.map +1 -0
  198. package/dist/components/Notice/notice.js +121 -0
  199. package/dist/components/Notice/notice.js.map +1 -0
  200. package/dist/components/NumberInput/number-input.d.ts +57 -0
  201. package/dist/components/NumberInput/number-input.d.ts.map +1 -0
  202. package/dist/components/NumberInput/number-input.js +131 -0
  203. package/dist/components/NumberInput/number-input.js.map +1 -0
  204. package/dist/components/OverflowIndicator/overflow-indicator.d.ts +23 -0
  205. package/dist/components/OverflowIndicator/overflow-indicator.d.ts.map +1 -0
  206. package/dist/components/OverflowIndicator/overflow-indicator.js +111 -0
  207. package/dist/components/OverflowIndicator/overflow-indicator.js.map +1 -0
  208. package/dist/components/PeoplePicker/avatar-stack-overflow.d.ts +57 -0
  209. package/dist/components/PeoplePicker/avatar-stack-overflow.d.ts.map +1 -0
  210. package/dist/components/PeoplePicker/avatar-stack-overflow.js +35 -0
  211. package/dist/components/PeoplePicker/avatar-stack-overflow.js.map +1 -0
  212. package/dist/components/PeoplePicker/people-picker-helpers.d.ts +7 -0
  213. package/dist/components/PeoplePicker/people-picker-helpers.d.ts.map +1 -0
  214. package/dist/components/PeoplePicker/people-picker-helpers.js +25 -0
  215. package/dist/components/PeoplePicker/people-picker-helpers.js.map +1 -0
  216. package/dist/components/PeoplePicker/people-picker.d.ts +77 -0
  217. package/dist/components/PeoplePicker/people-picker.d.ts.map +1 -0
  218. package/dist/components/PeoplePicker/people-picker.js +263 -0
  219. package/dist/components/PeoplePicker/people-picker.js.map +1 -0
  220. package/dist/components/PeoplePicker/person-display.d.ts +66 -0
  221. package/dist/components/PeoplePicker/person-display.d.ts.map +1 -0
  222. package/dist/components/PeoplePicker/person-display.js +203 -0
  223. package/dist/components/PeoplePicker/person-display.js.map +1 -0
  224. package/dist/components/Popover/popover.d.ts +50 -0
  225. package/dist/components/Popover/popover.d.ts.map +1 -0
  226. package/dist/components/Popover/popover.js +113 -0
  227. package/dist/components/Popover/popover.js.map +1 -0
  228. package/dist/components/ProgressBar/progress-bar.d.ts +37 -0
  229. package/dist/components/ProgressBar/progress-bar.d.ts.map +1 -0
  230. package/dist/components/ProgressBar/progress-bar.js +86 -0
  231. package/dist/components/ProgressBar/progress-bar.js.map +1 -0
  232. package/dist/components/RadioGroup/radio-group.d.ts +78 -0
  233. package/dist/components/RadioGroup/radio-group.d.ts.map +1 -0
  234. package/dist/components/RadioGroup/radio-group.js +153 -0
  235. package/dist/components/RadioGroup/radio-group.js.map +1 -0
  236. package/dist/components/Rating/rating.d.ts +46 -0
  237. package/dist/components/Rating/rating.d.ts.map +1 -0
  238. package/dist/components/Rating/rating.js +179 -0
  239. package/dist/components/Rating/rating.js.map +1 -0
  240. package/dist/components/ScrollArea/scroll-area.d.ts +45 -0
  241. package/dist/components/ScrollArea/scroll-area.d.ts.map +1 -0
  242. package/dist/components/ScrollArea/scroll-area.js +65 -0
  243. package/dist/components/ScrollArea/scroll-area.js.map +1 -0
  244. package/dist/components/SegmentedControl/segmented-control.d.ts +102 -0
  245. package/dist/components/SegmentedControl/segmented-control.d.ts.map +1 -0
  246. package/dist/components/SegmentedControl/segmented-control.js +171 -0
  247. package/dist/components/SegmentedControl/segmented-control.js.map +1 -0
  248. package/dist/components/Select/select.d.ts +102 -0
  249. package/dist/components/Select/select.d.ts.map +1 -0
  250. package/dist/components/Select/select.js +435 -0
  251. package/dist/components/Select/select.js.map +1 -0
  252. package/dist/components/SelectMenu/select-menu.d.ts +103 -0
  253. package/dist/components/SelectMenu/select-menu.d.ts.map +1 -0
  254. package/dist/components/SelectMenu/select-menu.js +239 -0
  255. package/dist/components/SelectMenu/select-menu.js.map +1 -0
  256. package/dist/components/SelectionControl/selection-item.d.ts +69 -0
  257. package/dist/components/SelectionControl/selection-item.d.ts.map +1 -0
  258. package/dist/components/SelectionControl/selection-item.js +142 -0
  259. package/dist/components/SelectionControl/selection-item.js.map +1 -0
  260. package/dist/components/Separator/separator.d.ts +17 -0
  261. package/dist/components/Separator/separator.d.ts.map +1 -0
  262. package/dist/components/Separator/separator.js +39 -0
  263. package/dist/components/Separator/separator.js.map +1 -0
  264. package/dist/components/Sheet/sheet.d.ts +56 -0
  265. package/dist/components/Sheet/sheet.d.ts.map +1 -0
  266. package/dist/components/Sheet/sheet.js +145 -0
  267. package/dist/components/Sheet/sheet.js.map +1 -0
  268. package/dist/components/Sidebar/sidebar.d.ts +195 -0
  269. package/dist/components/Sidebar/sidebar.d.ts.map +1 -0
  270. package/dist/components/Sidebar/sidebar.js +826 -0
  271. package/dist/components/Sidebar/sidebar.js.map +1 -0
  272. package/dist/components/Skeleton/skeleton.d.ts +16 -0
  273. package/dist/components/Skeleton/skeleton.d.ts.map +1 -0
  274. package/dist/components/Skeleton/skeleton.js +30 -0
  275. package/dist/components/Skeleton/skeleton.js.map +1 -0
  276. package/dist/components/Slider/slider.d.ts +48 -0
  277. package/dist/components/Slider/slider.d.ts.map +1 -0
  278. package/dist/components/Slider/slider.js +108 -0
  279. package/dist/components/Slider/slider.js.map +1 -0
  280. package/dist/components/Steps/steps.d.ts +71 -0
  281. package/dist/components/Steps/steps.d.ts.map +1 -0
  282. package/dist/components/Steps/steps.js +583 -0
  283. package/dist/components/Steps/steps.js.map +1 -0
  284. package/dist/components/Switch/switch.d.ts +112 -0
  285. package/dist/components/Switch/switch.d.ts.map +1 -0
  286. package/dist/components/Switch/switch.js +179 -0
  287. package/dist/components/Switch/switch.js.map +1 -0
  288. package/dist/components/Tabs/tabs.d.ts +104 -0
  289. package/dist/components/Tabs/tabs.d.ts.map +1 -0
  290. package/dist/components/Tabs/tabs.js +316 -0
  291. package/dist/components/Tabs/tabs.js.map +1 -0
  292. package/dist/components/Tag/tag.d.ts +86 -0
  293. package/dist/components/Tag/tag.d.ts.map +1 -0
  294. package/dist/components/Tag/tag.js +172 -0
  295. package/dist/components/Tag/tag.js.map +1 -0
  296. package/dist/components/Textarea/textarea.d.ts +74 -0
  297. package/dist/components/Textarea/textarea.d.ts.map +1 -0
  298. package/dist/components/Textarea/textarea.js +224 -0
  299. package/dist/components/Textarea/textarea.js.map +1 -0
  300. package/dist/components/TimePicker/time-columns.d.ts +46 -0
  301. package/dist/components/TimePicker/time-columns.d.ts.map +1 -0
  302. package/dist/components/TimePicker/time-columns.js +173 -0
  303. package/dist/components/TimePicker/time-columns.js.map +1 -0
  304. package/dist/components/TimePicker/time-picker.d.ts +94 -0
  305. package/dist/components/TimePicker/time-picker.d.ts.map +1 -0
  306. package/dist/components/TimePicker/time-picker.js +253 -0
  307. package/dist/components/TimePicker/time-picker.js.map +1 -0
  308. package/dist/components/Toast/toast.d.ts +61 -0
  309. package/dist/components/Toast/toast.d.ts.map +1 -0
  310. package/dist/components/Toast/toast.js +76 -0
  311. package/dist/components/Toast/toast.js.map +1 -0
  312. package/dist/components/Tooltip/tooltip.d.ts +20 -0
  313. package/dist/components/Tooltip/tooltip.d.ts.map +1 -0
  314. package/dist/components/Tooltip/tooltip.js +53 -0
  315. package/dist/components/Tooltip/tooltip.js.map +1 -0
  316. package/dist/components/TreeView/tree-view.d.ts +166 -0
  317. package/dist/components/TreeView/tree-view.d.ts.map +1 -0
  318. package/dist/components/TreeView/tree-view.js +617 -0
  319. package/dist/components/TreeView/tree-view.js.map +1 -0
  320. package/dist/hooks/use-controllable.d.ts +16 -0
  321. package/dist/hooks/use-controllable.d.ts.map +1 -0
  322. package/dist/hooks/use-controllable.js +26 -0
  323. package/dist/hooks/use-controllable.js.map +1 -0
  324. package/dist/hooks/use-is-narrow-viewport.d.ts +2 -0
  325. package/dist/hooks/use-is-narrow-viewport.d.ts.map +1 -0
  326. package/dist/hooks/use-is-narrow-viewport.js +19 -0
  327. package/dist/hooks/use-is-narrow-viewport.js.map +1 -0
  328. package/dist/hooks/use-is-touch-device.d.ts +8 -0
  329. package/dist/hooks/use-is-touch-device.d.ts.map +1 -0
  330. package/dist/hooks/use-is-touch-device.js +16 -0
  331. package/dist/hooks/use-is-touch-device.js.map +1 -0
  332. package/dist/hooks/use-overflow-items.d.ts +124 -0
  333. package/dist/hooks/use-overflow-items.d.ts.map +1 -0
  334. package/dist/hooks/use-overflow-items.js +97 -0
  335. package/dist/hooks/use-overflow-items.js.map +1 -0
  336. package/dist/index.d.ts +74 -0
  337. package/dist/index.d.ts.map +1 -0
  338. package/dist/index.js +371 -0
  339. package/dist/index.js.map +1 -0
  340. package/dist/lib/drag-visual.d.ts +158 -0
  341. package/dist/lib/drag-visual.d.ts.map +1 -0
  342. package/dist/lib/drag-visual.js +96 -0
  343. package/dist/lib/drag-visual.js.map +1 -0
  344. package/dist/lib/i18n/i18n-context.d.ts +105 -0
  345. package/dist/lib/i18n/i18n-context.d.ts.map +1 -0
  346. package/dist/lib/multi-select-ordering.d.ts +54 -0
  347. package/dist/lib/multi-select-ordering.d.ts.map +1 -0
  348. package/dist/lib/multi-select-ordering.js +13 -0
  349. package/dist/lib/multi-select-ordering.js.map +1 -0
  350. package/dist/lib/utils.d.ts +12 -0
  351. package/dist/lib/utils.d.ts.map +1 -0
  352. package/dist/lib/utils.js +79 -0
  353. package/dist/lib/utils.js.map +1 -0
  354. package/dist/patterns/element-anatomy/item-anatomy.d.ts +370 -0
  355. package/dist/patterns/element-anatomy/item-anatomy.d.ts.map +1 -0
  356. package/dist/patterns/element-anatomy/item-anatomy.js +272 -0
  357. package/dist/patterns/element-anatomy/item-anatomy.js.map +1 -0
  358. package/dist/patterns/header-canonical/chrome-header.d.ts +80 -0
  359. package/dist/patterns/header-canonical/chrome-header.d.ts.map +1 -0
  360. package/dist/patterns/header-canonical/chrome-header.js +75 -0
  361. package/dist/patterns/header-canonical/chrome-header.js.map +1 -0
  362. package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts +101 -0
  363. package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts.map +1 -0
  364. package/dist/patterns/horizontal-overflow/horizontal-overflow.js +105 -0
  365. package/dist/patterns/horizontal-overflow/horizontal-overflow.js.map +1 -0
  366. package/dist/patterns/overlay-surface/overlay-surface.d.ts +28 -0
  367. package/dist/patterns/overlay-surface/overlay-surface.d.ts.map +1 -0
  368. package/dist/patterns/overlay-surface/overlay-surface.js +85 -0
  369. package/dist/patterns/overlay-surface/overlay-surface.js.map +1 -0
  370. package/dist/patterns/resize-handle/resize-handle.d.ts +102 -0
  371. package/dist/patterns/resize-handle/resize-handle.d.ts.map +1 -0
  372. package/dist/patterns/resize-handle/resize-handle.js +74 -0
  373. package/dist/patterns/resize-handle/resize-handle.js.map +1 -0
  374. package/dist/react-day-picker.css +457 -0
  375. package/dist/stories-helpers/anatomy/anatomy-utils.d.ts +40 -0
  376. package/dist/stories-helpers/anatomy/anatomy-utils.d.ts.map +1 -0
  377. package/dist/tokens/elevation/overlay-geometry.d.ts +12 -0
  378. package/dist/tokens/elevation/overlay-geometry.d.ts.map +1 -0
  379. package/dist/tokens/elevation/overlay-geometry.js +7 -0
  380. package/dist/tokens/elevation/overlay-geometry.js.map +1 -0
  381. package/dist/tokens/motion/motion.d.ts +15 -0
  382. package/dist/tokens/motion/motion.d.ts.map +1 -0
  383. package/dist/tokens/motion/motion.js +9 -0
  384. package/dist/tokens/motion/motion.js.map +1 -0
  385. package/dist/tokens/uiSize/icon-size.d.ts +53 -0
  386. package/dist/tokens/uiSize/icon-size.d.ts.map +1 -0
  387. package/package.json +92 -0
  388. package/src/README.md +32 -0
  389. package/src/components/Accordion/accordion.tsx +104 -0
  390. package/src/components/Alert/alert.tsx +188 -0
  391. package/src/components/AppShell/_demo-helpers.tsx +198 -0
  392. package/src/components/AppShell/app-shell.tsx +364 -0
  393. package/src/components/AspectRatio/aspect-ratio.tsx +58 -0
  394. package/src/components/Avatar/avatar.tsx +368 -0
  395. package/src/components/Badge/badge.tsx +104 -0
  396. package/src/components/Breadcrumb/breadcrumb.tsx +619 -0
  397. package/src/components/BulkActionBar/bulk-action-bar.tsx +156 -0
  398. package/src/components/Button/button-group.tsx +96 -0
  399. package/src/components/Button/button.tsx +539 -0
  400. package/src/components/Calendar/calendar.tsx +411 -0
  401. package/src/components/Carousel/carousel.tsx +371 -0
  402. package/src/components/Chart/chart.tsx +376 -0
  403. package/src/components/Checkbox/checkbox-group.tsx +94 -0
  404. package/src/components/Checkbox/checkbox.tsx +237 -0
  405. package/src/components/Chip/chip.tsx +359 -0
  406. package/src/components/CircularProgress/circular-progress.tsx +204 -0
  407. package/src/components/Coachmark/coachmark.tsx +255 -0
  408. package/src/components/Combobox/combobox.tsx +826 -0
  409. package/src/components/Command/command.tsx +187 -0
  410. package/src/components/DataTable/active-editor-controller.ts +72 -0
  411. package/src/components/DataTable/cell-registry.tsx +520 -0
  412. package/src/components/DataTable/column-types.ts +180 -0
  413. package/src/components/DataTable/data-table-column-visibility-panel.tsx +261 -0
  414. package/src/components/DataTable/data-table-filter-panel.tsx +813 -0
  415. package/src/components/DataTable/data-table-interaction-layer.tsx +483 -0
  416. package/src/components/DataTable/data-table-sort-manager.tsx +210 -0
  417. package/src/components/DataTable/data-table.css +165 -0
  418. package/src/components/DataTable/data-table.tsx +2924 -0
  419. package/src/components/DataTable/filter-operators.ts +225 -0
  420. package/src/components/DataTable/filter-tree.ts +313 -0
  421. package/src/components/DataTable/lib/column-meta.ts +79 -0
  422. package/src/components/DateGrid/date-grid.tsx +209 -0
  423. package/src/components/DatePicker/date-picker.tsx +1114 -0
  424. package/src/components/DescriptionList/description-list.tsx +141 -0
  425. package/src/components/Dialog/dialog.tsx +267 -0
  426. package/src/components/DropdownMenu/dropdown-menu.tsx +475 -0
  427. package/src/components/Empty/empty.tsx +108 -0
  428. package/src/components/Field/field-context.ts +136 -0
  429. package/src/components/Field/field-types.ts +52 -0
  430. package/src/components/Field/field-wrapper.tsx +348 -0
  431. package/src/components/Field/field.tsx +535 -0
  432. package/src/components/FieldControlGroup/field-control-group.tsx +136 -0
  433. package/src/components/FileItem/file-item.tsx +322 -0
  434. package/src/components/FileUpload/file-upload.tsx +326 -0
  435. package/src/components/FileViewer/file-viewer-types.ts +76 -0
  436. package/src/components/FileViewer/file-viewer.tsx +1065 -0
  437. package/src/components/FileViewer/image-renderer.tsx +256 -0
  438. package/src/components/HoverCard/hover-card.tsx +79 -0
  439. package/src/components/Input/input.tsx +233 -0
  440. package/src/components/LinkInput/link-input.tsx +304 -0
  441. package/src/components/Menu/menu-item.tsx +334 -0
  442. package/src/components/NameCard/name-card.tsx +319 -0
  443. package/src/components/Notice/notice.tsx +196 -0
  444. package/src/components/NumberInput/number-input.tsx +203 -0
  445. package/src/components/OverflowIndicator/overflow-indicator.tsx +156 -0
  446. package/src/components/PeoplePicker/avatar-stack-overflow.ts +100 -0
  447. package/src/components/PeoplePicker/people-picker-helpers.ts +76 -0
  448. package/src/components/PeoplePicker/people-picker.tsx +455 -0
  449. package/src/components/PeoplePicker/person-display.tsx +358 -0
  450. package/src/components/Popover/popover.tsx +183 -0
  451. package/src/components/ProgressBar/progress-bar.tsx +157 -0
  452. package/src/components/README.md +58 -0
  453. package/src/components/RadioGroup/radio-group.tsx +261 -0
  454. package/src/components/Rating/rating.tsx +295 -0
  455. package/src/components/ScrollArea/scroll-area.tsx +110 -0
  456. package/src/components/SegmentedControl/segmented-control.tsx +304 -0
  457. package/src/components/Select/select.tsx +658 -0
  458. package/src/components/SelectMenu/select-menu.tsx +430 -0
  459. package/src/components/SelectionControl/selection-item.tsx +261 -0
  460. package/src/components/Separator/separator.tsx +48 -0
  461. package/src/components/Sheet/sheet.tsx +240 -0
  462. package/src/components/Sidebar/sidebar.tsx +1280 -0
  463. package/src/components/Skeleton/skeleton.tsx +35 -0
  464. package/src/components/Slider/slider.tsx +158 -0
  465. package/src/components/Steps/steps.tsx +850 -0
  466. package/src/components/Switch/switch.tsx +285 -0
  467. package/src/components/Tabs/tabs.tsx +515 -0
  468. package/src/components/Tag/tag.tsx +246 -0
  469. package/src/components/Textarea/textarea.tsx +280 -0
  470. package/src/components/TimePicker/time-columns.tsx +260 -0
  471. package/src/components/TimePicker/time-picker.tsx +419 -0
  472. package/src/components/Toast/toast.tsx +129 -0
  473. package/src/components/Tooltip/tooltip.tsx +68 -0
  474. package/src/components/TreeView/tree-view.tsx +1031 -0
  475. package/src/hooks/use-controllable.ts +40 -0
  476. package/src/hooks/use-is-narrow-viewport.ts +19 -0
  477. package/src/hooks/use-is-touch-device.ts +21 -0
  478. package/src/hooks/use-overflow-items.ts +256 -0
  479. package/src/index.ts +85 -0
  480. package/src/lib/README.md +82 -0
  481. package/src/lib/drag-visual.ts +272 -0
  482. package/src/lib/i18n/README.md +60 -0
  483. package/src/lib/i18n/i18n-context.tsx +129 -0
  484. package/src/lib/multi-select-ordering.ts +61 -0
  485. package/src/lib/utils.ts +93 -0
  486. package/src/patterns/README.md +67 -0
  487. package/src/patterns/element-anatomy/item-anatomy.tsx +744 -0
  488. package/src/patterns/header-canonical/chrome-header.tsx +175 -0
  489. package/src/patterns/header-canonical/header-canonical.css +27 -0
  490. package/src/patterns/horizontal-overflow/horizontal-overflow.tsx +217 -0
  491. package/src/patterns/overlay-surface/overlay-surface.tsx +191 -0
  492. package/src/patterns/resize-handle/resize-handle.tsx +188 -0
  493. package/src/stories-helpers/anatomy/anatomy-utils.tsx +64 -0
  494. package/src/styles/preset.css +31 -0
  495. package/src/styles/tokens.css +35 -0
  496. package/src/tokens/README.md +53 -0
  497. package/src/tokens/color/primitives.css +429 -0
  498. package/src/tokens/color/semantic.css +539 -0
  499. package/src/tokens/elevation/overlay-geometry.ts +13 -0
  500. package/src/tokens/layoutSpace/layoutSpace.css +36 -0
  501. package/src/tokens/motion/motion.css +30 -0
  502. package/src/tokens/motion/motion.ts +17 -0
  503. package/src/tokens/opacity/opacity.css +23 -0
  504. package/src/tokens/radius/radius.css +19 -0
  505. package/src/tokens/typography/typography.css +118 -0
  506. package/src/tokens/uiSize/icon-size.ts +52 -0
  507. package/src/tokens/uiSize/uiSize.css +125 -0
@@ -0,0 +1,40 @@
1
+ import { useCallback, useRef, useState } from 'react'
2
+
3
+ /**
4
+ * Controlled / Uncontrolled dual-mode state hook。
5
+ *
6
+ * 對齊 Radix `useControllableState` 慣例:
7
+ * - 提供 `value` → controlled,setter 純 callback,內部不存 state
8
+ * - 不提供 `value`(or undefined)→ uncontrolled,內部 state + callback 同步
9
+ *
10
+ * 使用情境:Field / Switch / Checkbox / DataTable selection / DropdownMenu open 等
11
+ * 雙模式 prop。
12
+ */
13
+ export function useControllable<T>({
14
+ value,
15
+ defaultValue,
16
+ onChange,
17
+ }: {
18
+ value?: T
19
+ defaultValue: T
20
+ onChange?: (next: T) => void
21
+ }): [T, (next: T | ((prev: T) => T)) => void] {
22
+ const isControlled = value !== undefined
23
+ const [internal, setInternal] = useState<T>(defaultValue)
24
+ const onChangeRef = useRef(onChange)
25
+ onChangeRef.current = onChange
26
+
27
+ const current = isControlled ? (value as T) : internal
28
+
29
+ const setValue = useCallback(
30
+ (next: T | ((prev: T) => T)) => {
31
+ const computed =
32
+ typeof next === 'function' ? (next as (prev: T) => T)(current) : next
33
+ if (!isControlled) setInternal(computed)
34
+ onChangeRef.current?.(computed)
35
+ },
36
+ [isControlled, current]
37
+ )
38
+
39
+ return [current, setValue]
40
+ }
@@ -0,0 +1,19 @@
1
+ import * as React from "react"
2
+
3
+ const MOBILE_BREAKPOINT = 768
4
+
5
+ export function useIsNarrowViewport() {
6
+ const [isNarrow, setIsNarrow] = React.useState<boolean | undefined>(undefined)
7
+
8
+ React.useEffect(() => {
9
+ const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`)
10
+ const onChange = () => {
11
+ setIsNarrow(window.innerWidth < MOBILE_BREAKPOINT)
12
+ }
13
+ mql.addEventListener("change", onChange)
14
+ setIsNarrow(window.innerWidth < MOBILE_BREAKPOINT)
15
+ return () => mql.removeEventListener("change", onChange)
16
+ }, [])
17
+
18
+ return !!isNarrow
19
+ }
@@ -0,0 +1,21 @@
1
+ import { useState, useEffect } from 'react'
2
+
3
+ /**
4
+ * useIsMobile — 偵測觸控裝置(mobile / tablet)
5
+ *
6
+ * 使用 `pointer: coarse` media query,正確區分觸控 vs 精確指標裝置。
7
+ * 用途:Select 等元件在 mobile 退回原生 picker。
8
+ */
9
+ export function useIsTouchDevice() {
10
+ const [isMobile, setIsMobile] = useState(false)
11
+
12
+ useEffect(() => {
13
+ const mq = window.matchMedia('(pointer: coarse)')
14
+ setIsMobile(mq.matches)
15
+ const handler = (e: MediaQueryListEvent) => setIsMobile(e.matches)
16
+ mq.addEventListener('change', handler)
17
+ return () => mq.removeEventListener('change', handler)
18
+ }, [])
19
+
20
+ return isMobile
21
+ }
@@ -0,0 +1,256 @@
1
+ import * as React from 'react'
2
+
3
+ /**
4
+ * 水平溢出追蹤 hooks — 給 Tabs / ChipGroup 等「一排水平 items 塞不下父容器」的元件共用。
5
+ *
6
+ * ── 設計原則 ──
7
+ * Scroll 模式與 Menu 模式是兩種處理策略:
8
+ *
9
+ * 1. **Scroll 模式**(Material / Polaris / Primer / iOS 作法)
10
+ * items 用原生 overflow-x-auto 水平滾動,邊緣 fade mask 指示還有內容。
11
+ * 使用 `useScrollEdges()`:回傳 atStart / atEnd / canScroll,讓消費端
12
+ * 決定 mask-image / scroll arrow 的顯示。
13
+ *
14
+ * 2. **Menu 模式**(Ant Design / Atlassian 作法)
15
+ * 塞不下的 items 收進 DropdownMenu。**所有 items 都渲染在 DOM 中**
16
+ * (只視覺隱藏溢出的)以保留 Radix 的 roving tabindex / roving focus 等
17
+ * a11y 語意。使用 `useOverflowIndices()`:回傳 overflowIndices
18
+ * 供消費端渲染對應的 menu items(通常是 click proxy,觸發同一個
19
+ * onValueChange)。
20
+ *
21
+ * ── 為什麼分兩個 hook,不合一 ──
22
+ * Scroll 的計算依據是 scroll 事件與 client/scroll width;Menu 的計算依據是
23
+ * items 的 offsetLeft/offsetWidth 相對容器 clientWidth。訂閱的事件不同
24
+ * (scroll vs resize),回傳的資料形狀不同。合一會讓 API 有一半是 noise。
25
+ */
26
+
27
+ // ─────────────────────────────────────────────────────────────────────────────
28
+ // useScrollEdges — 給 scroll 模式
29
+ // ─────────────────────────────────────────────────────────────────────────────
30
+
31
+ // code-quality-allow: dead-export — hook return type — API surface for consumers who want to annotate
32
+ export interface UseScrollEdgesResult<T extends HTMLElement> {
33
+ /** 綁在 scroll container 上的 ref */
34
+ scrollRef: React.RefObject<T>
35
+ /** scroll 位置在最左側(無法再往左)*/
36
+ atStart: boolean
37
+ /** scroll 位置在最右側(無法再往右)*/
38
+ atEnd: boolean
39
+ /** 內容總寬度超過可視寬度,有滾動空間 */
40
+ canScroll: boolean
41
+ }
42
+
43
+ /**
44
+ * 追蹤 scroll container 的滾動位置,用來決定左右 fade mask 是否顯示。
45
+ *
46
+ * 典型用法:
47
+ * ```tsx
48
+ * const { scrollRef, atStart, atEnd, canScroll } = useScrollEdges<HTMLDivElement>()
49
+ * const maskImage = canScroll
50
+ * ? `linear-gradient(to right,
51
+ * ${atStart ? 'black' : 'transparent'} 0,
52
+ * black 16px,
53
+ * black calc(100% - 16px),
54
+ * ${atEnd ? 'black' : 'transparent'} 100%)`
55
+ * : undefined
56
+ * return <div ref={scrollRef} className="overflow-x-auto" style={{ maskImage, WebkitMaskImage: maskImage }}>
57
+ * {items}
58
+ * </div>
59
+ * ```
60
+ */
61
+ export function useScrollEdges<T extends HTMLElement = HTMLElement>(): UseScrollEdgesResult<T> {
62
+ const scrollRef = React.useRef<T | null>(null)
63
+ const [state, setState] = React.useState({ atStart: true, atEnd: true, canScroll: false })
64
+
65
+ React.useEffect(() => {
66
+ const el = scrollRef.current
67
+ if (!el) return
68
+
69
+ const update = () => {
70
+ const canScroll = el.scrollWidth > el.clientWidth + 1
71
+ const atStart = el.scrollLeft <= 0
72
+ const atEnd = el.scrollLeft + el.clientWidth >= el.scrollWidth - 1
73
+ setState((prev) =>
74
+ prev.atStart === atStart && prev.atEnd === atEnd && prev.canScroll === canScroll
75
+ ? prev
76
+ : { atStart, atEnd, canScroll }
77
+ )
78
+ }
79
+
80
+ update()
81
+ el.addEventListener('scroll', update, { passive: true })
82
+ const ro = new ResizeObserver(update)
83
+ ro.observe(el)
84
+ // 監聽 children 變化(items 增減、字體載入)
85
+ const mo = new MutationObserver(update)
86
+ mo.observe(el, { childList: true, subtree: true, characterData: true })
87
+
88
+ return () => {
89
+ el.removeEventListener('scroll', update)
90
+ ro.disconnect()
91
+ mo.disconnect()
92
+ }
93
+ }, [])
94
+
95
+ return { scrollRef, ...state }
96
+ }
97
+
98
+ // ─────────────────────────────────────────────────────────────────────────────
99
+ // useOverflowIndices — 給 menu 模式
100
+ // ─────────────────────────────────────────────────────────────────────────────
101
+
102
+ export interface UseOverflowIndicesOptions {
103
+ /**
104
+ * 預留給 overflow trigger(如 "More" 按鈕)的右側寬度(px)。
105
+ * 計算 items 是否溢出時會從 container clientWidth 扣掉這個值。
106
+ */
107
+ reserveTriggerWidth?: number
108
+ }
109
+
110
+ // code-quality-allow: dead-export — hook return type — API surface for consumers who want to annotate
111
+ export interface UseOverflowIndicesResult<C extends HTMLElement> {
112
+ /** 綁在 items 的父容器上 */
113
+ containerRef: React.RefObject<C>
114
+ /** 為每個 item 註冊 ref(回傳 callback ref)*/
115
+ registerItem: (index: number) => (el: HTMLElement | null) => void
116
+ /** DOM 順序上溢出的 item 索引(連續區間,從某個 index 到尾端)*/
117
+ overflowIndices: number[]
118
+ /** 至少有一個 item 溢出 */
119
+ hasOverflow: boolean
120
+ /** 依 index 取得對應 item 的 DOM 元素,供 scrollIntoView 等操作使用 */
121
+ getItemAt: (index: number) => HTMLElement | undefined
122
+ }
123
+
124
+ /**
125
+ * 追蹤一排水平 items 裡哪些「當前不在可視範圍內」。
126
+ *
127
+ * ── 演算法 ──
128
+ * 對每個 item 檢查 `[offsetLeft, offsetLeft+offsetWidth]` 是否完全落在
129
+ * `[scrollLeft, scrollLeft + clientWidth - reserveTriggerWidth]` 範圍內。
130
+ * 沒完全落在內的就算溢出。
131
+ *
132
+ * **關鍵**:overflow 集合跟 scrollLeft 連動,不是靜態「原始佈局不 fit」集合。
133
+ * 這是 Ant Design / Atlassian 世界級作法 —— menu 顯示「當下看不到的 items」,
134
+ * 不是「原始溢出的 items」。
135
+ *
136
+ * 為什麼這樣對:
137
+ * - 使用者點 menu item → `scrollIntoView` → 原本 overflow 的 item 進入視圖,
138
+ * 原本可見的 items 被推出去 → 下次開 menu 看到的是「剛被推出去的 items」,
139
+ * 永遠能找到所有當前看不到的 items,不會卡住。
140
+ * - 靜態 overflow (只算原始佈局) 會造成 scroll 後無法回到前面的 items。
141
+ *
142
+ * ── 觸發重算 ──
143
+ * - ResizeObserver: 容器寬度變化 / item 尺寸變化
144
+ * - scroll event: scroll 位置變化
145
+ *
146
+ * ── 前提 ──
147
+ * items 在 DOM 裡始終存在 (不可 conditional render),並用 `registerItem(i)` 綁 ref。
148
+ * 容器要可以 scroll (overflow-x-auto 或類似),否則 scrollLeft 永遠 0。
149
+ *
150
+ * 典型用法:
151
+ * ```tsx
152
+ * const { containerRef, registerItem, overflowIndices, hasOverflow, getItemAt } =
153
+ * useOverflowIndices<HTMLDivElement>({ reserveTriggerWidth: 0 })
154
+ *
155
+ * const handleMenuSelect = (value: string, index: number) => {
156
+ * onValueChange?.(value)
157
+ * requestAnimationFrame(() => {
158
+ * getItemAt(index)?.scrollIntoView({ behavior: 'smooth', inline: 'center' })
159
+ * })
160
+ * }
161
+ *
162
+ * return (
163
+ * <div className="flex items-center">
164
+ * <div ref={containerRef} className="flex-1 min-w-0 overflow-x-auto">
165
+ * <ItemList>
166
+ * {items.map((item, i) => React.cloneElement(item, { ref: registerItem(i) }))}
167
+ * </ItemList>
168
+ * </div>
169
+ * {hasOverflow && <OverflowMenu items={overflowIndices.map(i => items[i])} />}
170
+ * </div>
171
+ * )
172
+ * ```
173
+ */
174
+ export function useOverflowIndices<C extends HTMLElement = HTMLElement>(
175
+ options: UseOverflowIndicesOptions = {}
176
+ ): UseOverflowIndicesResult<C> {
177
+ const { reserveTriggerWidth = 0 } = options
178
+ const containerRef = React.useRef<C | null>(null)
179
+ const itemRefsMap = React.useRef<Map<number, HTMLElement>>(new Map())
180
+ const [overflowIndices, setOverflowIndices] = React.useState<number[]>([])
181
+
182
+ const registerItem = React.useCallback((index: number) => {
183
+ return (el: HTMLElement | null) => {
184
+ if (el) {
185
+ itemRefsMap.current.set(index, el)
186
+ } else {
187
+ itemRefsMap.current.delete(index)
188
+ }
189
+ }
190
+ }, [])
191
+
192
+ React.useEffect(() => {
193
+ const container = containerRef.current
194
+ if (!container) return
195
+
196
+ const compute = () => {
197
+ const containerWidth = container.clientWidth
198
+ if (containerWidth === 0) return
199
+
200
+ const scrollLeft = container.scrollLeft
201
+ const visibleStart = scrollLeft
202
+ const visibleEnd = scrollLeft + containerWidth - reserveTriggerWidth
203
+
204
+ // 容許 1px 的像素取整誤差,避免邊界 item 被誤判為 overflow
205
+ const tolerance = 1
206
+
207
+ const indices = Array.from(itemRefsMap.current.keys()).sort((a, b) => a - b)
208
+
209
+ const overflow: number[] = []
210
+ for (const i of indices) {
211
+ const el = itemRefsMap.current.get(i)
212
+ if (!el) continue
213
+
214
+ const left = el.offsetLeft
215
+ const right = left + el.offsetWidth
216
+ // 完全可見條件: item 的左右邊都在可視窗口內
217
+ const fullyVisible =
218
+ left >= visibleStart - tolerance && right <= visibleEnd + tolerance
219
+ if (!fullyVisible) overflow.push(i)
220
+ }
221
+
222
+ setOverflowIndices((prev) => {
223
+ if (prev.length === overflow.length && prev.every((v, i) => v === overflow[i])) {
224
+ return prev
225
+ }
226
+ return overflow
227
+ })
228
+ }
229
+
230
+ compute()
231
+ const ro = new ResizeObserver(compute)
232
+ ro.observe(container)
233
+ // 也觀察每個 item 的尺寸變化(字體載入、label 更新等)
234
+ itemRefsMap.current.forEach((el) => ro.observe(el))
235
+ // Scroll event: overflow 集合隨 scroll 位置變化
236
+ container.addEventListener('scroll', compute, { passive: true })
237
+
238
+ return () => {
239
+ ro.disconnect()
240
+ container.removeEventListener('scroll', compute)
241
+ }
242
+ }, [reserveTriggerWidth])
243
+
244
+ const getItemAt = React.useCallback(
245
+ (index: number) => itemRefsMap.current.get(index),
246
+ []
247
+ )
248
+
249
+ return {
250
+ containerRef,
251
+ registerItem,
252
+ overflowIndices,
253
+ hasOverflow: overflowIndices.length > 0,
254
+ getItemAt,
255
+ }
256
+ }
package/src/index.ts ADDED
@@ -0,0 +1,85 @@
1
+ // 2026-05-22 Phase 1 team-distribution-roadmap:barrel auto-generated by scripts/gen-design-system-barrel.mjs
2
+ // Re-export 主元件 / patterns / hooks / lib(consumers can also use subpath imports per package.json exports map)
3
+
4
+ // ─── Components ───────────────────────────────────────────────────────────
5
+ export * from './components/Accordion/accordion'
6
+ export * from './components/Alert/alert'
7
+ export * from './components/AppShell/app-shell'
8
+ export * from './components/AspectRatio/aspect-ratio'
9
+ export * from './components/Avatar/avatar'
10
+ export * from './components/Badge/badge'
11
+ export * from './components/Breadcrumb/breadcrumb'
12
+ export * from './components/BulkActionBar/bulk-action-bar'
13
+ export * from './components/Button/button'
14
+ export * from './components/Calendar/calendar'
15
+ export * from './components/Carousel/carousel'
16
+ export * from './components/Chart/chart'
17
+ export * from './components/Checkbox/checkbox'
18
+ export * from './components/Chip/chip'
19
+ export * from './components/CircularProgress/circular-progress'
20
+ export * from './components/Coachmark/coachmark'
21
+ // Combobox re-exports SelectOption(也在 Select 出口)→ 改 type-explicit re-export 避 collision(2026-05-22)
22
+ export { Combobox } from './components/Combobox/combobox'
23
+ export type { ComboboxProps } from './components/Combobox/combobox'
24
+ export * from './components/Command/command'
25
+ export * from './components/DataTable/data-table'
26
+ export * from './components/DateGrid/date-grid'
27
+ export * from './components/DatePicker/date-picker'
28
+ export * from './components/DescriptionList/description-list'
29
+ export * from './components/Dialog/dialog'
30
+ export * from './components/DropdownMenu/dropdown-menu'
31
+ export * from './components/Empty/empty'
32
+ export * from './components/Field/field'
33
+ export * from './components/FieldControlGroup/field-control-group'
34
+ export * from './components/FileItem/file-item'
35
+ export * from './components/FileUpload/file-upload'
36
+ export * from './components/FileViewer/file-viewer'
37
+ export * from './components/HoverCard/hover-card'
38
+ export * from './components/Input/input'
39
+ export * from './components/LinkInput/link-input'
40
+ export * from './components/Menu/menu-item'
41
+ export * from './components/NameCard/name-card'
42
+ export * from './components/Notice/notice'
43
+ export * from './components/NumberInput/number-input'
44
+ export * from './components/OverflowIndicator/overflow-indicator'
45
+ export * from './components/PeoplePicker/people-picker'
46
+ export * from './components/Popover/popover'
47
+ export * from './components/ProgressBar/progress-bar'
48
+ export * from './components/RadioGroup/radio-group'
49
+ export * from './components/Rating/rating'
50
+ export * from './components/ScrollArea/scroll-area'
51
+ export * from './components/SegmentedControl/segmented-control'
52
+ export * from './components/Select/select'
53
+ export * from './components/SelectMenu/select-menu'
54
+ export * from './components/SelectionControl/selection-item'
55
+ export * from './components/Separator/separator'
56
+ export * from './components/Sheet/sheet'
57
+ export * from './components/Sidebar/sidebar'
58
+ export * from './components/Skeleton/skeleton'
59
+ export * from './components/Slider/slider'
60
+ export * from './components/Steps/steps'
61
+ export * from './components/Switch/switch'
62
+ export * from './components/Tabs/tabs'
63
+ export * from './components/Tag/tag'
64
+ export * from './components/Textarea/textarea'
65
+ export * from './components/TimePicker/time-picker'
66
+ export * from './components/Toast/toast'
67
+ export * from './components/Tooltip/tooltip'
68
+ // TreeView re-exports DropPosition(也在 dnd primitives)→ 改 type-explicit(2026-05-22)
69
+ export { TreeView, TreeItem } from './components/TreeView/tree-view'
70
+ export type { TreeViewProps, TreeItemProps, TreeDragEndEvent } from './components/TreeView/tree-view'
71
+
72
+ // ─── Patterns ─────────────────────────────────────────────────────────────
73
+ export * from './patterns/horizontal-overflow/horizontal-overflow'
74
+ export * from './patterns/overlay-surface/overlay-surface'
75
+ export * from './patterns/resize-handle/resize-handle'
76
+
77
+ // ─── Hooks ────────────────────────────────────────────────────────────────
78
+ export * from './hooks/use-controllable'
79
+ export * from './hooks/use-is-narrow-viewport'
80
+ export * from './hooks/use-is-touch-device'
81
+ export * from './hooks/use-overflow-items'
82
+
83
+ // ─── Lib utilities ────────────────────────────────────────────────────────
84
+ export * from './lib/drag-visual'
85
+ export * from './lib/multi-select-ordering'
@@ -0,0 +1,82 @@
1
+ # lib/ Charter
2
+
3
+ ## 這裡只收:cross-cutting non-visual utility module
4
+
5
+ 每個 lib 子模組提供**跨元件共用、無 visual surface 的 infrastructure / utility**:
6
+
7
+ - React Context Provider + hook(non-visual cross-cutting feature)
8
+ - 純運算 / 格式化 helper(date / number / a11y string)
9
+ - TypeScript type module(無 runtime,共用 type-only export)
10
+ - 第三方 library 的 thin wrapper(對齊 DS API 風格)
11
+
12
+ **核心特徵**:沒有 visual surface(不 render UI),但 ≥ 2 個 DS 元件 import 它使用。
13
+
14
+ ---
15
+
16
+ ## 跟 hooks/ / patterns/ / components/ 分權
17
+
18
+ | Home | 收什麼 | 反例(錯誤 home)|
19
+ |------|-------|----------------|
20
+ | `lib/{topic}/` | cross-cutting feature module(Provider + hook + types 集合)| 純 hook 一個檔案 → 應 `hooks/use-*.ts` |
21
+ | `hooks/use-*.ts` | 單純 stateless hook(無 Context / 無 Provider)| 帶 Provider → `lib/{topic}/` |
22
+ | `patterns/{topic}/` | runtime visual primitive(`<Item>` / `<ActionBar>` 等渲染 UI)| 沒 visual surface → `lib/` |
23
+ | `components/{Name}/` | user-facing 元件(public API)| internal cross-cutting → `lib/` |
24
+
25
+ **判斷 flow**:
26
+
27
+ ```
28
+ 有 visual surface(render UI 元素)?
29
+ ├─ Yes → 是 user-facing? → components/ : patterns/
30
+ └─ No → 是純 stateless hook 一支?
31
+ ├─ Yes → hooks/use-*.ts
32
+ └─ No(Provider + hook + types 一組,或 utility module)→ lib/{topic}/
33
+ ```
34
+
35
+ ---
36
+
37
+ ## 當前居民
38
+
39
+ | Module | 提供什麼 | Consumer | 世界級對齊 |
40
+ |--------|---------|----------|-----------|
41
+ | `i18n/` | `<I18nProvider>` + `useI18n()` hook + `I18nLabels` types(opt-in context-based label catalog,additive 與 prop API 並存)| 全 DS 元件 opt-in consumer | Material `@mui/material/locale` / Ant `<ConfigProvider locale>` / Carbon `<PrefixContext>` 共識:i18n 是 utility/locale module 非 visual pattern |
42
+
43
+ ---
44
+
45
+ ## 命名鐵律
46
+
47
+ - 子目錄名 kebab-case(對齊 components/ / patterns/)
48
+ - 入口 module 名描述功能(`i18n-context.tsx` / `formatters.ts`),非 generic 名(`utils.ts` / `helpers.ts` 違反 — 後者該歸到 `src/lib/utils.ts` 專案級)
49
+ - 違反 → audit Dim 19 home-name-vs-scope 抓
50
+
51
+ ---
52
+
53
+ ## 這裡**不收**(反例 + 正確去處)
54
+
55
+ | 疑似要放這但其實不是 | 實際應去 | 為什麼 |
56
+ |-------------------|---------|--------|
57
+ | 「`cn()` Tailwind 合併」工具 | `src/lib/utils.ts` | shadcn 慣例 home,專案級非 DS 內部 |
58
+ | 「`useControllable` 雙模式 hook」 | `packages/design-system/src/hooks/use-controllable.ts` | 純 stateless hook,無 Context |
59
+ | 「Toast 行為 primitive(渲染 UI)」 | `packages/design-system/src/patterns/{name}/` | 有 visual surface |
60
+ | 「formik / react-hook-form 整合」 | 不在 DS scope | DS 不耦合 form library;consumer 自己 wire |
61
+
62
+ ---
63
+
64
+ ## 新增 lib module 的 criteria(必須全部通過)
65
+
66
+ 1. **無 visual surface**(不 render UI 元素;Context Provider 例外因 wrap children)
67
+ 2. **≥ 2 個 DS 元件消費**(spec / README 必列 consumers)
68
+ 3. **≥ 3 家世界級對照**(MUI / Polaris / Ant / Carbon / Material 任一以上)
69
+ 4. **不適合 hooks/**(超過單一 stateless hook,有 Provider / types / multi-file 結構)
70
+
71
+ ---
72
+
73
+ ## 為什麼新建這個 home(2026-05-01)
74
+
75
+ i18n-context 原放 `patterns/i18n/`,但 patterns/ 定義是「runtime visual primitive」,i18n 無 visual surface(只是 Context + hook + types)→ home-name-vs-scope 不符(audit Dim 19 抓到)。
76
+
77
+ 世界級三家共識:**i18n 是 utility / locale module,不是 visual pattern**:
78
+ - Material `@mui/material/locale` 是 utility sub-package
79
+ - Ant `<ConfigProvider locale>` 是 provider config 非 visual element
80
+ - Carbon `<PrefixContext>` 是 DI module 非 visual primitive
81
+
82
+ 新建 `lib/` 為這類 cross-cutting non-visual primitive 留 home,patterns/ 純化只收 visual primitive。