@graupl/graupl 1.0.0-alpha.9 → 1.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (346) 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 +153 -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/{component → css/component}/input-group.css +1 -1
  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.map +1 -0
  39. package/dist/css/layout/flex-columns.css +2 -0
  40. package/dist/css/layout/flex-columns.css.map +1 -0
  41. package/dist/css/layout.css +2 -0
  42. package/dist/css/layout.css.map +1 -0
  43. package/dist/css/normalize.css +2 -0
  44. package/dist/css/normalize.css.map +1 -0
  45. package/dist/css/state/focus.css +2 -0
  46. package/dist/css/state/focus.css.map +1 -0
  47. package/dist/css/state.css +2 -0
  48. package/dist/css/state.css.map +1 -0
  49. package/dist/css/theme/color.css +2 -0
  50. package/dist/css/theme/color.css.map +1 -0
  51. package/dist/css/theme/typography.css +2 -0
  52. package/dist/css/theme/typography.css.map +1 -0
  53. package/dist/css/theme.css +2 -0
  54. package/dist/css/theme.css.map +1 -0
  55. package/dist/css/utilities/alignment.css +2 -0
  56. package/dist/css/utilities/alignment.css.map +1 -0
  57. package/dist/{utilities/colors.css → css/utilities/color.css} +2 -2
  58. package/dist/css/utilities/color.css.map +1 -0
  59. package/dist/css/utilities/display.css +2 -0
  60. package/dist/css/utilities/display.css.map +1 -0
  61. package/dist/css/utilities/flex.css +2 -0
  62. package/dist/css/utilities/flex.css.map +1 -0
  63. package/dist/css/utilities/height.css +2 -0
  64. package/dist/css/utilities/height.css.map +1 -0
  65. package/dist/css/utilities/inset.css +2 -0
  66. package/dist/css/utilities/inset.css.map +1 -0
  67. package/dist/css/utilities/justification.css +2 -0
  68. package/dist/css/utilities/justification.css.map +1 -0
  69. package/dist/css/utilities/list.css +2 -0
  70. package/dist/css/utilities/list.css.map +1 -0
  71. package/dist/css/utilities/order.css +2 -0
  72. package/dist/css/utilities/order.css.map +1 -0
  73. package/dist/css/utilities/postion.css +2 -0
  74. package/dist/css/utilities/postion.css.map +1 -0
  75. package/dist/css/utilities/ratio.css +2 -0
  76. package/dist/css/utilities/ratio.css.map +1 -0
  77. package/dist/css/utilities/spacing.css +2 -0
  78. package/dist/css/utilities/spacing.css.map +1 -0
  79. package/dist/css/utilities/typography.css +2 -0
  80. package/dist/css/utilities/typography.css.map +1 -0
  81. package/dist/css/utilities/visibility.css +2 -0
  82. package/dist/css/utilities/visibility.css.map +1 -0
  83. package/dist/css/utilities/width.css +2 -0
  84. package/dist/css/utilities/width.css.map +1 -0
  85. package/dist/css/utilities.css +2 -0
  86. package/dist/css/utilities.css.map +1 -0
  87. package/dist/js/component/accordion.cjs.js +3 -0
  88. package/dist/js/component/accordion.esm.js +1289 -0
  89. package/dist/js/component/accordion.iife.js +3 -0
  90. package/dist/js/component/alert.cjs.js +3 -0
  91. package/dist/js/component/alert.esm.js +529 -0
  92. package/dist/js/component/alert.iife.js +3 -0
  93. package/dist/js/component/carousel.cjs.js +3 -0
  94. package/dist/js/component/carousel.esm.js +1110 -0
  95. package/dist/js/component/carousel.iife.js +3 -0
  96. package/dist/js/graupl.cjs.js +5 -0
  97. package/dist/js/graupl.esm.js +1462 -0
  98. package/dist/js/graupl.iife.js +5 -0
  99. package/docs/.vitepress/config.js +39 -12
  100. package/docs/components/alert.md +130 -0
  101. package/docs/components/button.md +84 -0
  102. package/docs/components/card.md +369 -0
  103. package/docs/components/index.md +1 -0
  104. package/docs/components/inputgroup.md +159 -0
  105. package/docs/components/menu.md +326 -0
  106. package/docs/components/navigation.md +158 -0
  107. package/docs/content.md +237 -0
  108. package/docs/defaults.md +121 -0
  109. package/docs/forms.md +79 -0
  110. package/docs/functions.md +9 -0
  111. package/docs/getting-started.md +1 -0
  112. package/docs/index.md +1 -7
  113. package/docs/introduction.md +22 -2
  114. package/docs/layout.md +200 -0
  115. package/docs/mixins.md +47 -0
  116. package/docs/state.md +67 -0
  117. package/docs/theme.md +258 -0
  118. package/docs/utilities.md +357 -0
  119. package/eslint.config.js +1 -0
  120. package/index.html +816 -327
  121. package/index.js +12 -0
  122. package/package.json +31 -10
  123. package/scss/base/button.scss +3 -0
  124. package/scss/base/form.scss +1 -1
  125. package/scss/base/link.scss +1 -1
  126. package/scss/base/table.scss +1 -1
  127. package/scss/base.scss +1 -1
  128. package/scss/component/accordion.scss +3 -0
  129. package/scss/component/alert.scss +3 -0
  130. package/scss/component/card.scss +3 -0
  131. package/scss/component/carousel.scss +3 -0
  132. package/scss/component/input-group.scss +1 -1
  133. package/scss/component/menu.scss +3 -0
  134. package/scss/component/navigation.scss +3 -0
  135. package/scss/component.scss +1 -1
  136. package/scss/graupl.scss +1 -3
  137. package/scss/init.scss +3 -0
  138. package/scss/layout/columns.scss +1 -1
  139. package/scss/layout/container.scss +1 -1
  140. package/scss/layout/flex-columns.scss +3 -0
  141. package/scss/layout.scss +1 -1
  142. package/scss/normalize.scss +3 -0
  143. package/scss/state/focus.scss +1 -1
  144. package/scss/state.scss +1 -1
  145. package/scss/theme/color.scss +1 -1
  146. package/scss/theme/typography.scss +1 -1
  147. package/scss/theme.scss +1 -1
  148. package/scss/utilities/alignment.scss +3 -0
  149. package/scss/utilities/color.scss +3 -0
  150. package/scss/utilities/display.scss +3 -0
  151. package/scss/utilities/flex.scss +3 -0
  152. package/scss/utilities/height.scss +3 -0
  153. package/scss/utilities/inset.scss +3 -0
  154. package/scss/utilities/justification.scss +3 -0
  155. package/scss/utilities/list.scss +3 -0
  156. package/scss/utilities/order.scss +3 -0
  157. package/scss/utilities/postion.scss +3 -0
  158. package/scss/utilities/ratio.scss +3 -0
  159. package/scss/utilities/spacing.scss +1 -1
  160. package/scss/utilities/typography.scss +1 -1
  161. package/scss/utilities/visibility.scss +3 -0
  162. package/scss/utilities/width.scss +3 -0
  163. package/scss/utilities.scss +1 -1
  164. package/src/js/accordion/Accordion.js +1163 -0
  165. package/src/js/accordion/AccordionItem.js +496 -0
  166. package/src/js/accordion/index.js +10 -0
  167. package/src/js/alert/Alert.js +581 -0
  168. package/src/js/alert/index.js +11 -0
  169. package/src/js/carousel/Carousel.js +1427 -0
  170. package/src/js/carousel/index.js +10 -0
  171. package/src/js/domHelpers.js +37 -0
  172. package/src/js/eventHandlers.js +39 -0
  173. package/src/js/navigation/index.js +36 -0
  174. package/src/js/storage.js +106 -0
  175. package/src/js/validate.js +225 -0
  176. package/src/scss/_defaults.scss +74 -5
  177. package/src/scss/_index.scss +4 -3
  178. package/src/scss/_init.scss +2 -2
  179. package/src/scss/_normalize.scss +197 -0
  180. package/src/scss/_variables.scss +7 -7
  181. package/src/scss/base/_index.scss +2 -1
  182. package/src/scss/base/button/_defaults.scss +60 -0
  183. package/src/scss/base/button/_index.scss +107 -0
  184. package/src/scss/base/button/_mixins.scss +166 -0
  185. package/src/scss/{component → base}/button/_variables.scss +64 -19
  186. package/src/scss/base/form/_defaults.scss +14 -4
  187. package/src/scss/base/form/_index.scss +23 -20
  188. package/src/scss/base/form/_variables.scss +14 -2
  189. package/src/scss/base/link/_defaults.scss +48 -5
  190. package/src/scss/base/link/_index.scss +111 -10
  191. package/src/scss/base/link/_variables.scss +234 -4
  192. package/src/scss/base/table/_defaults.scss +49 -4
  193. package/src/scss/base/table/_index.scss +102 -8
  194. package/src/scss/base/table/_variables.scss +75 -5
  195. package/src/scss/component/_index.scss +7 -3
  196. package/src/scss/component/accordion/_defaults.scss +40 -0
  197. package/src/scss/component/accordion/_index.scss +180 -0
  198. package/src/scss/component/accordion/_variables.scss +316 -0
  199. package/src/scss/component/alert/_defaults.scss +49 -0
  200. package/src/scss/component/alert/_index.scss +118 -0
  201. package/src/scss/component/alert/_variables.scss +173 -0
  202. package/src/scss/component/card/_defaults.scss +32 -0
  203. package/src/scss/component/card/_index.scss +178 -0
  204. package/src/scss/component/card/_variables.scss +186 -0
  205. package/src/scss/component/carousel/_defaults.scss +43 -0
  206. package/src/scss/component/carousel/_index.scss +188 -0
  207. package/src/scss/component/carousel/_variables.scss +104 -0
  208. package/src/scss/component/input-group/_defaults.scss +11 -4
  209. package/src/scss/component/input-group/_index.scss +13 -11
  210. package/src/scss/component/input-group/_variables.scss +4 -1
  211. package/src/scss/component/menu/_defaults.scss +66 -0
  212. package/src/scss/component/menu/_index.scss +305 -0
  213. package/src/scss/component/menu/_variables.scss +500 -0
  214. package/src/scss/component/navigation/_defaults.scss +29 -0
  215. package/src/scss/component/navigation/_index.scss +189 -0
  216. package/src/scss/component/navigation/_variables.scss +237 -0
  217. package/src/scss/functions/_important.scss +2 -0
  218. package/src/scss/functions/_screen.scss +30 -0
  219. package/src/scss/functions/_theme.scss +28 -7
  220. package/src/scss/layout/_index.scss +2 -1
  221. package/src/scss/layout/columns/_defaults.scss +12 -4
  222. package/src/scss/layout/columns/_index.scss +29 -7
  223. package/src/scss/layout/columns/_variables.scss +6 -2
  224. package/src/scss/layout/container/_defaults.scss +13 -4
  225. package/src/scss/layout/container/_index.scss +12 -7
  226. package/src/scss/layout/container/_variables.scss +4 -1
  227. package/src/scss/layout/flex-columns/_defaults.scss +18 -0
  228. package/src/scss/layout/flex-columns/_index.scss +80 -0
  229. package/src/scss/layout/flex-columns/_variables.scss +26 -0
  230. package/src/scss/mixins/_animation.scss +15 -0
  231. package/src/scss/mixins/_layer.scss +3 -5
  232. package/src/scss/mixins/_screen.scss +56 -0
  233. package/src/scss/mixins/_utility.scss +30 -0
  234. package/src/scss/mixins/_visually-hidden.scss +20 -0
  235. package/src/scss/state/_index.scss +1 -1
  236. package/src/scss/state/focus/_defaults.scss +6 -4
  237. package/src/scss/state/focus/_index.scss +7 -7
  238. package/src/scss/state/focus/_mixins.scss +15 -0
  239. package/src/scss/state/focus/_variables.scss +6 -2
  240. package/src/scss/theme/_index.scss +1 -1
  241. package/src/scss/theme/color/_defaults.scss +101 -19
  242. package/src/scss/theme/color/_index.scss +17 -17
  243. package/src/scss/theme/color/_variables.scss +72 -64
  244. package/src/scss/theme/typography/_defaults.scss +7 -5
  245. package/src/scss/theme/typography/_index.scss +1 -1
  246. package/src/scss/theme/typography/_variables.scss +11 -7
  247. package/src/scss/utilities/_index.scss +14 -2
  248. package/src/scss/utilities/alignment/_defaults.scss +62 -0
  249. package/src/scss/utilities/alignment/_index.scss +75 -0
  250. package/src/scss/utilities/alignment/_variables.scss +6 -0
  251. package/src/scss/utilities/color/_defaults.scss +35 -0
  252. package/src/scss/utilities/color/_index.scss +91 -0
  253. package/src/scss/utilities/color/_variables.scss +6 -0
  254. package/src/scss/utilities/display/_defaults.scss +32 -0
  255. package/src/scss/utilities/display/_index.scss +61 -0
  256. package/src/scss/utilities/display/_variables.scss +6 -0
  257. package/src/scss/utilities/flex/_defaults.scss +63 -0
  258. package/src/scss/utilities/flex/_index.scss +71 -0
  259. package/src/scss/utilities/flex/_variables.scss +6 -0
  260. package/src/scss/utilities/height/_defaults.scss +41 -0
  261. package/src/scss/utilities/height/_index.scss +98 -0
  262. package/src/scss/utilities/height/_variables.scss +6 -0
  263. package/src/scss/utilities/inset/_defaults.scss +41 -0
  264. package/src/scss/utilities/inset/_index.scss +37 -0
  265. package/src/scss/utilities/inset/_variables.scss +6 -0
  266. package/src/scss/utilities/justification/_defaults.scss +59 -0
  267. package/src/scss/utilities/justification/_index.scss +75 -0
  268. package/src/scss/utilities/justification/_variables.scss +6 -0
  269. package/src/scss/utilities/list/_defaults.scss +39 -0
  270. package/src/scss/utilities/list/_index.scss +56 -0
  271. package/src/scss/utilities/list/_variables.scss +6 -0
  272. package/src/scss/utilities/order/_defaults.scss +22 -0
  273. package/src/scss/utilities/order/_index.scss +63 -0
  274. package/src/scss/utilities/order/_variables.scss +6 -0
  275. package/src/scss/utilities/position/_defaults.scss +26 -0
  276. package/src/scss/utilities/position/_index.scss +37 -0
  277. package/src/scss/utilities/position/_variables.scss +6 -0
  278. package/src/scss/utilities/ratio/_defaults.scss +28 -0
  279. package/src/scss/utilities/ratio/_index.scss +52 -0
  280. package/src/scss/utilities/ratio/_variables.scss +9 -0
  281. package/src/scss/utilities/spacing/_defaults.scss +9 -4
  282. package/src/scss/utilities/spacing/_index.scss +134 -29
  283. package/src/scss/utilities/spacing/_variables.scss +5 -2
  284. package/src/scss/utilities/typography/_defaults.scss +29 -4
  285. package/src/scss/utilities/typography/_index.scss +155 -23
  286. package/src/scss/utilities/typography/_variables.scss +5 -2
  287. package/src/scss/utilities/visibility/_defaults.scss +25 -0
  288. package/src/scss/utilities/visibility/_index.scss +36 -0
  289. package/src/scss/utilities/visibility/_variables.scss +6 -0
  290. package/src/scss/utilities/width/_defaults.scss +41 -0
  291. package/src/scss/utilities/width/_index.scss +98 -0
  292. package/src/scss/utilities/width/_variables.scss +6 -0
  293. package/stylelint.config.js +5 -0
  294. package/vite.config.js +57 -0
  295. package/dist/base/form.css +0 -2
  296. package/dist/base/form.css.map +0 -1
  297. package/dist/base/link.css +0 -2
  298. package/dist/base/link.css.map +0 -1
  299. package/dist/base/table.css +0 -2
  300. package/dist/base/table.css.map +0 -1
  301. package/dist/base.css +0 -2
  302. package/dist/base.css.map +0 -1
  303. package/dist/component/button.css +0 -2
  304. package/dist/component/button.css.map +0 -1
  305. package/dist/component/input-group.css.map +0 -1
  306. package/dist/component/table.css +0 -2
  307. package/dist/component/table.css.map +0 -1
  308. package/dist/component.css +0 -2
  309. package/dist/component.css.map +0 -1
  310. package/dist/graupl.css +0 -2
  311. package/dist/graupl.css.map +0 -1
  312. package/dist/layout/columns.css +0 -2
  313. package/dist/layout/columns.css.map +0 -1
  314. package/dist/layout/container.css.map +0 -1
  315. package/dist/layout.css +0 -2
  316. package/dist/layout.css.map +0 -1
  317. package/dist/state/focus.css +0 -2
  318. package/dist/state/focus.css.map +0 -1
  319. package/dist/state.css +0 -2
  320. package/dist/state.css.map +0 -1
  321. package/dist/theme/color.css +0 -2
  322. package/dist/theme/color.css.map +0 -1
  323. package/dist/theme/typography.css +0 -2
  324. package/dist/theme/typography.css.map +0 -1
  325. package/dist/theme.css +0 -2
  326. package/dist/theme.css.map +0 -1
  327. package/dist/utilities/colors.css.map +0 -1
  328. package/dist/utilities/spacing.css +0 -2
  329. package/dist/utilities/spacing.css.map +0 -1
  330. package/dist/utilities/typography.css +0 -2
  331. package/dist/utilities/typography.css.map +0 -1
  332. package/dist/utilities.css +0 -2
  333. package/dist/utilities.css.map +0 -1
  334. package/scss/component/button.scss +0 -3
  335. package/scss/component/table.scss +0 -3
  336. package/scss/utilities/colors.scss +0 -3
  337. package/src/scss/component/button/_defaults.scss +0 -39
  338. package/src/scss/component/button/_index.scss +0 -98
  339. package/src/scss/component/table/_defaults.scss +0 -30
  340. package/src/scss/component/table/_index.scss +0 -77
  341. package/src/scss/component/table/_variables.scss +0 -64
  342. package/src/scss/mixins/_media-queries.scss +0 -26
  343. package/src/scss/utilities/colors/_defaults.scss +0 -5
  344. package/src/scss/utilities/colors/_index.scss +0 -22
  345. package/src/scss/utilities/colors/_variables.scss +0 -3
  346. /package/dist/{layout → css/layout}/container.css +0 -0
@@ -0,0 +1,197 @@
1
+ // @graupl/graupl normalize.
2
+ //
3
+ // This file is manually forked from normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css
4
+ //
5
+ // We wanted to scope normalize.css to a normalize layer along with some customizations, so we forked it here.
6
+ //
7
+ // @use cannot be used in this file because you cannot insert it into a layer.
8
+ //
9
+ // @import would technically work, but it is not recommended by Sass and will eventually be removed.
10
+ // Using @import would cause headaches down the line, so a manual fork was the best option.
11
+
12
+ @use "mixins/layer" as *;
13
+
14
+ @include layer(normalize) {
15
+ // Correct box sizing of all elements to ensure everything is consistent.
16
+ *,
17
+ *::before,
18
+ *::after {
19
+ box-sizing: border-box;
20
+ }
21
+
22
+ // Document.
23
+
24
+ // 1. Correct the line height in all browsers.
25
+ // 2. Prevent adjustments of font size after orientation changes in iOS.
26
+ html {
27
+ line-height: 1.15; // 1.
28
+ text-size-adjust: 100%; // 2.
29
+ }
30
+
31
+ // Secions.
32
+
33
+ // Remove the margin in all browsers.
34
+ body {
35
+ margin: 0;
36
+ }
37
+
38
+ // Grouping content.
39
+
40
+ // Add the correct box sizing in Firefox.
41
+ hr {
42
+ box-sizing: content-box;
43
+ height: 0;
44
+ }
45
+
46
+ // 1. Correct the inheritance and scaling of font size in all browsers.
47
+ // 2. Correct the odd `em` font sizing in all browsers.
48
+ pre {
49
+ font-family: monospace; // 1.
50
+ font-size: 1em; // 2.
51
+ }
52
+
53
+ // Text-level semantics.
54
+
55
+ // 1. Remove the bottom border in Chrome 57-
56
+ // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
57
+ abbr[title] {
58
+ border-bottom: 0; // 1.
59
+ text-decoration: underline dotted; // 2.
60
+ }
61
+
62
+ // Add the correct font weight in Chrome, Edge, and Safari.
63
+ b,
64
+ strong {
65
+ font-weight: bolder;
66
+ }
67
+
68
+ // 1. Correct the inheritance and scaling of font size in all browsers.
69
+ // 2. Correct the odd `em` font sizing in all browsers.
70
+ code,
71
+ kbd,
72
+ samp {
73
+ font-family: monospace; // 1.
74
+ font-size: 1em; // 2.
75
+ }
76
+
77
+ // Add the correct font size in all browsers.
78
+ small {
79
+ font-size: 80%;
80
+ }
81
+
82
+ // Prevent `sub` and `sup` elements from affecting the line height in all browsers.
83
+ sub,
84
+ sup {
85
+ position: relative;
86
+ font-size: 75%;
87
+ line-height: 0;
88
+ vertical-align: baseline;
89
+ }
90
+
91
+ sub {
92
+ bottom: -0.25em;
93
+ }
94
+
95
+ sup {
96
+ top: -0.5em;
97
+ }
98
+
99
+ // Forms.
100
+
101
+ // 1. Change the font styles in all browsers.
102
+ // 2. Remove the margin in Firefox and Safari.
103
+ button,
104
+ input,
105
+ optgroup,
106
+ select,
107
+ textarea {
108
+ margin: 0; // 2.
109
+ font-family: inherit; // 1.
110
+ font-size: 100%; // 1.
111
+ line-height: 1.15; // 1.
112
+ }
113
+
114
+ // Remove the inheritance of text transform in Firefox.
115
+ button,
116
+ select {
117
+ /* 1 */
118
+ text-transform: none;
119
+ }
120
+
121
+ // Correct the inability to style clickable types in iOS and Safari.
122
+ button,
123
+ [type="button"],
124
+ [type="reset"],
125
+ [type="submit"] {
126
+ appearance: button;
127
+ }
128
+
129
+ // Remove the inner border and padding in Firefox.
130
+ button::-moz-focus-inner,
131
+ [type="button"]::-moz-focus-inner,
132
+ [type="reset"]::-moz-focus-inner,
133
+ [type="submit"]::-moz-focus-inner {
134
+ padding: 0;
135
+ border-style: none;
136
+ }
137
+
138
+ // Restore the focus styles unset by the previous rule.
139
+ button:-moz-focusring,
140
+ [type="button"]:-moz-focusring,
141
+ [type="reset"]:-moz-focusring,
142
+ [type="submit"]:-moz-focusring {
143
+ outline: 1px dotted ButtonText;
144
+ }
145
+
146
+ // Correct the padding in Firefox.
147
+ fieldset {
148
+ padding: 0.35em 0.75em 0.625em;
149
+ }
150
+
151
+ // Remove the padding so developers are not caught out when they zero out `fieldset` elements in all browsers.
152
+ legend {
153
+ padding: 0;
154
+ }
155
+
156
+ // Add the correct vertical alignment in Chrome, Firefox, and Opera.
157
+ progress {
158
+ vertical-align: baseline;
159
+ }
160
+
161
+ // Correct the cursor style of increment and decrement buttons in Chrome.
162
+ [type="number"]::-webkit-inner-spin-button,
163
+ [type="number"]::-webkit-outer-spin-button {
164
+ height: auto;
165
+ }
166
+
167
+ // 1. Correct the odd appearance in Chrome and Safari.
168
+ // 2. Correct the outline style in Safari.
169
+ [type="search"] {
170
+ appearance: textfield; // 1.
171
+ outline-offset: -2px; // 2.
172
+ }
173
+
174
+ // Remove the inner padding in Chrome and Safari on macOS.
175
+ [type="search"]::-webkit-search-decoration {
176
+ appearance: none;
177
+ }
178
+
179
+ // 1. Correct the inability to style clickable types in iOS and Safari.
180
+ // 2. Change font properties to `inherit` in Safari.
181
+ ::-webkit-file-upload-button {
182
+ appearance: button; /* 1 */
183
+ font: inherit; /* 2 */
184
+ }
185
+
186
+ // Interactive.
187
+
188
+ // Add the correct display in Edge, IE 10+, and Firefox.
189
+ details {
190
+ display: block;
191
+ }
192
+
193
+ // Add the correct display in all browsers.
194
+ summary {
195
+ display: list-item;
196
+ }
197
+ }
@@ -1,4 +1,7 @@
1
- // Variables referencing custom properties.
1
+ // @graupl/graupl variables.
2
+ //
3
+ // These values are to be used to directly style components and provide a
4
+ // cleaner way to reference custom properties.
2
5
 
3
6
  @use "defaults";
4
7
  @use "sass:map";
@@ -31,18 +34,15 @@ $border-style: var(--#{defaults.$prefix}-border-style, defaults.$border-style);
31
34
 
32
35
  // Transition properties.
33
36
  $transition-durations: (
34
- fast:
35
- var(
37
+ fast: var(
36
38
  --#{defaults.$prefix}-transition-duration-fast,
37
39
  map.get(defaults.$transition-durations, fast)
38
40
  ),
39
- default:
40
- var(
41
+ default: var(
41
42
  --#{defaults.$prefix}-transition-duration-default,
42
43
  map.get(defaults.$transition-durations, default)
43
44
  ),
44
- slow:
45
- var(
45
+ slow: var(
46
46
  --#{defaults.$prefix}-transition-duration-slow,
47
47
  map.get(defaults.$transition-durations, slow)
48
48
  ),
@@ -1,5 +1,6 @@
1
- // Graupl base.
1
+ // @graupl/graupl base styles.
2
2
 
3
+ @forward "button";
3
4
  @forward "form";
4
5
  @forward "link";
5
6
  @forward "table";
@@ -0,0 +1,60 @@
1
+ // @graupl/graupl button base default values.
2
+ //
3
+ // Generally, these should not be used directly when styling bases 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
+ // Button selectors.
12
+ $button-selector: ".button" !default;
13
+ $button-link-selector: ".link" !default;
14
+ $button-theme-selector-prefix: "." !default;
15
+
16
+ // State selectors.
17
+ $button-active-selector: ".active" !default;
18
+ $button-disabled-selector: ".disabled" !default;
19
+ $button-focus-selector: ".focus" !default;
20
+ $button-hover-selector: ".hover" !default;
21
+ $button-visited-selector: ".visited" !default;
22
+
23
+ // Button properties.
24
+ $button-transform: none !default;
25
+ $button-visited-transform: $button-transform !default;
26
+ $button-focus-transform: $button-transform !default;
27
+ $button-hover-transform: $button-transform !default;
28
+ $button-active-transform: scale(0.95) !default;
29
+ $button-disabled-transform: $button-transform !default;
30
+
31
+ // Button state theme defaults.
32
+ // This map is used to define the default colour shades for the
33
+ // themed button bases.
34
+ //
35
+ // e.g.
36
+ // Primary buttons will use primary--900 as the text colour, primary--100 as the background
37
+ // and primary--900 as the border colour.
38
+ //
39
+ // Secondary/tertiary buttons will use the same shade for their respective colours.
40
+ $base-button-state-theme-map: (
41
+ color: 900,
42
+ border-color: 700,
43
+ visited-color: 900,
44
+ visited-border-color: 700,
45
+ focus-color: 900,
46
+ focus-border-color: 700,
47
+ hover-color: 100,
48
+ hover-background: 700,
49
+ hover-border-color: 700,
50
+ active-color: 100,
51
+ active-background: 700,
52
+ active-border-color: 700,
53
+ disabled-color: 200,
54
+ disabled-border-color: 200,
55
+ );
56
+ $custom-button-state-theme-map: () !default;
57
+ $button-state-theme-map: map.merge(
58
+ $base-button-state-theme-map,
59
+ $custom-button-state-theme-map
60
+ );
@@ -0,0 +1,107 @@
1
+ // @graupl/graupl button base styles.
2
+
3
+ @use "defaults";
4
+ @use "../../defaults" as root-defaults;
5
+ @use "../link/defaults" as link-defaults;
6
+ @use "../../base/link/variables" as link;
7
+ @use "variables" as *;
8
+ @use "mixins" as *;
9
+ @use "../../mixins/layer" as *;
10
+
11
+ #{defaults.$button-selector} {
12
+ @include apply-button;
13
+
14
+ &#{defaults.$button-link-selector} {
15
+ --#{root-defaults.$prefix}-button-padding: #{link.$link-padding};
16
+ --#{root-defaults.$prefix}-button-transition: #{link.$link-transition};
17
+ --#{root-defaults.$prefix}-button-transition-reduced-motion: #{link.$link-transition-reduced-motion};
18
+ --#{root-defaults.$prefix}-button-transform: #{link.$link-transform};
19
+ --#{root-defaults.$prefix}-button-visited-transform: #{link.$link-visited-transform};
20
+ --#{root-defaults.$prefix}-button-focus-transform: #{link.$link-transform};
21
+ --#{root-defaults.$prefix}-button-hover-transform: #{link.$link-hover-transform};
22
+ --#{root-defaults.$prefix}-button-active-transform: #{link.$link-active-transform};
23
+ --#{root-defaults.$prefix}-button-border-width: #{link.$link-border-width};
24
+ --#{root-defaults.$prefix}-button-border-style: #{link.$link-border-style};
25
+ --#{root-defaults.$prefix}-button-border-radius: #{link.$link-border-radius};
26
+ --#{root-defaults.$prefix}-button-min-width: #{link.$link-min-width};
27
+ --#{root-defaults.$prefix}-button-min-height: #{link.$link-min-height};
28
+ --#{root-defaults.$prefix}-button-font-size: inherit;
29
+
30
+ text-decoration: link.$link-text-decoration;
31
+ text-decoration-thickness: link.$link-text-decoration-thickness;
32
+ text-decoration-style: link.$link-text-decoration-style;
33
+ }
34
+ }
35
+
36
+ @include layer(base) {
37
+ #{defaults.$button-selector}#{defaults.$button-link-selector} {
38
+ --#{root-defaults.$prefix}-button-color: #{link.$link-color};
39
+ --#{root-defaults.$prefix}-button-visited-color: #{link.$link-visited-color};
40
+ --#{root-defaults.$prefix}-button-focus-color: #{link.$link-focus-color};
41
+ --#{root-defaults.$prefix}-button-hover-color: #{link.$link-hover-color};
42
+ --#{root-defaults.$prefix}-button-active-color: #{link.$link-active-color};
43
+ --#{root-defaults.$prefix}-button-disabled-color: #{link.$link-disabled-color};
44
+ --#{root-defaults.$prefix}-button-background: #{link.$link-background};
45
+ --#{root-defaults.$prefix}-button-visited-background: #{link.$link-visited-background};
46
+ --#{root-defaults.$prefix}-button-focus-background: #{link.$link-focus-background};
47
+ --#{root-defaults.$prefix}-button-hover-background: #{link.$link-hover-background};
48
+ --#{root-defaults.$prefix}-button-active-background: #{link.$link-active-background};
49
+ --#{root-defaults.$prefix}-button-disabled-background: #{link.$link-disabled-background};
50
+ --#{root-defaults.$prefix}-button-border-color: #{link.$link-border-color};
51
+ --#{root-defaults.$prefix}-button-visited-border-color: #{link.$link-visited-border-color};
52
+ --#{root-defaults.$prefix}-button-focus-border-color: #{link.$link-focus-border-color};
53
+ --#{root-defaults.$prefix}-button-hover-border-color: #{link.$link-hover-border-color};
54
+ --#{root-defaults.$prefix}-button-active-border-color: #{link.$link-active-border-color};
55
+ --#{root-defaults.$prefix}-button-disabled-border-color: #{link.$link-disabled-border-color};
56
+ }
57
+
58
+ #{link-defaults.$link-selector} {
59
+ &#{defaults.$button-selector}:not(#{defaults.$button-link-selector}) {
60
+ --#{root-defaults.$prefix}-link-padding: #{$button-padding};
61
+ --#{root-defaults.$prefix}-link-transition: #{$button-transition};
62
+ --#{root-defaults.$prefix}-link-transition-reduced-motion: #{$button-transition-reduced-motion};
63
+ --#{root-defaults.$prefix}-link-transform: #{$button-transform};
64
+ --#{root-defaults.$prefix}-link-visited-transform: #{$button-visited-transform};
65
+ --#{root-defaults.$prefix}-link-focus-transform: #{$button-focus-transform};
66
+ --#{root-defaults.$prefix}-link-hover-transform: #{$button-hover-transform};
67
+ --#{root-defaults.$prefix}-link-active-transform: #{$button-active-transform};
68
+ --#{root-defaults.$prefix}-link-disabled-transform: #{$button-disabled-transform};
69
+ --#{root-defaults.$prefix}-link-border-width: #{$button-border-width};
70
+ --#{root-defaults.$prefix}-link-border-style: #{$button-border-style};
71
+ --#{root-defaults.$prefix}-link-border-radius: #{$button-border-radius};
72
+ --#{root-defaults.$prefix}-link-min-width: #{$button-min-width};
73
+ --#{root-defaults.$prefix}-link-min-height: #{$button-min-height};
74
+ --#{root-defaults.$prefix}-link-text-decoration: none;
75
+ --#{root-defaults.$prefix}-link-visited-text-decoration: none;
76
+ --#{root-defaults.$prefix}-link-focus-text-decoration: none;
77
+ --#{root-defaults.$prefix}-link-hover-text-decoration: none;
78
+ --#{root-defaults.$prefix}-link-active-text-decoration: none;
79
+ --#{root-defaults.$prefix}-link-disabled-text-decoration: none;
80
+ }
81
+ }
82
+ }
83
+
84
+ @include layer(theme) {
85
+ #{link-defaults.$link-selector} {
86
+ &#{defaults.$button-selector}:not(#{defaults.$button-link-selector}) {
87
+ --#{root-defaults.$prefix}-link-color: #{$button-color};
88
+ --#{root-defaults.$prefix}-link-visited-color: #{$button-visited-color};
89
+ --#{root-defaults.$prefix}-link-focus-color: #{$button-focus-color};
90
+ --#{root-defaults.$prefix}-link-hover-color: #{$button-hover-color};
91
+ --#{root-defaults.$prefix}-link-active-color: #{$button-active-color};
92
+ --#{root-defaults.$prefix}-link-disabled-color: #{$button-disabled-color};
93
+ --#{root-defaults.$prefix}-link-background: #{$button-background};
94
+ --#{root-defaults.$prefix}-link-visited-background: #{$button-visited-background};
95
+ --#{root-defaults.$prefix}-link-focus-background: #{$button-focus-background};
96
+ --#{root-defaults.$prefix}-link-hover-background: #{$button-hover-background};
97
+ --#{root-defaults.$prefix}-link-active-background: #{$button-active-background};
98
+ --#{root-defaults.$prefix}-link-disabled-background: #{$button-disabled-background};
99
+ --#{root-defaults.$prefix}-link-border-color: #{$button-border-color};
100
+ --#{root-defaults.$prefix}-link-visited-border-color: #{$button-visited-border-color};
101
+ --#{root-defaults.$prefix}-link-focus-border-color: #{$button-focus-border-color};
102
+ --#{root-defaults.$prefix}-link-hover-border-color: #{$button-hover-border-color};
103
+ --#{root-defaults.$prefix}-link-active-border-color: #{$button-active-border-color};
104
+ --#{root-defaults.$prefix}-link-disabled-border-color: #{$button-disabled-border-color};
105
+ }
106
+ }
107
+ }
@@ -0,0 +1,166 @@
1
+ // @graupl/graupl button base styles.
2
+
3
+ @use "defaults";
4
+ @use "../../defaults" as root-defaults;
5
+ @use "../../theme/color/variables" as color;
6
+ @use "variables" as *;
7
+ @use "../../mixins/layer" as *;
8
+ @use "../../mixins/animation";
9
+ @use "../../functions/theme";
10
+ @use "sass:map";
11
+
12
+ @mixin apply-button(
13
+ $min-width: $button-min-width,
14
+ $min-height: $button-min-height,
15
+ $padding: $button-padding,
16
+ $transform: $button-transform,
17
+ $transition: $button-transition,
18
+ $border: $button-border,
19
+ $border-radius: $button-border-radius,
20
+ $font-size: $button-font-size,
21
+ $visited-transform: $button-visited-transform,
22
+ $focus-transform: $button-focus-transform,
23
+ $hover-transform: $button-hover-transform,
24
+ $active-transform: $button-active-transform,
25
+ $disabled-transform: $button-disabled-transform,
26
+ $border-color: $button-border-color,
27
+ $background: $button-background,
28
+ $color: $button-color,
29
+ $visited-border-color: $button-visited-border-color,
30
+ $visited-background: $button-visited-background,
31
+ $visited-color: $button-visited-color,
32
+ $focus-border-color: $button-focus-border-color,
33
+ $focus-background: $button-focus-background,
34
+ $focus-color: $button-focus-color,
35
+ $hover-border-color: $button-hover-border-color,
36
+ $hover-background: $button-hover-background,
37
+ $hover-color: $button-hover-color,
38
+ $active-border-color: $button-active-border-color,
39
+ $active-background: $button-active-background,
40
+ $active-color: $button-active-color,
41
+ $disabled-border-color: $button-disabled-border-color,
42
+ $disabled-background: $button-disabled-background,
43
+ $disabled-color: $button-disabled-color
44
+ ) {
45
+ @include layer(base) {
46
+ display: flex;
47
+ align-items: center;
48
+ justify-content: center;
49
+ min-width: $min-width;
50
+ min-height: $min-height;
51
+ padding: $padding;
52
+ transform: $transform;
53
+ transition: $transition;
54
+ border: $border;
55
+ border-radius: $border-radius;
56
+ font-size: $font-size;
57
+ cursor: pointer;
58
+
59
+ @each $selector in map.get(root-defaults.$state-selectors, visited) {
60
+ &#{$selector} {
61
+ --#{root-defaults.$prefix}-button-transform: #{$visited-transform};
62
+ }
63
+ }
64
+
65
+ @each $selector in map.get(root-defaults.$state-selectors, focus) {
66
+ &#{$selector} {
67
+ --#{root-defaults.$prefix}-button-transform: #{$focus-transform};
68
+ }
69
+ }
70
+
71
+ @each $selector in map.get(root-defaults.$state-selectors, hover) {
72
+ &#{$selector} {
73
+ --#{root-defaults.$prefix}-button-transform: #{$hover-transform};
74
+ }
75
+ }
76
+
77
+ @each $selector in map.get(root-defaults.$state-selectors, active) {
78
+ &#{$selector} {
79
+ --#{root-defaults.$prefix}-button-transform: #{$active-transform};
80
+ }
81
+ }
82
+
83
+ @each $selector in map.get(root-defaults.$state-selectors, disabled) {
84
+ &#{$selector} {
85
+ @each $state, $selectors in root-defaults.$state-selectors {
86
+ @each $selector in $selectors {
87
+ &,
88
+ &#{$selector} {
89
+ --#{root-defaults.$prefix}-button-transform: #{$disabled-transform};
90
+
91
+ cursor: not-allowed;
92
+ }
93
+ }
94
+ }
95
+ }
96
+ }
97
+
98
+ @include animation.off {
99
+ --#{root-defaults.$prefix}-button-transition: #{$button-transition-reduced-motion};
100
+ }
101
+ }
102
+
103
+ @include layer(theme) {
104
+ border-color: $border-color;
105
+ background: $background;
106
+ color: $color;
107
+
108
+ @each $color, $map in map.get(color.$themes, active) {
109
+ &#{defaults.$button-theme-selector-prefix}#{$color} {
110
+ @each $prop, $shade in defaults.$button-state-theme-map {
111
+ --#{root-defaults.$prefix}-button-#{$prop}: #{theme.get(
112
+ $color,
113
+ $shade
114
+ )};
115
+ }
116
+ }
117
+ }
118
+
119
+ @each $selector in map.get(root-defaults.$state-selectors, visited) {
120
+ &#{$selector} {
121
+ --#{root-defaults.$prefix}-button-border-color: #{$visited-border-color};
122
+ --#{root-defaults.$prefix}-button-background: #{$visited-background};
123
+ --#{root-defaults.$prefix}-button-color: #{$visited-color};
124
+ }
125
+ }
126
+
127
+ @each $selector in map.get(root-defaults.$state-selectors, focus) {
128
+ &#{$selector} {
129
+ --#{root-defaults.$prefix}-button-border-color: #{$focus-border-color};
130
+ --#{root-defaults.$prefix}-button-background: #{$focus-background};
131
+ --#{root-defaults.$prefix}-button-color: #{$focus-color};
132
+ }
133
+ }
134
+
135
+ @each $selector in map.get(root-defaults.$state-selectors, hover) {
136
+ &#{$selector} {
137
+ --#{root-defaults.$prefix}-button-border-color: #{$hover-border-color};
138
+ --#{root-defaults.$prefix}-button-background: #{$hover-background};
139
+ --#{root-defaults.$prefix}-button-color: #{$hover-color};
140
+ }
141
+ }
142
+
143
+ @each $selector in map.get(root-defaults.$state-selectors, active) {
144
+ &#{$selector} {
145
+ --#{root-defaults.$prefix}-button-border-color: #{$active-border-color};
146
+ --#{root-defaults.$prefix}-button-background: #{$active-background};
147
+ --#{root-defaults.$prefix}-button-color: #{$active-color};
148
+ }
149
+ }
150
+
151
+ @each $selector in map.get(root-defaults.$state-selectors, disabled) {
152
+ &#{$selector} {
153
+ @each $state, $selectors in root-defaults.$state-selectors {
154
+ @each $selector in $selectors {
155
+ &,
156
+ &#{$selector} {
157
+ --#{root-defaults.$prefix}-button-border-color: #{$disabled-border-color};
158
+ --#{root-defaults.$prefix}-button-background: #{$disabled-background};
159
+ --#{root-defaults.$prefix}-button-color: #{$disabled-color};
160
+ }
161
+ }
162
+ }
163
+ }
164
+ }
165
+ }
166
+ }