@graupl/graupl 1.0.0-alpha.14 → 1.0.0-alpha.16
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/CHANGELOG.md +24 -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.map +1 -0
- package/dist/css/base/link.css.map +1 -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.map +1 -0
- package/dist/css/component/carousel.css +2 -0
- package/dist/css/component/carousel.css.map +1 -0
- package/dist/css/component/input-group.css.map +1 -0
- package/dist/css/component/menu.css.map +1 -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.map +1 -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.map +1 -0
- package/dist/css/layout.css +2 -0
- package/dist/css/layout.css.map +1 -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.map +1 -0
- package/dist/css/theme/typography.css.map +1 -0
- package/dist/css/theme.css.map +1 -0
- package/dist/css/utilities/alignment.css.map +1 -0
- package/dist/css/utilities/color.css.map +1 -0
- package/dist/css/utilities/display.css.map +1 -0
- package/dist/css/utilities/flex.css.map +1 -0
- package/dist/css/utilities/height.css.map +1 -0
- package/dist/css/utilities/inset.css.map +1 -0
- package/dist/css/utilities/justification.css.map +1 -0
- package/dist/css/utilities/list.css.map +1 -0
- package/dist/css/utilities/order.css.map +1 -0
- package/dist/css/utilities/postion.css.map +1 -0
- package/dist/css/utilities/spacing.css.map +1 -0
- package/dist/css/utilities/typography.css.map +1 -0
- package/dist/css/utilities/visibility.css.map +1 -0
- package/dist/css/utilities/width.css.map +1 -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/index.html +56 -2
- package/index.js +12 -0
- package/package.json +26 -5
- package/scss/component/accordion.scss +3 -0
- 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 +71 -1
- package/src/js/alert/index.js +1 -11
- package/src/js/carousel/Carousel.js +67 -16
- package/src/js/carousel/index.js +1 -11
- package/src/js/eventHandlers.js +7 -0
- package/src/js/storage.js +106 -0
- package/src/scss/_defaults.scss +29 -0
- package/src/scss/base/button/_mixins.scss +64 -62
- package/src/scss/component/_index.scss +1 -0
- 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 +304 -0
- package/src/scss/component/carousel/_index.scss +6 -0
- package/src/scss/layout/columns/_index.scss +1 -1
- package/src/scss/layout/flex-columns/_index.scss +1 -1
- package/src/scss/state/focus/_index.scss +6 -6
- package/src/scss/state/focus/_mixins.scss +15 -0
- package/stylelint.config.js +4 -0
- package/vite.config.js +57 -0
- package/dist/base/button.css +0 -2
- package/dist/base/button.css.map +0 -1
- package/dist/base/form.css.map +0 -1
- package/dist/base/link.css.map +0 -1
- package/dist/base/table.css.map +0 -1
- package/dist/base.css +0 -2
- package/dist/base.css.map +0 -1
- package/dist/component/alert.css +0 -2
- package/dist/component/alert.css.map +0 -1
- package/dist/component/card.css.map +0 -1
- package/dist/component/carousel.css +0 -2
- package/dist/component/carousel.css.map +0 -1
- package/dist/component/input-group.css.map +0 -1
- package/dist/component/menu.css.map +0 -1
- package/dist/component/navigation.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/init.css.map +0 -1
- package/dist/layout/columns.css.map +0 -1
- package/dist/layout/container.css.map +0 -1
- package/dist/layout/flex-columns.css.map +0 -1
- package/dist/layout.css +0 -2
- package/dist/layout.css.map +0 -1
- package/dist/normalize.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.map +0 -1
- package/dist/theme/typography.css.map +0 -1
- package/dist/theme.css.map +0 -1
- package/dist/utilities/alignment.css.map +0 -1
- package/dist/utilities/color.css.map +0 -1
- package/dist/utilities/display.css.map +0 -1
- package/dist/utilities/flex.css.map +0 -1
- package/dist/utilities/height.css.map +0 -1
- package/dist/utilities/inset.css.map +0 -1
- package/dist/utilities/justification.css.map +0 -1
- package/dist/utilities/list.css.map +0 -1
- package/dist/utilities/order.css.map +0 -1
- package/dist/utilities/postion.css.map +0 -1
- package/dist/utilities/spacing.css.map +0 -1
- package/dist/utilities/typography.css.map +0 -1
- package/dist/utilities/visibility.css.map +0 -1
- package/dist/utilities/width.css.map +0 -1
- package/dist/utilities.css.map +0 -1
- /package/dist/{base → css/base}/form.css +0 -0
- /package/dist/{base → css/base}/link.css +0 -0
- /package/dist/{base → css/base}/table.css +0 -0
- /package/dist/{component → css/component}/card.css +0 -0
- /package/dist/{component → css/component}/input-group.css +0 -0
- /package/dist/{component → css/component}/menu.css +0 -0
- /package/dist/{component → css/component}/navigation.css +0 -0
- /package/dist/{init.css → css/init.css} +0 -0
- /package/dist/{layout → css/layout}/columns.css +0 -0
- /package/dist/{layout → css/layout}/container.css +0 -0
- /package/dist/{layout → css/layout}/flex-columns.css +0 -0
- /package/dist/{normalize.css → css/normalize.css} +0 -0
- /package/dist/{theme → css/theme}/color.css +0 -0
- /package/dist/{theme → css/theme}/typography.css +0 -0
- /package/dist/{theme.css → css/theme.css} +0 -0
- /package/dist/{utilities → css/utilities}/alignment.css +0 -0
- /package/dist/{utilities → css/utilities}/color.css +0 -0
- /package/dist/{utilities → css/utilities}/display.css +0 -0
- /package/dist/{utilities → css/utilities}/flex.css +0 -0
- /package/dist/{utilities → css/utilities}/height.css +0 -0
- /package/dist/{utilities → css/utilities}/inset.css +0 -0
- /package/dist/{utilities → css/utilities}/justification.css +0 -0
- /package/dist/{utilities → css/utilities}/list.css +0 -0
- /package/dist/{utilities → css/utilities}/order.css +0 -0
- /package/dist/{utilities → css/utilities}/postion.css +0 -0
- /package/dist/{utilities → css/utilities}/spacing.css +0 -0
- /package/dist/{utilities → css/utilities}/typography.css +0 -0
- /package/dist/{utilities → css/utilities}/visibility.css +0 -0
- /package/dist/{utilities → css/utilities}/width.css +0 -0
- /package/dist/{utilities.css → css/utilities.css} +0 -0
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
// @graupl/graupl accordion component styles.
|
|
2
|
+
|
|
3
|
+
@use "defaults";
|
|
4
|
+
@use "variables" as *;
|
|
5
|
+
@use "../../base/button/mixins" as button-mixins;
|
|
6
|
+
@use "../../defaults" as root-defaults;
|
|
7
|
+
@use "../../mixins/layer" as *;
|
|
8
|
+
@use "../../state/focus/variables" as focus;
|
|
9
|
+
@use "sass:map";
|
|
10
|
+
|
|
11
|
+
#{defaults.$accordion-selector} {
|
|
12
|
+
@include layer(component) {
|
|
13
|
+
display: flex;
|
|
14
|
+
flex-flow: column nowrap;
|
|
15
|
+
padding: $accordion-padding;
|
|
16
|
+
gap: $accordion-gap;
|
|
17
|
+
|
|
18
|
+
> #{defaults.$accordion-item-selector} {
|
|
19
|
+
&:not(:first-child) {
|
|
20
|
+
margin-top: calc(-1 * #{$accordion-item-border-width});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@include layer(theme) {
|
|
26
|
+
background: $accordion-background;
|
|
27
|
+
color: $accordion-color;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
#{defaults.$accordion-item-selector} {
|
|
32
|
+
@include layer(component) {
|
|
33
|
+
overflow: hidden;
|
|
34
|
+
transition: $accordion-transition;
|
|
35
|
+
border: $accordion-item-border;
|
|
36
|
+
border-radius: $accordion-item-border-radius;
|
|
37
|
+
isolation: isolate;
|
|
38
|
+
|
|
39
|
+
&#{defaults.$accordion-item-close-selector}
|
|
40
|
+
#{defaults.$accordion-item-content-selector} {
|
|
41
|
+
display: none;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
&#{defaults.$accordion-item-open-selector}
|
|
45
|
+
#{defaults.$accordion-item-content-selector} {
|
|
46
|
+
transform: $accordion-item-content-open-transform;
|
|
47
|
+
opacity: 1;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
&#{defaults.$accordion-item-transition-selector}
|
|
51
|
+
#{defaults.$accordion-item-content-selector} {
|
|
52
|
+
display: flex;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
@include layer(state) {
|
|
57
|
+
#{defaults.$accordion-item-toggle-selector} {
|
|
58
|
+
--#{root-defaults.$prefix}-focus-outline-offset: calc(
|
|
59
|
+
-1 * (#{$accordion-item-border-width} + #{focus.$focus-width})
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
@include layer(theme) {
|
|
65
|
+
border-color: $accordion-item-border-color;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
#{defaults.$accordion-item-toggle-selector} {
|
|
70
|
+
@include button-mixins.apply-button;
|
|
71
|
+
|
|
72
|
+
@include layer(component) {
|
|
73
|
+
z-index: 2;
|
|
74
|
+
padding: $accordion-item-toggle-padding;
|
|
75
|
+
transform: $accordion-item-toggle-transform;
|
|
76
|
+
transition: $accordion-item-toggle-transition;
|
|
77
|
+
|
|
78
|
+
@each $selector in map.get(root-defaults.$state-selectors, visited) {
|
|
79
|
+
&#{$selector} {
|
|
80
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transform: #{$accordion-item-toggle-visited-transform};
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
@each $selector in map.get(root-defaults.$state-selectors, focus) {
|
|
85
|
+
&#{$selector} {
|
|
86
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transform: #{$accordion-item-toggle-focus-transform};
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
@each $selector in map.get(root-defaults.$state-selectors, hover) {
|
|
91
|
+
&#{$selector} {
|
|
92
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transform: #{$accordion-item-toggle-hover-transform};
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
@each $selector in map.get(root-defaults.$state-selectors, active) {
|
|
97
|
+
&#{$selector} {
|
|
98
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transform: #{$accordion-item-toggle-active-transform};
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
@each $selector in map.get(root-defaults.$state-selectors, disabled) {
|
|
103
|
+
&#{$selector} {
|
|
104
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transform: #{$accordion-item-toggle-disabled-transform};
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
&#{defaults.$accordion-item-toggle-pseudo-selector} {
|
|
109
|
+
content: defaults.$accordion-item-toggle-pseudo-content;
|
|
110
|
+
display: flex;
|
|
111
|
+
align-items: center;
|
|
112
|
+
justify-content: center;
|
|
113
|
+
margin-left: auto;
|
|
114
|
+
transform: $accordion-item-toggle-pseudo-transform;
|
|
115
|
+
transition: $accordion-item-toggle-pseudo-transition;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
&[aria-expanded="true"] {
|
|
119
|
+
&::after {
|
|
120
|
+
transform: $accordion-item-toggle-pseudo-open-transform;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
#{defaults.$accordion-item-header-selector} {
|
|
127
|
+
@include layer(component) {
|
|
128
|
+
margin: $accordion-item-header-margin;
|
|
129
|
+
padding: $accordion-item-header-padding;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
#{defaults.$accordion-item-title-selector} {
|
|
134
|
+
@include layer(component) {
|
|
135
|
+
margin: $accordion-item-title-margin;
|
|
136
|
+
padding: $accordion-item-title-padding;
|
|
137
|
+
|
|
138
|
+
&,
|
|
139
|
+
#{defaults.$accordion-item-toggle-selector} {
|
|
140
|
+
display: flex;
|
|
141
|
+
align-items: center;
|
|
142
|
+
justify-content: flex-start;
|
|
143
|
+
width: 100%;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
@include layer(theme) {
|
|
148
|
+
&,
|
|
149
|
+
#{defaults.$accordion-item-toggle-selector} {
|
|
150
|
+
font-family: $accordion-title-font-family;
|
|
151
|
+
font-size: $accordion-title-font-size;
|
|
152
|
+
font-weight: $accordion-title-font-weight;
|
|
153
|
+
line-height: $accordion-title-line-height;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
#{defaults.$accordion-item-content-selector} {
|
|
159
|
+
@include layer(component) {
|
|
160
|
+
display: flex;
|
|
161
|
+
flex-flow: column nowrap;
|
|
162
|
+
padding: $accordion-item-content-padding;
|
|
163
|
+
transform: $accordion-item-content-transform;
|
|
164
|
+
transition: $accordion-item-content-transition;
|
|
165
|
+
opacity: 0;
|
|
166
|
+
gap: $accordion-item-content-gap;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
#{defaults.$accordion-item-body-selector} {
|
|
171
|
+
@include layer(component) {
|
|
172
|
+
padding: $accordion-item-body-padding;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
#{defaults.$accordion-item-footer-selector} {
|
|
177
|
+
@include layer(component) {
|
|
178
|
+
padding: $accordion-item-footer-padding;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
@@ -0,0 +1,304 @@
|
|
|
1
|
+
// @graupl/graupl accordion 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 "../../functions/theme";
|
|
12
|
+
@use "sass:map";
|
|
13
|
+
@use "../../base/button/variables" as button;
|
|
14
|
+
|
|
15
|
+
// Accordion properties.
|
|
16
|
+
$accordion-padding-x: var(
|
|
17
|
+
--#{root-defaults.$prefix}-accordion-padding-x,
|
|
18
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
19
|
+
);
|
|
20
|
+
$accordion-padding-y: var(
|
|
21
|
+
--#{root-defaults.$prefix}-accordion-padding-y,
|
|
22
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
23
|
+
);
|
|
24
|
+
$accordion-padding: var(
|
|
25
|
+
--#{root-defaults.$prefix}-accordion-padding,
|
|
26
|
+
#{$accordion-padding-y} #{$accordion-padding-x}
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
// Accordion gap properties.
|
|
30
|
+
$accordion-column-gap: var(
|
|
31
|
+
--#{root-defaults.$prefix}-accordion-column-gap,
|
|
32
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
33
|
+
);
|
|
34
|
+
$accordion-row-gap: var(
|
|
35
|
+
--#{root-defaults.$prefix}-accordion-row-gap,
|
|
36
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
37
|
+
);
|
|
38
|
+
$accordion-gap: var(
|
|
39
|
+
--#{root-defaults.$prefix}-accordion-gap,
|
|
40
|
+
#{$accordion-column-gap} #{$accordion-row-gap}
|
|
41
|
+
);
|
|
42
|
+
|
|
43
|
+
// Accordion color properties.
|
|
44
|
+
$accordion-color: var(
|
|
45
|
+
--#{root-defaults.$prefix}-accordion-color,
|
|
46
|
+
#{color.$root-color}
|
|
47
|
+
);
|
|
48
|
+
$accordion-background: var(
|
|
49
|
+
--#{root-defaults.$prefix}-accordion-background,
|
|
50
|
+
#{color.$root-background}
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
// Accordion item border properties.
|
|
54
|
+
$accordion-item-border-color: var(
|
|
55
|
+
--#{root-defaults.$prefix}-accordion-item-border-color,
|
|
56
|
+
#{$accordion-color}
|
|
57
|
+
);
|
|
58
|
+
$accordion-item-top-left-border-radius: var(
|
|
59
|
+
--#{root-defaults.$prefix}-accordion-item-top-left-border-radius,
|
|
60
|
+
#{root-variables.$border-radius}
|
|
61
|
+
);
|
|
62
|
+
$accordion-item-top-right-border-radius: var(
|
|
63
|
+
--#{root-defaults.$prefix}-accordion-item-top-right-border-radius,
|
|
64
|
+
#{root-variables.$border-radius}
|
|
65
|
+
);
|
|
66
|
+
$accordion-item-bottom-left-border-radius: var(
|
|
67
|
+
--#{root-defaults.$prefix}-accordion-item-bottom-left-border-radius,
|
|
68
|
+
#{root-variables.$border-radius}
|
|
69
|
+
);
|
|
70
|
+
$accordion-item-bottom-right-border-radius: var(
|
|
71
|
+
--#{root-defaults.$prefix}-accordion-item-bottom-right-border-radius,
|
|
72
|
+
#{root-variables.$border-radius}
|
|
73
|
+
);
|
|
74
|
+
$accordion-item-border-radius: var(
|
|
75
|
+
--#{root-defaults.$prefix}-accordion-item-border-radius,
|
|
76
|
+
#{$accordion-item-top-left-border-radius} #{$accordion-item-top-right-border-radius}
|
|
77
|
+
#{$accordion-item-bottom-right-border-radius} #{$accordion-item-bottom-left-border-radius}
|
|
78
|
+
);
|
|
79
|
+
$accordion-item-border-style: var(
|
|
80
|
+
--#{root-defaults.$prefix}-accordion-item-border-style,
|
|
81
|
+
#{root-variables.$border-style}
|
|
82
|
+
);
|
|
83
|
+
$accordion-item-border-width: var(
|
|
84
|
+
--#{root-defaults.$prefix}-accordion-item-border-width,
|
|
85
|
+
#{root-variables.$border-width}
|
|
86
|
+
);
|
|
87
|
+
$accordion-item-border: var(
|
|
88
|
+
--#{root-defaults.$prefix}-accordion-item-border,
|
|
89
|
+
#{$accordion-item-border-width} #{$accordion-item-border-style}
|
|
90
|
+
);
|
|
91
|
+
|
|
92
|
+
// Accordion item properties.
|
|
93
|
+
$accordion-item-toggle-padding: var(
|
|
94
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-padding,
|
|
95
|
+
#{button.$button-padding}
|
|
96
|
+
);
|
|
97
|
+
|
|
98
|
+
// Transform properties.
|
|
99
|
+
$accordion-item-toggle-transform: var(
|
|
100
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transform,
|
|
101
|
+
#{defaults.$accordion-item-toggle-transform}
|
|
102
|
+
);
|
|
103
|
+
$accordion-item-toggle-visited-transform: var(
|
|
104
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-visited-transform,
|
|
105
|
+
#{defaults.$accordion-item-toggle-visited-transform}
|
|
106
|
+
);
|
|
107
|
+
$accordion-item-toggle-focus-transform: var(
|
|
108
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-focus-transform,
|
|
109
|
+
#{defaults.$accordion-item-toggle-focus-transform}
|
|
110
|
+
);
|
|
111
|
+
$accordion-item-toggle-hover-transform: var(
|
|
112
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-hover-transform,
|
|
113
|
+
#{defaults.$accordion-item-toggle-hover-transform}
|
|
114
|
+
);
|
|
115
|
+
$accordion-item-toggle-active-transform: var(
|
|
116
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-active-transform,
|
|
117
|
+
#{defaults.$accordion-item-toggle-active-transform}
|
|
118
|
+
);
|
|
119
|
+
$accordion-item-toggle-disabled-transform: var(
|
|
120
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-disabled-transform,
|
|
121
|
+
#{defaults.$accordion-item-toggle-disabled-transform}
|
|
122
|
+
);
|
|
123
|
+
$accordion-item-toggle-transition: var(
|
|
124
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transition,
|
|
125
|
+
background #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function},
|
|
126
|
+
color #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function},
|
|
127
|
+
transform #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function}
|
|
128
|
+
);
|
|
129
|
+
$accordion-item-toggle-transition-reduced-motion: var(
|
|
130
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transition-reduced-motion,
|
|
131
|
+
background #{map.get(root-variables.$transition-durations, none)} #{root-variables.$transition-timing-function},
|
|
132
|
+
color #{map.get(root-variables.$transition-durations, none)} #{root-variables.$transition-timing-function}
|
|
133
|
+
);
|
|
134
|
+
|
|
135
|
+
// Accordion item header properties.
|
|
136
|
+
$accordion-item-header-padding-x: var(
|
|
137
|
+
--#{root-defaults.$prefix}-accordion-item-header-padding-x,
|
|
138
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
139
|
+
);
|
|
140
|
+
$accordion-item-header-padding-y: var(
|
|
141
|
+
--#{root-defaults.$prefix}-accordion-item-header-padding-y,
|
|
142
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
143
|
+
);
|
|
144
|
+
$accordion-item-header-padding: var(
|
|
145
|
+
--#{root-defaults.$prefix}-accordion-item-header-padding,
|
|
146
|
+
#{$accordion-item-header-padding-y} #{$accordion-item-header-padding-x}
|
|
147
|
+
);
|
|
148
|
+
$accordion-item-header-margin: var(
|
|
149
|
+
--#{root-defaults.$prefix}-accordion-item-header-margin,
|
|
150
|
+
calc(-1 * #{$accordion-item-border-width})
|
|
151
|
+
);
|
|
152
|
+
|
|
153
|
+
// Accordion item title properties.
|
|
154
|
+
$accordion-item-title-padding-x: var(
|
|
155
|
+
--#{root-defaults.$prefix}-accordion-item-title-padding-x,
|
|
156
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
157
|
+
);
|
|
158
|
+
$accordion-item-title-padding-y: var(
|
|
159
|
+
--#{root-defaults.$prefix}-accordion-item-title-padding-y,
|
|
160
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
161
|
+
);
|
|
162
|
+
$accordion-item-title-padding: var(
|
|
163
|
+
--#{root-defaults.$prefix}-accordion-item-title-padding,
|
|
164
|
+
#{$accordion-item-title-padding-y} #{$accordion-item-title-padding-x}
|
|
165
|
+
);
|
|
166
|
+
$accordion-item-title-margin-x: var(
|
|
167
|
+
--#{root-defaults.$prefix}-accordion-item-title-margin-x,
|
|
168
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
169
|
+
);
|
|
170
|
+
$accordion-item-title-margin-y: var(
|
|
171
|
+
--#{root-defaults.$prefix}-accordion-item-title-margin-y,
|
|
172
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
173
|
+
);
|
|
174
|
+
$accordion-item-title-margin: var(
|
|
175
|
+
--#{root-defaults.$prefix}-accordion-item-title-margin,
|
|
176
|
+
#{$accordion-item-title-margin-y} #{$accordion-item-title-margin-x}
|
|
177
|
+
);
|
|
178
|
+
$accordion-title-color: var(
|
|
179
|
+
--#{root-defaults.$prefix}-accordion-title-color,
|
|
180
|
+
#{$accordion-color}
|
|
181
|
+
);
|
|
182
|
+
$accordion-title-font-size: var(
|
|
183
|
+
--#{root-defaults.$prefix}-accordion-title-font-size,
|
|
184
|
+
#{typography.$h5-font-size}
|
|
185
|
+
);
|
|
186
|
+
$accordion-title-font-weight: var(
|
|
187
|
+
--#{root-defaults.$prefix}-accordion-title-font-weight,
|
|
188
|
+
#{typography.$h5-font-weight}
|
|
189
|
+
);
|
|
190
|
+
$accordion-title-font-family: var(
|
|
191
|
+
--#{root-defaults.$prefix}-accordion-title-font-family,
|
|
192
|
+
#{typography.$h5-font-family}
|
|
193
|
+
);
|
|
194
|
+
$accordion-title-line-height: var(
|
|
195
|
+
--#{root-defaults.$prefix}-accordion-title-line-height,
|
|
196
|
+
#{typography.$h5-line-height}
|
|
197
|
+
);
|
|
198
|
+
|
|
199
|
+
// Accordion item content properties.
|
|
200
|
+
$accordion-item-content-padding-x: var(
|
|
201
|
+
--#{root-defaults.$prefix}-accordion-item-content-padding-x,
|
|
202
|
+
#{map.get(root-variables.$spacers, 5)}
|
|
203
|
+
);
|
|
204
|
+
$accordion-item-content-padding-y: var(
|
|
205
|
+
--#{root-defaults.$prefix}-accordion-item-content-padding-y,
|
|
206
|
+
#{map.get(root-variables.$spacers, 5)}
|
|
207
|
+
);
|
|
208
|
+
$accordion-item-content-padding: var(
|
|
209
|
+
--#{root-defaults.$prefix}-accordion-item-content-padding,
|
|
210
|
+
#{$accordion-item-content-padding-y} #{$accordion-item-content-padding-x}
|
|
211
|
+
);
|
|
212
|
+
$accordion-item-content-column-gap: var(
|
|
213
|
+
--#{root-defaults.$prefix}-accordion-item-content-column-gap,
|
|
214
|
+
#{map.get(root-variables.$spacers, 3)}
|
|
215
|
+
);
|
|
216
|
+
$accordion-item-content-row-gap: var(
|
|
217
|
+
--#{root-defaults.$prefix}-accordion-item-content-row-gap,
|
|
218
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
219
|
+
);
|
|
220
|
+
$accordion-item-content-gap: var(
|
|
221
|
+
--#{root-defaults.$prefix}-accordion-item-content-gap,
|
|
222
|
+
#{$accordion-item-content-column-gap} #{$accordion-item-content-row-gap}
|
|
223
|
+
);
|
|
224
|
+
|
|
225
|
+
// Accordion item body properties.
|
|
226
|
+
$accordion-item-body-padding-x: var(
|
|
227
|
+
--#{root-defaults.$prefix}-accordion-item-body-padding-x,
|
|
228
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
229
|
+
);
|
|
230
|
+
$accordion-item-body-padding-y: var(
|
|
231
|
+
--#{root-defaults.$prefix}-accordion-item-body-padding-y,
|
|
232
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
233
|
+
);
|
|
234
|
+
$accordion-item-body-padding: var(
|
|
235
|
+
--#{root-defaults.$prefix}-accordion-item-body-padding,
|
|
236
|
+
#{$accordion-item-body-padding-y} #{$accordion-item-body-padding-x}
|
|
237
|
+
);
|
|
238
|
+
|
|
239
|
+
// Accordion item footer properties.
|
|
240
|
+
$accordion-item-footer-padding-x: var(
|
|
241
|
+
--#{root-defaults.$prefix}-accordion-item-footer-padding-x,
|
|
242
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
243
|
+
);
|
|
244
|
+
$accordion-item-footer-padding-y: var(
|
|
245
|
+
--#{root-defaults.$prefix}-accordion-item-footer-padding-y,
|
|
246
|
+
#{map.get(root-variables.$spacers, 0)}
|
|
247
|
+
);
|
|
248
|
+
$accordion-item-footer-padding: var(
|
|
249
|
+
--#{root-defaults.$prefix}-accordion-item-footer-padding,
|
|
250
|
+
#{$accordion-item-footer-padding-y} #{$accordion-item-footer-padding-x}
|
|
251
|
+
);
|
|
252
|
+
|
|
253
|
+
// Accordion item transition properties.
|
|
254
|
+
$accordion-transition-duration: var(
|
|
255
|
+
--#{root-defaults.$prefix}-accordion-transition-duration,
|
|
256
|
+
#{map.get(root-variables.$transition-durations, slow)}
|
|
257
|
+
);
|
|
258
|
+
$accordion-item-toggle-transition-duration: var(
|
|
259
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-transition-duration,
|
|
260
|
+
#{$accordion-transition-duration}
|
|
261
|
+
);
|
|
262
|
+
$accordion-transition: var(
|
|
263
|
+
--#{root-defaults.$prefix}-accordion-transition,
|
|
264
|
+
height #{map.get(root-variables.$transition-durations, slow)} #{root-variables.$transition-timing-function}
|
|
265
|
+
);
|
|
266
|
+
$accordion-transition-reduced-motion: var(
|
|
267
|
+
--#{root-defaults.$prefix}-accordion-transition-reduced-motion,
|
|
268
|
+
none
|
|
269
|
+
);
|
|
270
|
+
$accordion-item-toggle-pseudo-transition: var(
|
|
271
|
+
--#{root-defaults.$prefix}-accordion-transition,
|
|
272
|
+
transform #{map.get(root-variables.$transition-durations, slow)} #{root-variables.$transition-timing-function}
|
|
273
|
+
);
|
|
274
|
+
$accordion-item-toggle-pseudo-transition-reduced-motion: var(
|
|
275
|
+
--#{root-defaults.$prefix}-accordion-transition-reduced-motion,
|
|
276
|
+
none
|
|
277
|
+
);
|
|
278
|
+
$accordion-item-content-transition: var(
|
|
279
|
+
--#{root-defaults.$prefix}-accordion-transition,
|
|
280
|
+
opacity #{map.get(root-variables.$transition-durations, slow)} #{root-variables.$transition-timing-function}
|
|
281
|
+
transform #{map.get(root-variables.$transition-durations, slow)} #{root-variables.$transition-timing-function}
|
|
282
|
+
);
|
|
283
|
+
$accordion-item-content-transition-reduced-motion: var(
|
|
284
|
+
--#{root-defaults.$prefix}-accordion-transition-reduced-motion,
|
|
285
|
+
opacity #{map.get(root-variables.$transition-durations, slow)} #{root-variables.$transition-timing-function}
|
|
286
|
+
);
|
|
287
|
+
|
|
288
|
+
// Accordion item transform properties.
|
|
289
|
+
$accordion-item-content-transform: var(
|
|
290
|
+
--#{root-defaults.$prefix}-accordion-item-content-transform,
|
|
291
|
+
#{defaults.$accordion-item-content-transform}
|
|
292
|
+
);
|
|
293
|
+
$accordion-item-content-open-transform: var(
|
|
294
|
+
--#{root-defaults.$prefix}-accordion-item-content-open-transform,
|
|
295
|
+
#{defaults.$accordion-item-content-open-transform}
|
|
296
|
+
);
|
|
297
|
+
$accordion-item-toggle-pseudo-transform: var(
|
|
298
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-pseudo-transform,
|
|
299
|
+
#{defaults.$accordion-item-toggle-pseudo-transform}
|
|
300
|
+
);
|
|
301
|
+
$accordion-item-toggle-pseudo-open-transform: var(
|
|
302
|
+
--#{root-defaults.$prefix}-accordion-item-toggle-pseudo-open-transform,
|
|
303
|
+
#{defaults.$accordion-item-toggle-pseudo-open-transform}
|
|
304
|
+
);
|
|
@@ -68,6 +68,7 @@
|
|
|
68
68
|
1fr [previous-start] $carousel-control-width [previous-end next-start]
|
|
69
69
|
$carousel-control-width [next-end];
|
|
70
70
|
grid-template-rows: [autoplay-start next-start previous-start] $carousel-control-height [previous-end next-end autoplay-end];
|
|
71
|
+
pointer-events: none;
|
|
71
72
|
}
|
|
72
73
|
}
|
|
73
74
|
|
|
@@ -75,6 +76,8 @@
|
|
|
75
76
|
@include button-mixins.apply-button;
|
|
76
77
|
|
|
77
78
|
@include layer(component) {
|
|
79
|
+
pointer-events: auto;
|
|
80
|
+
|
|
78
81
|
&#{defaults.$carousel-autoplay-selector} {
|
|
79
82
|
grid-area: autoplay;
|
|
80
83
|
}
|
|
@@ -170,6 +173,7 @@
|
|
|
170
173
|
justify-content: center;
|
|
171
174
|
padding: $carousel-tab-container-padding;
|
|
172
175
|
gap: $carousel-tab-container-gap;
|
|
176
|
+
pointer-events: none;
|
|
173
177
|
}
|
|
174
178
|
}
|
|
175
179
|
|
|
@@ -178,5 +182,7 @@
|
|
|
178
182
|
|
|
179
183
|
@include layer(component) {
|
|
180
184
|
--#{root-defaults.$prefix}-button-border-radius: 50%;
|
|
185
|
+
|
|
186
|
+
pointer-events: auto;
|
|
181
187
|
}
|
|
182
188
|
}
|
|
@@ -36,7 +36,7 @@
|
|
|
36
36
|
}
|
|
37
37
|
|
|
38
38
|
// Disable columns on small screens to avoid horizontal bleeding.
|
|
39
|
-
@include screen(
|
|
39
|
+
@include screen-trigger(force-single-column) {
|
|
40
40
|
#{defaults.$columns-selector} {
|
|
41
41
|
--#{root-defaults.$prefix}-columns-min-width: #{defaults.$columns-max-width};
|
|
42
42
|
|
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
/* stylelint-enable scss/operator-no-newline-after */
|
|
40
40
|
}
|
|
41
41
|
|
|
42
|
-
@include screen(
|
|
42
|
+
@include screen-trigger(force-single-column) {
|
|
43
43
|
#{defaults.$flex-columns-column-selector-prefix}#{$i} {
|
|
44
44
|
--#{root-defaults.$prefix}-flex-columns-size: 100%;
|
|
45
45
|
--#{root-defaults.$prefix}-flex-columns-max-width: auto;
|
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
|
|
3
3
|
@use "variables" as *;
|
|
4
4
|
@use "../../mixins/layer" as *;
|
|
5
|
+
@use "mixins" as *;
|
|
6
|
+
@use "../../defaults" as root-defaults;
|
|
7
|
+
@use "sass:map";
|
|
5
8
|
|
|
6
|
-
@
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
outline: $focus-outline-width $focus-outline-style $focus-outline-color;
|
|
10
|
-
outline-offset: $focus-outline-offset;
|
|
11
|
-
box-shadow: $focus-box-shadow;
|
|
9
|
+
@each $state in map.get(root-defaults.$state-selectors, focus) {
|
|
10
|
+
*#{$state} {
|
|
11
|
+
@include apply-focus;
|
|
12
12
|
}
|
|
13
13
|
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// @graupl/graupl focus state mixins.
|
|
2
|
+
|
|
3
|
+
@use "variables" as *;
|
|
4
|
+
@use "../../mixins/layer" as *;
|
|
5
|
+
@use "../../defaults" as root-defaults;
|
|
6
|
+
@use "sass:map";
|
|
7
|
+
|
|
8
|
+
@mixin apply-focus() {
|
|
9
|
+
@include layer(state) {
|
|
10
|
+
border-color: transparent;
|
|
11
|
+
outline: $focus-outline-width $focus-outline-style $focus-outline-color;
|
|
12
|
+
outline-offset: $focus-outline-offset;
|
|
13
|
+
box-shadow: $focus-box-shadow;
|
|
14
|
+
}
|
|
15
|
+
}
|
package/stylelint.config.js
CHANGED
|
@@ -11,6 +11,10 @@ const config = {
|
|
|
11
11
|
"selector-max-compound-selectors": 4,
|
|
12
12
|
"max-nesting-depth": 4,
|
|
13
13
|
"selector-no-qualifying-type": null,
|
|
14
|
+
"@stylistic/string-quotes": "double",
|
|
15
|
+
"@stylistic/function-parentheses-space-inside": "never-single-line",
|
|
16
|
+
"@stylistic/indentation": null,
|
|
17
|
+
"@stylistic/block-opening-brace-space-before": "never-single-line",
|
|
14
18
|
},
|
|
15
19
|
};
|
|
16
20
|
|
package/vite.config.js
ADDED
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { resolve } from "path";
|
|
2
|
+
import { defineConfig } from "vite";
|
|
3
|
+
import { fileURLToPath, URL } from "url";
|
|
4
|
+
import process from "process";
|
|
5
|
+
|
|
6
|
+
// Get the current directory path.
|
|
7
|
+
const __dirname = fileURLToPath(new URL(".", import.meta.url));
|
|
8
|
+
|
|
9
|
+
// The type of menu to build from the BUILD_TYPE environment variable.
|
|
10
|
+
// If BUILD_TYPE is not set, the default build is used
|
|
11
|
+
const buildType = process.env.BUILD_TYPE ?? "default";
|
|
12
|
+
|
|
13
|
+
// Supported build types.
|
|
14
|
+
const formats = ["iife", "esm", "cjs"];
|
|
15
|
+
|
|
16
|
+
// The library options for the different menus.
|
|
17
|
+
const lib = {
|
|
18
|
+
default: {
|
|
19
|
+
entry: resolve(__dirname, "build.js"),
|
|
20
|
+
name: "Graupl",
|
|
21
|
+
formats,
|
|
22
|
+
fileName: (format) => `graupl.${format}.js`,
|
|
23
|
+
},
|
|
24
|
+
Accordion: {
|
|
25
|
+
entry: resolve(__dirname, "/src/js/accordion/Accordion.js"),
|
|
26
|
+
name: "Accordion",
|
|
27
|
+
formats,
|
|
28
|
+
fileName: (format) => `component/accordion.${format}.js`,
|
|
29
|
+
},
|
|
30
|
+
Alert: {
|
|
31
|
+
entry: resolve(__dirname, "/src/js/alert/Alert.js"),
|
|
32
|
+
name: "Alert",
|
|
33
|
+
formats,
|
|
34
|
+
fileName: (format) => `component/alert.${format}.js`,
|
|
35
|
+
},
|
|
36
|
+
Carousel: {
|
|
37
|
+
entry: resolve(__dirname, "/src/js/carousel/Carousel.js"),
|
|
38
|
+
name: "Carousel",
|
|
39
|
+
formats,
|
|
40
|
+
fileName: (format) => `component/carousel.${format}.js`,
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
// https://vitejs.dev/config/
|
|
45
|
+
export default defineConfig({
|
|
46
|
+
build: {
|
|
47
|
+
outDir: "dist/js",
|
|
48
|
+
lib: lib[buildType] || lib.default,
|
|
49
|
+
emptyOutDir: false,
|
|
50
|
+
},
|
|
51
|
+
server: {
|
|
52
|
+
host: "0.0.0.0",
|
|
53
|
+
hmr: {
|
|
54
|
+
host: "localhost",
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
});
|