@iamproperty/components 7.0.0 → 7.1.0--beta2

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 (411) hide show
  1. package/assets/css/components/actionbar.css.map +1 -1
  2. package/assets/css/components/actionbar.global.css.map +1 -1
  3. package/assets/css/components/address-lookup.css.map +1 -1
  4. package/assets/css/components/applied-filters.css.map +1 -1
  5. package/assets/css/components/barchart.component.css +1 -1
  6. package/assets/css/components/barchart.component.css.map +1 -1
  7. package/assets/css/components/card.component.css +1 -1
  8. package/assets/css/components/card.component.css.map +1 -1
  9. package/assets/css/components/card.module.css.map +1 -1
  10. package/assets/css/components/carousel.component.css +1 -1
  11. package/assets/css/components/carousel.component.css.map +1 -1
  12. package/assets/css/components/carousel.config.css.map +1 -1
  13. package/assets/css/components/charts.config.css.map +1 -1
  14. package/assets/css/components/charts.css +1 -1
  15. package/assets/css/components/charts.css.map +1 -1
  16. package/assets/css/components/charts.module.css +1 -1
  17. package/assets/css/components/charts.module.css.map +1 -1
  18. package/assets/css/components/collapsible-side.css.map +1 -1
  19. package/assets/css/components/fileupload.css.map +1 -1
  20. package/assets/css/components/filter-card.component.css.map +1 -1
  21. package/assets/css/components/header.css.map +1 -1
  22. package/assets/css/components/inline-edit.css.map +1 -1
  23. package/assets/css/components/inline-edit.preload.css.map +1 -1
  24. package/assets/css/components/marketing.css.map +1 -1
  25. package/assets/css/components/multi-step.component.css.map +1 -1
  26. package/assets/css/components/multiselect.css +1 -1
  27. package/assets/css/components/multiselect.css.map +1 -1
  28. package/assets/css/components/multiselect.preload.css.map +1 -1
  29. package/assets/css/components/nav.css +1 -1
  30. package/assets/css/components/nav.css.map +1 -1
  31. package/assets/css/components/nav.docs.css.map +1 -1
  32. package/assets/css/components/nav.global.css +1 -1
  33. package/assets/css/components/nav.global.css.map +1 -1
  34. package/assets/css/components/nav.old.css +1 -1
  35. package/assets/css/components/nav.old.css.map +1 -1
  36. package/assets/css/components/nav.preload.css.map +1 -1
  37. package/assets/css/components/notification.css.map +1 -1
  38. package/assets/css/components/notification.global.css.map +1 -1
  39. package/assets/css/components/pagination.css.map +1 -1
  40. package/assets/css/components/property-searchbar.css +1 -1
  41. package/assets/css/components/property-searchbar.css.map +1 -1
  42. package/assets/css/components/record-card.component.css.map +1 -1
  43. package/assets/css/components/slider.css.map +1 -1
  44. package/assets/css/components/snapshot.css.map +1 -1
  45. package/assets/css/components/stepper.css.map +1 -1
  46. package/assets/css/components/table.css +1 -1
  47. package/assets/css/components/table.css.map +1 -1
  48. package/assets/css/components/table.global.css +1 -1
  49. package/assets/css/components/table.global.css.map +1 -1
  50. package/assets/css/components/tabs.css.map +1 -1
  51. package/assets/css/components/testimonial.css.map +1 -1
  52. package/assets/css/components/timeline.css +1 -1
  53. package/assets/css/components/timeline.css.map +1 -1
  54. package/assets/css/components/video-card.component.css.map +1 -1
  55. package/assets/css/core.min.css +1 -1
  56. package/assets/css/core.min.css.map +1 -1
  57. package/assets/css/style.min.css +1 -1
  58. package/assets/css/style.min.css.map +1 -1
  59. package/assets/js/components/_global.js +8 -8
  60. package/assets/js/components/accordion/accordion.component.js +13 -10
  61. package/assets/js/components/accordion/accordion.component.min.js +4 -4
  62. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  63. package/assets/js/components/actionbar/actionbar.component.js +97 -83
  64. package/assets/js/components/actionbar/actionbar.component.min.js +5 -5
  65. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  66. package/assets/js/components/address-lookup/address-lookup.component.js +30 -26
  67. package/assets/js/components/address-lookup/address-lookup.component.min.js +4 -4
  68. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  69. package/assets/js/components/applied-filters/applied-filters.component.js +10 -6
  70. package/assets/js/components/applied-filters/applied-filters.component.min.js +3 -3
  71. package/assets/js/components/applied-filters/applied-filters.component.min.js.map +1 -1
  72. package/assets/js/components/barchart/barchart.component.js +8 -7
  73. package/assets/js/components/barchart/barchart.component.min.js +4 -4
  74. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  75. package/assets/js/components/card/card.component.js +27 -12
  76. package/assets/js/components/card/card.component.min.js +3 -3
  77. package/assets/js/components/card/card.component.min.js.map +1 -1
  78. package/assets/js/components/carousel/carousel.component.js +18 -12
  79. package/assets/js/components/carousel/carousel.component.min.js +4 -4
  80. package/assets/js/components/carousel/carousel.component.min.js.map +1 -1
  81. package/assets/js/components/chart/chart.component.js +9 -8
  82. package/assets/js/components/collapsible-side/collapsible-side.component.js +20 -8
  83. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  84. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  85. package/assets/js/components/fileupload/fileupload.component.js +11 -7
  86. package/assets/js/components/fileupload/fileupload.component.min.js +2 -2
  87. package/assets/js/components/fileupload/fileupload.component.min.js.map +1 -1
  88. package/assets/js/components/filter-card/filter-card.component.js +19 -9
  89. package/assets/js/components/filter-card/filter-card.component.min.js +2 -2
  90. package/assets/js/components/filter-card/filter-card.component.min.js.map +1 -1
  91. package/assets/js/components/filterlist/filterlist.component.js +10 -6
  92. package/assets/js/components/filterlist/filterlist.component.min.js +3 -3
  93. package/assets/js/components/filterlist/filterlist.component.min.js.map +1 -1
  94. package/assets/js/components/header/header.component.js +8 -4
  95. package/assets/js/components/header/header.component.min.js +1 -1
  96. package/assets/js/components/header/header.component.min.js.map +1 -1
  97. package/assets/js/components/inline-edit/inline-edit.component.js +43 -23
  98. package/assets/js/components/inline-edit/inline-edit.component.min.js +4 -4
  99. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  100. package/assets/js/components/marketing/marketing.component.js +11 -5
  101. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  102. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  103. package/assets/js/components/multi-step/multi-step.component.js +22 -19
  104. package/assets/js/components/multiselect/multiselect.component.js +62 -45
  105. package/assets/js/components/multiselect/multiselect.component.min.js +5 -5
  106. package/assets/js/components/multiselect/multiselect.component.min.js.map +1 -1
  107. package/assets/js/components/nav/nav.component.js +57 -38
  108. package/assets/js/components/nav/nav.component.min.js +5 -5
  109. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  110. package/assets/js/components/notification/notification.component.js +9 -5
  111. package/assets/js/components/notification/notification.component.min.js +5 -5
  112. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  113. package/assets/js/components/pagination/pagination.component.js +18 -14
  114. package/assets/js/components/pagination/pagination.component.min.js +2 -2
  115. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  116. package/assets/js/components/record-card/record-card.component.js +10 -8
  117. package/assets/js/components/record-card/record-card.component.min.js +2 -2
  118. package/assets/js/components/record-card/record-card.component.min.js.map +1 -1
  119. package/assets/js/components/search/search.component.js +22 -17
  120. package/assets/js/components/search/search.component.min.js +4 -4
  121. package/assets/js/components/search/search.component.min.js.map +1 -1
  122. package/assets/js/components/slider/slider.component.js +25 -21
  123. package/assets/js/components/slider/slider.component.min.js +3 -3
  124. package/assets/js/components/slider/slider.component.min.js.map +1 -1
  125. package/assets/js/components/table/table.component.js +30 -24
  126. package/assets/js/components/table/table.component.min.js +7 -7
  127. package/assets/js/components/table/table.component.min.js.map +1 -1
  128. package/assets/js/components/tabs/tabs.component.js +10 -6
  129. package/assets/js/components/tabs/tabs.component.min.js +3 -3
  130. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  131. package/assets/js/components/video-card/video-card.component.js +45 -33
  132. package/assets/js/components/video-card/video-card.component.min.js +3 -3
  133. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  134. package/assets/js/components.bundle.js +1 -1
  135. package/assets/js/components.bundle.js.map +1 -1
  136. package/assets/js/components.js +35 -8
  137. package/assets/js/modules/applied-filters.js +20 -20
  138. package/assets/js/modules/carousel.js +65 -60
  139. package/assets/js/modules/chart.js +184 -134
  140. package/assets/js/modules/chart.module.js +74 -63
  141. package/assets/js/modules/data-layer.js +17 -17
  142. package/assets/js/modules/dialogs.js +47 -38
  143. package/assets/js/modules/drawer.js +1 -1
  144. package/assets/js/modules/dynamicEvents.js +24 -24
  145. package/assets/js/modules/file-upload.js +8 -9
  146. package/assets/js/modules/fileupload.js +5 -5
  147. package/assets/js/modules/filterlist.js +4 -4
  148. package/assets/js/modules/form.js +22 -18
  149. package/assets/js/modules/helpers.js +54 -44
  150. package/assets/js/modules/inputs.js +25 -21
  151. package/assets/js/modules/nav.js +3 -1
  152. package/assets/js/modules/notification.js +6 -6
  153. package/assets/js/modules/orderablelist.js +12 -12
  154. package/assets/js/modules/pagination.js +5 -5
  155. package/assets/js/modules/table.js +242 -181
  156. package/assets/js/modules/tabs.js +71 -60
  157. package/assets/js/modules/testimonial.js +11 -12
  158. package/assets/js/scripts.bundle.js +1 -1
  159. package/assets/js/scripts.bundle.js.map +1 -1
  160. package/assets/js/scripts.bundle.min.js +1 -1
  161. package/assets/js/scripts.bundle.min.js.map +1 -1
  162. package/assets/js/scripts.js +1 -1
  163. package/assets/js/tests/chart.spec.js +5 -5
  164. package/assets/js/tests/filterlist.spec.js +2 -2
  165. package/assets/js/tests/slider.spec.js +2 -2
  166. package/assets/js/tests/table.spec.js +2 -2
  167. package/assets/js/vendor/hibp.js +4 -4
  168. package/assets/sass/_components.scss +28 -40
  169. package/assets/sass/_corefiles.scss +22 -29
  170. package/assets/sass/_elements.scss +19 -19
  171. package/assets/sass/_fonts.scss +10 -7
  172. package/assets/sass/_func.scss +14 -14
  173. package/assets/sass/_functions/functions.scss +115 -90
  174. package/assets/sass/_functions/mixins.scss +72 -112
  175. package/assets/sass/_functions/utilities.scss +447 -393
  176. package/assets/sass/_functions/variables.scss +1357 -1371
  177. package/assets/sass/_print.scss +18 -16
  178. package/assets/sass/_tests/colours.spec.scss +15 -14
  179. package/assets/sass/_tests/func.spec.scss +1 -2
  180. package/assets/sass/_tests/mixins.spec.scss +9 -14
  181. package/assets/sass/_tests/typography.spec.scss +1 -2
  182. package/assets/sass/_utilities.scss +8 -12
  183. package/assets/sass/components/actionbar.global.scss +45 -64
  184. package/assets/sass/components/actionbar.scss +58 -84
  185. package/assets/sass/components/address-lookup.scss +9 -11
  186. package/assets/sass/components/applied-filters.scss +3 -7
  187. package/assets/sass/components/barchart.component.scss +68 -99
  188. package/assets/sass/components/card.component.scss +35 -50
  189. package/assets/sass/components/card.module.scss +34 -37
  190. package/assets/sass/components/carousel.component.scss +198 -177
  191. package/assets/sass/components/carousel.config.scss +13 -19
  192. package/assets/sass/components/charts.config.scss +16 -23
  193. package/assets/sass/components/charts.module.scss +139 -178
  194. package/assets/sass/components/charts.scss +173 -232
  195. package/assets/sass/components/collapsible-side.scss +65 -98
  196. package/assets/sass/components/fileupload.scss +17 -23
  197. package/assets/sass/components/filter-card.component.scss +21 -28
  198. package/assets/sass/components/header.scss +24 -37
  199. package/assets/sass/components/inline-edit.preload.scss +24 -45
  200. package/assets/sass/components/inline-edit.scss +4 -5
  201. package/assets/sass/components/marketing.scss +19 -14
  202. package/assets/sass/components/multi-step.component.scss +36 -42
  203. package/assets/sass/components/multiselect.preload.scss +9 -12
  204. package/assets/sass/components/multiselect.scss +20 -24
  205. package/assets/sass/components/nav.docs.scss +7 -15
  206. package/assets/sass/components/nav.global.scss +123 -177
  207. package/assets/sass/components/nav.old.scss +64 -135
  208. package/assets/sass/components/nav.preload.scss +11 -12
  209. package/assets/sass/components/nav.scss +126 -173
  210. package/assets/sass/components/notification.global.scss +2 -3
  211. package/assets/sass/components/notification.scss +17 -32
  212. package/assets/sass/components/pagination.scss +32 -44
  213. package/assets/sass/components/property-searchbar.scss +2 -6
  214. package/assets/sass/components/record-card.component.scss +42 -55
  215. package/assets/sass/components/slider.scss +38 -35
  216. package/assets/sass/components/snapshot.scss +4 -10
  217. package/assets/sass/components/stepper.scss +14 -22
  218. package/assets/sass/components/table.global.scss +130 -171
  219. package/assets/sass/components/table.scss +17 -27
  220. package/assets/sass/components/tabs.scss +23 -32
  221. package/assets/sass/components/testimonial.scss +6 -14
  222. package/assets/sass/components/timeline.scss +8 -12
  223. package/assets/sass/components/video-card.component.scss +9 -14
  224. package/assets/sass/components.reset.scss +5 -5
  225. package/assets/sass/core.scss +3 -3
  226. package/assets/sass/elements/admin-panel.scss +41 -45
  227. package/assets/sass/elements/badge-tag.scss +16 -26
  228. package/assets/sass/elements/brand.scss +13 -16
  229. package/assets/sass/elements/buttons.scss +80 -106
  230. package/assets/sass/elements/container.scss +24 -133
  231. package/assets/sass/elements/details.scss +30 -50
  232. package/assets/sass/elements/dialog.scss +4 -6
  233. package/assets/sass/elements/forms.scss +421 -437
  234. package/assets/sass/elements/icons.scss +3 -4
  235. package/assets/sass/elements/links.scss +17 -25
  236. package/assets/sass/elements/lists.scss +30 -47
  237. package/assets/sass/elements/media.scss +1 -4
  238. package/assets/sass/elements/modal.scss +54 -80
  239. package/assets/sass/elements/popover.scss +28 -45
  240. package/assets/sass/elements/progress.scss +30 -40
  241. package/assets/sass/elements/table.element.scss +10 -15
  242. package/assets/sass/elements/tooltips.scss +27 -49
  243. package/assets/sass/elements/type.scss +47 -53
  244. package/assets/sass/email.scss +7 -9
  245. package/assets/sass/error.scss +23 -20
  246. package/assets/sass/foundations/bs_grid.scss +0 -1
  247. package/assets/sass/foundations/grid.scss +120 -122
  248. package/assets/sass/foundations/reboot.scss +27 -35
  249. package/assets/sass/foundations/root.scss +21 -31
  250. package/assets/sass/helpers/dynamic.scss +5 -5
  251. package/assets/sass/helpers/line-clamp.scss +1 -2
  252. package/assets/sass/helpers/max-height.scss +28 -36
  253. package/assets/sass/helpers/wider-colours.scss +2 -5
  254. package/assets/sass/main.scss +4 -4
  255. package/assets/sass/templates/auth.scss +11 -18
  256. package/assets/sass/templates/form.scss +16 -29
  257. package/assets/ts/components/_global.ts +14 -17
  258. package/assets/ts/components/accordion/accordion.component.ts +23 -19
  259. package/assets/ts/components/actionbar/README.md +8 -7
  260. package/assets/ts/components/actionbar/actionbar.component.ts +170 -220
  261. package/assets/ts/components/address-lookup/address-lookup.component.ts +94 -130
  262. package/assets/ts/components/applied-filters/README.md +1 -1
  263. package/assets/ts/components/applied-filters/applied-filters.component.ts +16 -15
  264. package/assets/ts/components/barchart/barchart.component.ts +29 -26
  265. package/assets/ts/components/card/card.component.ts +56 -57
  266. package/assets/ts/components/carousel/README.md +8 -9
  267. package/assets/ts/components/carousel/carousel.component.ts +30 -33
  268. package/assets/ts/components/chart/README.md +1 -3
  269. package/assets/ts/components/chart/chart.component.ts +24 -36
  270. package/assets/ts/components/collapsible-side/README.md +1 -1
  271. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +44 -57
  272. package/assets/ts/components/fileupload/README.md +3 -3
  273. package/assets/ts/components/fileupload/fileupload.component.ts +23 -28
  274. package/assets/ts/components/filter-card/filter-card.component.ts +32 -33
  275. package/assets/ts/components/filterlist/README.md +3 -3
  276. package/assets/ts/components/filterlist/filterlist.component.ts +18 -16
  277. package/assets/ts/components/header/README.md +8 -9
  278. package/assets/ts/components/header/header.component.ts +15 -16
  279. package/assets/ts/components/inline-edit/README.md +1 -0
  280. package/assets/ts/components/inline-edit/inline-edit.component.ts +71 -71
  281. package/assets/ts/components/marketing/marketing.component.ts +17 -16
  282. package/assets/ts/components/multi-step/multi-step.component.ts +114 -156
  283. package/assets/ts/components/multiselect/README.md +5 -5
  284. package/assets/ts/components/multiselect/multiselect.component.ts +116 -133
  285. package/assets/ts/components/nav/README.md +13 -13
  286. package/assets/ts/components/nav/nav.component.ts +171 -167
  287. package/assets/ts/components/notification/README.md +9 -9
  288. package/assets/ts/components/notification/notification.component.ts +33 -32
  289. package/assets/ts/components/pagination/README.md +12 -12
  290. package/assets/ts/components/pagination/pagination.component.ts +51 -69
  291. package/assets/ts/components/record-card/record-card.component.ts +24 -34
  292. package/assets/ts/components/search/README.md +6 -7
  293. package/assets/ts/components/search/search.component.ts +75 -91
  294. package/assets/ts/components/slider/slider.component.ts +62 -77
  295. package/assets/ts/components/table/README.md +8 -8
  296. package/assets/ts/components/table/table.component.ts +97 -134
  297. package/assets/ts/components/tabs/README.md +4 -4
  298. package/assets/ts/components/tabs/tabs.component.ts +16 -14
  299. package/assets/ts/components/video-card/video-card.component.ts +89 -93
  300. package/assets/ts/components.ts +44 -20
  301. package/assets/ts/html.d.ts +1 -7
  302. package/assets/ts/modules/applied-filters.ts +104 -135
  303. package/assets/ts/modules/card.module.ts +13 -18
  304. package/assets/ts/modules/carousel.ts +194 -195
  305. package/assets/ts/modules/chart.module.ts +201 -246
  306. package/assets/ts/modules/chart.ts +454 -472
  307. package/assets/ts/modules/data-layer.md +35 -31
  308. package/assets/ts/modules/data-layer.ts +18 -18
  309. package/assets/ts/modules/dialogs.ts +113 -117
  310. package/assets/ts/modules/drawer.ts +7 -9
  311. package/assets/ts/modules/dynamicEvents.ts +67 -100
  312. package/assets/ts/modules/file-upload.ts +43 -40
  313. package/assets/ts/modules/fileupload.ts +38 -60
  314. package/assets/ts/modules/filterlist.ts +14 -20
  315. package/assets/ts/modules/form.ts +126 -128
  316. package/assets/ts/modules/helpers.ts +114 -120
  317. package/assets/ts/modules/inputs.ts +88 -120
  318. package/assets/ts/modules/nav.ts +19 -18
  319. package/assets/ts/modules/notification.ts +28 -32
  320. package/assets/ts/modules/orderablelist.ts +90 -82
  321. package/assets/ts/modules/pagination.ts +14 -19
  322. package/assets/ts/modules/table.ts +516 -599
  323. package/assets/ts/modules/tabs.ts +120 -145
  324. package/assets/ts/modules/testimonial.ts +59 -64
  325. package/assets/ts/scripts.ts +7 -9
  326. package/assets/ts/tests/chart.spec.ts +11 -20
  327. package/assets/ts/tests/data-layer.spec.js +3 -4
  328. package/assets/ts/tests/filterlist.spec.ts +3 -6
  329. package/assets/ts/tests/slider.spec.ts +9 -15
  330. package/assets/ts/tests/table.spec.ts +7 -24
  331. package/assets/ts/vendor/hibp.ts +43 -43
  332. package/dist/components.es.js +280 -270
  333. package/dist/components.umd.js +67 -67
  334. package/dist/style.css +1 -1
  335. package/package.json +14 -4
  336. package/src/components/Accordion/Accordion.spec.js +25 -31
  337. package/src/components/Accordion/Accordion.vue +16 -19
  338. package/src/components/Accordion/AccordionItem.vue +39 -37
  339. package/src/components/Accordion/README.md +10 -12
  340. package/src/components/Actionbar/Actionbar.vue +15 -18
  341. package/src/components/Actionbar/README.md +8 -7
  342. package/src/components/AddressLookup/AddressLookup.vue +14 -16
  343. package/src/components/AppliedFilters/AppliedFilters.vue +14 -16
  344. package/src/components/Banner/Banner.spec.js +13 -15
  345. package/src/components/Banner/Banner.vue +19 -19
  346. package/src/components/Banner/README.md +8 -10
  347. package/src/components/BarChart/BarChart.vue +14 -16
  348. package/src/components/Card/Card.vue +13 -16
  349. package/src/components/Card/README.md +8 -8
  350. package/src/components/Carousel/Carousel.vue +15 -18
  351. package/src/components/Carousel/README.md +7 -7
  352. package/src/components/Chart/Chart.spec.js +64 -87
  353. package/src/components/Chart/Chart.vue +41 -40
  354. package/src/components/Chart/README.md +8 -9
  355. package/src/components/CollapsibleSideMenu/CollapsibleSideMenu.vue +8 -10
  356. package/src/components/CollapsibleSideMenu/README.md +1 -1
  357. package/src/components/FileUpload/FileUpload.vue +35 -40
  358. package/src/components/FileUpload/README.md +3 -3
  359. package/src/components/FilterCard/FilterCard.vue +14 -16
  360. package/src/components/Filterlist/Filterlist.vue +7 -9
  361. package/src/components/Filterlist/README.md +3 -3
  362. package/src/components/Header/Header.vue +23 -26
  363. package/src/components/Header/README.md +8 -9
  364. package/src/components/InlineEdit/InlineEdit.vue +26 -32
  365. package/src/components/Input/Input.vue +323 -233
  366. package/src/components/Input/README.md +11 -11
  367. package/src/components/Marketing/Marketing.vue +24 -27
  368. package/src/components/Marketing/README.md +7 -7
  369. package/src/components/MultiStep/MultiStep.vue +13 -15
  370. package/src/components/Multiselect/Multiselect.vue +14 -17
  371. package/src/components/Nav/Nav.vue +15 -29
  372. package/src/components/Nav/README.md +12 -12
  373. package/src/components/Nav-old/Nav.vue +88 -93
  374. package/src/components/Nav-old/README.md +11 -12
  375. package/src/components/NoteFeed/NoteFeed.vue +59 -56
  376. package/src/components/NoteFeed/README.md +6 -6
  377. package/src/components/Notification/Notification.vue +11 -15
  378. package/src/components/Notification/README.md +9 -9
  379. package/src/components/Pagination/Pagination.vue +14 -24
  380. package/src/components/Pagination/README.md +12 -12
  381. package/src/components/PropertySearchbar/PropertySearchbar.vue +191 -160
  382. package/src/components/PropertySearchbar/README.md +14 -15
  383. package/src/components/RecordCard/RecordCard.vue +14 -16
  384. package/src/components/Search/README.md +1 -1
  385. package/src/components/Search/Search.vue +13 -16
  386. package/src/components/Slider/Slider.vue +13 -16
  387. package/src/components/Snapshot/README.md +9 -10
  388. package/src/components/Snapshot/Snapshot.vue +15 -17
  389. package/src/components/Stepper/README.md +12 -13
  390. package/src/components/Stepper/Step.vue +22 -18
  391. package/src/components/Stepper/Stepper.spec.js +41 -46
  392. package/src/components/Stepper/Stepper.vue +17 -18
  393. package/src/components/Table/README.md +12 -11
  394. package/src/components/Table/Table.spec.js +17 -28
  395. package/src/components/Table/Table.vue +49 -48
  396. package/src/components/Tabs/README.md +8 -8
  397. package/src/components/Tabs/Tab.vue +21 -21
  398. package/src/components/Tabs/Tabs.vue +14 -17
  399. package/src/components/Testimonial/README.md +11 -12
  400. package/src/components/Testimonial/Testimonial.spec.js +22 -26
  401. package/src/components/Testimonial/Testimonial.vue +31 -25
  402. package/src/components/Timeline/README.md +3 -3
  403. package/src/components/Timeline/Timeline.spec.js +9 -11
  404. package/src/components/Timeline/Timeline.vue +10 -10
  405. package/src/components/VideoCard/VideoCard.vue +14 -16
  406. package/src/foundations/Logo/Logo.spec.js +30 -30
  407. package/src/foundations/Logo/Logo.vue +28 -28
  408. package/src/foundations/Logo/README.md +5 -4
  409. package/src/helpers/strings.js +11 -8
  410. package/src/index.js +27 -28
  411. package/src/vue-shim.d.ts +4 -4
@@ -1,22 +1,28 @@
1
- // @ts-nocheck
2
1
  import Cookies from 'js-cookie';
3
2
 
4
3
  // Data layer Web component created
4
+ declare global {
5
+ interface Window {
6
+ dataLayer: Array<object>;
7
+ }
8
+ }
5
9
  window.dataLayer = window.dataLayer || [];
6
10
  window.dataLayer.push({
7
- "event": "customElementRegistered",
8
- "element": "Address Lookup"
11
+ event: 'customElementRegistered',
12
+ element: 'Address Lookup',
9
13
  });
10
14
 
11
-
12
15
  class iamAddressLookup extends HTMLElement {
13
-
14
- constructor(){
16
+ constructor() {
15
17
  super();
16
- this.attachShadow({ mode: 'open'});
17
-
18
- const assetLocation = document.body.hasAttribute('data-assets-location') ? document.body.getAttribute('data-assets-location') : '/assets'
19
- const coreCSS = document.body.hasAttribute('data-core-css') ? document.body.getAttribute('data-core-css') : `${assetLocation}/css/core.min.css`;
18
+ this.attachShadow({ mode: 'open' });
19
+
20
+ const assetLocation = document.body.hasAttribute('data-assets-location')
21
+ ? document.body.getAttribute('data-assets-location')
22
+ : '/assets';
23
+ const coreCSS = document.body.hasAttribute('data-core-css')
24
+ ? document.body.getAttribute('data-core-css')
25
+ : `${assetLocation}/css/core.min.css`;
20
26
  const loadCSS = `@import "${assetLocation}/css/components/address-lookup.css";`;
21
27
 
22
28
  const template = document.createElement('template');
@@ -56,11 +62,10 @@ class iamAddressLookup extends HTMLElement {
56
62
  </div>
57
63
  </div>
58
64
  `;
59
- this.shadowRoot.appendChild(template.content.cloneNode(true));
65
+ this.shadowRoot?.appendChild(template.content.cloneNode(true));
60
66
  }
61
67
 
62
- async connectedCallback() {
63
-
68
+ async connectedCallback() {
64
69
  const component = this;
65
70
  const wrapper = this.shadowRoot.querySelector('.wrapper');
66
71
  const lookup = this.shadowRoot.querySelector('[name="postcode"]');
@@ -70,185 +75,156 @@ class iamAddressLookup extends HTMLElement {
70
75
  const list = this.shadowRoot.querySelector('datalist');
71
76
  const switchManualBtn = this.shadowRoot.querySelector('.switch-to-manual-btn');
72
77
  const switchLookupBtn = this.shadowRoot.querySelector('.switch-to-lookup-btn');
73
- const title = this.hasAttribute('data-title') ? this.getAttribute('data-title') : "Property address";
78
+ const title = this.hasAttribute('data-title') ? this.getAttribute('data-title') : 'Property address';
74
79
  const preFilledAddressBtn = this.shadowRoot.querySelector('.pre-filled-address + button');
75
80
 
76
-
77
81
  Array.from(this.shadowRoot.querySelectorAll('.title')).forEach((titleElement, index) => {
78
-
79
82
  titleElement.innerHTML = title;
80
83
  });
81
84
 
82
- function checkFilled(component){
83
-
84
- let preFilledAddress = component.shadowRoot.querySelector('.pre-filled-address');
85
+ function checkFilled(component) {
86
+ const preFilledAddress = component.shadowRoot.querySelector('.pre-filled-address');
85
87
  let preFilled = true;
86
- preFilledAddress.innerHTML = "";
88
+ preFilledAddress.innerHTML = '';
87
89
 
88
- Array.from(component.querySelectorAll('input[required],input[data-required],select[required],select[data-required]')).forEach((input, index) => {
90
+ Array.from(
91
+ component.querySelectorAll('input[required],input[data-required],select[required],select[data-required]')
92
+ ).forEach((input, index) => {
89
93
  const value = input.value;
90
94
 
91
- if(!value)
92
- preFilled = false;
93
- else
94
- preFilledAddress.innerHTML += value+(/^-?\d+$/.test(value) ? ' ' : ', ');
95
+ if (!value) preFilled = false;
96
+ else preFilledAddress.innerHTML += value + (/^-?\d+$/.test(value) ? ' ' : ', ');
95
97
  });
96
98
 
97
99
  preFilledAddress.innerHTML = preFilledAddress.innerHTML.slice(0, -2);
98
100
 
99
- if(preFilled){
101
+ if (preFilled) {
100
102
  preFilledWrapper.classList.remove('js-hide');
101
103
  lookupWrapper.classList.add('js-hide');
102
104
  manualWrapper.classList.add('js-hide');
103
105
  }
104
106
  }
105
107
  checkFilled(this);
106
-
107
- this.addEventListener('filled', (event) => {
108
108
 
109
+ this.addEventListener('filled', (event) => {
109
110
  checkFilled(this);
110
111
  });
111
112
 
113
+ if (this.hasAttribute('data-use')) {
114
+ const useLabel = this.hasAttribute('data-use-label') ? this.getAttribute('data-use-label') : 'Use saved address';
115
+ const useCheckbox = `<div><input type="checkbox" name="use" id="use" value="yes"><label for="use">${useLabel}</label></div>`;
112
116
 
113
- if(this.hasAttribute('data-use')){
117
+ lookupWrapper.insertAdjacentHTML('afterbegin', useCheckbox);
114
118
 
115
- let useLabel = this.hasAttribute('data-use-label') ? this.getAttribute('data-use-label') : 'Use saved address';
116
- let useCheckbox =`<div><input type="checkbox" name="use" id="use" value="yes"><label for="use">${useLabel}</label></div>`;
117
-
118
- lookupWrapper.insertAdjacentHTML('afterbegin',useCheckbox);
119
-
120
119
  this.shadowRoot.addEventListener('change', (event) => {
120
+ if (event && event.target instanceof HTMLElement && event.target.closest('[name="use"]')) {
121
+ const checkbox = event.target.closest('[name="use"]');
121
122
 
122
- if (event && event.target instanceof HTMLElement && event.target.closest('[name="use"]')){
123
-
124
- let checkbox = event.target.closest('[name="use"]');
125
-
126
- if(checkbox.checked){
127
-
123
+ if (checkbox.checked) {
128
124
  lookupWrapper.classList.add('js-hide');
129
125
  manualWrapper.classList.remove('js-hide');
130
126
 
131
- let values = JSON.parse(this.getAttribute('data-use'));
132
-
127
+ const values = JSON.parse(this.getAttribute('data-use'));
128
+
133
129
  Object.keys(values).forEach((key, index) => {
134
-
135
- let value = values[key];
136
- if(this.querySelector(`[data-name="${key}"]`))
137
- this.querySelector(`[data-name="${key}"]`).value = value;
138
- else if(this.querySelector(`[name="${key}"]`))
139
- this.querySelector(`[name="${key}"]`).value = value;
130
+ const value = values[key];
131
+ if (this.querySelector(`[data-name="${key}"]`)) this.querySelector(`[data-name="${key}"]`).value = value;
132
+ else if (this.querySelector(`[name="${key}"]`)) this.querySelector(`[name="${key}"]`).value = value;
140
133
  });
141
134
  }
142
135
  }
143
136
  });
144
137
  }
145
138
 
146
- if(this.hasAttribute('data-manual')){
139
+ if (this.hasAttribute('data-manual')) {
147
140
  lookupWrapper.classList.add('js-hide');
148
141
  manualWrapper.classList.remove('js-hide');
149
142
 
150
143
  Array.from(manualWrapper.querySelectorAll('[data-required]')).forEach((input, index) => {
151
- input.setAttribute('required','true');
144
+ input.setAttribute('required', 'true');
152
145
  });
153
146
  }
154
-
155
- function openManualWrapper (){
147
+
148
+ function openManualWrapper() {
156
149
  lookupWrapper.classList.add('js-hide');
157
150
  manualWrapper.classList.remove('js-hide');
158
151
 
159
152
  Array.from(manualWrapper.querySelectorAll('[data-required]')).forEach((input, index) => {
160
- input.setAttribute('required','true');
153
+ input.setAttribute('required', 'true');
161
154
  });
162
155
 
163
156
  manualWrapper.scrollIntoView();
164
157
  }
165
158
 
166
159
  preFilledAddressBtn.addEventListener('click', (event) => {
167
-
168
160
  preFilledWrapper.classList.add('js-hide');
169
161
  openManualWrapper();
170
162
  });
171
163
  switchManualBtn.addEventListener('click', (event) => {
172
-
173
164
  openManualWrapper();
174
165
  });
175
166
  switchLookupBtn.addEventListener('click', (event) => {
176
-
177
167
  lookupWrapper.classList.remove('js-hide');
178
168
  manualWrapper.classList.add('js-hide');
179
169
 
180
170
  lookupWrapper.scrollIntoView();
181
171
  });
182
172
 
183
-
184
173
  lookup.addEventListener('keyup', (event) => {
185
-
186
- if(lookup.value.length >= 3)
187
- search(lookup.value);
174
+ if (lookup.value.length >= 3) search(lookup.value);
188
175
  });
189
176
 
190
177
  lookup.addEventListener('change', (event) => {
191
-
192
- if(lookup.value.length >= 3){
193
-
178
+ if (lookup.value.length >= 3) {
194
179
  search(lookup.value);
195
180
 
196
- if(list.querySelector(`[value="${lookup.value}"]`)){
197
-
198
-
181
+ if (list.querySelector(`[value="${lookup.value}"]`)) {
199
182
  lookupWrapper.classList.add('js-hide');
200
183
  manualWrapper.classList.remove('js-hide');
201
184
 
202
- let values = JSON.parse(list.querySelector(`[value="${lookup.value}"]`).getAttribute('data-values'));
203
-
204
- Object.keys(values).forEach((key, index) => {
185
+ const values = JSON.parse(list.querySelector(`[value="${lookup.value}"]`).getAttribute('data-values'));
205
186
 
206
- let value = values[key];
207
- if(this.querySelector(`[data-name="${key}"]`) && value != '')
187
+ Object.keys(values).forEach((key, index) => {
188
+ const value = values[key];
189
+ if (this.querySelector(`[data-name="${key}"]`) && value != '')
208
190
  this.querySelector(`[data-name="${key}"]`).value = value;
209
- else if(this.querySelector(`[data-name-alt="${key}"]`) && value != '')
191
+ else if (this.querySelector(`[data-name-alt="${key}"]`) && value != '')
210
192
  this.querySelector(`[data-name-alt="${key}"]`).value = value;
211
- else if(this.querySelector(`[name="${key}"]`) && value != '')
193
+ else if (this.querySelector(`[name="${key}"]`) && value != '')
212
194
  this.querySelector(`[name="${key}"]`).value = value;
213
-
214
- if(this.querySelector(`[data-name-2="${key}"]`))
215
- this.querySelector(`[data-name-2="${key}"]`).value += ' '+value;
195
+
196
+ if (this.querySelector(`[data-name-2="${key}"]`))
197
+ this.querySelector(`[data-name-2="${key}"]`).value += ' ' + value;
216
198
  });
217
199
 
218
200
  // Focus on first input
219
201
  this.querySelector('[name]').focus();
220
202
 
221
203
  Array.from(this.querySelectorAll('[data-required]')).forEach((input, index) => {
222
- input.setAttribute('required','true');
204
+ input.setAttribute('required', 'true');
223
205
  });
224
206
  lookup.removeAttribute('required');
225
207
 
226
- if(this.shadowRoot.querySelector('[name="use"]'))
208
+ if (this.shadowRoot.querySelector('[name="use"]'))
227
209
  this.shadowRoot.querySelector('[name="use"]').checked = false;
228
210
  }
229
211
  }
230
-
231
212
  });
232
213
 
233
-
234
-
235
214
  const search = async (postcode) => {
236
-
237
215
  let ajaxURL = this.getAttribute('data-url');
238
216
  ajaxURL += `${encodeURI(postcode)}`;
239
-
217
+
240
218
  // Setup controller vars if not already set
241
- if(!window.controller)
242
- window.controller = [];
219
+ if (!window.controller) window.controller = [];
243
220
 
244
221
  // Abort if controller already present for this url
245
- if(window.controller[ajaxURL])
246
- window.controller[ajaxURL].abort();
222
+ if (window.controller[ajaxURL]) window.controller[ajaxURL].abort();
247
223
 
248
224
  // Create a new controller so it can be aborted if new fetch made
249
225
  window.controller[ajaxURL] = new AbortController();
250
226
  const { signal } = controller[ajaxURL];
251
-
227
+
252
228
  try {
253
229
  await fetch(ajaxURL, {
254
230
  signal: signal,
@@ -258,56 +234,44 @@ class iamAddressLookup extends HTMLElement {
258
234
  'Content-Type': 'application/json',
259
235
  Accept: 'application/json',
260
236
  'X-Requested-With': 'XMLHttpRequest',
261
- 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN')
262
- })
237
+ 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN'),
238
+ }),
263
239
  })
264
- .then((response) => response.json()).then((response) => {
265
-
266
- // populate datalist
267
- let listString = '';
268
- response.forEach((address, index) => {
269
-
270
- // Deal with agent platform response
271
- if(typeof address.value == "object"){
272
- let values = JSON.stringify(address.value);
273
- listString += `<option value="${address['label']}, ${postcode}" data-values='${values}'></option>`;
274
- }
275
- else {
276
- let values = JSON.stringify(address);
277
-
278
- if(component.hasAttribute('data-display-text')){
279
-
280
- listString += `<option value="${address[component.getAttribute('data-display-text')]}, ${postcode}" data-values='${values}'></option>`;
281
- }
282
- else {
283
-
284
- let itemString = '';
285
- for (const [key, value] of Object.entries(address)) {
286
-
287
- if(key == "address_number_name")
288
- itemString += `${value} `;
289
- else if(key != "postcode" && key != "address_title")
290
- itemString += `${value}${(/^-?\d+$/.test(value)?'':',')} `;
240
+ .then((response) => response.json())
241
+ .then((response) => {
242
+ // populate datalist
243
+ let listString = '';
244
+ response.forEach((address, index) => {
245
+ // Deal with agent platform response
246
+ if (typeof address.value == 'object') {
247
+ const values = JSON.stringify(address.value);
248
+ listString += `<option value="${address['label']}, ${postcode}" data-values='${values}'></option>`;
249
+ } else {
250
+ const values = JSON.stringify(address);
251
+
252
+ if (component.hasAttribute('data-display-text')) {
253
+ listString += `<option value="${address[component.getAttribute('data-display-text')]}, ${postcode}" data-values='${values}'></option>`;
254
+ } else {
255
+ let itemString = '';
256
+ for (const [key, value] of Object.entries(address)) {
257
+ if (key == 'address_number_name') itemString += `${value} `;
258
+ else if (key != 'postcode' && key != 'address_title')
259
+ itemString += `${value}${/^-?\d+$/.test(value) ? '' : ','} `;
260
+ }
261
+
262
+ listString += `<option value="${itemString}${postcode}" data-values='${values}'></option>`;
291
263
  }
292
-
293
- listString += `<option value="${itemString}${postcode}" data-values='${values}'></option>`;
294
264
  }
295
-
296
- }
297
-
265
+ });
266
+ list.innerHTML = listString;
298
267
 
268
+ return response;
299
269
  });
300
- list.innerHTML = listString;
301
-
302
- return response;
303
- });
304
270
  } catch (error) {
305
271
  console.log(error);
306
272
  }
307
-
308
- }
309
-
273
+ };
310
274
  }
311
275
  }
312
276
 
313
- export default iamAddressLookup;
277
+ export default iamAddressLookup;
@@ -17,4 +17,4 @@ import('../node_modules/@iamproperty/components/assets/js/components/applied-fil
17
17
  <iam-applied-filters></iam-applied-filters>
18
18
  ```
19
19
 
20
- To add an input to the applied filters an attribute of **data-filter-text** needs to be supplied so that the JavaScript knows to listen for the value to change. This attribute can also be used on a wrapper for mulitple input filters also and dynamic values can also be given. **$value** passes the inputs value as the filter text and **$1,$2,$3...** will pass the corresponding child input value to the text.
20
+ To add an input to the applied filters an attribute of **data-filter-text** needs to be supplied so that the JavaScript knows to listen for the value to change. This attribute can also be used on a wrapper for mulitple input filters also and dynamic values can also be given. **$value** passes the inputs value as the filter text and **$1,$2,$3...** will pass the corresponding child input value to the text.
@@ -1,25 +1,27 @@
1
1
  // @ts-nocheck
2
- import createAppliedFilters from "../../modules/applied-filters";
2
+ import createAppliedFilters from '../../modules/applied-filters';
3
3
 
4
4
  // Data layer Web component created
5
5
  window.dataLayer = window.dataLayer || [];
6
6
  window.dataLayer.push({
7
- "event": "customElementRegistered",
8
- "element": "Applied Filters"
7
+ event: 'customElementRegistered',
8
+ element: 'Applied Filters',
9
9
  });
10
10
 
11
-
12
11
  class iamAppliedFilters extends HTMLElement {
13
-
14
- constructor(){
12
+ constructor() {
15
13
  super();
16
- this.attachShadow({ mode: 'open'});
17
-
18
- const assetLocation = document.body.hasAttribute('data-assets-location') ? document.body.getAttribute('data-assets-location') : '/assets'
19
- const coreCSS = document.body.hasAttribute('data-core-css') ? document.body.getAttribute('data-core-css') : `${assetLocation}/css/core.min.css`;
14
+ this.attachShadow({ mode: 'open' });
15
+
16
+ const assetLocation = document.body.hasAttribute('data-assets-location')
17
+ ? document.body.getAttribute('data-assets-location')
18
+ : '/assets';
19
+ const coreCSS = document.body.hasAttribute('data-core-css')
20
+ ? document.body.getAttribute('data-core-css')
21
+ : `${assetLocation}/css/core.min.css`;
20
22
  const loadCSS = `@import "${assetLocation}/css/components/applied-filters.css";`;
21
23
 
22
- let classList = this.classList.toString();
24
+ const classList = this.classList.toString();
23
25
  const template = document.createElement('template');
24
26
  template.innerHTML = `
25
27
  <style>
@@ -33,10 +35,9 @@ class iamAppliedFilters extends HTMLElement {
33
35
  this.shadowRoot.appendChild(template.content.cloneNode(true));
34
36
  }
35
37
 
36
- connectedCallback() {
37
-
38
- createAppliedFilters(this,this.shadowRoot.querySelector('.applied-filters'));
38
+ connectedCallback() {
39
+ createAppliedFilters(this, this.shadowRoot.querySelector('.applied-filters'));
39
40
  }
40
41
  }
41
42
 
42
- export default iamAppliedFilters;
43
+ export default iamAppliedFilters;
@@ -1,18 +1,27 @@
1
1
  // @ts-nocheck
2
- import {addClasses,setupChart,setEventListener,setEventObservers,setLongestLabel,setLongestValue,createTooltips} from "../../modules/chart.module";
3
- import {trackComponent, trackComponentRegistered} from "../_global";
4
-
5
- trackComponentRegistered("iam-barchart");
2
+ import {
3
+ addClasses,
4
+ setupChart,
5
+ setEventListener,
6
+ setEventObservers,
7
+ setLongestLabel,
8
+ setLongestValue,
9
+ createTooltips,
10
+ } from '../../modules/chart.module';
11
+ import { trackComponent, trackComponentRegistered } from '../_global';
12
+
13
+ trackComponentRegistered('iam-barchart');
6
14
 
7
15
  class iamBarChart extends HTMLElement {
8
-
9
- constructor(){
16
+ constructor() {
10
17
  super();
11
- this.attachShadow({ mode: 'open'});
18
+ this.attachShadow({ mode: 'open' });
12
19
 
13
- const assetLocation = document.body.hasAttribute('data-assets-location') ? document.body.getAttribute('data-assets-location') : '/assets';
20
+ const assetLocation = document.body.hasAttribute('data-assets-location')
21
+ ? document.body.getAttribute('data-assets-location')
22
+ : '/assets';
14
23
  const loadCSS = `@import "${assetLocation}/css/components/barchart.component.css";`;
15
-
24
+
16
25
  const template = document.createElement('template');
17
26
  template.innerHTML = `
18
27
  <style>
@@ -34,11 +43,10 @@ class iamBarChart extends HTMLElement {
34
43
  this.shadowRoot.appendChild(template.content.cloneNode(true));
35
44
  }
36
45
 
37
- connectedCallback() {
38
-
46
+ connectedCallback() {
39
47
  const chartComponent = this;
40
- const chartID = `chart-${Date.now()+(Math.floor(Math.random() * 100) + 1)}`;
41
- const orginalTable = this.querySelector('table');
48
+ const chartID = `chart-${Date.now() + (Math.floor(Math.random() * 100) + 1)}`;
49
+ const orginalTable = this.querySelector('table');
42
50
  const clonedTable = orginalTable.cloneNode(true);
43
51
  const chart = this.shadowRoot.querySelector('.chart');
44
52
  const chartOuter = this.shadowRoot.querySelector('.chart__outer');
@@ -47,30 +55,25 @@ class iamBarChart extends HTMLElement {
47
55
  chart.appendChild(clonedTable);
48
56
  addClasses(chartComponent, chartOuter);
49
57
 
50
- if(barCount <= 10){
51
-
58
+ if (barCount <= 10) {
52
59
  chartComponent.classList.add('chart--fit-content');
53
60
  }
54
61
 
55
- if(barCount <= 5){
56
-
62
+ if (barCount <= 5) {
57
63
  chartComponent.classList.add('chart--no-scale');
58
64
  }
59
65
 
60
- setupChart(chartComponent,chartOuter,clonedTable);
61
- setEventObservers(chartComponent,chartOuter);
62
- setEventListener(chartComponent,chartOuter);
66
+ setupChart(chartComponent, chartOuter, clonedTable);
67
+ setEventObservers(chartComponent, chartOuter);
68
+ setEventListener(chartComponent, chartOuter);
63
69
  setLongestLabel(chartOuter);
64
70
  setLongestValue(chartOuter);
65
71
  createTooltips(chartOuter);
66
72
 
67
- trackComponent(chartComponent,"iam-barchart",['view-change']);
73
+ trackComponent(chartComponent, 'iam-barchart', ['view-change']);
68
74
  }
69
75
 
70
- attributeChangedCallback(attrName, oldVal, newVal) {
71
-
72
-
73
- }
76
+ attributeChangedCallback(attrName, oldVal, newVal) {}
74
77
  }
75
78
 
76
- export default iamBarChart;
79
+ export default iamBarChart;