@ons/design-system 70.0.7 → 70.0.8

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 (270) hide show
  1. package/README.md +11 -17
  2. package/components/access-code/_macro.spec.js +145 -145
  3. package/components/access-code/access-code.dom.js +5 -5
  4. package/components/access-code/access-code.js +16 -16
  5. package/components/access-code/access-code.scss +22 -22
  6. package/components/access-code/access-code.spec.js +17 -17
  7. package/components/accordion/_macro.spec.js +154 -154
  8. package/components/accordion/accordion.dom.js +10 -10
  9. package/components/accordion/accordion.js +50 -50
  10. package/components/accordion/accordion.spec.js +104 -104
  11. package/components/address-input/_macro.spec.js +420 -420
  12. package/components/address-input/autosuggest.address.dom.js +5 -5
  13. package/components/address-input/autosuggest.address.error.js +77 -77
  14. package/components/address-input/autosuggest.address.js +357 -357
  15. package/components/address-input/autosuggest.address.setter.js +95 -95
  16. package/components/address-input/autosuggest.address.spec.js +668 -651
  17. package/components/address-input/example-address-input-editable.njk +1 -1
  18. package/components/address-input/example-address-input.njk +1 -1
  19. package/components/address-output/_address-output.scss +3 -3
  20. package/components/address-output/_macro.spec.js +84 -84
  21. package/components/autosuggest/_autosuggest.scss +114 -114
  22. package/components/autosuggest/_macro.spec.js +255 -255
  23. package/components/autosuggest/autosuggest.dom.js +5 -5
  24. package/components/autosuggest/autosuggest.helpers.js +11 -11
  25. package/components/autosuggest/autosuggest.helpers.spec.js +73 -73
  26. package/components/autosuggest/autosuggest.js +20 -20
  27. package/components/autosuggest/autosuggest.spec.js +542 -536
  28. package/components/autosuggest/autosuggest.ui.js +478 -475
  29. package/components/autosuggest/fuse-config.js +17 -17
  30. package/components/back-to-top/_back-to-top.scss +27 -27
  31. package/components/back-to-top/_macro.spec.js +49 -49
  32. package/components/back-to-top/back-to-top.dom.js +5 -5
  33. package/components/back-to-top/back-to-top.js +52 -52
  34. package/components/back-to-top/back-to-top.spec.js +106 -106
  35. package/components/back-to-top/example-back-to-top.njk +6 -6
  36. package/components/breadcrumbs/_breadcrumbs.scss +63 -65
  37. package/components/breadcrumbs/_macro.spec.js +91 -91
  38. package/components/browser-banner/_browser-banner.scss +23 -23
  39. package/components/browser-banner/_macro.spec.js +92 -92
  40. package/components/button/_button.scss +482 -483
  41. package/components/button/_macro.spec.js +363 -363
  42. package/components/button/button.dom.js +15 -15
  43. package/components/button/button.js +53 -53
  44. package/components/button/button.spec.js +248 -240
  45. package/components/call-to-action/_call-to-action.scss +5 -5
  46. package/components/call-to-action/_macro.spec.js +28 -28
  47. package/components/card/_card.scss +23 -23
  48. package/components/card/_macro.spec.js +180 -180
  49. package/components/char-check-limit/_macro.spec.js +48 -48
  50. package/components/char-check-limit/character-check.js +58 -58
  51. package/components/char-check-limit/character-check.spec.js +173 -173
  52. package/components/char-check-limit/character-limit.js +40 -40
  53. package/components/checkboxes/_checkbox-macro.spec.js +355 -355
  54. package/components/checkboxes/_checkbox.scss +180 -180
  55. package/components/checkboxes/_checkboxes.scss +37 -27
  56. package/components/checkboxes/_macro.spec.js +261 -261
  57. package/components/checkboxes/checkbox-with-autoselect.js +32 -32
  58. package/components/checkboxes/checkbox-with-fieldset.js +21 -21
  59. package/components/checkboxes/checkboxes-with-reveal.js +10 -10
  60. package/components/checkboxes/checkboxes.dom.js +27 -27
  61. package/components/checkboxes/checkboxes.spec.js +183 -183
  62. package/components/content-pagination/_content-pagination.scss +41 -41
  63. package/components/content-pagination/_macro.spec.js +159 -159
  64. package/components/cookies-banner/_cookies-banner.scss +22 -22
  65. package/components/cookies-banner/_macro.spec.js +177 -177
  66. package/components/cookies-banner/cookies-banner.dom.js +7 -7
  67. package/components/cookies-banner/cookies-banner.js +76 -76
  68. package/components/cookies-banner/cookies-banner.spec.js +72 -68
  69. package/components/date-input/_macro.spec.js +338 -338
  70. package/components/description-list/_description-list.scss +23 -23
  71. package/components/description-list/_macro.spec.js +144 -144
  72. package/components/details/_details.scss +109 -109
  73. package/components/details/_macro.spec.js +132 -132
  74. package/components/details/details.dom.js +6 -6
  75. package/components/details/details.js +60 -60
  76. package/components/details/details.spec.js +106 -106
  77. package/components/document-list/_macro.spec.js +444 -444
  78. package/components/document-list/document-list.scss +145 -149
  79. package/components/download-resources/_download-resources.scss +109 -108
  80. package/components/download-resources/download-resources.js +907 -900
  81. package/components/download-resources/download-resources.spec.js +461 -461
  82. package/components/duration/_macro.spec.js +291 -291
  83. package/components/error/_macro.spec.js +72 -72
  84. package/components/external-link/_external-link.scss +19 -19
  85. package/components/external-link/_macro.spec.js +68 -68
  86. package/components/feedback/_feedback.scss +31 -31
  87. package/components/feedback/_macro.spec.js +72 -72
  88. package/components/field/_field-group.scss +10 -10
  89. package/components/field/_field.scss +16 -16
  90. package/components/field/_macro.spec.js +80 -80
  91. package/components/fieldset/_fieldset.scss +27 -27
  92. package/components/fieldset/_macro.spec.js +161 -161
  93. package/components/footer/_footer.scss +45 -45
  94. package/components/footer/_macro.spec.js +452 -452
  95. package/components/header/_header.scss +202 -202
  96. package/components/header/_macro.spec.js +833 -829
  97. package/components/helpers/_grid.scss +4 -4
  98. package/components/hero/_hero.scss +48 -48
  99. package/components/hero/_macro.spec.js +59 -59
  100. package/components/icon/_icon.scss +44 -44
  101. package/components/icon/_macro.spec.js +110 -110
  102. package/components/image/_image.scss +11 -11
  103. package/components/image/_macro.spec.js +81 -81
  104. package/components/input/_input-type.scss +86 -89
  105. package/components/input/_input.scss +123 -124
  106. package/components/input/_macro.spec.js +604 -604
  107. package/components/input/character-check.dom.js +5 -5
  108. package/components/input/input.dom.js +5 -5
  109. package/components/input/input.js +10 -10
  110. package/components/input/input.spec.js +18 -18
  111. package/components/label/_label.scss +24 -24
  112. package/components/label/_macro.spec.js +173 -170
  113. package/components/language-selector/_macro.spec.js +97 -97
  114. package/components/language-selector/language.scss +7 -7
  115. package/components/list/_list.scss +84 -84
  116. package/components/list/_macro.spec.js +583 -583
  117. package/components/message/_macro.njk +5 -5
  118. package/components/message/_macro.spec.js +74 -74
  119. package/components/message/_message.scss +39 -39
  120. package/components/message-list/_macro.spec.js +86 -86
  121. package/components/message-list/_message-list.scss +16 -16
  122. package/components/modal/_macro.spec.js +69 -69
  123. package/components/modal/_modal.scss +36 -36
  124. package/components/modal/modal.dom.js +6 -6
  125. package/components/modal/modal.js +89 -89
  126. package/components/modal/modal.spec.js +50 -50
  127. package/components/mutually-exclusive/_macro.spec.js +140 -140
  128. package/components/mutually-exclusive/mutually-exclusive.checkboxes.spec.js +188 -188
  129. package/components/mutually-exclusive/mutually-exclusive.date.spec.js +211 -211
  130. package/components/mutually-exclusive/mutually-exclusive.dom.js +5 -5
  131. package/components/mutually-exclusive/mutually-exclusive.duration.spec.js +210 -210
  132. package/components/mutually-exclusive/mutually-exclusive.email.spec.js +90 -90
  133. package/components/mutually-exclusive/mutually-exclusive.js +137 -137
  134. package/components/mutually-exclusive/mutually-exclusive.multiple-options.checkboxes.spec.js +197 -197
  135. package/components/mutually-exclusive/mutually-exclusive.number.spec.js +96 -96
  136. package/components/mutually-exclusive/mutually-exclusive.textarea.spec.js +102 -102
  137. package/components/navigation/_macro.spec.js +360 -354
  138. package/components/navigation/_navigation.scss +122 -123
  139. package/components/navigation/navigation.dom.js +35 -35
  140. package/components/navigation/navigation.js +49 -49
  141. package/components/navigation/navigation.spec.js +249 -249
  142. package/components/pagination/_macro.spec.js +342 -335
  143. package/components/pagination/_pagination.scss +58 -58
  144. package/components/panel/_macro.spec.js +372 -372
  145. package/components/panel/_panel.scss +200 -199
  146. package/components/password/_macro.spec.js +95 -95
  147. package/components/password/password.dom.js +5 -5
  148. package/components/password/password.js +10 -10
  149. package/components/password/password.spec.js +26 -26
  150. package/components/phase-banner/_macro.spec.js +86 -86
  151. package/components/phase-banner/_phase-banner.scss +16 -16
  152. package/components/question/_macro.spec.js +235 -235
  153. package/components/question/_question.scss +24 -24
  154. package/components/quote/_macro.spec.js +52 -52
  155. package/components/quote/_quote.scss +24 -24
  156. package/components/radios/_macro.spec.js +524 -524
  157. package/components/radios/_radio.scss +49 -48
  158. package/components/radios/_radios.scss +14 -20
  159. package/components/radios/check-radios.js +21 -21
  160. package/components/radios/clear-radios.js +45 -45
  161. package/components/radios/radio-with-fieldset.js +22 -22
  162. package/components/radios/radios.dom.js +32 -32
  163. package/components/radios/radios.spec.js +251 -251
  164. package/components/related-content/_macro.spec.js +109 -109
  165. package/components/related-content/_related-content.scss +12 -12
  166. package/components/related-content/_section-macro.spec.js +20 -20
  167. package/components/relationships/_macro.spec.js +94 -94
  168. package/components/relationships/_relationships.scss +9 -9
  169. package/components/relationships/relationships.dom.js +5 -5
  170. package/components/relationships/relationships.js +18 -18
  171. package/components/relationships/relationships.spec.js +71 -71
  172. package/components/reply/_macro.spec.js +47 -47
  173. package/components/reply/reply-input.js +15 -15
  174. package/components/reply/reply.dom.js +5 -5
  175. package/components/reply/reply.spec.js +57 -57
  176. package/components/section-navigation/_macro.spec.js +210 -210
  177. package/components/section-navigation/_section-navigation.scss +76 -76
  178. package/components/select/_macro.spec.js +166 -166
  179. package/components/share-page/_macro.spec.js +68 -68
  180. package/components/skip-to-content/_macro.spec.js +54 -54
  181. package/components/skip-to-content/_skip.scss +30 -30
  182. package/components/skip-to-content/skip-to-content.dom.js +6 -6
  183. package/components/skip-to-content/skip-to-content.js +7 -7
  184. package/components/skip-to-content/skip-to-content.spec.js +21 -21
  185. package/components/status/_macro.spec.js +53 -53
  186. package/components/status/_status.scss +32 -32
  187. package/components/summary/_macro.spec.js +551 -535
  188. package/components/summary/_summary.scss +191 -195
  189. package/components/table/_macro.spec.js +499 -499
  190. package/components/table/_table.scss +204 -201
  191. package/components/table/scrollable-table.dom.js +5 -5
  192. package/components/table/scrollable-table.js +60 -60
  193. package/components/table/sortable-table.dom.js +5 -5
  194. package/components/table/sortable-table.js +135 -135
  195. package/components/table/table.spec.js +144 -140
  196. package/components/table-of-contents/_macro.spec.js +125 -125
  197. package/components/table-of-contents/_toc.scss +9 -9
  198. package/components/table-of-contents/toc.dom.js +5 -5
  199. package/components/table-of-contents/toc.js +30 -30
  200. package/components/table-of-contents/toc.spec.js +88 -88
  201. package/components/tabs/_macro.spec.js +92 -92
  202. package/components/tabs/_tabs.scss +120 -115
  203. package/components/tabs/tabs.dom.js +5 -5
  204. package/components/tabs/tabs.js +266 -266
  205. package/components/tabs/tabs.spec.js +268 -268
  206. package/components/text-indent/_macro.spec.js +33 -33
  207. package/components/text-indent/_text-indent.scss +3 -3
  208. package/components/textarea/_macro.spec.js +238 -238
  209. package/components/textarea/textarea.dom.js +5 -5
  210. package/components/textarea/textarea.spec.js +78 -74
  211. package/components/timeline/_macro.spec.js +83 -83
  212. package/components/timeline/_timeline.scss +26 -26
  213. package/components/timeout-modal/_macro.spec.js +47 -47
  214. package/components/timeout-modal/timeout-modal.dom.js +9 -9
  215. package/components/timeout-modal/timeout-modal.js +66 -66
  216. package/components/timeout-modal/timeout-modal.spec.js +157 -157
  217. package/components/timeout-panel/_macro.spec.js +41 -41
  218. package/components/timeout-panel/timeout-panel.dom.js +8 -8
  219. package/components/timeout-panel/timeout-panel.spec.js +118 -118
  220. package/components/upload/_macro.spec.js +52 -52
  221. package/components/upload/_upload.scss +28 -28
  222. package/components/video/_macro.spec.js +42 -42
  223. package/components/video/_video.scss +16 -16
  224. package/components/video/video.dom.js +5 -5
  225. package/components/video/video.js +32 -32
  226. package/components/video/video.spec.js +103 -97
  227. package/css/main.css +1 -1
  228. package/favicons/manifest.json +25 -25
  229. package/js/abortable-fetch.js +23 -23
  230. package/js/analytics.js +53 -53
  231. package/js/cookies-functions.js +135 -135
  232. package/js/cookies-settings.dom.js +7 -7
  233. package/js/cookies-settings.js +77 -77
  234. package/js/cookies-settings.spec.js +106 -106
  235. package/js/domready.js +8 -8
  236. package/js/fetch.js +14 -14
  237. package/js/inpagelink.dom.js +5 -5
  238. package/js/inpagelink.js +19 -19
  239. package/js/polyfills.js +0 -1
  240. package/js/print-button.js +6 -6
  241. package/js/timeout.js +211 -211
  242. package/layout/_template.njk +5 -7
  243. package/package.json +131 -128
  244. package/scss/base/_forms.scss +10 -10
  245. package/scss/base/_global.scss +45 -44
  246. package/scss/base/_typography.scss +20 -20
  247. package/scss/helpers/_functions.scss +18 -15
  248. package/scss/helpers/_mixins.scss +59 -53
  249. package/scss/helpers/_mq.scss +62 -65
  250. package/scss/objects/_container.scss +20 -20
  251. package/scss/objects/_page.scss +33 -33
  252. package/scss/objects/_spacing.scss +10 -10
  253. package/scss/overrides/hcm.scss +237 -237
  254. package/scss/overrides/rtl.scss +95 -95
  255. package/scss/print.scss +47 -47
  256. package/scss/utilities/_border.scss +7 -7
  257. package/scss/utilities/_colors.scss +6 -6
  258. package/scss/utilities/_display.scss +8 -8
  259. package/scss/utilities/_float.scss +7 -7
  260. package/scss/utilities/_grid.scss +144 -144
  261. package/scss/utilities/_highlight.scss +4 -4
  262. package/scss/utilities/_margin.scss +17 -17
  263. package/scss/utilities/_pad.scss +15 -15
  264. package/scss/utilities/_typography.scss +35 -33
  265. package/scss/utilities/_utilities.scss +8 -8
  266. package/scss/utilities/_visibility.scss +25 -25
  267. package/scss/vars/_colors.scss +116 -116
  268. package/scss/vars/_forms.scss +22 -22
  269. package/scss/vars/_grid.scss +11 -9
  270. package/scss/vars/_typography.scss +54 -54
@@ -7,251 +7,251 @@ import { mapAll } from '../../tests/helpers/cheerio';
7
7
  import { renderComponent } from '../../tests/helpers/rendering';
8
8
 
9
9
  const EXAMPLE_SECTION_NAVIGATION = {
10
- id: 'section-menu',
11
- currentPath: '/results',
12
- itemsList: [
13
- {
14
- title: 'Results',
15
- url: '/results',
16
- },
17
- {
18
- title: 'Dashboard',
19
- url: '/results/dashboard',
20
- },
21
- ],
10
+ id: 'section-menu',
11
+ currentPath: '/results',
12
+ itemsList: [
13
+ {
14
+ title: 'Results',
15
+ url: '/results',
16
+ },
17
+ {
18
+ title: 'Dashboard',
19
+ url: '/results/dashboard',
20
+ },
21
+ ],
22
22
  };
23
23
 
24
24
  const EXAMPLE_SECTION_NAVIGATION_VERTICAL = {
25
- variants: 'vertical',
26
- currentPath: '#section-2',
27
- itemsList: [
28
- {
29
- title: 'Section 1',
30
- url: '#section-1',
31
- },
32
- {
33
- title: 'Section 2',
34
- url: '#section-2',
35
- anchors: [
25
+ variants: 'vertical',
26
+ currentPath: '#section-2',
27
+ itemsList: [
36
28
  {
37
- title: 'Sub section 1',
38
- url: '#sub-section-1',
29
+ title: 'Section 1',
30
+ url: '#section-1',
39
31
  },
40
32
  {
41
- title: 'Sub section 2',
42
- url: '#sub-section-2',
33
+ title: 'Section 2',
34
+ url: '#section-2',
35
+ anchors: [
36
+ {
37
+ title: 'Sub section 1',
38
+ url: '#sub-section-1',
39
+ },
40
+ {
41
+ title: 'Sub section 2',
42
+ url: '#sub-section-2',
43
+ },
44
+ {
45
+ title: 'Sub section 3',
46
+ url: '#sub-section-3',
47
+ },
48
+ ],
43
49
  },
44
50
  {
45
- title: 'Sub section 3',
46
- url: '#sub-section-3',
51
+ title: 'Section 3',
52
+ url: '#0',
47
53
  },
48
- ],
49
- },
50
- {
51
- title: 'Section 3',
52
- url: '#0',
53
- },
54
- ],
54
+ ],
55
55
  };
56
56
 
57
57
  const EXAMPLE_SECTION_NAVIGATION_VERTICAL_WITH_SECTIONS = {
58
- variants: 'vertical',
59
- currentPath: '#section-2',
60
- sections: [
61
- {
62
- title: 'Section Title',
63
- itemsList: [
58
+ variants: 'vertical',
59
+ currentPath: '#section-2',
60
+ sections: [
64
61
  {
65
- title: 'Section 1',
66
- url: '#section-1',
62
+ title: 'Section Title',
63
+ itemsList: [
64
+ {
65
+ title: 'Section 1',
66
+ url: '#section-1',
67
+ },
68
+ {
69
+ title: 'Section 2',
70
+ url: '#section-2',
71
+ anchors: [
72
+ {
73
+ title: 'Sub section 1',
74
+ url: '#sub-section-1',
75
+ },
76
+ {
77
+ title: 'Sub section 2',
78
+ url: '#sub-section-2',
79
+ },
80
+ {
81
+ title: 'Sub section 3',
82
+ url: '#sub-section-3',
83
+ },
84
+ ],
85
+ },
86
+ {
87
+ title: 'Section 3',
88
+ url: '#0',
89
+ },
90
+ ],
67
91
  },
68
- {
69
- title: 'Section 2',
70
- url: '#section-2',
71
- anchors: [
72
- {
73
- title: 'Sub section 1',
74
- url: '#sub-section-1',
75
- },
76
- {
77
- title: 'Sub section 2',
78
- url: '#sub-section-2',
79
- },
80
- {
81
- title: 'Sub section 3',
82
- url: '#sub-section-3',
83
- },
84
- ],
85
- },
86
- {
87
- title: 'Section 3',
88
- url: '#0',
89
- },
90
- ],
91
- },
92
- ],
92
+ ],
93
93
  };
94
94
 
95
95
  describe('macro: section-navigation', () => {
96
- describe('variant: horizontal', () => {
97
- it('passes jest-axe checks', async () => {
98
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
99
-
100
- const results = await axe($.html());
101
- expect(results).toHaveNoViolations();
102
- });
103
-
104
- it('does not have the `vertical` modifier class', async () => {
105
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
106
-
107
- expect($('.ons-section-nav').hasClass('ons-section-nav--vertical')).toBe(false);
108
- });
109
- });
110
-
111
- describe('variant: vertical', () => {
112
- it('passes jest-axe checks', async () => {
113
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
114
-
115
- const results = await axe($.html());
116
- expect(results).toHaveNoViolations();
117
- });
118
-
119
- it('has the `vertical` modifier class', async () => {
120
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
121
-
122
- expect($('.ons-section-nav').hasClass('ons-section-nav--vertical')).toBe(true);
123
- });
124
- });
125
-
126
- it('has the provided `id` attribute', () => {
127
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
128
-
129
- expect($('.ons-section-nav').attr('id')).toBe('section-menu');
130
- });
131
-
132
- it('has the provided custom `classes`', () => {
133
- const $ = cheerio.load(renderComponent('section-navigation', { ...EXAMPLE_SECTION_NAVIGATION, classes: 'custom-class' }));
134
-
135
- expect($('.ons-section-nav').hasClass('custom-class')).toBe(true);
136
- });
96
+ describe('variant: horizontal', () => {
97
+ it('passes jest-axe checks', async () => {
98
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
137
99
 
138
- it('assumes a default `hiddenTitleId` of "Section menu"', () => {
139
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
100
+ const results = await axe($.html());
101
+ expect(results).toHaveNoViolations();
102
+ });
140
103
 
141
- expect($('.ons-section-nav').attr('aria-labelledby')).toBe('section-menu-nav-title');
142
- });
143
-
144
- describe('navigation items', () => {
145
- it('renders top level navigation items', () => {
146
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
147
-
148
- const itemLabels = mapAll($('.ons-section-nav__item .ons-section-nav__link'), (node) => node.text().trim());
149
- expect(itemLabels).toEqual(['Results', 'Dashboard']);
150
-
151
- const itemLinks = mapAll($('.ons-section-nav__item .ons-section-nav__link'), (node) => node.attr('href'));
152
- expect(itemLinks).toEqual(['/results', '/results/dashboard']);
153
- });
104
+ it('does not have the `vertical` modifier class', async () => {
105
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
154
106
 
155
- it('has additionally provided style classes', () => {
156
- const $ = cheerio.load(
157
- renderComponent('section-navigation', {
158
- currentPath: '#section-1',
159
- itemsList: [
160
- {
161
- classes: 'extra-class another-extra-class',
162
- title: 'Section 1',
163
- url: '#section-1',
164
- },
165
- ],
166
- }),
167
- );
168
-
169
- expect($('.ons-section-nav__item').hasClass('extra-class')).toBe(true);
170
- expect($('.ons-section-nav__item').hasClass('another-extra-class')).toBe(true);
107
+ expect($('.ons-section-nav').hasClass('ons-section-nav--vertical')).toBe(false);
108
+ });
171
109
  });
172
110
 
173
- it('marks the current item with a class when `currentPath` is provided', () => {
174
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
111
+ describe('variant: vertical', () => {
112
+ it('passes jest-axe checks', async () => {
113
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
175
114
 
176
- expect($('.ons-section-nav__item--active').text().trim()).toBe('Results');
177
- });
115
+ const results = await axe($.html());
116
+ expect(results).toHaveNoViolations();
117
+ });
178
118
 
179
- it('marks the current item with a class when `tabQuery` is provided', () => {
180
- const $ = cheerio.load(
181
- renderComponent('section-navigation', {
182
- ...EXAMPLE_SECTION_NAVIGATION,
183
- currentPath: undefined,
184
- tabQuery: 'dashboard',
185
- }),
186
- );
119
+ it('has the `vertical` modifier class', async () => {
120
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
187
121
 
188
- expect($('.ons-section-nav__item--active').text().trim()).toBe('Dashboard');
122
+ expect($('.ons-section-nav').hasClass('ons-section-nav--vertical')).toBe(true);
123
+ });
189
124
  });
190
125
 
191
- it('marks the current item with `aria-current` when `currentPath` is provided', () => {
192
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
126
+ it('has the provided `id` attribute', () => {
127
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
193
128
 
194
- expect($('.ons-section-nav__item--active .ons-section-nav__link').attr('aria-current')).toBe('location');
129
+ expect($('.ons-section-nav').attr('id')).toBe('section-menu');
195
130
  });
196
131
 
197
- it('marks the current item with `aria-current` when `tabQuery` is provided', () => {
198
- const $ = cheerio.load(
199
- renderComponent('section-navigation', {
200
- ...EXAMPLE_SECTION_NAVIGATION,
201
- currentPath: undefined,
202
- tabQuery: 'dashboard',
203
- }),
204
- );
132
+ it('has the provided custom `classes`', () => {
133
+ const $ = cheerio.load(renderComponent('section-navigation', { ...EXAMPLE_SECTION_NAVIGATION, classes: 'custom-class' }));
205
134
 
206
- expect($('.ons-section-nav__item--active .ons-section-nav__link').attr('aria-current')).toBe('location');
135
+ expect($('.ons-section-nav').hasClass('custom-class')).toBe(true);
207
136
  });
208
137
 
209
- describe('nested anchor navigation items', () => {
210
- it('renders anchor navigation list for top-level items that define `anchors`', () => {
211
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
212
-
213
- expect($('.ons-section-nav__list > .ons-section-nav__item:nth-child(1) .ons-section-nav__sub-items').length).toBe(0);
214
- expect($('.ons-section-nav__list > .ons-section-nav__item:nth-child(2) .ons-section-nav__sub-items').length).toBe(1);
215
- expect($('.ons-section-nav__list > .ons-section-nav__item:nth-child(3) .ons-section-nav__sub-items').length).toBe(0);
216
- });
217
-
218
- it('renders the expected anchor navigation items', () => {
219
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
138
+ it('assumes a default `hiddenTitleId` of "Section menu"', () => {
139
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
220
140
 
221
- const itemLabels = mapAll($('.ons-section-nav__sub-items .ons-section-nav__item .ons-section-nav__link'), (node) =>
222
- node.text().trim(),
223
- );
224
- expect(itemLabels).toEqual(['Sub section 1', 'Sub section 2', 'Sub section 3']);
225
-
226
- const itemLinks = mapAll($('.ons-section-nav__sub-items .ons-section-nav__item .ons-section-nav__link'), (node) =>
227
- node.attr('href'),
228
- );
229
- expect(itemLinks).toEqual(['#sub-section-1', '#sub-section-2', '#sub-section-3']);
230
- });
141
+ expect($('.ons-section-nav').attr('aria-labelledby')).toBe('section-menu-nav-title');
231
142
  });
232
143
 
233
- describe('Section Items', () => {
234
- it('passes jest-axe checks', async () => {
235
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL_WITH_SECTIONS));
236
-
237
- const results = await axe($.html());
238
- expect(results).toHaveNoViolations();
239
- });
240
-
241
- it('renders itemsLists, anchors and heading for each section', () => {
242
- const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL_WITH_SECTIONS));
243
-
244
- const anchors = mapAll($('.ons-section-nav__sub-items .ons-section-nav__item .ons-section-nav__link'), (node) =>
245
- node.text().trim(),
246
- );
247
- expect(anchors).toEqual(['Sub section 1', 'Sub section 2', 'Sub section 3']);
248
-
249
- const itemLists = mapAll($('.ons-section-nav__item .ons-section-nav__link'), (node) => node.text().trim());
250
- expect(itemLists).toEqual(['Section 1', 'Section 2', 'Sub section 1', 'Sub section 2', 'Sub section 3', 'Section 3']);
251
-
252
- const headings = mapAll($('h3'), (node) => $(node).text().trim());
253
- expect(headings).toEqual(['Section Title']);
254
- });
144
+ describe('navigation items', () => {
145
+ it('renders top level navigation items', () => {
146
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
147
+
148
+ const itemLabels = mapAll($('.ons-section-nav__item .ons-section-nav__link'), (node) => node.text().trim());
149
+ expect(itemLabels).toEqual(['Results', 'Dashboard']);
150
+
151
+ const itemLinks = mapAll($('.ons-section-nav__item .ons-section-nav__link'), (node) => node.attr('href'));
152
+ expect(itemLinks).toEqual(['/results', '/results/dashboard']);
153
+ });
154
+
155
+ it('has additionally provided style classes', () => {
156
+ const $ = cheerio.load(
157
+ renderComponent('section-navigation', {
158
+ currentPath: '#section-1',
159
+ itemsList: [
160
+ {
161
+ classes: 'extra-class another-extra-class',
162
+ title: 'Section 1',
163
+ url: '#section-1',
164
+ },
165
+ ],
166
+ }),
167
+ );
168
+
169
+ expect($('.ons-section-nav__item').hasClass('extra-class')).toBe(true);
170
+ expect($('.ons-section-nav__item').hasClass('another-extra-class')).toBe(true);
171
+ });
172
+
173
+ it('marks the current item with a class when `currentPath` is provided', () => {
174
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
175
+
176
+ expect($('.ons-section-nav__item--active').text().trim()).toBe('Results');
177
+ });
178
+
179
+ it('marks the current item with a class when `tabQuery` is provided', () => {
180
+ const $ = cheerio.load(
181
+ renderComponent('section-navigation', {
182
+ ...EXAMPLE_SECTION_NAVIGATION,
183
+ currentPath: undefined,
184
+ tabQuery: 'dashboard',
185
+ }),
186
+ );
187
+
188
+ expect($('.ons-section-nav__item--active').text().trim()).toBe('Dashboard');
189
+ });
190
+
191
+ it('marks the current item with `aria-current` when `currentPath` is provided', () => {
192
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION));
193
+
194
+ expect($('.ons-section-nav__item--active .ons-section-nav__link').attr('aria-current')).toBe('location');
195
+ });
196
+
197
+ it('marks the current item with `aria-current` when `tabQuery` is provided', () => {
198
+ const $ = cheerio.load(
199
+ renderComponent('section-navigation', {
200
+ ...EXAMPLE_SECTION_NAVIGATION,
201
+ currentPath: undefined,
202
+ tabQuery: 'dashboard',
203
+ }),
204
+ );
205
+
206
+ expect($('.ons-section-nav__item--active .ons-section-nav__link').attr('aria-current')).toBe('location');
207
+ });
208
+
209
+ describe('nested anchor navigation items', () => {
210
+ it('renders anchor navigation list for top-level items that define `anchors`', () => {
211
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
212
+
213
+ expect($('.ons-section-nav__list > .ons-section-nav__item:nth-child(1) .ons-section-nav__sub-items').length).toBe(0);
214
+ expect($('.ons-section-nav__list > .ons-section-nav__item:nth-child(2) .ons-section-nav__sub-items').length).toBe(1);
215
+ expect($('.ons-section-nav__list > .ons-section-nav__item:nth-child(3) .ons-section-nav__sub-items').length).toBe(0);
216
+ });
217
+
218
+ it('renders the expected anchor navigation items', () => {
219
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL));
220
+
221
+ const itemLabels = mapAll($('.ons-section-nav__sub-items .ons-section-nav__item .ons-section-nav__link'), (node) =>
222
+ node.text().trim(),
223
+ );
224
+ expect(itemLabels).toEqual(['Sub section 1', 'Sub section 2', 'Sub section 3']);
225
+
226
+ const itemLinks = mapAll($('.ons-section-nav__sub-items .ons-section-nav__item .ons-section-nav__link'), (node) =>
227
+ node.attr('href'),
228
+ );
229
+ expect(itemLinks).toEqual(['#sub-section-1', '#sub-section-2', '#sub-section-3']);
230
+ });
231
+ });
232
+
233
+ describe('Section Items', () => {
234
+ it('passes jest-axe checks', async () => {
235
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL_WITH_SECTIONS));
236
+
237
+ const results = await axe($.html());
238
+ expect(results).toHaveNoViolations();
239
+ });
240
+
241
+ it('renders itemsLists, anchors and heading for each section', () => {
242
+ const $ = cheerio.load(renderComponent('section-navigation', EXAMPLE_SECTION_NAVIGATION_VERTICAL_WITH_SECTIONS));
243
+
244
+ const anchors = mapAll($('.ons-section-nav__sub-items .ons-section-nav__item .ons-section-nav__link'), (node) =>
245
+ node.text().trim(),
246
+ );
247
+ expect(anchors).toEqual(['Sub section 1', 'Sub section 2', 'Sub section 3']);
248
+
249
+ const itemLists = mapAll($('.ons-section-nav__item .ons-section-nav__link'), (node) => node.text().trim());
250
+ expect(itemLists).toEqual(['Section 1', 'Section 2', 'Sub section 1', 'Sub section 2', 'Sub section 3', 'Section 3']);
251
+
252
+ const headings = mapAll($('h3'), (node) => $(node).text().trim());
253
+ expect(headings).toEqual(['Section Title']);
254
+ });
255
+ });
255
256
  });
256
- });
257
257
  });
@@ -1,92 +1,92 @@
1
1
  .ons-section-nav {
2
- &:not(&--vertical) {
3
- border-bottom: 1px solid var(--ons-color-borders);
4
- }
5
-
6
- &__list {
7
- list-style: none;
8
- margin: 0;
9
- padding: 0;
10
- }
11
-
12
- &__sub {
13
- padding-bottom: 0.5rem;
14
- padding-top: 0.5rem;
15
- }
2
+ &:not(&--vertical) {
3
+ border-bottom: 1px solid var(--ons-color-borders);
4
+ }
16
5
 
17
- &__link {
18
- text-decoration: none;
19
- &:hover {
20
- color: var(--ons-color-text-link-hover);
21
- text-decoration: underline solid var(--ons-color-text-link-hover) 2px;
6
+ &__list {
7
+ list-style: none;
8
+ margin: 0;
9
+ padding: 0;
22
10
  }
23
- }
24
11
 
25
- &__item {
26
- font-size: 1rem;
27
- padding: 0;
28
- &--active {
29
- border-left: 4px solid var(--ons-color-text-link-active);
30
- font-weight: $font-weight-bold;
31
- margin-left: -18px;
32
- padding-left: 14px;
33
- a,
34
- h2,
35
- h3,
36
- h4,
37
- h5,
38
- h6 {
39
- color: var(--ons-color-text-link-active);
40
- }
12
+ &__sub {
13
+ padding-bottom: 0.5rem;
14
+ padding-top: 0.5rem;
41
15
  }
42
- & & {
43
- margin-bottom: 0.3rem;
16
+
17
+ &__link {
18
+ text-decoration: none;
19
+ &:hover {
20
+ color: var(--ons-color-text-link-hover);
21
+ text-decoration: underline solid var(--ons-color-text-link-hover) 2px;
22
+ }
44
23
  }
45
- }
46
24
 
47
- &__item-header {
48
- @extend .ons-u-mb-no;
25
+ &__item {
26
+ font-size: 1rem;
27
+ padding: 0;
28
+ &--active {
29
+ border-left: 4px solid var(--ons-color-text-link-active);
30
+ font-weight: $font-weight-bold;
31
+ margin-left: -18px;
32
+ padding-left: 14px;
33
+ a,
34
+ h2,
35
+ h3,
36
+ h4,
37
+ h5,
38
+ h6 {
39
+ color: var(--ons-color-text-link-active);
40
+ }
41
+ }
42
+ & & {
43
+ margin-bottom: 0.3rem;
44
+ }
45
+ }
49
46
 
50
- font-size: 1rem;
51
- font-weight: 700;
52
- line-height: 1.6;
53
- }
47
+ &__item-header {
48
+ @extend .ons-u-mb-no;
54
49
 
55
- &__sub-items {
56
- a {
57
- color: var(--ons-color-text-link);
58
- font-weight: $font-weight-regular;
50
+ font-size: 1rem;
51
+ font-weight: 700;
52
+ line-height: 1.6;
59
53
  }
60
- }
61
54
 
62
- &:not(&--vertical) & {
63
- &__item {
64
- border: none;
65
- border-bottom: 4px solid transparent;
66
- display: inline-block;
67
- margin: 0 1rem 0 0;
68
- text-align: center;
69
- &--active,
70
- &:hover {
71
- border-color: var(--ons-color-text-link-active);
72
- margin: 0 1rem 0 0;
73
- padding: 0;
74
- a,
75
- h2,
76
- h3,
77
- h4,
78
- h5,
79
- h6 {
80
- color: var(--ons-color-text-link-active);
55
+ &__sub-items {
56
+ a {
57
+ color: var(--ons-color-text-link);
58
+ font-weight: $font-weight-regular;
81
59
  }
82
- }
83
60
  }
84
61
 
85
- &__link {
86
- text-decoration: none;
87
- &:hover {
88
- text-decoration: none;
89
- }
62
+ &:not(&--vertical) & {
63
+ &__item {
64
+ border: 0;
65
+ border-bottom: 4px solid transparent;
66
+ display: inline-block;
67
+ margin: 0 1rem 0 0;
68
+ text-align: center;
69
+ &--active,
70
+ &:hover {
71
+ border-color: var(--ons-color-text-link-active);
72
+ margin: 0 1rem 0 0;
73
+ padding: 0;
74
+ a,
75
+ h2,
76
+ h3,
77
+ h4,
78
+ h5,
79
+ h6 {
80
+ color: var(--ons-color-text-link-active);
81
+ }
82
+ }
83
+ }
84
+
85
+ &__link {
86
+ text-decoration: none;
87
+ &:hover {
88
+ text-decoration: none;
89
+ }
90
+ }
90
91
  }
91
- }
92
92
  }