@graupl/graupl 1.0.0-alpha.8 → 1.0.0-beta.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 (347) hide show
  1. package/.github/workflows/codeql-analysis.yml +3 -3
  2. package/.husky/commit-msg +0 -1
  3. package/.husky/pre-commit +0 -1
  4. package/.stylelintignore +9 -0
  5. package/CHANGELOG.md +160 -0
  6. package/build.js +7 -0
  7. package/dist/css/base/button.css +2 -0
  8. package/dist/css/base/button.css.map +1 -0
  9. package/dist/css/base/form.css +2 -0
  10. package/dist/css/base/form.css.map +1 -0
  11. package/dist/css/base/link.css +2 -0
  12. package/dist/css/base/link.css.map +1 -0
  13. package/dist/css/base/table.css +2 -0
  14. package/dist/css/base/table.css.map +1 -0
  15. package/dist/css/base.css +2 -0
  16. package/dist/css/base.css.map +1 -0
  17. package/dist/css/component/accordion.css +2 -0
  18. package/dist/css/component/accordion.css.map +1 -0
  19. package/dist/css/component/alert.css +2 -0
  20. package/dist/css/component/alert.css.map +1 -0
  21. package/dist/css/component/card.css +2 -0
  22. package/dist/css/component/card.css.map +1 -0
  23. package/dist/css/component/carousel.css +2 -0
  24. package/dist/css/component/carousel.css.map +1 -0
  25. package/dist/{component → css/component}/input-group.css +1 -1
  26. package/dist/css/component/input-group.css.map +1 -0
  27. package/dist/css/component/menu.css +2 -0
  28. package/dist/css/component/menu.css.map +1 -0
  29. package/dist/css/component/navigation.css +2 -0
  30. package/dist/css/component/navigation.css.map +1 -0
  31. package/dist/css/component.css +2 -0
  32. package/dist/css/component.css.map +1 -0
  33. package/dist/css/graupl.css +2 -0
  34. package/dist/css/graupl.css.map +1 -0
  35. package/dist/css/init.css +2 -0
  36. package/dist/css/init.css.map +1 -0
  37. package/dist/css/layout/columns.css +2 -0
  38. package/dist/css/layout/columns.css.map +1 -0
  39. package/dist/css/layout/container.css.map +1 -0
  40. package/dist/css/layout/flex-columns.css +2 -0
  41. package/dist/css/layout/flex-columns.css.map +1 -0
  42. package/dist/css/layout.css +2 -0
  43. package/dist/css/layout.css.map +1 -0
  44. package/dist/css/normalize.css +2 -0
  45. package/dist/css/normalize.css.map +1 -0
  46. package/dist/css/state/focus.css +2 -0
  47. package/dist/css/state/focus.css.map +1 -0
  48. package/dist/css/state.css +2 -0
  49. package/dist/css/state.css.map +1 -0
  50. package/dist/css/theme/color.css +2 -0
  51. package/dist/css/theme/color.css.map +1 -0
  52. package/dist/css/theme/typography.css +2 -0
  53. package/dist/css/theme/typography.css.map +1 -0
  54. package/dist/css/theme.css +2 -0
  55. package/dist/css/theme.css.map +1 -0
  56. package/dist/css/utilities/alignment.css +2 -0
  57. package/dist/css/utilities/alignment.css.map +1 -0
  58. package/dist/{utilities/colors.css → css/utilities/color.css} +2 -2
  59. package/dist/css/utilities/color.css.map +1 -0
  60. package/dist/css/utilities/display.css +2 -0
  61. package/dist/css/utilities/display.css.map +1 -0
  62. package/dist/css/utilities/flex.css +2 -0
  63. package/dist/css/utilities/flex.css.map +1 -0
  64. package/dist/css/utilities/height.css +2 -0
  65. package/dist/css/utilities/height.css.map +1 -0
  66. package/dist/css/utilities/inset.css +2 -0
  67. package/dist/css/utilities/inset.css.map +1 -0
  68. package/dist/css/utilities/justification.css +2 -0
  69. package/dist/css/utilities/justification.css.map +1 -0
  70. package/dist/css/utilities/list.css +2 -0
  71. package/dist/css/utilities/list.css.map +1 -0
  72. package/dist/css/utilities/order.css +2 -0
  73. package/dist/css/utilities/order.css.map +1 -0
  74. package/dist/css/utilities/postion.css +2 -0
  75. package/dist/css/utilities/postion.css.map +1 -0
  76. package/dist/css/utilities/ratio.css +2 -0
  77. package/dist/css/utilities/ratio.css.map +1 -0
  78. package/dist/css/utilities/spacing.css +2 -0
  79. package/dist/css/utilities/spacing.css.map +1 -0
  80. package/dist/css/utilities/typography.css +2 -0
  81. package/dist/css/utilities/typography.css.map +1 -0
  82. package/dist/css/utilities/visibility.css +2 -0
  83. package/dist/css/utilities/visibility.css.map +1 -0
  84. package/dist/css/utilities/width.css +2 -0
  85. package/dist/css/utilities/width.css.map +1 -0
  86. package/dist/css/utilities.css +2 -0
  87. package/dist/css/utilities.css.map +1 -0
  88. package/dist/js/component/accordion.cjs.js +3 -0
  89. package/dist/js/component/accordion.esm.js +1289 -0
  90. package/dist/js/component/accordion.iife.js +3 -0
  91. package/dist/js/component/alert.cjs.js +3 -0
  92. package/dist/js/component/alert.esm.js +529 -0
  93. package/dist/js/component/alert.iife.js +3 -0
  94. package/dist/js/component/carousel.cjs.js +3 -0
  95. package/dist/js/component/carousel.esm.js +1110 -0
  96. package/dist/js/component/carousel.iife.js +3 -0
  97. package/dist/js/graupl.cjs.js +5 -0
  98. package/dist/js/graupl.esm.js +1462 -0
  99. package/dist/js/graupl.iife.js +5 -0
  100. package/docs/.vitepress/config.js +39 -12
  101. package/docs/components/alert.md +130 -0
  102. package/docs/components/button.md +84 -0
  103. package/docs/components/card.md +369 -0
  104. package/docs/components/index.md +1 -0
  105. package/docs/components/inputgroup.md +159 -0
  106. package/docs/components/menu.md +326 -0
  107. package/docs/components/navigation.md +158 -0
  108. package/docs/content.md +237 -0
  109. package/docs/defaults.md +121 -0
  110. package/docs/forms.md +79 -0
  111. package/docs/functions.md +9 -0
  112. package/docs/getting-started.md +1 -0
  113. package/docs/index.md +1 -7
  114. package/docs/introduction.md +22 -2
  115. package/docs/layout.md +200 -0
  116. package/docs/mixins.md +47 -0
  117. package/docs/state.md +67 -0
  118. package/docs/theme.md +258 -0
  119. package/docs/utilities.md +357 -0
  120. package/eslint.config.js +1 -0
  121. package/index.html +816 -327
  122. package/index.js +12 -0
  123. package/package.json +32 -41
  124. package/scss/base/button.scss +3 -0
  125. package/scss/base/form.scss +1 -1
  126. package/scss/base/link.scss +1 -1
  127. package/scss/base/table.scss +1 -1
  128. package/scss/base.scss +1 -1
  129. package/scss/component/accordion.scss +3 -0
  130. package/scss/component/alert.scss +3 -0
  131. package/scss/component/card.scss +3 -0
  132. package/scss/component/carousel.scss +3 -0
  133. package/scss/component/input-group.scss +1 -1
  134. package/scss/component/menu.scss +3 -0
  135. package/scss/component/navigation.scss +3 -0
  136. package/scss/component.scss +1 -1
  137. package/scss/graupl.scss +1 -3
  138. package/scss/init.scss +3 -0
  139. package/scss/layout/columns.scss +1 -1
  140. package/scss/layout/container.scss +1 -1
  141. package/scss/layout/flex-columns.scss +3 -0
  142. package/scss/layout.scss +1 -1
  143. package/scss/normalize.scss +3 -0
  144. package/scss/state/focus.scss +1 -1
  145. package/scss/state.scss +1 -1
  146. package/scss/theme/color.scss +1 -1
  147. package/scss/theme/typography.scss +1 -1
  148. package/scss/theme.scss +1 -1
  149. package/scss/utilities/alignment.scss +3 -0
  150. package/scss/utilities/color.scss +3 -0
  151. package/scss/utilities/display.scss +3 -0
  152. package/scss/utilities/flex.scss +3 -0
  153. package/scss/utilities/height.scss +3 -0
  154. package/scss/utilities/inset.scss +3 -0
  155. package/scss/utilities/justification.scss +3 -0
  156. package/scss/utilities/list.scss +3 -0
  157. package/scss/utilities/order.scss +3 -0
  158. package/scss/utilities/postion.scss +3 -0
  159. package/scss/utilities/ratio.scss +3 -0
  160. package/scss/utilities/spacing.scss +1 -1
  161. package/scss/utilities/typography.scss +1 -1
  162. package/scss/utilities/visibility.scss +3 -0
  163. package/scss/utilities/width.scss +3 -0
  164. package/scss/utilities.scss +1 -1
  165. package/src/js/accordion/Accordion.js +1163 -0
  166. package/src/js/accordion/AccordionItem.js +496 -0
  167. package/src/js/accordion/index.js +10 -0
  168. package/src/js/alert/Alert.js +581 -0
  169. package/src/js/alert/index.js +11 -0
  170. package/src/js/carousel/Carousel.js +1427 -0
  171. package/src/js/carousel/index.js +10 -0
  172. package/src/js/domHelpers.js +37 -0
  173. package/src/js/eventHandlers.js +39 -0
  174. package/src/js/navigation/index.js +36 -0
  175. package/src/js/storage.js +106 -0
  176. package/src/js/validate.js +225 -0
  177. package/src/scss/_defaults.scss +74 -5
  178. package/src/scss/_index.scss +4 -3
  179. package/src/scss/_init.scss +2 -2
  180. package/src/scss/_normalize.scss +197 -0
  181. package/src/scss/_variables.scss +7 -7
  182. package/src/scss/base/_index.scss +2 -1
  183. package/src/scss/base/button/_defaults.scss +60 -0
  184. package/src/scss/base/button/_index.scss +107 -0
  185. package/src/scss/base/button/_mixins.scss +166 -0
  186. package/src/scss/{component → base}/button/_variables.scss +64 -19
  187. package/src/scss/base/form/_defaults.scss +14 -4
  188. package/src/scss/base/form/_index.scss +23 -20
  189. package/src/scss/base/form/_variables.scss +14 -2
  190. package/src/scss/base/link/_defaults.scss +48 -5
  191. package/src/scss/base/link/_index.scss +111 -10
  192. package/src/scss/base/link/_variables.scss +234 -4
  193. package/src/scss/base/table/_defaults.scss +49 -4
  194. package/src/scss/base/table/_index.scss +102 -8
  195. package/src/scss/base/table/_variables.scss +75 -5
  196. package/src/scss/component/_index.scss +7 -3
  197. package/src/scss/component/accordion/_defaults.scss +40 -0
  198. package/src/scss/component/accordion/_index.scss +180 -0
  199. package/src/scss/component/accordion/_variables.scss +316 -0
  200. package/src/scss/component/alert/_defaults.scss +49 -0
  201. package/src/scss/component/alert/_index.scss +118 -0
  202. package/src/scss/component/alert/_variables.scss +173 -0
  203. package/src/scss/component/card/_defaults.scss +32 -0
  204. package/src/scss/component/card/_index.scss +178 -0
  205. package/src/scss/component/card/_variables.scss +186 -0
  206. package/src/scss/component/carousel/_defaults.scss +43 -0
  207. package/src/scss/component/carousel/_index.scss +188 -0
  208. package/src/scss/component/carousel/_variables.scss +104 -0
  209. package/src/scss/component/input-group/_defaults.scss +11 -4
  210. package/src/scss/component/input-group/_index.scss +13 -11
  211. package/src/scss/component/input-group/_variables.scss +4 -1
  212. package/src/scss/component/menu/_defaults.scss +66 -0
  213. package/src/scss/component/menu/_index.scss +305 -0
  214. package/src/scss/component/menu/_variables.scss +500 -0
  215. package/src/scss/component/navigation/_defaults.scss +29 -0
  216. package/src/scss/component/navigation/_index.scss +189 -0
  217. package/src/scss/component/navigation/_variables.scss +237 -0
  218. package/src/scss/functions/_important.scss +2 -0
  219. package/src/scss/functions/_screen.scss +30 -0
  220. package/src/scss/functions/_theme.scss +28 -7
  221. package/src/scss/layout/_index.scss +2 -1
  222. package/src/scss/layout/columns/_defaults.scss +12 -4
  223. package/src/scss/layout/columns/_index.scss +29 -7
  224. package/src/scss/layout/columns/_variables.scss +6 -2
  225. package/src/scss/layout/container/_defaults.scss +13 -4
  226. package/src/scss/layout/container/_index.scss +12 -7
  227. package/src/scss/layout/container/_variables.scss +4 -1
  228. package/src/scss/layout/flex-columns/_defaults.scss +18 -0
  229. package/src/scss/layout/flex-columns/_index.scss +80 -0
  230. package/src/scss/layout/flex-columns/_variables.scss +26 -0
  231. package/src/scss/mixins/_animation.scss +15 -0
  232. package/src/scss/mixins/_layer.scss +3 -5
  233. package/src/scss/mixins/_screen.scss +56 -0
  234. package/src/scss/mixins/_utility.scss +30 -0
  235. package/src/scss/mixins/_visually-hidden.scss +20 -0
  236. package/src/scss/state/_index.scss +1 -1
  237. package/src/scss/state/focus/_defaults.scss +6 -4
  238. package/src/scss/state/focus/_index.scss +7 -7
  239. package/src/scss/state/focus/_mixins.scss +15 -0
  240. package/src/scss/state/focus/_variables.scss +6 -2
  241. package/src/scss/theme/_index.scss +1 -1
  242. package/src/scss/theme/color/_defaults.scss +101 -19
  243. package/src/scss/theme/color/_index.scss +17 -17
  244. package/src/scss/theme/color/_variables.scss +72 -64
  245. package/src/scss/theme/typography/_defaults.scss +7 -5
  246. package/src/scss/theme/typography/_index.scss +1 -1
  247. package/src/scss/theme/typography/_variables.scss +11 -7
  248. package/src/scss/utilities/_index.scss +14 -2
  249. package/src/scss/utilities/alignment/_defaults.scss +62 -0
  250. package/src/scss/utilities/alignment/_index.scss +75 -0
  251. package/src/scss/utilities/alignment/_variables.scss +6 -0
  252. package/src/scss/utilities/color/_defaults.scss +35 -0
  253. package/src/scss/utilities/color/_index.scss +91 -0
  254. package/src/scss/utilities/color/_variables.scss +6 -0
  255. package/src/scss/utilities/display/_defaults.scss +32 -0
  256. package/src/scss/utilities/display/_index.scss +61 -0
  257. package/src/scss/utilities/display/_variables.scss +6 -0
  258. package/src/scss/utilities/flex/_defaults.scss +63 -0
  259. package/src/scss/utilities/flex/_index.scss +71 -0
  260. package/src/scss/utilities/flex/_variables.scss +6 -0
  261. package/src/scss/utilities/height/_defaults.scss +41 -0
  262. package/src/scss/utilities/height/_index.scss +98 -0
  263. package/src/scss/utilities/height/_variables.scss +6 -0
  264. package/src/scss/utilities/inset/_defaults.scss +41 -0
  265. package/src/scss/utilities/inset/_index.scss +37 -0
  266. package/src/scss/utilities/inset/_variables.scss +6 -0
  267. package/src/scss/utilities/justification/_defaults.scss +59 -0
  268. package/src/scss/utilities/justification/_index.scss +75 -0
  269. package/src/scss/utilities/justification/_variables.scss +6 -0
  270. package/src/scss/utilities/list/_defaults.scss +39 -0
  271. package/src/scss/utilities/list/_index.scss +56 -0
  272. package/src/scss/utilities/list/_variables.scss +6 -0
  273. package/src/scss/utilities/order/_defaults.scss +22 -0
  274. package/src/scss/utilities/order/_index.scss +63 -0
  275. package/src/scss/utilities/order/_variables.scss +6 -0
  276. package/src/scss/utilities/position/_defaults.scss +26 -0
  277. package/src/scss/utilities/position/_index.scss +37 -0
  278. package/src/scss/utilities/position/_variables.scss +6 -0
  279. package/src/scss/utilities/ratio/_defaults.scss +28 -0
  280. package/src/scss/utilities/ratio/_index.scss +52 -0
  281. package/src/scss/utilities/ratio/_variables.scss +9 -0
  282. package/src/scss/utilities/spacing/_defaults.scss +9 -4
  283. package/src/scss/utilities/spacing/_index.scss +134 -29
  284. package/src/scss/utilities/spacing/_variables.scss +5 -2
  285. package/src/scss/utilities/typography/_defaults.scss +29 -4
  286. package/src/scss/utilities/typography/_index.scss +155 -23
  287. package/src/scss/utilities/typography/_variables.scss +5 -2
  288. package/src/scss/utilities/visibility/_defaults.scss +25 -0
  289. package/src/scss/utilities/visibility/_index.scss +36 -0
  290. package/src/scss/utilities/visibility/_variables.scss +6 -0
  291. package/src/scss/utilities/width/_defaults.scss +41 -0
  292. package/src/scss/utilities/width/_index.scss +98 -0
  293. package/src/scss/utilities/width/_variables.scss +6 -0
  294. package/stylelint.config.js +5 -0
  295. package/vite.config.js +57 -0
  296. package/dist/base/form.css +0 -2
  297. package/dist/base/form.css.map +0 -1
  298. package/dist/base/link.css +0 -2
  299. package/dist/base/link.css.map +0 -1
  300. package/dist/base/table.css +0 -2
  301. package/dist/base/table.css.map +0 -1
  302. package/dist/base.css +0 -2
  303. package/dist/base.css.map +0 -1
  304. package/dist/component/button.css +0 -2
  305. package/dist/component/button.css.map +0 -1
  306. package/dist/component/input-group.css.map +0 -1
  307. package/dist/component/table.css +0 -2
  308. package/dist/component/table.css.map +0 -1
  309. package/dist/component.css +0 -2
  310. package/dist/component.css.map +0 -1
  311. package/dist/graupl.css +0 -2
  312. package/dist/graupl.css.map +0 -1
  313. package/dist/layout/columns.css +0 -2
  314. package/dist/layout/columns.css.map +0 -1
  315. package/dist/layout/container.css.map +0 -1
  316. package/dist/layout.css +0 -2
  317. package/dist/layout.css.map +0 -1
  318. package/dist/state/focus.css +0 -2
  319. package/dist/state/focus.css.map +0 -1
  320. package/dist/state.css +0 -2
  321. package/dist/state.css.map +0 -1
  322. package/dist/theme/color.css +0 -2
  323. package/dist/theme/color.css.map +0 -1
  324. package/dist/theme/typography.css +0 -2
  325. package/dist/theme/typography.css.map +0 -1
  326. package/dist/theme.css +0 -2
  327. package/dist/theme.css.map +0 -1
  328. package/dist/utilities/colors.css.map +0 -1
  329. package/dist/utilities/spacing.css +0 -2
  330. package/dist/utilities/spacing.css.map +0 -1
  331. package/dist/utilities/typography.css +0 -2
  332. package/dist/utilities/typography.css.map +0 -1
  333. package/dist/utilities.css +0 -2
  334. package/dist/utilities.css.map +0 -1
  335. package/scss/component/button.scss +0 -3
  336. package/scss/component/table.scss +0 -3
  337. package/scss/utilities/colors.scss +0 -3
  338. package/src/scss/component/button/_defaults.scss +0 -39
  339. package/src/scss/component/button/_index.scss +0 -98
  340. package/src/scss/component/table/_defaults.scss +0 -30
  341. package/src/scss/component/table/_index.scss +0 -77
  342. package/src/scss/component/table/_variables.scss +0 -64
  343. package/src/scss/mixins/_media-queries.scss +0 -26
  344. package/src/scss/utilities/colors/_defaults.scss +0 -5
  345. package/src/scss/utilities/colors/_index.scss +0 -22
  346. package/src/scss/utilities/colors/_variables.scss +0 -3
  347. /package/dist/{layout → css/layout}/container.css +0 -0
@@ -0,0 +1,189 @@
1
+ // @graupl/graupl navigation component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../menu/defaults" as menu-defaults;
7
+ @use "../menu/variables" as menu-variables;
8
+ @use "../../mixins/layer" as *;
9
+ @use "../../mixins/screen";
10
+
11
+ @include layer(component) {
12
+ // Navigation.
13
+ #{defaults.$navigation-selector} {
14
+ display: grid;
15
+ grid-template-areas:
16
+ "branding - toggle"
17
+ "menu menu menu";
18
+ grid-template-columns: auto 1fr auto;
19
+ isolation: isolate;
20
+
21
+ #{menu-defaults.$menu-selector} {
22
+ grid-area: menu;
23
+
24
+ &#{menu-defaults.$menu-show-selector} {
25
+ --#{root-defaults.$prefix}-menu-display: #{menu-variables.$menu-show-display};
26
+ }
27
+
28
+ &#{menu-defaults.$menu-hide-selector} {
29
+ --#{root-defaults.$prefix}-menu-display: #{menu-variables.$menu-hide-display};
30
+ }
31
+ }
32
+ }
33
+
34
+ // Navigation toggle.
35
+ #{defaults.$navigation-toggle-selector} {
36
+ display: flex;
37
+ grid-area: toggle;
38
+ align-items: center;
39
+ justify-content: center;
40
+ min-width: $navigation-toggle-min-width;
41
+ min-height: $navigation-toggle-min-height;
42
+ padding: $navigation-toggle-padding;
43
+ border: $navigation-toggle-border;
44
+ border-radius: $navigation-toggle-border-radius;
45
+
46
+ &::before {
47
+ content: $navigation-toggle-content;
48
+ display: block;
49
+ }
50
+ }
51
+
52
+ // Navigation branding.
53
+ #{defaults.$navigation-branding-selector} {
54
+ display: flex;
55
+ grid-area: branding;
56
+ align-items: center;
57
+ justify-content: flex-start;
58
+ padding: $navigation-branding-padding;
59
+ font-size: $navigation-branding-font-size;
60
+ font-weight: $navigation-branding-font-weight;
61
+ text-decoration: $navigation-branding-text-decoration;
62
+ text-decoration-style: $navigation-branding-text-decoration-style;
63
+ text-decoration-thickness: $navigation-branding-text-decoration-thickness;
64
+
65
+ &:visited {
66
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-visited-text-decoration};
67
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-visited-text-decoration-thickness};
68
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-visited-text-decoration-style};
69
+ }
70
+
71
+ &:focus-visible {
72
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-focus-text-decoration};
73
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-focus-text-decoration-thickness};
74
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-focus-text-decoration-style};
75
+ }
76
+
77
+ &:hover {
78
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-hover-text-decoration};
79
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-hover-text-decoration-thickness};
80
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-hover-text-decoration-style};
81
+ }
82
+
83
+ &:active {
84
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-active-text-decoration};
85
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-active-text-decoration-thickness};
86
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-active-text-decoration-style};
87
+ }
88
+
89
+ &:disabled,
90
+ &[disabled] {
91
+ &,
92
+ &:visited,
93
+ &:focus-visible,
94
+ &:hover,
95
+ &:active {
96
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-disabled-text-decoration};
97
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-disabled-text-decoration-thickness};
98
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-disabled-text-decoration-style};
99
+ }
100
+ }
101
+ }
102
+
103
+ @include screen.trigger(navigation-collapse) {
104
+ // Navigation.
105
+ #{defaults.$navigation-selector} {
106
+ --#{root-defaults.$prefix}-menu-flex-direction: column;
107
+ --#{root-defaults.$prefix}-submenu-position: relative;
108
+ --#{root-defaults.$prefix}-menu-item-min-width: 100%;
109
+ --#{root-defaults.$prefix}-submenu-inset: auto;
110
+ }
111
+ }
112
+
113
+ @include screen.trigger(navigation-expand) {
114
+ // Navigation.
115
+ #{defaults.$navigation-selector} {
116
+ --#{root-defaults.$prefix}-menu-hide-display: #{menu-variables.$menu-show-display};
117
+
118
+ grid-template-areas: "branding - menu";
119
+ }
120
+
121
+ // Navigation toggle.
122
+ #{defaults.$navigation-toggle-selector} {
123
+ display: none;
124
+ }
125
+ }
126
+ }
127
+
128
+ @include layer(theme) {
129
+ // Navigation.
130
+ #{defaults.$navigation-selector} {
131
+ --#{root-defaults.$prefix}-menu-background: #{$navigation-background};
132
+ --#{root-defaults.$prefix}-menu-color: #{$navigation-color};
133
+ --#{root-defaults.$prefix}-submenu-background: #{$navigation-background};
134
+ --#{root-defaults.$prefix}-submenu-color: #{$navigation-color};
135
+
136
+ background: $navigation-background;
137
+ color: $navigation-color;
138
+ }
139
+
140
+ // Navigation toggle.
141
+ #{defaults.$navigation-toggle-selector} {
142
+ border-color: $navigation-toggle-border-color;
143
+ background: $navigation-toggle-background;
144
+ color: $navigation-toggle-color;
145
+
146
+ &:hover {
147
+ --#{root-defaults.$prefix}-navigation-toggle-background: #{$navigation-toggle-hover-background};
148
+ --#{root-defaults.$prefix}-navigation-toggle-color: #{$navigation-toggle-hover-color};
149
+ }
150
+ }
151
+
152
+ // Navigation branding.
153
+ #{defaults.$navigation-branding-selector} {
154
+ color: $navigation-branding-color;
155
+ text-decoration-color: $navigation-branding-text-decoration-color;
156
+
157
+ &:visited {
158
+ --#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-visited-color};
159
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-visited-text-decoration-color};
160
+ }
161
+
162
+ &:focus-visible {
163
+ --#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-focus-color};
164
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-focus-text-decoration-color};
165
+ }
166
+
167
+ &:hover {
168
+ --#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-hover-color};
169
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-hover-text-decoration-color};
170
+ }
171
+
172
+ &:active {
173
+ --#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-active-color};
174
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-active-text-decoration-color};
175
+ }
176
+
177
+ &:disabled,
178
+ &[disabled] {
179
+ &,
180
+ &:visited,
181
+ &:focus-visible,
182
+ &:hover,
183
+ &:active {
184
+ --#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-disabled-color};
185
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-disabled-text-decoration-color};
186
+ }
187
+ }
188
+ }
189
+ }
@@ -0,0 +1,237 @@
1
+ // @graupl/graupl navigation component variables.
2
+ //
3
+ // These values are to be used to directly style components and provide a
4
+ // cleaner way to reference custom properties.
5
+
6
+ @use "defaults";
7
+ @use "../../defaults" as root-defaults;
8
+ @use "../../variables" as root-variables;
9
+ @use "../../theme/color/variables" as color;
10
+ @use "../../theme/typography/variables" as typography;
11
+ @use "sass:map";
12
+
13
+ // Navigation colors.
14
+ $navigation-background: var(
15
+ --#{root-defaults.$prefix}-navigation-background,
16
+ #{color.$root-background}
17
+ );
18
+ $navigation-color: var(
19
+ --#{root-defaults.$prefix}-navigation-color,
20
+ #{color.$root-color}
21
+ );
22
+
23
+ // Navigation toggle size.
24
+ $navigation-toggle-min-width: var(
25
+ --#{root-defaults.$prefix}-navigation-toggle-min-width,
26
+ #{root-defaults.$interactive-min-width}
27
+ );
28
+ $navigation-toggle-min-height: var(
29
+ --#{root-defaults.$prefix}-navigation-toggle-min-height,
30
+ #{root-defaults.$interactive-min-height}
31
+ );
32
+
33
+ // Navigation toggle spacing.
34
+ $navigation-toggle-padding-x: var(
35
+ --#{root-defaults.$prefix}-navigation-toggle-padding-x,
36
+ #{map.get(root-variables.$spacers, 5)}
37
+ );
38
+ $navigation-toggle-padding-y: var(
39
+ --#{root-defaults.$prefix}-navigation-toggle-padding-y,
40
+ #{map.get(root-variables.$spacers, 3)}
41
+ );
42
+ $navigation-toggle-padding: var(
43
+ --#{root-defaults.$prefix}-navigation-toggle-padding,
44
+ #{$navigation-toggle-padding-y} #{$navigation-toggle-padding-x}
45
+ );
46
+
47
+ // Navigation toggle colors.
48
+ $navigation-toggle-background: var(
49
+ --#{root-defaults.$prefix}-navigation-toggle-background,
50
+ #{$navigation-background}
51
+ );
52
+ $navigation-toggle-color: var(
53
+ --#{root-defaults.$prefix}-navigation-toggle-color,
54
+ #{$navigation-color}
55
+ );
56
+ $navigation-toggle-hover-background: var(
57
+ --#{root-defaults.$prefix}-navigation-toggle-hover-background,
58
+ #{$navigation-color}
59
+ );
60
+ $navigation-toggle-hover-color: var(
61
+ --#{root-defaults.$prefix}-navigation-toggle-hover-color,
62
+ #{$navigation-background}
63
+ );
64
+
65
+ // Navigation toggle border properties.
66
+ $navigation-toggle-border-width: var(
67
+ --#{root-defaults.$prefix}-navigation-toggle-border-width,
68
+ #{root-variables.$border-width}
69
+ );
70
+ $navigation-toggle-border-style: var(
71
+ --#{root-defaults.$prefix}-navigation-toggle-border-style,
72
+ #{root-variables.$border-style}
73
+ );
74
+ $navigation-toggle-border: var(
75
+ --#{root-defaults.$prefix}-navigation-toggle-border,
76
+ #{$navigation-toggle-border-width} #{$navigation-toggle-border-style}
77
+ );
78
+ $navigation-toggle-border-color: var(
79
+ --#{root-defaults.$prefix}-navigation-toggle-border-color,
80
+ #{$navigation-toggle-color}
81
+ );
82
+ $navigation-toggle-border-radius: var(
83
+ --#{root-defaults.$prefix}-navigation-toggle-border-radius,
84
+ #{root-variables.$border-radius}
85
+ );
86
+
87
+ // Navigation branding properties.
88
+ $navigation-branding-font-size: var(
89
+ --#{root-defaults.$prefix}-navigation-branding-font-size,
90
+ #{map.get(typography.$font-sizes, "lg")}
91
+ );
92
+ $navigation-branding-font-weight: var(
93
+ --#{root-defaults.$prefix}-navigation-branding-font-weight,
94
+ #{typography.$font-weight-bold}
95
+ );
96
+ $navigation-branding-padding-x: var(
97
+ --#{root-defaults.$prefix}-navigation-branding-padding-x,
98
+ #{map.get(root-variables.$spacers, 3)}
99
+ );
100
+ $navigation-branding-padding-y: var(
101
+ --#{root-defaults.$prefix}-navigation-branding-padding-y,
102
+ #{map.get(root-variables.$spacers, 2)}
103
+ );
104
+ $navigation-branding-padding: var(
105
+ --#{root-defaults.$prefix}-navigation-branding-padding,
106
+ #{$navigation-branding-padding-y} #{$navigation-branding-padding-x}
107
+ );
108
+
109
+ // Navigation branding colors.
110
+ $navigation-branding-color: var(
111
+ --#{root-defaults.$prefix}-navigation-branding-color,
112
+ #{$navigation-color}
113
+ );
114
+ $navigation-branding-visited-color: var(
115
+ --#{root-defaults.$prefix}-navigation-branding-visited-color,
116
+ #{$navigation-color}
117
+ );
118
+ $navigation-branding-focus-color: var(
119
+ --#{root-defaults.$prefix}-navigation-branding-focus-color,
120
+ #{$navigation-color}
121
+ );
122
+ $navigation-branding-hover-color: var(
123
+ --#{root-defaults.$prefix}-navigation-branding-hover-color,
124
+ #{$navigation-color}
125
+ );
126
+ $navigation-branding-active-color: var(
127
+ --#{root-defaults.$prefix}-navigation-branding-active-color,
128
+ #{$navigation-color}
129
+ );
130
+ $navigation-branding-disabled-color: var(
131
+ --#{root-defaults.$prefix}-navigation-branding-disabled-color,
132
+ #{$navigation-color}
133
+ );
134
+
135
+ // Navigation branding text decoration properties.
136
+ $navigation-branding-text-decoration: var(
137
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration,
138
+ #{defaults.$navigation-branding-text-decoration}
139
+ );
140
+ $navigation-branding-visited-text-decoration: var(
141
+ --#{root-defaults.$prefix}-navigation-branding-visited-text-decoration,
142
+ #{defaults.$navigation-branding-visited-text-decoration}
143
+ );
144
+ $navigation-branding-focus-text-decoration: var(
145
+ --#{root-defaults.$prefix}-navigation-branding-focus-text-decoration,
146
+ #{defaults.$navigation-branding-focus-text-decoration}
147
+ );
148
+ $navigation-branding-hover-text-decoration: var(
149
+ --#{root-defaults.$prefix}-navigation-branding-hover-text-decoration,
150
+ #{defaults.$navigation-branding-hover-text-decoration}
151
+ );
152
+ $navigation-branding-active-text-decoration: var(
153
+ --#{root-defaults.$prefix}-navigation-branding-active-text-decoration,
154
+ #{defaults.$navigation-branding-active-text-decoration}
155
+ );
156
+ $navigation-branding-disabled-text-decoration: var(
157
+ --#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration,
158
+ #{defaults.$navigation-branding-disabled-text-decoration}
159
+ );
160
+ $navigation-branding-text-decoration-style: var(
161
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-style,
162
+ #{defaults.$navigation-branding-text-decoration-style}
163
+ );
164
+ $navigation-branding-visited-text-decoration-style: var(
165
+ --#{root-defaults.$prefix}-navigation-branding-visited-text-decoration-style,
166
+ #{defaults.$navigation-branding-visited-text-decoration-style}
167
+ );
168
+ $navigation-branding-focus-text-decoration-style: var(
169
+ --#{root-defaults.$prefix}-navigation-branding-focus-text-decoration-style,
170
+ #{defaults.$navigation-branding-focus-text-decoration-style}
171
+ );
172
+ $navigation-branding-hover-text-decoration-style: var(
173
+ --#{root-defaults.$prefix}-navigation-branding-hover-text-decoration-style,
174
+ #{defaults.$navigation-branding-hover-text-decoration-style}
175
+ );
176
+ $navigation-branding-active-text-decoration-style: var(
177
+ --#{root-defaults.$prefix}-navigation-branding-active-text-decoration-style,
178
+ #{defaults.$navigation-branding-active-text-decoration-style}
179
+ );
180
+ $navigation-branding-disabled-text-decoration-style: var(
181
+ --#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration-style,
182
+ #{defaults.$navigation-branding-disabled-text-decoration-style}
183
+ );
184
+ $navigation-branding-text-decoration-thickness: var(
185
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness,
186
+ #{root-variables.$border-width}
187
+ );
188
+ $navigation-branding-visited-text-decoration-thickness: var(
189
+ --#{root-defaults.$prefix}-navigation-branding-visited-text-decoration-thickness,
190
+ #{root-variables.$border-width}
191
+ );
192
+ $navigation-branding-focus-text-decoration-thickness: var(
193
+ --#{root-defaults.$prefix}-navigation-branding-focus-text-decoration-thickness,
194
+ #{root-variables.$border-width}
195
+ );
196
+ $navigation-branding-hover-text-decoration-thickness: var(
197
+ --#{root-defaults.$prefix}-navigation-branding-hover-text-decoration-thickness,
198
+ #{root-variables.$border-width}
199
+ );
200
+ $navigation-branding-active-text-decoration-thickness: var(
201
+ --#{root-defaults.$prefix}-navigation-branding-active-text-decoration-thickness,
202
+ #{root-variables.$border-width}
203
+ );
204
+ $navigation-branding-disabled-text-decoration-thickness: var(
205
+ --#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration-thickness,
206
+ #{root-variables.$border-width}
207
+ );
208
+ $navigation-branding-text-decoration-color: var(
209
+ --#{root-defaults.$prefix}-navigation-branding-text-decoration-color,
210
+ #{$navigation-branding-color}
211
+ );
212
+ $navigation-branding-visited-text-decoration-color: var(
213
+ --#{root-defaults.$prefix}-navigation-branding-visited-text-decoration-color,
214
+ #{$navigation-branding-visited-color}
215
+ );
216
+ $navigation-branding-focus-text-decoration-color: var(
217
+ --#{root-defaults.$prefix}-navigation-branding-focus-text-decoration-color,
218
+ #{$navigation-branding-focus-color}
219
+ );
220
+ $navigation-branding-hover-text-decoration-color: var(
221
+ --#{root-defaults.$prefix}-navigation-branding-hover-text-decoration-color,
222
+ #{$navigation-branding-hover-color}
223
+ );
224
+ $navigation-branding-active-text-decoration-color: var(
225
+ --#{root-defaults.$prefix}-navigation-branding-active-text-decoration-color,
226
+ #{$navigation-branding-active-color}
227
+ );
228
+ $navigation-branding-disabled-text-decoration-color: var(
229
+ --#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration-color,
230
+ #{$navigation-branding-disabled-color}
231
+ );
232
+
233
+ // Navigation toggle properties.
234
+ $navigation-toggle-content: var(
235
+ --#{root-defaults.$prefix}-navigation-toggle-content,
236
+ #{defaults.$navigation-toggle-content}
237
+ );
@@ -1,3 +1,5 @@
1
+ // @graupl/graupl important functions.
2
+ //
1
3
  // A function to determine if the !important flag should be added to a property.
2
4
 
3
5
  @use "../defaults";
@@ -0,0 +1,30 @@
1
+ // @graupl/graupl screen functions.
2
+ //
3
+ // A series of functions to determine ranges of screen sizes.
4
+
5
+ @use "../defaults" as root-defaults;
6
+ @use "sass:map";
7
+ @use "sass:list";
8
+
9
+ @function min($size) {
10
+ $screen-size: map.get(root-defaults.$screen-sizes, $size);
11
+
12
+ @return $screen-size;
13
+ }
14
+
15
+ @function max($size) {
16
+ $keys: map.keys(root-defaults.$screen-sizes);
17
+ $index: list.index($keys, "#{$size}");
18
+ $key: list.nth($keys, $index + 1);
19
+ $screen-size: map.get(root-defaults.$screen-sizes, $key);
20
+ $screen-size: $screen-size - 1;
21
+
22
+ @return $screen-size;
23
+ }
24
+
25
+ @function range($min, $max) {
26
+ $min-size: min($min);
27
+ $max-size: max($max);
28
+
29
+ @return (min: $min-size, max: $max-size);
30
+ }
@@ -1,18 +1,39 @@
1
+ // @graupl/graupl theme functions.
2
+ //
1
3
  // Functions to help with getting information about the theme.
2
4
 
3
5
  @use "sass:map";
4
6
  @use "../theme/color/variables" as color;
5
7
 
6
8
  // A function to get the specific theme shades.
7
- @function get($color, $shade) {
8
- $color-map: map.get(color.$theme-active, $color);
9
- $value: map.get($color-map, $shade);
9
+ @function get($color, $shade, $theme: active) {
10
+ @if $shade == transparent or $color == transparent {
11
+ @return transparent;
12
+ }
10
13
 
11
- @return $value;
14
+ @if $shade == none or $color == none {
15
+ @return none;
16
+ }
17
+
18
+ @if $shade == inherit or $color == inherit {
19
+ @return inherit;
20
+ }
21
+
22
+ @if $shade == initial or $color == initial {
23
+ @return initial;
24
+ }
25
+
26
+ @if map.has-key(color.$themes, $theme, $color, $shade) {
27
+ @return map.get(map.get(map.get(color.$themes, $theme), $color), $shade);
28
+ }
29
+
30
+ @return null;
12
31
  }
13
32
 
14
- @function variants() {
15
- $variants: map.keys(color.$theme-active);
33
+ @function variants($theme: active) {
34
+ @if map.has-key(color.$themes, $theme) {
35
+ @return map.keys(map.get(color.$themes, $theme));
36
+ }
16
37
 
17
- @return $variants;
38
+ @return null;
18
39
  }
@@ -1,4 +1,5 @@
1
- // Graupl layouts.
1
+ // @graupl/graupl layout styles.
2
2
 
3
3
  @forward "container";
4
4
  @forward "columns";
5
+ @forward "flex-columns";
@@ -1,9 +1,17 @@
1
- // Default values for Graupl.
1
+ // @graupl/graupl columns layout default values.
2
2
  //
3
- // Generally, these should not be used directly when styling components.
4
- // They are mainly used to provide default fallbacks for custom properties
5
- // which can be found in the `variables.scss` file.
3
+ // Generally, these should not be used directly when styling components unless a static value is needed.
4
+ // They are mainly used to provide class selectors, fallbacks for custom properties, or loop values.
5
+ //
6
+ // They should not be used to define direct property values (i.e. font-size, color, etc.).
7
+ // Those should be defined as custom properties in the `_variables.scss` file.
8
+
9
+ // Columns selectors.
10
+ $columns-selector: ".columns" !default;
11
+ $columns-count-selector-prefix: ".count-" !default;
12
+ $columns-span-selector-prefix: ".span-" !default;
6
13
 
14
+ // Columns properties.
7
15
  $columns-max-width: 1fr !default;
8
16
  $columns-count: 3 !default;
9
17
  $columns-min-count: 1 !default;
@@ -1,13 +1,13 @@
1
- // Graupl Columns layout.
1
+ // @graupl/graupl columns layout styles.
2
2
 
3
3
  @use "variables" as *;
4
4
  @use "defaults";
5
5
  @use "../../defaults" as root-defaults;
6
6
  @use "../../mixins/layer" as *;
7
- @use "../../mixins/media-queries" as *;
7
+ @use "../../mixins/screen";
8
8
 
9
9
  @include layer(layout) {
10
- .columns {
10
+ #{defaults.$columns-selector} {
11
11
  display: grid;
12
12
  grid-template-columns: $columns-grid-template-columns;
13
13
  gap: $columns-row-gap $columns-column-gap;
@@ -18,19 +18,41 @@
18
18
  }
19
19
 
20
20
  @for $i from defaults.$columns-min-count through defaults.$columns-max-count {
21
- .count-#{$i} {
21
+ #{defaults.$columns-count-selector-prefix}#{$i} {
22
22
  --#{root-defaults.$prefix}-columns-count: #{$i};
23
+
24
+ // For span values bigger than the actual column count, set them to the
25
+ // maximum column count so they don't break the layout.
26
+ @for $j from $i + 1 through defaults.$columns-max-count {
27
+ #{defaults.$columns-span-selector-prefix}#{$j} {
28
+ --#{root-defaults.$prefix}-columns-span: #{$i};
29
+ }
30
+ }
23
31
  }
24
32
 
25
- .span-#{$i} {
33
+ #{defaults.$columns-span-selector-prefix}#{$i} {
26
34
  --#{root-defaults.$prefix}-columns-span: #{$i};
27
35
  }
28
36
  }
29
37
 
30
38
  // Disable columns on small screens to avoid horizontal bleeding.
31
- @include screen(xs) {
32
- .columns {
39
+ @include screen.trigger(force-single-column) {
40
+ #{defaults.$columns-selector} {
33
41
  --#{root-defaults.$prefix}-columns-min-width: #{defaults.$columns-max-width};
42
+
43
+ > * {
44
+ --#{root-defaults.$prefix}-columns-span: 1;
45
+ }
46
+
47
+ // All spans should be set to 1 to avoid adding columns.
48
+ @for $i
49
+ from defaults.$columns-min-count
50
+ through defaults.$columns-max-count
51
+ {
52
+ #{defaults.$columns-span-selector-prefix}#{$i} {
53
+ --#{root-defaults.$prefix}-columns-span: 1;
54
+ }
55
+ }
34
56
  }
35
57
  }
36
58
  }
@@ -1,4 +1,7 @@
1
- // Variables referencing custom properties.
1
+ // @graupl/graupl columns layout variables.
2
+ //
3
+ // These values are to be used to directly style components and provide a
4
+ // cleaner way to reference custom properties.
2
5
 
3
6
  @use "defaults";
4
7
  @use "../../variables" as root-variables;
@@ -29,7 +32,8 @@ $columns-min-width: var(
29
32
  (
30
33
  #{root-variables.$content-max-width} - #{$columns-column-gap} *
31
34
  (#{$columns-count} - 1)
32
- ) / #{$columns-count}
35
+ ) /
36
+ #{$columns-count}
33
37
  )
34
38
  );
35
39
  /* stylelint-enable scss/operator-no-newline-after */
@@ -1,8 +1,17 @@
1
- // Default values for Graupl.
1
+ // @graupl/graupl container layout default values.
2
2
  //
3
- // Generally, these should not be used directly when styling components.
4
- // They are mainly used to provide default fallbacks for custom properties
5
- // which can be found in the `variables.scss` file.
3
+ // Generally, these should not be used directly when styling components unless a static value is needed.
4
+ // They are mainly used to provide class selectors, fallbacks for custom properties, or loop values.
5
+ //
6
+ // They should not be used to define direct property values (i.e. font-size, color, etc.).
7
+ // Those should be defined as custom properties in the `_variables.scss` file.
8
+
9
+ // Container selectors.
10
+ $container-selector: ".container" !default;
11
+ $container-breakout-selector: ".breakout" !default;
12
+ $container-feature-selector: ".feature" !default;
13
+ $container-full-width-selector: ".full-width" !default;
6
14
 
15
+ // Container properties.
7
16
  $container-breakout-width: 15ch !default;
8
17
  $container-feature-width: 20ch !default;