@graupl/graupl 1.0.0-alpha.8 → 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.
- package/.github/workflows/codeql-analysis.yml +3 -3
- package/.husky/commit-msg +0 -1
- package/.husky/pre-commit +0 -1
- package/.stylelintignore +9 -0
- package/CHANGELOG.md +160 -0
- package/build.js +7 -0
- package/dist/css/base/button.css +2 -0
- package/dist/css/base/button.css.map +1 -0
- package/dist/css/base/form.css +2 -0
- package/dist/css/base/form.css.map +1 -0
- package/dist/css/base/link.css +2 -0
- package/dist/css/base/link.css.map +1 -0
- package/dist/css/base/table.css +2 -0
- package/dist/css/base/table.css.map +1 -0
- package/dist/css/base.css +2 -0
- package/dist/css/base.css.map +1 -0
- package/dist/css/component/accordion.css +2 -0
- package/dist/css/component/accordion.css.map +1 -0
- package/dist/css/component/alert.css +2 -0
- package/dist/css/component/alert.css.map +1 -0
- package/dist/css/component/card.css +2 -0
- package/dist/css/component/card.css.map +1 -0
- package/dist/css/component/carousel.css +2 -0
- package/dist/css/component/carousel.css.map +1 -0
- package/dist/{component → css/component}/input-group.css +1 -1
- package/dist/css/component/input-group.css.map +1 -0
- package/dist/css/component/menu.css +2 -0
- package/dist/css/component/menu.css.map +1 -0
- package/dist/css/component/navigation.css +2 -0
- package/dist/css/component/navigation.css.map +1 -0
- package/dist/css/component.css +2 -0
- package/dist/css/component.css.map +1 -0
- package/dist/css/graupl.css +2 -0
- package/dist/css/graupl.css.map +1 -0
- package/dist/css/init.css +2 -0
- package/dist/css/init.css.map +1 -0
- package/dist/css/layout/columns.css +2 -0
- package/dist/css/layout/columns.css.map +1 -0
- package/dist/css/layout/container.css.map +1 -0
- package/dist/css/layout/flex-columns.css +2 -0
- package/dist/css/layout/flex-columns.css.map +1 -0
- package/dist/css/layout.css +2 -0
- package/dist/css/layout.css.map +1 -0
- package/dist/css/normalize.css +2 -0
- package/dist/css/normalize.css.map +1 -0
- package/dist/css/state/focus.css +2 -0
- package/dist/css/state/focus.css.map +1 -0
- package/dist/css/state.css +2 -0
- package/dist/css/state.css.map +1 -0
- package/dist/css/theme/color.css +2 -0
- package/dist/css/theme/color.css.map +1 -0
- package/dist/css/theme/typography.css +2 -0
- package/dist/css/theme/typography.css.map +1 -0
- package/dist/css/theme.css +2 -0
- package/dist/css/theme.css.map +1 -0
- package/dist/css/utilities/alignment.css +2 -0
- package/dist/css/utilities/alignment.css.map +1 -0
- package/dist/{utilities/colors.css → css/utilities/color.css} +2 -2
- package/dist/css/utilities/color.css.map +1 -0
- package/dist/css/utilities/display.css +2 -0
- package/dist/css/utilities/display.css.map +1 -0
- package/dist/css/utilities/flex.css +2 -0
- package/dist/css/utilities/flex.css.map +1 -0
- package/dist/css/utilities/height.css +2 -0
- package/dist/css/utilities/height.css.map +1 -0
- package/dist/css/utilities/inset.css +2 -0
- package/dist/css/utilities/inset.css.map +1 -0
- package/dist/css/utilities/justification.css +2 -0
- package/dist/css/utilities/justification.css.map +1 -0
- package/dist/css/utilities/list.css +2 -0
- package/dist/css/utilities/list.css.map +1 -0
- package/dist/css/utilities/order.css +2 -0
- package/dist/css/utilities/order.css.map +1 -0
- package/dist/css/utilities/postion.css +2 -0
- package/dist/css/utilities/postion.css.map +1 -0
- package/dist/css/utilities/ratio.css +2 -0
- package/dist/css/utilities/ratio.css.map +1 -0
- package/dist/css/utilities/spacing.css +2 -0
- package/dist/css/utilities/spacing.css.map +1 -0
- package/dist/css/utilities/typography.css +2 -0
- package/dist/css/utilities/typography.css.map +1 -0
- package/dist/css/utilities/visibility.css +2 -0
- package/dist/css/utilities/visibility.css.map +1 -0
- package/dist/css/utilities/width.css +2 -0
- package/dist/css/utilities/width.css.map +1 -0
- package/dist/css/utilities.css +2 -0
- package/dist/css/utilities.css.map +1 -0
- package/dist/js/component/accordion.cjs.js +3 -0
- package/dist/js/component/accordion.esm.js +1289 -0
- package/dist/js/component/accordion.iife.js +3 -0
- package/dist/js/component/alert.cjs.js +3 -0
- package/dist/js/component/alert.esm.js +529 -0
- package/dist/js/component/alert.iife.js +3 -0
- package/dist/js/component/carousel.cjs.js +3 -0
- package/dist/js/component/carousel.esm.js +1110 -0
- package/dist/js/component/carousel.iife.js +3 -0
- package/dist/js/graupl.cjs.js +5 -0
- package/dist/js/graupl.esm.js +1462 -0
- package/dist/js/graupl.iife.js +5 -0
- package/docs/.vitepress/config.js +39 -12
- package/docs/components/alert.md +130 -0
- package/docs/components/button.md +84 -0
- package/docs/components/card.md +369 -0
- package/docs/components/index.md +1 -0
- package/docs/components/inputgroup.md +159 -0
- package/docs/components/menu.md +326 -0
- package/docs/components/navigation.md +158 -0
- package/docs/content.md +237 -0
- package/docs/defaults.md +121 -0
- package/docs/forms.md +79 -0
- package/docs/functions.md +9 -0
- package/docs/getting-started.md +1 -0
- package/docs/index.md +1 -7
- package/docs/introduction.md +22 -2
- package/docs/layout.md +200 -0
- package/docs/mixins.md +47 -0
- package/docs/state.md +67 -0
- package/docs/theme.md +258 -0
- package/docs/utilities.md +357 -0
- package/eslint.config.js +1 -0
- package/index.html +816 -327
- package/index.js +12 -0
- package/package.json +32 -41
- package/scss/base/button.scss +3 -0
- package/scss/base/form.scss +1 -1
- package/scss/base/link.scss +1 -1
- package/scss/base/table.scss +1 -1
- package/scss/base.scss +1 -1
- package/scss/component/accordion.scss +3 -0
- package/scss/component/alert.scss +3 -0
- package/scss/component/card.scss +3 -0
- package/scss/component/carousel.scss +3 -0
- package/scss/component/input-group.scss +1 -1
- package/scss/component/menu.scss +3 -0
- package/scss/component/navigation.scss +3 -0
- package/scss/component.scss +1 -1
- package/scss/graupl.scss +1 -3
- package/scss/init.scss +3 -0
- package/scss/layout/columns.scss +1 -1
- package/scss/layout/container.scss +1 -1
- package/scss/layout/flex-columns.scss +3 -0
- package/scss/layout.scss +1 -1
- package/scss/normalize.scss +3 -0
- package/scss/state/focus.scss +1 -1
- package/scss/state.scss +1 -1
- package/scss/theme/color.scss +1 -1
- package/scss/theme/typography.scss +1 -1
- package/scss/theme.scss +1 -1
- package/scss/utilities/alignment.scss +3 -0
- package/scss/utilities/color.scss +3 -0
- package/scss/utilities/display.scss +3 -0
- package/scss/utilities/flex.scss +3 -0
- package/scss/utilities/height.scss +3 -0
- package/scss/utilities/inset.scss +3 -0
- package/scss/utilities/justification.scss +3 -0
- package/scss/utilities/list.scss +3 -0
- package/scss/utilities/order.scss +3 -0
- package/scss/utilities/postion.scss +3 -0
- package/scss/utilities/ratio.scss +3 -0
- package/scss/utilities/spacing.scss +1 -1
- package/scss/utilities/typography.scss +1 -1
- package/scss/utilities/visibility.scss +3 -0
- package/scss/utilities/width.scss +3 -0
- package/scss/utilities.scss +1 -1
- package/src/js/accordion/Accordion.js +1163 -0
- package/src/js/accordion/AccordionItem.js +496 -0
- package/src/js/accordion/index.js +10 -0
- package/src/js/alert/Alert.js +581 -0
- package/src/js/alert/index.js +11 -0
- package/src/js/carousel/Carousel.js +1427 -0
- package/src/js/carousel/index.js +10 -0
- package/src/js/domHelpers.js +37 -0
- package/src/js/eventHandlers.js +39 -0
- package/src/js/navigation/index.js +36 -0
- package/src/js/storage.js +106 -0
- package/src/js/validate.js +225 -0
- package/src/scss/_defaults.scss +74 -5
- package/src/scss/_index.scss +4 -3
- package/src/scss/_init.scss +2 -2
- package/src/scss/_normalize.scss +197 -0
- package/src/scss/_variables.scss +7 -7
- package/src/scss/base/_index.scss +2 -1
- package/src/scss/base/button/_defaults.scss +60 -0
- package/src/scss/base/button/_index.scss +107 -0
- package/src/scss/base/button/_mixins.scss +166 -0
- package/src/scss/{component → base}/button/_variables.scss +64 -19
- package/src/scss/base/form/_defaults.scss +14 -4
- package/src/scss/base/form/_index.scss +23 -20
- package/src/scss/base/form/_variables.scss +14 -2
- package/src/scss/base/link/_defaults.scss +48 -5
- package/src/scss/base/link/_index.scss +111 -10
- package/src/scss/base/link/_variables.scss +234 -4
- package/src/scss/base/table/_defaults.scss +49 -4
- package/src/scss/base/table/_index.scss +102 -8
- package/src/scss/base/table/_variables.scss +75 -5
- package/src/scss/component/_index.scss +7 -3
- package/src/scss/component/accordion/_defaults.scss +40 -0
- package/src/scss/component/accordion/_index.scss +180 -0
- package/src/scss/component/accordion/_variables.scss +316 -0
- package/src/scss/component/alert/_defaults.scss +49 -0
- package/src/scss/component/alert/_index.scss +118 -0
- package/src/scss/component/alert/_variables.scss +173 -0
- package/src/scss/component/card/_defaults.scss +32 -0
- package/src/scss/component/card/_index.scss +178 -0
- package/src/scss/component/card/_variables.scss +186 -0
- package/src/scss/component/carousel/_defaults.scss +43 -0
- package/src/scss/component/carousel/_index.scss +188 -0
- package/src/scss/component/carousel/_variables.scss +104 -0
- package/src/scss/component/input-group/_defaults.scss +11 -4
- package/src/scss/component/input-group/_index.scss +13 -11
- package/src/scss/component/input-group/_variables.scss +4 -1
- package/src/scss/component/menu/_defaults.scss +66 -0
- package/src/scss/component/menu/_index.scss +305 -0
- package/src/scss/component/menu/_variables.scss +500 -0
- package/src/scss/component/navigation/_defaults.scss +29 -0
- package/src/scss/component/navigation/_index.scss +189 -0
- package/src/scss/component/navigation/_variables.scss +237 -0
- package/src/scss/functions/_important.scss +2 -0
- package/src/scss/functions/_screen.scss +30 -0
- package/src/scss/functions/_theme.scss +28 -7
- package/src/scss/layout/_index.scss +2 -1
- package/src/scss/layout/columns/_defaults.scss +12 -4
- package/src/scss/layout/columns/_index.scss +29 -7
- package/src/scss/layout/columns/_variables.scss +6 -2
- package/src/scss/layout/container/_defaults.scss +13 -4
- package/src/scss/layout/container/_index.scss +12 -7
- package/src/scss/layout/container/_variables.scss +4 -1
- package/src/scss/layout/flex-columns/_defaults.scss +18 -0
- package/src/scss/layout/flex-columns/_index.scss +80 -0
- package/src/scss/layout/flex-columns/_variables.scss +26 -0
- package/src/scss/mixins/_animation.scss +15 -0
- package/src/scss/mixins/_layer.scss +3 -5
- package/src/scss/mixins/_screen.scss +56 -0
- package/src/scss/mixins/_utility.scss +30 -0
- package/src/scss/mixins/_visually-hidden.scss +20 -0
- package/src/scss/state/_index.scss +1 -1
- package/src/scss/state/focus/_defaults.scss +6 -4
- package/src/scss/state/focus/_index.scss +7 -7
- package/src/scss/state/focus/_mixins.scss +15 -0
- package/src/scss/state/focus/_variables.scss +6 -2
- package/src/scss/theme/_index.scss +1 -1
- package/src/scss/theme/color/_defaults.scss +101 -19
- package/src/scss/theme/color/_index.scss +17 -17
- package/src/scss/theme/color/_variables.scss +72 -64
- package/src/scss/theme/typography/_defaults.scss +7 -5
- package/src/scss/theme/typography/_index.scss +1 -1
- package/src/scss/theme/typography/_variables.scss +11 -7
- package/src/scss/utilities/_index.scss +14 -2
- package/src/scss/utilities/alignment/_defaults.scss +62 -0
- package/src/scss/utilities/alignment/_index.scss +75 -0
- package/src/scss/utilities/alignment/_variables.scss +6 -0
- package/src/scss/utilities/color/_defaults.scss +35 -0
- package/src/scss/utilities/color/_index.scss +91 -0
- package/src/scss/utilities/color/_variables.scss +6 -0
- package/src/scss/utilities/display/_defaults.scss +32 -0
- package/src/scss/utilities/display/_index.scss +61 -0
- package/src/scss/utilities/display/_variables.scss +6 -0
- package/src/scss/utilities/flex/_defaults.scss +63 -0
- package/src/scss/utilities/flex/_index.scss +71 -0
- package/src/scss/utilities/flex/_variables.scss +6 -0
- package/src/scss/utilities/height/_defaults.scss +41 -0
- package/src/scss/utilities/height/_index.scss +98 -0
- package/src/scss/utilities/height/_variables.scss +6 -0
- package/src/scss/utilities/inset/_defaults.scss +41 -0
- package/src/scss/utilities/inset/_index.scss +37 -0
- package/src/scss/utilities/inset/_variables.scss +6 -0
- package/src/scss/utilities/justification/_defaults.scss +59 -0
- package/src/scss/utilities/justification/_index.scss +75 -0
- package/src/scss/utilities/justification/_variables.scss +6 -0
- package/src/scss/utilities/list/_defaults.scss +39 -0
- package/src/scss/utilities/list/_index.scss +56 -0
- package/src/scss/utilities/list/_variables.scss +6 -0
- package/src/scss/utilities/order/_defaults.scss +22 -0
- package/src/scss/utilities/order/_index.scss +63 -0
- package/src/scss/utilities/order/_variables.scss +6 -0
- package/src/scss/utilities/position/_defaults.scss +26 -0
- package/src/scss/utilities/position/_index.scss +37 -0
- package/src/scss/utilities/position/_variables.scss +6 -0
- package/src/scss/utilities/ratio/_defaults.scss +28 -0
- package/src/scss/utilities/ratio/_index.scss +52 -0
- package/src/scss/utilities/ratio/_variables.scss +9 -0
- package/src/scss/utilities/spacing/_defaults.scss +9 -4
- package/src/scss/utilities/spacing/_index.scss +134 -29
- package/src/scss/utilities/spacing/_variables.scss +5 -2
- package/src/scss/utilities/typography/_defaults.scss +29 -4
- package/src/scss/utilities/typography/_index.scss +155 -23
- package/src/scss/utilities/typography/_variables.scss +5 -2
- package/src/scss/utilities/visibility/_defaults.scss +25 -0
- package/src/scss/utilities/visibility/_index.scss +36 -0
- package/src/scss/utilities/visibility/_variables.scss +6 -0
- package/src/scss/utilities/width/_defaults.scss +41 -0
- package/src/scss/utilities/width/_index.scss +98 -0
- package/src/scss/utilities/width/_variables.scss +6 -0
- package/stylelint.config.js +5 -0
- package/vite.config.js +57 -0
- package/dist/base/form.css +0 -2
- package/dist/base/form.css.map +0 -1
- package/dist/base/link.css +0 -2
- package/dist/base/link.css.map +0 -1
- package/dist/base/table.css +0 -2
- package/dist/base/table.css.map +0 -1
- package/dist/base.css +0 -2
- package/dist/base.css.map +0 -1
- package/dist/component/button.css +0 -2
- package/dist/component/button.css.map +0 -1
- package/dist/component/input-group.css.map +0 -1
- package/dist/component/table.css +0 -2
- package/dist/component/table.css.map +0 -1
- package/dist/component.css +0 -2
- package/dist/component.css.map +0 -1
- package/dist/graupl.css +0 -2
- package/dist/graupl.css.map +0 -1
- package/dist/layout/columns.css +0 -2
- package/dist/layout/columns.css.map +0 -1
- package/dist/layout/container.css.map +0 -1
- package/dist/layout.css +0 -2
- package/dist/layout.css.map +0 -1
- package/dist/state/focus.css +0 -2
- package/dist/state/focus.css.map +0 -1
- package/dist/state.css +0 -2
- package/dist/state.css.map +0 -1
- package/dist/theme/color.css +0 -2
- package/dist/theme/color.css.map +0 -1
- package/dist/theme/typography.css +0 -2
- package/dist/theme/typography.css.map +0 -1
- package/dist/theme.css +0 -2
- package/dist/theme.css.map +0 -1
- package/dist/utilities/colors.css.map +0 -1
- package/dist/utilities/spacing.css +0 -2
- package/dist/utilities/spacing.css.map +0 -1
- package/dist/utilities/typography.css +0 -2
- package/dist/utilities/typography.css.map +0 -1
- package/dist/utilities.css +0 -2
- package/dist/utilities.css.map +0 -1
- package/scss/component/button.scss +0 -3
- package/scss/component/table.scss +0 -3
- package/scss/utilities/colors.scss +0 -3
- package/src/scss/component/button/_defaults.scss +0 -39
- package/src/scss/component/button/_index.scss +0 -98
- package/src/scss/component/table/_defaults.scss +0 -30
- package/src/scss/component/table/_index.scss +0 -77
- package/src/scss/component/table/_variables.scss +0 -64
- package/src/scss/mixins/_media-queries.scss +0 -26
- package/src/scss/utilities/colors/_defaults.scss +0 -5
- package/src/scss/utilities/colors/_index.scss +0 -22
- package/src/scss/utilities/colors/_variables.scss +0 -3
- /package/dist/{layout → css/layout}/container.css +0 -0
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
// @graupl/graupl 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: $navigation-toggle-border;
|
|
44
|
+
border-radius: $navigation-toggle-border-radius;
|
|
45
|
+
|
|
46
|
+
&::before {
|
|
47
|
+
content: $navigation-toggle-content;
|
|
48
|
+
display: block;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
// Navigation branding.
|
|
53
|
+
#{defaults.$navigation-branding-selector} {
|
|
54
|
+
display: flex;
|
|
55
|
+
grid-area: branding;
|
|
56
|
+
align-items: center;
|
|
57
|
+
justify-content: flex-start;
|
|
58
|
+
padding: $navigation-branding-padding;
|
|
59
|
+
font-size: $navigation-branding-font-size;
|
|
60
|
+
font-weight: $navigation-branding-font-weight;
|
|
61
|
+
text-decoration: $navigation-branding-text-decoration;
|
|
62
|
+
text-decoration-style: $navigation-branding-text-decoration-style;
|
|
63
|
+
text-decoration-thickness: $navigation-branding-text-decoration-thickness;
|
|
64
|
+
|
|
65
|
+
&:visited {
|
|
66
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-visited-text-decoration};
|
|
67
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-visited-text-decoration-thickness};
|
|
68
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-visited-text-decoration-style};
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
&:focus-visible {
|
|
72
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-focus-text-decoration};
|
|
73
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-focus-text-decoration-thickness};
|
|
74
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-focus-text-decoration-style};
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
&:hover {
|
|
78
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-hover-text-decoration};
|
|
79
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-hover-text-decoration-thickness};
|
|
80
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-hover-text-decoration-style};
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
&:active {
|
|
84
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-active-text-decoration};
|
|
85
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-active-text-decoration-thickness};
|
|
86
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-active-text-decoration-style};
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
&:disabled,
|
|
90
|
+
&[disabled] {
|
|
91
|
+
&,
|
|
92
|
+
&:visited,
|
|
93
|
+
&:focus-visible,
|
|
94
|
+
&:hover,
|
|
95
|
+
&:active {
|
|
96
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration: #{$navigation-branding-disabled-text-decoration};
|
|
97
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness: #{$navigation-branding-disabled-text-decoration-thickness};
|
|
98
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-style: #{$navigation-branding-disabled-text-decoration-style};
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
@include screen.trigger(navigation-collapse) {
|
|
104
|
+
// Navigation.
|
|
105
|
+
#{defaults.$navigation-selector} {
|
|
106
|
+
--#{root-defaults.$prefix}-menu-flex-direction: column;
|
|
107
|
+
--#{root-defaults.$prefix}-submenu-position: relative;
|
|
108
|
+
--#{root-defaults.$prefix}-menu-item-min-width: 100%;
|
|
109
|
+
--#{root-defaults.$prefix}-submenu-inset: auto;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
@include screen.trigger(navigation-expand) {
|
|
114
|
+
// Navigation.
|
|
115
|
+
#{defaults.$navigation-selector} {
|
|
116
|
+
--#{root-defaults.$prefix}-menu-hide-display: #{menu-variables.$menu-show-display};
|
|
117
|
+
|
|
118
|
+
grid-template-areas: "branding - menu";
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// Navigation toggle.
|
|
122
|
+
#{defaults.$navigation-toggle-selector} {
|
|
123
|
+
display: none;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
@include layer(theme) {
|
|
129
|
+
// Navigation.
|
|
130
|
+
#{defaults.$navigation-selector} {
|
|
131
|
+
--#{root-defaults.$prefix}-menu-background: #{$navigation-background};
|
|
132
|
+
--#{root-defaults.$prefix}-menu-color: #{$navigation-color};
|
|
133
|
+
--#{root-defaults.$prefix}-submenu-background: #{$navigation-background};
|
|
134
|
+
--#{root-defaults.$prefix}-submenu-color: #{$navigation-color};
|
|
135
|
+
|
|
136
|
+
background: $navigation-background;
|
|
137
|
+
color: $navigation-color;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
// Navigation toggle.
|
|
141
|
+
#{defaults.$navigation-toggle-selector} {
|
|
142
|
+
border-color: $navigation-toggle-border-color;
|
|
143
|
+
background: $navigation-toggle-background;
|
|
144
|
+
color: $navigation-toggle-color;
|
|
145
|
+
|
|
146
|
+
&:hover {
|
|
147
|
+
--#{root-defaults.$prefix}-navigation-toggle-background: #{$navigation-toggle-hover-background};
|
|
148
|
+
--#{root-defaults.$prefix}-navigation-toggle-color: #{$navigation-toggle-hover-color};
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
// Navigation branding.
|
|
153
|
+
#{defaults.$navigation-branding-selector} {
|
|
154
|
+
color: $navigation-branding-color;
|
|
155
|
+
text-decoration-color: $navigation-branding-text-decoration-color;
|
|
156
|
+
|
|
157
|
+
&:visited {
|
|
158
|
+
--#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-visited-color};
|
|
159
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-visited-text-decoration-color};
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
&:focus-visible {
|
|
163
|
+
--#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-focus-color};
|
|
164
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-focus-text-decoration-color};
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
&:hover {
|
|
168
|
+
--#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-hover-color};
|
|
169
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-hover-text-decoration-color};
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
&:active {
|
|
173
|
+
--#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-active-color};
|
|
174
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-active-text-decoration-color};
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
&:disabled,
|
|
178
|
+
&[disabled] {
|
|
179
|
+
&,
|
|
180
|
+
&:visited,
|
|
181
|
+
&:focus-visible,
|
|
182
|
+
&:hover,
|
|
183
|
+
&:active {
|
|
184
|
+
--#{root-defaults.$prefix}-navigation-branding-color: #{$navigation-branding-disabled-color};
|
|
185
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-color: #{$navigation-branding-disabled-text-decoration-color};
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
// @graupl/graupl 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.$root-background}
|
|
17
|
+
);
|
|
18
|
+
$navigation-color: var(
|
|
19
|
+
--#{root-defaults.$prefix}-navigation-color,
|
|
20
|
+
#{color.$root-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-width: var(
|
|
67
|
+
--#{root-defaults.$prefix}-navigation-toggle-border-width,
|
|
68
|
+
#{root-variables.$border-width}
|
|
69
|
+
);
|
|
70
|
+
$navigation-toggle-border-style: var(
|
|
71
|
+
--#{root-defaults.$prefix}-navigation-toggle-border-style,
|
|
72
|
+
#{root-variables.$border-style}
|
|
73
|
+
);
|
|
74
|
+
$navigation-toggle-border: var(
|
|
75
|
+
--#{root-defaults.$prefix}-navigation-toggle-border,
|
|
76
|
+
#{$navigation-toggle-border-width} #{$navigation-toggle-border-style}
|
|
77
|
+
);
|
|
78
|
+
$navigation-toggle-border-color: var(
|
|
79
|
+
--#{root-defaults.$prefix}-navigation-toggle-border-color,
|
|
80
|
+
#{$navigation-toggle-color}
|
|
81
|
+
);
|
|
82
|
+
$navigation-toggle-border-radius: var(
|
|
83
|
+
--#{root-defaults.$prefix}-navigation-toggle-border-radius,
|
|
84
|
+
#{root-variables.$border-radius}
|
|
85
|
+
);
|
|
86
|
+
|
|
87
|
+
// Navigation branding properties.
|
|
88
|
+
$navigation-branding-font-size: var(
|
|
89
|
+
--#{root-defaults.$prefix}-navigation-branding-font-size,
|
|
90
|
+
#{map.get(typography.$font-sizes, "lg")}
|
|
91
|
+
);
|
|
92
|
+
$navigation-branding-font-weight: var(
|
|
93
|
+
--#{root-defaults.$prefix}-navigation-branding-font-weight,
|
|
94
|
+
#{typography.$font-weight-bold}
|
|
95
|
+
);
|
|
96
|
+
$navigation-branding-padding-x: var(
|
|
97
|
+
--#{root-defaults.$prefix}-navigation-branding-padding-x,
|
|
98
|
+
#{map.get(root-variables.$spacers, 3)}
|
|
99
|
+
);
|
|
100
|
+
$navigation-branding-padding-y: var(
|
|
101
|
+
--#{root-defaults.$prefix}-navigation-branding-padding-y,
|
|
102
|
+
#{map.get(root-variables.$spacers, 2)}
|
|
103
|
+
);
|
|
104
|
+
$navigation-branding-padding: var(
|
|
105
|
+
--#{root-defaults.$prefix}-navigation-branding-padding,
|
|
106
|
+
#{$navigation-branding-padding-y} #{$navigation-branding-padding-x}
|
|
107
|
+
);
|
|
108
|
+
|
|
109
|
+
// Navigation branding colors.
|
|
110
|
+
$navigation-branding-color: var(
|
|
111
|
+
--#{root-defaults.$prefix}-navigation-branding-color,
|
|
112
|
+
#{$navigation-color}
|
|
113
|
+
);
|
|
114
|
+
$navigation-branding-visited-color: var(
|
|
115
|
+
--#{root-defaults.$prefix}-navigation-branding-visited-color,
|
|
116
|
+
#{$navigation-color}
|
|
117
|
+
);
|
|
118
|
+
$navigation-branding-focus-color: var(
|
|
119
|
+
--#{root-defaults.$prefix}-navigation-branding-focus-color,
|
|
120
|
+
#{$navigation-color}
|
|
121
|
+
);
|
|
122
|
+
$navigation-branding-hover-color: var(
|
|
123
|
+
--#{root-defaults.$prefix}-navigation-branding-hover-color,
|
|
124
|
+
#{$navigation-color}
|
|
125
|
+
);
|
|
126
|
+
$navigation-branding-active-color: var(
|
|
127
|
+
--#{root-defaults.$prefix}-navigation-branding-active-color,
|
|
128
|
+
#{$navigation-color}
|
|
129
|
+
);
|
|
130
|
+
$navigation-branding-disabled-color: var(
|
|
131
|
+
--#{root-defaults.$prefix}-navigation-branding-disabled-color,
|
|
132
|
+
#{$navigation-color}
|
|
133
|
+
);
|
|
134
|
+
|
|
135
|
+
// Navigation branding text decoration properties.
|
|
136
|
+
$navigation-branding-text-decoration: var(
|
|
137
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration,
|
|
138
|
+
#{defaults.$navigation-branding-text-decoration}
|
|
139
|
+
);
|
|
140
|
+
$navigation-branding-visited-text-decoration: var(
|
|
141
|
+
--#{root-defaults.$prefix}-navigation-branding-visited-text-decoration,
|
|
142
|
+
#{defaults.$navigation-branding-visited-text-decoration}
|
|
143
|
+
);
|
|
144
|
+
$navigation-branding-focus-text-decoration: var(
|
|
145
|
+
--#{root-defaults.$prefix}-navigation-branding-focus-text-decoration,
|
|
146
|
+
#{defaults.$navigation-branding-focus-text-decoration}
|
|
147
|
+
);
|
|
148
|
+
$navigation-branding-hover-text-decoration: var(
|
|
149
|
+
--#{root-defaults.$prefix}-navigation-branding-hover-text-decoration,
|
|
150
|
+
#{defaults.$navigation-branding-hover-text-decoration}
|
|
151
|
+
);
|
|
152
|
+
$navigation-branding-active-text-decoration: var(
|
|
153
|
+
--#{root-defaults.$prefix}-navigation-branding-active-text-decoration,
|
|
154
|
+
#{defaults.$navigation-branding-active-text-decoration}
|
|
155
|
+
);
|
|
156
|
+
$navigation-branding-disabled-text-decoration: var(
|
|
157
|
+
--#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration,
|
|
158
|
+
#{defaults.$navigation-branding-disabled-text-decoration}
|
|
159
|
+
);
|
|
160
|
+
$navigation-branding-text-decoration-style: var(
|
|
161
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-style,
|
|
162
|
+
#{defaults.$navigation-branding-text-decoration-style}
|
|
163
|
+
);
|
|
164
|
+
$navigation-branding-visited-text-decoration-style: var(
|
|
165
|
+
--#{root-defaults.$prefix}-navigation-branding-visited-text-decoration-style,
|
|
166
|
+
#{defaults.$navigation-branding-visited-text-decoration-style}
|
|
167
|
+
);
|
|
168
|
+
$navigation-branding-focus-text-decoration-style: var(
|
|
169
|
+
--#{root-defaults.$prefix}-navigation-branding-focus-text-decoration-style,
|
|
170
|
+
#{defaults.$navigation-branding-focus-text-decoration-style}
|
|
171
|
+
);
|
|
172
|
+
$navigation-branding-hover-text-decoration-style: var(
|
|
173
|
+
--#{root-defaults.$prefix}-navigation-branding-hover-text-decoration-style,
|
|
174
|
+
#{defaults.$navigation-branding-hover-text-decoration-style}
|
|
175
|
+
);
|
|
176
|
+
$navigation-branding-active-text-decoration-style: var(
|
|
177
|
+
--#{root-defaults.$prefix}-navigation-branding-active-text-decoration-style,
|
|
178
|
+
#{defaults.$navigation-branding-active-text-decoration-style}
|
|
179
|
+
);
|
|
180
|
+
$navigation-branding-disabled-text-decoration-style: var(
|
|
181
|
+
--#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration-style,
|
|
182
|
+
#{defaults.$navigation-branding-disabled-text-decoration-style}
|
|
183
|
+
);
|
|
184
|
+
$navigation-branding-text-decoration-thickness: var(
|
|
185
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-thickness,
|
|
186
|
+
#{root-variables.$border-width}
|
|
187
|
+
);
|
|
188
|
+
$navigation-branding-visited-text-decoration-thickness: var(
|
|
189
|
+
--#{root-defaults.$prefix}-navigation-branding-visited-text-decoration-thickness,
|
|
190
|
+
#{root-variables.$border-width}
|
|
191
|
+
);
|
|
192
|
+
$navigation-branding-focus-text-decoration-thickness: var(
|
|
193
|
+
--#{root-defaults.$prefix}-navigation-branding-focus-text-decoration-thickness,
|
|
194
|
+
#{root-variables.$border-width}
|
|
195
|
+
);
|
|
196
|
+
$navigation-branding-hover-text-decoration-thickness: var(
|
|
197
|
+
--#{root-defaults.$prefix}-navigation-branding-hover-text-decoration-thickness,
|
|
198
|
+
#{root-variables.$border-width}
|
|
199
|
+
);
|
|
200
|
+
$navigation-branding-active-text-decoration-thickness: var(
|
|
201
|
+
--#{root-defaults.$prefix}-navigation-branding-active-text-decoration-thickness,
|
|
202
|
+
#{root-variables.$border-width}
|
|
203
|
+
);
|
|
204
|
+
$navigation-branding-disabled-text-decoration-thickness: var(
|
|
205
|
+
--#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration-thickness,
|
|
206
|
+
#{root-variables.$border-width}
|
|
207
|
+
);
|
|
208
|
+
$navigation-branding-text-decoration-color: var(
|
|
209
|
+
--#{root-defaults.$prefix}-navigation-branding-text-decoration-color,
|
|
210
|
+
#{$navigation-branding-color}
|
|
211
|
+
);
|
|
212
|
+
$navigation-branding-visited-text-decoration-color: var(
|
|
213
|
+
--#{root-defaults.$prefix}-navigation-branding-visited-text-decoration-color,
|
|
214
|
+
#{$navigation-branding-visited-color}
|
|
215
|
+
);
|
|
216
|
+
$navigation-branding-focus-text-decoration-color: var(
|
|
217
|
+
--#{root-defaults.$prefix}-navigation-branding-focus-text-decoration-color,
|
|
218
|
+
#{$navigation-branding-focus-color}
|
|
219
|
+
);
|
|
220
|
+
$navigation-branding-hover-text-decoration-color: var(
|
|
221
|
+
--#{root-defaults.$prefix}-navigation-branding-hover-text-decoration-color,
|
|
222
|
+
#{$navigation-branding-hover-color}
|
|
223
|
+
);
|
|
224
|
+
$navigation-branding-active-text-decoration-color: var(
|
|
225
|
+
--#{root-defaults.$prefix}-navigation-branding-active-text-decoration-color,
|
|
226
|
+
#{$navigation-branding-active-color}
|
|
227
|
+
);
|
|
228
|
+
$navigation-branding-disabled-text-decoration-color: var(
|
|
229
|
+
--#{root-defaults.$prefix}-navigation-branding-disabled-text-decoration-color,
|
|
230
|
+
#{$navigation-branding-disabled-color}
|
|
231
|
+
);
|
|
232
|
+
|
|
233
|
+
// Navigation toggle properties.
|
|
234
|
+
$navigation-toggle-content: var(
|
|
235
|
+
--#{root-defaults.$prefix}-navigation-toggle-content,
|
|
236
|
+
#{defaults.$navigation-toggle-content}
|
|
237
|
+
);
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// @graupl/graupl 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
|
+
$screen-size: map.get(root-defaults.$screen-sizes, $size);
|
|
11
|
+
|
|
12
|
+
@return $screen-size;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
@function max($size) {
|
|
16
|
+
$keys: map.keys(root-defaults.$screen-sizes);
|
|
17
|
+
$index: list.index($keys, "#{$size}");
|
|
18
|
+
$key: list.nth($keys, $index + 1);
|
|
19
|
+
$screen-size: map.get(root-defaults.$screen-sizes, $key);
|
|
20
|
+
$screen-size: $screen-size - 1;
|
|
21
|
+
|
|
22
|
+
@return $screen-size;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@function range($min, $max) {
|
|
26
|
+
$min-size: min($min);
|
|
27
|
+
$max-size: max($max);
|
|
28
|
+
|
|
29
|
+
@return (min: $min-size, max: $max-size);
|
|
30
|
+
}
|
|
@@ -1,18 +1,39 @@
|
|
|
1
|
+
// @graupl/graupl theme functions.
|
|
2
|
+
//
|
|
1
3
|
// Functions to help with getting information about the theme.
|
|
2
4
|
|
|
3
5
|
@use "sass:map";
|
|
4
6
|
@use "../theme/color/variables" as color;
|
|
5
7
|
|
|
6
8
|
// A function to get the specific theme shades.
|
|
7
|
-
@function get($color, $shade) {
|
|
8
|
-
$
|
|
9
|
-
|
|
9
|
+
@function get($color, $shade, $theme: active) {
|
|
10
|
+
@if $shade == transparent or $color == transparent {
|
|
11
|
+
@return transparent;
|
|
12
|
+
}
|
|
10
13
|
|
|
11
|
-
@
|
|
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;
|
|
12
31
|
}
|
|
13
32
|
|
|
14
|
-
@function variants() {
|
|
15
|
-
|
|
33
|
+
@function variants($theme: active) {
|
|
34
|
+
@if map.has-key(color.$themes, $theme) {
|
|
35
|
+
@return map.keys(map.get(color.$themes, $theme));
|
|
36
|
+
}
|
|
16
37
|
|
|
17
|
-
@return
|
|
38
|
+
@return null;
|
|
18
39
|
}
|
|
@@ -1,9 +1,17 @@
|
|
|
1
|
-
//
|
|
1
|
+
// @graupl/graupl columns layout default values.
|
|
2
2
|
//
|
|
3
|
-
// Generally, these should not be used directly when styling components.
|
|
4
|
-
// They are mainly used to provide
|
|
5
|
-
//
|
|
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
|
+
// Columns selectors.
|
|
10
|
+
$columns-selector: ".columns" !default;
|
|
11
|
+
$columns-count-selector-prefix: ".count-" !default;
|
|
12
|
+
$columns-span-selector-prefix: ".span-" !default;
|
|
6
13
|
|
|
14
|
+
// Columns properties.
|
|
7
15
|
$columns-max-width: 1fr !default;
|
|
8
16
|
$columns-count: 3 !default;
|
|
9
17
|
$columns-min-count: 1 !default;
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
//
|
|
1
|
+
// @graupl/graupl columns layout styles.
|
|
2
2
|
|
|
3
3
|
@use "variables" as *;
|
|
4
4
|
@use "defaults";
|
|
5
5
|
@use "../../defaults" as root-defaults;
|
|
6
6
|
@use "../../mixins/layer" as *;
|
|
7
|
-
@use "../../mixins/
|
|
7
|
+
@use "../../mixins/screen";
|
|
8
8
|
|
|
9
9
|
@include layer(layout) {
|
|
10
|
-
|
|
10
|
+
#{defaults.$columns-selector} {
|
|
11
11
|
display: grid;
|
|
12
12
|
grid-template-columns: $columns-grid-template-columns;
|
|
13
13
|
gap: $columns-row-gap $columns-column-gap;
|
|
@@ -18,19 +18,41 @@
|
|
|
18
18
|
}
|
|
19
19
|
|
|
20
20
|
@for $i from defaults.$columns-min-count through defaults.$columns-max-count {
|
|
21
|
-
|
|
21
|
+
#{defaults.$columns-count-selector-prefix}#{$i} {
|
|
22
22
|
--#{root-defaults.$prefix}-columns-count: #{$i};
|
|
23
|
+
|
|
24
|
+
// For span values bigger than the actual column count, set them to the
|
|
25
|
+
// maximum column count so they don't break the layout.
|
|
26
|
+
@for $j from $i + 1 through defaults.$columns-max-count {
|
|
27
|
+
#{defaults.$columns-span-selector-prefix}#{$j} {
|
|
28
|
+
--#{root-defaults.$prefix}-columns-span: #{$i};
|
|
29
|
+
}
|
|
30
|
+
}
|
|
23
31
|
}
|
|
24
32
|
|
|
25
|
-
|
|
33
|
+
#{defaults.$columns-span-selector-prefix}#{$i} {
|
|
26
34
|
--#{root-defaults.$prefix}-columns-span: #{$i};
|
|
27
35
|
}
|
|
28
36
|
}
|
|
29
37
|
|
|
30
38
|
// Disable columns on small screens to avoid horizontal bleeding.
|
|
31
|
-
@include screen(
|
|
32
|
-
|
|
39
|
+
@include screen.trigger(force-single-column) {
|
|
40
|
+
#{defaults.$columns-selector} {
|
|
33
41
|
--#{root-defaults.$prefix}-columns-min-width: #{defaults.$columns-max-width};
|
|
42
|
+
|
|
43
|
+
> * {
|
|
44
|
+
--#{root-defaults.$prefix}-columns-span: 1;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// All spans should be set to 1 to avoid adding columns.
|
|
48
|
+
@for $i
|
|
49
|
+
from defaults.$columns-min-count
|
|
50
|
+
through defaults.$columns-max-count
|
|
51
|
+
{
|
|
52
|
+
#{defaults.$columns-span-selector-prefix}#{$i} {
|
|
53
|
+
--#{root-defaults.$prefix}-columns-span: 1;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
34
56
|
}
|
|
35
57
|
}
|
|
36
58
|
}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
//
|
|
1
|
+
// @graupl/graupl columns layout 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 "../../variables" as root-variables;
|
|
@@ -29,7 +32,8 @@ $columns-min-width: var(
|
|
|
29
32
|
(
|
|
30
33
|
#{root-variables.$content-max-width} - #{$columns-column-gap} *
|
|
31
34
|
(#{$columns-count} - 1)
|
|
32
|
-
) /
|
|
35
|
+
) /
|
|
36
|
+
#{$columns-count}
|
|
33
37
|
)
|
|
34
38
|
);
|
|
35
39
|
/* stylelint-enable scss/operator-no-newline-after */
|
|
@@ -1,8 +1,17 @@
|
|
|
1
|
-
//
|
|
1
|
+
// @graupl/graupl container layout default values.
|
|
2
2
|
//
|
|
3
|
-
// Generally, these should not be used directly when styling components.
|
|
4
|
-
// They are mainly used to provide
|
|
5
|
-
//
|
|
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
|
+
// Container selectors.
|
|
10
|
+
$container-selector: ".container" !default;
|
|
11
|
+
$container-breakout-selector: ".breakout" !default;
|
|
12
|
+
$container-feature-selector: ".feature" !default;
|
|
13
|
+
$container-full-width-selector: ".full-width" !default;
|
|
6
14
|
|
|
15
|
+
// Container properties.
|
|
7
16
|
$container-breakout-width: 15ch !default;
|
|
8
17
|
$container-feature-width: 20ch !default;
|