@nationalarchives/frontend 0.1.41 → 0.1.43

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 (214) hide show
  1. package/nationalarchives/all.css +1 -1
  2. package/nationalarchives/all.css.map +1 -1
  3. package/nationalarchives/all.js +1 -1
  4. package/nationalarchives/all.js.map +1 -1
  5. package/nationalarchives/all.mjs +18 -0
  6. package/nationalarchives/analytics.js +2 -0
  7. package/nationalarchives/analytics.js.map +1 -0
  8. package/nationalarchives/analytics.mjs +281 -0
  9. package/nationalarchives/components/_index.scss +3 -1
  10. package/nationalarchives/components/breadcrumbs/analytics.js +17 -0
  11. package/nationalarchives/components/breadcrumbs/breadcrumbs.css.map +1 -1
  12. package/nationalarchives/components/breadcrumbs/breadcrumbs.stories.js +3 -1
  13. package/nationalarchives/components/breadcrumbs/fixtures.json +69 -6
  14. package/nationalarchives/components/breadcrumbs/macro-options.json +12 -6
  15. package/nationalarchives/components/breadcrumbs/template.njk +12 -4
  16. package/nationalarchives/components/button/_index.scss +1 -0
  17. package/nationalarchives/components/button/button-group.stories.js +122 -0
  18. package/nationalarchives/components/button/button.css +1 -1
  19. package/nationalarchives/components/button/button.css.map +1 -1
  20. package/nationalarchives/components/button/button.scss +5 -8
  21. package/nationalarchives/components/button/button.stories.js +36 -38
  22. package/nationalarchives/components/button/fixtures.json +5 -10
  23. package/nationalarchives/components/button/template.njk +11 -10
  24. package/nationalarchives/components/card/card.css +1 -1
  25. package/nationalarchives/components/card/card.css.map +1 -1
  26. package/nationalarchives/components/card/card.scss +6 -0
  27. package/nationalarchives/components/card/card.stories.js +11 -0
  28. package/nationalarchives/components/card/fixtures.json +17 -34
  29. package/nationalarchives/components/checkboxes/analytics.js +25 -0
  30. package/nationalarchives/components/checkboxes/checkboxes.css +1 -1
  31. package/nationalarchives/components/checkboxes/checkboxes.css.map +1 -1
  32. package/nationalarchives/components/checkboxes/checkboxes.njk +12 -0
  33. package/nationalarchives/components/checkboxes/checkboxes.scss +1 -0
  34. package/nationalarchives/components/checkboxes/fixtures.json +6 -12
  35. package/nationalarchives/components/checkboxes/template.njk +10 -7
  36. package/nationalarchives/components/compound-filters/compound-filters.css +1 -1
  37. package/nationalarchives/components/compound-filters/compound-filters.css.map +1 -1
  38. package/nationalarchives/components/compound-filters/compound-filters.scss +2 -0
  39. package/nationalarchives/components/compound-filters/fixtures.json +1 -2
  40. package/nationalarchives/components/compound-filters/template.njk +1 -1
  41. package/nationalarchives/components/cookie-banner/cookie-banner.css.map +1 -1
  42. package/nationalarchives/components/cookie-banner/cookie-banner.js +1 -1
  43. package/nationalarchives/components/cookie-banner/cookie-banner.js.map +1 -1
  44. package/nationalarchives/components/cookie-banner/fixtures.json +10 -20
  45. package/nationalarchives/components/date-input/date-input.css +1 -1
  46. package/nationalarchives/components/date-input/date-input.css.map +1 -1
  47. package/nationalarchives/components/date-input/fixtures.json +5 -10
  48. package/nationalarchives/components/date-input/template.njk +9 -9
  49. package/nationalarchives/components/date-search/date-search.css +1 -1
  50. package/nationalarchives/components/date-search/date-search.css.map +1 -1
  51. package/nationalarchives/components/date-search/date-search.njk +7 -0
  52. package/nationalarchives/components/date-search/fixtures.json +6 -12
  53. package/nationalarchives/components/date-search/template.njk +6 -7
  54. package/nationalarchives/components/error-summary/_index.scss +1 -0
  55. package/nationalarchives/components/error-summary/error-summary.css +1 -0
  56. package/nationalarchives/components/error-summary/error-summary.css.map +1 -0
  57. package/nationalarchives/components/error-summary/error-summary.js +2 -0
  58. package/nationalarchives/components/error-summary/error-summary.js.map +1 -0
  59. package/nationalarchives/components/error-summary/error-summary.mjs +51 -0
  60. package/nationalarchives/components/error-summary/error-summary.scss +39 -0
  61. package/nationalarchives/components/error-summary/error-summary.stories.js +59 -0
  62. package/nationalarchives/components/error-summary/fixtures.json +24 -0
  63. package/nationalarchives/components/error-summary/macro-options.json +52 -0
  64. package/nationalarchives/components/error-summary/macro.njk +3 -0
  65. package/nationalarchives/components/error-summary/template.njk +15 -0
  66. package/nationalarchives/components/featured-records/featured-records.css +1 -1
  67. package/nationalarchives/components/featured-records/featured-records.css.map +1 -1
  68. package/nationalarchives/components/featured-records/featured-records.scss +1 -1
  69. package/nationalarchives/components/featured-records/fixtures.json +2 -4
  70. package/nationalarchives/components/footer/analytics.js +97 -0
  71. package/nationalarchives/components/footer/fixtures.json +8 -15
  72. package/nationalarchives/components/footer/footer.css +1 -1
  73. package/nationalarchives/components/footer/footer.css.map +1 -1
  74. package/nationalarchives/components/footer/footer.scss +4 -2
  75. package/nationalarchives/components/footer/footer.stories.js +5 -11
  76. package/nationalarchives/components/footer/template.njk +13 -10
  77. package/nationalarchives/components/gallery/gallery.css.map +1 -1
  78. package/nationalarchives/components/global-header/analytics.js +57 -0
  79. package/nationalarchives/components/global-header/fixtures.json +1 -2
  80. package/nationalarchives/components/global-header/global-header.css +1 -1
  81. package/nationalarchives/components/global-header/global-header.css.map +1 -1
  82. package/nationalarchives/components/global-header/global-header.js +1 -1
  83. package/nationalarchives/components/global-header/global-header.js.map +1 -1
  84. package/nationalarchives/components/global-header/global-header.mjs +40 -79
  85. package/nationalarchives/components/global-header/global-header.scss +9 -6
  86. package/nationalarchives/components/global-header/global-header.stories.js +32 -20
  87. package/nationalarchives/components/global-header/macro-options.json +12 -0
  88. package/nationalarchives/components/global-header/template.njk +7 -7
  89. package/nationalarchives/components/grid/fixtures.json +13 -26
  90. package/nationalarchives/components/grid/grid.css +1 -1
  91. package/nationalarchives/components/grid/grid.css.map +1 -1
  92. package/nationalarchives/components/grid/grid.scss +0 -1
  93. package/nationalarchives/components/header/analytics.js +18 -0
  94. package/nationalarchives/components/header/fixtures.json +1 -2
  95. package/nationalarchives/components/header/header.css +1 -1
  96. package/nationalarchives/components/header/header.css.map +1 -1
  97. package/nationalarchives/components/header/header.js +1 -1
  98. package/nationalarchives/components/header/header.js.map +1 -1
  99. package/nationalarchives/components/header/header.mjs +32 -41
  100. package/nationalarchives/components/header/header.scss +3 -2
  101. package/nationalarchives/components/header/macro-options.json +6 -0
  102. package/nationalarchives/components/header/template.njk +6 -6
  103. package/nationalarchives/components/hero/analytics.js +26 -0
  104. package/nationalarchives/components/hero/fixtures.json +12 -24
  105. package/nationalarchives/components/hero/hero.css +1 -1
  106. package/nationalarchives/components/hero/hero.css.map +1 -1
  107. package/nationalarchives/components/hero/hero.scss +1 -1
  108. package/nationalarchives/components/index-grid/fixtures.json +8 -16
  109. package/nationalarchives/components/index-grid/index-grid.css +1 -1
  110. package/nationalarchives/components/index-grid/index-grid.css.map +1 -1
  111. package/nationalarchives/components/message/fixtures.json +1 -2
  112. package/nationalarchives/components/message/message.css +1 -1
  113. package/nationalarchives/components/message/message.css.map +1 -1
  114. package/nationalarchives/components/message/message.scss +2 -3
  115. package/nationalarchives/components/message/phase-banner.stories.js +1 -1
  116. package/nationalarchives/components/pagination/fixtures.json +1 -2
  117. package/nationalarchives/components/pagination/macro-options.json +6 -0
  118. package/nationalarchives/components/pagination/pagination.stories.js +44 -0
  119. package/nationalarchives/components/pagination/template.njk +4 -1
  120. package/nationalarchives/components/phase-banner/fixtures.json +4 -8
  121. package/nationalarchives/components/phase-banner/phase-banner.css.map +1 -1
  122. package/nationalarchives/components/picture/analytics.js +30 -0
  123. package/nationalarchives/components/picture/fixtures.json +5 -10
  124. package/nationalarchives/components/picture/picture.css.map +1 -1
  125. package/nationalarchives/components/quick-filters/_index.scss +1 -0
  126. package/nationalarchives/components/quick-filters/fixtures.json +51 -0
  127. package/nationalarchives/components/{filters → quick-filters}/macro-options.json +2 -2
  128. package/nationalarchives/components/quick-filters/macro.njk +3 -0
  129. package/nationalarchives/components/quick-filters/quick-filters.css +1 -0
  130. package/nationalarchives/components/quick-filters/quick-filters.css.map +1 -0
  131. package/nationalarchives/components/{filters/filters.scss → quick-filters/quick-filters.scss} +10 -8
  132. package/nationalarchives/components/{filters/filters.stories.js → quick-filters/quick-filters.stories.js} +2 -2
  133. package/nationalarchives/components/quick-filters/template.njk +8 -0
  134. package/nationalarchives/components/radios/analytics.js +25 -0
  135. package/nationalarchives/components/radios/fixtures.json +6 -12
  136. package/nationalarchives/components/radios/radios.css +1 -1
  137. package/nationalarchives/components/radios/radios.css.map +1 -1
  138. package/nationalarchives/components/radios/radios.njk +12 -0
  139. package/nationalarchives/components/radios/template.njk +6 -13
  140. package/nationalarchives/components/search-field/analytics.js +22 -0
  141. package/nationalarchives/components/search-field/fixtures.json +3 -6
  142. package/nationalarchives/components/search-field/search-field.css +1 -1
  143. package/nationalarchives/components/search-field/search-field.css.map +1 -1
  144. package/nationalarchives/components/search-field/search-field.scss +7 -2
  145. package/nationalarchives/components/search-field/template.njk +4 -4
  146. package/nationalarchives/components/search-filters/_index.scss +1 -0
  147. package/nationalarchives/components/search-filters/fixtures.json +16 -0
  148. package/nationalarchives/components/search-filters/macro-options.json +39 -0
  149. package/nationalarchives/components/search-filters/macro.njk +3 -0
  150. package/nationalarchives/components/search-filters/search-filters.css +1 -0
  151. package/nationalarchives/components/search-filters/search-filters.css.map +1 -0
  152. package/nationalarchives/components/search-filters/search-filters.js +2 -0
  153. package/nationalarchives/components/search-filters/search-filters.js.map +1 -0
  154. package/nationalarchives/components/search-filters/search-filters.mjs +67 -0
  155. package/nationalarchives/components/search-filters/search-filters.scss +163 -0
  156. package/nationalarchives/components/search-filters/search-filters.stories.js +207 -0
  157. package/nationalarchives/components/search-filters/template.njk +107 -0
  158. package/nationalarchives/components/select/fixtures.json +6 -12
  159. package/nationalarchives/components/select/select.css +1 -1
  160. package/nationalarchives/components/select/select.css.map +1 -1
  161. package/nationalarchives/components/select/select.scss +1 -1
  162. package/nationalarchives/components/select/template.njk +4 -4
  163. package/nationalarchives/components/sensitive-image/fixtures.json +3 -6
  164. package/nationalarchives/components/skip-link/fixtures.json +1 -2
  165. package/nationalarchives/components/skip-link/skip-link.css +1 -1
  166. package/nationalarchives/components/skip-link/skip-link.css.map +1 -1
  167. package/nationalarchives/components/skip-link/skip-link.scss +1 -1
  168. package/nationalarchives/components/tabs/fixtures.json +1 -2
  169. package/nationalarchives/components/tabs/tabs.css.map +1 -1
  170. package/nationalarchives/components/text-input/analytics.js +23 -0
  171. package/nationalarchives/components/text-input/fixtures.json +6 -12
  172. package/nationalarchives/components/text-input/template.njk +6 -10
  173. package/nationalarchives/components/text-input/text-input.css +1 -1
  174. package/nationalarchives/components/text-input/text-input.css.map +1 -1
  175. package/nationalarchives/components/text-input/text-input.njk +10 -0
  176. package/nationalarchives/components/text-input/text-input.scss +1 -1
  177. package/nationalarchives/components/textarea/analytics.js +23 -0
  178. package/nationalarchives/components/textarea/fixtures.json +6 -12
  179. package/nationalarchives/components/textarea/template.njk +5 -5
  180. package/nationalarchives/components/textarea/textarea.css +1 -1
  181. package/nationalarchives/components/textarea/textarea.css.map +1 -1
  182. package/nationalarchives/components/textarea/textarea.scss +1 -1
  183. package/nationalarchives/global-header-package.css +1 -1
  184. package/nationalarchives/global-header-package.css.map +1 -1
  185. package/nationalarchives/global-header-package.scss +4 -6
  186. package/nationalarchives/lib/analytics-helpers.mjs +68 -0
  187. package/nationalarchives/lib/cookies.mjs +59 -35
  188. package/nationalarchives/prototype-kit.css +1 -1
  189. package/nationalarchives/prototype-kit.css.map +1 -1
  190. package/nationalarchives/stories/utilities/colour-schemes/colour-themes.stories.js +49 -22
  191. package/nationalarchives/stories/utilities/forms/forms.mdx +6 -6
  192. package/nationalarchives/stories/utilities/tables/tables.stories.js +30 -28
  193. package/nationalarchives/tests/analytics.test.js +11 -0
  194. package/nationalarchives/tests/cookies.test.js +21 -0
  195. package/nationalarchives/tests/uuid.test.js +0 -6
  196. package/nationalarchives/tools/_a11y.scss +11 -2
  197. package/nationalarchives/tools/_colour.scss +47 -14
  198. package/nationalarchives/utilities/_a11y.scss +4 -0
  199. package/nationalarchives/utilities/_forms.scss +7 -1
  200. package/nationalarchives/utilities/_global.scss +3 -1
  201. package/nationalarchives/utilities/_reset.scss +5 -2
  202. package/nationalarchives/utilities/_tables.scss +23 -6
  203. package/nationalarchives/utilities/_typography.scss +5 -21
  204. package/nationalarchives/variables/_a11y.scss +2 -0
  205. package/nationalarchives/variables/_colour.scss +2 -0
  206. package/nationalarchives/variables/_forms.scss +1 -1
  207. package/nationalarchives/variables/_index.scss +1 -0
  208. package/package.json +2 -2
  209. package/nationalarchives/components/filters/_index.scss +0 -1
  210. package/nationalarchives/components/filters/filters.css +0 -1
  211. package/nationalarchives/components/filters/filters.css.map +0 -1
  212. package/nationalarchives/components/filters/fixtures.json +0 -51
  213. package/nationalarchives/components/filters/macro.njk +0 -3
  214. package/nationalarchives/components/filters/template.njk +0 -8
@@ -0,0 +1,163 @@
1
+ @use "sass:math";
2
+
3
+ @use "../../tools/colour";
4
+ @use "../../tools/media";
5
+ @use "../../tools/spacing";
6
+ @use "../../tools/typography";
7
+
8
+ .tna-search-filters {
9
+ @include spacing.space-above;
10
+
11
+ &__title {
12
+ }
13
+
14
+ &__update {
15
+ display: block;
16
+ }
17
+
18
+ .tna-heading-s {
19
+ margin: 0;
20
+ padding: 0;
21
+ }
22
+
23
+ &__fieldset {
24
+ border: none;
25
+ }
26
+
27
+ &__legend {
28
+ width: 100%;
29
+ }
30
+
31
+ &__heading-inner,
32
+ &__item-toggle {
33
+ padding: 0.5rem 0.75rem;
34
+
35
+ @include colour.colour-border("keyline", 1px, solid);
36
+ border-bottom-width: 0;
37
+ }
38
+
39
+ &__heading-inner {
40
+ margin-top: 1rem;
41
+ padding: 0.5rem 0.75rem;
42
+ }
43
+
44
+ &__item-toggle {
45
+ width: 100%;
46
+ margin: 0;
47
+ padding-right: 2.5rem;
48
+
49
+ display: block;
50
+
51
+ position: relative;
52
+
53
+ color: inherit;
54
+ font-family: inherit;
55
+ font-size: inherit;
56
+ font-weight: inherit;
57
+ line-height: inherit;
58
+ text-align: inherit;
59
+
60
+ background: none;
61
+
62
+ cursor: pointer;
63
+
64
+ &::before {
65
+ width: 0;
66
+ height: 0;
67
+
68
+ position: absolute;
69
+ right: 0.5rem;
70
+ top: calc(50% - #{math.div(math.sqrt(3), 4)}rem);
71
+
72
+ @include colour.colour-border(
73
+ "font-base",
74
+ #{math.div(math.sqrt(3), 2)}rem
75
+ );
76
+ border-right: 0.5rem transparent solid;
77
+ border-bottom-width: 0;
78
+ border-left: 0.5rem transparent solid;
79
+
80
+ content: "";
81
+ }
82
+
83
+ &:hover,
84
+ &:active {
85
+ @include typography.interacted-text-decoration;
86
+
87
+ background: none;
88
+ }
89
+
90
+ &[aria-expanded="true"] {
91
+ &::before {
92
+ border-top-width: 0;
93
+ border-bottom-width: #{math.div(math.sqrt(3), 2)}rem;
94
+ }
95
+ }
96
+ }
97
+
98
+ &__item-toggle-label {
99
+ }
100
+
101
+ &__item-toggle-info {
102
+ display: block;
103
+
104
+ @include typography.main-font-weight;
105
+ @include typography.relative-font-size(14);
106
+ }
107
+
108
+ &__item {
109
+ padding: 0.75rem;
110
+
111
+ @include colour.colour-background("background-tint");
112
+
113
+ @include colour.colour-border("keyline", 1px);
114
+ border-width: 0 1px 1px;
115
+ }
116
+
117
+ &__hint {
118
+ margin-bottom: 0.5rem;
119
+
120
+ @include typography.relative-font-size(16);
121
+ @include colour.colour-font("font-light");
122
+ }
123
+
124
+ &__inline-fields {
125
+ display: flex;
126
+ flex-wrap: wrap;
127
+ gap: 0.5rem 2rem;
128
+ }
129
+
130
+ &__label {
131
+ display: block;
132
+ }
133
+
134
+ &__footer {
135
+ padding: 0.75rem;
136
+
137
+ display: none;
138
+
139
+ @include colour.colour-border("keyline", 1px);
140
+ }
141
+
142
+ &--js-enabled &__title {
143
+ margin-bottom: 1rem;
144
+ }
145
+
146
+ &--js-enabled &__footer {
147
+ display: block;
148
+ }
149
+
150
+ &--js-enabled &__item {
151
+ border-bottom: none;
152
+ }
153
+
154
+ &--js-enabled &__update-item {
155
+ display: none;
156
+ }
157
+
158
+ &__fieldset[data-type="multiple"] &__item {
159
+ max-height: 15rem;
160
+
161
+ overflow: auto;
162
+ }
163
+ }
@@ -0,0 +1,207 @@
1
+ import Filters from "./template.njk";
2
+ import macroOptions from "./macro-options.json";
3
+
4
+ const argTypes = {
5
+ title: { control: "text" },
6
+ rootHeadingLevel: { control: { type: "number", min: 1, max: 6 } },
7
+ formId: { control: "text" },
8
+ items: { control: "object" },
9
+ classes: { control: "text" },
10
+ attributes: { control: "object" },
11
+ };
12
+
13
+ Object.keys(argTypes).forEach((argType) => {
14
+ argTypes[argType].description = macroOptions.find(
15
+ (option) => option.name === argType,
16
+ )?.description;
17
+ });
18
+
19
+ export default {
20
+ title: "Components/Search filters",
21
+ argTypes,
22
+ };
23
+
24
+ const Template = ({
25
+ title,
26
+ rootHeadingLevel,
27
+ formId,
28
+ items,
29
+ classes,
30
+ attributes,
31
+ }) =>
32
+ Filters({
33
+ params: {
34
+ title,
35
+ rootHeadingLevel,
36
+ formId,
37
+ items,
38
+ classes,
39
+ attributes,
40
+ },
41
+ });
42
+
43
+ export const Standard = Template.bind({});
44
+ Standard.args = {
45
+ title: "Filters",
46
+ rootHeadingLevel: 2,
47
+ formId: "test-form",
48
+ items: [
49
+ {
50
+ type: "text",
51
+ label: "Refine",
52
+ id: "refine1",
53
+ name: "refine1",
54
+ // open: true,
55
+ hint: "Search within the current results",
56
+ },
57
+ // {
58
+ // type: "single",
59
+ // label: "Type",
60
+ // id: "type1",
61
+ // name: "type1",
62
+ // small: true,
63
+ // // open: true,
64
+ // hint: "You can only select one.",
65
+ // items: [
66
+ // {
67
+ // text: "Audio",
68
+ // value: "audio",
69
+ // },
70
+ // {
71
+ // text: "Image",
72
+ // value: "image",
73
+ // },
74
+ // {
75
+ // text: "Video",
76
+ // value: "video",
77
+ // },
78
+ // ],
79
+ // },
80
+ {
81
+ type: "multiple",
82
+ label: "Category",
83
+ id: "categories1",
84
+ name: "categories1",
85
+ small: true,
86
+ // open: true,
87
+ hint: "The category of the record",
88
+ // count: 2,
89
+ seeMoreText: "See all 29 categories",
90
+ seeMoreUrl: "#",
91
+ items: [
92
+ {
93
+ text: "Alpha",
94
+ value: "alpha",
95
+ },
96
+ {
97
+ text: "Beta",
98
+ value: "beta",
99
+ // checked: true,
100
+ },
101
+ {
102
+ text: "Gamma",
103
+ value: "gamma",
104
+ },
105
+ ],
106
+ },
107
+ {
108
+ type: "date",
109
+ label: "Opening date",
110
+ id: "date1",
111
+ name: "date1",
112
+ hint: "The earliest opening date of the record",
113
+ },
114
+ {
115
+ type: "daterange",
116
+ label: "Covering date",
117
+ id: "dates",
118
+ hint: "The earliest and/or latest covering date of the record",
119
+ // open: true,
120
+ from: {
121
+ label: "From",
122
+ id: "date2",
123
+ name: "date2",
124
+ },
125
+ to: {
126
+ label: "To",
127
+ id: "date3",
128
+ name: "date3",
129
+ },
130
+ },
131
+ ],
132
+ classes: "tna-search-filters--demo",
133
+ };
134
+
135
+ export const OpenedAndPrepopulated = Template.bind({});
136
+ OpenedAndPrepopulated.args = {
137
+ title: "Filters",
138
+ rootHeadingLevel: 2,
139
+ formId: "test-form",
140
+ items: [
141
+ {
142
+ type: "text",
143
+ label: "Refine",
144
+ id: "refine1",
145
+ name: "refine1",
146
+ open: true,
147
+ hint: "Search within the current results",
148
+ value: "iceberg",
149
+ },
150
+ {
151
+ type: "multiple",
152
+ label: "Category",
153
+ id: "categories1",
154
+ name: "categories1",
155
+ small: true,
156
+ open: true,
157
+ hint: "The category of the record",
158
+ seeMoreText: "See all 29 categories",
159
+ seeMoreUrl: "#",
160
+ items: [
161
+ {
162
+ text: "Alpha",
163
+ value: "alpha",
164
+ },
165
+ {
166
+ text: "Beta",
167
+ value: "beta",
168
+ checked: true,
169
+ },
170
+ {
171
+ text: "Gamma",
172
+ value: "gamma",
173
+ checked: true,
174
+ },
175
+ ],
176
+ },
177
+ {
178
+ type: "date",
179
+ label: "Opening date",
180
+ id: "date1",
181
+ name: "date1",
182
+ hint: "The earliest opening date of the record",
183
+ open: true,
184
+ value: "1969-07-16",
185
+ },
186
+ {
187
+ type: "daterange",
188
+ label: "Covering date",
189
+ id: "dates",
190
+ hint: "The earliest and/or latest covering date of the record",
191
+ open: true,
192
+ from: {
193
+ label: "From",
194
+ id: "date2",
195
+ name: "date2",
196
+ value: "1912-04-14",
197
+ },
198
+ to: {
199
+ label: "To",
200
+ id: "date3",
201
+ name: "date3",
202
+ value: "1912-04-15",
203
+ },
204
+ },
205
+ ],
206
+ classes: "tna-search-filters--demo",
207
+ };
@@ -0,0 +1,107 @@
1
+ {% from "nationalarchives/components/button/macro.njk" import tnaButton %}
2
+ {% from "nationalarchives/components/checkboxes/checkboxes.njk" import tnaCheckboxesElement %}
3
+ {% from "nationalarchives/components/date-search/date-search.njk" import tnaDateSearchElement %}
4
+ {% from "nationalarchives/components/radios/radios.njk" import tnaRadiosElement %}
5
+ {% from "nationalarchives/components/text-input/text-input.njk" import tnaTextInputElement %}
6
+
7
+ {%- set containerClasses = [params.classes] if params.classes else [] -%}
8
+ <div class="tna-search-filters {{ containerClasses | join(' ') }}" data-module="tna-search-filters"{% for attribute, value in params.attributes %} {{ attribute }}="{{ value }}"{% endfor %}>
9
+ <h{{ params.rootHeadingLevel }} class="tna-heading-m tna-search-filters__title">
10
+ {{ params.title }}
11
+ </h{{ params.rootHeadingLevel }}>
12
+ {%- for filter in params.items %}
13
+ <fieldset class="tna-search-filters__fieldset" {%- if filter.hint and (filter.type == 'single' or filter.type == 'multiple' or filter.type == 'daterange') %} aria-describedby="{{ filter.id }}-hint"{% endif %} data-type="{{ filter.type }}">
14
+ <legend class="tna-search-filters__legend">
15
+ <h{{ params.rootHeadingLevel + 1 }} class="tna-heading-s">
16
+ <div class="tna-search-filters__heading-inner">
17
+ {% if filter.type == 'single' or filter.type == 'multiple' or filter.type == 'daterange' %}
18
+ {{ filter.label }}
19
+ {% else %}
20
+ <label for="{{ filter.id }}">
21
+ {{ filter.label }}
22
+ </label>
23
+ {% endif %}
24
+ </div>
25
+ <button class="tna-search-filters__item-toggle" aria-controls="{{ filter.id }}-wrapper" aria-expanded="{{ filter.open or false }}" hidden>
26
+ {% if filter.type == 'single' or filter.type == 'multiple' or filter.type == 'daterange' %}
27
+ <span class="tna-search-filters__item-toggle-label">
28
+ {{ filter.label }}
29
+ </span>
30
+ {% else %}
31
+ <label class="tna-search-filters__item-toggle-label" for="{{ filter.id }}">
32
+ {{ filter.label }}
33
+ </label>
34
+ {% endif %}
35
+ {% if filter.count %}
36
+ <span class="tna-search-filters__item-toggle-info">({{ filter.count }} selected)</span>
37
+ {% else %}
38
+ <span class="tna-search-filters__item-toggle-info"></span>
39
+ {% endif %}
40
+ </button>
41
+ </h{{ params.rootHeadingLevel + 1 }}>
42
+ </legend>
43
+ <div id="{{ filter.id }}-wrapper" class="tna-search-filters__item">
44
+ {%- if filter.hint %}
45
+ <p id="{{ filter.id }}-hint" class="tna-search-filters__hint">
46
+ {{ filter.hint }}
47
+ </p>
48
+ {%- endif %}
49
+ {% if filter.type == 'single' %}
50
+ {{ tnaRadiosElement(filter, { form: params.formId }) }}
51
+ {% elif filter.type == 'multiple' %}
52
+ {{ tnaCheckboxesElement(filter, { form: params.formId }) }}
53
+ <div class="tna-button-group tna-button-group--small tna-!--margin-top-xs">
54
+ {{ tnaButton({
55
+ text: filter.seeMoreText or 'See more',
56
+ href: filter.seeMoreUrl,
57
+ plain: true
58
+ }) }}
59
+ </div>
60
+ {% elif filter.type == 'text' %}
61
+ {{ tnaTextInputElement(filter, { form: params.formId }) }}
62
+ {% elif filter.type == 'date' %}
63
+ {{ tnaDateSearchElement(filter, { form: params.formId }) }}
64
+ {% elif filter.type == 'daterange' %}
65
+ <div class="tna-search-filters__inline-fields">
66
+ <label class="tna-search-filters__label">
67
+ {{ filter.from.label }}
68
+ {{ tnaDateSearchElement(filter.from, { form: params.formId }) }}
69
+ </label>
70
+ <label class="tna-search-filters__label">
71
+ {{ filter.to.label }}
72
+ {{ tnaDateSearchElement(filter.to, { form: params.formId }) }}
73
+ </label>
74
+ </div>
75
+ {% endif %}
76
+ <div class="tna-button-group tna-button-group--small tna-search-filters__update-item tna-!--margin-top-s">
77
+ {{ tnaButton({
78
+ text: 'Update',
79
+ buttonElement: true,
80
+ buttonType: 'submit',
81
+ attributes: {
82
+ form: params.formId
83
+ }
84
+ }) }}
85
+ </div>
86
+ </div>
87
+ </fieldset>
88
+ {%- endfor %}
89
+ <div class="tna-search-filters__footer">
90
+ <div class="tna-button-group tna-button-group--small">
91
+ {{ tnaButton({
92
+ text: 'Update',
93
+ buttonElement: true,
94
+ buttonType: 'submit',
95
+ classes: 'tna-search-filters__update',
96
+ attributes: {
97
+ form: params.formId
98
+ }
99
+ }) }}
100
+ {{ tnaButton({
101
+ text: 'Clear all filters',
102
+ href: '#',
103
+ plain: true
104
+ }) }}
105
+ </div>
106
+ </div>
107
+ </div>
@@ -24,8 +24,7 @@
24
24
  }
25
25
  ]
26
26
  },
27
- "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"tna-form__sort\">Sort by</label></h4></div><select class=\"tna-select \" name=\"sort\" id=\"tna-form__sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>",
28
- "hidden": false
27
+ "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"sort\">Sort by</label></h4></div><select class=\"tna-select \" name=\"sort\" id=\"sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>"
29
28
  },
30
29
  {
31
30
  "name": "select with a preselected value",
@@ -51,8 +50,7 @@
51
50
  ],
52
51
  "selected": "date"
53
52
  },
54
- "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"tna-form__sort\">Sort by</label></h4></div><select class=\"tna-select \" name=\"sort\" id=\"tna-form__sort\"><option value=\"relevance\">Relevance</option><option value=\"date\" selected>Date</option><option value=\"title\">Title</option></select></div>",
55
- "hidden": false
53
+ "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"sort\">Sort by</label></h4></div><select class=\"tna-select \" name=\"sort\" id=\"sort\"><option value=\"relevance\">Relevance</option><option value=\"date\" selected>Date</option><option value=\"title\">Title</option></select></div>"
56
54
  },
57
55
  {
58
56
  "name": "select with a hint",
@@ -78,8 +76,7 @@
78
76
  }
79
77
  ]
80
78
  },
81
- "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"tna-form__sort\">Sort by</label></h4><p id=\"tna-form__sort-hint\" class=\"tna-form__hint\">Select a field to sort by.</p></div><select class=\"tna-select \" name=\"sort\" id=\"tna-form__sort\" aria-describedby=\"tna-form__sort-hint\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>",
82
- "hidden": false
79
+ "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"sort\">Sort by</label></h4><p id=\"sort-hint\" class=\"tna-form__hint\">Select a field to sort by.</p></div><select class=\"tna-select \" name=\"sort\" id=\"sort\" aria-describedby=\"sort-hint\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>"
83
80
  },
84
81
  {
85
82
  "name": "select with an error",
@@ -107,8 +104,7 @@
107
104
  }
108
105
  ]
109
106
  },
110
- "html": "<div class=\"tna-form__group tna-form__group--error \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"tna-form__sort\">Sort by</label></h4><p id=\"tna-form__sort-error\" class=\"tna-form__error-message\"><span class=\"tna-!--visually-hidden\">Error:</span> You must select a field to sort by</p></div><select class=\"tna-select \" name=\"sort\" id=\"tna-form__sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>",
111
- "hidden": false
107
+ "html": "<div class=\"tna-form__group tna-form__group--error \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"sort\">Sort by</label></h4><p id=\"sort-error\" class=\"tna-form__error-message\"><span class=\"tna-!--visually-hidden\">Error:</span> You must select a field to sort by</p></div><select class=\"tna-select \" name=\"sort\" id=\"sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>"
112
108
  },
113
109
  {
114
110
  "name": "inline select",
@@ -134,8 +130,7 @@
134
130
  ],
135
131
  "inline": true
136
132
  },
137
- "html": "<div class=\"tna-form__group tna-form__group--inline\"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"tna-form__sort\">Sort by</label></h4></div><select class=\"tna-select \" name=\"sort\" id=\"tna-form__sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>",
138
- "hidden": false
133
+ "html": "<div class=\"tna-form__group tna-form__group--inline\"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"sort\">Sort by</label></h4></div><select class=\"tna-select \" name=\"sort\" id=\"sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>"
139
134
  },
140
135
  {
141
136
  "name": "select size",
@@ -161,8 +156,7 @@
161
156
  ],
162
157
  "size": "xl"
163
158
  },
164
- "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"tna-form__sort\">Sort by</label></h4></div><select class=\"tna-select tna-select--xl \" name=\"sort\" id=\"tna-form__sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>",
165
- "hidden": false
159
+ "html": "<div class=\"tna-form__group \"><div class=\"tna-form__group-contents\"><h4 class=\"tna-form__heading tna-form__heading--m\"><label class=\"tna-form__label\" for=\"sort\">Sort by</label></h4></div><select class=\"tna-select tna-select--xl \" name=\"sort\" id=\"sort\"><option value=\"relevance\">Relevance</option><option value=\"date\">Date</option><option value=\"title\">Title</option></select></div>"
166
160
  }
167
161
  ]
168
162
  }
@@ -1 +1 @@
1
- .tna-select{--page-background: #f4f4f4;--background-tint: #e4e4e4;--font-base: #343338;--font-dark: rgb(0, 0, 0);--font-light: rgb(0 0 0/0.58);--icon-light: rgb(52 51 56/0.45);--link: #0062a8;--link-visited: #4c2c92;--focus-outline: rgb(0, 176, 255);--keyline: rgb(38 38 42/0.25);--keyline-dark: #26262a;--input-foreground: rgb(0, 0, 0);--input-background: rgb(255, 255, 255);--input-border: rgb(0, 0, 0);--form-error: #c00;--button-text: rgb(255, 255, 255);--button-background: rgb(0, 0, 0);--button-hover-text: rgb(0, 0, 0);--button-hover-background: rgb(255, 255, 255);--contrast-background: #1e1e1e;--contrast-font-base: rgb(255, 255, 255);--contrast-font-dark: rgb(255, 255, 255);--contrast-font-light: rgb(255 255 255/0.7);--contrast-icon-light: rgb(255 255 255/0.45);--contrast-link: rgb(255, 255, 255);--contrast-link-visited: rgb(255, 255, 255);--contrast-keyline: rgb(255 255 255/0.5);--contrast-keyline-dark: rgb(255 255 255/0.8);--contrast-button-text: rgb(0, 0, 0);--contrast-button-background: rgb(255, 255, 255);--contrast-button-hover-text: rgb(255, 255, 255);--contrast-button-hover-background: rgb(0, 0, 0);--accent-background: #111;--accent-background-light: #ededed;--accent-font-base: rgb(255, 255, 255);--accent-font-dark: rgb(255, 255, 255);--accent-font-light: rgb(255 255 255/0.7);--accent-icon-light: rgb(255 255 255/0.45);--accent-link: rgb(255, 255, 255);--accent-link-visited: #b9f;--accent-keyline: rgb(255 255 255/0.5);--accent-keyline-dark: rgb(255 255 255/0.8);--button-accent-text: rgb(0, 0, 0);--button-accent-background: rgb(140, 150, 148)}@media(prefers-contrast: more){.tna-select{--page-background: rgb(255, 255, 255);--background-tint: #e4e4e4;--font-base: rgb(0, 0, 0);--font-dark: rgb(0, 0, 0);--font-light: rgb(0, 0, 0);--icon-light: rgb(0 0 0/0.75);--link: #34d;--link-visited: #848;--focus-outline: rgb(253, 63, 3);--keyline: rgb(0, 0, 0);--keyline-dark: rgb(0, 0, 0);--input-foreground: rgb(0, 0, 0);--input-background: rgb(255, 255, 255);--input-border: rgb(0, 0, 0);--form-error: #c00;--button-text: rgb(255, 255, 255);--button-background: rgb(0, 0, 0);--button-hover-text: rgb(0, 0, 0);--button-hover-background: rgb(255, 255, 255);--contrast-background: #f4f4f4;--contrast-font-base: rgb(0, 0, 0);--contrast-font-dark: rgb(0, 0, 0);--contrast-font-light: rgb(0, 0, 0);--contrast-icon-light: rgb(255 255 255/0.45);--contrast-link: #34d;--contrast-link-visited: #848;--contrast-keyline: rgb(0, 0, 0);--contrast-keyline-dark: rgb(0, 0, 0);--contrast-button-text: rgb(255, 255, 255);--contrast-button-background: rgb(0, 0, 0);--contrast-button-hover-text: rgb(0, 0, 0);--contrast-button-hover-background: rgb(255, 255, 255);--accent-background: #111;--accent-background-light: #ededed;--accent-font-base: rgb(255, 255, 255);--accent-font-dark: rgb(255, 255, 255);--accent-font-light: rgb(255 255 255/0.7);--accent-icon-light: rgb(255 255 255/0.45);--accent-link: rgb(255, 255, 255);--accent-link-visited: #b9f;--accent-keyline: rgb(255 255 255/0.5);--accent-keyline-dark: rgb(255 255 255/0.8);--button-accent-text: rgb(0, 0, 0);--button-accent-background: rgb(140, 150, 148)}}.tna-template--high-contrast-theme .tna-select{--page-background: rgb(255, 255, 255);--background-tint: #e4e4e4;--font-base: rgb(0, 0, 0);--font-dark: rgb(0, 0, 0);--font-light: rgb(0, 0, 0);--icon-light: rgb(0 0 0/0.75);--link: #34d;--link-visited: #848;--focus-outline: rgb(253, 63, 3);--keyline: rgb(0, 0, 0);--keyline-dark: rgb(0, 0, 0);--input-foreground: rgb(0, 0, 0);--input-background: rgb(255, 255, 255);--input-border: rgb(0, 0, 0);--form-error: #c00;--button-text: rgb(255, 255, 255);--button-background: rgb(0, 0, 0);--button-hover-text: rgb(0, 0, 0);--button-hover-background: rgb(255, 255, 255);--contrast-background: #f4f4f4;--contrast-font-base: rgb(0, 0, 0);--contrast-font-dark: rgb(0, 0, 0);--contrast-font-light: rgb(0, 0, 0);--contrast-icon-light: rgb(255 255 255/0.45);--contrast-link: #34d;--contrast-link-visited: #848;--contrast-keyline: rgb(0, 0, 0);--contrast-keyline-dark: rgb(0, 0, 0);--contrast-button-text: rgb(255, 255, 255);--contrast-button-background: rgb(0, 0, 0);--contrast-button-hover-text: rgb(0, 0, 0);--contrast-button-hover-background: rgb(255, 255, 255);--accent-background: #111;--accent-background-light: #ededed;--accent-font-base: rgb(255, 255, 255);--accent-font-dark: rgb(255, 255, 255);--accent-font-light: rgb(255 255 255/0.7);--accent-icon-light: rgb(255 255 255/0.45);--accent-link: rgb(255, 255, 255);--accent-link-visited: #b9f;--accent-keyline: rgb(255 255 255/0.5);--accent-keyline-dark: rgb(255 255 255/0.8);--button-accent-text: rgb(0, 0, 0);--button-accent-background: rgb(140, 150, 148)}.tna-select{max-width:100%;height:calc(2rem + 6px);padding:0 1rem 0 .5rem;display:block;color:#000;color:var(--input-foreground);font-size:inherit;line-height:2rem;background-color:#fff;background-color:var(--input-background);border:1px #000 solid;border:1px var(--input-border) solid;border-radius:0}.tna-select--styled{padding:0 2.5rem 0 .75rem;appearance:none;background-image:url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjUwMHB4IiBoZWlnaHQ9IjUwMHB4IiB2aWV3Qm94PSIwIDAgNTAwIDUwMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNTAwIDUwMCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHBvbHlnb24gcG9pbnRzPSIyNTAsNDAwIDUwLDEwMCA0NTAsMTAwIiBmaWxsPSIjMDAwIi8+PC9zdmc+");background-position:center right .5rem;background-size:.75rem .75rem;background-repeat:no-repeat}.tna-form__group--error .tna-select{border-color:#c00;border-color:var(--form-error)}.tna-select--s{width:10rem}.tna-select--m{width:20rem}.tna-select--l{width:40rem}.tna-select--xl{width:80rem}/*# sourceMappingURL=select.css.map */
1
+ .tna-select{--page-background: #f4f4f4;--background-tint: #e4e4e4;--font-base: #343338;--font-dark: rgb(0, 0, 0);--font-light: rgb(0 0 0/0.58);--icon-light: rgb(52 51 56/0.45);--link: #0062a8;--link-visited: #4c2c92;--focus-outline: rgb(0, 176, 255);--keyline: rgb(38 38 42/0.25);--keyline-dark: #26262a;--input-foreground: rgb(0, 0, 0);--input-background: rgb(255, 255, 255);--input-border: rgb(0, 0, 0);--button-text: rgb(255, 255, 255);--button-background: rgb(0, 0, 0);--button-hover-text: rgb(0, 0, 0);--button-hover-background: rgb(255, 255, 255);--contrast-background: #1e1e1e;--contrast-font-base: rgb(255, 255, 255);--contrast-font-dark: rgb(255, 255, 255);--contrast-font-light: rgb(255 255 255/0.7);--contrast-icon-light: rgb(255 255 255/0.45);--contrast-link: rgb(255, 255, 255);--contrast-link-visited: rgb(255, 255, 255);--contrast-keyline: rgb(255 255 255/0.5);--contrast-keyline-dark: rgb(255 255 255/0.8);--contrast-button-text: rgb(0, 0, 0);--contrast-button-background: rgb(255, 255, 255);--contrast-button-hover-text: rgb(255, 255, 255);--contrast-button-hover-background: rgb(0, 0, 0);--accent-background: #111;--accent-background-light: #ededed;--accent-font-base: rgb(255, 255, 255);--accent-font-dark: rgb(255, 255, 255);--accent-font-light: rgb(255 255 255/0.7);--accent-icon-light: rgb(255 255 255/0.45);--accent-link: rgb(255, 255, 255);--accent-link-visited: #b9f;--accent-keyline: rgb(255 255 255/0.5);--accent-keyline-dark: rgb(255 255 255/0.8);--button-accent-text: rgb(0, 0, 0);--button-accent-background: rgb(140, 150, 148)}@media(prefers-contrast: more){.tna-select{--page-background: rgb(255, 255, 255);--background-tint: #e4e4e4;--font-base: rgb(0, 0, 0);--font-dark: rgb(0, 0, 0);--font-light: rgb(0, 0, 0);--icon-light: rgb(0 0 0/0.75);--link: #34d;--link-visited: #848;--focus-outline: rgb(253, 63, 3);--keyline: rgb(0, 0, 0);--keyline-dark: rgb(0, 0, 0);--input-foreground: rgb(0, 0, 0);--input-background: rgb(255, 255, 255);--input-border: rgb(0, 0, 0);--button-text: rgb(255, 255, 255);--button-background: rgb(0, 0, 0);--button-hover-text: rgb(0, 0, 0);--button-hover-background: rgb(255, 255, 255);--contrast-background: #f4f4f4;--contrast-font-base: rgb(0, 0, 0);--contrast-font-dark: rgb(0, 0, 0);--contrast-font-light: rgb(0, 0, 0);--contrast-icon-light: rgb(255 255 255/0.45);--contrast-link: #34d;--contrast-link-visited: #848;--contrast-keyline: rgb(0, 0, 0);--contrast-keyline-dark: rgb(0, 0, 0);--contrast-button-text: rgb(255, 255, 255);--contrast-button-background: rgb(0, 0, 0);--contrast-button-hover-text: rgb(0, 0, 0);--contrast-button-hover-background: rgb(255, 255, 255);--accent-background: #111;--accent-background-light: #ededed;--accent-font-base: rgb(255, 255, 255);--accent-font-dark: rgb(255, 255, 255);--accent-font-light: rgb(255 255 255/0.7);--accent-icon-light: rgb(255 255 255/0.45);--accent-link: rgb(255, 255, 255);--accent-link-visited: #b9f;--accent-keyline: rgb(255 255 255/0.5);--accent-keyline-dark: rgb(255 255 255/0.8);--button-accent-text: rgb(0, 0, 0);--button-accent-background: rgb(140, 150, 148)}}.tna-template--high-contrast-theme .tna-select{--page-background: rgb(255, 255, 255);--background-tint: #e4e4e4;--font-base: rgb(0, 0, 0);--font-dark: rgb(0, 0, 0);--font-light: rgb(0, 0, 0);--icon-light: rgb(0 0 0/0.75);--link: #34d;--link-visited: #848;--focus-outline: rgb(253, 63, 3);--keyline: rgb(0, 0, 0);--keyline-dark: rgb(0, 0, 0);--input-foreground: rgb(0, 0, 0);--input-background: rgb(255, 255, 255);--input-border: rgb(0, 0, 0);--button-text: rgb(255, 255, 255);--button-background: rgb(0, 0, 0);--button-hover-text: rgb(0, 0, 0);--button-hover-background: rgb(255, 255, 255);--contrast-background: #f4f4f4;--contrast-font-base: rgb(0, 0, 0);--contrast-font-dark: rgb(0, 0, 0);--contrast-font-light: rgb(0, 0, 0);--contrast-icon-light: rgb(255 255 255/0.45);--contrast-link: #34d;--contrast-link-visited: #848;--contrast-keyline: rgb(0, 0, 0);--contrast-keyline-dark: rgb(0, 0, 0);--contrast-button-text: rgb(255, 255, 255);--contrast-button-background: rgb(0, 0, 0);--contrast-button-hover-text: rgb(0, 0, 0);--contrast-button-hover-background: rgb(255, 255, 255);--accent-background: #111;--accent-background-light: #ededed;--accent-font-base: rgb(255, 255, 255);--accent-font-dark: rgb(255, 255, 255);--accent-font-light: rgb(255 255 255/0.7);--accent-icon-light: rgb(255 255 255/0.45);--accent-link: rgb(255, 255, 255);--accent-link-visited: #b9f;--accent-keyline: rgb(255 255 255/0.5);--accent-keyline-dark: rgb(255 255 255/0.8);--button-accent-text: rgb(0, 0, 0);--button-accent-background: rgb(140, 150, 148)}.tna-select{max-width:100%;height:calc(2rem + 6px);padding:0 1rem 0 .5rem;display:block;color:#000;color:var(--input-foreground);font-size:inherit;line-height:2rem;background-color:#fff;background-color:var(--input-background);border:2px #000 solid;border:2px var(--input-border) solid;border-radius:.1px}.tna-select--styled{padding:0 2.5rem 0 .75rem;appearance:none;background-image:url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjUwMHB4IiBoZWlnaHQ9IjUwMHB4IiB2aWV3Qm94PSIwIDAgNTAwIDUwMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNTAwIDUwMCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHBvbHlnb24gcG9pbnRzPSIyNTAsNDAwIDUwLDEwMCA0NTAsMTAwIiBmaWxsPSIjMDAwIi8+PC9zdmc+");background-position:center right .5rem;background-size:.75rem .75rem;background-repeat:no-repeat}.tna-form__group--error .tna-select{border-color:#c00;border-color:var(--form-error)}.tna-select--s{width:10rem}.tna-select--m{width:20rem}.tna-select--l{width:40rem}.tna-select--xl{width:80rem}/*# sourceMappingURL=select.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../../../src/nationalarchives/tools/_colour.scss","../../../../src/nationalarchives/components/select/select.scss"],"names":[],"mappings":"AAwJA,YA9II,4hDAiJF,+BAHF,YAlII,+9CAyIF,+CAzIE,89CCnBJ,YACE,eACA,wBACA,uBAEA,cDwEA,WACA,8BCrEA,kBACA,iBDwEA,sBAEA,yCAgCI,sBAIA,qCCzGJ,gBAEA,oBACE,0BAEA,gBAEA,+lBACA,uCACA,8BACA,4BAGF,oCD8FI,kBAEA,+BC5FJ,eACE,YAGF,eACE,YAGF,eACE,YAGF,gBACE","file":"select.css","sourcesContent":["@use \"sass:map\";\n@use \"../variables/colour\";\n@use \"../tools/media\";\n\n@function brand-colour($colour, $opacity: 1) {\n @return colour.brand-colour($colour, $opacity);\n}\n\n@mixin colour-css-vars() {\n @each $name, $value in colour.$colour-palette-default {\n --#{$name}: #{$value};\n }\n}\n\n@mixin colour-css-vars-dark() {\n @each $name, $value in colour.$colour-palette-dark {\n --#{$name}: #{$value};\n }\n}\n\n@mixin colour-css-vars-high-contrast() {\n @each $name, $value in colour.$colour-palette-high-contrast {\n --#{$name}: #{$value};\n }\n}\n\n@mixin colour-css-vars-high-contrast-dark() {\n @each $name, $value in colour.$colour-palette-high-contrast-dark {\n --#{$name}: #{$value};\n }\n}\n\n@mixin accent-css-vars($colour) {\n @if $colour == \"yellow\" {\n --accent-background: #{brand-colour(\"yellow\")} !important;\n --accent-background-light: #{brand-colour(\"cream\")} !important;\n --accent-font-base: #{brand-colour(\"black\")} !important;\n --accent-font-dark: #{brand-colour(\"black\")} !important;\n --accent-font-light: #{brand-colour(\"black\", 0.7)} !important;\n --accent-icon-light: #{brand-colour(\"black\", 0.45)} !important;\n --accent-link: #{brand-colour(\"black\")} !important;\n --accent-link-visited: #{brand-colour(\"black\")} !important;\n --accent-keyline: #{brand-colour(\"black\", 0.5)} !important;\n --accent-keyline-dark: #{brand-colour(\"black\", 0.8)} !important;\n --button-accent-background: #{brand-colour(\"yellow\")} !important;\n } @else {\n --accent-font-base: #{brand-colour(\"white\")} !important;\n --accent-font-dark: #{brand-colour(\"white\")} !important;\n --accent-font-light: #{brand-colour(\"white\", 0.7)} !important;\n --accent-icon-light: #{brand-colour(\"white\", 0.45)} !important;\n --accent-link: #{brand-colour(\"white\")} !important;\n --accent-link-visited: #{brand-colour(\"white\")} !important;\n --accent-keyline: #{brand-colour(\"white\", 0.5)} !important;\n --accent-keyline-dark: #{brand-colour(\"white\", 0.8)} !important;\n --button-accent-text: #{brand-colour(\"white\")} !important;\n @if $colour == \"pink\" {\n --accent-background: #{brand-colour(\"maroon\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-pink\")} !important;\n --button-accent-background: #{brand-colour(\"maroon\")} !important;\n } @else if $colour == \"orange\" {\n --accent-background: #{brand-colour(\"chestnut\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-orange\")} !important;\n --button-accent-background: #{brand-colour(\"chestnut\")} !important;\n } @else if $colour == \"green\" {\n --accent-background: #{brand-colour(\"forest\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-green\")} !important;\n --button-accent-background: #{brand-colour(\"forest\")} !important;\n } @else if $colour == \"blue\" {\n --accent-background: #{brand-colour(\"navy\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-blue\")} !important;\n --button-accent-background: #{brand-colour(\"navy\")} !important;\n }\n }\n}\n\n@mixin colour-font(\n $colour,\n $important: false,\n $default-palette: colour.$colour-palette-default\n) {\n color: map.get($default-palette, $colour) if($important, !important, null);\n color: var(--#{$colour}) if($important, !important, null);\n}\n\n@mixin colour-background($colour, $important: false) {\n background-color: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n background-color: var(--#{$colour}) if($important, !important, null);\n}\n\n@mixin colour-border(\n $colour,\n $width: \"\",\n $style: solid,\n $direction: \"\",\n $important: false\n) {\n @if $direction != \"\" {\n @if $width != \"\" {\n $property: border-#{$direction};\n border-#{$direction}: $width\n map.get(colour.$colour-palette-default, $colour)\n $style\n if($important, !important, null);\n border-#{$direction}: $width\n var(--#{$colour})\n $style\n if($important, !important, null);\n } @else {\n border-#{$direction}-color: map.get(\n colour.$colour-palette-default,\n $colour\n )\n if($important, !important, null);\n border-#{$direction}-color: var(--#{$colour})\n if($important, !important, null);\n }\n } @else {\n @if $width != \"\" {\n border: $width\n map.get(colour.$colour-palette-default, $colour)\n $style\n if($important, !important, null);\n border: $width var(--#{$colour}) $style if($important, !important, null);\n } @else {\n border-color: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n border-color: var(--#{$colour}) if($important, !important, null);\n }\n }\n}\n\n@mixin colour-outline($colour, $width: \"\", $style: solid, $important: false) {\n @if $width != \"\" {\n outline: $width\n map.get(colour.$colour-palette-default, $colour)\n $style\n if($important, !important, null);\n outline: $width var(--#{$colour}) $style if($important, !important, null);\n } @else {\n outline-color: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n outline-color: var(--#{$colour}) if($important, !important, null);\n }\n}\n\n@mixin colour-fill($colour, $important: false) {\n fill: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n fill: var(--#{$colour}) if($important, !important, null);\n}\n\n%light {\n @include colour-css-vars;\n\n @media (prefers-contrast: more) {\n @include colour-css-vars-high-contrast;\n }\n\n .tna-template--high-contrast-theme & {\n @include colour-css-vars-high-contrast;\n }\n}\n\n@mixin light {\n @extend %light;\n}\n\n%dark {\n @include colour-css-vars-dark;\n\n @media (prefers-contrast: more) {\n @include colour-css-vars-high-contrast-dark;\n }\n\n .tna-template--high-contrast-theme & {\n @include colour-css-vars-high-contrast-dark;\n }\n}\n\n@mixin dark {\n @extend %dark;\n}\n\n%plain {\n .tna-template--system-theme & {\n @extend %light;\n\n @media (prefers-color-scheme: dark) {\n @include colour-css-vars-dark;\n }\n\n @media (prefers-contrast: more) and (prefers-color-scheme: dark) {\n @include colour-css-vars-high-contrast-dark;\n }\n }\n\n .tna-template--light-theme & {\n @include colour-css-vars;\n }\n\n .tna-template--dark-theme & {\n @include colour-css-vars-dark;\n }\n\n .tna-template--high-contrast-theme & {\n @include colour-css-vars-high-contrast;\n }\n\n .tna-template--high-contrast-theme.tna-template--dark-theme & {\n @include colour-css-vars-high-contrast-dark;\n }\n\n --background: var(--page-background);\n}\n\n@mixin plain {\n @extend %plain;\n}\n\n%contrast {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\", false, colour.$colour-palette-dark);\n}\n\n@mixin contrast {\n @extend %contrast;\n}\n\n%contrast-on-mobile {\n @include media.on-mobile {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\", false, colour.$colour-palette-dark);\n }\n}\n\n@mixin contrast-on-mobile {\n @extend %contrast-on-mobile;\n}\n\n%accent {\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\", false, colour.$colour-palette-dark);\n}\n\n@mixin accent {\n @extend %accent;\n}\n\n%tint {\n @include colour-background(\"background-tint\");\n @include colour-font(\"font-base\");\n}\n\n@mixin tint {\n @extend %tint;\n}\n\n%accent-background {\n @include colour-background(\"accent-background\");\n}\n\n@mixin accent-background {\n @extend %accent-background;\n}\n\n%accent-light {\n --background: var(--accent-background-light);\n --font-base: #{map.get(colour.$colour-palette-default, \"font-base\")};\n --font-dark: #{map.get(colour.$colour-palette-default, \"font-dark\")};\n --font-light: #{map.get(colour.$colour-palette-default, \"font-light\")};\n --icon-light: #{map.get(colour.$colour-palette-default, \"icon-light\")};\n // --link: #{map.get(colour.$colour-palette-default, \"link\")};\n // --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n --keyline: #{map.get(colour.$colour-palette-default, \"keyline\")};\n --keyline-dark: #{map.get(colour.$colour-palette-default, \"keyline-dark\")};\n --button-text: #{map.get(colour.$colour-palette-default, \"button-text\")};\n --button-background: #{map.get(\n colour.$colour-palette-default,\n \"button-background\"\n )};\n --button-hover-text: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-text\"\n )};\n --button-hover-background: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-background\"\n )};\n\n @include colour-background(\"background\");\n @include colour-font(\"font-base\");\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n --link: #{map.get(colour.$colour-palette-default, \"link\")};\n --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n }\n }\n\n .tna-template--dark-theme & {\n --link: #{map.get(colour.$colour-palette-default, \"link\")};\n --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n }\n}\n\n@mixin accent-light {\n @extend %accent-light;\n}\n\n@mixin on-high-contrast {\n .tna-template--high-contrast-theme & {\n @content;\n }\n\n .tna-template--system-theme & {\n @media (prefers-contrast: more) {\n @content;\n }\n }\n}\n\n@mixin on-forced-colours {\n @media (forced-colors: active) {\n @content;\n }\n}\n\n@mixin on-high-contrast-and-forced-colours {\n @include on-forced-colours {\n @content;\n }\n\n @include on-high-contrast {\n @content;\n }\n}\n","@use \"../../variables/forms\";\n@use \"../../tools/colour\";\n\n.tna-select {\n max-width: 100%;\n height: calc(2rem + 6px);\n padding: 0 1rem 0 0.5rem;\n\n display: block;\n\n @include colour.light;\n @include colour.colour-font(\"input-foreground\");\n font-size: inherit;\n line-height: 2rem;\n\n @include colour.colour-background(\"input-background\");\n\n @include colour.colour-border(\"input-border\", forms.$form-field-border-width);\n border-radius: 0;\n\n &--styled {\n padding: 0 2.5rem 0 0.75rem;\n\n appearance: none;\n\n background-image: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjUwMHB4IiBoZWlnaHQ9IjUwMHB4IiB2aWV3Qm94PSIwIDAgNTAwIDUwMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNTAwIDUwMCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHBvbHlnb24gcG9pbnRzPSIyNTAsNDAwIDUwLDEwMCA0NTAsMTAwIiBmaWxsPSIjMDAwIi8+PC9zdmc+\");\n background-position: center right 0.5rem;\n background-size: 0.75rem 0.75rem;\n background-repeat: no-repeat;\n }\n\n .tna-form__group--error & {\n @include colour.colour-border(\"form-error\");\n }\n\n &--s {\n width: 10rem;\n }\n\n &--m {\n width: 20rem;\n }\n\n &--l {\n width: 40rem;\n }\n\n &--xl {\n width: 80rem;\n }\n}\n"]}
1
+ {"version":3,"sourceRoot":"","sources":["../../../../src/nationalarchives/tools/_colour.scss","../../../../src/nationalarchives/components/select/select.scss"],"names":[],"mappings":"AAyLA,YA7KM,ygDAgLJ,+BAHF,YA7JM,48CAoKJ,+CApKI,28CCzBN,YACE,eACA,wBACA,uBAEA,cDiFA,WACA,8BC9EA,kBACA,iBDiFA,sBAEA,yCAoCI,sBAIA,qCCtHJ,mBAEA,oBACE,0BAEA,gBAEA,+lBACA,uCACA,8BACA,4BAGF,oCD2GI,kBAEA,+BCzGJ,eACE,YAGF,eACE,YAGF,eACE,YAGF,gBACE","file":"select.css","sourcesContent":["@use \"sass:map\";\n@use \"sass:list\";\n@use \"../variables/colour\";\n@use \"../tools/media\";\n\n@function brand-colour($colour, $opacity: 1) {\n @return colour.brand-colour($colour, $opacity);\n}\n\n@mixin colour-css-vars($excludes...) {\n @each $name, $value in colour.$colour-palette-default {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n }\n }\n}\n\n@mixin colour-css-vars-dark($excludes...) {\n @each $name, $value in colour.$colour-palette-dark {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n }\n }\n}\n\n@mixin colour-css-vars-high-contrast($excludes...) {\n @each $name, $value in colour.$colour-palette-high-contrast {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n }\n }\n}\n\n@mixin colour-css-vars-high-contrast-dark($excludes...) {\n @each $name, $value in colour.$colour-palette-high-contrast-dark {\n @if not list.index($excludes, $name) {\n --#{$name}: #{$value};\n }\n }\n}\n\n@mixin accent-css-vars($colour) {\n @if $colour == \"yellow\" {\n --accent-background: #{brand-colour(\"yellow\")} !important;\n --accent-background-light: #{brand-colour(\"cream\")} !important;\n --accent-font-base: #{brand-colour(\"black\")} !important;\n --accent-font-dark: #{brand-colour(\"black\")} !important;\n --accent-font-light: #{brand-colour(\"black\", 0.7)} !important;\n --accent-icon-light: #{brand-colour(\"black\", 0.45)} !important;\n --accent-link: #{brand-colour(\"black\")} !important;\n --accent-link-visited: #{brand-colour(\"black\")} !important;\n --accent-keyline: #{brand-colour(\"black\", 0.5)} !important;\n --accent-keyline-dark: #{brand-colour(\"black\", 0.8)} !important;\n --button-accent-background: #{brand-colour(\"yellow\")} !important;\n } @else {\n --accent-font-base: #{brand-colour(\"white\")} !important;\n --accent-font-dark: #{brand-colour(\"white\")} !important;\n --accent-font-light: #{brand-colour(\"white\", 0.7)} !important;\n --accent-icon-light: #{brand-colour(\"white\", 0.45)} !important;\n --accent-link: #{brand-colour(\"white\")} !important;\n --accent-link-visited: #{brand-colour(\"white\")} !important;\n --accent-keyline: #{brand-colour(\"white\", 0.5)} !important;\n --accent-keyline-dark: #{brand-colour(\"white\", 0.8)} !important;\n --button-accent-text: #{brand-colour(\"white\")} !important;\n @if $colour == \"pink\" {\n --accent-background: #{brand-colour(\"maroon\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-pink\")} !important;\n --button-accent-background: #{brand-colour(\"maroon\")} !important;\n } @else if $colour == \"orange\" {\n --accent-background: #{brand-colour(\"chestnut\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-orange\")} !important;\n --button-accent-background: #{brand-colour(\"chestnut\")} !important;\n } @else if $colour == \"green\" {\n --accent-background: #{brand-colour(\"forest\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-green\")} !important;\n --button-accent-background: #{brand-colour(\"forest\")} !important;\n } @else if $colour == \"blue\" {\n --accent-background: #{brand-colour(\"navy\")} !important;\n --accent-background-light: #{brand-colour(\"pastel-blue\")} !important;\n --button-accent-background: #{brand-colour(\"navy\")} !important;\n }\n }\n}\n\n@mixin colour-font(\n $colour,\n $important: false,\n $default-palette: colour.$colour-palette-default\n) {\n color: map.get($default-palette, $colour) if($important, !important, null);\n color: var(--#{$colour}) if($important, !important, null);\n}\n\n@mixin colour-background($colour, $important: false) {\n background-color: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n background-color: var(--#{$colour}) if($important, !important, null);\n}\n\n@mixin colour-background-brand($brandColour, $important: false) {\n background-color: #{brand-colour($brandColour)} if($important, !important, null);\n}\n\n@mixin colour-border(\n $colour,\n $width: \"\",\n $style: solid,\n $direction: \"\",\n $important: false\n) {\n @if $direction != \"\" {\n @if $width != \"\" {\n $property: border-#{$direction};\n border-#{$direction}: $width\n map.get(colour.$colour-palette-default, $colour)\n $style\n if($important, !important, null);\n border-#{$direction}: $width\n var(--#{$colour})\n $style\n if($important, !important, null);\n } @else {\n border-#{$direction}-color: map.get(\n colour.$colour-palette-default,\n $colour\n )\n if($important, !important, null);\n border-#{$direction}-color: var(--#{$colour})\n if($important, !important, null);\n }\n } @else {\n @if $width != \"\" {\n border: $width\n map.get(colour.$colour-palette-default, $colour)\n $style\n if($important, !important, null);\n border: $width var(--#{$colour}) $style if($important, !important, null);\n } @else {\n border-color: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n border-color: var(--#{$colour}) if($important, !important, null);\n }\n }\n}\n\n@mixin colour-outline($colour, $width: \"\", $style: solid, $important: false) {\n @if $width != \"\" {\n outline: $width\n map.get(colour.$colour-palette-default, $colour)\n $style\n if($important, !important, null);\n outline: $width var(--#{$colour}) $style if($important, !important, null);\n } @else {\n outline-color: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n outline-color: var(--#{$colour}) if($important, !important, null);\n }\n}\n\n@mixin colour-fill($colour, $important: false) {\n fill: map.get(colour.$colour-palette-default, $colour)\n if($important, !important, null);\n fill: var(--#{$colour}) if($important, !important, null);\n}\n\n@mixin thick-keyline($direction) {\n @include colour-border(\"keyline\", 5px, solid, $direction);\n}\n\n@mixin thick-keyline-dark($direction) {\n @include colour-border(\"keyline-dark\", 5px, solid, $direction);\n}\n\n@mixin thick-keyline-accent($direction) {\n @include colour-border(\"accent-background\", 5px, solid, $direction);\n}\n\n@mixin thick-keyline-error($direction) {\n @include colour-border(\"form-error\", 5px, solid, $direction);\n}\n\n@mixin thick-keyline-brand($direction, $brandColour) {\n border-#{$direction}: 5px #{brand-colour($brandColour)} solid;\n}\n\n%light {\n @include colour-css-vars(\"form-error\");\n\n @media (prefers-contrast: more) {\n @include colour-css-vars-high-contrast(\"form-error\");\n }\n\n .tna-template--high-contrast-theme & {\n @include colour-css-vars-high-contrast(\"form-error\");\n }\n}\n\n@mixin light {\n @extend %light;\n}\n\n%dark {\n @include colour-css-vars-dark(\"form-error\");\n\n @media (prefers-contrast: more) {\n @include colour-css-vars-high-contrast-dark(\"form-error\");\n }\n\n .tna-template--high-contrast-theme & {\n @include colour-css-vars-high-contrast-dark(\"form-error\");\n }\n}\n\n@mixin dark {\n @extend %dark;\n}\n\n%plain {\n .tna-template--system-theme & {\n @extend %light;\n\n @media (prefers-color-scheme: dark) {\n @include colour-css-vars-dark;\n }\n\n @media (prefers-contrast: more) and (prefers-color-scheme: dark) {\n @include colour-css-vars-high-contrast-dark;\n }\n }\n\n .tna-template--light-theme & {\n @include colour-css-vars;\n }\n\n .tna-template--dark-theme & {\n @include colour-css-vars-dark;\n }\n\n .tna-template--high-contrast-theme & {\n @include colour-css-vars-high-contrast;\n }\n\n .tna-template--high-contrast-theme.tna-template--dark-theme & {\n @include colour-css-vars-high-contrast-dark;\n }\n\n --background: var(--page-background);\n}\n\n@mixin plain {\n @extend %plain;\n}\n\n%contrast {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\", false, colour.$colour-palette-dark);\n}\n\n@mixin contrast {\n @extend %contrast;\n}\n\n%contrast-on-mobile {\n @include media.on-mobile {\n --background: var(--contrast-background);\n --font-base: var(--contrast-font-base);\n --font-dark: var(--contrast-font-dark);\n --font-light: var(--contrast-font-light);\n --icon-light: var(--contrast-icon-light);\n --link: var(--contrast-link);\n --link-visited: var(--contrast-link-visited);\n --keyline: var(--contrast-keyline);\n --keyline-dark: var(--contrast-keyline-dark);\n --button-text: var(--contrast-button-text);\n --button-background: var(--contrast-button-background);\n --button-hover-text: var(--contrast-button-hover-text);\n --button-hover-background: var(--contrast-button-hover-background);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\", false, colour.$colour-palette-dark);\n }\n}\n\n@mixin contrast-on-mobile {\n @extend %contrast-on-mobile;\n}\n\n%accent {\n --background: var(--accent-background);\n --font-base: var(--accent-font-base);\n --font-dark: var(--accent-font-dark);\n --font-light: var(--accent-font-light);\n --icon-light: var(--accent-icon-light);\n --link: var(--accent-link);\n --link-visited: var(--accent-link);\n --keyline: var(--accent-keyline);\n --keyline-dark: var(--accent-keyline-dark);\n\n @include colour-background(\"background\");\n\n @include colour-font(\"font-base\", false, colour.$colour-palette-dark);\n}\n\n@mixin accent {\n @extend %accent;\n}\n\n%tint {\n @include colour-background(\"background-tint\");\n @include colour-font(\"font-base\");\n}\n\n@mixin tint {\n @extend %tint;\n}\n\n%accent-background {\n @include colour-background(\"accent-background\");\n}\n\n@mixin accent-background {\n @extend %accent-background;\n}\n\n%accent-light {\n --background: var(--accent-background-light);\n --font-base: #{map.get(colour.$colour-palette-default, \"font-base\")};\n --font-dark: #{map.get(colour.$colour-palette-default, \"font-dark\")};\n --font-light: #{map.get(colour.$colour-palette-default, \"font-light\")};\n --icon-light: #{map.get(colour.$colour-palette-default, \"icon-light\")};\n // --link: #{map.get(colour.$colour-palette-default, \"link\")};\n // --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n --keyline: #{map.get(colour.$colour-palette-default, \"keyline\")};\n --keyline-dark: #{map.get(colour.$colour-palette-default, \"keyline-dark\")};\n --button-text: #{map.get(colour.$colour-palette-default, \"button-text\")};\n --button-background: #{map.get(\n colour.$colour-palette-default,\n \"button-background\"\n )};\n --button-hover-text: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-text\"\n )};\n --button-hover-background: #{map.get(\n colour.$colour-palette-default,\n \"button-hover-background\"\n )};\n\n @include colour-background(\"background\");\n @include colour-font(\"font-base\");\n\n .tna-template--system-theme & {\n @media (prefers-color-scheme: dark) {\n --link: #{map.get(colour.$colour-palette-default, \"link\")};\n --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n }\n }\n\n .tna-template--dark-theme & {\n --link: #{map.get(colour.$colour-palette-default, \"link\")};\n --link-visited: #{map.get(colour.$colour-palette-default, \"link-visited\")};\n }\n}\n\n@mixin accent-light {\n @extend %accent-light;\n}\n\n@mixin on-high-contrast {\n .tna-template--high-contrast-theme & {\n @content;\n }\n\n .tna-template--system-theme & {\n @media (prefers-contrast: more) {\n @content;\n }\n }\n}\n\n@mixin on-forced-colours {\n @media (forced-colors: active) {\n @content;\n }\n}\n\n@mixin on-high-contrast-and-forced-colours {\n @include on-forced-colours {\n @content;\n }\n\n @include on-high-contrast {\n @content;\n }\n}\n","@use \"../../variables/forms\";\n@use \"../../tools/colour\";\n\n.tna-select {\n max-width: 100%;\n height: calc(2rem + 6px);\n padding: 0 1rem 0 0.5rem;\n\n display: block;\n\n @include colour.light;\n @include colour.colour-font(\"input-foreground\");\n font-size: inherit;\n line-height: 2rem;\n\n @include colour.colour-background(\"input-background\");\n\n @include colour.colour-border(\"input-border\", forms.$form-field-border-width);\n border-radius: 0.1px;\n\n &--styled {\n padding: 0 2.5rem 0 0.75rem;\n\n appearance: none;\n\n background-image: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz48IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPjxzdmcgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjUwMHB4IiBoZWlnaHQ9IjUwMHB4IiB2aWV3Qm94PSIwIDAgNTAwIDUwMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNTAwIDUwMCIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHBvbHlnb24gcG9pbnRzPSIyNTAsNDAwIDUwLDEwMCA0NTAsMTAwIiBmaWxsPSIjMDAwIi8+PC9zdmc+\");\n background-position: center right 0.5rem;\n background-size: 0.75rem 0.75rem;\n background-repeat: no-repeat;\n }\n\n .tna-form__group--error & {\n @include colour.colour-border(\"form-error\");\n }\n\n &--s {\n width: 10rem;\n }\n\n &--m {\n width: 20rem;\n }\n\n &--l {\n width: 40rem;\n }\n\n &--xl {\n width: 80rem;\n }\n}\n"]}
@@ -16,7 +16,7 @@
16
16
  @include colour.colour-background("input-background");
17
17
 
18
18
  @include colour.colour-border("input-border", forms.$form-field-border-width);
19
- border-radius: 0;
19
+ border-radius: 0.1px;
20
20
 
21
21
  &--styled {
22
22
  padding: 0 2.5rem 0 0.75rem;