@graupl/graupl 1.0.0-alpha.1 → 1.0.0-alpha.11
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/.stylelintignore +9 -0
- package/CHANGELOG.md +177 -0
- package/dist/base/form.css +2 -0
- package/dist/base/form.css.map +1 -0
- package/dist/base/link.css +2 -0
- package/dist/base/link.css.map +1 -0
- package/dist/base/table.css +2 -0
- package/dist/base/table.css.map +1 -0
- package/dist/base.css +2 -0
- package/dist/base.css.map +1 -0
- package/dist/component/button.css +2 -0
- package/dist/component/button.css.map +1 -0
- package/dist/component/input-group.css +2 -0
- package/dist/component/input-group.css.map +1 -0
- package/dist/component/table.css +2 -0
- package/dist/component/table.css.map +1 -0
- package/dist/component.css +2 -0
- package/dist/component.css.map +1 -0
- package/dist/graupl.css +1 -284
- package/dist/graupl.css.map +1 -1
- package/dist/layout/columns.css +2 -0
- package/dist/layout/columns.css.map +1 -0
- package/dist/layout/container.css +2 -0
- package/dist/layout/container.css.map +1 -0
- package/dist/layout.css +2 -0
- package/dist/layout.css.map +1 -0
- package/dist/state/focus.css +2 -0
- package/dist/state/focus.css.map +1 -0
- package/dist/state.css +2 -0
- package/dist/state.css.map +1 -0
- package/dist/theme/color.css +2 -0
- package/dist/theme/color.css.map +1 -0
- package/dist/theme/typography.css +2 -0
- package/dist/theme/typography.css.map +1 -0
- package/dist/theme.css +2 -0
- package/dist/theme.css.map +1 -0
- package/dist/utilities/alignment.css +2 -0
- package/dist/utilities/alignment.css.map +1 -0
- package/dist/utilities/color.css +2 -0
- package/dist/utilities/color.css.map +1 -0
- package/dist/utilities/display.css +2 -0
- package/dist/utilities/display.css.map +1 -0
- package/dist/utilities/flex.css +2 -0
- package/dist/utilities/flex.css.map +1 -0
- package/dist/utilities/inset.css +2 -0
- package/dist/utilities/inset.css.map +1 -0
- package/dist/utilities/justification.css +2 -0
- package/dist/utilities/justification.css.map +1 -0
- package/dist/utilities/list.css +2 -0
- package/dist/utilities/list.css.map +1 -0
- package/dist/utilities/postion.css +2 -0
- package/dist/utilities/postion.css.map +1 -0
- package/dist/utilities/spacing.css +2 -0
- package/dist/utilities/spacing.css.map +1 -0
- package/dist/utilities/typography.css +2 -0
- package/dist/utilities/typography.css.map +1 -0
- package/dist/utilities/visibility.css +2 -0
- package/dist/utilities/visibility.css.map +1 -0
- package/dist/utilities.css +2 -0
- package/dist/utilities.css.map +1 -0
- package/docs/.vitepress/config.js +41 -1
- package/docs/.vitepress/theme/custom.scss +29 -29
- package/docs/compiling-graupl.md +56 -0
- package/docs/introduction.md +5 -0
- package/index.html +333 -72
- package/package.json +16 -4
- package/postcss.config.cjs +1 -1
- package/scss/base/form.scss +3 -0
- package/scss/base/link.scss +3 -0
- package/scss/base/table.scss +3 -0
- package/scss/base.scss +3 -0
- package/scss/component/button.scss +3 -0
- package/scss/component/input-group.scss +3 -0
- package/scss/component/table.scss +3 -0
- package/scss/component.scss +3 -0
- package/scss/graupl.scss +1 -5
- package/scss/layout/columns.scss +3 -0
- package/scss/layout/container.scss +3 -0
- package/scss/layout.scss +3 -0
- package/scss/state/focus.scss +3 -0
- package/scss/state.scss +3 -0
- package/scss/theme/color.scss +3 -0
- package/scss/theme/typography.scss +3 -0
- package/scss/theme.scss +3 -0
- 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/inset.scss +3 -0
- package/scss/utilities/justification.scss +3 -0
- package/scss/utilities/list.scss +3 -0
- package/scss/utilities/postion.scss +3 -0
- package/scss/utilities/spacing.scss +3 -0
- package/scss/utilities/typography.scss +3 -0
- package/scss/utilities/visibility.scss +3 -0
- package/scss/utilities.scss +3 -0
- package/{scss → src/scss}/_defaults.scss +40 -13
- package/src/scss/_index.scss +14 -0
- package/src/scss/_init.scss +3 -0
- package/{scss → src/scss}/_variables.scss +14 -24
- package/{scss → src/scss}/base/_index.scss +1 -0
- package/{scss → src/scss}/base/form/_defaults.scss +0 -2
- package/{scss → src/scss}/base/form/_index.scss +12 -0
- package/src/scss/base/form/_variables.scss +145 -0
- package/{scss → src/scss}/base/link/_defaults.scss +0 -2
- package/src/scss/base/link/_index.scss +50 -0
- package/src/scss/base/link/_variables.scss +36 -0
- package/src/scss/base/table/_defaults.scss +8 -0
- package/src/scss/base/table/_index.scss +27 -0
- package/src/scss/base/table/_variables.scss +65 -0
- package/{scss → src/scss}/component/_index.scss +2 -0
- package/src/scss/component/button/_defaults.scss +39 -0
- package/src/scss/component/button/_index.scss +134 -0
- package/src/scss/component/button/_variables.scss +132 -0
- package/src/scss/component/input-group/_defaults.scss +23 -0
- package/src/scss/component/input-group/_index.scss +45 -0
- package/src/scss/component/input-group/_variables.scss +63 -0
- package/src/scss/component/table/_defaults.scss +30 -0
- package/src/scss/component/table/_index.scss +77 -0
- package/src/scss/component/table/_variables.scss +64 -0
- package/src/scss/functions/_important.scss +11 -0
- package/src/scss/functions/_theme.scss +18 -0
- package/{scss → src/scss}/layout/columns/_defaults.scss +1 -4
- package/src/scss/layout/columns/_index.scss +36 -0
- package/src/scss/layout/columns/_variables.scss +47 -0
- package/{scss → src/scss}/layout/container/_defaults.scss +0 -2
- package/src/scss/layout/container/_index.scss +36 -0
- package/src/scss/layout/container/_variables.scss +47 -0
- package/{scss → src/scss}/mixins/_layer.scss +2 -2
- package/{scss → src/scss}/mixins/_media-queries.scss +11 -0
- package/{scss → src/scss}/state/focus/_defaults.scss +0 -2
- package/src/scss/state/focus/_variables.scss +40 -0
- package/src/scss/theme/_index.scss +4 -0
- package/src/scss/theme/color/_defaults.scss +61 -0
- package/src/scss/theme/color/_index.scss +42 -0
- package/src/scss/theme/color/_variables.scss +121 -0
- package/src/scss/theme/typography/_defaults.scss +52 -0
- package/src/scss/theme/typography/_index.scss +111 -0
- package/src/scss/theme/typography/_variables.scss +227 -0
- package/src/scss/utilities/_index.scss +13 -0
- package/src/scss/utilities/alignment/_defaults.scss +57 -0
- package/src/scss/utilities/alignment/_index.scss +29 -0
- package/src/scss/utilities/alignment/_variables.scss +3 -0
- package/src/scss/utilities/color/_defaults.scss +30 -0
- package/src/scss/utilities/color/_index.scss +38 -0
- package/src/scss/utilities/color/_variables.scss +3 -0
- package/src/scss/utilities/display/_defaults.scss +27 -0
- package/src/scss/utilities/display/_index.scss +15 -0
- package/src/scss/utilities/display/_variables.scss +3 -0
- package/src/scss/utilities/flex/_defaults.scss +58 -0
- package/src/scss/utilities/flex/_index.scss +36 -0
- package/src/scss/utilities/flex/_variables.scss +3 -0
- package/src/scss/utilities/inset/_defaults.scss +36 -0
- package/src/scss/utilities/inset/_index.scss +19 -0
- package/src/scss/utilities/inset/_variables.scss +3 -0
- package/src/scss/utilities/justification/_defaults.scss +54 -0
- package/src/scss/utilities/justification/_index.scss +29 -0
- package/src/scss/utilities/justification/_variables.scss +3 -0
- package/src/scss/utilities/list/_defaults.scss +34 -0
- package/src/scss/utilities/list/_index.scss +22 -0
- package/src/scss/utilities/list/_variables.scss +3 -0
- package/src/scss/utilities/position/_defaults.scss +21 -0
- package/src/scss/utilities/position/_index.scss +15 -0
- package/src/scss/utilities/position/_variables.scss +3 -0
- package/src/scss/utilities/spacing/_defaults.scss +44 -0
- package/src/scss/utilities/spacing/_index.scss +64 -0
- package/src/scss/utilities/spacing/_variables.scss +3 -0
- package/src/scss/utilities/typography/_defaults.scss +25 -0
- package/src/scss/utilities/typography/_index.scss +95 -0
- package/src/scss/utilities/typography/_variables.scss +3 -0
- package/src/scss/utilities/visibility/_defaults.scss +20 -0
- package/src/scss/utilities/visibility/_index.scss +15 -0
- package/src/scss/utilities/visibility/_variables.scss +3 -0
- package/stylelint.config.js +2 -0
- package/dist/base/form/form.css +0 -78
- package/dist/base/form/form.css.map +0 -1
- package/dist/base/link/link.css +0 -26
- package/dist/base/link/link.css.map +0 -1
- package/dist/component/button/button.css +0 -62
- package/dist/component/button/button.css.map +0 -1
- package/dist/layout/columns/columns.css +0 -41
- package/dist/layout/columns/columns.css.map +0 -1
- package/dist/layout/container/container.css +0 -38
- package/dist/layout/container/container.css.map +0 -1
- package/dist/state/focus/focus.css +0 -10
- package/dist/state/focus/focus.css.map +0 -1
- package/dist/theme/theme.css +0 -42
- package/dist/theme/theme.css.map +0 -1
- package/scss/base/form/_variables.scss +0 -133
- package/scss/base/form/form.scss +0 -3
- package/scss/base/link/_index.scss +0 -33
- package/scss/base/link/_variables.scss +0 -31
- package/scss/base/link/link.scss +0 -3
- package/scss/component/button/_defaults.scss +0 -10
- package/scss/component/button/_index.scss +0 -75
- package/scss/component/button/_variables.scss +0 -102
- package/scss/component/button/button.scss +0 -3
- package/scss/layout/columns/_index.scss +0 -38
- package/scss/layout/columns/_variables.scss +0 -24
- package/scss/layout/columns/columns.scss +0 -3
- package/scss/layout/container/_index.scss +0 -50
- package/scss/layout/container/_variables.scss +0 -26
- package/scss/layout/container/container.scss +0 -3
- package/scss/state/focus/_variables.scss +0 -36
- package/scss/state/focus/focus.scss +0 -3
- package/scss/theme/_defaults.scss +0 -56
- package/scss/theme/_index.scss +0 -53
- package/scss/theme/_variables.scss +0 -297
- package/scss/theme/theme.scss +0 -3
- /package/{scss → src/scss}/layout/_index.scss +0 -0
- /package/{scss → src/scss}/state/_index.scss +0 -0
- /package/{scss → src/scss}/state/focus/_index.scss +0 -0
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
// Graupl Button Component.
|
|
2
|
+
|
|
3
|
+
@use "defaults";
|
|
4
|
+
@use "../../defaults" as root-defaults;
|
|
5
|
+
@use "../../theme/color/variables" as color;
|
|
6
|
+
@use "../../base/link/variables" as link;
|
|
7
|
+
@use "variables" as *;
|
|
8
|
+
@use "../../mixins/layer" as *;
|
|
9
|
+
@use "../../mixins/media-queries" as *;
|
|
10
|
+
@use "sass:map";
|
|
11
|
+
|
|
12
|
+
@include layer(component) {
|
|
13
|
+
.button {
|
|
14
|
+
display: flex;
|
|
15
|
+
align-items: center;
|
|
16
|
+
justify-content: center;
|
|
17
|
+
min-width: $button-min-width;
|
|
18
|
+
min-height: $button-min-height;
|
|
19
|
+
padding: $button-padding;
|
|
20
|
+
transition: $button-transition;
|
|
21
|
+
border-width: $button-border-width;
|
|
22
|
+
border-style: $button-border-style;
|
|
23
|
+
border-radius: $button-border-radius;
|
|
24
|
+
font-size: $button-font-size;
|
|
25
|
+
cursor: pointer;
|
|
26
|
+
|
|
27
|
+
&:hover {
|
|
28
|
+
transform: $button-hover-transform;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
&:active {
|
|
32
|
+
transform: $button-active-transform;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
&:disabled {
|
|
36
|
+
cursor: not-allowed;
|
|
37
|
+
|
|
38
|
+
&:hover,
|
|
39
|
+
&:active {
|
|
40
|
+
transform: none;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
&.link {
|
|
45
|
+
min-width: auto;
|
|
46
|
+
min-height: auto;
|
|
47
|
+
padding: 0;
|
|
48
|
+
border: 0;
|
|
49
|
+
font-size: inherit;
|
|
50
|
+
text-decoration: link.$link-text-decoration;
|
|
51
|
+
text-decoration-thickness: link.$link-text-decoration-thickness;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
@include animation-off {
|
|
56
|
+
.button {
|
|
57
|
+
transition: $button-transition-reduced-motion;
|
|
58
|
+
|
|
59
|
+
&:hover {
|
|
60
|
+
transform: $button-hover-transform-reduced-motion;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
&:active {
|
|
64
|
+
transform: $button-active-transform-reduced-motion;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
@include layer(theme) {
|
|
71
|
+
.button {
|
|
72
|
+
border-color: $button-border-color;
|
|
73
|
+
background: $button-background;
|
|
74
|
+
color: $button-color;
|
|
75
|
+
|
|
76
|
+
@each $color, $map in color.$theme-active {
|
|
77
|
+
&.#{$color} {
|
|
78
|
+
@each $prop, $shade in defaults.$button-state-theme-map {
|
|
79
|
+
--#{root-defaults.$prefix}-button-#{$prop}: #{map.get($map, $shade)};
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
&.link {
|
|
85
|
+
--#{root-defaults.$prefix}-button-color: #{link.$link-color};
|
|
86
|
+
--#{root-defaults.$prefix}-button-hover-color: #{link.$link-hover-color};
|
|
87
|
+
--#{root-defaults.$prefix}-button-active-color: #{link.$link-active-color};
|
|
88
|
+
--#{root-defaults.$prefix}-button-disabled-color: #{link.$link-disabled-color};
|
|
89
|
+
--#{root-defaults.$prefix}-button-background: none;
|
|
90
|
+
--#{root-defaults.$prefix}-button-hover-background: none;
|
|
91
|
+
--#{root-defaults.$prefix}-button-active-background: none;
|
|
92
|
+
--#{root-defaults.$prefix}-button-disabled-background: none;
|
|
93
|
+
--#{root-defaults.$prefix}-button-border-color: none;
|
|
94
|
+
--#{root-defaults.$prefix}-button-hover-border-color: none;
|
|
95
|
+
--#{root-defaults.$prefix}-button-active-border-color: none;
|
|
96
|
+
--#{root-defaults.$prefix}-button-disabled-border-color: none;
|
|
97
|
+
--#{root-defaults.$prefix}-button-hover-transform: none;
|
|
98
|
+
--#{root-defaults.$prefix}-button-active-transform: none;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
&:not(.link) {
|
|
102
|
+
--#{root-defaults.$prefix}-link-color: #{$button-color};
|
|
103
|
+
--#{root-defaults.$prefix}-link-hover-color: #{$button-hover-color};
|
|
104
|
+
--#{root-defaults.$prefix}-link-active-color: #{$button-active-color};
|
|
105
|
+
--#{root-defaults.$prefix}-link-visited-color: #{$button-hover-color};
|
|
106
|
+
--#{root-defaults.$prefix}-link-disabled-color: #{$button-disabled-color};
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
&:hover {
|
|
110
|
+
--#{root-defaults.$prefix}-button-border-color: #{$button-hover-border-color};
|
|
111
|
+
--#{root-defaults.$prefix}-button-background: #{$button-hover-background};
|
|
112
|
+
--#{root-defaults.$prefix}-button-color: #{$button-hover-color};
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
&:active {
|
|
116
|
+
--#{root-defaults.$prefix}-button-border-color: #{$button-active-border-color};
|
|
117
|
+
--#{root-defaults.$prefix}-button-background: #{$button-active-background};
|
|
118
|
+
--#{root-defaults.$prefix}-button-color: #{$button-active-color};
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
&:disabled {
|
|
122
|
+
--#{root-defaults.$prefix}-button-border-color: #{$button-disabled-border-color};
|
|
123
|
+
--#{root-defaults.$prefix}-button-background: #{$button-disabled-background};
|
|
124
|
+
--#{root-defaults.$prefix}-button-color: #{$button-disabled-color};
|
|
125
|
+
|
|
126
|
+
&:hover,
|
|
127
|
+
&:active {
|
|
128
|
+
--#{root-defaults.$prefix}-button-border-color: #{$button-disabled-border-color};
|
|
129
|
+
--#{root-defaults.$prefix}-button-background: #{$button-disabled-background};
|
|
130
|
+
--#{root-defaults.$prefix}-button-color: #{$button-disabled-color};
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
// Variables referencing custom properties.
|
|
2
|
+
|
|
3
|
+
@use "defaults";
|
|
4
|
+
@use "../../variables" as root-variables;
|
|
5
|
+
@use "../../defaults" as root-defaults;
|
|
6
|
+
@use "../../theme/color/variables" as color;
|
|
7
|
+
@use "../../theme/typography/variables" as typography;
|
|
8
|
+
@use "../../functions/theme";
|
|
9
|
+
@use "sass:map";
|
|
10
|
+
|
|
11
|
+
// Button properties.
|
|
12
|
+
$button-min-width: var(
|
|
13
|
+
--#{root-defaults.$prefix}-button-min-width,
|
|
14
|
+
#{root-defaults.$interactive-min-width}
|
|
15
|
+
);
|
|
16
|
+
$button-min-height: var(
|
|
17
|
+
--#{root-defaults.$prefix}-button-min-height,
|
|
18
|
+
#{root-defaults.$interactive-min-height}
|
|
19
|
+
);
|
|
20
|
+
$button-padding-x: var(
|
|
21
|
+
--#{root-defaults.$prefix}-button-padding-x,
|
|
22
|
+
#{map.get(root-variables.$spacers, 5)}
|
|
23
|
+
);
|
|
24
|
+
$button-padding-y: var(
|
|
25
|
+
--#{root-defaults.$prefix}-button-padding-y,
|
|
26
|
+
#{map.get(root-variables.$spacers, 3)}
|
|
27
|
+
);
|
|
28
|
+
$button-padding: var(
|
|
29
|
+
--#{root-defaults.$prefix}-button-padding,
|
|
30
|
+
#{$button-padding-y} #{$button-padding-x}
|
|
31
|
+
);
|
|
32
|
+
$button-font-size: var(
|
|
33
|
+
--#{root-defaults.$prefix}-button-font-size,
|
|
34
|
+
#{map.get(typography.$font-sizes, base)}
|
|
35
|
+
);
|
|
36
|
+
$button-transition: var(
|
|
37
|
+
--#{root-defaults.$prefix}-button-transition,
|
|
38
|
+
background #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function},
|
|
39
|
+
color #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function},
|
|
40
|
+
transform #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function}
|
|
41
|
+
);
|
|
42
|
+
$button-transition-reduced-motion: var(
|
|
43
|
+
--#{root-defaults.$prefix}-button-transition-reduced-motion,
|
|
44
|
+
background #{map.get(root-variables.$transition-durations, none)} #{root-variables.$transition-timing-function},
|
|
45
|
+
color #{map.get(root-variables.$transition-durations, none)} #{root-variables.$transition-timing-function}
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
// Transform properties.
|
|
49
|
+
$button-hover-transform: var(
|
|
50
|
+
--#{root-defaults.$prefix}-button-hover-transform,
|
|
51
|
+
#{defaults.$button-hover-transform}
|
|
52
|
+
);
|
|
53
|
+
$button-active-transform: var(
|
|
54
|
+
--#{root-defaults.$prefix}-button-active-transform,
|
|
55
|
+
#{defaults.$button-active-transform}
|
|
56
|
+
);
|
|
57
|
+
$button-hover-transform-reduced-motion: var(
|
|
58
|
+
--#{root-defaults.$prefix}-button-hover-transform-reduced-motion,
|
|
59
|
+
#{defaults.$button-hover-transform-reduced-motion}
|
|
60
|
+
);
|
|
61
|
+
$button-active-transform-reduced-motion: var(
|
|
62
|
+
--#{root-defaults.$prefix}-button-active-transform-reduced-motion,
|
|
63
|
+
#{defaults.$button-active-transform-reduced-motion}
|
|
64
|
+
);
|
|
65
|
+
|
|
66
|
+
// Background properties.
|
|
67
|
+
$button-background: var(
|
|
68
|
+
--#{root-defaults.$prefix}-button-background,
|
|
69
|
+
#{color.$root-background}
|
|
70
|
+
);
|
|
71
|
+
$button-hover-background: var(
|
|
72
|
+
--#{root-defaults.$prefix}-button-hover-background,
|
|
73
|
+
#{theme.get(primary, 900)}
|
|
74
|
+
);
|
|
75
|
+
$button-active-background: var(
|
|
76
|
+
--#{root-defaults.$prefix}-button-active-background,
|
|
77
|
+
#{theme.get(primary, 900)}
|
|
78
|
+
);
|
|
79
|
+
$button-disabled-background: var(
|
|
80
|
+
--#{root-defaults.$prefix}-button-disabled-background,
|
|
81
|
+
#{color.$root-background}
|
|
82
|
+
);
|
|
83
|
+
|
|
84
|
+
// Text properties.
|
|
85
|
+
$button-color: var(
|
|
86
|
+
--#{root-defaults.$prefix}-button-color,
|
|
87
|
+
#{theme.get(primary, 900)}
|
|
88
|
+
);
|
|
89
|
+
$button-hover-color: var(
|
|
90
|
+
--#{root-defaults.$prefix}-button-hover-color,
|
|
91
|
+
#{theme.get(primary, 100)}
|
|
92
|
+
);
|
|
93
|
+
$button-active-color: var(
|
|
94
|
+
--#{root-defaults.$prefix}-button-active-color,
|
|
95
|
+
#{theme.get(primary, 100)}
|
|
96
|
+
);
|
|
97
|
+
$button-disabled-color: var(
|
|
98
|
+
--#{root-defaults.$prefix}-button-disabled-color,
|
|
99
|
+
#{theme.get(primary, 200)}
|
|
100
|
+
);
|
|
101
|
+
|
|
102
|
+
// Border properties.
|
|
103
|
+
$button-border-width: var(
|
|
104
|
+
--#{root-defaults.$prefix}-button-border-width,
|
|
105
|
+
#{root-variables.$border-width}
|
|
106
|
+
);
|
|
107
|
+
$button-border-style: var(
|
|
108
|
+
--#{root-defaults.$prefix}-botton-border-style,
|
|
109
|
+
#{root-variables.$border-style}
|
|
110
|
+
);
|
|
111
|
+
$button-border-radius: var(
|
|
112
|
+
--#{root-defaults.$prefix}-button-border-radius,
|
|
113
|
+
#{root-variables.$border-radius}
|
|
114
|
+
);
|
|
115
|
+
|
|
116
|
+
// Border colour properties.
|
|
117
|
+
$button-border-color: var(
|
|
118
|
+
--#{root-defaults.$prefix}-button-border-color,
|
|
119
|
+
#{theme.get(primary, 900)}
|
|
120
|
+
);
|
|
121
|
+
$button-hover-border-color: var(
|
|
122
|
+
--#{root-defaults.$prefix}-button-hover-border-color,
|
|
123
|
+
#{theme.get(primary, 900)}
|
|
124
|
+
);
|
|
125
|
+
$button-active-border-color: var(
|
|
126
|
+
--#{root-defaults.$prefix}-button-active-border-color,
|
|
127
|
+
#{theme.get(primary, 900)}
|
|
128
|
+
);
|
|
129
|
+
$button-disabled-border-color: var(
|
|
130
|
+
--#{root-defaults.$prefix}-button-disabled-border-color,
|
|
131
|
+
#{theme.get(primary, 200)}
|
|
132
|
+
);
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Default values for Graupl.
|
|
2
|
+
//
|
|
3
|
+
// Generally, these should not be used directly when styling components.
|
|
4
|
+
// They are mainly used to provide default fallbacks for custom properties
|
|
5
|
+
// which can be found in the `variables.scss` file.
|
|
6
|
+
|
|
7
|
+
// Grid names.
|
|
8
|
+
$input-group-grid-label-name: label !default;
|
|
9
|
+
$input-group-grid-input-name: input !default;
|
|
10
|
+
$input-group-grid-help-name: help !default;
|
|
11
|
+
|
|
12
|
+
// Input group properties.
|
|
13
|
+
$input-group-grid-template-columns: 100% !default;
|
|
14
|
+
$input-group-grid-template-rows: auto auto auto !default;
|
|
15
|
+
|
|
16
|
+
// Inline input group properties.
|
|
17
|
+
$input-group-inline-grid-template-columns: auto 1fr !default;
|
|
18
|
+
$input-group-inline-grid-template-rows: auto auto !default;
|
|
19
|
+
|
|
20
|
+
// Inner element properties.
|
|
21
|
+
$input-group-label-grid-area: $input-group-grid-label-name !default;
|
|
22
|
+
$input-group-input-grid-area: $input-group-grid-input-name !default;
|
|
23
|
+
$input-group-help-grid-area: $input-group-grid-help-name !default;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
// Graupl Input group Component.
|
|
2
|
+
|
|
3
|
+
@use "variables" as *;
|
|
4
|
+
@use "../../mixins/layer" as *;
|
|
5
|
+
@use "../../mixins/media-queries" as *;
|
|
6
|
+
|
|
7
|
+
// stylelint-disable declaration-block-no-redundant-longhand-properties
|
|
8
|
+
@include layer(component) {
|
|
9
|
+
.input-group {
|
|
10
|
+
display: grid;
|
|
11
|
+
grid-template-areas: $input-group-grid-template-areas;
|
|
12
|
+
grid-template-columns: $input-group-grid-template-columns;
|
|
13
|
+
grid-template-rows: $input-group-grid-template-rows;
|
|
14
|
+
align-items: center;
|
|
15
|
+
gap: $input-group-gap;
|
|
16
|
+
|
|
17
|
+
label {
|
|
18
|
+
grid-area: $input-group-label-grid-area;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
input,
|
|
22
|
+
textarea,
|
|
23
|
+
select {
|
|
24
|
+
grid-area: $input-group-input-grid-area;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.help-text {
|
|
28
|
+
grid-area: $input-group-help-grid-area;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
&.inline {
|
|
32
|
+
grid-template-areas: $input-group-inline-grid-template-areas;
|
|
33
|
+
grid-template-columns: $input-group-inline-grid-template-columns;
|
|
34
|
+
grid-template-rows: $input-group-inline-grid-template-rows;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
@include screen(xs) {
|
|
39
|
+
.input-group.inline {
|
|
40
|
+
grid-template-areas: $input-group-grid-template-areas;
|
|
41
|
+
grid-template-columns: $input-group-grid-template-columns;
|
|
42
|
+
grid-template-rows: $input-group-grid-template-rows;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
// Variables referencing custom properties.
|
|
2
|
+
|
|
3
|
+
@use "defaults";
|
|
4
|
+
@use "../../defaults" as root-defaults;
|
|
5
|
+
@use "../../variables" as root-variables;
|
|
6
|
+
@use "sass:map";
|
|
7
|
+
|
|
8
|
+
// Input group properties.
|
|
9
|
+
$input-group-grid-template-areas: var(
|
|
10
|
+
--#{root-defaults.$prefix}-input-group-grid-template-areas,
|
|
11
|
+
"#{defaults.$input-group-grid-label-name}"
|
|
12
|
+
"#{defaults.$input-group-grid-input-name}"
|
|
13
|
+
"#{defaults.$input-group-grid-help-name}"
|
|
14
|
+
);
|
|
15
|
+
$input-group-grid-template-columns: var(
|
|
16
|
+
--#{root-defaults.$prefix}-input-group-grid-template-columns,
|
|
17
|
+
#{defaults.$input-group-grid-template-columns}
|
|
18
|
+
);
|
|
19
|
+
$input-group-grid-template-rows: var(
|
|
20
|
+
--#{root-defaults.$prefix}-input-group-grid-template-rows,
|
|
21
|
+
#{defaults.$input-group-grid-template-rows}
|
|
22
|
+
);
|
|
23
|
+
$input-group-row-gap: var(
|
|
24
|
+
--#{root-defaults.$prefix}-input-group-row-gap,
|
|
25
|
+
#{map.get(root-variables.$spacers, 2)}
|
|
26
|
+
);
|
|
27
|
+
$input-group-column-gap: var(
|
|
28
|
+
--#{root-defaults.$prefix}-input-group-column-gap,
|
|
29
|
+
#{map.get(root-variables.$spacers, 3)}
|
|
30
|
+
);
|
|
31
|
+
$input-group-gap: var(
|
|
32
|
+
--#{root-defaults.$prefix}-input-group-gap,
|
|
33
|
+
#{$input-group-row-gap} #{$input-group-column-gap}
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
// Inline input group properties.
|
|
37
|
+
$input-group-inline-grid-template-areas: var(
|
|
38
|
+
--#{root-defaults.$prefix}-input-group-inline-grid-template-areas,
|
|
39
|
+
"#{defaults.$input-group-grid-label-name} #{defaults.$input-group-grid-input-name}"
|
|
40
|
+
"- #{defaults.$input-group-grid-help-name}"
|
|
41
|
+
);
|
|
42
|
+
$input-group-inline-grid-template-columns: var(
|
|
43
|
+
--#{root-defaults.$prefix}-input-group-inline-grid-template-columns,
|
|
44
|
+
#{defaults.$input-group-inline-grid-template-columns}
|
|
45
|
+
);
|
|
46
|
+
$input-group-inline-grid-template-rows: var(
|
|
47
|
+
--#{root-defaults.$prefix}-input-group-inline-grid-template-rows,
|
|
48
|
+
#{defaults.$input-group-inline-grid-template-rows}
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
// Inner element properties.
|
|
52
|
+
$input-group-label-grid-area: var(
|
|
53
|
+
--#{root-defaults.$prefix}-input-group-label-grid-area,
|
|
54
|
+
#{defaults.$input-group-label-grid-area}
|
|
55
|
+
);
|
|
56
|
+
$input-group-input-grid-area: var(
|
|
57
|
+
--#{root-defaults.$prefix}-input-group-input-grid-area,
|
|
58
|
+
#{defaults.$input-group-input-grid-area}
|
|
59
|
+
);
|
|
60
|
+
$input-group-help-grid-area: var(
|
|
61
|
+
--#{root-defaults.$prefix}-input-group-help-grid-area,
|
|
62
|
+
#{defaults.$input-group-help-grid-area}
|
|
63
|
+
);
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// Default values for Graupl.
|
|
2
|
+
//
|
|
3
|
+
// Generally, these should not be used directly when styling components.
|
|
4
|
+
// They are mainly used to provide default fallbacks for custom properties
|
|
5
|
+
// which can be found in the `variables.scss` file.
|
|
6
|
+
|
|
7
|
+
@use "sass:map";
|
|
8
|
+
|
|
9
|
+
// Table theme defaults.
|
|
10
|
+
// This map is used to define the default colour shades for the
|
|
11
|
+
// themed table components.
|
|
12
|
+
//
|
|
13
|
+
// e.g.
|
|
14
|
+
// Primary tables will use primary--700 as the header background,
|
|
15
|
+
// and primary--100 as the header text colour.
|
|
16
|
+
//
|
|
17
|
+
// Secondary/tertiary tables will use the same shade for their respective colours.
|
|
18
|
+
$base-table-theme-map: (
|
|
19
|
+
header-background: 700,
|
|
20
|
+
header-color: 100,
|
|
21
|
+
striped-background: 200,
|
|
22
|
+
striped-color: 900,
|
|
23
|
+
hover-background: 300,
|
|
24
|
+
hover-color: 900,
|
|
25
|
+
border-color: 900,
|
|
26
|
+
highlight-background: 500,
|
|
27
|
+
highlight-color: 100,
|
|
28
|
+
);
|
|
29
|
+
$custom-table-theme-map: () !default;
|
|
30
|
+
$table-theme-map: map.merge($base-table-theme-map, $custom-table-theme-map);
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
// Table component styles.
|
|
2
|
+
|
|
3
|
+
@use "variables" as *;
|
|
4
|
+
@use "defaults";
|
|
5
|
+
@use "../../mixins/layer" as *;
|
|
6
|
+
@use "../../defaults" as root-defaults;
|
|
7
|
+
@use "../../functions/theme";
|
|
8
|
+
|
|
9
|
+
@include layer(component) {
|
|
10
|
+
table {
|
|
11
|
+
@each $variant in theme.variants() {
|
|
12
|
+
&.#{$variant},
|
|
13
|
+
.#{$variant} {
|
|
14
|
+
@each $prop, $key in defaults.$table-theme-map {
|
|
15
|
+
--#{root-defaults.$prefix}-table-#{$prop}: #{theme.get(
|
|
16
|
+
$variant,
|
|
17
|
+
$key
|
|
18
|
+
)};
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
&.bordered {
|
|
24
|
+
border-collapse: collapse;
|
|
25
|
+
border-width: $table-border-width;
|
|
26
|
+
border-style: $table-border-style;
|
|
27
|
+
border-color: $table-border-color;
|
|
28
|
+
|
|
29
|
+
tr > * {
|
|
30
|
+
border-width: $table-cell-border-width;
|
|
31
|
+
border-style: $table-cell-border-style;
|
|
32
|
+
border-color: $table-cell-border-color;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
&.striped-columns {
|
|
37
|
+
tbody tr:nth-child(odd) > * {
|
|
38
|
+
background: $table-striped-background;
|
|
39
|
+
color: $table-striped-color;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
&.striped-rows {
|
|
44
|
+
tbody tr > :nth-child(odd) {
|
|
45
|
+
background: $table-striped-background;
|
|
46
|
+
color: $table-striped-color;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
&.hoverable {
|
|
51
|
+
tbody tr:hover > * {
|
|
52
|
+
background: $table-hover-background;
|
|
53
|
+
color: $table-hover-color;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.highlight {
|
|
58
|
+
--#{root-defaults.$prefix}-table-cell-background: #{$table-highlight-background};
|
|
59
|
+
--#{root-defaults.$prefix}-table-cell-color: #{$table-highlight-color};
|
|
60
|
+
--#{root-defaults.$prefix}-table-header-background: #{$table-highlight-background};
|
|
61
|
+
--#{root-defaults.$prefix}-table-header-color: #{$table-highlight-color};
|
|
62
|
+
--#{root-defaults.$prefix}-table-striped-background: #{$table-highlight-background};
|
|
63
|
+
--#{root-defaults.$prefix}-table-striped-color: #{$table-highlight-color};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
.responsive-table {
|
|
68
|
+
display: block;
|
|
69
|
+
width: 100%;
|
|
70
|
+
overflow: scroll hidden;
|
|
71
|
+
|
|
72
|
+
table {
|
|
73
|
+
width: 100%;
|
|
74
|
+
margin-bottom: 0;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
// Variables referencing custom properties.
|
|
2
|
+
|
|
3
|
+
@use "defaults";
|
|
4
|
+
@use "../../defaults" as root-defaults;
|
|
5
|
+
@use "../../variables" as root-variables;
|
|
6
|
+
@use "../../functions/theme";
|
|
7
|
+
|
|
8
|
+
// Table border properties.
|
|
9
|
+
$table-border-width: var(
|
|
10
|
+
--#{root-defaults.$prefix}-table-border-width,
|
|
11
|
+
#{root-variables.$border-width}
|
|
12
|
+
);
|
|
13
|
+
$table-border-style: var(
|
|
14
|
+
--#{root-defaults.$prefix}-table-border-style,
|
|
15
|
+
#{root-variables.$border-style}
|
|
16
|
+
);
|
|
17
|
+
$table-border-color: var(
|
|
18
|
+
--#{root-defaults.$prefix}-table-border-color,
|
|
19
|
+
#{theme.get(primary, 900)}
|
|
20
|
+
);
|
|
21
|
+
|
|
22
|
+
// Table cell border properties.
|
|
23
|
+
$table-cell-border-width: var(
|
|
24
|
+
--#{root-defaults.$prefix}-table-cell-border-width,
|
|
25
|
+
#{$table-border-width}
|
|
26
|
+
);
|
|
27
|
+
$table-cell-border-style: var(
|
|
28
|
+
--#{root-defaults.$prefix}-table-cell-border-style,
|
|
29
|
+
#{$table-border-style}
|
|
30
|
+
);
|
|
31
|
+
$table-cell-border-color: var(
|
|
32
|
+
--#{root-defaults.$prefix}-table-cell-border-color,
|
|
33
|
+
#{$table-border-color}
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
// Table striped properties.
|
|
37
|
+
$table-striped-background: var(
|
|
38
|
+
--#{root-defaults.$prefix}-table-striped-background,
|
|
39
|
+
#{theme.get(secondary, 200)}
|
|
40
|
+
);
|
|
41
|
+
$table-striped-color: var(
|
|
42
|
+
--#{root-defaults.$prefix}-table-striped-color,
|
|
43
|
+
#{theme.get(secondary, 900)}
|
|
44
|
+
);
|
|
45
|
+
|
|
46
|
+
// Table hover properties.
|
|
47
|
+
$table-hover-background: var(
|
|
48
|
+
--#{root-defaults.$prefix}-table-hover-background,
|
|
49
|
+
#{theme.get(secondary, 300)}
|
|
50
|
+
);
|
|
51
|
+
$table-hover-color: var(
|
|
52
|
+
--#{root-defaults.$prefix}-table-hover-color,
|
|
53
|
+
#{theme.get(secondary, 900)}
|
|
54
|
+
);
|
|
55
|
+
|
|
56
|
+
// Table highlight properties.
|
|
57
|
+
$table-highlight-background: var(
|
|
58
|
+
--#{root-defaults.$prefix}-table-highlight-background,
|
|
59
|
+
#{theme.get(secondary, 500)}
|
|
60
|
+
);
|
|
61
|
+
$table-highlight-color: var(
|
|
62
|
+
--#{root-defaults.$prefix}-table-highlight-color,
|
|
63
|
+
#{theme.get(secondary, 100)}
|
|
64
|
+
);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// Functions to help with getting information about the theme.
|
|
2
|
+
|
|
3
|
+
@use "sass:map";
|
|
4
|
+
@use "../theme/color/variables" as color;
|
|
5
|
+
|
|
6
|
+
// A function to get the specific theme shades.
|
|
7
|
+
@function get($color, $shade) {
|
|
8
|
+
$color-map: map.get(color.$theme-active, $color);
|
|
9
|
+
$value: map.get($color-map, $shade);
|
|
10
|
+
|
|
11
|
+
@return $value;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
@function variants() {
|
|
15
|
+
$variants: map.keys(color.$theme-active);
|
|
16
|
+
|
|
17
|
+
@return $variants;
|
|
18
|
+
}
|
|
@@ -4,11 +4,8 @@
|
|
|
4
4
|
// They are mainly used to provide default fallbacks for custom properties
|
|
5
5
|
// which can be found in the `variables.scss` file.
|
|
6
6
|
|
|
7
|
-
@forward "../../defaults";
|
|
8
|
-
|
|
9
7
|
$columns-max-width: 1fr !default;
|
|
10
8
|
$columns-count: 3 !default;
|
|
11
|
-
$columns-disable-width: 48ch !default;
|
|
12
9
|
$columns-min-count: 1 !default;
|
|
13
|
-
$columns-max-count:
|
|
10
|
+
$columns-max-count: 6 !default;
|
|
14
11
|
$columns-span: 1 !default;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
// Graupl Columns layout.
|
|
2
|
+
|
|
3
|
+
@use "variables" as *;
|
|
4
|
+
@use "defaults";
|
|
5
|
+
@use "../../defaults" as root-defaults;
|
|
6
|
+
@use "../../mixins/layer" as *;
|
|
7
|
+
@use "../../mixins/media-queries" as *;
|
|
8
|
+
|
|
9
|
+
@include layer(layout) {
|
|
10
|
+
.columns {
|
|
11
|
+
display: grid;
|
|
12
|
+
grid-template-columns: $columns-grid-template-columns;
|
|
13
|
+
gap: $columns-row-gap $columns-column-gap;
|
|
14
|
+
|
|
15
|
+
> * {
|
|
16
|
+
grid-column: span $columns-span;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
@for $i from defaults.$columns-min-count through defaults.$columns-max-count {
|
|
21
|
+
.count-#{$i} {
|
|
22
|
+
--#{root-defaults.$prefix}-columns-count: #{$i};
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.span-#{$i} {
|
|
26
|
+
--#{root-defaults.$prefix}-columns-span: #{$i};
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// Disable columns on small screens to avoid horizontal bleeding.
|
|
31
|
+
@include screen(xs) {
|
|
32
|
+
.columns {
|
|
33
|
+
--#{root-defaults.$prefix}-columns-min-width: #{defaults.$columns-max-width};
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|