@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,143 @@
1
+ // @gruapl/graupl card component styles.
2
+
3
+ @use "defaults";
4
+ @use "variables" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../mixins/layer" as *;
7
+ @use "../../mixins/media-queries" as *;
8
+
9
+ @include layer(component) {
10
+ #{defaults.$card-selector} {
11
+ display: grid;
12
+ position: relative;
13
+ grid-template-columns: 1fr;
14
+ grid-template-rows:
15
+ [image-start]
16
+ $card-image-ratio
17
+ [image-end content-start]
18
+ $card-content-ratio
19
+ [content-end];
20
+ padding: $card-padding;
21
+ transform: $card-transform;
22
+ transition: $card-transition;
23
+ border: $card-border;
24
+ border-radius: $card-border-radius;
25
+ gap: $card-gap;
26
+ isolation: isolate;
27
+
28
+ &:hover {
29
+ --#{root-defaults.$prefix}-card-transform: #{$card-hover-transform};
30
+ }
31
+
32
+ &#{defaults.$horizontal-card-selector} {
33
+ &,
34
+ &#{defaults.$horizontal-card-left-selector} {
35
+ --#{root-defaults.$prefix}-card-content-ratio: #{$horizontal-card-content-ratio};
36
+ --#{root-defaults.$prefix}-card-image-ratio: #{$horizontal-card-image-ratio};
37
+
38
+ grid-template-columns:
39
+ [image-start]
40
+ $card-image-ratio
41
+ [image-end content-start]
42
+ $card-content-ratio
43
+ [content-end];
44
+ grid-template-rows: 1fr;
45
+
46
+ #{defaults.$card-image-selector} img {
47
+ border-radius: calc($card-top-left-border-radius - $card-border-width)
48
+ 0 0 calc($card-bottom-left-border-radius - $card-border-width);
49
+ }
50
+ }
51
+
52
+ &#{defaults.$horizontal-card-right-selector} {
53
+ grid-template-columns:
54
+ [content-start]
55
+ $card-content-ratio
56
+ [content-end image-start]
57
+ $card-image-ratio
58
+ [image-end];
59
+
60
+ #{defaults.$card-image-selector} img {
61
+ border-radius: 0
62
+ calc($card-top-right-border-radius - $card-border-width)
63
+ calc($card-bottom-right-border-radius - $card-border-width) 0;
64
+ }
65
+ }
66
+ }
67
+ }
68
+
69
+ #{defaults.$card-image-selector} {
70
+ grid-area: image;
71
+ padding: $card-image-padding;
72
+
73
+ img {
74
+ width: 100%;
75
+ height: 100%;
76
+ border-radius: calc($card-top-left-border-radius - $card-border-width)
77
+ calc($card-top-right-border-radius - $card-border-width) 0 0;
78
+ object-fit: cover;
79
+ }
80
+ }
81
+
82
+ #{defaults.$card-content-selector} {
83
+ display: flex;
84
+ grid-area: content;
85
+ flex-direction: column;
86
+ padding: $card-content-padding;
87
+ gap: $card-content-gap;
88
+ }
89
+
90
+ #{defaults.$card-body-selector} {
91
+ flex: 1 0 auto;
92
+ }
93
+
94
+ #{defaults.$card-footer-selector} {
95
+ flex: 0 0 auto;
96
+ }
97
+
98
+ #{defaults.$card-title-selector} {
99
+ flex: 0 0 auto;
100
+ }
101
+
102
+ @include screen-trigger(force-vertical-card) {
103
+ #{defaults.$card-selector} {
104
+ &#{defaults.$horizontal-card-selector} {
105
+ &,
106
+ &#{defaults.$horizontal-card-left-selector},
107
+ &#{defaults.$horizontal-card-right-selector} {
108
+ --#{root-defaults.$prefix}-horizontal-card-image-ratio: #{defaults.$card-image-ratio};
109
+ --#{root-defaults.$prefix}-horizontal-card-content-ratio: #{defaults.$card-content-ratio};
110
+
111
+ grid-template-columns: 1fr;
112
+ grid-template-rows:
113
+ [image-start]
114
+ $card-image-ratio
115
+ [image-end content-start]
116
+ $card-content-ratio
117
+ [content-end];
118
+ }
119
+ }
120
+ }
121
+ }
122
+
123
+ @include animation-off {
124
+ #{defaults.$card-selector} {
125
+ --#{root-defaults.$prefix}-card-transition: #{$card-transition-reduced-motion};
126
+ }
127
+ }
128
+ }
129
+
130
+ @include layer(theme) {
131
+ #{defaults.$card-selector} {
132
+ border-color: $card-border-color;
133
+ background: $card-background;
134
+ color: $card-color;
135
+ }
136
+
137
+ #{defaults.$card-title-selector} {
138
+ color: $card-title-color;
139
+ font-size: $card-title-font-size;
140
+ font-weight: $card-title-font-weight;
141
+ line-height: $card-title-line-height;
142
+ }
143
+ }
@@ -0,0 +1,185 @@
1
+ // @graupl/graupl card component variables.
2
+ //
3
+ // These values are to be used to directly style components and provide a
4
+ // cleaner way to reference custom properties.
5
+
6
+ @use "defaults";
7
+ @use "../../defaults" as root-defaults;
8
+ @use "../../variables" as root-variables;
9
+ @use "../../theme/color/variables" as color;
10
+ @use "../../theme/typography/variables" as typography;
11
+ @use "sass:map";
12
+
13
+ // Card properties.
14
+ $card-padding-x: var(
15
+ --#{root-defaults.$prefix}-card-padding-x,
16
+ #{map.get(root-variables.$spacers, 0)}
17
+ );
18
+ $card-padding-y: var(
19
+ --#{root-defaults.$prefix}-card-padding-y,
20
+ #{map.get(root-variables.$spacers, 0)}
21
+ );
22
+ $card-padding: var(
23
+ --#{root-defaults.$prefix}-card-padding,
24
+ #{$card-padding-y} #{$card-padding-x}
25
+ );
26
+ $card-transition: var(
27
+ --#{root-defaults.$prefix}-card-transition,
28
+ transform #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function}
29
+ );
30
+ $card-transition-reduced-motion: var(
31
+ --#{root-defaults.$prefix}-card-transition-reduced-motion,
32
+ none
33
+ );
34
+
35
+ // Card transform properties.
36
+ $card-transform: var(
37
+ --#{root-defaults.$prefix}-card-transform,
38
+ #{defaults.$card-transform}
39
+ );
40
+ $card-hover-transform: var(
41
+ --#{root-defaults.$prefix}-card-hover-transform,
42
+ #{defaults.$card-hover-transform}
43
+ );
44
+
45
+ // Card gap properties.
46
+ $card-column-gap: var(
47
+ --#{root-defaults.$prefix}-card-column-gap,
48
+ #{map.get(root-variables.$spacers, 0)}
49
+ );
50
+ $card-row-gap: var(
51
+ --#{root-defaults.$prefix}-card-row-gap,
52
+ #{map.get(root-variables.$spacers, 0)}
53
+ );
54
+ $card-gap: var(
55
+ --#{root-defaults.$prefix}-card-gap,
56
+ #{$card-column-gap} #{$card-row-gap}
57
+ );
58
+
59
+ // Card color properties.
60
+ $card-background: var(
61
+ --#{root-defaults.$prefix}-card-background,
62
+ #{color.$root-background}
63
+ );
64
+ $card-color: var(--#{root-defaults.$prefix}-card-color, #{color.$root-color});
65
+
66
+ // Card border-properties.
67
+ $card-border-color: var(
68
+ --#{root-defaults.$prefix}-card-border-color,
69
+ #{$card-color}
70
+ );
71
+ $card-top-left-border-radius: var(
72
+ --#{root-defaults.$prefix}-card-top-left-border-radius,
73
+ #{root-variables.$border-radius}
74
+ );
75
+ $card-top-right-border-radius: var(
76
+ --#{root-defaults.$prefix}-card-top-right-border-radius,
77
+ #{root-variables.$border-radius}
78
+ );
79
+ $card-bottom-left-border-radius: var(
80
+ --#{root-defaults.$prefix}-card-bottom-left-border-radius,
81
+ #{root-variables.$border-radius}
82
+ );
83
+ $card-bottom-right-border-radius: var(
84
+ --#{root-defaults.$prefix}-card-bottom-right-border-radius,
85
+ #{root-variables.$border-radius}
86
+ );
87
+ $card-border-radius: var(
88
+ --#{root-defaults.$prefix}-card-border-radius,
89
+ #{$card-top-left-border-radius} #{$card-top-right-border-radius} #{$card-bottom-right-border-radius}
90
+ #{$card-bottom-left-border-radius}
91
+ );
92
+ $card-border-style: var(
93
+ --#{root-defaults.$prefix}-card-border-style,
94
+ #{root-variables.$border-style}
95
+ );
96
+ $card-border-width: var(
97
+ --#{root-defaults.$prefix}-card-border-width,
98
+ #{root-variables.$border-width}
99
+ );
100
+ $card-border: var(
101
+ --#{root-defaults.$prefix}-card-border,
102
+ #{$card-border-width} #{$card-border-style}
103
+ );
104
+
105
+ // Card layout properties.
106
+ $card-content-ratio: var(
107
+ --#{root-defaults.$prefix}-card-content-ratio,
108
+ defaults.$card-content-ratio
109
+ );
110
+ $card-image-ratio: var(
111
+ --#{root-defaults.$prefix}-card-image-ratio,
112
+ defaults.$card-image-ratio
113
+ );
114
+ $horizontal-card-content-ratio: var(
115
+ --#{root-defaults.$prefix}-horizontal-card-content-ratio,
116
+ defaults.$horizontal-card-content-ratio
117
+ );
118
+ $horizontal-card-image-ratio: var(
119
+ --#{root-defaults.$prefix}-horizontal-card-image-ratio,
120
+ defaults.$horizontal-card-image-ratio
121
+ );
122
+
123
+ // Card image properties.
124
+ $card-image-padding-x: var(
125
+ --#{root-defaults.$prefix}-card-image-padding-x,
126
+ #{map.get(root-variables.$spacers, 0)}
127
+ );
128
+ $card-image-padding-y: var(
129
+ --#{root-defaults.$prefix}-card-image-padding-y,
130
+ #{map.get(root-variables.$spacers, 0)}
131
+ );
132
+ $card-image-padding: var(
133
+ --#{root-defaults.$prefix}-card-image-padding,
134
+ #{$card-image-padding-y} #{$card-image-padding-x}
135
+ );
136
+
137
+ // Card content properties.
138
+ $card-content-padding-x: var(
139
+ --#{root-defaults.$prefix}-card-content-padding-x,
140
+ #{map.get(root-variables.$spacers, 5)}
141
+ );
142
+ $card-content-padding-y: var(
143
+ --#{root-defaults.$prefix}-card-content-padding-y,
144
+ #{map.get(root-variables.$spacers, 3)}
145
+ );
146
+ $card-content-padding: var(
147
+ --#{root-defaults.$prefix}-card-content-padding,
148
+ #{$card-content-padding-y} #{$card-content-padding-x}
149
+ );
150
+
151
+ // Card content gap properties.
152
+ $card-content-column-gap: var(
153
+ --#{root-defaults.$prefix}-card-content-column-gap,
154
+ #{map.get(root-variables.$spacers, 0)}
155
+ );
156
+ $card-content-row-gap: var(
157
+ --#{root-defaults.$prefix}-card-content-row-gap,
158
+ #{map.get(root-variables.$spacers, 3)}
159
+ );
160
+ $card-content-gap: var(
161
+ --#{root-defaults.$prefix}-card-content-gap,
162
+ #{$card-content-column-gap} #{$card-content-row-gap}
163
+ );
164
+
165
+ // Card title properties.
166
+ $card-title-color: var(
167
+ --#{root-defaults.$prefix}-card-title-color,
168
+ #{$card-color}
169
+ );
170
+ $card-title-font-size: var(
171
+ --#{root-defaults.$prefix}-card-title-font-size,
172
+ #{typography.$h4-font-size}
173
+ );
174
+ $card-title-font-weight: var(
175
+ --#{root-defaults.$prefix}-card-title-font-weight,
176
+ #{typography.$h4-font-weight}
177
+ );
178
+ $card-title-font-family: var(
179
+ --#{root-defaults.$prefix}-card-title-font-family,
180
+ #{typography.$h4-font-family}
181
+ );
182
+ $card-title-line-height: var(
183
+ --#{root-defaults.$prefix}-card-title-line-height,
184
+ #{typography.$h4-line-height}
185
+ );
@@ -1,8 +1,15 @@
1
- // Default values for Graupl.
1
+ // @graupl/graupl input group component 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 components unless a static value is needed.
4
+ // They are mainly used to provide class selectors, fallbacks for custom properties, or loop values.
5
+ //
6
+ // They should not be used to define direct property values (i.e. font-size, color, etc.).
7
+ // Those should be defined as custom properties in the `_variables.scss` file.
8
+
9
+ // Input group selectors.
10
+ $input-group-selector: ".input-group" !default;
11
+ $input-group-inline-selector: ".inline" !default;
12
+ $input-group-help-text-selector: ".help-text" !default;
6
13
 
7
14
  // Grid names.
8
15
  $input-group-grid-label-name: label !default;
@@ -1,12 +1,14 @@
1
- // Graupl Input group Component.
1
+ // @gruapl/graupl input group component styles.
2
2
 
3
+ @use "defaults";
4
+ @use "../../base/form/defaults" as form-defaults;
3
5
  @use "variables" as *;
4
6
  @use "../../mixins/layer" as *;
5
7
  @use "../../mixins/media-queries" as *;
6
8
 
7
9
  // stylelint-disable declaration-block-no-redundant-longhand-properties
8
10
  @include layer(component) {
9
- .input-group {
11
+ #{defaults.$input-group-selector} {
10
12
  display: grid;
11
13
  grid-template-areas: $input-group-grid-template-areas;
12
14
  grid-template-columns: $input-group-grid-template-columns;
@@ -14,21 +16,21 @@
14
16
  align-items: center;
15
17
  gap: $input-group-gap;
16
18
 
17
- label {
19
+ #{form-defaults.$label-selector} {
18
20
  grid-area: $input-group-label-grid-area;
19
21
  }
20
22
 
21
- input,
22
- textarea,
23
- select {
23
+ #{form-defaults.$input-selector},
24
+ #{form-defaults.$textarea-selector},
25
+ #{form-defaults.$select-selector} {
24
26
  grid-area: $input-group-input-grid-area;
25
27
  }
26
28
 
27
- .help-text {
29
+ #{defaults.$input-group-help-text-selector} {
28
30
  grid-area: $input-group-help-grid-area;
29
31
  }
30
32
 
31
- &.inline {
33
+ &#{defaults.$input-group-inline-selector} {
32
34
  grid-template-areas: $input-group-inline-grid-template-areas;
33
35
  grid-template-columns: $input-group-inline-grid-template-columns;
34
36
  grid-template-rows: $input-group-inline-grid-template-rows;
@@ -36,7 +38,7 @@
36
38
  }
37
39
 
38
40
  @include screen(xs) {
39
- .input-group.inline {
41
+ #{defaults.$input-group-selector}#{defaults.$input-group-inline-selector} {
40
42
  grid-template-areas: $input-group-grid-template-areas;
41
43
  grid-template-columns: $input-group-grid-template-columns;
42
44
  grid-template-rows: $input-group-grid-template-rows;
@@ -1,4 +1,7 @@
1
- // Variables referencing custom properties.
1
+ // @graupl/graupl input group component variables.
2
+ //
3
+ // These values are to be used to directly style components and provide a
4
+ // cleaner way to reference custom properties.
2
5
 
3
6
  @use "defaults";
4
7
  @use "../../defaults" as root-defaults;
@@ -0,0 +1,65 @@
1
+ // @graupl/graupl menu component default values.
2
+ //
3
+ // Generally, these should not be used directly when styling components unless a static value is needed.
4
+ // They are mainly used to provide class selectors, fallbacks for custom properties, or loop values.
5
+ //
6
+ // They should not be used to define direct property values (i.e. font-size, color, etc.).
7
+ // Those should be defined as custom properties in the `_variables.scss` file.
8
+
9
+ // Menu selectors.
10
+ $menu-selector: ".menu" !default;
11
+ $submenu-selector: ".submenu" !default;
12
+ $menu-item-selector: ".menu-item" !default;
13
+ $menu-link-selector: ".menu-link" !default;
14
+ $submenu-toggle-selector: ".submenu-toggle" !default;
15
+ $menu-show-selector: ".show" !default;
16
+ $menu-hide-selector: ".hide" !default;
17
+
18
+ // Flex properties.
19
+ $menu-flex-direction: row !default;
20
+ $submenu-flex-direction: column !default;
21
+
22
+ // Visibility properties.
23
+ $menu-show-display: flex !default;
24
+ $menu-hide-display: none !default;
25
+ $submenu-show-display: $menu-show-display !default;
26
+ $submenu-hide-display: $menu-hide-display !default;
27
+
28
+ // Menu item properties.
29
+ $menu-item-min-width: max-content !default;
30
+
31
+ // Submenu properties.
32
+ $submenu-position: absolute !default;
33
+ $submenu-z-index: 2 !default;
34
+ $submenu-top: 100% !default;
35
+ $submenu-right: auto !default;
36
+ $submenu-bottom: auto !default;
37
+ $submenu-left: 0 !default;
38
+
39
+ // Submenu item properties.
40
+ $submenu-item-width: 100% !default;
41
+
42
+ // Menu link properties.
43
+ $menu-link-text-decoration: none !default;
44
+ $menu-link-visited-text-decoration: $menu-link-text-decoration !default;
45
+ $menu-link-focus-text-decoration: $menu-link-text-decoration !default;
46
+ $menu-link-hover-text-decoration: $menu-link-text-decoration !default;
47
+ $menu-link-active-text-decoration: $menu-link-text-decoration !default;
48
+ $menu-link-disabled-text-decoration: $menu-link-text-decoration !default;
49
+ $menu-link-text-decoration-style: solid !default;
50
+ $menu-link-visited-text-decoration-style: $menu-link-text-decoration-style !default;
51
+ $menu-link-focus-text-decoration-style: $menu-link-text-decoration-style !default;
52
+ $menu-link-hover-text-decoration-style: $menu-link-text-decoration-style !default;
53
+ $menu-link-active-text-decoration-style: $menu-link-text-decoration-style !default;
54
+ $menu-link-disabled-text-decoration-style: $menu-link-text-decoration-style !default;
55
+ $menu-link-transform: none !default;
56
+ $menu-link-visited-transform: $menu-link-transform !default;
57
+ $menu-link-focus-transform: $menu-link-transform !default;
58
+ $menu-link-hover-transform: $menu-link-transform !default;
59
+ $menu-link-active-transform: $menu-link-transform !default;
60
+ $menu-link-disabled-transform: $menu-link-transform !default;
61
+ $menu-border-width: 0 !default;
62
+ $menu-link-border-width: 0 !default;
63
+ $submenu-toggle-transform: rotate(0deg) !default;
64
+ $submenu-toggle-open-transform: rotate(-180deg) !default;
65
+ $submenu-toggle-content: "'▼'" !default;