@graupl/graupl 1.0.0-alpha.1 → 1.0.0-alpha.10

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 (211) hide show
  1. package/.stylelintignore +9 -0
  2. package/CHANGELOG.md +164 -0
  3. package/dist/base/form.css +2 -0
  4. package/dist/base/form.css.map +1 -0
  5. package/dist/base/link.css +2 -0
  6. package/dist/base/link.css.map +1 -0
  7. package/dist/base/table.css +2 -0
  8. package/dist/base/table.css.map +1 -0
  9. package/dist/base.css +2 -0
  10. package/dist/base.css.map +1 -0
  11. package/dist/component/button.css +2 -0
  12. package/dist/component/button.css.map +1 -0
  13. package/dist/component/input-group.css +2 -0
  14. package/dist/component/input-group.css.map +1 -0
  15. package/dist/component/table.css +2 -0
  16. package/dist/component/table.css.map +1 -0
  17. package/dist/component.css +2 -0
  18. package/dist/component.css.map +1 -0
  19. package/dist/graupl.css +1 -284
  20. package/dist/graupl.css.map +1 -1
  21. package/dist/layout/columns.css +2 -0
  22. package/dist/layout/columns.css.map +1 -0
  23. package/dist/layout/container.css +2 -0
  24. package/dist/layout/container.css.map +1 -0
  25. package/dist/layout.css +2 -0
  26. package/dist/layout.css.map +1 -0
  27. package/dist/state/focus.css +2 -0
  28. package/dist/state/focus.css.map +1 -0
  29. package/dist/state.css +2 -0
  30. package/dist/state.css.map +1 -0
  31. package/dist/theme/color.css +2 -0
  32. package/dist/theme/color.css.map +1 -0
  33. package/dist/theme/typography.css +2 -0
  34. package/dist/theme/typography.css.map +1 -0
  35. package/dist/theme.css +2 -0
  36. package/dist/theme.css.map +1 -0
  37. package/dist/utilities/alignment.css +2 -0
  38. package/dist/utilities/alignment.css.map +1 -0
  39. package/dist/utilities/color.css +2 -0
  40. package/dist/utilities/color.css.map +1 -0
  41. package/dist/utilities/display.css +2 -0
  42. package/dist/utilities/display.css.map +1 -0
  43. package/dist/utilities/flex.css +2 -0
  44. package/dist/utilities/flex.css.map +1 -0
  45. package/dist/utilities/inset.css +2 -0
  46. package/dist/utilities/inset.css.map +1 -0
  47. package/dist/utilities/justification.css +2 -0
  48. package/dist/utilities/justification.css.map +1 -0
  49. package/dist/utilities/list.css +2 -0
  50. package/dist/utilities/list.css.map +1 -0
  51. package/dist/utilities/postion.css +2 -0
  52. package/dist/utilities/postion.css.map +1 -0
  53. package/dist/utilities/spacing.css +2 -0
  54. package/dist/utilities/spacing.css.map +1 -0
  55. package/dist/utilities/typography.css +2 -0
  56. package/dist/utilities/typography.css.map +1 -0
  57. package/dist/utilities/visibility.css +2 -0
  58. package/dist/utilities/visibility.css.map +1 -0
  59. package/dist/utilities.css +2 -0
  60. package/dist/utilities.css.map +1 -0
  61. package/docs/.vitepress/config.js +41 -1
  62. package/docs/.vitepress/theme/custom.scss +29 -29
  63. package/docs/compiling-graupl.md +56 -0
  64. package/docs/introduction.md +5 -0
  65. package/index.html +333 -72
  66. package/package.json +16 -4
  67. package/postcss.config.cjs +1 -1
  68. package/scss/base/form.scss +3 -0
  69. package/scss/base/link.scss +3 -0
  70. package/scss/base/table.scss +3 -0
  71. package/scss/base.scss +3 -0
  72. package/scss/component/button.scss +3 -0
  73. package/scss/component/input-group.scss +3 -0
  74. package/scss/component/table.scss +3 -0
  75. package/scss/component.scss +3 -0
  76. package/scss/graupl.scss +1 -5
  77. package/scss/layout/columns.scss +3 -0
  78. package/scss/layout/container.scss +3 -0
  79. package/scss/layout.scss +3 -0
  80. package/scss/state/focus.scss +3 -0
  81. package/scss/state.scss +3 -0
  82. package/scss/theme/color.scss +3 -0
  83. package/scss/theme/typography.scss +3 -0
  84. package/scss/theme.scss +3 -0
  85. package/scss/utilities/alignment.scss +3 -0
  86. package/scss/utilities/color.scss +3 -0
  87. package/scss/utilities/display.scss +3 -0
  88. package/scss/utilities/flex.scss +3 -0
  89. package/scss/utilities/inset.scss +3 -0
  90. package/scss/utilities/justification.scss +3 -0
  91. package/scss/utilities/list.scss +3 -0
  92. package/scss/utilities/postion.scss +3 -0
  93. package/scss/utilities/spacing.scss +3 -0
  94. package/scss/utilities/typography.scss +3 -0
  95. package/scss/utilities/visibility.scss +3 -0
  96. package/scss/utilities.scss +3 -0
  97. package/{scss → src/scss}/_defaults.scss +40 -13
  98. package/src/scss/_index.scss +14 -0
  99. package/src/scss/_init.scss +3 -0
  100. package/{scss → src/scss}/_variables.scss +14 -24
  101. package/{scss → src/scss}/base/_index.scss +1 -0
  102. package/{scss → src/scss}/base/form/_defaults.scss +0 -2
  103. package/{scss → src/scss}/base/form/_index.scss +12 -0
  104. package/src/scss/base/form/_variables.scss +145 -0
  105. package/{scss → src/scss}/base/link/_defaults.scss +0 -2
  106. package/src/scss/base/link/_variables.scss +32 -0
  107. package/src/scss/base/table/_defaults.scss +8 -0
  108. package/src/scss/base/table/_index.scss +27 -0
  109. package/src/scss/base/table/_variables.scss +65 -0
  110. package/{scss → src/scss}/component/_index.scss +2 -0
  111. package/src/scss/component/button/_defaults.scss +39 -0
  112. package/src/scss/component/button/_index.scss +98 -0
  113. package/src/scss/component/button/_variables.scss +132 -0
  114. package/src/scss/component/input-group/_defaults.scss +23 -0
  115. package/src/scss/component/input-group/_index.scss +45 -0
  116. package/src/scss/component/input-group/_variables.scss +63 -0
  117. package/src/scss/component/table/_defaults.scss +30 -0
  118. package/src/scss/component/table/_index.scss +77 -0
  119. package/src/scss/component/table/_variables.scss +64 -0
  120. package/src/scss/functions/_important.scss +11 -0
  121. package/src/scss/functions/_theme.scss +18 -0
  122. package/{scss → src/scss}/layout/columns/_defaults.scss +1 -4
  123. package/src/scss/layout/columns/_index.scss +36 -0
  124. package/src/scss/layout/columns/_variables.scss +47 -0
  125. package/{scss → src/scss}/layout/container/_defaults.scss +0 -2
  126. package/src/scss/layout/container/_index.scss +36 -0
  127. package/src/scss/layout/container/_variables.scss +47 -0
  128. package/{scss → src/scss}/mixins/_layer.scss +2 -2
  129. package/{scss → src/scss}/mixins/_media-queries.scss +11 -0
  130. package/{scss → src/scss}/state/focus/_defaults.scss +0 -2
  131. package/src/scss/state/focus/_variables.scss +40 -0
  132. package/src/scss/theme/_index.scss +4 -0
  133. package/src/scss/theme/color/_defaults.scss +61 -0
  134. package/src/scss/theme/color/_index.scss +42 -0
  135. package/src/scss/theme/color/_variables.scss +121 -0
  136. package/src/scss/theme/typography/_defaults.scss +52 -0
  137. package/src/scss/theme/typography/_index.scss +111 -0
  138. package/src/scss/theme/typography/_variables.scss +227 -0
  139. package/src/scss/utilities/_index.scss +13 -0
  140. package/src/scss/utilities/alignment/_defaults.scss +57 -0
  141. package/src/scss/utilities/alignment/_index.scss +29 -0
  142. package/src/scss/utilities/alignment/_variables.scss +3 -0
  143. package/src/scss/utilities/color/_defaults.scss +30 -0
  144. package/src/scss/utilities/color/_index.scss +38 -0
  145. package/src/scss/utilities/color/_variables.scss +3 -0
  146. package/src/scss/utilities/display/_defaults.scss +27 -0
  147. package/src/scss/utilities/display/_index.scss +15 -0
  148. package/src/scss/utilities/display/_variables.scss +3 -0
  149. package/src/scss/utilities/flex/_defaults.scss +58 -0
  150. package/src/scss/utilities/flex/_index.scss +36 -0
  151. package/src/scss/utilities/flex/_variables.scss +3 -0
  152. package/src/scss/utilities/inset/_defaults.scss +36 -0
  153. package/src/scss/utilities/inset/_index.scss +19 -0
  154. package/src/scss/utilities/inset/_variables.scss +3 -0
  155. package/src/scss/utilities/justification/_defaults.scss +54 -0
  156. package/src/scss/utilities/justification/_index.scss +29 -0
  157. package/src/scss/utilities/justification/_variables.scss +3 -0
  158. package/src/scss/utilities/list/_defaults.scss +34 -0
  159. package/src/scss/utilities/list/_index.scss +22 -0
  160. package/src/scss/utilities/list/_variables.scss +3 -0
  161. package/src/scss/utilities/position/_defaults.scss +21 -0
  162. package/src/scss/utilities/position/_index.scss +15 -0
  163. package/src/scss/utilities/position/_variables.scss +3 -0
  164. package/src/scss/utilities/spacing/_defaults.scss +44 -0
  165. package/src/scss/utilities/spacing/_index.scss +64 -0
  166. package/src/scss/utilities/spacing/_variables.scss +3 -0
  167. package/src/scss/utilities/typography/_defaults.scss +25 -0
  168. package/src/scss/utilities/typography/_index.scss +95 -0
  169. package/src/scss/utilities/typography/_variables.scss +3 -0
  170. package/src/scss/utilities/visibility/_defaults.scss +20 -0
  171. package/src/scss/utilities/visibility/_index.scss +15 -0
  172. package/src/scss/utilities/visibility/_variables.scss +3 -0
  173. package/stylelint.config.js +2 -0
  174. package/dist/base/form/form.css +0 -78
  175. package/dist/base/form/form.css.map +0 -1
  176. package/dist/base/link/link.css +0 -26
  177. package/dist/base/link/link.css.map +0 -1
  178. package/dist/component/button/button.css +0 -62
  179. package/dist/component/button/button.css.map +0 -1
  180. package/dist/layout/columns/columns.css +0 -41
  181. package/dist/layout/columns/columns.css.map +0 -1
  182. package/dist/layout/container/container.css +0 -38
  183. package/dist/layout/container/container.css.map +0 -1
  184. package/dist/state/focus/focus.css +0 -10
  185. package/dist/state/focus/focus.css.map +0 -1
  186. package/dist/theme/theme.css +0 -42
  187. package/dist/theme/theme.css.map +0 -1
  188. package/scss/base/form/_variables.scss +0 -133
  189. package/scss/base/form/form.scss +0 -3
  190. package/scss/base/link/_variables.scss +0 -31
  191. package/scss/base/link/link.scss +0 -3
  192. package/scss/component/button/_defaults.scss +0 -10
  193. package/scss/component/button/_index.scss +0 -75
  194. package/scss/component/button/_variables.scss +0 -102
  195. package/scss/component/button/button.scss +0 -3
  196. package/scss/layout/columns/_index.scss +0 -38
  197. package/scss/layout/columns/_variables.scss +0 -24
  198. package/scss/layout/columns/columns.scss +0 -3
  199. package/scss/layout/container/_index.scss +0 -50
  200. package/scss/layout/container/_variables.scss +0 -26
  201. package/scss/layout/container/container.scss +0 -3
  202. package/scss/state/focus/_variables.scss +0 -36
  203. package/scss/state/focus/focus.scss +0 -3
  204. package/scss/theme/_defaults.scss +0 -56
  205. package/scss/theme/_index.scss +0 -53
  206. package/scss/theme/_variables.scss +0 -297
  207. package/scss/theme/theme.scss +0 -3
  208. /package/{scss → src/scss}/base/link/_index.scss +0 -0
  209. /package/{scss → src/scss}/layout/_index.scss +0 -0
  210. /package/{scss → src/scss}/state/_index.scss +0 -0
  211. /package/{scss → src/scss}/state/focus/_index.scss +0 -0
@@ -0,0 +1,132 @@
1
+ // Variables referencing custom properties.
2
+
3
+ @use "defaults";
4
+ @use "../../variables" as root-variables;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../theme/color/variables" as color;
7
+ @use "../../theme/typography/variables" as typography;
8
+ @use "../../functions/theme";
9
+ @use "sass:map";
10
+
11
+ // Button properties.
12
+ $button-min-width: var(
13
+ --#{root-defaults.$prefix}-button-min-width,
14
+ #{root-defaults.$interactive-min-width}
15
+ );
16
+ $button-min-height: var(
17
+ --#{root-defaults.$prefix}-button-min-height,
18
+ #{root-defaults.$interactive-min-height}
19
+ );
20
+ $button-padding-x: var(
21
+ --#{root-defaults.$prefix}-button-padding-x,
22
+ #{map.get(root-variables.$spacers, 5)}
23
+ );
24
+ $button-padding-y: var(
25
+ --#{root-defaults.$prefix}-button-padding-y,
26
+ #{map.get(root-variables.$spacers, 3)}
27
+ );
28
+ $button-padding: var(
29
+ --#{root-defaults.$prefix}-button-padding,
30
+ #{$button-padding-y} #{$button-padding-x}
31
+ );
32
+ $button-font-size: var(
33
+ --#{root-defaults.$prefix}-button-font-size,
34
+ #{map.get(typography.$font-sizes, base)}
35
+ );
36
+ $button-transition: var(
37
+ --#{root-defaults.$prefix}-button-transition,
38
+ background #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function},
39
+ color #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function},
40
+ transform #{map.get(root-variables.$transition-durations, fast)} #{root-variables.$transition-timing-function}
41
+ );
42
+ $button-transition-reduced-motion: var(
43
+ --#{root-defaults.$prefix}-button-transition-reduced-motion,
44
+ background #{map.get(root-variables.$transition-durations, none)} #{root-variables.$transition-timing-function},
45
+ color #{map.get(root-variables.$transition-durations, none)} #{root-variables.$transition-timing-function}
46
+ );
47
+
48
+ // Transform properties.
49
+ $button-hover-transform: var(
50
+ --#{root-defaults.$prefix}-button-hover-transform,
51
+ #{defaults.$button-hover-transform}
52
+ );
53
+ $button-active-transform: var(
54
+ --#{root-defaults.$prefix}-button-active-transform,
55
+ #{defaults.$button-active-transform}
56
+ );
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}
64
+ );
65
+
66
+ // Background properties.
67
+ $button-background: var(
68
+ --#{root-defaults.$prefix}-button-background,
69
+ #{color.$root-background}
70
+ );
71
+ $button-hover-background: var(
72
+ --#{root-defaults.$prefix}-button-hover-background,
73
+ #{theme.get(primary, 900)}
74
+ );
75
+ $button-active-background: var(
76
+ --#{root-defaults.$prefix}-button-active-background,
77
+ #{theme.get(primary, 900)}
78
+ );
79
+ $button-disabled-background: var(
80
+ --#{root-defaults.$prefix}-button-disabled-background,
81
+ #{color.$root-background}
82
+ );
83
+
84
+ // Text properties.
85
+ $button-color: var(
86
+ --#{root-defaults.$prefix}-button-color,
87
+ #{theme.get(primary, 900)}
88
+ );
89
+ $button-hover-color: var(
90
+ --#{root-defaults.$prefix}-button-hover-color,
91
+ #{theme.get(primary, 100)}
92
+ );
93
+ $button-active-color: var(
94
+ --#{root-defaults.$prefix}-button-active-color,
95
+ #{theme.get(primary, 100)}
96
+ );
97
+ $button-disabled-color: var(
98
+ --#{root-defaults.$prefix}-button-disabled-color,
99
+ #{theme.get(primary, 200)}
100
+ );
101
+
102
+ // Border properties.
103
+ $button-border-width: var(
104
+ --#{root-defaults.$prefix}-button-border-width,
105
+ #{root-variables.$border-width}
106
+ );
107
+ $button-border-style: var(
108
+ --#{root-defaults.$prefix}-botton-border-style,
109
+ #{root-variables.$border-style}
110
+ );
111
+ $button-border-radius: var(
112
+ --#{root-defaults.$prefix}-button-border-radius,
113
+ #{root-variables.$border-radius}
114
+ );
115
+
116
+ // Border colour properties.
117
+ $button-border-color: var(
118
+ --#{root-defaults.$prefix}-button-border-color,
119
+ #{theme.get(primary, 900)}
120
+ );
121
+ $button-hover-border-color: var(
122
+ --#{root-defaults.$prefix}-button-hover-border-color,
123
+ #{theme.get(primary, 900)}
124
+ );
125
+ $button-active-border-color: var(
126
+ --#{root-defaults.$prefix}-button-active-border-color,
127
+ #{theme.get(primary, 900)}
128
+ );
129
+ $button-disabled-border-color: var(
130
+ --#{root-defaults.$prefix}-button-disabled-border-color,
131
+ #{theme.get(primary, 200)}
132
+ );
@@ -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(xs) {
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,30 @@
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
+ @use "sass:map";
8
+
9
+ // Table theme defaults.
10
+ // This map is used to define the default colour shades for the
11
+ // themed table components.
12
+ //
13
+ // e.g.
14
+ // Primary tables will use primary--700 as the header background,
15
+ // and primary--100 as the header text colour.
16
+ //
17
+ // Secondary/tertiary tables will use the same shade for their respective colours.
18
+ $base-table-theme-map: (
19
+ header-background: 700,
20
+ header-color: 100,
21
+ striped-background: 200,
22
+ striped-color: 900,
23
+ hover-background: 300,
24
+ hover-color: 900,
25
+ border-color: 900,
26
+ highlight-background: 500,
27
+ highlight-color: 100,
28
+ );
29
+ $custom-table-theme-map: () !default;
30
+ $table-theme-map: map.merge($base-table-theme-map, $custom-table-theme-map);
@@ -0,0 +1,77 @@
1
+ // Table component styles.
2
+
3
+ @use "variables" as *;
4
+ @use "defaults";
5
+ @use "../../mixins/layer" as *;
6
+ @use "../../defaults" as root-defaults;
7
+ @use "../../functions/theme";
8
+
9
+ @include layer(component) {
10
+ table {
11
+ @each $variant in theme.variants() {
12
+ &.#{$variant},
13
+ .#{$variant} {
14
+ @each $prop, $key in defaults.$table-theme-map {
15
+ --#{root-defaults.$prefix}-table-#{$prop}: #{theme.get(
16
+ $variant,
17
+ $key
18
+ )};
19
+ }
20
+ }
21
+ }
22
+
23
+ &.bordered {
24
+ border-collapse: collapse;
25
+ border-width: $table-border-width;
26
+ border-style: $table-border-style;
27
+ border-color: $table-border-color;
28
+
29
+ tr > * {
30
+ border-width: $table-cell-border-width;
31
+ border-style: $table-cell-border-style;
32
+ border-color: $table-cell-border-color;
33
+ }
34
+ }
35
+
36
+ &.striped-columns {
37
+ tbody tr:nth-child(odd) > * {
38
+ background: $table-striped-background;
39
+ color: $table-striped-color;
40
+ }
41
+ }
42
+
43
+ &.striped-rows {
44
+ tbody tr > :nth-child(odd) {
45
+ background: $table-striped-background;
46
+ color: $table-striped-color;
47
+ }
48
+ }
49
+
50
+ &.hoverable {
51
+ tbody tr:hover > * {
52
+ background: $table-hover-background;
53
+ color: $table-hover-color;
54
+ }
55
+ }
56
+
57
+ .highlight {
58
+ --#{root-defaults.$prefix}-table-cell-background: #{$table-highlight-background};
59
+ --#{root-defaults.$prefix}-table-cell-color: #{$table-highlight-color};
60
+ --#{root-defaults.$prefix}-table-header-background: #{$table-highlight-background};
61
+ --#{root-defaults.$prefix}-table-header-color: #{$table-highlight-color};
62
+ --#{root-defaults.$prefix}-table-striped-background: #{$table-highlight-background};
63
+ --#{root-defaults.$prefix}-table-striped-color: #{$table-highlight-color};
64
+ }
65
+ }
66
+
67
+ .responsive-table {
68
+ display: block;
69
+ width: 100%;
70
+ overflow: scroll hidden;
71
+
72
+ table {
73
+ width: 100%;
74
+ margin-bottom: 0;
75
+ }
76
+ }
77
+ }
@@ -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,11 @@
1
+ // A function to determine if the !important flag should be added to a property.
2
+
3
+ @use "../defaults";
4
+
5
+ @function insert($value) {
6
+ @if defaults.$use-important {
7
+ @return #{$value !important};
8
+ }
9
+
10
+ @return #{$value};
11
+ }
@@ -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
+ }
@@ -4,11 +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
- @forward "../../defaults";
8
-
9
7
  $columns-max-width: 1fr !default;
10
8
  $columns-count: 3 !default;
11
- $columns-disable-width: 48ch !default;
12
9
  $columns-min-count: 1 !default;
13
- $columns-max-count: 4 !default;
10
+ $columns-max-count: 6 !default;
14
11
  $columns-span: 1 !default;
@@ -0,0 +1,36 @@
1
+ // Graupl Columns layout.
2
+
3
+ @use "variables" as *;
4
+ @use "defaults";
5
+ @use "../../defaults" as root-defaults;
6
+ @use "../../mixins/layer" as *;
7
+ @use "../../mixins/media-queries" as *;
8
+
9
+ @include layer(layout) {
10
+ .columns {
11
+ display: grid;
12
+ grid-template-columns: $columns-grid-template-columns;
13
+ gap: $columns-row-gap $columns-column-gap;
14
+
15
+ > * {
16
+ grid-column: span $columns-span;
17
+ }
18
+ }
19
+
20
+ @for $i from defaults.$columns-min-count through defaults.$columns-max-count {
21
+ .count-#{$i} {
22
+ --#{root-defaults.$prefix}-columns-count: #{$i};
23
+ }
24
+
25
+ .span-#{$i} {
26
+ --#{root-defaults.$prefix}-columns-span: #{$i};
27
+ }
28
+ }
29
+
30
+ // Disable columns on small screens to avoid horizontal bleeding.
31
+ @include screen(xs) {
32
+ .columns {
33
+ --#{root-defaults.$prefix}-columns-min-width: #{defaults.$columns-max-width};
34
+ }
35
+ }
36
+ }
@@ -0,0 +1,47 @@
1
+ // Variables referencing custom properties.
2
+
3
+ @use "defaults";
4
+ @use "../../variables" as root-variables;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "sass:map";
7
+
8
+ $columns-row-gap: var(
9
+ --#{root-defaults.$prefix}-columns-row-gap,
10
+ #{map.get(root-variables.$spacers, 5)}
11
+ );
12
+ $columns-column-gap: var(
13
+ --#{root-defaults.$prefix}-columns-column-gap,
14
+ #{map.get(root-variables.$spacers, 5)}
15
+ );
16
+ $columns-count: var(
17
+ --#{root-defaults.$prefix}-columns-count,
18
+ #{defaults.$columns-count}
19
+ );
20
+
21
+ // Calculate the min-width of each column based on the content-max-width and column-gap.
22
+ // We take the maximum width of the page and subtract the gap width multiplied by the number of
23
+ // columns minus one (to account for the gaps between columns).
24
+ // We then divide this by the number of columns to get the min-width of each column.
25
+ /* stylelint-disable scss/operator-no-newline-after -- Prettier wants to format it this way. */
26
+ $columns-min-width: var(
27
+ --#{root-defaults.$prefix}-columns-min-width,
28
+ calc(
29
+ (
30
+ #{root-variables.$content-max-width} - #{$columns-column-gap} *
31
+ (#{$columns-count} - 1)
32
+ ) / #{$columns-count}
33
+ )
34
+ );
35
+ /* stylelint-enable scss/operator-no-newline-after */
36
+ $columns-max-width: var(
37
+ --#{root-defaults.$prefix}-columns-max-width,
38
+ #{defaults.$columns-max-width}
39
+ );
40
+ $columns-grid-template-columns: var(
41
+ --#{root-defaults.$prefix}-columns-grid-template-columns,
42
+ repeat(auto-fit, minmax(#{$columns-min-width}, #{$columns-max-width}))
43
+ );
44
+ $columns-span: var(
45
+ --#{root-defaults.$prefix}-columns-span,
46
+ #{defaults.$columns-span}
47
+ );
@@ -4,7 +4,5 @@
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
- @forward "../../defaults";
8
-
9
7
  $container-breakout-width: 15ch !default;
10
8
  $container-feature-width: 20ch !default;
@@ -0,0 +1,36 @@
1
+ // Graupl Container layout.
2
+
3
+ @use "variables" as *;
4
+ @use "../../mixins/layer" as *;
5
+
6
+ @include layer(layout) {
7
+ .container,
8
+ .container > .full-width {
9
+ display: grid;
10
+ grid-template-columns:
11
+ [full-width-start] $container-full-width-section-width
12
+ [feature-start] $container-feature-section-width
13
+ [breakout-start] $container-breakout-section-width
14
+ [content-start] $container-content-section-width
15
+ [content-end]
16
+ $container-breakout-section-width [breakout-end]
17
+ $container-feature-section-width [feature-end]
18
+ $container-full-width-section-width [full-width-end];
19
+
20
+ > :not(.breakout, .full-width, .feature) {
21
+ grid-column: content;
22
+ }
23
+
24
+ .breakout {
25
+ grid-column: breakout;
26
+ }
27
+
28
+ .feature {
29
+ grid-column: feature;
30
+ }
31
+
32
+ .full-width {
33
+ grid-column: full-width;
34
+ }
35
+ }
36
+ }
@@ -0,0 +1,47 @@
1
+ // Variables referencing custom properties.
2
+
3
+ @use "defaults";
4
+ @use "../../variables" as root-variables;
5
+ @use "../../defaults" as root-defaults;
6
+ @use "sass:map";
7
+
8
+ $container-gap: var(
9
+ --#{root-defaults.$prefix}-container-gap,
10
+ #{map.get(root-variables.$spacers, 5)}
11
+ );
12
+ $container-content-max-width: var(
13
+ --#{root-defaults.$prefix}-container-content-max-width,
14
+ #{root-variables.$content-max-width}
15
+ );
16
+ $container-breakout-max-width: var(
17
+ --#{root-defaults.$prefix}-container-breakout-max-width,
18
+ calc(#{$container-content-max-width} + #{defaults.$container-breakout-width})
19
+ );
20
+ $container-breakout-width: var(
21
+ --#{root-defaults.$prefix}-container-breakout-width,
22
+ calc((#{$container-breakout-max-width} - #{$container-content-max-width}) / 2)
23
+ );
24
+ $container-feature-max-width: var(
25
+ --#{root-defaults.$prefix}-container-feature-max-width,
26
+ calc(#{$container-breakout-max-width} + #{defaults.$container-feature-width})
27
+ );
28
+ $container-feature-width: var(
29
+ --#{root-defaults.$prefix}-container-feature-width,
30
+ calc((#{$container-feature-max-width} - #{$container-breakout-max-width}) / 2)
31
+ );
32
+ $container-content-section-width: var(
33
+ --#{root-defaults.$prefix}-container-content-section-width,
34
+ min(#{$container-content-max-width}, calc(100% - #{$container-gap} * 2))
35
+ );
36
+ $container-full-width-section-width: var(
37
+ --#{root-defaults.$prefix}-container-full-width-section-width,
38
+ minmax(#{$container-gap}, 1fr)
39
+ );
40
+ $container-breakout-section-width: var(
41
+ --#{root-defaults.$prefix}-container-breakout-section-width,
42
+ minmax(0, #{$container-breakout-width})
43
+ );
44
+ $container-feature-section-width: var(
45
+ --#{root-defaults.$prefix}-container-feature-section-width,
46
+ minmax(0, #{$container-feature-width})
47
+ );
@@ -3,11 +3,11 @@
3
3
  // These should be used to define the layers of your components to ensure that
4
4
  // they are output in the correct order in the final compiled CSS.
5
5
 
6
- @use "../defaults" as base;
6
+ @use "../defaults" as root-defaults;
7
7
 
8
8
  @mixin layer($layer) {
9
9
  @at-root {
10
- @layer #{base.$prefix}.#{$layer} {
10
+ @layer #{root-defaults.$prefix}.#{$layer} {
11
11
  @content;
12
12
  }
13
13
  }