@graupl/core 1.0.0-beta.10

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 (303) hide show
  1. package/dist/css/base/button.css +2 -0
  2. package/dist/css/base/button.css.map +1 -0
  3. package/dist/css/base/form.css +2 -0
  4. package/dist/css/base/form.css.map +1 -0
  5. package/dist/css/base/link.css +2 -0
  6. package/dist/css/base/link.css.map +1 -0
  7. package/dist/css/base/table.css +2 -0
  8. package/dist/css/base/table.css.map +1 -0
  9. package/dist/css/base.css +2 -0
  10. package/dist/css/base.css.map +1 -0
  11. package/dist/css/component/accordion.css +5 -0
  12. package/dist/css/component/accordion.css.map +1 -0
  13. package/dist/css/component/alert.css +2 -0
  14. package/dist/css/component/alert.css.map +1 -0
  15. package/dist/css/component/card.css +2 -0
  16. package/dist/css/component/card.css.map +1 -0
  17. package/dist/css/component/carousel.css +2 -0
  18. package/dist/css/component/carousel.css.map +1 -0
  19. package/dist/css/component/input-group.css +2 -0
  20. package/dist/css/component/input-group.css.map +1 -0
  21. package/dist/css/component/list.css +2 -0
  22. package/dist/css/component/list.css.map +1 -0
  23. package/dist/css/component/menu.css +2 -0
  24. package/dist/css/component/menu.css.map +1 -0
  25. package/dist/css/component/navigation.css +2 -0
  26. package/dist/css/component/navigation.css.map +1 -0
  27. package/dist/css/component.css +5 -0
  28. package/dist/css/component.css.map +1 -0
  29. package/dist/css/graupl.css +5 -0
  30. package/dist/css/graupl.css.map +1 -0
  31. package/dist/css/init.css +2 -0
  32. package/dist/css/init.css.map +1 -0
  33. package/dist/css/layout/columns.css +2 -0
  34. package/dist/css/layout/columns.css.map +1 -0
  35. package/dist/css/layout/container.css +2 -0
  36. package/dist/css/layout/container.css.map +1 -0
  37. package/dist/css/layout/flex-columns.css +2 -0
  38. package/dist/css/layout/flex-columns.css.map +1 -0
  39. package/dist/css/layout.css +5 -0
  40. package/dist/css/layout.css.map +1 -0
  41. package/dist/css/normalize.css +2 -0
  42. package/dist/css/normalize.css.map +1 -0
  43. package/dist/css/state/focus.css +2 -0
  44. package/dist/css/state/focus.css.map +1 -0
  45. package/dist/css/state.css +2 -0
  46. package/dist/css/state.css.map +1 -0
  47. package/dist/css/theme/color.css +2 -0
  48. package/dist/css/theme/color.css.map +1 -0
  49. package/dist/css/theme/typography.css +2 -0
  50. package/dist/css/theme/typography.css.map +1 -0
  51. package/dist/css/theme.css +2 -0
  52. package/dist/css/theme.css.map +1 -0
  53. package/dist/css/utilities/alignment.css +2 -0
  54. package/dist/css/utilities/alignment.css.map +1 -0
  55. package/dist/css/utilities/background.css +2 -0
  56. package/dist/css/utilities/background.css.map +1 -0
  57. package/dist/css/utilities/border.css +2 -0
  58. package/dist/css/utilities/border.css.map +1 -0
  59. package/dist/css/utilities/color.css +2 -0
  60. package/dist/css/utilities/color.css.map +1 -0
  61. package/dist/css/utilities/container.css +2 -0
  62. package/dist/css/utilities/container.css.map +1 -0
  63. package/dist/css/utilities/display.css +2 -0
  64. package/dist/css/utilities/display.css.map +1 -0
  65. package/dist/css/utilities/flex.css +2 -0
  66. package/dist/css/utilities/flex.css.map +1 -0
  67. package/dist/css/utilities/gradient.css +2 -0
  68. package/dist/css/utilities/gradient.css.map +1 -0
  69. package/dist/css/utilities/height.css +2 -0
  70. package/dist/css/utilities/height.css.map +1 -0
  71. package/dist/css/utilities/inset.css +2 -0
  72. package/dist/css/utilities/inset.css.map +1 -0
  73. package/dist/css/utilities/justification.css +2 -0
  74. package/dist/css/utilities/justification.css.map +1 -0
  75. package/dist/css/utilities/list.css +2 -0
  76. package/dist/css/utilities/list.css.map +1 -0
  77. package/dist/css/utilities/order.css +2 -0
  78. package/dist/css/utilities/order.css.map +1 -0
  79. package/dist/css/utilities/position.css +2 -0
  80. package/dist/css/utilities/position.css.map +1 -0
  81. package/dist/css/utilities/ratio.css +2 -0
  82. package/dist/css/utilities/ratio.css.map +1 -0
  83. package/dist/css/utilities/spacing.css +2 -0
  84. package/dist/css/utilities/spacing.css.map +1 -0
  85. package/dist/css/utilities/typography.css +2 -0
  86. package/dist/css/utilities/typography.css.map +1 -0
  87. package/dist/css/utilities/visibility.css +2 -0
  88. package/dist/css/utilities/visibility.css.map +1 -0
  89. package/dist/css/utilities/visually-hidden.css +2 -0
  90. package/dist/css/utilities/visually-hidden.css.map +1 -0
  91. package/dist/css/utilities/width.css +2 -0
  92. package/dist/css/utilities/width.css.map +1 -0
  93. package/dist/css/utilities/z-index.css +2 -0
  94. package/dist/css/utilities/z-index.css.map +1 -0
  95. package/dist/css/utilities.css +2 -0
  96. package/dist/css/utilities.css.map +1 -0
  97. package/package.json +58 -0
  98. package/scss/base/button.scss +3 -0
  99. package/scss/base/form.scss +3 -0
  100. package/scss/base/link.scss +3 -0
  101. package/scss/base/table.scss +3 -0
  102. package/scss/base.scss +3 -0
  103. package/scss/component/accordion.scss +3 -0
  104. package/scss/component/alert.scss +3 -0
  105. package/scss/component/card.scss +3 -0
  106. package/scss/component/carousel.scss +3 -0
  107. package/scss/component/input-group.scss +3 -0
  108. package/scss/component/list.scss +3 -0
  109. package/scss/component/menu.scss +3 -0
  110. package/scss/component/navigation.scss +3 -0
  111. package/scss/component.scss +3 -0
  112. package/scss/graupl.scss +3 -0
  113. package/scss/init.scss +3 -0
  114. package/scss/layout/columns.scss +3 -0
  115. package/scss/layout/container.scss +3 -0
  116. package/scss/layout/flex-columns.scss +3 -0
  117. package/scss/layout.scss +3 -0
  118. package/scss/normalize.scss +3 -0
  119. package/scss/state/focus.scss +3 -0
  120. package/scss/state.scss +3 -0
  121. package/scss/theme/color.scss +3 -0
  122. package/scss/theme/typography.scss +3 -0
  123. package/scss/theme.scss +3 -0
  124. package/scss/utilities/alignment.scss +3 -0
  125. package/scss/utilities/background.scss +3 -0
  126. package/scss/utilities/border.scss +3 -0
  127. package/scss/utilities/color.scss +3 -0
  128. package/scss/utilities/container.scss +3 -0
  129. package/scss/utilities/display.scss +3 -0
  130. package/scss/utilities/flex.scss +3 -0
  131. package/scss/utilities/gradient.scss +3 -0
  132. package/scss/utilities/height.scss +3 -0
  133. package/scss/utilities/inset.scss +3 -0
  134. package/scss/utilities/justification.scss +3 -0
  135. package/scss/utilities/list.scss +3 -0
  136. package/scss/utilities/order.scss +3 -0
  137. package/scss/utilities/position.scss +3 -0
  138. package/scss/utilities/ratio.scss +3 -0
  139. package/scss/utilities/spacing.scss +3 -0
  140. package/scss/utilities/typography.scss +3 -0
  141. package/scss/utilities/visibility.scss +3 -0
  142. package/scss/utilities/visually-hidden.scss +3 -0
  143. package/scss/utilities/width.scss +3 -0
  144. package/scss/utilities/z-index.scss +3 -0
  145. package/scss/utilities.scss +3 -0
  146. package/src/js/accordion/Accordion.js +1163 -0
  147. package/src/js/accordion/AccordionItem.js +496 -0
  148. package/src/js/accordion/index.js +10 -0
  149. package/src/js/alert/Alert.js +581 -0
  150. package/src/js/alert/index.js +11 -0
  151. package/src/js/carousel/Carousel.js +1427 -0
  152. package/src/js/carousel/index.js +10 -0
  153. package/src/js/domHelpers.js +37 -0
  154. package/src/js/eventHandlers.js +39 -0
  155. package/src/js/navigation/index.js +36 -0
  156. package/src/js/storage.js +106 -0
  157. package/src/js/validate.js +225 -0
  158. package/src/scss/_defaults.scss +184 -0
  159. package/src/scss/_index.scss +15 -0
  160. package/src/scss/_init.scss +6 -0
  161. package/src/scss/_normalize.scss +197 -0
  162. package/src/scss/_variables.scss +95 -0
  163. package/src/scss/base/_index.scss +6 -0
  164. package/src/scss/base/button/_defaults.scss +49 -0
  165. package/src/scss/base/button/_index.scss +206 -0
  166. package/src/scss/base/button/_mixins.scss +104 -0
  167. package/src/scss/base/button/_variables.scss +252 -0
  168. package/src/scss/base/form/_defaults.scss +24 -0
  169. package/src/scss/base/form/_index.scss +227 -0
  170. package/src/scss/base/form/_variables.scss +245 -0
  171. package/src/scss/base/link/_defaults.scss +35 -0
  172. package/src/scss/base/link/_index.scss +245 -0
  173. package/src/scss/base/link/_variables.scss +370 -0
  174. package/src/scss/base/table/_defaults.scss +68 -0
  175. package/src/scss/base/table/_index.scss +314 -0
  176. package/src/scss/base/table/_variables.scss +309 -0
  177. package/src/scss/component/_index.scss +10 -0
  178. package/src/scss/component/accordion/_defaults.scss +40 -0
  179. package/src/scss/component/accordion/_index.scss +198 -0
  180. package/src/scss/component/accordion/_variables.scss +356 -0
  181. package/src/scss/component/alert/_defaults.scss +49 -0
  182. package/src/scss/component/alert/_index.scss +119 -0
  183. package/src/scss/component/alert/_variables.scss +200 -0
  184. package/src/scss/component/card/_defaults.scss +32 -0
  185. package/src/scss/component/card/_index.scss +212 -0
  186. package/src/scss/component/card/_variables.scss +216 -0
  187. package/src/scss/component/carousel/_defaults.scss +43 -0
  188. package/src/scss/component/carousel/_index.scss +192 -0
  189. package/src/scss/component/carousel/_variables.scss +104 -0
  190. package/src/scss/component/input-group/_defaults.scss +30 -0
  191. package/src/scss/component/input-group/_index.scss +47 -0
  192. package/src/scss/component/input-group/_variables.scss +66 -0
  193. package/src/scss/component/list/_defaults.scss +15 -0
  194. package/src/scss/component/list/_index.scss +52 -0
  195. package/src/scss/component/list/_variables.scss +236 -0
  196. package/src/scss/component/menu/_defaults.scss +57 -0
  197. package/src/scss/component/menu/_index.scss +308 -0
  198. package/src/scss/component/menu/_variables.scss +642 -0
  199. package/src/scss/component/navigation/_defaults.scss +23 -0
  200. package/src/scss/component/navigation/_index.scss +190 -0
  201. package/src/scss/component/navigation/_variables.scss +290 -0
  202. package/src/scss/functions/_container.scss +38 -0
  203. package/src/scss/functions/_important.scss +36 -0
  204. package/src/scss/functions/_screen.scss +38 -0
  205. package/src/scss/functions/_theme.scss +39 -0
  206. package/src/scss/functions/_utility.scss +28 -0
  207. package/src/scss/layout/_index.scss +5 -0
  208. package/src/scss/layout/columns/_defaults.scss +24 -0
  209. package/src/scss/layout/columns/_index.scss +137 -0
  210. package/src/scss/layout/columns/_variables.scss +55 -0
  211. package/src/scss/layout/container/_defaults.scss +35 -0
  212. package/src/scss/layout/container/_index.scss +628 -0
  213. package/src/scss/layout/container/_variables.scss +114 -0
  214. package/src/scss/layout/flex-columns/_defaults.scss +28 -0
  215. package/src/scss/layout/flex-columns/_index.scss +184 -0
  216. package/src/scss/layout/flex-columns/_variables.scss +30 -0
  217. package/src/scss/mixins/_animation.scss +15 -0
  218. package/src/scss/mixins/_container.scss +80 -0
  219. package/src/scss/mixins/_layer.scss +16 -0
  220. package/src/scss/mixins/_screen.scss +77 -0
  221. package/src/scss/mixins/_state.scss +18 -0
  222. package/src/scss/mixins/_theme.scss +15 -0
  223. package/src/scss/mixins/_utility.scss +185 -0
  224. package/src/scss/mixins/_visually-hidden.scss +30 -0
  225. package/src/scss/state/_index.scss +3 -0
  226. package/src/scss/state/focus/_defaults.scss +9 -0
  227. package/src/scss/state/focus/_index.scss +42 -0
  228. package/src/scss/state/focus/_mixins.scss +13 -0
  229. package/src/scss/state/focus/_variables.scss +50 -0
  230. package/src/scss/theme/_index.scss +4 -0
  231. package/src/scss/theme/color/_defaults.scss +143 -0
  232. package/src/scss/theme/color/_index.scss +42 -0
  233. package/src/scss/theme/color/_variables.scss +133 -0
  234. package/src/scss/theme/typography/_defaults.scss +54 -0
  235. package/src/scss/theme/typography/_index.scss +120 -0
  236. package/src/scss/theme/typography/_variables.scss +248 -0
  237. package/src/scss/utilities/_index.scss +23 -0
  238. package/src/scss/utilities/_template/_defaults.scss +41 -0
  239. package/src/scss/utilities/_template/_index.scss +171 -0
  240. package/src/scss/utilities/_template/_variables.scss +6 -0
  241. package/src/scss/utilities/alignment/_defaults.scss +76 -0
  242. package/src/scss/utilities/alignment/_index.scss +336 -0
  243. package/src/scss/utilities/alignment/_variables.scss +6 -0
  244. package/src/scss/utilities/background/_defaults.scss +122 -0
  245. package/src/scss/utilities/background/_index.scss +634 -0
  246. package/src/scss/utilities/background/_variables.scss +6 -0
  247. package/src/scss/utilities/border/_defaults.scss +73 -0
  248. package/src/scss/utilities/border/_index.scss +558 -0
  249. package/src/scss/utilities/border/_variables.scss +6 -0
  250. package/src/scss/utilities/color/_defaults.scss +49 -0
  251. package/src/scss/utilities/color/_index.scss +469 -0
  252. package/src/scss/utilities/color/_variables.scss +6 -0
  253. package/src/scss/utilities/container/_defaults.scss +40 -0
  254. package/src/scss/utilities/container/_index.scss +174 -0
  255. package/src/scss/utilities/container/_variables.scss +6 -0
  256. package/src/scss/utilities/display/_defaults.scss +47 -0
  257. package/src/scss/utilities/display/_index.scss +184 -0
  258. package/src/scss/utilities/display/_variables.scss +6 -0
  259. package/src/scss/utilities/flex/_defaults.scss +99 -0
  260. package/src/scss/utilities/flex/_index.scss +486 -0
  261. package/src/scss/utilities/flex/_variables.scss +6 -0
  262. package/src/scss/utilities/gradient/_defaults.scss +70 -0
  263. package/src/scss/utilities/gradient/_index.scss +696 -0
  264. package/src/scss/utilities/gradient/_variables.scss +29 -0
  265. package/src/scss/utilities/height/_defaults.scss +54 -0
  266. package/src/scss/utilities/height/_index.scss +525 -0
  267. package/src/scss/utilities/height/_variables.scss +6 -0
  268. package/src/scss/utilities/inset/_defaults.scss +55 -0
  269. package/src/scss/utilities/inset/_index.scss +258 -0
  270. package/src/scss/utilities/inset/_variables.scss +6 -0
  271. package/src/scss/utilities/justification/_defaults.scss +73 -0
  272. package/src/scss/utilities/justification/_index.scss +333 -0
  273. package/src/scss/utilities/justification/_variables.scss +6 -0
  274. package/src/scss/utilities/list/_defaults.scss +53 -0
  275. package/src/scss/utilities/list/_index.scss +253 -0
  276. package/src/scss/utilities/list/_variables.scss +6 -0
  277. package/src/scss/utilities/order/_defaults.scss +36 -0
  278. package/src/scss/utilities/order/_index.scss +246 -0
  279. package/src/scss/utilities/order/_variables.scss +6 -0
  280. package/src/scss/utilities/position/_defaults.scss +41 -0
  281. package/src/scss/utilities/position/_index.scss +178 -0
  282. package/src/scss/utilities/position/_variables.scss +6 -0
  283. package/src/scss/utilities/ratio/_defaults.scss +42 -0
  284. package/src/scss/utilities/ratio/_index.scss +188 -0
  285. package/src/scss/utilities/ratio/_variables.scss +9 -0
  286. package/src/scss/utilities/spacing/_defaults.scss +64 -0
  287. package/src/scss/utilities/spacing/_index.scss +970 -0
  288. package/src/scss/utilities/spacing/_variables.scss +6 -0
  289. package/src/scss/utilities/typography/_defaults.scss +58 -0
  290. package/src/scss/utilities/typography/_index.scss +1089 -0
  291. package/src/scss/utilities/typography/_variables.scss +6 -0
  292. package/src/scss/utilities/visibility/_defaults.scss +39 -0
  293. package/src/scss/utilities/visibility/_index.scss +173 -0
  294. package/src/scss/utilities/visibility/_variables.scss +6 -0
  295. package/src/scss/utilities/visually-hidden/_defaults.scss +29 -0
  296. package/src/scss/utilities/visually-hidden/_index.scss +189 -0
  297. package/src/scss/utilities/visually-hidden/_variables.scss +6 -0
  298. package/src/scss/utilities/width/_defaults.scss +54 -0
  299. package/src/scss/utilities/width/_index.scss +525 -0
  300. package/src/scss/utilities/width/_variables.scss +6 -0
  301. package/src/scss/utilities/z-index/_defaults.scss +40 -0
  302. package/src/scss/utilities/z-index/_index.scss +173 -0
  303. package/src/scss/utilities/z-index/_variables.scss +6 -0
@@ -0,0 +1,119 @@
1
+ // @graupl/core 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
+ @include layer(base) {
14
+ #{defaults.$alert-dismisser-selector} {
15
+ @include button-mixins.apply-base;
16
+ }
17
+ }
18
+
19
+ @include layer(component) {
20
+ #{defaults.$alert-selector} {
21
+ --#{root-defaults.$prefix}button-border: 0;
22
+
23
+ display: grid;
24
+ grid-template-columns: [content-start] 1fr [content-end dismiss-start] auto [dismiss-end];
25
+ grid-template-rows: [header-start] auto [header-end body-start] auto [body-end footer-start] auto [footer-end];
26
+ padding: $alert-padding;
27
+ transition: $alert-transition;
28
+ border-width: $alert-border-width;
29
+ border-style: $alert-border-style;
30
+ border-radius: $alert-border-radius;
31
+ gap: $alert-gap;
32
+
33
+ &#{defaults.$alert-hidden-selector} {
34
+ display: none;
35
+ }
36
+
37
+ &#{defaults.$alert-transition-selector} {
38
+ display: grid;
39
+ opacity: 0;
40
+ }
41
+
42
+ &#{defaults.$alert-shown-selector} {
43
+ display: grid;
44
+ }
45
+
46
+ @include animation.off {
47
+ #{defaults.$alert-selector} {
48
+ --#{root-defaults.$prefix}alert-transition: #{$alert-transition-reduced-motion};
49
+ }
50
+ }
51
+ }
52
+
53
+ #{defaults.$alert-header-selector} {
54
+ grid-column: content;
55
+ grid-row: header;
56
+ padding: $alert-header-padding;
57
+ }
58
+
59
+ #{defaults.$alert-body-selector} {
60
+ grid-column: content;
61
+ grid-row: body;
62
+ padding: $alert-body-padding;
63
+ }
64
+
65
+ #{defaults.$alert-footer-selector} {
66
+ grid-column: content;
67
+ grid-row: footer;
68
+ padding: $alert-footer-padding;
69
+ }
70
+
71
+ #{defaults.$alert-dismisser-selector} {
72
+ grid-column: dismiss;
73
+ grid-row: 1 / -1;
74
+ align-self: flex-start;
75
+ }
76
+
77
+ #{defaults.$alert-title-selector} {
78
+ margin: $alert-title-margin;
79
+ }
80
+ }
81
+
82
+ @include layer(theme) {
83
+ #{defaults.$alert-selector} {
84
+ --#{root-defaults.$prefix}button-background: #{$alert-background};
85
+ --#{root-defaults.$prefix}button-focus-background: #{$alert-background};
86
+ --#{root-defaults.$prefix}link-color: #{$alert-link-color};
87
+ --#{root-defaults.$prefix}link-visited-color: #{$alert-link-visited-color};
88
+ --#{root-defaults.$prefix}link-focus-color: #{$alert-link-focus-color};
89
+ --#{root-defaults.$prefix}link-hover-color: #{$alert-link-hover-color};
90
+ --#{root-defaults.$prefix}link-active-color: #{$alert-link-active-color};
91
+ --#{root-defaults.$prefix}link-disabled-color: #{$alert-link-disabled-color};
92
+
93
+ border-color: $alert-border-color;
94
+ background-color: $alert-background;
95
+ color: $alert-color;
96
+
97
+ @each $color, $map in map.get(color.$themes, active) {
98
+ &#{defaults.$alert-theme-selector-prefix}#{$color} {
99
+ @each $prop, $shade in defaults.$alert-state-theme-map {
100
+ --#{root-defaults.$prefix}alert-#{$prop}: #{theme.get(
101
+ $color,
102
+ $shade
103
+ )};
104
+ }
105
+ }
106
+ }
107
+ }
108
+
109
+ #{defaults.$alert-dismisser-selector} {
110
+ @include button-mixins.apply-theme;
111
+ }
112
+
113
+ #{defaults.$alert-title-selector} {
114
+ color: $alert-title-color;
115
+ font-size: $alert-title-font-size;
116
+ font-weight: $alert-title-font-weight;
117
+ line-height: $alert-title-line-height;
118
+ }
119
+ }
@@ -0,0 +1,200 @@
1
+ // @graupl/core 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.$background}
45
+ );
46
+ $alert-color: var(--#{root-defaults.$prefix}alert-color, #{color.$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-border-top-left-radius: var(
66
+ --#{root-defaults.$prefix}alert-border-top-left-radius,
67
+ #{root-variables.$border-top-left-radius}
68
+ );
69
+ $alert-border-top-right-radius: var(
70
+ --#{root-defaults.$prefix}alert-border-top-right-radius,
71
+ #{root-variables.$border-top-right-radius}
72
+ );
73
+ $alert-border-bottom-left-radius: var(
74
+ --#{root-defaults.$prefix}alert-border-bottom-left-radius,
75
+ #{root-variables.$border-bottom-left-radius}
76
+ );
77
+ $alert-border-bottom-right-radius: var(
78
+ --#{root-defaults.$prefix}alert-border-bottom-right-radius,
79
+ #{root-variables.$border-bottom-right-radius}
80
+ );
81
+ $alert-border-radius: var(
82
+ --#{root-defaults.$prefix}alert-border-radius,
83
+ #{$alert-border-top-left-radius} #{$alert-border-top-right-radius}
84
+ #{$alert-border-bottom-right-radius} #{$alert-border-bottom-left-radius}
85
+ );
86
+ $alert-border-top-width: var(
87
+ --#{root-defaults.$prefix}alert-border-top-width,
88
+ #{root-variables.$border-top-width}
89
+ );
90
+ $alert-border-right-width: var(
91
+ --#{root-defaults.$prefix}alert-border-right-width,
92
+ #{root-variables.$border-right-width}
93
+ );
94
+ $alert-border-bottom-width: var(
95
+ --#{root-defaults.$prefix}alert-border-bottom-width,
96
+ #{root-variables.$border-bottom-width}
97
+ );
98
+ $alert-border-left-width: var(
99
+ --#{root-defaults.$prefix}alert-border-left-width,
100
+ #{root-variables.$border-left-width}
101
+ );
102
+ $alert-border-width: var(
103
+ --#{root-defaults.$prefix}alert-border-width,
104
+ #{$alert-border-top-width} #{$alert-border-right-width}
105
+ #{$alert-border-bottom-width} #{$alert-border-left-width}
106
+ );
107
+ $alert-border-top-style: var(
108
+ --#{root-defaults.$prefix}alert-border-top-style,
109
+ #{root-variables.$border-top-style}
110
+ );
111
+ $alert-border-right-style: var(
112
+ --#{root-defaults.$prefix}alert-border-right-style,
113
+ #{root-variables.$border-right-style}
114
+ );
115
+ $alert-border-bottom-style: var(
116
+ --#{root-defaults.$prefix}alert-border-bottom-style,
117
+ #{root-variables.$border-bottom-style}
118
+ );
119
+ $alert-border-left-style: var(
120
+ --#{root-defaults.$prefix}alert-border-left-style,
121
+ #{root-variables.$border-left-style}
122
+ );
123
+ $alert-border-style: var(
124
+ --#{root-defaults.$prefix}alert-border-style,
125
+ #{$alert-border-top-style} #{$alert-border-right-style}
126
+ #{$alert-border-bottom-style} #{$alert-border-left-style}
127
+ );
128
+
129
+ // Alert transition properties.
130
+ $alert-transition: var(
131
+ --#{root-defaults.$prefix}alert-transition,
132
+ opacity #{map.get(root-variables.$transition-durations, fast)}
133
+ #{root-variables.$transition-timing-function},
134
+ transform #{map.get(root-variables.$transition-durations, fast)}
135
+ #{root-variables.$transition-timing-function}
136
+ );
137
+ $alert-transition-reduced-motion: var(
138
+ --#{root-defaults.$prefix}alert-transition-reduced-motion,
139
+ opacity #{map.get(root-variables.$transition-durations, fast)}
140
+ #{root-variables.$transition-timing-function}
141
+ );
142
+
143
+ // Alert header properties.
144
+ $alert-header-padding-x: var(
145
+ --#{root-defaults.$prefix}alert-header-padding-x,
146
+ 0
147
+ );
148
+ $alert-header-padding-y: var(
149
+ --#{root-defaults.$prefix}alert-header-padding-y,
150
+ 0
151
+ );
152
+ $alert-header-padding: var(
153
+ --#{root-defaults.$prefix}alert-header-padding,
154
+ #{$alert-header-padding-y} #{$alert-header-padding-x}
155
+ );
156
+
157
+ // Alert title properties.
158
+ $alert-title-color: var(
159
+ --#{root-defaults.$prefix}alert-title-color,
160
+ #{$alert-color}
161
+ );
162
+ $alert-title-font-size: var(
163
+ --#{root-defaults.$prefix}alert-title-font-size,
164
+ #{typography.$h4-font-size}
165
+ );
166
+ $alert-title-font-weight: var(
167
+ --#{root-defaults.$prefix}alert-title-font-weight,
168
+ #{typography.$h4-font-weight}
169
+ );
170
+ $alert-title-font-family: var(
171
+ --#{root-defaults.$prefix}alert-title-font-family,
172
+ #{typography.$h4-font-family}
173
+ );
174
+ $alert-title-line-height: var(
175
+ --#{root-defaults.$prefix}alert-title-line-height,
176
+ #{typography.$h4-line-height}
177
+ );
178
+ $alert-title-margin: var(--#{root-defaults.$prefix}alert-title-margin, 0 0 0 0);
179
+
180
+ // Alert body properties.
181
+ $alert-body-padding-x: var(--#{root-defaults.$prefix}alert-body-padding-x, 0);
182
+ $alert-body-padding-y: var(--#{root-defaults.$prefix}alert-body-padding-y, 0);
183
+ $alert-body-padding: var(
184
+ --#{root-defaults.$prefix}alert-body-padding,
185
+ #{$alert-body-padding-y} #{$alert-body-padding-x}
186
+ );
187
+
188
+ // Alert footer properties.
189
+ $alert-footer-padding-x: var(
190
+ --#{root-defaults.$prefix}alert-footer-padding-x,
191
+ 0
192
+ );
193
+ $alert-footer-padding-y: var(
194
+ --#{root-defaults.$prefix}alert-footer-padding-y,
195
+ 0
196
+ );
197
+ $alert-footer-padding: var(
198
+ --#{root-defaults.$prefix}alert-footer-padding,
199
+ #{$alert-footer-padding-y} #{$alert-footer-padding-x}
200
+ );
@@ -0,0 +1,32 @@
1
+ // @graupl/core 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,212 @@
1
+ // @graupl/core 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/container";
9
+
10
+ @include layer(component) {
11
+ #{defaults.$card-selector} {
12
+ display: grid;
13
+ position: relative;
14
+ grid-template-columns: [image-start content-start] 1fr [image-end content-end];
15
+ padding: $card-padding;
16
+ transform: $card-transform;
17
+ transition: $card-transition;
18
+ border-width: $card-border-width;
19
+ border-style: $card-border-style;
20
+ border-radius: $card-border-radius;
21
+ gap: $card-gap;
22
+ isolation: isolate;
23
+
24
+ &,
25
+ &#{defaults.$vertical-card-top-selector} {
26
+ grid-template-rows:
27
+ [image-start]
28
+ $card-image-ratio
29
+ [image-end content-start]
30
+ $card-content-ratio
31
+ [content-end];
32
+ }
33
+
34
+ &#{defaults.$vertical-card-bottom-selector},
35
+ &#{defaults.$inverse-card-selector} {
36
+ grid-template-rows:
37
+ [content-start]
38
+ $card-content-ratio
39
+ [content-end image-start]
40
+ $card-image-ratio
41
+ [image-end];
42
+ }
43
+
44
+ &:hover {
45
+ --#{root-defaults.$prefix}card-transform: #{$card-hover-transform};
46
+ }
47
+
48
+ &#{defaults.$horizontal-card-selector} {
49
+ &,
50
+ &#{defaults.$horizontal-card-left-selector} {
51
+ --#{root-defaults.$prefix}card-content-ratio: #{$horizontal-card-content-ratio};
52
+ --#{root-defaults.$prefix}card-image-ratio: #{$horizontal-card-image-ratio};
53
+
54
+ grid-template-columns:
55
+ [image-start]
56
+ $card-image-ratio
57
+ [image-end content-start]
58
+ $card-content-ratio
59
+ [content-end];
60
+ grid-template-rows: [image-start content-start] 1fr [image-end content-end];
61
+
62
+ #{defaults.$card-image-selector} img {
63
+ border-radius: calc(
64
+ $card-border-top-left-radius - min(
65
+ $card-border-top-width,
66
+ $card-border-left-width
67
+ )
68
+ )
69
+ 0 0
70
+ calc(
71
+ $card-border-bottom-left-radius - min(
72
+ $card-border-bottom-width,
73
+ $card-border-left-width
74
+ )
75
+ );
76
+ }
77
+ }
78
+
79
+ &#{defaults.$horizontal-card-right-selector},
80
+ &#{defaults.$inverse-card-selector} {
81
+ grid-template-columns:
82
+ [content-start]
83
+ $card-content-ratio
84
+ [content-end image-start]
85
+ $card-image-ratio
86
+ [image-end];
87
+
88
+ #{defaults.$card-image-selector} img {
89
+ border-radius: 0
90
+ calc(
91
+ $card-border-top-right-radius - min(
92
+ $card-border-top-width,
93
+ $card-border-right-width
94
+ )
95
+ )
96
+ calc(
97
+ $card-border-bottom-right-radius - min(
98
+ $card-border-bottom-width,
99
+ $card-border-right-width
100
+ )
101
+ )
102
+ 0;
103
+ }
104
+ }
105
+ }
106
+ }
107
+
108
+ #{defaults.$card-image-selector} {
109
+ grid-area: image;
110
+ padding: $card-image-padding;
111
+
112
+ img {
113
+ width: 100%;
114
+ height: 100%;
115
+ border-radius: calc(
116
+ $card-border-top-left-radius - min(
117
+ $card-border-top-width,
118
+ $card-border-left-width
119
+ )
120
+ )
121
+ calc(
122
+ $card-border-top-right-radius - min(
123
+ $card-border-top-width,
124
+ $card-border-right-width
125
+ )
126
+ )
127
+ 0 0;
128
+ object-fit: cover;
129
+ }
130
+ }
131
+
132
+ #{defaults.$card-content-selector} {
133
+ display: flex;
134
+ grid-area: content;
135
+ flex-direction: column;
136
+ padding: $card-content-padding;
137
+ gap: $card-content-gap;
138
+ }
139
+
140
+ #{defaults.$card-body-selector} {
141
+ flex: 1 0 auto;
142
+ }
143
+
144
+ #{defaults.$card-footer-selector} {
145
+ flex: 0 0 auto;
146
+ }
147
+
148
+ #{defaults.$card-title-selector} {
149
+ flex: 0 0 auto;
150
+ }
151
+
152
+ @include container.trigger(force-vertical-card) {
153
+ #{defaults.$card-selector} {
154
+ &#{defaults.$horizontal-card-selector} {
155
+ &,
156
+ &#{defaults.$horizontal-card-left-selector},
157
+ &#{defaults.$vertical-card-top-selector},
158
+ &#{defaults.$horizontal-card-right-selector},
159
+ &#{defaults.$vertical-card-bottom-selector},
160
+ &#{defaults.$inverse-card-selector} {
161
+ --#{root-defaults.$prefix}horizontal-card-image-ratio: #{defaults.$card-image-ratio};
162
+ --#{root-defaults.$prefix}horizontal-card-content-ratio: #{defaults.$card-content-ratio};
163
+
164
+ grid-template-columns: [image-start content-start] 1fr [image-end content-end];
165
+ }
166
+
167
+ &,
168
+ &#{defaults.$horizontal-card-left-selector},
169
+ &#{defaults.$horizontal-card-right-selector},
170
+ &#{defaults.$vertical-card-top-selector} {
171
+ grid-template-rows:
172
+ [image-start]
173
+ $card-image-ratio
174
+ [image-end content-start]
175
+ $card-content-ratio
176
+ [content-end];
177
+ }
178
+
179
+ &#{defaults.$vertical-card-bottom-selector},
180
+ &#{defaults.$inverse-card-selector} {
181
+ grid-template-rows:
182
+ [content-start]
183
+ $card-content-ratio
184
+ [content-end image-start]
185
+ $card-image-ratio
186
+ [image-end];
187
+ }
188
+ }
189
+ }
190
+ }
191
+
192
+ @include animation.off {
193
+ #{defaults.$card-selector} {
194
+ --#{root-defaults.$prefix}card-transition: #{$card-transition-reduced-motion};
195
+ }
196
+ }
197
+ }
198
+
199
+ @include layer(theme) {
200
+ #{defaults.$card-selector} {
201
+ border-color: $card-border-color;
202
+ background: $card-background;
203
+ color: $card-color;
204
+ }
205
+
206
+ #{defaults.$card-title-selector} {
207
+ color: $card-title-color;
208
+ font-size: $card-title-font-size;
209
+ font-weight: $card-title-font-weight;
210
+ line-height: $card-title-line-height;
211
+ }
212
+ }