@iamproperty/components 7.1.0--beta7 → 7.2.1--beta1

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 (382) hide show
  1. package/assets/css/components/actionbar.component.css +1 -0
  2. package/assets/css/components/actionbar.component.css.map +1 -0
  3. package/assets/css/components/actionbar.global.css +1 -1
  4. package/assets/css/components/actionbar.global.css.map +1 -1
  5. package/assets/css/components/address-lookup.css +1 -1
  6. package/assets/css/components/address-lookup.css.map +1 -1
  7. package/assets/css/components/barchart.component.css +1 -1
  8. package/assets/css/components/barchart.component.css.map +1 -1
  9. package/assets/css/components/bento-grid.component.css +1 -0
  10. package/assets/css/components/bento-grid.component.css.map +1 -0
  11. package/assets/css/components/card.component.css +1 -1
  12. package/assets/css/components/card.component.css.map +1 -1
  13. package/assets/css/components/carousel.component.css +1 -1
  14. package/assets/css/components/carousel.component.css.map +1 -1
  15. package/assets/css/components/carousel.config.css +1 -1
  16. package/assets/css/components/carousel.config.css.map +1 -1
  17. package/assets/css/components/charts.config.css +1 -1
  18. package/assets/css/components/charts.config.css.map +1 -1
  19. package/assets/css/components/charts.css +1 -1
  20. package/assets/css/components/charts.css.map +1 -1
  21. package/assets/css/components/charts.module.css +1 -1
  22. package/assets/css/components/charts.module.css.map +1 -1
  23. package/assets/css/components/collapsible-side.css +1 -1
  24. package/assets/css/components/collapsible-side.css.map +1 -1
  25. package/assets/css/components/doughnutchart.component.css +1 -0
  26. package/assets/css/components/doughnutchart.component.css.map +1 -0
  27. package/assets/css/components/fileupload.css.map +1 -1
  28. package/assets/css/components/header.css.map +1 -1
  29. package/assets/css/components/inline-edit.preload.css +1 -1
  30. package/assets/css/components/inline-edit.preload.css.map +1 -1
  31. package/assets/css/components/marketing.css.map +1 -1
  32. package/assets/css/components/menu.component.css +1 -0
  33. package/assets/css/components/menu.component.css.map +1 -0
  34. package/assets/css/components/menu.css +1 -0
  35. package/assets/css/components/menu.css.map +1 -0
  36. package/assets/css/components/multi-step.component.css.map +1 -1
  37. package/assets/css/components/multiselect.preload.css +1 -1
  38. package/assets/css/components/multiselect.preload.css.map +1 -1
  39. package/assets/css/components/nav.component.css +1 -0
  40. package/assets/css/components/nav.component.css.map +1 -0
  41. package/assets/css/components/nav.docs.css.map +1 -1
  42. package/assets/css/components/nav.global.css.map +1 -1
  43. package/assets/css/components/nav.old.css +1 -1
  44. package/assets/css/components/nav.old.css.map +1 -1
  45. package/assets/css/components/nav.preload.css +1 -1
  46. package/assets/css/components/nav.preload.css.map +1 -1
  47. package/assets/css/components/notification.css +1 -1
  48. package/assets/css/components/notification.css.map +1 -1
  49. package/assets/css/components/pagination.css +1 -1
  50. package/assets/css/components/pagination.css.map +1 -1
  51. package/assets/css/components/property-searchbar.css.map +1 -1
  52. package/assets/css/components/slider.css +1 -1
  53. package/assets/css/components/slider.css.map +1 -1
  54. package/assets/css/components/snapshot.css.map +1 -1
  55. package/assets/css/components/stepper.css.map +1 -1
  56. package/assets/css/components/table-basic.component.css +1 -0
  57. package/assets/css/components/table-basic.component.css.map +1 -0
  58. package/assets/css/components/table-basic.global.css +1 -0
  59. package/assets/css/components/table-basic.global.css.map +1 -0
  60. package/assets/css/components/table.component.css +1 -0
  61. package/assets/css/components/table.component.css.map +1 -0
  62. package/assets/css/components/table.global.css +1 -1
  63. package/assets/css/components/table.global.css.map +1 -1
  64. package/assets/css/components/tabs.component.css +1 -0
  65. package/assets/css/components/tabs.component.css.map +1 -0
  66. package/assets/css/components/tabs.config.css +1 -0
  67. package/assets/css/components/tabs.config.css.map +1 -0
  68. package/assets/css/components/tabs.css +1 -1
  69. package/assets/css/components/tabs.css.map +1 -1
  70. package/assets/css/components/testimonial.css.map +1 -1
  71. package/assets/css/components/timeline.css.map +1 -1
  72. package/assets/css/core.min.css +1 -1
  73. package/assets/css/core.min.css.map +1 -1
  74. package/assets/css/mobile-core.min.css +1 -0
  75. package/assets/css/mobile-core.min.css.map +1 -0
  76. package/assets/css/mobile.min.css +1 -0
  77. package/assets/css/mobile.min.css.map +1 -0
  78. package/assets/css/style.min.css +1 -1
  79. package/assets/css/style.min.css.map +1 -1
  80. package/assets/js/components/_global.js +0 -1
  81. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  82. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  83. package/assets/js/components/actionbar/actionbar.component.js +86 -8
  84. package/assets/js/components/actionbar/actionbar.component.min.js +19 -6
  85. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  86. package/assets/js/components/address-lookup/address-lookup.component.js +17 -18
  87. package/assets/js/components/address-lookup/address-lookup.component.min.js +5 -5
  88. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  89. package/assets/js/components/applied-filters/applied-filters.component.js +0 -1
  90. package/assets/js/components/applied-filters/applied-filters.component.min.js +4 -4
  91. package/assets/js/components/applied-filters/applied-filters.component.min.js.map +1 -1
  92. package/assets/js/components/barchart/barchart.component.js +2 -3
  93. package/assets/js/components/barchart/barchart.component.min.js +8 -4
  94. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  95. package/assets/js/components/bento-grid/bento-grid.component.js +50 -0
  96. package/assets/js/components/bento-grid/bento-grid.component.min.js +15 -0
  97. package/assets/js/components/bento-grid/bento-grid.component.min.js.map +1 -0
  98. package/assets/js/components/card/card.component.js +10 -13
  99. package/assets/js/components/card/card.component.min.js +7 -7
  100. package/assets/js/components/card/card.component.min.js.map +1 -1
  101. package/assets/js/components/carousel/carousel.component.js +4 -5
  102. package/assets/js/components/carousel/carousel.component.min.js +4 -4
  103. package/assets/js/components/carousel/carousel.component.min.js.map +1 -1
  104. package/assets/js/components/chart/chart.component.js +1 -5
  105. package/assets/js/components/collapsible-side/collapsible-side.component.js +4 -5
  106. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +4 -4
  107. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  108. package/assets/js/components/doughnutchart/doughnutchart.component.js +70 -0
  109. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +25 -0
  110. package/assets/js/components/doughnutchart/doughnutchart.component.min.js.map +1 -0
  111. package/assets/js/components/fileupload/fileupload.component.js +2 -3
  112. package/assets/js/components/fileupload/fileupload.component.min.js +6 -6
  113. package/assets/js/components/fileupload/fileupload.component.min.js.map +1 -1
  114. package/assets/js/components/filter-card/filter-card.component.js +3 -4
  115. package/assets/js/components/filter-card/filter-card.component.min.js +4 -4
  116. package/assets/js/components/filter-card/filter-card.component.min.js.map +1 -1
  117. package/assets/js/components/filterlist/filterlist.component.js +0 -1
  118. package/assets/js/components/filterlist/filterlist.component.min.js +3 -3
  119. package/assets/js/components/filterlist/filterlist.component.min.js.map +1 -1
  120. package/assets/js/components/header/header.component.js +0 -1
  121. package/assets/js/components/header/header.component.min.js +1 -1
  122. package/assets/js/components/header/header.component.min.js.map +1 -1
  123. package/assets/js/components/inline-edit/inline-edit.component.js +7 -8
  124. package/assets/js/components/inline-edit/inline-edit.component.min.js +4 -4
  125. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  126. package/assets/js/components/marketing/marketing.component.js +0 -1
  127. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  128. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  129. package/assets/js/components/menu/menu.component.js +200 -0
  130. package/assets/js/components/menu/menu.component.min.js +77 -0
  131. package/assets/js/components/menu/menu.component.min.js.map +1 -0
  132. package/assets/js/components/multi-step/multi-step.component.js +10 -10
  133. package/assets/js/components/multi-step/multi-step.component.min.js +13 -0
  134. package/assets/js/components/multi-step/multi-step.component.min.js.map +1 -0
  135. package/assets/js/components/multiselect/multiselect.component.js +10 -10
  136. package/assets/js/components/multiselect/multiselect.component.min.js +3 -3
  137. package/assets/js/components/multiselect/multiselect.component.min.js.map +1 -1
  138. package/assets/js/components/nav/nav.component.js +7 -7
  139. package/assets/js/components/nav/nav.component.min.js +7 -7
  140. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  141. package/assets/js/components/notification/notification.component.js +3 -3
  142. package/assets/js/components/notification/notification.component.min.js +4 -4
  143. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  144. package/assets/js/components/pagination/pagination.component.js +14 -8
  145. package/assets/js/components/pagination/pagination.component.min.js +5 -5
  146. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  147. package/assets/js/components/record-card/record-card.component.js +6 -8
  148. package/assets/js/components/record-card/record-card.component.min.js +4 -4
  149. package/assets/js/components/record-card/record-card.component.min.js.map +1 -1
  150. package/assets/js/components/search/search.component.js +9 -6
  151. package/assets/js/components/search/search.component.min.js +8 -5
  152. package/assets/js/components/search/search.component.min.js.map +1 -1
  153. package/assets/js/components/slider/slider.component.js +8 -8
  154. package/assets/js/components/slider/slider.component.min.js +5 -5
  155. package/assets/js/components/slider/slider.component.min.js.map +1 -1
  156. package/assets/js/components/table/table.component.js +36 -200
  157. package/assets/js/components/table/table.component.min.js +13 -23
  158. package/assets/js/components/table/table.component.min.js.map +1 -1
  159. package/assets/js/components/table-ajax/table-ajax.component.js +46 -0
  160. package/assets/js/components/table-ajax/table-ajax.component.min.js +22 -0
  161. package/assets/js/components/table-ajax/table-ajax.component.min.js.map +1 -0
  162. package/assets/js/components/table-basic/table-basic.component.js +46 -0
  163. package/assets/js/components/table-basic/table-basic.component.min.js +22 -0
  164. package/assets/js/components/table-basic/table-basic.component.min.js.map +1 -0
  165. package/assets/js/components/table-no-submit/table-no-submit.component.js +77 -0
  166. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +22 -0
  167. package/assets/js/components/table-no-submit/table-no-submit.component.min.js.map +1 -0
  168. package/assets/js/components/table-submit/table-submit.component.js +55 -0
  169. package/assets/js/components/table-submit/table-submit.component.min.js +22 -0
  170. package/assets/js/components/table-submit/table-submit.component.min.js.map +1 -0
  171. package/assets/js/components/tabs/tabs.component.js +3 -2
  172. package/assets/js/components/tabs/tabs.component.min.js +6 -4
  173. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  174. package/assets/js/components/video-card/video-card.component.js +4 -3
  175. package/assets/js/components/video-card/video-card.component.min.js +3 -3
  176. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  177. package/assets/js/modules/applied-filters.js +8 -9
  178. package/assets/js/modules/carousel.js +9 -10
  179. package/assets/js/modules/chart.js +5 -3
  180. package/assets/js/modules/chart.module.js +108 -1
  181. package/assets/js/modules/dialogs.js +6 -7
  182. package/assets/js/modules/drawer.js +1 -2
  183. package/assets/js/modules/dynamicEvents.js +7 -8
  184. package/assets/js/modules/fileupload.js +7 -7
  185. package/assets/js/modules/filterlist.js +3 -4
  186. package/assets/js/modules/form.js +12 -13
  187. package/assets/js/modules/helpers.js +7 -5
  188. package/assets/js/modules/inputs.js +6 -9
  189. package/assets/js/modules/nav.js +3 -4
  190. package/assets/js/modules/notification.js +2 -3
  191. package/assets/js/modules/orderablelist.js +0 -1
  192. package/assets/js/modules/table.js +604 -317
  193. package/assets/js/modules/tabs.js +46 -19
  194. package/assets/js/scripts.bundle.js +3 -3
  195. package/assets/js/scripts.bundle.js.map +1 -1
  196. package/assets/js/scripts.bundle.min.js +2 -2
  197. package/assets/js/scripts.bundle.min.js.map +1 -1
  198. package/assets/js/scripts.js +71 -6
  199. package/assets/js/tests/card.spec.js +14 -0
  200. package/assets/js/tests/carousel.spec.js +60 -0
  201. package/assets/js/tests/chart.spec.js +7 -5
  202. package/assets/js/tests/fileupload.spec.js +22 -0
  203. package/assets/js/tests/multistep.spec.js +68 -0
  204. package/assets/js/tests/table.spec.js +0 -31
  205. package/assets/sass/_bs_grid.scss +4 -1
  206. package/assets/sass/_components.scss +326 -100
  207. package/assets/sass/_corefiles.scss +42 -18
  208. package/assets/sass/_elements.scss +98 -18
  209. package/assets/sass/_example.scss +61 -0
  210. package/assets/sass/_func.scss +5 -13
  211. package/assets/sass/_functions/bs_utilities.scss +43 -39
  212. package/assets/sass/_functions/functions.scss +66 -52
  213. package/assets/sass/_functions/mixins.scss +84 -100
  214. package/assets/sass/_functions/utility-mixins.scss +56 -44
  215. package/assets/sass/_functions/variables.scss +90 -1659
  216. package/assets/sass/_functions/variables_old.scss +1701 -0
  217. package/assets/sass/_grid.scss +19 -5
  218. package/assets/sass/_tests/func.spec.scss +1 -37
  219. package/assets/sass/_tests/mixins.spec.scss +1 -77
  220. package/assets/sass/_tests/typography.spec.scss +1 -1
  221. package/assets/sass/_utilities.scss +15 -5
  222. package/assets/sass/_utility-mixins.scss +6 -1
  223. package/assets/sass/components/{actionbar.scss → actionbar.component.scss} +83 -16
  224. package/assets/sass/components/actionbar.global.scss +12 -68
  225. package/assets/sass/components/address-lookup.scss +6 -0
  226. package/assets/sass/components/barchart.component.scss +7 -20
  227. package/assets/sass/components/bento-grid.component.scss +91 -0
  228. package/assets/sass/components/carousel.config.scss +64 -58
  229. package/assets/sass/components/charts.config.scss +73 -67
  230. package/assets/sass/components/charts.module.scss +128 -97
  231. package/assets/sass/components/charts.scss +43 -42
  232. package/assets/sass/components/collapsible-side.scss +29 -27
  233. package/assets/sass/components/doughnutchart.component.scss +205 -0
  234. package/assets/sass/components/fileupload.scss +4 -3
  235. package/assets/sass/components/header.scss +5 -5
  236. package/assets/sass/components/inline-edit.preload.scss +108 -102
  237. package/assets/sass/components/menu.component.scss +101 -0
  238. package/assets/sass/components/menu.scss +21 -0
  239. package/assets/sass/components/multi-step.component.scss +5 -3
  240. package/assets/sass/components/multiselect.preload.scss +36 -30
  241. package/assets/sass/components/{nav.scss → nav.component.scss} +41 -21
  242. package/assets/sass/components/nav.docs.scss +1 -1
  243. package/assets/sass/components/nav.global.scss +13 -11
  244. package/assets/sass/components/nav.old.scss +21 -24
  245. package/assets/sass/components/nav.preload.scss +40 -34
  246. package/assets/sass/components/notification.scss +9 -5
  247. package/assets/sass/components/pagination.scss +7 -0
  248. package/assets/sass/components/property-searchbar.scss +7 -7
  249. package/assets/sass/components/slider.scss +2 -0
  250. package/assets/sass/components/snapshot.scss +2 -2
  251. package/assets/sass/components/stepper.scss +7 -7
  252. package/assets/sass/components/{table.scss → table-basic.component.scss} +25 -68
  253. package/assets/sass/components/table-basic.global.scss +355 -0
  254. package/assets/sass/components/table.component.scss +40 -0
  255. package/assets/sass/components/table.global.scss +215 -418
  256. package/assets/sass/components/tabs.component.scss +5 -0
  257. package/assets/sass/components/tabs.config.scss +27 -0
  258. package/assets/sass/components/tabs.scss +40 -4
  259. package/assets/sass/components/testimonial.scss +7 -7
  260. package/assets/sass/components/timeline.scss +1 -1
  261. package/assets/sass/core.scss +13 -4
  262. package/assets/sass/elements/admin-panel.scss +199 -185
  263. package/assets/sass/elements/badge-tag.scss +87 -81
  264. package/assets/sass/elements/brand.scss +67 -61
  265. package/assets/sass/elements/buttons--action.scss +55 -0
  266. package/assets/sass/elements/buttons--compact.scss +135 -0
  267. package/assets/sass/elements/buttons--global.scss +323 -0
  268. package/assets/sass/elements/buttons--secondary.scss +24 -0
  269. package/assets/sass/elements/buttons--tertiary.scss +57 -0
  270. package/assets/sass/elements/buttons.scss +29 -503
  271. package/assets/sass/elements/container.scss +157 -151
  272. package/assets/sass/elements/details.scss +147 -138
  273. package/assets/sass/elements/dialog.scss +36 -30
  274. package/assets/sass/elements/forms.scss +1061 -1047
  275. package/assets/sass/elements/icons.scss +23 -17
  276. package/assets/sass/elements/links.scss +131 -116
  277. package/assets/sass/elements/lists.scss +270 -264
  278. package/assets/sass/elements/media.scss +19 -13
  279. package/assets/sass/elements/modal.scss +336 -330
  280. package/assets/sass/elements/popover.scss +163 -152
  281. package/assets/sass/elements/progress.scss +173 -162
  282. package/assets/sass/elements/table.element.scss +116 -108
  283. package/assets/sass/elements/tooltips.scss +87 -80
  284. package/assets/sass/elements/type.scss +172 -160
  285. package/assets/sass/email.scss +0 -1
  286. package/assets/sass/error.scss +15 -13
  287. package/assets/sass/foundations/reboot.scss +176 -170
  288. package/assets/sass/foundations/root.scss +136 -125
  289. package/assets/sass/helpers/max-height.scss +2 -2
  290. package/assets/sass/main.scss +14 -6
  291. package/assets/sass/mobile-core.scss +14 -0
  292. package/assets/sass/mobile.scss +16 -0
  293. package/assets/sass/templates/auth.scss +88 -83
  294. package/assets/sass/templates/form.scss +68 -59
  295. package/assets/ts/components/_global.ts +2 -3
  296. package/assets/ts/components/actionbar/actionbar.component.ts +94 -2
  297. package/assets/ts/components/address-lookup/address-lookup.component.ts +21 -22
  298. package/assets/ts/components/applied-filters/applied-filters.component.ts +1 -2
  299. package/assets/ts/components/barchart/barchart.component.ts +3 -5
  300. package/assets/ts/components/bento-grid/README.md +31 -0
  301. package/assets/ts/components/bento-grid/bento-grid.component.ts +67 -0
  302. package/assets/ts/components/card/card.component.ts +13 -16
  303. package/assets/ts/components/carousel/carousel.component.ts +5 -7
  304. package/assets/ts/components/chart/chart.component.ts +4 -9
  305. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +5 -6
  306. package/assets/ts/components/doughnutchart/doughnutchart.component.ts +85 -0
  307. package/assets/ts/components/fileupload/fileupload.component.ts +5 -6
  308. package/assets/ts/components/filter-card/filter-card.component.ts +4 -5
  309. package/assets/ts/components/filterlist/filterlist.component.ts +1 -2
  310. package/assets/ts/components/header/header.component.ts +1 -3
  311. package/assets/ts/components/inline-edit/inline-edit.component.ts +8 -11
  312. package/assets/ts/components/marketing/marketing.component.ts +1 -3
  313. package/assets/ts/components/menu/menu.component.ts +222 -0
  314. package/assets/ts/components/multi-step/multi-step.component.ts +19 -23
  315. package/assets/ts/components/multiselect/multiselect.component.ts +13 -14
  316. package/assets/ts/components/nav/nav.component.ts +8 -9
  317. package/assets/ts/components/notification/notification.component.ts +3 -3
  318. package/assets/ts/components/pagination/pagination.component.ts +24 -12
  319. package/assets/ts/components/record-card/record-card.component.ts +9 -11
  320. package/assets/ts/components/search/search.component.ts +12 -9
  321. package/assets/ts/components/slider/slider.component.ts +9 -10
  322. package/assets/ts/components/table/table.component.ts +50 -247
  323. package/assets/ts/components/table-ajax/table-ajax.component.ts +64 -0
  324. package/assets/ts/components/table-basic/README.md +40 -0
  325. package/assets/ts/components/table-basic/table-basic.component.ts +56 -0
  326. package/assets/ts/components/table-no-submit/table-no-submit.component.ts +134 -0
  327. package/assets/ts/components/table-submit/table-submit.component.ts +64 -0
  328. package/assets/ts/components/tabs/tabs.component.ts +4 -3
  329. package/assets/ts/components/video-card/video-card.component.ts +13 -12
  330. package/assets/ts/modules/applied-filters.ts +10 -11
  331. package/assets/ts/modules/card.module.ts +1 -1
  332. package/assets/ts/modules/carousel.ts +13 -15
  333. package/assets/ts/modules/chart.module.ts +152 -19
  334. package/assets/ts/modules/chart.ts +26 -24
  335. package/assets/ts/modules/dialogs.ts +10 -13
  336. package/assets/ts/modules/drawer.ts +1 -2
  337. package/assets/ts/modules/dynamicEvents.ts +12 -14
  338. package/assets/ts/modules/fileupload.ts +10 -10
  339. package/assets/ts/modules/filterlist.ts +6 -7
  340. package/assets/ts/modules/form.ts +16 -17
  341. package/assets/ts/modules/helpers.ts +24 -21
  342. package/assets/ts/modules/inputs.ts +15 -18
  343. package/assets/ts/modules/nav.ts +4 -5
  344. package/assets/ts/modules/notification.ts +7 -8
  345. package/assets/ts/modules/orderablelist.ts +3 -4
  346. package/assets/ts/modules/pagination.ts +1 -1
  347. package/assets/ts/modules/table.ts +726 -356
  348. package/assets/ts/modules/tabs.ts +59 -20
  349. package/assets/ts/scripts.ts +72 -6
  350. package/assets/ts/tests/card.spec.ts +19 -0
  351. package/assets/ts/tests/carousel.spec.ts +66 -0
  352. package/assets/ts/tests/chart.spec.ts +9 -6
  353. package/assets/ts/tests/fileupload.spec.ts +30 -0
  354. package/assets/ts/tests/multistep.spec.ts +78 -0
  355. package/assets/ts/tests/table.spec.ts +0 -38
  356. package/dist/components.es.js +1260 -1063
  357. package/dist/components.umd.js +468 -198
  358. package/package.json +44 -49
  359. package/src/components/BentoGrid/BentoGrid.vue +20 -0
  360. package/src/components/DoughnutChart/DoughnutChart.vue +23 -0
  361. package/src/components/FileUpload/FileUpload.vue +4 -1
  362. package/src/components/Menu/Menu.vue +22 -0
  363. package/src/components/Table/TableAjax.vue +34 -0
  364. package/src/components/Table/TableBasic.vue +34 -0
  365. package/src/components/Table/TableNoSubmit.vue +34 -0
  366. package/src/components/Table/TableSubmit.vue +34 -0
  367. package/src/components/Tabs/Tabs.vue +0 -4
  368. package/src/index.js +25 -19
  369. package/assets/css/components/actionbar.css +0 -1
  370. package/assets/css/components/actionbar.css.map +0 -1
  371. package/assets/css/components/nav.css +0 -1
  372. package/assets/css/components/nav.css.map +0 -1
  373. package/assets/css/components/table.css +0 -1
  374. package/assets/css/components/table.css.map +0 -1
  375. package/assets/js/components.bundle.js +0 -5
  376. package/assets/js/components.bundle.js.map +0 -1
  377. package/assets/js/components.js +0 -57
  378. package/assets/js/modules/file-upload.js +0 -32
  379. package/assets/ts/components.ts +0 -62
  380. package/assets/ts/modules/file-upload.ts +0 -52
  381. package/dist/style.css +0 -1
  382. package/src/components/Table/Table.spec.js +0 -47
@@ -0,0 +1,68 @@
1
+ // @ts-nocheck
2
+ import '@testing-library/jest-dom';
3
+ import 'expect-puppeteer';
4
+ import iamMultiStep from '../components/multi-step/multi-step.component.js';
5
+ describe('The Multi-step component', () => {
6
+ if (!window.customElements.get(`iam-multi-step`))
7
+ window.customElements.define(`iam-multi-step`, iamMultiStep);
8
+ document.body.innerHTML = `
9
+ <iam-multi-step>
10
+ <form>
11
+ <span class="h3">Multi-step modal title</span>
12
+
13
+ <fieldset data-title="Personal details">
14
+ <div>
15
+ <label for="input1">Name 1</label>
16
+ <input type="text" id="input1" name="input1" placeholder="Optional placeholder text" required="" />
17
+ <span class="invalid-feedback">This field is required</span>
18
+ </div>
19
+ </fieldset>
20
+ <fieldset data-title="Property details">
21
+ <div>
22
+ <label for="input2">Name 2</label>
23
+ <input type="text" id="input2" name="input2" placeholder="Optional placeholder text" required="" />
24
+ <span class="invalid-feedback">This field is required</span>
25
+ </div>
26
+ </fieldset>
27
+ <fieldset data-title="Location">
28
+ <div>
29
+ <label for="input3">Name 3</label>
30
+ <input
31
+ type="text"
32
+ id="input3"
33
+ name="input3"
34
+ placeholder="Optional placeholder text"
35
+ required=""
36
+ class="is-invalid"
37
+ />
38
+ <span class="invalid-feedback">This field is required</span>
39
+ </div>
40
+ </fieldset>
41
+ <fieldset data-title="Submit property">
42
+ <div>
43
+ <label for="input4">Name 4</label>
44
+ <input type="text" id="input4" name="input4" placeholder="Optional placeholder text" required="" />
45
+ <span class="invalid-feedback">This field is required</span>
46
+ </div>
47
+ </fieldset>
48
+ <button class="btn btn-primary colour-success" type="submit">Register</button>
49
+ </form>
50
+
51
+ </iam-multi-step>`;
52
+ test('should add the active class to the first fieldset element', () => {
53
+ let component = document.querySelector('iam-multi-step');
54
+ let fieldset = component.querySelector('fieldset');
55
+ expect(fieldset.classList).toContain('active');
56
+ });
57
+ test('should have a next button added to each fieldset element', () => {
58
+ let component = document.querySelector('iam-multi-step');
59
+ let fieldset = component.querySelector('fieldset');
60
+ let button = fieldset.querySelector('.btn--wrapper button[data-next]');
61
+ expect(button === null || button === void 0 ? void 0 : button.innerHTML).toContain('Next');
62
+ });
63
+ test('should have a steps list created using the data-title attributes for content', () => {
64
+ let component = document.querySelector('iam-multi-step');
65
+ let button = component === null || component === void 0 ? void 0 : component.shadowRoot.querySelector('.steps button');
66
+ expect(button === null || button === void 0 ? void 0 : button.innerHTML).toContain('Personal details');
67
+ });
68
+ });
@@ -59,26 +59,6 @@ describe('addDataAttributes', () => {
59
59
  expect(table.querySelector('tbody tr:nth-child(3) td:nth-child(2)').getAttribute('data-content')).toEqual('medium');
60
60
  });
61
61
  });
62
- describe('createSearchDataList', () => {
63
- const table = document.createElement('table');
64
- table.innerHTML = basicTable;
65
- const form = document.createElement('form');
66
- form.innerHTML += `<div><input name="search" id="search" type="text" class="form-control" data-search="Heading 1"></div>`;
67
- tableModule.addDataAttributes(table);
68
- tableModule.createSearchDataList(table, form);
69
- test('should create a datalist populated by the defined columns in the data-search ', () => {
70
- expect(form.querySelectorAll('datalist').length).toEqual(1);
71
- expect(form.querySelectorAll('datalist option').length).toEqual(2);
72
- expect(form.querySelector('datalist option:nth-child(1)').value).toEqual('Cell 1');
73
- expect(form.querySelector('datalist option:nth-child(2)').value).toEqual('Different Cell 1');
74
- });
75
- test('should set the autocomplete attribute to off', () => {
76
- expect(form.querySelectorAll('datalist').length).toEqual(1);
77
- expect(form.querySelectorAll('datalist option').length).toEqual(2);
78
- expect(form.querySelector('datalist option:nth-child(1)').value).toEqual('Cell 1');
79
- expect(form.querySelector('input').getAttribute('autocomplete')).toEqual('off');
80
- });
81
- });
82
62
  describe('sortTable', () => {
83
63
  const table = document.createElement('table');
84
64
  table.innerHTML = basicTable;
@@ -93,17 +73,6 @@ describe('sortTable', () => {
93
73
  expect(table.querySelector('tbody tr:nth-child(3) td:nth-child(2)').textContent).toEqual('Low');
94
74
  });
95
75
  });
96
- describe('filterTable', () => {
97
- const table = document.createElement('table');
98
- table.innerHTML = basicTable;
99
- const form = document.createElement('form');
100
- form.innerHTML += `<div><input type="text" name="filter" id="filter" data-filter="Heading 2" value="High" /></div>`;
101
- tableModule.addDataAttributes(table);
102
- tableModule.filterTable(table, form, document.createElement('div'));
103
- test('should filter the table to only show high values', () => {
104
- expect(table.querySelectorAll('tbody tr.filtered--matched').length).toEqual(1);
105
- });
106
- });
107
76
  describe('formatCell', () => {
108
77
  test('should format the text correctly', () => {
109
78
  expect(tableModule.formatCell('date', '2023-05-15 12:10:45.000000')).toEqual('15 May 23');
@@ -1,6 +1,9 @@
1
1
  @use '_func' as *;
2
2
 
3
- @include layer('reset') {
3
+ $layers: 'false' !default;
4
+ $mobileOnly: 'false' !default;
5
+
6
+ @include layer('reset', $layers) {
4
7
  // Row
5
8
  //
6
9
  // Rows contain your columns.
@@ -1,141 +1,367 @@
1
1
  @use 'sass:math';
2
2
  @use '_func' as *;
3
3
 
4
- @use 'components/nav.preload';
5
- @use 'components/carousel.config';
6
- @use 'components/multiselect.preload';
7
- @use 'components/inline-edit.preload';
8
- @use 'components/charts.config.scss';
4
+ $layers: 'true' !default;
5
+ $mobileOnly: 'false' !default;
6
+ $darkMode: 'true' !default;
9
7
 
10
- // Make sure the first
11
- main {
12
- position: relative;
8
+ @use 'components/nav.preload' with (
9
+ $layers: $layers,
10
+ $darkMode: $darkMode,
11
+ $mobileOnly: $mobileOnly
12
+ );
13
+ @use 'components/carousel.config' with (
14
+ $layers: $layers,
15
+ $darkMode: $darkMode,
16
+ $mobileOnly: $mobileOnly
17
+ );
18
+ @use 'components/multiselect.preload' with (
19
+ $layers: $layers,
20
+ $darkMode: $darkMode,
21
+ $mobileOnly: $mobileOnly
22
+ );
23
+ @use 'components/inline-edit.preload' with (
24
+ $layers: $layers,
25
+ $darkMode: $darkMode,
26
+ $mobileOnly: $mobileOnly
27
+ );
28
+ @use 'components/charts.config.scss' with (
29
+ $layers: $layers,
30
+ $darkMode: $darkMode,
31
+ $mobileOnly: $mobileOnly
32
+ );
33
+ @use 'components/menu.scss' with (
34
+ $layers: $layers,
35
+ $darkMode: $darkMode,
36
+ $mobileOnly: $mobileOnly
37
+ );
13
38
 
14
- > *:first-child {
15
- padding-top: 2rem;
16
- }
17
- }
39
+ @use 'components/tabs.scss' with (
40
+ $layers: $layers,
41
+ $darkMode: $darkMode,
42
+ $mobileOnly: $mobileOnly
43
+ );
18
44
 
19
- // #region Undefined web components
45
+ @include layer('components', $layers) {
46
+ // Make sure the first
47
+ main {
48
+ position: relative;
20
49
 
21
- @include media-breakpoint-up(md) {
22
- iam-header:not(:defined) {
23
- min-height: rem(470);
50
+ > *:first-child {
51
+ padding-top: 2rem;
52
+ }
24
53
  }
25
- }
26
54
 
27
- // #region Cards
28
- .card:not(:defined) {
29
- box-shadow: var(--card-box-shadow);
30
- border-radius: var(--card-border-radius);
31
- padding: var(--card-top-padding) var(--card-right-padding) var(--card-bottom-padding) var(--card-left-padding);
32
- }
55
+ // #region Undefined web components
33
56
 
34
- .row
35
- [class*='col']:has(
36
- label:first-child:last-child .card:defined:first-child:last-child,
37
- button:first-child:last-child .card:defined:first-child:last-child,
38
- a:first-child:last-child .card:defined:first-child:last-child
39
- ) {
40
- display: flex;
41
- }
42
-
43
- iam-card:has([type='checkbox']:checked) {
44
- --hover-outline-colour: var(--colour-info);
45
- --outline-colour: var(--colour-info);
46
- }
57
+ @include media-breakpoint-up(md, $mobileOnly) {
58
+ iam-header:not(:defined) {
59
+ min-height: rem(470);
60
+ }
61
+ }
47
62
 
48
- label:has(.card) {
49
- padding: 0 !important;
50
- margin-right: 0 !important;
63
+ // #region Cards
64
+ .card:not(:defined) {
65
+ box-shadow: var(--card-box-shadow);
66
+ border-radius: var(--card-border-radius);
67
+ padding: var(--card-top-padding) var(--card-right-padding) var(--card-bottom-padding) var(--card-left-padding);
68
+ }
51
69
 
52
- &:before,
53
- &:after {
54
- display: none !important;
70
+ .row
71
+ [class*='col']:has(
72
+ label:first-child:last-child .card:defined:first-child:last-child,
73
+ button:first-child:last-child .card:defined:first-child:last-child,
74
+ a:first-child:last-child .card:defined:first-child:last-child
75
+ ) {
76
+ display: flex;
55
77
  }
56
78
 
57
- .optional-text {
58
- display: none;
79
+ iam-card:has([type='checkbox']:checked) {
80
+ --hover-outline-colour: var(--colour-info);
81
+ --outline-colour: var(--colour-info);
59
82
  }
60
83
 
61
- &:has(:checked) {
62
- .card:defined {
63
- outline: 2px solid var(--colour, var(--colour-primary));
64
- outline-offset: -2px;
84
+ label:has(.card) {
85
+ padding: 0 !important;
86
+ margin-right: 0 !important;
65
87
 
66
- ::part(body) {
67
- background: none;
68
- }
69
- ::part(footer) {
70
- background: none;
88
+ &:before,
89
+ &:after {
90
+ display: none !important;
91
+ }
92
+
93
+ .optional-text {
94
+ display: none;
95
+ }
96
+
97
+ &:has(:checked) {
98
+ .card:defined {
99
+ outline: 2px solid var(--colour, var(--colour-primary));
100
+ outline-offset: -2px;
101
+
102
+ ::part(body) {
103
+ background: none;
104
+ }
105
+
106
+ ::part(footer) {
107
+ background: none;
108
+ }
71
109
  }
72
110
  }
73
111
  }
74
- }
75
112
 
76
- iam-filter-card:not(:has(i)) {
77
- border-left: 0.75rem solid var(--colour, var(--colour-primary));
78
- }
113
+ iam-filter-card:not(:has(i)) {
114
+ border-left: 0.75rem solid var(--colour, var(--colour-primary));
115
+ }
79
116
 
80
- .card .badge:not([class*='bg-']):not([class*='wider-colour-']) {
81
- background-color: var(--colour-canvas);
82
- outline: 1px solid var(--colour-light);
83
- }
117
+ .card .badge:not([class*='bg-']):not([class*='wider-colour-']) {
118
+ background-color: var(--colour-canvas);
119
+ outline: 1px solid var(--colour-light);
120
+ }
84
121
 
85
- a[target='_blank'] .card {
86
- --icon: var(--icon-new-tab);
87
- }
122
+ a[target='_blank'] .card {
123
+ --icon: var(--icon-new-tab);
124
+ }
88
125
 
89
- // #endregion
126
+ // #endregion
90
127
 
91
- // Search
92
- iam-search input:not(.is-invalid):not(:invalid) {
93
- background: none !important;
94
- }
95
- iam-search .optional-text {
96
- display: none !important;
97
- }
128
+ // Search
129
+ iam-search input:not(.is-invalid):not(:invalid) {
130
+ background: none !important;
131
+ }
98
132
 
99
- // Table dark mode support
100
- iam-table {
101
- tbody tr {
102
- @include dark-mode() {
103
- --hover-background: var(--colour-canvas);
133
+ iam-search .optional-text {
134
+ display: none !important;
135
+ }
104
136
 
105
- &:is(:hover, :focus-within, .hover) {
106
- background: var(--row-bg);
137
+ // Table dark mode support
138
+ iam-table {
139
+ tbody tr {
140
+ @include dark-mode($darkMode) {
141
+ --hover-background: var(--colour-canvas);
142
+
143
+ &:is(:hover, :focus-within, .hover) {
144
+ background: var(--row-bg);
145
+ }
107
146
  }
108
147
  }
109
148
  }
110
- }
111
149
 
112
- @container (width > 23.4375em) {
113
- iam-table.table--cta:not(.table--loading):not(:has(tr:first-child td:first-child:last-child)) {
114
- tr > *:not(:first-child):last-child {
115
- @media screen and (prefers-color-scheme: dark) {
116
- background: linear-gradient(90deg, transparent 0%, var(--row-bg) 1.25rem);
150
+ @container (width > 23.4375em) {
151
+ iam-table.table--cta:not(.table--loading):not(:has(tr:first-child td:first-child:last-child)) {
152
+ tr > *:not(:first-child):last-child {
153
+ @media screen and (prefers-color-scheme: dark) {
154
+ background: linear-gradient(90deg, transparent 0%, var(--row-bg) 1.25rem);
155
+ }
117
156
  }
118
157
  }
119
158
  }
120
- }
121
159
 
122
- iam-table {
123
- tr:has([type='checkbox']:checked) {
124
- @include dark-mode() {
125
- --row-bg: #000000;
160
+ iam-table {
161
+ tr:has([type='checkbox']:checked) {
162
+ @include dark-mode($darkMode) {
163
+ --row-bg: #000000;
164
+ }
126
165
  }
127
166
  }
128
- }
129
167
 
130
- iam-pagination {
131
- --pagination-link-color: var(--colour-light);
132
- --pagination-link-color-active: #e0e0e0;
133
- }
168
+ iam-pagination {
169
+ --pagination-link-color: var(--colour-light);
170
+ --pagination-link-color-active: #e0e0e0;
171
+ }
172
+
173
+ iam-fileupload::part(file) {
174
+ @include dark-mode($darkMode) {
175
+ background: var(--colour-canvas-2);
176
+ border-color: var(--colour-canvas-2);
177
+ color: var(--colour-body);
178
+ }
179
+ }
180
+
181
+ iam-bento-grid {
182
+ details {
183
+ summary {
184
+ position: relative;
185
+ height: 100%;
186
+ width: 100%;
187
+ max-width: 100%;
188
+ padding: 1.5rem;
189
+ margin-bottom: 0;
190
+
191
+ [role='presentation'] {
192
+ display: block;
193
+ font-family: var(--font-body);
194
+ font-weight: normal;
195
+ font-size: 1rem;
196
+ position: relative;
197
+ width: fit-content;
198
+ //margin-bottom: 2rem;
199
+ opacity: 0;
200
+ transition: opacity 1s;
201
+
202
+ &:before {
203
+ display: block;
204
+ content: ' ';
205
+ position: absolute;
206
+ top: 100%;
207
+ left: 50%;
208
+ width: 100%;
209
+ height: 0;
210
+ border: 1px solid currentColor;
211
+ transform: translate(-50%, 0);
212
+ transition: 1s;
213
+ }
134
214
 
135
- iam-fileupload::part(file) {
136
- @include dark-mode() {
137
- background: var(--colour-canvas-2);
138
- border-color: var(--colour-canvas-2);
139
- color: var(--colour-body);
215
+ &:after {
216
+ display: inline-block;
217
+ content: '\f061';
218
+ top: 100%;
219
+ margin-left: 0.5em;
220
+ line-height: 1em;
221
+ font-size: 1em;
222
+ font-family: 'Font Awesome 6 Pro';
223
+ }
224
+ }
225
+
226
+ &::after {
227
+ opacity: 0;
228
+ content: '\f422';
229
+ pointer-events: all;
230
+ top: 1.5rem;
231
+ right: 1.5rem;
232
+ left: auto;
233
+ position: absolute;
234
+ line-height: 1em;
235
+ font-size: 1em;
236
+ font-family: 'Font Awesome 6 Pro';
237
+ }
238
+
239
+ &:hover {
240
+ [role='presentation'] {
241
+ display: block;
242
+ font-family: var(--font-body);
243
+ font-weight: normal;
244
+ font-size: 1rem;
245
+ position: relative;
246
+ width: fit-content;
247
+
248
+ &:before {
249
+ width: 80%;
250
+ }
251
+ }
252
+ }
253
+ }
254
+
255
+ &:before {
256
+ content: '';
257
+ position: absolute;
258
+ display: block;
259
+ top: 30%;
260
+ left: 40%;
261
+ height: 70%;
262
+ aspect-ratio: 2 / 1;
263
+
264
+ background-image: var(--bg);
265
+ background-repeat: no-repeat;
266
+ background-size: cover;
267
+ border-radius: 0.5rem;
268
+ transition: 1s;
269
+ }
270
+
271
+ &:hover:before {
272
+ left: 35%;
273
+ top: 25%;
274
+ height: 75%;
275
+ }
276
+
277
+ &[open]:before {
278
+ left: 50% !important;
279
+ top: 30% !important;
280
+ height: 70% !important;
281
+ }
282
+
283
+ &::details-content {
284
+ opacity: 0;
285
+
286
+ padding: 0 1.5rem 1.5rem 1.5rem;
287
+ transition: 1s;
288
+
289
+ overflow: auto;
290
+ }
291
+ }
292
+
293
+ details {
294
+ summary:hover {
295
+ [role='presentation'] {
296
+ opacity: 1;
297
+ }
298
+ }
299
+ }
300
+
301
+ @container (width > 40em) {
302
+ details summary {
303
+ position: sticky;
304
+ top: 0;
305
+ left: 0;
306
+ }
307
+ }
308
+
309
+ details[open] {
310
+ &:not(.animating)::details-content {
311
+ opacity: 1;
312
+ }
313
+
314
+ > *:last-child {
315
+ padding-bottom: 0;
316
+ margin-bottom: 0;
317
+ }
318
+
319
+ summary {
320
+ pointer-events: none;
321
+ width: 100%;
322
+ max-width: 100%;
323
+ height: fit-content;
324
+
325
+ [role='presentation'] {
326
+ opacity: 0;
327
+ }
328
+
329
+ [role='presentation'] {
330
+ margin-bottom: -2rem;
331
+ }
332
+
333
+ &:after {
334
+ opacity: 1;
335
+ }
336
+ }
337
+ }
338
+
339
+ :is(details)::-webkit-scrollbar {
340
+ width: 4px;
341
+ height: 4px;
342
+ }
343
+
344
+ :is(details)::-webkit-scrollbar-track {
345
+ background-color: #00313c;
346
+ border-top: none;
347
+ border-left: 4px solid transparent;
348
+ }
349
+
350
+ :is(details)::-webkit-scrollbar-thumb {
351
+ background-color: white;
352
+ width: 4px;
353
+ border-top: none;
354
+ border-left: none;
355
+ }
356
+
357
+ details[open] {
358
+ position: relative;
359
+ }
360
+ }
361
+
362
+ @supports selector(::details-content) {
363
+ .notice {
364
+ display: none;
365
+ }
140
366
  }
141
367
  }
@@ -1,32 +1,56 @@
1
1
  @use 'sass:math';
2
2
  @use '_func' as *;
3
3
 
4
- @layer reset, elements, components, templates, overrides, utilities;
5
-
6
4
  $root: ':root' !default;
7
5
  $layers: 'true' !default;
6
+ $mobileOnly: 'false' !default;
7
+ $darkMode: 'true' !default;
8
+ $optionalText: 'true' !default;
8
9
 
9
10
  // Foundations
10
- @include layer('reset') {
11
- @import 'foundations/root.scss';
12
- @import 'foundations/reboot.scss';
13
- }
11
+ @use 'foundations/root.scss' with (
12
+ $root: $root,
13
+ $layers: $layers,
14
+ $mobileOnly: $mobileOnly,
15
+ $darkMode: $darkMode
16
+ );
14
17
 
15
- @include layer('elements') {
16
- @import '_elements.scss';
17
- }
18
+ @use 'foundations/reboot.scss' with (
19
+ $layers: $layers,
20
+ $mobileOnly: $mobileOnly,
21
+ $darkMode: $darkMode
22
+ );
18
23
 
19
- @include layer('components') {
20
- // Deal with preloaded state of native components
21
- @import '_components.scss';
22
- }
24
+ // Elements
25
+ @use '_elements.scss' with (
26
+ $layers: $layers,
27
+ $mobileOnly: $mobileOnly,
28
+ $darkMode: $darkMode,
29
+ $optionalText: $optionalText
30
+ );
23
31
 
24
- @include layer('templates') {
25
- @import 'templates/form.scss';
26
- @import 'templates/auth.scss';
27
- }
32
+ // Components
33
+ @use '_components.scss' with (
34
+ $layers: $layers,
35
+ $mobileOnly: $mobileOnly,
36
+ $darkMode: $darkMode
37
+ );
38
+
39
+ // Templates
40
+ @use 'templates/form.scss' with (
41
+ $layers: $layers,
42
+ $mobileOnly: $mobileOnly,
43
+ $darkMode: $darkMode
44
+ );
45
+
46
+ @use 'templates/auth.scss' with (
47
+ $layers: $layers,
48
+ $mobileOnly: $mobileOnly,
49
+ $darkMode: $darkMode
50
+ );
28
51
 
29
- @include layer('overrides') {
52
+ // Overrides
53
+ @include layer('overrides', $layers) {
30
54
  @media (prefers-reduced-motion) {
31
55
  * {
32
56
  transition: unset;