@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,180 @@
1
+ // @graupl/graupl accordion component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../base/button/mixins" as button-mixins;
6
+ @use "../../defaults" as root-defaults;
7
+ @use "../../mixins/layer" as *;
8
+ @use "../../state/focus/variables" as focus;
9
+ @use "sass:map";
10
+
11
+ #{defaults.$accordion-selector} {
12
+ @include layer(component) {
13
+ display: flex;
14
+ flex-flow: column nowrap;
15
+ padding: $accordion-padding;
16
+ gap: $accordion-gap;
17
+
18
+ > #{defaults.$accordion-item-selector} {
19
+ &:not(:first-child) {
20
+ margin-top: calc(-1 * #{$accordion-item-border-width});
21
+ }
22
+ }
23
+ }
24
+
25
+ @include layer(theme) {
26
+ background: $accordion-background;
27
+ color: $accordion-color;
28
+ }
29
+ }
30
+
31
+ #{defaults.$accordion-item-selector} {
32
+ @include layer(component) {
33
+ overflow: hidden;
34
+ transition: $accordion-transition;
35
+ border: $accordion-item-border;
36
+ border-radius: $accordion-item-border-radius;
37
+ isolation: isolate;
38
+
39
+ &#{defaults.$accordion-item-close-selector}
40
+ #{defaults.$accordion-item-content-selector} {
41
+ display: none;
42
+ }
43
+
44
+ &#{defaults.$accordion-item-open-selector}
45
+ #{defaults.$accordion-item-content-selector} {
46
+ transform: $accordion-item-content-open-transform;
47
+ opacity: 1;
48
+ }
49
+
50
+ &#{defaults.$accordion-item-transition-selector}
51
+ #{defaults.$accordion-item-content-selector} {
52
+ display: flex;
53
+ }
54
+ }
55
+
56
+ @include layer(state) {
57
+ #{defaults.$accordion-item-toggle-selector} {
58
+ --#{root-defaults.$prefix}focus-outline-offset: calc(
59
+ -1 * (#{$accordion-item-border-width} + #{focus.$focus-width})
60
+ );
61
+ }
62
+ }
63
+
64
+ @include layer(theme) {
65
+ border-color: $accordion-item-border-color;
66
+ }
67
+ }
68
+
69
+ #{defaults.$accordion-item-toggle-selector} {
70
+ @include button-mixins.apply-button;
71
+
72
+ @include layer(component) {
73
+ z-index: 2;
74
+ padding: $accordion-item-toggle-padding;
75
+ transform: $accordion-item-toggle-transform;
76
+ transition: $accordion-item-toggle-transition;
77
+
78
+ @each $selector in map.get(root-defaults.$state-selectors, visited) {
79
+ &#{$selector} {
80
+ --#{root-defaults.$prefix}accordion-item-toggle-transform: #{$accordion-item-toggle-visited-transform};
81
+ }
82
+ }
83
+
84
+ @each $selector in map.get(root-defaults.$state-selectors, focus) {
85
+ &#{$selector} {
86
+ --#{root-defaults.$prefix}accordion-item-toggle-transform: #{$accordion-item-toggle-focus-transform};
87
+ }
88
+ }
89
+
90
+ @each $selector in map.get(root-defaults.$state-selectors, hover) {
91
+ &#{$selector} {
92
+ --#{root-defaults.$prefix}accordion-item-toggle-transform: #{$accordion-item-toggle-hover-transform};
93
+ }
94
+ }
95
+
96
+ @each $selector in map.get(root-defaults.$state-selectors, active) {
97
+ &#{$selector} {
98
+ --#{root-defaults.$prefix}accordion-item-toggle-transform: #{$accordion-item-toggle-active-transform};
99
+ }
100
+ }
101
+
102
+ @each $selector in map.get(root-defaults.$state-selectors, disabled) {
103
+ &#{$selector} {
104
+ --#{root-defaults.$prefix}accordion-item-toggle-transform: #{$accordion-item-toggle-disabled-transform};
105
+ }
106
+ }
107
+
108
+ &#{defaults.$accordion-item-toggle-pseudo-selector} {
109
+ content: defaults.$accordion-item-toggle-pseudo-content;
110
+ display: flex;
111
+ align-items: center;
112
+ justify-content: center;
113
+ margin-left: auto;
114
+ transform: $accordion-item-toggle-pseudo-transform;
115
+ transition: $accordion-item-toggle-pseudo-transition;
116
+ }
117
+
118
+ &[aria-expanded="true"] {
119
+ &::after {
120
+ transform: $accordion-item-toggle-pseudo-open-transform;
121
+ }
122
+ }
123
+ }
124
+ }
125
+
126
+ #{defaults.$accordion-item-header-selector} {
127
+ @include layer(component) {
128
+ margin: $accordion-item-header-margin;
129
+ padding: $accordion-item-header-padding;
130
+ }
131
+ }
132
+
133
+ #{defaults.$accordion-item-title-selector} {
134
+ @include layer(component) {
135
+ margin: $accordion-item-title-margin;
136
+ padding: $accordion-item-title-padding;
137
+
138
+ &,
139
+ #{defaults.$accordion-item-toggle-selector} {
140
+ display: flex;
141
+ align-items: center;
142
+ justify-content: flex-start;
143
+ width: 100%;
144
+ }
145
+ }
146
+
147
+ @include layer(theme) {
148
+ &,
149
+ #{defaults.$accordion-item-toggle-selector} {
150
+ font-family: $accordion-title-font-family;
151
+ font-size: $accordion-title-font-size;
152
+ font-weight: $accordion-title-font-weight;
153
+ line-height: $accordion-title-line-height;
154
+ }
155
+ }
156
+ }
157
+
158
+ #{defaults.$accordion-item-content-selector} {
159
+ @include layer(component) {
160
+ display: flex;
161
+ flex-flow: column nowrap;
162
+ padding: $accordion-item-content-padding;
163
+ transform: $accordion-item-content-transform;
164
+ transition: $accordion-item-content-transition;
165
+ opacity: 0;
166
+ gap: $accordion-item-content-gap;
167
+ }
168
+ }
169
+
170
+ #{defaults.$accordion-item-body-selector} {
171
+ @include layer(component) {
172
+ padding: $accordion-item-body-padding;
173
+ }
174
+ }
175
+
176
+ #{defaults.$accordion-item-footer-selector} {
177
+ @include layer(component) {
178
+ padding: $accordion-item-footer-padding;
179
+ }
180
+ }
@@ -0,0 +1,316 @@
1
+ // @graupl/graupl accordion 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 "../../functions/theme";
12
+ @use "sass:map";
13
+ @use "../../base/button/variables" as button;
14
+
15
+ // Accordion properties.
16
+ $accordion-padding-x: var(
17
+ --#{root-defaults.$prefix}accordion-padding-x,
18
+ #{map.get(root-variables.$spacers, 0)}
19
+ );
20
+ $accordion-padding-y: var(
21
+ --#{root-defaults.$prefix}accordion-padding-y,
22
+ #{map.get(root-variables.$spacers, 0)}
23
+ );
24
+ $accordion-padding: var(
25
+ --#{root-defaults.$prefix}accordion-padding,
26
+ #{$accordion-padding-y} #{$accordion-padding-x}
27
+ );
28
+
29
+ // Accordion gap properties.
30
+ $accordion-column-gap: var(
31
+ --#{root-defaults.$prefix}accordion-column-gap,
32
+ #{map.get(root-variables.$spacers, 0)}
33
+ );
34
+ $accordion-row-gap: var(
35
+ --#{root-defaults.$prefix}accordion-row-gap,
36
+ #{map.get(root-variables.$spacers, 0)}
37
+ );
38
+ $accordion-gap: var(
39
+ --#{root-defaults.$prefix}accordion-gap,
40
+ #{$accordion-column-gap} #{$accordion-row-gap}
41
+ );
42
+
43
+ // Accordion color properties.
44
+ $accordion-color: var(
45
+ --#{root-defaults.$prefix}accordion-color,
46
+ #{color.$root-color}
47
+ );
48
+ $accordion-background: var(
49
+ --#{root-defaults.$prefix}accordion-background,
50
+ #{color.$root-background}
51
+ );
52
+
53
+ // Accordion item border properties.
54
+ $accordion-item-border-color: var(
55
+ --#{root-defaults.$prefix}accordion-item-border-color,
56
+ #{$accordion-color}
57
+ );
58
+ $accordion-item-top-left-border-radius: var(
59
+ --#{root-defaults.$prefix}accordion-item-top-left-border-radius,
60
+ #{root-variables.$border-radius}
61
+ );
62
+ $accordion-item-top-right-border-radius: var(
63
+ --#{root-defaults.$prefix}accordion-item-top-right-border-radius,
64
+ #{root-variables.$border-radius}
65
+ );
66
+ $accordion-item-bottom-left-border-radius: var(
67
+ --#{root-defaults.$prefix}accordion-item-bottom-left-border-radius,
68
+ #{root-variables.$border-radius}
69
+ );
70
+ $accordion-item-bottom-right-border-radius: var(
71
+ --#{root-defaults.$prefix}accordion-item-bottom-right-border-radius,
72
+ #{root-variables.$border-radius}
73
+ );
74
+ $accordion-item-border-radius: var(
75
+ --#{root-defaults.$prefix}accordion-item-border-radius,
76
+ #{$accordion-item-top-left-border-radius}
77
+ #{$accordion-item-top-right-border-radius}
78
+ #{$accordion-item-bottom-right-border-radius}
79
+ #{$accordion-item-bottom-left-border-radius}
80
+ );
81
+ $accordion-item-border-style: var(
82
+ --#{root-defaults.$prefix}accordion-item-border-style,
83
+ #{root-variables.$border-style}
84
+ );
85
+ $accordion-item-border-width: var(
86
+ --#{root-defaults.$prefix}accordion-item-border-width,
87
+ #{root-variables.$border-width}
88
+ );
89
+ $accordion-item-border: var(
90
+ --#{root-defaults.$prefix}accordion-item-border,
91
+ #{$accordion-item-border-width} #{$accordion-item-border-style}
92
+ );
93
+
94
+ // Accordion item properties.
95
+ $accordion-item-toggle-padding: var(
96
+ --#{root-defaults.$prefix}accordion-item-toggle-padding,
97
+ #{button.$button-padding}
98
+ );
99
+
100
+ // Transform properties.
101
+ $accordion-item-toggle-transform: var(
102
+ --#{root-defaults.$prefix}accordion-item-toggle-transform,
103
+ #{defaults.$accordion-item-toggle-transform}
104
+ );
105
+ $accordion-item-toggle-visited-transform: var(
106
+ --#{root-defaults.$prefix}accordion-item-toggle-visited-transform,
107
+ #{defaults.$accordion-item-toggle-visited-transform}
108
+ );
109
+ $accordion-item-toggle-focus-transform: var(
110
+ --#{root-defaults.$prefix}accordion-item-toggle-focus-transform,
111
+ #{defaults.$accordion-item-toggle-focus-transform}
112
+ );
113
+ $accordion-item-toggle-hover-transform: var(
114
+ --#{root-defaults.$prefix}accordion-item-toggle-hover-transform,
115
+ #{defaults.$accordion-item-toggle-hover-transform}
116
+ );
117
+ $accordion-item-toggle-active-transform: var(
118
+ --#{root-defaults.$prefix}accordion-item-toggle-active-transform,
119
+ #{defaults.$accordion-item-toggle-active-transform}
120
+ );
121
+ $accordion-item-toggle-disabled-transform: var(
122
+ --#{root-defaults.$prefix}accordion-item-toggle-disabled-transform,
123
+ #{defaults.$accordion-item-toggle-disabled-transform}
124
+ );
125
+ $accordion-item-toggle-transition: var(
126
+ --#{root-defaults.$prefix}accordion-item-toggle-transition,
127
+ background #{map.get(root-variables.$transition-durations, fast)}
128
+ #{root-variables.$transition-timing-function},
129
+ color #{map.get(root-variables.$transition-durations, fast)}
130
+ #{root-variables.$transition-timing-function},
131
+ transform #{map.get(root-variables.$transition-durations, fast)}
132
+ #{root-variables.$transition-timing-function}
133
+ );
134
+ $accordion-item-toggle-transition-reduced-motion: var(
135
+ --#{root-defaults.$prefix}accordion-item-toggle-transition-reduced-motion,
136
+ background #{map.get(root-variables.$transition-durations, none)}
137
+ #{root-variables.$transition-timing-function},
138
+ color #{map.get(root-variables.$transition-durations, none)}
139
+ #{root-variables.$transition-timing-function}
140
+ );
141
+
142
+ // Accordion item header properties.
143
+ $accordion-item-header-padding-x: var(
144
+ --#{root-defaults.$prefix}accordion-item-header-padding-x,
145
+ #{map.get(root-variables.$spacers, 0)}
146
+ );
147
+ $accordion-item-header-padding-y: var(
148
+ --#{root-defaults.$prefix}accordion-item-header-padding-y,
149
+ #{map.get(root-variables.$spacers, 0)}
150
+ );
151
+ $accordion-item-header-padding: var(
152
+ --#{root-defaults.$prefix}accordion-item-header-padding,
153
+ #{$accordion-item-header-padding-y} #{$accordion-item-header-padding-x}
154
+ );
155
+ $accordion-item-header-margin: var(
156
+ --#{root-defaults.$prefix}accordion-item-header-margin,
157
+ calc(-1 * #{$accordion-item-border-width})
158
+ );
159
+
160
+ // Accordion item title properties.
161
+ $accordion-item-title-padding-x: var(
162
+ --#{root-defaults.$prefix}accordion-item-title-padding-x,
163
+ #{map.get(root-variables.$spacers, 0)}
164
+ );
165
+ $accordion-item-title-padding-y: var(
166
+ --#{root-defaults.$prefix}accordion-item-title-padding-y,
167
+ #{map.get(root-variables.$spacers, 0)}
168
+ );
169
+ $accordion-item-title-padding: var(
170
+ --#{root-defaults.$prefix}accordion-item-title-padding,
171
+ #{$accordion-item-title-padding-y} #{$accordion-item-title-padding-x}
172
+ );
173
+ $accordion-item-title-margin-x: var(
174
+ --#{root-defaults.$prefix}accordion-item-title-margin-x,
175
+ #{map.get(root-variables.$spacers, 0)}
176
+ );
177
+ $accordion-item-title-margin-y: var(
178
+ --#{root-defaults.$prefix}accordion-item-title-margin-y,
179
+ #{map.get(root-variables.$spacers, 0)}
180
+ );
181
+ $accordion-item-title-margin: var(
182
+ --#{root-defaults.$prefix}accordion-item-title-margin,
183
+ #{$accordion-item-title-margin-y} #{$accordion-item-title-margin-x}
184
+ );
185
+ $accordion-title-color: var(
186
+ --#{root-defaults.$prefix}accordion-title-color,
187
+ #{$accordion-color}
188
+ );
189
+ $accordion-title-font-size: var(
190
+ --#{root-defaults.$prefix}accordion-title-font-size,
191
+ #{typography.$h5-font-size}
192
+ );
193
+ $accordion-title-font-weight: var(
194
+ --#{root-defaults.$prefix}accordion-title-font-weight,
195
+ #{typography.$h5-font-weight}
196
+ );
197
+ $accordion-title-font-family: var(
198
+ --#{root-defaults.$prefix}accordion-title-font-family,
199
+ #{typography.$h5-font-family}
200
+ );
201
+ $accordion-title-line-height: var(
202
+ --#{root-defaults.$prefix}accordion-title-line-height,
203
+ #{typography.$h5-line-height}
204
+ );
205
+
206
+ // Accordion item content properties.
207
+ $accordion-item-content-padding-x: var(
208
+ --#{root-defaults.$prefix}accordion-item-content-padding-x,
209
+ #{map.get(root-variables.$spacers, 5)}
210
+ );
211
+ $accordion-item-content-padding-y: var(
212
+ --#{root-defaults.$prefix}accordion-item-content-padding-y,
213
+ #{map.get(root-variables.$spacers, 5)}
214
+ );
215
+ $accordion-item-content-padding: var(
216
+ --#{root-defaults.$prefix}accordion-item-content-padding,
217
+ #{$accordion-item-content-padding-y} #{$accordion-item-content-padding-x}
218
+ );
219
+ $accordion-item-content-column-gap: var(
220
+ --#{root-defaults.$prefix}accordion-item-content-column-gap,
221
+ #{map.get(root-variables.$spacers, 3)}
222
+ );
223
+ $accordion-item-content-row-gap: var(
224
+ --#{root-defaults.$prefix}accordion-item-content-row-gap,
225
+ #{map.get(root-variables.$spacers, 0)}
226
+ );
227
+ $accordion-item-content-gap: var(
228
+ --#{root-defaults.$prefix}accordion-item-content-gap,
229
+ #{$accordion-item-content-column-gap} #{$accordion-item-content-row-gap}
230
+ );
231
+
232
+ // Accordion item body properties.
233
+ $accordion-item-body-padding-x: var(
234
+ --#{root-defaults.$prefix}accordion-item-body-padding-x,
235
+ #{map.get(root-variables.$spacers, 0)}
236
+ );
237
+ $accordion-item-body-padding-y: var(
238
+ --#{root-defaults.$prefix}accordion-item-body-padding-y,
239
+ #{map.get(root-variables.$spacers, 0)}
240
+ );
241
+ $accordion-item-body-padding: var(
242
+ --#{root-defaults.$prefix}accordion-item-body-padding,
243
+ #{$accordion-item-body-padding-y} #{$accordion-item-body-padding-x}
244
+ );
245
+
246
+ // Accordion item footer properties.
247
+ $accordion-item-footer-padding-x: var(
248
+ --#{root-defaults.$prefix}accordion-item-footer-padding-x,
249
+ #{map.get(root-variables.$spacers, 0)}
250
+ );
251
+ $accordion-item-footer-padding-y: var(
252
+ --#{root-defaults.$prefix}accordion-item-footer-padding-y,
253
+ #{map.get(root-variables.$spacers, 0)}
254
+ );
255
+ $accordion-item-footer-padding: var(
256
+ --#{root-defaults.$prefix}accordion-item-footer-padding,
257
+ #{$accordion-item-footer-padding-y} #{$accordion-item-footer-padding-x}
258
+ );
259
+
260
+ // Accordion item transition properties.
261
+ $accordion-transition-duration: var(
262
+ --#{root-defaults.$prefix}accordion-transition-duration,
263
+ #{map.get(root-variables.$transition-durations, slow)}
264
+ );
265
+ $accordion-item-toggle-transition-duration: var(
266
+ --#{root-defaults.$prefix}accordion-item-toggle-transition-duration,
267
+ #{$accordion-transition-duration}
268
+ );
269
+ $accordion-transition: var(
270
+ --#{root-defaults.$prefix}accordion-transition,
271
+ height #{map.get(root-variables.$transition-durations, slow)}
272
+ #{root-variables.$transition-timing-function}
273
+ );
274
+ $accordion-transition-reduced-motion: var(
275
+ --#{root-defaults.$prefix}accordion-transition-reduced-motion,
276
+ none
277
+ );
278
+ $accordion-item-toggle-pseudo-transition: var(
279
+ --#{root-defaults.$prefix}accordion-transition,
280
+ transform #{map.get(root-variables.$transition-durations, slow)}
281
+ #{root-variables.$transition-timing-function}
282
+ );
283
+ $accordion-item-toggle-pseudo-transition-reduced-motion: var(
284
+ --#{root-defaults.$prefix}accordion-transition-reduced-motion,
285
+ none
286
+ );
287
+ $accordion-item-content-transition: var(
288
+ --#{root-defaults.$prefix}accordion-transition,
289
+ opacity #{map.get(root-variables.$transition-durations, slow)}
290
+ #{root-variables.$transition-timing-function} transform
291
+ #{map.get(root-variables.$transition-durations, slow)}
292
+ #{root-variables.$transition-timing-function}
293
+ );
294
+ $accordion-item-content-transition-reduced-motion: var(
295
+ --#{root-defaults.$prefix}accordion-transition-reduced-motion,
296
+ opacity #{map.get(root-variables.$transition-durations, slow)}
297
+ #{root-variables.$transition-timing-function}
298
+ );
299
+
300
+ // Accordion item transform properties.
301
+ $accordion-item-content-transform: var(
302
+ --#{root-defaults.$prefix}accordion-item-content-transform,
303
+ #{defaults.$accordion-item-content-transform}
304
+ );
305
+ $accordion-item-content-open-transform: var(
306
+ --#{root-defaults.$prefix}accordion-item-content-open-transform,
307
+ #{defaults.$accordion-item-content-open-transform}
308
+ );
309
+ $accordion-item-toggle-pseudo-transform: var(
310
+ --#{root-defaults.$prefix}accordion-item-toggle-pseudo-transform,
311
+ #{defaults.$accordion-item-toggle-pseudo-transform}
312
+ );
313
+ $accordion-item-toggle-pseudo-open-transform: var(
314
+ --#{root-defaults.$prefix}accordion-item-toggle-pseudo-open-transform,
315
+ #{defaults.$accordion-item-toggle-pseudo-open-transform}
316
+ );
@@ -0,0 +1,49 @@
1
+ // @graupl/graupl alert 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
+ // Alert selectors.
12
+ $alert-selector: ".alert" !default;
13
+ $alert-theme-selector-prefix: "." !default;
14
+ $alert-body-selector: ".alert-body" !default;
15
+ $alert-header-selector: ".alert-header" !default;
16
+ $alert-footer-selector: ".alert-footer" !default;
17
+ $alert-title-selector: ".alert-title" !default;
18
+ $alert-dismisser-selector: ".alert-dismisser" !default;
19
+ $alert-hidden-selector: ".hide" !default;
20
+ $alert-shown-selector: ".show" !default;
21
+ $alert-transition-selector: ".transitioning" !default;
22
+
23
+ // Alert state theme defaults.
24
+ // This map is used to define the default colour shades for the
25
+ // themed alert components.
26
+ //
27
+ // e.g.
28
+ // Primary alerts will use primary--900 as the text colour, primary--100 as the background
29
+ // and primary--900 as the border colour.
30
+ //
31
+ // Secondary/tertiary alerts will use the same shade for their respective colours.
32
+ $base-alert-state-theme-map: (
33
+ color: 900,
34
+ background: 200,
35
+ border-color: 700,
36
+ title-color: 800,
37
+ button-border-color: transparent,
38
+ link-color: 800,
39
+ link-visited-color: 800,
40
+ link-focus-color: 800,
41
+ link-hover-color: 900,
42
+ link-active-color: 900,
43
+ link-disabled-color: 400,
44
+ );
45
+ $custom-alert-state-theme-map: () !default;
46
+ $alert-state-theme-map: map.merge(
47
+ $base-alert-state-theme-map,
48
+ $custom-alert-state-theme-map
49
+ );
@@ -0,0 +1,118 @@
1
+ // @graupl/graupl alert component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../theme/color/variables" as color;
7
+ @use "../../mixins/layer" as *;
8
+ @use "../../mixins/animation";
9
+ @use "../../functions/theme";
10
+ @use "../../base/button/mixins" as button-mixins;
11
+ @use "sass:map";
12
+
13
+ #{defaults.$alert-selector} {
14
+ @include layer(component) {
15
+ --#{root-defaults.$prefix}button-border: 0;
16
+
17
+ display: grid;
18
+ grid-template-columns: [content-start] 1fr [content-end dismiss-start] auto [dismiss-end];
19
+ grid-template-rows: [header-start] auto [header-end body-start] auto [body-end footer-start] auto [footer-end];
20
+ padding: $alert-padding;
21
+ transition: $alert-transition;
22
+ border: $alert-border;
23
+ border-radius: $alert-border-radius;
24
+ gap: $alert-gap;
25
+
26
+ &#{defaults.$alert-hidden-selector} {
27
+ display: none;
28
+ }
29
+
30
+ &#{defaults.$alert-transition-selector} {
31
+ display: grid;
32
+ opacity: 0;
33
+ }
34
+
35
+ &#{defaults.$alert-shown-selector} {
36
+ display: grid;
37
+ }
38
+
39
+ @include animation.off {
40
+ #{defaults.$alert-selector} {
41
+ --#{root-defaults.$prefix}alert-transition: #{$alert-transition-reduced-motion};
42
+ }
43
+ }
44
+ }
45
+
46
+ @include layer(theme) {
47
+ --#{root-defaults.$prefix}button-background: #{$alert-background};
48
+ --#{root-defaults.$prefix}button-focus-background: #{$alert-background};
49
+ --#{root-defaults.$prefix}link-color: #{$alert-link-color};
50
+ --#{root-defaults.$prefix}link-visited-color: #{$alert-link-visited-color};
51
+ --#{root-defaults.$prefix}link-focus-color: #{$alert-link-focus-color};
52
+ --#{root-defaults.$prefix}link-hover-color: #{$alert-link-hover-color};
53
+ --#{root-defaults.$prefix}link-active-color: #{$alert-link-active-color};
54
+ --#{root-defaults.$prefix}link-disabled-color: #{$alert-link-disabled-color};
55
+
56
+ border-color: $alert-border-color;
57
+ background-color: $alert-background;
58
+ color: $alert-color;
59
+
60
+ @each $color, $map in map.get(color.$themes, active) {
61
+ &#{defaults.$alert-theme-selector-prefix}#{$color} {
62
+ @each $prop, $shade in defaults.$alert-state-theme-map {
63
+ --#{root-defaults.$prefix}alert-#{$prop}: #{theme.get(
64
+ $color,
65
+ $shade
66
+ )};
67
+ }
68
+ }
69
+ }
70
+ }
71
+ }
72
+
73
+ #{defaults.$alert-header-selector} {
74
+ @include layer(component) {
75
+ grid-column: content;
76
+ grid-row: header;
77
+ padding: $alert-header-padding;
78
+ }
79
+ }
80
+
81
+ #{defaults.$alert-body-selector} {
82
+ @include layer(component) {
83
+ grid-column: content;
84
+ grid-row: body;
85
+ padding: $alert-body-padding;
86
+ }
87
+ }
88
+
89
+ #{defaults.$alert-footer-selector} {
90
+ @include layer(component) {
91
+ grid-column: content;
92
+ grid-row: footer;
93
+ padding: $alert-footer-padding;
94
+ }
95
+ }
96
+
97
+ #{defaults.$alert-dismisser-selector} {
98
+ @include button-mixins.apply-button;
99
+
100
+ @include layer(component) {
101
+ grid-column: dismiss;
102
+ grid-row: 1 / -1;
103
+ align-self: flex-start;
104
+ }
105
+ }
106
+
107
+ #{defaults.$alert-title-selector} {
108
+ @include layer(component) {
109
+ margin: $alert-title-margin;
110
+ }
111
+
112
+ @include layer(theme) {
113
+ color: $alert-title-color;
114
+ font-size: $alert-title-font-size;
115
+ font-weight: $alert-title-font-weight;
116
+ line-height: $alert-title-line-height;
117
+ }
118
+ }