@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,190 @@
1
+ // @graupl/core navigation component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../menu/defaults" as menu-defaults;
7
+ @use "../menu/variables" as menu-variables;
8
+ @use "../../mixins/layer" as *;
9
+ @use "../../mixins/screen";
10
+
11
+ @include layer(component) {
12
+ // Navigation.
13
+ #{defaults.$navigation-selector} {
14
+ display: grid;
15
+ grid-template-areas:
16
+ "branding - toggle"
17
+ "menu menu menu";
18
+ grid-template-columns: auto 1fr auto;
19
+ isolation: isolate;
20
+
21
+ #{menu-defaults.$menu-selector} {
22
+ grid-area: menu;
23
+
24
+ &#{menu-defaults.$menu-show-selector} {
25
+ --#{root-defaults.$prefix}menu-display: #{menu-variables.$menu-show-display};
26
+ }
27
+
28
+ &#{menu-defaults.$menu-hide-selector} {
29
+ --#{root-defaults.$prefix}menu-display: #{menu-variables.$menu-hide-display};
30
+ }
31
+ }
32
+ }
33
+
34
+ // Navigation toggle.
35
+ #{defaults.$navigation-toggle-selector} {
36
+ display: flex;
37
+ grid-area: toggle;
38
+ align-items: center;
39
+ justify-content: center;
40
+ min-width: $navigation-toggle-min-width;
41
+ min-height: $navigation-toggle-min-height;
42
+ padding: $navigation-toggle-padding;
43
+ border-width: $navigation-toggle-border-width;
44
+ border-style: $navigation-toggle-border-style;
45
+ border-radius: $navigation-toggle-border-radius;
46
+
47
+ &::before {
48
+ content: $navigation-toggle-content;
49
+ display: block;
50
+ }
51
+ }
52
+
53
+ // Navigation branding.
54
+ #{defaults.$navigation-branding-selector} {
55
+ display: flex;
56
+ grid-area: branding;
57
+ align-items: center;
58
+ justify-content: flex-start;
59
+ padding: $navigation-branding-padding;
60
+ font-size: $navigation-branding-font-size;
61
+ font-weight: $navigation-branding-font-weight;
62
+ text-decoration: $navigation-branding-text-decoration;
63
+ text-decoration-style: $navigation-branding-text-decoration-style;
64
+ text-decoration-thickness: $navigation-branding-text-decoration-thickness;
65
+
66
+ &:visited {
67
+ --#{root-defaults.$prefix}navigation-branding-text-decoration: #{$navigation-branding-visited-text-decoration};
68
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-thickness: #{$navigation-branding-visited-text-decoration-thickness};
69
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-style: #{$navigation-branding-visited-text-decoration-style};
70
+ }
71
+
72
+ &:focus-visible {
73
+ --#{root-defaults.$prefix}navigation-branding-text-decoration: #{$navigation-branding-focus-text-decoration};
74
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-thickness: #{$navigation-branding-focus-text-decoration-thickness};
75
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-style: #{$navigation-branding-focus-text-decoration-style};
76
+ }
77
+
78
+ &:hover {
79
+ --#{root-defaults.$prefix}navigation-branding-text-decoration: #{$navigation-branding-hover-text-decoration};
80
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-thickness: #{$navigation-branding-hover-text-decoration-thickness};
81
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-style: #{$navigation-branding-hover-text-decoration-style};
82
+ }
83
+
84
+ &:active {
85
+ --#{root-defaults.$prefix}navigation-branding-text-decoration: #{$navigation-branding-active-text-decoration};
86
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-thickness: #{$navigation-branding-active-text-decoration-thickness};
87
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-style: #{$navigation-branding-active-text-decoration-style};
88
+ }
89
+
90
+ &:disabled,
91
+ &[disabled] {
92
+ &,
93
+ &:visited,
94
+ &:focus-visible,
95
+ &:hover,
96
+ &:active {
97
+ --#{root-defaults.$prefix}navigation-branding-text-decoration: #{$navigation-branding-disabled-text-decoration};
98
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-thickness: #{$navigation-branding-disabled-text-decoration-thickness};
99
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-style: #{$navigation-branding-disabled-text-decoration-style};
100
+ }
101
+ }
102
+ }
103
+
104
+ @include screen.trigger(navigation-collapse) {
105
+ // Navigation.
106
+ #{defaults.$navigation-selector} {
107
+ --#{root-defaults.$prefix}menu-flex-direction: column;
108
+ --#{root-defaults.$prefix}submenu-position: relative;
109
+ --#{root-defaults.$prefix}menu-item-min-width: 100%;
110
+ --#{root-defaults.$prefix}submenu-inset: auto;
111
+ }
112
+ }
113
+
114
+ @include screen.trigger(navigation-expand) {
115
+ // Navigation.
116
+ #{defaults.$navigation-selector} {
117
+ --#{root-defaults.$prefix}menu-hide-display: #{menu-variables.$menu-show-display};
118
+
119
+ grid-template-areas: "branding - menu";
120
+ }
121
+
122
+ // Navigation toggle.
123
+ #{defaults.$navigation-toggle-selector} {
124
+ display: none;
125
+ }
126
+ }
127
+ }
128
+
129
+ @include layer(theme) {
130
+ // Navigation.
131
+ #{defaults.$navigation-selector} {
132
+ --#{root-defaults.$prefix}menu-background: #{$navigation-background};
133
+ --#{root-defaults.$prefix}menu-color: #{$navigation-color};
134
+ --#{root-defaults.$prefix}submenu-background: #{$navigation-background};
135
+ --#{root-defaults.$prefix}submenu-color: #{$navigation-color};
136
+
137
+ background: $navigation-background;
138
+ color: $navigation-color;
139
+ }
140
+
141
+ // Navigation toggle.
142
+ #{defaults.$navigation-toggle-selector} {
143
+ border-color: $navigation-toggle-border-color;
144
+ background: $navigation-toggle-background;
145
+ color: $navigation-toggle-color;
146
+
147
+ &:hover {
148
+ --#{root-defaults.$prefix}navigation-toggle-background: #{$navigation-toggle-hover-background};
149
+ --#{root-defaults.$prefix}navigation-toggle-color: #{$navigation-toggle-hover-color};
150
+ }
151
+ }
152
+
153
+ // Navigation branding.
154
+ #{defaults.$navigation-branding-selector} {
155
+ color: $navigation-branding-color;
156
+ text-decoration-color: $navigation-branding-text-decoration-color;
157
+
158
+ &:visited {
159
+ --#{root-defaults.$prefix}navigation-branding-color: #{$navigation-branding-visited-color};
160
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-color: #{$navigation-branding-visited-text-decoration-color};
161
+ }
162
+
163
+ &:focus-visible {
164
+ --#{root-defaults.$prefix}navigation-branding-color: #{$navigation-branding-focus-color};
165
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-color: #{$navigation-branding-focus-text-decoration-color};
166
+ }
167
+
168
+ &:hover {
169
+ --#{root-defaults.$prefix}navigation-branding-color: #{$navigation-branding-hover-color};
170
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-color: #{$navigation-branding-hover-text-decoration-color};
171
+ }
172
+
173
+ &:active {
174
+ --#{root-defaults.$prefix}navigation-branding-color: #{$navigation-branding-active-color};
175
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-color: #{$navigation-branding-active-text-decoration-color};
176
+ }
177
+
178
+ &:disabled,
179
+ &[disabled] {
180
+ &,
181
+ &:visited,
182
+ &:focus-visible,
183
+ &:hover,
184
+ &:active {
185
+ --#{root-defaults.$prefix}navigation-branding-color: #{$navigation-branding-disabled-color};
186
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-color: #{$navigation-branding-disabled-text-decoration-color};
187
+ }
188
+ }
189
+ }
190
+ }
@@ -0,0 +1,290 @@
1
+ // @graupl/core navigation 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
+ // Navigation colors.
14
+ $navigation-background: var(
15
+ --#{root-defaults.$prefix}navigation-background,
16
+ #{color.$background}
17
+ );
18
+ $navigation-color: var(
19
+ --#{root-defaults.$prefix}navigation-color,
20
+ #{color.$color}
21
+ );
22
+
23
+ // Navigation toggle size.
24
+ $navigation-toggle-min-width: var(
25
+ --#{root-defaults.$prefix}navigation-toggle-min-width,
26
+ #{root-defaults.$interactive-min-width}
27
+ );
28
+ $navigation-toggle-min-height: var(
29
+ --#{root-defaults.$prefix}navigation-toggle-min-height,
30
+ #{root-defaults.$interactive-min-height}
31
+ );
32
+
33
+ // Navigation toggle spacing.
34
+ $navigation-toggle-padding-x: var(
35
+ --#{root-defaults.$prefix}navigation-toggle-padding-x,
36
+ #{map.get(root-variables.$spacers, 5)}
37
+ );
38
+ $navigation-toggle-padding-y: var(
39
+ --#{root-defaults.$prefix}navigation-toggle-padding-y,
40
+ #{map.get(root-variables.$spacers, 3)}
41
+ );
42
+ $navigation-toggle-padding: var(
43
+ --#{root-defaults.$prefix}navigation-toggle-padding,
44
+ #{$navigation-toggle-padding-y} #{$navigation-toggle-padding-x}
45
+ );
46
+
47
+ // Navigation toggle colors.
48
+ $navigation-toggle-background: var(
49
+ --#{root-defaults.$prefix}navigation-toggle-background,
50
+ #{$navigation-background}
51
+ );
52
+ $navigation-toggle-color: var(
53
+ --#{root-defaults.$prefix}navigation-toggle-color,
54
+ #{$navigation-color}
55
+ );
56
+ $navigation-toggle-hover-background: var(
57
+ --#{root-defaults.$prefix}navigation-toggle-hover-background,
58
+ #{$navigation-color}
59
+ );
60
+ $navigation-toggle-hover-color: var(
61
+ --#{root-defaults.$prefix}navigation-toggle-hover-color,
62
+ #{$navigation-background}
63
+ );
64
+
65
+ // Navigation toggle border properties.
66
+ $navigation-toggle-border-top-width: var(
67
+ --#{root-defaults.$prefix}navigation-toggle-border-top-width,
68
+ #{root-variables.$border-top-width}
69
+ );
70
+ $navigation-toggle-border-right-width: var(
71
+ --#{root-defaults.$prefix}navigation-toggle-border-right-width,
72
+ #{root-variables.$border-right-width}
73
+ );
74
+ $navigation-toggle-border-bottom-width: var(
75
+ --#{root-defaults.$prefix}navigation-toggle-border-bottom-width,
76
+ #{root-variables.$border-bottom-width}
77
+ );
78
+ $navigation-toggle-border-left-width: var(
79
+ --#{root-defaults.$prefix}navigation-toggle-border-left-width,
80
+ #{root-variables.$border-left-width}
81
+ );
82
+ $navigation-toggle-border-width: var(
83
+ --#{root-defaults.$prefix}navigation-toggle-border-width,
84
+ #{$navigation-toggle-border-top-width}
85
+ #{$navigation-toggle-border-right-width}
86
+ #{$navigation-toggle-border-bottom-width}
87
+ #{$navigation-toggle-border-left-width}
88
+ );
89
+ $navigation-toggle-border-top-style: var(
90
+ --#{root-defaults.$prefix}navigation-toggle-border-top-style,
91
+ #{root-variables.$border-top-style}
92
+ );
93
+ $navigation-toggle-border-right-style: var(
94
+ --#{root-defaults.$prefix}navigation-toggle-border-right-style,
95
+ #{root-variables.$border-right-style}
96
+ );
97
+ $navigation-toggle-border-bottom-style: var(
98
+ --#{root-defaults.$prefix}navigation-toggle-border-bottom-style,
99
+ #{root-variables.$border-bottom-style}
100
+ );
101
+ $navigation-toggle-border-left-style: var(
102
+ --#{root-defaults.$prefix}navigation-toggle-border-left-style,
103
+ #{root-variables.$border-left-style}
104
+ );
105
+ $navigation-toggle-border-style: var(
106
+ --#{root-defaults.$prefix}navigation-toggle-border-style,
107
+ #{$navigation-toggle-border-top-style}
108
+ #{$navigation-toggle-border-right-style}
109
+ #{$navigation-toggle-border-bottom-style}
110
+ #{$navigation-toggle-border-left-style}
111
+ );
112
+ $navigation-toggle-border-color: var(
113
+ --#{root-defaults.$prefix}navigation-toggle-border-color,
114
+ #{$navigation-toggle-color}
115
+ );
116
+ $navigation-toggle-border-top-left-radius: var(
117
+ --#{root-defaults.$prefix}navigation-toggle-border-top-left-radius,
118
+ #{root-variables.$border-top-left-radius}
119
+ );
120
+ $navigation-toggle-border-top-right-radius: var(
121
+ --#{root-defaults.$prefix}navigation-toggle-border-top-right-radius,
122
+ #{root-variables.$border-top-right-radius}
123
+ );
124
+ $navigation-toggle-border-bottom-left-radius: var(
125
+ --#{root-defaults.$prefix}navigation-toggle-border-bottom-left-radius,
126
+ #{root-variables.$border-bottom-left-radius}
127
+ );
128
+ $navigation-toggle-border-bottom-right-radius: var(
129
+ --#{root-defaults.$prefix}navigation-toggle-border-bottom-right-radius,
130
+ #{root-variables.$border-bottom-right-radius}
131
+ );
132
+ $navigation-toggle-border-radius: var(
133
+ --#{root-defaults.$prefix}navigation-toggle-border-radius,
134
+ #{$navigation-toggle-border-top-left-radius}
135
+ #{$navigation-toggle-border-top-right-radius}
136
+ #{$navigation-toggle-border-bottom-right-radius}
137
+ #{$navigation-toggle-border-bottom-left-radius}
138
+ );
139
+
140
+ // Navigation branding properties.
141
+ $navigation-branding-font-size: var(
142
+ --#{root-defaults.$prefix}navigation-branding-font-size,
143
+ #{map.get(typography.$font-sizes, "lg")}
144
+ );
145
+ $navigation-branding-font-weight: var(
146
+ --#{root-defaults.$prefix}navigation-branding-font-weight,
147
+ #{typography.$font-weight-bold}
148
+ );
149
+ $navigation-branding-padding-x: var(
150
+ --#{root-defaults.$prefix}navigation-branding-padding-x,
151
+ #{map.get(root-variables.$spacers, 3)}
152
+ );
153
+ $navigation-branding-padding-y: var(
154
+ --#{root-defaults.$prefix}navigation-branding-padding-y,
155
+ #{map.get(root-variables.$spacers, 2)}
156
+ );
157
+ $navigation-branding-padding: var(
158
+ --#{root-defaults.$prefix}navigation-branding-padding,
159
+ #{$navigation-branding-padding-y} #{$navigation-branding-padding-x}
160
+ );
161
+
162
+ // Navigation branding colors.
163
+ $navigation-branding-color: var(
164
+ --#{root-defaults.$prefix}navigation-branding-color,
165
+ #{$navigation-color}
166
+ );
167
+ $navigation-branding-visited-color: var(
168
+ --#{root-defaults.$prefix}navigation-branding-visited-color,
169
+ #{$navigation-branding-color}
170
+ );
171
+ $navigation-branding-focus-color: var(
172
+ --#{root-defaults.$prefix}navigation-branding-focus-color,
173
+ #{$navigation-branding-color}
174
+ );
175
+ $navigation-branding-hover-color: var(
176
+ --#{root-defaults.$prefix}navigation-branding-hover-color,
177
+ #{$navigation-color}
178
+ );
179
+ $navigation-branding-active-color: var(
180
+ --#{root-defaults.$prefix}navigation-branding-active-color,
181
+ #{$navigation-branding-hover-color}
182
+ );
183
+ $navigation-branding-disabled-color: var(
184
+ --#{root-defaults.$prefix}navigation-branding-disabled-color,
185
+ #{$navigation-color}
186
+ );
187
+
188
+ // Navigation branding text decoration properties.
189
+ $navigation-branding-text-decoration: var(
190
+ --#{root-defaults.$prefix}navigation-branding-text-decoration,
191
+ #{defaults.$navigation-branding-initial-text-decoration}
192
+ );
193
+ $navigation-branding-visited-text-decoration: var(
194
+ --#{root-defaults.$prefix}navigation-branding-visited-text-decoration,
195
+ #{$navigation-branding-text-decoration}
196
+ );
197
+ $navigation-branding-focus-text-decoration: var(
198
+ --#{root-defaults.$prefix}navigation-branding-focus-text-decoration,
199
+ #{$navigation-branding-text-decoration}
200
+ );
201
+ $navigation-branding-hover-text-decoration: var(
202
+ --#{root-defaults.$prefix}navigation-branding-hover-text-decoration,
203
+ #{defaults.$navigation-branding-final-text-decoration}
204
+ );
205
+ $navigation-branding-active-text-decoration: var(
206
+ --#{root-defaults.$prefix}navigation-branding-active-text-decoration,
207
+ #{$navigation-branding-hover-text-decoration}
208
+ );
209
+ $navigation-branding-disabled-text-decoration: var(
210
+ --#{root-defaults.$prefix}navigation-branding-disabled-text-decoration,
211
+ #{defaults.$navigation-branding-disabled-text-decoration}
212
+ );
213
+ $navigation-branding-text-decoration-style: var(
214
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-style,
215
+ #{defaults.$navigation-branding-initial-text-decoration-style}
216
+ );
217
+ $navigation-branding-visited-text-decoration-style: var(
218
+ --#{root-defaults.$prefix}navigation-branding-visited-text-decoration-style,
219
+ #{$navigation-branding-text-decoration-style}
220
+ );
221
+ $navigation-branding-focus-text-decoration-style: var(
222
+ --#{root-defaults.$prefix}navigation-branding-focus-text-decoration-style,
223
+ #{$navigation-branding-text-decoration-style}
224
+ );
225
+ $navigation-branding-hover-text-decoration-style: var(
226
+ --#{root-defaults.$prefix}navigation-branding-hover-text-decoration-style,
227
+ #{defaults.$navigation-branding-final-text-decoration-style}
228
+ );
229
+ $navigation-branding-active-text-decoration-style: var(
230
+ --#{root-defaults.$prefix}navigation-branding-active-text-decoration-style,
231
+ #{$navigation-branding-hover-text-decoration-style}
232
+ );
233
+ $navigation-branding-disabled-text-decoration-style: var(
234
+ --#{root-defaults.$prefix}navigation-branding-disabled-text-decoration-style,
235
+ #{defaults.$navigation-branding-disabled-text-decoration-style}
236
+ );
237
+ $navigation-branding-text-decoration-thickness: var(
238
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-thickness,
239
+ #{root-variables.$border-width}
240
+ );
241
+ $navigation-branding-visited-text-decoration-thickness: var(
242
+ --#{root-defaults.$prefix}navigation-branding-visited-text-decoration-thickness,
243
+ #{$navigation-branding-text-decoration-thickness}
244
+ );
245
+ $navigation-branding-focus-text-decoration-thickness: var(
246
+ --#{root-defaults.$prefix}navigation-branding-focus-text-decoration-thickness,
247
+ #{$navigation-branding-text-decoration-thickness}
248
+ );
249
+ $navigation-branding-hover-text-decoration-thickness: var(
250
+ --#{root-defaults.$prefix}navigation-branding-hover-text-decoration-thickness,
251
+ #{root-variables.$border-width}
252
+ );
253
+ $navigation-branding-active-text-decoration-thickness: var(
254
+ --#{root-defaults.$prefix}navigation-branding-active-text-decoration-thickness,
255
+ #{$navigation-branding-hover-text-decoration-thickness}
256
+ );
257
+ $navigation-branding-disabled-text-decoration-thickness: var(
258
+ --#{root-defaults.$prefix}navigation-branding-disabled-text-decoration-thickness,
259
+ #{root-variables.$border-width}
260
+ );
261
+ $navigation-branding-text-decoration-color: var(
262
+ --#{root-defaults.$prefix}navigation-branding-text-decoration-color,
263
+ #{$navigation-branding-color}
264
+ );
265
+ $navigation-branding-visited-text-decoration-color: var(
266
+ --#{root-defaults.$prefix}navigation-branding-visited-text-decoration-color,
267
+ #{$navigation-branding-visited-color}
268
+ );
269
+ $navigation-branding-focus-text-decoration-color: var(
270
+ --#{root-defaults.$prefix}navigation-branding-focus-text-decoration-color,
271
+ #{$navigation-branding-focus-color}
272
+ );
273
+ $navigation-branding-hover-text-decoration-color: var(
274
+ --#{root-defaults.$prefix}navigation-branding-hover-text-decoration-color,
275
+ #{$navigation-branding-hover-color}
276
+ );
277
+ $navigation-branding-active-text-decoration-color: var(
278
+ --#{root-defaults.$prefix}navigation-branding-active-text-decoration-color,
279
+ #{$navigation-branding-active-color}
280
+ );
281
+ $navigation-branding-disabled-text-decoration-color: var(
282
+ --#{root-defaults.$prefix}navigation-branding-disabled-text-decoration-color,
283
+ #{$navigation-branding-disabled-color}
284
+ );
285
+
286
+ // Navigation toggle properties.
287
+ $navigation-toggle-content: var(
288
+ --#{root-defaults.$prefix}navigation-toggle-content,
289
+ #{defaults.$navigation-toggle-content}
290
+ );
@@ -0,0 +1,38 @@
1
+ // @graupl/core container functions.
2
+ //
3
+ // A series of functions to determine ranges of container sizes.
4
+
5
+ @use "../defaults" as root-defaults;
6
+ @use "sass:map";
7
+ @use "sass:list";
8
+
9
+ @function min($size) {
10
+ @if not map.has-key(root-defaults.$container-sizes, $size) {
11
+ @error "The container size \"#{$size}\" does not exist.";
12
+ }
13
+
14
+ $container-size: map.get(root-defaults.$container-sizes, $size);
15
+
16
+ @return $container-size;
17
+ }
18
+
19
+ @function max($size) {
20
+ @if not map.has-key(root-defaults.$container-sizes, $size) {
21
+ @error "The container size \"#{$size}\" does not exist.";
22
+ }
23
+
24
+ $keys: map.keys(root-defaults.$container-sizes);
25
+ $index: list.index($keys, "#{$size}");
26
+ $key: list.nth($keys, $index + 1);
27
+ $container-size: map.get(root-defaults.$container-sizes, $key);
28
+ $container-size: $container-size - 1;
29
+
30
+ @return $container-size;
31
+ }
32
+
33
+ @function range($min, $max) {
34
+ $min-size: min($min);
35
+ $max-size: max($max);
36
+
37
+ @return (min: $min-size, max: $max-size);
38
+ }
@@ -0,0 +1,36 @@
1
+ // @graupl/core important functions.
2
+ //
3
+ // A function to determine if the !important flag should be added to a property.
4
+
5
+ @use "../defaults";
6
+
7
+ /// Determine if an important flag is required and insert it into a property value.
8
+ ///
9
+ /// @param {String} $value
10
+ /// The value to insert the important flag into.
11
+ /// @param {Boolean} $use-important
12
+ /// A flag to determine if the important flag should be overridden.
13
+ ///
14
+ /// @return {String}
15
+ /// The value with the important flag added.
16
+ @function insert($value, $override: null) {
17
+ // If override is set, use it.
18
+ /* stylelint-disable scss/at-if-no-null */
19
+ @if $override != null {
20
+ // Convert the override to a string.
21
+ // We have to do this because true/false values are weird in Sass.
22
+ // Using the raw boolean value, it will always return true for some reason.
23
+ @if "#{$override}" == "true" {
24
+ @return #{$value} !important;
25
+ } @else {
26
+ @return #{$value};
27
+ }
28
+ }
29
+ /* stylelint-enable scss/at-if-no-null */
30
+
31
+ @if defaults.$use-important {
32
+ @return #{$value} !important;
33
+ }
34
+
35
+ @return #{$value};
36
+ }
@@ -0,0 +1,38 @@
1
+ // @graupl/core screen functions.
2
+ //
3
+ // A series of functions to determine ranges of screen sizes.
4
+
5
+ @use "../defaults" as root-defaults;
6
+ @use "sass:map";
7
+ @use "sass:list";
8
+
9
+ @function min($size) {
10
+ @if not map.has-key(root-defaults.$screen-sizes, $size) {
11
+ @error "The screen size \"#{$size}\" does not exist.";
12
+ }
13
+
14
+ $screen-size: map.get(root-defaults.$screen-sizes, $size);
15
+
16
+ @return $screen-size;
17
+ }
18
+
19
+ @function max($size) {
20
+ @if not map.has-key(root-defaults.$screen-sizes, $size) {
21
+ @error "The screen size \"#{$size}\" does not exist.";
22
+ }
23
+
24
+ $keys: map.keys(root-defaults.$screen-sizes);
25
+ $index: list.index($keys, "#{$size}");
26
+ $key: list.nth($keys, $index + 1);
27
+ $screen-size: map.get(root-defaults.$screen-sizes, $key);
28
+ $screen-size: $screen-size - 1;
29
+
30
+ @return $screen-size;
31
+ }
32
+
33
+ @function range($min, $max) {
34
+ $min-size: min($min);
35
+ $max-size: max($max);
36
+
37
+ @return (min: $min-size, max: $max-size);
38
+ }
@@ -0,0 +1,39 @@
1
+ // @graupl/core theme functions.
2
+ //
3
+ // Functions to help with getting information about the theme.
4
+
5
+ @use "sass:map";
6
+ @use "../theme/color/variables" as color;
7
+
8
+ // A function to get the specific theme shades.
9
+ @function get($color, $shade: null, $theme: active) {
10
+ @if $shade == transparent or $color == transparent {
11
+ @return transparent;
12
+ }
13
+
14
+ @if $shade == none or $color == none {
15
+ @return none;
16
+ }
17
+
18
+ @if $shade == inherit or $color == inherit {
19
+ @return inherit;
20
+ }
21
+
22
+ @if $shade == initial or $color == initial {
23
+ @return initial;
24
+ }
25
+
26
+ @if map.has-key(color.$themes, $theme, $color, $shade) {
27
+ @return map.get(map.get(map.get(color.$themes, $theme), $color), $shade);
28
+ }
29
+
30
+ @return null;
31
+ }
32
+
33
+ @function variants($theme: active) {
34
+ @if map.has-key(color.$themes, $theme) {
35
+ @return map.keys(map.get(color.$themes, $theme));
36
+ }
37
+
38
+ @return null;
39
+ }
@@ -0,0 +1,28 @@
1
+ // @graupl/core utility functions.
2
+ //
3
+ // Functions to help generate utility classes.
4
+
5
+ @use "sass:map";
6
+
7
+ /// Convert a property and value to a map.
8
+ ///
9
+ /// This mixin is used internally.
10
+ ///
11
+ /// @param {string|List} $property
12
+ /// The property/properties to convert to keys.
13
+ /// @param {string} $value
14
+ /// The value to use for keys.
15
+ @function convert-property-values-to-map($property, $value) {
16
+ $map: ();
17
+
18
+ @each $prop in $property {
19
+ $map: map.merge(
20
+ $map,
21
+ (
22
+ $prop: $value,
23
+ )
24
+ );
25
+ }
26
+
27
+ @return $map;
28
+ }
@@ -0,0 +1,5 @@
1
+ // @graupl/core layout styles.
2
+
3
+ @forward "container";
4
+ @forward "columns";
5
+ @forward "flex-columns";
@@ -0,0 +1,24 @@
1
+ // @graupl/core columns layout 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 "../../defaults" as root-defaults;
10
+
11
+ // Columns selectors.
12
+ $columns-selector-base: root-defaults.$component-selector-base !default;
13
+ $columns-selector: "columns" !default;
14
+ $columns-count-selector-base: $columns-selector-base !default;
15
+ $columns-count-selector-prefix: "count-" !default;
16
+ $columns-span-selector-base: $columns-selector-base !default;
17
+ $columns-span-selector-prefix: "span-" !default;
18
+
19
+ // Columns properties.
20
+ $columns-max-width: 1fr !default;
21
+ $columns-count: 3 !default;
22
+ $columns-min-count: 1 !default;
23
+ $columns-max-count: 6 !default;
24
+ $columns-span: 1 !default;