@qijenchen/design-system 0.1.0-beta.4 → 0.1.0-beta.43

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 (1343) hide show
  1. package/CLAUDE.md +199 -0
  2. package/README.md +155 -0
  3. package/cli-init.mjs +90 -0
  4. package/dist/components/Accordion/accordion.d.ts +37 -0
  5. package/dist/components/Accordion/accordion.d.ts.map +1 -0
  6. package/dist/components/Accordion/accordion.js +81 -0
  7. package/dist/components/Accordion/accordion.js.map +1 -0
  8. package/dist/components/Accordion/index.d.ts +2 -0
  9. package/dist/components/Accordion/index.d.ts.map +1 -0
  10. package/dist/components/Accordion/index.js +9 -0
  11. package/dist/components/Accordion/index.js.map +1 -0
  12. package/dist/components/Alert/alert.d.ts +47 -0
  13. package/dist/components/Alert/alert.d.ts.map +1 -0
  14. package/dist/components/Alert/alert.js +132 -0
  15. package/dist/components/Alert/alert.js.map +1 -0
  16. package/dist/components/Alert/index.d.ts +2 -0
  17. package/dist/components/Alert/index.d.ts.map +1 -0
  18. package/dist/components/Alert/index.js +7 -0
  19. package/dist/components/Alert/index.js.map +1 -0
  20. package/dist/components/AppShell/_demo-helpers.d.ts +49 -0
  21. package/dist/components/AppShell/_demo-helpers.d.ts.map +1 -0
  22. package/dist/components/AppShell/app-shell.d.ts +76 -0
  23. package/dist/components/AppShell/app-shell.d.ts.map +1 -0
  24. package/dist/components/AppShell/app-shell.js +214 -0
  25. package/dist/components/AppShell/app-shell.js.map +1 -0
  26. package/dist/components/AppShell/index.d.ts +2 -0
  27. package/dist/components/AppShell/index.d.ts.map +1 -0
  28. package/dist/components/AppShell/index.js +7 -0
  29. package/dist/components/AppShell/index.js.map +1 -0
  30. package/dist/components/AspectRatio/aspect-ratio.d.ts +40 -0
  31. package/dist/components/AspectRatio/aspect-ratio.d.ts.map +1 -0
  32. package/dist/components/AspectRatio/aspect-ratio.js +23 -0
  33. package/dist/components/AspectRatio/aspect-ratio.js.map +1 -0
  34. package/dist/components/AspectRatio/index.d.ts +2 -0
  35. package/dist/components/AspectRatio/index.d.ts.map +1 -0
  36. package/dist/components/AspectRatio/index.js +6 -0
  37. package/dist/components/AspectRatio/index.js.map +1 -0
  38. package/dist/components/Avatar/avatar.d.ts +85 -0
  39. package/dist/components/Avatar/avatar.d.ts.map +1 -0
  40. package/dist/components/Avatar/avatar.js +197 -0
  41. package/dist/components/Avatar/avatar.js.map +1 -0
  42. package/dist/components/Avatar/index.d.ts +2 -0
  43. package/dist/components/Avatar/index.d.ts.map +1 -0
  44. package/dist/components/Avatar/index.js +6 -0
  45. package/dist/components/Avatar/index.js.map +1 -0
  46. package/dist/components/Badge/badge.d.ts +43 -0
  47. package/dist/components/Badge/badge.d.ts.map +1 -0
  48. package/dist/components/Badge/badge.js +69 -0
  49. package/dist/components/Badge/badge.js.map +1 -0
  50. package/dist/components/Badge/index.d.ts +2 -0
  51. package/dist/components/Badge/index.d.ts.map +1 -0
  52. package/dist/components/Badge/index.js +7 -0
  53. package/dist/components/Badge/index.js.map +1 -0
  54. package/dist/components/Breadcrumb/breadcrumb.d.ts +163 -0
  55. package/dist/components/Breadcrumb/breadcrumb.d.ts.map +1 -0
  56. package/dist/components/Breadcrumb/breadcrumb.js +300 -0
  57. package/dist/components/Breadcrumb/breadcrumb.js.map +1 -0
  58. package/dist/components/Breadcrumb/index.d.ts +2 -0
  59. package/dist/components/Breadcrumb/index.d.ts.map +1 -0
  60. package/dist/components/Breadcrumb/index.js +12 -0
  61. package/dist/components/Breadcrumb/index.js.map +1 -0
  62. package/dist/components/BulkActionBar/bulk-action-bar.d.ts +46 -0
  63. package/dist/components/BulkActionBar/bulk-action-bar.d.ts.map +1 -0
  64. package/dist/components/BulkActionBar/bulk-action-bar.js +78 -0
  65. package/dist/components/BulkActionBar/bulk-action-bar.js.map +1 -0
  66. package/dist/components/BulkActionBar/index.d.ts +2 -0
  67. package/dist/components/BulkActionBar/index.d.ts.map +1 -0
  68. package/dist/components/BulkActionBar/index.js +7 -0
  69. package/dist/components/BulkActionBar/index.js.map +1 -0
  70. package/dist/components/Button/button-group.d.ts +49 -0
  71. package/dist/components/Button/button-group.d.ts.map +1 -0
  72. package/dist/components/Button/button-group.js +46 -0
  73. package/dist/components/Button/button-group.js.map +1 -0
  74. package/dist/components/Button/button.d.ts +203 -0
  75. package/dist/components/Button/button.d.ts.map +1 -0
  76. package/dist/components/Button/button.js +309 -0
  77. package/dist/components/Button/button.js.map +1 -0
  78. package/dist/components/Button/index.d.ts +2 -0
  79. package/dist/components/Button/index.d.ts.map +1 -0
  80. package/dist/components/Button/index.js +8 -0
  81. package/dist/components/Button/index.js.map +1 -0
  82. package/dist/components/Calendar/calendar.d.ts +81 -0
  83. package/dist/components/Calendar/calendar.d.ts.map +1 -0
  84. package/dist/components/Calendar/calendar.js +294 -0
  85. package/dist/components/Calendar/calendar.js.map +1 -0
  86. package/dist/components/Calendar/index.d.ts +2 -0
  87. package/dist/components/Calendar/index.d.ts.map +1 -0
  88. package/dist/components/Calendar/index.js +6 -0
  89. package/dist/components/Calendar/index.js.map +1 -0
  90. package/dist/components/Carousel/carousel.d.ts +61 -0
  91. package/dist/components/Carousel/carousel.d.ts.map +1 -0
  92. package/dist/components/Carousel/carousel.js +279 -0
  93. package/dist/components/Carousel/carousel.js.map +1 -0
  94. package/dist/components/Carousel/index.d.ts +2 -0
  95. package/dist/components/Carousel/index.d.ts.map +1 -0
  96. package/dist/components/Carousel/index.js +11 -0
  97. package/dist/components/Carousel/index.js.map +1 -0
  98. package/dist/components/Chart/chart.d.ts +94 -0
  99. package/dist/components/Chart/chart.d.ts.map +1 -0
  100. package/dist/components/Chart/chart.js +235 -0
  101. package/dist/components/Chart/chart.js.map +1 -0
  102. package/dist/components/Chart/index.d.ts +2 -0
  103. package/dist/components/Chart/index.d.ts.map +1 -0
  104. package/dist/components/Chart/index.js +11 -0
  105. package/dist/components/Chart/index.js.map +1 -0
  106. package/dist/components/Checkbox/checkbox-group.d.ts +58 -0
  107. package/dist/components/Checkbox/checkbox-group.d.ts.map +1 -0
  108. package/dist/components/Checkbox/checkbox-group.js +28 -0
  109. package/dist/components/Checkbox/checkbox-group.js.map +1 -0
  110. package/dist/components/Checkbox/checkbox.d.ts +73 -0
  111. package/dist/components/Checkbox/checkbox.d.ts.map +1 -0
  112. package/dist/components/Checkbox/checkbox.js +126 -0
  113. package/dist/components/Checkbox/checkbox.js.map +1 -0
  114. package/dist/components/Checkbox/index.d.ts +2 -0
  115. package/dist/components/Checkbox/index.d.ts.map +1 -0
  116. package/dist/components/Checkbox/index.js +7 -0
  117. package/dist/components/Checkbox/index.js.map +1 -0
  118. package/dist/components/Chip/chip.d.ts +54 -0
  119. package/dist/components/Chip/chip.d.ts.map +1 -0
  120. package/dist/components/Chip/chip.js +224 -0
  121. package/dist/components/Chip/chip.js.map +1 -0
  122. package/dist/components/Chip/index.d.ts +2 -0
  123. package/dist/components/Chip/index.d.ts.map +1 -0
  124. package/dist/components/Chip/index.js +8 -0
  125. package/dist/components/Chip/index.js.map +1 -0
  126. package/dist/components/CircularProgress/circular-progress.d.ts +40 -0
  127. package/dist/components/CircularProgress/circular-progress.d.ts.map +1 -0
  128. package/dist/components/CircularProgress/circular-progress.js +118 -0
  129. package/dist/components/CircularProgress/circular-progress.js.map +1 -0
  130. package/dist/components/CircularProgress/index.d.ts +2 -0
  131. package/dist/components/CircularProgress/index.d.ts.map +1 -0
  132. package/dist/components/CircularProgress/index.js +6 -0
  133. package/dist/components/CircularProgress/index.js.map +1 -0
  134. package/dist/components/Coachmark/coachmark-story-helpers.d.ts +22 -0
  135. package/dist/components/Coachmark/coachmark-story-helpers.d.ts.map +1 -0
  136. package/dist/components/Coachmark/coachmark.d.ts +100 -0
  137. package/dist/components/Coachmark/coachmark.d.ts.map +1 -0
  138. package/dist/components/Coachmark/coachmark.js +111 -0
  139. package/dist/components/Coachmark/coachmark.js.map +1 -0
  140. package/dist/components/Coachmark/index.d.ts +2 -0
  141. package/dist/components/Coachmark/index.d.ts.map +1 -0
  142. package/dist/components/Coachmark/index.js +6 -0
  143. package/dist/components/Coachmark/index.js.map +1 -0
  144. package/dist/components/Combobox/combobox.d.ts +150 -0
  145. package/dist/components/Combobox/combobox.d.ts.map +1 -0
  146. package/dist/components/Combobox/combobox.js +622 -0
  147. package/dist/components/Combobox/combobox.js.map +1 -0
  148. package/dist/components/Combobox/index.d.ts +2 -0
  149. package/dist/components/Combobox/index.d.ts.map +1 -0
  150. package/dist/components/Combobox/index.js +6 -0
  151. package/dist/components/Combobox/index.js.map +1 -0
  152. package/dist/components/Command/command.d.ts +106 -0
  153. package/dist/components/Command/command.d.ts.map +1 -0
  154. package/dist/components/Command/command.js +123 -0
  155. package/dist/components/Command/command.js.map +1 -0
  156. package/dist/components/Command/index.d.ts +2 -0
  157. package/dist/components/Command/index.d.ts.map +1 -0
  158. package/dist/components/Command/index.js +14 -0
  159. package/dist/components/Command/index.js.map +1 -0
  160. package/dist/components/DataTable/active-editor-controller.d.ts +66 -0
  161. package/dist/components/DataTable/active-editor-controller.d.ts.map +1 -0
  162. package/dist/components/DataTable/cell-registry.d.ts +37 -0
  163. package/dist/components/DataTable/cell-registry.d.ts.map +1 -0
  164. package/dist/components/DataTable/cell-registry.js +377 -0
  165. package/dist/components/DataTable/cell-registry.js.map +1 -0
  166. package/dist/components/DataTable/column-types.d.ts +145 -0
  167. package/dist/components/DataTable/column-types.d.ts.map +1 -0
  168. package/dist/components/DataTable/column-types.js +17 -0
  169. package/dist/components/DataTable/column-types.js.map +1 -0
  170. package/dist/components/DataTable/data-table-column-visibility-panel.d.ts +49 -0
  171. package/dist/components/DataTable/data-table-column-visibility-panel.d.ts.map +1 -0
  172. package/dist/components/DataTable/data-table-filter-panel.d.ts +30 -0
  173. package/dist/components/DataTable/data-table-filter-panel.d.ts.map +1 -0
  174. package/dist/components/DataTable/data-table-interaction-layer.d.ts +78 -0
  175. package/dist/components/DataTable/data-table-interaction-layer.d.ts.map +1 -0
  176. package/dist/components/DataTable/data-table-interaction-layer.js +220 -0
  177. package/dist/components/DataTable/data-table-interaction-layer.js.map +1 -0
  178. package/dist/components/DataTable/data-table-sort-manager.d.ts +19 -0
  179. package/dist/components/DataTable/data-table-sort-manager.d.ts.map +1 -0
  180. package/dist/components/DataTable/data-table.d.ts +181 -0
  181. package/dist/components/DataTable/data-table.d.ts.map +1 -0
  182. package/dist/components/DataTable/data-table.js +1851 -0
  183. package/dist/components/DataTable/data-table.js.map +1 -0
  184. package/dist/components/DataTable/filter-operators.d.ts +116 -0
  185. package/dist/components/DataTable/filter-operators.d.ts.map +1 -0
  186. package/dist/components/DataTable/filter-tree.d.ts +66 -0
  187. package/dist/components/DataTable/filter-tree.d.ts.map +1 -0
  188. package/dist/components/DataTable/index.d.ts +2 -0
  189. package/dist/components/DataTable/index.d.ts.map +1 -0
  190. package/dist/components/DataTable/index.js +8 -0
  191. package/dist/components/DataTable/index.js.map +1 -0
  192. package/dist/components/DataTable/lib/column-meta.d.ts +49 -0
  193. package/dist/components/DataTable/lib/column-meta.d.ts.map +1 -0
  194. package/dist/components/DateGrid/date-grid.d.ts +61 -0
  195. package/dist/components/DateGrid/date-grid.d.ts.map +1 -0
  196. package/dist/components/DateGrid/date-grid.js +168 -0
  197. package/dist/components/DateGrid/date-grid.js.map +1 -0
  198. package/dist/components/DateGrid/index.d.ts +2 -0
  199. package/dist/components/DateGrid/index.d.ts.map +1 -0
  200. package/dist/components/DateGrid/index.js +6 -0
  201. package/dist/components/DateGrid/index.js.map +1 -0
  202. package/dist/components/DatePicker/date-picker.d.ts +119 -0
  203. package/dist/components/DatePicker/date-picker.d.ts.map +1 -0
  204. package/dist/components/DatePicker/date-picker.js +750 -0
  205. package/dist/components/DatePicker/date-picker.js.map +1 -0
  206. package/dist/components/DatePicker/index.d.ts +2 -0
  207. package/dist/components/DatePicker/index.d.ts.map +1 -0
  208. package/dist/components/DatePicker/index.js +8 -0
  209. package/dist/components/DatePicker/index.js.map +1 -0
  210. package/dist/components/DescriptionList/description-list.d.ts +60 -0
  211. package/dist/components/DescriptionList/description-list.d.ts.map +1 -0
  212. package/dist/components/DescriptionList/description-list.js +78 -0
  213. package/dist/components/DescriptionList/description-list.js.map +1 -0
  214. package/dist/components/DescriptionList/index.d.ts +2 -0
  215. package/dist/components/DescriptionList/index.d.ts.map +1 -0
  216. package/dist/components/DescriptionList/index.js +7 -0
  217. package/dist/components/DescriptionList/index.js.map +1 -0
  218. package/dist/components/Dialog/dialog.d.ts +54 -0
  219. package/dist/components/Dialog/dialog.d.ts.map +1 -0
  220. package/dist/components/Dialog/dialog.js +151 -0
  221. package/dist/components/Dialog/dialog.js.map +1 -0
  222. package/dist/components/Dialog/index.d.ts +2 -0
  223. package/dist/components/Dialog/index.d.ts.map +1 -0
  224. package/dist/components/Dialog/index.js +16 -0
  225. package/dist/components/Dialog/index.js.map +1 -0
  226. package/dist/components/DropdownMenu/dropdown-menu.d.ts +112 -0
  227. package/dist/components/DropdownMenu/dropdown-menu.d.ts.map +1 -0
  228. package/dist/components/DropdownMenu/dropdown-menu.js +288 -0
  229. package/dist/components/DropdownMenu/dropdown-menu.js.map +1 -0
  230. package/dist/components/DropdownMenu/index.d.ts +2 -0
  231. package/dist/components/DropdownMenu/index.d.ts.map +1 -0
  232. package/dist/components/DropdownMenu/index.js +21 -0
  233. package/dist/components/DropdownMenu/index.js.map +1 -0
  234. package/dist/components/Empty/empty.d.ts +40 -0
  235. package/dist/components/Empty/empty.d.ts.map +1 -0
  236. package/dist/components/Empty/empty.js +66 -0
  237. package/dist/components/Empty/empty.js.map +1 -0
  238. package/dist/components/Empty/index.d.ts +2 -0
  239. package/dist/components/Empty/index.d.ts.map +1 -0
  240. package/dist/components/Empty/index.js +6 -0
  241. package/dist/components/Empty/index.js.map +1 -0
  242. package/dist/components/Field/field-context.d.ts +77 -0
  243. package/dist/components/Field/field-context.d.ts.map +1 -0
  244. package/dist/components/Field/field-context.js +37 -0
  245. package/dist/components/Field/field-context.js.map +1 -0
  246. package/dist/components/Field/field-types.d.ts +5 -0
  247. package/dist/components/Field/field-types.d.ts.map +1 -0
  248. package/dist/components/Field/field-types.js +13 -0
  249. package/dist/components/Field/field-types.js.map +1 -0
  250. package/dist/components/Field/field-wrapper.d.ts +17 -0
  251. package/dist/components/Field/field-wrapper.d.ts.map +1 -0
  252. package/dist/components/Field/field-wrapper.js +252 -0
  253. package/dist/components/Field/field-wrapper.js.map +1 -0
  254. package/dist/components/Field/field.d.ts +127 -0
  255. package/dist/components/Field/field.d.ts.map +1 -0
  256. package/dist/components/Field/field.js +295 -0
  257. package/dist/components/Field/field.js.map +1 -0
  258. package/dist/components/Field/index.d.ts +2 -0
  259. package/dist/components/Field/index.d.ts.map +1 -0
  260. package/dist/components/Field/index.js +10 -0
  261. package/dist/components/Field/index.js.map +1 -0
  262. package/dist/components/FieldControlGroup/field-control-group.d.ts +74 -0
  263. package/dist/components/FieldControlGroup/field-control-group.d.ts.map +1 -0
  264. package/dist/components/FieldControlGroup/field-control-group.js +62 -0
  265. package/dist/components/FieldControlGroup/field-control-group.js.map +1 -0
  266. package/dist/components/FieldControlGroup/index.d.ts +2 -0
  267. package/dist/components/FieldControlGroup/index.d.ts.map +1 -0
  268. package/dist/components/FieldControlGroup/index.js +6 -0
  269. package/dist/components/FieldControlGroup/index.js.map +1 -0
  270. package/dist/components/FileItem/file-item.d.ts +44 -0
  271. package/dist/components/FileItem/file-item.d.ts.map +1 -0
  272. package/dist/components/FileItem/file-item.js +202 -0
  273. package/dist/components/FileItem/file-item.js.map +1 -0
  274. package/dist/components/FileItem/index.d.ts +2 -0
  275. package/dist/components/FileItem/index.d.ts.map +1 -0
  276. package/dist/components/FileItem/index.js +6 -0
  277. package/dist/components/FileItem/index.js.map +1 -0
  278. package/dist/components/FileUpload/file-upload.d.ts +97 -0
  279. package/dist/components/FileUpload/file-upload.d.ts.map +1 -0
  280. package/dist/components/FileUpload/file-upload.js +231 -0
  281. package/dist/components/FileUpload/file-upload.js.map +1 -0
  282. package/dist/components/FileUpload/index.d.ts +2 -0
  283. package/dist/components/FileUpload/index.d.ts.map +1 -0
  284. package/dist/components/FileUpload/index.js +6 -0
  285. package/dist/components/FileUpload/index.js.map +1 -0
  286. package/dist/components/FileViewer/file-viewer-types.d.ts +73 -0
  287. package/dist/components/FileViewer/file-viewer-types.d.ts.map +1 -0
  288. package/dist/components/FileViewer/file-viewer.d.ts +82 -0
  289. package/dist/components/FileViewer/file-viewer.d.ts.map +1 -0
  290. package/dist/components/FileViewer/file-viewer.js +751 -0
  291. package/dist/components/FileViewer/file-viewer.js.map +1 -0
  292. package/dist/components/FileViewer/image-renderer.d.ts +9 -0
  293. package/dist/components/FileViewer/image-renderer.d.ts.map +1 -0
  294. package/dist/components/FileViewer/image-renderer.js +165 -0
  295. package/dist/components/FileViewer/image-renderer.js.map +1 -0
  296. package/dist/components/FileViewer/index.d.ts +2 -0
  297. package/dist/components/FileViewer/index.d.ts.map +1 -0
  298. package/dist/components/FileViewer/index.js +7 -0
  299. package/dist/components/FileViewer/index.js.map +1 -0
  300. package/dist/components/HoverCard/hover-card.d.ts +30 -0
  301. package/dist/components/HoverCard/hover-card.d.ts.map +1 -0
  302. package/dist/components/HoverCard/hover-card.js +61 -0
  303. package/dist/components/HoverCard/hover-card.js.map +1 -0
  304. package/dist/components/HoverCard/index.d.ts +2 -0
  305. package/dist/components/HoverCard/index.d.ts.map +1 -0
  306. package/dist/components/HoverCard/index.js +8 -0
  307. package/dist/components/HoverCard/index.js.map +1 -0
  308. package/dist/components/Input/index.d.ts +2 -0
  309. package/dist/components/Input/index.d.ts.map +1 -0
  310. package/dist/components/Input/index.js +6 -0
  311. package/dist/components/Input/index.js.map +1 -0
  312. package/dist/components/Input/input.d.ts +75 -0
  313. package/dist/components/Input/input.d.ts.map +1 -0
  314. package/dist/components/Input/input.js +150 -0
  315. package/dist/components/Input/input.js.map +1 -0
  316. package/dist/components/LinkInput/index.d.ts +2 -0
  317. package/dist/components/LinkInput/index.d.ts.map +1 -0
  318. package/dist/components/LinkInput/index.js +6 -0
  319. package/dist/components/LinkInput/index.js.map +1 -0
  320. package/dist/components/LinkInput/link-input.d.ts +46 -0
  321. package/dist/components/LinkInput/link-input.d.ts.map +1 -0
  322. package/dist/components/LinkInput/link-input.js +215 -0
  323. package/dist/components/LinkInput/link-input.js.map +1 -0
  324. package/dist/components/Menu/index.d.ts +2 -0
  325. package/dist/components/Menu/index.d.ts.map +1 -0
  326. package/dist/components/Menu/index.js +9 -0
  327. package/dist/components/Menu/index.js.map +1 -0
  328. package/dist/components/Menu/menu-item.d.ts +83 -0
  329. package/dist/components/Menu/menu-item.d.ts.map +1 -0
  330. package/dist/components/Menu/menu-item.js +210 -0
  331. package/dist/components/Menu/menu-item.js.map +1 -0
  332. package/dist/components/Notice/index.d.ts +2 -0
  333. package/dist/components/Notice/index.d.ts.map +1 -0
  334. package/dist/components/Notice/index.js +8 -0
  335. package/dist/components/Notice/index.js.map +1 -0
  336. package/dist/components/Notice/notice.d.ts +69 -0
  337. package/dist/components/Notice/notice.d.ts.map +1 -0
  338. package/dist/components/Notice/notice.js +122 -0
  339. package/dist/components/Notice/notice.js.map +1 -0
  340. package/dist/components/NumberInput/index.d.ts +2 -0
  341. package/dist/components/NumberInput/index.d.ts.map +1 -0
  342. package/dist/components/NumberInput/index.js +7 -0
  343. package/dist/components/NumberInput/index.js.map +1 -0
  344. package/dist/components/NumberInput/number-input.d.ts +57 -0
  345. package/dist/components/NumberInput/number-input.d.ts.map +1 -0
  346. package/dist/components/NumberInput/number-input.js +132 -0
  347. package/dist/components/NumberInput/number-input.js.map +1 -0
  348. package/dist/components/OverflowIndicator/index.d.ts +2 -0
  349. package/dist/components/OverflowIndicator/index.d.ts.map +1 -0
  350. package/dist/components/OverflowIndicator/index.js +6 -0
  351. package/dist/components/OverflowIndicator/index.js.map +1 -0
  352. package/dist/components/OverflowIndicator/overflow-indicator.d.ts +23 -0
  353. package/dist/components/OverflowIndicator/overflow-indicator.d.ts.map +1 -0
  354. package/dist/components/OverflowIndicator/overflow-indicator.js +118 -0
  355. package/dist/components/OverflowIndicator/overflow-indicator.js.map +1 -0
  356. package/dist/components/PeoplePicker/avatar-stack-overflow.d.ts +57 -0
  357. package/dist/components/PeoplePicker/avatar-stack-overflow.d.ts.map +1 -0
  358. package/dist/components/PeoplePicker/avatar-stack-overflow.js +35 -0
  359. package/dist/components/PeoplePicker/avatar-stack-overflow.js.map +1 -0
  360. package/dist/components/PeoplePicker/index.d.ts +2 -0
  361. package/dist/components/PeoplePicker/index.d.ts.map +1 -0
  362. package/dist/components/PeoplePicker/index.js +9 -0
  363. package/dist/components/PeoplePicker/index.js.map +1 -0
  364. package/dist/components/PeoplePicker/people-picker-helpers.d.ts +7 -0
  365. package/dist/components/PeoplePicker/people-picker-helpers.d.ts.map +1 -0
  366. package/dist/components/PeoplePicker/people-picker-helpers.js +25 -0
  367. package/dist/components/PeoplePicker/people-picker-helpers.js.map +1 -0
  368. package/dist/components/PeoplePicker/people-picker.d.ts +77 -0
  369. package/dist/components/PeoplePicker/people-picker.d.ts.map +1 -0
  370. package/dist/components/PeoplePicker/people-picker.js +263 -0
  371. package/dist/components/PeoplePicker/people-picker.js.map +1 -0
  372. package/dist/components/PeoplePicker/person-display.d.ts +66 -0
  373. package/dist/components/PeoplePicker/person-display.d.ts.map +1 -0
  374. package/dist/components/PeoplePicker/person-display.js +203 -0
  375. package/dist/components/PeoplePicker/person-display.js.map +1 -0
  376. package/dist/components/Popover/index.d.ts +2 -0
  377. package/dist/components/Popover/index.d.ts.map +1 -0
  378. package/dist/components/Popover/index.js +14 -0
  379. package/dist/components/Popover/index.js.map +1 -0
  380. package/dist/components/Popover/popover.d.ts +50 -0
  381. package/dist/components/Popover/popover.d.ts.map +1 -0
  382. package/dist/components/Popover/popover.js +113 -0
  383. package/dist/components/Popover/popover.js.map +1 -0
  384. package/dist/components/ProfileCard/index.d.ts +2 -0
  385. package/dist/components/ProfileCard/index.d.ts.map +1 -0
  386. package/dist/components/ProfileCard/index.js +8 -0
  387. package/dist/components/ProfileCard/index.js.map +1 -0
  388. package/dist/components/ProfileCard/profile-card.d.ts +85 -0
  389. package/dist/components/ProfileCard/profile-card.d.ts.map +1 -0
  390. package/dist/components/ProfileCard/profile-card.js +153 -0
  391. package/dist/components/ProfileCard/profile-card.js.map +1 -0
  392. package/dist/components/ProgressBar/index.d.ts +2 -0
  393. package/dist/components/ProgressBar/index.d.ts.map +1 -0
  394. package/dist/components/ProgressBar/index.js +6 -0
  395. package/dist/components/ProgressBar/index.js.map +1 -0
  396. package/dist/components/ProgressBar/progress-bar.d.ts +37 -0
  397. package/dist/components/ProgressBar/progress-bar.d.ts.map +1 -0
  398. package/dist/components/ProgressBar/progress-bar.js +86 -0
  399. package/dist/components/ProgressBar/progress-bar.js.map +1 -0
  400. package/dist/components/RadioGroup/index.d.ts +2 -0
  401. package/dist/components/RadioGroup/index.d.ts.map +1 -0
  402. package/dist/components/RadioGroup/index.js +8 -0
  403. package/dist/components/RadioGroup/index.js.map +1 -0
  404. package/dist/components/RadioGroup/radio-group.d.ts +78 -0
  405. package/dist/components/RadioGroup/radio-group.d.ts.map +1 -0
  406. package/dist/components/RadioGroup/radio-group.js +148 -0
  407. package/dist/components/RadioGroup/radio-group.js.map +1 -0
  408. package/dist/components/Rating/index.d.ts +2 -0
  409. package/dist/components/Rating/index.d.ts.map +1 -0
  410. package/dist/components/Rating/index.js +6 -0
  411. package/dist/components/Rating/index.js.map +1 -0
  412. package/dist/components/Rating/rating.d.ts +50 -0
  413. package/dist/components/Rating/rating.d.ts.map +1 -0
  414. package/dist/components/Rating/rating.js +179 -0
  415. package/dist/components/Rating/rating.js.map +1 -0
  416. package/dist/components/ScrollArea/index.d.ts +2 -0
  417. package/dist/components/ScrollArea/index.d.ts.map +1 -0
  418. package/dist/components/ScrollArea/index.js +7 -0
  419. package/dist/components/ScrollArea/index.js.map +1 -0
  420. package/dist/components/ScrollArea/scroll-area.d.ts +45 -0
  421. package/dist/components/ScrollArea/scroll-area.d.ts.map +1 -0
  422. package/dist/components/ScrollArea/scroll-area.js +65 -0
  423. package/dist/components/ScrollArea/scroll-area.js.map +1 -0
  424. package/dist/components/SegmentedControl/index.d.ts +2 -0
  425. package/dist/components/SegmentedControl/index.d.ts.map +1 -0
  426. package/dist/components/SegmentedControl/index.js +9 -0
  427. package/dist/components/SegmentedControl/index.js.map +1 -0
  428. package/dist/components/SegmentedControl/segmented-control.d.ts +102 -0
  429. package/dist/components/SegmentedControl/segmented-control.d.ts.map +1 -0
  430. package/dist/components/SegmentedControl/segmented-control.js +171 -0
  431. package/dist/components/SegmentedControl/segmented-control.js.map +1 -0
  432. package/dist/components/Select/index.d.ts +2 -0
  433. package/dist/components/Select/index.d.ts.map +1 -0
  434. package/dist/components/Select/index.js +6 -0
  435. package/dist/components/Select/index.js.map +1 -0
  436. package/dist/components/Select/select.d.ts +102 -0
  437. package/dist/components/Select/select.d.ts.map +1 -0
  438. package/dist/components/Select/select.js +437 -0
  439. package/dist/components/Select/select.js.map +1 -0
  440. package/dist/components/SelectMenu/index.d.ts +2 -0
  441. package/dist/components/SelectMenu/index.d.ts.map +1 -0
  442. package/dist/components/SelectMenu/index.js +6 -0
  443. package/dist/components/SelectMenu/index.js.map +1 -0
  444. package/dist/components/SelectMenu/select-menu.d.ts +104 -0
  445. package/dist/components/SelectMenu/select-menu.d.ts.map +1 -0
  446. package/dist/components/SelectMenu/select-menu.js +244 -0
  447. package/dist/components/SelectMenu/select-menu.js.map +1 -0
  448. package/dist/components/SelectionControl/index.d.ts +2 -0
  449. package/dist/components/SelectionControl/index.d.ts.map +1 -0
  450. package/dist/components/SelectionControl/index.js +7 -0
  451. package/dist/components/SelectionControl/index.js.map +1 -0
  452. package/dist/components/SelectionControl/selection-item.d.ts +69 -0
  453. package/dist/components/SelectionControl/selection-item.d.ts.map +1 -0
  454. package/dist/components/SelectionControl/selection-item.js +142 -0
  455. package/dist/components/SelectionControl/selection-item.js.map +1 -0
  456. package/dist/components/Separator/index.d.ts +2 -0
  457. package/dist/components/Separator/index.d.ts.map +1 -0
  458. package/dist/components/Separator/index.js +6 -0
  459. package/dist/components/Separator/index.js.map +1 -0
  460. package/dist/components/Separator/separator.d.ts +17 -0
  461. package/dist/components/Separator/separator.d.ts.map +1 -0
  462. package/dist/components/Separator/separator.js +39 -0
  463. package/dist/components/Separator/separator.js.map +1 -0
  464. package/dist/components/Sheet/index.d.ts +2 -0
  465. package/dist/components/Sheet/index.d.ts.map +1 -0
  466. package/dist/components/Sheet/index.js +17 -0
  467. package/dist/components/Sheet/index.js.map +1 -0
  468. package/dist/components/Sheet/sheet.d.ts +56 -0
  469. package/dist/components/Sheet/sheet.d.ts.map +1 -0
  470. package/dist/components/Sheet/sheet.js +145 -0
  471. package/dist/components/Sheet/sheet.js.map +1 -0
  472. package/dist/components/Sidebar/index.d.ts +2 -0
  473. package/dist/components/Sidebar/index.d.ts.map +1 -0
  474. package/dist/components/Sidebar/index.js +24 -0
  475. package/dist/components/Sidebar/index.js.map +1 -0
  476. package/dist/components/Sidebar/sidebar.d.ts +195 -0
  477. package/dist/components/Sidebar/sidebar.d.ts.map +1 -0
  478. package/dist/components/Sidebar/sidebar.js +829 -0
  479. package/dist/components/Sidebar/sidebar.js.map +1 -0
  480. package/dist/components/Skeleton/index.d.ts +2 -0
  481. package/dist/components/Skeleton/index.d.ts.map +1 -0
  482. package/dist/components/Skeleton/index.js +6 -0
  483. package/dist/components/Skeleton/index.js.map +1 -0
  484. package/dist/components/Skeleton/skeleton.d.ts +16 -0
  485. package/dist/components/Skeleton/skeleton.d.ts.map +1 -0
  486. package/dist/components/Skeleton/skeleton.js +30 -0
  487. package/dist/components/Skeleton/skeleton.js.map +1 -0
  488. package/dist/components/Slider/index.d.ts +2 -0
  489. package/dist/components/Slider/index.d.ts.map +1 -0
  490. package/dist/components/Slider/index.js +7 -0
  491. package/dist/components/Slider/index.js.map +1 -0
  492. package/dist/components/Slider/slider.d.ts +48 -0
  493. package/dist/components/Slider/slider.d.ts.map +1 -0
  494. package/dist/components/Slider/slider.js +111 -0
  495. package/dist/components/Slider/slider.js.map +1 -0
  496. package/dist/components/Steps/index.d.ts +2 -0
  497. package/dist/components/Steps/index.d.ts.map +1 -0
  498. package/dist/components/Steps/index.js +12 -0
  499. package/dist/components/Steps/index.js.map +1 -0
  500. package/dist/components/Steps/steps.d.ts +71 -0
  501. package/dist/components/Steps/steps.d.ts.map +1 -0
  502. package/dist/components/Steps/steps.js +597 -0
  503. package/dist/components/Steps/steps.js.map +1 -0
  504. package/dist/components/Switch/index.d.ts +2 -0
  505. package/dist/components/Switch/index.d.ts.map +1 -0
  506. package/dist/components/Switch/index.js +7 -0
  507. package/dist/components/Switch/index.js.map +1 -0
  508. package/dist/components/Switch/switch.d.ts +112 -0
  509. package/dist/components/Switch/switch.d.ts.map +1 -0
  510. package/dist/components/Switch/switch.js +180 -0
  511. package/dist/components/Switch/switch.js.map +1 -0
  512. package/dist/components/Tabs/index.d.ts +2 -0
  513. package/dist/components/Tabs/index.d.ts.map +1 -0
  514. package/dist/components/Tabs/index.js +10 -0
  515. package/dist/components/Tabs/index.js.map +1 -0
  516. package/dist/components/Tabs/tabs.d.ts +104 -0
  517. package/dist/components/Tabs/tabs.d.ts.map +1 -0
  518. package/dist/components/Tabs/tabs.js +317 -0
  519. package/dist/components/Tabs/tabs.js.map +1 -0
  520. package/dist/components/Tag/index.d.ts +2 -0
  521. package/dist/components/Tag/index.d.ts.map +1 -0
  522. package/dist/components/Tag/index.js +7 -0
  523. package/dist/components/Tag/index.js.map +1 -0
  524. package/dist/components/Tag/tag.d.ts +86 -0
  525. package/dist/components/Tag/tag.d.ts.map +1 -0
  526. package/dist/components/Tag/tag.js +177 -0
  527. package/dist/components/Tag/tag.js.map +1 -0
  528. package/dist/components/Textarea/index.d.ts +2 -0
  529. package/dist/components/Textarea/index.d.ts.map +1 -0
  530. package/dist/components/Textarea/index.js +7 -0
  531. package/dist/components/Textarea/index.js.map +1 -0
  532. package/dist/components/Textarea/textarea.d.ts +69 -0
  533. package/dist/components/Textarea/textarea.d.ts.map +1 -0
  534. package/dist/components/Textarea/textarea.js +226 -0
  535. package/dist/components/Textarea/textarea.js.map +1 -0
  536. package/dist/components/TimePicker/index.d.ts +2 -0
  537. package/dist/components/TimePicker/index.d.ts.map +1 -0
  538. package/dist/components/TimePicker/index.js +6 -0
  539. package/dist/components/TimePicker/index.js.map +1 -0
  540. package/dist/components/TimePicker/time-columns.d.ts +46 -0
  541. package/dist/components/TimePicker/time-columns.d.ts.map +1 -0
  542. package/dist/components/TimePicker/time-columns.js +173 -0
  543. package/dist/components/TimePicker/time-columns.js.map +1 -0
  544. package/dist/components/TimePicker/time-picker.d.ts +95 -0
  545. package/dist/components/TimePicker/time-picker.d.ts.map +1 -0
  546. package/dist/components/TimePicker/time-picker.js +261 -0
  547. package/dist/components/TimePicker/time-picker.js.map +1 -0
  548. package/dist/components/Toast/index.d.ts +2 -0
  549. package/dist/components/Toast/index.d.ts.map +1 -0
  550. package/dist/components/Toast/index.js +7 -0
  551. package/dist/components/Toast/index.js.map +1 -0
  552. package/dist/components/Toast/toast.d.ts +61 -0
  553. package/dist/components/Toast/toast.d.ts.map +1 -0
  554. package/dist/components/Toast/toast.js +76 -0
  555. package/dist/components/Toast/toast.js.map +1 -0
  556. package/dist/components/Tooltip/index.d.ts +2 -0
  557. package/dist/components/Tooltip/index.d.ts.map +1 -0
  558. package/dist/components/Tooltip/index.js +9 -0
  559. package/dist/components/Tooltip/index.js.map +1 -0
  560. package/dist/components/Tooltip/tooltip.d.ts +20 -0
  561. package/dist/components/Tooltip/tooltip.d.ts.map +1 -0
  562. package/dist/components/Tooltip/tooltip.js +53 -0
  563. package/dist/components/Tooltip/tooltip.js.map +1 -0
  564. package/dist/components/TreeView/index.d.ts +2 -0
  565. package/dist/components/TreeView/index.d.ts.map +1 -0
  566. package/dist/components/TreeView/index.js +8 -0
  567. package/dist/components/TreeView/index.js.map +1 -0
  568. package/dist/components/TreeView/tree-view.d.ts +166 -0
  569. package/dist/components/TreeView/tree-view.d.ts.map +1 -0
  570. package/dist/components/TreeView/tree-view.js +644 -0
  571. package/dist/components/TreeView/tree-view.js.map +1 -0
  572. package/dist/hooks/use-controllable.d.ts +16 -0
  573. package/dist/hooks/use-controllable.d.ts.map +1 -0
  574. package/dist/hooks/use-controllable.js +26 -0
  575. package/dist/hooks/use-controllable.js.map +1 -0
  576. package/dist/hooks/use-is-narrow-viewport.d.ts +2 -0
  577. package/dist/hooks/use-is-narrow-viewport.d.ts.map +1 -0
  578. package/dist/hooks/use-is-narrow-viewport.js +19 -0
  579. package/dist/hooks/use-is-narrow-viewport.js.map +1 -0
  580. package/dist/hooks/use-is-touch-device.d.ts +8 -0
  581. package/dist/hooks/use-is-touch-device.d.ts.map +1 -0
  582. package/dist/hooks/use-is-touch-device.js +16 -0
  583. package/dist/hooks/use-is-touch-device.js.map +1 -0
  584. package/dist/hooks/use-overflow-items.d.ts +128 -0
  585. package/dist/hooks/use-overflow-items.d.ts.map +1 -0
  586. package/dist/hooks/use-overflow-items.js +97 -0
  587. package/dist/hooks/use-overflow-items.js.map +1 -0
  588. package/dist/index.d.ts +75 -0
  589. package/dist/index.d.ts.map +1 -0
  590. package/dist/index.js +395 -0
  591. package/dist/index.js.map +1 -0
  592. package/dist/lib/drag-visual.d.ts +158 -0
  593. package/dist/lib/drag-visual.d.ts.map +1 -0
  594. package/dist/lib/drag-visual.js +96 -0
  595. package/dist/lib/drag-visual.js.map +1 -0
  596. package/dist/lib/i18n/i18n-context.d.ts +105 -0
  597. package/dist/lib/i18n/i18n-context.d.ts.map +1 -0
  598. package/dist/lib/multi-select-ordering.d.ts +54 -0
  599. package/dist/lib/multi-select-ordering.d.ts.map +1 -0
  600. package/dist/lib/multi-select-ordering.js +13 -0
  601. package/dist/lib/multi-select-ordering.js.map +1 -0
  602. package/dist/lib/utils.d.ts +12 -0
  603. package/dist/lib/utils.d.ts.map +1 -0
  604. package/dist/lib/utils.js +79 -0
  605. package/dist/lib/utils.js.map +1 -0
  606. package/dist/patterns/element-anatomy/index.d.ts +2 -0
  607. package/dist/patterns/element-anatomy/index.d.ts.map +1 -0
  608. package/dist/patterns/element-anatomy/index.js +20 -0
  609. package/dist/patterns/element-anatomy/index.js.map +1 -0
  610. package/dist/patterns/element-anatomy/item-anatomy.d.ts +371 -0
  611. package/dist/patterns/element-anatomy/item-anatomy.d.ts.map +1 -0
  612. package/dist/patterns/element-anatomy/item-anatomy.js +272 -0
  613. package/dist/patterns/element-anatomy/item-anatomy.js.map +1 -0
  614. package/dist/patterns/header-canonical/chrome-header.d.ts +80 -0
  615. package/dist/patterns/header-canonical/chrome-header.d.ts.map +1 -0
  616. package/dist/patterns/header-canonical/chrome-header.js +75 -0
  617. package/dist/patterns/header-canonical/chrome-header.js.map +1 -0
  618. package/dist/patterns/header-canonical/index.d.ts +2 -0
  619. package/dist/patterns/header-canonical/index.d.ts.map +1 -0
  620. package/dist/patterns/header-canonical/index.js +5 -0
  621. package/dist/patterns/header-canonical/index.js.map +1 -0
  622. package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts +101 -0
  623. package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts.map +1 -0
  624. package/dist/patterns/horizontal-overflow/horizontal-overflow.js +105 -0
  625. package/dist/patterns/horizontal-overflow/horizontal-overflow.js.map +1 -0
  626. package/dist/patterns/horizontal-overflow/index.d.ts +2 -0
  627. package/dist/patterns/horizontal-overflow/index.d.ts.map +1 -0
  628. package/dist/patterns/horizontal-overflow/index.js +14 -0
  629. package/dist/patterns/horizontal-overflow/index.js.map +1 -0
  630. package/dist/patterns/overlay-surface/index.d.ts +2 -0
  631. package/dist/patterns/overlay-surface/index.d.ts.map +1 -0
  632. package/dist/patterns/overlay-surface/index.js +7 -0
  633. package/dist/patterns/overlay-surface/index.js.map +1 -0
  634. package/dist/patterns/overlay-surface/overlay-surface.d.ts +28 -0
  635. package/dist/patterns/overlay-surface/overlay-surface.d.ts.map +1 -0
  636. package/dist/patterns/overlay-surface/overlay-surface.js +85 -0
  637. package/dist/patterns/overlay-surface/overlay-surface.js.map +1 -0
  638. package/dist/patterns/resize-handle/index.d.ts +2 -0
  639. package/dist/patterns/resize-handle/index.d.ts.map +1 -0
  640. package/dist/patterns/resize-handle/index.js +5 -0
  641. package/dist/patterns/resize-handle/index.js.map +1 -0
  642. package/dist/patterns/resize-handle/resize-handle.d.ts +102 -0
  643. package/dist/patterns/resize-handle/resize-handle.d.ts.map +1 -0
  644. package/dist/patterns/resize-handle/resize-handle.js +74 -0
  645. package/dist/patterns/resize-handle/resize-handle.js.map +1 -0
  646. package/dist/react-day-picker.css +457 -0
  647. package/dist/stories-helpers/anatomy/anatomy-utils.d.ts +40 -0
  648. package/dist/stories-helpers/anatomy/anatomy-utils.d.ts.map +1 -0
  649. package/dist/tokens/elevation/overlay-geometry.d.ts +12 -0
  650. package/dist/tokens/elevation/overlay-geometry.d.ts.map +1 -0
  651. package/dist/tokens/elevation/overlay-geometry.js +7 -0
  652. package/dist/tokens/elevation/overlay-geometry.js.map +1 -0
  653. package/dist/tokens/motion/motion.d.ts +15 -0
  654. package/dist/tokens/motion/motion.d.ts.map +1 -0
  655. package/dist/tokens/motion/motion.js +9 -0
  656. package/dist/tokens/motion/motion.js.map +1 -0
  657. package/dist/tokens/uiSize/icon-size.d.ts +52 -0
  658. package/dist/tokens/uiSize/icon-size.d.ts.map +1 -0
  659. package/ds-canonical/commands/README.md +26 -0
  660. package/ds-canonical/commands/gov-status.md +79 -0
  661. package/ds-canonical/hooks/README.md +145 -0
  662. package/ds-canonical/hooks/_log-fire.sh +44 -0
  663. package/ds-canonical/hooks/auto_regen_ds_barrel.sh +58 -0
  664. package/ds-canonical/hooks/block_prototype_imports.py +111 -0
  665. package/ds-canonical/hooks/check_addon_subdir_ship.sh +76 -0
  666. package/ds-canonical/hooks/check_audit_post_report_validator.sh +136 -0
  667. package/ds-canonical/hooks/check_audit_sample_escape.sh +73 -0
  668. package/ds-canonical/hooks/check_benchmark_citation.sh +106 -0
  669. package/ds-canonical/hooks/check_canonical_propagation.sh +189 -0
  670. package/ds-canonical/hooks/check_chrome_header_avatar_canonical.sh +87 -0
  671. package/ds-canonical/hooks/check_codex_brief_invariants.sh +115 -0
  672. package/ds-canonical/hooks/check_codex_collab_5step.sh +108 -0
  673. package/ds-canonical/hooks/check_consumer_app_story_title.sh +81 -0
  674. package/ds-canonical/hooks/check_consumer_ds_primitive_misuse.sh +106 -0
  675. package/ds-canonical/hooks/check_consumer_no_ds_catalog.sh +98 -0
  676. package/ds-canonical/hooks/check_consumer_story_baseline.sh +76 -0
  677. package/ds-canonical/hooks/check_data_table_size_num_to_meta_width.sh +68 -0
  678. package/ds-canonical/hooks/check_datatable_invariants.sh +117 -0
  679. package/ds-canonical/hooks/check_dim_count_drift.sh +72 -0
  680. package/ds-canonical/hooks/check_ds_anchor_preflight.sh +132 -0
  681. package/ds-canonical/hooks/check_escape_marker_abuse.sh +126 -0
  682. package/ds-canonical/hooks/check_field_controls_contracts.sh +110 -0
  683. package/ds-canonical/hooks/check_field_family_invariants.sh +240 -0
  684. package/ds-canonical/hooks/check_file_size_budget.sh +60 -0
  685. package/ds-canonical/hooks/check_fork_user_plugin_install.sh +79 -0
  686. package/ds-canonical/hooks/check_full_story_visual_interaction_sweep.sh +71 -0
  687. package/ds-canonical/hooks/check_item_list_gap.sh +54 -0
  688. package/ds-canonical/hooks/check_layout_space_magic_numbers.sh +84 -0
  689. package/ds-canonical/hooks/check_main_branch_workbench.sh +93 -0
  690. package/ds-canonical/hooks/check_naming_and_abstraction.sh +165 -0
  691. package/ds-canonical/hooks/check_opacity_token_usage.sh +149 -0
  692. package/ds-canonical/hooks/check_orphan_ds_css.sh +66 -0
  693. package/ds-canonical/hooks/check_overlay_open_focus_escape_probe.sh +75 -0
  694. package/ds-canonical/hooks/check_pattern_invariants.sh +196 -0
  695. package/ds-canonical/hooks/check_peoplepicker_ssot_drift.sh +56 -0
  696. package/ds-canonical/hooks/check_pixel_quantified_audit.sh +53 -0
  697. package/ds-canonical/hooks/check_plugin_freshness.sh +68 -0
  698. package/ds-canonical/hooks/check_post_main_ssot_propagate.sh +88 -0
  699. package/ds-canonical/hooks/check_propose_cite_required.sh +88 -0
  700. package/ds-canonical/hooks/check_propose_plain_chinese.sh +74 -0
  701. package/ds-canonical/hooks/check_propose_pre_grep_verify.sh +70 -0
  702. package/ds-canonical/hooks/check_propose_without_benchmark.sh +63 -0
  703. package/ds-canonical/hooks/check_select_all_canonical.sh +58 -0
  704. package/ds-canonical/hooks/check_sidebar_menu_button_implicit_wrap.sh +86 -0
  705. package/ds-canonical/hooks/check_solo_workflow.sh +258 -0
  706. package/ds-canonical/hooks/check_spec_class_drift.sh +88 -0
  707. package/ds-canonical/hooks/check_story_invariants.sh +612 -0
  708. package/ds-canonical/hooks/check_storybook_addon_preset_cjs.sh +87 -0
  709. package/ds-canonical/hooks/check_substantive_edit_approval_preflight.sh +110 -0
  710. package/ds-canonical/hooks/check_tailwind_wildcard_in_docs.sh +73 -0
  711. package/ds-canonical/hooks/check_wrapper_primitive_schema_drift.sh +104 -0
  712. package/ds-canonical/hooks/chrome_header_dispatcher.sh +53 -0
  713. package/ds-canonical/hooks/enforce_home_charter.sh +44 -0
  714. package/ds-canonical/hooks/inject_deploy_url_after_push.sh +182 -0
  715. package/ds-canonical/hooks/inject_pending_self_audit.sh +248 -0
  716. package/ds-canonical/hooks/lib/_app_shell_primary_header_consistency.sh +70 -0
  717. package/ds-canonical/hooks/lib/_approval_re.sh +33 -0
  718. package/ds-canonical/hooks/lib/_chrome_header_handcraft.sh +70 -0
  719. package/ds-canonical/hooks/lib/_code_quality.sh +73 -0
  720. package/ds-canonical/hooks/lib/_cva_default_sync.sh +69 -0
  721. package/ds-canonical/hooks/lib/_governance_coverage_check.sh +49 -0
  722. package/ds-canonical/hooks/lib/_hardcoded_strings.sh +163 -0
  723. package/ds-canonical/hooks/lib/_header_with_tabs_border.sh +87 -0
  724. package/ds-canonical/hooks/lib/_layout_space_canonical.sh +56 -0
  725. package/ds-canonical/hooks/lib/_overlay_handcraft.sh +141 -0
  726. package/ds-canonical/hooks/lib/_person_data_richness.sh +42 -0
  727. package/ds-canonical/hooks/lib/_story_compile_drift.sh +48 -0
  728. package/ds-canonical/hooks/lib/_tab_lg_chrome_header_equal.sh +70 -0
  729. package/ds-canonical/hooks/lib/_token_hygiene.sh +96 -0
  730. package/ds-canonical/hooks/log_governance_fires.sh +50 -0
  731. package/ds-canonical/hooks/log_skill_invokes.sh +41 -0
  732. package/ds-canonical/hooks/post_edit_dispatcher.sh +62 -0
  733. package/ds-canonical/hooks/retired/check_anatomy_section_numbering.sh +106 -0
  734. package/ds-canonical/hooks/retired/check_avatar_hovercard.sh +90 -0
  735. package/ds-canonical/hooks/retired/check_button_icon_literal.sh.retired-2026-04-28 +38 -0
  736. package/ds-canonical/hooks/retired/check_container_breathing.sh +142 -0
  737. package/ds-canonical/hooks/retired/check_governance_compliance.sh +61 -0
  738. package/ds-canonical/hooks/retired/check_icon_only_padding_formula.sh +104 -0
  739. package/ds-canonical/hooks/retired/check_item_content_primitive.sh +150 -0
  740. package/ds-canonical/hooks/retired/check_item_list_gap.sh +153 -0
  741. package/ds-canonical/hooks/retired/check_sideoffset_canonical.sh +65 -0
  742. package/ds-canonical/hooks/retired/check_spec_iteration_tag.sh +87 -0
  743. package/ds-canonical/hooks/retired/check_ssot_consultation.sh +88 -0
  744. package/ds-canonical/hooks/retired/check_sync_update.sh +20 -0
  745. package/ds-canonical/hooks/retired/check_third_party_dom_verified.sh +95 -0
  746. package/ds-canonical/hooks/retired/enforce_home_charter.sh +125 -0
  747. package/ds-canonical/hooks/retired/post_edit_canonical_interrogate.sh +109 -0
  748. package/ds-canonical/hooks/retired/pre_edit_spec_check.sh +68 -0
  749. package/ds-canonical/hooks/retired/pre_new_component_spec.sh +39 -0
  750. package/ds-canonical/hooks/retired/pre_write_subsumption_check.sh +112 -0
  751. package/ds-canonical/hooks/retired/stop_meta_self_audit.sh.retired-2026-05-13 +76 -0
  752. package/ds-canonical/hooks/retired/tests/test_check_anatomy_section_numbering.sh +14 -0
  753. package/ds-canonical/hooks/retired/tests/test_check_avatar_hovercard.sh +15 -0
  754. package/ds-canonical/hooks/retired/tests/test_check_container_breathing.sh +15 -0
  755. package/ds-canonical/hooks/retired/tests/test_check_governance_compliance.sh +15 -0
  756. package/ds-canonical/hooks/retired/tests/test_check_icon_only_padding_formula.sh +79 -0
  757. package/ds-canonical/hooks/retired/tests/test_check_item_content_primitive.sh +15 -0
  758. package/ds-canonical/hooks/retired/tests/test_check_item_list_gap.sh +163 -0
  759. package/ds-canonical/hooks/retired/tests/test_check_sideoffset_canonical.sh +15 -0
  760. package/ds-canonical/hooks/retired/tests/test_check_spec_iteration_tag.sh +15 -0
  761. package/ds-canonical/hooks/retired/tests/test_check_ssot_consultation.sh +15 -0
  762. package/ds-canonical/hooks/retired/tests/test_check_sync_update.sh +14 -0
  763. package/ds-canonical/hooks/retired/tests/test_check_third_party_dom_verified.sh +15 -0
  764. package/ds-canonical/hooks/retired/tests/test_enforce_home_charter.sh +15 -0
  765. package/ds-canonical/hooks/retired/tests/test_pre_edit_spec_check.sh +15 -0
  766. package/ds-canonical/hooks/retired/tests/test_pre_new_component_spec.sh +15 -0
  767. package/ds-canonical/hooks/retired/tests/test_pre_write_subsumption_check.sh +63 -0
  768. package/ds-canonical/hooks/session_start_governance_check.sh +305 -0
  769. package/ds-canonical/hooks/stop_passive_logging.sh +322 -0
  770. package/ds-canonical/hooks/stop_self_audit.sh +475 -0
  771. package/ds-canonical/hooks/tests/KNOWN-BROKEN.md +15 -0
  772. package/ds-canonical/hooks/tests/run-all.sh +76 -0
  773. package/ds-canonical/hooks/tests/test_auto_regen_ds_barrel.sh +180 -0
  774. package/ds-canonical/hooks/tests/test_block_prototype_imports.sh +143 -0
  775. package/ds-canonical/hooks/tests/test_check_addon_subdir_ship.sh +170 -0
  776. package/ds-canonical/hooks/tests/test_check_app_shell_primary_header_consistency.sh +140 -0
  777. package/ds-canonical/hooks/tests/test_check_audit_post_report_validator.sh +127 -0
  778. package/ds-canonical/hooks/tests/test_check_audit_sample_escape.sh +93 -0
  779. package/ds-canonical/hooks/tests/test_check_benchmark_citation.sh +115 -0
  780. package/ds-canonical/hooks/tests/test_check_canonical_propagation.sh +133 -0
  781. package/ds-canonical/hooks/tests/test_check_chrome_header_avatar_canonical.sh +198 -0
  782. package/ds-canonical/hooks/tests/test_check_chrome_header_handcraft.sh +123 -0
  783. package/ds-canonical/hooks/tests/test_check_code_quality.sh +15 -0
  784. package/ds-canonical/hooks/tests/test_check_codex_brief_invariants.sh +208 -0
  785. package/ds-canonical/hooks/tests/test_check_codex_collab_5step.sh +96 -0
  786. package/ds-canonical/hooks/tests/test_check_consumer_app_story_title.sh +163 -0
  787. package/ds-canonical/hooks/tests/test_check_consumer_ds_primitive_misuse.sh +202 -0
  788. package/ds-canonical/hooks/tests/test_check_consumer_no_ds_catalog.sh +201 -0
  789. package/ds-canonical/hooks/tests/test_check_consumer_story_baseline.sh +200 -0
  790. package/ds-canonical/hooks/tests/test_check_cva_default_sync.sh +15 -0
  791. package/ds-canonical/hooks/tests/test_check_data_table_size_num_to_meta_width.sh +52 -0
  792. package/ds-canonical/hooks/tests/test_check_datatable_invariants.sh +122 -0
  793. package/ds-canonical/hooks/tests/test_check_dim_count_drift.sh +98 -0
  794. package/ds-canonical/hooks/tests/test_check_ds_anchor_preflight.sh +104 -0
  795. package/ds-canonical/hooks/tests/test_check_escape_marker_abuse.sh +192 -0
  796. package/ds-canonical/hooks/tests/test_check_field_controls_contracts.sh +126 -0
  797. package/ds-canonical/hooks/tests/test_check_field_family_invariants.sh +194 -0
  798. package/ds-canonical/hooks/tests/test_check_file_size_budget.sh +32 -0
  799. package/ds-canonical/hooks/tests/test_check_fork_user_plugin_install.sh +45 -0
  800. package/ds-canonical/hooks/tests/test_check_full_story_visual_interaction_sweep.sh +190 -0
  801. package/ds-canonical/hooks/tests/test_check_hardcoded_strings.sh +14 -0
  802. package/ds-canonical/hooks/tests/test_check_header_with_tabs_border.sh +110 -0
  803. package/ds-canonical/hooks/tests/test_check_item_list_gap.sh +44 -0
  804. package/ds-canonical/hooks/tests/test_check_layout_space_canonical.sh +73 -0
  805. package/ds-canonical/hooks/tests/test_check_layout_space_magic_numbers.sh +196 -0
  806. package/ds-canonical/hooks/tests/test_check_main_branch_workbench.sh +147 -0
  807. package/ds-canonical/hooks/tests/test_check_naming_and_abstraction.sh +136 -0
  808. package/ds-canonical/hooks/tests/test_check_opacity_token_usage.sh +110 -0
  809. package/ds-canonical/hooks/tests/test_check_orphan_ds_css.sh +212 -0
  810. package/ds-canonical/hooks/tests/test_check_overlay_handcraft.sh +126 -0
  811. package/ds-canonical/hooks/tests/test_check_overlay_open_focus_escape_probe.sh +191 -0
  812. package/ds-canonical/hooks/tests/test_check_pattern_invariants.sh +148 -0
  813. package/ds-canonical/hooks/tests/test_check_peoplepicker_ssot_drift.sh +108 -0
  814. package/ds-canonical/hooks/tests/test_check_person_data_richness.sh +58 -0
  815. package/ds-canonical/hooks/tests/test_check_pixel_quantified_audit.sh +142 -0
  816. package/ds-canonical/hooks/tests/test_check_propose_cite_required.sh +180 -0
  817. package/ds-canonical/hooks/tests/test_check_propose_plain_chinese.sh +126 -0
  818. package/ds-canonical/hooks/tests/test_check_propose_pre_grep_verify.sh +117 -0
  819. package/ds-canonical/hooks/tests/test_check_propose_without_benchmark.sh +55 -0
  820. package/ds-canonical/hooks/tests/test_check_select_all_canonical.sh +125 -0
  821. package/ds-canonical/hooks/tests/test_check_sidebar_menu_button_implicit_wrap.sh +224 -0
  822. package/ds-canonical/hooks/tests/test_check_solo_workflow.sh +201 -0
  823. package/ds-canonical/hooks/tests/test_check_spec_class_drift.sh +135 -0
  824. package/ds-canonical/hooks/tests/test_check_story_anatomy.sh.broken +197 -0
  825. package/ds-canonical/hooks/tests/test_check_story_category.sh.broken +187 -0
  826. package/ds-canonical/hooks/tests/test_check_story_compile_drift.sh +15 -0
  827. package/ds-canonical/hooks/tests/test_check_story_invariants.sh +209 -0
  828. package/ds-canonical/hooks/tests/test_check_story_name_jargon.sh.broken +53 -0
  829. package/ds-canonical/hooks/tests/test_check_story_slot_split.sh +156 -0
  830. package/ds-canonical/hooks/tests/test_check_storybook_addon_preset_cjs.sh +199 -0
  831. package/ds-canonical/hooks/tests/test_check_substantive_edit_approval_preflight.sh +176 -0
  832. package/ds-canonical/hooks/tests/test_check_tab_lg_chrome_header_equal.sh +138 -0
  833. package/ds-canonical/hooks/tests/test_check_tailwind_wildcard_in_docs.sh +182 -0
  834. package/ds-canonical/hooks/tests/test_check_token_hygiene.sh +21 -0
  835. package/ds-canonical/hooks/tests/test_check_wrapper_primitive_schema_drift.sh +169 -0
  836. package/ds-canonical/hooks/tests/test_enforce_home_charter.sh +77 -0
  837. package/ds-canonical/hooks/tests/test_inject_pending_self_audit.sh +125 -0
  838. package/ds-canonical/hooks/tests/test_log_governance_fires.sh +10 -0
  839. package/ds-canonical/hooks/tests/test_log_skill_invokes.sh +7 -0
  840. package/ds-canonical/hooks/tests/test_post_edit_dispatcher.sh +108 -0
  841. package/ds-canonical/hooks/tests/test_session_start_governance_check.sh +154 -0
  842. package/ds-canonical/hooks/tests/test_stop_capture_metrics.sh +95 -0
  843. package/ds-canonical/hooks/tests/test_stop_governance_drift_check.sh.broken +125 -0
  844. package/ds-canonical/hooks/tests/test_stop_harvest_corrections.sh +10 -0
  845. package/ds-canonical/hooks/tests/test_stop_passive_logging.sh +100 -0
  846. package/ds-canonical/hooks/tests/test_stop_self_audit.sh +76 -0
  847. package/ds-canonical/hooks/tests/test_stop_tsc_sanity.sh +10 -0
  848. package/ds-canonical/references/README.md +46 -0
  849. package/ds-canonical/references/audit-coverage-vs-24-checklist.md +74 -0
  850. package/ds-canonical/references/build-ui-canonicals.md +69 -0
  851. package/ds-canonical/references/composition-fidelity.md +101 -0
  852. package/ds-canonical/references/cva-patterns.md +41 -0
  853. package/ds-canonical/references/drag-canonical.md +331 -0
  854. package/ds-canonical/references/item-anatomy-recipe.md +225 -0
  855. package/ds-canonical/references/naming-conventions.md +56 -0
  856. package/ds-canonical/references/principle-dim-map.json +513 -0
  857. package/ds-canonical/references/props-naming.md +45 -0
  858. package/ds-canonical/references/scenario-definition.md +146 -0
  859. package/ds-canonical/references/spec-rules.md +58 -0
  860. package/ds-canonical/references/ssot-consultation.md +63 -0
  861. package/ds-canonical/references/ssot-index.md +40 -0
  862. package/ds-canonical/references/story-baseline-registry.json +79 -0
  863. package/ds-canonical/references/structural-token-retention.md +42 -0
  864. package/ds-canonical/references/tailwind-gotchas.md +87 -0
  865. package/ds-canonical/references/ui-dev-rules.md +60 -0
  866. package/ds-canonical/rules/README.md +34 -0
  867. package/ds-canonical/rules/meta-patterns.md +87 -0
  868. package/ds-canonical/rules/self-verify.md +53 -0
  869. package/ds-canonical/rules/spec-rules.md +25 -0
  870. package/ds-canonical/rules/story-rules.md +65 -0
  871. package/ds-canonical/rules/ui-development.md +87 -0
  872. package/ds-canonical/skills/README.md +88 -0
  873. package/ds-canonical/skills/bug-fix-rhythm/SKILL.md +181 -0
  874. package/ds-canonical/skills/code-quality-audit/SKILL.md +63 -0
  875. package/ds-canonical/skills/codex-collab/SKILL.md +249 -0
  876. package/ds-canonical/skills/codex-collab/references/brief-template.md +48 -0
  877. package/ds-canonical/skills/codex-collab/references/transport.md +58 -0
  878. package/ds-canonical/skills/codify-corrections/SKILL.md +184 -0
  879. package/ds-canonical/skills/codify-principle/SKILL.md +151 -0
  880. package/ds-canonical/skills/component-quality-gate/SKILL.md +102 -0
  881. package/ds-canonical/skills/component-quality-gate/references/checklist.md +79 -0
  882. package/ds-canonical/skills/deep-audit-cross-codex/SKILL.md +267 -0
  883. package/ds-canonical/skills/deep-audit-cross-codex/references/phase-a-workflow.md +123 -0
  884. package/ds-canonical/skills/deep-audit-cross-codex/references/phase-b-codex-brief.md +186 -0
  885. package/ds-canonical/skills/deep-audit-cross-codex/references/skill-relationships-antipatterns-benchmarks.md +30 -0
  886. package/ds-canonical/skills/deep-audit-cross-codex/references/triage-rubric.md +91 -0
  887. package/ds-canonical/skills/deep-audit-cross-codex/references/upstream-directives-r-mapping.md +33 -0
  888. package/ds-canonical/skills/delivery-handoff/SKILL.md +229 -0
  889. package/ds-canonical/skills/delivery-handoff/references/flow-diagram.md +180 -0
  890. package/ds-canonical/skills/delivery-handoff/references/handoff-template.md +177 -0
  891. package/ds-canonical/skills/delivery-handoff/references/inventory-checklist.md +196 -0
  892. package/ds-canonical/skills/design-system-audit/SKILL.md +384 -0
  893. package/ds-canonical/skills/design-system-audit/references/audit-prompts.md +1317 -0
  894. package/ds-canonical/skills/design-system-audit/references/checkpoints.md +240 -0
  895. package/ds-canonical/skills/design-system-audit/references/historical-bugs.md +240 -0
  896. package/ds-canonical/skills/design-system-audit/references/principle-audit-protocol.md +378 -0
  897. package/ds-canonical/skills/design-system-audit/references/rule-placement.md +175 -0
  898. package/ds-canonical/skills/ensure-canonical/SKILL.md +196 -0
  899. package/ds-canonical/skills/governance-health/SKILL.md +147 -0
  900. package/ds-canonical/skills/knowledge-prune/SKILL.md +248 -0
  901. package/ds-canonical/skills/knowledge-prune/references/phase-z-cross-repo-ssot-propagation.md +11 -0
  902. package/ds-canonical/skills/knowledge-prune/references/prune-dimensions-d5-d10.md +55 -0
  903. package/ds-canonical/skills/knowledge-prune/references/world-class-prune-alignment.md +7 -0
  904. package/ds-canonical/skills/new-component/SKILL.md +170 -0
  905. package/ds-canonical/skills/new-component/references/new-component-checklist.md +85 -0
  906. package/ds-canonical/skills/performance-audit/SKILL.md +107 -0
  907. package/ds-canonical/skills/product-ui-audit/SKILL.md +230 -0
  908. package/ds-canonical/skills/product-ui-audit/references/audit-checks.md +246 -0
  909. package/ds-canonical/skills/product-ui-audit/references/common-misuses.md +329 -0
  910. package/ds-canonical/skills/product-ui-audit/references/report-template.md +159 -0
  911. package/ds-canonical/skills/propose-options/SKILL.md +177 -0
  912. package/ds-canonical/skills/prototype/SKILL.md +244 -0
  913. package/ds-canonical/skills/prototype/references/audit-checks.md +37 -0
  914. package/ds-canonical/skills/prototype/references/benchmark-sources.md +94 -0
  915. package/ds-canonical/skills/prototype/references/checkpoints.md +191 -0
  916. package/ds-canonical/skills/prototype/references/evaluation-matrix.md +141 -0
  917. package/ds-canonical/skills/prototype/references/ooux-template.md +198 -0
  918. package/ds-canonical/skills/prototype/references/proposal-template.md +229 -0
  919. package/ds-canonical/skills/scan-similar-bugs/SKILL.md +198 -0
  920. package/ds-canonical/skills/story-auto-compile-migrate/SKILL.md +159 -0
  921. package/ds-canonical/skills/story-writing/SKILL.md +122 -0
  922. package/ds-canonical/skills/story-writing/references/anatomy-standard.md +217 -0
  923. package/ds-canonical/skills/story-writing/references/category-templates.md +174 -0
  924. package/ds-canonical/skills/story-writing/references/example-selection.md +70 -0
  925. package/ds-canonical/skills/story-writing/references/self-check.md +20 -0
  926. package/ds-canonical/skills/ux-audit/SKILL.md +130 -0
  927. package/ds-canonical/skills/visual-audit/SKILL.md +245 -0
  928. package/ds-canonical/skills/visual-audit/output/.gitkeep +0 -0
  929. package/ds-canonical/skills/visual-audit/references/audit-architecture.md +100 -0
  930. package/ds-canonical/skills/visual-audit/references/visual-checklist.md +297 -0
  931. package/ds-canonical/skills/visual-audit/references/world-class-benchmarks.md +198 -0
  932. package/ds-canonical/templates/_README.md +23 -0
  933. package/ds-canonical/templates/dashboard-app.tsx +145 -0
  934. package/ds-story-manifest.json +1685 -0
  935. package/package.json +22 -13
  936. package/src/components/Accordion/accordion.anatomy.stories.tsx +496 -0
  937. package/src/components/Accordion/accordion.principles.stories.tsx +360 -0
  938. package/src/components/Accordion/accordion.spec.md +114 -0
  939. package/src/components/Accordion/accordion.stories.tsx +190 -0
  940. package/src/components/Accordion/accordion.tsx +3 -0
  941. package/src/components/Accordion/index.ts +5 -0
  942. package/src/components/Alert/alert.anatomy.stories.tsx +238 -0
  943. package/src/components/Alert/alert.principles.stories.tsx +220 -0
  944. package/src/components/Alert/alert.spec.md +197 -0
  945. package/src/components/Alert/alert.stories.tsx +139 -0
  946. package/src/components/Alert/index.ts +5 -0
  947. package/src/components/AppShell/_demo-helpers.tsx +5 -5
  948. package/src/components/AppShell/app-shell.anatomy.stories.tsx +176 -0
  949. package/src/components/AppShell/app-shell.principles.stories.tsx +81 -0
  950. package/src/components/AppShell/app-shell.spec.md +330 -0
  951. package/src/components/AppShell/app-shell.stories.tsx +435 -0
  952. package/src/components/AppShell/index.ts +5 -0
  953. package/src/components/AspectRatio/aspect-ratio.anatomy.stories.tsx +208 -0
  954. package/src/components/AspectRatio/aspect-ratio.principles.stories.tsx +303 -0
  955. package/src/components/AspectRatio/aspect-ratio.spec.md +134 -0
  956. package/src/components/AspectRatio/aspect-ratio.stories.tsx +170 -0
  957. package/src/components/AspectRatio/index.ts +5 -0
  958. package/src/components/Avatar/avatar.anatomy.stories.tsx +700 -0
  959. package/src/components/Avatar/avatar.principles.stories.tsx +245 -0
  960. package/src/components/Avatar/avatar.spec.md +331 -0
  961. package/src/components/Avatar/avatar.stories.tsx +135 -0
  962. package/src/components/Avatar/avatar.tsx +21 -16
  963. package/src/components/Avatar/index.ts +5 -0
  964. package/src/components/Badge/badge.anatomy.stories.tsx +588 -0
  965. package/src/components/Badge/badge.principles.stories.tsx +393 -0
  966. package/src/components/Badge/badge.spec.md +380 -0
  967. package/src/components/Badge/badge.stories.tsx +82 -0
  968. package/src/components/Badge/index.ts +5 -0
  969. package/src/components/Breadcrumb/breadcrumb.anatomy.stories.tsx +458 -0
  970. package/src/components/Breadcrumb/breadcrumb.principles.stories.tsx +340 -0
  971. package/src/components/Breadcrumb/breadcrumb.spec.md +258 -0
  972. package/src/components/Breadcrumb/breadcrumb.stories.tsx +332 -0
  973. package/src/components/Breadcrumb/breadcrumb.tsx +27 -17
  974. package/src/components/Breadcrumb/index.ts +5 -0
  975. package/src/components/BulkActionBar/bulk-action-bar.anatomy.stories.tsx +224 -0
  976. package/src/components/BulkActionBar/bulk-action-bar.principles.stories.tsx +242 -0
  977. package/src/components/BulkActionBar/bulk-action-bar.spec.md +210 -0
  978. package/src/components/BulkActionBar/bulk-action-bar.stories.tsx +136 -0
  979. package/src/components/BulkActionBar/bulk-action-bar.tsx +2 -1
  980. package/src/components/BulkActionBar/index.ts +5 -0
  981. package/src/components/Button/button.anatomy.stories.tsx +710 -0
  982. package/src/components/Button/button.principles.stories.tsx +370 -0
  983. package/src/components/Button/button.spec.md +461 -0
  984. package/src/components/Button/button.stories.tsx +362 -0
  985. package/src/components/Button/index.ts +5 -0
  986. package/src/components/Calendar/calendar.anatomy.stories.tsx +218 -0
  987. package/src/components/Calendar/calendar.principles.stories.tsx +143 -0
  988. package/src/components/Calendar/calendar.spec.md +244 -0
  989. package/src/components/Calendar/calendar.stories.tsx +88 -0
  990. package/src/components/Calendar/calendar.tsx +22 -2
  991. package/src/components/Calendar/index.ts +5 -0
  992. package/src/components/Carousel/carousel.anatomy.stories.tsx +516 -0
  993. package/src/components/Carousel/carousel.principles.stories.tsx +330 -0
  994. package/src/components/Carousel/carousel.spec.md +253 -0
  995. package/src/components/Carousel/carousel.stories.tsx +121 -0
  996. package/src/components/Carousel/carousel.tsx +7 -3
  997. package/src/components/Carousel/index.ts +5 -0
  998. package/src/components/Chart/chart.anatomy.stories.tsx +307 -0
  999. package/src/components/Chart/chart.principles.stories.tsx +436 -0
  1000. package/src/components/Chart/chart.spec.md +155 -0
  1001. package/src/components/Chart/chart.stories.tsx +268 -0
  1002. package/src/components/Chart/chart.tsx +3 -0
  1003. package/src/components/Chart/index.ts +5 -0
  1004. package/src/components/Checkbox/checkbox.anatomy.stories.tsx +626 -0
  1005. package/src/components/Checkbox/checkbox.principles.stories.tsx +213 -0
  1006. package/src/components/Checkbox/checkbox.spec.md +344 -0
  1007. package/src/components/Checkbox/checkbox.stories.tsx +114 -0
  1008. package/src/components/Checkbox/checkbox.tsx +12 -12
  1009. package/src/components/Checkbox/index.ts +5 -0
  1010. package/src/components/Chip/chip.anatomy.stories.tsx +422 -0
  1011. package/src/components/Chip/chip.principles.stories.tsx +222 -0
  1012. package/src/components/Chip/chip.spec.md +238 -0
  1013. package/src/components/Chip/chip.stories.tsx +88 -0
  1014. package/src/components/Chip/chip.tsx +4 -4
  1015. package/src/components/Chip/index.ts +5 -0
  1016. package/src/components/CircularProgress/circular-progress.anatomy.stories.tsx +176 -0
  1017. package/src/components/CircularProgress/circular-progress.principles.stories.tsx +258 -0
  1018. package/src/components/CircularProgress/circular-progress.spec.md +268 -0
  1019. package/src/components/CircularProgress/circular-progress.stories.tsx +160 -0
  1020. package/src/components/CircularProgress/index.ts +5 -0
  1021. package/src/components/Coachmark/coachmark-story-helpers.tsx +39 -0
  1022. package/src/components/Coachmark/coachmark.anatomy.stories.tsx +356 -0
  1023. package/src/components/Coachmark/coachmark.principles.stories.tsx +369 -0
  1024. package/src/components/Coachmark/coachmark.spec.md +230 -0
  1025. package/src/components/Coachmark/coachmark.stories.tsx +214 -0
  1026. package/src/components/Coachmark/coachmark.tsx +12 -3
  1027. package/src/components/Coachmark/index.ts +5 -0
  1028. package/src/components/Combobox/combobox.anatomy.stories.tsx +918 -0
  1029. package/src/components/Combobox/combobox.principles.stories.tsx +239 -0
  1030. package/src/components/Combobox/combobox.spec.md +182 -0
  1031. package/src/components/Combobox/combobox.stories.tsx +184 -0
  1032. package/src/components/Combobox/combobox.tsx +21 -8
  1033. package/src/components/Combobox/index.ts +5 -0
  1034. package/src/components/Command/command.anatomy.stories.tsx +105 -0
  1035. package/src/components/Command/command.principles.stories.tsx +88 -0
  1036. package/src/components/Command/command.spec.md +171 -0
  1037. package/src/components/Command/command.stories.tsx +280 -0
  1038. package/src/components/Command/index.ts +5 -0
  1039. package/src/components/DataTable/data-table-filter-panel.tsx +1 -1
  1040. package/src/components/DataTable/data-table.anatomy.stories.tsx +523 -0
  1041. package/src/components/DataTable/data-table.principles.stories.tsx +265 -0
  1042. package/src/components/DataTable/data-table.spec.md +526 -0
  1043. package/src/components/DataTable/data-table.stories.tsx +1892 -0
  1044. package/src/components/DataTable/data-table.tsx +4 -4
  1045. package/src/components/DataTable/index.ts +5 -0
  1046. package/src/components/DateGrid/date-grid.anatomy.stories.tsx +583 -0
  1047. package/src/components/DateGrid/date-grid.principles.stories.tsx +338 -0
  1048. package/src/components/DateGrid/date-grid.spec.md +215 -0
  1049. package/src/components/DateGrid/date-grid.stories.tsx +195 -0
  1050. package/src/components/DateGrid/date-grid.tsx +13 -13
  1051. package/src/components/DateGrid/index.ts +5 -0
  1052. package/src/components/DatePicker/date-picker.anatomy.stories.tsx +952 -0
  1053. package/src/components/DatePicker/date-picker.principles.stories.tsx +205 -0
  1054. package/src/components/DatePicker/date-picker.spec.md +333 -0
  1055. package/src/components/DatePicker/date-picker.stories.tsx +353 -0
  1056. package/src/components/DatePicker/date-picker.tsx +12 -1
  1057. package/src/components/DatePicker/index.ts +5 -0
  1058. package/src/components/DescriptionList/description-list.anatomy.stories.tsx +252 -0
  1059. package/src/components/DescriptionList/description-list.principles.stories.tsx +323 -0
  1060. package/src/components/DescriptionList/description-list.spec.md +214 -0
  1061. package/src/components/DescriptionList/description-list.stories.tsx +128 -0
  1062. package/src/components/DescriptionList/description-list.tsx +2 -2
  1063. package/src/components/DescriptionList/index.ts +5 -0
  1064. package/src/components/Dialog/dialog.anatomy.stories.tsx +484 -0
  1065. package/src/components/Dialog/dialog.principles.stories.tsx +313 -0
  1066. package/src/components/Dialog/dialog.spec.md +201 -0
  1067. package/src/components/Dialog/dialog.stories.tsx +500 -0
  1068. package/src/components/Dialog/dialog.tsx +4 -4
  1069. package/src/components/Dialog/index.ts +5 -0
  1070. package/src/components/DropdownMenu/dropdown-menu.anatomy.stories.tsx +969 -0
  1071. package/src/components/DropdownMenu/dropdown-menu.principles.stories.tsx +340 -0
  1072. package/src/components/DropdownMenu/dropdown-menu.spec.md +259 -0
  1073. package/src/components/DropdownMenu/dropdown-menu.stories.tsx +288 -0
  1074. package/src/components/DropdownMenu/dropdown-menu.tsx +13 -5
  1075. package/src/components/DropdownMenu/index.ts +5 -0
  1076. package/src/components/Empty/empty.anatomy.stories.tsx +272 -0
  1077. package/src/components/Empty/empty.principles.stories.tsx +314 -0
  1078. package/src/components/Empty/empty.spec.md +215 -0
  1079. package/src/components/Empty/empty.stories.tsx +80 -0
  1080. package/src/components/Empty/index.ts +5 -0
  1081. package/src/components/Field/field-controls.spec.md +338 -0
  1082. package/src/components/Field/field-types.ts +1 -1
  1083. package/src/components/Field/field.anatomy.stories.tsx +541 -0
  1084. package/src/components/Field/field.principles.stories.tsx +277 -0
  1085. package/src/components/Field/field.spec.md +438 -0
  1086. package/src/components/Field/field.stories.tsx +552 -0
  1087. package/src/components/Field/form-validation.spec.md +150 -0
  1088. package/src/components/Field/index.ts +5 -0
  1089. package/src/components/FieldControlGroup/field-control-group.anatomy.stories.tsx +117 -0
  1090. package/src/components/FieldControlGroup/field-control-group.principles.stories.tsx +117 -0
  1091. package/src/components/FieldControlGroup/field-control-group.spec.md +179 -0
  1092. package/src/components/FieldControlGroup/field-control-group.stories.tsx +161 -0
  1093. package/src/components/FieldControlGroup/index.ts +5 -0
  1094. package/src/components/FileItem/file-item.anatomy.stories.tsx +354 -0
  1095. package/src/components/FileItem/file-item.principles.stories.tsx +275 -0
  1096. package/src/components/FileItem/file-item.spec.md +461 -0
  1097. package/src/components/FileItem/file-item.stories.tsx +204 -0
  1098. package/src/components/FileItem/index.ts +5 -0
  1099. package/src/components/FileUpload/file-upload.anatomy.stories.tsx +457 -0
  1100. package/src/components/FileUpload/file-upload.principles.stories.tsx +314 -0
  1101. package/src/components/FileUpload/file-upload.spec.md +123 -0
  1102. package/src/components/FileUpload/file-upload.stories.tsx +134 -0
  1103. package/src/components/FileUpload/file-upload.tsx +4 -4
  1104. package/src/components/FileUpload/index.ts +5 -0
  1105. package/src/components/FileViewer/file-viewer.anatomy.stories.tsx +1122 -0
  1106. package/src/components/FileViewer/file-viewer.principles.stories.tsx +636 -0
  1107. package/src/components/FileViewer/file-viewer.spec.md +374 -0
  1108. package/src/components/FileViewer/file-viewer.stories.tsx +407 -0
  1109. package/src/components/FileViewer/file-viewer.tsx +10 -9
  1110. package/src/components/FileViewer/index.ts +5 -0
  1111. package/src/components/HoverCard/hover-card.anatomy.stories.tsx +145 -0
  1112. package/src/components/HoverCard/hover-card.principles.stories.tsx +222 -0
  1113. package/src/components/HoverCard/hover-card.spec.md +157 -0
  1114. package/src/components/HoverCard/hover-card.stories.tsx +304 -0
  1115. package/src/components/HoverCard/hover-card.tsx +2 -2
  1116. package/src/components/HoverCard/index.ts +5 -0
  1117. package/src/components/Input/index.ts +5 -0
  1118. package/src/components/Input/input.anatomy.stories.tsx +763 -0
  1119. package/src/components/Input/input.principles.stories.tsx +292 -0
  1120. package/src/components/Input/input.spec.md +195 -0
  1121. package/src/components/Input/input.stories.tsx +133 -0
  1122. package/src/components/Input/input.tsx +11 -4
  1123. package/src/components/LinkInput/index.ts +5 -0
  1124. package/src/components/LinkInput/link-input.anatomy.stories.tsx +746 -0
  1125. package/src/components/LinkInput/link-input.principles.stories.tsx +182 -0
  1126. package/src/components/LinkInput/link-input.spec.md +131 -0
  1127. package/src/components/LinkInput/link-input.stories.tsx +132 -0
  1128. package/src/components/Menu/index.ts +5 -0
  1129. package/src/components/Menu/menu-item.anatomy.stories.tsx +780 -0
  1130. package/src/components/Menu/menu-item.principles.stories.tsx +81 -0
  1131. package/src/components/Menu/menu-item.spec.md +292 -0
  1132. package/src/components/Menu/menu-item.stories.tsx +214 -0
  1133. package/src/components/Menu/menu-item.tsx +1 -0
  1134. package/src/components/Notice/index.ts +5 -0
  1135. package/src/components/Notice/notice.anatomy.stories.tsx +610 -0
  1136. package/src/components/Notice/notice.principles.stories.tsx +102 -0
  1137. package/src/components/Notice/notice.spec.md +151 -0
  1138. package/src/components/Notice/notice.stories.tsx +257 -0
  1139. package/src/components/Notice/notice.tsx +1 -0
  1140. package/src/components/NumberInput/index.ts +5 -0
  1141. package/src/components/NumberInput/number-input.anatomy.stories.tsx +786 -0
  1142. package/src/components/NumberInput/number-input.principles.stories.tsx +221 -0
  1143. package/src/components/NumberInput/number-input.spec.md +125 -0
  1144. package/src/components/NumberInput/number-input.stories.tsx +142 -0
  1145. package/src/components/NumberInput/number-input.tsx +2 -1
  1146. package/src/components/OverflowIndicator/index.ts +5 -0
  1147. package/src/components/OverflowIndicator/overflow-indicator.anatomy.stories.tsx +548 -0
  1148. package/src/components/OverflowIndicator/overflow-indicator.principles.stories.tsx +80 -0
  1149. package/src/components/OverflowIndicator/overflow-indicator.spec.md +119 -0
  1150. package/src/components/OverflowIndicator/overflow-indicator.stories.tsx +274 -0
  1151. package/src/components/OverflowIndicator/overflow-indicator.tsx +9 -2
  1152. package/src/components/PeoplePicker/index.ts +5 -0
  1153. package/src/components/PeoplePicker/people-picker-helpers.ts +5 -5
  1154. package/src/components/PeoplePicker/people-picker.anatomy.stories.tsx +418 -0
  1155. package/src/components/PeoplePicker/people-picker.principles.stories.tsx +192 -0
  1156. package/src/components/PeoplePicker/people-picker.spec.md +278 -0
  1157. package/src/components/PeoplePicker/people-picker.stories.tsx +162 -0
  1158. package/src/components/PeoplePicker/people-picker.tsx +3 -3
  1159. package/src/components/PeoplePicker/person-display.tsx +25 -25
  1160. package/src/components/Popover/index.ts +5 -0
  1161. package/src/components/Popover/popover.anatomy.stories.tsx +277 -0
  1162. package/src/components/Popover/popover.principles.stories.tsx +293 -0
  1163. package/src/components/Popover/popover.spec.md +200 -0
  1164. package/src/components/Popover/popover.stories.tsx +116 -0
  1165. package/src/components/Popover/popover.tsx +2 -2
  1166. package/src/components/ProfileCard/index.ts +5 -0
  1167. package/src/components/ProfileCard/profile-card.anatomy.stories.tsx +504 -0
  1168. package/src/components/ProfileCard/profile-card.principles.stories.tsx +221 -0
  1169. package/src/components/ProfileCard/profile-card.spec.md +171 -0
  1170. package/src/components/ProfileCard/profile-card.stories.tsx +53 -0
  1171. package/src/components/{NameCard/name-card.tsx → ProfileCard/profile-card.tsx} +23 -23
  1172. package/src/components/ProgressBar/index.ts +5 -0
  1173. package/src/components/ProgressBar/progress-bar.anatomy.stories.tsx +438 -0
  1174. package/src/components/ProgressBar/progress-bar.principles.stories.tsx +337 -0
  1175. package/src/components/ProgressBar/progress-bar.spec.md +232 -0
  1176. package/src/components/ProgressBar/progress-bar.stories.tsx +119 -0
  1177. package/src/components/RadioGroup/index.ts +5 -0
  1178. package/src/components/RadioGroup/radio-group.anatomy.stories.tsx +678 -0
  1179. package/src/components/RadioGroup/radio-group.principles.stories.tsx +170 -0
  1180. package/src/components/RadioGroup/radio-group.spec.md +141 -0
  1181. package/src/components/RadioGroup/radio-group.stories.tsx +101 -0
  1182. package/src/components/RadioGroup/radio-group.tsx +11 -22
  1183. package/src/components/Rating/index.ts +5 -0
  1184. package/src/components/Rating/rating.anatomy.stories.tsx +494 -0
  1185. package/src/components/Rating/rating.principles.stories.tsx +293 -0
  1186. package/src/components/Rating/rating.spec.md +208 -0
  1187. package/src/components/Rating/rating.stories.tsx +133 -0
  1188. package/src/components/Rating/rating.tsx +16 -5
  1189. package/src/components/ScrollArea/index.ts +5 -0
  1190. package/src/components/ScrollArea/scroll-area.anatomy.stories.tsx +431 -0
  1191. package/src/components/ScrollArea/scroll-area.principles.stories.tsx +337 -0
  1192. package/src/components/ScrollArea/scroll-area.spec.md +145 -0
  1193. package/src/components/ScrollArea/scroll-area.stories.tsx +193 -0
  1194. package/src/components/SegmentedControl/index.ts +5 -0
  1195. package/src/components/SegmentedControl/segmented-control.anatomy.stories.tsx +295 -0
  1196. package/src/components/SegmentedControl/segmented-control.principles.stories.tsx +281 -0
  1197. package/src/components/SegmentedControl/segmented-control.spec.md +296 -0
  1198. package/src/components/SegmentedControl/segmented-control.stories.tsx +33 -0
  1199. package/src/components/SegmentedControl/segmented-control.tsx +3 -2
  1200. package/src/components/Select/index.ts +5 -0
  1201. package/src/components/Select/select.anatomy.stories.tsx +827 -0
  1202. package/src/components/Select/select.principles.stories.tsx +311 -0
  1203. package/src/components/Select/select.spec.md +311 -0
  1204. package/src/components/Select/select.stories.tsx +198 -0
  1205. package/src/components/Select/select.tsx +6 -2
  1206. package/src/components/SelectMenu/index.ts +5 -0
  1207. package/src/components/SelectMenu/select-menu.anatomy.stories.tsx +811 -0
  1208. package/src/components/SelectMenu/select-menu.principles.stories.tsx +107 -0
  1209. package/src/components/SelectMenu/select-menu.spec.md +222 -0
  1210. package/src/components/SelectMenu/select-menu.stories.tsx +148 -0
  1211. package/src/components/SelectMenu/select-menu.tsx +20 -6
  1212. package/src/components/SelectionControl/index.ts +5 -0
  1213. package/src/components/SelectionControl/selection-item.anatomy.stories.tsx +571 -0
  1214. package/src/components/SelectionControl/selection-item.principles.stories.tsx +77 -0
  1215. package/src/components/SelectionControl/selection-item.spec.md +130 -0
  1216. package/src/components/SelectionControl/selection-item.stories.tsx +137 -0
  1217. package/src/components/Separator/index.ts +5 -0
  1218. package/src/components/Separator/separator.anatomy.stories.tsx +125 -0
  1219. package/src/components/Separator/separator.principles.stories.tsx +141 -0
  1220. package/src/components/Separator/separator.spec.md +109 -0
  1221. package/src/components/Separator/separator.stories.tsx +127 -0
  1222. package/src/components/Sheet/index.ts +5 -0
  1223. package/src/components/Sheet/sheet.anatomy.stories.tsx +268 -0
  1224. package/src/components/Sheet/sheet.principles.stories.tsx +370 -0
  1225. package/src/components/Sheet/sheet.spec.md +148 -0
  1226. package/src/components/Sheet/sheet.stories.tsx +168 -0
  1227. package/src/components/Sheet/sheet.tsx +1 -1
  1228. package/src/components/Sidebar/index.ts +5 -0
  1229. package/src/components/Sidebar/sidebar.anatomy.stories.tsx +769 -0
  1230. package/src/components/Sidebar/sidebar.principles.stories.tsx +506 -0
  1231. package/src/components/Sidebar/sidebar.spec.md +711 -0
  1232. package/src/components/Sidebar/sidebar.stories.tsx +481 -0
  1233. package/src/components/Sidebar/sidebar.tsx +5 -2
  1234. package/src/components/Skeleton/index.ts +5 -0
  1235. package/src/components/Skeleton/skeleton.anatomy.stories.tsx +145 -0
  1236. package/src/components/Skeleton/skeleton.principles.stories.tsx +221 -0
  1237. package/src/components/Skeleton/skeleton.spec.md +104 -0
  1238. package/src/components/Skeleton/skeleton.stories.tsx +129 -0
  1239. package/src/components/Slider/index.ts +5 -0
  1240. package/src/components/Slider/slider.anatomy.stories.tsx +235 -0
  1241. package/src/components/Slider/slider.principles.stories.tsx +250 -0
  1242. package/src/components/Slider/slider.spec.md +353 -0
  1243. package/src/components/Slider/slider.stories.tsx +115 -0
  1244. package/src/components/Slider/slider.tsx +18 -4
  1245. package/src/components/Steps/index.ts +5 -0
  1246. package/src/components/Steps/steps.anatomy.stories.tsx +448 -0
  1247. package/src/components/Steps/steps.principles.stories.tsx +303 -0
  1248. package/src/components/Steps/steps.spec.md +473 -0
  1249. package/src/components/Steps/steps.stories.tsx +370 -0
  1250. package/src/components/Steps/steps.tsx +19 -2
  1251. package/src/components/Switch/index.ts +5 -0
  1252. package/src/components/Switch/switch.anatomy.stories.tsx +227 -0
  1253. package/src/components/Switch/switch.principles.stories.tsx +174 -0
  1254. package/src/components/Switch/switch.spec.md +221 -0
  1255. package/src/components/Switch/switch.stories.tsx +107 -0
  1256. package/src/components/Switch/switch.tsx +13 -13
  1257. package/src/components/Tabs/index.ts +5 -0
  1258. package/src/components/Tabs/tabs.anatomy.stories.tsx +414 -0
  1259. package/src/components/Tabs/tabs.principles.stories.tsx +257 -0
  1260. package/src/components/Tabs/tabs.spec.md +316 -0
  1261. package/src/components/Tabs/tabs.stories.tsx +155 -0
  1262. package/src/components/Tabs/tabs.tsx +4 -3
  1263. package/src/components/Tag/index.ts +5 -0
  1264. package/src/components/Tag/tag.anatomy.stories.tsx +656 -0
  1265. package/src/components/Tag/tag.principles.stories.tsx +270 -0
  1266. package/src/components/Tag/tag.spec.md +281 -0
  1267. package/src/components/Tag/tag.stories.tsx +69 -0
  1268. package/src/components/Tag/tag.tsx +9 -4
  1269. package/src/components/Textarea/index.ts +5 -0
  1270. package/src/components/Textarea/textarea.anatomy.stories.tsx +304 -0
  1271. package/src/components/Textarea/textarea.principles.stories.tsx +175 -0
  1272. package/src/components/Textarea/textarea.spec.md +151 -0
  1273. package/src/components/Textarea/textarea.stories.tsx +53 -0
  1274. package/src/components/Textarea/textarea.tsx +10 -6
  1275. package/src/components/TimePicker/index.ts +5 -0
  1276. package/src/components/TimePicker/time-picker.anatomy.stories.tsx +275 -0
  1277. package/src/components/TimePicker/time-picker.principles.stories.tsx +140 -0
  1278. package/src/components/TimePicker/time-picker.spec.md +270 -0
  1279. package/src/components/TimePicker/time-picker.stories.tsx +193 -0
  1280. package/src/components/TimePicker/time-picker.tsx +20 -5
  1281. package/src/components/Toast/index.ts +5 -0
  1282. package/src/components/Toast/toast.anatomy.stories.tsx +324 -0
  1283. package/src/components/Toast/toast.principles.stories.tsx +217 -0
  1284. package/src/components/Toast/toast.spec.md +178 -0
  1285. package/src/components/Toast/toast.stories.tsx +119 -0
  1286. package/src/components/Tooltip/index.ts +5 -0
  1287. package/src/components/Tooltip/tooltip.anatomy.stories.tsx +413 -0
  1288. package/src/components/Tooltip/tooltip.principles.stories.tsx +204 -0
  1289. package/src/components/Tooltip/tooltip.spec.md +139 -0
  1290. package/src/components/Tooltip/tooltip.stories.tsx +116 -0
  1291. package/src/components/TreeView/index.ts +5 -0
  1292. package/src/components/TreeView/tree-view.anatomy.stories.tsx +410 -0
  1293. package/src/components/TreeView/tree-view.principles.stories.tsx +190 -0
  1294. package/src/components/TreeView/tree-view.spec.md +388 -0
  1295. package/src/components/TreeView/tree-view.stories.tsx +297 -0
  1296. package/src/components/TreeView/tree-view.tsx +46 -13
  1297. package/src/hooks/use-overflow-items.ts +10 -6
  1298. package/src/index.ts +68 -69
  1299. package/src/patterns/action-bar/action-bar.spec.md +458 -0
  1300. package/src/patterns/action-bar/action-bar.stories.tsx +612 -0
  1301. package/src/patterns/element-anatomy/element-anatomy.spec.md +215 -0
  1302. package/src/patterns/element-anatomy/index.ts +5 -0
  1303. package/src/patterns/element-anatomy/inline-action.spec.md +320 -0
  1304. package/src/patterns/element-anatomy/item-anatomy.spec.md +1042 -0
  1305. package/src/patterns/element-anatomy/item-anatomy.stories.tsx +1622 -0
  1306. package/src/patterns/element-anatomy/item-anatomy.tsx +3 -2
  1307. package/src/patterns/header-canonical/header-canonical.css +2 -2
  1308. package/src/patterns/header-canonical/header-canonical.spec.md +291 -0
  1309. package/src/patterns/header-canonical/index.ts +5 -0
  1310. package/src/patterns/horizontal-overflow/horizontal-overflow.spec.md +195 -0
  1311. package/src/patterns/horizontal-overflow/index.ts +5 -0
  1312. package/src/patterns/overlay-surface/index.ts +5 -0
  1313. package/src/patterns/overlay-surface/overlay-surface.spec.md +429 -0
  1314. package/src/patterns/resize-handle/index.ts +5 -0
  1315. package/src/patterns/resize-handle/resize-handle.spec.md +111 -0
  1316. package/src/patterns/resize-handle/resize-handle.stories.tsx +71 -0
  1317. package/src/styles/base.css +85 -0
  1318. package/src/styles/tokens.css +11 -0
  1319. package/src/tokens/README.md +2 -0
  1320. package/src/tokens/color/color.spec.md +785 -0
  1321. package/src/tokens/color/color.stories.tsx +363 -0
  1322. package/src/tokens/color/primitives.css +7 -0
  1323. package/src/tokens/density/density.spec.md +127 -0
  1324. package/src/tokens/density/density.stories.tsx +240 -0
  1325. package/src/tokens/elevation/elevation.spec.md +79 -0
  1326. package/src/tokens/elevation/elevation.stories.tsx +98 -0
  1327. package/src/tokens/layoutSpace/layoutSpace.css +1 -1
  1328. package/src/tokens/layoutSpace/layoutSpace.spec.md +313 -0
  1329. package/src/tokens/layoutSpace/layoutSpace.stories.tsx +75 -0
  1330. package/src/tokens/motion/motion.css +2 -2
  1331. package/src/tokens/motion/motion.spec.md +97 -0
  1332. package/src/tokens/motion/motion.ts +1 -1
  1333. package/src/tokens/opacity/opacity.spec.md +84 -0
  1334. package/src/tokens/opacity/opacity.stories.tsx +69 -0
  1335. package/src/tokens/orphan-tokens.spec.md +117 -0
  1336. package/src/tokens/radius/radius.spec.md +128 -0
  1337. package/src/tokens/radius/radius.stories.tsx +86 -0
  1338. package/src/tokens/token-system.spec.md +243 -0
  1339. package/src/tokens/typography/typography.spec.md +208 -0
  1340. package/src/tokens/typography/typography.stories.tsx +133 -0
  1341. package/src/tokens/uiSize/icon-size.ts +1 -2
  1342. package/src/tokens/uiSize/uiSize.css +16 -0
  1343. package/src/tokens/uiSize/uiSize.spec.md +439 -0
@@ -0,0 +1,438 @@
1
+ ---
2
+ component: Field
3
+ family: self-contained
4
+ traits:
5
+ - hasInteractiveStates
6
+ - isStructural
7
+ variants: {}
8
+ sizes: {}
9
+ ---
10
+
11
+ <!-- @benchmark-cited: D5 retrofit 2026-05-18 — body claims marked per-claim @benchmark-unverified inline; canonical source URLs in frontmatter benchmark list. -->
12
+
13
+ # Field 設計原則
14
+
15
+ > **Foundational SSOT rationale**(cap 800,2026-04-25 approved):
16
+ > 表單 layout container canonical。Input / NumberInput / Checkbox / RadioGroup / Switch / Select / Combobox / DatePicker 等 field controls 皆消費本 spec 的 `orientation` / `controlLayout` / context API(mode / disabled / required / invalid / id)/ 水平對齊公式。跨元件 pattern canonical,scope 本質 > 單一元件。
17
+
18
+ ## 定位
19
+
20
+ Field 是**表單欄位的佈局容器**。只負責排版(label / control / description / error 的空間關係)與**狀態 context**(把 mode / disabled / required / invalid / id 傳給子元件),**不擁有任何資料型別邏輯**。
21
+
22
+ 與資料相關的一切(格式化、驗證、readonly 呈現、DataTable cell 顯示)住在各個資料型別的 Control 元件本身(Input、NumberInput、Checkbox、Switch 等)。Field 不 wrap、不代理、不轉換它們的行為。
23
+
24
+ **實作基礎**:自建——本 DS 的 form layout 設計。shadcn 的 `Form` 元件走 react-hook-form + Zod + 自己的 Field primitive(含 Controller),本 DS 不採用這套耦合設計:Field 只做 layout + context,驗證由 consumer 自選(本 DS 建議 zod,見 `form-validation.spec.md`),保持更輕量、更獨立的定位。
25
+
26
+ **Layout Family**:Field **不屬於** 4-Family Model 的 element layout families——它是 form composition pattern(包 Family 4 control + label + description)。見 CLAUDE.md「系統內部 Layout — 4-Family Model」→「Field Composition」段落。
27
+
28
+ ---
29
+
30
+ ## 與 Field Controls 的職責切分
31
+
32
+ Field 和 Field Controls(Input / NumberInput / DatePicker / Select / Combobox / LinkInput / PeoplePicker / Textarea)是兩件事:
33
+
34
+ - **Field**(本元件):只管佈局 + 狀態 context
35
+ - **Field Controls / Checkbox / Switch / RadioGroup**:管自己的資料型別 + edit/readonly/disabled 三態 + 格式化(XxxDisplay 供 DataTable 共用)
36
+
37
+ 這麼拆的理由:**Checkbox 在 table cell、form field、settings row 應該是同一個 primitive**,不該為了進到 form 就被包一層 CheckboxField;form 的高度對齊由 Field 的 control area 負責,不由 primitive 本身負責。Field Controls 的詳細共用規則見 `Field/field-controls.spec.md`。
38
+
39
+ ---
40
+
41
+ ## 結構
42
+
43
+ ```tsx
44
+ <Field orientation="vertical | horizontal" labelWidth="120px">
45
+ <FieldLabel>姓名</FieldLabel>
46
+ <Input value={name} onChange={setName} />
47
+ <FieldDescription>會顯示在專案列表標題</FieldDescription>
48
+ <FieldError>{errors.name}</FieldError>
49
+ </Field>
50
+ ```
51
+
52
+ 子元件有四種 slot:
53
+
54
+ | Slot | 元件 | 職責 |
55
+ |---|---|---|
56
+ | label | `<FieldLabel>` | 欄位名稱,handles required 星號、disabled 灰化、htmlFor 連結 |
57
+ | control | 任何非 label/desc/error 的 child | 輸入元件本體(Input、Checkbox、Switch...) |
58
+ | description | `<FieldDescription>` | 次要說明文字,fg-secondary |
59
+ | error | `<FieldError>` | 錯誤訊息,error-text 色,`role="alert"`,無內容時不渲染 |
60
+
61
+ 子元件寫法採**扁平結構**(直接作為 Field children),Field 內部用 `displayName` 判別 slot 類型並自動組合。consumer 不需要包 wrapper。
62
+
63
+ ---
64
+
65
+ ## 樣式規範(全部 codify 在 field.tsx,不依賴 consumer)
66
+
67
+ | 元素 | Token / 值 |
68
+ |---|---|
69
+ | FieldLabel(一般) | `text-body`(14px)/ `text-foreground`(neutral-9) |
70
+ | FieldLabel(disabled) | `text-body` / `text-fg-disabled`(neutral-6) |
71
+ | FieldLabel 的 required `*` | `text-fg-muted`(neutral-7),**貼齊 label 文字無 gap**,disabled 時 `text-fg-disabled` |
72
+ | FieldDescription(一般) | `text-body`(14px)/ `text-fg-secondary`(neutral-8) |
73
+ | FieldDescription(disabled) | `text-body` / `text-fg-disabled` |
74
+ | FieldError | `text-body`(14px)/ `text-error-text` / `role="alert"` |
75
+ | Field 內部 gap(vertical) | `gap-1`(4px) |
76
+ | Field 內部 gap(horizontal,content 欄) | `gap-1`(4px) |
77
+ | Horizontal 模式 label 與 control 的 gap | `gap-x-3`(12px) |
78
+ | Control area(任何 size) | `min-h-field-{size}` + `flex items-center` |
79
+
80
+ **Label / Description / Error 字體固定 `text-body`(14px),不隨 field size 變。** Field size 只影響 input 高度,不影響表單佈局元素的 typography。世界級系統(Material、Ant Design、Atlassian、Carbon、Polaris)都是固定 label/helper text size。 <!-- @benchmark-unverified: see frontmatter benchmark list for canonical DS source URL -->
81
+
82
+ ---
83
+
84
+ ## Orientation
85
+
86
+ ### vertical(預設)
87
+
88
+ Label 在上、control 在下、description 和 error 往下堆疊。垂直節奏 `gap-1`(4px)。
89
+
90
+ ```
91
+ [Label]
92
+ [Control] ← min-h-field-md,control 垂直置中於此 box
93
+ [Description]
94
+ [Error]
95
+ ```
96
+
97
+ 適用:標準表單、密集欄位。
98
+
99
+ ### horizontal
100
+
101
+ Label 在左、control + description + error 在右欄垂直堆疊。Label 與 control **垂直對齊於第一行中線**(見下一段)。
102
+
103
+ ```
104
+ [Label] [Control ]
105
+ [Description]
106
+ [Error]
107
+ ```
108
+
109
+ 適用:settings 面板、寬螢幕 form、iOS-style 欄位。
110
+
111
+ Horizontal 模式下 label 的欄寬由 `labelWidth` prop 控制(任何 CSS length 值),預設 `auto` 由 label 內容撐開。內部用 CSS variable `--field-label-width` 傳給 grid template column。
112
+
113
+ ---
114
+
115
+ ## Horizontal 模式 label 垂直對齊
116
+
117
+ 依 `controlLayout`(Field 自動偵測)分兩套對齊語意:
118
+
119
+ **A. Inline control**(Input/Button/Switch/SegmentedControl)— control 有固定 `--field-height-{size}`,可談中線。
120
+ - label ≤ field-height → 第一行中線對齊 control 中線(視覺置中)
121
+ - label > field-height → 齊頂對齊 control top
122
+ - 實作:`min-h-field-{size} flex flex-col justify-center`(內容 < min-h → justify-center 置中;內容 > min-h → 容器被撐大,top 對齊)
123
+
124
+ **B. Block control**(RadioGroup/CheckboxGroup)— 多行群組無整體中線,錨點 = 第一個 item 第一行中線在 `field-height/2`(SelectionItem `py = calc((field-height - 1lh)/2)` 維持)。
125
+ - label 第一行永遠對齊第一個 item 第一行
126
+ - 實作:`padding-top: calc((field-height - 1lh)/2)`
127
+
128
+ **為什麼分兩套**:曾試 `min-h + flex-center` 統一 → block + 長 label regression(justify-center 失效 + 跟 SelectionItem 公式錯位)。Inline / block 不同對齊語意模型,必分兩套。純 CSS 跨 size/density/字體自動連動,無 JS 測量。對齊 Atlassian DSP / Salesforce Lightning(Polaris 用 baseline 修正,類似)。 <!-- @benchmark-unverified: see frontmatter benchmark list for canonical DS source URL -->
129
+
130
+ ---
131
+
132
+ ## Control area:Inline vs Block
133
+
134
+ Field 的 control area 有兩種佈局模型,涵蓋所有 control 類型。**核心原則:無論哪一種,「control 第一行內容的中線」都錨在 `field-height/2`**——這是維持 FieldGroup 垂直韻律的關鍵錨點,也讓 horizontal 模式的 label 公式對 inline / block 都成立。
135
+
136
+ | Layout | Control area 樣式 | 適用 control |
137
+ |---|---|---|
138
+ | **inline**(預設) | `min-h-field-{size}` + `flex items-center` | Input / NumberInput / DatePicker / Select / Combobox / LinkInput / Textarea(單行使用)、Checkbox / Switch / 單一 Button(如 upload picker) |
139
+ | **block** | `flex flex-col items-start` + `padding-top: calc((field-height - 1lh) / 2)`,**不設 min-h** | RadioGroup / CheckboxGroup / FileDropzone / RichTextEditor / inline DataTable 等多行/任意高度區塊 |
140
+
141
+ ### 兩種模式的對齊幾何
142
+
143
+ ```
144
+ Inline Block
145
+ ┌────┬───────────────┐ ┌────┬───────────────┐
146
+ │ │ │ │Lbl │ ● Option A │ ← 第一行中線 = field-height/2
147
+ │Lbl │ [Input ] │ ← 中線 │ │ ● Option B │
148
+ │ │ │ │ │ ● Option C │
149
+ └────┴───────────────┘ └────┴───────────────┘
150
+ ```
151
+
152
+ 兩個 Field 放在同一個 FieldGroup 時,Lbl 第一行中線完全對齊——Input 的中線與 Option A 的中線都落在同一條水平線上。
153
+
154
+ ### 為什麼 block 不是「整組垂直置中」
155
+
156
+ 直覺上會想說 control area 多行時整組 vertical center,但這會讓:
157
+ 1. 第一個 Radio 往下掉,跟 label 第一行中線錯位
158
+ 2. FieldGroup 裡 inline / block field 並排時節奏斷掉
159
+
160
+ 正確做法是「**第一行對齊**」——後續 item 從第一行往下流,label 公式錨在第一行中線。Atlassian DSP / Polaris / Material 都是這個模型。 <!-- @benchmark-unverified: see frontmatter benchmark list for canonical DS source URL -->
161
+
162
+ ### 為什麼 primitive 不自己變高
163
+
164
+ **Checkbox / Switch / RadioGroupItem 的 primitive 保持原生尺寸**(16-20px),不為了 form 而被拉高。世界級系統(shadcn、Radix、Material、Atlassian)全部這樣做。理由: <!-- @benchmark-unverified: see frontmatter benchmark list for canonical DS source URL -->
165
+
166
+ 1. **Primitive 保持單一職責**——Checkbox 在 table cell、toolbar、menu 裡仍然是 16px,不受 form 高度污染
167
+ 2. **高度節奏由 Field 容器提供**——一次設定,所有 primitive 在任何 size / density 都自動對齊
168
+ 3. **DataTable cell 共用同一個 min-h 機制**——不需為 cell 另發明對齊邏輯
169
+
170
+ ### 水平排列 Field 時的垂直對齊
171
+
172
+ 多個 Field 並排時,每個 Field 的 control area 都依公式錨在 `field-height/2`,不論 inline 還是 block,**「控件第一行中線」都落在同一條線上**——Input、Checkbox、Switch、RadioGroup 第一個 option 並列時視覺上完全對齊。
173
+
174
+ ---
175
+
176
+ ## 如何宣告 block primitive(程式化機制)
177
+
178
+ block / inline 是**元件固有性質**(RadioGroup 永遠 block,Input 永遠 inline),由 primitive 自我宣告:
179
+
180
+ ```tsx
181
+ ;(RadioGroup as unknown as { fieldLayout: 'block' }).fieldLayout = 'block'
182
+ ```
183
+
184
+ Field render 時讀第一個 control child 的 `type.fieldLayout`,缺則 `'inline'`。Consumer 完全無感(`<Field><RadioGroup>...</RadioGroup></Field>` 自動切 block)。
185
+
186
+ **為什麼這機制**:Consumer 傳 prop 易忘 → 歪;Field 內寫死白名單 → 跟 primitive 名稱耦合。Primitive 自宣告 = Field 0 耦合,新增 block primitive 只在自己檔案加 1 行。
187
+
188
+ **逃生艙**:`Field controlLayout="inline"|"block"` prop 覆寫(consumer 手寫 JSX 當 control 無法偵測時用)。
189
+
190
+ **第一行對齊責任**:Field 的 block control area **不加 paddingTop**(避免跟 RadioGroup 自帶 `py = calc((field-height - 1lh) / 2)` double)。需 label 對齊的 block primitive 自行保證第一行位置(RadioGroup/CheckboxGroup 自帶 ✓;FileDropzone/RichTextEditor 自管)。
191
+
192
+ **已宣告 block**:`RadioGroup`、`CheckboxGroup`(checkbox-group.tsx:92)。新增 `FileDropzone` 等同模式加 `fieldLayout = 'block'`。
193
+
194
+ ---
195
+
196
+ ## FieldContext — 子元件如何讀 Field 狀態
197
+
198
+ Field 透過 Context 暴露以下狀態給子元件(Primitive 可以透過 `useFieldContext()` 讀取):
199
+
200
+ | 欄位 | 用途 |
201
+ |---|---|
202
+ | `id` | FieldLabel 自動 `htmlFor`、Input 自動 `id` |
203
+ | `descriptionId` | FieldDescription 的 id,Input 自動 `aria-describedby` |
204
+ | `errorId` | FieldError 的 id,Input 自動 `aria-errormessage` |
205
+ | `mode` | `edit` / `readonly` / `disabled`,Control 決定自己的視覺形態 |
206
+ | `disabled` | Control 顯示 disabled 樣式 |
207
+ | `required` | FieldLabel 自動渲染 `*`;Input 自動 `aria-required` |
208
+ | `invalid` | Control 顯示 error 邊框;Input 自動 `aria-invalid` |
209
+ | `size` | Control 自動同步尺寸(sm / md / lg) |
210
+ | `orientation` | FieldLabel 的垂直對齊策略(horizontal 模式套用 padding-top 公式) |
211
+ | `hasFieldWrapper` | Primitive 讀到此旗標時應忽略自己的 label / description prop,由 FieldLabel / FieldDescription 接管 |
212
+
213
+ ### Primitive 的 Field-aware 行為
214
+
215
+ **Checkbox / Switch / RadioItem** 等 primitive 自己有 `label` / `description` props 可用於**獨立使用場景**(不在 Field 內),但在 Field context 內時:
216
+
217
+ - 讀到 `hasFieldWrapper === true` 就**忽略自己的 `label` / `description` props**(若 consumer 誤傳,開發環境可 warn)
218
+ - 改由 `<FieldLabel>` 和 `<FieldDescription>` 接管這兩個 slot
219
+ - 避免「雙層 label」
220
+
221
+ 這個機制讓**同一個 primitive 可以在兩種情境下正確呈現**:
222
+
223
+ ```tsx
224
+ // 情境 A:獨立使用(toolbar / settings row / dashboard widget)
225
+ <Checkbox label="訂閱電子報" description="每週一封" />
226
+
227
+ // 情境 B:form 內(Field 接管 label)
228
+ <Field>
229
+ <FieldLabel>訂閱電子報</FieldLabel>
230
+ <Checkbox />
231
+ <FieldDescription>每週一封</FieldDescription>
232
+ </Field>
233
+ ```
234
+
235
+ 兩種情境用同一個 primitive,一份樣式規範。
236
+
237
+ ---
238
+
239
+ ## Required 星號
240
+
241
+ - Field 的 `required` prop 透過 context 傳給 FieldLabel 自動渲染 `*`
242
+ - 星號 `text-fg-muted`(neutral-7),**緊貼 label 文字無 gap**(不用 `margin-right`)
243
+ - Disabled 時星號改為 `text-fg-disabled`(neutral-6),與 label 同步降色
244
+ - 個別 FieldLabel 可用 `required` prop 覆寫 context 值
245
+
246
+ **為什麼貼齊無 gap**:星號是 label 語意的一部分(WCAG 友善——screen reader 先讀 required 再讀 label),不是獨立視覺元素,所以不需要間距。
247
+
248
+ ---
249
+
250
+ ## 驗證與 aria 屬性
251
+
252
+ - `invalid` 透過 context 讓 Control 顯示 error 邊框、自動 `aria-invalid`
253
+ - `errorId` 讓 Control 自動 `aria-errormessage`
254
+ - `descriptionId` 讓 Control 自動 `aria-describedby`
255
+ - `<FieldError>` 自帶 `role="alert"` 並有 id = `errorId`
256
+ - 無 children 的 `<FieldError>` 不渲染,不佔位
257
+
258
+ ---
259
+
260
+ ## FieldGroup — 多 Field 垂直堆疊
261
+
262
+ ```tsx
263
+ <FieldGroup gap="normal" horizontalLabelWidth="120px">
264
+ <Field><FieldLabel>姓名</FieldLabel><Input /></Field>
265
+ <Field><FieldLabel>Email</FieldLabel><Input /></Field>
266
+ <Field orientation="horizontal">
267
+ <FieldLabel>訂閱通知</FieldLabel>
268
+ <Switch />
269
+ </Field>
270
+ <Field orientation="horizontal">
271
+ <FieldLabel>小字體</FieldLabel>
272
+ <Switch />
273
+ </Field>
274
+ </FieldGroup>
275
+ ```
276
+
277
+ gap 三個語意層級(具體 gap token 見 `field.tsx` cva):
278
+
279
+ | gap | 用途 |
280
+ |---|---|
281
+ | `compact` | 密集表單、dialog 內 |
282
+ | `normal`(預設) | 標準表單 |
283
+ | `loose` | 寬鬆大表單、settings 頁 |
284
+
285
+ ### FieldGroup `horizontalLabelWidth` cascade(2026-04-20)
286
+
287
+ 同一畫面 / 同一 FieldGroup 內多個 horizontal Field **必須共用 label 欄寬度**。若每個 Field 各自傳 `labelWidth`(或省略 → 內容撐開),label 寬度會參差不齊,Switch / Input 的左邊緣不對齊,視覺上每一行「歪七扭八」。
288
+
289
+ **世界級 idiom**:macOS System Settings / iOS Settings / GitHub Settings / Notion preferences / Figma 偏好設定——setting list 的 label 全部固定寬、control 全部右對齊,列與列對齊成可掃描的欄位格網。 <!-- @benchmark-unverified: see frontmatter benchmark list for canonical DS source URL -->
290
+
291
+ `FieldGroup horizontalLabelWidth` 透過 React Context cascade 到所有子 Field(含 `vertical` 模式的 Field 不受影響——vertical 無 label 欄概念)。單一 Field 仍可用自己的 `labelWidth` prop 覆寫 group 預設(罕見 — 通常 group 預設就是 canonical)。
292
+
293
+ **搭配 Switch 自動齊右**:horizontal Field 內的 Switch 自動 `ml-auto` 推到右邊緣。配合 FieldGroup `horizontalLabelWidth` → 整排 toggles 的 switch 視覺完全對齊。
294
+
295
+ ---
296
+
297
+ ## Button 作為 control 的判斷標準
298
+
299
+ Field 的 control 是「**承載這個欄位 value 的輸入介面**」。Button 在某些場景就是這個介面——例如 upload button(點擊開檔案選擇器,結果寫回 field)、picker opener(連結 OAuth、開選人對話框)。這類 Button **可以**作為 control:
300
+
301
+ ```tsx
302
+ <Field orientation="horizontal" labelWidth="120px">
303
+ <FieldLabel>合約附件</FieldLabel>
304
+ <Button startIcon={Upload} variant="secondary">上傳檔案</Button>
305
+ <FieldDescription>PDF / DOCX,最大 10 MB</FieldDescription>
306
+ </Field>
307
+ ```
308
+
309
+ Button 的 height 與 `field-height` 共用同一組 token,放進 inline control area 自然對齊 Input 中線,horizontal 模式的 label 公式也自然對到——不需要任何特例。
310
+
311
+ **判斷標準**:點擊這顆 Button 是否產生 / 修改此欄位的 value?
312
+
313
+ | 是 | 否 |
314
+ |---|---|
315
+ | ✅ Upload(產生 file value) | ❌ 表單 submit / cancel(form action,放到 form footer) |
316
+ | ✅ Picker opener(開對話框選 value) | ❌ 「重設此欄位」(可放到 endAction 或 description 旁,不是 control) |
317
+ | ✅ Connect OAuth(產生 token value) | ❌ 頁面導覽、刪除整筆資料(page action) |
318
+
319
+ **規則**:Button 是 control 時通常 inline(高度 = field-height);若是 block 類的「上傳區塊」(FileDropzone),則該元件本身宣告為 block primitive。
320
+
321
+ ---
322
+
323
+ ## 禁止事項
324
+
325
+ - ❌ 不得在 Field 內再包 Field——Field 不支援巢狀
326
+ - ❌ 不得在 Field 內同時放 `<FieldLabel>` 和給 primitive 傳 `label` prop——Field context 會讓 primitive 忽略自己的 label,但語意上仍是重複宣告,避免誤導
327
+ - ❌ 不得跳過 `<FieldLabel>` 直接寫 `<label>`——失去 required 星號、disabled 處理、size 連動等 codified 樣式
328
+ - ❌ 不得為了「讓 Checkbox 與 Input 同高」而修改 Checkbox primitive——高度對齊由 Field control area 負責
329
+ - ❌ Horizontal 模式下不得對 FieldLabel 自訂 `padding-top`——會打破公式對齊
330
+ - ❌ 不得把**與此欄位 value 無關的 action**(form submit/cancel、頁面導覽、刪除整筆資料)放進 control area——Field 是資料輸入容器,不是 action container。Button 是否能當 control,看上一節的判斷標準
331
+ - ❌ 不得在 block control area 自訂 `min-height` 或改 `items-start`——會打破第一行對齊公式
332
+ - ❌ 不得在 block primitive 的 `.tsx` 漏掉 `fieldLayout = 'block'` 宣告——Field 會誤判成 inline 導致 layout 歪掉
333
+
334
+ ---
335
+
336
+ ## Field Controls 共用設計原則
337
+
338
+ Field 內的資料輸入控件(Input / NumberInput / DatePicker / Select / Combobox / LinkInput / PeoplePicker / Textarea)共用的三 mode、size、focus、endAction、Display 規則,詳見 `Field/field-controls.spec.md`。
339
+
340
+ ---
341
+
342
+ ## 何時用
343
+
344
+ - **表單欄位的 label + control + description + error 標準佈局**:登入表單、設定頁、建立對話框
345
+ - **需要 required 星號、disabled 狀態、invalid 驗證的統一行為**
346
+ - **需要 `horizontal` / `vertical` 排版切換**:設定頁常用 horizontal(label 左 / control 右)
347
+ - **多欄位垂直堆疊**:搭配 `FieldGroup` 管理 density-aware 間距
348
+
349
+ ## 何時不用
350
+
351
+ | 場景 | 改用 | 原因 |
352
+ |------|------|------|
353
+ | 唯讀資訊展示 | `DescriptionList` | Field 是表單容器,純展示用 `dl/dt/dd` 語義 |
354
+ | 單一 Checkbox(勾選同意)without label 結構 | 直接 Checkbox + label prop | 單個 Checkbox 是 inline primitive,不需要 Field 佈局 |
355
+ | DataTable cell 編輯(inline editable)| 直接放 Field Control | Field 是頁面表單佈局,table cell 空間受限 |
356
+ | 純 action 按鈕(submit / cancel / 頁面導覽)| 頁面 footer / toolbar | Field 是資料輸入容器,不放頁面級 action |
357
+ | 巢狀 Field | ❌ 不支援 | Field 不支援巢狀,多欄位用 FieldGroup |
358
+
359
+ ---
360
+
361
+ ## 為何無 Inspector
362
+
363
+ Field 是**表單欄位容器**(label + helper + control + error 的佈局包裝),設計決策維度是 `orientation`(vertical / horizontal)× `size`(sm/md/lg)× `state`(required / invalid / disabled / readonly)× `color`——已由 `OrientationMatrix` / `SizeMatrix` / `StateBehavior` / `ColorMatrix` + 元件特有 `FieldGroupBehavior` 五張結構矩陣完整覆蓋。
364
+
365
+ Inspector 對 container 類元件沒有對應教學價值——Field 本身不產生互動 affordance(互動由 Field Control 例如 Input / Select 處理),該 Inspect 的是 Field Control layer(已有各自元件的 Inspector)。重寫 Inspector = 複製 Input / Select 的 Inspector。
366
+
367
+ 對應 anatomy story:保留 `Overview` + `OrientationMatrix` + `SizeMatrix` + `StateBehavior` + `ColorMatrix` + 元件特有 `FieldGroupBehavior`。
368
+
369
+ ---
370
+
371
+ ## Field state machine SSOT(v13.3)
372
+
373
+ **Canonical**:**focus dominates everything**(M11 延伸:focus 勝 hover/open/error-rest)。Cursor in input = user 編輯中 = 永遠藍。對齊 Material 3 / Polaris / Ant Design 5 共識。SSOT 在 `field-wrapper.tsx` 三 compoundVariant — 改一處全 control + cell + 各 variant 跟動。 <!-- @benchmark-unverified: see frontmatter benchmark list for canonical DS source URL -->
374
+
375
+ | State | Token | CSS |
376
+ |---|---|---|
377
+ | rest | `--border` | `border-border` |
378
+ | hover(無 focus)| `--border-hover` | `hover:border-border-hover` |
379
+ | **focus** | `--primary` | **`focus-within:!border-primary`**(`!important` 勝 data-state)|
380
+ | focus + hover | `--primary` | `focus-within:hover:!border-primary`(M11 AND case)|
381
+ | open(無 focus)| `--border-hover` | `data-[state=open]:border-border-hover` |
382
+ | error | `--error` | `focus-within:border-error focus-within:hover:border-error` |
383
+
384
+ 副作用(自動達成 Ant「選後藍 / 取消灰」):選 option → Radix `onCloseAutoFocus` return focus → focus-within fires → 藍 / 點外取消 → focus 移外 → 灰。純 focus 機制無需 transient class。
385
+
386
+ **反模式 ❌**:per-control `open && 'border-primary'`(Combobox/Select/PeoplePicker)/ `data-[state=open]:border-primary` — 已 v13.3 全 retire。`hook check_field_state_token_consume` write-time 攔。
387
+
388
+ ---
389
+
390
+ ## Naked variant — Cell-as-input(M19 SSOT,v15)
391
+
392
+ `naked` = cell-as-input(Notion / Airtable / Excel / AG Grid:host cell 提供 box,Field 融入)。**核心**:完全繼承 Field default state machine,只改**物理尺寸 + 位置**。Combobox/Select 加新 stacking 子元件必檢查 cell context;cell 內元件不要自寫 `position:absolute/fixed` 對抗(必要時加 `// @field-state-ring-allow:` 通過 hook)。
393
+
394
+ ### Layer 分配
395
+
396
+ | Layer | Home | 內容 |
397
+ |---|---|---|
398
+ | **L1 Slot** | `patterns/element-anatomy/item-anatomy.tsx` | `<ItemPrefix>` / `<ItemSuffix>`(永遠 `h-[1lh]` 對齊第 1 行) |
399
+ | **L2 Align** | `field-wrapper.tsx` `nakedCellRowModeAlign` | host cell `data-row-mode` propagate(autoRow→items-start / fixed→items-center)|
400
+ | **L3 State machine** | **繼承 Field default v13.3**(↑ 上方 SSOT)| 不重定義 |
401
+ | **L4 Display hover** | `field-wrapper.tsx` `nakedCellEditableDisplayHover` | editable cell display mode `outline-1 outline-offset:-1 outline-[var(--border-hover)]`(cell wrapper outline)。**v15.13 design intent(user-accepted 2026-05-07)**:hover ring 蓋 cell.borderRight。**known asymmetry**(2026-05-09 user 重抓):只 **right** 邊 outline 跟 cell own border-r 同位置覆蓋成 1 條;top/left/bottom 邊 outline 在 cell.outer 內 1px,grid lines(前 row border-b / 前 cell border-r / row 自己 border-b 在 cell.outer 外 1px)露出 → 視覺 4 邊不對稱。**Pending design decision**(等 user 拍板才 ship):4 邊都蓋(spec 1 selection-style)vs 4 邊都不蓋(spec 2 inset 1px)vs 維持現狀。三層 SSOT:state source = cell wrapper / paint owner = 混合(hover=cell / edit=Field)/ grid divider = DataTable own |
402
+ | **L5 Position(v14,2026-05-06 revert v12)** | naked compoundVariant flow | Field 留 layout flow,**不**用 `!absolute`(v12 absolute 跟 autoRowHeight 不相容)。視覺接受 cell `border-r grid` + Field border 2px 雙線;cell border-r divider 永遠保留(對齊 L4 Invariant divider-owner / editor-owner 分離)|
403
+ | **L6 Cell trigger indicator(v15,2026-05-09)** | naked-display branch + `showDisplayEndIcon?: boolean` opt-in | DataTable cell-registry 顯式傳 `showDisplayEndIcon` → Field component 內部 `<ItemSuffix>` 渲對應 trigger icon(Select/Combobox/PeoplePicker → ChevronDown / DatePicker → CalendarIcon / TimePicker → Clock / LinkInput 例外無 suffix)。table 外用法不傳此 prop = 純展示無 icon。詳 `.claude/planning/cell-indicator-ssot-rfc.md`。|
404
+
405
+ **前身 retire**:v4-v8 `outline-2` 平行 state(已下沉 L3)/ v9 border-only(focus 跟 open specificity tie)/ per-control `open && 'border-primary'`(v13.3 retire)/ `nakedCell{Hover,Focus,Open}Ring` 三 const / `nakedCell{Prefix,Suffix}Slot`(下沉 L1)/ **v12 `!absolute -inset-px` seamless grid**(2026-05-06 revert — autoRowHeight 不相容)/ **DataTable parallel `getEditIndicator`**(2026-05-09 D-path retire — 由 Field naked-display 透過 `showDisplayEndIcon` opt-in 自渲 ItemSuffix,跨元件 SSOT 統一)。
406
+
407
+ **反模式 ❌**:naked 自寫 `outline-*` / `box-shadow inset` state ring(用 L3) / hardcode `<span h-[1lh]>` slot(用 L1)/ hardcode `items-center`(用 L2)/ per-control `open && 'border-primary'`(用 L3 SSOT)。
408
+
409
+ **機械防漂移**:hooks `check_naked_row_mode_propagation` / `check_field_state_token_consume`(v13 升級)/ `check_inline_action_canonical_gap` / `check_row_slot_handcraft`(write-time)+ audit `/design-system-audit` Group N M36-M39。
410
+
411
+ ## 相關
412
+
413
+ - `./field-controls.spec.md` — Field Controls(Input/Select/etc.)共用規則:三 mode、size、focus、endAction、Display
414
+ - `./form-validation.spec.md` — 表單驗證標準(blur 驗證、zod schema、error 顯示)
415
+ - `../DescriptionList/description-list.spec.md` — 唯讀資訊展示(非表單)
416
+ - `../../patterns/element-anatomy/item-anatomy.spec.md` — SelectionItem 佈局(Checkbox / Radio 放進 Field 時 block 模式的參照)
417
+ - CLAUDE.md「元件 Props 命名原則」— Field 的 orientation / block control 宣告規則
418
+
419
+ ## A11y 預設
420
+
421
+ **ARIA / Pattern**:對齊 [W3C ARIA Authoring Practices Guide](https://www.w3.org/WAI/ARIA/apg/patterns/) 對應 pattern。
422
+
423
+ **Keyboard 行為**:Field 是純排版容器,不擁有任何鍵盤 handler,鍵盤行為全由內部 control 接管。
424
+
425
+ - Tab — focus 移進內部 control(Input / Select / DatePicker 等)
426
+ - Esc 取消編輯等行為由 control 本身或放置它的 host(如 DataTable cell)實作,**不在 Field**
427
+
428
+ **Focus**:focus-visible ring 對齊 DS canonical(`outline: 2px solid var(--ring)`);Field 不搶焦點,focus 由內部 control 自管。
429
+
430
+ **驗證**:Storybook a11y addon panel 應 0 critical violation;鍵盤完整可操作(無需滑鼠)。WCAG AA contrast ≥ 4.5:1(text)/ 3:1(UI)。
431
+
432
+ ## 被引用(auto-maintained,Dim 3 reciprocal audit)
433
+
434
+ > 本節由 `scripts/add-reciprocal-pointers.mjs` 自動維護,列出在 SSOT 語境下指向本 spec 的其他 spec。若要手動補充,寫在本節之前。
435
+
436
+ - `element-anatomy.spec.md`
437
+ - `radio-group.spec.md`
438
+ - `switch.spec.md`