@iamproperty/components 7.7.1--beta6 → 7.7.1--beta7

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 (577) hide show
  1. package/README.md +4 -4
  2. package/assets/bootstrap/README.md +247 -247
  3. package/assets/bootstrap/js/index.esm.js +19 -19
  4. package/assets/bootstrap/js/index.umd.js +34 -34
  5. package/assets/bootstrap/js/src/alert.js +87 -87
  6. package/assets/bootstrap/js/src/base-component.js +85 -85
  7. package/assets/bootstrap/js/src/button.js +72 -72
  8. package/assets/bootstrap/js/src/carousel.js +475 -475
  9. package/assets/bootstrap/js/src/collapse.js +302 -302
  10. package/assets/bootstrap/js/src/dom/data.js +55 -55
  11. package/assets/bootstrap/js/src/dom/event-handler.js +320 -320
  12. package/assets/bootstrap/js/src/dom/manipulator.js +71 -71
  13. package/assets/bootstrap/js/src/dom/selector-engine.js +83 -83
  14. package/assets/bootstrap/js/src/dropdown.js +445 -445
  15. package/assets/bootstrap/js/src/modal.js +373 -373
  16. package/assets/bootstrap/js/src/offcanvas.js +283 -283
  17. package/assets/bootstrap/js/src/popover.js +97 -97
  18. package/assets/bootstrap/js/src/scrollspy.js +290 -290
  19. package/assets/bootstrap/js/src/tab.js +307 -307
  20. package/assets/bootstrap/js/src/toast.js +220 -220
  21. package/assets/bootstrap/js/src/tooltip.js +651 -651
  22. package/assets/bootstrap/js/src/util/backdrop.js +149 -149
  23. package/assets/bootstrap/js/src/util/component-functions.js +34 -34
  24. package/assets/bootstrap/js/src/util/config.js +66 -66
  25. package/assets/bootstrap/js/src/util/focustrap.js +115 -115
  26. package/assets/bootstrap/js/src/util/index.js +336 -336
  27. package/assets/bootstrap/js/src/util/sanitizer.js +118 -118
  28. package/assets/bootstrap/js/src/util/scrollbar.js +114 -114
  29. package/assets/bootstrap/js/src/util/swipe.js +146 -146
  30. package/assets/bootstrap/js/src/util/template-factory.js +160 -160
  31. package/assets/bootstrap/package.json +180 -180
  32. package/assets/bootstrap/scss/_accordion.scss +146 -146
  33. package/assets/bootstrap/scss/_button-group.scss +142 -142
  34. package/assets/bootstrap/scss/_buttons.scss +186 -186
  35. package/assets/bootstrap/scss/_carousel.scss +229 -229
  36. package/assets/bootstrap/scss/_dropdown.scss +248 -248
  37. package/assets/bootstrap/scss/_functions.scss +302 -302
  38. package/assets/bootstrap/scss/_list-group.scss +191 -191
  39. package/assets/bootstrap/scss/_modal.scss +237 -237
  40. package/assets/bootstrap/scss/_nav.scss +172 -172
  41. package/assets/bootstrap/scss/_navbar.scss +276 -276
  42. package/assets/bootstrap/scss/_offcanvas.scss +143 -143
  43. package/assets/bootstrap/scss/_pagination.scss +109 -109
  44. package/assets/bootstrap/scss/_popover.scss +196 -196
  45. package/assets/bootstrap/scss/_toasts.scss +70 -70
  46. package/assets/bootstrap/scss/_variables-dark.scss +87 -87
  47. package/assets/bootstrap/scss/_variables.scss +1633 -1633
  48. package/assets/bootstrap/scss/bootstrap-utilities.scss +15 -15
  49. package/assets/bootstrap/scss/forms/_floating-labels.scss +74 -74
  50. package/assets/bootstrap/scss/forms/_input-group.scss +129 -129
  51. package/assets/bootstrap/scss/helpers/_focus-ring.scss +5 -5
  52. package/assets/bootstrap/scss/helpers/_icon-link.scss +25 -25
  53. package/assets/bootstrap/scss/mixins/_banner.scss +9 -9
  54. package/assets/bootstrap/scss/mixins/_color-mode.scss +21 -21
  55. package/assets/bootstrap/scss/mixins/_forms.scss +152 -152
  56. package/assets/bootstrap/scss/mixins/_table-variants.scss +24 -24
  57. package/assets/bootstrap/scss/mixins/_utilities.scss +97 -97
  58. package/assets/css/components/notification.css +1 -1
  59. package/assets/css/components/notification.css.map +1 -1
  60. package/assets/favicons/README.md +20 -20
  61. package/assets/favicons/browserconfig.xml +9 -9
  62. package/assets/favicons/manifest.json +31 -31
  63. package/assets/favicons/safari-pinned-tab.svg +35 -35
  64. package/assets/favicons/site.webmanifest +20 -20
  65. package/assets/js/components/accordion/accordion.component.js +14 -14
  66. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  67. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  68. package/assets/js/components/actionbar/actionbar.component.js +66 -66
  69. package/assets/js/components/actionbar/actionbar.component.min.js +1 -1
  70. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  71. package/assets/js/components/address-lookup/address-lookup.component.js +58 -58
  72. package/assets/js/components/address-lookup/address-lookup.component.min.js +1 -1
  73. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  74. package/assets/js/components/advanced-select/advanced-select.component.js +18 -18
  75. package/assets/js/components/advanced-select/advanced-select.component.min.js +1 -1
  76. package/assets/js/components/advanced-select/advanced-select.component.min.js.map +1 -1
  77. package/assets/js/components/applied-filters/applied-filters.component.js +6 -6
  78. package/assets/js/components/applied-filters/applied-filters.component.min.js +1 -1
  79. package/assets/js/components/applied-filters/applied-filters.component.min.js.map +1 -1
  80. package/assets/js/components/barchart/barchart.component.min.js +1 -1
  81. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  82. package/assets/js/components/bento-grid/bento-grid.component.js +9 -9
  83. package/assets/js/components/bento-grid/bento-grid.component.min.js +1 -1
  84. package/assets/js/components/bento-grid/bento-grid.component.min.js.map +1 -1
  85. package/assets/js/components/calendar/calendar.component.min.js +1 -1
  86. package/assets/js/components/card/card.component.min.js +1 -1
  87. package/assets/js/components/card/card.component.min.js.map +1 -1
  88. package/assets/js/components/carousel/carousel.component.min.js +1 -1
  89. package/assets/js/components/collapsible-side/collapsible-side.component.js +20 -20
  90. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  91. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  92. package/assets/js/components/config/config.component.js +53 -53
  93. package/assets/js/components/config/config.component.min.js +1 -1
  94. package/assets/js/components/config/config.component.min.js.map +1 -1
  95. package/assets/js/components/content/content.component.js +9 -9
  96. package/assets/js/components/content/content.component.min.js +1 -1
  97. package/assets/js/components/content/content.component.min.js.map +1 -1
  98. package/assets/js/components/darkmode/darkmode.component.js +4 -4
  99. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  100. package/assets/js/components/darkmode/darkmode.component.min.js.map +1 -1
  101. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +1 -1
  102. package/assets/js/components/doughnutchart/doughnutchart.component.min.js.map +1 -1
  103. package/assets/js/components/fileupload/fileupload.component.js +16 -16
  104. package/assets/js/components/fileupload/fileupload.component.min.js +1 -1
  105. package/assets/js/components/fileupload/fileupload.component.min.js.map +1 -1
  106. package/assets/js/components/filter-card/filter-card.component.js +7 -7
  107. package/assets/js/components/filter-card/filter-card.component.min.js +1 -1
  108. package/assets/js/components/filter-card/filter-card.component.min.js.map +1 -1
  109. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  110. package/assets/js/components/form/form.component.js +4 -4
  111. package/assets/js/components/form/form.component.min.js +1 -1
  112. package/assets/js/components/form/form.component.min.js.map +1 -1
  113. package/assets/js/components/header/header.component.js +53 -53
  114. package/assets/js/components/header/header.component.min.js +1 -1
  115. package/assets/js/components/header/header.component.min.js.map +1 -1
  116. package/assets/js/components/inline-edit/inline-edit.component.js +16 -16
  117. package/assets/js/components/inline-edit/inline-edit.component.min.js +1 -1
  118. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  119. package/assets/js/components/input/input.component.js +10 -10
  120. package/assets/js/components/input/input.component.min.js +1 -1
  121. package/assets/js/components/input/input.component.min.js.map +1 -1
  122. package/assets/js/components/input-range/input-range.component.js +8 -8
  123. package/assets/js/components/input-range/input-range.component.min.js +1 -1
  124. package/assets/js/components/input-range/input-range.component.min.js.map +1 -1
  125. package/assets/js/components/marketing/marketing.component.js +10 -10
  126. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  127. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  128. package/assets/js/components/menu/menu.component.js +6 -6
  129. package/assets/js/components/menu/menu.component.min.js +1 -1
  130. package/assets/js/components/menu/menu.component.min.js.map +1 -1
  131. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  132. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  133. package/assets/js/components/modal/modal.component.js +21 -21
  134. package/assets/js/components/modal/modal.component.min.js +1 -1
  135. package/assets/js/components/modal/modal.component.min.js.map +1 -1
  136. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  137. package/assets/js/components/multi-step-modal/multi-step-modal.component.js +11 -11
  138. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +1 -1
  139. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js.map +1 -1
  140. package/assets/js/components/multiselect/multiselect.component.js +20 -20
  141. package/assets/js/components/multiselect/multiselect.component.min.js +1 -1
  142. package/assets/js/components/multiselect/multiselect.component.min.js.map +1 -1
  143. package/assets/js/components/nav/nav.component.js +45 -45
  144. package/assets/js/components/nav/nav.component.min.js +1 -1
  145. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  146. package/assets/js/components/notification/notification.component.js +14 -13
  147. package/assets/js/components/notification/notification.component.min.js +5 -4
  148. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  149. package/assets/js/components/pagination/pagination.component.js +39 -39
  150. package/assets/js/components/pagination/pagination.component.min.js +1 -1
  151. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  152. package/assets/js/components/password/password.component.js +10 -10
  153. package/assets/js/components/password/password.component.min.js +1 -1
  154. package/assets/js/components/password/password.component.min.js.map +1 -1
  155. package/assets/js/components/popover/popover.component.js +7 -7
  156. package/assets/js/components/popover/popover.component.min.js +1 -1
  157. package/assets/js/components/popover/popover.component.min.js.map +1 -1
  158. package/assets/js/components/rank/rank.component.js +359 -359
  159. package/assets/js/components/rank/rank.component.min.js +1 -1
  160. package/assets/js/components/rank/rank.component.min.js.map +1 -1
  161. package/assets/js/components/rankings/rankings.component.js +16 -16
  162. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  163. package/assets/js/components/rankings/rankings.component.min.js.map +1 -1
  164. package/assets/js/components/rating/rating.component.js +9 -9
  165. package/assets/js/components/rating/rating.component.min.js +1 -1
  166. package/assets/js/components/rating/rating.component.min.js.map +1 -1
  167. package/assets/js/components/record-card/record-card.component.min.js +1 -1
  168. package/assets/js/components/record-card/record-card.component.min.js.map +1 -1
  169. package/assets/js/components/search/search.component.js +17 -17
  170. package/assets/js/components/search/search.component.min.js +1 -1
  171. package/assets/js/components/search/search.component.min.js.map +1 -1
  172. package/assets/js/components/slider/slider.component.js +12 -12
  173. package/assets/js/components/slider/slider.component.min.js +1 -1
  174. package/assets/js/components/slider/slider.component.min.js.map +1 -1
  175. package/assets/js/components/split-button/split-button.component.js +18 -18
  176. package/assets/js/components/split-button/split-button.component.min.js +1 -1
  177. package/assets/js/components/split-button/split-button.component.min.js.map +1 -1
  178. package/assets/js/components/std-address-lookup/std-address-lookup.component.js +113 -113
  179. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +1 -1
  180. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js.map +1 -1
  181. package/assets/js/components/table/table.component.js +15 -15
  182. package/assets/js/components/table/table.component.min.js +1 -1
  183. package/assets/js/components/table/table.component.min.js.map +1 -1
  184. package/assets/js/components/table-ajax/table-ajax.component.js +15 -15
  185. package/assets/js/components/table-ajax/table-ajax.component.min.js +1 -1
  186. package/assets/js/components/table-ajax/table-ajax.component.min.js.map +1 -1
  187. package/assets/js/components/table-basic/table-basic.component.js +15 -15
  188. package/assets/js/components/table-basic/table-basic.component.min.js +1 -1
  189. package/assets/js/components/table-basic/table-basic.component.min.js.map +1 -1
  190. package/assets/js/components/table-no-submit/table-no-submit.component.js +15 -15
  191. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +1 -1
  192. package/assets/js/components/table-no-submit/table-no-submit.component.min.js.map +1 -1
  193. package/assets/js/components/table-submit/table-submit.component.js +15 -15
  194. package/assets/js/components/table-submit/table-submit.component.min.js +1 -1
  195. package/assets/js/components/table-submit/table-submit.component.min.js.map +1 -1
  196. package/assets/js/components/tabs/tabs.component.js +17 -17
  197. package/assets/js/components/tabs/tabs.component.min.js +1 -1
  198. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  199. package/assets/js/components/tag/tag.component.js +12 -12
  200. package/assets/js/components/tag/tag.component.min.js +1 -1
  201. package/assets/js/components/tag/tag.component.min.js.map +1 -1
  202. package/assets/js/components/tooltip/tooltip.component.js +8 -8
  203. package/assets/js/components/tooltip/tooltip.component.min.js +1 -1
  204. package/assets/js/components/tooltip/tooltip.component.min.js.map +1 -1
  205. package/assets/js/components/video/video.component.js +9 -9
  206. package/assets/js/components/video/video.component.min.js +1 -1
  207. package/assets/js/components/video/video.component.min.js.map +1 -1
  208. package/assets/js/components/video-card/video-card.component.js +12 -12
  209. package/assets/js/components/video-card/video-card.component.min.js +1 -1
  210. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  211. package/assets/js/components/video-modal/video-modal.component.js +13 -13
  212. package/assets/js/components/video-modal/video-modal.component.min.js +1 -1
  213. package/assets/js/components/video-modal/video-modal.component.min.js.map +1 -1
  214. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  215. package/assets/js/modules/card.module.js +14 -14
  216. package/assets/js/modules/chart.module.js +4 -4
  217. package/assets/js/modules/integration-tests.js +3 -3
  218. package/assets/js/modules/table.js +2 -2
  219. package/assets/js/modules/videos.js +6 -6
  220. package/assets/js/scripts.bundle.js +1 -1
  221. package/assets/js/scripts.bundle.js.map +1 -1
  222. package/assets/js/scripts.bundle.min.js +1 -1
  223. package/assets/js/scripts.bundle.min.js.map +1 -1
  224. package/assets/sass/_bs_grid.scss +41 -41
  225. package/assets/sass/_bs_utilities.scss +51 -51
  226. package/assets/sass/_components.scss +162 -162
  227. package/assets/sass/_corefiles.scss +31 -31
  228. package/assets/sass/_elements.scss +30 -30
  229. package/assets/sass/_fonts.scss +28 -28
  230. package/assets/sass/_func.scss +2 -2
  231. package/assets/sass/_functions/bs_functions.scss +487 -487
  232. package/assets/sass/_functions/bs_mixins.scss +2103 -2103
  233. package/assets/sass/_functions/bs_utilities.scss +922 -922
  234. package/assets/sass/_functions/bs_variables.scss +1701 -1701
  235. package/assets/sass/_functions/functions.scss +48 -48
  236. package/assets/sass/_functions/mixins.scss +1 -1
  237. package/assets/sass/_grid.scss +320 -320
  238. package/assets/sass/_print.scss +64 -64
  239. package/assets/sass/_utilities.scss +35 -35
  240. package/assets/sass/components/actionbar.component.scss +421 -421
  241. package/assets/sass/components/actionbar.global.scss +115 -115
  242. package/assets/sass/components/address-lookup.component.scss +160 -160
  243. package/assets/sass/components/address-lookup.preload.scss +90 -90
  244. package/assets/sass/components/applied-filters.scss +19 -19
  245. package/assets/sass/components/barchart.component.scss +347 -347
  246. package/assets/sass/components/bento-grid.component.scss +109 -109
  247. package/assets/sass/components/bento-grid.global.scss +248 -248
  248. package/assets/sass/components/calendar.component.scss +1272 -1272
  249. package/assets/sass/components/calendar.config.scss +423 -423
  250. package/assets/sass/components/card.component.scss +187 -187
  251. package/assets/sass/components/card.module.scss +154 -154
  252. package/assets/sass/components/carousel.component.scss +631 -631
  253. package/assets/sass/components/carousel.config.scss +84 -84
  254. package/assets/sass/components/charts.config.scss +86 -86
  255. package/assets/sass/components/charts.module.scss +588 -588
  256. package/assets/sass/components/charts.scss +1298 -1298
  257. package/assets/sass/components/collapsible-side.scss +307 -307
  258. package/assets/sass/components/config.component.scss +235 -235
  259. package/assets/sass/components/content.component.scss +18 -18
  260. package/assets/sass/components/darkmode.component.scss +20 -20
  261. package/assets/sass/components/doughnutchart.component.scss +206 -206
  262. package/assets/sass/components/fileupload.scss +162 -162
  263. package/assets/sass/components/filter-card.component.scss +99 -99
  264. package/assets/sass/components/header.scss +251 -251
  265. package/assets/sass/components/inline-edit.preload.scss +203 -203
  266. package/assets/sass/components/inline-edit.scss +40 -40
  267. package/assets/sass/components/input-range.component.scss +46 -46
  268. package/assets/sass/components/input.component.scss +101 -101
  269. package/assets/sass/components/marketing.component.scss +65 -65
  270. package/assets/sass/components/menu.component.scss +161 -161
  271. package/assets/sass/components/menu.global.scss +82 -82
  272. package/assets/sass/components/milestone.scss +216 -216
  273. package/assets/sass/components/modal.component.scss +252 -252
  274. package/assets/sass/components/multi-step-modal.component.scss +255 -255
  275. package/assets/sass/components/multi-step-modal.global.scss +91 -91
  276. package/assets/sass/components/multi-step.component.scss +144 -144
  277. package/assets/sass/components/multiselect.preload.scss +8 -8
  278. package/assets/sass/components/multiselect.scss +238 -238
  279. package/assets/sass/components/nav.component.scss +718 -718
  280. package/assets/sass/components/nav.docs.scss +55 -55
  281. package/assets/sass/components/nav.global.scss +870 -870
  282. package/assets/sass/components/nav.preload.scss +54 -54
  283. package/assets/sass/components/notification.scss +204 -217
  284. package/assets/sass/components/pagination.scss +237 -237
  285. package/assets/sass/components/password.component.scss +55 -55
  286. package/assets/sass/components/popover.component.scss +28 -28
  287. package/assets/sass/components/property-searchbar.scss +139 -139
  288. package/assets/sass/components/rank.component.scss +275 -275
  289. package/assets/sass/components/rankings.component.scss +70 -70
  290. package/assets/sass/components/rankings.global.scss +140 -140
  291. package/assets/sass/components/rating.component.css +211 -211
  292. package/assets/sass/components/record-card.component.scss +191 -191
  293. package/assets/sass/components/slider.scss +127 -127
  294. package/assets/sass/components/snapshot.scss +65 -65
  295. package/assets/sass/components/split-button.component.scss +83 -83
  296. package/assets/sass/components/stepper.scss +157 -157
  297. package/assets/sass/components/table-basic.component.scss +136 -136
  298. package/assets/sass/components/table-basic.global.scss +676 -676
  299. package/assets/sass/components/table.component.scss +51 -51
  300. package/assets/sass/components/table.global.scss +398 -398
  301. package/assets/sass/components/tabs.component.scss +34 -34
  302. package/assets/sass/components/tabs.config.scss +258 -258
  303. package/assets/sass/components/tag.component.scss +59 -59
  304. package/assets/sass/components/tag.preload.scss +20 -20
  305. package/assets/sass/components/testimonial.scss +125 -125
  306. package/assets/sass/components/timeline.scss +92 -92
  307. package/assets/sass/components/tooltip.component.scss +148 -148
  308. package/assets/sass/components/video-card.component.scss +48 -48
  309. package/assets/sass/components/video-modal.component.scss +26 -26
  310. package/assets/sass/components/video.component.scss +74 -74
  311. package/assets/sass/components/word-count.component.scss +26 -26
  312. package/assets/sass/core.scss +4 -4
  313. package/assets/sass/elements/admin-panel.css +310 -310
  314. package/assets/sass/elements/badge-tag.css +101 -101
  315. package/assets/sass/elements/brand.css +80 -80
  316. package/assets/sass/elements/button__group.css +135 -135
  317. package/assets/sass/elements/buttons--action.css +71 -71
  318. package/assets/sass/elements/buttons--compact.css +168 -168
  319. package/assets/sass/elements/buttons--global.css +239 -239
  320. package/assets/sass/elements/buttons--secondary.css +18 -18
  321. package/assets/sass/elements/buttons--special.css +164 -164
  322. package/assets/sass/elements/buttons--tertiary.css +51 -51
  323. package/assets/sass/elements/buttons.scss +9 -9
  324. package/assets/sass/elements/code.css +45 -45
  325. package/assets/sass/elements/container.scss +118 -118
  326. package/assets/sass/elements/details.css +224 -224
  327. package/assets/sass/elements/dialog.scss +75 -75
  328. package/assets/sass/elements/dropdown.css +85 -85
  329. package/assets/sass/elements/feature.css +174 -174
  330. package/assets/sass/elements/forms.scss +1337 -1337
  331. package/assets/sass/elements/highlight.css +76 -76
  332. package/assets/sass/elements/hr.css +41 -41
  333. package/assets/sass/elements/icons.css +48 -48
  334. package/assets/sass/elements/input.scss +212 -212
  335. package/assets/sass/elements/label.css +20 -20
  336. package/assets/sass/elements/links--collapsible-side.scss +129 -129
  337. package/assets/sass/elements/links--global.scss +155 -155
  338. package/assets/sass/elements/links--video.scss +73 -73
  339. package/assets/sass/elements/links.scss +4 -4
  340. package/assets/sass/elements/lists--breadcrumbs.scss +26 -26
  341. package/assets/sass/elements/lists--steps.css +171 -171
  342. package/assets/sass/elements/lists--tick-list.scss +112 -112
  343. package/assets/sass/elements/lists.scss +99 -99
  344. package/assets/sass/elements/media.css +20 -20
  345. package/assets/sass/elements/modal.scss +411 -411
  346. package/assets/sass/elements/popover.scss +259 -259
  347. package/assets/sass/elements/prefix.scss +139 -139
  348. package/assets/sass/elements/progress.scss +208 -208
  349. package/assets/sass/elements/table.element.scss +144 -144
  350. package/assets/sass/elements/textarea.css +84 -84
  351. package/assets/sass/elements/toggle-button.css +49 -49
  352. package/assets/sass/elements/tooltips.scss +152 -152
  353. package/assets/sass/elements/type.css +166 -166
  354. package/assets/sass/email.scss +68 -68
  355. package/assets/sass/error.scss +31 -31
  356. package/assets/sass/foundations/animations.scss +2 -2
  357. package/assets/sass/foundations/colours.scss +104 -104
  358. package/assets/sass/foundations/reboot.scss +166 -166
  359. package/assets/sass/foundations/root.scss +269 -269
  360. package/assets/sass/main.scss +7 -7
  361. package/assets/sass/templates/auth.scss +106 -106
  362. package/assets/sass/templates/form.scss +95 -95
  363. package/assets/sass/utilities/align.css +24 -24
  364. package/assets/sass/utilities/border.css +65 -65
  365. package/assets/sass/utilities/clearfix.css +8 -8
  366. package/assets/sass/utilities/colours.scss +43 -43
  367. package/assets/sass/utilities/columns.css +61 -61
  368. package/assets/sass/utilities/display.scss +89 -89
  369. package/assets/sass/utilities/fixed.css +16 -16
  370. package/assets/sass/utilities/flex.scss +291 -291
  371. package/assets/sass/utilities/font-awesome-iso-fallbacks.css +43 -43
  372. package/assets/sass/utilities/gap.css +25 -25
  373. package/assets/sass/utilities/gradients.css +39 -39
  374. package/assets/sass/utilities/js-display.css +12 -12
  375. package/assets/sass/utilities/line-clamp.css +24 -24
  376. package/assets/sass/utilities/margins.scss +74 -74
  377. package/assets/sass/utilities/max-height.scss +93 -93
  378. package/assets/sass/utilities/opacity.css +20 -20
  379. package/assets/sass/utilities/order.css +104 -104
  380. package/assets/sass/utilities/overflow.css +16 -16
  381. package/assets/sass/utilities/paddings.scss +33 -33
  382. package/assets/sass/utilities/pointer-events.css +8 -8
  383. package/assets/sass/utilities/position.css +67 -67
  384. package/assets/sass/utilities/ratio.css +33 -33
  385. package/assets/sass/utilities/rounded.css +56 -56
  386. package/assets/sass/utilities/shadow.css +6 -6
  387. package/assets/sass/utilities/sizes.css +92 -92
  388. package/assets/sass/utilities/sticky.css +38 -38
  389. package/assets/sass/utilities/text-truncate.css +6 -6
  390. package/assets/sass/utilities/text.css +190 -190
  391. package/assets/sass/utilities/visible.css +8 -8
  392. package/assets/sass/utilities/visually-hidden.css +13 -13
  393. package/assets/sass/utilities/wider-colours.scss +8 -8
  394. package/assets/svg/illustrations/table.svg +165 -165
  395. package/assets/svg/logo.svg +56 -56
  396. package/assets/ts/components/accordion/accordion.component.ts +77 -77
  397. package/assets/ts/components/actionbar/actionbar.component.ts +567 -567
  398. package/assets/ts/components/address-lookup/address-lookup.component.ts +672 -672
  399. package/assets/ts/components/advanced-select/advanced-select.component.ts +116 -116
  400. package/assets/ts/components/applied-filters/applied-filters.component.ts +37 -37
  401. package/assets/ts/components/bento-grid/bento-grid.component.ts +88 -88
  402. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +165 -165
  403. package/assets/ts/components/config/config.component.ts +699 -699
  404. package/assets/ts/components/content/content.component.ts +78 -78
  405. package/assets/ts/components/darkmode/darkmode.component.ts +108 -108
  406. package/assets/ts/components/fileupload/fileupload.component.ts +74 -74
  407. package/assets/ts/components/filter-card/filter-card.component.ts +106 -106
  408. package/assets/ts/components/form/form.component.ts +102 -102
  409. package/assets/ts/components/header/header.component.ts +97 -97
  410. package/assets/ts/components/inline-edit/inline-edit.component.ts +212 -212
  411. package/assets/ts/components/input/input.component.ts +278 -278
  412. package/assets/ts/components/input-range/input-range.component.ts +78 -78
  413. package/assets/ts/components/marketing/marketing.component.ts +44 -44
  414. package/assets/ts/components/menu/menu.component.ts +212 -212
  415. package/assets/ts/components/modal/modal.component.ts +184 -184
  416. package/assets/ts/components/multi-step-modal/multi-step-modal.component.ts +304 -304
  417. package/assets/ts/components/multiselect/multiselect.component.ts +349 -349
  418. package/assets/ts/components/nav/nav.component.ts +369 -369
  419. package/assets/ts/components/notification/notification.component.ts +173 -172
  420. package/assets/ts/components/pagination/pagination.component.ts +213 -213
  421. package/assets/ts/components/password/password.component.ts +118 -118
  422. package/assets/ts/components/popover/popover.component.ts +50 -50
  423. package/assets/ts/components/rank/rank.component.ts +394 -394
  424. package/assets/ts/components/rankings/rankings.component.ts +79 -79
  425. package/assets/ts/components/rating/rating.component.ts +86 -86
  426. package/assets/ts/components/search/search.component.ts +244 -244
  427. package/assets/ts/components/slider/slider.component.ts +170 -170
  428. package/assets/ts/components/split-button/split-button.component.ts +63 -63
  429. package/assets/ts/components/std-address-lookup/std-address-lookup.component.ts +1919 -1919
  430. package/assets/ts/components/table/table.component.ts +94 -94
  431. package/assets/ts/components/table-ajax/table-ajax.component.ts +70 -70
  432. package/assets/ts/components/table-basic/table-basic.component.ts +56 -56
  433. package/assets/ts/components/table-no-submit/table-no-submit.component.ts +130 -130
  434. package/assets/ts/components/table-submit/table-submit.component.ts +71 -71
  435. package/assets/ts/components/tabs/tabs.component.ts +70 -70
  436. package/assets/ts/components/tag/tag.component.ts +104 -104
  437. package/assets/ts/components/tooltip/tooltip.component.ts +98 -98
  438. package/assets/ts/components/video/video.component.ts +74 -74
  439. package/assets/ts/components/video-card/video-card.component.ts +129 -129
  440. package/assets/ts/components/video-modal/video-modal.component.ts +88 -88
  441. package/assets/ts/modules/advanced-select.ts +186 -186
  442. package/assets/ts/modules/applied-filters.ts +238 -238
  443. package/assets/ts/modules/card.module.ts +46 -46
  444. package/assets/ts/modules/chart.module.ts +594 -594
  445. package/assets/ts/modules/data-layer.md +71 -71
  446. package/assets/ts/modules/dialogs.ts +259 -259
  447. package/assets/ts/modules/dropdown.ts +216 -216
  448. package/assets/ts/modules/helper.test.ts +143 -143
  449. package/assets/ts/modules/helpers.ts +212 -212
  450. package/assets/ts/modules/integration-tests.ts +525 -525
  451. package/assets/ts/modules/modal.ts +45 -45
  452. package/assets/ts/modules/password.ts +82 -82
  453. package/assets/ts/modules/table.ts +1500 -1500
  454. package/assets/ts/modules/test.ts +22 -22
  455. package/assets/ts/modules/videos.ts +233 -233
  456. package/assets/ts/scripts.ts +111 -111
  457. package/dist/components.es.js +24 -24
  458. package/dist/components.umd.js +3 -2
  459. package/package.json +115 -115
  460. package/src/components/AdvancedSelect/AdvancedSelect.vue +28 -28
  461. package/src/components/Config/Config.vue +23 -23
  462. package/src/components/DarkMode/DarkMode.vue +19 -19
  463. package/src/components/Filterlist/Filterlist.vue +23 -23
  464. package/src/components/Form/Form.vue +22 -22
  465. package/src/components/Header/Header.vue +36 -36
  466. package/src/components/Input/Input.vue +22 -22
  467. package/src/components/InputRange/InputRange.vue +22 -22
  468. package/src/components/Modal/Modal.vue +22 -22
  469. package/src/components/MultiStepModal/MultiStepModal.vue +23 -23
  470. package/src/components/NoteFeed/NoteFeed.vue +82 -82
  471. package/src/components/Password/Password.vue +23 -23
  472. package/src/components/Popover/Popover.vue +22 -22
  473. package/src/components/PropertySearchbar/PropertySearchbar.vue +235 -235
  474. package/src/components/PropertySearchbar/README.md +25 -25
  475. package/src/components/Rating/Rating.vue +22 -22
  476. package/src/components/STDAddressLookup/STDAddressLookup.vue +22 -22
  477. package/src/components/Snapshot/Snapshot.vue +30 -30
  478. package/src/components/Tag/Tag.vue +22 -22
  479. package/src/components/Tooltip/Tooltip.vue +22 -22
  480. package/src/components/Video/Video.vue +22 -22
  481. package/src/components/VideoModal/VideoModal.vue +22 -22
  482. package/assets/bootstrap/dist/css/bootstrap-grid.css +0 -4124
  483. package/assets/bootstrap/dist/css/bootstrap-grid.css.map +0 -1
  484. package/assets/bootstrap/dist/css/bootstrap-grid.min.css +0 -7
  485. package/assets/bootstrap/dist/css/bootstrap-grid.min.css.map +0 -1
  486. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.css +0 -4123
  487. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.css.map +0 -1
  488. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.min.css +0 -7
  489. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.min.css.map +0 -1
  490. package/assets/bootstrap/dist/css/bootstrap-reboot.css +0 -488
  491. package/assets/bootstrap/dist/css/bootstrap-reboot.css.map +0 -1
  492. package/assets/bootstrap/dist/css/bootstrap-reboot.min.css +0 -7
  493. package/assets/bootstrap/dist/css/bootstrap-reboot.min.css.map +0 -1
  494. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.css +0 -485
  495. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.css.map +0 -1
  496. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.min.css +0 -7
  497. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.min.css.map +0 -1
  498. package/assets/bootstrap/dist/css/bootstrap-utilities.css +0 -4197
  499. package/assets/bootstrap/dist/css/bootstrap-utilities.css.map +0 -1
  500. package/assets/bootstrap/dist/css/bootstrap-utilities.min.css +0 -7
  501. package/assets/bootstrap/dist/css/bootstrap-utilities.min.css.map +0 -1
  502. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.css +0 -4188
  503. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.css.map +0 -1
  504. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.min.css +0 -7
  505. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.min.css.map +0 -1
  506. package/assets/bootstrap/dist/css/bootstrap.css +0 -10907
  507. package/assets/bootstrap/dist/css/bootstrap.css.map +0 -1
  508. package/assets/bootstrap/dist/css/bootstrap.min.css +0 -7
  509. package/assets/bootstrap/dist/css/bootstrap.min.css.map +0 -1
  510. package/assets/bootstrap/dist/css/bootstrap.rtl.css +0 -10867
  511. package/assets/bootstrap/dist/css/bootstrap.rtl.css.map +0 -1
  512. package/assets/bootstrap/dist/css/bootstrap.rtl.min.css +0 -7
  513. package/assets/bootstrap/dist/css/bootstrap.rtl.min.css.map +0 -1
  514. package/assets/bootstrap/dist/js/bootstrap.bundle.js +0 -7066
  515. package/assets/bootstrap/dist/js/bootstrap.bundle.js.map +0 -1
  516. package/assets/bootstrap/dist/js/bootstrap.bundle.min.js +0 -7
  517. package/assets/bootstrap/dist/js/bootstrap.bundle.min.js.map +0 -1
  518. package/assets/bootstrap/dist/js/bootstrap.esm.js +0 -5204
  519. package/assets/bootstrap/dist/js/bootstrap.esm.js.map +0 -1
  520. package/assets/bootstrap/dist/js/bootstrap.esm.min.js +0 -7
  521. package/assets/bootstrap/dist/js/bootstrap.esm.min.js.map +0 -1
  522. package/assets/bootstrap/dist/js/bootstrap.js +0 -5251
  523. package/assets/bootstrap/dist/js/bootstrap.js.map +0 -1
  524. package/assets/bootstrap/dist/js/bootstrap.min.js +0 -7
  525. package/assets/bootstrap/dist/js/bootstrap.min.js.map +0 -1
  526. package/assets/bootstrap/js/dist/alert.js +0 -100
  527. package/assets/bootstrap/js/dist/alert.js.map +0 -1
  528. package/assets/bootstrap/js/dist/base-component.js +0 -100
  529. package/assets/bootstrap/js/dist/base-component.js.map +0 -1
  530. package/assets/bootstrap/js/dist/button.js +0 -82
  531. package/assets/bootstrap/js/dist/button.js.map +0 -1
  532. package/assets/bootstrap/js/dist/carousel.js +0 -471
  533. package/assets/bootstrap/js/dist/carousel.js.map +0 -1
  534. package/assets/bootstrap/js/dist/collapse.js +0 -311
  535. package/assets/bootstrap/js/dist/collapse.js.map +0 -1
  536. package/assets/bootstrap/js/dist/dom/data.js +0 -67
  537. package/assets/bootstrap/js/dist/dom/data.js.map +0 -1
  538. package/assets/bootstrap/js/dist/dom/event-handler.js +0 -284
  539. package/assets/bootstrap/js/dist/dom/event-handler.js.map +0 -1
  540. package/assets/bootstrap/js/dist/dom/manipulator.js +0 -85
  541. package/assets/bootstrap/js/dist/dom/manipulator.js.map +0 -1
  542. package/assets/bootstrap/js/dist/dom/selector-engine.js +0 -86
  543. package/assets/bootstrap/js/dist/dom/selector-engine.js.map +0 -1
  544. package/assets/bootstrap/js/dist/dropdown.js +0 -471
  545. package/assets/bootstrap/js/dist/dropdown.js.map +0 -1
  546. package/assets/bootstrap/js/dist/modal.js +0 -397
  547. package/assets/bootstrap/js/dist/modal.js.map +0 -1
  548. package/assets/bootstrap/js/dist/offcanvas.js +0 -298
  549. package/assets/bootstrap/js/dist/offcanvas.js.map +0 -1
  550. package/assets/bootstrap/js/dist/popover.js +0 -102
  551. package/assets/bootstrap/js/dist/popover.js.map +0 -1
  552. package/assets/bootstrap/js/dist/scrollspy.js +0 -308
  553. package/assets/bootstrap/js/dist/scrollspy.js.map +0 -1
  554. package/assets/bootstrap/js/dist/tab.js +0 -334
  555. package/assets/bootstrap/js/dist/tab.js.map +0 -1
  556. package/assets/bootstrap/js/dist/toast.js +0 -237
  557. package/assets/bootstrap/js/dist/toast.js.map +0 -1
  558. package/assets/bootstrap/js/dist/tooltip.js +0 -663
  559. package/assets/bootstrap/js/dist/tooltip.js.map +0 -1
  560. package/assets/bootstrap/js/dist/util/backdrop.js +0 -166
  561. package/assets/bootstrap/js/dist/util/backdrop.js.map +0 -1
  562. package/assets/bootstrap/js/dist/util/component-functions.js +0 -47
  563. package/assets/bootstrap/js/dist/util/component-functions.js.map +0 -1
  564. package/assets/bootstrap/js/dist/util/config.js +0 -80
  565. package/assets/bootstrap/js/dist/util/config.js.map +0 -1
  566. package/assets/bootstrap/js/dist/util/focustrap.js +0 -130
  567. package/assets/bootstrap/js/dist/util/focustrap.js.map +0 -1
  568. package/assets/bootstrap/js/dist/util/index.js +0 -351
  569. package/assets/bootstrap/js/dist/util/index.js.map +0 -1
  570. package/assets/bootstrap/js/dist/util/sanitizer.js +0 -123
  571. package/assets/bootstrap/js/dist/util/sanitizer.js.map +0 -1
  572. package/assets/bootstrap/js/dist/util/scrollbar.js +0 -139
  573. package/assets/bootstrap/js/dist/util/scrollbar.js.map +0 -1
  574. package/assets/bootstrap/js/dist/util/swipe.js +0 -156
  575. package/assets/bootstrap/js/dist/util/swipe.js.map +0 -1
  576. package/assets/bootstrap/js/dist/util/template-factory.js +0 -178
  577. package/assets/bootstrap/js/dist/util/template-factory.js.map +0 -1
@@ -1,526 +1,526 @@
1
- const integrationTests = () => {
2
-
3
- let errorTable = [];
4
- let test = {};
5
- const intro = "These tests run against mark-up and content meant to test how a component or element has been integrated. Making sure that guidance setout in the design system is being followed.";
6
-
7
- window.integrationTestsIntro = intro;
8
-
9
- console.log("%cVirgin Money Framework Tests","color: #E10A0A; font-size: 24px; font-weight: bold; margin-top: 20px; margin-bottom: 10px;");
10
-
11
- console.log("%c"+intro,"font-size: 14px; margin-bottom: 20px;");
12
-
13
- console.log("%cKey","font-size: 16px;font-weight:bold;");
14
- console.log('%c %c' + 'Successfully implemented', 'background-color: green; margin-right: 10px', 'background-color: transparent');
15
- console.log('%c %c' + 'NOT implemented correctly', 'background-color: red; margin-right: 10px', 'background-color: transparent');
16
- console.log('%c %c' + 'N/A', 'background-color: grey; margin-right: 10px', 'background-color: transparent');
17
- console.log('%c %c' + 'Warning - No action needed', 'background-color: orange; margin-right: 10px', 'background-color: transparent');
18
- console.log('%c ? %c' + 'Warning - Action needed', 'background-color: orange; margin-right: 10px', 'background-color: transparent');
19
-
20
- // #region Card deck Footer test
21
- test = {
22
- 'Test': 'Each card with in a card deck has a footer with some CTA text via a button link',
23
- 'Total': 0,
24
- 'Passes': 0,
25
- 'Fails': 0
26
- }
27
-
28
- Array.from(document.querySelectorAll('.card-deck .card')).forEach((card, index) => {
29
-
30
- if(card.closest('.navbar') == null){
31
-
32
- let btnLink = card.querySelector('.btn-link');
33
-
34
- if(btnLink != null && btnLink.textContent.length)
35
- test['Passes']++;
36
- else
37
- test['Fails']++;
38
- }
39
- });
40
-
41
- test['Total'] = test['Passes'] + test['Fails'];
42
- errorTable.push(test);
43
- // #endregion
44
-
45
- // #region Article deck background colour
46
- test = {
47
- 'Test': 'Article Decks need to have a background colour applied',
48
- 'Total': 0,
49
- 'Passes': 0,
50
- 'Fails': 0
51
- }
52
-
53
- Array.from(document.querySelectorAll('.article-deck')).forEach((deck, index) => {
54
-
55
- let container = deck.closest('.container');
56
-
57
- if (container != null && container.matches('[class*="bg-"]'))
58
- test['Passes']++;
59
- else
60
- test['Fails']++;
61
- });
62
-
63
- test['Total'] = test['Passes'] + test['Fails'];
64
- errorTable.push(test);
65
- // #endregion
66
-
67
- // #region Tabs Carousel title test
68
- test = {
69
- 'Test': 'Tabs Carousel has a h2 title with a display-4 class. It should always have a strapline next to it also.',
70
- 'Total': 0,
71
- 'Passes': 0,
72
- 'Fails': 0,
73
- 'Notes': 'The site nav contains cards without a footer by design.'
74
- }
75
-
76
- Array.from(document.querySelectorAll('.tabs__container--carousel')).forEach((tabs, index) => {
77
-
78
- let title = tabs.querySelector('h2.display-4:first-child');
79
- let strapline = tabs.querySelector('h2.display-4:first-child + .strapline');
80
-
81
- if(title != null && strapline != null)
82
- test['Passes']++;
83
- else
84
- test['Fails']++
85
- });
86
-
87
- test['Total'] = test['Passes'] + test['Fails'];
88
- errorTable.push(test);
89
- // #endregion
90
-
91
- // #region Split Container tests
92
- test = {
93
- 'Test': 'Split Containers can only have multiple of two columns. So either 2, 4, 6 and so on.',
94
- 'Total': 0,
95
- 'Passes': 0,
96
- 'Fails': 0,
97
- 'Notes': ''
98
- }
99
-
100
- Array.from(document.querySelectorAll('.container.container--split')).forEach((container, index) => {
101
-
102
- if(container.querySelectorAll(':scope > .row > [class*="col"]').length % 2 === 0)
103
- test['Passes']++;
104
- else
105
- test['Fails']++;
106
- });
107
- test['Total'] = test['Passes'] + test['Fails'];
108
- errorTable.push(test);
109
- // #endregion
110
-
111
- // #region Statement Container tests
112
- test = {
113
- 'Test': 'Statement Containers with only one paragraph or text element should have the class of .h6',
114
- 'Total': 0,
115
- 'Passes': 0,
116
- 'Fails': 0,
117
- 'Notes': ''
118
- }
119
-
120
- Array.from(document.querySelectorAll('.container.container--statement')).forEach((container, index) => {
121
- if(container.querySelectorAll(':scope > *').length == 1 && container.querySelectorAll(':scope > .h6:first-child').length == 1)
122
- test['Passes']++;
123
- else if(container.querySelectorAll(':scope > *').length == 1)
124
- test['Fails']++;
125
- });
126
- test['Total'] = test['Passes'] + test['Fails'];
127
- errorTable.push(test);
128
- // #endregion
129
-
130
- // #region CTA Container tests
131
- test = {
132
- 'Test': 'CTA Containers title should always have the class of .h1',
133
- 'Total': 0,
134
- 'Passes': 0,
135
- 'Fails': 0,
136
- 'Notes': ''
137
- }
138
-
139
- Array.from(document.querySelectorAll('.container.container--cta')).forEach((container, index) => {
140
-
141
- if(container.querySelectorAll('h2.h1:first-child').length == 1)
142
- test['Passes']++;
143
- else
144
- test['Fails']++;
145
- });
146
- test['Total'] = test['Passes'] + test['Fails'];
147
- errorTable.push(test);
148
- // #endregion
149
-
150
- // Print Implementation tests
151
- console.log("%cImplementation Tests","font-size: 16px;font-weight:bold; margin-top: 20px;");
152
- errorTable.forEach(function(entry) {
153
- let color = 'green';
154
-
155
- if(entry['Total'] === 0){
156
- color = 'grey';
157
- }
158
- else if(entry['Fails'] != 0){
159
- color = 'red';
160
- }
161
-
162
- if(entry['Type'] == 'warning'){
163
- color = 'orange';
164
- }
165
-
166
- console.groupCollapsed('%c %c' + entry.Test, 'background-color: ' + color + '; margin-right: 10px', 'background-color: transparent');
167
- console.table({
168
- Passed: {value: entry['Passes']},
169
- Failed: {value: entry['Fails']},
170
- Total: {value: entry['Total']}
171
- });
172
-
173
- if(entry['Notes'] != ''){
174
- console.log(entry['Notes']);
175
- }
176
-
177
- console.groupEnd();
178
- });
179
-
180
-
181
- window.integrationTests = errorTable;
182
-
183
- // Resest table
184
- var errorTableUtility = [];
185
-
186
- // #region Padding classes
187
- test = {
188
- 'Test': 'There are XX padding classes being used on this page',
189
- 'Type': 'warning',
190
- 'Total': 0,
191
- 'Passes': 0,
192
- 'Fails': 0,
193
- 'Notes': ''
194
- }
195
-
196
- Array.from(document.querySelectorAll('[class*="p-"],[class*="pt-"],[class*="pb-"],[class*="pl-"],[class*="pr-"],[class*="px-"],[class*="py-"]')).forEach((element, index) => {
197
-
198
- test['Total']++;
199
- });
200
-
201
- test['Test'] = test['Test'].replace('XX',test['Total']);
202
- errorTableUtility.push(test);
203
- // #endregion
204
-
205
- // #region Margin classes
206
- test = {
207
- 'Test': 'There are XX margin classes being used on this page',
208
- 'Type': 'warning',
209
- 'Total': 0,
210
- 'Passes': 0,
211
- 'Fails': 0,
212
- 'Notes': ''
213
- }
214
-
215
- Array.from(document.querySelectorAll('[class*="m-"],[class*="mt-"],[class*="mb-"],[class*="ml-"],[class*="mr-"],[class*="mx-"],[class*="my-"]')).forEach((element, index) => {
216
-
217
- test['Total']++;
218
- });
219
-
220
- test['Test'] = test['Test'].replace('XX',test['Total']);
221
- errorTableUtility.push(test);
222
- // #endregion
223
-
224
- // #region Text modifier classes
225
- test = {
226
- 'Test': 'There are XX text modifier classes being used on this page',
227
- 'Type': 'warning',
228
- 'Total': 0,
229
- 'Passes': 0,
230
- 'Fails': 0,
231
- 'Notes': ''
232
- }
233
- Array.from(document.querySelectorAll('[class*="text-"]')).forEach((element, index) => {
234
-
235
- test['Total']++;
236
- });
237
-
238
- test['Test'] = test['Test'].replace('XX',test['Total']);
239
- errorTableUtility.push(test);
240
- // #endregion
241
-
242
-
243
- // Print the utility classes tests
244
- console.log("%cUtility classes","font-size: 16px;font-weight:bold;");
245
-
246
- console.log("The use of certain utility classes is necessary at times but the over use of these classes will lead to design/layout inconsistencies.");
247
-
248
- errorTableUtility.forEach(function(entry) {
249
- let color = 'green';
250
-
251
- if(entry['Total'] === 0)
252
- color = 'grey';
253
- else if(entry['Fails'] != 0)
254
- color = 'red';
255
-
256
- if(entry['Type'] == 'warning')
257
- color = 'orange';
258
-
259
- console.groupCollapsed('%c %c' + entry.Test, 'background-color: ' + color + '; margin-right: 10px', 'background-color: transparent');
260
- console.table({
261
- Total: {value: entry['Total']}
262
- });
263
-
264
- if(entry['Notes'] != ''){
265
- console.log(entry['Notes']);
266
- }
267
-
268
- console.groupEnd();
269
- });
270
-
271
-
272
- // #region Headings out of context tests
273
- console.log("%cAccessibility and Best practice Tests","font-size: 16px;font-weight:bold;");
274
-
275
- let color = 'green';
276
- let contextLevel = 1;
277
- let headingTable = {};
278
-
279
- Array.from(document.querySelectorAll('h1,h2,h3,h4,h5,h6')).forEach((heading, index) => {
280
-
281
- let level = 1;
282
- let text = heading.textContent;
283
-
284
- if(heading.matches("h2"))
285
- level = 2;
286
- else if(heading.matches("h3"))
287
- level = 3;
288
- else if(heading.matches("h4"))
289
- level = 4;
290
- else if(heading.matches("h5"))
291
- level = 5;
292
- else if(heading.matches("h6"))
293
- level = 6;
294
-
295
-
296
- let inOrder = (level - contextLevel) <= 1;
297
-
298
- if(index == 0 && level != 1){
299
- inOrder = false;
300
- }
301
-
302
- let test = {
303
- "Heading Level": level,
304
- "In order": inOrder
305
- }
306
-
307
- if (inOrder){
308
-
309
- contextLevel = level;
310
- }
311
- else {
312
- color = 'red';
313
- }
314
-
315
- headingTable[text] = test;
316
- });
317
-
318
- console.groupCollapsed('%c %c' + 'Headings are in the correct order', 'background-color: ' + color + '; margin-right: 10px', 'background-color: transparent');
319
- console.table(headingTable);
320
- console.groupEnd();
321
-
322
- console.groupCollapsed('%c ? %c' + 'Do all of the headings make sense out of context and do they introduce the content that follows?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
323
- console.log("You should be able to read the below table and get an understanding of what the page content consists of. The titles should make sense when read in order and child titles should be relevant to the parent title.");
324
- console.table(headingTable);
325
- console.groupEnd();
326
- // #endregion
327
-
328
- // #region Links out of context tests
329
- let linksTable = {};
330
- Array.from(document.querySelectorAll('a')).forEach((link, index) => {
331
-
332
- var url = link.getAttribute('href');
333
- var text = link.textContent;
334
- var title = link.getAttribute('title');
335
-
336
- let test = {
337
- "Text": text,
338
- "Title": title
339
- }
340
-
341
- linksTable[url] = test;
342
- });
343
-
344
- console.groupCollapsed('%c ? %c' + 'Do all of the links make sense out of context and do they describe the page/section that it links to?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
345
- console.table(linksTable);
346
- console.groupEnd();
347
- // #endregion
348
-
349
-
350
- // #region Image alt tags out of context tests
351
- let imgTable = {};
352
- let imgNoAltTable = {};
353
-
354
- Array.from(document.querySelectorAll('img[alt]')).forEach((image, index) => {
355
-
356
- var url = image.getAttribute('src');
357
- var alt = image.getAttribute('alt');
358
-
359
- if(alt != ""){
360
-
361
- let test = {
362
- "Alt": alt
363
- }
364
-
365
- imgTable[url] = test;
366
-
367
- }
368
- else {
369
-
370
- var url = image.getAttribute('src');
371
-
372
- let test = {};
373
-
374
- imgNoAltTable[url] = test;
375
- }
376
-
377
- });
378
-
379
- console.groupCollapsed('%c ? %c' + 'Do all of the images with an alt tag make sense out of context and describes the image appropriately?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
380
- console.table(imgTable);
381
- console.log('%cImages with an empty alt tag:', 'font-weight: bold;');
382
- console.table(imgNoAltTable);
383
- console.groupEnd();
384
- // #endregion
385
-
386
- // #region Keyboard user messages
387
- console.groupCollapsed('%c ? %c' + 'Can you navigation the page links by tabbing through the page?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
388
- console.log('Are all of the links, input fields and buttons accessible through using the keyboard only?');
389
- console.groupEnd();
390
- // #endregion
391
-
392
-
393
-
394
- console.log("%cLighthouse","font-size: 16px;font-weight:bold;");
395
-
396
- // #region Lighthouse
397
- console.groupCollapsed('%c ? %c' + 'Have you ran a lighthouse report on this page', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
398
- console.log('If you are in a modern version of chrome you can a lighthouse report by opening the lighthouse window within the devtools. This should appear as a tab link above.');
399
- console.log('This report will give you more detail about the above the tests aswell as extra tests. ');
400
- console.groupEnd();
401
- // #endregion
402
-
403
- console.log("%cImage sizes","font-size: 16px;font-weight:bold;");
404
- console.log("The below tests work from the current screen size, so if you have your screen at a mobile viewport the scaling and sizes of images will reflect that. It is worth running the image tests in both mobile and desktop views. Simply change the screen size and refresh the page.");
405
-
406
- Array.from(document.querySelectorAll('img')).forEach((imgElem, index) => {
407
-
408
- if(!imgElem.matches("[src*='http']") && !imgElem.matches("[src$='.svg']")){
409
-
410
- let src = imgElem.getAttribute('src');
411
-
412
- var xhr = new XMLHttpRequest();
413
- xhr.open('HEAD', src, true);
414
- xhr.onreadystatechange = function(){
415
- if (xhr.readyState == 4) {
416
- if (xhr.status == 200){
417
- var imgFSize = xhr.getResponseHeader('Content-Length');
418
- if (imgFSize > 1024){ //ignore images under 1Kb
419
- var imgW = imgElem.naturalWidth;
420
- var imgH = imgElem.naturalHeight;
421
- var imgW2 = imgElem.clientWidth;
422
- var imgH2 = imgElem.clientHeight;
423
- var imgScl = (imgW2/imgW).toFixed(2) == "0.00" ? "Hidden" : (imgW2/imgW).toFixed(2);
424
- var imgFSize2 = Math.floor(imgFSize/1024);
425
- var imgBPP = (imgFSize/(imgW*imgH)).toFixed(2);
426
- var cssColor = "green";
427
- var bppColor = "green";
428
- var scaleColor = "green";
429
-
430
- var bppError = "";
431
- var scaleError = "";
432
-
433
-
434
- if (imgBPP > 0.5){
435
- cssColor = "red";
436
- bppColor = "red";
437
- bppError = "The image has a VERY large \'Bytes per pixel\' score, trying optimising the image using https://tinypng.com/.";
438
- }
439
- else if (imgBPP > 0.2){
440
- cssColor = "orange";
441
- bppColor = "orange";
442
- bppError = "The image has a large \'Bytes per pixel\' score, trying optimising the image using https://tinypng.com/.";
443
- }
444
-
445
- if (imgScl > 1.2){
446
- cssColor = "red";
447
- scaleColor = "red";
448
- scaleError = "The image size is smaller than the size shown on screen this may cause the image to appear blurry and low quality.";
449
- }
450
- else if (imgScl < 0.5){
451
- cssColor = "red";
452
- scaleColor = "red";
453
- scaleError = "The image size is VERY large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software.";
454
- }
455
- else if (imgScl < 0.8){
456
- cssColor = "orange";
457
- scaleColor = "orange";
458
- scaleError = "The image size is large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software.";
459
- }
460
-
461
- console.log("%c %c "+imgElem.src,'background: url('+imgElem.src+'); border: 3px solid '+cssColor+'; line-height: 30px; width: 30px; background-size: cover;', 'background-color: transparent');
462
-
463
- if(bppError != ""){
464
- console.log('%c %c'+bppError , 'background-color: ' + bppColor + '; margin-right: 10px', 'background-color: transparent');
465
- }
466
- if(scaleError != ""){
467
- console.log('%c %c'+scaleError , 'background-color: ' + scaleColor + '; margin-right: 10px', 'background-color: transparent');
468
- }
469
-
470
- console.table({
471
- Image: {"Dimensions": imgW + "x" + imgH, "Scaled to": imgW2 + "x" + imgH2, "Scale": imgScl, "Filesize": imgFSize2 + "Kb", "Bytes per pixel": imgBPP}
472
- });
473
-
474
- console.groupEnd();
475
- }
476
- }
477
- else {
478
- console.log('%c %c'+imgElem.src+' not loaded' , 'background-color: red; margin-right: 10px', 'background-color: transparent');
479
- }
480
- }
481
- };
482
- xhr.send(null);
483
-
484
-
485
- }
486
- });
487
-
488
- // Add to dom here
489
- let integrationTestsArr = [];
490
- if(typeof window.integrationTests != "undefined"){
491
-
492
- window.integrationTests.forEach(function(entry) {
493
- if(entry['Total'] != 0 && entry['Type'] != "warning" ){
494
- integrationTestsArr.push(entry['Test']);
495
- }
496
- });
497
- }
498
-
499
- if (integrationTestsArr.length != 0) {
500
-
501
- let displayComp = document.querySelector('#vmtests-display');
502
-
503
- if(displayComp != null){
504
-
505
- displayComp.innerHTML = `<div class="container">
506
- <h2>Integration notes</h2>
507
- <ul id="integrationTests"></ul>
508
- </div>`;
509
-
510
- let integrationTests = document.getElementById('integrationTests');
511
-
512
- if(integrationTests != null){
513
-
514
- integrationTestsArr.forEach(function(test) {
515
-
516
- integrationTests.innerHTML += '<li>'+test+'</li>';
517
-
518
- });
519
- }
520
- }
521
- }
522
-
523
- return null
524
- }
525
-
1
+ const integrationTests = () => {
2
+
3
+ let errorTable = [];
4
+ let test = {};
5
+ const intro = "These tests run against mark-up and content meant to test how a component or element has been integrated. Making sure that guidance setout in the design system is being followed.";
6
+
7
+ window.integrationTestsIntro = intro;
8
+
9
+ console.log("%cVirgin Money Framework Tests","color: #E10A0A; font-size: 24px; font-weight: bold; margin-top: 20px; margin-bottom: 10px;");
10
+
11
+ console.log("%c"+intro,"font-size: 14px; margin-bottom: 20px;");
12
+
13
+ console.log("%cKey","font-size: 16px;font-weight:bold;");
14
+ console.log('%c %c' + 'Successfully implemented', 'background-color: green; margin-right: 10px', 'background-color: transparent');
15
+ console.log('%c %c' + 'NOT implemented correctly', 'background-color: red; margin-right: 10px', 'background-color: transparent');
16
+ console.log('%c %c' + 'N/A', 'background-color: grey; margin-right: 10px', 'background-color: transparent');
17
+ console.log('%c %c' + 'Warning - No action needed', 'background-color: orange; margin-right: 10px', 'background-color: transparent');
18
+ console.log('%c ? %c' + 'Warning - Action needed', 'background-color: orange; margin-right: 10px', 'background-color: transparent');
19
+
20
+ // #region Card deck Footer test
21
+ test = {
22
+ 'Test': 'Each card with in a card deck has a footer with some CTA text via a button link',
23
+ 'Total': 0,
24
+ 'Passes': 0,
25
+ 'Fails': 0
26
+ }
27
+
28
+ Array.from(document.querySelectorAll('.card-deck .card')).forEach((card, index) => {
29
+
30
+ if(card.closest('.navbar') == null){
31
+
32
+ let btnLink = card.querySelector('.btn-link');
33
+
34
+ if(btnLink != null && btnLink.textContent.length)
35
+ test['Passes']++;
36
+ else
37
+ test['Fails']++;
38
+ }
39
+ });
40
+
41
+ test['Total'] = test['Passes'] + test['Fails'];
42
+ errorTable.push(test);
43
+ // #endregion
44
+
45
+ // #region Article deck background colour
46
+ test = {
47
+ 'Test': 'Article Decks need to have a background colour applied',
48
+ 'Total': 0,
49
+ 'Passes': 0,
50
+ 'Fails': 0
51
+ }
52
+
53
+ Array.from(document.querySelectorAll('.article-deck')).forEach((deck, index) => {
54
+
55
+ let container = deck.closest('.container');
56
+
57
+ if (container != null && container.matches('[class*="bg-"]'))
58
+ test['Passes']++;
59
+ else
60
+ test['Fails']++;
61
+ });
62
+
63
+ test['Total'] = test['Passes'] + test['Fails'];
64
+ errorTable.push(test);
65
+ // #endregion
66
+
67
+ // #region Tabs Carousel title test
68
+ test = {
69
+ 'Test': 'Tabs Carousel has a h2 title with a display-4 class. It should always have a strapline next to it also.',
70
+ 'Total': 0,
71
+ 'Passes': 0,
72
+ 'Fails': 0,
73
+ 'Notes': 'The site nav contains cards without a footer by design.'
74
+ }
75
+
76
+ Array.from(document.querySelectorAll('.tabs__container--carousel')).forEach((tabs, index) => {
77
+
78
+ let title = tabs.querySelector('h2.display-4:first-child');
79
+ let strapline = tabs.querySelector('h2.display-4:first-child + .strapline');
80
+
81
+ if(title != null && strapline != null)
82
+ test['Passes']++;
83
+ else
84
+ test['Fails']++
85
+ });
86
+
87
+ test['Total'] = test['Passes'] + test['Fails'];
88
+ errorTable.push(test);
89
+ // #endregion
90
+
91
+ // #region Split Container tests
92
+ test = {
93
+ 'Test': 'Split Containers can only have multiple of two columns. So either 2, 4, 6 and so on.',
94
+ 'Total': 0,
95
+ 'Passes': 0,
96
+ 'Fails': 0,
97
+ 'Notes': ''
98
+ }
99
+
100
+ Array.from(document.querySelectorAll('.container.container--split')).forEach((container, index) => {
101
+
102
+ if(container.querySelectorAll(':scope > .row > [class*="col"]').length % 2 === 0)
103
+ test['Passes']++;
104
+ else
105
+ test['Fails']++;
106
+ });
107
+ test['Total'] = test['Passes'] + test['Fails'];
108
+ errorTable.push(test);
109
+ // #endregion
110
+
111
+ // #region Statement Container tests
112
+ test = {
113
+ 'Test': 'Statement Containers with only one paragraph or text element should have the class of .h6',
114
+ 'Total': 0,
115
+ 'Passes': 0,
116
+ 'Fails': 0,
117
+ 'Notes': ''
118
+ }
119
+
120
+ Array.from(document.querySelectorAll('.container.container--statement')).forEach((container, index) => {
121
+ if(container.querySelectorAll(':scope > *').length == 1 && container.querySelectorAll(':scope > .h6:first-child').length == 1)
122
+ test['Passes']++;
123
+ else if(container.querySelectorAll(':scope > *').length == 1)
124
+ test['Fails']++;
125
+ });
126
+ test['Total'] = test['Passes'] + test['Fails'];
127
+ errorTable.push(test);
128
+ // #endregion
129
+
130
+ // #region CTA Container tests
131
+ test = {
132
+ 'Test': 'CTA Containers title should always have the class of .h1',
133
+ 'Total': 0,
134
+ 'Passes': 0,
135
+ 'Fails': 0,
136
+ 'Notes': ''
137
+ }
138
+
139
+ Array.from(document.querySelectorAll('.container.container--cta')).forEach((container, index) => {
140
+
141
+ if(container.querySelectorAll('h2.h1:first-child').length == 1)
142
+ test['Passes']++;
143
+ else
144
+ test['Fails']++;
145
+ });
146
+ test['Total'] = test['Passes'] + test['Fails'];
147
+ errorTable.push(test);
148
+ // #endregion
149
+
150
+ // Print Implementation tests
151
+ console.log("%cImplementation Tests","font-size: 16px;font-weight:bold; margin-top: 20px;");
152
+ errorTable.forEach(function(entry) {
153
+ let color = 'green';
154
+
155
+ if(entry['Total'] === 0){
156
+ color = 'grey';
157
+ }
158
+ else if(entry['Fails'] != 0){
159
+ color = 'red';
160
+ }
161
+
162
+ if(entry['Type'] == 'warning'){
163
+ color = 'orange';
164
+ }
165
+
166
+ console.groupCollapsed('%c %c' + entry.Test, 'background-color: ' + color + '; margin-right: 10px', 'background-color: transparent');
167
+ console.table({
168
+ Passed: {value: entry['Passes']},
169
+ Failed: {value: entry['Fails']},
170
+ Total: {value: entry['Total']}
171
+ });
172
+
173
+ if(entry['Notes'] != ''){
174
+ console.log(entry['Notes']);
175
+ }
176
+
177
+ console.groupEnd();
178
+ });
179
+
180
+
181
+ window.integrationTests = errorTable;
182
+
183
+ // Resest table
184
+ var errorTableUtility = [];
185
+
186
+ // #region Padding classes
187
+ test = {
188
+ 'Test': 'There are XX padding classes being used on this page',
189
+ 'Type': 'warning',
190
+ 'Total': 0,
191
+ 'Passes': 0,
192
+ 'Fails': 0,
193
+ 'Notes': ''
194
+ }
195
+
196
+ Array.from(document.querySelectorAll('[class*="p-"],[class*="pt-"],[class*="pb-"],[class*="pl-"],[class*="pr-"],[class*="px-"],[class*="py-"]')).forEach((element, index) => {
197
+
198
+ test['Total']++;
199
+ });
200
+
201
+ test['Test'] = test['Test'].replace('XX',test['Total']);
202
+ errorTableUtility.push(test);
203
+ // #endregion
204
+
205
+ // #region Margin classes
206
+ test = {
207
+ 'Test': 'There are XX margin classes being used on this page',
208
+ 'Type': 'warning',
209
+ 'Total': 0,
210
+ 'Passes': 0,
211
+ 'Fails': 0,
212
+ 'Notes': ''
213
+ }
214
+
215
+ Array.from(document.querySelectorAll('[class*="m-"],[class*="mt-"],[class*="mb-"],[class*="ml-"],[class*="mr-"],[class*="mx-"],[class*="my-"]')).forEach((element, index) => {
216
+
217
+ test['Total']++;
218
+ });
219
+
220
+ test['Test'] = test['Test'].replace('XX',test['Total']);
221
+ errorTableUtility.push(test);
222
+ // #endregion
223
+
224
+ // #region Text modifier classes
225
+ test = {
226
+ 'Test': 'There are XX text modifier classes being used on this page',
227
+ 'Type': 'warning',
228
+ 'Total': 0,
229
+ 'Passes': 0,
230
+ 'Fails': 0,
231
+ 'Notes': ''
232
+ }
233
+ Array.from(document.querySelectorAll('[class*="text-"]')).forEach((element, index) => {
234
+
235
+ test['Total']++;
236
+ });
237
+
238
+ test['Test'] = test['Test'].replace('XX',test['Total']);
239
+ errorTableUtility.push(test);
240
+ // #endregion
241
+
242
+
243
+ // Print the utility classes tests
244
+ console.log("%cUtility classes","font-size: 16px;font-weight:bold;");
245
+
246
+ console.log("The use of certain utility classes is necessary at times but the over use of these classes will lead to design/layout inconsistencies.");
247
+
248
+ errorTableUtility.forEach(function(entry) {
249
+ let color = 'green';
250
+
251
+ if(entry['Total'] === 0)
252
+ color = 'grey';
253
+ else if(entry['Fails'] != 0)
254
+ color = 'red';
255
+
256
+ if(entry['Type'] == 'warning')
257
+ color = 'orange';
258
+
259
+ console.groupCollapsed('%c %c' + entry.Test, 'background-color: ' + color + '; margin-right: 10px', 'background-color: transparent');
260
+ console.table({
261
+ Total: {value: entry['Total']}
262
+ });
263
+
264
+ if(entry['Notes'] != ''){
265
+ console.log(entry['Notes']);
266
+ }
267
+
268
+ console.groupEnd();
269
+ });
270
+
271
+
272
+ // #region Headings out of context tests
273
+ console.log("%cAccessibility and Best practice Tests","font-size: 16px;font-weight:bold;");
274
+
275
+ let color = 'green';
276
+ let contextLevel = 1;
277
+ let headingTable = {};
278
+
279
+ Array.from(document.querySelectorAll('h1,h2,h3,h4,h5,h6')).forEach((heading, index) => {
280
+
281
+ let level = 1;
282
+ let text = heading.textContent;
283
+
284
+ if(heading.matches("h2"))
285
+ level = 2;
286
+ else if(heading.matches("h3"))
287
+ level = 3;
288
+ else if(heading.matches("h4"))
289
+ level = 4;
290
+ else if(heading.matches("h5"))
291
+ level = 5;
292
+ else if(heading.matches("h6"))
293
+ level = 6;
294
+
295
+
296
+ let inOrder = (level - contextLevel) <= 1;
297
+
298
+ if(index == 0 && level != 1){
299
+ inOrder = false;
300
+ }
301
+
302
+ let test = {
303
+ "Heading Level": level,
304
+ "In order": inOrder
305
+ }
306
+
307
+ if (inOrder){
308
+
309
+ contextLevel = level;
310
+ }
311
+ else {
312
+ color = 'red';
313
+ }
314
+
315
+ headingTable[text] = test;
316
+ });
317
+
318
+ console.groupCollapsed('%c %c' + 'Headings are in the correct order', 'background-color: ' + color + '; margin-right: 10px', 'background-color: transparent');
319
+ console.table(headingTable);
320
+ console.groupEnd();
321
+
322
+ console.groupCollapsed('%c ? %c' + 'Do all of the headings make sense out of context and do they introduce the content that follows?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
323
+ console.log("You should be able to read the below table and get an understanding of what the page content consists of. The titles should make sense when read in order and child titles should be relevant to the parent title.");
324
+ console.table(headingTable);
325
+ console.groupEnd();
326
+ // #endregion
327
+
328
+ // #region Links out of context tests
329
+ let linksTable = {};
330
+ Array.from(document.querySelectorAll('a')).forEach((link, index) => {
331
+
332
+ var url = link.getAttribute('href');
333
+ var text = link.textContent;
334
+ var title = link.getAttribute('title');
335
+
336
+ let test = {
337
+ "Text": text,
338
+ "Title": title
339
+ }
340
+
341
+ linksTable[url] = test;
342
+ });
343
+
344
+ console.groupCollapsed('%c ? %c' + 'Do all of the links make sense out of context and do they describe the page/section that it links to?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
345
+ console.table(linksTable);
346
+ console.groupEnd();
347
+ // #endregion
348
+
349
+
350
+ // #region Image alt tags out of context tests
351
+ let imgTable = {};
352
+ let imgNoAltTable = {};
353
+
354
+ Array.from(document.querySelectorAll('img[alt]')).forEach((image, index) => {
355
+
356
+ var url = image.getAttribute('src');
357
+ var alt = image.getAttribute('alt');
358
+
359
+ if(alt != ""){
360
+
361
+ let test = {
362
+ "Alt": alt
363
+ }
364
+
365
+ imgTable[url] = test;
366
+
367
+ }
368
+ else {
369
+
370
+ var url = image.getAttribute('src');
371
+
372
+ let test = {};
373
+
374
+ imgNoAltTable[url] = test;
375
+ }
376
+
377
+ });
378
+
379
+ console.groupCollapsed('%c ? %c' + 'Do all of the images with an alt tag make sense out of context and describes the image appropriately?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
380
+ console.table(imgTable);
381
+ console.log('%cImages with an empty alt tag:', 'font-weight: bold;');
382
+ console.table(imgNoAltTable);
383
+ console.groupEnd();
384
+ // #endregion
385
+
386
+ // #region Keyboard user messages
387
+ console.groupCollapsed('%c ? %c' + 'Can you navigation the page links by tabbing through the page?', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
388
+ console.log('Are all of the links, input fields and buttons accessible through using the keyboard only?');
389
+ console.groupEnd();
390
+ // #endregion
391
+
392
+
393
+
394
+ console.log("%cLighthouse","font-size: 16px;font-weight:bold;");
395
+
396
+ // #region Lighthouse
397
+ console.groupCollapsed('%c ? %c' + 'Have you ran a lighthouse report on this page', 'background-color: ' + 'orange' + '; margin-right: 10px', 'background-color: transparent');
398
+ console.log('If you are in a modern version of chrome you can a lighthouse report by opening the lighthouse window within the devtools. This should appear as a tab link above.');
399
+ console.log('This report will give you more detail about the above the tests aswell as extra tests. ');
400
+ console.groupEnd();
401
+ // #endregion
402
+
403
+ console.log("%cImage sizes","font-size: 16px;font-weight:bold;");
404
+ console.log("The below tests work from the current screen size, so if you have your screen at a mobile viewport the scaling and sizes of images will reflect that. It is worth running the image tests in both mobile and desktop views. Simply change the screen size and refresh the page.");
405
+
406
+ Array.from(document.querySelectorAll('img')).forEach((imgElem, index) => {
407
+
408
+ if(!imgElem.matches("[src*='http']") && !imgElem.matches("[src$='.svg']")){
409
+
410
+ let src = imgElem.getAttribute('src');
411
+
412
+ var xhr = new XMLHttpRequest();
413
+ xhr.open('HEAD', src, true);
414
+ xhr.onreadystatechange = function(){
415
+ if (xhr.readyState == 4) {
416
+ if (xhr.status == 200){
417
+ var imgFSize = xhr.getResponseHeader('Content-Length');
418
+ if (imgFSize > 1024){ //ignore images under 1Kb
419
+ var imgW = imgElem.naturalWidth;
420
+ var imgH = imgElem.naturalHeight;
421
+ var imgW2 = imgElem.clientWidth;
422
+ var imgH2 = imgElem.clientHeight;
423
+ var imgScl = (imgW2/imgW).toFixed(2) == "0.00" ? "Hidden" : (imgW2/imgW).toFixed(2);
424
+ var imgFSize2 = Math.floor(imgFSize/1024);
425
+ var imgBPP = (imgFSize/(imgW*imgH)).toFixed(2);
426
+ var cssColor = "green";
427
+ var bppColor = "green";
428
+ var scaleColor = "green";
429
+
430
+ var bppError = "";
431
+ var scaleError = "";
432
+
433
+
434
+ if (imgBPP > 0.5){
435
+ cssColor = "red";
436
+ bppColor = "red";
437
+ bppError = "The image has a VERY large \'Bytes per pixel\' score, trying optimising the image using https://tinypng.com/.";
438
+ }
439
+ else if (imgBPP > 0.2){
440
+ cssColor = "orange";
441
+ bppColor = "orange";
442
+ bppError = "The image has a large \'Bytes per pixel\' score, trying optimising the image using https://tinypng.com/.";
443
+ }
444
+
445
+ if (imgScl > 1.2){
446
+ cssColor = "red";
447
+ scaleColor = "red";
448
+ scaleError = "The image size is smaller than the size shown on screen this may cause the image to appear blurry and low quality.";
449
+ }
450
+ else if (imgScl < 0.5){
451
+ cssColor = "red";
452
+ scaleColor = "red";
453
+ scaleError = "The image size is VERY large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software.";
454
+ }
455
+ else if (imgScl < 0.8){
456
+ cssColor = "orange";
457
+ scaleColor = "orange";
458
+ scaleError = "The image size is large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software.";
459
+ }
460
+
461
+ console.log("%c %c "+imgElem.src,'background: url('+imgElem.src+'); border: 3px solid '+cssColor+'; line-height: 30px; width: 30px; background-size: cover;', 'background-color: transparent');
462
+
463
+ if(bppError != ""){
464
+ console.log('%c %c'+bppError , 'background-color: ' + bppColor + '; margin-right: 10px', 'background-color: transparent');
465
+ }
466
+ if(scaleError != ""){
467
+ console.log('%c %c'+scaleError , 'background-color: ' + scaleColor + '; margin-right: 10px', 'background-color: transparent');
468
+ }
469
+
470
+ console.table({
471
+ Image: {"Dimensions": imgW + "x" + imgH, "Scaled to": imgW2 + "x" + imgH2, "Scale": imgScl, "Filesize": imgFSize2 + "Kb", "Bytes per pixel": imgBPP}
472
+ });
473
+
474
+ console.groupEnd();
475
+ }
476
+ }
477
+ else {
478
+ console.log('%c %c'+imgElem.src+' not loaded' , 'background-color: red; margin-right: 10px', 'background-color: transparent');
479
+ }
480
+ }
481
+ };
482
+ xhr.send(null);
483
+
484
+
485
+ }
486
+ });
487
+
488
+ // Add to dom here
489
+ let integrationTestsArr = [];
490
+ if(typeof window.integrationTests != "undefined"){
491
+
492
+ window.integrationTests.forEach(function(entry) {
493
+ if(entry['Total'] != 0 && entry['Type'] != "warning" ){
494
+ integrationTestsArr.push(entry['Test']);
495
+ }
496
+ });
497
+ }
498
+
499
+ if (integrationTestsArr.length != 0) {
500
+
501
+ let displayComp = document.querySelector('#vmtests-display');
502
+
503
+ if(displayComp != null){
504
+
505
+ displayComp.innerHTML = `<div class="container">
506
+ <h2>Integration notes</h2>
507
+ <ul id="integrationTests"></ul>
508
+ </div>`;
509
+
510
+ let integrationTests = document.getElementById('integrationTests');
511
+
512
+ if(integrationTests != null){
513
+
514
+ integrationTestsArr.forEach(function(test) {
515
+
516
+ integrationTests.innerHTML += '<li>'+test+'</li>';
517
+
518
+ });
519
+ }
520
+ }
521
+ }
522
+
523
+ return null
524
+ }
525
+
526
526
  export default integrationTests;