@graupl/graupl 1.0.0-alpha.11 → 1.0.0-alpha.13

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 (195) hide show
  1. package/CHANGELOG.md +54 -0
  2. package/dist/base/button.css +2 -0
  3. package/dist/base/button.css.map +1 -0
  4. package/dist/base/form.css +1 -1
  5. package/dist/base/form.css.map +1 -1
  6. package/dist/base/link.css +1 -1
  7. package/dist/base/link.css.map +1 -1
  8. package/dist/base/table.css +1 -1
  9. package/dist/base/table.css.map +1 -1
  10. package/dist/base.css +1 -1
  11. package/dist/base.css.map +1 -1
  12. package/dist/component/card.css +2 -0
  13. package/dist/component/card.css.map +1 -0
  14. package/dist/component/input-group.css +1 -1
  15. package/dist/component/input-group.css.map +1 -1
  16. package/dist/component/menu.css +2 -0
  17. package/dist/component/menu.css.map +1 -0
  18. package/dist/component/navigation.css +2 -0
  19. package/dist/component/navigation.css.map +1 -0
  20. package/dist/component.css +1 -1
  21. package/dist/component.css.map +1 -1
  22. package/dist/graupl.css +1 -1
  23. package/dist/graupl.css.map +1 -1
  24. package/dist/init.css +2 -0
  25. package/dist/init.css.map +1 -0
  26. package/dist/layout/columns.css +1 -1
  27. package/dist/layout/columns.css.map +1 -1
  28. package/dist/layout/container.css.map +1 -1
  29. package/dist/layout/flex-columns.css +2 -0
  30. package/dist/layout/flex-columns.css.map +1 -0
  31. package/dist/layout.css +1 -1
  32. package/dist/layout.css.map +1 -1
  33. package/dist/normalize.css +2 -0
  34. package/dist/normalize.css.map +1 -0
  35. package/dist/state/focus.css.map +1 -1
  36. package/dist/state.css.map +1 -1
  37. package/dist/theme/color.css.map +1 -1
  38. package/dist/theme/typography.css +1 -1
  39. package/dist/theme/typography.css.map +1 -1
  40. package/dist/theme.css +1 -1
  41. package/dist/theme.css.map +1 -1
  42. package/dist/utilities/order.css +2 -0
  43. package/dist/utilities/order.css.map +1 -0
  44. package/dist/utilities/spacing.css +1 -1
  45. package/dist/utilities/spacing.css.map +1 -1
  46. package/dist/utilities/typography.css +1 -1
  47. package/dist/utilities/typography.css.map +1 -1
  48. package/dist/utilities.css +1 -1
  49. package/dist/utilities.css.map +1 -1
  50. package/eslint.config.js +1 -0
  51. package/index.html +619 -326
  52. package/package.json +2 -1
  53. package/scss/base/button.scss +3 -0
  54. package/scss/base/form.scss +1 -1
  55. package/scss/base/link.scss +1 -1
  56. package/scss/base/table.scss +1 -1
  57. package/scss/base.scss +1 -1
  58. package/scss/component/card.scss +3 -0
  59. package/scss/component/input-group.scss +1 -1
  60. package/scss/component/menu.scss +3 -0
  61. package/scss/component/navigation.scss +3 -0
  62. package/scss/component.scss +1 -1
  63. package/scss/graupl.scss +1 -3
  64. package/scss/init.scss +3 -0
  65. package/scss/layout/columns.scss +1 -1
  66. package/scss/layout/container.scss +1 -1
  67. package/scss/layout/flex-columns.scss +3 -0
  68. package/scss/layout.scss +1 -1
  69. package/scss/normalize.scss +3 -0
  70. package/scss/state/focus.scss +1 -1
  71. package/scss/state.scss +1 -1
  72. package/scss/theme/color.scss +1 -1
  73. package/scss/theme/typography.scss +1 -1
  74. package/scss/theme.scss +1 -1
  75. package/scss/utilities/alignment.scss +1 -1
  76. package/scss/utilities/color.scss +1 -1
  77. package/scss/utilities/display.scss +1 -1
  78. package/scss/utilities/flex.scss +1 -1
  79. package/scss/utilities/inset.scss +1 -1
  80. package/scss/utilities/justification.scss +1 -1
  81. package/scss/utilities/list.scss +1 -1
  82. package/scss/utilities/order.scss +3 -0
  83. package/scss/utilities/postion.scss +1 -1
  84. package/scss/utilities/spacing.scss +1 -1
  85. package/scss/utilities/typography.scss +1 -1
  86. package/scss/utilities/visibility.scss +1 -1
  87. package/scss/utilities.scss +1 -1
  88. package/src/js/navigation.js +34 -0
  89. package/src/scss/_defaults.scss +21 -5
  90. package/src/scss/_index.scss +4 -3
  91. package/src/scss/_init.scss +2 -2
  92. package/src/scss/_normalize.scss +197 -0
  93. package/src/scss/_variables.scss +4 -1
  94. package/src/scss/base/_index.scss +2 -1
  95. package/src/scss/base/button/_defaults.scss +53 -0
  96. package/src/scss/base/button/_index.scss +210 -0
  97. package/src/scss/{component → base}/button/_variables.scss +51 -12
  98. package/src/scss/base/form/_defaults.scss +14 -4
  99. package/src/scss/base/form/_index.scss +23 -20
  100. package/src/scss/base/form/_variables.scss +12 -1
  101. package/src/scss/base/link/_defaults.scss +48 -5
  102. package/src/scss/base/link/_index.scss +101 -17
  103. package/src/scss/base/link/_variables.scss +226 -5
  104. package/src/scss/base/table/_defaults.scss +49 -4
  105. package/src/scss/base/table/_index.scss +102 -8
  106. package/src/scss/base/table/_variables.scss +71 -1
  107. package/src/scss/component/_index.scss +4 -3
  108. package/src/scss/component/card/_defaults.scss +29 -0
  109. package/src/scss/component/card/_index.scss +143 -0
  110. package/src/scss/component/card/_variables.scss +185 -0
  111. package/src/scss/component/input-group/_defaults.scss +11 -4
  112. package/src/scss/component/input-group/_index.scss +11 -9
  113. package/src/scss/component/input-group/_variables.scss +4 -1
  114. package/src/scss/component/menu/_defaults.scss +65 -0
  115. package/src/scss/component/menu/_index.scss +304 -0
  116. package/src/scss/component/menu/_variables.scss +491 -0
  117. package/src/scss/component/navigation/_defaults.scss +29 -0
  118. package/src/scss/component/navigation/_index.scss +189 -0
  119. package/src/scss/component/navigation/_variables.scss +237 -0
  120. package/src/scss/functions/_important.scss +2 -0
  121. package/src/scss/functions/_theme.scss +18 -0
  122. package/src/scss/layout/_index.scss +2 -1
  123. package/src/scss/layout/columns/_defaults.scss +12 -4
  124. package/src/scss/layout/columns/_index.scss +27 -5
  125. package/src/scss/layout/columns/_variables.scss +4 -1
  126. package/src/scss/layout/container/_defaults.scss +13 -4
  127. package/src/scss/layout/container/_index.scss +12 -7
  128. package/src/scss/layout/container/_variables.scss +4 -1
  129. package/src/scss/layout/flex-columns/_defaults.scss +18 -0
  130. package/src/scss/layout/flex-columns/_index.scss +77 -0
  131. package/src/scss/layout/flex-columns/_variables.scss +26 -0
  132. package/src/scss/mixins/_layer.scss +1 -1
  133. package/src/scss/mixins/_media-queries.scss +10 -1
  134. package/src/scss/state/_index.scss +1 -1
  135. package/src/scss/state/focus/_defaults.scss +6 -4
  136. package/src/scss/state/focus/_index.scss +1 -1
  137. package/src/scss/state/focus/_variables.scss +4 -1
  138. package/src/scss/theme/_index.scss +1 -1
  139. package/src/scss/theme/color/_defaults.scss +6 -4
  140. package/src/scss/theme/color/_index.scss +1 -1
  141. package/src/scss/theme/color/_variables.scss +4 -1
  142. package/src/scss/theme/typography/_defaults.scss +7 -5
  143. package/src/scss/theme/typography/_index.scss +1 -1
  144. package/src/scss/theme/typography/_variables.scss +9 -3
  145. package/src/scss/utilities/_index.scss +3 -1
  146. package/src/scss/utilities/alignment/_defaults.scss +6 -4
  147. package/src/scss/utilities/alignment/_index.scss +1 -1
  148. package/src/scss/utilities/alignment/_variables.scss +4 -1
  149. package/src/scss/utilities/color/_defaults.scss +6 -4
  150. package/src/scss/utilities/color/_index.scss +1 -1
  151. package/src/scss/utilities/color/_variables.scss +4 -1
  152. package/src/scss/utilities/display/_defaults.scss +6 -4
  153. package/src/scss/utilities/display/_index.scss +1 -1
  154. package/src/scss/utilities/display/_variables.scss +4 -1
  155. package/src/scss/utilities/flex/_defaults.scss +6 -4
  156. package/src/scss/utilities/flex/_index.scss +1 -1
  157. package/src/scss/utilities/flex/_variables.scss +4 -1
  158. package/src/scss/utilities/inset/_defaults.scss +6 -4
  159. package/src/scss/utilities/inset/_index.scss +1 -1
  160. package/src/scss/utilities/inset/_variables.scss +4 -1
  161. package/src/scss/utilities/justification/_defaults.scss +6 -4
  162. package/src/scss/utilities/justification/_index.scss +1 -1
  163. package/src/scss/utilities/justification/_variables.scss +4 -1
  164. package/src/scss/utilities/list/_defaults.scss +6 -4
  165. package/src/scss/utilities/list/_index.scss +1 -1
  166. package/src/scss/utilities/list/_variables.scss +4 -1
  167. package/src/scss/utilities/order/_defaults.scss +19 -0
  168. package/src/scss/utilities/order/_index.scss +35 -0
  169. package/src/scss/utilities/order/_variables.scss +6 -0
  170. package/src/scss/utilities/position/_defaults.scss +6 -4
  171. package/src/scss/utilities/position/_index.scss +1 -1
  172. package/src/scss/utilities/position/_variables.scss +4 -1
  173. package/src/scss/utilities/ratio/_defaults.scss +24 -0
  174. package/src/scss/utilities/ratio/_index.scss +26 -0
  175. package/src/scss/utilities/ratio/_variables.scss +9 -0
  176. package/src/scss/utilities/spacing/_defaults.scss +6 -4
  177. package/src/scss/utilities/spacing/_index.scss +41 -17
  178. package/src/scss/utilities/spacing/_variables.scss +4 -1
  179. package/src/scss/utilities/typography/_defaults.scss +6 -4
  180. package/src/scss/utilities/typography/_index.scss +1 -1
  181. package/src/scss/utilities/typography/_variables.scss +4 -1
  182. package/src/scss/utilities/visibility/_defaults.scss +6 -4
  183. package/src/scss/utilities/visibility/_index.scss +1 -1
  184. package/src/scss/utilities/visibility/_variables.scss +4 -1
  185. package/dist/component/button.css +0 -2
  186. package/dist/component/button.css.map +0 -1
  187. package/dist/component/table.css +0 -2
  188. package/dist/component/table.css.map +0 -1
  189. package/scss/component/button.scss +0 -3
  190. package/scss/component/table.scss +0 -3
  191. package/src/scss/component/button/_defaults.scss +0 -39
  192. package/src/scss/component/button/_index.scss +0 -134
  193. package/src/scss/component/table/_defaults.scss +0 -30
  194. package/src/scss/component/table/_index.scss +0 -77
  195. package/src/scss/component/table/_variables.scss +0 -64
@@ -0,0 +1,210 @@
1
+ // @gruapl/graupl button base styles.
2
+
3
+ @use "defaults";
4
+ @use "../../defaults" as root-defaults;
5
+ @use "../link/defaults" as link-defaults;
6
+ @use "../../theme/color/variables" as color;
7
+ @use "../../base/link/variables" as link;
8
+ @use "variables" as *;
9
+ @use "../../mixins/layer" as *;
10
+ @use "../../mixins/media-queries" as *;
11
+ @use "../../functions/theme";
12
+ @use "sass:map";
13
+
14
+ @include layer(base) {
15
+ #{defaults.$button-selector} {
16
+ display: flex;
17
+ align-items: center;
18
+ justify-content: center;
19
+ min-width: $button-min-width;
20
+ min-height: $button-min-height;
21
+ padding: $button-padding;
22
+ transform: $button-transform;
23
+ transition: $button-transition;
24
+ border: $button-border;
25
+ border-radius: $button-border-radius;
26
+ font-size: $button-font-size;
27
+ cursor: pointer;
28
+
29
+ &:visited {
30
+ --#{root-defaults.$prefix}-button-transform: #{$button-visited-transform};
31
+ }
32
+
33
+ &:focus-visible {
34
+ --#{root-defaults.$prefix}-button-transform: #{$button-focus-transform};
35
+ }
36
+
37
+ &:hover {
38
+ --#{root-defaults.$prefix}-button-transform: #{$button-hover-transform};
39
+ }
40
+
41
+ &:active {
42
+ --#{root-defaults.$prefix}-button-transform: #{$button-active-transform};
43
+ }
44
+
45
+ &:disabled,
46
+ &[disabled] {
47
+ cursor: not-allowed;
48
+
49
+ &,
50
+ &:visited,
51
+ &:focus-visible,
52
+ &:hover,
53
+ &:active {
54
+ --#{root-defaults.$prefix}-button-transform: #{$button-disabled-transform};
55
+ }
56
+ }
57
+
58
+ &#{defaults.$button-link-selector} {
59
+ --#{root-defaults.$prefix}-button-padding: #{link.$link-padding};
60
+ --#{root-defaults.$prefix}-button-transition: #{link.$link-transition};
61
+ --#{root-defaults.$prefix}-button-transition-reduced-motion: #{link.$link-transition-reduced-motion};
62
+ --#{root-defaults.$prefix}-button-transform: #{link.$link-transform};
63
+ --#{root-defaults.$prefix}-button-visited-transform: #{link.$link-visited-transform};
64
+ --#{root-defaults.$prefix}-button-focus-transform: #{link.$link-transform};
65
+ --#{root-defaults.$prefix}-button-hover-transform: #{link.$link-hover-transform};
66
+ --#{root-defaults.$prefix}-button-active-transform: #{link.$link-active-transform};
67
+ --#{root-defaults.$prefix}-button-border-width: #{link.$link-border-width};
68
+ --#{root-defaults.$prefix}-button-border-style: #{link.$link-border-style};
69
+ --#{root-defaults.$prefix}-button-border-radius: #{link.$link-border-radius};
70
+ --#{root-defaults.$prefix}-button-min-width: #{link.$link-min-width};
71
+ --#{root-defaults.$prefix}-button-min-height: #{link.$link-min-height};
72
+ --#{root-defaults.$prefix}-button-font-size: inherit;
73
+
74
+ text-decoration: link.$link-text-decoration;
75
+ text-decoration-thickness: link.$link-text-decoration-thickness;
76
+ text-decoration-style: link.$link-text-decoration-style;
77
+ }
78
+ }
79
+
80
+ #{link-defaults.$link-selector} {
81
+ &#{defaults.$button-selector}:not(#{defaults.$button-link-selector}) {
82
+ --#{root-defaults.$prefix}-link-padding: #{$button-padding};
83
+ --#{root-defaults.$prefix}-link-transition: #{$button-transition};
84
+ --#{root-defaults.$prefix}-link-transition-reduced-motion: #{$button-transition-reduced-motion};
85
+ --#{root-defaults.$prefix}-link-transform: #{$button-transform};
86
+ --#{root-defaults.$prefix}-link-visited-transform: #{$button-visited-transform};
87
+ --#{root-defaults.$prefix}-link-focus-transform: #{$button-focus-transform};
88
+ --#{root-defaults.$prefix}-link-hover-transform: #{$button-hover-transform};
89
+ --#{root-defaults.$prefix}-link-active-transform: #{$button-active-transform};
90
+ --#{root-defaults.$prefix}-link-disabled-transform: #{$button-disabled-transform};
91
+ --#{root-defaults.$prefix}-link-border-width: #{$button-border-width};
92
+ --#{root-defaults.$prefix}-link-border-style: #{$button-border-style};
93
+ --#{root-defaults.$prefix}-link-border-radius: #{$button-border-radius};
94
+ --#{root-defaults.$prefix}-link-min-width: #{$button-min-width};
95
+ --#{root-defaults.$prefix}-link-min-height: #{$button-min-height};
96
+ --#{root-defaults.$prefix}-link-text-decoration: none;
97
+ --#{root-defaults.$prefix}-link-visited-text-decoration: none;
98
+ --#{root-defaults.$prefix}-link-focus-text-decoration: none;
99
+ --#{root-defaults.$prefix}-link-hover-text-decoration: none;
100
+ --#{root-defaults.$prefix}-link-active-text-decoration: none;
101
+ --#{root-defaults.$prefix}-link-disabled-text-decoration: none;
102
+ }
103
+ }
104
+
105
+ @include animation-off {
106
+ #{defaults.$button-selector} {
107
+ --#{root-defaults.$prefix}-button-transition: #{$button-transition-reduced-motion};
108
+ }
109
+ }
110
+ }
111
+
112
+ @include layer(theme) {
113
+ #{defaults.$button-selector} {
114
+ border-color: $button-border-color;
115
+ background: $button-background;
116
+ color: $button-color;
117
+
118
+ @each $color, $map in color.$theme-active {
119
+ &#{defaults.$button-theme-selector-prefix}#{$color} {
120
+ @each $prop, $shade in defaults.$button-state-theme-map {
121
+ --#{root-defaults.$prefix}-button-#{$prop}: #{theme.get(
122
+ $color,
123
+ $shade
124
+ )};
125
+ }
126
+ }
127
+ }
128
+
129
+ &#{defaults.$button-link-selector} {
130
+ --#{root-defaults.$prefix}-button-color: #{link.$link-color};
131
+ --#{root-defaults.$prefix}-button-visited-color: #{link.$link-visited-color};
132
+ --#{root-defaults.$prefix}-button-focus-color: #{link.$link-focus-color};
133
+ --#{root-defaults.$prefix}-button-hover-color: #{link.$link-hover-color};
134
+ --#{root-defaults.$prefix}-button-active-color: #{link.$link-active-color};
135
+ --#{root-defaults.$prefix}-button-disabled-color: #{link.$link-disabled-color};
136
+ --#{root-defaults.$prefix}-button-background: #{link.$link-background};
137
+ --#{root-defaults.$prefix}-button-visited-background: #{link.$link-visited-background};
138
+ --#{root-defaults.$prefix}-button-focus-background: #{link.$link-focus-background};
139
+ --#{root-defaults.$prefix}-button-hover-background: #{link.$link-hover-background};
140
+ --#{root-defaults.$prefix}-button-active-background: #{link.$link-active-background};
141
+ --#{root-defaults.$prefix}-button-disabled-background: #{link.$link-disabled-background};
142
+ --#{root-defaults.$prefix}-button-border-color: #{link.$link-border-color};
143
+ --#{root-defaults.$prefix}-button-visited-border-color: #{link.$link-visited-border-color};
144
+ --#{root-defaults.$prefix}-button-focus-border-color: #{link.$link-focus-border-color};
145
+ --#{root-defaults.$prefix}-button-hover-border-color: #{link.$link-hover-border-color};
146
+ --#{root-defaults.$prefix}-button-active-border-color: #{link.$link-active-border-color};
147
+ --#{root-defaults.$prefix}-button-disabled-border-color: #{link.$link-disabled-border-color};
148
+ }
149
+
150
+ &:visited {
151
+ --#{root-defaults.$prefix}-button-border-color: #{$button-visited-border-color};
152
+ --#{root-defaults.$prefix}-button-background: #{$button-visited-background};
153
+ --#{root-defaults.$prefix}-button-color: #{$button-visited-color};
154
+ }
155
+
156
+ &:focus-visible {
157
+ --#{root-defaults.$prefix}-button-border-color: #{$button-focus-border-color};
158
+ --#{root-defaults.$prefix}-button-background: #{$button-focus-background};
159
+ --#{root-defaults.$prefix}-button-color: #{$button-focus-color};
160
+ }
161
+
162
+ &:hover {
163
+ --#{root-defaults.$prefix}-button-border-color: #{$button-hover-border-color};
164
+ --#{root-defaults.$prefix}-button-background: #{$button-hover-background};
165
+ --#{root-defaults.$prefix}-button-color: #{$button-hover-color};
166
+ }
167
+
168
+ &:active {
169
+ --#{root-defaults.$prefix}-button-border-color: #{$button-active-border-color};
170
+ --#{root-defaults.$prefix}-button-background: #{$button-active-background};
171
+ --#{root-defaults.$prefix}-button-color: #{$button-active-color};
172
+ }
173
+
174
+ &:disabled,
175
+ &[disabled] {
176
+ &,
177
+ &:visited,
178
+ &:focus-visible,
179
+ &:hover,
180
+ &:active {
181
+ --#{root-defaults.$prefix}-button-border-color: #{$button-disabled-border-color};
182
+ --#{root-defaults.$prefix}-button-background: #{$button-disabled-background};
183
+ --#{root-defaults.$prefix}-button-color: #{$button-disabled-color};
184
+ }
185
+ }
186
+ }
187
+
188
+ #{link-defaults.$link-selector} {
189
+ &#{defaults.$button-selector}:not(#{defaults.$button-link-selector}) {
190
+ --#{root-defaults.$prefix}-link-color: #{$button-color};
191
+ --#{root-defaults.$prefix}-link-visited-color: #{$button-visited-color};
192
+ --#{root-defaults.$prefix}-link-focus-color: #{$button-focus-color};
193
+ --#{root-defaults.$prefix}-link-hover-color: #{$button-hover-color};
194
+ --#{root-defaults.$prefix}-link-active-color: #{$button-active-color};
195
+ --#{root-defaults.$prefix}-link-disabled-color: #{$button-disabled-color};
196
+ --#{root-defaults.$prefix}-link-background: #{$button-background};
197
+ --#{root-defaults.$prefix}-link-visited-background: #{$button-visited-background};
198
+ --#{root-defaults.$prefix}-link-focus-background: #{$button-focus-background};
199
+ --#{root-defaults.$prefix}-link-hover-background: #{$button-hover-background};
200
+ --#{root-defaults.$prefix}-link-active-background: #{$button-active-background};
201
+ --#{root-defaults.$prefix}-link-disabled-background: #{$button-disabled-background};
202
+ --#{root-defaults.$prefix}-link-border-color: #{$button-border-color};
203
+ --#{root-defaults.$prefix}-link-visited-border-color: #{$button-visited-border-color};
204
+ --#{root-defaults.$prefix}-link-focus-border-color: #{$button-focus-border-color};
205
+ --#{root-defaults.$prefix}-link-hover-border-color: #{$button-hover-border-color};
206
+ --#{root-defaults.$prefix}-link-active-border-color: #{$button-active-border-color};
207
+ --#{root-defaults.$prefix}-link-disabled-border-color: #{$button-disabled-border-color};
208
+ }
209
+ }
210
+ }
@@ -1,4 +1,7 @@
1
- // Variables referencing custom properties.
1
+ // @graupl/graupl button base variables.
2
+ //
3
+ // These values are to be used to directly style bases and provide a
4
+ // cleaner way to reference custom properties.
2
5
 
3
6
  @use "defaults";
4
7
  @use "../../variables" as root-variables;
@@ -46,6 +49,18 @@ $button-transition-reduced-motion: var(
46
49
  );
47
50
 
48
51
  // Transform properties.
52
+ $button-transform: var(
53
+ --#{root-defaults.$prefix}-button-transform,
54
+ #{defaults.$button-transform}
55
+ );
56
+ $button-visited-transform: var(
57
+ --#{root-defaults.$prefix}-button-visited-transform,
58
+ #{defaults.$button-visited-transform}
59
+ );
60
+ $button-focus-transform: var(
61
+ --#{root-defaults.$prefix}-button-focus-transform,
62
+ #{defaults.$button-focus-transform}
63
+ );
49
64
  $button-hover-transform: var(
50
65
  --#{root-defaults.$prefix}-button-hover-transform,
51
66
  #{defaults.$button-hover-transform}
@@ -54,13 +69,9 @@ $button-active-transform: var(
54
69
  --#{root-defaults.$prefix}-button-active-transform,
55
70
  #{defaults.$button-active-transform}
56
71
  );
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}
72
+ $button-disabled-transform: var(
73
+ --#{root-defaults.$prefix}-button-disabled-transform,
74
+ #{defaults.$button-disabled-transform}
64
75
  );
65
76
 
66
77
  // Background properties.
@@ -68,6 +79,14 @@ $button-background: var(
68
79
  --#{root-defaults.$prefix}-button-background,
69
80
  #{color.$root-background}
70
81
  );
82
+ $button-visited-background: var(
83
+ --#{root-defaults.$prefix}-button-visited-background,
84
+ #{color.$root-background}
85
+ );
86
+ $button-focus-background: var(
87
+ --#{root-defaults.$prefix}-button-focus-background,
88
+ #{color.$root-background}
89
+ );
71
90
  $button-hover-background: var(
72
91
  --#{root-defaults.$prefix}-button-hover-background,
73
92
  #{theme.get(primary, 900)}
@@ -84,7 +103,15 @@ $button-disabled-background: var(
84
103
  // Text properties.
85
104
  $button-color: var(
86
105
  --#{root-defaults.$prefix}-button-color,
87
- #{theme.get(primary, 900)}
106
+ #{color.$root-color}
107
+ );
108
+ $button-visited-color: var(
109
+ --#{root-defaults.$prefix}-button-visited-color,
110
+ #{color.$root-color}
111
+ );
112
+ $button-focus-color: var(
113
+ --#{root-defaults.$prefix}-button-focus-color,
114
+ #{color.$root-color}
88
115
  );
89
116
  $button-hover-color: var(
90
117
  --#{root-defaults.$prefix}-button-hover-color,
@@ -108,6 +135,10 @@ $button-border-style: var(
108
135
  --#{root-defaults.$prefix}-botton-border-style,
109
136
  #{root-variables.$border-style}
110
137
  );
138
+ $button-border: var(
139
+ --#{root-defaults.$prefix}-button-border,
140
+ #{$button-border-width} #{$button-border-style}
141
+ );
111
142
  $button-border-radius: var(
112
143
  --#{root-defaults.$prefix}-button-border-radius,
113
144
  #{root-variables.$border-radius}
@@ -116,15 +147,23 @@ $button-border-radius: var(
116
147
  // Border colour properties.
117
148
  $button-border-color: var(
118
149
  --#{root-defaults.$prefix}-button-border-color,
119
- #{theme.get(primary, 900)}
150
+ #{color.$root-color}
151
+ );
152
+ $button-visited-border-color: var(
153
+ --#{root-defaults.$prefix}-button-visited-border-color,
154
+ #{color.$root-color}
155
+ );
156
+ $button-focus-border-color: var(
157
+ --#{root-defaults.$prefix}-button-focus-border-color,
158
+ #{color.$root-color}
120
159
  );
121
160
  $button-hover-border-color: var(
122
161
  --#{root-defaults.$prefix}-button-hover-border-color,
123
- #{theme.get(primary, 900)}
162
+ #{color.$root-color}
124
163
  );
125
164
  $button-active-border-color: var(
126
165
  --#{root-defaults.$prefix}-button-active-border-color,
127
- #{theme.get(primary, 900)}
166
+ #{color.$root-color}
128
167
  );
129
168
  $button-disabled-border-color: var(
130
169
  --#{root-defaults.$prefix}-button-disabled-border-color,
@@ -1,7 +1,17 @@
1
- // Default values for Graupl.
1
+ // @graupl/graupl form base default values.
2
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.
3
+ // Generally, these should not be used directly when styling bases unless a static value is needed.
4
+ // They are mainly used to provide class selectors, fallbacks for custom properties, or loop values.
5
+ //
6
+ // They should not be used to define direct property values (i.e. font-size, color, etc.).
7
+ // Those should be defined as custom properties in the `_variables.scss` file.
8
+
9
+ // Form selectors.
10
+ $input-selector: "input" !default;
11
+ $textarea-selector: "textarea" !default;
12
+ $select-selector: "select" !default;
13
+ $label-selector: "label" !default;
14
+ $fieldset-selector: "fieldset" !default;
6
15
 
16
+ // Fieldset properties.
7
17
  $fieldset-direction: column !default;
@@ -1,15 +1,15 @@
1
- // Graupl form base styles.
1
+ // @gruapl/graupl form base styles.
2
2
 
3
+ @use "defaults";
3
4
  @use "variables" as *;
4
5
  @use "../../mixins/layer" as *;
5
6
 
6
7
  @include layer(base) {
7
- input,
8
- textarea,
9
- select {
8
+ #{defaults.$input-selector},
9
+ #{defaults.$textarea-selector},
10
+ #{defaults.$select-selector} {
10
11
  padding: $input-padding;
11
- border-width: $input-border-width;
12
- border-style: $input-border-style;
12
+ border: $input-border;
13
13
  border-radius: $input-border-radius;
14
14
  font-size: $input-font-size;
15
15
 
@@ -18,24 +18,23 @@
18
18
  }
19
19
  }
20
20
 
21
- label {
21
+ #{defaults.$label-selector} {
22
22
  font-size: $label-font-size;
23
23
  }
24
24
 
25
- fieldset {
25
+ #{defaults.$fieldset-selector} {
26
26
  display: flex;
27
27
  flex-flow: $fieldset-direction wrap;
28
28
  gap: $fieldset-gap;
29
29
  padding: $fieldset-padding;
30
- border-width: $fieldset-border-width;
31
- border-style: $fieldset-border-style;
30
+ border: $fieldset-border;
32
31
  border-radius: $fieldset-border-radius;
33
32
  font-size: $fieldset-font-size;
34
33
 
35
34
  &:disabled {
36
- input,
37
- textarea,
38
- select {
35
+ #{defaults.$input-selector},
36
+ #{defaults.$textarea-selector},
37
+ #{defaults.$select-selector} {
39
38
  cursor: not-allowed;
40
39
  }
41
40
  }
@@ -43,9 +42,9 @@
43
42
  }
44
43
 
45
44
  @include layer(theme) {
46
- input,
47
- textarea,
48
- select {
45
+ #{defaults.$input-selector},
46
+ #{defaults.$textarea-selector},
47
+ #{defaults.$select-selector} {
49
48
  border-color: $input-border-color;
50
49
  background: $input-background;
51
50
  color: $input-color;
@@ -65,15 +64,19 @@
65
64
  }
66
65
  }
67
66
 
68
- label {
67
+ #{defaults.$label-selector} {
69
68
  color: $label-color;
70
69
 
71
- &:has(+ input:disabled, + textarea:disabled, + select:disabled) {
70
+ &:has(
71
+ + #{defaults.$input-selector}:disabled,
72
+ + #{defaults.$textarea-selector}:disabled,
73
+ + #{defaults.$select-selector}:disabled
74
+ ) {
72
75
  color: $label-disabled-color;
73
76
  }
74
77
  }
75
78
 
76
- fieldset {
79
+ #{defaults.$fieldset-selector} {
77
80
  border-color: $fieldset-border-color;
78
81
  background: $fieldset-background;
79
82
  color: $fieldset-color;
@@ -82,7 +85,7 @@
82
85
  border-color: $fieldset-disabled-border-color;
83
86
  color: $fieldset-disabled-color;
84
87
 
85
- label {
88
+ #{defaults.$label-selector} {
86
89
  color: $label-disabled-color;
87
90
  }
88
91
  }
@@ -1,4 +1,7 @@
1
- // Variables referencing custom properties.
1
+ // @graupl/graupl form base variables.
2
+ //
3
+ // These values are to be used to directly style bases and provide a
4
+ // cleaner way to reference custom properties.
2
5
 
3
6
  @use "defaults";
4
7
  @use "../../variables" as root-variables;
@@ -103,6 +106,10 @@ $input-border-style: var(
103
106
  --#{root-defaults.$prefix}-botton-border-style,
104
107
  #{root-variables.$border-style}
105
108
  );
109
+ $input-border: var(
110
+ --#{root-defaults.$prefix}-input-border,
111
+ #{$input-border-width} #{$input-border-style}
112
+ );
106
113
  $input-border-radius: var(
107
114
  --#{root-defaults.$prefix}-input-border-radius,
108
115
  #{root-variables.$border-radius}
@@ -115,6 +122,10 @@ $fieldset-border-style: var(
115
122
  --#{root-defaults.$prefix}-fieldset-border-style,
116
123
  #{$input-border-style}
117
124
  );
125
+ $fieldset-border: var(
126
+ --#{root-defaults.$prefix}-fieldset-border,
127
+ #{$fieldset-border-width} #{$fieldset-border-style}
128
+ );
118
129
  $fieldset-border-radius: var(
119
130
  --#{root-defaults.$prefix}-fieldset-border-radius,
120
131
  #{$input-border-radius}
@@ -1,7 +1,50 @@
1
- // Default values for Graupl.
1
+ // @graupl/graupl link base default values.
2
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.
3
+ // Generally, these should not be used directly when styling bases unless a static value is needed.
4
+ // They are mainly used to provide class selectors, fallbacks for custom properties, or loop values.
5
+ //
6
+ // They should not be used to define direct property values (i.e. font-size, color, etc.).
7
+ // Those should be defined as custom properties in the `_variables.scss` file.
8
+
9
+ // Link selectors.
10
+ $link-selector: "a" !default;
11
+ $stretched-link-selector: ".stretched" !default;
12
+ $stretched-link-pseudo-selector: "before" !default;
13
+
14
+ // Link properties.
15
+ $link-text-decoration: underline !default;
16
+ $link-visited-text-decoration: $link-text-decoration !default;
17
+ $link-active-text-decoration: $link-text-decoration !default;
18
+ $link-hover-text-decoration: $link-text-decoration !default;
19
+ $link-focus-text-decoration: $link-text-decoration !default;
20
+ $link-disabled-text-decoration: $link-text-decoration !default;
21
+ $link-text-decoration-style: solid !default;
22
+ $link-visited-text-decoration-style: $link-text-decoration-style !default;
23
+ $link-active-text-decoration-style: $link-text-decoration-style !default;
24
+ $link-hover-text-decoration-style: $link-text-decoration-style !default;
25
+ $link-focus-text-decoration-style: $link-text-decoration-style !default;
26
+ $link-disabled-text-decoration-style: $link-text-decoration-style !default;
27
+ $link-transform: none !default;
28
+ $link-visited-transform: $link-transform !default;
29
+ $link-focus-transform: $link-transform !default;
30
+ $link-hover-transform: $link-transform !default;
31
+ $link-active-transform: $link-transform !default;
32
+ $link-disabled-transform: $link-transform !default;
33
+ $link-border-width: 0 !default;
34
+ $link-border-color: transparent !default;
35
+ $link-visited-border-color: $link-border-color !default;
36
+ $link-focus-border-color: $link-border-color !default;
37
+ $link-hover-border-color: $link-border-color !default;
38
+ $link-active-border-color: $link-border-color !default;
39
+ $link-disabled-border-color: $link-border-color !default;
40
+ $link-background: transparent !default;
41
+ $link-visited-background: $link-background !default;
42
+ $link-focus-background: $link-background !default;
43
+ $link-hover-background: $link-background !default;
44
+ $link-active-background: $link-background !default;
45
+ $link-disabled-background: $link-background !default;
46
+ $link-min-width: auto;
47
+ $link-min-height: auto;
6
48
 
7
- $link-text-decoration: underline;
49
+ // Stretched link properties.
50
+ $stretched-link-z-index: 5 !default;
@@ -1,50 +1,134 @@
1
- // Link base styles.
1
+ // @gruapl/graupl link base styles.
2
2
 
3
+ @use "defaults";
3
4
  @use "variables" as *;
4
5
  @use "../../defaults" as root-defaults;
5
6
  @use "../../mixins/layer" as *;
7
+ @use "../../mixins/media-queries" as *;
6
8
 
7
9
  @include layer(base) {
8
- a {
10
+ #{defaults.$link-selector} {
11
+ min-width: $link-min-width;
12
+ min-height: $link-min-height;
13
+ padding: $link-padding;
14
+ transform: $link-transform;
15
+ transition: $link-transition;
16
+ border: $link-border;
17
+ border-radius: $link-border-radius;
9
18
  text-decoration: $link-text-decoration;
19
+ text-decoration-style: $link-text-decoration-style;
10
20
  text-decoration-thickness: $link-text-decoration-thickness;
11
21
 
12
- &:disabled {
22
+ &:visited {
23
+ --#{root-defaults.$prefix}-link-text-decoration: #{$link-visited-text-decoration};
24
+ --#{root-defaults.$prefix}-link-text-decoration-thickness: #{$link-visited-text-decoration-thickness};
25
+ --#{root-defaults.$prefix}-link-text-decoration-style: #{$link-visited-text-decoration-style};
26
+ --#{root-defaults.$prefix}-link-transform: #{$link-visited-transform};
27
+ }
28
+
29
+ &:focus-visible {
30
+ --#{root-defaults.$prefix}-link-text-decoration: #{$link-focus-text-decoration};
31
+ --#{root-defaults.$prefix}-link-text-decoration-thickness: #{$link-focus-text-decoration-thickness};
32
+ --#{root-defaults.$prefix}-link-text-decoration-style: #{$link-focus-text-decoration-style};
33
+ --#{root-defaults.$prefix}-link-transform: #{$link-focus-transform};
34
+ }
35
+
36
+ &:hover {
37
+ --#{root-defaults.$prefix}-link-text-decoration: #{$link-hover-text-decoration};
38
+ --#{root-defaults.$prefix}-link-text-decoration-thickness: #{$link-hover-text-decoration-thickness};
39
+ --#{root-defaults.$prefix}-link-text-decoration-style: #{$link-hover-text-decoration-style};
40
+ --#{root-defaults.$prefix}-link-transform: #{$link-hover-transform};
41
+ }
42
+
43
+ &:active {
44
+ --#{root-defaults.$prefix}-link-text-decoration: #{$link-active-text-decoration};
45
+ --#{root-defaults.$prefix}-link-text-decoration-thickness: #{$link-active-text-decoration-thickness};
46
+ --#{root-defaults.$prefix}-link-text-decoration-style: #{$link-active-text-decoration-style};
47
+ --#{root-defaults.$prefix}-link-transform: #{$link-active-transform};
48
+ }
49
+
50
+ &:disabled,
51
+ &[disabled] {
13
52
  cursor: not-allowed;
53
+
54
+ &,
55
+ &:visited,
56
+ &:focus-visible,
57
+ &:hover,
58
+ &:active {
59
+ --#{root-defaults.$prefix}-link-text-decoration: #{$link-disabled-text-decoration};
60
+ --#{root-defaults.$prefix}-link-text-decoration-thickness: #{$link-disabled-text-decoration-thickness};
61
+ --#{root-defaults.$prefix}-link-text-decoration-style: #{$link-disabled-text-decoration-style};
62
+ --#{root-defaults.$prefix}-link-transform: #{$link-disabled-transform};
63
+ }
64
+ }
65
+
66
+ &#{defaults.$stretched-link-selector} {
67
+ isolation: isolate;
68
+
69
+ &::#{defaults.$stretched-link-pseudo-selector} {
70
+ content: "";
71
+ position: absolute;
72
+ inset: 0;
73
+ z-index: $stretched-link-z-index;
74
+ }
75
+ }
76
+ }
77
+
78
+ @include animation-off {
79
+ #{defaults.$link-selector} {
80
+ --#{root-defaults.$prefix}-link-transition: #{$link-transition-reduced-motion};
14
81
  }
15
82
  }
16
83
  }
17
84
 
18
85
  @include layer(theme) {
19
- a {
86
+ #{defaults.$link-selector} {
87
+ border-color: $link-border-color;
88
+ background: $link-background;
20
89
  color: $link-color;
90
+ text-decoration-color: $link-text-decoration-color;
91
+
92
+ &:visited {
93
+ --#{root-defaults.$prefix}-link-color: #{$link-visited-color};
94
+ --#{root-defaults.$prefix}-link-background: #{$link-visited-background};
95
+ --#{root-defaults.$prefix}-link-border-color: #{$link-visited-border-color};
96
+ --#{root-defaults.$prefix}-link-text-decoration-color: #{$link-visited-text-decoration-color};
97
+ }
98
+
99
+ &:focus-visible {
100
+ --#{root-defaults.$prefix}-link-color: #{$link-focus-color};
101
+ --#{root-defaults.$prefix}-link-background: #{$link-focus-background};
102
+ --#{root-defaults.$prefix}-link-border-color: #{$link-focus-border-color};
103
+ --#{root-defaults.$prefix}-link-text-decoration-color: #{$link-focus-text-decoration-color};
104
+ }
21
105
 
22
106
  &:hover {
23
107
  --#{root-defaults.$prefix}-link-color: #{$link-hover-color};
108
+ --#{root-defaults.$prefix}-link-background: #{$link-hover-background};
109
+ --#{root-defaults.$prefix}-link-border-color: #{$link-hover-border-color};
110
+ --#{root-defaults.$prefix}-link-text-decoration-color: #{$link-hover-text-decoration-color};
24
111
  }
25
112
 
26
113
  &:active {
27
114
  --#{root-defaults.$prefix}-link-color: #{$link-active-color};
115
+ --#{root-defaults.$prefix}-link-background: #{$link-active-background};
116
+ --#{root-defaults.$prefix}-link-border-color: #{$link-active-border-color};
117
+ --#{root-defaults.$prefix}-link-text-decoration-color: #{$link-active-text-decoration-color};
28
118
  }
29
119
 
30
- // stylelint-disable no-descending-specificity
31
- &:visited {
32
- &,
33
- &:hover {
34
- --#{root-defaults.$prefix}-link-color: #{$link-hover-color};
35
- }
36
- }
37
-
120
+ &:disabled,
38
121
  &[disabled] {
39
- pointer-events: none;
40
-
41
122
  &,
123
+ &:visited,
124
+ &:focus-visible,
42
125
  &:hover,
43
- &:active,
44
- &:visited {
126
+ &:active {
45
127
  --#{root-defaults.$prefix}-link-color: #{$link-disabled-color};
128
+ --#{root-defaults.$prefix}-link-background: #{$link-disabled-background};
129
+ --#{root-defaults.$prefix}-link-border-color: #{$link-disabled-border-color};
130
+ --#{root-defaults.$prefix}-link-text-decoration-color: #{$link-disabled-text-decoration-color};
46
131
  }
47
132
  }
48
- // stylelint-enable no-descending-specificity
49
133
  }
50
134
  }