@openeuropa/bcl-theme-default 0.20.0 → 0.23.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 (285) hide show
  1. package/css/oe-bcl-default.css +970 -410
  2. package/css/oe-bcl-default.css.map +1 -1
  3. package/css/oe-bcl-default.min.css +1 -1
  4. package/css/oe-bcl-default.min.css.map +1 -1
  5. package/icons/bcl-default-icons.svg +1 -1
  6. package/js/oe-bcl-default.bundle.js +242 -76
  7. package/js/oe-bcl-default.bundle.js.map +1 -1
  8. package/js/oe-bcl-default.bundle.min.js +1 -1
  9. package/js/oe-bcl-default.bundle.min.js.map +1 -1
  10. package/js/oe-bcl-default.esm.js +236 -75
  11. package/js/oe-bcl-default.esm.js.map +1 -1
  12. package/js/oe-bcl-default.esm.min.js +1 -1
  13. package/js/oe-bcl-default.esm.min.js.map +1 -1
  14. package/js/oe-bcl-default.umd.js +242 -76
  15. package/js/oe-bcl-default.umd.js.map +1 -1
  16. package/js/oe-bcl-default.umd.min.js +1 -1
  17. package/js/oe-bcl-default.umd.min.js.map +1 -1
  18. package/logos/ec/{logo-ec--mute.svg → dist/logo-ec--mute.svg} +0 -0
  19. package/logos/ec/{negative → dist/negative}/logo-ec--ar.svg +0 -0
  20. package/logos/ec/{negative → dist/negative}/logo-ec--bg.svg +0 -0
  21. package/logos/ec/{negative → dist/negative}/logo-ec--ca.svg +0 -0
  22. package/logos/ec/{negative → dist/negative}/logo-ec--cs.svg +0 -0
  23. package/logos/ec/{negative → dist/negative}/logo-ec--da.svg +0 -0
  24. package/logos/ec/{negative → dist/negative}/logo-ec--de.svg +0 -0
  25. package/logos/ec/{negative → dist/negative}/logo-ec--el.svg +0 -0
  26. package/logos/ec/{negative → dist/negative}/logo-ec--en.svg +0 -0
  27. package/logos/ec/{negative → dist/negative}/logo-ec--es.svg +0 -0
  28. package/logos/ec/{negative → dist/negative}/logo-ec--et.svg +0 -0
  29. package/logos/ec/{negative → dist/negative}/logo-ec--fi.svg +0 -0
  30. package/logos/ec/{negative → dist/negative}/logo-ec--fr.svg +0 -0
  31. package/logos/ec/{negative → dist/negative}/logo-ec--ga.svg +0 -0
  32. package/logos/ec/{negative → dist/negative}/logo-ec--hr.svg +0 -0
  33. package/logos/ec/{negative → dist/negative}/logo-ec--hu.svg +0 -0
  34. package/logos/ec/{negative → dist/negative}/logo-ec--is.svg +0 -0
  35. package/logos/ec/{negative → dist/negative}/logo-ec--it.svg +0 -0
  36. package/logos/ec/dist/negative/logo-ec--jp.svg +72 -0
  37. package/logos/ec/dist/negative/logo-ec--lb.svg +93 -0
  38. package/logos/ec/{negative → dist/negative}/logo-ec--lt.svg +0 -0
  39. package/logos/ec/{negative → dist/negative}/logo-ec--lv.svg +0 -0
  40. package/logos/ec/{negative → dist/negative}/logo-ec--mt.svg +0 -0
  41. package/logos/ec/{negative → dist/negative}/logo-ec--nl.svg +0 -0
  42. package/logos/ec/{negative → dist/negative}/logo-ec--no.svg +0 -0
  43. package/logos/ec/{negative → dist/negative}/logo-ec--pl.svg +0 -0
  44. package/logos/ec/{negative → dist/negative}/logo-ec--pt.svg +0 -0
  45. package/logos/ec/{negative → dist/negative}/logo-ec--ro.svg +0 -0
  46. package/logos/ec/dist/negative/logo-ec--ru.svg +91 -0
  47. package/logos/ec/{negative → dist/negative}/logo-ec--sk.svg +0 -0
  48. package/logos/ec/{negative → dist/negative}/logo-ec--sl.svg +0 -0
  49. package/logos/ec/{negative → dist/negative}/logo-ec--sv.svg +0 -0
  50. package/logos/ec/{negative → dist/negative}/logo-ec--tr.svg +0 -0
  51. package/logos/ec/dist/negative/logo-ec--uk.svg +90 -0
  52. package/logos/ec/dist/negative/logo-ec--zh.svg +72 -0
  53. package/logos/ec/{positive → dist/positive}/logo-ec--ar.svg +0 -0
  54. package/logos/ec/{positive → dist/positive}/logo-ec--bg.svg +0 -0
  55. package/logos/ec/{positive → dist/positive}/logo-ec--ca.svg +0 -0
  56. package/logos/ec/{positive → dist/positive}/logo-ec--cs.svg +0 -0
  57. package/logos/ec/{positive → dist/positive}/logo-ec--da.svg +0 -0
  58. package/logos/ec/{positive → dist/positive}/logo-ec--de.svg +0 -0
  59. package/logos/ec/{positive → dist/positive}/logo-ec--el.svg +0 -0
  60. package/logos/ec/{positive → dist/positive}/logo-ec--en.svg +0 -0
  61. package/logos/ec/{positive → dist/positive}/logo-ec--es.svg +0 -0
  62. package/logos/ec/{positive → dist/positive}/logo-ec--et.svg +0 -0
  63. package/logos/ec/{positive → dist/positive}/logo-ec--fi.svg +0 -0
  64. package/logos/ec/{positive → dist/positive}/logo-ec--fr.svg +0 -0
  65. package/logos/ec/{positive → dist/positive}/logo-ec--ga.svg +0 -0
  66. package/logos/ec/{positive → dist/positive}/logo-ec--hr.svg +0 -0
  67. package/logos/ec/{positive → dist/positive}/logo-ec--hu.svg +0 -0
  68. package/logos/ec/{positive → dist/positive}/logo-ec--is.svg +0 -0
  69. package/logos/ec/{positive → dist/positive}/logo-ec--it.svg +0 -0
  70. package/logos/ec/dist/positive/logo-ec--jp.svg +77 -0
  71. package/logos/ec/dist/positive/logo-ec--lb.svg +93 -0
  72. package/logos/ec/{positive → dist/positive}/logo-ec--lt.svg +0 -0
  73. package/logos/ec/{positive → dist/positive}/logo-ec--lv.svg +0 -0
  74. package/logos/ec/{positive → dist/positive}/logo-ec--mt.svg +0 -0
  75. package/logos/ec/{positive → dist/positive}/logo-ec--nl.svg +0 -0
  76. package/logos/ec/{positive → dist/positive}/logo-ec--no.svg +0 -0
  77. package/logos/ec/{positive → dist/positive}/logo-ec--pl.svg +0 -0
  78. package/logos/ec/{positive → dist/positive}/logo-ec--pt.svg +0 -0
  79. package/logos/ec/{positive → dist/positive}/logo-ec--ro.svg +0 -0
  80. package/logos/ec/dist/positive/logo-ec--ru.svg +91 -0
  81. package/logos/ec/{positive → dist/positive}/logo-ec--sk.svg +0 -0
  82. package/logos/ec/{positive → dist/positive}/logo-ec--sl.svg +0 -0
  83. package/logos/ec/{positive → dist/positive}/logo-ec--sv.svg +0 -0
  84. package/logos/ec/{positive → dist/positive}/logo-ec--tr.svg +0 -0
  85. package/logos/ec/dist/positive/logo-ec--uk.svg +90 -0
  86. package/logos/ec/dist/positive/logo-ec--zh.svg +77 -0
  87. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--ar.svg +0 -0
  88. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--bg.svg +0 -0
  89. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--ca.svg +0 -0
  90. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--cs.svg +0 -0
  91. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--da.svg +0 -0
  92. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--de.svg +0 -0
  93. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--el.svg +0 -0
  94. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--en.svg +0 -0
  95. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--es.svg +0 -0
  96. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--et.svg +0 -0
  97. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--fi.svg +0 -0
  98. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--fr.svg +0 -0
  99. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--ga.svg +0 -0
  100. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--hr.svg +0 -0
  101. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--hu.svg +0 -0
  102. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--is.svg +0 -0
  103. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--it.svg +0 -0
  104. package/logos/eu/dist/condensed-version/negative/logo-eu--jp.svg +17 -0
  105. package/logos/eu/dist/condensed-version/negative/logo-eu--lb.svg +19 -0
  106. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--lt.svg +0 -0
  107. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--lv.svg +0 -0
  108. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--mt.svg +0 -0
  109. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--nl.svg +0 -0
  110. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--no.svg +0 -0
  111. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--pl.svg +0 -0
  112. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--pt.svg +0 -0
  113. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--ro.svg +0 -0
  114. package/logos/eu/dist/condensed-version/negative/logo-eu--ru.svg +19 -0
  115. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--sk.svg +0 -0
  116. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--sl.svg +0 -0
  117. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--sv.svg +0 -0
  118. package/logos/eu/{condensed-version → dist/condensed-version}/negative/logo-eu--tr.svg +0 -0
  119. package/logos/eu/dist/condensed-version/negative/logo-eu--uk.svg +19 -0
  120. package/logos/eu/dist/condensed-version/negative/logo-eu--zh.svg +7 -0
  121. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--ar.svg +0 -0
  122. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--bg.svg +0 -0
  123. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--ca.svg +0 -0
  124. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--cs.svg +0 -0
  125. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--da.svg +0 -0
  126. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--de.svg +0 -0
  127. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--el.svg +0 -0
  128. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--en.svg +0 -0
  129. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--es.svg +0 -0
  130. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--et.svg +0 -0
  131. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--fi.svg +0 -0
  132. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--fr.svg +0 -0
  133. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--ga.svg +0 -0
  134. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--hr.svg +0 -0
  135. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--hu.svg +0 -0
  136. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--is.svg +0 -0
  137. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--it.svg +0 -0
  138. package/logos/eu/dist/condensed-version/positive/logo-eu--jp.svg +6 -0
  139. package/logos/eu/dist/condensed-version/positive/logo-eu--lb.svg +6 -0
  140. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--lt.svg +0 -0
  141. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--lv.svg +0 -0
  142. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--mt.svg +0 -0
  143. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--nl.svg +0 -0
  144. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--no.svg +0 -0
  145. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--pl.svg +0 -0
  146. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--pt.svg +0 -0
  147. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--ro.svg +0 -0
  148. package/logos/eu/dist/condensed-version/positive/logo-eu--ru.svg +6 -0
  149. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--sk.svg +0 -0
  150. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--sl.svg +0 -0
  151. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--sv.svg +0 -0
  152. package/logos/eu/{condensed-version → dist/condensed-version}/positive/logo-eu--tr.svg +0 -0
  153. package/logos/eu/dist/condensed-version/positive/logo-eu--uk.svg +6 -0
  154. package/logos/eu/dist/condensed-version/positive/logo-eu--zh.svg +6 -0
  155. package/logos/eu/{logo-eu--mute.svg → dist/logo-eu--mute.svg} +0 -0
  156. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--ar.svg +0 -0
  157. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--bg.svg +0 -0
  158. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--ca.svg +0 -0
  159. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--cs.svg +0 -0
  160. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--da.svg +0 -0
  161. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--de.svg +0 -0
  162. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--el.svg +0 -0
  163. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--en.svg +0 -0
  164. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--es.svg +0 -0
  165. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--et.svg +0 -0
  166. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--fi.svg +0 -0
  167. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--fr.svg +0 -0
  168. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--ga.svg +0 -0
  169. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--hr.svg +0 -0
  170. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--hu.svg +0 -0
  171. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--is.svg +0 -0
  172. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--it.svg +0 -0
  173. package/logos/eu/dist/standard-version/negative/logo-eu--jp.svg +9 -0
  174. package/logos/eu/dist/standard-version/negative/logo-eu--lb.svg +21 -0
  175. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--lt.svg +0 -0
  176. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--lv.svg +0 -0
  177. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--mt.svg +0 -0
  178. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--nl.svg +0 -0
  179. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--no.svg +0 -0
  180. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--pl.svg +0 -0
  181. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--pt.svg +0 -0
  182. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--ro.svg +0 -0
  183. package/logos/eu/dist/standard-version/negative/logo-eu--ru.svg +20 -0
  184. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--sk.svg +0 -0
  185. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--sl.svg +0 -0
  186. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--sv.svg +0 -0
  187. package/logos/eu/{standard-version → dist/standard-version}/negative/logo-eu--tr.svg +0 -0
  188. package/logos/eu/dist/standard-version/negative/logo-eu--uk.svg +21 -0
  189. package/logos/eu/dist/standard-version/negative/logo-eu--zh.svg +9 -0
  190. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--ar.svg +0 -0
  191. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--bg.svg +0 -0
  192. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--ca.svg +0 -0
  193. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--cs.svg +0 -0
  194. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--da.svg +0 -0
  195. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--de.svg +0 -0
  196. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--el.svg +0 -0
  197. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--en.svg +0 -0
  198. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--es.svg +0 -0
  199. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--et.svg +0 -0
  200. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--fi.svg +0 -0
  201. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--fr.svg +0 -0
  202. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--ga.svg +0 -0
  203. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--hr.svg +0 -0
  204. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--hu.svg +0 -0
  205. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--is.svg +0 -0
  206. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--it.svg +0 -0
  207. package/logos/eu/dist/standard-version/positive/logo-eu--jp.svg +8 -0
  208. package/logos/eu/dist/standard-version/positive/logo-eu--lb.svg +20 -0
  209. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--lt.svg +0 -0
  210. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--lv.svg +0 -0
  211. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--mt.svg +0 -0
  212. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--nl.svg +0 -0
  213. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--no.svg +0 -0
  214. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--pl.svg +0 -0
  215. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--pt.svg +0 -0
  216. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--ro.svg +0 -0
  217. package/logos/eu/dist/standard-version/positive/logo-eu--ru.svg +19 -0
  218. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--sk.svg +0 -0
  219. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--sl.svg +0 -0
  220. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--sv.svg +0 -0
  221. package/logos/eu/{standard-version → dist/standard-version}/positive/logo-eu--tr.svg +0 -0
  222. package/logos/eu/dist/standard-version/positive/logo-eu--uk.svg +20 -0
  223. package/logos/eu/dist/standard-version/positive/logo-eu--zh.svg +8 -0
  224. package/package.json +9 -9
  225. package/src/icons/icons.js +19 -0
  226. package/src/js/gallery/gallery.js +168 -0
  227. package/src/js/index.esm.js +2 -0
  228. package/src/js/index.umd.js +2 -0
  229. package/src/scss/_alert.scss +8 -0
  230. package/src/scss/_badge.scss +76 -58
  231. package/src/scss/_banners.scss +16 -0
  232. package/src/scss/_bcl-offcanvas.scss +7 -0
  233. package/src/scss/_carousel.scss +85 -0
  234. package/src/scss/_circular-progress-bar.scss +13 -11
  235. package/src/scss/_gallery.scss +269 -0
  236. package/src/scss/_inpage-navigation.scss +1 -2
  237. package/src/scss/_multiselect.scss +7 -7
  238. package/src/scss/_pagination.scss +8 -0
  239. package/src/scss/_search-form.scss +4 -2
  240. package/src/scss/base/_colors.scss +17 -6
  241. package/src/scss/base/_utilities.scss +10 -0
  242. package/src/scss/base/_variables.scss +4 -0
  243. package/src/scss/oe-bcl-default.scss +4 -0
  244. package/templates/bcl-alert/alert.html.twig +9 -1
  245. package/templates/bcl-badge/badge.html.twig +13 -9
  246. package/templates/bcl-banner/banner.html.twig +20 -9
  247. package/templates/bcl-base-templates/content-type.html.twig +3 -3
  248. package/templates/bcl-base-templates/listing-page.html.twig +30 -20
  249. package/templates/bcl-card/card.html.twig +57 -41
  250. package/templates/bcl-carousel/carousel.html.twig +26 -5
  251. package/templates/bcl-content-banner/content-banner.html.twig +53 -62
  252. package/templates/bcl-date-block/date-block.html.twig +29 -9
  253. package/templates/bcl-description-list/description-list.html.twig +14 -10
  254. package/templates/bcl-event/event.html.twig +2 -2
  255. package/templates/bcl-fact-figures/fact-figures.html.twig +31 -25
  256. package/templates/bcl-file/file.html.twig +22 -14
  257. package/templates/bcl-footer/footer.html.twig +3 -1
  258. package/templates/bcl-form/form.html.twig +10 -4
  259. package/templates/bcl-gallery/gallery.html.twig +207 -0
  260. package/templates/bcl-group/group-landing.html.twig +7 -7
  261. package/templates/bcl-group/group.html.twig +1 -1
  262. package/templates/bcl-heading/heading.html.twig +40 -0
  263. package/templates/bcl-inpage-navigation/inpage-navigation.html.twig +16 -8
  264. package/templates/bcl-landing-page/landing-page.html.twig +2 -2
  265. package/templates/bcl-links-block/links-block.html.twig +16 -6
  266. package/templates/bcl-listing/listing.html.twig +19 -9
  267. package/templates/bcl-modal/modal.html.twig +4 -1
  268. package/templates/bcl-offcanvas/offcanvas.html.twig +16 -19
  269. package/templates/bcl-page/page.html.twig +3 -3
  270. package/templates/bcl-pagination/pagination.html.twig +123 -9
  271. package/templates/bcl-person/person.html.twig +44 -0
  272. package/templates/bcl-progress/progress.html.twig +3 -0
  273. package/templates/bcl-project/project-lists.html.twig +70 -0
  274. package/templates/bcl-project/project.html.twig +51 -76
  275. package/templates/bcl-project-status/project-contributions.html.twig +56 -0
  276. package/templates/bcl-project-status/project-status.html.twig +14 -44
  277. package/templates/bcl-recent-activities/recent-activities.html.twig +9 -7
  278. package/templates/bcl-search/search.html.twig +9 -2
  279. package/templates/bcl-select/select.html.twig +10 -3
  280. package/templates/bcl-timeline/timeline.html.twig +22 -18
  281. package/templates/bcl-user/{user-view-compact.html.twig → user-compact.html.twig} +0 -0
  282. package/templates/bcl-user/user-terms.html.twig +11 -0
  283. package/templates/bcl-user/user.html.twig +129 -0
  284. package/templates/bcl-user/user-edit.html.twig +0 -38
  285. package/templates/bcl-user/user-view.html.twig +0 -86
@@ -0,0 +1,168 @@
1
+ /**
2
+ * --------------------------------------------------------------------------
3
+ * Bootstrap (v5.1.3): gallery.js
4
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
5
+ * --------------------------------------------------------------------------
6
+ */
7
+
8
+ import { defineJQueryPlugin, typeCheckConfig } from '@openeuropa/bcl-bootstrap/js/src/util/index'
9
+ import EventHandler from '@openeuropa/bcl-bootstrap/js/src/dom/event-handler'
10
+ import BaseComponent from '@openeuropa/bcl-bootstrap/js/src/base-component'
11
+ import SelectorEngine from '@openeuropa/bcl-bootstrap/js/src/dom/selector-engine'
12
+ import Manipulator from '@openeuropa/bcl-bootstrap/js/src/dom/manipulator'
13
+
14
+ /**
15
+ * ------------------------------------------------------------------------
16
+ * Constants
17
+ * ------------------------------------------------------------------------
18
+ */
19
+
20
+ const Default = {}
21
+ const DefaultType = {}
22
+
23
+ const NAME = 'gallery'
24
+ const DATA_KEY = 'bs.gallery'
25
+ const EVENT_KEY = `.${DATA_KEY}`
26
+ const DATA_API_KEY = '.data-api'
27
+
28
+ const CAROUSEL_SELECTOR = '.carousel'
29
+ const CAROUSEL_PAGER_SELECTOR = '.carousel-pager span'
30
+ const CAROUSEL_ACTIVE_SELECTOR = '.carousel-item.active'
31
+ const CAROUSEL_ITEM_SELECTOR = '.carousel-item'
32
+ const THUMBNAIL_SELECTOR = '.bcl-gallery__grid a, .bcl-gallery__mobile-view-more'
33
+ const MODAL_SELECTOR = '.modal'
34
+ const EVENT_MODAL_HIDE = 'hide.bs.modal'
35
+ const CAROUSEL_EVENT = 'slide.bs.carousel'
36
+ const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`
37
+
38
+ /**
39
+ * ------------------------------------------------------------------------
40
+ * Class Definition
41
+ * ------------------------------------------------------------------------
42
+ */
43
+
44
+ class Gallery extends BaseComponent {
45
+ constructor(element, config) {
46
+ super(element)
47
+ this._carousel = SelectorEngine.findOne(CAROUSEL_SELECTOR, this._element)
48
+ this._carouselPager = SelectorEngine.findOne(CAROUSEL_PAGER_SELECTOR, this._element)
49
+ this._carouselStartIndex = element.getAttribute('data-gallery-start')
50
+ this._carouselActiveItem = SelectorEngine.find(CAROUSEL_ITEM_SELECTOR, this._carousel)[this._carouselStartIndex]
51
+ this._carouselPager.textContent = Number(this._carouselStartIndex) + 1
52
+ this._modal = SelectorEngine.findOne(MODAL_SELECTOR, this._element)
53
+ this._config = this._getConfig(config)
54
+ this._addEventListeners()
55
+ this._carouselLazyLoad(this._carouselActiveItem)
56
+ }
57
+
58
+ // Getters
59
+ static get NAME() {
60
+ return NAME
61
+ }
62
+
63
+ // Public
64
+ setSlide(event) {
65
+ const slideFrom = SelectorEngine.findOne(CAROUSEL_ACTIVE_SELECTOR, this._carousel)
66
+ const slideTo = event.relatedTarget
67
+ this._carouselLazyLoad(slideTo)
68
+ this._carouselPager.textContent = event.to + 1
69
+ this.stopVideo(slideFrom)
70
+ }
71
+
72
+ stopSlide() {
73
+ const currentSlide = SelectorEngine.findOne(CAROUSEL_ACTIVE_SELECTOR, this._carousel)
74
+ this.stopVideo(currentSlide)
75
+ }
76
+
77
+ stopVideo(slide) {
78
+ const iframe = SelectorEngine.findOne('iframe', slide);
79
+ const video = SelectorEngine.findOne('video', slide);
80
+ if (iframe) {
81
+ iframe.src = iframe.dataset.src;
82
+ } else if (video) {
83
+ video.pause();
84
+ }
85
+ }
86
+
87
+ // Private
88
+ _carouselLazyLoad(slide) {
89
+ const media = SelectorEngine.findOne('[data-src]', slide);
90
+
91
+ if (media && !media.src) {
92
+ media.src = media.dataset.src;
93
+ }
94
+ }
95
+
96
+ _getConfig(config) {
97
+ config = {
98
+ ...Default,
99
+ ...Manipulator.getDataAttributes(this._element),
100
+ ...(typeof config === 'object' ? config : {})
101
+ }
102
+ typeCheckConfig(NAME, config, DefaultType)
103
+ return config
104
+ }
105
+
106
+ _addEventListeners() {
107
+ EventHandler.on(this._carousel, CAROUSEL_EVENT, event => this.setSlide(event))
108
+ EventHandler.on(this._modal, EVENT_MODAL_HIDE, event => this.stopSlide(event))
109
+ }
110
+
111
+ // Static
112
+ static get Default() {
113
+ return Default
114
+ }
115
+
116
+ static galleryInterface(element, config) {
117
+ const data = Gallery.getOrCreateInstance(element, config)
118
+
119
+ let { _config } = data
120
+ if (typeof config === 'object') {
121
+ _config = {
122
+ ..._config,
123
+ ...config
124
+ }
125
+ }
126
+ }
127
+
128
+ static jQueryInterface(config) {
129
+ return this.each(function () {
130
+ const data = Gallery.getOrCreateInstance(this)
131
+
132
+ if (typeof config !== 'string') {
133
+ return
134
+ }
135
+
136
+ if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
137
+ throw new TypeError(`No method named "${config}"`)
138
+ }
139
+
140
+ data[config](this)
141
+ })
142
+ }
143
+ }
144
+
145
+ /**
146
+ * ------------------------------------------------------------------------
147
+ * Data Api implementation
148
+ * ------------------------------------------------------------------------
149
+ */
150
+
151
+ EventHandler.on(document, EVENT_CLICK_DATA_API, THUMBNAIL_SELECTOR, function (event) {
152
+ const gallery = event.target.closest('div.bcl-gallery')
153
+ const firstSlide = event.target.parentNode.getAttribute('data-bs-slide-to');
154
+ gallery.dataset.galleryStart = firstSlide;
155
+
156
+ Gallery.galleryInterface(gallery, Gallery.getInstance(gallery))
157
+ })
158
+
159
+ /**
160
+ * ------------------------------------------------------------------------
161
+ * jQuery
162
+ * ------------------------------------------------------------------------
163
+ * add .gallery to jQuery only if jQuery is present
164
+ */
165
+
166
+ defineJQueryPlugin(Gallery)
167
+
168
+ export default Gallery
@@ -10,6 +10,7 @@ import Button from "@openeuropa/bcl-bootstrap/js/src/button";
10
10
  import Carousel from "@openeuropa/bcl-bootstrap/js/src/carousel";
11
11
  import Collapse from "@openeuropa/bcl-bootstrap/js/src/collapse";
12
12
  import Dropdown from "@openeuropa/bcl-bootstrap/js/src/dropdown";
13
+ import Gallery from "@openeuropa/bcl-theme-default/src/js/gallery/gallery";
13
14
  import Modal from "@openeuropa/bcl-bootstrap/js/src/modal";
14
15
  import Offcanvas from "@openeuropa/bcl-bootstrap/js/src/offcanvas";
15
16
  import Popover from "@openeuropa/bcl-bootstrap/js/src/popover";
@@ -24,6 +25,7 @@ export {
24
25
  Carousel,
25
26
  Collapse,
26
27
  Dropdown,
28
+ Gallery,
27
29
  Modal,
28
30
  Offcanvas,
29
31
  Popover,
@@ -10,6 +10,7 @@ import Button from "@openeuropa/bcl-bootstrap/js/src/button";
10
10
  import Carousel from "@openeuropa/bcl-bootstrap/js/src/carousel";
11
11
  import Collapse from "@openeuropa/bcl-bootstrap/js/src/collapse";
12
12
  import Dropdown from "@openeuropa/bcl-bootstrap/js/src/dropdown";
13
+ import Gallery from "@openeuropa/bcl-theme-default/src/js/gallery/gallery";
13
14
  import Modal from "@openeuropa/bcl-bootstrap/js/src/modal";
14
15
  import Offcanvas from "@openeuropa/bcl-bootstrap/js/src/offcanvas";
15
16
  import Popover from "@openeuropa/bcl-bootstrap/js/src/popover";
@@ -24,6 +25,7 @@ export default {
24
25
  Carousel,
25
26
  Collapse,
26
27
  Dropdown,
28
+ Gallery,
27
29
  Modal,
28
30
  Offcanvas,
29
31
  Popover,
@@ -0,0 +1,8 @@
1
+ .alert-light {
2
+ border-color: $light;
3
+ background: $white;
4
+ }
5
+ .alert-dark {
6
+ border-color: $gray-400;
7
+ background: $gray-200;
8
+ }
@@ -16,84 +16,102 @@
16
16
  font-weight: 300;
17
17
  justify-content: center;
18
18
  align-items: center;
19
- cursor: pointer;
20
19
  background: $white;
21
20
  border-radius: 50%;
21
+ border: none;
22
+ padding: 0;
22
23
  svg {
23
24
  width: 6px;
24
25
  height: 6px;
25
26
  margin: 0;
26
27
  }
27
28
  }
28
- &.bg-primary {
29
- .icon--close {
30
- color: $primary;
31
- }
32
- }
33
- &.bg-secondary {
34
- .icon--close {
35
- color: $secondary;
36
- }
37
- }
38
- &.bg-success {
39
- .icon--close {
40
- color: $success;
41
- }
42
- }
43
- &.bg-danger {
44
- .icon--close {
45
- color: $danger;
46
- }
47
- }
48
- &.bg-dark {
49
- .icon--close {
50
- color: $dark;
51
- }
52
- }
53
- &.bg-warning {
54
- .icon--close {
55
- color: $warning;
56
- background: $black;
57
- }
58
- }
59
- &.bg-info {
60
- .icon--close {
61
- color: $info;
62
- background: $black;
63
- }
64
- }
65
- &.bg-light {
66
- .icon--close {
67
- color: $light;
68
- background: $black;
69
- }
70
- }
71
29
  }
72
30
 
73
- // Badges in headings and other text elements
74
- h1,
75
- h2,
76
- h3,
77
- h4,
78
- h5,
79
- h6,
80
- p,
81
- a {
82
- .badge {
83
- font-size: 0.75em; // Default size in Bootstrap
31
+ a.badge {
32
+ text-decoration: none;
33
+ &:focus-visible {
34
+ outline: none;
84
35
  }
85
36
  }
86
37
 
87
38
  @each $color, $value in $theme-colors {
88
- .badge-outline-#{$color} {
89
- border: $border-width solid $value;
39
+ .badge.bg-#{$color} a,
40
+ .badge.bg-#{$color} {
41
+ @if $color == light or $color == warning {
42
+ color: $black;
43
+ } @else {
44
+ color: $white;
45
+ }
46
+ .icon--close {
47
+ color: $value;
48
+ @if $color == light or $color == warning {
49
+ background: $black;
50
+ }
51
+ }
52
+ }
53
+ .badge-outline-#{$color} a {
90
54
  color: $value !important;
55
+ }
56
+ .badge-outline-#{$color} {
91
57
  background: transparent !important;
58
+ @if $color == light {
59
+ border: $border-width solid $light;
60
+ color: $light !important;
61
+ } @else {
62
+ border: $border-width solid $value;
63
+ color: $value !important;
64
+ }
92
65
  .icon--close {
93
66
  background: $value;
94
- color: $white;
95
67
  @if $color == light {
96
68
  color: $black;
69
+ } @else {
70
+ color: $white;
71
+ }
72
+ }
73
+ }
74
+ a.badge {
75
+ &:focus-within,
76
+ &:active,
77
+ &:hover {
78
+ &.badge-outline-#{$color} {
79
+ @if $color == dark {
80
+ background-color: $light !important;
81
+ border-color: $black;
82
+ } @else if $color == light {
83
+ border-color: $white;
84
+ color: $white;
85
+ background: rgba($white, 0.3) !important;
86
+ } @else {
87
+ background-color: tint-color($value, 90%) !important;
88
+ border-color: shade-color($value, 15%) !important;
89
+ }
90
+ }
91
+ &.bg-#{$color} {
92
+ background-color: shade-color($value, 15%) !important;
93
+ }
94
+ }
95
+ &.badge.bg-#{$color} {
96
+ &:focus {
97
+ @if $enable-shadows {
98
+ @include box-shadow(
99
+ $btn-box-shadow,
100
+ 0 0 0 $btn-focus-width
101
+ rgba(mix(color-contrast($value), $value, 15%), 0.5)
102
+ );
103
+ } @else {
104
+ box-shadow: 0
105
+ 0
106
+ 0
107
+ $btn-focus-width
108
+ rgba(mix(color-contrast($value), $value, 15%), 0.5);
109
+ }
110
+ }
111
+ }
112
+ &.badge-outline-#{$color} {
113
+ &:focus {
114
+ box-shadow: 0 0 0 $btn-focus-width rgba($value, 0.5);
97
115
  }
98
116
  }
99
117
  }
@@ -51,6 +51,16 @@
51
51
  }
52
52
  }
53
53
 
54
+ @include media-breakpoint-down(md) {
55
+ .container {
56
+ .bcl-content-banner {
57
+ .container {
58
+ padding: 0;
59
+ }
60
+ }
61
+ }
62
+ }
63
+
54
64
  @include media-breakpoint-up(md) {
55
65
  .bcl-banner {
56
66
  overflow: hidden;
@@ -128,6 +138,12 @@
128
138
  margin-left: 0;
129
139
  }
130
140
  }
141
+ .bcl-content-banner {
142
+ .card {
143
+ margin-right: -$container-padding-x;
144
+ margin-left: -$container-padding-x;
145
+ }
146
+ }
131
147
  }
132
148
  }
133
149
 
@@ -5,10 +5,17 @@
5
5
  visibility: visible !important; // stylelint-disable-line declaration-no-important
6
6
  border: none;
7
7
  transform: none;
8
+ box-shadow: none;
8
9
 
9
10
  .offcanvas-body {
10
11
  overflow: visible;
11
12
  }
13
+
14
+ .offcanvas-title {
15
+ height: 38px;
16
+ display: flex;
17
+ align-items: center;
18
+ }
12
19
  }
13
20
 
14
21
  .bcl-offcanvas + .offcanvas-backdrop {
@@ -0,0 +1,85 @@
1
+ $indicator-size: 8px;
2
+
3
+ .carousel-indicators {
4
+ background-color: rgba(0, 0, 0, 0.5);
5
+ margin: 0;
6
+ [data-bs-target] {
7
+ width: $indicator-size;
8
+ height: $indicator-size;
9
+ margin: map-get($spacers, "1-5") map-get($spacers, 2) map-get($spacers, 3);
10
+ border-radius: 50%;
11
+ }
12
+ }
13
+
14
+ .carousel-caption {
15
+ width: 100%;
16
+ left: 0;
17
+ right: 0;
18
+ background-color: rgba(0, 0, 0, 0.5);
19
+ bottom: 0;
20
+ padding: map-get($spacers, 3) 0 map-get($spacers, 4);
21
+ p {
22
+ margin-bottom: 0;
23
+ }
24
+ a {
25
+ color: $white;
26
+ text-decoration-color: $white;
27
+ }
28
+ }
29
+
30
+ .carousel-dark {
31
+ .carousel-caption {
32
+ background-color: rgba(255, 255, 255, 0.5);
33
+ a {
34
+ color: $black;
35
+ text-decoration-color: $black;
36
+ }
37
+ }
38
+
39
+ .carousel-indicators {
40
+ background-color: rgba(255, 255, 255, 0.5);
41
+ }
42
+ }
43
+
44
+ .carousel-control-next,
45
+ .carousel-control-prev {
46
+ opacity: 1;
47
+ &:hover {
48
+ opacity: 1;
49
+ }
50
+ }
51
+
52
+ .carousel-control-prev-icon,
53
+ .carousel-control-next-icon {
54
+ width: 40px;
55
+ height: 40px;
56
+ background-size: 60% 60%;
57
+ background-color: rgba(0, 0, 0, 0.5);
58
+ border-radius: 4px;
59
+ }
60
+
61
+ .carousel-control-next-icon {
62
+ background-position: 9px center;
63
+ }
64
+
65
+ .carousel-control-prev-icon {
66
+ background-position: 7px center;
67
+ }
68
+
69
+ .carousel.rounded-indicators {
70
+ .carousel-control-prev-icon,
71
+ .carousel-control-next-icon {
72
+ border-radius: 50%;
73
+ }
74
+ }
75
+
76
+ @include media-breakpoint-up(md) {
77
+ .carousel-indicators {
78
+ & + .carousel-inner {
79
+ .carousel-caption {
80
+ bottom: 50px;
81
+ padding-bottom: 0;
82
+ }
83
+ }
84
+ }
85
+ }
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  //styling
2
4
  $borderWidth: 12px;
3
5
  $animationTime: 1s;
@@ -48,8 +50,8 @@ $howManySteps: 20;
48
50
  left: 0;
49
51
  .circular-progress-bar {
50
52
  left: 100%;
51
- border-top-right-radius: ($size / 2);
52
- border-bottom-right-radius: ($size / 2);
53
+ border-top-right-radius: math.div($size, 2);
54
+ border-bottom-right-radius: math.div($size, 2);
53
55
  border-left: 0;
54
56
  transform-origin: center left;
55
57
  }
@@ -59,8 +61,8 @@ $howManySteps: 20;
59
61
  right: 0;
60
62
  .circular-progress-bar {
61
63
  left: -100%;
62
- border-top-left-radius: ($size / 2);
63
- border-bottom-left-radius: ($size / 2);
64
+ border-top-left-radius: math.div($size, 2);
65
+ border-bottom-left-radius: math.div($size, 2);
64
66
  border-right: 0;
65
67
  transform-origin: center right;
66
68
  }
@@ -70,10 +72,10 @@ $howManySteps: 20;
70
72
  Due to the split circle of progress-left and progress right, we must use the animations on each side.
71
73
  */
72
74
  @for $i from 1 through $howManySteps {
73
- $stepName: ($i * (100 / $howManySteps));
75
+ $stepName: ($i * math.div(100, $howManySteps));
74
76
 
75
77
  //animation only the left side if below 50%
76
- @if $i <= ($howManySteps / 2) {
78
+ @if $i <= math.div($howManySteps, 2) {
77
79
  .circular-progress[data-percentage="#{$stepName}"] {
78
80
  .circular-progress-right .circular-progress-bar {
79
81
  animation: loading-#{$i} $animationTime linear forwards;
@@ -84,18 +86,18 @@ Due to the split circle of progress-left and progress right, we must use the ani
84
86
  }
85
87
  }
86
88
  //animation only the right side if above 50%
87
- @if $i > ($howManySteps / 2) {
89
+ @if $i > math.div($howManySteps, 2) {
88
90
  .circular-progress[data-percentage="#{$stepName}"] {
89
91
  .circular-progress-right .circular-progress-bar {
90
92
  // prettier-ignore
91
- animation: loading-#{($howManySteps / 2)}
93
+ animation: loading-#{ math.div($howManySteps, 2)}
92
94
  $animationTime
93
95
  linear
94
96
  forwards; //set the animation to longest animation
95
97
  }
96
98
  .circular-progress-left .circular-progress-bar {
97
99
  // prettier-ignore
98
- animation: loading-#{$i - ($howManySteps / 2)}
100
+ animation: loading-#{$i - math.div($howManySteps, 2)}
99
101
  $animationTime
100
102
  linear
101
103
  forwards
@@ -106,8 +108,8 @@ Due to the split circle of progress-left and progress right, we must use the ani
106
108
  }
107
109
 
108
110
  //animation
109
- @for $i from 1 through ($howManySteps / 2) {
110
- $degrees: (180 / ($howManySteps / 2));
111
+ @for $i from 1 through math.div($howManySteps, 2) {
112
+ $degrees: math.div(180, math.div($howManySteps, 2));
111
113
  $degrees: ($degrees * $i);
112
114
  @keyframes loading-#{$i} {
113
115
  0% {