@worksafevictoria/wcl7.5 1.1.0-beta.7 → 1.1.0-beta.70

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 (311) hide show
  1. package/.env +1 -3
  2. package/.storybook/preview.js +2 -2
  3. package/README.md +4 -4
  4. package/ci/build/build_validation.yml +2 -2
  5. package/ci/release/beta.yml +4 -3
  6. package/ci/release/master.yml +4 -3
  7. package/jest.config.js +10 -8
  8. package/lib/utility.js +1 -1
  9. package/package.json +13 -12
  10. package/src/assets/icons/AppFooter/x-ws-footer.svg +10 -0
  11. package/src/assets/icons/AppFooter/x-ww-footer.svg +28 -0
  12. package/src/assets/icons/SocialShare/x-icon-white.svg +28 -0
  13. package/src/assets/icons/WSV-reversed.svg +20 -0
  14. package/src/assets/icons/contrast.svg +4 -0
  15. package/src/assets/icons/lang.svg +13 -0
  16. package/src/assets/icons/login.svg +4 -0
  17. package/src/components/Common/CardGrid/cardgrid.stories.js +4 -57
  18. package/src/components/Common/CardGrid/index.vue +23 -3
  19. package/src/components/Common/CardGridItem/card-grid-item-icon.vue +1 -1
  20. package/src/components/Common/CardGridItem/index.vue +21 -5
  21. package/src/components/Containers/Carousel/index.stories.js +30 -0
  22. package/src/components/Containers/Carousel/index.vue +165 -0
  23. package/src/components/Containers/HomepageHeader/index.vue +26 -12
  24. package/src/components/Containers/HomepageHeaderNew/index.stories.js +75 -0
  25. package/src/components/Containers/HomepageHeaderNew/index.vue +198 -0
  26. package/src/components/Containers/SectionGroup/index.vue +4 -4
  27. package/src/components/Containers/Subheader/index.vue +25 -19
  28. package/src/components/Global/AlertStrip/index.stories.js +1 -0
  29. package/src/components/Global/AppFooter/FooterSocialShare/index.vue +1 -1
  30. package/src/components/Global/AppFooter/index.stories.js +1 -0
  31. package/src/components/Global/AppFooter/index.vue +30 -28
  32. package/src/components/Global/AppHeader/index.vue +49 -52
  33. package/src/components/Global/AppHeaderNew/ModalSearch/index.vue +71 -0
  34. package/src/components/Global/AppHeaderNew/ModalSearch/styles.scss +43 -0
  35. package/src/components/Global/AppHeaderNew/includes.scss +71 -0
  36. package/src/components/Global/AppHeaderNew/index.stories.js +74 -0
  37. package/src/components/Global/AppHeaderNew/index.vue +1176 -0
  38. package/src/components/Global/AppHeaderNew/mobile.scss +269 -0
  39. package/src/components/Global/AppHeaderNew/styles.scss +647 -0
  40. package/src/components/Global/ContrastMode/index.stories.js +1 -0
  41. package/src/components/Global/ContrastMode/index.vue +1 -1
  42. package/src/components/Global/Cookies/index.vue +141 -141
  43. package/src/components/Global/DirectoryFilters/SingleTaxonomy/index.vue +2 -1
  44. package/src/components/Global/GlobalNotice/index.stories.js +7 -1
  45. package/src/components/Global/GlobalNotice/index.vue +23 -2
  46. package/src/components/Global/HeroHeader/index.stories.js +3 -4
  47. package/src/components/Global/HeroHeader/index.vue +28 -29
  48. package/src/components/Global/ProgressBar/index.stories.js +6 -16
  49. package/src/components/Global/SocialShare/index.vue +3 -2
  50. package/src/components/Global/Strip/index.stories.js +1 -17
  51. package/src/components/Global/Strip/index.vue +8 -4
  52. package/src/components/Paragraphs/Accordion/AccordionItem/index.vue +21 -17
  53. package/src/components/Paragraphs/Accordion/index.stories.js +1 -0
  54. package/src/components/Paragraphs/Breakout/index.stories.js +1 -0
  55. package/src/components/Paragraphs/BrowseContent/index.stories.js +1 -0
  56. package/src/components/Paragraphs/BrowseContent/index.vue +42 -31
  57. package/src/components/Paragraphs/Calculator/Constants.js +2 -2
  58. package/src/components/Paragraphs/Calculator/index.stories.js +1 -0
  59. package/src/components/Paragraphs/Directory/Records/CJ/index.vue +3 -3
  60. package/src/components/Paragraphs/Directory/Records/ISP/index.vue +5 -5
  61. package/src/components/Paragraphs/Directory/Records/PRS/index.vue +2 -2
  62. package/src/components/Paragraphs/Directory/Records/PRS/recordContent.vue +3 -3
  63. package/src/components/Paragraphs/Directory/Records/PRS/recordDetails.vue +3 -3
  64. package/src/components/Paragraphs/Directory/Records/index.vue +3 -3
  65. package/src/components/Paragraphs/Directory/index.vue +42 -31
  66. package/src/components/Paragraphs/ListGroup/Link/list-link.stories.js +35 -39
  67. package/src/components/Paragraphs/ListGroup/index.vue +55 -46
  68. package/src/components/Paragraphs/ListGroup/list-group.stories.js +35 -31
  69. package/src/components/Paragraphs/ListGroup/navigation-card.stories.js +34 -30
  70. package/src/components/Paragraphs/MarketingBanner/index.stories.js +4 -18
  71. package/src/components/Paragraphs/ProofPoints/index.stories.js +19 -20
  72. package/src/components/Paragraphs/RelatedInformation/index.stories.js +11 -21
  73. package/src/components/Paragraphs/RelatedInformation/index.vue +12 -6
  74. package/src/components/Paragraphs/RelatedInformation/styles.scss +1 -3
  75. package/src/components/Paragraphs/RichText/index.stories.js +2 -1
  76. package/src/components/Paragraphs/ScrollSpy/index.stories.js +20 -26
  77. package/src/components/Paragraphs/ScrollSpy/index.vue +27 -12
  78. package/src/components/Paragraphs/SelectableCards/Control/index.stories.js +1 -0
  79. package/src/components/Paragraphs/SelectableCards/index.vue +15 -12
  80. package/src/components/Paragraphs/Statistics/index.stories.js +1 -0
  81. package/src/components/Paragraphs/Statistics/index.vue +1 -0
  82. package/src/components/Paragraphs/TabbedCards/index.stories.js +8 -27
  83. package/src/components/Paragraphs/TabbedCards/index.vue +58 -92
  84. package/src/components/Paragraphs/Tabs/index.stories.js +1 -0
  85. package/src/components/Paragraphs/TabulatedData/index.stories.js +6 -5
  86. package/src/components/Paragraphs/TabulatedData/index.vue +63 -35
  87. package/src/components/Paragraphs/TaskFinder/index.stories.js +9 -32
  88. package/src/components/Paragraphs/TaskFinder/index.vue +3 -3
  89. package/src/components/Paragraphs/TaskFinder/pdf/index.vue +1 -1
  90. package/src/components/Paragraphs/TaskFinder/task-finder-column.vue +1 -1
  91. package/src/components/Paragraphs/TextMedia/index.stories.js +1 -0
  92. package/src/components/Paragraphs/TextMedia/index.vue +5 -1
  93. package/src/components/Paragraphs/VideoGrid/index.stories.js +1 -0
  94. package/src/components/Paragraphs/VideoPlayer/index.stories.js +1 -13
  95. package/src/components/Paragraphs/Webform/index.stories.js +94 -57
  96. package/src/components/Paragraphs/Webform/index.vue +11 -8
  97. package/src/components/SubComponents/Breadcrumb/index.stories.js +3 -11
  98. package/src/components/SubComponents/CardGroup/index.stories.js +1 -30
  99. package/src/components/SubComponents/CardGroup/index.vue +33 -27
  100. package/src/components/SubComponents/CtaButton/index.stories.js +1 -24
  101. package/src/components/SubComponents/CtaButton/index.vue +27 -25
  102. package/src/components/SubComponents/FormAddressPostcode/index.stories.js +3 -28
  103. package/src/components/SubComponents/FormInstance/components/alert/index.vue +129 -0
  104. package/src/components/SubComponents/FormInstance/components/custom/base-formio.js +77 -0
  105. package/src/components/SubComponents/FormInstance/components/custom/code-formio.js +35 -0
  106. package/src/components/SubComponents/FormInstance/components/custom/custom-formio-registry.js +30 -0
  107. package/src/components/SubComponents/FormInstance/components/custom/range-formio.js +121 -0
  108. package/src/components/SubComponents/FormInstance/components/custom/rating-formio.js +121 -0
  109. package/src/components/SubComponents/FormInstance/components/custom/scale-formio.js +99 -0
  110. package/src/components/SubComponents/FormInstance/components/custom/tableselect-formio.js +200 -0
  111. package/src/components/SubComponents/FormInstance/components/handler/index.vue +208 -0
  112. package/src/components/SubComponents/FormInstance/components/renderer/index.vue +282 -0
  113. package/src/components/SubComponents/FormInstance/index.test.js +65 -0
  114. package/src/components/SubComponents/FormInstance/index.vue +55 -6
  115. package/src/components/SubComponents/FormInstance/models/base-form-element.js +338 -0
  116. package/src/components/SubComponents/FormInstance/models/form-callback-queue.js +45 -0
  117. package/src/components/SubComponents/FormInstance/models/form-utils.js +50 -0
  118. package/src/components/SubComponents/FormInstance/models/overrides/address.js +141 -0
  119. package/src/components/SubComponents/FormInstance/models/overrides/autocomplete.js +41 -0
  120. package/src/components/SubComponents/FormInstance/models/overrides/checkbox.js +14 -0
  121. package/src/components/SubComponents/FormInstance/models/overrides/checkboxes.js +49 -0
  122. package/src/components/SubComponents/FormInstance/models/overrides/code.js +27 -0
  123. package/src/components/SubComponents/FormInstance/models/overrides/composite.js +57 -0
  124. package/src/components/SubComponents/FormInstance/models/overrides/container.js +65 -0
  125. package/src/components/SubComponents/FormInstance/models/overrides/currency.js +17 -0
  126. package/src/components/SubComponents/FormInstance/models/overrides/customcomposite.js +41 -0
  127. package/src/components/SubComponents/FormInstance/models/overrides/date.js +126 -0
  128. package/src/components/SubComponents/FormInstance/models/overrides/datelist.js +73 -0
  129. package/src/components/SubComponents/FormInstance/models/overrides/detail.js +38 -0
  130. package/src/components/SubComponents/FormInstance/models/overrides/email-confirm.js +12 -0
  131. package/src/components/SubComponents/FormInstance/models/overrides/email.js +7 -0
  132. package/src/components/SubComponents/FormInstance/models/overrides/file.js +56 -0
  133. package/src/components/SubComponents/FormInstance/models/overrides/flexbox.js +33 -0
  134. package/src/components/SubComponents/FormInstance/models/overrides/hidden.js +24 -0
  135. package/src/components/SubComponents/FormInstance/models/overrides/likert.js +40 -0
  136. package/src/components/SubComponents/FormInstance/models/overrides/markup.js +47 -0
  137. package/src/components/SubComponents/FormInstance/models/overrides/message.js +53 -0
  138. package/src/components/SubComponents/FormInstance/models/overrides/moretext.js +64 -0
  139. package/src/components/SubComponents/FormInstance/models/overrides/multiple.js +51 -0
  140. package/src/components/SubComponents/FormInstance/models/overrides/number.js +22 -0
  141. package/src/components/SubComponents/FormInstance/models/overrides/options-other.js +34 -0
  142. package/src/components/SubComponents/FormInstance/models/overrides/page.js +7 -0
  143. package/src/components/SubComponents/FormInstance/models/overrides/phonenumber.js +13 -0
  144. package/src/components/SubComponents/FormInstance/models/overrides/radio.js +31 -0
  145. package/src/components/SubComponents/FormInstance/models/overrides/range.js +19 -0
  146. package/src/components/SubComponents/FormInstance/models/overrides/rating.js +47 -0
  147. package/src/components/SubComponents/FormInstance/models/overrides/scale.js +33 -0
  148. package/src/components/SubComponents/FormInstance/models/overrides/section.js +39 -0
  149. package/src/components/SubComponents/FormInstance/models/overrides/select.js +28 -0
  150. package/src/components/SubComponents/FormInstance/models/overrides/signature.js +7 -0
  151. package/src/components/SubComponents/FormInstance/models/overrides/submit.js +23 -0
  152. package/src/components/SubComponents/FormInstance/models/overrides/table.js +48 -0
  153. package/src/components/SubComponents/FormInstance/models/overrides/tablerow.js +20 -0
  154. package/src/components/SubComponents/FormInstance/models/overrides/tableselect.js +66 -0
  155. package/src/components/SubComponents/FormInstance/models/overrides/testing.js +47 -0
  156. package/src/components/SubComponents/FormInstance/models/overrides/text.js +7 -0
  157. package/src/components/SubComponents/FormInstance/models/overrides/textarea.js +26 -0
  158. package/src/components/SubComponents/FormInstance/models/overrides/textformat.js +13 -0
  159. package/src/components/SubComponents/FormInstance/models/overrides/time.js +13 -0
  160. package/src/components/SubComponents/FormInstance/models/overrides/twig.js +118 -0
  161. package/src/components/SubComponents/FormInstance/models/overrides/unknown.js +24 -0
  162. package/src/components/SubComponents/FormInstance/models/overrides/url.js +13 -0
  163. package/src/components/SubComponents/FormInstance/services/convert-form-element.js +49 -0
  164. package/src/components/SubComponents/FormInstance/services/form-api.js +47 -0
  165. package/src/components/SubComponents/FormInstance/services/form-render-parser.js +156 -0
  166. package/src/components/SubComponents/FormInstance/services/form-submit-parser.js +61 -0
  167. package/src/components/SubComponents/FormInstance/services/logic-linker.js +73 -0
  168. package/src/components/SubComponents/FormInstance/services/logic-parser.js +173 -0
  169. package/src/components/SubComponents/FormInstance/services/registry-factory.js +284 -0
  170. package/src/components/SubComponents/FormInstance/stories/Documentation.mdx +234 -0
  171. package/src/components/SubComponents/FormInstance/stories/advanced.stories.js +109 -0
  172. package/src/components/SubComponents/FormInstance/stories/basic.stories.js +73 -0
  173. package/src/components/SubComponents/FormInstance/stories/build.stories.js +27 -0
  174. package/src/components/SubComponents/FormInstance/stories/composite.stories.js +90 -0
  175. package/src/components/SubComponents/FormInstance/stories/condition.stories.js +83 -0
  176. package/src/components/SubComponents/FormInstance/stories/custom.stories.js +69 -0
  177. package/src/components/SubComponents/FormInstance/stories/date.stories.js +76 -0
  178. package/src/components/SubComponents/FormInstance/stories/fileupload.stories.js +57 -0
  179. package/src/components/SubComponents/FormInstance/stories/form-alert.stories.js +93 -0
  180. package/src/components/SubComponents/FormInstance/stories/index.stories.js +63 -0
  181. package/src/components/SubComponents/FormInstance/stories/layout.stories.js +85 -0
  182. package/src/components/SubComponents/FormInstance/stories/markup.stories.js +91 -0
  183. package/src/components/SubComponents/FormInstance/stories/mocks/address.json +298 -0
  184. package/src/components/SubComponents/FormInstance/stories/mocks/advancedhtml.json +23 -0
  185. package/src/components/SubComponents/FormInstance/stories/mocks/autocomplete.json +34 -0
  186. package/src/components/SubComponents/FormInstance/stories/mocks/basichtml.json +15 -0
  187. package/src/components/SubComponents/FormInstance/stories/mocks/checkboxes.json +102 -0
  188. package/src/components/SubComponents/FormInstance/stories/mocks/checkboxesother.json +197 -0
  189. package/src/components/SubComponents/FormInstance/stories/mocks/container.json +134 -0
  190. package/src/components/SubComponents/FormInstance/stories/mocks/customcomposite.json +469 -0
  191. package/src/components/SubComponents/FormInstance/stories/mocks/date.json +19 -0
  192. package/src/components/SubComponents/FormInstance/stories/mocks/datelist.json +752 -0
  193. package/src/components/SubComponents/FormInstance/stories/mocks/datetime.json +89 -0
  194. package/src/components/SubComponents/FormInstance/stories/mocks/details.json +63 -0
  195. package/src/components/SubComponents/FormInstance/stories/mocks/email.json +18 -0
  196. package/src/components/SubComponents/FormInstance/stories/mocks/emailconfirm.json +110 -0
  197. package/src/components/SubComponents/FormInstance/stories/mocks/fieldset.json +62 -0
  198. package/src/components/SubComponents/FormInstance/stories/mocks/fileupload.json +25 -0
  199. package/src/components/SubComponents/FormInstance/stories/mocks/flexbox.json +58 -0
  200. package/src/components/SubComponents/FormInstance/stories/mocks/hidden.json +35 -0
  201. package/src/components/SubComponents/FormInstance/stories/mocks/horizontalrule.json +14 -0
  202. package/src/components/SubComponents/FormInstance/stories/mocks/jahd.json +1359 -0
  203. package/src/components/SubComponents/FormInstance/stories/mocks/label.json +14 -0
  204. package/src/components/SubComponents/FormInstance/stories/mocks/likert.json +375 -0
  205. package/src/components/SubComponents/FormInstance/stories/mocks/message.json +86 -0
  206. package/src/components/SubComponents/FormInstance/stories/mocks/more.json +19 -0
  207. package/src/components/SubComponents/FormInstance/stories/mocks/multiple.json +142 -0
  208. package/src/components/SubComponents/FormInstance/stories/mocks/number.json +35 -0
  209. package/src/components/SubComponents/FormInstance/stories/mocks/quad.json +249 -0
  210. package/src/components/SubComponents/FormInstance/stories/mocks/radios.json +70 -0
  211. package/src/components/SubComponents/FormInstance/stories/mocks/radiosother.json +176 -0
  212. package/src/components/SubComponents/FormInstance/stories/mocks/range.json +58 -0
  213. package/src/components/SubComponents/FormInstance/stories/mocks/rating.json +42 -0
  214. package/src/components/SubComponents/FormInstance/stories/mocks/rule-disabled-value.json +66 -0
  215. package/src/components/SubComponents/FormInstance/stories/mocks/rule-enabled-value.json +43 -0
  216. package/src/components/SubComponents/FormInstance/stories/mocks/rule-hidden-value.json +68 -0
  217. package/src/components/SubComponents/FormInstance/stories/mocks/rule-required-value.json +69 -0
  218. package/src/components/SubComponents/FormInstance/stories/mocks/rule-visible-value.json +157 -0
  219. package/src/components/SubComponents/FormInstance/stories/mocks/sameas.json +66 -0
  220. package/src/components/SubComponents/FormInstance/stories/mocks/scale.json +200 -0
  221. package/src/components/SubComponents/FormInstance/stories/mocks/section.json +63 -0
  222. package/src/components/SubComponents/FormInstance/stories/mocks/select.json +41 -0
  223. package/src/components/SubComponents/FormInstance/stories/mocks/selectother.json +115 -0
  224. package/src/components/SubComponents/FormInstance/stories/mocks/signature.json +25 -0
  225. package/src/components/SubComponents/FormInstance/stories/mocks/styles.json +81 -0
  226. package/src/components/SubComponents/FormInstance/stories/mocks/table-select.json +472 -0
  227. package/src/components/SubComponents/FormInstance/stories/mocks/table.json +154 -0
  228. package/src/components/SubComponents/FormInstance/stories/mocks/telephone.json +18 -0
  229. package/src/components/SubComponents/FormInstance/stories/mocks/textarea.json +22 -0
  230. package/src/components/SubComponents/FormInstance/stories/mocks/textfield.json +66 -0
  231. package/src/components/SubComponents/FormInstance/stories/mocks/time.json +20 -0
  232. package/src/components/SubComponents/FormInstance/stories/mocks/token.json +260 -0
  233. package/src/components/SubComponents/FormInstance/stories/mocks/twig.json +154 -0
  234. package/src/components/SubComponents/FormInstance/stories/mocks/url.json +18 -0
  235. package/src/components/SubComponents/FormInstance/stories/mocks/value.json +17 -0
  236. package/src/components/SubComponents/FormInstance/stories/mocks/wizard.json +353 -0
  237. package/src/components/SubComponents/FormInstance/stories/options.stories.js +98 -0
  238. package/src/components/SubComponents/FormInstance/stories/style.stories.js +55 -0
  239. package/src/components/SubComponents/FormInstance/stories/wizard.stories.js +55 -0
  240. package/src/components/SubComponents/FormInstance/style.scss +185 -0
  241. package/src/components/SubComponents/FormInstance/tests/address.test.js +255 -0
  242. package/src/components/SubComponents/FormInstance/tests/advancedhtml.test.js +31 -0
  243. package/src/components/SubComponents/FormInstance/tests/autocomplete.test.js +38 -0
  244. package/src/components/SubComponents/FormInstance/tests/basichtml.test.js +31 -0
  245. package/src/components/SubComponents/FormInstance/tests/checkbox.test.js +29 -0
  246. package/src/components/SubComponents/FormInstance/tests/checkboxes.test.js +44 -0
  247. package/src/components/SubComponents/FormInstance/tests/checkboxesother.test.js +91 -0
  248. package/src/components/SubComponents/FormInstance/tests/container.test.js +66 -0
  249. package/src/components/SubComponents/FormInstance/tests/customcomposite.test.js +86 -0
  250. package/src/components/SubComponents/FormInstance/tests/date.test.js +63 -0
  251. package/src/components/SubComponents/FormInstance/tests/datelist.test.js +136 -0
  252. package/src/components/SubComponents/FormInstance/tests/datetime.test.js +54 -0
  253. package/src/components/SubComponents/FormInstance/tests/details.test.js +58 -0
  254. package/src/components/SubComponents/FormInstance/tests/email.test.js +28 -0
  255. package/src/components/SubComponents/FormInstance/tests/emailconfirm.test.js +79 -0
  256. package/src/components/SubComponents/FormInstance/tests/fieldset.test.js +63 -0
  257. package/src/components/SubComponents/FormInstance/tests/flexbox.test.js +71 -0
  258. package/src/components/SubComponents/FormInstance/tests/form-test-utils.js +120 -0
  259. package/src/components/SubComponents/FormInstance/tests/form.test.js +26 -0
  260. package/src/components/SubComponents/FormInstance/tests/hidden.test.js +52 -0
  261. package/src/components/SubComponents/FormInstance/tests/horizontalrule.test.js +31 -0
  262. package/src/components/SubComponents/FormInstance/tests/label.test.js +31 -0
  263. package/src/components/SubComponents/FormInstance/tests/likert.test.js +38 -0
  264. package/src/components/SubComponents/FormInstance/tests/message.test.js +89 -0
  265. package/src/components/SubComponents/FormInstance/tests/more.test.js +32 -0
  266. package/src/components/SubComponents/FormInstance/tests/multiple.test.js +71 -0
  267. package/src/components/SubComponents/FormInstance/tests/number.test.js +51 -0
  268. package/src/components/SubComponents/FormInstance/tests/radios.test.js +34 -0
  269. package/src/components/SubComponents/FormInstance/tests/radiosother.test.js +79 -0
  270. package/src/components/SubComponents/FormInstance/tests/range.test.js +32 -0
  271. package/src/components/SubComponents/FormInstance/tests/rating.test.js +38 -0
  272. package/src/components/SubComponents/FormInstance/tests/rule-disabled.test.js +128 -0
  273. package/src/components/SubComponents/FormInstance/tests/rule-enabled-value.test.js +78 -0
  274. package/src/components/SubComponents/FormInstance/tests/rule-hidden.test.js +131 -0
  275. package/src/components/SubComponents/FormInstance/tests/rule-required-value.test.js +144 -0
  276. package/src/components/SubComponents/FormInstance/tests/rule-visible.test.js +619 -0
  277. package/src/components/SubComponents/FormInstance/tests/sameas.test.js +94 -0
  278. package/src/components/SubComponents/FormInstance/tests/scale.test.js +43 -0
  279. package/src/components/SubComponents/FormInstance/tests/section.test.js +63 -0
  280. package/src/components/SubComponents/FormInstance/tests/select.test.js +45 -0
  281. package/src/components/SubComponents/FormInstance/tests/selectother.test.js +82 -0
  282. package/src/components/SubComponents/FormInstance/tests/signature.test.js +32 -0
  283. package/src/components/SubComponents/FormInstance/tests/styles.test.js +73 -0
  284. package/src/components/SubComponents/FormInstance/tests/table-select.test.js +93 -0
  285. package/src/components/SubComponents/FormInstance/tests/table.test.js +97 -0
  286. package/src/components/SubComponents/FormInstance/tests/telephone.test.js +29 -0
  287. package/src/components/SubComponents/FormInstance/tests/textarea.test.js +29 -0
  288. package/src/components/SubComponents/FormInstance/tests/textfield.test.js +48 -0
  289. package/src/components/SubComponents/FormInstance/tests/time.test.js +29 -0
  290. package/src/components/SubComponents/FormInstance/tests/token.test.js +33 -0
  291. package/src/components/SubComponents/FormInstance/tests/twig.test.js +74 -0
  292. package/src/components/SubComponents/FormInstance/tests/url.test.js +45 -0
  293. package/src/components/SubComponents/FormInstance/tests/value.test.js +31 -0
  294. package/src/components/SubComponents/FormInstance/tests/wizard.test.js +145 -0
  295. package/src/components/SubComponents/Icon/index.stories.js +1 -6
  296. package/src/components/SubComponents/MediaPlayer/index.stories.js +1 -6
  297. package/src/components/SubComponents/Pagination/index.stories.js +3 -8
  298. package/src/components/SubComponents/ResourceGroup/List/index.stories.js +3 -2
  299. package/src/components/SubComponents/ResourceGroup/index.vue +206 -173
  300. package/src/components/SubComponents/Search/index.vue +4 -4
  301. package/src/components/SubComponents/SingleImage/index.stories.js +2 -16
  302. package/src/components/SubComponents/VideoThumbnail/index.stories.js +1 -0
  303. package/src/components/SubComponents/VideoThumbnail/index.vue +4 -7
  304. package/src/includes/scss/mixins/src/grid.scss +4 -2
  305. package/src/includes/scss/mixins/src/units.scss +25 -4
  306. package/src/main.js +2 -10
  307. package/src/mock/app-header-new.js +715 -0
  308. package/src/mock/carousel-items.js +57 -0
  309. package/src/mock/jest.fileMock.js +1 -0
  310. package/vite.config.js +28 -15
  311. package/src/components/SubComponents/FormInstance/index.stories.js +0 -8
@@ -0,0 +1,619 @@
1
+ import json from '../stories/mocks/rule-visible-value.json'
2
+ import { FormTestUtils } from './form-test-utils'
3
+
4
+ const testComponent = 'rule-visible'
5
+ describe(`Form ${testComponent} parser`, () => {
6
+ it(`should render a ${testComponent} component`, () => {
7
+ const components = FormTestUtils.getParsedComponentsFromJSON(json)
8
+ console.log(components)
9
+ console.log(
10
+ FormTestUtils.getComparisonJSON([
11
+ {
12
+ attributes: { counter: 1 },
13
+ clearOnHide: true,
14
+ customClass: 'custom-formio-1',
15
+ disabled: false,
16
+ hideLabel: false,
17
+ id: 'kitchen_sink_formio_v1--textbox1',
18
+ input: true,
19
+ key: 'textbox1',
20
+ label: 'textbox1',
21
+ labelPosition: 'top',
22
+ mask: false,
23
+ placeholder:
24
+ "type 'show' to show textfield2 and hide container with textbox",
25
+ type: 'textfield',
26
+ validate: { maxLength: 255, required: false }
27
+ },
28
+ {
29
+ attributes: { counter: 2 },
30
+ clearOnHide: true,
31
+ customClass: 'custom-formio-2',
32
+ disabled: false,
33
+ hidden: true,
34
+ hideLabel: false,
35
+ id: 'kitchen_sink_formio_v1--textbox2',
36
+ input: true,
37
+ key: 'textbox2',
38
+ label: 'textfield2',
39
+ labelPosition: 'top',
40
+ logic: [
41
+ {
42
+ actions: [
43
+ {
44
+ name: 0,
45
+ property: { label: 0, type: 'boolean', value: 'hidden' },
46
+ state: false,
47
+ type: 'property'
48
+ }
49
+ ],
50
+ defaultProps: { hidden: true },
51
+ name: 0,
52
+ trigger: {
53
+ javascript: "result = (Boolean(data.textbox1 === 'show'))",
54
+ type: 'javascript'
55
+ }
56
+ },
57
+ {
58
+ actions: [
59
+ {
60
+ name: 0,
61
+ property: { label: 0, type: 'boolean', value: 'hidden' },
62
+ state: false,
63
+ type: 'property'
64
+ }
65
+ ],
66
+ defaultProps: { hidden: true },
67
+ name: 0,
68
+ trigger: {
69
+ javascript: "result = (Boolean(data.textbox1 === 'show'))",
70
+ type: 'javascript'
71
+ }
72
+ }
73
+ ],
74
+ mask: false,
75
+ type: 'textfield',
76
+ validate: { maxLength: 255, required: false }
77
+ },
78
+ {
79
+ attributes: { counter: 3 },
80
+ clearOnHide: true,
81
+ components: [
82
+ {
83
+ attributes: { counter: 7 },
84
+ clearOnHide: false,
85
+ customClass: 'custom-formio-7',
86
+ disabled: false,
87
+ hideLabel: false,
88
+ id: 'kitchen_sink_formio_v1--textboxContainer',
89
+ input: true,
90
+ key: 'textboxContainer',
91
+ label: 'Container textbox',
92
+ labelPosition: 'top',
93
+ mask: false,
94
+ placeholder: 'type anything to show textbox3',
95
+ type: 'textfield',
96
+ validate: { maxLength: 255, required: false }
97
+ }
98
+ ],
99
+ customClass: 'custom-formio-3',
100
+ disabled: false,
101
+ hidden: true,
102
+ hideLabel: true,
103
+ id: 'kitchen_sink_formio_v1--c31',
104
+ input: false,
105
+ key: 'c31',
106
+ label: null,
107
+ labelPosition: 'top',
108
+ logic: [
109
+ {
110
+ actions: [
111
+ {
112
+ name: 0,
113
+ property: { label: 0, type: 'boolean', value: 'hidden' },
114
+ state: false,
115
+ type: 'property'
116
+ }
117
+ ],
118
+ defaultProps: { hidden: true },
119
+ name: 0,
120
+ trigger: {
121
+ javascript: "result = (Boolean(data.textbox1 !== 'show'))",
122
+ type: 'javascript'
123
+ }
124
+ },
125
+ {
126
+ actions: [
127
+ {
128
+ name: 0,
129
+ property: { label: 0, type: 'boolean', value: 'hidden' },
130
+ state: false,
131
+ type: 'property'
132
+ }
133
+ ],
134
+ defaultProps: { hidden: true },
135
+ name: 0,
136
+ trigger: {
137
+ javascript: "result = (Boolean(data.textbox1 !== 'show'))",
138
+ type: 'javascript'
139
+ }
140
+ }
141
+ ],
142
+ mask: false,
143
+ type: 'container',
144
+ validate: {}
145
+ },
146
+ {
147
+ attributes: { counter: 4 },
148
+ clearOnHide: true,
149
+ customClass: 'custom-formio-4',
150
+ disabled: false,
151
+ hidden: true,
152
+ hideLabel: false,
153
+ id: 'kitchen_sink_formio_v1--textbox3',
154
+ input: true,
155
+ key: 'textbox3',
156
+ label: 'textfield3',
157
+ labelPosition: 'top',
158
+ logic: [
159
+ {
160
+ actions: [
161
+ {
162
+ name: 0,
163
+ property: { label: 0, type: 'boolean', value: 'hidden' },
164
+ state: false,
165
+ type: 'property'
166
+ }
167
+ ],
168
+ defaultProps: { hidden: true },
169
+ name: 0,
170
+ trigger: {
171
+ javascript:
172
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
173
+ type: 'javascript'
174
+ }
175
+ },
176
+ {
177
+ actions: [
178
+ {
179
+ name: 0,
180
+ property: { label: 0, type: 'boolean', value: 'hidden' },
181
+ state: false,
182
+ type: 'property'
183
+ }
184
+ ],
185
+ defaultProps: { hidden: true },
186
+ name: 0,
187
+ trigger: {
188
+ javascript:
189
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
190
+ type: 'javascript'
191
+ }
192
+ },
193
+ {
194
+ actions: [
195
+ {
196
+ name: 0,
197
+ property: { label: 0, type: 'boolean', value: 'hidden' },
198
+ state: false,
199
+ type: 'property'
200
+ }
201
+ ],
202
+ defaultProps: { hidden: true },
203
+ name: 0,
204
+ trigger: {
205
+ javascript:
206
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
207
+ type: 'javascript'
208
+ }
209
+ },
210
+ {
211
+ actions: [
212
+ {
213
+ name: 0,
214
+ property: { label: 0, type: 'boolean', value: 'hidden' },
215
+ state: false,
216
+ type: 'property'
217
+ }
218
+ ],
219
+ defaultProps: { hidden: true },
220
+ name: 0,
221
+ trigger: {
222
+ javascript:
223
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
224
+ type: 'javascript'
225
+ }
226
+ }
227
+ ],
228
+ mask: false,
229
+ placeholder: "type a pattern ending with 'text4' to show textbox4",
230
+ type: 'textfield',
231
+ validate: { maxLength: 255, required: false }
232
+ },
233
+ {
234
+ attributes: { counter: 5 },
235
+ clearOnHide: true,
236
+ customClass: 'custom-formio-5',
237
+ disabled: false,
238
+ hidden: true,
239
+ hideLabel: false,
240
+ id: 'kitchen_sink_formio_v1--textbox4',
241
+ input: true,
242
+ key: 'textbox4',
243
+ label: 'textfield4',
244
+ labelPosition: 'top',
245
+ logic: [
246
+ {
247
+ actions: [
248
+ {
249
+ name: 0,
250
+ property: { label: 0, type: 'boolean', value: 'hidden' },
251
+ state: false,
252
+ type: 'property'
253
+ }
254
+ ],
255
+ defaultProps: { hidden: true },
256
+ name: 0,
257
+ trigger: {
258
+ javascript:
259
+ 'result = (Boolean((/text4$/.test(data.textbox1))) || Boolean((/text4$/.test(data.textbox3))))',
260
+ type: 'javascript'
261
+ }
262
+ },
263
+ {
264
+ actions: [
265
+ {
266
+ name: 0,
267
+ property: { label: 0, type: 'boolean', value: 'hidden' },
268
+ state: false,
269
+ type: 'property'
270
+ }
271
+ ],
272
+ defaultProps: { hidden: true },
273
+ name: 0,
274
+ trigger: {
275
+ javascript:
276
+ 'result = (Boolean((/text4$/.test(data.textbox1))) || Boolean((/text4$/.test(data.textbox3))))',
277
+ type: 'javascript'
278
+ }
279
+ },
280
+ {
281
+ actions: [
282
+ {
283
+ name: 0,
284
+ property: { label: 0, type: 'boolean', value: 'hidden' },
285
+ state: false,
286
+ type: 'property'
287
+ }
288
+ ],
289
+ defaultProps: { hidden: true },
290
+ name: 0,
291
+ trigger: {
292
+ javascript:
293
+ 'result = (Boolean((/text4$/.test(data.textbox1))) || Boolean((/text4$/.test(data.textbox3))))',
294
+ type: 'javascript'
295
+ }
296
+ }
297
+ ],
298
+ mask: false,
299
+ type: 'textfield',
300
+ validate: { maxLength: 255, required: false }
301
+ }
302
+ ])
303
+ )
304
+ expect(components).toEqual(
305
+ FormTestUtils.getComparisonJSON([
306
+ {
307
+ attributes: { counter: 1 },
308
+ clearOnHide: true,
309
+ customClass: 'custom-formio-1',
310
+ disabled: false,
311
+ hideLabel: false,
312
+ id: 'kitchen_sink_formio_v1--textbox1',
313
+ input: true,
314
+ key: 'textbox1',
315
+ label: 'textbox1',
316
+ labelPosition: 'top',
317
+ mask: false,
318
+ placeholder:
319
+ "type 'show' to show textfield2 and hide container with textbox",
320
+ type: 'textfield',
321
+ validate: { maxLength: 255, required: false }
322
+ },
323
+ {
324
+ attributes: { counter: 2 },
325
+ clearOnHide: true,
326
+ customClass: 'custom-formio-2',
327
+ disabled: false,
328
+ hidden: true,
329
+ hideLabel: false,
330
+ id: 'kitchen_sink_formio_v1--textbox2',
331
+ input: true,
332
+ key: 'textbox2',
333
+ label: 'textfield2',
334
+ labelPosition: 'top',
335
+ logic: [
336
+ {
337
+ actions: [
338
+ {
339
+ name: 0,
340
+ property: { label: 0, type: 'boolean', value: 'hidden' },
341
+ state: false,
342
+ type: 'property'
343
+ }
344
+ ],
345
+ defaultProps: { hidden: true },
346
+ name: 0,
347
+ trigger: {
348
+ javascript: "result = (Boolean(data.textbox1 === 'show'))",
349
+ type: 'javascript'
350
+ }
351
+ },
352
+ {
353
+ actions: [
354
+ {
355
+ name: 0,
356
+ property: { label: 0, type: 'boolean', value: 'hidden' },
357
+ state: false,
358
+ type: 'property'
359
+ }
360
+ ],
361
+ defaultProps: { hidden: true },
362
+ name: 0,
363
+ trigger: {
364
+ javascript: "result = (Boolean(data.textbox1 === 'show'))",
365
+ type: 'javascript'
366
+ }
367
+ }
368
+ ],
369
+ mask: false,
370
+ type: 'textfield',
371
+ validate: { maxLength: 255, required: false }
372
+ },
373
+ {
374
+ attributes: { counter: 3 },
375
+ clearOnHide: true,
376
+ components: [
377
+ {
378
+ attributes: { counter: 7 },
379
+ clearOnHide: false,
380
+ customClass: 'custom-formio-7',
381
+ disabled: false,
382
+ hideLabel: false,
383
+ id: 'kitchen_sink_formio_v1--textboxContainer',
384
+ input: true,
385
+ key: 'textboxContainer',
386
+ label: 'Container textbox',
387
+ labelPosition: 'top',
388
+ mask: false,
389
+ placeholder: 'type anything to show textbox3',
390
+ type: 'textfield',
391
+ validate: { maxLength: 255, required: false }
392
+ }
393
+ ],
394
+ customClass: 'custom-formio-3',
395
+ disabled: false,
396
+ hidden: true,
397
+ hideLabel: true,
398
+ id: 'kitchen_sink_formio_v1--c31',
399
+ input: false,
400
+ key: 'c31',
401
+ label: null,
402
+ labelPosition: 'top',
403
+ logic: [
404
+ {
405
+ actions: [
406
+ {
407
+ name: 0,
408
+ property: { label: 0, type: 'boolean', value: 'hidden' },
409
+ state: false,
410
+ type: 'property'
411
+ }
412
+ ],
413
+ defaultProps: { hidden: true },
414
+ name: 0,
415
+ trigger: {
416
+ javascript: "result = (Boolean(data.textbox1 !== 'show'))",
417
+ type: 'javascript'
418
+ }
419
+ },
420
+ {
421
+ actions: [
422
+ {
423
+ name: 0,
424
+ property: { label: 0, type: 'boolean', value: 'hidden' },
425
+ state: false,
426
+ type: 'property'
427
+ }
428
+ ],
429
+ defaultProps: { hidden: true },
430
+ name: 0,
431
+ trigger: {
432
+ javascript: "result = (Boolean(data.textbox1 !== 'show'))",
433
+ type: 'javascript'
434
+ }
435
+ }
436
+ ],
437
+ mask: false,
438
+ type: 'container',
439
+ validate: {}
440
+ },
441
+ {
442
+ attributes: { counter: 4 },
443
+ clearOnHide: true,
444
+ customClass: 'custom-formio-4',
445
+ disabled: false,
446
+ hidden: true,
447
+ hideLabel: false,
448
+ id: 'kitchen_sink_formio_v1--textbox3',
449
+ input: true,
450
+ key: 'textbox3',
451
+ label: 'textfield3',
452
+ labelPosition: 'top',
453
+ logic: [
454
+ {
455
+ actions: [
456
+ {
457
+ name: 0,
458
+ property: { label: 0, type: 'boolean', value: 'hidden' },
459
+ state: false,
460
+ type: 'property'
461
+ }
462
+ ],
463
+ defaultProps: { hidden: true },
464
+ name: 0,
465
+ trigger: {
466
+ javascript:
467
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
468
+ type: 'javascript'
469
+ }
470
+ },
471
+ {
472
+ actions: [
473
+ {
474
+ name: 0,
475
+ property: { label: 0, type: 'boolean', value: 'hidden' },
476
+ state: false,
477
+ type: 'property'
478
+ }
479
+ ],
480
+ defaultProps: { hidden: true },
481
+ name: 0,
482
+ trigger: {
483
+ javascript:
484
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
485
+ type: 'javascript'
486
+ }
487
+ },
488
+ {
489
+ actions: [
490
+ {
491
+ name: 0,
492
+ property: { label: 0, type: 'boolean', value: 'hidden' },
493
+ state: false,
494
+ type: 'property'
495
+ }
496
+ ],
497
+ defaultProps: { hidden: true },
498
+ name: 0,
499
+ trigger: {
500
+ javascript:
501
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
502
+ type: 'javascript'
503
+ }
504
+ },
505
+ {
506
+ actions: [
507
+ {
508
+ name: 0,
509
+ property: { label: 0, type: 'boolean', value: 'hidden' },
510
+ state: false,
511
+ type: 'property'
512
+ }
513
+ ],
514
+ defaultProps: { hidden: true },
515
+ name: 0,
516
+ trigger: {
517
+ javascript:
518
+ "result = (Boolean((data.c31.textboxContainer !== null && data.c31.textboxContainer !== undefined && data.c31.textboxContainer !== '')))",
519
+ type: 'javascript'
520
+ }
521
+ }
522
+ ],
523
+ mask: false,
524
+ placeholder: "type a pattern ending with 'text4' to show textbox4",
525
+ type: 'textfield',
526
+ validate: { maxLength: 255, required: false }
527
+ },
528
+ {
529
+ attributes: { counter: 5 },
530
+ clearOnHide: true,
531
+ customClass: 'custom-formio-5',
532
+ disabled: false,
533
+ hidden: true,
534
+ hideLabel: false,
535
+ id: 'kitchen_sink_formio_v1--textbox4',
536
+ input: true,
537
+ key: 'textbox4',
538
+ label: 'textfield4',
539
+ labelPosition: 'top',
540
+ logic: [
541
+ {
542
+ actions: [
543
+ {
544
+ name: 0,
545
+ property: { label: 0, type: 'boolean', value: 'hidden' },
546
+ state: false,
547
+ type: 'property'
548
+ }
549
+ ],
550
+ defaultProps: { hidden: true },
551
+ name: 0,
552
+ trigger: {
553
+ javascript:
554
+ 'result = (Boolean((/text4$/.test(data.textbox1))) || Boolean((/text4$/.test(data.textbox3))))',
555
+ type: 'javascript'
556
+ }
557
+ },
558
+ {
559
+ actions: [
560
+ {
561
+ name: 0,
562
+ property: { label: 0, type: 'boolean', value: 'hidden' },
563
+ state: false,
564
+ type: 'property'
565
+ }
566
+ ],
567
+ defaultProps: { hidden: true },
568
+ name: 0,
569
+ trigger: {
570
+ javascript:
571
+ 'result = (Boolean((/text4$/.test(data.textbox1))) || Boolean((/text4$/.test(data.textbox3))))',
572
+ type: 'javascript'
573
+ }
574
+ },
575
+ {
576
+ actions: [
577
+ {
578
+ name: 0,
579
+ property: { label: 0, type: 'boolean', value: 'hidden' },
580
+ state: false,
581
+ type: 'property'
582
+ }
583
+ ],
584
+ defaultProps: { hidden: true },
585
+ name: 0,
586
+ trigger: {
587
+ javascript:
588
+ 'result = (Boolean((/text4$/.test(data.textbox1))) || Boolean((/text4$/.test(data.textbox3))))',
589
+ type: 'javascript'
590
+ }
591
+ }
592
+ ],
593
+ mask: false,
594
+ type: 'textfield',
595
+ validate: { maxLength: 255, required: false }
596
+ }
597
+ ])
598
+ )
599
+ })
600
+
601
+ it(`should return a submission value`, () => {
602
+ const formioform = FormTestUtils.getParsedFormFromJSON(json)
603
+ const submission = FormTestUtils.getSubmissionValue(
604
+ {
605
+ textbox1: 'asa',
606
+ c31: {
607
+ textboxContainer: 'ssdsd'
608
+ },
609
+ textbox3: 'dsds'
610
+ },
611
+ formioform
612
+ )
613
+ expect(submission).toEqual({
614
+ textbox1: 'asa',
615
+ textboxContainer: 'ssdsd',
616
+ textbox3: 'dsds'
617
+ })
618
+ })
619
+ })
@@ -0,0 +1,94 @@
1
+ import json from '../stories/mocks/sameas.json'
2
+ import { FormTestUtils } from './form-test-utils'
3
+
4
+ const testComponent = 'sameas'
5
+ describe(`Form ${testComponent} parser`, () => {
6
+ it(`should render a ${testComponent} component`, () => {
7
+ const components = FormTestUtils.getParsedComponentsFromJSON(json)
8
+ expect(components).toEqual(
9
+ FormTestUtils.getComparisonJSON([
10
+ {
11
+ attributes: { counter: 1 },
12
+ clearOnHide: true,
13
+ customClass: 'custom-formio-1',
14
+ disabled: false,
15
+ hideLabel: false,
16
+ id: 'kitchen_sink_formio_v1--full_name',
17
+ input: true,
18
+ key: 'full_name',
19
+ label: 'First Name',
20
+ labelPosition: 'top',
21
+ mask: false,
22
+ type: 'textfield',
23
+ validate: { maxLength: 255, required: true }
24
+ },
25
+ {
26
+ attributes: { counter: 2 },
27
+ clearOnHide: false,
28
+ customClass: 'custom-formio-2',
29
+ disabled: false,
30
+ hidden: true,
31
+ hideLabel: false,
32
+ id: 'kitchen_sink_formio_v1--last_name',
33
+ input: true,
34
+ key: 'last_name',
35
+ label: 'Last name',
36
+ labelPosition: 'top',
37
+ logic: [
38
+ {
39
+ actions: [
40
+ {
41
+ name: 0,
42
+ property: { label: 0, type: 'boolean', value: 'hidden' },
43
+ state: false,
44
+ type: 'property'
45
+ }
46
+ ],
47
+ defaultProps: { hidden: true },
48
+ name: 0,
49
+ trigger: {
50
+ javascript: 'result = (Boolean((data.samea === false)))',
51
+ type: 'javascript'
52
+ }
53
+ },
54
+ {
55
+ actions: [
56
+ {
57
+ name: 0,
58
+ property: { label: 0, type: 'boolean', value: 'hidden' },
59
+ state: false,
60
+ type: 'property'
61
+ }
62
+ ],
63
+ defaultProps: { hidden: true },
64
+ name: 0,
65
+ trigger: {
66
+ javascript: 'result = (Boolean((data.samea === false)))',
67
+ type: 'javascript'
68
+ }
69
+ }
70
+ ],
71
+ mask: false,
72
+ type: 'textfield',
73
+ validate: { maxLength: 255, required: false }
74
+ },
75
+ {
76
+ attributes: { counter: 3 },
77
+ clearOnHide: true,
78
+ customClass: 'custom-formio-3',
79
+ defaultValue: 0,
80
+ disabled: false,
81
+ hideLabel: false,
82
+ id: 'kitchen_sink_formio_v1--samea',
83
+ input: true,
84
+ key: 'samea',
85
+ label: 'Is your first name same as last name?',
86
+ labelPosition: 'bottom',
87
+ mask: false,
88
+ type: 'checkbox',
89
+ validate: { required: false }
90
+ }
91
+ ])
92
+ )
93
+ })
94
+ })