@qijenchen/design-system 0.1.0-beta.6 → 0.1.0-beta.60

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 (1237) hide show
  1. package/CLAUDE.md +200 -0
  2. package/README.md +155 -0
  3. package/cli-init.mjs +90 -0
  4. package/dist/components/Accordion/accordion.d.ts.map +1 -1
  5. package/dist/components/Accordion/accordion.js +3 -0
  6. package/dist/components/Accordion/accordion.js.map +1 -1
  7. package/dist/components/Accordion/index.d.ts +2 -0
  8. package/dist/components/Accordion/index.d.ts.map +1 -0
  9. package/dist/components/Accordion/index.js +9 -0
  10. package/dist/components/Accordion/index.js.map +1 -0
  11. package/dist/components/Alert/alert.d.ts +1 -1
  12. package/dist/components/Alert/index.d.ts +2 -0
  13. package/dist/components/Alert/index.d.ts.map +1 -0
  14. package/dist/components/Alert/index.js +7 -0
  15. package/dist/components/Alert/index.js.map +1 -0
  16. package/dist/components/AppShell/app-shell.d.ts.map +1 -1
  17. package/dist/components/AppShell/app-shell.js +5 -5
  18. package/dist/components/AppShell/app-shell.js.map +1 -1
  19. package/dist/components/AppShell/index.d.ts +2 -0
  20. package/dist/components/AppShell/index.d.ts.map +1 -0
  21. package/dist/components/AppShell/index.js +7 -0
  22. package/dist/components/AppShell/index.js.map +1 -0
  23. package/dist/components/AspectRatio/aspect-ratio.d.ts +1 -1
  24. package/dist/components/AspectRatio/aspect-ratio.d.ts.map +1 -1
  25. package/dist/components/AspectRatio/aspect-ratio.js +4 -2
  26. package/dist/components/AspectRatio/aspect-ratio.js.map +1 -1
  27. package/dist/components/AspectRatio/index.d.ts +2 -0
  28. package/dist/components/AspectRatio/index.d.ts.map +1 -0
  29. package/dist/components/AspectRatio/index.js +6 -0
  30. package/dist/components/AspectRatio/index.js.map +1 -0
  31. package/dist/components/Avatar/avatar.d.ts +6 -5
  32. package/dist/components/Avatar/avatar.d.ts.map +1 -1
  33. package/dist/components/Avatar/avatar.js +6 -17
  34. package/dist/components/Avatar/avatar.js.map +1 -1
  35. package/dist/components/Avatar/index.d.ts +2 -0
  36. package/dist/components/Avatar/index.d.ts.map +1 -0
  37. package/dist/components/Avatar/index.js +6 -0
  38. package/dist/components/Avatar/index.js.map +1 -0
  39. package/dist/components/Badge/badge.d.ts +19 -7
  40. package/dist/components/Badge/badge.d.ts.map +1 -1
  41. package/dist/components/Badge/badge.js +5 -4
  42. package/dist/components/Badge/badge.js.map +1 -1
  43. package/dist/components/Badge/index.d.ts +2 -0
  44. package/dist/components/Badge/index.d.ts.map +1 -0
  45. package/dist/components/Badge/index.js +7 -0
  46. package/dist/components/Badge/index.js.map +1 -0
  47. package/dist/components/Breadcrumb/breadcrumb.d.ts +1 -1
  48. package/dist/components/Breadcrumb/breadcrumb.d.ts.map +1 -1
  49. package/dist/components/Breadcrumb/breadcrumb.js +16 -21
  50. package/dist/components/Breadcrumb/breadcrumb.js.map +1 -1
  51. package/dist/components/Breadcrumb/index.d.ts +2 -0
  52. package/dist/components/Breadcrumb/index.d.ts.map +1 -0
  53. package/dist/components/Breadcrumb/index.js +12 -0
  54. package/dist/components/Breadcrumb/index.js.map +1 -0
  55. package/dist/components/BulkActionBar/bulk-action-bar.d.ts +2 -2
  56. package/dist/components/BulkActionBar/bulk-action-bar.d.ts.map +1 -1
  57. package/dist/components/BulkActionBar/bulk-action-bar.js +2 -2
  58. package/dist/components/BulkActionBar/bulk-action-bar.js.map +1 -1
  59. package/dist/components/BulkActionBar/index.d.ts +2 -0
  60. package/dist/components/BulkActionBar/index.d.ts.map +1 -0
  61. package/dist/components/BulkActionBar/index.js +7 -0
  62. package/dist/components/BulkActionBar/index.js.map +1 -0
  63. package/dist/components/Button/button.d.ts +2 -2
  64. package/dist/components/Button/button.d.ts.map +1 -1
  65. package/dist/components/Button/button.js +7 -3
  66. package/dist/components/Button/button.js.map +1 -1
  67. package/dist/components/Button/index.d.ts +2 -0
  68. package/dist/components/Button/index.d.ts.map +1 -0
  69. package/dist/components/Button/index.js +8 -0
  70. package/dist/components/Button/index.js.map +1 -0
  71. package/dist/components/Calendar/calendar.d.ts +8 -4
  72. package/dist/components/Calendar/calendar.d.ts.map +1 -1
  73. package/dist/components/Calendar/calendar.js +14 -13
  74. package/dist/components/Calendar/calendar.js.map +1 -1
  75. package/dist/components/Calendar/index.d.ts +2 -0
  76. package/dist/components/Calendar/index.d.ts.map +1 -0
  77. package/dist/components/Calendar/index.js +6 -0
  78. package/dist/components/Calendar/index.js.map +1 -0
  79. package/dist/components/Carousel/carousel.d.ts.map +1 -1
  80. package/dist/components/Carousel/carousel.js +6 -3
  81. package/dist/components/Carousel/carousel.js.map +1 -1
  82. package/dist/components/Carousel/index.d.ts +2 -0
  83. package/dist/components/Carousel/index.d.ts.map +1 -0
  84. package/dist/components/Carousel/index.js +11 -0
  85. package/dist/components/Carousel/index.js.map +1 -0
  86. package/dist/components/Chart/chart.d.ts +1 -1
  87. package/dist/components/Chart/chart.d.ts.map +1 -1
  88. package/dist/components/Chart/chart.js +3 -1
  89. package/dist/components/Chart/chart.js.map +1 -1
  90. package/dist/components/Chart/index.d.ts +2 -0
  91. package/dist/components/Chart/index.d.ts.map +1 -0
  92. package/dist/components/Chart/index.js +11 -0
  93. package/dist/components/Chart/index.js.map +1 -0
  94. package/dist/components/Checkbox/checkbox.d.ts +4 -4
  95. package/dist/components/Checkbox/checkbox.js +8 -7
  96. package/dist/components/Checkbox/checkbox.js.map +1 -1
  97. package/dist/components/Checkbox/index.d.ts +2 -0
  98. package/dist/components/Checkbox/index.d.ts.map +1 -0
  99. package/dist/components/Checkbox/index.js +7 -0
  100. package/dist/components/Checkbox/index.js.map +1 -0
  101. package/dist/components/Chip/chip.d.ts +4 -4
  102. package/dist/components/Chip/chip.js +1 -1
  103. package/dist/components/Chip/chip.js.map +1 -1
  104. package/dist/components/Chip/index.d.ts +2 -0
  105. package/dist/components/Chip/index.d.ts.map +1 -0
  106. package/dist/components/Chip/index.js +8 -0
  107. package/dist/components/Chip/index.js.map +1 -0
  108. package/dist/components/CircularProgress/circular-progress.d.ts +1 -2
  109. package/dist/components/CircularProgress/circular-progress.d.ts.map +1 -1
  110. package/dist/components/CircularProgress/circular-progress.js +2 -2
  111. package/dist/components/CircularProgress/circular-progress.js.map +1 -1
  112. package/dist/components/CircularProgress/index.d.ts +2 -0
  113. package/dist/components/CircularProgress/index.d.ts.map +1 -0
  114. package/dist/components/CircularProgress/index.js +6 -0
  115. package/dist/components/CircularProgress/index.js.map +1 -0
  116. package/dist/components/Coachmark/coachmark-story-helpers.d.ts +22 -0
  117. package/dist/components/Coachmark/coachmark-story-helpers.d.ts.map +1 -0
  118. package/dist/components/Coachmark/coachmark.d.ts.map +1 -1
  119. package/dist/components/Coachmark/coachmark.js +7 -3
  120. package/dist/components/Coachmark/coachmark.js.map +1 -1
  121. package/dist/components/Coachmark/index.d.ts +2 -0
  122. package/dist/components/Coachmark/index.d.ts.map +1 -0
  123. package/dist/components/Coachmark/index.js +6 -0
  124. package/dist/components/Coachmark/index.js.map +1 -0
  125. package/dist/components/Combobox/combobox.d.ts +17 -8
  126. package/dist/components/Combobox/combobox.d.ts.map +1 -1
  127. package/dist/components/Combobox/combobox.js +31 -4
  128. package/dist/components/Combobox/combobox.js.map +1 -1
  129. package/dist/components/Combobox/index.d.ts +2 -0
  130. package/dist/components/Combobox/index.d.ts.map +1 -0
  131. package/dist/components/Combobox/index.js +6 -0
  132. package/dist/components/Combobox/index.js.map +1 -0
  133. package/dist/components/Command/index.d.ts +2 -0
  134. package/dist/components/Command/index.d.ts.map +1 -0
  135. package/dist/components/Command/index.js +14 -0
  136. package/dist/components/Command/index.js.map +1 -0
  137. package/dist/components/DataTable/data-table.d.ts +2 -2
  138. package/dist/components/DataTable/data-table.js +2 -2
  139. package/dist/components/DataTable/data-table.js.map +1 -1
  140. package/dist/components/DataTable/filter-operators.d.ts +1 -1
  141. package/dist/components/DataTable/filter-tree.d.ts +1 -1
  142. package/dist/components/DataTable/index.d.ts +2 -0
  143. package/dist/components/DataTable/index.d.ts.map +1 -0
  144. package/dist/components/DataTable/index.js +8 -0
  145. package/dist/components/DataTable/index.js.map +1 -0
  146. package/dist/components/DateGrid/date-grid.d.ts +14 -14
  147. package/dist/components/DateGrid/date-grid.js +1 -1
  148. package/dist/components/DateGrid/date-grid.js.map +1 -1
  149. package/dist/components/DateGrid/index.d.ts +2 -0
  150. package/dist/components/DateGrid/index.d.ts.map +1 -0
  151. package/dist/components/DateGrid/index.js +6 -0
  152. package/dist/components/DateGrid/index.js.map +1 -0
  153. package/dist/components/DatePicker/date-picker.d.ts +2 -2
  154. package/dist/components/DatePicker/date-picker.d.ts.map +1 -1
  155. package/dist/components/DatePicker/date-picker.js +8 -1
  156. package/dist/components/DatePicker/date-picker.js.map +1 -1
  157. package/dist/components/DatePicker/index.d.ts +2 -0
  158. package/dist/components/DatePicker/index.d.ts.map +1 -0
  159. package/dist/components/DatePicker/index.js +8 -0
  160. package/dist/components/DatePicker/index.js.map +1 -0
  161. package/dist/components/DescriptionList/description-list.d.ts +2 -2
  162. package/dist/components/DescriptionList/description-list.js +2 -1
  163. package/dist/components/DescriptionList/description-list.js.map +1 -1
  164. package/dist/components/DescriptionList/index.d.ts +2 -0
  165. package/dist/components/DescriptionList/index.d.ts.map +1 -0
  166. package/dist/components/DescriptionList/index.js +7 -0
  167. package/dist/components/DescriptionList/index.js.map +1 -0
  168. package/dist/components/Dialog/dialog.d.ts +1 -1
  169. package/dist/components/Dialog/dialog.js.map +1 -1
  170. package/dist/components/Dialog/index.d.ts +2 -0
  171. package/dist/components/Dialog/index.d.ts.map +1 -0
  172. package/dist/components/Dialog/index.js +16 -0
  173. package/dist/components/Dialog/index.js.map +1 -0
  174. package/dist/components/DropdownMenu/dropdown-menu.d.ts +4 -3
  175. package/dist/components/DropdownMenu/dropdown-menu.d.ts.map +1 -1
  176. package/dist/components/DropdownMenu/dropdown-menu.js +4 -3
  177. package/dist/components/DropdownMenu/dropdown-menu.js.map +1 -1
  178. package/dist/components/DropdownMenu/index.d.ts +2 -0
  179. package/dist/components/DropdownMenu/index.d.ts.map +1 -0
  180. package/dist/components/DropdownMenu/index.js +21 -0
  181. package/dist/components/DropdownMenu/index.js.map +1 -0
  182. package/dist/components/Empty/empty.d.ts +8 -2
  183. package/dist/components/Empty/empty.d.ts.map +1 -1
  184. package/dist/components/Empty/empty.js +6 -6
  185. package/dist/components/Empty/empty.js.map +1 -1
  186. package/dist/components/Empty/index.d.ts +2 -0
  187. package/dist/components/Empty/index.d.ts.map +1 -0
  188. package/dist/components/Empty/index.js +6 -0
  189. package/dist/components/Empty/index.js.map +1 -0
  190. package/dist/components/Field/field-types.js.map +1 -1
  191. package/dist/components/Field/field.d.ts +2 -2
  192. package/dist/components/Field/field.js.map +1 -1
  193. package/dist/components/Field/index.d.ts +2 -0
  194. package/dist/components/Field/index.d.ts.map +1 -0
  195. package/dist/components/Field/index.js +10 -0
  196. package/dist/components/Field/index.js.map +1 -0
  197. package/dist/components/FieldControlGroup/field-control-group.d.ts +6 -6
  198. package/dist/components/FieldControlGroup/field-control-group.d.ts.map +1 -1
  199. package/dist/components/FieldControlGroup/field-control-group.js.map +1 -1
  200. package/dist/components/FieldControlGroup/index.d.ts +2 -0
  201. package/dist/components/FieldControlGroup/index.d.ts.map +1 -0
  202. package/dist/components/FieldControlGroup/index.js +6 -0
  203. package/dist/components/FieldControlGroup/index.js.map +1 -0
  204. package/dist/components/FileItem/file-item.d.ts +12 -2
  205. package/dist/components/FileItem/file-item.d.ts.map +1 -1
  206. package/dist/components/FileItem/file-item.js +20 -6
  207. package/dist/components/FileItem/file-item.js.map +1 -1
  208. package/dist/components/FileItem/index.d.ts +2 -0
  209. package/dist/components/FileItem/index.d.ts.map +1 -0
  210. package/dist/components/FileItem/index.js +6 -0
  211. package/dist/components/FileItem/index.js.map +1 -0
  212. package/dist/components/FileUpload/file-upload.d.ts +24 -12
  213. package/dist/components/FileUpload/file-upload.d.ts.map +1 -1
  214. package/dist/components/FileUpload/file-upload.js +57 -17
  215. package/dist/components/FileUpload/file-upload.js.map +1 -1
  216. package/dist/components/FileUpload/index.d.ts +2 -0
  217. package/dist/components/FileUpload/index.d.ts.map +1 -0
  218. package/dist/components/FileUpload/index.js +6 -0
  219. package/dist/components/FileUpload/index.js.map +1 -0
  220. package/dist/components/FileViewer/file-viewer.d.ts +1 -1
  221. package/dist/components/FileViewer/file-viewer.d.ts.map +1 -1
  222. package/dist/components/FileViewer/file-viewer.js +2 -3
  223. package/dist/components/FileViewer/file-viewer.js.map +1 -1
  224. package/dist/components/FileViewer/index.d.ts +2 -0
  225. package/dist/components/FileViewer/index.d.ts.map +1 -0
  226. package/dist/components/FileViewer/index.js +7 -0
  227. package/dist/components/FileViewer/index.js.map +1 -0
  228. package/dist/components/HoverCard/hover-card.d.ts +2 -2
  229. package/dist/components/HoverCard/hover-card.js +2 -2
  230. package/dist/components/HoverCard/hover-card.js.map +1 -1
  231. package/dist/components/HoverCard/index.d.ts +2 -0
  232. package/dist/components/HoverCard/index.d.ts.map +1 -0
  233. package/dist/components/HoverCard/index.js +8 -0
  234. package/dist/components/HoverCard/index.js.map +1 -0
  235. package/dist/components/Input/index.d.ts +2 -0
  236. package/dist/components/Input/index.d.ts.map +1 -0
  237. package/dist/components/Input/index.js +6 -0
  238. package/dist/components/Input/index.js.map +1 -0
  239. package/dist/components/Input/input.d.ts +8 -5
  240. package/dist/components/Input/input.d.ts.map +1 -1
  241. package/dist/components/Input/input.js +6 -4
  242. package/dist/components/Input/input.js.map +1 -1
  243. package/dist/components/LinkInput/index.d.ts +2 -0
  244. package/dist/components/LinkInput/index.d.ts.map +1 -0
  245. package/dist/components/LinkInput/index.js +6 -0
  246. package/dist/components/LinkInput/index.js.map +1 -0
  247. package/dist/components/LinkInput/link-input.d.ts +2 -2
  248. package/dist/components/LinkInput/link-input.d.ts.map +1 -1
  249. package/dist/components/LinkInput/link-input.js +4 -4
  250. package/dist/components/LinkInput/link-input.js.map +1 -1
  251. package/dist/components/Menu/index.d.ts +2 -0
  252. package/dist/components/Menu/index.d.ts.map +1 -0
  253. package/dist/components/Menu/index.js +9 -0
  254. package/dist/components/Menu/index.js.map +1 -0
  255. package/dist/components/Menu/menu-item.d.ts +2 -2
  256. package/dist/components/Menu/menu-item.d.ts.map +1 -1
  257. package/dist/components/Menu/menu-item.js +2 -1
  258. package/dist/components/Menu/menu-item.js.map +1 -1
  259. package/dist/components/Notice/index.d.ts +2 -0
  260. package/dist/components/Notice/index.d.ts.map +1 -0
  261. package/dist/components/Notice/index.js +8 -0
  262. package/dist/components/Notice/index.js.map +1 -0
  263. package/dist/components/Notice/notice.d.ts +2 -2
  264. package/dist/components/Notice/notice.d.ts.map +1 -1
  265. package/dist/components/Notice/notice.js +4 -3
  266. package/dist/components/Notice/notice.js.map +1 -1
  267. package/dist/components/NumberInput/index.d.ts +2 -0
  268. package/dist/components/NumberInput/index.d.ts.map +1 -0
  269. package/dist/components/NumberInput/index.js +7 -0
  270. package/dist/components/NumberInput/index.js.map +1 -0
  271. package/dist/components/NumberInput/number-input.d.ts +3 -3
  272. package/dist/components/NumberInput/number-input.d.ts.map +1 -1
  273. package/dist/components/NumberInput/number-input.js +2 -1
  274. package/dist/components/NumberInput/number-input.js.map +1 -1
  275. package/dist/components/OverflowIndicator/index.d.ts +2 -0
  276. package/dist/components/OverflowIndicator/index.d.ts.map +1 -0
  277. package/dist/components/OverflowIndicator/index.js +6 -0
  278. package/dist/components/OverflowIndicator/index.js.map +1 -0
  279. package/dist/components/OverflowIndicator/overflow-indicator.d.ts.map +1 -1
  280. package/dist/components/OverflowIndicator/overflow-indicator.js +9 -2
  281. package/dist/components/OverflowIndicator/overflow-indicator.js.map +1 -1
  282. package/dist/components/PeoplePicker/index.d.ts +2 -0
  283. package/dist/components/PeoplePicker/index.d.ts.map +1 -0
  284. package/dist/components/PeoplePicker/index.js +9 -0
  285. package/dist/components/PeoplePicker/index.js.map +1 -0
  286. package/dist/components/PeoplePicker/people-picker-helpers.d.ts +1 -1
  287. package/dist/components/PeoplePicker/people-picker-helpers.d.ts.map +1 -1
  288. package/dist/components/PeoplePicker/people-picker-helpers.js +2 -2
  289. package/dist/components/PeoplePicker/people-picker-helpers.js.map +1 -1
  290. package/dist/components/PeoplePicker/people-picker.d.ts +1 -1
  291. package/dist/components/PeoplePicker/people-picker.d.ts.map +1 -1
  292. package/dist/components/PeoplePicker/people-picker.js +7 -7
  293. package/dist/components/PeoplePicker/people-picker.js.map +1 -1
  294. package/dist/components/PeoplePicker/person-display.d.ts +7 -7
  295. package/dist/components/PeoplePicker/person-display.d.ts.map +1 -1
  296. package/dist/components/PeoplePicker/person-display.js +8 -8
  297. package/dist/components/PeoplePicker/person-display.js.map +1 -1
  298. package/dist/components/Popover/index.d.ts +2 -0
  299. package/dist/components/Popover/index.d.ts.map +1 -0
  300. package/dist/components/Popover/index.js +14 -0
  301. package/dist/components/Popover/index.js.map +1 -0
  302. package/dist/components/Popover/popover.js +3 -2
  303. package/dist/components/Popover/popover.js.map +1 -1
  304. package/dist/components/ProfileCard/index.d.ts +2 -0
  305. package/dist/components/ProfileCard/index.d.ts.map +1 -0
  306. package/dist/components/ProfileCard/index.js +8 -0
  307. package/dist/components/ProfileCard/index.js.map +1 -0
  308. package/dist/components/{NameCard/name-card.d.ts → ProfileCard/profile-card.d.ts} +19 -18
  309. package/dist/components/ProfileCard/profile-card.d.ts.map +1 -0
  310. package/dist/components/{NameCard/name-card.js → ProfileCard/profile-card.js} +9 -9
  311. package/dist/components/ProfileCard/profile-card.js.map +1 -0
  312. package/dist/components/ProgressBar/index.d.ts +2 -0
  313. package/dist/components/ProgressBar/index.d.ts.map +1 -0
  314. package/dist/components/ProgressBar/index.js +6 -0
  315. package/dist/components/ProgressBar/index.js.map +1 -0
  316. package/dist/components/ProgressBar/progress-bar.d.ts +2 -2
  317. package/dist/components/ProgressBar/progress-bar.js +3 -3
  318. package/dist/components/ProgressBar/progress-bar.js.map +1 -1
  319. package/dist/components/RadioGroup/index.d.ts +2 -0
  320. package/dist/components/RadioGroup/index.d.ts.map +1 -0
  321. package/dist/components/RadioGroup/index.js +8 -0
  322. package/dist/components/RadioGroup/index.js.map +1 -0
  323. package/dist/components/RadioGroup/radio-group.d.ts +6 -6
  324. package/dist/components/RadioGroup/radio-group.d.ts.map +1 -1
  325. package/dist/components/RadioGroup/radio-group.js +12 -13
  326. package/dist/components/RadioGroup/radio-group.js.map +1 -1
  327. package/dist/components/Rating/index.d.ts +2 -0
  328. package/dist/components/Rating/index.d.ts.map +1 -0
  329. package/dist/components/Rating/index.js +6 -0
  330. package/dist/components/Rating/index.js.map +1 -0
  331. package/dist/components/Rating/rating.d.ts +6 -2
  332. package/dist/components/Rating/rating.d.ts.map +1 -1
  333. package/dist/components/Rating/rating.js +3 -2
  334. package/dist/components/Rating/rating.js.map +1 -1
  335. package/dist/components/ScrollArea/index.d.ts +2 -0
  336. package/dist/components/ScrollArea/index.d.ts.map +1 -0
  337. package/dist/components/ScrollArea/index.js +7 -0
  338. package/dist/components/ScrollArea/index.js.map +1 -0
  339. package/dist/components/ScrollArea/scroll-area.d.ts +1 -1
  340. package/dist/components/ScrollArea/scroll-area.js +1 -1
  341. package/dist/components/ScrollArea/scroll-area.js.map +1 -1
  342. package/dist/components/SegmentedControl/index.d.ts +2 -0
  343. package/dist/components/SegmentedControl/index.d.ts.map +1 -0
  344. package/dist/components/SegmentedControl/index.js +9 -0
  345. package/dist/components/SegmentedControl/index.js.map +1 -0
  346. package/dist/components/SegmentedControl/segmented-control.d.ts +2 -2
  347. package/dist/components/SegmentedControl/segmented-control.d.ts.map +1 -1
  348. package/dist/components/SegmentedControl/segmented-control.js +4 -4
  349. package/dist/components/SegmentedControl/segmented-control.js.map +1 -1
  350. package/dist/components/Select/index.d.ts +2 -0
  351. package/dist/components/Select/index.d.ts.map +1 -0
  352. package/dist/components/Select/index.js +6 -0
  353. package/dist/components/Select/index.js.map +1 -0
  354. package/dist/components/Select/select.d.ts +2 -2
  355. package/dist/components/Select/select.d.ts.map +1 -1
  356. package/dist/components/Select/select.js +5 -3
  357. package/dist/components/Select/select.js.map +1 -1
  358. package/dist/components/SelectMenu/index.d.ts +2 -0
  359. package/dist/components/SelectMenu/index.d.ts.map +1 -0
  360. package/dist/components/SelectMenu/index.js +6 -0
  361. package/dist/components/SelectMenu/index.js.map +1 -0
  362. package/dist/components/SelectMenu/select-menu.d.ts +7 -6
  363. package/dist/components/SelectMenu/select-menu.d.ts.map +1 -1
  364. package/dist/components/SelectMenu/select-menu.js +6 -1
  365. package/dist/components/SelectMenu/select-menu.js.map +1 -1
  366. package/dist/components/SelectionControl/index.d.ts +2 -0
  367. package/dist/components/SelectionControl/index.d.ts.map +1 -0
  368. package/dist/components/SelectionControl/index.js +7 -0
  369. package/dist/components/SelectionControl/index.js.map +1 -0
  370. package/dist/components/SelectionControl/selection-item.d.ts +1 -1
  371. package/dist/components/Separator/index.d.ts +2 -0
  372. package/dist/components/Separator/index.d.ts.map +1 -0
  373. package/dist/components/Separator/index.js +6 -0
  374. package/dist/components/Separator/index.js.map +1 -0
  375. package/dist/components/Separator/separator.d.ts +2 -2
  376. package/dist/components/Separator/separator.js +4 -3
  377. package/dist/components/Separator/separator.js.map +1 -1
  378. package/dist/components/Sheet/index.d.ts +2 -0
  379. package/dist/components/Sheet/index.d.ts.map +1 -0
  380. package/dist/components/Sheet/index.js +17 -0
  381. package/dist/components/Sheet/index.js.map +1 -0
  382. package/dist/components/Sheet/sheet.d.ts +1 -1
  383. package/dist/components/Sheet/sheet.js.map +1 -1
  384. package/dist/components/Sidebar/index.d.ts +2 -0
  385. package/dist/components/Sidebar/index.d.ts.map +1 -0
  386. package/dist/components/Sidebar/index.js +24 -0
  387. package/dist/components/Sidebar/index.js.map +1 -0
  388. package/dist/components/Sidebar/sidebar.d.ts +5 -5
  389. package/dist/components/Sidebar/sidebar.d.ts.map +1 -1
  390. package/dist/components/Sidebar/sidebar.js +6 -3
  391. package/dist/components/Sidebar/sidebar.js.map +1 -1
  392. package/dist/components/Skeleton/index.d.ts +2 -0
  393. package/dist/components/Skeleton/index.d.ts.map +1 -0
  394. package/dist/components/Skeleton/index.js +6 -0
  395. package/dist/components/Skeleton/index.js.map +1 -0
  396. package/dist/components/Slider/index.d.ts +2 -0
  397. package/dist/components/Slider/index.d.ts.map +1 -0
  398. package/dist/components/Slider/index.js +7 -0
  399. package/dist/components/Slider/index.js.map +1 -0
  400. package/dist/components/Slider/slider.d.ts +4 -4
  401. package/dist/components/Slider/slider.d.ts.map +1 -1
  402. package/dist/components/Slider/slider.js +11 -4
  403. package/dist/components/Slider/slider.js.map +1 -1
  404. package/dist/components/Steps/index.d.ts +2 -0
  405. package/dist/components/Steps/index.d.ts.map +1 -0
  406. package/dist/components/Steps/index.js +12 -0
  407. package/dist/components/Steps/index.js.map +1 -0
  408. package/dist/components/Steps/steps.d.ts +1 -1
  409. package/dist/components/Steps/steps.d.ts.map +1 -1
  410. package/dist/components/Steps/steps.js +28 -14
  411. package/dist/components/Steps/steps.js.map +1 -1
  412. package/dist/components/Switch/index.d.ts +2 -0
  413. package/dist/components/Switch/index.d.ts.map +1 -0
  414. package/dist/components/Switch/index.js +7 -0
  415. package/dist/components/Switch/index.js.map +1 -0
  416. package/dist/components/Switch/switch.d.ts +3 -3
  417. package/dist/components/Switch/switch.js +6 -5
  418. package/dist/components/Switch/switch.js.map +1 -1
  419. package/dist/components/Tabs/index.d.ts +2 -0
  420. package/dist/components/Tabs/index.d.ts.map +1 -0
  421. package/dist/components/Tabs/index.js +10 -0
  422. package/dist/components/Tabs/index.js.map +1 -0
  423. package/dist/components/Tabs/tabs.d.ts +5 -5
  424. package/dist/components/Tabs/tabs.d.ts.map +1 -1
  425. package/dist/components/Tabs/tabs.js +4 -3
  426. package/dist/components/Tabs/tabs.js.map +1 -1
  427. package/dist/components/Tag/index.d.ts +2 -0
  428. package/dist/components/Tag/index.d.ts.map +1 -0
  429. package/dist/components/Tag/index.js +7 -0
  430. package/dist/components/Tag/index.js.map +1 -0
  431. package/dist/components/Tag/tag.d.ts +35 -23
  432. package/dist/components/Tag/tag.d.ts.map +1 -1
  433. package/dist/components/Tag/tag.js +38 -43
  434. package/dist/components/Tag/tag.js.map +1 -1
  435. package/dist/components/Textarea/index.d.ts +2 -0
  436. package/dist/components/Textarea/index.d.ts.map +1 -0
  437. package/dist/components/Textarea/index.js +7 -0
  438. package/dist/components/Textarea/index.js.map +1 -0
  439. package/dist/components/Textarea/textarea.d.ts +5 -10
  440. package/dist/components/Textarea/textarea.d.ts.map +1 -1
  441. package/dist/components/Textarea/textarea.js +6 -4
  442. package/dist/components/Textarea/textarea.js.map +1 -1
  443. package/dist/components/TimePicker/index.d.ts +2 -0
  444. package/dist/components/TimePicker/index.d.ts.map +1 -0
  445. package/dist/components/TimePicker/index.js +6 -0
  446. package/dist/components/TimePicker/index.js.map +1 -0
  447. package/dist/components/TimePicker/time-picker.d.ts +4 -3
  448. package/dist/components/TimePicker/time-picker.d.ts.map +1 -1
  449. package/dist/components/TimePicker/time-picker.js +10 -2
  450. package/dist/components/TimePicker/time-picker.js.map +1 -1
  451. package/dist/components/Toast/index.d.ts +2 -0
  452. package/dist/components/Toast/index.d.ts.map +1 -0
  453. package/dist/components/Toast/index.js +7 -0
  454. package/dist/components/Toast/index.js.map +1 -0
  455. package/dist/components/Toast/toast.d.ts +2 -2
  456. package/dist/components/Toast/toast.js +2 -2
  457. package/dist/components/Toast/toast.js.map +1 -1
  458. package/dist/components/Tooltip/index.d.ts +2 -0
  459. package/dist/components/Tooltip/index.d.ts.map +1 -0
  460. package/dist/components/Tooltip/index.js +9 -0
  461. package/dist/components/Tooltip/index.js.map +1 -0
  462. package/dist/components/Tooltip/tooltip.d.ts.map +1 -1
  463. package/dist/components/Tooltip/tooltip.js +1 -0
  464. package/dist/components/Tooltip/tooltip.js.map +1 -1
  465. package/dist/components/TreeView/index.d.ts +2 -0
  466. package/dist/components/TreeView/index.d.ts.map +1 -0
  467. package/dist/components/TreeView/index.js +8 -0
  468. package/dist/components/TreeView/index.js.map +1 -0
  469. package/dist/components/TreeView/tree-view.d.ts +8 -8
  470. package/dist/components/TreeView/tree-view.d.ts.map +1 -1
  471. package/dist/components/TreeView/tree-view.js +35 -8
  472. package/dist/components/TreeView/tree-view.js.map +1 -1
  473. package/dist/hooks/use-overflow-items.d.ts +10 -6
  474. package/dist/hooks/use-overflow-items.d.ts.map +1 -1
  475. package/dist/hooks/use-overflow-items.js.map +1 -1
  476. package/dist/index.d.ts +57 -67
  477. package/dist/index.d.ts.map +1 -1
  478. package/dist/index.js +26 -59
  479. package/dist/index.js.map +1 -1
  480. package/dist/lib/i18n/i18n-context.d.ts +3 -3
  481. package/dist/lib/utils.d.ts.map +1 -1
  482. package/dist/lib/utils.js +3 -1
  483. package/dist/lib/utils.js.map +1 -1
  484. package/dist/patterns/element-anatomy/index.d.ts +2 -0
  485. package/dist/patterns/element-anatomy/index.d.ts.map +1 -0
  486. package/dist/patterns/element-anatomy/index.js +20 -0
  487. package/dist/patterns/element-anatomy/index.js.map +1 -0
  488. package/dist/patterns/element-anatomy/item-anatomy.d.ts +9 -5
  489. package/dist/patterns/element-anatomy/item-anatomy.d.ts.map +1 -1
  490. package/dist/patterns/element-anatomy/item-anatomy.js +1 -1
  491. package/dist/patterns/element-anatomy/item-anatomy.js.map +1 -1
  492. package/dist/patterns/header-canonical/chrome-header.d.ts +2 -2
  493. package/dist/patterns/header-canonical/chrome-header.js.map +1 -1
  494. package/dist/patterns/header-canonical/index.d.ts +2 -0
  495. package/dist/patterns/header-canonical/index.d.ts.map +1 -0
  496. package/dist/patterns/header-canonical/index.js +5 -0
  497. package/dist/patterns/header-canonical/index.js.map +1 -0
  498. package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts +1 -1
  499. package/dist/patterns/horizontal-overflow/index.d.ts +2 -0
  500. package/dist/patterns/horizontal-overflow/index.d.ts.map +1 -0
  501. package/dist/patterns/horizontal-overflow/index.js +14 -0
  502. package/dist/patterns/horizontal-overflow/index.js.map +1 -0
  503. package/dist/patterns/overlay-surface/index.d.ts +2 -0
  504. package/dist/patterns/overlay-surface/index.d.ts.map +1 -0
  505. package/dist/patterns/overlay-surface/index.js +7 -0
  506. package/dist/patterns/overlay-surface/index.js.map +1 -0
  507. package/dist/patterns/overlay-surface/overlay-surface.js.map +1 -1
  508. package/dist/patterns/resize-handle/index.d.ts +2 -0
  509. package/dist/patterns/resize-handle/index.d.ts.map +1 -0
  510. package/dist/patterns/resize-handle/index.js +5 -0
  511. package/dist/patterns/resize-handle/index.js.map +1 -0
  512. package/dist/story-governance/category-matrix.d.ts +35 -0
  513. package/dist/story-governance/category-matrix.d.ts.map +1 -0
  514. package/dist/tokens/categorical-color.d.ts +60 -0
  515. package/dist/tokens/categorical-color.d.ts.map +1 -0
  516. package/dist/tokens/categorical-color.js +110 -0
  517. package/dist/tokens/categorical-color.js.map +1 -0
  518. package/dist/tokens/motion/motion.d.ts +1 -1
  519. package/dist/tokens/motion/motion.d.ts.map +1 -1
  520. package/dist/tokens/motion/motion.js.map +1 -1
  521. package/dist/tokens/uiSize/icon-size.d.ts +4 -5
  522. package/dist/tokens/uiSize/icon-size.d.ts.map +1 -1
  523. package/ds-canonical/commands/README.md +26 -0
  524. package/ds-canonical/commands/gov-status.md +79 -0
  525. package/ds-canonical/hooks/README.md +145 -0
  526. package/ds-canonical/hooks/_log-fire.sh +44 -0
  527. package/ds-canonical/hooks/auto_regen_ds_barrel.sh +58 -0
  528. package/ds-canonical/hooks/block_prototype_imports.py +111 -0
  529. package/ds-canonical/hooks/check_addon_subdir_ship.sh +76 -0
  530. package/ds-canonical/hooks/check_audit_post_report_validator.sh +136 -0
  531. package/ds-canonical/hooks/check_audit_sample_escape.sh +73 -0
  532. package/ds-canonical/hooks/check_benchmark_citation.sh +106 -0
  533. package/ds-canonical/hooks/check_canonical_propagation.sh +189 -0
  534. package/ds-canonical/hooks/check_chrome_header_avatar_canonical.sh +87 -0
  535. package/ds-canonical/hooks/check_codex_brief_invariants.sh +115 -0
  536. package/ds-canonical/hooks/check_codex_collab_5step.sh +108 -0
  537. package/ds-canonical/hooks/check_consumer_app_story_title.sh +81 -0
  538. package/ds-canonical/hooks/check_consumer_ds_primitive_misuse.sh +120 -0
  539. package/ds-canonical/hooks/check_consumer_no_ds_catalog.sh +101 -0
  540. package/ds-canonical/hooks/check_consumer_story_baseline.sh +76 -0
  541. package/ds-canonical/hooks/check_data_table_size_num_to_meta_width.sh +68 -0
  542. package/ds-canonical/hooks/check_datatable_invariants.sh +117 -0
  543. package/ds-canonical/hooks/check_dim_count_drift.sh +72 -0
  544. package/ds-canonical/hooks/check_ds_anchor_preflight.sh +132 -0
  545. package/ds-canonical/hooks/check_escape_marker_abuse.sh +126 -0
  546. package/ds-canonical/hooks/check_field_controls_contracts.sh +110 -0
  547. package/ds-canonical/hooks/check_field_family_invariants.sh +240 -0
  548. package/ds-canonical/hooks/check_file_size_budget.sh +60 -0
  549. package/ds-canonical/hooks/check_fork_user_plugin_install.sh +79 -0
  550. package/ds-canonical/hooks/check_full_story_visual_interaction_sweep.sh +71 -0
  551. package/ds-canonical/hooks/check_item_list_gap.sh +54 -0
  552. package/ds-canonical/hooks/check_layout_space_magic_numbers.sh +96 -0
  553. package/ds-canonical/hooks/check_main_branch_workbench.sh +93 -0
  554. package/ds-canonical/hooks/check_naming_and_abstraction.sh +165 -0
  555. package/ds-canonical/hooks/check_opacity_token_usage.sh +149 -0
  556. package/ds-canonical/hooks/check_orphan_ds_css.sh +66 -0
  557. package/ds-canonical/hooks/check_overlay_open_focus_escape_probe.sh +75 -0
  558. package/ds-canonical/hooks/check_pattern_invariants.sh +196 -0
  559. package/ds-canonical/hooks/check_peoplepicker_ssot_drift.sh +56 -0
  560. package/ds-canonical/hooks/check_pixel_quantified_audit.sh +53 -0
  561. package/ds-canonical/hooks/check_plugin_freshness.sh +68 -0
  562. package/ds-canonical/hooks/check_post_main_ssot_propagate.sh +90 -0
  563. package/ds-canonical/hooks/check_propose_cite_required.sh +88 -0
  564. package/ds-canonical/hooks/check_propose_plain_chinese.sh +74 -0
  565. package/ds-canonical/hooks/check_propose_pre_grep_verify.sh +70 -0
  566. package/ds-canonical/hooks/check_propose_without_benchmark.sh +63 -0
  567. package/ds-canonical/hooks/check_select_all_canonical.sh +58 -0
  568. package/ds-canonical/hooks/check_sidebar_menu_button_implicit_wrap.sh +86 -0
  569. package/ds-canonical/hooks/check_solo_workflow.sh +307 -0
  570. package/ds-canonical/hooks/check_spec_class_drift.sh +88 -0
  571. package/ds-canonical/hooks/check_story_invariants.sh +668 -0
  572. package/ds-canonical/hooks/check_storybook_addon_preset_cjs.sh +87 -0
  573. package/ds-canonical/hooks/check_substantive_edit_approval_preflight.sh +110 -0
  574. package/ds-canonical/hooks/check_tailwind_wildcard_in_docs.sh +73 -0
  575. package/ds-canonical/hooks/check_wrapper_primitive_schema_drift.sh +104 -0
  576. package/ds-canonical/hooks/chrome_header_dispatcher.sh +56 -0
  577. package/ds-canonical/hooks/enforce_home_charter.sh +44 -0
  578. package/ds-canonical/hooks/inject_deploy_url_after_push.sh +238 -0
  579. package/ds-canonical/hooks/inject_pending_self_audit.sh +248 -0
  580. package/ds-canonical/hooks/lib/_app_shell_primary_header_consistency.sh +70 -0
  581. package/ds-canonical/hooks/lib/_approval_re.sh +33 -0
  582. package/ds-canonical/hooks/lib/_chrome_header_handcraft.sh +75 -0
  583. package/ds-canonical/hooks/lib/_code_quality.sh +73 -0
  584. package/ds-canonical/hooks/lib/_cva_default_sync.sh +69 -0
  585. package/ds-canonical/hooks/lib/_governance_coverage_check.sh +49 -0
  586. package/ds-canonical/hooks/lib/_hardcoded_strings.sh +163 -0
  587. package/ds-canonical/hooks/lib/_header_with_tabs_border.sh +87 -0
  588. package/ds-canonical/hooks/lib/_layout_space_canonical.sh +56 -0
  589. package/ds-canonical/hooks/lib/_overlay_handcraft.sh +141 -0
  590. package/ds-canonical/hooks/lib/_person_data_richness.sh +42 -0
  591. package/ds-canonical/hooks/lib/_story_compile_drift.sh +48 -0
  592. package/ds-canonical/hooks/lib/_tab_lg_chrome_header_equal.sh +70 -0
  593. package/ds-canonical/hooks/lib/_token_hygiene.sh +96 -0
  594. package/ds-canonical/hooks/log_governance_fires.sh +50 -0
  595. package/ds-canonical/hooks/log_skill_invokes.sh +41 -0
  596. package/ds-canonical/hooks/post_edit_dispatcher.sh +62 -0
  597. package/ds-canonical/hooks/retired/check_anatomy_section_numbering.sh +106 -0
  598. package/ds-canonical/hooks/retired/check_avatar_hovercard.sh +90 -0
  599. package/ds-canonical/hooks/retired/check_button_icon_literal.sh.retired-2026-04-28 +38 -0
  600. package/ds-canonical/hooks/retired/check_container_breathing.sh +142 -0
  601. package/ds-canonical/hooks/retired/check_governance_compliance.sh +61 -0
  602. package/ds-canonical/hooks/retired/check_icon_only_padding_formula.sh +104 -0
  603. package/ds-canonical/hooks/retired/check_item_content_primitive.sh +150 -0
  604. package/ds-canonical/hooks/retired/check_item_list_gap.sh +153 -0
  605. package/ds-canonical/hooks/retired/check_sideoffset_canonical.sh +65 -0
  606. package/ds-canonical/hooks/retired/check_spec_iteration_tag.sh +87 -0
  607. package/ds-canonical/hooks/retired/check_ssot_consultation.sh +88 -0
  608. package/ds-canonical/hooks/retired/check_sync_update.sh +20 -0
  609. package/ds-canonical/hooks/retired/check_third_party_dom_verified.sh +95 -0
  610. package/ds-canonical/hooks/retired/enforce_home_charter.sh +125 -0
  611. package/ds-canonical/hooks/retired/post_edit_canonical_interrogate.sh +109 -0
  612. package/ds-canonical/hooks/retired/pre_edit_spec_check.sh +68 -0
  613. package/ds-canonical/hooks/retired/pre_new_component_spec.sh +39 -0
  614. package/ds-canonical/hooks/retired/pre_write_subsumption_check.sh +112 -0
  615. package/ds-canonical/hooks/retired/stop_meta_self_audit.sh.retired-2026-05-13 +76 -0
  616. package/ds-canonical/hooks/retired/tests/test_check_anatomy_section_numbering.sh +14 -0
  617. package/ds-canonical/hooks/retired/tests/test_check_avatar_hovercard.sh +15 -0
  618. package/ds-canonical/hooks/retired/tests/test_check_container_breathing.sh +15 -0
  619. package/ds-canonical/hooks/retired/tests/test_check_governance_compliance.sh +15 -0
  620. package/ds-canonical/hooks/retired/tests/test_check_icon_only_padding_formula.sh +79 -0
  621. package/ds-canonical/hooks/retired/tests/test_check_item_content_primitive.sh +15 -0
  622. package/ds-canonical/hooks/retired/tests/test_check_item_list_gap.sh +163 -0
  623. package/ds-canonical/hooks/retired/tests/test_check_sideoffset_canonical.sh +15 -0
  624. package/ds-canonical/hooks/retired/tests/test_check_spec_iteration_tag.sh +15 -0
  625. package/ds-canonical/hooks/retired/tests/test_check_ssot_consultation.sh +15 -0
  626. package/ds-canonical/hooks/retired/tests/test_check_sync_update.sh +14 -0
  627. package/ds-canonical/hooks/retired/tests/test_check_third_party_dom_verified.sh +15 -0
  628. package/ds-canonical/hooks/retired/tests/test_enforce_home_charter.sh +15 -0
  629. package/ds-canonical/hooks/retired/tests/test_pre_edit_spec_check.sh +15 -0
  630. package/ds-canonical/hooks/retired/tests/test_pre_new_component_spec.sh +15 -0
  631. package/ds-canonical/hooks/retired/tests/test_pre_write_subsumption_check.sh +63 -0
  632. package/ds-canonical/hooks/session_start_governance_check.sh +305 -0
  633. package/ds-canonical/hooks/stop_passive_logging.sh +322 -0
  634. package/ds-canonical/hooks/stop_self_audit.sh +516 -0
  635. package/ds-canonical/hooks/tests/KNOWN-BROKEN.md +15 -0
  636. package/ds-canonical/hooks/tests/run-all.sh +76 -0
  637. package/ds-canonical/hooks/tests/test_auto_regen_ds_barrel.sh +180 -0
  638. package/ds-canonical/hooks/tests/test_block_prototype_imports.sh +143 -0
  639. package/ds-canonical/hooks/tests/test_check_addon_subdir_ship.sh +170 -0
  640. package/ds-canonical/hooks/tests/test_check_app_shell_primary_header_consistency.sh +140 -0
  641. package/ds-canonical/hooks/tests/test_check_audit_post_report_validator.sh +127 -0
  642. package/ds-canonical/hooks/tests/test_check_audit_sample_escape.sh +93 -0
  643. package/ds-canonical/hooks/tests/test_check_benchmark_citation.sh +115 -0
  644. package/ds-canonical/hooks/tests/test_check_canonical_propagation.sh +133 -0
  645. package/ds-canonical/hooks/tests/test_check_chrome_header_avatar_canonical.sh +198 -0
  646. package/ds-canonical/hooks/tests/test_check_chrome_header_handcraft.sh +146 -0
  647. package/ds-canonical/hooks/tests/test_check_code_quality.sh +15 -0
  648. package/ds-canonical/hooks/tests/test_check_codex_brief_invariants.sh +208 -0
  649. package/ds-canonical/hooks/tests/test_check_codex_collab_5step.sh +96 -0
  650. package/ds-canonical/hooks/tests/test_check_consumer_app_story_title.sh +163 -0
  651. package/ds-canonical/hooks/tests/test_check_consumer_ds_primitive_misuse.sh +238 -0
  652. package/ds-canonical/hooks/tests/test_check_consumer_no_ds_catalog.sh +211 -0
  653. package/ds-canonical/hooks/tests/test_check_consumer_story_baseline.sh +200 -0
  654. package/ds-canonical/hooks/tests/test_check_cva_default_sync.sh +15 -0
  655. package/ds-canonical/hooks/tests/test_check_data_table_size_num_to_meta_width.sh +52 -0
  656. package/ds-canonical/hooks/tests/test_check_datatable_invariants.sh +122 -0
  657. package/ds-canonical/hooks/tests/test_check_dim_count_drift.sh +98 -0
  658. package/ds-canonical/hooks/tests/test_check_ds_anchor_preflight.sh +104 -0
  659. package/ds-canonical/hooks/tests/test_check_escape_marker_abuse.sh +192 -0
  660. package/ds-canonical/hooks/tests/test_check_field_controls_contracts.sh +126 -0
  661. package/ds-canonical/hooks/tests/test_check_field_family_invariants.sh +203 -0
  662. package/ds-canonical/hooks/tests/test_check_file_size_budget.sh +32 -0
  663. package/ds-canonical/hooks/tests/test_check_fork_user_plugin_install.sh +45 -0
  664. package/ds-canonical/hooks/tests/test_check_full_story_visual_interaction_sweep.sh +190 -0
  665. package/ds-canonical/hooks/tests/test_check_hardcoded_strings.sh +14 -0
  666. package/ds-canonical/hooks/tests/test_check_header_with_tabs_border.sh +110 -0
  667. package/ds-canonical/hooks/tests/test_check_item_list_gap.sh +44 -0
  668. package/ds-canonical/hooks/tests/test_check_layout_space_canonical.sh +73 -0
  669. package/ds-canonical/hooks/tests/test_check_layout_space_magic_numbers.sh +206 -0
  670. package/ds-canonical/hooks/tests/test_check_main_branch_workbench.sh +147 -0
  671. package/ds-canonical/hooks/tests/test_check_naming_and_abstraction.sh +136 -0
  672. package/ds-canonical/hooks/tests/test_check_opacity_token_usage.sh +110 -0
  673. package/ds-canonical/hooks/tests/test_check_orphan_ds_css.sh +212 -0
  674. package/ds-canonical/hooks/tests/test_check_overlay_handcraft.sh +126 -0
  675. package/ds-canonical/hooks/tests/test_check_overlay_open_focus_escape_probe.sh +191 -0
  676. package/ds-canonical/hooks/tests/test_check_pattern_invariants.sh +148 -0
  677. package/ds-canonical/hooks/tests/test_check_peoplepicker_ssot_drift.sh +108 -0
  678. package/ds-canonical/hooks/tests/test_check_person_data_richness.sh +58 -0
  679. package/ds-canonical/hooks/tests/test_check_pixel_quantified_audit.sh +142 -0
  680. package/ds-canonical/hooks/tests/test_check_propose_cite_required.sh +180 -0
  681. package/ds-canonical/hooks/tests/test_check_propose_plain_chinese.sh +126 -0
  682. package/ds-canonical/hooks/tests/test_check_propose_pre_grep_verify.sh +117 -0
  683. package/ds-canonical/hooks/tests/test_check_propose_without_benchmark.sh +55 -0
  684. package/ds-canonical/hooks/tests/test_check_select_all_canonical.sh +125 -0
  685. package/ds-canonical/hooks/tests/test_check_sidebar_menu_button_implicit_wrap.sh +224 -0
  686. package/ds-canonical/hooks/tests/test_check_solo_workflow.sh +201 -0
  687. package/ds-canonical/hooks/tests/test_check_spec_class_drift.sh +135 -0
  688. package/ds-canonical/hooks/tests/test_check_story_anatomy.sh.broken +197 -0
  689. package/ds-canonical/hooks/tests/test_check_story_category.sh.broken +187 -0
  690. package/ds-canonical/hooks/tests/test_check_story_compile_drift.sh +15 -0
  691. package/ds-canonical/hooks/tests/test_check_story_invariants.sh +354 -0
  692. package/ds-canonical/hooks/tests/test_check_story_name_jargon.sh.broken +53 -0
  693. package/ds-canonical/hooks/tests/test_check_story_slot_split.sh +156 -0
  694. package/ds-canonical/hooks/tests/test_check_storybook_addon_preset_cjs.sh +199 -0
  695. package/ds-canonical/hooks/tests/test_check_substantive_edit_approval_preflight.sh +176 -0
  696. package/ds-canonical/hooks/tests/test_check_tab_lg_chrome_header_equal.sh +141 -0
  697. package/ds-canonical/hooks/tests/test_check_tailwind_wildcard_in_docs.sh +182 -0
  698. package/ds-canonical/hooks/tests/test_check_token_hygiene.sh +21 -0
  699. package/ds-canonical/hooks/tests/test_check_wrapper_primitive_schema_drift.sh +169 -0
  700. package/ds-canonical/hooks/tests/test_enforce_home_charter.sh +77 -0
  701. package/ds-canonical/hooks/tests/test_inject_deploy_url_after_push.sh +193 -0
  702. package/ds-canonical/hooks/tests/test_inject_pending_self_audit.sh +125 -0
  703. package/ds-canonical/hooks/tests/test_log_governance_fires.sh +10 -0
  704. package/ds-canonical/hooks/tests/test_log_skill_invokes.sh +7 -0
  705. package/ds-canonical/hooks/tests/test_post_edit_dispatcher.sh +108 -0
  706. package/ds-canonical/hooks/tests/test_session_start_governance_check.sh +154 -0
  707. package/ds-canonical/hooks/tests/test_stop_capture_metrics.sh +95 -0
  708. package/ds-canonical/hooks/tests/test_stop_governance_drift_check.sh.broken +125 -0
  709. package/ds-canonical/hooks/tests/test_stop_harvest_corrections.sh +10 -0
  710. package/ds-canonical/hooks/tests/test_stop_passive_logging.sh +100 -0
  711. package/ds-canonical/hooks/tests/test_stop_self_audit.sh +98 -0
  712. package/ds-canonical/hooks/tests/test_stop_tsc_sanity.sh +10 -0
  713. package/ds-canonical/references/README.md +46 -0
  714. package/ds-canonical/references/audit-coverage-vs-24-checklist.md +74 -0
  715. package/ds-canonical/references/build-ui-canonicals.md +72 -0
  716. package/ds-canonical/references/composition-fidelity.md +47 -0
  717. package/ds-canonical/references/cva-patterns.md +41 -0
  718. package/ds-canonical/references/drag-canonical.md +331 -0
  719. package/ds-canonical/references/item-anatomy-recipe.md +225 -0
  720. package/ds-canonical/references/naming-conventions.md +56 -0
  721. package/ds-canonical/references/principle-dim-map.json +513 -0
  722. package/ds-canonical/references/props-naming.md +45 -0
  723. package/ds-canonical/references/scenario-definition.md +146 -0
  724. package/ds-canonical/references/spec-rules.md +58 -0
  725. package/ds-canonical/references/ssot-consultation.md +63 -0
  726. package/ds-canonical/references/ssot-index.md +40 -0
  727. package/ds-canonical/references/story-baseline-registry.json +79 -0
  728. package/ds-canonical/references/structural-token-retention.md +42 -0
  729. package/ds-canonical/references/tailwind-gotchas.md +87 -0
  730. package/ds-canonical/references/ui-dev-rules.md +60 -0
  731. package/ds-canonical/rules/README.md +34 -0
  732. package/ds-canonical/rules/meta-patterns.md +87 -0
  733. package/ds-canonical/rules/self-verify.md +56 -0
  734. package/ds-canonical/rules/spec-rules.md +25 -0
  735. package/ds-canonical/rules/story-rules.md +65 -0
  736. package/ds-canonical/rules/ui-development.md +92 -0
  737. package/ds-canonical/skills/README.md +88 -0
  738. package/ds-canonical/skills/bug-fix-rhythm/SKILL.md +181 -0
  739. package/ds-canonical/skills/code-quality-audit/SKILL.md +63 -0
  740. package/ds-canonical/skills/codex-collab/SKILL.md +249 -0
  741. package/ds-canonical/skills/codex-collab/references/brief-template.md +48 -0
  742. package/ds-canonical/skills/codex-collab/references/transport.md +58 -0
  743. package/ds-canonical/skills/codify-corrections/SKILL.md +184 -0
  744. package/ds-canonical/skills/codify-principle/SKILL.md +151 -0
  745. package/ds-canonical/skills/component-quality-gate/SKILL.md +102 -0
  746. package/ds-canonical/skills/component-quality-gate/references/checklist.md +79 -0
  747. package/ds-canonical/skills/deep-audit-cross-codex/SKILL.md +242 -0
  748. package/ds-canonical/skills/deep-audit-cross-codex/references/phase-a-workflow.md +123 -0
  749. package/ds-canonical/skills/deep-audit-cross-codex/references/phase-b-codex-brief.md +186 -0
  750. package/ds-canonical/skills/deep-audit-cross-codex/references/skill-relationships-antipatterns-benchmarks.md +30 -0
  751. package/ds-canonical/skills/deep-audit-cross-codex/references/triage-rubric.md +69 -0
  752. package/ds-canonical/skills/deep-audit-cross-codex/references/upstream-directives-r-mapping.md +33 -0
  753. package/ds-canonical/skills/delivery-handoff/SKILL.md +229 -0
  754. package/ds-canonical/skills/delivery-handoff/references/flow-diagram.md +180 -0
  755. package/ds-canonical/skills/delivery-handoff/references/handoff-template.md +177 -0
  756. package/ds-canonical/skills/delivery-handoff/references/inventory-checklist.md +196 -0
  757. package/ds-canonical/skills/design-system-audit/SKILL.md +384 -0
  758. package/ds-canonical/skills/design-system-audit/references/audit-prompts.md +1324 -0
  759. package/ds-canonical/skills/design-system-audit/references/checkpoints.md +240 -0
  760. package/ds-canonical/skills/design-system-audit/references/historical-bugs.md +240 -0
  761. package/ds-canonical/skills/design-system-audit/references/principle-audit-protocol.md +378 -0
  762. package/ds-canonical/skills/design-system-audit/references/rule-placement.md +175 -0
  763. package/ds-canonical/skills/ensure-canonical/SKILL.md +196 -0
  764. package/ds-canonical/skills/governance-health/SKILL.md +147 -0
  765. package/ds-canonical/skills/knowledge-prune/SKILL.md +250 -0
  766. package/ds-canonical/skills/knowledge-prune/references/phase-z-cross-repo-ssot-propagation.md +11 -0
  767. package/ds-canonical/skills/knowledge-prune/references/prune-dimensions-d5-d10.md +55 -0
  768. package/ds-canonical/skills/knowledge-prune/references/world-class-prune-alignment.md +7 -0
  769. package/ds-canonical/skills/new-component/SKILL.md +170 -0
  770. package/ds-canonical/skills/new-component/references/new-component-checklist.md +85 -0
  771. package/ds-canonical/skills/performance-audit/SKILL.md +107 -0
  772. package/ds-canonical/skills/product-ui-audit/SKILL.md +230 -0
  773. package/ds-canonical/skills/product-ui-audit/references/audit-checks.md +246 -0
  774. package/ds-canonical/skills/product-ui-audit/references/common-misuses.md +329 -0
  775. package/ds-canonical/skills/product-ui-audit/references/report-template.md +159 -0
  776. package/ds-canonical/skills/propose-options/SKILL.md +177 -0
  777. package/ds-canonical/skills/prototype/SKILL.md +244 -0
  778. package/ds-canonical/skills/prototype/references/audit-checks.md +37 -0
  779. package/ds-canonical/skills/prototype/references/benchmark-sources.md +94 -0
  780. package/ds-canonical/skills/prototype/references/checkpoints.md +191 -0
  781. package/ds-canonical/skills/prototype/references/evaluation-matrix.md +141 -0
  782. package/ds-canonical/skills/prototype/references/ooux-template.md +198 -0
  783. package/ds-canonical/skills/prototype/references/proposal-template.md +229 -0
  784. package/ds-canonical/skills/scan-similar-bugs/SKILL.md +198 -0
  785. package/ds-canonical/skills/story-auto-compile-migrate/SKILL.md +159 -0
  786. package/ds-canonical/skills/story-writing/SKILL.md +122 -0
  787. package/ds-canonical/skills/story-writing/references/anatomy-standard.md +217 -0
  788. package/ds-canonical/skills/story-writing/references/category-templates.md +174 -0
  789. package/ds-canonical/skills/story-writing/references/example-selection.md +70 -0
  790. package/ds-canonical/skills/story-writing/references/self-check.md +20 -0
  791. package/ds-canonical/skills/ux-audit/SKILL.md +130 -0
  792. package/ds-canonical/skills/visual-audit/SKILL.md +245 -0
  793. package/ds-canonical/skills/visual-audit/output/.gitkeep +0 -0
  794. package/ds-canonical/skills/visual-audit/references/audit-architecture.md +100 -0
  795. package/ds-canonical/skills/visual-audit/references/visual-checklist.md +297 -0
  796. package/ds-canonical/skills/visual-audit/references/world-class-benchmarks.md +198 -0
  797. package/ds-canonical/templates/_README.md +23 -0
  798. package/ds-canonical/templates/dashboard-app.tsx +151 -0
  799. package/ds-story-manifest.json +1688 -0
  800. package/package.json +29 -13
  801. package/src/components/Accordion/accordion.anatomy.stories.tsx +496 -0
  802. package/src/components/Accordion/accordion.principles.stories.tsx +360 -0
  803. package/src/components/Accordion/accordion.spec.md +114 -0
  804. package/src/components/Accordion/accordion.stories.tsx +190 -0
  805. package/src/components/Accordion/accordion.tsx +3 -0
  806. package/src/components/Accordion/index.ts +5 -0
  807. package/src/components/Alert/alert.anatomy.stories.tsx +238 -0
  808. package/src/components/Alert/alert.principles.stories.tsx +220 -0
  809. package/src/components/Alert/alert.spec.md +197 -0
  810. package/src/components/Alert/alert.stories.tsx +139 -0
  811. package/src/components/Alert/index.ts +5 -0
  812. package/src/components/AppShell/_demo-helpers.tsx +5 -5
  813. package/src/components/AppShell/app-shell.anatomy.stories.tsx +176 -0
  814. package/src/components/AppShell/app-shell.principles.stories.tsx +81 -0
  815. package/src/components/AppShell/app-shell.spec.md +330 -0
  816. package/src/components/AppShell/app-shell.stories.tsx +435 -0
  817. package/src/components/AppShell/app-shell.tsx +9 -4
  818. package/src/components/AppShell/index.ts +5 -0
  819. package/src/components/AspectRatio/aspect-ratio.anatomy.stories.tsx +208 -0
  820. package/src/components/AspectRatio/aspect-ratio.principles.stories.tsx +303 -0
  821. package/src/components/AspectRatio/aspect-ratio.spec.md +134 -0
  822. package/src/components/AspectRatio/aspect-ratio.stories.tsx +170 -0
  823. package/src/components/AspectRatio/aspect-ratio.tsx +4 -2
  824. package/src/components/AspectRatio/index.ts +5 -0
  825. package/src/components/Avatar/avatar.anatomy.stories.tsx +701 -0
  826. package/src/components/Avatar/avatar.principles.stories.tsx +245 -0
  827. package/src/components/Avatar/avatar.spec.md +339 -0
  828. package/src/components/Avatar/avatar.stories.tsx +135 -0
  829. package/src/components/Avatar/avatar.tsx +33 -39
  830. package/src/components/Avatar/index.ts +5 -0
  831. package/src/components/Badge/badge.anatomy.stories.tsx +591 -0
  832. package/src/components/Badge/badge.principles.stories.tsx +391 -0
  833. package/src/components/Badge/badge.spec.md +389 -0
  834. package/src/components/Badge/badge.stories.tsx +80 -0
  835. package/src/components/Badge/badge.tsx +33 -12
  836. package/src/components/Badge/index.ts +5 -0
  837. package/src/components/Breadcrumb/breadcrumb.anatomy.stories.tsx +458 -0
  838. package/src/components/Breadcrumb/breadcrumb.principles.stories.tsx +340 -0
  839. package/src/components/Breadcrumb/breadcrumb.spec.md +258 -0
  840. package/src/components/Breadcrumb/breadcrumb.stories.tsx +332 -0
  841. package/src/components/Breadcrumb/breadcrumb.tsx +27 -17
  842. package/src/components/Breadcrumb/index.ts +5 -0
  843. package/src/components/BulkActionBar/bulk-action-bar.anatomy.stories.tsx +224 -0
  844. package/src/components/BulkActionBar/bulk-action-bar.principles.stories.tsx +242 -0
  845. package/src/components/BulkActionBar/bulk-action-bar.spec.md +210 -0
  846. package/src/components/BulkActionBar/bulk-action-bar.stories.tsx +136 -0
  847. package/src/components/BulkActionBar/bulk-action-bar.tsx +8 -7
  848. package/src/components/BulkActionBar/index.ts +5 -0
  849. package/src/components/Button/button.anatomy.stories.tsx +710 -0
  850. package/src/components/Button/button.principles.stories.tsx +370 -0
  851. package/src/components/Button/button.spec.md +461 -0
  852. package/src/components/Button/button.stories.tsx +362 -0
  853. package/src/components/Button/button.tsx +12 -5
  854. package/src/components/Button/index.ts +5 -0
  855. package/src/components/Calendar/calendar.anatomy.stories.tsx +218 -0
  856. package/src/components/Calendar/calendar.principles.stories.tsx +143 -0
  857. package/src/components/Calendar/calendar.spec.md +244 -0
  858. package/src/components/Calendar/calendar.stories.tsx +88 -0
  859. package/src/components/Calendar/calendar.tsx +29 -19
  860. package/src/components/Calendar/index.ts +5 -0
  861. package/src/components/Carousel/carousel.anatomy.stories.tsx +516 -0
  862. package/src/components/Carousel/carousel.principles.stories.tsx +330 -0
  863. package/src/components/Carousel/carousel.spec.md +253 -0
  864. package/src/components/Carousel/carousel.stories.tsx +121 -0
  865. package/src/components/Carousel/carousel.tsx +7 -3
  866. package/src/components/Carousel/index.ts +5 -0
  867. package/src/components/Chart/chart.anatomy.stories.tsx +307 -0
  868. package/src/components/Chart/chart.principles.stories.tsx +436 -0
  869. package/src/components/Chart/chart.spec.md +155 -0
  870. package/src/components/Chart/chart.stories.tsx +268 -0
  871. package/src/components/Chart/chart.tsx +4 -1
  872. package/src/components/Chart/index.ts +5 -0
  873. package/src/components/Checkbox/checkbox.anatomy.stories.tsx +626 -0
  874. package/src/components/Checkbox/checkbox.principles.stories.tsx +213 -0
  875. package/src/components/Checkbox/checkbox.spec.md +344 -0
  876. package/src/components/Checkbox/checkbox.stories.tsx +114 -0
  877. package/src/components/Checkbox/checkbox.tsx +14 -14
  878. package/src/components/Checkbox/index.ts +5 -0
  879. package/src/components/Chip/chip.anatomy.stories.tsx +422 -0
  880. package/src/components/Chip/chip.principles.stories.tsx +222 -0
  881. package/src/components/Chip/chip.spec.md +238 -0
  882. package/src/components/Chip/chip.stories.tsx +88 -0
  883. package/src/components/Chip/chip.tsx +4 -4
  884. package/src/components/Chip/index.ts +5 -0
  885. package/src/components/CircularProgress/circular-progress.anatomy.stories.tsx +176 -0
  886. package/src/components/CircularProgress/circular-progress.principles.stories.tsx +258 -0
  887. package/src/components/CircularProgress/circular-progress.spec.md +268 -0
  888. package/src/components/CircularProgress/circular-progress.stories.tsx +160 -0
  889. package/src/components/CircularProgress/circular-progress.tsx +3 -4
  890. package/src/components/CircularProgress/index.ts +5 -0
  891. package/src/components/Coachmark/coachmark-story-helpers.tsx +39 -0
  892. package/src/components/Coachmark/coachmark.anatomy.stories.tsx +356 -0
  893. package/src/components/Coachmark/coachmark.principles.stories.tsx +369 -0
  894. package/src/components/Coachmark/coachmark.spec.md +230 -0
  895. package/src/components/Coachmark/coachmark.stories.tsx +214 -0
  896. package/src/components/Coachmark/coachmark.tsx +12 -3
  897. package/src/components/Coachmark/index.ts +5 -0
  898. package/src/components/Combobox/combobox.anatomy.stories.tsx +919 -0
  899. package/src/components/Combobox/combobox.principles.stories.tsx +239 -0
  900. package/src/components/Combobox/combobox.spec.md +184 -0
  901. package/src/components/Combobox/combobox.stories.tsx +184 -0
  902. package/src/components/Combobox/combobox.tsx +35 -13
  903. package/src/components/Combobox/index.ts +5 -0
  904. package/src/components/Command/command.anatomy.stories.tsx +105 -0
  905. package/src/components/Command/command.principles.stories.tsx +88 -0
  906. package/src/components/Command/command.spec.md +171 -0
  907. package/src/components/Command/command.stories.tsx +280 -0
  908. package/src/components/Command/index.ts +5 -0
  909. package/src/components/DataTable/data-table-filter-panel.tsx +2 -2
  910. package/src/components/DataTable/data-table.anatomy.stories.tsx +517 -0
  911. package/src/components/DataTable/data-table.principles.stories.tsx +265 -0
  912. package/src/components/DataTable/data-table.spec.md +526 -0
  913. package/src/components/DataTable/data-table.stories.tsx +1892 -0
  914. package/src/components/DataTable/data-table.tsx +6 -6
  915. package/src/components/DataTable/filter-operators.spec.md +275 -0
  916. package/src/components/DataTable/filter-operators.ts +1 -1
  917. package/src/components/DataTable/filter-tree.ts +2 -2
  918. package/src/components/DataTable/index.ts +5 -0
  919. package/src/components/DateGrid/date-grid.anatomy.stories.tsx +583 -0
  920. package/src/components/DateGrid/date-grid.principles.stories.tsx +338 -0
  921. package/src/components/DateGrid/date-grid.spec.md +215 -0
  922. package/src/components/DateGrid/date-grid.stories.tsx +195 -0
  923. package/src/components/DateGrid/date-grid.tsx +15 -15
  924. package/src/components/DateGrid/index.ts +5 -0
  925. package/src/components/DatePicker/date-picker.anatomy.stories.tsx +952 -0
  926. package/src/components/DatePicker/date-picker.principles.stories.tsx +205 -0
  927. package/src/components/DatePicker/date-picker.spec.md +333 -0
  928. package/src/components/DatePicker/date-picker.stories.tsx +353 -0
  929. package/src/components/DatePicker/date-picker.tsx +12 -1
  930. package/src/components/DatePicker/index.ts +5 -0
  931. package/src/components/DescriptionList/description-list.anatomy.stories.tsx +252 -0
  932. package/src/components/DescriptionList/description-list.principles.stories.tsx +323 -0
  933. package/src/components/DescriptionList/description-list.spec.md +214 -0
  934. package/src/components/DescriptionList/description-list.stories.tsx +128 -0
  935. package/src/components/DescriptionList/description-list.tsx +2 -2
  936. package/src/components/DescriptionList/index.ts +5 -0
  937. package/src/components/Dialog/dialog.anatomy.stories.tsx +484 -0
  938. package/src/components/Dialog/dialog.principles.stories.tsx +313 -0
  939. package/src/components/Dialog/dialog.spec.md +201 -0
  940. package/src/components/Dialog/dialog.stories.tsx +500 -0
  941. package/src/components/Dialog/dialog.tsx +4 -4
  942. package/src/components/Dialog/index.ts +5 -0
  943. package/src/components/DropdownMenu/dropdown-menu.anatomy.stories.tsx +969 -0
  944. package/src/components/DropdownMenu/dropdown-menu.principles.stories.tsx +340 -0
  945. package/src/components/DropdownMenu/dropdown-menu.spec.md +265 -0
  946. package/src/components/DropdownMenu/dropdown-menu.stories.tsx +288 -0
  947. package/src/components/DropdownMenu/dropdown-menu.tsx +14 -5
  948. package/src/components/DropdownMenu/index.ts +5 -0
  949. package/src/components/Empty/empty.anatomy.stories.tsx +275 -0
  950. package/src/components/Empty/empty.principles.stories.tsx +314 -0
  951. package/src/components/Empty/empty.spec.md +215 -0
  952. package/src/components/Empty/empty.stories.tsx +80 -0
  953. package/src/components/Empty/empty.tsx +13 -6
  954. package/src/components/Empty/index.ts +5 -0
  955. package/src/components/Field/field-controls.spec.md +338 -0
  956. package/src/components/Field/field-types.ts +1 -1
  957. package/src/components/Field/field.anatomy.stories.tsx +541 -0
  958. package/src/components/Field/field.principles.stories.tsx +277 -0
  959. package/src/components/Field/field.spec.md +438 -0
  960. package/src/components/Field/field.stories.tsx +552 -0
  961. package/src/components/Field/field.tsx +2 -2
  962. package/src/components/Field/form-validation.spec.md +150 -0
  963. package/src/components/Field/index.ts +5 -0
  964. package/src/components/FieldControlGroup/field-control-group.anatomy.stories.tsx +117 -0
  965. package/src/components/FieldControlGroup/field-control-group.principles.stories.tsx +117 -0
  966. package/src/components/FieldControlGroup/field-control-group.spec.md +179 -0
  967. package/src/components/FieldControlGroup/field-control-group.stories.tsx +161 -0
  968. package/src/components/FieldControlGroup/field-control-group.tsx +5 -5
  969. package/src/components/FieldControlGroup/index.ts +5 -0
  970. package/src/components/FileItem/file-item.anatomy.stories.tsx +354 -0
  971. package/src/components/FileItem/file-item.principles.stories.tsx +275 -0
  972. package/src/components/FileItem/file-item.spec.md +491 -0
  973. package/src/components/FileItem/file-item.stories.tsx +265 -0
  974. package/src/components/FileItem/file-item.tsx +37 -13
  975. package/src/components/FileItem/index.ts +5 -0
  976. package/src/components/FileUpload/file-upload.anatomy.stories.tsx +444 -0
  977. package/src/components/FileUpload/file-upload.principles.stories.tsx +314 -0
  978. package/src/components/FileUpload/file-upload.spec.md +134 -0
  979. package/src/components/FileUpload/file-upload.stories.tsx +167 -0
  980. package/src/components/FileUpload/file-upload.tsx +75 -26
  981. package/src/components/FileUpload/index.ts +5 -0
  982. package/src/components/FileViewer/file-viewer.anatomy.stories.tsx +1122 -0
  983. package/src/components/FileViewer/file-viewer.principles.stories.tsx +636 -0
  984. package/src/components/FileViewer/file-viewer.spec.md +380 -0
  985. package/src/components/FileViewer/file-viewer.stories.tsx +407 -0
  986. package/src/components/FileViewer/file-viewer.tsx +10 -9
  987. package/src/components/FileViewer/index.ts +5 -0
  988. package/src/components/HoverCard/hover-card.anatomy.stories.tsx +145 -0
  989. package/src/components/HoverCard/hover-card.principles.stories.tsx +222 -0
  990. package/src/components/HoverCard/hover-card.spec.md +157 -0
  991. package/src/components/HoverCard/hover-card.stories.tsx +304 -0
  992. package/src/components/HoverCard/hover-card.tsx +3 -3
  993. package/src/components/HoverCard/index.ts +5 -0
  994. package/src/components/Input/index.ts +5 -0
  995. package/src/components/Input/input.anatomy.stories.tsx +763 -0
  996. package/src/components/Input/input.principles.stories.tsx +292 -0
  997. package/src/components/Input/input.spec.md +195 -0
  998. package/src/components/Input/input.stories.tsx +133 -0
  999. package/src/components/Input/input.tsx +11 -4
  1000. package/src/components/LinkInput/index.ts +5 -0
  1001. package/src/components/LinkInput/link-input.anatomy.stories.tsx +746 -0
  1002. package/src/components/LinkInput/link-input.principles.stories.tsx +182 -0
  1003. package/src/components/LinkInput/link-input.spec.md +131 -0
  1004. package/src/components/LinkInput/link-input.stories.tsx +132 -0
  1005. package/src/components/LinkInput/link-input.tsx +7 -4
  1006. package/src/components/Menu/index.ts +5 -0
  1007. package/src/components/Menu/menu-item.anatomy.stories.tsx +780 -0
  1008. package/src/components/Menu/menu-item.principles.stories.tsx +81 -0
  1009. package/src/components/Menu/menu-item.spec.md +292 -0
  1010. package/src/components/Menu/menu-item.stories.tsx +214 -0
  1011. package/src/components/Menu/menu-item.tsx +1 -0
  1012. package/src/components/Notice/index.ts +5 -0
  1013. package/src/components/Notice/notice.anatomy.stories.tsx +610 -0
  1014. package/src/components/Notice/notice.principles.stories.tsx +102 -0
  1015. package/src/components/Notice/notice.spec.md +151 -0
  1016. package/src/components/Notice/notice.stories.tsx +257 -0
  1017. package/src/components/Notice/notice.tsx +3 -2
  1018. package/src/components/NumberInput/index.ts +5 -0
  1019. package/src/components/NumberInput/number-input.anatomy.stories.tsx +786 -0
  1020. package/src/components/NumberInput/number-input.principles.stories.tsx +221 -0
  1021. package/src/components/NumberInput/number-input.spec.md +125 -0
  1022. package/src/components/NumberInput/number-input.stories.tsx +142 -0
  1023. package/src/components/NumberInput/number-input.tsx +2 -1
  1024. package/src/components/OverflowIndicator/index.ts +5 -0
  1025. package/src/components/OverflowIndicator/overflow-indicator.anatomy.stories.tsx +548 -0
  1026. package/src/components/OverflowIndicator/overflow-indicator.principles.stories.tsx +80 -0
  1027. package/src/components/OverflowIndicator/overflow-indicator.spec.md +119 -0
  1028. package/src/components/OverflowIndicator/overflow-indicator.stories.tsx +274 -0
  1029. package/src/components/OverflowIndicator/overflow-indicator.tsx +9 -2
  1030. package/src/components/PeoplePicker/index.ts +5 -0
  1031. package/src/components/PeoplePicker/people-picker-helpers.ts +5 -5
  1032. package/src/components/PeoplePicker/people-picker.anatomy.stories.tsx +418 -0
  1033. package/src/components/PeoplePicker/people-picker.principles.stories.tsx +192 -0
  1034. package/src/components/PeoplePicker/people-picker.spec.md +278 -0
  1035. package/src/components/PeoplePicker/people-picker.stories.tsx +163 -0
  1036. package/src/components/PeoplePicker/people-picker.tsx +7 -7
  1037. package/src/components/PeoplePicker/person-display.tsx +26 -26
  1038. package/src/components/Popover/index.ts +5 -0
  1039. package/src/components/Popover/popover.anatomy.stories.tsx +277 -0
  1040. package/src/components/Popover/popover.principles.stories.tsx +293 -0
  1041. package/src/components/Popover/popover.spec.md +200 -0
  1042. package/src/components/Popover/popover.stories.tsx +116 -0
  1043. package/src/components/Popover/popover.tsx +2 -2
  1044. package/src/components/ProfileCard/index.ts +5 -0
  1045. package/src/components/ProfileCard/profile-card.anatomy.stories.tsx +504 -0
  1046. package/src/components/ProfileCard/profile-card.principles.stories.tsx +221 -0
  1047. package/src/components/ProfileCard/profile-card.spec.md +171 -0
  1048. package/src/components/ProfileCard/profile-card.stories.tsx +53 -0
  1049. package/src/components/{NameCard/name-card.tsx → ProfileCard/profile-card.tsx} +25 -24
  1050. package/src/components/ProgressBar/index.ts +5 -0
  1051. package/src/components/ProgressBar/progress-bar.anatomy.stories.tsx +438 -0
  1052. package/src/components/ProgressBar/progress-bar.principles.stories.tsx +337 -0
  1053. package/src/components/ProgressBar/progress-bar.spec.md +232 -0
  1054. package/src/components/ProgressBar/progress-bar.stories.tsx +119 -0
  1055. package/src/components/ProgressBar/progress-bar.tsx +4 -4
  1056. package/src/components/RadioGroup/index.ts +5 -0
  1057. package/src/components/RadioGroup/radio-group.anatomy.stories.tsx +678 -0
  1058. package/src/components/RadioGroup/radio-group.principles.stories.tsx +170 -0
  1059. package/src/components/RadioGroup/radio-group.spec.md +141 -0
  1060. package/src/components/RadioGroup/radio-group.stories.tsx +101 -0
  1061. package/src/components/RadioGroup/radio-group.tsx +34 -33
  1062. package/src/components/Rating/index.ts +5 -0
  1063. package/src/components/Rating/rating.anatomy.stories.tsx +494 -0
  1064. package/src/components/Rating/rating.principles.stories.tsx +293 -0
  1065. package/src/components/Rating/rating.spec.md +208 -0
  1066. package/src/components/Rating/rating.stories.tsx +133 -0
  1067. package/src/components/Rating/rating.tsx +17 -6
  1068. package/src/components/ScrollArea/index.ts +5 -0
  1069. package/src/components/ScrollArea/scroll-area.anatomy.stories.tsx +431 -0
  1070. package/src/components/ScrollArea/scroll-area.principles.stories.tsx +337 -0
  1071. package/src/components/ScrollArea/scroll-area.spec.md +145 -0
  1072. package/src/components/ScrollArea/scroll-area.stories.tsx +193 -0
  1073. package/src/components/ScrollArea/scroll-area.tsx +1 -1
  1074. package/src/components/SegmentedControl/index.ts +5 -0
  1075. package/src/components/SegmentedControl/segmented-control.anatomy.stories.tsx +295 -0
  1076. package/src/components/SegmentedControl/segmented-control.principles.stories.tsx +281 -0
  1077. package/src/components/SegmentedControl/segmented-control.spec.md +296 -0
  1078. package/src/components/SegmentedControl/segmented-control.stories.tsx +33 -0
  1079. package/src/components/SegmentedControl/segmented-control.tsx +4 -3
  1080. package/src/components/Select/index.ts +5 -0
  1081. package/src/components/Select/select.anatomy.stories.tsx +827 -0
  1082. package/src/components/Select/select.principles.stories.tsx +311 -0
  1083. package/src/components/Select/select.spec.md +311 -0
  1084. package/src/components/Select/select.stories.tsx +198 -0
  1085. package/src/components/Select/select.tsx +6 -2
  1086. package/src/components/SelectMenu/index.ts +5 -0
  1087. package/src/components/SelectMenu/select-menu.anatomy.stories.tsx +811 -0
  1088. package/src/components/SelectMenu/select-menu.principles.stories.tsx +107 -0
  1089. package/src/components/SelectMenu/select-menu.spec.md +222 -0
  1090. package/src/components/SelectMenu/select-menu.stories.tsx +148 -0
  1091. package/src/components/SelectMenu/select-menu.tsx +20 -6
  1092. package/src/components/SelectionControl/index.ts +5 -0
  1093. package/src/components/SelectionControl/selection-item.anatomy.stories.tsx +571 -0
  1094. package/src/components/SelectionControl/selection-item.principles.stories.tsx +77 -0
  1095. package/src/components/SelectionControl/selection-item.spec.md +130 -0
  1096. package/src/components/SelectionControl/selection-item.stories.tsx +137 -0
  1097. package/src/components/Separator/index.ts +5 -0
  1098. package/src/components/Separator/separator.anatomy.stories.tsx +125 -0
  1099. package/src/components/Separator/separator.principles.stories.tsx +141 -0
  1100. package/src/components/Separator/separator.spec.md +109 -0
  1101. package/src/components/Separator/separator.stories.tsx +127 -0
  1102. package/src/components/Separator/separator.tsx +2 -2
  1103. package/src/components/Sheet/index.ts +5 -0
  1104. package/src/components/Sheet/sheet.anatomy.stories.tsx +268 -0
  1105. package/src/components/Sheet/sheet.principles.stories.tsx +370 -0
  1106. package/src/components/Sheet/sheet.spec.md +148 -0
  1107. package/src/components/Sheet/sheet.stories.tsx +168 -0
  1108. package/src/components/Sheet/sheet.tsx +1 -1
  1109. package/src/components/Sidebar/index.ts +5 -0
  1110. package/src/components/Sidebar/sidebar.anatomy.stories.tsx +763 -0
  1111. package/src/components/Sidebar/sidebar.principles.stories.tsx +505 -0
  1112. package/src/components/Sidebar/sidebar.spec.md +711 -0
  1113. package/src/components/Sidebar/sidebar.stories.tsx +482 -0
  1114. package/src/components/Sidebar/sidebar.tsx +5 -2
  1115. package/src/components/Skeleton/index.ts +5 -0
  1116. package/src/components/Skeleton/skeleton.anatomy.stories.tsx +145 -0
  1117. package/src/components/Skeleton/skeleton.principles.stories.tsx +221 -0
  1118. package/src/components/Skeleton/skeleton.spec.md +104 -0
  1119. package/src/components/Skeleton/skeleton.stories.tsx +129 -0
  1120. package/src/components/Slider/index.ts +5 -0
  1121. package/src/components/Slider/slider.anatomy.stories.tsx +235 -0
  1122. package/src/components/Slider/slider.principles.stories.tsx +250 -0
  1123. package/src/components/Slider/slider.spec.md +353 -0
  1124. package/src/components/Slider/slider.stories.tsx +115 -0
  1125. package/src/components/Slider/slider.tsx +26 -5
  1126. package/src/components/Steps/index.ts +5 -0
  1127. package/src/components/Steps/steps.anatomy.stories.tsx +448 -0
  1128. package/src/components/Steps/steps.principles.stories.tsx +303 -0
  1129. package/src/components/Steps/steps.spec.md +473 -0
  1130. package/src/components/Steps/steps.stories.tsx +370 -0
  1131. package/src/components/Steps/steps.tsx +28 -11
  1132. package/src/components/Switch/index.ts +5 -0
  1133. package/src/components/Switch/switch.anatomy.stories.tsx +227 -0
  1134. package/src/components/Switch/switch.principles.stories.tsx +174 -0
  1135. package/src/components/Switch/switch.spec.md +221 -0
  1136. package/src/components/Switch/switch.stories.tsx +107 -0
  1137. package/src/components/Switch/switch.tsx +13 -13
  1138. package/src/components/Tabs/index.ts +5 -0
  1139. package/src/components/Tabs/tabs.anatomy.stories.tsx +414 -0
  1140. package/src/components/Tabs/tabs.principles.stories.tsx +257 -0
  1141. package/src/components/Tabs/tabs.spec.md +316 -0
  1142. package/src/components/Tabs/tabs.stories.tsx +155 -0
  1143. package/src/components/Tabs/tabs.tsx +6 -5
  1144. package/src/components/Tag/index.ts +5 -0
  1145. package/src/components/Tag/tag.anatomy.stories.tsx +664 -0
  1146. package/src/components/Tag/tag.principles.stories.tsx +270 -0
  1147. package/src/components/Tag/tag.spec.md +304 -0
  1148. package/src/components/Tag/tag.stories.tsx +69 -0
  1149. package/src/components/Tag/tag.tsx +52 -56
  1150. package/src/components/Textarea/index.ts +5 -0
  1151. package/src/components/Textarea/textarea.anatomy.stories.tsx +304 -0
  1152. package/src/components/Textarea/textarea.principles.stories.tsx +175 -0
  1153. package/src/components/Textarea/textarea.spec.md +150 -0
  1154. package/src/components/Textarea/textarea.stories.tsx +53 -0
  1155. package/src/components/Textarea/textarea.tsx +10 -6
  1156. package/src/components/TimePicker/index.ts +5 -0
  1157. package/src/components/TimePicker/time-picker.anatomy.stories.tsx +275 -0
  1158. package/src/components/TimePicker/time-picker.principles.stories.tsx +140 -0
  1159. package/src/components/TimePicker/time-picker.spec.md +270 -0
  1160. package/src/components/TimePicker/time-picker.stories.tsx +193 -0
  1161. package/src/components/TimePicker/time-picker.tsx +20 -5
  1162. package/src/components/Toast/index.ts +5 -0
  1163. package/src/components/Toast/toast.anatomy.stories.tsx +324 -0
  1164. package/src/components/Toast/toast.principles.stories.tsx +217 -0
  1165. package/src/components/Toast/toast.spec.md +178 -0
  1166. package/src/components/Toast/toast.stories.tsx +119 -0
  1167. package/src/components/Toast/toast.tsx +1 -1
  1168. package/src/components/Tooltip/index.ts +5 -0
  1169. package/src/components/Tooltip/tooltip.anatomy.stories.tsx +413 -0
  1170. package/src/components/Tooltip/tooltip.principles.stories.tsx +204 -0
  1171. package/src/components/Tooltip/tooltip.spec.md +139 -0
  1172. package/src/components/Tooltip/tooltip.stories.tsx +116 -0
  1173. package/src/components/Tooltip/tooltip.tsx +1 -0
  1174. package/src/components/TreeView/index.ts +5 -0
  1175. package/src/components/TreeView/tree-view.anatomy.stories.tsx +410 -0
  1176. package/src/components/TreeView/tree-view.principles.stories.tsx +190 -0
  1177. package/src/components/TreeView/tree-view.spec.md +388 -0
  1178. package/src/components/TreeView/tree-view.stories.tsx +297 -0
  1179. package/src/components/TreeView/tree-view.tsx +49 -16
  1180. package/src/hooks/use-overflow-items.ts +10 -6
  1181. package/src/index.ts +73 -69
  1182. package/src/lib/utils.ts +2 -1
  1183. package/src/patterns/README.md +15 -11
  1184. package/src/patterns/action-bar/action-bar.spec.md +458 -0
  1185. package/src/patterns/action-bar/action-bar.stories.tsx +612 -0
  1186. package/src/patterns/element-anatomy/element-anatomy.spec.md +215 -0
  1187. package/src/patterns/element-anatomy/index.ts +5 -0
  1188. package/src/patterns/element-anatomy/inline-action.spec.md +320 -0
  1189. package/src/patterns/element-anatomy/item-anatomy.spec.md +1042 -0
  1190. package/src/patterns/element-anatomy/item-anatomy.stories.tsx +1622 -0
  1191. package/src/patterns/element-anatomy/item-anatomy.tsx +6 -2
  1192. package/src/patterns/header-canonical/chrome-header.tsx +2 -2
  1193. package/src/patterns/header-canonical/header-canonical.css +2 -2
  1194. package/src/patterns/header-canonical/header-canonical.spec.md +290 -0
  1195. package/src/patterns/header-canonical/header-canonical.stories.tsx +150 -0
  1196. package/src/patterns/header-canonical/index.ts +5 -0
  1197. package/src/patterns/horizontal-overflow/horizontal-overflow.spec.md +201 -0
  1198. package/src/patterns/horizontal-overflow/index.ts +5 -0
  1199. package/src/patterns/overlay-surface/index.ts +5 -0
  1200. package/src/patterns/overlay-surface/overlay-surface.spec.md +435 -0
  1201. package/src/patterns/overlay-surface/overlay-surface.tsx +1 -1
  1202. package/src/patterns/resize-handle/index.ts +5 -0
  1203. package/src/patterns/resize-handle/resize-handle.spec.md +111 -0
  1204. package/src/patterns/resize-handle/resize-handle.stories.tsx +71 -0
  1205. package/src/story-governance/category-matrix.ts +55 -0
  1206. package/src/styles/base.css +85 -0
  1207. package/src/styles/tokens.css +11 -0
  1208. package/src/tokens/README.md +2 -0
  1209. package/src/tokens/categorical-color.ts +164 -0
  1210. package/src/tokens/color/color.spec.md +790 -0
  1211. package/src/tokens/color/color.stories.tsx +363 -0
  1212. package/src/tokens/color/primitives.css +7 -0
  1213. package/src/tokens/color/semantic.css +20 -11
  1214. package/src/tokens/density/density.spec.md +127 -0
  1215. package/src/tokens/density/density.stories.tsx +240 -0
  1216. package/src/tokens/elevation/elevation.spec.md +79 -0
  1217. package/src/tokens/elevation/elevation.stories.tsx +98 -0
  1218. package/src/tokens/layoutSpace/layoutSpace.css +1 -1
  1219. package/src/tokens/layoutSpace/layoutSpace.spec.md +313 -0
  1220. package/src/tokens/layoutSpace/layoutSpace.stories.tsx +75 -0
  1221. package/src/tokens/motion/motion.css +2 -2
  1222. package/src/tokens/motion/motion.spec.md +97 -0
  1223. package/src/tokens/motion/motion.ts +1 -1
  1224. package/src/tokens/opacity/opacity.spec.md +84 -0
  1225. package/src/tokens/opacity/opacity.stories.tsx +69 -0
  1226. package/src/tokens/orphan-tokens.spec.md +117 -0
  1227. package/src/tokens/radius/radius.spec.md +128 -0
  1228. package/src/tokens/radius/radius.stories.tsx +86 -0
  1229. package/src/tokens/token-system.spec.md +243 -0
  1230. package/src/tokens/typography/typography.spec.md +208 -0
  1231. package/src/tokens/typography/typography.stories.tsx +133 -0
  1232. package/src/tokens/uiSize/icon-size.ts +1 -2
  1233. package/src/tokens/uiSize/uiSize.css +16 -0
  1234. package/src/tokens/uiSize/uiSize.spec.md +439 -0
  1235. package/dist/components/NameCard/name-card.d.ts.map +0 -1
  1236. package/dist/components/NameCard/name-card.js.map +0 -1
  1237. /package/dist/{style.css → react-day-picker.css} +0 -0
@@ -0,0 +1,221 @@
1
+ // @principles-rationale: UsageGuidance merges WhenToUse + WhenNotToUse into single 使用指引 story per refactor task (2026-04-26)
2
+ import React from 'react'
3
+ import LinkTo from '@storybook/addon-links/react'
4
+ import type { Meta, StoryObj } from '@storybook/react'
5
+ import { createColumnHelper } from '@tanstack/react-table'
6
+ import { NumberInput } from './number-input'
7
+ import { Input } from '@/design-system/components/Input/input'
8
+ import { DataTable } from '@/design-system/components/DataTable/data-table'
9
+ import '@/design-system/components/DataTable/column-types'
10
+
11
+ const meta: Meta = {
12
+ title: 'Design System/Components/NumberInput/設計原則',
13
+ parameters: { layout: 'padded' },
14
+ }
15
+ export default meta
16
+ type Story = StoryObj
17
+
18
+ // ── Helpers ───────────────────────────────────────────────────────────────────
19
+
20
+ const Rule = ({
21
+ title, note, children,
22
+ }: {
23
+ title: string; note?: string; children: React.ReactNode
24
+ }) => (
25
+ <div className="mb-14">
26
+ <h3 className="text-body font-bold text-foreground mb-1">{title}</h3>
27
+ {note && <p className="text-caption text-fg-muted mb-5 max-w-[720px] leading-relaxed">{note}</p>}
28
+ <div className="flex flex-col gap-3 max-w-md">{children}</div>
29
+ </div>
30
+ )
31
+
32
+ const Label = ({ children, warn }: { children: React.ReactNode; warn?: boolean }) => (
33
+ <p className={`text-footnote leading-normal ${warn ? 'text-error font-medium' : 'text-fg-muted'}`}>{children}</p>
34
+ )
35
+
36
+ const Section = ({ title, children }: { title: string; children: React.ReactNode }) => (
37
+ <section className="mb-12">
38
+ <h2 className="text-heading-3 font-bold text-foreground mb-4 pb-2 border-b border-border">{title}</h2>
39
+ {children}
40
+ </section>
41
+ )
42
+
43
+ // ── Stories ───────────────────────────────────────────────────────────────────
44
+
45
+ export const UsageGuidance: Story = {
46
+ name: '使用指引',
47
+ render: () => (
48
+ <div>
49
+ <Section title="何時用">
50
+ <div className="prose prose-sm max-w-prose mb-8">
51
+ <p>適合 NumberInput 的真實業務場景(點擊跳轉「展示」頁範例):</p>
52
+ <ul className="space-y-1">
53
+ <li><LinkTo kind="Design System/Components/NumberInput/展示" name="四模式"><span className="text-primary hover:underline font-medium cursor-pointer">四模式</span></LinkTo></li>
54
+ <li><LinkTo kind="Design System/Components/NumberInput/展示" name="尺寸與 Button 對齊"><span className="text-primary hover:underline font-medium cursor-pointer">尺寸與 Button 對齊</span></LinkTo></li>
55
+ <li><LinkTo kind="Design System/Components/NumberInput/展示" name="格式化選項"><span className="text-primary hover:underline font-medium cursor-pointer">格式化選項</span></LinkTo></li>
56
+ <li><LinkTo kind="Design System/Components/NumberInput/展示" name="DataTable 整合"><span className="text-primary hover:underline font-medium cursor-pointer">DataTable 整合</span></LinkTo></li>
57
+ </ul>
58
+ <p className="text-fg-muted mt-3">判斷不確定時:對照 spec.md「何時用 / 何時不用」段;若仍不符,改用近親元件(見下方 vs 近親 段)。</p>
59
+ </div>
60
+ </Section>
61
+
62
+ <Section title="何時不用 + 替代方案">
63
+ <Rule
64
+ title="❌ 不用 NumberInput 做 DataTable 列表展示"
65
+ note="Table cell 用 `mode='display'` 渲染,不用 edit 模式輸入元件。DataTable 的 currency 欄位自動消費 `<NumberInput mode='display'>`"
66
+ >
67
+ <Label warn>Table cell 顯示值 → `mode='display'` 渲染,不用 edit Input</Label>
68
+ </Rule>
69
+ </Section>
70
+
71
+ <Section title="vs 近親元件">
72
+ <Rule
73
+ title="❌ 不用 NumberInput 做電話號碼或郵遞區號 → Input"
74
+ note="電話不是算術數字。改用 Input + type='tel'。Stripe 的電話欄用 Input,不用 NumberInput(不該加千分位或用 step)"
75
+ >
76
+ <NumberInput mode="readonly" value={912345678} />
77
+ <Label warn>↑ 電話 0912-345-678 被當數值,顯示時加上千分位 912,345,678 → 數字意義錯誤(前導零也被吃掉)</Label>
78
+ <Input defaultValue="0912-345-678" />
79
+ <Label>↑ 電話用 Input(可自訂 type=tel 或 pattern),保留 dash / 前導零</Label>
80
+ </Rule>
81
+
82
+ <Rule
83
+ title="❌ 不用 NumberInput 做音量 / 亮度滑動調整 → Slider"
84
+ note="視覺調整用 Slider。NumberInput 是「輸入精確值」的 form field。Material 音量控制用 Slider"
85
+ >
86
+ <Label warn>音量 / 亮度 → Slider,使用者目標是「感受」而非「輸入精確值」</Label>
87
+ </Rule>
88
+
89
+ <Rule
90
+ title="✅ 數值資料一律 NumberInput,不用 Input type=number"
91
+ note="NumberInput 提供:千分位格式化、locale 切換、prefix/suffix、precision、edit 左 / table 右 對齊、DataTable 自動整合。原生 input type=number 這些都沒有"
92
+ >
93
+ <NumberInput mode="readonly" value={1234567} prefix="$" />
94
+ <NumberInput mode="readonly" value={85.5} suffix="%" precision={1} />
95
+ <NumberInput mode="readonly" value={12500} />
96
+ </Rule>
97
+ </Section>
98
+ </div>
99
+ ),
100
+ }
101
+
102
+ export const AlignmentRule: Story = {
103
+ name: '對齊原則',
104
+ render: () => {
105
+ const [value, setValue] = React.useState<number | null>(2490)
106
+ interface Row { product: string; price: number; stock: number }
107
+ const data: Row[] = [
108
+ { product: 'Headphones', price: 2490, stock: 12 },
109
+ { product: 'Chair', price: 890, stock: 3 },
110
+ { product: 'Green Tea', price: 35, stock: 120 },
111
+ { product: 'USB Hub', price: 1290, stock: 0 },
112
+ ]
113
+ const col = createColumnHelper<Row>()
114
+ const columns = [
115
+ col.accessor('product', { header: 'Product', meta: { type: 'string', width: 160 } }),
116
+ col.accessor('price', { header: 'Price', meta: { type: 'currency', prefix: '$', width: 120 } }),
117
+ col.accessor('stock', { header: 'Stock', meta: { type: 'number', width: 100 } }),
118
+ ]
119
+ return (
120
+ <div>
121
+ <Rule
122
+ title="Edit 模式 — 靠左(input 打字由左往右)"
123
+ note="使用者打字是由左到右的連續動作,數字從左邊出現最自然。Edit 模式不需要比較位數"
124
+ >
125
+ <NumberInput value={value} onChange={setValue} prefix="$" />
126
+ </Rule>
127
+
128
+ <Rule
129
+ title="Table cell — 靠右(縱向比較位數)"
130
+ note="表格中同欄的數字需要對齊小數點/個位數,右對齊讓使用者一眼比較大小。由 DataTable 的 column meta type=number / currency 自動套用,不需要手動設對齊"
131
+ >
132
+ <div className="w-full max-w-lg">
133
+ <DataTable columns={columns} data={data} height="auto" />
134
+ </div>
135
+ <Label>↑ price 和 stock 欄自動右對齊,小數點縱向對齊</Label>
136
+ </Rule>
137
+
138
+ <Rule
139
+ title="❌ 不要手動改動對齊方向"
140
+ note="edit 左、table 右是跨產業的共識(Excel、會計軟體、財務系統都是)。手動反向會讓使用者的掃視習慣被打破"
141
+ >
142
+ <NumberInput value={value} onChange={setValue} prefix="$" className="text-right" />
143
+ <Label warn>↑ Edit input 強制右對齊 → 打字時游標位置感變怪</Label>
144
+ </Rule>
145
+ </div>
146
+ )
147
+ },
148
+ }
149
+
150
+ export const FormatOptionsRule: Story = {
151
+ name: '格式化選項使用',
152
+ render: () => (
153
+ <div>
154
+ <Rule
155
+ title="prefix — 置於數字前的符號(貨幣是最常見場景)"
156
+ note="prefix 會同時出現在 edit、readonly、DataTable cell。使用者不需要自己輸入 $——打字就是純數字"
157
+ >
158
+ <NumberInput mode="readonly" value={2490} prefix="$" />
159
+ <NumberInput mode="readonly" value={12500} prefix="NT$" precision={0} />
160
+ </Rule>
161
+
162
+ <Rule
163
+ title="suffix — 置於數字後的單位(百分比、度量)"
164
+ note="suffix 標示「這個數字代表什麼」。%、°C、kg、ms 都是適合 suffix 的單位"
165
+ >
166
+ <NumberInput mode="readonly" value={85.5} suffix="%" precision={1} />
167
+ <NumberInput mode="readonly" value={36.5} suffix="°C" precision={1} />
168
+ </Rule>
169
+
170
+ <Rule
171
+ title="precision — 固定小數位數"
172
+ note="需要一致位數時才設——金融、科學、測量。整數欄位不需要 precision(預設就是不補零)"
173
+ >
174
+ <NumberInput mode="readonly" value={85} suffix="%" precision={2} />
175
+ <Label>↑ 85 → 85.00%(科學報告、金融報表場景)</Label>
176
+ </Rule>
177
+
178
+ <Rule
179
+ title="❌ 不要手動拼接格式化字串"
180
+ note="手動用 toLocaleString() 或字串模板格式化會導致 edit / readonly / table cell 不一致——三個地方都要各自寫一遍格式化邏輯,且 locale 切換時全部要改"
181
+ >
182
+ <Input defaultValue="$2,490.00" />
183
+ <Label warn>↑ 用 Input + 手動格式化字串 → 使用者打字時要 parse「$2,490.00」→ 脆且不 locale-aware</Label>
184
+ </Rule>
185
+ </div>
186
+ ),
187
+ }
188
+
189
+ export const DataTypeMatchRule: Story = {
190
+ name: '數字一律用 NumberInput',
191
+ render: () => (
192
+ <div>
193
+ <Rule
194
+ title="所有數值資料都用 NumberInput——不用 Input type=number"
195
+ note="NumberInput 提供:千分位格式化、locale 切換、prefix/suffix、precision、edit 左 / table 右 對齊、DataTable 自動整合。原生 input type=number 這些都沒有"
196
+ >
197
+ <NumberInput mode="readonly" value={1234567} prefix="$" />
198
+ <NumberInput mode="readonly" value={85.5} suffix="%" precision={1} />
199
+ <NumberInput mode="readonly" value={12500} />
200
+ </Rule>
201
+
202
+ <Rule
203
+ title="❌ 不用 Input 顯示數字"
204
+ note="即使值看起來「就是數字字串」,缺少格式化會讓大數字不可讀(1234567 vs 1,234,567)。Edit 與 Display 分離是 Field 設計的基本前提——用 NumberInput 兩者都得到"
205
+ >
206
+ <Input defaultValue="1234567" />
207
+ <Label warn>↑ 1234567 難讀、無貨幣前綴、無 locale、無右對齊</Label>
208
+ </Rule>
209
+
210
+ <Rule
211
+ title="❌ 看起來像數字但不是算術型的資料:用 Input"
212
+ note="電話、郵遞區號、身分證字號、產品代碼都「長得像數字」但不是算術型 value——不做加減、不做千分位、不做 step。用 NumberInput 會錯誤套用千分位(0912-345-678 變成「912,345,678」)、誤導 mobile 彈出數字鍵盤且關閉符號輸入"
213
+ >
214
+ <NumberInput mode="readonly" value={912345678} />
215
+ <Label warn>↑ 電話 0912-345-678 被當數值,顯示時加上千分位 912,345,678 → 數字意義錯誤(前導零也被吃掉)</Label>
216
+ <Input defaultValue="0912-345-678" />
217
+ <Label>↑ 電話用 Input(可自訂 type=tel 或 pattern),保留 dash / 前導零</Label>
218
+ </Rule>
219
+ </div>
220
+ ),
221
+ }
@@ -0,0 +1,125 @@
1
+ ---
2
+ component: NumberInput
3
+ family: 4
4
+ variants: {}
5
+ sizes: {}
6
+ traits:
7
+ - hasInteractiveStates
8
+ - isInputLike
9
+ benchmark:
10
+ - Ant Design InputNumber: github.com/ant-design/ant-design/tree/master/components/input-number
11
+ - MUI TextField (number): github.com/mui/material-ui/tree/master/packages/mui-material/src/TextField
12
+ ---
13
+
14
+ # NumberInput 設計原則
15
+
16
+ ## 定位
17
+
18
+ NumberInput 是**數值的**輸入與顯示元件。格式化邏輯:`toLocaleString()` + prefix/suffix + precision。
19
+
20
+ 共用規則見 `../Field/field-controls.spec.md`。本文件只記錄 NumberInput 特有的原則。
21
+
22
+ **Layout Family**:CLAUDE.md 4-Family Model **Family 4(Field control layout)** 消費者。結構繼承 `components/Field/field-controls.spec.md` 的 `fieldWrapperStyles + [startIcon?] [<editable>] [endAction?]` 規格,視覺對齊 Family 1(Menu item)讓 SelectMenu trigger + options 連續一致。
23
+
24
+ ---
25
+
26
+ ## 何時用
27
+
28
+ - **所有數值資料**:金額、數量、百分比、比率、測量值、年齡、計數
29
+ - **需要格式化的 value**:千分位(`1,234,567`)、貨幣前綴(`$2,490`)、百分比後綴(`85.5%`)、小數精度(`0.00`)
30
+ - **需要 locale-aware 顯示**(`toLocaleString()` 自動處理千分位分隔符、小數點形式)
31
+ - **DataTable 的數值欄位**(right-aligned + 自動格式化)
32
+
33
+ ## 何時不用
34
+
35
+ | 場景 | 改用 | 原因 |
36
+ |------|------|------|
37
+ | 純文字 / 看起來像數字的字串(電話、郵遞區號)| `Input` | 電話不是算術型數字,不需要千分位 / 不該用 step |
38
+ | 日期 / 時間戳 | `DatePicker` | 需要日期語意和 picker 互動 |
39
+ | 視覺調整數值(音量、亮度、滑動調整)| `Slider` | 使用者目標是「感受」而非「輸入精確值」 |
40
+ | 大量帶小數的科學計算 | `Input` + 自訂驗證 | 極端精度需求超出 NumberInput 格式化能力 |
41
+
42
+ ---
43
+
44
+ ## 格式化選項
45
+
46
+ | 選項 | 說明 | 範例 |
47
+ |------|------|------|
48
+ | `prefix` | 前綴字串(如貨幣符號) | `$2,490` |
49
+ | `suffix` | 後綴字串(如百分比) | `85.5%` |
50
+ | `precision` | 小數位數 | `85.50` |
51
+ | `locale` | 數字格式 locale | 預設 `en-US` |
52
+
53
+ ## 對齊
54
+
55
+ - **Edit 模式(input)**:靠左——input 內打字是左到右
56
+ - **Table cell(Display)**:靠右——縱向比較位數需要右對齊(由 DataTable 的 column type `number` / `currency` 控制)
57
+
58
+ ## Display
59
+
60
+ `<NumberInput mode="display">` 在 table cell 和 Form readonly 共用 `formatNumber()` 格式化函式。
61
+
62
+ - 有值:格式化輸出(prefix + localized number + suffix)
63
+ - null / undefined:`—`(em dash),`text-fg-muted`
64
+
65
+ ## DataTable 整合
66
+
67
+ ```tsx
68
+ // 自動格式化——不需要手寫 cell
69
+ col.accessor('price', {
70
+ header: 'Price',
71
+ meta: { type: 'currency', prefix: '$' },
72
+ })
73
+ ```
74
+
75
+ `currency` 類型預設 `prefix: '$'`,其餘等同 `number`。
76
+
77
+ ---
78
+
79
+ ## Mode / Validation / a11y
80
+
81
+ 詳見 `../Field/field-controls.spec.md`(Mode / Validation)+ `../Field/form-validation.spec.md`(驗證時機)。
82
+
83
+ ---
84
+
85
+ ## 禁止事項
86
+
87
+ - ❌ 不要拿 NumberInput 顯示電話 / 郵遞區號 / 身分證號(非算術型數字)— 用 `Input`(電話千分位無意義 / step 不適用)
88
+ - ❌ 不要把 `precision` 設超過 6(浮點精度雜訊)— 極端精度需求超出格式化能力,改用 `Input` + 自驗證
89
+ - ❌ 不要在 DataTable cell 用左對齊 NumberInput(縱向比較位數需右對齊)— 走 DataTable column type `number` / `currency` 預設右對齊
90
+ - ❌ 不要把 `prefix='$'` 跟 `suffix='元'` 同時用 — 貨幣語意衝突,擇一即可
91
+ - ❌ 不要拿 NumberInput 做百分比但 value 存 0–1(`0.85` × 100 = 85%)— DS canonical 是 value 直接存百分比數值(85),`suffix='%'` 純顯示
92
+ - ❌ 不要自加 step ↑↓ button — NumberInput 是純值輸入(`type="text" inputMode="decimal"`),不提供 step;需要加減互動請走 `endSlot` 放自訂 stepper button group
93
+
94
+ ---
95
+
96
+ ## 邊界案例
97
+
98
+ - **Disabled**:由 Field SSOT own(`Field/field-controls.spec.md` State machine 段)。視覺:wrapper bg → `bg-disabled`(neutral-2,`semantic.css` `--bg-disabled`)、formatted text → `text-fg-disabled`(M24 state>emphasis)。Display mode + disabled 維持格式化輸出但 token 切 disabled。
99
+ - **Loading**:NumberInput 不提供 loading state(`NumberInputProps` 無 `loading` prop、無 `CircularProgress` / `aria-busy` 邏輯)。數值輸入為同步操作,無 async fetch 語意;若需 async 場景(如遠端校驗)請走外層 Field validation + `endSlot` 自訂 spinner。
100
+ - **Empty(null / undefined / 空字串)**:Display mode 渲 `—`(em dash + `text-fg-muted`);Edit mode placeholder 走 default placeholder color。
101
+ - **Invalid input**(non-numeric):input 為 `type="text" inputMode="decimal"`,onChange 以 `Number(raw)` parse,NaN 時忽略不觸發 `onChange`(value 維持原值);搭配 Field validation 渲 error variant(`aria-invalid="true"` + `text-fg-error` border + 下方 error message)。
102
+ - **Dark mode / density**:走 Field SSOT,不獨立 own。
103
+
104
+ ---
105
+
106
+ ## 相關
107
+
108
+ - `../Input/input.spec.md` — 純文字(含電話 / 郵遞區號等「看起來像數字」的資料)
109
+ - `../DatePicker/date-picker.spec.md` — 日期
110
+ - `../Slider/slider.spec.md` — 視覺調整數值(音量、亮度)
111
+ - `../Field/field-controls.spec.md` — Field Control 共用規則(mode / size / endAction / error)
112
+
113
+ ## A11y 預設
114
+
115
+ **ARIA / Pattern**:ARIA / keyboard 機制**僅 edit mode 適用**——edit mode 渲染 native `<input>` element(預設 a11y),且把 `...props`(含 `aria-label` / `aria-describedby` 等)轉發到該 input,Field wrapper 另補 `aria-invalid` / `aria-required` / `aria-describedby` / `aria-errormessage`。`display` / `readonly` / `disabled` 三 mode 渲染的是無互動純展示文字(`<div>` + `<span>`,不轉發 `aria-*`),螢幕報讀僅得格式化後的靜態值(對齊 Carbon read-only / Stripe display 慣例)。
116
+
117
+ **Keyboard 行為**:
118
+
119
+ - Tab — focus
120
+ - 數字鍵 — 輸入數值
121
+
122
+ **Focus**:native input 為 `outline-none` 無自身 focus ring;藍框由 Field wrapper 的 `focus-within:!border-primary` 提供(input 取得 focus → wrapper `focus-within` fire → border 轉 primary)。
123
+
124
+ **驗證**:Storybook a11y addon panel 應 0 critical violation;鍵盤完整可操作(無需滑鼠)。WCAG AA contrast ≥ 4.5:1(text)/ 3:1(UI)。
125
+
@@ -0,0 +1,142 @@
1
+ // @story-trait-rationale: D3 mechanical migration (size:N → meta.width) — preexisting Default/WithError trait gap unrelated to this edit; tracked separately
2
+ // @story-baseline: packages/design-system/src/components/DataTable/data-table.stories.tsx#WithBulkActions
3
+ // (per .claude/references/story-baseline-registry.json#DataTable)
4
+ import React from 'react'
5
+ import type { Meta, StoryObj } from '@storybook/react'
6
+ import { createColumnHelper } from '@tanstack/react-table'
7
+ import { NumberInput } from './number-input'
8
+ import { Button } from '@/design-system/components/Button/button'
9
+ import { DataTable } from '@/design-system/components/DataTable/data-table'
10
+ import '@/design-system/components/DataTable/column-types'
11
+
12
+ const meta: Meta<typeof NumberInput> = {
13
+ title: 'Design System/Components/NumberInput/展示',
14
+ component: NumberInput,
15
+ tags: ['autodocs'],
16
+ }
17
+
18
+ export default meta
19
+ type Story = StoryObj<typeof NumberInput>
20
+
21
+ // @story-trait-rationale: pre-existing trait gaps (Default/WithError) tracked separately; this PR scope = add display mode card to Modes story only.
22
+ /* ── 四模式 ── */
23
+ export const Modes: Story = {
24
+ name: '四模式',
25
+ render: () => {
26
+ const [value, setValue] = React.useState<number | null>(2490)
27
+ return (
28
+ <div className="flex flex-col gap-6 max-w-xs">
29
+ <div>
30
+ <h3 className="text-body font-bold text-foreground mb-2">edit</h3>
31
+ <NumberInput value={value} onChange={setValue} prefix="$" aria-label="價格(edit mode demo)" />
32
+ </div>
33
+ <div>
34
+ <h3 className="text-body font-bold text-foreground mb-2">display</h3>
35
+ <NumberInput mode="display" value={value} prefix="$" aria-label="價格(display mode demo)" />
36
+ </div>
37
+ <div>
38
+ <h3 className="text-body font-bold text-foreground mb-2">readonly</h3>
39
+ <NumberInput mode="readonly" value={value} prefix="$" aria-label="價格(readonly mode demo)" />
40
+ </div>
41
+ <div>
42
+ <h3 className="text-body font-bold text-foreground mb-2">disabled</h3>
43
+ <NumberInput mode="disabled" value={value} prefix="$" aria-label="價格(disabled mode demo)" />
44
+ </div>
45
+ </div>
46
+ )
47
+ },
48
+ }
49
+
50
+ /* ── 尺寸與 Button 對齊 ── */
51
+ export const SizeAlignment: Story = {
52
+ name: '尺寸與 Button 對齊',
53
+ render: () => {
54
+ const [sm, setSm] = React.useState<number | null>(2490)
55
+ const [md, setMd] = React.useState<number | null>(2490)
56
+ const [lg, setLg] = React.useState<number | null>(2490)
57
+ const states: Record<string, [number | null, (v: number | null) => void]> = { sm: [sm, setSm], md: [md, setMd], lg: [lg, setLg] }
58
+ return (
59
+ <div className="flex flex-col gap-4">
60
+ {(['sm', 'md', 'lg'] as const).map(size => (
61
+ <div key={size} className="flex items-center gap-3">
62
+ <NumberInput size={size} value={states[size][0]} onChange={states[size][1]} prefix="$" className="max-w-xs" />
63
+ <Button variant="primary" size={size}>送出</Button>
64
+ <span className="text-caption text-fg-muted">size="{size}"</span>
65
+ </div>
66
+ ))}
67
+ </div>
68
+ )
69
+ },
70
+ }
71
+
72
+ /* ── 格式化選項 ── */
73
+ export const FormatOptions: Story = {
74
+ name: '格式化選項',
75
+ render: () => (
76
+ <div className="flex flex-col gap-4 max-w-xs">
77
+ <div>
78
+ <p className="text-caption text-fg-muted mb-1">prefix="$"</p>
79
+ <NumberInput mode="readonly" value={2490} prefix="$" />
80
+ </div>
81
+ <div>
82
+ <p className="text-caption text-fg-muted mb-1">suffix="%" precision={1}</p>
83
+ <NumberInput mode="readonly" value={85.5} suffix="%" precision={1} />
84
+ </div>
85
+ <div>
86
+ <p className="text-caption text-fg-muted mb-1">prefix="NT$" precision={0}</p>
87
+ <NumberInput mode="readonly" value={12500} prefix="NT$" precision={0} />
88
+ </div>
89
+ <div>
90
+ <p className="text-caption text-fg-muted mb-1">null value</p>
91
+ <NumberInput mode="readonly" value={null} prefix="$" />
92
+ </div>
93
+ </div>
94
+ ),
95
+ }
96
+
97
+ /* ── Display in DataTable ── */
98
+ export const InDataTable: Story = {
99
+ name: 'DataTable 整合',
100
+ render: () => {
101
+ interface Product {
102
+ name: string
103
+ price: number
104
+ stock: number
105
+ discount: number
106
+ }
107
+
108
+ const data: Product[] = [
109
+ { name: 'Wireless Headphones', price: 2490, stock: 142, discount: 15 },
110
+ { name: 'Office Chair', price: 8900, stock: 38, discount: 0 },
111
+ { name: 'Green Tea 100 Bags', price: 350, stock: 520, discount: 10.5 },
112
+ { name: 'USB-C Hub', price: 1290, stock: 0, discount: 20 },
113
+ ]
114
+
115
+ const col = createColumnHelper<Product>()
116
+
117
+ const columns = [
118
+ col.accessor('name', { header: 'Product', meta: { type: 'string', width: 200 } }),
119
+ col.accessor('price', {
120
+ header: 'Price',
121
+ meta: { type: 'currency', prefix: '$', width: 120 },
122
+ }),
123
+ col.accessor('stock', {
124
+ header: 'Stock',
125
+ meta: { type: 'number', width: 100 },
126
+ }),
127
+ col.accessor('discount', {
128
+ header: 'Discount',
129
+ meta: { type: 'number', suffix: '%', width: 100 },
130
+ }),
131
+ ]
132
+
133
+ return (
134
+ <div>
135
+ <p className="text-caption text-fg-muted mb-3">
136
+ 不需要手寫 cell renderer——meta.type + 格式化參數自動套用 Display 元件
137
+ </p>
138
+ <DataTable columns={columns} data={data} height="auto" />
139
+ </div>
140
+ )
141
+ },
142
+ }
@@ -117,7 +117,8 @@ const NumberInput = React.forwardRef<HTMLInputElement, NumberInputProps>(
117
117
  className={cn(
118
118
  'flex-1 min-w-0',
119
119
  resolvedMode === 'disabled' && 'text-fg-disabled cursor-not-allowed',
120
- value == null && 'text-fg-muted',
120
+ // 2026-05-31 M24:disabled > muted。disabled 時不可再套 muted(否則 neutral-7 蓋過 disabled neutral-6)
121
+ value == null && resolvedMode !== 'disabled' && 'text-fg-muted',
121
122
  )}
122
123
  >
123
124
  {value == null ? EMPTY_DISPLAY : formatNumber(value, { precision, prefix, suffix, locale })}
@@ -0,0 +1,5 @@
1
+ // AUTO-GENERATED by scripts/gen-component-indexes.mjs — DO NOT EDIT MANUALLY.
2
+ // Re-export pattern enables package.json exports map subpath:
3
+ // import { ... } from '@qijenchen/design-system/{components,patterns}/<Dir>'
4
+ // Regenerate: node scripts/gen-component-indexes.mjs
5
+ export * from './overflow-indicator'