@teseor/css 1.14.2 → 1.15.0

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 (300) hide show
  1. package/package.json +1 -1
  2. package/src/base/root.docs.html +20 -0
  3. package/src/base/typography/typography.docs.html +161 -0
  4. package/src/components/actions/button/button.docs.html +76 -0
  5. package/src/components/actions/button/button.visual.spec.ts +7 -3
  6. package/src/components/actions/button-group/button-group.docs.html +47 -0
  7. package/src/components/actions/button-group/button-group.visual.spec.ts +7 -3
  8. package/src/components/actions/close-button/close-button.docs.html +77 -0
  9. package/src/components/actions/close-button/close-button.visual.spec.ts +7 -3
  10. package/src/components/content/divider/divider.docs.html +27 -0
  11. package/src/components/content/divider/divider.visual.spec.ts +7 -3
  12. package/src/components/content/scroll-area/scroll-area-visual.png +0 -0
  13. package/src/components/content/scroll-area/scroll-area.docs.html +130 -0
  14. package/src/components/content/scroll-area/scroll-area.visual.spec.ts +7 -3
  15. package/src/components/content/spacer/spacer.docs.html +23 -0
  16. package/src/components/content/spacer/spacer.visual.spec.ts +3 -3
  17. package/src/components/data-display/avatar/avatar.docs.html +67 -0
  18. package/src/components/data-display/avatar/avatar.visual.spec.ts +7 -3
  19. package/src/components/data-display/badge/badge.docs.html +39 -0
  20. package/src/components/data-display/badge/badge.visual.spec.ts +7 -3
  21. package/src/components/data-display/card/card-visual.png +0 -0
  22. package/src/components/data-display/card/card.docs.html +36 -0
  23. package/src/components/data-display/card/card.visual.spec.ts +7 -3
  24. package/src/components/data-display/data-list/data-list-visual.png +0 -0
  25. package/src/components/data-display/data-list/data-list.docs.html +97 -0
  26. package/src/components/data-display/data-list/data-list.visual.spec.ts +7 -3
  27. package/src/components/data-display/icon/icon.docs.html +72 -0
  28. package/src/components/data-display/icon/icon.visual.spec.ts +7 -3
  29. package/src/components/data-display/image/image-visual.png +0 -0
  30. package/src/components/data-display/image/image.docs.html +67 -0
  31. package/src/components/data-display/image/image.visual.spec.ts +7 -3
  32. package/src/components/data-display/stat/stat.docs.html +35 -0
  33. package/src/components/data-display/stat/stat.visual.spec.ts +7 -3
  34. package/src/components/data-display/status/status.docs.html +67 -0
  35. package/src/components/data-display/status/status.visual.spec.ts +7 -3
  36. package/src/components/data-display/table/table.docs.html +73 -0
  37. package/src/components/data-display/table/table.visual.spec.ts +7 -3
  38. package/src/components/data-display/tag/tag.docs.html +42 -0
  39. package/src/components/data-display/tag/tag.visual.spec.ts +7 -3
  40. package/src/components/disclosure/accordion/accordion.docs.html +83 -0
  41. package/src/components/disclosure/accordion/accordion.visual.spec.ts +7 -3
  42. package/src/components/disclosure/disclosure/disclosure.docs.html +51 -0
  43. package/src/components/disclosure/disclosure/disclosure.visual.spec.ts +7 -3
  44. package/src/components/feedback/alert/alert.docs.html +90 -0
  45. package/src/components/feedback/alert/alert.visual.spec.ts +7 -3
  46. package/src/components/feedback/progress/progress.docs.html +65 -0
  47. package/src/components/feedback/progress/progress.visual.spec.ts +7 -3
  48. package/src/components/feedback/progress-circle/progress-circle.docs.html +65 -0
  49. package/src/components/feedback/progress-circle/progress-circle.visual.spec.ts +7 -3
  50. package/src/components/feedback/skeleton/skeleton.docs.html +40 -0
  51. package/src/components/feedback/skeleton/skeleton.visual.spec.ts +7 -3
  52. package/src/components/feedback/spinner/spinner.docs.html +28 -0
  53. package/src/components/feedback/spinner/spinner.visual.spec.ts +7 -3
  54. package/src/components/feedback/toast/toast-visual.png +0 -0
  55. package/src/components/feedback/toast/toast.docs.html +109 -0
  56. package/src/components/feedback/toast/toast.visual.spec.ts +7 -3
  57. package/src/components/forms/checkbox/checkbox.docs.html +33 -0
  58. package/src/components/forms/checkbox/checkbox.visual.spec.ts +7 -3
  59. package/src/components/forms/checkbox-group/checkbox-group.docs.html +104 -0
  60. package/src/components/forms/checkbox-group/checkbox-group.visual.spec.ts +7 -3
  61. package/src/components/forms/field/field.docs.html +63 -0
  62. package/src/components/forms/field/field.visual.spec.ts +7 -3
  63. package/src/components/forms/fieldset/fieldset.docs.html +122 -0
  64. package/src/components/forms/fieldset/fieldset.visual.spec.ts +7 -3
  65. package/src/components/forms/form/form.docs.html +132 -0
  66. package/src/components/forms/form/form.visual.spec.ts +7 -3
  67. package/src/components/forms/form-error/form-error.docs.html +18 -0
  68. package/src/components/forms/form-error/form-error.visual.spec.ts +7 -3
  69. package/src/components/forms/form-helper/form-helper.docs.html +42 -0
  70. package/src/components/forms/form-helper/form-helper.visual.spec.ts +7 -3
  71. package/src/components/forms/input/input-visual.png +0 -0
  72. package/src/components/forms/input/input.docs.html +69 -0
  73. package/src/components/forms/input/input.visual.spec.ts +7 -3
  74. package/src/components/forms/label/label-visual.png +0 -0
  75. package/src/components/forms/label/label.docs.html +29 -0
  76. package/src/components/forms/label/label.visual.spec.ts +7 -3
  77. package/src/components/forms/number-input/number-input-visual.png +0 -0
  78. package/src/components/forms/number-input/number-input.docs.html +100 -0
  79. package/src/components/forms/number-input/number-input.visual.spec.ts +7 -3
  80. package/src/components/forms/password-input/password-input-visual.png +0 -0
  81. package/src/components/forms/password-input/password-input.docs.html +88 -0
  82. package/src/components/forms/password-input/password-input.visual.spec.ts +7 -3
  83. package/src/components/forms/radio/radio.docs.html +52 -0
  84. package/src/components/forms/radio/radio.visual.spec.ts +7 -3
  85. package/src/components/forms/radio-group/radio-group.docs.html +100 -0
  86. package/src/components/forms/radio-group/radio-group.visual.spec.ts +7 -3
  87. package/src/components/forms/search-input/search-input-visual.png +0 -0
  88. package/src/components/forms/search-input/search-input.docs.html +87 -0
  89. package/src/components/forms/search-input/search-input.visual.spec.ts +7 -3
  90. package/src/components/forms/select/select-visual.png +0 -0
  91. package/src/components/forms/select/select.docs.html +70 -0
  92. package/src/components/forms/select/select.visual.spec.ts +7 -3
  93. package/src/components/forms/slider/slider-visual.png +0 -0
  94. package/src/components/forms/slider/slider.docs.html +25 -0
  95. package/src/components/forms/slider/slider.visual.spec.ts +7 -3
  96. package/src/components/forms/textarea/textarea-visual.png +0 -0
  97. package/src/components/forms/textarea/textarea.docs.html +39 -0
  98. package/src/components/forms/textarea/textarea.visual.spec.ts +7 -3
  99. package/src/components/forms/toggle/toggle.docs.html +64 -0
  100. package/src/components/forms/toggle/toggle.visual.spec.ts +7 -3
  101. package/src/components/navigation/breadcrumb/breadcrumb.docs.html +60 -0
  102. package/src/components/navigation/breadcrumb/breadcrumb.visual.spec.ts +7 -3
  103. package/src/components/navigation/dropdown-menu/dropdown-menu-visual.png +0 -0
  104. package/src/components/navigation/dropdown-menu/dropdown-menu.docs.html +106 -0
  105. package/src/components/navigation/dropdown-menu/dropdown-menu.visual.spec.ts +7 -3
  106. package/src/components/navigation/menu/menu.docs.html +122 -0
  107. package/src/components/navigation/menu/menu.visual.spec.ts +7 -3
  108. package/src/components/navigation/nav/nav.docs.html +74 -0
  109. package/src/components/navigation/nav/nav.visual.spec.ts +7 -3
  110. package/src/components/navigation/pagination/pagination-visual.png +0 -0
  111. package/src/components/navigation/pagination/pagination.docs.html +116 -0
  112. package/src/components/navigation/pagination/pagination.visual.spec.ts +7 -3
  113. package/src/components/navigation/tabs/tabs.docs.html +66 -0
  114. package/src/components/navigation/tabs/tabs.visual.spec.ts +7 -3
  115. package/src/components/overlays/dialog/dialog.docs.html +61 -0
  116. package/src/components/overlays/dialog/dialog.visual.spec.ts +7 -3
  117. package/src/components/overlays/drawer/drawer-visual.png +0 -0
  118. package/src/components/overlays/drawer/drawer.docs.html +90 -0
  119. package/src/components/overlays/drawer/drawer.visual.spec.ts +7 -3
  120. package/src/components/overlays/modal/modal.docs.html +69 -0
  121. package/src/components/overlays/modal/modal.visual.spec.ts +7 -3
  122. package/src/components/overlays/overlay/overlay.docs.html +30 -0
  123. package/src/components/overlays/overlay/overlay.visual.spec.ts +7 -3
  124. package/src/components/overlays/popover/popover.docs.html +41 -0
  125. package/src/components/overlays/popover/popover.visual.spec.ts +7 -3
  126. package/src/components/overlays/tooltip/tooltip.docs.html +33 -0
  127. package/src/components/overlays/tooltip/tooltip.visual.spec.ts +7 -3
  128. package/src/components/typography/blockquote/blockquote.docs.html +24 -0
  129. package/src/components/typography/blockquote/blockquote.visual.spec.ts +7 -3
  130. package/src/components/typography/code/code-visual.png +0 -0
  131. package/src/components/typography/code/code.docs.html +23 -0
  132. package/src/components/typography/code/code.visual.spec.ts +7 -3
  133. package/src/components/typography/code-block/code-block-visual.png +0 -0
  134. package/src/components/typography/code-block/code-block.docs.html +87 -0
  135. package/src/components/typography/code-block/code-block.visual.spec.ts +7 -3
  136. package/src/components/typography/heading/heading-visual.png +0 -0
  137. package/src/components/typography/heading/heading.docs.html +26 -0
  138. package/src/components/typography/heading/heading.visual.spec.ts +7 -3
  139. package/src/components/typography/kbd/kbd.docs.html +16 -0
  140. package/src/components/typography/kbd/kbd.visual.spec.ts +7 -3
  141. package/src/components/typography/link/link.docs.html +33 -0
  142. package/src/components/typography/link/link.visual.spec.ts +7 -3
  143. package/src/components/typography/list/list.docs.html +79 -0
  144. package/src/components/typography/list/list.visual.spec.ts +7 -3
  145. package/src/components/typography/mark/mark.docs.html +12 -0
  146. package/src/components/typography/mark/mark.visual.spec.ts +7 -3
  147. package/src/config/guides/accessibility.docs.html +108 -0
  148. package/src/config/guides/getting-started.docs.html +47 -0
  149. package/src/config/guides/theming.docs.html +71 -0
  150. package/src/config/tokens/colors/colors.docs.html +75 -0
  151. package/src/config/tokens/design-tokens.docs.html +116 -0
  152. package/src/config/tokens/grid/grid.docs.html +12 -0
  153. package/src/config/tokens/spacing/spacing.docs.html +33 -0
  154. package/src/debug/debug.docs.html +29 -0
  155. package/src/debug/index.scss +81 -1
  156. package/src/layout/app-shell/app-shell-visual.png +0 -0
  157. package/src/layout/app-shell/app-shell.docs.html +102 -0
  158. package/src/layout/app-shell/app-shell.visual.spec.ts +3 -3
  159. package/src/layout/aspect-ratio/aspect-ratio.docs.html +41 -0
  160. package/src/layout/aspect-ratio/aspect-ratio.visual.spec.ts +3 -3
  161. package/src/layout/box/box-visual.png +0 -0
  162. package/src/layout/box/box.docs.html +27 -0
  163. package/src/layout/box/box.visual.spec.ts +3 -3
  164. package/src/layout/center/center.docs.html +26 -0
  165. package/src/layout/center/center.visual.spec.ts +3 -3
  166. package/src/layout/column/column.docs.html +32 -0
  167. package/src/layout/column/column.visual.spec.ts +3 -3
  168. package/src/layout/container/container.docs.html +37 -0
  169. package/src/layout/content/content-visual.png +0 -0
  170. package/src/layout/content/content.docs.html +38 -0
  171. package/src/layout/content/content.visual.spec.ts +7 -3
  172. package/src/layout/footer/footer-visual.png +0 -0
  173. package/src/layout/footer/footer.docs.html +73 -0
  174. package/src/layout/footer/footer.visual.spec.ts +7 -3
  175. package/src/layout/grid/grid.docs.html +87 -0
  176. package/src/layout/grid/grid.visual.spec.ts +3 -3
  177. package/src/layout/main/main.docs.html +31 -0
  178. package/src/layout/nav-rail/nav-rail-visual.png +0 -0
  179. package/src/layout/nav-rail/nav-rail.docs.html +42 -0
  180. package/src/layout/nav-rail/nav-rail.visual.spec.ts +7 -3
  181. package/src/layout/page-header/page-header.docs.html +52 -0
  182. package/src/layout/page-header/page-header.visual.spec.ts +7 -3
  183. package/src/layout/row/row.docs.html +47 -0
  184. package/src/layout/row/row.visual.spec.ts +3 -3
  185. package/src/layout/sidebar/sidebar-visual.png +0 -0
  186. package/src/layout/sidebar/sidebar.docs.html +30 -0
  187. package/src/layout/sidebar/sidebar.visual.spec.ts +7 -3
  188. package/src/layout/sidebar-nav/sidebar-nav.docs.html +235 -0
  189. package/src/layout/sidebar-nav/sidebar-nav.visual.spec.ts +7 -3
  190. package/src/layout/topbar/topbar-visual.png +0 -0
  191. package/src/layout/topbar/topbar.docs.html +64 -0
  192. package/src/layout/topbar/topbar.visual.spec.ts +7 -3
  193. package/src/utilities/container/container.docs.html +34 -0
  194. package/src/utilities/display/display.docs.html +30 -0
  195. package/src/utilities/scroll-animation/scroll-animation.docs.html +32 -0
  196. package/src/utilities/scroll-snap/scroll-snap.docs.html +80 -0
  197. package/src/utilities/spacing/spacing.docs.html +29 -0
  198. package/src/utilities/text/text.docs.html +66 -0
  199. package/src/utilities/view-transition/view-transition.docs.html +52 -0
  200. package/src/utilities/visually-hidden/visually-hidden.docs.html +18 -0
  201. package/src/base/typography/typography.docs.json +0 -328
  202. package/src/components/actions/button/button.docs.json +0 -264
  203. package/src/components/actions/button-group/button-group.docs.json +0 -151
  204. package/src/components/actions/close-button/close-button.docs.json +0 -265
  205. package/src/components/content/divider/divider.docs.json +0 -113
  206. package/src/components/content/scroll-area/scroll-area.docs.json +0 -273
  207. package/src/components/content/spacer/spacer.docs.json +0 -102
  208. package/src/components/data-display/avatar/avatar.docs.json +0 -245
  209. package/src/components/data-display/badge/badge.docs.json +0 -114
  210. package/src/components/data-display/card/card.docs.json +0 -229
  211. package/src/components/data-display/data-list/data-list.docs.json +0 -259
  212. package/src/components/data-display/icon/icon.docs.json +0 -307
  213. package/src/components/data-display/image/image.docs.json +0 -337
  214. package/src/components/data-display/stat/stat.docs.json +0 -114
  215. package/src/components/data-display/status/status.docs.json +0 -147
  216. package/src/components/data-display/table/table.docs.json +0 -184
  217. package/src/components/data-display/tag/tag.docs.json +0 -146
  218. package/src/components/disclosure/accordion/accordion.docs.json +0 -206
  219. package/src/components/disclosure/disclosure/disclosure.docs.json +0 -154
  220. package/src/components/feedback/alert/alert.docs.json +0 -325
  221. package/src/components/feedback/progress/progress.docs.json +0 -315
  222. package/src/components/feedback/progress-circle/progress-circle.docs.json +0 -378
  223. package/src/components/feedback/skeleton/skeleton.docs.json +0 -142
  224. package/src/components/feedback/spinner/spinner.docs.json +0 -121
  225. package/src/components/feedback/toast/toast.docs.json +0 -418
  226. package/src/components/forms/checkbox/checkbox.docs.json +0 -166
  227. package/src/components/forms/checkbox-group/checkbox-group.docs.json +0 -339
  228. package/src/components/forms/field/field.docs.json +0 -276
  229. package/src/components/forms/fieldset/fieldset.docs.json +0 -520
  230. package/src/components/forms/form/form.docs.json +0 -482
  231. package/src/components/forms/form-error/form-error.docs.json +0 -61
  232. package/src/components/forms/form-helper/form-helper.docs.json +0 -151
  233. package/src/components/forms/input/input.docs.json +0 -306
  234. package/src/components/forms/label/label.docs.json +0 -110
  235. package/src/components/forms/number-input/number-input.docs.json +0 -311
  236. package/src/components/forms/password-input/password-input.docs.json +0 -316
  237. package/src/components/forms/radio/radio.docs.json +0 -236
  238. package/src/components/forms/radio-group/radio-group.docs.json +0 -351
  239. package/src/components/forms/search-input/search-input.docs.json +0 -293
  240. package/src/components/forms/select/select.docs.json +0 -231
  241. package/src/components/forms/slider/slider.docs.json +0 -144
  242. package/src/components/forms/textarea/textarea.docs.json +0 -229
  243. package/src/components/forms/toggle/toggle.docs.json +0 -229
  244. package/src/components/navigation/breadcrumb/breadcrumb.docs.json +0 -240
  245. package/src/components/navigation/dropdown-menu/dropdown-menu.docs.json +0 -290
  246. package/src/components/navigation/menu/menu.docs.json +0 -326
  247. package/src/components/navigation/nav/nav.docs.json +0 -304
  248. package/src/components/navigation/pagination/pagination.docs.json +0 -483
  249. package/src/components/navigation/tabs/tabs.docs.json +0 -243
  250. package/src/components/overlays/dialog/dialog.docs.json +0 -200
  251. package/src/components/overlays/drawer/drawer.docs.json +0 -307
  252. package/src/components/overlays/modal/modal.docs.json +0 -252
  253. package/src/components/overlays/overlay/overlay.docs.json +0 -138
  254. package/src/components/overlays/popover/popover.docs.json +0 -154
  255. package/src/components/overlays/tooltip/tooltip.docs.json +0 -133
  256. package/src/components/typography/blockquote/blockquote.docs.json +0 -89
  257. package/src/components/typography/code/code.docs.json +0 -104
  258. package/src/components/typography/code-block/code-block.docs.json +0 -308
  259. package/src/components/typography/heading/heading.docs.json +0 -120
  260. package/src/components/typography/kbd/kbd.docs.json +0 -61
  261. package/src/components/typography/link/link.docs.json +0 -149
  262. package/src/components/typography/list/list.docs.json +0 -296
  263. package/src/components/typography/mark/mark.docs.json +0 -60
  264. package/src/config/tokens/accessibility.docs.json +0 -125
  265. package/src/config/tokens/colors/colors.docs.json +0 -316
  266. package/src/config/tokens/grid/grid.docs.json +0 -54
  267. package/src/config/tokens/spacing/spacing.docs.json +0 -114
  268. package/src/config/tokens/theming.docs.json +0 -288
  269. package/src/debug/grid-overlay.scss +0 -81
  270. package/src/layout/app-shell/app-shell.docs.json +0 -155
  271. package/src/layout/aspect-ratio/aspect-ratio.docs.json +0 -193
  272. package/src/layout/box/box.docs.json +0 -93
  273. package/src/layout/center/center.docs.json +0 -63
  274. package/src/layout/column/column.docs.json +0 -157
  275. package/src/layout/container/container.docs.json +0 -85
  276. package/src/layout/content/content.docs.json +0 -82
  277. package/src/layout/footer/footer.docs.json +0 -119
  278. package/src/layout/grid/grid.docs.json +0 -493
  279. package/src/layout/main/main.docs.json +0 -87
  280. package/src/layout/nav-rail/nav-rail.docs.json +0 -76
  281. package/src/layout/page-header/page-header.docs.json +0 -124
  282. package/src/layout/row/row.docs.json +0 -237
  283. package/src/layout/sidebar/sidebar.docs.json +0 -63
  284. package/src/layout/sidebar-nav/sidebar-nav.docs.json +0 -833
  285. package/src/layout/topbar/topbar.docs.json +0 -110
  286. package/src/testing/api-types.ts +0 -20
  287. package/src/testing/grid-alignment.spec.ts +0 -38
  288. package/src/testing/html-generator.ts +0 -151
  289. package/src/testing/index.ts +0 -15
  290. package/src/testing/page-setup.ts +0 -149
  291. package/src/testing/rhythm.ts +0 -146
  292. package/src/testing/scaffold.ts +0 -50
  293. package/src/utilities/container/container.docs.json +0 -121
  294. package/src/utilities/display/display.docs.json +0 -83
  295. package/src/utilities/scroll-animation/scroll-animation.docs.json +0 -100
  296. package/src/utilities/scroll-snap/scroll-snap.docs.json +0 -333
  297. package/src/utilities/spacing/spacing.docs.json +0 -133
  298. package/src/utilities/text/text.docs.json +0 -191
  299. package/src/utilities/view-transition/view-transition.docs.json +0 -63
  300. package/src/utilities/visually-hidden/visually-hidden.docs.json +0 -44
@@ -1,119 +0,0 @@
1
- {
2
- "id": "footer",
3
- "type": "primitive",
4
- "title": "Footer",
5
- "description": "Page footer with start, center, and end sections. Supports sticky/fixed positioning and border/shadow variants.",
6
- "api": "./footer.api.json",
7
- "sections": [
8
- {
9
- "title": "Default",
10
- "description": "Basic footer with three sections.",
11
- "examples": [
12
- {
13
- "items": [
14
- {
15
- "tag": "footer",
16
- "class": "ui-footer ui-footer--bordered",
17
- "children": [
18
- {
19
- "tag": "div",
20
- "class": "ui-footer__start",
21
- "children": [{ "tag": "small", "text": "2026 Brand" }]
22
- },
23
- {
24
- "tag": "div",
25
- "class": "ui-footer__center",
26
- "children": [{ "tag": "span", "text": "Footer links" }]
27
- },
28
- {
29
- "tag": "div",
30
- "class": "ui-footer__end",
31
- "children": [{ "tag": "small", "text": "v1.0.0" }]
32
- }
33
- ]
34
- }
35
- ]
36
- }
37
- ]
38
- },
39
- {
40
- "title": "Sticky",
41
- "description": "Stays at the bottom of the viewport on scroll.",
42
- "examples": [
43
- {
44
- "code": "<footer class=\"ui-footer ui-footer--sticky ui-footer--bordered\">\n <div class=\"ui-footer__start\"><small>Brand</small></div>\n <div class=\"ui-footer__center\">Links</div>\n <div class=\"ui-footer__end\"><small>v1.0.0</small></div>\n</footer>"
45
- }
46
- ]
47
- },
48
- {
49
- "title": "Bordered",
50
- "description": "Top border via inset box-shadow to preserve grid rhythm.",
51
- "examples": [
52
- {
53
- "items": [
54
- {
55
- "tag": "footer",
56
- "class": "ui-footer ui-footer--bordered",
57
- "children": [
58
- {
59
- "tag": "div",
60
- "class": "ui-footer__start",
61
- "children": [{ "tag": "small", "text": "Bordered footer" }]
62
- },
63
- {
64
- "tag": "div",
65
- "class": "ui-footer__end",
66
- "children": [{ "tag": "small", "text": "v1.0.0" }]
67
- }
68
- ]
69
- }
70
- ]
71
- }
72
- ]
73
- },
74
- {
75
- "title": "Raised",
76
- "description": "Subtle drop shadow above the footer.",
77
- "examples": [
78
- {
79
- "items": [
80
- {
81
- "tag": "footer",
82
- "class": "ui-footer ui-footer--raised",
83
- "children": [
84
- {
85
- "tag": "div",
86
- "class": "ui-footer__start",
87
- "children": [{ "tag": "small", "text": "Raised footer" }]
88
- },
89
- {
90
- "tag": "div",
91
- "class": "ui-footer__end",
92
- "children": [{ "tag": "small", "text": "v1.0.0" }]
93
- }
94
- ]
95
- }
96
- ]
97
- }
98
- ]
99
- },
100
- {
101
- "title": "Fixed",
102
- "description": "Fixed to viewport bottom, always visible.",
103
- "examples": [
104
- {
105
- "code": "<footer class=\"ui-footer ui-footer--fixed ui-footer--bordered\">\n <div class=\"ui-footer__start\"><small>Brand</small></div>\n <div class=\"ui-footer__end\"><small>v1.0.0</small></div>\n</footer>"
106
- }
107
- ]
108
- },
109
- {
110
- "title": "Full Layout",
111
- "description": "Footer inside an app-shell with topbar and sidebar.",
112
- "examples": [
113
- {
114
- "code": "<body class=\"ui-app-shell\">\n <header class=\"ui-topbar ui-topbar--bordered\">\n <div class=\"ui-topbar__start\"><strong>App</strong></div>\n </header>\n <main class=\"ui-main ui-main--full\">\n <div class=\"ui-container\">Content</div>\n <footer class=\"ui-footer ui-footer--bordered\">\n <div class=\"ui-footer__start\"><small>Brand</small></div>\n <div class=\"ui-footer__end\"><small>v1.0.0</small></div>\n </footer>\n </main>\n</body>"
115
- }
116
- ]
117
- }
118
- ]
119
- }
@@ -1,493 +0,0 @@
1
- {
2
- "id": "grid-primitive",
3
- "type": "primitive",
4
- "title": "Grid",
5
- "description": "CSS Grid with column variants, subgrid support, and span utilities.",
6
- "api": "grid.api.json",
7
- "sections": [
8
- {
9
- "title": "Columns",
10
- "examples": [
11
- {
12
- "items": [
13
- {
14
- "tag": "div",
15
- "class": "ui-grid ui-grid--2",
16
- "children": [
17
- {
18
- "tag": "div",
19
- "text": "1",
20
- "style": {
21
- "background": "var(--ui-color-bg-muted)",
22
- "padding": "var(--ui-space-2)"
23
- }
24
- },
25
- {
26
- "tag": "div",
27
- "text": "2",
28
- "style": {
29
- "background": "var(--ui-color-bg-muted)",
30
- "padding": "var(--ui-space-2)"
31
- }
32
- }
33
- ]
34
- }
35
- ]
36
- },
37
- {
38
- "items": [
39
- {
40
- "tag": "div",
41
- "class": "ui-grid ui-grid--3",
42
- "children": [
43
- {
44
- "tag": "div",
45
- "text": "1",
46
- "style": {
47
- "background": "var(--ui-color-bg-muted)",
48
- "padding": "var(--ui-space-2)"
49
- }
50
- },
51
- {
52
- "tag": "div",
53
- "text": "2",
54
- "style": {
55
- "background": "var(--ui-color-bg-muted)",
56
- "padding": "var(--ui-space-2)"
57
- }
58
- },
59
- {
60
- "tag": "div",
61
- "text": "3",
62
- "style": {
63
- "background": "var(--ui-color-bg-muted)",
64
- "padding": "var(--ui-space-2)"
65
- }
66
- }
67
- ]
68
- }
69
- ]
70
- },
71
- {
72
- "items": [
73
- {
74
- "tag": "div",
75
- "class": "ui-grid ui-grid--4",
76
- "children": [
77
- {
78
- "tag": "div",
79
- "text": "1",
80
- "style": {
81
- "background": "var(--ui-color-bg-muted)",
82
- "padding": "var(--ui-space-2)"
83
- }
84
- },
85
- {
86
- "tag": "div",
87
- "text": "2",
88
- "style": {
89
- "background": "var(--ui-color-bg-muted)",
90
- "padding": "var(--ui-space-2)"
91
- }
92
- },
93
- {
94
- "tag": "div",
95
- "text": "3",
96
- "style": {
97
- "background": "var(--ui-color-bg-muted)",
98
- "padding": "var(--ui-space-2)"
99
- }
100
- },
101
- {
102
- "tag": "div",
103
- "text": "4",
104
- "style": {
105
- "background": "var(--ui-color-bg-muted)",
106
- "padding": "var(--ui-space-2)"
107
- }
108
- }
109
- ]
110
- }
111
- ]
112
- },
113
- {
114
- "items": [
115
- {
116
- "tag": "div",
117
- "class": "ui-grid ui-grid--auto",
118
- "children": [
119
- {
120
- "tag": "div",
121
- "text": "Auto",
122
- "style": {
123
- "background": "var(--ui-color-bg-muted)",
124
- "padding": "var(--ui-space-2)"
125
- }
126
- },
127
- {
128
- "tag": "div",
129
- "text": "Auto",
130
- "style": {
131
- "background": "var(--ui-color-bg-muted)",
132
- "padding": "var(--ui-space-2)"
133
- }
134
- },
135
- {
136
- "tag": "div",
137
- "text": "Auto",
138
- "style": {
139
- "background": "var(--ui-color-bg-muted)",
140
- "padding": "var(--ui-space-2)"
141
- }
142
- }
143
- ]
144
- }
145
- ]
146
- }
147
- ]
148
- },
149
- {
150
- "title": "Subgrid",
151
- "description": "Children inherit parent grid tracks for cross-item alignment.",
152
- "examples": [
153
- {
154
- "title": "Column subgrid",
155
- "items": [
156
- {
157
- "tag": "div",
158
- "class": "ui-grid ui-grid--3",
159
- "children": [
160
- {
161
- "tag": "div",
162
- "class": "ui-grid--subgrid",
163
- "style": {
164
- "grid-column": "span 3"
165
- },
166
- "children": [
167
- {
168
- "tag": "div",
169
- "text": "Subgrid child 1",
170
- "style": {
171
- "background": "var(--ui-color-bg-muted)",
172
- "padding": "var(--ui-space-2)"
173
- }
174
- },
175
- {
176
- "tag": "div",
177
- "text": "Subgrid child 2",
178
- "style": {
179
- "background": "var(--ui-color-bg-muted)",
180
- "padding": "var(--ui-space-2)"
181
- }
182
- },
183
- {
184
- "tag": "div",
185
- "text": "Subgrid child 3",
186
- "style": {
187
- "background": "var(--ui-color-bg-muted)",
188
- "padding": "var(--ui-space-2)"
189
- }
190
- }
191
- ]
192
- }
193
- ]
194
- }
195
- ],
196
- "code": "<div class=\"ui-grid ui-grid--3\">\n <div class=\"ui-grid--subgrid\" style=\"grid-column: span 3\">\n <div>Subgrid child 1</div>\n <div>Subgrid child 2</div>\n <div>Subgrid child 3</div>\n </div>\n</div>"
197
- },
198
- {
199
- "title": "Row subgrid (aligned cards)",
200
- "items": [
201
- {
202
- "tag": "div",
203
- "class": "ui-grid ui-grid--3",
204
- "style": {
205
- "grid-template-rows": "auto 1fr auto"
206
- },
207
- "children": [
208
- {
209
- "tag": "div",
210
- "class": "ui-grid--subgrid-rows",
211
- "style": {
212
- "grid-row": "span 3",
213
- "border": "1px solid var(--ui-color-border)",
214
- "padding": "var(--ui-space-2)"
215
- },
216
- "children": [
217
- {
218
- "tag": "strong",
219
- "text": "Card A"
220
- },
221
- {
222
- "tag": "p",
223
- "text": "Short content."
224
- },
225
- {
226
- "tag": "span",
227
- "text": "Footer",
228
- "style": {
229
- "color": "var(--ui-color-text-muted)"
230
- }
231
- }
232
- ]
233
- },
234
- {
235
- "tag": "div",
236
- "class": "ui-grid--subgrid-rows",
237
- "style": {
238
- "grid-row": "span 3",
239
- "border": "1px solid var(--ui-color-border)",
240
- "padding": "var(--ui-space-2)"
241
- },
242
- "children": [
243
- {
244
- "tag": "strong",
245
- "text": "Card B"
246
- },
247
- {
248
- "tag": "p",
249
- "text": "Longer content that wraps to multiple lines to demonstrate row alignment."
250
- },
251
- {
252
- "tag": "span",
253
- "text": "Footer",
254
- "style": {
255
- "color": "var(--ui-color-text-muted)"
256
- }
257
- }
258
- ]
259
- },
260
- {
261
- "tag": "div",
262
- "class": "ui-grid--subgrid-rows",
263
- "style": {
264
- "grid-row": "span 3",
265
- "border": "1px solid var(--ui-color-border)",
266
- "padding": "var(--ui-space-2)"
267
- },
268
- "children": [
269
- {
270
- "tag": "strong",
271
- "text": "Card C"
272
- },
273
- {
274
- "tag": "p",
275
- "text": "Medium text."
276
- },
277
- {
278
- "tag": "span",
279
- "text": "Footer",
280
- "style": {
281
- "color": "var(--ui-color-text-muted)"
282
- }
283
- }
284
- ]
285
- }
286
- ]
287
- }
288
- ],
289
- "code": "<div class=\"ui-grid ui-grid--3\" style=\"grid-template-rows: auto 1fr auto\">\n <div class=\"ui-grid--subgrid-rows\" style=\"grid-row: span 3\">\n <strong>Title</strong>\n <p>Content</p>\n <span>Footer</span>\n </div>\n</div>"
290
- },
291
- {
292
- "title": "Both axes subgrid",
293
- "items": [
294
- {
295
- "tag": "div",
296
- "class": "ui-grid ui-grid--3",
297
- "style": {
298
- "grid-template-rows": "auto auto"
299
- },
300
- "children": [
301
- {
302
- "tag": "div",
303
- "class": "ui-grid--subgrid-both",
304
- "style": {
305
- "grid-column": "span 3",
306
- "grid-row": "span 2"
307
- },
308
- "children": [
309
- {
310
- "tag": "div",
311
- "text": "A1",
312
- "style": {
313
- "background": "var(--ui-color-bg-muted)",
314
- "padding": "var(--ui-space-2)"
315
- }
316
- },
317
- {
318
- "tag": "div",
319
- "text": "A2",
320
- "style": {
321
- "background": "var(--ui-color-bg-muted)",
322
- "padding": "var(--ui-space-2)"
323
- }
324
- },
325
- {
326
- "tag": "div",
327
- "text": "A3",
328
- "style": {
329
- "background": "var(--ui-color-bg-muted)",
330
- "padding": "var(--ui-space-2)"
331
- }
332
- },
333
- {
334
- "tag": "div",
335
- "text": "B1",
336
- "style": {
337
- "background": "var(--ui-color-bg-subtle)",
338
- "padding": "var(--ui-space-2)"
339
- }
340
- },
341
- {
342
- "tag": "div",
343
- "text": "B2",
344
- "style": {
345
- "background": "var(--ui-color-bg-subtle)",
346
- "padding": "var(--ui-space-2)"
347
- }
348
- },
349
- {
350
- "tag": "div",
351
- "text": "B3",
352
- "style": {
353
- "background": "var(--ui-color-bg-subtle)",
354
- "padding": "var(--ui-space-2)"
355
- }
356
- }
357
- ]
358
- }
359
- ]
360
- }
361
- ],
362
- "code": "<div class=\"ui-grid ui-grid--3\" style=\"grid-template-rows: auto auto\">\n <div class=\"ui-grid--subgrid-both\" style=\"grid-column: span 3; grid-row: span 2\">\n <div>A1</div><div>A2</div><div>A3</div>\n <div>B1</div><div>B2</div><div>B3</div>\n </div>\n</div>"
363
- }
364
- ]
365
- },
366
- {
367
- "title": "Column Span",
368
- "description": "Span multiple columns with .ui-grid-col-span-{2,3,4,full} utilities.",
369
- "examples": [
370
- {
371
- "items": [
372
- {
373
- "tag": "div",
374
- "class": "ui-grid ui-grid--4",
375
- "children": [
376
- {
377
- "tag": "div",
378
- "text": "Span 2",
379
- "style": {
380
- "grid-column": "span 2",
381
- "background": "var(--ui-color-bg-muted)",
382
- "padding": "var(--ui-space-2)"
383
- }
384
- },
385
- {
386
- "tag": "div",
387
- "text": "1",
388
- "style": {
389
- "background": "var(--ui-color-bg-subtle)",
390
- "padding": "var(--ui-space-2)"
391
- }
392
- },
393
- {
394
- "tag": "div",
395
- "text": "1",
396
- "style": {
397
- "background": "var(--ui-color-bg-subtle)",
398
- "padding": "var(--ui-space-2)"
399
- }
400
- },
401
- {
402
- "tag": "div",
403
- "text": "1",
404
- "style": {
405
- "background": "var(--ui-color-bg-subtle)",
406
- "padding": "var(--ui-space-2)"
407
- }
408
- },
409
- {
410
- "tag": "div",
411
- "text": "Span 3",
412
- "style": {
413
- "grid-column": "span 3",
414
- "background": "var(--ui-color-bg-muted)",
415
- "padding": "var(--ui-space-2)"
416
- }
417
- },
418
- {
419
- "tag": "div",
420
- "text": "Span full",
421
- "style": {
422
- "grid-column": "1 / -1",
423
- "background": "var(--ui-color-bg-muted)",
424
- "padding": "var(--ui-space-2)"
425
- }
426
- }
427
- ]
428
- }
429
- ],
430
- "code": "{% set spans = ['2', '3', '4', 'full'] %}<div class=\"ui-grid ui-grid--4\">\n{% for s in spans %} <div class=\"ui-grid-col-span-{{ s }}\">Span {{ s }}</div>\n{% endfor %}</div>"
431
- }
432
- ]
433
- },
434
- {
435
- "title": "Row Span",
436
- "description": "Span multiple rows with .ui-grid-row-span-{2,3,full} utilities.",
437
- "examples": [
438
- {
439
- "items": [
440
- {
441
- "tag": "div",
442
- "class": "ui-grid ui-grid--3",
443
- "children": [
444
- {
445
- "tag": "div",
446
- "text": "Row span 2",
447
- "style": {
448
- "grid-row": "span 2",
449
- "background": "var(--ui-color-bg-muted)",
450
- "padding": "var(--ui-space-2)"
451
- }
452
- },
453
- {
454
- "tag": "div",
455
- "text": "1",
456
- "style": {
457
- "background": "var(--ui-color-bg-subtle)",
458
- "padding": "var(--ui-space-2)"
459
- }
460
- },
461
- {
462
- "tag": "div",
463
- "text": "2",
464
- "style": {
465
- "background": "var(--ui-color-bg-subtle)",
466
- "padding": "var(--ui-space-2)"
467
- }
468
- },
469
- {
470
- "tag": "div",
471
- "text": "3",
472
- "style": {
473
- "background": "var(--ui-color-bg-subtle)",
474
- "padding": "var(--ui-space-2)"
475
- }
476
- },
477
- {
478
- "tag": "div",
479
- "text": "4",
480
- "style": {
481
- "background": "var(--ui-color-bg-subtle)",
482
- "padding": "var(--ui-space-2)"
483
- }
484
- }
485
- ]
486
- }
487
- ],
488
- "code": "{% set spans = ['2', '3', 'full'] %}<div class=\"ui-grid ui-grid--3\">\n{% for s in spans %} <div class=\"ui-grid-row-span-{{ s }}\">Row span {{ s }}</div>\n{% endfor %}</div>"
489
- }
490
- ]
491
- }
492
- ]
493
- }