@graupl/graupl 1.0.0-alpha.5 → 1.0.0-alpha.7

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 (150) hide show
  1. package/CHANGELOG.md +56 -0
  2. package/dist/base/form.css +2 -0
  3. package/dist/base/form.css.map +1 -0
  4. package/dist/base/link.css.map +1 -0
  5. package/dist/base/table.css +2 -0
  6. package/dist/base/table.css.map +1 -0
  7. package/dist/base.css +2 -0
  8. package/dist/base.css.map +1 -0
  9. package/dist/component/button.css +2 -0
  10. package/dist/component/button.css.map +1 -0
  11. package/dist/component/input-group.css +2 -0
  12. package/dist/component/input-group.css.map +1 -0
  13. package/dist/component/table.css +2 -0
  14. package/dist/component/table.css.map +1 -0
  15. package/dist/component.css +2 -0
  16. package/dist/component.css.map +1 -0
  17. package/dist/graupl.css +1 -1
  18. package/dist/graupl.css.map +1 -1
  19. package/dist/layout/columns.css +2 -0
  20. package/dist/layout/columns.css.map +1 -0
  21. package/dist/layout/container.css +2 -0
  22. package/dist/layout/container.css.map +1 -0
  23. package/dist/layout.css +2 -0
  24. package/dist/layout.css.map +1 -0
  25. package/dist/state/focus.css.map +1 -0
  26. package/dist/state.css +2 -0
  27. package/dist/state.css.map +1 -0
  28. package/dist/theme/color.css +2 -0
  29. package/dist/theme/color.css.map +1 -0
  30. package/dist/theme/typography.css +2 -0
  31. package/dist/theme/typography.css.map +1 -0
  32. package/dist/theme.css +2 -0
  33. package/dist/theme.css.map +1 -0
  34. package/dist/utilities/colors.css.map +1 -0
  35. package/dist/utilities/spacing.css +2 -0
  36. package/dist/utilities/spacing.css.map +1 -0
  37. package/dist/utilities/typography.css +2 -0
  38. package/dist/utilities/typography.css.map +1 -0
  39. package/dist/utilities.css +2 -0
  40. package/dist/utilities.css.map +1 -0
  41. package/docs/.vitepress/theme/custom.scss +1 -1
  42. package/index.html +327 -75
  43. package/package.json +34 -18
  44. package/scss/base/form.scss +3 -0
  45. package/scss/base/link.scss +3 -0
  46. package/scss/base/table.scss +3 -0
  47. package/scss/base.scss +3 -0
  48. package/scss/component/button.scss +3 -0
  49. package/scss/component/input-group.scss +3 -0
  50. package/scss/component/table.scss +3 -0
  51. package/scss/component.scss +3 -0
  52. package/scss/graupl.scss +1 -1
  53. package/scss/layout/columns.scss +3 -0
  54. package/scss/layout/container.scss +3 -0
  55. package/scss/layout.scss +3 -0
  56. package/scss/state/focus.scss +3 -0
  57. package/scss/state.scss +3 -0
  58. package/scss/theme/color.scss +3 -0
  59. package/scss/theme/typography.scss +3 -0
  60. package/scss/theme.scss +3 -0
  61. package/scss/utilities/colors.scss +3 -0
  62. package/scss/utilities/spacing.scss +3 -0
  63. package/scss/utilities/typography.scss +3 -0
  64. package/scss/utilities.scss +3 -0
  65. package/{scss → src/scss}/_defaults.scss +35 -9
  66. package/{scss → src/scss}/_variables.scss +10 -20
  67. package/{scss → src/scss}/base/_index.scss +1 -0
  68. package/{scss → src/scss}/base/form/_variables.scss +5 -4
  69. package/src/scss/base/table/_defaults.scss +8 -0
  70. package/src/scss/base/table/_index.scss +27 -0
  71. package/src/scss/base/table/_variables.scss +65 -0
  72. package/{scss → src/scss}/component/_index.scss +2 -0
  73. package/{scss → src/scss}/component/button/_index.scss +6 -2
  74. package/{scss → src/scss}/component/button/_variables.scss +4 -3
  75. package/src/scss/component/input-group/_defaults.scss +23 -0
  76. package/src/scss/component/input-group/_index.scss +45 -0
  77. package/src/scss/component/input-group/_variables.scss +63 -0
  78. package/src/scss/component/table/_index.scss +106 -0
  79. package/src/scss/component/table/_variables.scss +64 -0
  80. package/src/scss/functions/_theme.scss +18 -0
  81. package/{scss → src/scss}/layout/columns/_defaults.scss +1 -2
  82. package/{scss → src/scss}/layout/columns/_index.scss +4 -6
  83. package/src/scss/layout/columns/_variables.scss +47 -0
  84. package/src/scss/layout/container/_index.scss +36 -0
  85. package/{scss → src/scss}/layout/container/_variables.scss +18 -1
  86. package/src/scss/mixins/_media-queries.scss +43 -0
  87. package/src/scss/theme/_index.scss +4 -0
  88. package/{scss/theme → src/scss/theme/color}/_defaults.scss +0 -13
  89. package/{scss/theme → src/scss/theme/color}/_index.scss +6 -8
  90. package/{scss/theme → src/scss/theme/color}/_variables.scss +5 -15
  91. package/src/scss/theme/typography/_defaults.scss +52 -0
  92. package/src/scss/theme/typography/_index.scss +111 -0
  93. package/src/scss/theme/typography/_variables.scss +227 -0
  94. package/src/scss/utilities/_index.scss +5 -0
  95. package/src/scss/utilities/colors/_defaults.scss +5 -0
  96. package/{scss → src/scss}/utilities/colors/_index.scss +2 -2
  97. package/src/scss/utilities/spacing/_defaults.scss +44 -0
  98. package/src/scss/utilities/spacing/_index.scss +64 -0
  99. package/src/scss/utilities/spacing/_variables.scss +3 -0
  100. package/src/scss/utilities/typography/_defaults.scss +5 -0
  101. package/src/scss/utilities/typography/_index.scss +92 -0
  102. package/src/scss/utilities/typography/_variables.scss +3 -0
  103. package/stylelint.config.js +2 -0
  104. package/dist/base/form/form.css +0 -2
  105. package/dist/base/form/form.css.map +0 -1
  106. package/dist/base/link/link.css.map +0 -1
  107. package/dist/component/button/button.css +0 -2
  108. package/dist/component/button/button.css.map +0 -1
  109. package/dist/layout/columns/columns.css +0 -2
  110. package/dist/layout/columns/columns.css.map +0 -1
  111. package/dist/layout/container/container.css +0 -2
  112. package/dist/layout/container/container.css.map +0 -1
  113. package/dist/state/focus/focus.css.map +0 -1
  114. package/dist/theme/theme.css +0 -2
  115. package/dist/theme/theme.css.map +0 -1
  116. package/dist/utilities/colors/colors.css.map +0 -1
  117. package/scss/base/form/form.scss +0 -3
  118. package/scss/base/link/link.scss +0 -3
  119. package/scss/component/button/button.scss +0 -3
  120. package/scss/functions/_theme.scss +0 -11
  121. package/scss/layout/columns/_variables.scss +0 -33
  122. package/scss/layout/columns/columns.scss +0 -3
  123. package/scss/layout/container/_index.scss +0 -54
  124. package/scss/layout/container/container.scss +0 -3
  125. package/scss/mixins/_media-queries.scss +0 -15
  126. package/scss/state/focus/focus.scss +0 -3
  127. package/scss/theme/theme.scss +0 -3
  128. package/scss/utilities/_index.scss +0 -3
  129. package/scss/utilities/colors/colors.scss +0 -3
  130. /package/dist/base/{link/link.css → link.css} +0 -0
  131. /package/dist/state/{focus/focus.css → focus.css} +0 -0
  132. /package/dist/utilities/{colors/colors.css → colors.css} +0 -0
  133. /package/{scss → src/scss}/_index.scss +0 -0
  134. /package/{scss → src/scss}/_init.scss +0 -0
  135. /package/{scss → src/scss}/base/form/_defaults.scss +0 -0
  136. /package/{scss → src/scss}/base/form/_index.scss +0 -0
  137. /package/{scss → src/scss}/base/link/_defaults.scss +0 -0
  138. /package/{scss → src/scss}/base/link/_index.scss +0 -0
  139. /package/{scss → src/scss}/base/link/_variables.scss +0 -0
  140. /package/{scss → src/scss}/component/button/_defaults.scss +0 -0
  141. /package/{scss/utilities/colors → src/scss/component/table}/_defaults.scss +0 -0
  142. /package/{scss → src/scss}/functions/_important.scss +0 -0
  143. /package/{scss → src/scss}/layout/_index.scss +0 -0
  144. /package/{scss → src/scss}/layout/container/_defaults.scss +0 -0
  145. /package/{scss → src/scss}/mixins/_layer.scss +0 -0
  146. /package/{scss → src/scss}/state/_index.scss +0 -0
  147. /package/{scss → src/scss}/state/focus/_defaults.scss +0 -0
  148. /package/{scss → src/scss}/state/focus/_index.scss +0 -0
  149. /package/{scss → src/scss}/state/focus/_variables.scss +0 -0
  150. /package/{scss → src/scss}/utilities/colors/_variables.scss +0 -0
@@ -4,6 +4,8 @@
4
4
  // They are mainly used to provide default fallbacks for custom properties
5
5
  // which can be found in the `variables.scss` file.
6
6
 
7
+ @use "sass:map";
8
+
7
9
  // Prefix for custom properties and other naming conventions.
8
10
  $prefix: "graupl" !default;
9
11
 
@@ -13,8 +15,40 @@ $use-important: true !default;
13
15
  // Layout properties.
14
16
  $content-max-width: 96ch !default;
15
17
 
18
+ // Screen sizes.
19
+ $base-screen-sizes: (
20
+ xs: 0,
21
+ sm: 469px,
22
+ md: 768px,
23
+ lg: 1024px,
24
+ xl: 1280px,
25
+ hd: 1920px,
26
+ qhd: 2560px,
27
+ uhd: 3840px,
28
+ ) !default;
29
+ $custom-screen-sizes: () !default;
30
+ $screen-sizes: map.merge($base-screen-sizes, $custom-screen-sizes) !default;
31
+
16
32
  // Spacing properties.
17
- $gap: 1rem !default;
33
+ $spacer: 1rem !default;
34
+ $base-spacer-multipliers: (
35
+ 0: 0,
36
+ 1: 0.125,
37
+ 2: 0.25,
38
+ 3: 0.5,
39
+ 4: 0.75,
40
+ 5: 1,
41
+ 6: 1.5,
42
+ 7: 2,
43
+ 8: 3,
44
+ 9: 5,
45
+ 10: 10,
46
+ ) !default;
47
+ $custom-spacer-multipliers: () !default;
48
+ $spacer-multipliers: map.merge(
49
+ $base-spacer-multipliers,
50
+ $custom-spacer-multipliers
51
+ ) !default;
18
52
 
19
53
  // Size properties.
20
54
  $interactive-min-width: 44px !default;
@@ -25,14 +59,6 @@ $border-radius: 0.125rem !default;
25
59
  $border-width: 2px !default;
26
60
  $border-style: solid !default;
27
61
 
28
- // Font properties.
29
- $font-size-base: 1rem !default;
30
- $font-size: (
31
- small: $font-size-base * 0.875,
32
- default: $font-size-base,
33
- large: $font-size-base * 1.125,
34
- ) !default;
35
-
36
62
  // Transition properties.
37
63
  $transition-duration-base: 100;
38
64
  $transition-duration: (
@@ -10,7 +10,16 @@ $content-max-width: var(
10
10
  );
11
11
 
12
12
  // Spacing properties.
13
- $gap: var(--#{defaults.$prefix}-gap, defaults.$gap);
13
+ $spacer: var(--#{defaults.$prefix}-spacer, defaults.$spacer);
14
+ $spacers: ();
15
+
16
+ @each $key, $value in defaults.$spacer-multipliers {
17
+ $space: var(
18
+ --#{defaults.$prefix}-spacer-#{$key},
19
+ calc(#{$value} * #{$spacer})
20
+ );
21
+ $spacers: map.set($spacers, $key, $space);
22
+ }
14
23
 
15
24
  // Border properties.
16
25
  $border-radius: var(
@@ -20,25 +29,6 @@ $border-radius: var(
20
29
  $border-width: var(--#{defaults.$prefix}-border-width, defaults.$border-width);
21
30
  $border-style: var(--#{defaults.$prefix}-border-style, defaults.$border-style);
22
31
 
23
- // Font properties.
24
- $font-size: (
25
- small:
26
- var(
27
- --#{defaults.$prefix}-font-size-small,
28
- map.get(defaults.$font-size, small)
29
- ),
30
- default:
31
- var(
32
- --#{defaults.$prefix}-font-size-default,
33
- map.get(defaults.$font-size, default)
34
- ),
35
- large:
36
- var(
37
- --#{defaults.$prefix}-font-size-large,
38
- map.get(defaults.$font-size, large)
39
- ),
40
- );
41
-
42
32
  // Transition properties.
43
33
  $transition-duration: (
44
34
  fast:
@@ -2,3 +2,4 @@
2
2
 
3
3
  @forward "form";
4
4
  @forward "link";
5
+ @forward "table";
@@ -3,16 +3,17 @@
3
3
  @use "defaults";
4
4
  @use "../../variables" as root-variables;
5
5
  @use "../../defaults" as root-defaults;
6
+ @use "../../theme/typography/variables" as typography;
6
7
  @use "../../functions/theme";
7
8
  @use "sass:map";
8
9
 
9
10
  $input-padding-x: var(
10
11
  --#{root-defaults.$prefix}-input-padding-x,
11
- #{root-variables.$gap}
12
+ #{map.get(root-variables.$spacers, 5)}
12
13
  );
13
14
  $input-padding-y: var(
14
15
  --#{root-defaults.$prefix}-input-padding-y,
15
- calc(#{root-variables.$gap} / 2)
16
+ #{map.get(root-variables.$spacers, 3)}
16
17
  );
17
18
  $input-padding: var(
18
19
  --#{root-defaults.$prefix}-input-padding,
@@ -20,7 +21,7 @@ $input-padding: var(
20
21
  );
21
22
  $input-font-size: var(
22
23
  --#{root-defaults.$prefix}-input-font-size,
23
- #{map.get(root-variables.$font-size, default)}
24
+ #{map.get(typography.$font-sizes, base)}
24
25
  );
25
26
  $label-font-size: var(
26
27
  --#{root-defaults.$prefix}-label-font-size,
@@ -32,7 +33,7 @@ $fieldset-direction: var(
32
33
  );
33
34
  $fieldset-gap: var(
34
35
  --#{root-defaults.$prefix}-fieldset-gap,
35
- calc(#{root-variables.$gap} / 4)
36
+ map.get(root-variables.$spacers, 2)
36
37
  );
37
38
  $fieldset-padding-x: var(
38
39
  --#{root-defaults.$prefix}-fieldset-padding-x,
@@ -0,0 +1,8 @@
1
+ // Default values for Graupl.
2
+ //
3
+ // Generally, these should not be used directly when styling components.
4
+ // They are mainly used to provide default fallbacks for custom properties
5
+ // which can be found in the `variables.scss` file.
6
+
7
+ // Table properties.
8
+ $caption-side: bottom !default;
@@ -0,0 +1,27 @@
1
+ // Table base styles.
2
+
3
+ @use "variables" as *;
4
+ @use "../../mixins/layer" as *;
5
+
6
+ @include layer(base) {
7
+ table {
8
+ caption {
9
+ padding: $table-caption-padding;
10
+ caption-side: $table-caption-side;
11
+ }
12
+
13
+ th {
14
+ padding: $table-header-padding;
15
+ background: $table-header-background;
16
+ color: $table-header-color;
17
+ font-weight: $table-header-font-weight;
18
+ }
19
+
20
+ td,
21
+ tbody th {
22
+ padding: $table-cell-padding;
23
+ background: $table-cell-background;
24
+ color: $table-cell-color;
25
+ }
26
+ }
27
+ }
@@ -0,0 +1,65 @@
1
+ // Variables referencing custom properties.
2
+
3
+ @use "defaults";
4
+ @use "../../defaults" as root-defaults;
5
+ @use "../../variables" as root-variables;
6
+ @use "../../theme/typography/variables" as typography;
7
+ @use "../../functions/theme" as theme;
8
+ @use "sass:map";
9
+
10
+ // Table caption properties.
11
+ $table-caption-side: var(
12
+ --#{root-defaults.$prefix}-table-caption-side,
13
+ #{defaults.$caption-side}
14
+ ) !default;
15
+ $table-caption-padding-x: var(
16
+ --#{root-defaults.$prefix}-table-caption-padding-x,
17
+ #{map.get(root-variables.$spacers, 3)}
18
+ ) !default;
19
+ $table-caption-padding-y: var(
20
+ --#{root-defaults.$prefix}-table-caption-padding-y,
21
+ #{map.get(root-variables.$spacers, 3)}
22
+ ) !default;
23
+ $table-caption-padding: $table-caption-padding-y $table-caption-padding-x;
24
+
25
+ // Table header properties.
26
+ $table-header-font-weight: var(
27
+ --#{root-defaults.$prefix}-table-header-font-weight,
28
+ #{typography.$font-weight-bold}
29
+ ) !default;
30
+ $table-header-padding-x: var(
31
+ --#{root-defaults.$prefix}-table-header-padding-x,
32
+ #{map.get(root-variables.$spacers, 3)}
33
+ ) !default;
34
+ $table-header-padding-y: var(
35
+ --#{root-defaults.$prefix}-table-header-padding-y,
36
+ #{map.get(root-variables.$spacers, 3)}
37
+ ) !default;
38
+ $table-header-padding: $table-header-padding-y $table-header-padding-x;
39
+ $table-header-background: var(
40
+ --#{root-defaults.$prefix}-table-header-background,
41
+ #{theme.get(primary, 100)}
42
+ );
43
+ $table-header-color: var(
44
+ --#{root-defaults.$prefix}-table-header-color,
45
+ #{theme.get(primary, 900)}
46
+ );
47
+
48
+ // Table cell properties.
49
+ $table-cell-padding-x: var(
50
+ --#{root-defaults.$prefix}-table-cell-padding-x,
51
+ #{map.get(root-variables.$spacers, 3)}
52
+ ) !default;
53
+ $table-cell-padding-y: var(
54
+ --#{root-defaults.$prefix}-table-cell-padding-y,
55
+ #{map.get(root-variables.$spacers, 3)}
56
+ ) !default;
57
+ $table-cell-padding: $table-cell-padding-y $table-cell-padding-x;
58
+ $table-cell-background: var(
59
+ --#{root-defaults.$prefix}-table-cell-background,
60
+ #{theme.get(primary, 100)}
61
+ );
62
+ $table-cell-color: var(
63
+ --#{root-defaults.$prefix}-table-cell-color,
64
+ #{theme.get(primary, 900)}
65
+ );
@@ -1,3 +1,5 @@
1
1
  // Graupl components.
2
2
 
3
3
  @forward "button";
4
+ @forward "input-group";
5
+ @forward "table";
@@ -1,7 +1,7 @@
1
1
  // Graupl Button Component.
2
2
 
3
3
  @use "../../defaults" as root-defaults;
4
- @use "../../theme/variables" as theme;
4
+ @use "../../theme/color/variables" as color;
5
5
  @use "variables" as *;
6
6
  @use "../../mixins/layer" as *;
7
7
  @use "../../mixins/media-queries" as *;
@@ -86,8 +86,12 @@
86
86
  }
87
87
  }
88
88
 
89
- @each $color, $map in theme.$theme-active {
89
+ @each $color, $map in color.$theme-active {
90
90
  &.#{$color} {
91
+ --#{root-defaults.$prefix}-button-color: #{map.get($map, 900)};
92
+ --#{root-defaults.$prefix}-button-hover-color: #{map.get($map, 100)};
93
+ --#{root-defaults.$prefix}-button-active-color: #{map.get($map, 100)};
94
+ --#{root-defaults.$prefix}-button-disabled-color: #{map.get($map, 200)};
91
95
  --#{root-defaults.$prefix}-button-hover-background: #{map.get(
92
96
  $map,
93
97
  700
@@ -3,6 +3,7 @@
3
3
  @use "defaults";
4
4
  @use "../../variables" as root-variables;
5
5
  @use "../../defaults" as root-defaults;
6
+ @use "../../theme/typography/variables" as typography;
6
7
  @use "../../functions/theme";
7
8
  @use "sass:map";
8
9
 
@@ -17,11 +18,11 @@ $button-min-height: var(
17
18
  );
18
19
  $button-padding-x: var(
19
20
  --#{root-defaults.$prefix}-button-padding-x,
20
- #{root-variables.$gap}
21
+ #{map.get(root-variables.$spacers, 5)}
21
22
  );
22
23
  $button-padding-y: var(
23
24
  --#{root-defaults.$prefix}-button-padding-y,
24
- calc(#{root-variables.$gap} / 2)
25
+ #{map.get(root-variables.$spacers, 3)}
25
26
  );
26
27
  $button-padding: var(
27
28
  --#{root-defaults.$prefix}-button-padding,
@@ -29,7 +30,7 @@ $button-padding: var(
29
30
  );
30
31
  $button-font-size: var(
31
32
  --#{root-defaults.$prefix}-button-font-size,
32
- #{map.get(root-variables.$font-size, default)}
33
+ #{map.get(typography.$font-sizes, base)}
33
34
  );
34
35
  $button-transition: var(
35
36
  --#{root-defaults.$prefix}-button-transition,
@@ -0,0 +1,23 @@
1
+ // Default values for Graupl.
2
+ //
3
+ // Generally, these should not be used directly when styling components.
4
+ // They are mainly used to provide default fallbacks for custom properties
5
+ // which can be found in the `variables.scss` file.
6
+
7
+ // Grid names.
8
+ $input-group-grid-label-name: label !default;
9
+ $input-group-grid-input-name: input !default;
10
+ $input-group-grid-help-name: help !default;
11
+
12
+ // Input group properties.
13
+ $input-group-grid-template-columns: 100% !default;
14
+ $input-group-grid-template-rows: auto auto auto !default;
15
+
16
+ // Inline input group properties.
17
+ $input-group-inline-grid-template-columns: auto 1fr !default;
18
+ $input-group-inline-grid-template-rows: auto auto !default;
19
+
20
+ // Inner element properties.
21
+ $input-group-label-grid-area: $input-group-grid-label-name !default;
22
+ $input-group-input-grid-area: $input-group-grid-input-name !default;
23
+ $input-group-help-grid-area: $input-group-grid-help-name !default;
@@ -0,0 +1,45 @@
1
+ // Graupl Input group Component.
2
+
3
+ @use "variables" as *;
4
+ @use "../../mixins/layer" as *;
5
+ @use "../../mixins/media-queries" as *;
6
+
7
+ // stylelint-disable declaration-block-no-redundant-longhand-properties
8
+ @include layer(component) {
9
+ .input-group {
10
+ display: grid;
11
+ grid-template-areas: $input-group-grid-template-areas;
12
+ grid-template-columns: $input-group-grid-template-columns;
13
+ grid-template-rows: $input-group-grid-template-rows;
14
+ align-items: center;
15
+ gap: $input-group-gap;
16
+
17
+ label {
18
+ grid-area: $input-group-label-grid-area;
19
+ }
20
+
21
+ input,
22
+ textarea,
23
+ select {
24
+ grid-area: $input-group-input-grid-area;
25
+ }
26
+
27
+ .help-text {
28
+ grid-area: $input-group-help-grid-area;
29
+ }
30
+
31
+ &.inline {
32
+ grid-template-areas: $input-group-inline-grid-template-areas;
33
+ grid-template-columns: $input-group-inline-grid-template-columns;
34
+ grid-template-rows: $input-group-inline-grid-template-rows;
35
+ }
36
+ }
37
+
38
+ @include screen-under(sm) {
39
+ .input-group.inline {
40
+ grid-template-areas: $input-group-grid-template-areas;
41
+ grid-template-columns: $input-group-grid-template-columns;
42
+ grid-template-rows: $input-group-grid-template-rows;
43
+ }
44
+ }
45
+ }
@@ -0,0 +1,63 @@
1
+ // Variables referencing custom properties.
2
+
3
+ @use "defaults";
4
+ @use "../../defaults" as root-defaults;
5
+ @use "../../variables" as root-variables;
6
+ @use "sass:map";
7
+
8
+ // Input group properties.
9
+ $input-group-grid-template-areas: var(
10
+ --#{root-defaults.$prefix}-input-group-grid-template-areas,
11
+ "#{defaults.$input-group-grid-label-name}"
12
+ "#{defaults.$input-group-grid-input-name}"
13
+ "#{defaults.$input-group-grid-help-name}"
14
+ );
15
+ $input-group-grid-template-columns: var(
16
+ --#{root-defaults.$prefix}-input-group-grid-template-columns,
17
+ #{defaults.$input-group-grid-template-columns}
18
+ );
19
+ $input-group-grid-template-rows: var(
20
+ --#{root-defaults.$prefix}-input-group-grid-template-rows,
21
+ #{defaults.$input-group-grid-template-rows}
22
+ );
23
+ $input-group-row-gap: var(
24
+ --#{root-defaults.$prefix}-input-group-row-gap,
25
+ #{map.get(root-variables.$spacers, 2)}
26
+ );
27
+ $input-group-column-gap: var(
28
+ --#{root-defaults.$prefix}-input-group-column-gap,
29
+ #{map.get(root-variables.$spacers, 3)}
30
+ );
31
+ $input-group-gap: var(
32
+ --#{root-defaults.$prefix}-input-group-gap,
33
+ #{$input-group-row-gap} #{$input-group-column-gap}
34
+ );
35
+
36
+ // Inline input group properties.
37
+ $input-group-inline-grid-template-areas: var(
38
+ --#{root-defaults.$prefix}-input-group-inline-grid-template-areas,
39
+ "#{defaults.$input-group-grid-label-name} #{defaults.$input-group-grid-input-name}"
40
+ "- #{defaults.$input-group-grid-help-name}"
41
+ );
42
+ $input-group-inline-grid-template-columns: var(
43
+ --#{root-defaults.$prefix}-input-group-inline-grid-template-columns,
44
+ #{defaults.$input-group-inline-grid-template-columns}
45
+ );
46
+ $input-group-inline-grid-template-rows: var(
47
+ --#{root-defaults.$prefix}-input-group-inline-grid-template-rows,
48
+ #{defaults.$input-group-inline-grid-template-rows}
49
+ );
50
+
51
+ // Inner element properties.
52
+ $input-group-label-grid-area: var(
53
+ --#{root-defaults.$prefix}-input-group-label-grid-area,
54
+ #{defaults.$input-group-label-grid-area}
55
+ );
56
+ $input-group-input-grid-area: var(
57
+ --#{root-defaults.$prefix}-input-group-input-grid-area,
58
+ #{defaults.$input-group-input-grid-area}
59
+ );
60
+ $input-group-help-grid-area: var(
61
+ --#{root-defaults.$prefix}-input-group-help-grid-area,
62
+ #{defaults.$input-group-help-grid-area}
63
+ );
@@ -0,0 +1,106 @@
1
+ // Table component styles.
2
+
3
+ @use "variables" as *;
4
+ @use "../../mixins/layer" as *;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../functions/theme";
7
+
8
+ @include layer(component) {
9
+ table {
10
+ @each $variant in theme.variants() {
11
+ &.#{$variant},
12
+ .#{$variant} {
13
+ --#{root-defaults.$prefix}-table-header-background: #{theme.get(
14
+ $variant,
15
+ 700
16
+ )};
17
+ --#{root-defaults.$prefix}-table-header-color: #{theme.get(
18
+ $variant,
19
+ 100
20
+ )};
21
+ --#{root-defaults.$prefix}-table-striped-background: #{theme.get(
22
+ $variant,
23
+ 200
24
+ )};
25
+ --#{root-defaults.$prefix}-table-striped-color: #{theme.get(
26
+ $variant,
27
+ 900
28
+ )};
29
+ --#{root-defaults.$prefix}-table-hover-background: #{theme.get(
30
+ $variant,
31
+ 300
32
+ )};
33
+ --#{root-defaults.$prefix}-table-hover-color: #{theme.get(
34
+ $variant,
35
+ 900
36
+ )};
37
+ --#{root-defaults.$prefix}-table-border-color: #{theme.get(
38
+ $variant,
39
+ 900
40
+ )};
41
+ --#{root-defaults.$prefix}-table-highlight-background: #{theme.get(
42
+ $variant,
43
+ 500
44
+ )};
45
+ --#{root-defaults.$prefix}-table-highlight-color: #{theme.get(
46
+ $variant,
47
+ 100
48
+ )};
49
+ }
50
+ }
51
+
52
+ &.bordered {
53
+ border-collapse: collapse;
54
+ border-width: $table-border-width;
55
+ border-style: $table-border-style;
56
+ border-color: $table-border-color;
57
+
58
+ tr > * {
59
+ border-width: $table-cell-border-width;
60
+ border-style: $table-cell-border-style;
61
+ border-color: $table-cell-border-color;
62
+ }
63
+ }
64
+
65
+ &.striped-columns {
66
+ tbody tr:nth-child(odd) > * {
67
+ background: $table-striped-background;
68
+ color: $table-striped-color;
69
+ }
70
+ }
71
+
72
+ &.striped-rows {
73
+ tbody tr > :nth-child(odd) {
74
+ background: $table-striped-background;
75
+ color: $table-striped-color;
76
+ }
77
+ }
78
+
79
+ &.hoverable {
80
+ tbody tr:hover > * {
81
+ background: $table-hover-background;
82
+ color: $table-hover-color;
83
+ }
84
+ }
85
+
86
+ .highlight {
87
+ --#{root-defaults.$prefix}-table-cell-background: #{$table-highlight-background};
88
+ --#{root-defaults.$prefix}-table-cell-color: #{$table-highlight-color};
89
+ --#{root-defaults.$prefix}-table-header-background: #{$table-highlight-background};
90
+ --#{root-defaults.$prefix}-table-header-color: #{$table-highlight-color};
91
+ --#{root-defaults.$prefix}-table-striped-background: #{$table-highlight-background};
92
+ --#{root-defaults.$prefix}-table-striped-color: #{$table-highlight-color};
93
+ }
94
+ }
95
+
96
+ .responsive-table {
97
+ display: block;
98
+ width: 100%;
99
+ overflow: scroll hidden;
100
+
101
+ table {
102
+ width: 100%;
103
+ margin-bottom: 0;
104
+ }
105
+ }
106
+ }
@@ -0,0 +1,64 @@
1
+ // Variables referencing custom properties.
2
+
3
+ @use "defaults";
4
+ @use "../../defaults" as root-defaults;
5
+ @use "../../variables" as root-variables;
6
+ @use "../../functions/theme";
7
+
8
+ // Table border properties.
9
+ $table-border-width: var(
10
+ --#{root-defaults.$prefix}-table-border-width,
11
+ #{root-variables.$border-width}
12
+ );
13
+ $table-border-style: var(
14
+ --#{root-defaults.$prefix}-table-border-style,
15
+ #{root-variables.$border-style}
16
+ );
17
+ $table-border-color: var(
18
+ --#{root-defaults.$prefix}-table-border-color,
19
+ #{theme.get(primary, 900)}
20
+ );
21
+
22
+ // Table cell border properties.
23
+ $table-cell-border-width: var(
24
+ --#{root-defaults.$prefix}-table-cell-border-width,
25
+ #{$table-border-width}
26
+ );
27
+ $table-cell-border-style: var(
28
+ --#{root-defaults.$prefix}-table-cell-border-style,
29
+ #{$table-border-style}
30
+ );
31
+ $table-cell-border-color: var(
32
+ --#{root-defaults.$prefix}-table-cell-border-color,
33
+ #{$table-border-color}
34
+ );
35
+
36
+ // Table striped properties.
37
+ $table-striped-background: var(
38
+ --#{root-defaults.$prefix}-table-striped-background,
39
+ #{theme.get(secondary, 200)}
40
+ );
41
+ $table-striped-color: var(
42
+ --#{root-defaults.$prefix}-table-striped-color,
43
+ #{theme.get(secondary, 900)}
44
+ );
45
+
46
+ // Table hover properties.
47
+ $table-hover-background: var(
48
+ --#{root-defaults.$prefix}-table-hover-background,
49
+ #{theme.get(secondary, 300)}
50
+ );
51
+ $table-hover-color: var(
52
+ --#{root-defaults.$prefix}-table-hover-color,
53
+ #{theme.get(secondary, 900)}
54
+ );
55
+
56
+ // Table highlight properties.
57
+ $table-highlight-background: var(
58
+ --#{root-defaults.$prefix}-table-highlight-background,
59
+ #{theme.get(secondary, 500)}
60
+ );
61
+ $table-highlight-color: var(
62
+ --#{root-defaults.$prefix}-table-highlight-color,
63
+ #{theme.get(secondary, 100)}
64
+ );
@@ -0,0 +1,18 @@
1
+ // Functions to help with getting information about the theme.
2
+
3
+ @use "sass:map";
4
+ @use "../theme/color/variables" as color;
5
+
6
+ // A function to get the specific theme shades.
7
+ @function get($color, $shade) {
8
+ $color-map: map.get(color.$theme-active, $color);
9
+ $value: map.get($color-map, $shade);
10
+
11
+ @return $value;
12
+ }
13
+
14
+ @function variants() {
15
+ $variants: map.keys(color.$theme-active);
16
+
17
+ @return $variants;
18
+ }
@@ -6,7 +6,6 @@
6
6
 
7
7
  $columns-max-width: 1fr !default;
8
8
  $columns-count: 3 !default;
9
- $columns-disable-width: 48ch !default;
10
9
  $columns-min-count: 1 !default;
11
- $columns-max-count: 4 !default;
10
+ $columns-max-count: 6 !default;
12
11
  $columns-span: 1 !default;
@@ -4,15 +4,13 @@
4
4
  @use "defaults";
5
5
  @use "../../defaults" as root-defaults;
6
6
  @use "../../mixins/layer" as *;
7
+ @use "../../mixins/media-queries" as *;
7
8
 
8
9
  @include layer(layout) {
9
10
  .columns {
10
11
  display: grid;
11
- grid-template-columns: var(
12
- --#{root-defaults.$prefix}-columns,
13
- repeat(auto-fit, minmax(#{$columns-min-width}, #{$columns-max-width}))
14
- );
15
- gap: $columns-gap;
12
+ grid-template-columns: $columns-grid-template-columns;
13
+ gap: $columns-row-gap $columns-column-gap;
16
14
 
17
15
  > * {
18
16
  grid-column: span $columns-span;
@@ -30,7 +28,7 @@
30
28
  }
31
29
 
32
30
  // Disable columns on small screens to avoid horizontal bleeding.
33
- @media screen and (max-width: #{defaults.$columns-disable-width}) {
31
+ @include screen-under(sm) {
34
32
  .columns {
35
33
  --#{root-defaults.$prefix}-columns-min-width: #{defaults.$columns-max-width};
36
34
  }