@graupl/graupl 1.0.0-alpha.9 → 1.0.0-beta.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 (350) 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/CHANGELOG.md +160 -0
  5. package/build.js +7 -0
  6. package/dist/css/base/button.css +2 -0
  7. package/dist/css/base/button.css.map +1 -0
  8. package/dist/css/base/form.css +2 -0
  9. package/dist/css/base/form.css.map +1 -0
  10. package/dist/css/base/link.css +2 -0
  11. package/dist/css/base/link.css.map +1 -0
  12. package/dist/css/base/table.css +2 -0
  13. package/dist/css/base/table.css.map +1 -0
  14. package/dist/css/base.css +2 -0
  15. package/dist/css/base.css.map +1 -0
  16. package/dist/css/component/accordion.css +2 -0
  17. package/dist/css/component/accordion.css.map +1 -0
  18. package/dist/css/component/alert.css +2 -0
  19. package/dist/css/component/alert.css.map +1 -0
  20. package/dist/css/component/card.css +2 -0
  21. package/dist/css/component/card.css.map +1 -0
  22. package/dist/css/component/carousel.css +2 -0
  23. package/dist/css/component/carousel.css.map +1 -0
  24. package/dist/css/component/input-group.css +2 -0
  25. package/dist/css/component/input-group.css.map +1 -0
  26. package/dist/css/component/menu.css +2 -0
  27. package/dist/css/component/menu.css.map +1 -0
  28. package/dist/css/component/navigation.css +2 -0
  29. package/dist/css/component/navigation.css.map +1 -0
  30. package/dist/css/component.css +2 -0
  31. package/dist/css/component.css.map +1 -0
  32. package/dist/css/graupl.css +2 -0
  33. package/dist/css/graupl.css.map +1 -0
  34. package/dist/css/init.css +2 -0
  35. package/dist/css/init.css.map +1 -0
  36. package/dist/css/layout/columns.css +2 -0
  37. package/dist/css/layout/columns.css.map +1 -0
  38. package/dist/css/layout/container.css +2 -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/css/utilities/color.css +2 -0
  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 +31 -10
  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 +75 -6
  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 +17 -17
  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/base/button/_variables.scss +176 -0
  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 +46 -37
  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 +239 -9
  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 +87 -17
  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 +170 -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 +16 -13
  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 +32 -10
  224. package/src/scss/layout/columns/_variables.scss +13 -9
  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 +14 -11
  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 +14 -10
  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 +18 -18
  244. package/src/scss/theme/color/_variables.scss +73 -65
  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 +62 -58
  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 +138 -33
  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 +0 -2
  307. package/dist/component/input-group.css.map +0 -1
  308. package/dist/component/table.css +0 -2
  309. package/dist/component/table.css.map +0 -1
  310. package/dist/component.css +0 -2
  311. package/dist/component.css.map +0 -1
  312. package/dist/graupl.css +0 -2
  313. package/dist/graupl.css.map +0 -1
  314. package/dist/layout/columns.css +0 -2
  315. package/dist/layout/columns.css.map +0 -1
  316. package/dist/layout/container.css +0 -2
  317. package/dist/layout/container.css.map +0 -1
  318. package/dist/layout.css +0 -2
  319. package/dist/layout.css.map +0 -1
  320. package/dist/state/focus.css +0 -2
  321. package/dist/state/focus.css.map +0 -1
  322. package/dist/state.css +0 -2
  323. package/dist/state.css.map +0 -1
  324. package/dist/theme/color.css +0 -2
  325. package/dist/theme/color.css.map +0 -1
  326. package/dist/theme/typography.css +0 -2
  327. package/dist/theme/typography.css.map +0 -1
  328. package/dist/theme.css +0 -2
  329. package/dist/theme.css.map +0 -1
  330. package/dist/utilities/colors.css +0 -2
  331. package/dist/utilities/colors.css.map +0 -1
  332. package/dist/utilities/spacing.css +0 -2
  333. package/dist/utilities/spacing.css.map +0 -1
  334. package/dist/utilities/typography.css +0 -2
  335. package/dist/utilities/typography.css.map +0 -1
  336. package/dist/utilities.css +0 -2
  337. package/dist/utilities.css.map +0 -1
  338. package/scss/component/button.scss +0 -3
  339. package/scss/component/table.scss +0 -3
  340. package/scss/utilities/colors.scss +0 -3
  341. package/src/scss/component/button/_defaults.scss +0 -39
  342. package/src/scss/component/button/_index.scss +0 -98
  343. package/src/scss/component/button/_variables.scss +0 -131
  344. package/src/scss/component/table/_defaults.scss +0 -30
  345. package/src/scss/component/table/_index.scss +0 -77
  346. package/src/scss/component/table/_variables.scss +0 -64
  347. package/src/scss/mixins/_media-queries.scss +0 -26
  348. package/src/scss/utilities/colors/_defaults.scss +0 -5
  349. package/src/scss/utilities/colors/_index.scss +0 -22
  350. package/src/scss/utilities/colors/_variables.scss +0 -3
@@ -0,0 +1,170 @@
1
+ // @graupl/graupl alert 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
+ // Alert properties.
14
+ $alert-padding-x: var(
15
+ --#{root-defaults.$prefix}alert-padding-x,
16
+ #{map.get(root-variables.$spacers, 5)}
17
+ );
18
+ $alert-padding-y: var(
19
+ --#{root-defaults.$prefix}alert-padding-y,
20
+ #{map.get(root-variables.$spacers, 5)}
21
+ );
22
+ $alert-padding: var(
23
+ --#{root-defaults.$prefix}alert-padding,
24
+ #{$alert-padding-y} #{$alert-padding-x}
25
+ );
26
+
27
+ // Alert gap properties.
28
+ $alert-column-gap: var(
29
+ --#{root-defaults.$prefix}alert-column-gap,
30
+ #{map.get(root-variables.$spacers, 0)}
31
+ );
32
+ $alert-row-gap: var(
33
+ --#{root-defaults.$prefix}alert-row-gap,
34
+ #{map.get(root-variables.$spacers, 3)}
35
+ );
36
+ $alert-gap: var(
37
+ --#{root-defaults.$prefix}alert-gap,
38
+ #{$alert-column-gap} #{$alert-row-gap}
39
+ );
40
+
41
+ // Alert color properties.
42
+ $alert-background: var(
43
+ --#{root-defaults.$prefix}alert-background,
44
+ #{color.$root-background}
45
+ );
46
+ $alert-color: var(--#{root-defaults.$prefix}alert-color, #{color.$root-color});
47
+ $alert-link-color: var(--#{root-defaults.$prefix}alert-link-color);
48
+ $alert-link-visited-color: var(
49
+ --#{root-defaults.$prefix}alert-link-visited-color
50
+ );
51
+ $alert-link-focus-color: var(--#{root-defaults.$prefix}alert-link-focus-color);
52
+ $alert-link-hover-color: var(--#{root-defaults.$prefix}alert-link-hover-color);
53
+ $alert-link-active-color: var(
54
+ --#{root-defaults.$prefix}alert-link-active-color
55
+ );
56
+ $alert-link-disabled-color: var(
57
+ --#{root-defaults.$prefix}alert-link-disabled-color
58
+ );
59
+
60
+ // Alert border-properties.
61
+ $alert-border-color: var(
62
+ --#{root-defaults.$prefix}alert-border-color,
63
+ #{$alert-color}
64
+ );
65
+ $alert-top-left-border-radius: var(
66
+ --#{root-defaults.$prefix}alert-top-left-border-radius,
67
+ #{root-variables.$border-radius}
68
+ );
69
+ $alert-top-right-border-radius: var(
70
+ --#{root-defaults.$prefix}alert-top-right-border-radius,
71
+ #{root-variables.$border-radius}
72
+ );
73
+ $alert-bottom-left-border-radius: var(
74
+ --#{root-defaults.$prefix}alert-bottom-left-border-radius,
75
+ #{root-variables.$border-radius}
76
+ );
77
+ $alert-bottom-right-border-radius: var(
78
+ --#{root-defaults.$prefix}alert-bottom-right-border-radius,
79
+ #{root-variables.$border-radius}
80
+ );
81
+ $alert-border-radius: var(
82
+ --#{root-defaults.$prefix}alert-border-radius,
83
+ #{$alert-top-left-border-radius} #{$alert-top-right-border-radius}
84
+ #{$alert-bottom-right-border-radius} #{$alert-bottom-left-border-radius}
85
+ );
86
+ $alert-border-style: var(
87
+ --#{root-defaults.$prefix}alert-border-style,
88
+ #{root-variables.$border-style}
89
+ );
90
+ $alert-border-width: var(
91
+ --#{root-defaults.$prefix}alert-border-width,
92
+ #{root-variables.$border-width}
93
+ );
94
+ $alert-border: var(
95
+ --#{root-defaults.$prefix}alert-border,
96
+ #{$alert-border-width} #{$alert-border-style}
97
+ );
98
+
99
+ // Alert transition properties.
100
+ $alert-transition: var(
101
+ --#{root-defaults.$prefix}alert-transition,
102
+ opacity #{map.get(root-variables.$transition-durations, fast)}
103
+ #{root-variables.$transition-timing-function},
104
+ transform #{map.get(root-variables.$transition-durations, fast)}
105
+ #{root-variables.$transition-timing-function}
106
+ );
107
+ $alert-transition-reduced-motion: var(
108
+ --#{root-defaults.$prefix}alert-transition-reduced-motion,
109
+ opacity #{map.get(root-variables.$transition-durations, fast)}
110
+ #{root-variables.$transition-timing-function}
111
+ );
112
+
113
+ // Alert header properties.
114
+ $alert-header-padding-x: var(
115
+ --#{root-defaults.$prefix}alert-header-padding-x,
116
+ 0
117
+ );
118
+ $alert-header-padding-y: var(
119
+ --#{root-defaults.$prefix}alert-header-padding-y,
120
+ 0
121
+ );
122
+ $alert-header-padding: var(
123
+ --#{root-defaults.$prefix}alert-header-padding,
124
+ #{$alert-header-padding-y} #{$alert-header-padding-x}
125
+ );
126
+
127
+ // Alert title properties.
128
+ $alert-title-color: var(
129
+ --#{root-defaults.$prefix}alert-title-color,
130
+ #{$alert-color}
131
+ );
132
+ $alert-title-font-size: var(
133
+ --#{root-defaults.$prefix}alert-title-font-size,
134
+ #{typography.$h4-font-size}
135
+ );
136
+ $alert-title-font-weight: var(
137
+ --#{root-defaults.$prefix}alert-title-font-weight,
138
+ #{typography.$h4-font-weight}
139
+ );
140
+ $alert-title-font-family: var(
141
+ --#{root-defaults.$prefix}alert-title-font-family,
142
+ #{typography.$h4-font-family}
143
+ );
144
+ $alert-title-line-height: var(
145
+ --#{root-defaults.$prefix}alert-title-line-height,
146
+ #{typography.$h4-line-height}
147
+ );
148
+ $alert-title-margin: var(--#{root-defaults.$prefix}alert-title-margin, 0 0 0 0);
149
+
150
+ // Alert body properties.
151
+ $alert-body-padding-x: var(--#{root-defaults.$prefix}alert-body-padding-x, 0);
152
+ $alert-body-padding-y: var(--#{root-defaults.$prefix}alert-body-padding-y, 0);
153
+ $alert-body-padding: var(
154
+ --#{root-defaults.$prefix}alert-body-padding,
155
+ #{$alert-body-padding-y} #{$alert-body-padding-x}
156
+ );
157
+
158
+ // Alert footer properties.
159
+ $alert-footer-padding-x: var(
160
+ --#{root-defaults.$prefix}alert-footer-padding-x,
161
+ 0
162
+ );
163
+ $alert-footer-padding-y: var(
164
+ --#{root-defaults.$prefix}alert-footer-padding-y,
165
+ 0
166
+ );
167
+ $alert-footer-padding: var(
168
+ --#{root-defaults.$prefix}alert-footer-padding,
169
+ #{$alert-footer-padding-y} #{$alert-footer-padding-x}
170
+ );
@@ -0,0 +1,32 @@
1
+ // @graupl/graupl card component default values.
2
+ //
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
+ // Card selectors.
10
+ $card-selector: ".card" !default;
11
+ $card-image-selector: ".card-image" !default;
12
+ $card-content-selector: ".card-content" !default;
13
+ $card-body-selector: ".card-body" !default;
14
+ $card-header-selector: ".card-header" !default;
15
+ $card-footer-selector: ".card-footer" !default;
16
+ $card-title-selector: ".card-title" !default;
17
+ $horizontal-card-selector: ".horizontal" !default;
18
+ $horizontal-card-left-selector: ".left" !default;
19
+ $horizontal-card-right-selector: ".right" !default;
20
+ $vertical-card-top-selector: ".top" !default;
21
+ $vertical-card-bottom-selector: ".bottom" !default;
22
+ $inverse-card-selector: ".inverse" !default;
23
+
24
+ // Card properties.
25
+ $card-transform: none !default;
26
+ $card-hover-transform: $card-transform !default;
27
+
28
+ // Card layout properties.
29
+ $card-content-ratio: 1fr !default;
30
+ $card-image-ratio: auto !default;
31
+ $horizontal-card-content-ratio: 3fr !default;
32
+ $horizontal-card-image-ratio: 2fr !default;
@@ -0,0 +1,178 @@
1
+ // @graupl/graupl card component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../mixins/layer" as *;
7
+ @use "../../mixins/animation";
8
+ @use "../../mixins/screen";
9
+
10
+ @include layer(component) {
11
+ #{defaults.$card-selector} {
12
+ display: grid;
13
+ position: relative;
14
+ grid-template-columns: 1fr;
15
+ padding: $card-padding;
16
+ transform: $card-transform;
17
+ transition: $card-transition;
18
+ border: $card-border;
19
+ border-radius: $card-border-radius;
20
+ gap: $card-gap;
21
+ isolation: isolate;
22
+
23
+ &,
24
+ &#{defaults.$vertical-card-top-selector} {
25
+ grid-template-rows:
26
+ [image-start]
27
+ $card-image-ratio
28
+ [image-end content-start]
29
+ $card-content-ratio
30
+ [content-end];
31
+ }
32
+
33
+ &#{defaults.$vertical-card-bottom-selector},
34
+ &#{defaults.$inverse-card-selector} {
35
+ grid-template-rows:
36
+ [content-start]
37
+ $card-content-ratio
38
+ [content-end image-start]
39
+ $card-image-ratio
40
+ [image-end];
41
+ }
42
+
43
+ &:hover {
44
+ --#{root-defaults.$prefix}card-transform: #{$card-hover-transform};
45
+ }
46
+
47
+ &#{defaults.$horizontal-card-selector} {
48
+ &,
49
+ &#{defaults.$horizontal-card-left-selector} {
50
+ --#{root-defaults.$prefix}card-content-ratio: #{$horizontal-card-content-ratio};
51
+ --#{root-defaults.$prefix}card-image-ratio: #{$horizontal-card-image-ratio};
52
+
53
+ grid-template-columns:
54
+ [image-start]
55
+ $card-image-ratio
56
+ [image-end content-start]
57
+ $card-content-ratio
58
+ [content-end];
59
+ grid-template-rows: 1fr;
60
+
61
+ #{defaults.$card-image-selector} img {
62
+ border-radius: calc($card-top-left-border-radius - $card-border-width)
63
+ 0 0 calc($card-bottom-left-border-radius - $card-border-width);
64
+ }
65
+ }
66
+
67
+ &#{defaults.$horizontal-card-right-selector},
68
+ &#{defaults.$inverse-card-selector} {
69
+ grid-template-columns:
70
+ [content-start]
71
+ $card-content-ratio
72
+ [content-end image-start]
73
+ $card-image-ratio
74
+ [image-end];
75
+
76
+ #{defaults.$card-image-selector} img {
77
+ border-radius: 0
78
+ calc($card-top-right-border-radius - $card-border-width)
79
+ calc($card-bottom-right-border-radius - $card-border-width) 0;
80
+ }
81
+ }
82
+ }
83
+ }
84
+
85
+ #{defaults.$card-image-selector} {
86
+ grid-area: image;
87
+ padding: $card-image-padding;
88
+
89
+ img {
90
+ width: 100%;
91
+ height: 100%;
92
+ border-radius: calc($card-top-left-border-radius - $card-border-width)
93
+ calc($card-top-right-border-radius - $card-border-width) 0 0;
94
+ object-fit: cover;
95
+ }
96
+ }
97
+
98
+ #{defaults.$card-content-selector} {
99
+ display: flex;
100
+ grid-area: content;
101
+ flex-direction: column;
102
+ padding: $card-content-padding;
103
+ gap: $card-content-gap;
104
+ }
105
+
106
+ #{defaults.$card-body-selector} {
107
+ flex: 1 0 auto;
108
+ }
109
+
110
+ #{defaults.$card-footer-selector} {
111
+ flex: 0 0 auto;
112
+ }
113
+
114
+ #{defaults.$card-title-selector} {
115
+ flex: 0 0 auto;
116
+ }
117
+
118
+ @include screen.trigger(force-vertical-card) {
119
+ #{defaults.$card-selector} {
120
+ &#{defaults.$horizontal-card-selector} {
121
+ &,
122
+ &#{defaults.$horizontal-card-left-selector},
123
+ &#{defaults.$vertical-card-top-selector},
124
+ &#{defaults.$horizontal-card-right-selector},
125
+ &#{defaults.$vertical-card-bottom-selector},
126
+ &#{defaults.$inverse-card-selector} {
127
+ --#{root-defaults.$prefix}horizontal-card-image-ratio: #{defaults.$card-image-ratio};
128
+ --#{root-defaults.$prefix}horizontal-card-content-ratio: #{defaults.$card-content-ratio};
129
+
130
+ grid-template-columns: 1fr;
131
+ }
132
+
133
+ &,
134
+ &#{defaults.$horizontal-card-left-selector},
135
+ &#{defaults.$horizontal-card-right-selector},
136
+ &#{defaults.$vertical-card-top-selector} {
137
+ grid-template-rows:
138
+ [image-start]
139
+ $card-image-ratio
140
+ [image-end content-start]
141
+ $card-content-ratio
142
+ [content-end];
143
+ }
144
+
145
+ &#{defaults.$vertical-card-bottom-selector},
146
+ &#{defaults.$inverse-card-selector} {
147
+ grid-template-rows:
148
+ [content-start]
149
+ $card-content-ratio
150
+ [content-end image-start]
151
+ $card-image-ratio
152
+ [image-end];
153
+ }
154
+ }
155
+ }
156
+ }
157
+
158
+ @include animation.off {
159
+ #{defaults.$card-selector} {
160
+ --#{root-defaults.$prefix}card-transition: #{$card-transition-reduced-motion};
161
+ }
162
+ }
163
+ }
164
+
165
+ @include layer(theme) {
166
+ #{defaults.$card-selector} {
167
+ border-color: $card-border-color;
168
+ background: $card-background;
169
+ color: $card-color;
170
+ }
171
+
172
+ #{defaults.$card-title-selector} {
173
+ color: $card-title-color;
174
+ font-size: $card-title-font-size;
175
+ font-weight: $card-title-font-weight;
176
+ line-height: $card-title-line-height;
177
+ }
178
+ }
@@ -0,0 +1,186 @@
1
+ // @graupl/graupl card 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
+ // Card properties.
14
+ $card-padding-x: var(
15
+ --#{root-defaults.$prefix}card-padding-x,
16
+ #{map.get(root-variables.$spacers, 0)}
17
+ );
18
+ $card-padding-y: var(
19
+ --#{root-defaults.$prefix}card-padding-y,
20
+ #{map.get(root-variables.$spacers, 0)}
21
+ );
22
+ $card-padding: var(
23
+ --#{root-defaults.$prefix}card-padding,
24
+ #{$card-padding-y} #{$card-padding-x}
25
+ );
26
+ $card-transition: var(
27
+ --#{root-defaults.$prefix}card-transition,
28
+ transform #{map.get(root-variables.$transition-durations, fast)}
29
+ #{root-variables.$transition-timing-function}
30
+ );
31
+ $card-transition-reduced-motion: var(
32
+ --#{root-defaults.$prefix}card-transition-reduced-motion,
33
+ none
34
+ );
35
+
36
+ // Card transform properties.
37
+ $card-transform: var(
38
+ --#{root-defaults.$prefix}card-transform,
39
+ #{defaults.$card-transform}
40
+ );
41
+ $card-hover-transform: var(
42
+ --#{root-defaults.$prefix}card-hover-transform,
43
+ #{defaults.$card-hover-transform}
44
+ );
45
+
46
+ // Card gap properties.
47
+ $card-column-gap: var(
48
+ --#{root-defaults.$prefix}card-column-gap,
49
+ #{map.get(root-variables.$spacers, 0)}
50
+ );
51
+ $card-row-gap: var(
52
+ --#{root-defaults.$prefix}card-row-gap,
53
+ #{map.get(root-variables.$spacers, 0)}
54
+ );
55
+ $card-gap: var(
56
+ --#{root-defaults.$prefix}card-gap,
57
+ #{$card-column-gap} #{$card-row-gap}
58
+ );
59
+
60
+ // Card color properties.
61
+ $card-background: var(
62
+ --#{root-defaults.$prefix}card-background,
63
+ #{color.$root-background}
64
+ );
65
+ $card-color: var(--#{root-defaults.$prefix}card-color, #{color.$root-color});
66
+
67
+ // Card border-properties.
68
+ $card-border-color: var(
69
+ --#{root-defaults.$prefix}card-border-color,
70
+ #{$card-color}
71
+ );
72
+ $card-top-left-border-radius: var(
73
+ --#{root-defaults.$prefix}card-top-left-border-radius,
74
+ #{root-variables.$border-radius}
75
+ );
76
+ $card-top-right-border-radius: var(
77
+ --#{root-defaults.$prefix}card-top-right-border-radius,
78
+ #{root-variables.$border-radius}
79
+ );
80
+ $card-bottom-left-border-radius: var(
81
+ --#{root-defaults.$prefix}card-bottom-left-border-radius,
82
+ #{root-variables.$border-radius}
83
+ );
84
+ $card-bottom-right-border-radius: var(
85
+ --#{root-defaults.$prefix}card-bottom-right-border-radius,
86
+ #{root-variables.$border-radius}
87
+ );
88
+ $card-border-radius: var(
89
+ --#{root-defaults.$prefix}card-border-radius,
90
+ #{$card-top-left-border-radius} #{$card-top-right-border-radius}
91
+ #{$card-bottom-right-border-radius} #{$card-bottom-left-border-radius}
92
+ );
93
+ $card-border-style: var(
94
+ --#{root-defaults.$prefix}card-border-style,
95
+ #{root-variables.$border-style}
96
+ );
97
+ $card-border-width: var(
98
+ --#{root-defaults.$prefix}card-border-width,
99
+ #{root-variables.$border-width}
100
+ );
101
+ $card-border: var(
102
+ --#{root-defaults.$prefix}card-border,
103
+ #{$card-border-width} #{$card-border-style}
104
+ );
105
+
106
+ // Card layout properties.
107
+ $card-content-ratio: var(
108
+ --#{root-defaults.$prefix}card-content-ratio,
109
+ defaults.$card-content-ratio
110
+ );
111
+ $card-image-ratio: var(
112
+ --#{root-defaults.$prefix}card-image-ratio,
113
+ defaults.$card-image-ratio
114
+ );
115
+ $horizontal-card-content-ratio: var(
116
+ --#{root-defaults.$prefix}horizontal-card-content-ratio,
117
+ defaults.$horizontal-card-content-ratio
118
+ );
119
+ $horizontal-card-image-ratio: var(
120
+ --#{root-defaults.$prefix}horizontal-card-image-ratio,
121
+ defaults.$horizontal-card-image-ratio
122
+ );
123
+
124
+ // Card image properties.
125
+ $card-image-padding-x: var(
126
+ --#{root-defaults.$prefix}card-image-padding-x,
127
+ #{map.get(root-variables.$spacers, 0)}
128
+ );
129
+ $card-image-padding-y: var(
130
+ --#{root-defaults.$prefix}card-image-padding-y,
131
+ #{map.get(root-variables.$spacers, 0)}
132
+ );
133
+ $card-image-padding: var(
134
+ --#{root-defaults.$prefix}card-image-padding,
135
+ #{$card-image-padding-y} #{$card-image-padding-x}
136
+ );
137
+
138
+ // Card content properties.
139
+ $card-content-padding-x: var(
140
+ --#{root-defaults.$prefix}card-content-padding-x,
141
+ #{map.get(root-variables.$spacers, 5)}
142
+ );
143
+ $card-content-padding-y: var(
144
+ --#{root-defaults.$prefix}card-content-padding-y,
145
+ #{map.get(root-variables.$spacers, 3)}
146
+ );
147
+ $card-content-padding: var(
148
+ --#{root-defaults.$prefix}card-content-padding,
149
+ #{$card-content-padding-y} #{$card-content-padding-x}
150
+ );
151
+
152
+ // Card content gap properties.
153
+ $card-content-column-gap: var(
154
+ --#{root-defaults.$prefix}card-content-column-gap,
155
+ #{map.get(root-variables.$spacers, 0)}
156
+ );
157
+ $card-content-row-gap: var(
158
+ --#{root-defaults.$prefix}card-content-row-gap,
159
+ #{map.get(root-variables.$spacers, 3)}
160
+ );
161
+ $card-content-gap: var(
162
+ --#{root-defaults.$prefix}card-content-gap,
163
+ #{$card-content-column-gap} #{$card-content-row-gap}
164
+ );
165
+
166
+ // Card title properties.
167
+ $card-title-color: var(
168
+ --#{root-defaults.$prefix}card-title-color,
169
+ #{$card-color}
170
+ );
171
+ $card-title-font-size: var(
172
+ --#{root-defaults.$prefix}card-title-font-size,
173
+ #{typography.$h4-font-size}
174
+ );
175
+ $card-title-font-weight: var(
176
+ --#{root-defaults.$prefix}card-title-font-weight,
177
+ #{typography.$h4-font-weight}
178
+ );
179
+ $card-title-font-family: var(
180
+ --#{root-defaults.$prefix}card-title-font-family,
181
+ #{typography.$h4-font-family}
182
+ );
183
+ $card-title-line-height: var(
184
+ --#{root-defaults.$prefix}card-title-line-height,
185
+ #{typography.$h4-line-height}
186
+ );
@@ -0,0 +1,43 @@
1
+ // @graupl/graupl carousel component default values.
2
+ //
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
+ @use "sass:map";
10
+
11
+ // Carousel selectors.
12
+ $carousel-selector: ".carousel" !default;
13
+ $carousel-control-container-selector: ".carousel-control-container" !default;
14
+ $carousel-control-selector: ".carousel-control" !default;
15
+ $carousel-pause-selector: ".pause" !default;
16
+ $carousel-play-selector: ".play" !default;
17
+ $carousel-autoplay-selector: ".autoplay" !default;
18
+ $carousel-previous-selector: ".previous" !default;
19
+ $carousel-next-selector: ".next" !default;
20
+ $carousel-item-container-selector: ".carousel-item-container" !default;
21
+ $carousel-item-selector: ".carousel-item" !default;
22
+ $carousel-tab-container-selector: ".carousel-tab-container" !default;
23
+ $carousel-tab-selector: ".carousel-tab" !default;
24
+ $carousel-active-item-selector: ".active" !default;
25
+ $carousel-next-item-selector: ".next" !default;
26
+ $carousel-previous-item-selector: ".previous" !default;
27
+
28
+ // Carousel grid area properties.
29
+ $carousel-controls-height: auto !default;
30
+ $carousel-tabs-width: 1fr !default;
31
+ $carousel-tabs-height: auto !default;
32
+ $carousel-slide-height: 1fr !default;
33
+ $carousel-control-height: 3rem !default;
34
+ $carousel-control-width: 4rem !default;
35
+
36
+ // Carousel slide properties.
37
+ $carousel-item-max-width: 100% !default;
38
+
39
+ // Carousel control properties.
40
+ $carousel-play-content: "'▶'" !default;
41
+ $carousel-pause-content: "'❚❚'" !default;
42
+ $carousel-next-content: "'▶'" !default;
43
+ $carousel-previous-content: "'◀'" !default;