@graupl/graupl 1.0.0-alpha.15 → 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.
Files changed (167) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/build.js +7 -0
  3. package/dist/css/base/button.css +2 -0
  4. package/dist/css/base/button.css.map +1 -0
  5. package/dist/css/base/form.css.map +1 -0
  6. package/dist/css/base/link.css.map +1 -0
  7. package/dist/css/base/table.css.map +1 -0
  8. package/dist/css/base.css +2 -0
  9. package/dist/css/base.css.map +1 -0
  10. package/dist/css/component/accordion.css +2 -0
  11. package/dist/css/component/accordion.css.map +1 -0
  12. package/dist/css/component/alert.css +2 -0
  13. package/dist/css/component/alert.css.map +1 -0
  14. package/dist/css/component/card.css.map +1 -0
  15. package/dist/css/component/carousel.css +2 -0
  16. package/dist/css/component/carousel.css.map +1 -0
  17. package/dist/css/component/input-group.css.map +1 -0
  18. package/dist/css/component/menu.css.map +1 -0
  19. package/dist/css/component/navigation.css.map +1 -0
  20. package/dist/css/component.css +2 -0
  21. package/dist/css/component.css.map +1 -0
  22. package/dist/css/graupl.css +2 -0
  23. package/dist/css/graupl.css.map +1 -0
  24. package/dist/css/init.css.map +1 -0
  25. package/dist/css/layout/columns.css.map +1 -0
  26. package/dist/css/layout/container.css.map +1 -0
  27. package/dist/css/layout/flex-columns.css.map +1 -0
  28. package/dist/css/layout.css +2 -0
  29. package/dist/css/layout.css.map +1 -0
  30. package/dist/css/normalize.css.map +1 -0
  31. package/dist/css/state/focus.css +2 -0
  32. package/dist/css/state/focus.css.map +1 -0
  33. package/dist/css/state.css +2 -0
  34. package/dist/css/state.css.map +1 -0
  35. package/dist/css/theme/color.css.map +1 -0
  36. package/dist/css/theme/typography.css.map +1 -0
  37. package/dist/css/theme.css.map +1 -0
  38. package/dist/css/utilities/alignment.css.map +1 -0
  39. package/dist/css/utilities/color.css.map +1 -0
  40. package/dist/css/utilities/display.css.map +1 -0
  41. package/dist/css/utilities/flex.css.map +1 -0
  42. package/dist/css/utilities/height.css.map +1 -0
  43. package/dist/css/utilities/inset.css.map +1 -0
  44. package/dist/css/utilities/justification.css.map +1 -0
  45. package/dist/css/utilities/list.css.map +1 -0
  46. package/dist/css/utilities/order.css.map +1 -0
  47. package/dist/css/utilities/postion.css.map +1 -0
  48. package/dist/css/utilities/spacing.css.map +1 -0
  49. package/dist/css/utilities/typography.css.map +1 -0
  50. package/dist/css/utilities/visibility.css.map +1 -0
  51. package/dist/css/utilities/width.css.map +1 -0
  52. package/dist/css/utilities.css.map +1 -0
  53. package/dist/js/component/accordion.cjs.js +3 -0
  54. package/dist/js/component/accordion.esm.js +1289 -0
  55. package/dist/js/component/accordion.iife.js +3 -0
  56. package/dist/js/component/alert.cjs.js +3 -0
  57. package/dist/js/component/alert.esm.js +529 -0
  58. package/dist/js/component/alert.iife.js +3 -0
  59. package/dist/js/component/carousel.cjs.js +3 -0
  60. package/dist/js/component/carousel.esm.js +1110 -0
  61. package/dist/js/component/carousel.iife.js +3 -0
  62. package/dist/js/graupl.cjs.js +5 -0
  63. package/dist/js/graupl.esm.js +1462 -0
  64. package/dist/js/graupl.iife.js +5 -0
  65. package/index.html +56 -2
  66. package/index.js +12 -0
  67. package/package.json +26 -5
  68. package/scss/component/accordion.scss +3 -0
  69. package/src/js/accordion/Accordion.js +1163 -0
  70. package/src/js/accordion/AccordionItem.js +496 -0
  71. package/src/js/accordion/index.js +10 -0
  72. package/src/js/alert/Alert.js +71 -1
  73. package/src/js/alert/index.js +1 -11
  74. package/src/js/carousel/Carousel.js +67 -16
  75. package/src/js/carousel/index.js +1 -11
  76. package/src/js/eventHandlers.js +7 -0
  77. package/src/js/storage.js +106 -0
  78. package/src/scss/_defaults.scss +29 -0
  79. package/src/scss/base/button/_mixins.scss +64 -62
  80. package/src/scss/component/_index.scss +1 -0
  81. package/src/scss/component/accordion/_defaults.scss +40 -0
  82. package/src/scss/component/accordion/_index.scss +180 -0
  83. package/src/scss/component/accordion/_variables.scss +304 -0
  84. package/src/scss/component/carousel/_index.scss +6 -0
  85. package/src/scss/layout/columns/_index.scss +1 -1
  86. package/src/scss/layout/flex-columns/_index.scss +1 -1
  87. package/src/scss/state/focus/_index.scss +6 -6
  88. package/src/scss/state/focus/_mixins.scss +15 -0
  89. package/vite.config.js +57 -0
  90. package/dist/base/button.css +0 -2
  91. package/dist/base/button.css.map +0 -1
  92. package/dist/base/form.css.map +0 -1
  93. package/dist/base/link.css.map +0 -1
  94. package/dist/base/table.css.map +0 -1
  95. package/dist/base.css +0 -2
  96. package/dist/base.css.map +0 -1
  97. package/dist/component/alert.css +0 -2
  98. package/dist/component/alert.css.map +0 -1
  99. package/dist/component/card.css.map +0 -1
  100. package/dist/component/carousel.css +0 -2
  101. package/dist/component/carousel.css.map +0 -1
  102. package/dist/component/input-group.css.map +0 -1
  103. package/dist/component/menu.css.map +0 -1
  104. package/dist/component/navigation.css.map +0 -1
  105. package/dist/component.css +0 -2
  106. package/dist/component.css.map +0 -1
  107. package/dist/graupl.css +0 -2
  108. package/dist/graupl.css.map +0 -1
  109. package/dist/init.css.map +0 -1
  110. package/dist/layout/columns.css.map +0 -1
  111. package/dist/layout/container.css.map +0 -1
  112. package/dist/layout/flex-columns.css.map +0 -1
  113. package/dist/layout.css +0 -2
  114. package/dist/layout.css.map +0 -1
  115. package/dist/normalize.css.map +0 -1
  116. package/dist/state/focus.css +0 -2
  117. package/dist/state/focus.css.map +0 -1
  118. package/dist/state.css +0 -2
  119. package/dist/state.css.map +0 -1
  120. package/dist/theme/color.css.map +0 -1
  121. package/dist/theme/typography.css.map +0 -1
  122. package/dist/theme.css.map +0 -1
  123. package/dist/utilities/alignment.css.map +0 -1
  124. package/dist/utilities/color.css.map +0 -1
  125. package/dist/utilities/display.css.map +0 -1
  126. package/dist/utilities/flex.css.map +0 -1
  127. package/dist/utilities/height.css.map +0 -1
  128. package/dist/utilities/inset.css.map +0 -1
  129. package/dist/utilities/justification.css.map +0 -1
  130. package/dist/utilities/list.css.map +0 -1
  131. package/dist/utilities/order.css.map +0 -1
  132. package/dist/utilities/postion.css.map +0 -1
  133. package/dist/utilities/spacing.css.map +0 -1
  134. package/dist/utilities/typography.css.map +0 -1
  135. package/dist/utilities/visibility.css.map +0 -1
  136. package/dist/utilities/width.css.map +0 -1
  137. package/dist/utilities.css.map +0 -1
  138. /package/dist/{base → css/base}/form.css +0 -0
  139. /package/dist/{base → css/base}/link.css +0 -0
  140. /package/dist/{base → css/base}/table.css +0 -0
  141. /package/dist/{component → css/component}/card.css +0 -0
  142. /package/dist/{component → css/component}/input-group.css +0 -0
  143. /package/dist/{component → css/component}/menu.css +0 -0
  144. /package/dist/{component → css/component}/navigation.css +0 -0
  145. /package/dist/{init.css → css/init.css} +0 -0
  146. /package/dist/{layout → css/layout}/columns.css +0 -0
  147. /package/dist/{layout → css/layout}/container.css +0 -0
  148. /package/dist/{layout → css/layout}/flex-columns.css +0 -0
  149. /package/dist/{normalize.css → css/normalize.css} +0 -0
  150. /package/dist/{theme → css/theme}/color.css +0 -0
  151. /package/dist/{theme → css/theme}/typography.css +0 -0
  152. /package/dist/{theme.css → css/theme.css} +0 -0
  153. /package/dist/{utilities → css/utilities}/alignment.css +0 -0
  154. /package/dist/{utilities → css/utilities}/color.css +0 -0
  155. /package/dist/{utilities → css/utilities}/display.css +0 -0
  156. /package/dist/{utilities → css/utilities}/flex.css +0 -0
  157. /package/dist/{utilities → css/utilities}/height.css +0 -0
  158. /package/dist/{utilities → css/utilities}/inset.css +0 -0
  159. /package/dist/{utilities → css/utilities}/justification.css +0 -0
  160. /package/dist/{utilities → css/utilities}/list.css +0 -0
  161. /package/dist/{utilities → css/utilities}/order.css +0 -0
  162. /package/dist/{utilities → css/utilities}/postion.css +0 -0
  163. /package/dist/{utilities → css/utilities}/spacing.css +0 -0
  164. /package/dist/{utilities → css/utilities}/typography.css +0 -0
  165. /package/dist/{utilities → css/utilities}/visibility.css +0 -0
  166. /package/dist/{utilities → css/utilities}/width.css +0 -0
  167. /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(xs) {
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(xs) {
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
- @include layer(state) {
7
- *:focus-visible {
8
- border-color: transparent;
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/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
+ });
@@ -1,2 +0,0 @@
1
- @layer graupl.base{.button{align-items:center;border:var(--graupl-button-border,var(--graupl-button-border-width,var(--graupl-border-width,2px)) var(--graupl-botton-border-style,var(--graupl-border-style,solid)));border-radius:var(--graupl-button-border-radius,var(--graupl-border-radius,.125rem));cursor:pointer;display:flex;font-size:var(--graupl-button-font-size,var(--graupl-font-base,calc(var(--graupl-font-size-base, 1rem)*1)));justify-content:center;min-height:var(--graupl-button-min-height,44px);min-width:var(--graupl-button-min-width,44px);padding:var(--graupl-button-padding,var(--graupl-button-padding-y,var(--graupl-spacer-3,calc(var(--graupl-spacer, 1rem)*.5))) var(--graupl-button-padding-x,var(--graupl-spacer-5,calc(var(--graupl-spacer, 1rem)*1))));transform:var(--graupl-button-transform,none);transition:var(--graupl-button-transition,background var(--graupl-transition-duration-fast,.15s) var(--graupl-transition-timing-function,ease),color var(--graupl-transition-duration-fast,.15s) var(--graupl-transition-timing-function,ease),transform var(--graupl-transition-duration-fast,.15s) var(--graupl-transition-timing-function,ease))}.button.visited,.button:visited{--graupl-button-transform:var(--graupl-button-visited-transform,none)}.button.focus,.button:focus-visible{--graupl-button-transform:var(--graupl-button-focus-transform,none)}.button.hover,.button:hover{--graupl-button-transform:var(--graupl-button-hover-transform,none)}.button.active,.button:active{--graupl-button-transform:var(--graupl-button-active-transform,scale(0.95))}.button.disabled,.button:disabled,.button[disabled]{cursor:not-allowed}.button.disabled,.button.disabled.active,.button.disabled.focus,.button.disabled.hover,.button.disabled.visited,.button.disabled:active,.button.disabled:focus-visible,.button.disabled:hover,.button.disabled:visited,.button:disabled,.button:disabled.active,.button:disabled.focus,.button:disabled.hover,.button:disabled.visited,.button:disabled:active,.button:disabled:focus-visible,.button:disabled:hover,.button:disabled:visited,.button[disabled],.button[disabled].active,.button[disabled].focus,.button[disabled].hover,.button[disabled].visited,.button[disabled]:active,.button[disabled]:focus-visible,.button[disabled]:hover,.button[disabled]:visited{--graupl-button-transform:var(--graupl-button-disabled-transform,none)}@media (prefers-reduced-motion:reduce){.button{--graupl-button-transition:var(--graupl-button-transition-reduced-motion,background var(--graupl-transition-timing-function,ease),color var(--graupl-transition-timing-function,ease))}}}@layer graupl.theme{.button{background:var(--graupl-button-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));border-color:var(--graupl-button-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));color:var(--graupl-button-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))))}.button.primary{--graupl-button-color:var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)));--graupl-button-border-color:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-visited-color:var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)));--graupl-button-visited-border-color:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-focus-color:var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)));--graupl-button-focus-border-color:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-hover-color:var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)));--graupl-button-hover-background:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-hover-border-color:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-active-color:var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)));--graupl-button-active-background:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-active-border-color:var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1)));--graupl-button-disabled-color:var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa)));--graupl-button-disabled-border-color:var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa)))}.button.secondary{--graupl-button-color:var(--graupl-theme-active--secondary--900,var(--graupl-theme-light--secondary--900,var(--graupl-secondary--900,#0f1124)));--graupl-button-border-color:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-visited-color:var(--graupl-theme-active--secondary--900,var(--graupl-theme-light--secondary--900,var(--graupl-secondary--900,#0f1124)));--graupl-button-visited-border-color:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-focus-color:var(--graupl-theme-active--secondary--900,var(--graupl-theme-light--secondary--900,var(--graupl-secondary--900,#0f1124)));--graupl-button-focus-border-color:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-hover-color:var(--graupl-theme-active--secondary--100,var(--graupl-theme-light--secondary--100,var(--graupl-secondary--100,#edeef7)));--graupl-button-hover-background:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-hover-border-color:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-active-color:var(--graupl-theme-active--secondary--100,var(--graupl-theme-light--secondary--100,var(--graupl-secondary--100,#edeef7)));--graupl-button-active-background:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-active-border-color:var(--graupl-theme-active--secondary--700,var(--graupl-theme-light--secondary--700,var(--graupl-secondary--700,#474a6b)));--graupl-button-disabled-color:var(--graupl-theme-active--secondary--200,var(--graupl-theme-light--secondary--200,var(--graupl-secondary--200,#bdbfdb)));--graupl-button-disabled-border-color:var(--graupl-theme-active--secondary--200,var(--graupl-theme-light--secondary--200,var(--graupl-secondary--200,#bdbfdb)))}.button.tertiary{--graupl-button-color:var(--graupl-theme-active--tertiary--900,var(--graupl-theme-light--tertiary--900,var(--graupl-tertiary--900,#2f0412)));--graupl-button-border-color:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-visited-color:var(--graupl-theme-active--tertiary--900,var(--graupl-theme-light--tertiary--900,var(--graupl-tertiary--900,#2f0412)));--graupl-button-visited-border-color:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-focus-color:var(--graupl-theme-active--tertiary--900,var(--graupl-theme-light--tertiary--900,var(--graupl-tertiary--900,#2f0412)));--graupl-button-focus-border-color:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-hover-color:var(--graupl-theme-active--tertiary--100,var(--graupl-theme-light--tertiary--100,var(--graupl-tertiary--100,#fde7ef)));--graupl-button-hover-background:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-hover-border-color:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-active-color:var(--graupl-theme-active--tertiary--100,var(--graupl-theme-light--tertiary--100,var(--graupl-tertiary--100,#fde7ef)));--graupl-button-active-background:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-active-border-color:var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46)));--graupl-button-disabled-color:var(--graupl-theme-active--tertiary--200,var(--graupl-theme-light--tertiary--200,var(--graupl-tertiary--200,#f2a6bf)));--graupl-button-disabled-border-color:var(--graupl-theme-active--tertiary--200,var(--graupl-theme-light--tertiary--200,var(--graupl-tertiary--200,#f2a6bf)))}.button.visited,.button:visited{--graupl-button-border-color:var(--graupl-button-visited-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-button-background:var(--graupl-button-visited-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-button-color:var(--graupl-button-visited-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))))}.button.focus,.button:focus-visible{--graupl-button-border-color:var(--graupl-button-focus-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-button-background:var(--graupl-button-focus-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-button-color:var(--graupl-button-focus-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))))}.button.hover,.button:hover{--graupl-button-border-color:var(--graupl-button-hover-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-button-background:var(--graupl-button-hover-background,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233))));--graupl-button-color:var(--graupl-button-hover-color,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff))))}.button.active,.button:active{--graupl-button-border-color:var(--graupl-button-active-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-button-background:var(--graupl-button-active-background,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233))));--graupl-button-color:var(--graupl-button-active-color,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff))))}.button.disabled,.button.disabled.active,.button.disabled.focus,.button.disabled.hover,.button.disabled.visited,.button.disabled:active,.button.disabled:focus-visible,.button.disabled:hover,.button.disabled:visited,.button:disabled,.button:disabled.active,.button:disabled.focus,.button:disabled.hover,.button:disabled.visited,.button:disabled:active,.button:disabled:focus-visible,.button:disabled:hover,.button:disabled:visited,.button[disabled],.button[disabled].active,.button[disabled].focus,.button[disabled].hover,.button[disabled].visited,.button[disabled]:active,.button[disabled]:focus-visible,.button[disabled]:hover,.button[disabled]:visited{--graupl-button-border-color:var(--graupl-button-disabled-border-color,var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa))));--graupl-button-background:var(--graupl-button-disabled-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-button-color:var(--graupl-button-disabled-color,var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa))))}}.button.link{--graupl-button-padding:var(--graupl-link-padding,var(--graupl-link-padding-y,var(--graupl-spacer-0,calc(var(--graupl-spacer, 1rem)*0))) var(--graupl-link-padding-x,var(--graupl-spacer-0,calc(var(--graupl-spacer, 1rem)*0))));--graupl-button-transition:var(--graupl-link-transition,background var(--graupl-transition-duration-fast,150ms) var(--graupl-transition-timing-function,ease),color var(--graupl-transition-duration-fast,150ms) var(--graupl-transition-timing-function,ease),transform var(--graupl-transition-duration-fast,150ms) var(--graupl-transition-timing-function,ease));--graupl-button-transition-reduced-motion:var(--graupl-link-transition-reduced-motion,background var(--graupl-transition-timing-function,ease),color var(--graupl-transition-timing-function,ease));--graupl-button-transform:var(--graupl-link-transform,none);--graupl-button-visited-transform:var(--graupl-link-visited-transform,none);--graupl-button-focus-transform:var(--graupl-link-transform,none);--graupl-button-hover-transform:var(--graupl-link-hover-transform,none);--graupl-button-active-transform:var(--graupl-link-active-transform,none);--graupl-button-border-width:var(--graupl-link-border-width,0);--graupl-button-border-style:var(--graupl-link-border-style,var(--graupl-border-style,solid));--graupl-button-border-radius:var(--graupl-link-border-radius,var(--graupl-border-radius,0.125rem));--graupl-button-min-width:var(--graupl-link-min-width,auto);--graupl-button-min-height:var(--graupl-link-min-height,auto);--graupl-button-font-size:inherit;-webkit-text-decoration:var(--graupl-link-text-decoration,underline);text-decoration:var(--graupl-link-text-decoration,underline);text-decoration-style:var(--graupl-link-text-decoration-style,solid);text-decoration-thickness:var(--graupl-link-text-decoration-thickness,var(--graupl-border-width,2px))}@layer graupl.base{.button.link{--graupl-button-color:var(--graupl-link-color,var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1))));--graupl-button-visited-color:var(--graupl-link-visited-color,var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1))));--graupl-button-focus-color:var(--graupl-link-focus-color,var(--graupl-theme-active--primary--700,var(--graupl-theme-light--primary--700,var(--graupl-primary--700,#1244a1))));--graupl-button-hover-color:var(--graupl-link-hover-color,var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46))));--graupl-button-active-color:var(--graupl-link-active-color,var(--graupl-theme-active--tertiary--700,var(--graupl-theme-light--tertiary--700,var(--graupl-tertiary--700,#931f46))));--graupl-button-disabled-color:var(--graupl-link-disabled-color,var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa))));--graupl-button-background:var(--graupl-link-background,transparent);--graupl-button-visited-background:var(--graupl-link-visited-background,transparent);--graupl-button-focus-background:var(--graupl-link-focus-background,transparent);--graupl-button-hover-background:var(--graupl-link-hover-background,transparent);--graupl-button-active-background:var(--graupl-link-active-background,transparent);--graupl-button-disabled-background:var(--graupl-link-disabled-background,transparent);--graupl-button-border-color:var(--graupl-link-border-color,transparent);--graupl-button-visited-border-color:var(--graupl-link-visited-border-color,transparent);--graupl-button-focus-border-color:var(--graupl-link-focus-border-color,transparent);--graupl-button-hover-border-color:var(--graupl-link-hover-border-color,transparent);--graupl-button-active-border-color:var(--graupl-link-active-border-color,transparent);--graupl-button-disabled-border-color:var(--graupl-link-disabled-border-color,transparent)}a.button:not(.link){--graupl-link-padding:var(--graupl-button-padding,var(--graupl-button-padding-y,var(--graupl-spacer-3,calc(var(--graupl-spacer, 1rem)*0.5))) var(--graupl-button-padding-x,var(--graupl-spacer-5,calc(var(--graupl-spacer, 1rem)*1))));--graupl-link-transition:var(--graupl-button-transition,background var(--graupl-transition-duration-fast,150ms) var(--graupl-transition-timing-function,ease),color var(--graupl-transition-duration-fast,150ms) var(--graupl-transition-timing-function,ease),transform var(--graupl-transition-duration-fast,150ms) var(--graupl-transition-timing-function,ease));--graupl-link-transition-reduced-motion:var(--graupl-button-transition-reduced-motion,background var(--graupl-transition-timing-function,ease),color var(--graupl-transition-timing-function,ease));--graupl-link-transform:var(--graupl-button-transform,none);--graupl-link-visited-transform:var(--graupl-button-visited-transform,none);--graupl-link-focus-transform:var(--graupl-button-focus-transform,none);--graupl-link-hover-transform:var(--graupl-button-hover-transform,none);--graupl-link-active-transform:var(--graupl-button-active-transform,scale(0.95));--graupl-link-disabled-transform:var(--graupl-button-disabled-transform,none);--graupl-link-border-width:var(--graupl-button-border-width,var(--graupl-border-width,2px));--graupl-link-border-style:var(--graupl-botton-border-style,var(--graupl-border-style,solid));--graupl-link-border-radius:var(--graupl-button-border-radius,var(--graupl-border-radius,0.125rem));--graupl-link-min-width:var(--graupl-button-min-width,44px);--graupl-link-min-height:var(--graupl-button-min-height,44px);--graupl-link-text-decoration:none;--graupl-link-visited-text-decoration:none;--graupl-link-focus-text-decoration:none;--graupl-link-hover-text-decoration:none;--graupl-link-active-text-decoration:none;--graupl-link-disabled-text-decoration:none}}@layer graupl.theme{a.button:not(.link){--graupl-link-color:var(--graupl-button-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-visited-color:var(--graupl-button-visited-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-focus-color:var(--graupl-button-focus-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-hover-color:var(--graupl-button-hover-color,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff))));--graupl-link-active-color:var(--graupl-button-active-color,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff))));--graupl-link-disabled-color:var(--graupl-button-disabled-color,var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa))));--graupl-link-background:var(--graupl-button-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-link-visited-background:var(--graupl-button-visited-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-link-focus-background:var(--graupl-button-focus-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-link-hover-background:var(--graupl-button-hover-background,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233))));--graupl-link-active-background:var(--graupl-button-active-background,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233))));--graupl-link-disabled-background:var(--graupl-button-disabled-background,var(--graupl-root-background,var(--graupl-theme-active--primary--100,var(--graupl-theme-light--primary--100,var(--graupl-primary--100,#e6eeff)))));--graupl-link-border-color:var(--graupl-button-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-visited-border-color:var(--graupl-button-visited-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-focus-border-color:var(--graupl-button-focus-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-hover-border-color:var(--graupl-button-hover-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-active-border-color:var(--graupl-button-active-border-color,var(--graupl-root-color,var(--graupl-theme-active--primary--900,var(--graupl-theme-light--primary--900,var(--graupl-primary--900,#001233)))));--graupl-link-disabled-border-color:var(--graupl-button-disabled-border-color,var(--graupl-theme-active--primary--200,var(--graupl-theme-light--primary--200,var(--graupl-primary--200,#9ebefa))))}}
2
- /*# sourceMappingURL=button.css.map */