@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,216 @@
1
+ // @graupl/core 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.$background}
64
+ );
65
+ $card-color: var(--#{root-defaults.$prefix}card-color, #{color.$color});
66
+
67
+ // Card border-properties.
68
+ $card-border-color: var(
69
+ --#{root-defaults.$prefix}card-border-color,
70
+ #{$card-color}
71
+ );
72
+ $card-border-top-left-radius: var(
73
+ --#{root-defaults.$prefix}card-border-top-left-radius,
74
+ #{root-variables.$border-top-left-radius}
75
+ );
76
+ $card-border-top-right-radius: var(
77
+ --#{root-defaults.$prefix}card-border-top-right-radius,
78
+ #{root-variables.$border-top-right-radius}
79
+ );
80
+ $card-border-bottom-left-radius: var(
81
+ --#{root-defaults.$prefix}card-border-bottom-left-radius,
82
+ #{root-variables.$border-bottom-left-radius}
83
+ );
84
+ $card-border-bottom-right-radius: var(
85
+ --#{root-defaults.$prefix}card-border-bottom-right-radius,
86
+ #{root-variables.$border-bottom-right-radius}
87
+ );
88
+ $card-border-radius: var(
89
+ --#{root-defaults.$prefix}card-border-radius,
90
+ #{$card-border-top-left-radius} #{$card-border-top-right-radius}
91
+ #{$card-border-bottom-right-radius} #{$card-border-bottom-left-radius}
92
+ );
93
+ $card-border-top-width: var(
94
+ --#{root-defaults.$prefix}card-border-top-width,
95
+ #{root-variables.$border-top-width}
96
+ );
97
+ $card-border-right-width: var(
98
+ --#{root-defaults.$prefix}card-border-right-width,
99
+ #{root-variables.$border-right-width}
100
+ );
101
+ $card-border-bottom-width: var(
102
+ --#{root-defaults.$prefix}card-border-bottom-width,
103
+ #{root-variables.$border-bottom-width}
104
+ );
105
+ $card-border-left-width: var(
106
+ --#{root-defaults.$prefix}card-border-left-width,
107
+ #{root-variables.$border-left-width}
108
+ );
109
+ $card-border-width: var(
110
+ --#{root-defaults.$prefix}card-border-width,
111
+ #{$card-border-top-width} #{$card-border-right-width}
112
+ #{$card-border-bottom-width} #{$card-border-left-width}
113
+ );
114
+ $card-border-top-style: var(
115
+ --#{root-defaults.$prefix}card-border-top-style,
116
+ #{root-variables.$border-top-style}
117
+ );
118
+ $card-border-right-style: var(
119
+ --#{root-defaults.$prefix}card-border-right-style,
120
+ #{root-variables.$border-right-style}
121
+ );
122
+ $card-border-bottom-style: var(
123
+ --#{root-defaults.$prefix}card-border-bottom-style,
124
+ #{root-variables.$border-bottom-style}
125
+ );
126
+ $card-border-left-style: var(
127
+ --#{root-defaults.$prefix}card-border-left-style,
128
+ #{root-variables.$border-left-style}
129
+ );
130
+ $card-border-style: var(
131
+ --#{root-defaults.$prefix}card-border-style,
132
+ #{$card-border-top-style} #{$card-border-right-style}
133
+ #{$card-border-bottom-style} #{$card-border-left-style}
134
+ );
135
+
136
+ // Card layout properties.
137
+ $card-content-ratio: var(
138
+ --#{root-defaults.$prefix}card-content-ratio,
139
+ defaults.$card-content-ratio
140
+ );
141
+ $card-image-ratio: var(
142
+ --#{root-defaults.$prefix}card-image-ratio,
143
+ defaults.$card-image-ratio
144
+ );
145
+ $horizontal-card-content-ratio: var(
146
+ --#{root-defaults.$prefix}horizontal-card-content-ratio,
147
+ defaults.$horizontal-card-content-ratio
148
+ );
149
+ $horizontal-card-image-ratio: var(
150
+ --#{root-defaults.$prefix}horizontal-card-image-ratio,
151
+ defaults.$horizontal-card-image-ratio
152
+ );
153
+
154
+ // Card image properties.
155
+ $card-image-padding-x: var(
156
+ --#{root-defaults.$prefix}card-image-padding-x,
157
+ #{map.get(root-variables.$spacers, 0)}
158
+ );
159
+ $card-image-padding-y: var(
160
+ --#{root-defaults.$prefix}card-image-padding-y,
161
+ #{map.get(root-variables.$spacers, 0)}
162
+ );
163
+ $card-image-padding: var(
164
+ --#{root-defaults.$prefix}card-image-padding,
165
+ #{$card-image-padding-y} #{$card-image-padding-x}
166
+ );
167
+
168
+ // Card content properties.
169
+ $card-content-padding-x: var(
170
+ --#{root-defaults.$prefix}card-content-padding-x,
171
+ #{map.get(root-variables.$spacers, 5)}
172
+ );
173
+ $card-content-padding-y: var(
174
+ --#{root-defaults.$prefix}card-content-padding-y,
175
+ #{map.get(root-variables.$spacers, 3)}
176
+ );
177
+ $card-content-padding: var(
178
+ --#{root-defaults.$prefix}card-content-padding,
179
+ #{$card-content-padding-y} #{$card-content-padding-x}
180
+ );
181
+
182
+ // Card content gap properties.
183
+ $card-content-column-gap: var(
184
+ --#{root-defaults.$prefix}card-content-column-gap,
185
+ #{map.get(root-variables.$spacers, 0)}
186
+ );
187
+ $card-content-row-gap: var(
188
+ --#{root-defaults.$prefix}card-content-row-gap,
189
+ #{map.get(root-variables.$spacers, 3)}
190
+ );
191
+ $card-content-gap: var(
192
+ --#{root-defaults.$prefix}card-content-gap,
193
+ #{$card-content-column-gap} #{$card-content-row-gap}
194
+ );
195
+
196
+ // Card title properties.
197
+ $card-title-color: var(
198
+ --#{root-defaults.$prefix}card-title-color,
199
+ #{$card-color}
200
+ );
201
+ $card-title-font-size: var(
202
+ --#{root-defaults.$prefix}card-title-font-size,
203
+ #{typography.$h4-font-size}
204
+ );
205
+ $card-title-font-weight: var(
206
+ --#{root-defaults.$prefix}card-title-font-weight,
207
+ #{typography.$h4-font-weight}
208
+ );
209
+ $card-title-font-family: var(
210
+ --#{root-defaults.$prefix}card-title-font-family,
211
+ #{typography.$h4-font-family}
212
+ );
213
+ $card-title-line-height: var(
214
+ --#{root-defaults.$prefix}card-title-line-height,
215
+ #{typography.$h4-line-height}
216
+ );
@@ -0,0 +1,43 @@
1
+ // @graupl/core 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;
@@ -0,0 +1,192 @@
1
+ // @graupl/core carousel component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../mixins/layer" as *;
7
+ @use "../../base/button/variables" as button-variables;
8
+ @use "../../base/button/mixins" as button-mixins;
9
+
10
+ @include layer(base) {
11
+ #{defaults.$carousel-control-selector} {
12
+ @include button-mixins.apply-base;
13
+ }
14
+
15
+ #{defaults.$carousel-tab-selector} {
16
+ @include button-mixins.apply-base;
17
+ }
18
+ }
19
+
20
+ @include layer(component) {
21
+ #{defaults.$carousel-selector} {
22
+ display: grid;
23
+ position: relative;
24
+ grid-template-columns: [slide-start controls-start] auto [tabs-start] $carousel-tabs-width [tabs-end] auto [controls-end slide-end];
25
+ grid-template-rows: [slide-start controls-start] $carousel-controls-height [controls-end] $carousel-slide-height [tabs-start] $carousel-tabs-height [tabs-end slide-end];
26
+ isolation: isolate;
27
+ padding: $carousel-padding;
28
+
29
+ &[data-graupl-action="next"] {
30
+ #{defaults.$carousel-item-selector} {
31
+ &#{defaults.$carousel-previous-item-selector} {
32
+ transform: translateX(calc(-1 * $carousel-item-max-width));
33
+
34
+ &#{defaults.$carousel-active-item-selector} {
35
+ transform: none;
36
+ }
37
+ }
38
+
39
+ &#{defaults.$carousel-next-item-selector} {
40
+ transform: translateX($carousel-item-max-width);
41
+
42
+ &#{defaults.$carousel-active-item-selector} {
43
+ transform: none;
44
+ }
45
+ }
46
+ }
47
+ }
48
+
49
+ &[data-graupl-action="previous"] {
50
+ #{defaults.$carousel-item-selector} {
51
+ &#{defaults.$carousel-previous-item-selector} {
52
+ transform: translateX($carousel-item-max-width);
53
+
54
+ &#{defaults.$carousel-active-item-selector} {
55
+ transform: none;
56
+ }
57
+ }
58
+
59
+ &#{defaults.$carousel-next-item-selector} {
60
+ transform: translateX(calc(-1 * $carousel-item-max-width));
61
+
62
+ &#{defaults.$carousel-active-item-selector} {
63
+ transform: none;
64
+ }
65
+ }
66
+ }
67
+ }
68
+ }
69
+
70
+ #{defaults.$carousel-control-container-selector} {
71
+ display: grid;
72
+ z-index: 1;
73
+ grid-area: controls;
74
+ grid-template-columns:
75
+ [autoplay-start] $carousel-control-width [autoplay-end]
76
+ 1fr [previous-start] $carousel-control-width [previous-end next-start]
77
+ $carousel-control-width [next-end];
78
+ grid-template-rows: [autoplay-start next-start previous-start] $carousel-control-height [previous-end next-end autoplay-end];
79
+ pointer-events: none;
80
+ }
81
+
82
+ #{defaults.$carousel-control-selector} {
83
+ pointer-events: auto;
84
+
85
+ &#{defaults.$carousel-autoplay-selector} {
86
+ grid-area: autoplay;
87
+ }
88
+
89
+ &#{defaults.$carousel-play-selector}::before {
90
+ content: $carousel-play-content;
91
+ display: inline-block;
92
+ }
93
+
94
+ &#{defaults.$carousel-pause-selector}::before {
95
+ content: $carousel-pause-content;
96
+ display: inline-block;
97
+ }
98
+
99
+ &#{defaults.$carousel-next-selector} {
100
+ grid-area: next;
101
+
102
+ &::before {
103
+ content: $carousel-next-content;
104
+ display: inline-block;
105
+ }
106
+ }
107
+
108
+ &#{defaults.$carousel-previous-selector} {
109
+ grid-area: previous;
110
+
111
+ &::before {
112
+ content: $carousel-previous-content;
113
+ display: inline-block;
114
+ }
115
+ }
116
+ }
117
+
118
+ #{defaults.$carousel-item-container-selector} {
119
+ display: grid;
120
+ z-index: 0;
121
+ grid-area: slide;
122
+ grid-template-areas: "items";
123
+ padding: $carousel-item-container-padding;
124
+ overflow-x: hidden;
125
+ isolation: isolate;
126
+ }
127
+
128
+ #{defaults.$carousel-item-selector} {
129
+ z-index: -1;
130
+ grid-area: items;
131
+ max-width: $carousel-item-max-width;
132
+ opacity: 0;
133
+
134
+ &#{defaults.$carousel-active-item-selector} {
135
+ z-index: 1;
136
+ transform: none;
137
+ transition: transform
138
+ var(--#{root-defaults.$prefix}carousel-transition-duration, 500ms)
139
+ ease-in-out;
140
+ opacity: 1;
141
+ }
142
+
143
+ &#{defaults.$carousel-previous-item-selector} {
144
+ z-index: 1;
145
+ transform: translateX(calc(-1 * $carousel-item-max-width));
146
+ transition: transform
147
+ var(--#{root-defaults.$prefix}carousel-transition-duration, 500ms)
148
+ ease-in-out;
149
+ opacity: 1;
150
+
151
+ &#{defaults.$carousel-active-item-selector} {
152
+ transform: none;
153
+ }
154
+ }
155
+
156
+ &#{defaults.$carousel-next-item-selector} {
157
+ z-index: 1;
158
+ transform: translateX($carousel-item-max-width);
159
+ opacity: 1;
160
+
161
+ &#{defaults.$carousel-active-item-selector} {
162
+ transform: none;
163
+ }
164
+ }
165
+ }
166
+
167
+ #{defaults.$carousel-tab-container-selector} {
168
+ display: flex;
169
+ z-index: 1;
170
+ grid-area: tabs;
171
+ justify-content: center;
172
+ padding: $carousel-tab-container-padding;
173
+ gap: $carousel-tab-container-gap;
174
+ pointer-events: none;
175
+ }
176
+
177
+ #{defaults.$carousel-tab-selector} {
178
+ --#{root-defaults.$prefix}button-border-radius: 50%;
179
+
180
+ pointer-events: auto;
181
+ }
182
+ }
183
+
184
+ @include layer(theme) {
185
+ #{defaults.$carousel-control-selector} {
186
+ @include button-mixins.apply-theme;
187
+ }
188
+
189
+ #{defaults.$carousel-tab-selector} {
190
+ @include button-mixins.apply-theme;
191
+ }
192
+ }
@@ -0,0 +1,104 @@
1
+ // @graupl/core carousel 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 "../../base/button/variables" as button-variables;
10
+ @use "sass:map";
11
+
12
+ // Carousel grid area properties.
13
+ $carousel-controls-height: var(
14
+ --#{root-defaults.$prefix}carousel-controls-height,
15
+ #{defaults.$carousel-controls-height}
16
+ );
17
+ $carousel-tabs-width: var(
18
+ --#{root-defaults.$prefix}carousel-tabs-width,
19
+ #{defaults.$carousel-tabs-width}
20
+ );
21
+ $carousel-tabs-height: var(
22
+ --#{root-defaults.$prefix}carousel-tabs-height,
23
+ #{defaults.$carousel-tabs-height}
24
+ );
25
+ $carousel-slide-height: var(
26
+ --#{root-defaults.$prefix}carousel-slide-height,
27
+ #{defaults.$carousel-slide-height}
28
+ );
29
+
30
+ // Carousel properties.
31
+ $carousel-padding-x: var(
32
+ --#{root-defaults.$prefix}carousel-padding-x,
33
+ #{map.get(root-variables.$spacers, 0)}
34
+ );
35
+ $carousel-padding-y: var(
36
+ --#{root-defaults.$prefix}carousel-padding-y,
37
+ #{map.get(root-variables.$spacers, 0)}
38
+ );
39
+ $carousel-padding: var(
40
+ --#{root-defaults.$prefix}carousel-padding,
41
+ #{$carousel-padding-y} #{$carousel-padding-x}
42
+ );
43
+
44
+ // Carousel slide properties.
45
+ $carousel-item-max-width: var(
46
+ --#{root-defaults.$prefix}carousel-item-max-width,
47
+ #{defaults.$carousel-item-max-width}
48
+ );
49
+ $carousel-item-container-padding-x: var(
50
+ --#{root-defaults.$prefix}carousel-item-container-padding-x,
51
+ #{map.get(root-variables.$spacers, 0)}
52
+ );
53
+ $carousel-item-container-padding-y: var(
54
+ --#{root-defaults.$prefix}carousel-item-container-padding-y,
55
+ #{map.get(root-variables.$spacers, 0)}
56
+ );
57
+ $carousel-item-container-padding: var(
58
+ --#{root-defaults.$prefix}carousel-item-container-padding,
59
+ #{$carousel-item-container-padding-y} #{$carousel-item-container-padding-x}
60
+ );
61
+
62
+ // Carousel control properties.
63
+ $carousel-play-content: var(
64
+ --#{root-defaults.$prefix}carousel-play-content,
65
+ #{defaults.$carousel-play-content}
66
+ );
67
+ $carousel-pause-content: var(
68
+ --#{root-defaults.$prefix}carousel-pause-content,
69
+ #{defaults.$carousel-pause-content}
70
+ );
71
+ $carousel-next-content: var(
72
+ --#{root-defaults.$prefix}carousel-next-content,
73
+ #{defaults.$carousel-next-content}
74
+ );
75
+ $carousel-previous-content: var(
76
+ --#{root-defaults.$prefix}carousel-previous-content,
77
+ #{defaults.$carousel-previous-content}
78
+ );
79
+ $carousel-control-width: var(
80
+ --#{root-defaults.$prefix}carousel-control-width,
81
+ #{defaults.$carousel-control-width}
82
+ );
83
+ $carousel-control-height: var(
84
+ --#{root-defaults.$prefix}carousel-control-height,
85
+ #{defaults.$carousel-control-height}
86
+ );
87
+
88
+ // Carousel tab properties.
89
+ $carousel-tab-container-padding-x: var(
90
+ --#{root-defaults.$prefix}carousel-tab-container-padding-x,
91
+ #{map.get(root-variables.$spacers, 3)}
92
+ );
93
+ $carousel-tab-container-padding-y: var(
94
+ --#{root-defaults.$prefix}carousel-tab-container-padding-y,
95
+ #{map.get(root-variables.$spacers, 3)}
96
+ );
97
+ $carousel-tab-container-padding: var(
98
+ --#{root-defaults.$prefix}carousel-tab-container-padding,
99
+ #{$carousel-tab-container-padding-y} #{$carousel-tab-container-padding-x}
100
+ );
101
+ $carousel-tab-container-gap: var(
102
+ --#{root-defaults.$prefix}carousel-tab-container-gap,
103
+ #{map.get(root-variables.$spacers, 3)}
104
+ );
@@ -0,0 +1,30 @@
1
+ // @graupl/core input group 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
+ // Input group selectors.
10
+ $input-group-selector: ".input-group" !default;
11
+ $input-group-inline-selector: ".inline" !default;
12
+ $input-group-help-text-selector: ".help-text" !default;
13
+
14
+ // Grid names.
15
+ $input-group-grid-label-name: label !default;
16
+ $input-group-grid-input-name: input !default;
17
+ $input-group-grid-help-name: help !default;
18
+
19
+ // Input group properties.
20
+ $input-group-grid-template-columns: 100% !default;
21
+ $input-group-grid-template-rows: auto auto auto !default;
22
+
23
+ // Inline input group properties.
24
+ $input-group-inline-grid-template-columns: auto 1fr !default;
25
+ $input-group-inline-grid-template-rows: auto auto !default;
26
+
27
+ // Inner element properties.
28
+ $input-group-label-grid-area: $input-group-grid-label-name !default;
29
+ $input-group-input-grid-area: $input-group-grid-input-name !default;
30
+ $input-group-help-grid-area: $input-group-grid-help-name !default;
@@ -0,0 +1,47 @@
1
+ // @graupl/core input group component styles.
2
+
3
+ @use "defaults";
4
+ @use "../../base/form/defaults" as form-defaults;
5
+ @use "variables" as *;
6
+ @use "../../mixins/layer" as *;
7
+ @use "../../mixins/screen";
8
+
9
+ // stylelint-disable declaration-block-no-redundant-longhand-properties
10
+ @include layer(component) {
11
+ #{defaults.$input-group-selector} {
12
+ display: grid;
13
+ grid-template-areas: $input-group-grid-template-areas;
14
+ grid-template-columns: $input-group-grid-template-columns;
15
+ grid-template-rows: $input-group-grid-template-rows;
16
+ align-items: center;
17
+ gap: $input-group-gap;
18
+
19
+ #{form-defaults.$label-selector} {
20
+ grid-area: $input-group-label-grid-area;
21
+ }
22
+
23
+ #{form-defaults.$input-selector},
24
+ #{form-defaults.$textarea-selector},
25
+ #{form-defaults.$select-selector} {
26
+ grid-area: $input-group-input-grid-area;
27
+ }
28
+
29
+ #{defaults.$input-group-help-text-selector} {
30
+ grid-area: $input-group-help-grid-area;
31
+ }
32
+
33
+ &#{defaults.$input-group-inline-selector} {
34
+ grid-template-areas: $input-group-inline-grid-template-areas;
35
+ grid-template-columns: $input-group-inline-grid-template-columns;
36
+ grid-template-rows: $input-group-inline-grid-template-rows;
37
+ }
38
+ }
39
+
40
+ @include screen.down(xs) {
41
+ #{defaults.$input-group-selector}#{defaults.$input-group-inline-selector} {
42
+ grid-template-areas: $input-group-grid-template-areas;
43
+ grid-template-columns: $input-group-grid-template-columns;
44
+ grid-template-rows: $input-group-grid-template-rows;
45
+ }
46
+ }
47
+ }
@@ -0,0 +1,66 @@
1
+ // @graupl/core input group 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 "sass:map";
10
+
11
+ // Input group properties.
12
+ $input-group-grid-template-areas: var(
13
+ --#{root-defaults.$prefix}input-group-grid-template-areas,
14
+ "#{defaults.$input-group-grid-label-name}"
15
+ "#{defaults.$input-group-grid-input-name}"
16
+ "#{defaults.$input-group-grid-help-name}"
17
+ );
18
+ $input-group-grid-template-columns: var(
19
+ --#{root-defaults.$prefix}input-group-grid-template-columns,
20
+ #{defaults.$input-group-grid-template-columns}
21
+ );
22
+ $input-group-grid-template-rows: var(
23
+ --#{root-defaults.$prefix}input-group-grid-template-rows,
24
+ #{defaults.$input-group-grid-template-rows}
25
+ );
26
+ $input-group-row-gap: var(
27
+ --#{root-defaults.$prefix}input-group-row-gap,
28
+ #{map.get(root-variables.$spacers, 2)}
29
+ );
30
+ $input-group-column-gap: var(
31
+ --#{root-defaults.$prefix}input-group-column-gap,
32
+ #{map.get(root-variables.$spacers, 3)}
33
+ );
34
+ $input-group-gap: var(
35
+ --#{root-defaults.$prefix}input-group-gap,
36
+ #{$input-group-row-gap} #{$input-group-column-gap}
37
+ );
38
+
39
+ // Inline input group properties.
40
+ $input-group-inline-grid-template-areas: var(
41
+ --#{root-defaults.$prefix}input-group-inline-grid-template-areas,
42
+ "#{defaults.$input-group-grid-label-name} #{defaults.$input-group-grid-input-name}"
43
+ "- #{defaults.$input-group-grid-help-name}"
44
+ );
45
+ $input-group-inline-grid-template-columns: var(
46
+ --#{root-defaults.$prefix}input-group-inline-grid-template-columns,
47
+ #{defaults.$input-group-inline-grid-template-columns}
48
+ );
49
+ $input-group-inline-grid-template-rows: var(
50
+ --#{root-defaults.$prefix}input-group-inline-grid-template-rows,
51
+ #{defaults.$input-group-inline-grid-template-rows}
52
+ );
53
+
54
+ // Inner element properties.
55
+ $input-group-label-grid-area: var(
56
+ --#{root-defaults.$prefix}input-group-label-grid-area,
57
+ #{defaults.$input-group-label-grid-area}
58
+ );
59
+ $input-group-input-grid-area: var(
60
+ --#{root-defaults.$prefix}input-group-input-grid-area,
61
+ #{defaults.$input-group-input-grid-area}
62
+ );
63
+ $input-group-help-grid-area: var(
64
+ --#{root-defaults.$prefix}input-group-help-grid-area,
65
+ #{defaults.$input-group-help-grid-area}
66
+ );