desy-html 12.1.0 → 13.0.0

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 (508) hide show
  1. package/README.md +36 -36
  2. package/config/tailwind.config.js +218 -218
  3. package/docs/_global.content-placeholder.njk +7 -7
  4. package/docs/_global.foot.njk +14 -14
  5. package/docs/_global.head.njk +28 -28
  6. package/docs/_include.template-header.njk +381 -381
  7. package/docs/_macro.component-example.njk +6 -6
  8. package/docs/_macro.example-render.njk +376 -376
  9. package/docs/_macro.load-component-params.njk +2 -2
  10. package/docs/_macro.load-component-template.njk +3 -3
  11. package/docs/_macro.render-caller.njk +3 -3
  12. package/docs/_macro.show-code-from-file.njk +57 -57
  13. package/docs/_macro.show-html-from-file.njk +42 -42
  14. package/docs/_template.default.njk +8 -8
  15. package/docs/_template.examples.njk +13 -13
  16. package/docs/catalogo.html +26 -26
  17. package/docs/componentes.html +180 -180
  18. package/docs/ds/_ds.example.accordion.njk +109 -109
  19. package/docs/ds/_ds.example.border.njk +39 -39
  20. package/docs/ds/_ds.example.botones-alert-sm.njk +264 -264
  21. package/docs/ds/_ds.example.botones-alert.njk +264 -264
  22. package/docs/ds/_ds.example.botones-default-sm.njk +264 -264
  23. package/docs/ds/_ds.example.botones-default.njk +258 -258
  24. package/docs/ds/_ds.example.botones-primary-lg.njk +264 -264
  25. package/docs/ds/_ds.example.botones-primary-sm.njk +264 -264
  26. package/docs/ds/_ds.example.botones-primary.njk +264 -264
  27. package/docs/ds/_ds.example.botones-transparent-sm.njk +264 -264
  28. package/docs/ds/_ds.example.botones-transparent.njk +264 -264
  29. package/docs/ds/_ds.example.breadcrumbs.njk +65 -65
  30. package/docs/ds/_ds.example.card.njk +198 -198
  31. package/docs/ds/_ds.example.checkboxes.njk +377 -377
  32. package/docs/ds/_ds.example.collapsible.njk +18 -18
  33. package/docs/ds/_ds.example.color-de-interaccion.njk +16 -16
  34. package/docs/ds/_ds.example.colores-cabecera.njk +15 -15
  35. package/docs/ds/_ds.example.colores-de-soporte.njk +82 -82
  36. package/docs/ds/_ds.example.colores-neutros.njk +26 -26
  37. package/docs/ds/_ds.example.date-input.njk +363 -363
  38. package/docs/ds/_ds.example.description-list.njk +289 -289
  39. package/docs/ds/_ds.example.details.njk +23 -23
  40. package/docs/ds/_ds.example.dropdowns-default.njk +186 -186
  41. package/docs/ds/_ds.example.dropdowns-en-uso.njk +105 -105
  42. package/docs/ds/_ds.example.dropdowns-variaciones.njk +224 -224
  43. package/docs/ds/_ds.example.error-summary.njk +34 -34
  44. package/docs/ds/_ds.example.file-upload.njk +54 -54
  45. package/docs/ds/_ds.example.footer.njk +28 -28
  46. package/docs/ds/_ds.example.header-advanced.njk +70 -70
  47. package/docs/ds/_ds.example.header.njk +211 -211
  48. package/docs/ds/_ds.example.input-group.njk +242 -242
  49. package/docs/ds/_ds.example.input.njk +164 -164
  50. package/docs/ds/_ds.example.item.njk +176 -176
  51. package/docs/ds/_ds.example.layout-escritorio.njk +38 -38
  52. package/docs/ds/_ds.example.layout-movil.njk +14 -14
  53. package/docs/ds/_ds.example.layout-sidebar.njk +11 -11
  54. package/docs/ds/_ds.example.links-list.njk +170 -170
  55. package/docs/ds/_ds.example.listbox-default.njk +677 -677
  56. package/docs/ds/_ds.example.listbox-variaciones.njk +824 -824
  57. package/docs/ds/_ds.example.menu-horizontal.njk +66 -66
  58. package/docs/ds/_ds.example.menu-navigation.njk +493 -493
  59. package/docs/ds/_ds.example.menu-vertical.njk +129 -129
  60. package/docs/ds/_ds.example.menubar-en-uso.njk +244 -244
  61. package/docs/ds/_ds.example.menubar-variaciones.njk +785 -785
  62. package/docs/ds/_ds.example.modal.njk +210 -210
  63. package/docs/ds/_ds.example.nav.njk +158 -158
  64. package/docs/ds/_ds.example.notification.njk +122 -122
  65. package/docs/ds/_ds.example.pagination.njk +190 -190
  66. package/docs/ds/_ds.example.pills.njk +215 -215
  67. package/docs/ds/_ds.example.radios.njk +419 -419
  68. package/docs/ds/_ds.example.searchbar.njk +87 -87
  69. package/docs/ds/_ds.example.select.njk +390 -390
  70. package/docs/ds/_ds.example.status-item.njk +239 -239
  71. package/docs/ds/_ds.example.status.njk +47 -47
  72. package/docs/ds/_ds.example.table.njk +740 -740
  73. package/docs/ds/_ds.example.tabs.njk +136 -136
  74. package/docs/ds/_ds.example.textarea.njk +237 -237
  75. package/docs/ds/_ds.example.textos.njk +32 -32
  76. package/docs/ds/_ds.example.toggle.njk +75 -75
  77. package/docs/ds/_ds.example.tree.njk +456 -456
  78. package/docs/ds/_ds.example.typography.njk +225 -225
  79. package/docs/ds/_ds.macro.code-snippet.njk +32 -32
  80. package/docs/ds/_ds.macro.section-title.njk +2 -2
  81. package/docs/ds/_ds.macro.subsection-title.njk +2 -2
  82. package/docs/ds/_ds.section.avisos.njk +22 -22
  83. package/docs/ds/_ds.section.botones.njk +53 -53
  84. package/docs/ds/_ds.section.campo-y-area-de-texto.njk +19 -19
  85. package/docs/ds/_ds.section.color.njk +147 -147
  86. package/docs/ds/_ds.section.datos.njk +37 -37
  87. package/docs/ds/_ds.section.dropdowns.njk +23 -23
  88. package/docs/ds/_ds.section.espaciado.njk +296 -296
  89. package/docs/ds/_ds.section.forms.njk +68 -68
  90. package/docs/ds/_ds.section.informacion.njk +12 -12
  91. package/docs/ds/_ds.section.layout.njk +63 -63
  92. package/docs/ds/_ds.section.menubar.njk +18 -18
  93. package/docs/ds/_ds.section.mostrar-ocultar.njk +33 -33
  94. package/docs/ds/_ds.section.navigation.njk +57 -57
  95. package/docs/ds/_ds.section.textos.njk +287 -287
  96. package/docs/ds/_ds.section.typography.njk +28 -28
  97. package/docs/estilos.html +37 -37
  98. package/docs/examples-accordion-history.html +8 -8
  99. package/docs/examples-accordion.html +8 -8
  100. package/docs/examples-alert.html +8 -8
  101. package/docs/examples-breadcrumbs.html +8 -8
  102. package/docs/examples-button-loader.html +8 -8
  103. package/docs/examples-button.html +8 -8
  104. package/docs/examples-card.html +7 -7
  105. package/docs/examples-character-count.html +8 -8
  106. package/docs/examples-checkboxes.html +7 -7
  107. package/docs/examples-collapsible.html +7 -7
  108. package/docs/examples-date-input.html +8 -8
  109. package/docs/examples-datepicker.html +8 -8
  110. package/docs/examples-description-list.html +8 -8
  111. package/docs/examples-details.html +8 -8
  112. package/docs/examples-dialog.html +7 -7
  113. package/docs/examples-dropdown.html +8 -8
  114. package/docs/examples-error-message.html +8 -8
  115. package/docs/examples-error-summary.html +8 -8
  116. package/docs/examples-fieldset.html +8 -8
  117. package/docs/examples-file-upload.html +8 -8
  118. package/docs/examples-footer.html +8 -8
  119. package/docs/examples-header-advanced.html +8 -8
  120. package/docs/examples-header-mini.html +8 -8
  121. package/docs/examples-header.html +8 -8
  122. package/docs/examples-hint.html +8 -8
  123. package/docs/examples-input-group.html +8 -8
  124. package/docs/examples-input.html +8 -8
  125. package/docs/examples-item.html +8 -8
  126. package/docs/examples-label.html +8 -8
  127. package/docs/examples-links-list.html +7 -7
  128. package/docs/examples-listbox.html +8 -8
  129. package/docs/examples-media-object.html +7 -7
  130. package/docs/examples-menu-horizontal.html +8 -8
  131. package/docs/examples-menu-navigation.html +8 -8
  132. package/docs/examples-menu-vertical.html +7 -7
  133. package/docs/examples-menubar.html +7 -7
  134. package/docs/examples-modal.html +7 -7
  135. package/docs/examples-nav.html +8 -8
  136. package/docs/examples-notification.html +8 -8
  137. package/docs/examples-pagination.html +8 -8
  138. package/docs/examples-pill.html +8 -8
  139. package/docs/examples-radios.html +8 -8
  140. package/docs/examples-searchbar.html +8 -8
  141. package/docs/examples-select.html +9 -9
  142. package/docs/examples-skip-link.html +8 -8
  143. package/docs/examples-spinner.html +8 -8
  144. package/docs/examples-status-item.html +8 -8
  145. package/docs/examples-status.html +8 -8
  146. package/docs/examples-table-advanced.html +8 -8
  147. package/docs/examples-table.html +8 -8
  148. package/docs/examples-tabs.html +8 -8
  149. package/docs/examples-textarea.html +8 -8
  150. package/docs/examples-toggle.html +8 -8
  151. package/docs/examples-tooltip.html +8 -8
  152. package/docs/examples-tree.html +8 -8
  153. package/docs/index.html +747 -739
  154. package/docs/pagina-accesibilidad.html +109 -109
  155. package/docs/pagina-mapa-web.html +136 -136
  156. package/docs/pagina-prueba.html +94 -94
  157. package/docs/plantilla-con-header-advanced.html +13 -13
  158. package/docs/plantilla-editar-con-cabecera-fija-y-sidebar-sticky.html +153 -153
  159. package/docs/plantilla-editar-con-cabecera-fija.html +16 -16
  160. package/docs/plantilla-logueado-con-cabecera-fija-headroom.html +14 -14
  161. package/docs/plantilla-logueado-con-cabecera-fija.html +14 -14
  162. package/docs/plantilla-logueado-con-selector-de-app-y-sidebar.html +163 -163
  163. package/docs/plantilla-logueado-con-selector-de-app-y-subheader.html +15 -15
  164. package/docs/plantilla-logueado-con-selector-de-app.html +13 -13
  165. package/docs/plantilla-logueado-con-titulo-de-app.html +13 -13
  166. package/docs/plantilla-sin-loguear.html +13 -13
  167. package/docs/plantillas.html +88 -88
  168. package/docs/spinner-plantilla-con-header-advanced.html +1 -1
  169. package/docs/spinner-plantilla-editar-con-cabecera-fija.html +5 -5
  170. package/docs/spinner-plantilla-logueado-con-cabecera-fija.html +1 -1
  171. package/docs/spinner-plantilla-logueado-con-selector-de-app-y-subheader.html +4 -4
  172. package/docs/spinner-plantilla-logueado-con-titulo-de-app.html +1 -1
  173. package/docs/spinner-plantilla-sin-loguear.html +17 -17
  174. package/gulpfile.js +127 -127
  175. package/package.json +67 -67
  176. package/src/EUPL-1.2.txt +287 -287
  177. package/src/css/base.css +44 -44
  178. package/src/css/component.form-group.css +23 -23
  179. package/src/css/component.headroom.css +31 -31
  180. package/src/css/component.text.css +165 -165
  181. package/src/css/component.tippy-box.css +11 -11
  182. package/src/css/styles.css +51 -51
  183. package/src/js/aria/MenuHorizontal.js +63 -63
  184. package/src/js/aria/MenuNavigation.js +4 -1
  185. package/src/js/aria/MenuVertical.js +60 -60
  186. package/src/js/aria/MenubarAction.js +100 -25
  187. package/src/js/aria/Nav.js +60 -60
  188. package/src/js/aria/accordion.js +264 -264
  189. package/src/js/aria/checkBoxes.js +52 -52
  190. package/src/js/aria/collapsible.js +44 -44
  191. package/src/js/aria/dataGrid.js +950 -950
  192. package/src/js/aria/linksList.js +42 -42
  193. package/src/js/aria/listbox.js +1 -1
  194. package/src/js/aria/notification.js +56 -56
  195. package/src/js/aria/radioButton.js +50 -50
  196. package/src/js/aria/tabs.js +0 -2
  197. package/src/js/aria/toggle.js +61 -61
  198. package/src/js/aria/utils.js +193 -193
  199. package/src/js/cally.js +1114 -1114
  200. package/src/js/desy-html.js +564 -573
  201. package/src/js/filters/filter-caller.js +8 -8
  202. package/src/js/filters/filter-escape-ltgt.js +6 -6
  203. package/src/js/filters/filter-quotes.js +49 -49
  204. package/src/js/filters/filter-slugify.js +11 -11
  205. package/src/js/filters/filter-version.js +8 -8
  206. package/src/js/filters/highlight.js +14 -14
  207. package/src/js/filters/index.js +19 -19
  208. package/src/js/globals/get-html-code-from-example.js +31 -31
  209. package/src/js/globals/get-html-code-from-file.js +26 -26
  210. package/src/js/globals/get-nunjucks-code-from-example.js +31 -31
  211. package/src/js/globals/get-nunjucks-code-from-file.js +24 -24
  212. package/src/js/globals/index.js +14 -14
  213. package/src/js/headroom.min.js +6 -6
  214. package/src/js/index.js +73 -75
  215. package/src/js/popper.min.js +6 -6
  216. package/src/js/tippy-bundle.umd.min.js +2 -2
  217. package/src/templates/components/accordion/_examples.accordion.njk +398 -398
  218. package/src/templates/components/accordion/_macro.accordion.njk +3 -3
  219. package/src/templates/components/accordion/_template.accordion.njk +131 -131
  220. package/src/templates/components/accordion/params.accordion.yaml +125 -125
  221. package/src/templates/components/accordion-history/_examples.accordion-history.njk +431 -431
  222. package/src/templates/components/accordion-history/_macro.accordion-history.njk +3 -3
  223. package/src/templates/components/accordion-history/_template.accordion-history.njk +193 -193
  224. package/src/templates/components/accordion-history/params.accordion-history.yaml +129 -129
  225. package/src/templates/components/alert/_examples.alert.njk +79 -79
  226. package/src/templates/components/alert/_macro.alert.njk +3 -3
  227. package/src/templates/components/alert/_styles.alert.css +9 -9
  228. package/src/templates/components/alert/_template.alert.njk +16 -16
  229. package/src/templates/components/alert/params.alert.yaml +25 -25
  230. package/src/templates/components/breadcrumbs/_examples.breadcrumbs.njk +374 -374
  231. package/src/templates/components/breadcrumbs/_macro.breadcrumbs.njk +3 -3
  232. package/src/templates/components/breadcrumbs/_styles.breadcrumbs.css +81 -78
  233. package/src/templates/components/breadcrumbs/_template.breadcrumbs.njk +77 -77
  234. package/src/templates/components/breadcrumbs/params.breadcrumbs.yaml +44 -44
  235. package/src/templates/components/button/_examples.button.njk +295 -296
  236. package/src/templates/components/button/_macro.button.njk +3 -3
  237. package/src/templates/components/button/_styles.button.css +189 -189
  238. package/src/templates/components/button/_template.button.njk +49 -49
  239. package/src/templates/components/button/params.button.yaml +48 -48
  240. package/src/templates/components/button-loader/_examples.button-loader.njk +288 -288
  241. package/src/templates/components/button-loader/_macro.button-loader.njk +3 -3
  242. package/src/templates/components/button-loader/_styles.button-loader.css +204 -204
  243. package/src/templates/components/button-loader/_template.button-loader.njk +84 -84
  244. package/src/templates/components/button-loader/params.button-loader.yaml +74 -74
  245. package/src/templates/components/card/_examples.card.njk +303 -303
  246. package/src/templates/components/card/_macro.card.njk +3 -3
  247. package/src/templates/components/card/_template.card.njk +34 -34
  248. package/src/templates/components/card/params.card.yaml +112 -112
  249. package/src/templates/components/character-count/_examples.character-count.njk +147 -147
  250. package/src/templates/components/character-count/_macro.character-count.njk +5 -5
  251. package/src/templates/components/character-count/_template.character-count.njk +38 -38
  252. package/src/templates/components/character-count/params.character-count.yaml +77 -77
  253. package/src/templates/components/checkboxes/_examples.checkboxes.njk +734 -734
  254. package/src/templates/components/checkboxes/_macro.checkboxes.njk +3 -3
  255. package/src/templates/components/checkboxes/_styles.checkboxes.css +31 -31
  256. package/src/templates/components/checkboxes/_template.checkboxes.njk +137 -138
  257. package/src/templates/components/checkboxes/params.checkboxes.yaml +116 -116
  258. package/src/templates/components/collapsible/_examples.collapsible.njk +77 -77
  259. package/src/templates/components/collapsible/_macro.collapsible.njk +3 -3
  260. package/src/templates/components/collapsible/_styles.collapsible.css +33 -33
  261. package/src/templates/components/collapsible/_template.collapsible.njk +17 -17
  262. package/src/templates/components/collapsible/params.collapsible.yaml +48 -48
  263. package/src/templates/components/date-input/_examples.date-input.njk +500 -500
  264. package/src/templates/components/date-input/_macro.date-input.njk +3 -3
  265. package/src/templates/components/date-input/_template.date-input.njk +125 -126
  266. package/src/templates/components/date-input/params.date-input.yaml +97 -97
  267. package/src/templates/components/datepicker/_examples.datepicker.njk +329 -329
  268. package/src/templates/components/datepicker/_macro.datepicker.njk +3 -3
  269. package/src/templates/components/datepicker/_styles.datepicker.css +89 -89
  270. package/src/templates/components/datepicker/_template.datepicker.njk +130 -131
  271. package/src/templates/components/datepicker/params.datepicker.yaml +104 -104
  272. package/src/templates/components/description-list/_examples.description-list.njk +436 -436
  273. package/src/templates/components/description-list/_macro.description-list.njk +3 -3
  274. package/src/templates/components/description-list/_template.description-list.njk +17 -17
  275. package/src/templates/components/description-list/params.description-list.yaml +61 -61
  276. package/src/templates/components/details/_examples.details.njk +44 -44
  277. package/src/templates/components/details/_macro.details.njk +3 -3
  278. package/src/templates/components/details/_template.details.njk +17 -17
  279. package/src/templates/components/details/params.details.yaml +40 -40
  280. package/src/templates/components/dialog/_examples.dialog.njk +138 -138
  281. package/src/templates/components/dialog/_macro.dialog.njk +3 -3
  282. package/src/templates/components/dialog/_styles.dialog.css +19 -19
  283. package/src/templates/components/dialog/_template.dialog.njk +12 -12
  284. package/src/templates/components/dialog/params.dialog.yaml +25 -25
  285. package/src/templates/components/dropdown/_examples.dropdown.njk +136 -136
  286. package/src/templates/components/dropdown/_macro.dropdown.njk +3 -3
  287. package/src/templates/components/dropdown/_styles.dropdown.css +203 -203
  288. package/src/templates/components/dropdown/_template.dropdown.njk +34 -34
  289. package/src/templates/components/dropdown/params.dropdown.yaml +32 -32
  290. package/src/templates/components/error-message/_examples.error-message.njk +14 -14
  291. package/src/templates/components/error-message/_macro.error-message.njk +5 -5
  292. package/src/templates/components/error-message/_template.error-message.njk +8 -8
  293. package/src/templates/components/error-message/params.error-message.yaml +23 -23
  294. package/src/templates/components/error-summary/_examples.error-summary.njk +81 -81
  295. package/src/templates/components/error-summary/_macro.error-summary.njk +5 -5
  296. package/src/templates/components/error-summary/_template.error-summary.njk +48 -48
  297. package/src/templates/components/error-summary/params.error-summary.yaml +52 -52
  298. package/src/templates/components/fieldset/_examples.fieldset.njk +88 -88
  299. package/src/templates/components/fieldset/_macro.fieldset.njk +2 -2
  300. package/src/templates/components/fieldset/_template.fieldset.njk +46 -46
  301. package/src/templates/components/fieldset/params.fieldset.yaml +49 -49
  302. package/src/templates/components/file-upload/_examples.file-upload.njk +84 -84
  303. package/src/templates/components/file-upload/_macro.file-upload.njk +2 -2
  304. package/src/templates/components/file-upload/_template.file-upload.njk +45 -46
  305. package/src/templates/components/file-upload/params.file-upload.yaml +48 -48
  306. package/src/templates/components/footer/_examples.footer.njk +450 -450
  307. package/src/templates/components/footer/_macro.footer.njk +3 -3
  308. package/src/templates/components/footer/_styles.footer.css +43 -43
  309. package/src/templates/components/footer/_template.footer.njk +115 -114
  310. package/src/templates/components/footer/params.footer.yaml +140 -140
  311. package/src/templates/components/header/_examples.header.njk +542 -542
  312. package/src/templates/components/header/_macro.header.header__dropdown.njk +3 -3
  313. package/src/templates/components/header/_macro.header.header__navigation.njk +3 -3
  314. package/src/templates/components/header/_macro.header.header__offcanvas.njk +3 -3
  315. package/src/templates/components/header/_macro.header.header__offcanvasButton.njk +3 -3
  316. package/src/templates/components/header/_macro.header.header__subnav.njk +3 -3
  317. package/src/templates/components/header/_macro.header.njk +3 -3
  318. package/src/templates/components/header/_styles.header.css +12 -12
  319. package/src/templates/components/header/_template.header.header__dropdown.njk +27 -27
  320. package/src/templates/components/header/_template.header.header__navigation.njk +26 -28
  321. package/src/templates/components/header/_template.header.header__offcanvas.njk +20 -20
  322. package/src/templates/components/header/_template.header.header__offcanvasButton.njk +10 -10
  323. package/src/templates/components/header/_template.header.header__subnav.njk +33 -33
  324. package/src/templates/components/header/_template.header.njk +139 -138
  325. package/src/templates/components/header/params.header.yaml +280 -280
  326. package/src/templates/components/header-advanced/_examples.header-advanced.njk +1033 -1023
  327. package/src/templates/components/header-advanced/_macro.header-advanced.njk +3 -3
  328. package/src/templates/components/header-advanced/_template.header-advanced.njk +168 -168
  329. package/src/templates/components/header-advanced/params.header-advanced.yaml +346 -346
  330. package/src/templates/components/header-mini/_examples.header-mini.njk +304 -304
  331. package/src/templates/components/header-mini/_macro.header-mini.njk +3 -3
  332. package/src/templates/components/header-mini/_template.header-mini.njk +39 -39
  333. package/src/templates/components/header-mini/params.header-mini.yaml +80 -80
  334. package/src/templates/components/hint/_examples.hint.njk +14 -14
  335. package/src/templates/components/hint/_macro.hint.njk +3 -3
  336. package/src/templates/components/hint/_template.hint.njk +3 -3
  337. package/src/templates/components/hint/params.hint.yaml +34 -34
  338. package/src/templates/components/input/_examples.input.njk +309 -309
  339. package/src/templates/components/input/_macro.input.njk +3 -3
  340. package/src/templates/components/input/_styles.input.css +18 -18
  341. package/src/templates/components/input/_template.input.njk +53 -54
  342. package/src/templates/components/input/params.input.yaml +80 -80
  343. package/src/templates/components/input-group/_examples.input-group.njk +503 -503
  344. package/src/templates/components/input-group/_macro.input-group.njk +3 -3
  345. package/src/templates/components/input-group/_template.input-group.njk +107 -108
  346. package/src/templates/components/input-group/params.input-group.yaml +123 -123
  347. package/src/templates/components/item/_examples.item.njk +273 -273
  348. package/src/templates/components/item/_macro.item.njk +3 -3
  349. package/src/templates/components/item/_template.item.njk +73 -73
  350. package/src/templates/components/item/params.item.yaml +101 -101
  351. package/src/templates/components/label/_examples.label.njk +34 -34
  352. package/src/templates/components/label/_macro.label.njk +5 -5
  353. package/src/templates/components/label/_template.label.njk +37 -37
  354. package/src/templates/components/label/params.label.yaml +28 -28
  355. package/src/templates/components/links-list/_examples.links-list.njk +647 -647
  356. package/src/templates/components/links-list/_macro.links-list.njk +3 -3
  357. package/src/templates/components/links-list/_template.links-list.njk +119 -119
  358. package/src/templates/components/links-list/params.links-list.yaml +101 -101
  359. package/src/templates/components/listbox/_examples.listbox.njk +691 -691
  360. package/src/templates/components/listbox/_macro.listbox.njk +3 -3
  361. package/src/templates/components/listbox/_styles.listbox.css +231 -231
  362. package/src/templates/components/listbox/_template.listbox.njk +90 -90
  363. package/src/templates/components/listbox/params.listbox.yaml +85 -85
  364. package/src/templates/components/media-object/_examples.media-object.njk +48 -48
  365. package/src/templates/components/media-object/_macro.media-object.njk +3 -3
  366. package/src/templates/components/media-object/_template.media-object.njk +21 -21
  367. package/src/templates/components/media-object/params.media-object.yaml +16 -16
  368. package/src/templates/components/menu-horizontal/_examples.menu-horizontal.njk +529 -529
  369. package/src/templates/components/menu-horizontal/_macro.menu-horizontal.njk +3 -3
  370. package/src/templates/components/menu-horizontal/_styles.menu-horizontal.css +162 -162
  371. package/src/templates/components/menu-horizontal/_template.menu-horizontal.njk +36 -36
  372. package/src/templates/components/menu-horizontal/params.menu-horizontal.yaml +53 -53
  373. package/src/templates/components/menu-navigation/_examples.menu-navigation.njk +1190 -1213
  374. package/src/templates/components/menu-navigation/_macro.menu-navigation.njk +3 -3
  375. package/src/templates/components/menu-navigation/_styles.menu-navigation.css +235 -235
  376. package/src/templates/components/menu-navigation/_template.menu-navigation.njk +87 -89
  377. package/src/templates/components/menu-navigation/params.menu-navigation.yaml +86 -86
  378. package/src/templates/components/menu-vertical/_examples.menu-vertical.njk +739 -739
  379. package/src/templates/components/menu-vertical/_macro.menu-vertical.njk +3 -3
  380. package/src/templates/components/menu-vertical/_template.menu-vertical.njk +92 -92
  381. package/src/templates/components/menu-vertical/params.menu-vertical.yaml +77 -77
  382. package/src/templates/components/menubar/_examples.menubar.njk +1777 -1777
  383. package/src/templates/components/menubar/_macro.menubar.njk +3 -3
  384. package/src/templates/components/menubar/_styles.menubar.css +272 -262
  385. package/src/templates/components/menubar/_template.menubar.njk +106 -105
  386. package/src/templates/components/menubar/params.menubar.yaml +139 -139
  387. package/src/templates/components/modal/_examples.modal.njk +354 -354
  388. package/src/templates/components/modal/_macro.modal.njk +3 -3
  389. package/src/templates/components/modal/_template.modal.njk +129 -129
  390. package/src/templates/components/modal/params.modal.yaml +77 -77
  391. package/src/templates/components/nav/_examples.nav.njk +402 -402
  392. package/src/templates/components/nav/_macro.nav.njk +3 -3
  393. package/src/templates/components/nav/_template.nav.njk +53 -53
  394. package/src/templates/components/nav/params.nav.yaml +61 -61
  395. package/src/templates/components/notification/_examples.notification.njk +193 -193
  396. package/src/templates/components/notification/_macro.notification.njk +3 -3
  397. package/src/templates/components/notification/_styles.notification.css +28 -28
  398. package/src/templates/components/notification/_template.notification.njk +86 -86
  399. package/src/templates/components/notification/params.notification.yaml +101 -101
  400. package/src/templates/components/pagination/_examples.pagination.njk +402 -402
  401. package/src/templates/components/pagination/_macro.pagination.njk +3 -3
  402. package/src/templates/components/pagination/_template.pagination.njk +162 -162
  403. package/src/templates/components/pagination/params.pagination.yaml +150 -150
  404. package/src/templates/components/pill/_examples.pill.njk +101 -101
  405. package/src/templates/components/pill/_macro.pill.njk +3 -3
  406. package/src/templates/components/pill/_styles.pill.css +63 -63
  407. package/src/templates/components/pill/_template.pill.njk +38 -38
  408. package/src/templates/components/pill/params.pill.yaml +28 -28
  409. package/src/templates/components/radios/_examples.radios.njk +637 -637
  410. package/src/templates/components/radios/_macro.radios.njk +5 -5
  411. package/src/templates/components/radios/_styles.radios.css +31 -31
  412. package/src/templates/components/radios/_template.radios.njk +133 -134
  413. package/src/templates/components/radios/params.radios.yaml +104 -104
  414. package/src/templates/components/searchbar/_examples.searchbar.njk +98 -98
  415. package/src/templates/components/searchbar/_macro.searchbar.njk +3 -3
  416. package/src/templates/components/searchbar/_template.searchbar.njk +45 -46
  417. package/src/templates/components/searchbar/params.searchbar.yaml +46 -46
  418. package/src/templates/components/select/_examples.select.njk +336 -336
  419. package/src/templates/components/select/_macro.select.njk +5 -5
  420. package/src/templates/components/select/_styles.select.css +47 -47
  421. package/src/templates/components/select/_template.select.njk +67 -70
  422. package/src/templates/components/select/params.select.yaml +93 -93
  423. package/src/templates/components/skip-link/_examples.skip-link.njk +19 -19
  424. package/src/templates/components/skip-link/_macro.skip-link.njk +3 -3
  425. package/src/templates/components/skip-link/_styles.skip-link.css +13 -13
  426. package/src/templates/components/skip-link/_template.skip-link.njk +4 -4
  427. package/src/templates/components/skip-link/params.skip-link.yaml +20 -20
  428. package/src/templates/components/spinner/_examples.spinner.njk +52 -52
  429. package/src/templates/components/spinner/_macro.spinner.njk +3 -3
  430. package/src/templates/components/spinner/_styles.spinner.css +32 -32
  431. package/src/templates/components/spinner/_template.spinner.njk +12 -8
  432. package/src/templates/components/spinner/params.spinner.yaml +12 -12
  433. package/src/templates/components/status/_examples.status.njk +49 -49
  434. package/src/templates/components/status/_macro.status.njk +3 -3
  435. package/src/templates/components/status/_template.status.njk +23 -23
  436. package/src/templates/components/status/params.status.yaml +24 -24
  437. package/src/templates/components/status-item/_examples.status-item.njk +245 -245
  438. package/src/templates/components/status-item/_macro.status-item.njk +3 -3
  439. package/src/templates/components/status-item/_template.status-item.njk +99 -99
  440. package/src/templates/components/status-item/params.status-item.yaml +106 -106
  441. package/src/templates/components/table/_examples.table.njk +668 -668
  442. package/src/templates/components/table/_macro.table.njk +3 -3
  443. package/src/templates/components/table/_styles.table.css +20 -20
  444. package/src/templates/components/table/_template.table.njk +68 -68
  445. package/src/templates/components/table/params.table.yaml +130 -130
  446. package/src/templates/components/table-advanced/_examples.table-advanced.njk +785 -785
  447. package/src/templates/components/table-advanced/_macro.table-advanced.njk +3 -3
  448. package/src/templates/components/table-advanced/_styles.table-advanced.css +65 -65
  449. package/src/templates/components/table-advanced/_template.table-advanced.njk +210 -210
  450. package/src/templates/components/table-advanced/params.table-advanced.yaml +160 -160
  451. package/src/templates/components/tabs/_examples.tabs.njk +516 -516
  452. package/src/templates/components/tabs/_macro.tabs.njk +3 -3
  453. package/src/templates/components/tabs/_styles.tabs.css +78 -78
  454. package/src/templates/components/tabs/_template.tabs.njk +70 -70
  455. package/src/templates/components/tabs/params.tabs.yaml +83 -83
  456. package/src/templates/components/textarea/_examples.textarea.njk +131 -131
  457. package/src/templates/components/textarea/_macro.textarea.njk +5 -5
  458. package/src/templates/components/textarea/_template.textarea.njk +47 -48
  459. package/src/templates/components/textarea/params.textarea.yaml +64 -64
  460. package/src/templates/components/toggle/_examples.toggle.njk +188 -188
  461. package/src/templates/components/toggle/_macro.toggle.njk +3 -3
  462. package/src/templates/components/toggle/_styles.toggle.css +31 -31
  463. package/src/templates/components/toggle/_template.toggle.njk +27 -27
  464. package/src/templates/components/toggle/params.toggle.yaml +69 -69
  465. package/src/templates/components/tooltip/_examples.tooltip.njk +86 -86
  466. package/src/templates/components/tooltip/_macro.tooltip.njk +3 -3
  467. package/src/templates/components/tooltip/_styles.tooltip.css +12 -12
  468. package/src/templates/components/tooltip/_template.tooltip.njk +39 -39
  469. package/src/templates/components/tooltip/params.tooltip.yaml +40 -40
  470. package/src/templates/components/tree/_examples.tree.njk +2679 -2679
  471. package/src/templates/components/tree/_macro.tree.njk +3 -3
  472. package/src/templates/components/tree/_styles.tree.css +53 -53
  473. package/src/templates/components/tree/_template.tree.njk +222 -222
  474. package/src/templates/components/tree/params.tree.yaml +169 -169
  475. package/src/templates/includes/_abrir-notificaciones-extra.njk +2 -2
  476. package/src/templates/includes/_abrir-notificaciones.njk +2 -2
  477. package/src/templates/includes/_acciones-de-cabecera.njk +28 -28
  478. package/src/templates/includes/_ejemplo-titulo-h2-parrafo.njk +4 -4
  479. package/src/templates/includes/_ejemplo-titulo-parrafo.njk +4 -4
  480. package/src/templates/includes/_test-include.njk +13 -13
  481. package/src/templates/pages/_page.foot-headroom.njk +33 -33
  482. package/src/templates/pages/_page.foot.njk +8 -8
  483. package/src/templates/pages/_page.footer.njk +19 -19
  484. package/src/templates/pages/_page.head.njk +12 -12
  485. package/src/templates/pages/_page.notification-edit-inner-content.njk +31 -31
  486. package/src/templates/pages/_page.notification-edit.njk +30 -30
  487. package/src/templates/pages/_page.notification-footer.njk +32 -32
  488. package/src/templates/pages/_page.notification-header-fixed.njk +30 -30
  489. package/src/templates/pages/_page.notification-header.njk +31 -31
  490. package/src/templates/pages/_page.sidebar-content.njk +20 -20
  491. package/src/templates/pages/_page.spinner-block.njk +14 -14
  492. package/src/templates/pages/_page.spinner-show.njk +15 -15
  493. package/src/templates/pages/_page.spinner.njk +15 -15
  494. package/src/templates/pages/_template.edit-fixed-with-sticky-sidebar.njk +36 -36
  495. package/src/templates/pages/_template.edit-fixed.njk +74 -74
  496. package/src/templates/pages/_template.home.njk +111 -111
  497. package/src/templates/pages/_template.logged-out.njk +56 -56
  498. package/src/templates/pages/_template.logged-selector-fixed-headroom.njk +198 -198
  499. package/src/templates/pages/_template.logged-selector-fixed.njk +195 -195
  500. package/src/templates/pages/_template.logged-selector-subheader.njk +80 -80
  501. package/src/templates/pages/_template.logged-selector-with-sidebar.njk +28 -28
  502. package/src/templates/pages/_template.logged-selector.njk +195 -195
  503. package/src/templates/pages/_template.logged.njk +141 -141
  504. package/src/templates/pages/_template.mfe-iframe-content.njk +31 -31
  505. package/src/templates/pages/_template.mfe.njk +83 -83
  506. package/src/templates/pages/_template.test.njk +48 -48
  507. package/src/templates/pages/_template.with-header-advanced.njk +311 -311
  508. package/src/js/aria/HeaderNavigation.js +0 -55
@@ -1,106 +1,107 @@
1
- {#- If an id 'prefix' is not passed, fall back to using the name attribute
2
- instead. We need this for error messages and hints as well -#}
3
- {% set idPrefix = params.idPrefix if params.idPrefix else params.id + "menubar-item" %}
4
-
5
- {% set iconHtml %}
6
- {#- The SVG needs `focusable="false"` so that Internet Explorer does not
7
- treat it as an interactive element - without this it will be
8
- 'focusable' when using the keyboard to navigate. #}
9
- <svg class="inline-block -mr-2 align-middle -my-px" viewBox="0 0 96 96" aria-hidden="true" fill="currentColor" focusable="false" width="1.5em" height="1.5em"><g><path d="M46.71 58.037a1.823 1.823 0 002.581 0L62.048 45.28a1.823 1.823 0 00-1.29-3.113H35.243a1.823 1.823 0 00-1.291 3.113z"/></g></svg>
10
- {% endset %}
11
-
12
- {#- Capture the HTML so we can optionally nest it in a fieldset -#}
13
- {% set innerHtml %}
14
- <ul data-module="c-menubar" id="{{ params.id }}-menubar" class="lg:flex lg:flex-wrap" role="menubar" aria-label="{{ params.ariaLabel }}" {%- if params.label %} aria-describedby="{{ params.id }}-label"{% endif %}>
15
- {% for item in params.items %}
16
- {% if item %}
17
- {#- If the user explicitly sets an id, use this instead of the regular idPrefix -#}
18
- {%- if item.id -%}
19
- {%- set id = item.id -%}
20
- {%- else -%}
21
- {%- set id = idPrefix + "-" + loop.index -%}
22
- {%- endif -%}
23
- {% set subId = "sub-" + id %}
24
- <li class="relative" role="none">
25
- {% if item.sub %}
26
- <a href="#" role="menuitem" aria-haspopup="true" aria-expanded="false" class="c-menubar__button {%- if item.classes %} {{ item.classes }}{% endif %} {%- if item.disabled %} c-menubar__button--disabled{% endif %} {%- if item.active %} c-menubar__button--has-selection{% endif %}" {%- if item.title %} title="{{ item.title }}"{% endif %} {% if item.disabled %} aria-disabled="true" tabindex="-1"{% endif %} id="{{ id }}"
27
- {%- if item.sub.html %} data-aria-controls="{{ subId }}"{% endif %}
28
- {%- for attribute, value in item.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
29
- <span class="inline-flex self-center max-w-xs align-middle truncate">{{ item.html | filterquotes | safe if item.html else item.text }}</span>
30
- {# Indentation is intentional to output HTML nicely #}
31
- {{- iconHtml | safe | trim if iconHtml -}}
32
- </a>
33
- {% endif %}
34
- {% if item.href and not item.sub %}
35
- <a role="menuitem" {%- if id %} id="{{ id }}"{% endif %} {%- if item.href %} href="{{ item.href }}"{% endif %} class="c-menubar__button {%- if item.classes %} {{ item.classes }}{% endif %} {%- if item.disabled %} c-menubar__button--disabled{% endif %} {%- if item.active %} c-menubar__button--has-selection{% endif %}" {%- if item.title %} title="{{ item.title }}"{% endif %} {% if item.disabled %} disabled="disabled" aria-disabled="true" tabindex="-1"{% endif %} {% if item.target %} target="{{ item.target }}"{% endif %}{%- for attribute, value in item.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
36
- {{ item.html | filterquotes | safe if item.html else item.text }}
37
- </a>
38
- {% endif %}
39
- {% if item.sub.items %}
40
- <ul role="menu" class="c-menubar__tooltip w-max max-w-64 hidden border border-neutral-base shadow-md bg-white text-sm {%- if item.sub.classes %} {{ item.sub.classes }}{% endif %}" aria-label="{{ item.ariaLabel }}" {%- for attribute, value in item.sub.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
41
- {% for subitem in item.sub.items %}
42
- {% if subitem %}
43
- {#- If the user explicitly sets an id, use this instead of the regular idPrefix -#}
44
- {%- if subitem.id -%}
45
- {%- set subId = subitem.id -%}
46
- {%- else -%}
47
- {%- set subId = "sub-" + id + "-" + loop.index -%}
48
- {%- endif %}
49
- {% if subitem.role == 'none' %}
50
- <li role="none" id="{{ subId }}" data-option="{{ subId }}">
51
- {{ subitem.html | filterquotes | safe if subitem.html else subitem.text }}
52
- </li>
53
- {% elseif subitem.role == 'group' %}
54
- <li role="none">
55
- <ul role="group" id="{{ subId }}" data-option="{{ subId }}" {%- if subitem.ariaLabel %} aria-label="{{ subitem.ariaLabel }}"{% endif %}>
56
- {% for subsubitem in subitem.items %}
57
- {% if subsubitem %}
58
- {#- If the user explicitly sets an id, use this instead of the regular idPrefix -#}
59
- {%- if subsubitem.id -%}
60
- {%- set subsubId = subsubitem.id -%}
61
- {%- else -%}
62
- {%- set subsubId = "sub-" + subId + "-" + loop.index -%}
63
- {%- endif %}
64
- <li {%- if subsubitem.role %} role="{{ subsubitem.role}}"{% endif %}{% if subsubitem.role == 'menuitemcheckbox' or subsubitem.role == 'menuitemradio' %} aria-checked="{% if subsubitem.checked %}{{ subsubitem.checked }}{% else %}false{% endif %}"{% endif %} class="flex items-center pr-base pl-lg py-sm cursor-pointer hover:bg-primary-base hover:text-white" id="{{ subsubId }}" data-option="{{ subsubId }}">
65
- {{ subsubitem.html | filterquotes | safe if subsubitem.html else subsubitem.text }}
66
- </li>
67
- {% endif %}
68
- {% endfor %}
69
- </ul>
70
- </li>
71
- {% elseif subitem.role == 'menuitem' %}
72
- <li role="menuitem" id="{{ subId }}" data-option="{{ subId }}" class="flex items-center pr-base pl-lg py-sm cursor-pointer hover:bg-primary-base hover:text-white focus:bg-primary-base focus:text-white focus:outline-none" >
73
- {{ subitem.html | filterquotes | safe if subitem.html else subitem.text }}
74
- </li>
75
- {% elseif subitem.role == 'menuitemcheckbox' %}
76
- <li role="menuitemcheckbox" aria-checked="{% if subitem.checked %}{{ subitem.checked }}{% else %}false{% endif %}" class="flex items-center pr-base pl-lg py-sm cursor-pointer hover:bg-primary-base hover:text-white" id="{{ subId }}" data-option="{{ subId }}">
77
- {{ subitem.html | filterquotes | safe if subitem.html else subitem.text }}
78
- </li>
79
- {% elseif subitem.role == 'separator' %}
80
- <li role="separator" id="{{ subId }}" class="my-sm border-b border-neutral-base">
81
- </li>
82
- {% endif %}
83
- {% endif %}
84
- {% endfor %}
85
- </ul>
86
- {% endif %}
87
- </li>
88
- {% endif %}
89
- {% endfor %}
90
- </ul>
91
- {% endset -%}
92
-
93
- <!-- menubar -->
94
- <div id="{{ params.id }}" class="c-menubar {%- if params.classes %} {{ params.classes }}{% endif %}" {%- for attribute, value in params.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
95
- {% if params.label %}
96
- <div id="{{ params.id }}-label" class="mb-sm {%- if params.label.classes %} {{ params.label.classes }}{% endif %}">
97
- {% if params.label.html %}
98
- {{ params.label.html | filterquotes | safe}}
99
- {% else %}
100
- <p>{{ params.label.text }}</p>
101
- {% endif %}
102
- </div>
103
- {% endif %}
104
- {{ innerHtml | trim | safe }}
105
- </div>
1
+ {#- If an id 'prefix' is not passed, fall back to using the name attribute
2
+ instead. We need this for error messages and hints as well -#}
3
+ {% set idPrefix = params.idPrefix if params.idPrefix else params.id + "menubar-item" %}
4
+
5
+ {% set iconHtml %}
6
+ {#- The SVG needs `focusable="false"` so that Internet Explorer does not
7
+ treat it as an interactive element - without this it will be
8
+ 'focusable' when using the keyboard to navigate. #}
9
+ <svg class="inline-block -mr-2 align-middle -my-px" viewBox="0 0 96 96" aria-hidden="true" fill="currentColor" focusable="false" width="1.5em" height="1.5em"><g><path d="M46.71 58.037a1.823 1.823 0 002.581 0L62.048 45.28a1.823 1.823 0 00-1.29-3.113H35.243a1.823 1.823 0 00-1.291 3.113z"/></g></svg>
10
+ {% endset %}
11
+
12
+ {#- Capture the HTML so we can optionally nest it in a fieldset -#}
13
+ {% set innerHtml %}
14
+ <ul data-module="c-menubar" id="{{ params.id }}-menubar" class="lg:flex lg:flex-wrap" role="menubar" aria-label="{{ params.ariaLabel }}" {%- if params.label %} aria-describedby="{{ params.id }}-label"{% endif %}>
15
+ {% for item in params.items %}
16
+ {% if item %}
17
+ {#- If the user explicitly sets an id, use this instead of the regular idPrefix -#}
18
+ {%- if item.id -%}
19
+ {%- set id = item.id -%}
20
+ {%- else -%}
21
+ {%- set id = idPrefix + "-" + loop.index -%}
22
+ {%- endif -%}
23
+ {% set subId = "sub-" + id %}
24
+ <li class="relative" role="none">
25
+ {% if item.sub %}
26
+ <a href="#" role="menuitem" aria-haspopup="true" aria-expanded="false" class="c-menubar__button {%- if item.classes %} {{ item.classes }}{% endif %} {%- if item.disabled %} c-menubar__button--disabled{% endif %} {%- if item.active %} c-menubar__button--has-selection{% endif %}" {%- if item.title %} title="{{ item.title }}"{% endif %} {% if item.disabled %} aria-disabled="true" tabindex="-1"{% endif %} id="{{ id }}"
27
+ {%- if item.sub.html %} data-aria-controls="{{ subId }}"{% endif %}
28
+ {%- for attribute, value in item.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
29
+ <span class="inline-flex self-center align-middle">{{ item.html | filterquotes | safe if item.html else item.text }}</span>
30
+ <span class="c-menubar__msg">Con ítems seleccionados</span>
31
+ {# Indentation is intentional to output HTML nicely #}
32
+ {{- iconHtml | safe | trim if iconHtml -}}
33
+ </a>
34
+ {% endif %}
35
+ {% if item.href and not item.sub %}
36
+ <a role="menuitem" {%- if id %} id="{{ id }}"{% endif %} {%- if item.href %} href="{{ item.href }}"{% endif %} class="c-menubar__button {%- if item.classes %} {{ item.classes }}{% endif %} {%- if item.disabled %} c-menubar__button--disabled{% endif %} {%- if item.active %} c-menubar__button--has-selection{% endif %}" {%- if item.title %} title="{{ item.title }}"{% endif %} {% if item.disabled %} disabled="disabled" aria-disabled="true" tabindex="-1"{% endif %} {% if item.target %} target="{{ item.target }}"{% endif %}{%- for attribute, value in item.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
37
+ {{ item.html | filterquotes | safe if item.html else item.text }}
38
+ </a>
39
+ {% endif %}
40
+ {% if item.sub.items %}
41
+ <ul role="menu" class="c-menubar__tooltip w-max max-w-64 hidden border border-neutral-base shadow-md bg-white text-sm {%- if item.sub.classes %} {{ item.sub.classes }}{% endif %}" aria-label="{{ item.ariaLabel }}" {%- for attribute, value in item.sub.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
42
+ {% for subitem in item.sub.items %}
43
+ {% if subitem %}
44
+ {#- If the user explicitly sets an id, use this instead of the regular idPrefix -#}
45
+ {%- if subitem.id -%}
46
+ {%- set subId = subitem.id -%}
47
+ {%- else -%}
48
+ {%- set subId = "sub-" + id + "-" + loop.index -%}
49
+ {%- endif %}
50
+ {% if subitem.role == 'none' %}
51
+ <li role="none" id="{{ subId }}" data-option="{{ subId }}">
52
+ {{ subitem.html | filterquotes | safe if subitem.html else subitem.text }}
53
+ </li>
54
+ {% elseif subitem.role == 'group' %}
55
+ <li role="none">
56
+ <ul role="group" id="{{ subId }}" data-option="{{ subId }}" {%- if subitem.ariaLabel %} aria-label="{{ subitem.ariaLabel }}"{% endif %}>
57
+ {% for subsubitem in subitem.items %}
58
+ {% if subsubitem %}
59
+ {#- If the user explicitly sets an id, use this instead of the regular idPrefix -#}
60
+ {%- if subsubitem.id -%}
61
+ {%- set subsubId = subsubitem.id -%}
62
+ {%- else -%}
63
+ {%- set subsubId = "sub-" + subId + "-" + loop.index -%}
64
+ {%- endif %}
65
+ <li {%- if subsubitem.role %} role="{{ subsubitem.role}}"{% endif %}{% if subsubitem.role == 'menuitemcheckbox' or subsubitem.role == 'menuitemradio' %} aria-checked="{% if subsubitem.checked %}{{ subsubitem.checked }}{% else %}false{% endif %}"{% endif %} class="flex items-center pr-base pl-lg py-sm cursor-pointer hover:bg-primary-base hover:text-white" id="{{ subsubId }}" data-option="{{ subsubId }}">
66
+ {{ subsubitem.html | filterquotes | safe if subsubitem.html else subsubitem.text }}
67
+ </li>
68
+ {% endif %}
69
+ {% endfor %}
70
+ </ul>
71
+ </li>
72
+ {% elseif subitem.role == 'menuitem' %}
73
+ <li role="menuitem" id="{{ subId }}" data-option="{{ subId }}" class="flex items-center pr-base pl-lg py-sm cursor-pointer hover:bg-primary-base hover:text-white focus:bg-primary-base focus:text-white focus:outline-none" >
74
+ {{ subitem.html | filterquotes | safe if subitem.html else subitem.text }}
75
+ </li>
76
+ {% elseif subitem.role == 'menuitemcheckbox' %}
77
+ <li role="menuitemcheckbox" aria-checked="{% if subitem.checked %}{{ subitem.checked }}{% else %}false{% endif %}" class="flex items-center pr-base pl-lg py-sm cursor-pointer hover:bg-primary-base hover:text-white" id="{{ subId }}" data-option="{{ subId }}">
78
+ {{ subitem.html | filterquotes | safe if subitem.html else subitem.text }}
79
+ </li>
80
+ {% elseif subitem.role == 'separator' %}
81
+ <li role="separator" id="{{ subId }}" class="my-sm border-b border-neutral-base">
82
+ </li>
83
+ {% endif %}
84
+ {% endif %}
85
+ {% endfor %}
86
+ </ul>
87
+ {% endif %}
88
+ </li>
89
+ {% endif %}
90
+ {% endfor %}
91
+ </ul>
92
+ {% endset -%}
93
+
94
+ <!-- menubar -->
95
+ <div id="{{ params.id }}" class="c-menubar {%- if params.classes %} {{ params.classes }}{% endif %}" {%- for attribute, value in params.attributes %} {{ attribute }}="{{ value }}"{% endfor -%}>
96
+ {% if params.label %}
97
+ <div id="{{ params.id }}-label" class="mb-sm {%- if params.label.classes %} {{ params.label.classes }}{% endif %}">
98
+ {% if params.label.html %}
99
+ {{ params.label.html | filterquotes | safe}}
100
+ {% else %}
101
+ <p>{{ params.label.text }}</p>
102
+ {% endif %}
103
+ </div>
104
+ {% endif %}
105
+ {{ innerHtml | trim | safe }}
106
+ </div>
106
107
  <!-- /menubar -->
@@ -1,140 +1,140 @@
1
- params:
2
- - name: id
3
- type: string
4
- required: true
5
- description: menubar unique id.
6
- - name: idPrefix
7
- type: string
8
- required: false
9
- description: String to prefix id for each item if no id is specified on each item.
10
- - name: ariaLabel
11
- type: text
12
- required: true
13
- description: aria-label for menubar. Should be a description of the menubar.
14
- - name: label
15
- type: object
16
- required: true
17
- description: Label text or HTML by specifying value for either text or html keys.
18
- - name: text
19
- type: string
20
- required: true
21
- description: If `html` is set, this is not required. Text for the button. If `html` is provided, the `text` argument will be ignored.
22
- - name: html
23
- type: string
24
- required: true
25
- description: If `text` is set, this is not required. HTML for the button. If `html` is provided, the `text` argument will be ignored.
26
- - name: classes
27
- type: string
28
- required: false
29
- description: Classes to add to the element that acts as label.
30
- - name: items
31
- type: array
32
- required: true
33
- description: Array of items objects.
34
- params:
35
- - name: href
36
- type: string
37
- required: false
38
- description: Item link.
39
- - name: target
40
- type: string
41
- required: false
42
- description: The target where the item should link to.
43
- - name: text
44
- type: string
45
- required: true
46
- description: If `html` is set, this is not required. Text to use within each item label. If `html` is provided, the `text` argument will be ignored.
47
- - name: html
48
- type: string
49
- required: true
50
- description: If `text` is set, this is not required. HTML to use within each item label. If `html` is provided, the `text` argument will be ignored.
51
- - name: id
52
- type: string
53
- required: false
54
- description: Specific id attribute for the item. If omitted, then idPrefix option will be applied.
55
- - name: ariaLabel
56
- type: text
57
- required: true
58
- description: aria-label for parent items. Should be similar as item text or item html text content.
59
- - name: disabled
60
- type: boolean
61
- required: false
62
- description: If disabled, the item will be disabled
63
- - name: active
64
- type: boolean
65
- required: false
66
- description: If active, the item will be with primary color
67
- - name: sub
68
- type: boolean
69
- required: false
70
- description: If true, content provided will be revealed when the item is expanded.
71
- - name: classes
72
- type: string
73
- required: false
74
- description: Classes to add to the sub container.
75
- - name: items
76
- type: array
77
- required: false
78
- description: Provide subitems for the sub reveal.
79
- - name: role
80
- type: string
81
- required: false
82
- description: Defaults to `none`. Allowed values are `none`, `group`, `menuitem`, `menuitemcheckbox` and `separator`. Use the `group` role to group menuitems, menuitemcheckbox or menuitemradio sub-subitems.
83
- - name: ariaLabel
84
- type: text
85
- required: false
86
- description: aria-label for parent role `group` items. Should be descriptive of group.
87
- - name: text
88
- type: string
89
- required: true
90
- description: Text to use within each item.
91
- - name: html
92
- type: string
93
- required: true
94
- description: Only can be used in menuitems with role=`none`. If `text` is set, this is not required. HTML to use within each item label. If `html` is provided, the `text` argument will be ignored.
95
- - name: checked
96
- type: boolean
97
- required: false
98
- description: If true, not grouped `menuitemcheckbox` will be checked.
99
- - name: items
100
- type: array
101
- required: false
102
- description: Optional array for `role=menuitemradio` sub-subitems, that should be nested in a `role=group` subitem.
103
- - name: role
104
- type: string
105
- required: false
106
- description: Defaults to `none`. Allowed values are `none`, `menuitem`, `menuitemcheckbox` and `menuitemradio`.
107
- - name: text
108
- type: string
109
- required: true
110
- description: Text to use within each item label.
111
- - name: checked
112
- type: boolean
113
- required: false
114
- description: If true, `menuitemradio` will be checked.
115
- - name: classes
116
- type: string
117
- required: false
118
- description: Classes to add to the item.
119
- - name: attributes
120
- type: object
121
- required: false
122
- description: HTML attributes (for example data attributes) to add to the item.
123
- - name: classes
124
- type: string
125
- required: false
126
- description: Classes to add to the menubar container.
127
- - name: attributes
128
- type: object
129
- required: false
130
- description: HTML attributes (for example data attributes) to add to the menubar container.
131
-
132
- accessibilityCriteria: |
133
- ## sub reveals
134
- Must:
135
- - be visible as static content if JavaScript is unavailable or fails
136
- - be hidden if JavaScript is available and is collapsed
137
- - indicate if content is expanded or collapsed
138
- - indicate that there is collapsed content to interact with
139
-
1
+ params:
2
+ - name: id
3
+ type: string
4
+ required: true
5
+ description: menubar unique id.
6
+ - name: idPrefix
7
+ type: string
8
+ required: false
9
+ description: String to prefix id for each item if no id is specified on each item.
10
+ - name: ariaLabel
11
+ type: text
12
+ required: true
13
+ description: aria-label for menubar. Should be a description of the menubar.
14
+ - name: label
15
+ type: object
16
+ required: true
17
+ description: Label text or HTML by specifying value for either text or html keys.
18
+ - name: text
19
+ type: string
20
+ required: true
21
+ description: If `html` is set, this is not required. Text for the button. If `html` is provided, the `text` argument will be ignored.
22
+ - name: html
23
+ type: string
24
+ required: true
25
+ description: If `text` is set, this is not required. HTML for the button. If `html` is provided, the `text` argument will be ignored.
26
+ - name: classes
27
+ type: string
28
+ required: false
29
+ description: Classes to add to the element that acts as label.
30
+ - name: items
31
+ type: array
32
+ required: true
33
+ description: Array of items objects.
34
+ params:
35
+ - name: href
36
+ type: string
37
+ required: false
38
+ description: Item link.
39
+ - name: target
40
+ type: string
41
+ required: false
42
+ description: The target where the item should link to.
43
+ - name: text
44
+ type: string
45
+ required: true
46
+ description: If `html` is set, this is not required. Text to use within each item label. If `html` is provided, the `text` argument will be ignored.
47
+ - name: html
48
+ type: string
49
+ required: true
50
+ description: If `text` is set, this is not required. HTML to use within each item label. If `html` is provided, the `text` argument will be ignored.
51
+ - name: id
52
+ type: string
53
+ required: false
54
+ description: Specific id attribute for the item. If omitted, then idPrefix option will be applied.
55
+ - name: ariaLabel
56
+ type: text
57
+ required: true
58
+ description: aria-label for parent items. Should be similar as item text or item html text content.
59
+ - name: disabled
60
+ type: boolean
61
+ required: false
62
+ description: If disabled, the item will be disabled
63
+ - name: active
64
+ type: boolean
65
+ required: false
66
+ description: If active, the item will be with primary color
67
+ - name: sub
68
+ type: boolean
69
+ required: false
70
+ description: If true, content provided will be revealed when the item is expanded.
71
+ - name: classes
72
+ type: string
73
+ required: false
74
+ description: Classes to add to the sub container.
75
+ - name: items
76
+ type: array
77
+ required: false
78
+ description: Provide subitems for the sub reveal.
79
+ - name: role
80
+ type: string
81
+ required: false
82
+ description: Defaults to `none`. Allowed values are `none`, `group`, `menuitem`, `menuitemcheckbox` and `separator`. Use the `group` role to group menuitems, menuitemcheckbox or menuitemradio sub-subitems.
83
+ - name: ariaLabel
84
+ type: text
85
+ required: false
86
+ description: aria-label for parent role `group` items. Should be descriptive of group.
87
+ - name: text
88
+ type: string
89
+ required: true
90
+ description: Text to use within each item.
91
+ - name: html
92
+ type: string
93
+ required: true
94
+ description: Only can be used in menuitems with role=`none`. If `text` is set, this is not required. HTML to use within each item label. If `html` is provided, the `text` argument will be ignored.
95
+ - name: checked
96
+ type: boolean
97
+ required: false
98
+ description: If true, not grouped `menuitemcheckbox` will be checked.
99
+ - name: items
100
+ type: array
101
+ required: false
102
+ description: Optional array for `role=menuitemradio` sub-subitems, that should be nested in a `role=group` subitem.
103
+ - name: role
104
+ type: string
105
+ required: false
106
+ description: Defaults to `none`. Allowed values are `none`, `menuitem`, `menuitemcheckbox` and `menuitemradio`.
107
+ - name: text
108
+ type: string
109
+ required: true
110
+ description: Text to use within each item label.
111
+ - name: checked
112
+ type: boolean
113
+ required: false
114
+ description: If true, `menuitemradio` will be checked.
115
+ - name: classes
116
+ type: string
117
+ required: false
118
+ description: Classes to add to the item.
119
+ - name: attributes
120
+ type: object
121
+ required: false
122
+ description: HTML attributes (for example data attributes) to add to the item.
123
+ - name: classes
124
+ type: string
125
+ required: false
126
+ description: Classes to add to the menubar container.
127
+ - name: attributes
128
+ type: object
129
+ required: false
130
+ description: HTML attributes (for example data attributes) to add to the menubar container.
131
+
132
+ accessibilityCriteria: |
133
+ ## sub reveals
134
+ Must:
135
+ - be visible as static content if JavaScript is unavailable or fails
136
+ - be hidden if JavaScript is available and is collapsed
137
+ - indicate if content is expanded or collapsed
138
+ - indicate that there is collapsed content to interact with
139
+
140
140
  Note that alphagov have known issues against this criteria: https://github.com/alphagov/govuk_elements/issues/575