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

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 (1255) 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 +8 -20
  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 +9 -7
  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.d.ts.map +1 -1
  96. package/dist/components/Checkbox/checkbox.js +17 -13
  97. package/dist/components/Checkbox/checkbox.js.map +1 -1
  98. package/dist/components/Checkbox/index.d.ts +2 -0
  99. package/dist/components/Checkbox/index.d.ts.map +1 -0
  100. package/dist/components/Checkbox/index.js +7 -0
  101. package/dist/components/Checkbox/index.js.map +1 -0
  102. package/dist/components/Chip/chip.d.ts +4 -4
  103. package/dist/components/Chip/chip.js +1 -1
  104. package/dist/components/Chip/chip.js.map +1 -1
  105. package/dist/components/Chip/index.d.ts +2 -0
  106. package/dist/components/Chip/index.d.ts.map +1 -0
  107. package/dist/components/Chip/index.js +8 -0
  108. package/dist/components/Chip/index.js.map +1 -0
  109. package/dist/components/CircularProgress/circular-progress.d.ts +1 -2
  110. package/dist/components/CircularProgress/circular-progress.d.ts.map +1 -1
  111. package/dist/components/CircularProgress/circular-progress.js +2 -2
  112. package/dist/components/CircularProgress/circular-progress.js.map +1 -1
  113. package/dist/components/CircularProgress/index.d.ts +2 -0
  114. package/dist/components/CircularProgress/index.d.ts.map +1 -0
  115. package/dist/components/CircularProgress/index.js +6 -0
  116. package/dist/components/CircularProgress/index.js.map +1 -0
  117. package/dist/components/Coachmark/coachmark-story-helpers.d.ts +22 -0
  118. package/dist/components/Coachmark/coachmark-story-helpers.d.ts.map +1 -0
  119. package/dist/components/Coachmark/coachmark.d.ts.map +1 -1
  120. package/dist/components/Coachmark/coachmark.js +7 -3
  121. package/dist/components/Coachmark/coachmark.js.map +1 -1
  122. package/dist/components/Coachmark/index.d.ts +2 -0
  123. package/dist/components/Coachmark/index.d.ts.map +1 -0
  124. package/dist/components/Coachmark/index.js +6 -0
  125. package/dist/components/Coachmark/index.js.map +1 -0
  126. package/dist/components/Combobox/combobox.d.ts +17 -8
  127. package/dist/components/Combobox/combobox.d.ts.map +1 -1
  128. package/dist/components/Combobox/combobox.js +46 -18
  129. package/dist/components/Combobox/combobox.js.map +1 -1
  130. package/dist/components/Combobox/index.d.ts +2 -0
  131. package/dist/components/Combobox/index.d.ts.map +1 -0
  132. package/dist/components/Combobox/index.js +6 -0
  133. package/dist/components/Combobox/index.js.map +1 -0
  134. package/dist/components/Command/index.d.ts +2 -0
  135. package/dist/components/Command/index.d.ts.map +1 -0
  136. package/dist/components/Command/index.js +14 -0
  137. package/dist/components/Command/index.js.map +1 -0
  138. package/dist/components/DataTable/cell-registry.d.ts.map +1 -1
  139. package/dist/components/DataTable/cell-registry.js +4 -3
  140. package/dist/components/DataTable/cell-registry.js.map +1 -1
  141. package/dist/components/DataTable/data-table.d.ts +2 -2
  142. package/dist/components/DataTable/data-table.d.ts.map +1 -1
  143. package/dist/components/DataTable/data-table.js +12 -5
  144. package/dist/components/DataTable/data-table.js.map +1 -1
  145. package/dist/components/DataTable/filter-operators.d.ts +1 -1
  146. package/dist/components/DataTable/filter-tree.d.ts +1 -1
  147. package/dist/components/DataTable/index.d.ts +2 -0
  148. package/dist/components/DataTable/index.d.ts.map +1 -0
  149. package/dist/components/DataTable/index.js +8 -0
  150. package/dist/components/DataTable/index.js.map +1 -0
  151. package/dist/components/DateGrid/date-grid.d.ts +14 -14
  152. package/dist/components/DateGrid/date-grid.js +1 -1
  153. package/dist/components/DateGrid/date-grid.js.map +1 -1
  154. package/dist/components/DateGrid/index.d.ts +2 -0
  155. package/dist/components/DateGrid/index.d.ts.map +1 -0
  156. package/dist/components/DateGrid/index.js +6 -0
  157. package/dist/components/DateGrid/index.js.map +1 -0
  158. package/dist/components/DatePicker/date-picker.d.ts +2 -2
  159. package/dist/components/DatePicker/date-picker.d.ts.map +1 -1
  160. package/dist/components/DatePicker/date-picker.js +23 -14
  161. package/dist/components/DatePicker/date-picker.js.map +1 -1
  162. package/dist/components/DatePicker/index.d.ts +2 -0
  163. package/dist/components/DatePicker/index.d.ts.map +1 -0
  164. package/dist/components/DatePicker/index.js +8 -0
  165. package/dist/components/DatePicker/index.js.map +1 -0
  166. package/dist/components/DescriptionList/description-list.d.ts +2 -2
  167. package/dist/components/DescriptionList/description-list.js +2 -1
  168. package/dist/components/DescriptionList/description-list.js.map +1 -1
  169. package/dist/components/DescriptionList/index.d.ts +2 -0
  170. package/dist/components/DescriptionList/index.d.ts.map +1 -0
  171. package/dist/components/DescriptionList/index.js +7 -0
  172. package/dist/components/DescriptionList/index.js.map +1 -0
  173. package/dist/components/Dialog/dialog.d.ts +1 -1
  174. package/dist/components/Dialog/dialog.js.map +1 -1
  175. package/dist/components/Dialog/index.d.ts +2 -0
  176. package/dist/components/Dialog/index.d.ts.map +1 -0
  177. package/dist/components/Dialog/index.js +16 -0
  178. package/dist/components/Dialog/index.js.map +1 -0
  179. package/dist/components/DropdownMenu/dropdown-menu.d.ts +4 -3
  180. package/dist/components/DropdownMenu/dropdown-menu.d.ts.map +1 -1
  181. package/dist/components/DropdownMenu/dropdown-menu.js +4 -3
  182. package/dist/components/DropdownMenu/dropdown-menu.js.map +1 -1
  183. package/dist/components/DropdownMenu/index.d.ts +2 -0
  184. package/dist/components/DropdownMenu/index.d.ts.map +1 -0
  185. package/dist/components/DropdownMenu/index.js +21 -0
  186. package/dist/components/DropdownMenu/index.js.map +1 -0
  187. package/dist/components/Empty/empty.d.ts +8 -2
  188. package/dist/components/Empty/empty.d.ts.map +1 -1
  189. package/dist/components/Empty/empty.js +6 -6
  190. package/dist/components/Empty/empty.js.map +1 -1
  191. package/dist/components/Empty/index.d.ts +2 -0
  192. package/dist/components/Empty/index.d.ts.map +1 -0
  193. package/dist/components/Empty/index.js +6 -0
  194. package/dist/components/Empty/index.js.map +1 -0
  195. package/dist/components/Field/field-context.d.ts +49 -0
  196. package/dist/components/Field/field-context.d.ts.map +1 -1
  197. package/dist/components/Field/field-context.js +42 -0
  198. package/dist/components/Field/field-context.js.map +1 -1
  199. package/dist/components/Field/field-types.js.map +1 -1
  200. package/dist/components/Field/field.d.ts +2 -2
  201. package/dist/components/Field/field.js.map +1 -1
  202. package/dist/components/Field/index.d.ts +2 -0
  203. package/dist/components/Field/index.d.ts.map +1 -0
  204. package/dist/components/Field/index.js +10 -0
  205. package/dist/components/Field/index.js.map +1 -0
  206. package/dist/components/FieldControlGroup/field-control-group.d.ts +6 -6
  207. package/dist/components/FieldControlGroup/field-control-group.d.ts.map +1 -1
  208. package/dist/components/FieldControlGroup/field-control-group.js.map +1 -1
  209. package/dist/components/FieldControlGroup/index.d.ts +2 -0
  210. package/dist/components/FieldControlGroup/index.d.ts.map +1 -0
  211. package/dist/components/FieldControlGroup/index.js +6 -0
  212. package/dist/components/FieldControlGroup/index.js.map +1 -0
  213. package/dist/components/FileItem/file-item.d.ts +12 -2
  214. package/dist/components/FileItem/file-item.d.ts.map +1 -1
  215. package/dist/components/FileItem/file-item.js +20 -6
  216. package/dist/components/FileItem/file-item.js.map +1 -1
  217. package/dist/components/FileItem/index.d.ts +2 -0
  218. package/dist/components/FileItem/index.d.ts.map +1 -0
  219. package/dist/components/FileItem/index.js +6 -0
  220. package/dist/components/FileItem/index.js.map +1 -0
  221. package/dist/components/FileUpload/file-upload.d.ts +24 -12
  222. package/dist/components/FileUpload/file-upload.d.ts.map +1 -1
  223. package/dist/components/FileUpload/file-upload.js +57 -17
  224. package/dist/components/FileUpload/file-upload.js.map +1 -1
  225. package/dist/components/FileUpload/index.d.ts +2 -0
  226. package/dist/components/FileUpload/index.d.ts.map +1 -0
  227. package/dist/components/FileUpload/index.js +6 -0
  228. package/dist/components/FileUpload/index.js.map +1 -0
  229. package/dist/components/FileViewer/file-viewer.d.ts +1 -1
  230. package/dist/components/FileViewer/file-viewer.d.ts.map +1 -1
  231. package/dist/components/FileViewer/file-viewer.js +2 -3
  232. package/dist/components/FileViewer/file-viewer.js.map +1 -1
  233. package/dist/components/FileViewer/index.d.ts +2 -0
  234. package/dist/components/FileViewer/index.d.ts.map +1 -0
  235. package/dist/components/FileViewer/index.js +7 -0
  236. package/dist/components/FileViewer/index.js.map +1 -0
  237. package/dist/components/HoverCard/hover-card.d.ts +2 -2
  238. package/dist/components/HoverCard/hover-card.js +2 -2
  239. package/dist/components/HoverCard/hover-card.js.map +1 -1
  240. package/dist/components/HoverCard/index.d.ts +2 -0
  241. package/dist/components/HoverCard/index.d.ts.map +1 -0
  242. package/dist/components/HoverCard/index.js +8 -0
  243. package/dist/components/HoverCard/index.js.map +1 -0
  244. package/dist/components/Input/index.d.ts +2 -0
  245. package/dist/components/Input/index.d.ts.map +1 -0
  246. package/dist/components/Input/index.js +6 -0
  247. package/dist/components/Input/index.js.map +1 -0
  248. package/dist/components/Input/input.d.ts +8 -5
  249. package/dist/components/Input/input.d.ts.map +1 -1
  250. package/dist/components/Input/input.js +10 -8
  251. package/dist/components/Input/input.js.map +1 -1
  252. package/dist/components/LinkInput/index.d.ts +2 -0
  253. package/dist/components/LinkInput/index.d.ts.map +1 -0
  254. package/dist/components/LinkInput/index.js +6 -0
  255. package/dist/components/LinkInput/index.js.map +1 -0
  256. package/dist/components/LinkInput/link-input.d.ts +2 -2
  257. package/dist/components/LinkInput/link-input.d.ts.map +1 -1
  258. package/dist/components/LinkInput/link-input.js +8 -8
  259. package/dist/components/LinkInput/link-input.js.map +1 -1
  260. package/dist/components/Menu/index.d.ts +2 -0
  261. package/dist/components/Menu/index.d.ts.map +1 -0
  262. package/dist/components/Menu/index.js +9 -0
  263. package/dist/components/Menu/index.js.map +1 -0
  264. package/dist/components/Menu/menu-item.d.ts +2 -2
  265. package/dist/components/Menu/menu-item.d.ts.map +1 -1
  266. package/dist/components/Menu/menu-item.js +2 -1
  267. package/dist/components/Menu/menu-item.js.map +1 -1
  268. package/dist/components/Notice/index.d.ts +2 -0
  269. package/dist/components/Notice/index.d.ts.map +1 -0
  270. package/dist/components/Notice/index.js +8 -0
  271. package/dist/components/Notice/index.js.map +1 -0
  272. package/dist/components/Notice/notice.d.ts +2 -2
  273. package/dist/components/Notice/notice.d.ts.map +1 -1
  274. package/dist/components/Notice/notice.js +4 -3
  275. package/dist/components/Notice/notice.js.map +1 -1
  276. package/dist/components/NumberInput/index.d.ts +2 -0
  277. package/dist/components/NumberInput/index.d.ts.map +1 -0
  278. package/dist/components/NumberInput/index.js +7 -0
  279. package/dist/components/NumberInput/index.js.map +1 -0
  280. package/dist/components/NumberInput/number-input.d.ts +3 -3
  281. package/dist/components/NumberInput/number-input.d.ts.map +1 -1
  282. package/dist/components/NumberInput/number-input.js +8 -7
  283. package/dist/components/NumberInput/number-input.js.map +1 -1
  284. package/dist/components/OverflowIndicator/index.d.ts +2 -0
  285. package/dist/components/OverflowIndicator/index.d.ts.map +1 -0
  286. package/dist/components/OverflowIndicator/index.js +6 -0
  287. package/dist/components/OverflowIndicator/index.js.map +1 -0
  288. package/dist/components/OverflowIndicator/overflow-indicator.d.ts.map +1 -1
  289. package/dist/components/OverflowIndicator/overflow-indicator.js +9 -2
  290. package/dist/components/OverflowIndicator/overflow-indicator.js.map +1 -1
  291. package/dist/components/PeoplePicker/index.d.ts +2 -0
  292. package/dist/components/PeoplePicker/index.d.ts.map +1 -0
  293. package/dist/components/PeoplePicker/index.js +9 -0
  294. package/dist/components/PeoplePicker/index.js.map +1 -0
  295. package/dist/components/PeoplePicker/people-picker-helpers.d.ts +1 -1
  296. package/dist/components/PeoplePicker/people-picker-helpers.d.ts.map +1 -1
  297. package/dist/components/PeoplePicker/people-picker-helpers.js +2 -2
  298. package/dist/components/PeoplePicker/people-picker-helpers.js.map +1 -1
  299. package/dist/components/PeoplePicker/people-picker.d.ts +1 -1
  300. package/dist/components/PeoplePicker/people-picker.d.ts.map +1 -1
  301. package/dist/components/PeoplePicker/people-picker.js +14 -14
  302. package/dist/components/PeoplePicker/people-picker.js.map +1 -1
  303. package/dist/components/PeoplePicker/person-display.d.ts +7 -7
  304. package/dist/components/PeoplePicker/person-display.d.ts.map +1 -1
  305. package/dist/components/PeoplePicker/person-display.js +8 -8
  306. package/dist/components/PeoplePicker/person-display.js.map +1 -1
  307. package/dist/components/Popover/index.d.ts +2 -0
  308. package/dist/components/Popover/index.d.ts.map +1 -0
  309. package/dist/components/Popover/index.js +14 -0
  310. package/dist/components/Popover/index.js.map +1 -0
  311. package/dist/components/Popover/popover.js +3 -2
  312. package/dist/components/Popover/popover.js.map +1 -1
  313. package/dist/components/ProfileCard/index.d.ts +2 -0
  314. package/dist/components/ProfileCard/index.d.ts.map +1 -0
  315. package/dist/components/ProfileCard/index.js +8 -0
  316. package/dist/components/ProfileCard/index.js.map +1 -0
  317. package/dist/components/{NameCard/name-card.d.ts → ProfileCard/profile-card.d.ts} +19 -18
  318. package/dist/components/ProfileCard/profile-card.d.ts.map +1 -0
  319. package/dist/components/{NameCard/name-card.js → ProfileCard/profile-card.js} +9 -9
  320. package/dist/components/ProfileCard/profile-card.js.map +1 -0
  321. package/dist/components/ProgressBar/index.d.ts +2 -0
  322. package/dist/components/ProgressBar/index.d.ts.map +1 -0
  323. package/dist/components/ProgressBar/index.js +6 -0
  324. package/dist/components/ProgressBar/index.js.map +1 -0
  325. package/dist/components/ProgressBar/progress-bar.d.ts +2 -2
  326. package/dist/components/ProgressBar/progress-bar.js +3 -3
  327. package/dist/components/ProgressBar/progress-bar.js.map +1 -1
  328. package/dist/components/RadioGroup/index.d.ts +2 -0
  329. package/dist/components/RadioGroup/index.d.ts.map +1 -0
  330. package/dist/components/RadioGroup/index.js +8 -0
  331. package/dist/components/RadioGroup/index.js.map +1 -0
  332. package/dist/components/RadioGroup/radio-group.d.ts +6 -6
  333. package/dist/components/RadioGroup/radio-group.d.ts.map +1 -1
  334. package/dist/components/RadioGroup/radio-group.js +17 -18
  335. package/dist/components/RadioGroup/radio-group.js.map +1 -1
  336. package/dist/components/Rating/index.d.ts +2 -0
  337. package/dist/components/Rating/index.d.ts.map +1 -0
  338. package/dist/components/Rating/index.js +6 -0
  339. package/dist/components/Rating/index.js.map +1 -0
  340. package/dist/components/Rating/rating.d.ts +6 -2
  341. package/dist/components/Rating/rating.d.ts.map +1 -1
  342. package/dist/components/Rating/rating.js +7 -6
  343. package/dist/components/Rating/rating.js.map +1 -1
  344. package/dist/components/ScrollArea/index.d.ts +2 -0
  345. package/dist/components/ScrollArea/index.d.ts.map +1 -0
  346. package/dist/components/ScrollArea/index.js +7 -0
  347. package/dist/components/ScrollArea/index.js.map +1 -0
  348. package/dist/components/ScrollArea/scroll-area.d.ts +1 -1
  349. package/dist/components/ScrollArea/scroll-area.js +1 -1
  350. package/dist/components/ScrollArea/scroll-area.js.map +1 -1
  351. package/dist/components/SegmentedControl/index.d.ts +2 -0
  352. package/dist/components/SegmentedControl/index.d.ts.map +1 -0
  353. package/dist/components/SegmentedControl/index.js +9 -0
  354. package/dist/components/SegmentedControl/index.js.map +1 -0
  355. package/dist/components/SegmentedControl/segmented-control.d.ts +2 -2
  356. package/dist/components/SegmentedControl/segmented-control.d.ts.map +1 -1
  357. package/dist/components/SegmentedControl/segmented-control.js +8 -10
  358. package/dist/components/SegmentedControl/segmented-control.js.map +1 -1
  359. package/dist/components/Select/index.d.ts +2 -0
  360. package/dist/components/Select/index.d.ts.map +1 -0
  361. package/dist/components/Select/index.js +6 -0
  362. package/dist/components/Select/index.js.map +1 -0
  363. package/dist/components/Select/select.d.ts +2 -2
  364. package/dist/components/Select/select.d.ts.map +1 -1
  365. package/dist/components/Select/select.js +14 -12
  366. package/dist/components/Select/select.js.map +1 -1
  367. package/dist/components/SelectMenu/index.d.ts +2 -0
  368. package/dist/components/SelectMenu/index.d.ts.map +1 -0
  369. package/dist/components/SelectMenu/index.js +6 -0
  370. package/dist/components/SelectMenu/index.js.map +1 -0
  371. package/dist/components/SelectMenu/select-menu.d.ts +7 -6
  372. package/dist/components/SelectMenu/select-menu.d.ts.map +1 -1
  373. package/dist/components/SelectMenu/select-menu.js +6 -1
  374. package/dist/components/SelectMenu/select-menu.js.map +1 -1
  375. package/dist/components/SelectionControl/index.d.ts +2 -0
  376. package/dist/components/SelectionControl/index.d.ts.map +1 -0
  377. package/dist/components/SelectionControl/index.js +7 -0
  378. package/dist/components/SelectionControl/index.js.map +1 -0
  379. package/dist/components/SelectionControl/selection-item.d.ts +1 -1
  380. package/dist/components/Separator/index.d.ts +2 -0
  381. package/dist/components/Separator/index.d.ts.map +1 -0
  382. package/dist/components/Separator/index.js +6 -0
  383. package/dist/components/Separator/index.js.map +1 -0
  384. package/dist/components/Separator/separator.d.ts +2 -2
  385. package/dist/components/Separator/separator.js +4 -3
  386. package/dist/components/Separator/separator.js.map +1 -1
  387. package/dist/components/Sheet/index.d.ts +2 -0
  388. package/dist/components/Sheet/index.d.ts.map +1 -0
  389. package/dist/components/Sheet/index.js +17 -0
  390. package/dist/components/Sheet/index.js.map +1 -0
  391. package/dist/components/Sheet/sheet.d.ts +1 -1
  392. package/dist/components/Sheet/sheet.js.map +1 -1
  393. package/dist/components/Sidebar/index.d.ts +2 -0
  394. package/dist/components/Sidebar/index.d.ts.map +1 -0
  395. package/dist/components/Sidebar/index.js +24 -0
  396. package/dist/components/Sidebar/index.js.map +1 -0
  397. package/dist/components/Sidebar/sidebar.d.ts +5 -5
  398. package/dist/components/Sidebar/sidebar.d.ts.map +1 -1
  399. package/dist/components/Sidebar/sidebar.js +6 -3
  400. package/dist/components/Sidebar/sidebar.js.map +1 -1
  401. package/dist/components/Skeleton/index.d.ts +2 -0
  402. package/dist/components/Skeleton/index.d.ts.map +1 -0
  403. package/dist/components/Skeleton/index.js +6 -0
  404. package/dist/components/Skeleton/index.js.map +1 -0
  405. package/dist/components/Slider/index.d.ts +2 -0
  406. package/dist/components/Slider/index.d.ts.map +1 -0
  407. package/dist/components/Slider/index.js +7 -0
  408. package/dist/components/Slider/index.js.map +1 -0
  409. package/dist/components/Slider/slider.d.ts +4 -4
  410. package/dist/components/Slider/slider.d.ts.map +1 -1
  411. package/dist/components/Slider/slider.js +10 -4
  412. package/dist/components/Slider/slider.js.map +1 -1
  413. package/dist/components/Steps/index.d.ts +2 -0
  414. package/dist/components/Steps/index.d.ts.map +1 -0
  415. package/dist/components/Steps/index.js +12 -0
  416. package/dist/components/Steps/index.js.map +1 -0
  417. package/dist/components/Steps/steps.d.ts +1 -1
  418. package/dist/components/Steps/steps.d.ts.map +1 -1
  419. package/dist/components/Steps/steps.js +28 -14
  420. package/dist/components/Steps/steps.js.map +1 -1
  421. package/dist/components/Switch/index.d.ts +2 -0
  422. package/dist/components/Switch/index.d.ts.map +1 -0
  423. package/dist/components/Switch/index.js +7 -0
  424. package/dist/components/Switch/index.js.map +1 -0
  425. package/dist/components/Switch/switch.d.ts +3 -3
  426. package/dist/components/Switch/switch.d.ts.map +1 -1
  427. package/dist/components/Switch/switch.js +14 -10
  428. package/dist/components/Switch/switch.js.map +1 -1
  429. package/dist/components/Tabs/index.d.ts +2 -0
  430. package/dist/components/Tabs/index.d.ts.map +1 -0
  431. package/dist/components/Tabs/index.js +10 -0
  432. package/dist/components/Tabs/index.js.map +1 -0
  433. package/dist/components/Tabs/tabs.d.ts +5 -5
  434. package/dist/components/Tabs/tabs.d.ts.map +1 -1
  435. package/dist/components/Tabs/tabs.js +4 -3
  436. package/dist/components/Tabs/tabs.js.map +1 -1
  437. package/dist/components/Tag/index.d.ts +2 -0
  438. package/dist/components/Tag/index.d.ts.map +1 -0
  439. package/dist/components/Tag/index.js +7 -0
  440. package/dist/components/Tag/index.js.map +1 -0
  441. package/dist/components/Tag/tag.d.ts +35 -23
  442. package/dist/components/Tag/tag.d.ts.map +1 -1
  443. package/dist/components/Tag/tag.js +38 -43
  444. package/dist/components/Tag/tag.js.map +1 -1
  445. package/dist/components/Textarea/index.d.ts +2 -0
  446. package/dist/components/Textarea/index.d.ts.map +1 -0
  447. package/dist/components/Textarea/index.js +7 -0
  448. package/dist/components/Textarea/index.js.map +1 -0
  449. package/dist/components/Textarea/textarea.d.ts +5 -10
  450. package/dist/components/Textarea/textarea.d.ts.map +1 -1
  451. package/dist/components/Textarea/textarea.js +11 -9
  452. package/dist/components/Textarea/textarea.js.map +1 -1
  453. package/dist/components/TimePicker/index.d.ts +2 -0
  454. package/dist/components/TimePicker/index.d.ts.map +1 -0
  455. package/dist/components/TimePicker/index.js +6 -0
  456. package/dist/components/TimePicker/index.js.map +1 -0
  457. package/dist/components/TimePicker/time-picker.d.ts +4 -3
  458. package/dist/components/TimePicker/time-picker.d.ts.map +1 -1
  459. package/dist/components/TimePicker/time-picker.js +18 -9
  460. package/dist/components/TimePicker/time-picker.js.map +1 -1
  461. package/dist/components/Toast/index.d.ts +2 -0
  462. package/dist/components/Toast/index.d.ts.map +1 -0
  463. package/dist/components/Toast/index.js +7 -0
  464. package/dist/components/Toast/index.js.map +1 -0
  465. package/dist/components/Toast/toast.d.ts +2 -2
  466. package/dist/components/Toast/toast.js +2 -2
  467. package/dist/components/Toast/toast.js.map +1 -1
  468. package/dist/components/Tooltip/index.d.ts +2 -0
  469. package/dist/components/Tooltip/index.d.ts.map +1 -0
  470. package/dist/components/Tooltip/index.js +9 -0
  471. package/dist/components/Tooltip/index.js.map +1 -0
  472. package/dist/components/Tooltip/tooltip.d.ts.map +1 -1
  473. package/dist/components/Tooltip/tooltip.js +1 -0
  474. package/dist/components/Tooltip/tooltip.js.map +1 -1
  475. package/dist/components/TreeView/index.d.ts +2 -0
  476. package/dist/components/TreeView/index.d.ts.map +1 -0
  477. package/dist/components/TreeView/index.js +8 -0
  478. package/dist/components/TreeView/index.js.map +1 -0
  479. package/dist/components/TreeView/tree-view.d.ts +8 -8
  480. package/dist/components/TreeView/tree-view.d.ts.map +1 -1
  481. package/dist/components/TreeView/tree-view.js +35 -8
  482. package/dist/components/TreeView/tree-view.js.map +1 -1
  483. package/dist/hooks/use-overflow-items.d.ts +10 -6
  484. package/dist/hooks/use-overflow-items.d.ts.map +1 -1
  485. package/dist/hooks/use-overflow-items.js.map +1 -1
  486. package/dist/index.d.ts +57 -67
  487. package/dist/index.d.ts.map +1 -1
  488. package/dist/index.js +27 -59
  489. package/dist/index.js.map +1 -1
  490. package/dist/lib/i18n/i18n-context.d.ts +3 -3
  491. package/dist/lib/utils.d.ts.map +1 -1
  492. package/dist/lib/utils.js +3 -1
  493. package/dist/lib/utils.js.map +1 -1
  494. package/dist/patterns/element-anatomy/index.d.ts +2 -0
  495. package/dist/patterns/element-anatomy/index.d.ts.map +1 -0
  496. package/dist/patterns/element-anatomy/index.js +20 -0
  497. package/dist/patterns/element-anatomy/index.js.map +1 -0
  498. package/dist/patterns/element-anatomy/item-anatomy.d.ts +9 -5
  499. package/dist/patterns/element-anatomy/item-anatomy.d.ts.map +1 -1
  500. package/dist/patterns/element-anatomy/item-anatomy.js +1 -1
  501. package/dist/patterns/element-anatomy/item-anatomy.js.map +1 -1
  502. package/dist/patterns/header-canonical/chrome-header.d.ts +10 -2
  503. package/dist/patterns/header-canonical/chrome-header.d.ts.map +1 -1
  504. package/dist/patterns/header-canonical/chrome-header.js +4 -2
  505. package/dist/patterns/header-canonical/chrome-header.js.map +1 -1
  506. package/dist/patterns/header-canonical/index.d.ts +2 -0
  507. package/dist/patterns/header-canonical/index.d.ts.map +1 -0
  508. package/dist/patterns/header-canonical/index.js +6 -0
  509. package/dist/patterns/header-canonical/index.js.map +1 -0
  510. package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts +1 -1
  511. package/dist/patterns/horizontal-overflow/index.d.ts +2 -0
  512. package/dist/patterns/horizontal-overflow/index.d.ts.map +1 -0
  513. package/dist/patterns/horizontal-overflow/index.js +14 -0
  514. package/dist/patterns/horizontal-overflow/index.js.map +1 -0
  515. package/dist/patterns/overlay-surface/index.d.ts +2 -0
  516. package/dist/patterns/overlay-surface/index.d.ts.map +1 -0
  517. package/dist/patterns/overlay-surface/index.js +7 -0
  518. package/dist/patterns/overlay-surface/index.js.map +1 -0
  519. package/dist/patterns/overlay-surface/overlay-surface.d.ts.map +1 -1
  520. package/dist/patterns/overlay-surface/overlay-surface.js +2 -1
  521. package/dist/patterns/overlay-surface/overlay-surface.js.map +1 -1
  522. package/dist/patterns/resize-handle/index.d.ts +2 -0
  523. package/dist/patterns/resize-handle/index.d.ts.map +1 -0
  524. package/dist/patterns/resize-handle/index.js +5 -0
  525. package/dist/patterns/resize-handle/index.js.map +1 -0
  526. package/dist/story-governance/category-matrix.d.ts +35 -0
  527. package/dist/story-governance/category-matrix.d.ts.map +1 -0
  528. package/dist/tokens/categorical-color.d.ts +60 -0
  529. package/dist/tokens/categorical-color.d.ts.map +1 -0
  530. package/dist/tokens/categorical-color.js +110 -0
  531. package/dist/tokens/categorical-color.js.map +1 -0
  532. package/dist/tokens/motion/motion.d.ts +1 -1
  533. package/dist/tokens/motion/motion.d.ts.map +1 -1
  534. package/dist/tokens/motion/motion.js.map +1 -1
  535. package/dist/tokens/uiSize/icon-size.d.ts +4 -5
  536. package/dist/tokens/uiSize/icon-size.d.ts.map +1 -1
  537. package/ds-canonical/commands/README.md +26 -0
  538. package/ds-canonical/commands/gov-status.md +79 -0
  539. package/ds-canonical/hooks/README.md +145 -0
  540. package/ds-canonical/hooks/_log-fire.sh +44 -0
  541. package/ds-canonical/hooks/auto_regen_ds_barrel.sh +58 -0
  542. package/ds-canonical/hooks/block_prototype_imports.py +111 -0
  543. package/ds-canonical/hooks/check_addon_subdir_ship.sh +76 -0
  544. package/ds-canonical/hooks/check_audit_post_report_validator.sh +136 -0
  545. package/ds-canonical/hooks/check_audit_sample_escape.sh +73 -0
  546. package/ds-canonical/hooks/check_benchmark_citation.sh +106 -0
  547. package/ds-canonical/hooks/check_canonical_propagation.sh +189 -0
  548. package/ds-canonical/hooks/check_chrome_header_avatar_canonical.sh +87 -0
  549. package/ds-canonical/hooks/check_codex_brief_invariants.sh +115 -0
  550. package/ds-canonical/hooks/check_codex_collab_5step.sh +108 -0
  551. package/ds-canonical/hooks/check_consumer_app_story_title.sh +81 -0
  552. package/ds-canonical/hooks/check_consumer_ds_primitive_misuse.sh +120 -0
  553. package/ds-canonical/hooks/check_consumer_no_ds_catalog.sh +101 -0
  554. package/ds-canonical/hooks/check_consumer_story_baseline.sh +76 -0
  555. package/ds-canonical/hooks/check_data_table_size_num_to_meta_width.sh +68 -0
  556. package/ds-canonical/hooks/check_datatable_invariants.sh +117 -0
  557. package/ds-canonical/hooks/check_dim_count_drift.sh +72 -0
  558. package/ds-canonical/hooks/check_ds_anchor_preflight.sh +132 -0
  559. package/ds-canonical/hooks/check_escape_marker_abuse.sh +126 -0
  560. package/ds-canonical/hooks/check_field_controls_contracts.sh +110 -0
  561. package/ds-canonical/hooks/check_field_family_invariants.sh +240 -0
  562. package/ds-canonical/hooks/check_file_size_budget.sh +60 -0
  563. package/ds-canonical/hooks/check_fork_user_plugin_install.sh +79 -0
  564. package/ds-canonical/hooks/check_full_story_visual_interaction_sweep.sh +71 -0
  565. package/ds-canonical/hooks/check_item_list_gap.sh +54 -0
  566. package/ds-canonical/hooks/check_layout_space_magic_numbers.sh +96 -0
  567. package/ds-canonical/hooks/check_main_branch_workbench.sh +93 -0
  568. package/ds-canonical/hooks/check_naming_and_abstraction.sh +165 -0
  569. package/ds-canonical/hooks/check_opacity_token_usage.sh +149 -0
  570. package/ds-canonical/hooks/check_orphan_ds_css.sh +66 -0
  571. package/ds-canonical/hooks/check_overlay_open_focus_escape_probe.sh +75 -0
  572. package/ds-canonical/hooks/check_pattern_invariants.sh +196 -0
  573. package/ds-canonical/hooks/check_peoplepicker_ssot_drift.sh +56 -0
  574. package/ds-canonical/hooks/check_pixel_quantified_audit.sh +53 -0
  575. package/ds-canonical/hooks/check_plugin_freshness.sh +68 -0
  576. package/ds-canonical/hooks/check_post_main_ssot_propagate.sh +90 -0
  577. package/ds-canonical/hooks/check_propose_cite_required.sh +88 -0
  578. package/ds-canonical/hooks/check_propose_plain_chinese.sh +74 -0
  579. package/ds-canonical/hooks/check_propose_pre_grep_verify.sh +70 -0
  580. package/ds-canonical/hooks/check_propose_without_benchmark.sh +63 -0
  581. package/ds-canonical/hooks/check_select_all_canonical.sh +58 -0
  582. package/ds-canonical/hooks/check_sidebar_menu_button_implicit_wrap.sh +86 -0
  583. package/ds-canonical/hooks/check_solo_workflow.sh +307 -0
  584. package/ds-canonical/hooks/check_spec_class_drift.sh +88 -0
  585. package/ds-canonical/hooks/check_story_invariants.sh +668 -0
  586. package/ds-canonical/hooks/check_storybook_addon_preset_cjs.sh +87 -0
  587. package/ds-canonical/hooks/check_substantive_edit_approval_preflight.sh +110 -0
  588. package/ds-canonical/hooks/check_tailwind_wildcard_in_docs.sh +73 -0
  589. package/ds-canonical/hooks/check_wrapper_primitive_schema_drift.sh +104 -0
  590. package/ds-canonical/hooks/chrome_header_dispatcher.sh +56 -0
  591. package/ds-canonical/hooks/enforce_home_charter.sh +44 -0
  592. package/ds-canonical/hooks/inject_deploy_url_after_push.sh +238 -0
  593. package/ds-canonical/hooks/inject_pending_self_audit.sh +248 -0
  594. package/ds-canonical/hooks/lib/_app_shell_primary_header_consistency.sh +70 -0
  595. package/ds-canonical/hooks/lib/_approval_re.sh +33 -0
  596. package/ds-canonical/hooks/lib/_chrome_header_handcraft.sh +75 -0
  597. package/ds-canonical/hooks/lib/_code_quality.sh +73 -0
  598. package/ds-canonical/hooks/lib/_cva_default_sync.sh +69 -0
  599. package/ds-canonical/hooks/lib/_governance_coverage_check.sh +49 -0
  600. package/ds-canonical/hooks/lib/_hardcoded_strings.sh +163 -0
  601. package/ds-canonical/hooks/lib/_header_with_tabs_border.sh +87 -0
  602. package/ds-canonical/hooks/lib/_layout_space_canonical.sh +56 -0
  603. package/ds-canonical/hooks/lib/_overlay_handcraft.sh +141 -0
  604. package/ds-canonical/hooks/lib/_person_data_richness.sh +42 -0
  605. package/ds-canonical/hooks/lib/_story_compile_drift.sh +48 -0
  606. package/ds-canonical/hooks/lib/_tab_lg_chrome_header_equal.sh +70 -0
  607. package/ds-canonical/hooks/lib/_token_hygiene.sh +96 -0
  608. package/ds-canonical/hooks/log_governance_fires.sh +50 -0
  609. package/ds-canonical/hooks/log_skill_invokes.sh +41 -0
  610. package/ds-canonical/hooks/post_edit_dispatcher.sh +62 -0
  611. package/ds-canonical/hooks/retired/check_anatomy_section_numbering.sh +106 -0
  612. package/ds-canonical/hooks/retired/check_avatar_hovercard.sh +90 -0
  613. package/ds-canonical/hooks/retired/check_button_icon_literal.sh.retired-2026-04-28 +38 -0
  614. package/ds-canonical/hooks/retired/check_container_breathing.sh +142 -0
  615. package/ds-canonical/hooks/retired/check_governance_compliance.sh +61 -0
  616. package/ds-canonical/hooks/retired/check_icon_only_padding_formula.sh +104 -0
  617. package/ds-canonical/hooks/retired/check_item_content_primitive.sh +150 -0
  618. package/ds-canonical/hooks/retired/check_item_list_gap.sh +153 -0
  619. package/ds-canonical/hooks/retired/check_sideoffset_canonical.sh +65 -0
  620. package/ds-canonical/hooks/retired/check_spec_iteration_tag.sh +87 -0
  621. package/ds-canonical/hooks/retired/check_ssot_consultation.sh +88 -0
  622. package/ds-canonical/hooks/retired/check_sync_update.sh +20 -0
  623. package/ds-canonical/hooks/retired/check_third_party_dom_verified.sh +95 -0
  624. package/ds-canonical/hooks/retired/enforce_home_charter.sh +125 -0
  625. package/ds-canonical/hooks/retired/post_edit_canonical_interrogate.sh +109 -0
  626. package/ds-canonical/hooks/retired/pre_edit_spec_check.sh +68 -0
  627. package/ds-canonical/hooks/retired/pre_new_component_spec.sh +39 -0
  628. package/ds-canonical/hooks/retired/pre_write_subsumption_check.sh +112 -0
  629. package/ds-canonical/hooks/retired/stop_meta_self_audit.sh.retired-2026-05-13 +76 -0
  630. package/ds-canonical/hooks/retired/tests/test_check_anatomy_section_numbering.sh +14 -0
  631. package/ds-canonical/hooks/retired/tests/test_check_avatar_hovercard.sh +15 -0
  632. package/ds-canonical/hooks/retired/tests/test_check_container_breathing.sh +15 -0
  633. package/ds-canonical/hooks/retired/tests/test_check_governance_compliance.sh +15 -0
  634. package/ds-canonical/hooks/retired/tests/test_check_icon_only_padding_formula.sh +79 -0
  635. package/ds-canonical/hooks/retired/tests/test_check_item_content_primitive.sh +15 -0
  636. package/ds-canonical/hooks/retired/tests/test_check_item_list_gap.sh +163 -0
  637. package/ds-canonical/hooks/retired/tests/test_check_sideoffset_canonical.sh +15 -0
  638. package/ds-canonical/hooks/retired/tests/test_check_spec_iteration_tag.sh +15 -0
  639. package/ds-canonical/hooks/retired/tests/test_check_ssot_consultation.sh +15 -0
  640. package/ds-canonical/hooks/retired/tests/test_check_sync_update.sh +14 -0
  641. package/ds-canonical/hooks/retired/tests/test_check_third_party_dom_verified.sh +15 -0
  642. package/ds-canonical/hooks/retired/tests/test_enforce_home_charter.sh +15 -0
  643. package/ds-canonical/hooks/retired/tests/test_pre_edit_spec_check.sh +15 -0
  644. package/ds-canonical/hooks/retired/tests/test_pre_new_component_spec.sh +15 -0
  645. package/ds-canonical/hooks/retired/tests/test_pre_write_subsumption_check.sh +63 -0
  646. package/ds-canonical/hooks/session_start_governance_check.sh +305 -0
  647. package/ds-canonical/hooks/stop_passive_logging.sh +322 -0
  648. package/ds-canonical/hooks/stop_self_audit.sh +516 -0
  649. package/ds-canonical/hooks/tests/KNOWN-BROKEN.md +15 -0
  650. package/ds-canonical/hooks/tests/run-all.sh +76 -0
  651. package/ds-canonical/hooks/tests/test_auto_regen_ds_barrel.sh +180 -0
  652. package/ds-canonical/hooks/tests/test_block_prototype_imports.sh +143 -0
  653. package/ds-canonical/hooks/tests/test_check_addon_subdir_ship.sh +170 -0
  654. package/ds-canonical/hooks/tests/test_check_app_shell_primary_header_consistency.sh +140 -0
  655. package/ds-canonical/hooks/tests/test_check_audit_post_report_validator.sh +127 -0
  656. package/ds-canonical/hooks/tests/test_check_audit_sample_escape.sh +93 -0
  657. package/ds-canonical/hooks/tests/test_check_benchmark_citation.sh +115 -0
  658. package/ds-canonical/hooks/tests/test_check_canonical_propagation.sh +133 -0
  659. package/ds-canonical/hooks/tests/test_check_chrome_header_avatar_canonical.sh +198 -0
  660. package/ds-canonical/hooks/tests/test_check_chrome_header_handcraft.sh +146 -0
  661. package/ds-canonical/hooks/tests/test_check_code_quality.sh +15 -0
  662. package/ds-canonical/hooks/tests/test_check_codex_brief_invariants.sh +208 -0
  663. package/ds-canonical/hooks/tests/test_check_codex_collab_5step.sh +96 -0
  664. package/ds-canonical/hooks/tests/test_check_consumer_app_story_title.sh +163 -0
  665. package/ds-canonical/hooks/tests/test_check_consumer_ds_primitive_misuse.sh +238 -0
  666. package/ds-canonical/hooks/tests/test_check_consumer_no_ds_catalog.sh +211 -0
  667. package/ds-canonical/hooks/tests/test_check_consumer_story_baseline.sh +200 -0
  668. package/ds-canonical/hooks/tests/test_check_cva_default_sync.sh +15 -0
  669. package/ds-canonical/hooks/tests/test_check_data_table_size_num_to_meta_width.sh +52 -0
  670. package/ds-canonical/hooks/tests/test_check_datatable_invariants.sh +122 -0
  671. package/ds-canonical/hooks/tests/test_check_dim_count_drift.sh +98 -0
  672. package/ds-canonical/hooks/tests/test_check_ds_anchor_preflight.sh +104 -0
  673. package/ds-canonical/hooks/tests/test_check_escape_marker_abuse.sh +192 -0
  674. package/ds-canonical/hooks/tests/test_check_field_controls_contracts.sh +126 -0
  675. package/ds-canonical/hooks/tests/test_check_field_family_invariants.sh +203 -0
  676. package/ds-canonical/hooks/tests/test_check_file_size_budget.sh +32 -0
  677. package/ds-canonical/hooks/tests/test_check_fork_user_plugin_install.sh +45 -0
  678. package/ds-canonical/hooks/tests/test_check_full_story_visual_interaction_sweep.sh +190 -0
  679. package/ds-canonical/hooks/tests/test_check_hardcoded_strings.sh +14 -0
  680. package/ds-canonical/hooks/tests/test_check_header_with_tabs_border.sh +110 -0
  681. package/ds-canonical/hooks/tests/test_check_item_list_gap.sh +44 -0
  682. package/ds-canonical/hooks/tests/test_check_layout_space_canonical.sh +73 -0
  683. package/ds-canonical/hooks/tests/test_check_layout_space_magic_numbers.sh +206 -0
  684. package/ds-canonical/hooks/tests/test_check_main_branch_workbench.sh +147 -0
  685. package/ds-canonical/hooks/tests/test_check_naming_and_abstraction.sh +136 -0
  686. package/ds-canonical/hooks/tests/test_check_opacity_token_usage.sh +110 -0
  687. package/ds-canonical/hooks/tests/test_check_orphan_ds_css.sh +212 -0
  688. package/ds-canonical/hooks/tests/test_check_overlay_handcraft.sh +126 -0
  689. package/ds-canonical/hooks/tests/test_check_overlay_open_focus_escape_probe.sh +191 -0
  690. package/ds-canonical/hooks/tests/test_check_pattern_invariants.sh +148 -0
  691. package/ds-canonical/hooks/tests/test_check_peoplepicker_ssot_drift.sh +108 -0
  692. package/ds-canonical/hooks/tests/test_check_person_data_richness.sh +58 -0
  693. package/ds-canonical/hooks/tests/test_check_pixel_quantified_audit.sh +142 -0
  694. package/ds-canonical/hooks/tests/test_check_propose_cite_required.sh +180 -0
  695. package/ds-canonical/hooks/tests/test_check_propose_plain_chinese.sh +126 -0
  696. package/ds-canonical/hooks/tests/test_check_propose_pre_grep_verify.sh +117 -0
  697. package/ds-canonical/hooks/tests/test_check_propose_without_benchmark.sh +55 -0
  698. package/ds-canonical/hooks/tests/test_check_select_all_canonical.sh +125 -0
  699. package/ds-canonical/hooks/tests/test_check_sidebar_menu_button_implicit_wrap.sh +224 -0
  700. package/ds-canonical/hooks/tests/test_check_solo_workflow.sh +201 -0
  701. package/ds-canonical/hooks/tests/test_check_spec_class_drift.sh +135 -0
  702. package/ds-canonical/hooks/tests/test_check_story_anatomy.sh.broken +197 -0
  703. package/ds-canonical/hooks/tests/test_check_story_category.sh.broken +187 -0
  704. package/ds-canonical/hooks/tests/test_check_story_compile_drift.sh +15 -0
  705. package/ds-canonical/hooks/tests/test_check_story_invariants.sh +354 -0
  706. package/ds-canonical/hooks/tests/test_check_story_name_jargon.sh.broken +53 -0
  707. package/ds-canonical/hooks/tests/test_check_story_slot_split.sh +156 -0
  708. package/ds-canonical/hooks/tests/test_check_storybook_addon_preset_cjs.sh +199 -0
  709. package/ds-canonical/hooks/tests/test_check_substantive_edit_approval_preflight.sh +176 -0
  710. package/ds-canonical/hooks/tests/test_check_tab_lg_chrome_header_equal.sh +141 -0
  711. package/ds-canonical/hooks/tests/test_check_tailwind_wildcard_in_docs.sh +182 -0
  712. package/ds-canonical/hooks/tests/test_check_token_hygiene.sh +21 -0
  713. package/ds-canonical/hooks/tests/test_check_wrapper_primitive_schema_drift.sh +169 -0
  714. package/ds-canonical/hooks/tests/test_enforce_home_charter.sh +77 -0
  715. package/ds-canonical/hooks/tests/test_inject_deploy_url_after_push.sh +193 -0
  716. package/ds-canonical/hooks/tests/test_inject_pending_self_audit.sh +125 -0
  717. package/ds-canonical/hooks/tests/test_log_governance_fires.sh +10 -0
  718. package/ds-canonical/hooks/tests/test_log_skill_invokes.sh +7 -0
  719. package/ds-canonical/hooks/tests/test_post_edit_dispatcher.sh +108 -0
  720. package/ds-canonical/hooks/tests/test_session_start_governance_check.sh +154 -0
  721. package/ds-canonical/hooks/tests/test_stop_capture_metrics.sh +95 -0
  722. package/ds-canonical/hooks/tests/test_stop_governance_drift_check.sh.broken +125 -0
  723. package/ds-canonical/hooks/tests/test_stop_harvest_corrections.sh +10 -0
  724. package/ds-canonical/hooks/tests/test_stop_passive_logging.sh +100 -0
  725. package/ds-canonical/hooks/tests/test_stop_self_audit.sh +98 -0
  726. package/ds-canonical/hooks/tests/test_stop_tsc_sanity.sh +10 -0
  727. package/ds-canonical/references/README.md +46 -0
  728. package/ds-canonical/references/audit-coverage-vs-24-checklist.md +74 -0
  729. package/ds-canonical/references/build-ui-canonicals.md +72 -0
  730. package/ds-canonical/references/composition-fidelity.md +47 -0
  731. package/ds-canonical/references/cva-patterns.md +41 -0
  732. package/ds-canonical/references/drag-canonical.md +331 -0
  733. package/ds-canonical/references/item-anatomy-recipe.md +225 -0
  734. package/ds-canonical/references/naming-conventions.md +56 -0
  735. package/ds-canonical/references/principle-dim-map.json +513 -0
  736. package/ds-canonical/references/props-naming.md +45 -0
  737. package/ds-canonical/references/scenario-definition.md +146 -0
  738. package/ds-canonical/references/spec-rules.md +58 -0
  739. package/ds-canonical/references/ssot-consultation.md +63 -0
  740. package/ds-canonical/references/ssot-index.md +40 -0
  741. package/ds-canonical/references/story-baseline-registry.json +79 -0
  742. package/ds-canonical/references/structural-token-retention.md +42 -0
  743. package/ds-canonical/references/tailwind-gotchas.md +87 -0
  744. package/ds-canonical/references/ui-dev-rules.md +60 -0
  745. package/ds-canonical/rules/README.md +34 -0
  746. package/ds-canonical/rules/meta-patterns.md +87 -0
  747. package/ds-canonical/rules/self-verify.md +56 -0
  748. package/ds-canonical/rules/spec-rules.md +25 -0
  749. package/ds-canonical/rules/story-rules.md +65 -0
  750. package/ds-canonical/rules/ui-development.md +92 -0
  751. package/ds-canonical/skills/README.md +88 -0
  752. package/ds-canonical/skills/bug-fix-rhythm/SKILL.md +181 -0
  753. package/ds-canonical/skills/code-quality-audit/SKILL.md +63 -0
  754. package/ds-canonical/skills/codex-collab/SKILL.md +249 -0
  755. package/ds-canonical/skills/codex-collab/references/brief-template.md +48 -0
  756. package/ds-canonical/skills/codex-collab/references/transport.md +58 -0
  757. package/ds-canonical/skills/codify-corrections/SKILL.md +184 -0
  758. package/ds-canonical/skills/codify-principle/SKILL.md +151 -0
  759. package/ds-canonical/skills/component-quality-gate/SKILL.md +102 -0
  760. package/ds-canonical/skills/component-quality-gate/references/checklist.md +79 -0
  761. package/ds-canonical/skills/deep-audit-cross-codex/SKILL.md +242 -0
  762. package/ds-canonical/skills/deep-audit-cross-codex/references/phase-a-workflow.md +123 -0
  763. package/ds-canonical/skills/deep-audit-cross-codex/references/phase-b-codex-brief.md +186 -0
  764. package/ds-canonical/skills/deep-audit-cross-codex/references/skill-relationships-antipatterns-benchmarks.md +30 -0
  765. package/ds-canonical/skills/deep-audit-cross-codex/references/triage-rubric.md +69 -0
  766. package/ds-canonical/skills/deep-audit-cross-codex/references/upstream-directives-r-mapping.md +33 -0
  767. package/ds-canonical/skills/delivery-handoff/SKILL.md +229 -0
  768. package/ds-canonical/skills/delivery-handoff/references/flow-diagram.md +180 -0
  769. package/ds-canonical/skills/delivery-handoff/references/handoff-template.md +177 -0
  770. package/ds-canonical/skills/delivery-handoff/references/inventory-checklist.md +196 -0
  771. package/ds-canonical/skills/design-system-audit/SKILL.md +384 -0
  772. package/ds-canonical/skills/design-system-audit/references/audit-prompts.md +1324 -0
  773. package/ds-canonical/skills/design-system-audit/references/checkpoints.md +240 -0
  774. package/ds-canonical/skills/design-system-audit/references/historical-bugs.md +240 -0
  775. package/ds-canonical/skills/design-system-audit/references/principle-audit-protocol.md +378 -0
  776. package/ds-canonical/skills/design-system-audit/references/rule-placement.md +175 -0
  777. package/ds-canonical/skills/ensure-canonical/SKILL.md +196 -0
  778. package/ds-canonical/skills/governance-health/SKILL.md +147 -0
  779. package/ds-canonical/skills/knowledge-prune/SKILL.md +250 -0
  780. package/ds-canonical/skills/knowledge-prune/references/phase-z-cross-repo-ssot-propagation.md +11 -0
  781. package/ds-canonical/skills/knowledge-prune/references/prune-dimensions-d5-d10.md +55 -0
  782. package/ds-canonical/skills/knowledge-prune/references/world-class-prune-alignment.md +7 -0
  783. package/ds-canonical/skills/new-component/SKILL.md +170 -0
  784. package/ds-canonical/skills/new-component/references/new-component-checklist.md +85 -0
  785. package/ds-canonical/skills/performance-audit/SKILL.md +107 -0
  786. package/ds-canonical/skills/product-ui-audit/SKILL.md +230 -0
  787. package/ds-canonical/skills/product-ui-audit/references/audit-checks.md +246 -0
  788. package/ds-canonical/skills/product-ui-audit/references/common-misuses.md +329 -0
  789. package/ds-canonical/skills/product-ui-audit/references/report-template.md +159 -0
  790. package/ds-canonical/skills/propose-options/SKILL.md +177 -0
  791. package/ds-canonical/skills/prototype/SKILL.md +244 -0
  792. package/ds-canonical/skills/prototype/references/audit-checks.md +37 -0
  793. package/ds-canonical/skills/prototype/references/benchmark-sources.md +94 -0
  794. package/ds-canonical/skills/prototype/references/checkpoints.md +191 -0
  795. package/ds-canonical/skills/prototype/references/evaluation-matrix.md +141 -0
  796. package/ds-canonical/skills/prototype/references/ooux-template.md +198 -0
  797. package/ds-canonical/skills/prototype/references/proposal-template.md +229 -0
  798. package/ds-canonical/skills/scan-similar-bugs/SKILL.md +198 -0
  799. package/ds-canonical/skills/story-auto-compile-migrate/SKILL.md +159 -0
  800. package/ds-canonical/skills/story-writing/SKILL.md +122 -0
  801. package/ds-canonical/skills/story-writing/references/anatomy-standard.md +217 -0
  802. package/ds-canonical/skills/story-writing/references/category-templates.md +174 -0
  803. package/ds-canonical/skills/story-writing/references/example-selection.md +70 -0
  804. package/ds-canonical/skills/story-writing/references/self-check.md +20 -0
  805. package/ds-canonical/skills/ux-audit/SKILL.md +130 -0
  806. package/ds-canonical/skills/visual-audit/SKILL.md +245 -0
  807. package/ds-canonical/skills/visual-audit/output/.gitkeep +0 -0
  808. package/ds-canonical/skills/visual-audit/references/audit-architecture.md +100 -0
  809. package/ds-canonical/skills/visual-audit/references/visual-checklist.md +297 -0
  810. package/ds-canonical/skills/visual-audit/references/world-class-benchmarks.md +198 -0
  811. package/ds-canonical/templates/_README.md +23 -0
  812. package/ds-canonical/templates/dashboard-app.tsx +151 -0
  813. package/ds-story-manifest.json +1689 -0
  814. package/llms-full.txt +405 -0
  815. package/llms.txt +70 -0
  816. package/package.json +33 -13
  817. package/src/components/Accordion/accordion.anatomy.stories.tsx +496 -0
  818. package/src/components/Accordion/accordion.principles.stories.tsx +360 -0
  819. package/src/components/Accordion/accordion.spec.md +114 -0
  820. package/src/components/Accordion/accordion.stories.tsx +190 -0
  821. package/src/components/Accordion/accordion.tsx +3 -0
  822. package/src/components/Accordion/index.ts +5 -0
  823. package/src/components/Alert/alert.anatomy.stories.tsx +238 -0
  824. package/src/components/Alert/alert.principles.stories.tsx +220 -0
  825. package/src/components/Alert/alert.spec.md +197 -0
  826. package/src/components/Alert/alert.stories.tsx +139 -0
  827. package/src/components/Alert/index.ts +5 -0
  828. package/src/components/AppShell/_demo-helpers.tsx +5 -5
  829. package/src/components/AppShell/app-shell.anatomy.stories.tsx +176 -0
  830. package/src/components/AppShell/app-shell.principles.stories.tsx +81 -0
  831. package/src/components/AppShell/app-shell.spec.md +330 -0
  832. package/src/components/AppShell/app-shell.stories.tsx +435 -0
  833. package/src/components/AppShell/app-shell.tsx +9 -4
  834. package/src/components/AppShell/index.ts +5 -0
  835. package/src/components/AspectRatio/aspect-ratio.anatomy.stories.tsx +208 -0
  836. package/src/components/AspectRatio/aspect-ratio.principles.stories.tsx +303 -0
  837. package/src/components/AspectRatio/aspect-ratio.spec.md +134 -0
  838. package/src/components/AspectRatio/aspect-ratio.stories.tsx +170 -0
  839. package/src/components/AspectRatio/aspect-ratio.tsx +4 -2
  840. package/src/components/AspectRatio/index.ts +5 -0
  841. package/src/components/Avatar/avatar.anatomy.stories.tsx +701 -0
  842. package/src/components/Avatar/avatar.principles.stories.tsx +245 -0
  843. package/src/components/Avatar/avatar.spec.md +339 -0
  844. package/src/components/Avatar/avatar.stories.tsx +135 -0
  845. package/src/components/Avatar/avatar.tsx +37 -43
  846. package/src/components/Avatar/index.ts +5 -0
  847. package/src/components/Badge/badge.anatomy.stories.tsx +591 -0
  848. package/src/components/Badge/badge.principles.stories.tsx +391 -0
  849. package/src/components/Badge/badge.spec.md +389 -0
  850. package/src/components/Badge/badge.stories.tsx +80 -0
  851. package/src/components/Badge/badge.tsx +33 -12
  852. package/src/components/Badge/index.ts +5 -0
  853. package/src/components/Breadcrumb/breadcrumb.anatomy.stories.tsx +458 -0
  854. package/src/components/Breadcrumb/breadcrumb.principles.stories.tsx +340 -0
  855. package/src/components/Breadcrumb/breadcrumb.spec.md +258 -0
  856. package/src/components/Breadcrumb/breadcrumb.stories.tsx +332 -0
  857. package/src/components/Breadcrumb/breadcrumb.tsx +27 -17
  858. package/src/components/Breadcrumb/index.ts +5 -0
  859. package/src/components/BulkActionBar/bulk-action-bar.anatomy.stories.tsx +224 -0
  860. package/src/components/BulkActionBar/bulk-action-bar.principles.stories.tsx +242 -0
  861. package/src/components/BulkActionBar/bulk-action-bar.spec.md +210 -0
  862. package/src/components/BulkActionBar/bulk-action-bar.stories.tsx +136 -0
  863. package/src/components/BulkActionBar/bulk-action-bar.tsx +8 -7
  864. package/src/components/BulkActionBar/index.ts +5 -0
  865. package/src/components/Button/button.anatomy.stories.tsx +710 -0
  866. package/src/components/Button/button.principles.stories.tsx +370 -0
  867. package/src/components/Button/button.spec.md +461 -0
  868. package/src/components/Button/button.stories.tsx +362 -0
  869. package/src/components/Button/button.tsx +15 -9
  870. package/src/components/Button/index.ts +5 -0
  871. package/src/components/Calendar/calendar.anatomy.stories.tsx +218 -0
  872. package/src/components/Calendar/calendar.principles.stories.tsx +143 -0
  873. package/src/components/Calendar/calendar.spec.md +244 -0
  874. package/src/components/Calendar/calendar.stories.tsx +88 -0
  875. package/src/components/Calendar/calendar.tsx +29 -19
  876. package/src/components/Calendar/index.ts +5 -0
  877. package/src/components/Carousel/carousel.anatomy.stories.tsx +516 -0
  878. package/src/components/Carousel/carousel.principles.stories.tsx +330 -0
  879. package/src/components/Carousel/carousel.spec.md +253 -0
  880. package/src/components/Carousel/carousel.stories.tsx +121 -0
  881. package/src/components/Carousel/carousel.tsx +7 -3
  882. package/src/components/Carousel/index.ts +5 -0
  883. package/src/components/Chart/chart.anatomy.stories.tsx +307 -0
  884. package/src/components/Chart/chart.principles.stories.tsx +436 -0
  885. package/src/components/Chart/chart.spec.md +155 -0
  886. package/src/components/Chart/chart.stories.tsx +268 -0
  887. package/src/components/Chart/chart.tsx +4 -1
  888. package/src/components/Chart/index.ts +5 -0
  889. package/src/components/Checkbox/checkbox.anatomy.stories.tsx +626 -0
  890. package/src/components/Checkbox/checkbox.principles.stories.tsx +213 -0
  891. package/src/components/Checkbox/checkbox.spec.md +344 -0
  892. package/src/components/Checkbox/checkbox.stories.tsx +114 -0
  893. package/src/components/Checkbox/checkbox.tsx +25 -20
  894. package/src/components/Checkbox/index.ts +5 -0
  895. package/src/components/Chip/chip.anatomy.stories.tsx +422 -0
  896. package/src/components/Chip/chip.principles.stories.tsx +222 -0
  897. package/src/components/Chip/chip.spec.md +238 -0
  898. package/src/components/Chip/chip.stories.tsx +88 -0
  899. package/src/components/Chip/chip.tsx +4 -4
  900. package/src/components/Chip/index.ts +5 -0
  901. package/src/components/CircularProgress/circular-progress.anatomy.stories.tsx +176 -0
  902. package/src/components/CircularProgress/circular-progress.principles.stories.tsx +258 -0
  903. package/src/components/CircularProgress/circular-progress.spec.md +268 -0
  904. package/src/components/CircularProgress/circular-progress.stories.tsx +160 -0
  905. package/src/components/CircularProgress/circular-progress.tsx +3 -4
  906. package/src/components/CircularProgress/index.ts +5 -0
  907. package/src/components/Coachmark/coachmark-story-helpers.tsx +39 -0
  908. package/src/components/Coachmark/coachmark.anatomy.stories.tsx +356 -0
  909. package/src/components/Coachmark/coachmark.principles.stories.tsx +369 -0
  910. package/src/components/Coachmark/coachmark.spec.md +230 -0
  911. package/src/components/Coachmark/coachmark.stories.tsx +214 -0
  912. package/src/components/Coachmark/coachmark.tsx +12 -3
  913. package/src/components/Coachmark/index.ts +5 -0
  914. package/src/components/Combobox/combobox.anatomy.stories.tsx +919 -0
  915. package/src/components/Combobox/combobox.principles.stories.tsx +239 -0
  916. package/src/components/Combobox/combobox.spec.md +184 -0
  917. package/src/components/Combobox/combobox.stories.tsx +184 -0
  918. package/src/components/Combobox/combobox.tsx +54 -27
  919. package/src/components/Combobox/index.ts +5 -0
  920. package/src/components/Command/command.anatomy.stories.tsx +105 -0
  921. package/src/components/Command/command.principles.stories.tsx +88 -0
  922. package/src/components/Command/command.spec.md +171 -0
  923. package/src/components/Command/command.stories.tsx +280 -0
  924. package/src/components/Command/index.ts +5 -0
  925. package/src/components/DataTable/cell-registry.tsx +13 -4
  926. package/src/components/DataTable/data-table-filter-panel.tsx +2 -2
  927. package/src/components/DataTable/data-table.anatomy.stories.tsx +517 -0
  928. package/src/components/DataTable/data-table.principles.stories.tsx +265 -0
  929. package/src/components/DataTable/data-table.spec.md +528 -0
  930. package/src/components/DataTable/data-table.stories.tsx +1892 -0
  931. package/src/components/DataTable/data-table.tsx +16 -9
  932. package/src/components/DataTable/filter-operators.spec.md +275 -0
  933. package/src/components/DataTable/filter-operators.ts +1 -1
  934. package/src/components/DataTable/filter-tree.ts +2 -2
  935. package/src/components/DataTable/index.ts +5 -0
  936. package/src/components/DateGrid/date-grid.anatomy.stories.tsx +583 -0
  937. package/src/components/DateGrid/date-grid.principles.stories.tsx +338 -0
  938. package/src/components/DateGrid/date-grid.spec.md +215 -0
  939. package/src/components/DateGrid/date-grid.stories.tsx +195 -0
  940. package/src/components/DateGrid/date-grid.tsx +15 -15
  941. package/src/components/DateGrid/index.ts +5 -0
  942. package/src/components/DatePicker/date-picker.anatomy.stories.tsx +952 -0
  943. package/src/components/DatePicker/date-picker.principles.stories.tsx +205 -0
  944. package/src/components/DatePicker/date-picker.spec.md +333 -0
  945. package/src/components/DatePicker/date-picker.stories.tsx +353 -0
  946. package/src/components/DatePicker/date-picker.tsx +29 -14
  947. package/src/components/DatePicker/index.ts +5 -0
  948. package/src/components/DescriptionList/description-list.anatomy.stories.tsx +252 -0
  949. package/src/components/DescriptionList/description-list.principles.stories.tsx +323 -0
  950. package/src/components/DescriptionList/description-list.spec.md +214 -0
  951. package/src/components/DescriptionList/description-list.stories.tsx +128 -0
  952. package/src/components/DescriptionList/description-list.tsx +2 -2
  953. package/src/components/DescriptionList/index.ts +5 -0
  954. package/src/components/Dialog/dialog.anatomy.stories.tsx +484 -0
  955. package/src/components/Dialog/dialog.principles.stories.tsx +313 -0
  956. package/src/components/Dialog/dialog.spec.md +201 -0
  957. package/src/components/Dialog/dialog.stories.tsx +500 -0
  958. package/src/components/Dialog/dialog.tsx +4 -4
  959. package/src/components/Dialog/index.ts +5 -0
  960. package/src/components/DropdownMenu/dropdown-menu.anatomy.stories.tsx +969 -0
  961. package/src/components/DropdownMenu/dropdown-menu.principles.stories.tsx +340 -0
  962. package/src/components/DropdownMenu/dropdown-menu.spec.md +265 -0
  963. package/src/components/DropdownMenu/dropdown-menu.stories.tsx +288 -0
  964. package/src/components/DropdownMenu/dropdown-menu.tsx +14 -5
  965. package/src/components/DropdownMenu/index.ts +5 -0
  966. package/src/components/Empty/empty.anatomy.stories.tsx +275 -0
  967. package/src/components/Empty/empty.principles.stories.tsx +314 -0
  968. package/src/components/Empty/empty.spec.md +215 -0
  969. package/src/components/Empty/empty.stories.tsx +80 -0
  970. package/src/components/Empty/empty.tsx +13 -6
  971. package/src/components/Empty/index.ts +5 -0
  972. package/src/components/Field/field-context.ts +98 -0
  973. package/src/components/Field/field-controls.spec.md +366 -0
  974. package/src/components/Field/field-types.ts +1 -1
  975. package/src/components/Field/field.anatomy.stories.tsx +541 -0
  976. package/src/components/Field/field.principles.stories.tsx +277 -0
  977. package/src/components/Field/field.spec.md +438 -0
  978. package/src/components/Field/field.stories.tsx +598 -0
  979. package/src/components/Field/field.tsx +2 -2
  980. package/src/components/Field/form-validation.spec.md +150 -0
  981. package/src/components/Field/index.ts +5 -0
  982. package/src/components/FieldControlGroup/field-control-group.anatomy.stories.tsx +117 -0
  983. package/src/components/FieldControlGroup/field-control-group.principles.stories.tsx +117 -0
  984. package/src/components/FieldControlGroup/field-control-group.spec.md +179 -0
  985. package/src/components/FieldControlGroup/field-control-group.stories.tsx +161 -0
  986. package/src/components/FieldControlGroup/field-control-group.tsx +5 -5
  987. package/src/components/FieldControlGroup/index.ts +5 -0
  988. package/src/components/FileItem/file-item.anatomy.stories.tsx +354 -0
  989. package/src/components/FileItem/file-item.principles.stories.tsx +275 -0
  990. package/src/components/FileItem/file-item.spec.md +491 -0
  991. package/src/components/FileItem/file-item.stories.tsx +265 -0
  992. package/src/components/FileItem/file-item.tsx +37 -13
  993. package/src/components/FileItem/index.ts +5 -0
  994. package/src/components/FileUpload/file-upload.anatomy.stories.tsx +444 -0
  995. package/src/components/FileUpload/file-upload.principles.stories.tsx +314 -0
  996. package/src/components/FileUpload/file-upload.spec.md +134 -0
  997. package/src/components/FileUpload/file-upload.stories.tsx +167 -0
  998. package/src/components/FileUpload/file-upload.tsx +75 -26
  999. package/src/components/FileUpload/index.ts +5 -0
  1000. package/src/components/FileViewer/file-viewer.anatomy.stories.tsx +1122 -0
  1001. package/src/components/FileViewer/file-viewer.principles.stories.tsx +636 -0
  1002. package/src/components/FileViewer/file-viewer.spec.md +380 -0
  1003. package/src/components/FileViewer/file-viewer.stories.tsx +407 -0
  1004. package/src/components/FileViewer/file-viewer.tsx +10 -9
  1005. package/src/components/FileViewer/index.ts +5 -0
  1006. package/src/components/HoverCard/hover-card.anatomy.stories.tsx +145 -0
  1007. package/src/components/HoverCard/hover-card.principles.stories.tsx +222 -0
  1008. package/src/components/HoverCard/hover-card.spec.md +157 -0
  1009. package/src/components/HoverCard/hover-card.stories.tsx +304 -0
  1010. package/src/components/HoverCard/hover-card.tsx +3 -3
  1011. package/src/components/HoverCard/index.ts +5 -0
  1012. package/src/components/Input/index.ts +5 -0
  1013. package/src/components/Input/input.anatomy.stories.tsx +763 -0
  1014. package/src/components/Input/input.principles.stories.tsx +292 -0
  1015. package/src/components/Input/input.spec.md +195 -0
  1016. package/src/components/Input/input.stories.tsx +133 -0
  1017. package/src/components/Input/input.tsx +17 -14
  1018. package/src/components/LinkInput/index.ts +5 -0
  1019. package/src/components/LinkInput/link-input.anatomy.stories.tsx +746 -0
  1020. package/src/components/LinkInput/link-input.principles.stories.tsx +182 -0
  1021. package/src/components/LinkInput/link-input.spec.md +131 -0
  1022. package/src/components/LinkInput/link-input.stories.tsx +132 -0
  1023. package/src/components/LinkInput/link-input.tsx +9 -8
  1024. package/src/components/Menu/index.ts +5 -0
  1025. package/src/components/Menu/menu-item.anatomy.stories.tsx +780 -0
  1026. package/src/components/Menu/menu-item.principles.stories.tsx +81 -0
  1027. package/src/components/Menu/menu-item.spec.md +292 -0
  1028. package/src/components/Menu/menu-item.stories.tsx +214 -0
  1029. package/src/components/Menu/menu-item.tsx +1 -0
  1030. package/src/components/Notice/index.ts +5 -0
  1031. package/src/components/Notice/notice.anatomy.stories.tsx +610 -0
  1032. package/src/components/Notice/notice.principles.stories.tsx +102 -0
  1033. package/src/components/Notice/notice.spec.md +151 -0
  1034. package/src/components/Notice/notice.stories.tsx +257 -0
  1035. package/src/components/Notice/notice.tsx +3 -2
  1036. package/src/components/NumberInput/index.ts +5 -0
  1037. package/src/components/NumberInput/number-input.anatomy.stories.tsx +786 -0
  1038. package/src/components/NumberInput/number-input.principles.stories.tsx +221 -0
  1039. package/src/components/NumberInput/number-input.spec.md +125 -0
  1040. package/src/components/NumberInput/number-input.stories.tsx +142 -0
  1041. package/src/components/NumberInput/number-input.tsx +9 -10
  1042. package/src/components/OverflowIndicator/index.ts +5 -0
  1043. package/src/components/OverflowIndicator/overflow-indicator.anatomy.stories.tsx +548 -0
  1044. package/src/components/OverflowIndicator/overflow-indicator.principles.stories.tsx +80 -0
  1045. package/src/components/OverflowIndicator/overflow-indicator.spec.md +119 -0
  1046. package/src/components/OverflowIndicator/overflow-indicator.stories.tsx +274 -0
  1047. package/src/components/OverflowIndicator/overflow-indicator.tsx +9 -2
  1048. package/src/components/PeoplePicker/index.ts +5 -0
  1049. package/src/components/PeoplePicker/people-picker-helpers.ts +5 -5
  1050. package/src/components/PeoplePicker/people-picker.anatomy.stories.tsx +418 -0
  1051. package/src/components/PeoplePicker/people-picker.principles.stories.tsx +192 -0
  1052. package/src/components/PeoplePicker/people-picker.spec.md +278 -0
  1053. package/src/components/PeoplePicker/people-picker.stories.tsx +163 -0
  1054. package/src/components/PeoplePicker/people-picker.tsx +15 -14
  1055. package/src/components/PeoplePicker/person-display.tsx +26 -26
  1056. package/src/components/Popover/index.ts +5 -0
  1057. package/src/components/Popover/popover.anatomy.stories.tsx +277 -0
  1058. package/src/components/Popover/popover.principles.stories.tsx +293 -0
  1059. package/src/components/Popover/popover.spec.md +200 -0
  1060. package/src/components/Popover/popover.stories.tsx +116 -0
  1061. package/src/components/Popover/popover.tsx +2 -2
  1062. package/src/components/ProfileCard/index.ts +5 -0
  1063. package/src/components/ProfileCard/profile-card.anatomy.stories.tsx +504 -0
  1064. package/src/components/ProfileCard/profile-card.principles.stories.tsx +221 -0
  1065. package/src/components/ProfileCard/profile-card.spec.md +171 -0
  1066. package/src/components/ProfileCard/profile-card.stories.tsx +53 -0
  1067. package/src/components/{NameCard/name-card.tsx → ProfileCard/profile-card.tsx} +25 -24
  1068. package/src/components/ProgressBar/index.ts +5 -0
  1069. package/src/components/ProgressBar/progress-bar.anatomy.stories.tsx +438 -0
  1070. package/src/components/ProgressBar/progress-bar.principles.stories.tsx +337 -0
  1071. package/src/components/ProgressBar/progress-bar.spec.md +232 -0
  1072. package/src/components/ProgressBar/progress-bar.stories.tsx +119 -0
  1073. package/src/components/ProgressBar/progress-bar.tsx +4 -4
  1074. package/src/components/RadioGroup/index.ts +5 -0
  1075. package/src/components/RadioGroup/radio-group.anatomy.stories.tsx +678 -0
  1076. package/src/components/RadioGroup/radio-group.principles.stories.tsx +170 -0
  1077. package/src/components/RadioGroup/radio-group.spec.md +141 -0
  1078. package/src/components/RadioGroup/radio-group.stories.tsx +101 -0
  1079. package/src/components/RadioGroup/radio-group.tsx +41 -41
  1080. package/src/components/Rating/index.ts +5 -0
  1081. package/src/components/Rating/rating.anatomy.stories.tsx +494 -0
  1082. package/src/components/Rating/rating.principles.stories.tsx +293 -0
  1083. package/src/components/Rating/rating.spec.md +208 -0
  1084. package/src/components/Rating/rating.stories.tsx +133 -0
  1085. package/src/components/Rating/rating.tsx +23 -12
  1086. package/src/components/ScrollArea/index.ts +5 -0
  1087. package/src/components/ScrollArea/scroll-area.anatomy.stories.tsx +431 -0
  1088. package/src/components/ScrollArea/scroll-area.principles.stories.tsx +337 -0
  1089. package/src/components/ScrollArea/scroll-area.spec.md +145 -0
  1090. package/src/components/ScrollArea/scroll-area.stories.tsx +193 -0
  1091. package/src/components/ScrollArea/scroll-area.tsx +1 -1
  1092. package/src/components/SegmentedControl/index.ts +5 -0
  1093. package/src/components/SegmentedControl/segmented-control.anatomy.stories.tsx +295 -0
  1094. package/src/components/SegmentedControl/segmented-control.principles.stories.tsx +281 -0
  1095. package/src/components/SegmentedControl/segmented-control.spec.md +296 -0
  1096. package/src/components/SegmentedControl/segmented-control.stories.tsx +33 -0
  1097. package/src/components/SegmentedControl/segmented-control.tsx +9 -10
  1098. package/src/components/Select/index.ts +5 -0
  1099. package/src/components/Select/select.anatomy.stories.tsx +827 -0
  1100. package/src/components/Select/select.principles.stories.tsx +311 -0
  1101. package/src/components/Select/select.spec.md +311 -0
  1102. package/src/components/Select/select.stories.tsx +198 -0
  1103. package/src/components/Select/select.tsx +17 -11
  1104. package/src/components/SelectMenu/index.ts +5 -0
  1105. package/src/components/SelectMenu/select-menu.anatomy.stories.tsx +811 -0
  1106. package/src/components/SelectMenu/select-menu.principles.stories.tsx +107 -0
  1107. package/src/components/SelectMenu/select-menu.spec.md +222 -0
  1108. package/src/components/SelectMenu/select-menu.stories.tsx +148 -0
  1109. package/src/components/SelectMenu/select-menu.tsx +20 -6
  1110. package/src/components/SelectionControl/index.ts +5 -0
  1111. package/src/components/SelectionControl/selection-item.anatomy.stories.tsx +571 -0
  1112. package/src/components/SelectionControl/selection-item.principles.stories.tsx +77 -0
  1113. package/src/components/SelectionControl/selection-item.spec.md +130 -0
  1114. package/src/components/SelectionControl/selection-item.stories.tsx +137 -0
  1115. package/src/components/Separator/index.ts +5 -0
  1116. package/src/components/Separator/separator.anatomy.stories.tsx +125 -0
  1117. package/src/components/Separator/separator.principles.stories.tsx +141 -0
  1118. package/src/components/Separator/separator.spec.md +109 -0
  1119. package/src/components/Separator/separator.stories.tsx +127 -0
  1120. package/src/components/Separator/separator.tsx +2 -2
  1121. package/src/components/Sheet/index.ts +5 -0
  1122. package/src/components/Sheet/sheet.anatomy.stories.tsx +268 -0
  1123. package/src/components/Sheet/sheet.principles.stories.tsx +370 -0
  1124. package/src/components/Sheet/sheet.spec.md +148 -0
  1125. package/src/components/Sheet/sheet.stories.tsx +168 -0
  1126. package/src/components/Sheet/sheet.tsx +1 -1
  1127. package/src/components/Sidebar/index.ts +5 -0
  1128. package/src/components/Sidebar/sidebar.anatomy.stories.tsx +763 -0
  1129. package/src/components/Sidebar/sidebar.principles.stories.tsx +505 -0
  1130. package/src/components/Sidebar/sidebar.spec.md +711 -0
  1131. package/src/components/Sidebar/sidebar.stories.tsx +482 -0
  1132. package/src/components/Sidebar/sidebar.tsx +5 -2
  1133. package/src/components/Skeleton/index.ts +5 -0
  1134. package/src/components/Skeleton/skeleton.anatomy.stories.tsx +145 -0
  1135. package/src/components/Skeleton/skeleton.principles.stories.tsx +221 -0
  1136. package/src/components/Skeleton/skeleton.spec.md +104 -0
  1137. package/src/components/Skeleton/skeleton.stories.tsx +129 -0
  1138. package/src/components/Slider/index.ts +5 -0
  1139. package/src/components/Slider/slider.anatomy.stories.tsx +235 -0
  1140. package/src/components/Slider/slider.principles.stories.tsx +250 -0
  1141. package/src/components/Slider/slider.spec.md +353 -0
  1142. package/src/components/Slider/slider.stories.tsx +115 -0
  1143. package/src/components/Slider/slider.tsx +26 -5
  1144. package/src/components/Steps/index.ts +5 -0
  1145. package/src/components/Steps/steps.anatomy.stories.tsx +448 -0
  1146. package/src/components/Steps/steps.principles.stories.tsx +303 -0
  1147. package/src/components/Steps/steps.spec.md +473 -0
  1148. package/src/components/Steps/steps.stories.tsx +370 -0
  1149. package/src/components/Steps/steps.tsx +28 -11
  1150. package/src/components/Switch/index.ts +5 -0
  1151. package/src/components/Switch/switch.anatomy.stories.tsx +227 -0
  1152. package/src/components/Switch/switch.principles.stories.tsx +174 -0
  1153. package/src/components/Switch/switch.spec.md +221 -0
  1154. package/src/components/Switch/switch.stories.tsx +107 -0
  1155. package/src/components/Switch/switch.tsx +22 -18
  1156. package/src/components/Tabs/index.ts +5 -0
  1157. package/src/components/Tabs/tabs.anatomy.stories.tsx +414 -0
  1158. package/src/components/Tabs/tabs.principles.stories.tsx +257 -0
  1159. package/src/components/Tabs/tabs.spec.md +316 -0
  1160. package/src/components/Tabs/tabs.stories.tsx +155 -0
  1161. package/src/components/Tabs/tabs.tsx +6 -5
  1162. package/src/components/Tag/index.ts +5 -0
  1163. package/src/components/Tag/tag.anatomy.stories.tsx +664 -0
  1164. package/src/components/Tag/tag.principles.stories.tsx +270 -0
  1165. package/src/components/Tag/tag.spec.md +304 -0
  1166. package/src/components/Tag/tag.stories.tsx +69 -0
  1167. package/src/components/Tag/tag.tsx +52 -56
  1168. package/src/components/Textarea/index.ts +5 -0
  1169. package/src/components/Textarea/textarea.anatomy.stories.tsx +304 -0
  1170. package/src/components/Textarea/textarea.principles.stories.tsx +175 -0
  1171. package/src/components/Textarea/textarea.spec.md +150 -0
  1172. package/src/components/Textarea/textarea.stories.tsx +53 -0
  1173. package/src/components/Textarea/textarea.tsx +16 -14
  1174. package/src/components/TimePicker/index.ts +5 -0
  1175. package/src/components/TimePicker/time-picker.anatomy.stories.tsx +275 -0
  1176. package/src/components/TimePicker/time-picker.principles.stories.tsx +140 -0
  1177. package/src/components/TimePicker/time-picker.spec.md +270 -0
  1178. package/src/components/TimePicker/time-picker.stories.tsx +193 -0
  1179. package/src/components/TimePicker/time-picker.tsx +29 -12
  1180. package/src/components/Toast/index.ts +5 -0
  1181. package/src/components/Toast/toast.anatomy.stories.tsx +324 -0
  1182. package/src/components/Toast/toast.principles.stories.tsx +217 -0
  1183. package/src/components/Toast/toast.spec.md +178 -0
  1184. package/src/components/Toast/toast.stories.tsx +119 -0
  1185. package/src/components/Toast/toast.tsx +1 -1
  1186. package/src/components/Tooltip/index.ts +5 -0
  1187. package/src/components/Tooltip/tooltip.anatomy.stories.tsx +413 -0
  1188. package/src/components/Tooltip/tooltip.principles.stories.tsx +204 -0
  1189. package/src/components/Tooltip/tooltip.spec.md +139 -0
  1190. package/src/components/Tooltip/tooltip.stories.tsx +116 -0
  1191. package/src/components/Tooltip/tooltip.tsx +1 -0
  1192. package/src/components/TreeView/index.ts +5 -0
  1193. package/src/components/TreeView/tree-view.anatomy.stories.tsx +410 -0
  1194. package/src/components/TreeView/tree-view.principles.stories.tsx +190 -0
  1195. package/src/components/TreeView/tree-view.spec.md +388 -0
  1196. package/src/components/TreeView/tree-view.stories.tsx +297 -0
  1197. package/src/components/TreeView/tree-view.tsx +49 -16
  1198. package/src/hooks/use-overflow-items.ts +10 -6
  1199. package/src/index.ts +73 -69
  1200. package/src/lib/utils.ts +2 -1
  1201. package/src/patterns/README.md +15 -11
  1202. package/src/patterns/action-bar/action-bar.spec.md +458 -0
  1203. package/src/patterns/action-bar/action-bar.stories.tsx +612 -0
  1204. package/src/patterns/element-anatomy/element-anatomy.spec.md +215 -0
  1205. package/src/patterns/element-anatomy/index.ts +5 -0
  1206. package/src/patterns/element-anatomy/inline-action.spec.md +320 -0
  1207. package/src/patterns/element-anatomy/item-anatomy.spec.md +1042 -0
  1208. package/src/patterns/element-anatomy/item-anatomy.stories.tsx +1622 -0
  1209. package/src/patterns/element-anatomy/item-anatomy.tsx +6 -2
  1210. package/src/patterns/header-canonical/chrome-header.tsx +13 -3
  1211. package/src/patterns/header-canonical/header-canonical.css +2 -2
  1212. package/src/patterns/header-canonical/header-canonical.spec.md +310 -0
  1213. package/src/patterns/header-canonical/header-canonical.stories.tsx +150 -0
  1214. package/src/patterns/header-canonical/index.ts +5 -0
  1215. package/src/patterns/horizontal-overflow/horizontal-overflow.spec.md +201 -0
  1216. package/src/patterns/horizontal-overflow/index.ts +5 -0
  1217. package/src/patterns/overlay-surface/index.ts +5 -0
  1218. package/src/patterns/overlay-surface/overlay-surface.spec.md +435 -0
  1219. package/src/patterns/overlay-surface/overlay-surface.tsx +4 -2
  1220. package/src/patterns/resize-handle/index.ts +5 -0
  1221. package/src/patterns/resize-handle/resize-handle.spec.md +111 -0
  1222. package/src/patterns/resize-handle/resize-handle.stories.tsx +71 -0
  1223. package/src/story-governance/category-matrix.ts +55 -0
  1224. package/src/styles/base.css +85 -0
  1225. package/src/styles/tokens.css +11 -0
  1226. package/src/tokens/README.md +2 -0
  1227. package/src/tokens/categorical-color.ts +164 -0
  1228. package/src/tokens/color/color.spec.md +790 -0
  1229. package/src/tokens/color/color.stories.tsx +363 -0
  1230. package/src/tokens/color/primitives.css +7 -0
  1231. package/src/tokens/color/semantic.css +20 -11
  1232. package/src/tokens/density/density.spec.md +127 -0
  1233. package/src/tokens/density/density.stories.tsx +240 -0
  1234. package/src/tokens/elevation/elevation.spec.md +79 -0
  1235. package/src/tokens/elevation/elevation.stories.tsx +98 -0
  1236. package/src/tokens/layoutSpace/layoutSpace.css +1 -1
  1237. package/src/tokens/layoutSpace/layoutSpace.spec.md +313 -0
  1238. package/src/tokens/layoutSpace/layoutSpace.stories.tsx +75 -0
  1239. package/src/tokens/motion/motion.css +2 -2
  1240. package/src/tokens/motion/motion.spec.md +97 -0
  1241. package/src/tokens/motion/motion.ts +1 -1
  1242. package/src/tokens/opacity/opacity.spec.md +84 -0
  1243. package/src/tokens/opacity/opacity.stories.tsx +69 -0
  1244. package/src/tokens/orphan-tokens.spec.md +117 -0
  1245. package/src/tokens/radius/radius.spec.md +128 -0
  1246. package/src/tokens/radius/radius.stories.tsx +86 -0
  1247. package/src/tokens/token-system.spec.md +243 -0
  1248. package/src/tokens/typography/typography.spec.md +208 -0
  1249. package/src/tokens/typography/typography.stories.tsx +133 -0
  1250. package/src/tokens/uiSize/icon-size.ts +1 -2
  1251. package/src/tokens/uiSize/uiSize.css +16 -0
  1252. package/src/tokens/uiSize/uiSize.spec.md +439 -0
  1253. package/dist/components/NameCard/name-card.d.ts.map +0 -1
  1254. package/dist/components/NameCard/name-card.js.map +0 -1
  1255. /package/dist/{style.css → react-day-picker.css} +0 -0
@@ -0,0 +1,780 @@
1
+ // @anatomy-rationale:
2
+ // StateBehavior covered by ColorMatrix「State 色彩對照」段(default / hover /
3
+ // selected / disabled,單選 × 多選 = 8 組合)+ Header 子段。Menu item
4
+ // 狀態本身就是色彩變化(bg / text / icon / desc 四 token),分到獨立 5.
5
+ // 會與 ColorMatrix 重複。
6
+ import type { Meta } from '@storybook/react'
7
+ import { useState, useEffect } from 'react'
8
+ import { Mail, Bell, FileText } from 'lucide-react'
9
+ import { MenuItem, MenuGroup } from './menu-item'
10
+ import { Tag } from '@/design-system/components/Tag/tag'
11
+ // Avatar is now passed as AvatarData (data object), rendered internally by MenuItem
12
+
13
+ const meta: Meta = {
14
+ title: 'Design System/Internal/Menu/設計規格',
15
+ tags: ['!dev'],
16
+ parameters: { layout: 'padded' },
17
+ }
18
+ export default meta
19
+
20
+ /* ═══════════════════════════════════════════════════════════════════════════
21
+ Types & Data
22
+ ═══════════════════════════════════════════════════════════════════════════ */
23
+
24
+ type SizeKey = 'sm' | 'md' | 'lg'
25
+ type StateKey = 'default' | 'hover' | 'selected' | 'disabled'
26
+ type ModeKey = 'single' | 'multi'
27
+ type ColorSpec = { bg: string; text: string; icon: string; desc: string }
28
+
29
+ const SIZES: SizeKey[] = ['sm', 'md', 'lg']
30
+ const STATES: StateKey[] = ['default', 'hover', 'selected', 'disabled']
31
+
32
+ /** 單選 token map */
33
+ const SINGLE_TOKEN_MAP: Record<StateKey, ColorSpec> = {
34
+ default: { bg: 'transparent', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
35
+ hover: { bg: '--neutral-hover', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
36
+ selected: { bg: '--neutral-selected',text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
37
+ disabled: { bg: 'transparent', text: '--fg-disabled',icon: '--fg-disabled', desc: '--fg-disabled' },
38
+ }
39
+
40
+ /** 多選 token map */
41
+ const MULTI_TOKEN_MAP: Record<StateKey, ColorSpec> = {
42
+ default: { bg: 'transparent', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
43
+ hover: { bg: '--neutral-hover', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
44
+ selected: { bg: 'transparent', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
45
+ disabled: { bg: 'transparent', text: '--fg-disabled',icon: '--fg-disabled', desc: '--fg-disabled' },
46
+ }
47
+
48
+ interface SizeSpec {
49
+ heightToken: string
50
+ labelFont: string; labelSize: string
51
+ descFont: string; descSize: string
52
+ icon: number
53
+ checkbox: string
54
+ avatarInline: number; avatarBlock: number
55
+ py: string
56
+ }
57
+
58
+ const SIZE_SPECS: Record<SizeKey, SizeSpec> = {
59
+ sm: {
60
+ heightToken: '--field-height-sm',
61
+ labelFont: 'text-body leading-compact', labelSize: '14px × 1.3',
62
+ descFont: 'text-caption', descSize: '12px × 1.3',
63
+ icon: 16, checkbox: 'sm (16px)',
64
+ avatarInline: 20, avatarBlock: 32,
65
+ py: 'calc((var(--field-height-sm) − 一行文字高度) / 2)',
66
+ },
67
+ md: {
68
+ heightToken: '--field-height-md',
69
+ labelFont: 'text-body leading-compact', labelSize: '14px × 1.3',
70
+ descFont: 'text-caption', descSize: '12px × 1.3',
71
+ icon: 16, checkbox: 'md (16px)',
72
+ avatarInline: 24, avatarBlock: 32,
73
+ py: 'calc((var(--field-height-md) − 一行文字高度) / 2)',
74
+ },
75
+ lg: {
76
+ heightToken: '--field-height-lg',
77
+ labelFont: 'text-body-lg leading-compact', labelSize: '16px × 1.3',
78
+ descFont: 'text-body leading-compact', descSize: '14px × 1.3',
79
+ icon: 20, checkbox: 'lg (20px)',
80
+ avatarInline: 24, avatarBlock: 40,
81
+ py: 'calc((var(--field-height-lg) − 一行文字高度) / 2)',
82
+ },
83
+ }
84
+
85
+ /* ═══════════════════════════════════════════════════════════════════════════
86
+ Shared UI
87
+
88
+ NOTE: Kept local (not imported from `_anatomy/anatomy-utils`) because the
89
+ Button-family inspector layout diverges visually from the 通用 helpers:
90
+ H3 `text-h6 font-semibold` (not `text-body font-bold mb-2`), Desc has no
91
+ bottom margin, Th/Td use `p-2 border-b border-divider` row style, and
92
+ Swatch defaults to `size="md"` for inline token chips.
93
+ ═══════════════════════════════════════════════════════════════════════════ */
94
+
95
+ const H3 = ({ children }: { children: React.ReactNode }) => (
96
+ <h3 className="text-h6 font-semibold text-foreground">{children}</h3>
97
+ )
98
+ const Desc = ({ children }: { children: React.ReactNode }) => (
99
+ <p className="text-caption text-fg-muted max-w-[720px]">{children}</p>
100
+ )
101
+ const Th = ({ children }: { children: React.ReactNode }) => (
102
+ <th className="text-left p-2 border-b border-divider text-fg-muted font-medium text-caption whitespace-nowrap">{children}</th>
103
+ )
104
+ const Td = ({ children, mono }: { children: React.ReactNode; mono?: boolean }) => (
105
+ <td className={`p-2 border-b border-divider align-top whitespace-nowrap text-caption ${mono ? 'font-mono' : ''}`}>{children}</td>
106
+ )
107
+ const TkVal = ({ token, value }: { token: string; value?: string }) => (
108
+ <div className="flex flex-col gap-0.5">
109
+ <span className="font-mono text-[12px] text-fg-secondary">{token}</span>
110
+ {value && <span className="font-mono text-[10px] text-fg-muted">{value}</span>}
111
+ </div>
112
+ )
113
+
114
+ const Swatch = ({ value, size = 'md' }: { value: string; size?: 'sm' | 'md' }) => {
115
+ const s = size === 'sm' ? 'w-3 h-3' : 'w-4 h-4'
116
+ if (value === 'transparent') {
117
+ return <span className={`${s} rounded-md shrink-0 border border-border`}
118
+ style={{ backgroundImage: 'linear-gradient(45deg,#ddd 25%,transparent 25%,transparent 75%,#ddd 75%),linear-gradient(45deg,#ddd 25%,transparent 25%,transparent 75%,#ddd 75%)', backgroundSize: '6px 6px', backgroundPosition: '0 0,3px 3px' }} />
119
+ }
120
+ return <span className={`${s} rounded-md shrink-0 border border-black/10`} style={{ backgroundColor: `var(${value})` }} />
121
+ }
122
+
123
+ const TokenAnnotation = ({ colors }: { colors: ColorSpec }) => (
124
+ <div className="flex flex-col gap-0.5 mt-2">
125
+ {([['bg', 'bg'], ['text', 'label'], ['icon', 'icon'], ['desc', 'desc']] as const).map(([key, label]) => (
126
+ <span key={key} className="inline-flex items-center gap-1 text-[10px]">
127
+ <Swatch value={colors[key]} size="sm" />
128
+ <span className="text-fg-muted w-7 shrink-0">{label}</span>
129
+ <span className="font-mono text-fg-secondary">{colors[key]}</span>
130
+ </span>
131
+ ))}
132
+ </div>
133
+ )
134
+
135
+ const Tab = ({ active, onClick, disabled, children }: { active: boolean; onClick: () => void; disabled?: boolean; children: React.ReactNode }) => {
136
+ if (disabled) return <span className="px-2.5 py-1 text-[12px] font-mono rounded-md text-fg-disabled bg-neutral-hover cursor-not-allowed">{children}</span>
137
+ return (
138
+ <button type="button" onClick={onClick}
139
+ className={`px-2.5 py-1 text-[12px] font-mono rounded-md cursor-pointer transition-colors ${
140
+ active ? 'bg-primary text-white font-semibold' : 'bg-neutral-hover text-fg-secondary hover:bg-neutral-active'
141
+ }`}>
142
+ {children}
143
+ </button>
144
+ )
145
+ }
146
+
147
+ const PropRow = ({ label, dot, children }: { label: string; dot?: string; children: React.ReactNode }) => (
148
+ <div className="flex items-start gap-3 py-2 border-b border-divider last:border-b-0">
149
+ <span className="text-[11px] text-fg-muted font-medium w-[80px] shrink-0 pt-0.5 flex items-center gap-1.5">
150
+ {dot && <span className="w-2 h-2 rounded-full shrink-0" style={{ backgroundColor: dot }} />}
151
+ {label}
152
+ </span>
153
+ <div className="flex-1 text-[12px] font-mono text-fg-secondary">{children}</div>
154
+ </div>
155
+ )
156
+
157
+ const TokenValue = ({ value }: { value: string }) => (
158
+ <span className="inline-flex items-center gap-2"><Swatch value={value} /><span>{value}</span></span>
159
+ )
160
+
161
+ /* ── Blueprint zone colors ── */
162
+ const Z = {
163
+ pad: { bg: 'rgba(194,225,154,0.6)', border: 'rgba(139,179,91,0.9)', text: '#5a7a2e' },
164
+ prefix: { bg: 'rgba(166,208,245,0.6)', border: 'rgba(80,145,210,0.9)', text: '#2d6a9f' },
165
+ gap: { bg: 'rgba(253,218,158,0.6)', border: 'rgba(218,165,60,0.9)', text: '#8a6010' },
166
+ content: { bg: 'rgba(199,178,230,0.6)', border: 'rgba(138,103,190,0.9)', text: '#6035a8' },
167
+ suffix: { bg: 'rgba(251,191,206,0.6)', border: 'rgba(220,110,140,0.9)', text: '#a33060' },
168
+ dim: { text: '#d04040' },
169
+ }
170
+
171
+ /** Horizontal zone block */
172
+ const BpZoneH = ({ w, color, label, sub }: { w: number; color: { bg: string; border: string; text: string }; label: string; sub?: string }) => (
173
+ <div className="flex flex-col items-center justify-center shrink-0 gap-0.5"
174
+ style={{ width: w, height: '100%', background: color.bg, borderLeft: `1.5px dashed ${color.border}`, borderRight: `1.5px dashed ${color.border}` }}>
175
+ <span className="text-[10px] font-mono font-bold leading-none" style={{ color: color.text }}>{label}</span>
176
+ {sub && <span className="text-[9px] font-mono leading-none opacity-70" style={{ color: color.text }}>{sub}</span>}
177
+ </div>
178
+ )
179
+
180
+ /** Vertical zone block (full width, fixed height) */
181
+ const BpZoneV = ({ h, color, label, sub }: { h: number; color: { bg: string; border: string; text: string }; label: string; sub?: string }) => (
182
+ <div className="flex items-center justify-center gap-1.5"
183
+ style={{ height: h, width: '100%', background: color.bg, borderTop: `1.5px dashed ${color.border}`, borderBottom: `1.5px dashed ${color.border}` }}>
184
+ <span className="text-[10px] font-mono font-bold leading-none" style={{ color: color.text }}>{label}</span>
185
+ {sub && <span className="text-[9px] font-mono leading-none opacity-70" style={{ color: color.text }}>{sub}</span>}
186
+ </div>
187
+ )
188
+
189
+ const MenuContainer = ({ children, width = 320 }: { children: React.ReactNode; width?: number }) => (
190
+ <div className="rounded-lg bg-surface-raised border border-border overflow-hidden"
191
+ style={{ boxShadow: 'var(--elevation-200)', width }}>
192
+ {children}
193
+ </div>
194
+ )
195
+
196
+
197
+ /* ═══════════════════════════════════════════════════════════════════════════
198
+ 1. 元件總覽
199
+ ═══════════════════════════════════════════════════════════════════════════ */
200
+
201
+ export const Overview = {
202
+ name: '元件總覽',
203
+ render: () => (
204
+ <div className="flex flex-col gap-8">
205
+ {/* Anatomy */}
206
+ <div className="flex flex-col gap-4">
207
+ <div className="flex flex-col gap-1">
208
+ <H3>結構(Anatomy)</H3>
209
+ <Desc>三個區域:prefix(checkbox + icon 或 avatar)、content(label + description)、suffix(tag)。prefix 內 checkbox 和 icon/avatar 由對齊容器統一管理。</Desc>
210
+ </div>
211
+ <div className="flex flex-col gap-4">
212
+ {/* Full structure */}
213
+ <div className="flex flex-col gap-2 items-start">
214
+ <span className="text-[11px] text-fg-muted font-medium">完整結構</span>
215
+ <div className="inline-flex items-center border-2 border-dashed border-primary/30 rounded-md px-3 py-2.5 gap-2">
216
+ {[
217
+ { name: 'checkbox', color: 'warning' },
218
+ { name: 'startIcon | avatar', color: 'info' },
219
+ { name: 'label', color: 'success' },
220
+ { name: 'description', color: 'magenta' },
221
+ { name: 'tag', color: 'warning' },
222
+ ].map((s) => (
223
+ <span key={s.name} className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
224
+ style={{ borderColor: `var(--${s.color})`, backgroundColor: `var(--${s.color}-subtle)`, color: `var(--${s.color})` }}>{s.name}</span>
225
+ ))}
226
+ </div>
227
+ <span className="text-[10px] text-fg-muted font-mono">
228
+ prefix: [checkbox?] [startIcon? | avatar?] &middot; content: [label + description?] &middot; suffix: [tag?]
229
+ </span>
230
+ </div>
231
+
232
+ {/* Prefix alignment modes */}
233
+ <div className="flex gap-8">
234
+ <div className="flex flex-col gap-2 items-start">
235
+ <span className="text-[11px] text-fg-muted font-medium">Inline 對齊(prefix &le; 24px)</span>
236
+ <div className="inline-flex items-center border-2 border-dashed border-primary/30 rounded-md px-3 py-2.5 gap-2">
237
+ <span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
238
+ style={{ borderColor: 'var(--info)', backgroundColor: 'var(--info-subtle)', color: 'var(--info)' }}>icon 16px</span>
239
+ <div className="flex flex-col gap-0.5">
240
+ <span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
241
+ style={{ borderColor: 'var(--success)', backgroundColor: 'var(--success-subtle)', color: 'var(--success)' }}>label</span>
242
+ <span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
243
+ style={{ borderColor: 'var(--color-magenta-6)', backgroundColor: 'var(--color-magenta-1)', color: 'var(--color-magenta-6)' }}>description</span>
244
+ </div>
245
+ </div>
246
+ <span className="text-[10px] text-fg-muted font-mono">prefix 容器高度 = 一行文字高度,對齊第一行 label</span>
247
+ </div>
248
+ <div className="flex flex-col gap-2 items-start">
249
+ <span className="text-[11px] text-fg-muted font-medium">Block 對齊(avatar &gt; 24px + description)</span>
250
+ <div className="inline-flex items-center border-2 border-dashed border-primary/30 rounded-md px-3 py-2.5 gap-2">
251
+ <span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
252
+ style={{ borderColor: 'var(--info)', backgroundColor: 'var(--info-subtle)', color: 'var(--info)' }}>avatar 32px</span>
253
+ <div className="flex flex-col gap-0.5">
254
+ <span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
255
+ style={{ borderColor: 'var(--success)', backgroundColor: 'var(--success-subtle)', color: 'var(--success)' }}>label</span>
256
+ <span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
257
+ style={{ borderColor: 'var(--color-magenta-6)', backgroundColor: 'var(--color-magenta-1)', color: 'var(--color-magenta-6)' }}>description</span>
258
+ </div>
259
+ </div>
260
+ <span className="text-[10px] text-fg-muted font-mono">prefix 容器高度 = label行高 + 2px + desc行高,對齊文字塊中心</span>
261
+ </div>
262
+ </div>
263
+ </div>
264
+ </div>
265
+
266
+ {/* Props */}
267
+ <div className="flex flex-col gap-3">
268
+ <H3>Props</H3>
269
+ <div className="overflow-x-auto">
270
+ <table className="text-caption border-collapse">
271
+ <thead><tr><Th>Prop</Th><Th>Type</Th><Th>Default</Th><Th>說明</Th></tr></thead>
272
+ <tbody>
273
+ {[
274
+ ['children', 'ReactNode', '(required)', 'Label 文字'],
275
+ ['description', 'ReactNode', '—', '次要說明,顯示在 label 下方'],
276
+ ['startIcon', 'LucideIcon', '—', '左側 icon,與 avatar 互斥'],
277
+ ['avatar', 'AvatarData', '—', '左側頭像資料({ src?, alt, color? }),元件內部渲染 Avatar。與 startIcon 互斥'],
278
+ ['checkbox', 'boolean', 'false', '顯示 checkbox(多選模式)'],
279
+ ['checked', "boolean | 'indeterminate'", 'false', 'checkbox 選中狀態'],
280
+ ['selected', 'boolean', 'false', '單選選中(bg-neutral-selected 背景)'],
281
+ ['tag', 'ReactNode', '—', '後綴 Tag,靠右對齊'],
282
+ ['disabled', 'boolean', 'false', '停用:文字 / startIcon 套 fg-disabled,checkbox 用 disabled 樣式,tag / endContent 套 opacity-disabled,avatar 不變'],
283
+ ['header', 'boolean', 'false', '群組標題,不可選不可 hover'],
284
+ ['size', "'sm' | 'md' | 'lg'", "'md'", '尺寸,對齊 field-height token'],
285
+ ['endContent', 'ReactNode', '—', '後綴自訂內容(DropdownMenu 的 badge/endIcon/shortcut 經由此注入)'],
286
+ ['labelMaxLines', "number | 'none'", '1', `標籤最大行數,'none' 不截斷`],
287
+ ['descMaxLines', "number | 'none'", '1', `描述最大行數,'none' 不截斷`],
288
+ ].map(([p, t, d, desc]) => (
289
+ <tr key={p}><Td mono>{p}</Td><Td mono>{t}</Td><Td mono>{d}</Td><Td>{desc}</Td></tr>
290
+ ))}
291
+ </tbody>
292
+ </table>
293
+ </div>
294
+ </div>
295
+ </div>
296
+ ),
297
+ }
298
+
299
+ /* ═══════════════════════════════════════════════════════════════════════════
300
+ 2. 元件檢閱器
301
+ ═══════════════════════════════════════════════════════════════════════════ */
302
+
303
+ const InspectorInner = () => {
304
+ const [size, setSize] = useState<SizeKey>('md')
305
+ const [mode, setMode] = useState<ModeKey>('single')
306
+ const [selected, setSelected] = useState(false)
307
+ const [disabled, setDisabled] = useState(false)
308
+ const [hasIcon, setHasIcon] = useState(true)
309
+ const [hasAvatar, setHasAvatar] = useState(false)
310
+ const [hasDesc, setHasDesc] = useState(false)
311
+ const [hasTag, setHasTag] = useState(false)
312
+
313
+ // avatar and icon are mutually exclusive
314
+ useEffect(() => { if (hasAvatar) setHasIcon(false) }, [hasAvatar])
315
+ useEffect(() => { if (hasIcon) setHasAvatar(false) }, [hasIcon])
316
+
317
+ const s = SIZE_SPECS[size]
318
+ const isMulti = mode === 'multi'
319
+ const stateKey: StateKey = disabled ? 'disabled' : selected ? 'selected' : 'default'
320
+ const colors = isMulti ? MULTI_TOKEN_MAP[stateKey] : SINGLE_TOKEN_MAP[stateKey]
321
+ const avatarPx = hasAvatar ? (hasDesc ? s.avatarBlock : s.avatarInline) : 0
322
+ const prefixAlign = avatarPx > 24 && hasDesc ? 'block' : 'inline'
323
+ const hasPrefix = isMulti || hasIcon || hasAvatar
324
+
325
+ return (
326
+ <div className="flex flex-col gap-6">
327
+ {/* Controls */}
328
+ <div className="flex flex-col gap-2.5">
329
+ <div className="flex items-center gap-2">
330
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">Size</span>
331
+ <div className="flex gap-1.5">
332
+ {SIZES.map((sz) => <Tab key={sz} active={size === sz} onClick={() => setSize(sz)}>{sz}</Tab>)}
333
+ </div>
334
+ </div>
335
+ <div className="flex items-center gap-2">
336
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">Mode</span>
337
+ <div className="flex gap-1.5">
338
+ <Tab active={mode === 'single'} onClick={() => setMode('single')}>single</Tab>
339
+ <Tab active={mode === 'multi'} onClick={() => setMode('multi')}>multi</Tab>
340
+ </div>
341
+ </div>
342
+ <div className="flex items-center gap-2">
343
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">selected</span>
344
+ <div className="flex gap-1.5">
345
+ <Tab active={!selected} onClick={() => setSelected(false)}>off</Tab>
346
+ <Tab active={selected} onClick={() => setSelected(true)}>on</Tab>
347
+ </div>
348
+ </div>
349
+ <div className="flex items-center gap-2">
350
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">disabled</span>
351
+ <div className="flex gap-1.5">
352
+ <Tab active={!disabled} onClick={() => setDisabled(false)}>off</Tab>
353
+ <Tab active={disabled} onClick={() => setDisabled(true)}>on</Tab>
354
+ </div>
355
+ </div>
356
+ <div className="flex items-center gap-2">
357
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">startIcon</span>
358
+ <div className="flex gap-1.5">
359
+ <Tab active={!hasIcon} onClick={() => setHasIcon(false)}>off</Tab>
360
+ <Tab active={hasIcon} onClick={() => setHasIcon(true)} disabled={hasAvatar}>on</Tab>
361
+ </div>
362
+ </div>
363
+ <div className="flex items-center gap-2">
364
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">avatar</span>
365
+ <div className="flex gap-1.5">
366
+ <Tab active={!hasAvatar} onClick={() => setHasAvatar(false)}>off</Tab>
367
+ <Tab active={hasAvatar} onClick={() => setHasAvatar(true)} disabled={hasIcon}>on</Tab>
368
+ </div>
369
+ </div>
370
+ <div className="flex items-center gap-2">
371
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">description</span>
372
+ <div className="flex gap-1.5">
373
+ <Tab active={!hasDesc} onClick={() => setHasDesc(false)}>off</Tab>
374
+ <Tab active={hasDesc} onClick={() => setHasDesc(true)}>on</Tab>
375
+ </div>
376
+ </div>
377
+ <div className="flex items-center gap-2">
378
+ <span className="text-[11px] text-fg-muted w-20 shrink-0">tag</span>
379
+ <div className="flex gap-1.5">
380
+ <Tab active={!hasTag} onClick={() => setHasTag(false)}>off</Tab>
381
+ <Tab active={hasTag} onClick={() => setHasTag(true)}>on</Tab>
382
+ </div>
383
+ </div>
384
+ </div>
385
+
386
+ {/* Preview + Panel */}
387
+ <div className="flex gap-6 items-start">
388
+ {/* Left: preview + blueprint */}
389
+ <div className="flex flex-col gap-5 min-w-[360px]">
390
+ <div className="px-4 py-6 rounded-lg bg-canvas border border-divider flex items-center justify-center">
391
+ <MenuContainer width={340}>
392
+ <MenuGroup>
393
+ <MenuItem
394
+ size={size}
395
+ startIcon={hasIcon ? Mail : undefined}
396
+ avatar={hasAvatar ? { alt: "Alice", color: "indigo" as const } : undefined}
397
+ description={hasDesc ? '每日摘要信件到信箱' : undefined}
398
+ checkbox={isMulti}
399
+ checked={isMulti ? selected : undefined}
400
+ selected={!isMulti ? selected : undefined}
401
+ disabled={disabled}
402
+ tag={hasTag ? <Tag size={size} color="neutral">標籤</Tag> : undefined}
403
+ >
404
+ 電子郵件通知
405
+ </MenuItem>
406
+ </MenuGroup>
407
+ </MenuContainer>
408
+ </div>
409
+
410
+ {/* 2D Blueprint */}
411
+ <div className="flex flex-col gap-2">
412
+ {/* Legend */}
413
+ <div className="flex items-center gap-4 text-[10px] flex-wrap">
414
+ {[
415
+ { c: Z.pad, l: '內距' },
416
+ ...(hasPrefix ? [{ c: Z.prefix, l: 'Prefix' }] : []),
417
+ { c: Z.gap, l: '間距' },
418
+ { c: Z.content, l: 'Content' },
419
+ ...(hasTag ? [{ c: Z.suffix, l: 'Suffix' }] : []),
420
+ ].map(({ c, l }) => (
421
+ <span key={l} className="inline-flex items-center gap-1">
422
+ <span className="w-2.5 h-2.5 rounded-md" style={{ background: c.bg, border: `1px dashed ${c.border}` }} />
423
+ <span className="font-medium" style={{ color: c.text }}>{l}</span>
424
+ </span>
425
+ ))}
426
+ </div>
427
+
428
+ {/* Blueprint rows: top padding → content row → bottom padding */}
429
+ <div className="flex items-start gap-0">
430
+ <div className="flex flex-col rounded-md overflow-hidden" style={{ outline: `2px solid ${Z.dim.text}22` }}>
431
+ {/* Top padding-y */}
432
+ <BpZoneV h={20} color={Z.pad} label="padding-y" sub={s.py} />
433
+ {/* Horizontal content row */}
434
+ <div className="flex items-center" style={{ height: 44 }}>
435
+ {/* Left padding-x */}
436
+ <BpZoneH w={40} color={Z.pad} label="px-3" sub="12px" />
437
+ {/* Prefix */}
438
+ {hasPrefix && (
439
+ <>
440
+ <BpZoneH w={isMulti ? 50 : 44} color={Z.prefix}
441
+ label={isMulti && hasIcon ? 'CB+Icon' : isMulti ? 'Checkbox' : hasIcon ? `${s.icon}px` : hasAvatar ? `${avatarPx}px` : '—'}
442
+ sub={isMulti && hasIcon ? `${s.checkbox}+${s.icon}px` : isMulti ? s.checkbox : hasIcon ? 'icon' : hasAvatar ? 'avatar' : ''} />
443
+ <BpZoneH w={28} color={Z.gap} label="gap-2" sub="8px" />
444
+ </>
445
+ )}
446
+ {/* Content */}
447
+ <BpZoneH w={hasDesc ? 80 : 64} color={Z.content}
448
+ label={hasDesc ? 'Label+Desc' : 'Label'}
449
+ sub={s.labelFont} />
450
+ {/* Suffix */}
451
+ {hasTag && (
452
+ <>
453
+ <BpZoneH w={28} color={Z.gap} label="gap-2" sub="8px" />
454
+ <BpZoneH w={36} color={Z.suffix} label="Tag" sub="suffix" />
455
+ </>
456
+ )}
457
+ {/* Right padding-x */}
458
+ <BpZoneH w={40} color={Z.pad} label="px-3" sub="12px" />
459
+ </div>
460
+ {/* Bottom padding-y */}
461
+ <BpZoneV h={20} color={Z.pad} label="padding-y" sub={s.py} />
462
+ </div>
463
+
464
+ {/* Height dimension line */}
465
+ <div className="ml-3 flex items-center" style={{ height: 84 }}>
466
+ <svg width="10" height="84" className="shrink-0">
467
+ <line x1="5" y1="2" x2="5" y2="82" stroke={Z.dim.text} strokeWidth="1" />
468
+ <line x1="1" y1="2" x2="9" y2="2" stroke={Z.dim.text} strokeWidth="1.5" />
469
+ <line x1="1" y1="82" x2="9" y2="82" stroke={Z.dim.text} strokeWidth="1.5" />
470
+ </svg>
471
+ <div className="ml-1.5"><TkVal token={s.heightToken} /></div>
472
+ </div>
473
+ </div>
474
+ <p className="text-[10px] text-fg-muted">寬度為示意比例,實際由內容決定</p>
475
+ </div>
476
+ </div>
477
+
478
+ {/* Right: inspect panel */}
479
+ <div className="w-[300px] shrink-0 border border-divider rounded-lg bg-surface overflow-hidden">
480
+ <div className="px-4 py-2.5 border-b border-divider bg-neutral-hover">
481
+ <span className="text-[12px] font-semibold text-foreground">Inspect</span>
482
+ </div>
483
+
484
+ {/* COLOR */}
485
+ <div className="px-4 py-1">
486
+ <div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Color</span></div>
487
+ <PropRow label="Background"><TokenValue value={colors.bg} /></PropRow>
488
+ <PropRow label="Label"><TokenValue value={colors.text} /></PropRow>
489
+ <PropRow label="Prefix icon"><TokenValue value={colors.icon} /></PropRow>
490
+ {hasDesc && <PropRow label="Description"><TokenValue value={colors.desc} /></PropRow>}
491
+ </div>
492
+
493
+ {/* LAYOUT */}
494
+ <div className="px-4 py-1">
495
+ <div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Layout</span></div>
496
+ <PropRow label="單行高度"><TkVal token={s.heightToken} /></PropRow>
497
+ <PropRow label="padding-y"><TkVal token={s.py} /></PropRow>
498
+ <PropRow label="padding-x"><TkVal token="px-3" value="12px" /></PropRow>
499
+ <PropRow label="元素間距"><TkVal token="gap-2" value="8px" /></PropRow>
500
+ <PropRow label="Prefix align">
501
+ {prefixAlign === 'inline'
502
+ ? <TkVal token="一行文字高度" value="對齊第一行 label" />
503
+ : <TkVal token="label行高 + 2px + desc行高" value="對齊文字塊中心" />
504
+ }
505
+ </PropRow>
506
+ {hasIcon && <PropRow label="Icon">{s.icon}px</PropRow>}
507
+ {hasAvatar && <PropRow label="Avatar">{avatarPx}px ({prefixAlign})</PropRow>}
508
+ {isMulti && <PropRow label="Checkbox">{s.checkbox}</PropRow>}
509
+ </div>
510
+
511
+ {/* TYPOGRAPHY */}
512
+ <div className="px-4 py-1">
513
+ <div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Typography</span></div>
514
+ <PropRow label="Label"><TkVal token={s.labelFont} value={s.labelSize} /></PropRow>
515
+ {hasDesc && <PropRow label="Description"><TkVal token={s.descFont} value={s.descSize} /></PropRow>}
516
+ {hasDesc && <PropRow label="Label-Desc 間距"><TkVal token={size === 'lg' ? '--item-gap-label-desc-scanning-lg' : '--item-gap-label-desc-scanning'} value="2px" /></PropRow>}
517
+ </div>
518
+
519
+ {/* SELECTION */}
520
+ <div className="px-4 py-1 pb-3">
521
+ <div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Selection</span></div>
522
+ <PropRow label="模式">{isMulti ? 'Checkbox 勾選' : 'bg-neutral-selected 背景'}</PropRow>
523
+ <PropRow label="選後行為">{isMulti ? '不關閉浮層' : '關閉浮層'}</PropRow>
524
+ </div>
525
+ </div>
526
+ </div>
527
+ </div>
528
+ )
529
+ }
530
+
531
+ export const Inspector = {
532
+ name: '元件檢閱器',
533
+ render: () => (
534
+ <div className="flex flex-col gap-4">
535
+ <div className="flex flex-col gap-1">
536
+ <H3>元件檢閱器</H3>
537
+ <Desc>選擇任意組合,即時查看所有 token。開發只需確認 token 正確——theme / density 的值解析由系統處理。</Desc>
538
+ </div>
539
+ <InspectorInner />
540
+ </div>
541
+ ),
542
+ }
543
+
544
+ /* ═══════════════════════════════════════════════════════════════════════════
545
+ 3. 色彩對照表
546
+ ═══════════════════════════════════════════════════════════════════════════ */
547
+
548
+ export const ColorMatrix = {
549
+ name: '色彩對照表',
550
+ render: () => (
551
+ <div className="flex flex-col gap-8">
552
+ <div className="flex flex-col gap-1">
553
+ <H3>State 色彩對照</H3>
554
+ <Desc>單選用 bg-neutral-selected 背景指示選中,多選用 Checkbox 勾選——背景不變。disabled 時所有元素統一 fg-disabled。色塊即時渲染,切 dark mode 自動更新。</Desc>
555
+ </div>
556
+
557
+ {/* Single-select */}
558
+ <div className="flex flex-col gap-3">
559
+ <span className="text-caption font-medium text-fg-secondary">單選(selected = bg-neutral-selected)</span>
560
+ <div className="overflow-x-auto">
561
+ <table className="border-collapse">
562
+ <thead><tr><Th>State</Th><Th>預覽</Th><Th>Token</Th></tr></thead>
563
+ <tbody>
564
+ {STATES.map((st) => (
565
+ <tr key={st}>
566
+ <Td mono>{st}</Td>
567
+ <td className="p-3 border-b border-divider align-top min-w-[280px]">
568
+ <MenuContainer width={260}>
569
+ <MenuGroup>
570
+ <MenuItem
571
+ size="md"
572
+ startIcon={Mail}
573
+ selected={st === 'selected'}
574
+ disabled={st === 'disabled'}
575
+ description="摘要通知"
576
+ >
577
+ 電子郵件
578
+ </MenuItem>
579
+ </MenuGroup>
580
+ </MenuContainer>
581
+ </td>
582
+ <td className="p-3 border-b border-divider align-top min-w-[200px]">
583
+ <TokenAnnotation colors={SINGLE_TOKEN_MAP[st]} />
584
+ </td>
585
+ </tr>
586
+ ))}
587
+ </tbody>
588
+ </table>
589
+ </div>
590
+ </div>
591
+
592
+ {/* Multi-select */}
593
+ <div className="flex flex-col gap-3">
594
+ <span className="text-caption font-medium text-fg-secondary">多選(selected = checkbox 勾選,背景不變)</span>
595
+ <div className="overflow-x-auto">
596
+ <table className="border-collapse">
597
+ <thead><tr><Th>State</Th><Th>預覽</Th><Th>Token</Th></tr></thead>
598
+ <tbody>
599
+ {STATES.map((st) => (
600
+ <tr key={st}>
601
+ <Td mono>{st}</Td>
602
+ <td className="p-3 border-b border-divider align-top min-w-[280px]">
603
+ <MenuContainer width={260}>
604
+ <MenuGroup>
605
+ <MenuItem
606
+ size="md"
607
+ startIcon={Mail}
608
+ checkbox
609
+ checked={st === 'selected'}
610
+ disabled={st === 'disabled'}
611
+ description="摘要通知"
612
+ >
613
+ 電子郵件
614
+ </MenuItem>
615
+ </MenuGroup>
616
+ </MenuContainer>
617
+ </td>
618
+ <td className="p-3 border-b border-divider align-top min-w-[200px]">
619
+ <TokenAnnotation colors={MULTI_TOKEN_MAP[st]} />
620
+ </td>
621
+ </tr>
622
+ ))}
623
+ </tbody>
624
+ </table>
625
+ </div>
626
+ </div>
627
+
628
+ {/* Header */}
629
+ <div className="flex flex-col gap-3">
630
+ <span className="text-caption font-medium text-fg-secondary">Header(群組標題)</span>
631
+ <div className="flex items-start gap-4">
632
+ <MenuContainer width={260}>
633
+ <MenuGroup>
634
+ <MenuItem size="md" header>群組標題</MenuItem>
635
+ <MenuItem size="md" startIcon={FileText}>一般選項</MenuItem>
636
+ </MenuGroup>
637
+ </MenuContainer>
638
+ <div className="flex flex-col gap-0.5">
639
+ <span className="inline-flex items-center gap-1 text-[10px]">
640
+ <span className="text-fg-muted w-7 shrink-0">text</span>
641
+ <span className="font-mono text-fg-secondary">--fg-muted + font-medium</span>
642
+ </span>
643
+ <span className="inline-flex items-center gap-1 text-[10px]">
644
+ <span className="text-fg-muted w-7 shrink-0">互動</span>
645
+ <span className="font-mono text-fg-secondary">pointer-events-none</span>
646
+ </span>
647
+ </div>
648
+ </div>
649
+ </div>
650
+ </div>
651
+ ),
652
+ }
653
+
654
+ /* ═══════════════════════════════════════════════════════════════════════════
655
+ 4. 尺寸對照表
656
+ ═══════════════════════════════════════════════════════════════════════════ */
657
+
658
+ export const SizeMatrix = {
659
+ name: '尺寸對照表',
660
+ render: () => (
661
+ <div className="flex flex-col gap-8">
662
+ <div className="flex flex-col gap-1">
663
+ <H3>Size Token 對照</H3>
664
+ <Desc>每個 size 對應的 token 一覽。density 切換由系統自動處理 field-height 值。</Desc>
665
+ </div>
666
+
667
+ {/* Token comparison table */}
668
+ <div className="overflow-x-auto">
669
+ <table className="border-collapse text-caption">
670
+ <thead><tr>
671
+ <Th>屬性</Th>
672
+ {SIZES.map((sz) => <Th key={sz}>{sz}{sz === 'md' ? '(預設)' : ''}</Th>)}
673
+ </tr></thead>
674
+ <tbody>
675
+ <tr>
676
+ <Td>單行高度</Td>
677
+ {SIZES.map((sz) => <Td key={sz} mono><TkVal token={SIZE_SPECS[sz].heightToken} /></Td>)}
678
+ </tr>
679
+ <tr>
680
+ <Td>padding-y</Td>
681
+ {SIZES.map((sz) => <Td key={sz} mono><span className="text-fg-secondary text-[11px]">(field-height − 一行文字高度) / 2</span></Td>)}
682
+ </tr>
683
+ <tr>
684
+ <Td>padding-x</Td>
685
+ {SIZES.map(() => <Td mono><TkVal token="px-3" value="12px" /></Td>)}
686
+ </tr>
687
+ <tr>
688
+ <Td>Label 字體</Td>
689
+ {SIZES.map((sz) => <Td key={sz} mono><TkVal token={SIZE_SPECS[sz].labelFont} value={SIZE_SPECS[sz].labelSize} /></Td>)}
690
+ </tr>
691
+ <tr>
692
+ <Td>Description 字體</Td>
693
+ {SIZES.map((sz) => <Td key={sz} mono><TkVal token={SIZE_SPECS[sz].descFont} value={SIZE_SPECS[sz].descSize} /></Td>)}
694
+ </tr>
695
+ <tr>
696
+ <Td>Icon</Td>
697
+ {SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].icon}px</Td>)}
698
+ </tr>
699
+ <tr>
700
+ <Td>Checkbox</Td>
701
+ {SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].checkbox}</Td>)}
702
+ </tr>
703
+ </tbody>
704
+ </table>
705
+ </div>
706
+
707
+ {/* Avatar sizing */}
708
+ <div className="flex flex-col gap-3">
709
+ <H3>Avatar 尺寸——24px 閾值</H3>
710
+ <Desc>
711
+ avatar 尺寸由 description 決定。無 description 時使用 inline 尺寸(對齊 Tag 高度,&le; 24px),有 description 時使用 block 尺寸(floor8(label行高 + 2px + desc行高),&gt; 24px)。24px 是物理限制——16px icon 在 24px 圓內可辨識,更小則不行。
712
+ </Desc>
713
+ <div className="overflow-x-auto">
714
+ <table className="border-collapse text-caption">
715
+ <thead><tr>
716
+ <Th>Avatar 模式</Th>
717
+ {SIZES.map((sz) => <Th key={sz}>{sz}</Th>)}
718
+ <Th>Prefix 對齊</Th>
719
+ </tr></thead>
720
+ <tbody>
721
+ <tr>
722
+ <Td>inline(無 description)</Td>
723
+ {SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].avatarInline}px</Td>)}
724
+ <Td mono>一行文字高度</Td>
725
+ </tr>
726
+ <tr>
727
+ <Td>block(有 description)</Td>
728
+ {SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].avatarBlock}px</Td>)}
729
+ <Td mono>label行高 + 2px + desc行高</Td>
730
+ </tr>
731
+ </tbody>
732
+ </table>
733
+ </div>
734
+ </div>
735
+
736
+ {/* Visual preview per size */}
737
+ <div className="flex flex-col gap-4">
738
+ <span className="text-caption font-medium text-fg-secondary">預覽</span>
739
+ <div className="flex flex-col gap-6">
740
+ {SIZES.map((sz) => (
741
+ <div key={sz} className="flex flex-col gap-1">
742
+ <span className="text-caption text-fg-muted font-mono">{sz}{sz === 'md' ? '(預設)' : ''}</span>
743
+ <MenuContainer width={380}>
744
+ <MenuGroup>
745
+ <MenuItem size={sz} startIcon={Mail} description="每日摘要信件">
746
+ 電子郵件通知
747
+ </MenuItem>
748
+ <MenuItem size={sz} avatar={{ alt: "Alice", color: "indigo" as const }}>
749
+ Alice Chen
750
+ </MenuItem>
751
+ <MenuItem size={sz} avatar={{ alt: "Bob", color: "magenta" as const }} description="工程部門">
752
+ Bob Wang
753
+ </MenuItem>
754
+ <MenuItem size={sz} checkbox checked={true} startIcon={Bell}>
755
+ 推播通知
756
+ </MenuItem>
757
+ <MenuItem size={sz} tag={<Tag size={sz} color="neutral">Admin</Tag>}>
758
+ 權限標記
759
+ </MenuItem>
760
+ </MenuGroup>
761
+ </MenuContainer>
762
+ </div>
763
+ ))}
764
+ </div>
765
+ </div>
766
+ </div>
767
+ ),
768
+ }
769
+
770
+ // ── Accessibility ─────────────────────────────────────────────────────────
771
+ // 2026-05-17 ship per audit Dim 13(story-rules.md 6-canonical 含 Accessibility)
772
+ export const Accessibility = {
773
+ name: '無障礙',
774
+ render: () => (
775
+ <div className="max-w-3xl text-body text-fg-secondary">
776
+ <h3 className="text-h5 text-foreground mb-2">無障礙設計</h3>
777
+ <p className="whitespace-pre-line">{"MenuItem 只負責單行的視覺排版,本身不接管鍵盤與焦點。真正的鍵盤導覽(上下鍵切換、Enter 選取、Esc 關閉)與焦點管理由外層的選單元件(SelectMenu / DropdownMenu)負責——MenuItem 不重複實作這些行為。\n\n 語意 role :在 listbox 語境(SelectMenu / Combobox)MenuItem 預設渲染為 role=\"option\";在 menu 語境(DropdownMenu)外層會把每個 item 覆蓋為 role=\"presentation\",由 Radix parent 持有 role=\"menuitem\" 語意。哪一項目前被聚焦與選取由外層選單決定。\n\n 焦點外觀 :聚焦時以 bg-neutral-hover 背景高亮標示被聚焦的選項(cva base 為 outline-none + focus-visible:bg-neutral-hover),對齊 menu/listbox option 的 active-highlight 慣例,而非畫 outline ring。\n\n 驗證 :Storybook a11y addon 面板應 0 critical violation;整個選單用鍵盤即可完整操作(無需滑鼠);文字對比 ≥ 4.5:1、介面元素對比 ≥ 3:1(WCAG AA)。"}</p>
778
+ </div>
779
+ ),
780
+ }