@teseor/css 1.1.0 → 1.2.1

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 (236) hide show
  1. package/dist/compiled.css +1967 -1877
  2. package/dist/index.css +2015 -1925
  3. package/package.json +1 -1
  4. package/src/00-config/tokens/_variables.scss +39 -25
  5. package/src/00-config/tokens/colors/index.scss +22 -21
  6. package/src/00-config/tokens/shadows/index.scss +3 -3
  7. package/src/03-layout/cluster/cluster-visual.png +0 -0
  8. package/src/03-layout/cluster/cluster.visual.spec.ts +15 -0
  9. package/src/03-layout/sidebar/sidebar-visual.png +0 -0
  10. package/src/03-layout/sidebar/sidebar.docs.json +62 -0
  11. package/src/03-layout/sidebar/sidebar.visual.spec.ts +14 -0
  12. package/src/03-layout/sidebar-nav/sidebar-nav.api.json +29 -80
  13. package/src/04-components/actions/button/button-visual.png +0 -0
  14. package/src/04-components/{button → actions/button}/button.api.json +30 -56
  15. package/src/04-components/{button → actions/button}/button.docs.json +75 -0
  16. package/src/04-components/{button → actions/button}/button.visual.spec.ts +1 -1
  17. package/src/04-components/{button → actions/button}/index.scss +28 -18
  18. package/src/04-components/actions/button-group/button-group-visual.png +0 -0
  19. package/src/04-components/{button-group → actions/button-group}/button-group.api.json +5 -1
  20. package/src/04-components/{button-group → actions/button-group}/button-group.visual.spec.ts +3 -2
  21. package/src/04-components/{button-group → actions/button-group}/index.scss +1 -1
  22. package/src/04-components/{avatar → data-display/avatar}/avatar.api.json +5 -0
  23. package/src/04-components/{avatar → data-display/avatar}/avatar.visual.spec.ts +1 -1
  24. package/src/04-components/{avatar → data-display/avatar}/index.scss +1 -1
  25. package/src/04-components/{badge → data-display/badge}/badge.visual.spec.ts +1 -1
  26. package/src/04-components/{badge → data-display/badge}/index.scss +13 -10
  27. package/src/04-components/{card → data-display/card}/card.visual.spec.ts +1 -1
  28. package/src/04-components/{card → data-display/card}/index.scss +1 -1
  29. package/src/04-components/data-display/data-list/data-list-visual.png +0 -0
  30. package/src/04-components/{data-list → data-display/data-list}/data-list.api.json +16 -1
  31. package/src/04-components/{data-list → data-display/data-list}/data-list.visual.spec.ts +3 -2
  32. package/src/04-components/{data-list → data-display/data-list}/index.scss +4 -3
  33. package/src/04-components/data-display/icon/icon-visual.png +0 -0
  34. package/src/04-components/{icon → data-display/icon}/icon.api.json +7 -6
  35. package/src/04-components/{icon → data-display/icon}/icon.docs.json +86 -22
  36. package/src/04-components/{icon → data-display/icon}/icon.visual.spec.ts +1 -1
  37. package/src/04-components/{icon → data-display/icon}/index.scss +7 -20
  38. package/src/04-components/{status → data-display/status}/index.scss +1 -1
  39. package/src/04-components/{status → data-display/status}/status.api.json +14 -1
  40. package/src/04-components/{status → data-display/status}/status.visual.spec.ts +1 -1
  41. package/src/04-components/{table → data-display/table}/index.scss +1 -1
  42. package/src/04-components/{table → data-display/table}/table.api.json +8 -1
  43. package/src/04-components/{table → data-display/table}/table.visual.spec.ts +1 -1
  44. package/src/04-components/{tag → data-display/tag}/index.scss +1 -1
  45. package/src/04-components/{tag → data-display/tag}/tag.api.json +4 -0
  46. package/src/04-components/{tag → data-display/tag}/tag.visual.spec.ts +1 -1
  47. package/src/04-components/{accordion → disclosure/accordion}/accordion.api.json +5 -1
  48. package/src/04-components/{accordion → disclosure/accordion}/accordion.visual.spec.ts +1 -1
  49. package/src/04-components/{accordion → disclosure/accordion}/index.scss +1 -1
  50. package/src/04-components/disclosure/{disclosure.api.json → disclosure/disclosure.api.json} +13 -1
  51. package/src/04-components/disclosure/{disclosure.visual.spec.ts → disclosure/disclosure.visual.spec.ts} +1 -1
  52. package/src/04-components/disclosure/{index.scss → disclosure/index.scss} +1 -1
  53. package/src/04-components/{alert → feedback/alert}/alert.api.json +6 -0
  54. package/src/04-components/{alert → feedback/alert}/alert.visual.spec.ts +1 -1
  55. package/src/04-components/{alert → feedback/alert}/index.scss +11 -16
  56. package/src/04-components/{progress → feedback/progress}/index.scss +1 -1
  57. package/src/04-components/{progress → feedback/progress}/progress.api.json +20 -1
  58. package/src/04-components/{progress → feedback/progress}/progress.visual.spec.ts +1 -1
  59. package/src/04-components/{skeleton → feedback/skeleton}/index.scss +1 -1
  60. package/src/04-components/{skeleton → feedback/skeleton}/skeleton.api.json +8 -1
  61. package/src/04-components/{skeleton → feedback/skeleton}/skeleton.visual.spec.ts +1 -1
  62. package/src/04-components/{spinner → feedback/spinner}/index.scss +1 -1
  63. package/src/04-components/{spinner → feedback/spinner}/spinner.visual.spec.ts +1 -1
  64. package/src/04-components/{toast → feedback/toast}/index.scss +1 -1
  65. package/src/04-components/{toast → feedback/toast}/toast.api.json +22 -1
  66. package/src/04-components/{toast → feedback/toast}/toast.visual.spec.ts +1 -1
  67. package/src/04-components/forms/checkbox/checkbox-visual.png +0 -0
  68. package/src/04-components/{checkbox → forms/checkbox}/checkbox.api.json +1 -1
  69. package/src/04-components/{checkbox → forms/checkbox}/checkbox.visual.spec.ts +1 -1
  70. package/src/04-components/{checkbox → forms/checkbox}/index.scss +1 -1
  71. package/src/04-components/forms/field/field.api.json +19 -0
  72. package/src/04-components/{field → forms/field}/field.visual.spec.ts +1 -1
  73. package/src/04-components/{field → forms/field}/index.scss +1 -1
  74. package/src/04-components/forms/form-error/form-error-visual.png +0 -0
  75. package/src/04-components/{form-error → forms/form-error}/form-error.api.json +3 -0
  76. package/src/04-components/{form-error → forms/form-error}/form-error.visual.spec.ts +1 -1
  77. package/src/04-components/{form-error → forms/form-error}/index.scss +1 -1
  78. package/src/04-components/{form-helper → forms/form-helper}/form-helper.visual.spec.ts +1 -1
  79. package/src/04-components/{form-helper → forms/form-helper}/index.scss +1 -1
  80. package/src/04-components/{input → forms/input}/index.scss +1 -1
  81. package/src/04-components/forms/input/input-visual.png +0 -0
  82. package/src/04-components/{input → forms/input}/input.api.json +31 -0
  83. package/src/04-components/{input → forms/input}/input.visual.spec.ts +1 -1
  84. package/src/04-components/{label → forms/label}/index.scss +1 -1
  85. package/src/04-components/{label → forms/label}/label.api.json +4 -0
  86. package/src/04-components/{label → forms/label}/label.visual.spec.ts +1 -1
  87. package/src/04-components/{radio → forms/radio}/index.scss +1 -1
  88. package/src/04-components/forms/radio/radio-visual.png +0 -0
  89. package/src/04-components/{radio → forms/radio}/radio.api.json +1 -1
  90. package/src/04-components/{radio → forms/radio}/radio.visual.spec.ts +1 -1
  91. package/src/04-components/{select → forms/select}/index.scss +1 -1
  92. package/src/04-components/{select → forms/select}/select.api.json +3 -0
  93. package/src/04-components/{select → forms/select}/select.visual.spec.ts +1 -1
  94. package/src/04-components/{textarea → forms/textarea}/index.scss +1 -1
  95. package/src/04-components/{textarea → forms/textarea}/textarea.api.json +3 -0
  96. package/src/04-components/{textarea → forms/textarea}/textarea.visual.spec.ts +1 -1
  97. package/src/04-components/{toggle → forms/toggle}/index.scss +1 -1
  98. package/src/04-components/{toggle → forms/toggle}/toggle.api.json +5 -0
  99. package/src/04-components/{toggle → forms/toggle}/toggle.visual.spec.ts +1 -1
  100. package/src/04-components/index.scss +42 -41
  101. package/src/04-components/{divider → layout/divider}/divider.api.json +3 -0
  102. package/src/04-components/{divider → layout/divider}/divider.visual.spec.ts +1 -1
  103. package/src/04-components/{divider → layout/divider}/index.scss +1 -1
  104. package/src/04-components/{breadcrumb → navigation/breadcrumb}/breadcrumb.api.json +5 -0
  105. package/src/04-components/{breadcrumb → navigation/breadcrumb}/breadcrumb.visual.spec.ts +1 -1
  106. package/src/04-components/{breadcrumb → navigation/breadcrumb}/index.scss +1 -1
  107. package/src/04-components/{menu → navigation/menu}/index.scss +1 -1
  108. package/src/04-components/{menu → navigation/menu}/menu.api.json +24 -0
  109. package/src/04-components/{menu → navigation/menu}/menu.visual.spec.ts +1 -1
  110. package/src/04-components/navigation/nav/index.scss +142 -0
  111. package/src/04-components/navigation/nav/nav-visual.png +0 -0
  112. package/src/04-components/navigation/nav/nav.api.json +55 -0
  113. package/src/04-components/navigation/nav/nav.docs.json +242 -0
  114. package/src/04-components/navigation/nav/nav.visual.spec.ts +14 -0
  115. package/src/04-components/{pagination → navigation/pagination}/index.scss +1 -1
  116. package/src/04-components/{pagination → navigation/pagination}/pagination.api.json +22 -1
  117. package/src/04-components/{pagination → navigation/pagination}/pagination.visual.spec.ts +1 -1
  118. package/src/04-components/{tabs → navigation/tabs}/index.scss +1 -1
  119. package/src/04-components/{tabs → navigation/tabs}/tabs.api.json +17 -0
  120. package/src/04-components/{tabs → navigation/tabs}/tabs.visual.spec.ts +1 -1
  121. package/src/04-components/{dialog → overlays/dialog}/dialog.api.json +12 -1
  122. package/src/04-components/{dialog → overlays/dialog}/dialog.visual.spec.ts +1 -1
  123. package/src/04-components/{dialog → overlays/dialog}/index.scss +1 -1
  124. package/src/04-components/{drawer → overlays/drawer}/drawer.api.json +17 -1
  125. package/src/04-components/{drawer → overlays/drawer}/drawer.visual.spec.ts +1 -1
  126. package/src/04-components/{drawer → overlays/drawer}/index.scss +1 -1
  127. package/src/04-components/{modal → overlays/modal}/index.scss +1 -1
  128. package/src/04-components/{modal → overlays/modal}/modal.api.json +12 -1
  129. package/src/04-components/{modal → overlays/modal}/modal.visual.spec.ts +1 -1
  130. package/src/04-components/{overlay → overlays/overlay}/index.scss +1 -1
  131. package/src/04-components/{overlay → overlays/overlay}/overlay.api.json +14 -1
  132. package/src/04-components/{overlay → overlays/overlay}/overlay.visual.spec.ts +1 -1
  133. package/src/04-components/{popover → overlays/popover}/index.scss +1 -1
  134. package/src/04-components/{popover → overlays/popover}/popover.api.json +9 -1
  135. package/src/04-components/{popover → overlays/popover}/popover.visual.spec.ts +1 -1
  136. package/src/04-components/{tooltip → overlays/tooltip}/index.scss +1 -1
  137. package/src/04-components/{tooltip → overlays/tooltip}/tooltip.api.json +11 -1
  138. package/src/04-components/{tooltip → overlays/tooltip}/tooltip.visual.spec.ts +1 -1
  139. package/src/04-components/{code → typography/code}/code.api.json +6 -1
  140. package/src/04-components/{code → typography/code}/code.visual.spec.ts +1 -1
  141. package/src/04-components/{code → typography/code}/index.scss +1 -1
  142. package/src/04-components/{heading → typography/heading}/heading.visual.spec.ts +1 -1
  143. package/src/04-components/{heading → typography/heading}/index.scss +1 -1
  144. package/src/04-components/{link → typography/link}/index.scss +1 -1
  145. package/src/04-components/typography/link/link-visual.png +0 -0
  146. package/src/04-components/{link → typography/link}/link.api.json +6 -0
  147. package/src/04-components/{link → typography/link}/link.visual.spec.ts +1 -1
  148. package/src/99-debug/grid-overlay.scss +9 -8
  149. package/src/testing/page-setup.ts +25 -9
  150. package/src/testing/sidebar-toggles.spec.ts +103 -0
  151. package/src/04-components/button/button-visual.png +0 -0
  152. package/src/04-components/button-group/button-group-visual.png +0 -0
  153. package/src/04-components/checkbox/checkbox-visual.png +0 -0
  154. package/src/04-components/data-list/data-list-visual.png +0 -0
  155. package/src/04-components/field/field.api.json +0 -11
  156. package/src/04-components/form-error/form-error-visual.png +0 -0
  157. package/src/04-components/icon/icon-visual.png +0 -0
  158. package/src/04-components/input/input-visual.png +0 -0
  159. package/src/04-components/link/link-visual.png +0 -0
  160. package/src/04-components/radio/radio-visual.png +0 -0
  161. /package/src/04-components/{button-group → actions/button-group}/button-group.docs.json +0 -0
  162. /package/src/04-components/{avatar → data-display/avatar}/avatar-visual.png +0 -0
  163. /package/src/04-components/{avatar → data-display/avatar}/avatar.docs.json +0 -0
  164. /package/src/04-components/{badge → data-display/badge}/badge-visual.png +0 -0
  165. /package/src/04-components/{badge → data-display/badge}/badge.api.json +0 -0
  166. /package/src/04-components/{badge → data-display/badge}/badge.docs.json +0 -0
  167. /package/src/04-components/{card → data-display/card}/card-visual.png +0 -0
  168. /package/src/04-components/{card → data-display/card}/card.api.json +0 -0
  169. /package/src/04-components/{card → data-display/card}/card.docs.json +0 -0
  170. /package/src/04-components/{data-list → data-display/data-list}/data-list.docs.json +0 -0
  171. /package/src/04-components/{status → data-display/status}/status-visual.png +0 -0
  172. /package/src/04-components/{status → data-display/status}/status.docs.json +0 -0
  173. /package/src/04-components/{table → data-display/table}/table-visual.png +0 -0
  174. /package/src/04-components/{table → data-display/table}/table.docs.json +0 -0
  175. /package/src/04-components/{tag → data-display/tag}/tag-visual.png +0 -0
  176. /package/src/04-components/{tag → data-display/tag}/tag.docs.json +0 -0
  177. /package/src/04-components/{accordion → disclosure/accordion}/accordion-visual.png +0 -0
  178. /package/src/04-components/{accordion → disclosure/accordion}/accordion.docs.json +0 -0
  179. /package/src/04-components/disclosure/{disclosure-visual.png → disclosure/disclosure-visual.png} +0 -0
  180. /package/src/04-components/disclosure/{disclosure.docs.json → disclosure/disclosure.docs.json} +0 -0
  181. /package/src/04-components/{alert → feedback/alert}/alert-visual.png +0 -0
  182. /package/src/04-components/{alert → feedback/alert}/alert.docs.json +0 -0
  183. /package/src/04-components/{progress → feedback/progress}/progress-visual.png +0 -0
  184. /package/src/04-components/{progress → feedback/progress}/progress.docs.json +0 -0
  185. /package/src/04-components/{skeleton → feedback/skeleton}/skeleton-visual.png +0 -0
  186. /package/src/04-components/{skeleton → feedback/skeleton}/skeleton.docs.json +0 -0
  187. /package/src/04-components/{spinner → feedback/spinner}/spinner-visual.png +0 -0
  188. /package/src/04-components/{spinner → feedback/spinner}/spinner.api.json +0 -0
  189. /package/src/04-components/{spinner → feedback/spinner}/spinner.docs.json +0 -0
  190. /package/src/04-components/{toast → feedback/toast}/toast-visual.png +0 -0
  191. /package/src/04-components/{toast → feedback/toast}/toast.docs.json +0 -0
  192. /package/src/04-components/{checkbox → forms/checkbox}/checkbox.docs.json +0 -0
  193. /package/src/04-components/{field → forms/field}/field-visual.png +0 -0
  194. /package/src/04-components/{field → forms/field}/field.docs.json +0 -0
  195. /package/src/04-components/{form-error → forms/form-error}/form-error.docs.json +0 -0
  196. /package/src/04-components/{form-helper → forms/form-helper}/form-helper-visual.png +0 -0
  197. /package/src/04-components/{form-helper → forms/form-helper}/form-helper.api.json +0 -0
  198. /package/src/04-components/{form-helper → forms/form-helper}/form-helper.docs.json +0 -0
  199. /package/src/04-components/{input → forms/input}/input.docs.json +0 -0
  200. /package/src/04-components/{label → forms/label}/label-visual.png +0 -0
  201. /package/src/04-components/{label → forms/label}/label.docs.json +0 -0
  202. /package/src/04-components/{radio → forms/radio}/radio.docs.json +0 -0
  203. /package/src/04-components/{select → forms/select}/select-visual.png +0 -0
  204. /package/src/04-components/{select → forms/select}/select.docs.json +0 -0
  205. /package/src/04-components/{textarea → forms/textarea}/textarea-visual.png +0 -0
  206. /package/src/04-components/{textarea → forms/textarea}/textarea.docs.json +0 -0
  207. /package/src/04-components/{toggle → forms/toggle}/toggle-visual.png +0 -0
  208. /package/src/04-components/{toggle → forms/toggle}/toggle.docs.json +0 -0
  209. /package/src/04-components/{divider → layout/divider}/divider-visual.png +0 -0
  210. /package/src/04-components/{divider → layout/divider}/divider.docs.json +0 -0
  211. /package/src/04-components/{breadcrumb → navigation/breadcrumb}/breadcrumb-visual.png +0 -0
  212. /package/src/04-components/{breadcrumb → navigation/breadcrumb}/breadcrumb.docs.json +0 -0
  213. /package/src/04-components/{menu → navigation/menu}/menu-visual.png +0 -0
  214. /package/src/04-components/{menu → navigation/menu}/menu.docs.json +0 -0
  215. /package/src/04-components/{pagination → navigation/pagination}/pagination-visual.png +0 -0
  216. /package/src/04-components/{pagination → navigation/pagination}/pagination.docs.json +0 -0
  217. /package/src/04-components/{tabs → navigation/tabs}/tabs-visual.png +0 -0
  218. /package/src/04-components/{tabs → navigation/tabs}/tabs.docs.json +0 -0
  219. /package/src/04-components/{dialog → overlays/dialog}/dialog-visual.png +0 -0
  220. /package/src/04-components/{dialog → overlays/dialog}/dialog.docs.json +0 -0
  221. /package/src/04-components/{drawer → overlays/drawer}/drawer-visual.png +0 -0
  222. /package/src/04-components/{drawer → overlays/drawer}/drawer.docs.json +0 -0
  223. /package/src/04-components/{modal → overlays/modal}/modal-visual.png +0 -0
  224. /package/src/04-components/{modal → overlays/modal}/modal.docs.json +0 -0
  225. /package/src/04-components/{overlay → overlays/overlay}/overlay-visual.png +0 -0
  226. /package/src/04-components/{overlay → overlays/overlay}/overlay.docs.json +0 -0
  227. /package/src/04-components/{popover → overlays/popover}/popover-visual.png +0 -0
  228. /package/src/04-components/{popover → overlays/popover}/popover.docs.json +0 -0
  229. /package/src/04-components/{tooltip → overlays/tooltip}/tooltip-visual.png +0 -0
  230. /package/src/04-components/{tooltip → overlays/tooltip}/tooltip.docs.json +0 -0
  231. /package/src/04-components/{code → typography/code}/code-visual.png +0 -0
  232. /package/src/04-components/{code → typography/code}/code.docs.json +0 -0
  233. /package/src/04-components/{heading → typography/heading}/heading-visual.png +0 -0
  234. /package/src/04-components/{heading → typography/heading}/heading.api.json +0 -0
  235. /package/src/04-components/{heading → typography/heading}/heading.docs.json +0 -0
  236. /package/src/04-components/{link → typography/link}/link.docs.json +0 -0
@@ -1,7 +1,11 @@
1
1
  {
2
2
  "name": "accordion",
3
3
  "element": "div",
4
- "modifiers": {},
4
+ "modifiers": {
5
+ "separated": {
6
+ "type": "boolean"
7
+ }
8
+ },
5
9
  "cssVars": [
6
10
  {
7
11
  "name": "--ui-accordion-border-color",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'accordion.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Accordion - grouped expandable sections
4
4
  // Container for multiple disclosure items
@@ -1,7 +1,19 @@
1
1
  {
2
2
  "name": "disclosure",
3
3
  "element": "div",
4
- "modifiers": {},
4
+ "modifiers": {
5
+ "borderless": {
6
+ "type": "boolean"
7
+ },
8
+ "animate": {
9
+ "type": "boolean"
10
+ }
11
+ },
12
+ "elements": {
13
+ "trigger": {},
14
+ "icon": {},
15
+ "content": {}
16
+ },
5
17
  "cssVars": [
6
18
  {
7
19
  "name": "--ui-disclosure-border-color",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'disclosure.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Disclosure - expandable/collapsible content section
4
4
  // Uses native details/summary for no-JS accessibility
@@ -6,6 +6,12 @@
6
6
  "values": ["info", "success", "warning", "danger"]
7
7
  }
8
8
  },
9
+ "elements": {
10
+ "content": {},
11
+ "title": {},
12
+ "description": {},
13
+ "icon": {}
14
+ },
9
15
  "cssVars": [
10
16
  {
11
17
  "name": "--ui-alert-padding",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'alert.docs.json');
6
6
 
@@ -1,43 +1,38 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component alert
4
4
  // @element div
5
5
 
6
6
  @layer components.tokens {
7
7
  .alert {
8
+ // Single accent color - variants override, bg/border derived via color-mix
9
+ --_accent: var(--ui-alert-accent, var(--ui-color-border, #{t.$color-border}));
10
+
8
11
  --_padding: var(--ui-alert-padding, var(--ui-space-2, #{t.$space-2}));
9
12
  --_border-width: var(--ui-alert-border-width, var(--ui-border-width-sm, #{t.$border-width-sm}));
10
13
  --_gap: var(--ui-alert-gap, var(--ui-space-1, #{t.$space-1}));
11
14
  --_radius: var(--ui-alert-radius, var(--ui-radius-md, #{t.$radius-md}));
12
- --_bg: var(--ui-alert-bg, var(--ui-color-bg-subtle, #{t.$color-bg-subtle}));
13
- --_border-color: var(--ui-alert-border-color, var(--ui-color-border, #{t.$color-border}));
15
+ --_bg: color-mix(in oklch, var(--_accent) 8%, white);
16
+ --_border-color: var(--_accent);
14
17
  --_color: var(--ui-alert-color, var(--ui-color-text, #{t.$color-text}));
15
- --_icon-color: var(--ui-alert-icon-color, currentcolor);
18
+ --_icon-color: var(--_accent);
16
19
  }
17
20
 
18
21
  // @modifier variant
19
22
  .alert--info {
20
- --_bg: var(--ui-alert-info-bg, var(--ui-color-bg-subtle, #{t.$color-bg-subtle}));
21
- --_border-color: var(--ui-alert-info-border, var(--ui-color-primary, #{t.$color-primary}));
22
- --_icon-color: var(--ui-alert-info-icon, var(--ui-color-primary, #{t.$color-primary}));
23
+ --_accent: var(--ui-color-primary, #{t.$color-primary});
23
24
  }
24
25
 
25
26
  .alert--success {
26
- --_bg: var(--ui-alert-success-bg, var(--ui-color-bg-subtle, #{t.$color-bg-subtle}));
27
- --_border-color: var(--ui-alert-success-border, var(--ui-color-success, #{t.$color-success}));
28
- --_icon-color: var(--ui-alert-success-icon, var(--ui-color-success, #{t.$color-success}));
27
+ --_accent: var(--ui-color-success, #{t.$color-success});
29
28
  }
30
29
 
31
30
  .alert--warning {
32
- --_bg: var(--ui-alert-warning-bg, var(--ui-color-bg-subtle, #{t.$color-bg-subtle}));
33
- --_border-color: var(--ui-alert-warning-border, var(--ui-color-warning, #{t.$color-warning}));
34
- --_icon-color: var(--ui-alert-warning-icon, var(--ui-color-warning, #{t.$color-warning}));
31
+ --_accent: var(--ui-color-warning, #{t.$color-warning});
35
32
  }
36
33
 
37
34
  .alert--danger {
38
- --_bg: var(--ui-alert-danger-bg, var(--ui-color-bg-subtle, #{t.$color-bg-subtle}));
39
- --_border-color: var(--ui-alert-danger-border, var(--ui-color-danger, #{t.$color-danger}));
40
- --_icon-color: var(--ui-alert-danger-icon, var(--ui-color-danger, #{t.$color-danger}));
35
+ --_accent: var(--ui-color-danger, #{t.$color-danger});
41
36
  }
42
37
  }
43
38
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Progress - progress bar indicator
4
4
  // Shows completion status of a task
@@ -1,7 +1,26 @@
1
1
  {
2
2
  "name": "progress",
3
3
  "element": "div",
4
- "modifiers": {},
4
+ "modifiers": {
5
+ "size": {
6
+ "values": ["sm", "lg"]
7
+ },
8
+ "variant": {
9
+ "values": ["success", "warning", "danger"]
10
+ },
11
+ "striped": {
12
+ "type": "boolean"
13
+ },
14
+ "animated": {
15
+ "type": "boolean"
16
+ },
17
+ "indeterminate": {
18
+ "type": "boolean"
19
+ }
20
+ },
21
+ "elements": {
22
+ "bar": {}
23
+ },
5
24
  "cssVars": [
6
25
  {
7
26
  "name": "--ui-progress-height",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'progress.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Skeleton - loading placeholder
4
4
  // Animated shimmer effect for content loading states
@@ -1,7 +1,14 @@
1
1
  {
2
2
  "name": "skeleton",
3
3
  "element": "div",
4
- "modifiers": {},
4
+ "modifiers": {
5
+ "variant": {
6
+ "values": ["text", "circle", "heading", "rect"]
7
+ },
8
+ "pulse": {
9
+ "type": "boolean"
10
+ }
11
+ },
5
12
  "cssVars": [
6
13
  {
7
14
  "name": "--ui-skeleton-bg",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'skeleton.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component spinner
4
4
  // @element div
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'spinner.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Toast - notification messages
4
4
  // Appears in viewport corner with auto-dismiss
@@ -1,7 +1,28 @@
1
1
  {
2
2
  "name": "toast",
3
3
  "element": "div",
4
- "modifiers": {},
4
+ "modifiers": {
5
+ "variant": {
6
+ "values": ["success", "warning", "danger", "info"]
7
+ }
8
+ },
9
+ "elements": {
10
+ "content": {},
11
+ "title": {},
12
+ "description": {},
13
+ "close": {},
14
+ "action": {}
15
+ },
16
+ "relatedComponents": [
17
+ {
18
+ "name": "toast-viewport",
19
+ "modifiers": {
20
+ "position": {
21
+ "values": ["top-end", "bottom-end"]
22
+ }
23
+ }
24
+ }
25
+ ],
5
26
  "cssVars": [
6
27
  {
7
28
  "name": "--ui-toast-viewport-gap",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'toast.docs.json');
6
6
 
@@ -3,7 +3,7 @@
3
3
  "element": "input",
4
4
  "modifiers": {
5
5
  "size": {
6
- "values": ["lg"]
6
+ "values": ["sm", "lg"]
7
7
  },
8
8
  "error": {
9
9
  "type": "boolean"
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'checkbox.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component checkbox
4
4
  // @element input
@@ -0,0 +1,19 @@
1
+ {
2
+ "name": "field",
3
+ "element": "div",
4
+ "modifiers": {
5
+ "horizontal": {
6
+ "type": "boolean"
7
+ }
8
+ },
9
+ "elements": {
10
+ "label": {},
11
+ "control": {}
12
+ },
13
+ "cssVars": [
14
+ {
15
+ "name": "--ui-field-gap",
16
+ "default": "0"
17
+ }
18
+ ]
19
+ }
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'field.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Field - form field wrapper
4
4
  // Combines label, control, helper text, and error message
@@ -2,6 +2,9 @@
2
2
  "name": "form-error",
3
3
  "element": "div",
4
4
  "modifiers": {},
5
+ "elements": {
6
+ "icon": {}
7
+ },
5
8
  "cssVars": [
6
9
  {
7
10
  "name": "--ui-form-error-color",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'form-error.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Form Error - validation error message for form fields
4
4
  // Displays error text with danger color
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'form-helper.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // Form Helper - helper text for form fields
4
4
  // Displays muted text below form controls
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component input
4
4
  // @element input
@@ -10,8 +10,39 @@
10
10
  },
11
11
  "state": {
12
12
  "values": ["error", "success"]
13
+ },
14
+ "block": {
15
+ "type": "boolean"
13
16
  }
14
17
  },
18
+ "relatedComponents": [
19
+ {
20
+ "name": "input-group",
21
+ "modifiers": {
22
+ "has-prefix": {
23
+ "type": "boolean"
24
+ },
25
+ "has-suffix": {
26
+ "type": "boolean"
27
+ }
28
+ },
29
+ "elements": {
30
+ "addon": {
31
+ "modifiers": {
32
+ "start": {
33
+ "type": "boolean"
34
+ },
35
+ "end": {
36
+ "type": "boolean"
37
+ },
38
+ "interactive": {
39
+ "type": "boolean"
40
+ }
41
+ }
42
+ }
43
+ }
44
+ }
45
+ ],
15
46
  "cssVars": [
16
47
  {
17
48
  "name": "--ui-input-height",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'input.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component label
4
4
  // @element label
@@ -6,6 +6,10 @@
6
6
  "values": ["lg"]
7
7
  }
8
8
  },
9
+ "elements": {
10
+ "required": {},
11
+ "optional": {}
12
+ },
9
13
  "cssVars": [
10
14
  {
11
15
  "name": "--ui-label-font-size",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'label.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component radio
4
4
  // @element input
@@ -3,7 +3,7 @@
3
3
  "element": "input",
4
4
  "modifiers": {
5
5
  "size": {
6
- "values": ["lg"]
6
+ "values": ["sm", "lg"]
7
7
  },
8
8
  "error": {
9
9
  "type": "boolean"
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'radio.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component select
4
4
  // @element select
@@ -10,6 +10,9 @@
10
10
  },
11
11
  "state": {
12
12
  "values": ["error", "success"]
13
+ },
14
+ "block": {
15
+ "type": "boolean"
13
16
  }
14
17
  },
15
18
  "cssVars": [
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'select.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component textarea
4
4
  // @element textarea
@@ -10,6 +10,9 @@
10
10
  },
11
11
  "state": {
12
12
  "values": ["error", "success"]
13
+ },
14
+ "resize": {
15
+ "values": ["resize-none", "resize-both"]
13
16
  }
14
17
  },
15
18
  "cssVars": [
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'textarea.docs.json');
6
6
 
@@ -1,4 +1,4 @@
1
- @use '../../00-config/tokens/variables' as t;
1
+ @use '../../../00-config/tokens/variables' as t;
2
2
 
3
3
  // @component toggle
4
4
  // @element div
@@ -6,6 +6,11 @@
6
6
  "values": ["sm", "lg"]
7
7
  }
8
8
  },
9
+ "elements": {
10
+ "input": {},
11
+ "track": {},
12
+ "thumb": {}
13
+ },
9
14
  "cssVars": [
10
15
  {
11
16
  "name": "--ui-toggle-track-width",
@@ -1,6 +1,6 @@
1
1
  import { resolve } from 'node:path';
2
2
  import { expect, test } from '@playwright/test';
3
- import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../testing';
3
+ import { saveForLostPixel, setupVisualTestFromDocs, validateGridRhythm } from '../../../testing';
4
4
 
5
5
  const DOCS_PATH = resolve(__dirname, 'toggle.docs.json');
6
6