@theseam/ui-common 0.2.12 → 0.2.13

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 (327) hide show
  1. package/assets/vendor/intl-tel-input/js/utils.js +255 -254
  2. package/bundles/theseam-ui-common-asset-reader.umd.js +7 -9
  3. package/bundles/theseam-ui-common-asset-reader.umd.js.map +1 -1
  4. package/bundles/theseam-ui-common-breadcrumbs.umd.js +6 -8
  5. package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +1 -1
  6. package/bundles/theseam-ui-common-buttons.umd.js +5 -5
  7. package/bundles/theseam-ui-common-buttons.umd.js.map +1 -1
  8. package/bundles/theseam-ui-common-card.umd.js +6 -6
  9. package/bundles/theseam-ui-common-card.umd.js.map +1 -1
  10. package/bundles/theseam-ui-common-checkbox.umd.js +4 -4
  11. package/bundles/theseam-ui-common-checkbox.umd.js.map +1 -1
  12. package/bundles/theseam-ui-common-confirm-dialog.umd.js +4 -4
  13. package/bundles/theseam-ui-common-confirm-dialog.umd.js.map +1 -1
  14. package/bundles/theseam-ui-common-core.umd.js +4 -4
  15. package/bundles/theseam-ui-common-core.umd.js.map +1 -1
  16. package/bundles/theseam-ui-common-data-exporter.umd.js +5 -5
  17. package/bundles/theseam-ui-common-data-filters.umd.js +9 -6
  18. package/bundles/theseam-ui-common-data-filters.umd.js.map +1 -1
  19. package/bundles/theseam-ui-common-datatable-dynamic.umd.js +7 -7
  20. package/bundles/theseam-ui-common-datatable-dynamic.umd.js.map +1 -1
  21. package/bundles/theseam-ui-common-datatable.umd.js +1308 -375
  22. package/bundles/theseam-ui-common-datatable.umd.js.map +1 -1
  23. package/bundles/theseam-ui-common-dynamic-component-loader.umd.js +5 -7
  24. package/bundles/theseam-ui-common-dynamic-component-loader.umd.js.map +1 -1
  25. package/bundles/theseam-ui-common-dynamic.umd.js +7 -9
  26. package/bundles/theseam-ui-common-dynamic.umd.js.map +1 -1
  27. package/bundles/theseam-ui-common-footer-bar.umd.js +3 -3
  28. package/bundles/theseam-ui-common-form-field-error.umd.js +5 -5
  29. package/bundles/theseam-ui-common-form-field-error.umd.js.map +1 -1
  30. package/bundles/theseam-ui-common-form-field.umd.js +5 -5
  31. package/bundles/theseam-ui-common-form-field.umd.js.map +1 -1
  32. package/bundles/theseam-ui-common-framework.umd.js +27 -29
  33. package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
  34. package/bundles/theseam-ui-common-graphql.umd.js +958 -8
  35. package/bundles/theseam-ui-common-graphql.umd.js.map +1 -1
  36. package/bundles/theseam-ui-common-icon.umd.js +5 -5
  37. package/bundles/theseam-ui-common-icon.umd.js.map +1 -1
  38. package/bundles/theseam-ui-common-layout.umd.js +5 -7
  39. package/bundles/theseam-ui-common-layout.umd.js.map +1 -1
  40. package/bundles/theseam-ui-common-loading.umd.js +4 -4
  41. package/bundles/theseam-ui-common-menu.umd.js +5 -5
  42. package/bundles/theseam-ui-common-menu.umd.js.map +1 -1
  43. package/bundles/theseam-ui-common-modal.umd.js +6 -6
  44. package/bundles/theseam-ui-common-modal.umd.js.map +1 -1
  45. package/bundles/theseam-ui-common-models.umd.js +3 -3
  46. package/bundles/theseam-ui-common-popover.umd.js +4 -4
  47. package/bundles/theseam-ui-common-progress.umd.js +5 -5
  48. package/bundles/theseam-ui-common-progress.umd.js.map +1 -1
  49. package/bundles/theseam-ui-common-scrollbar.umd.js +7 -9
  50. package/bundles/theseam-ui-common-scrollbar.umd.js.map +1 -1
  51. package/bundles/theseam-ui-common-services.umd.js +6 -8
  52. package/bundles/theseam-ui-common-services.umd.js.map +1 -1
  53. package/bundles/theseam-ui-common-shared.umd.js +4 -4
  54. package/bundles/theseam-ui-common-shared.umd.js.map +1 -1
  55. package/bundles/theseam-ui-common-storage.umd.js +5 -7
  56. package/bundles/theseam-ui-common-storage.umd.js.map +1 -1
  57. package/bundles/theseam-ui-common-story-helpers.umd.js +4 -4
  58. package/bundles/theseam-ui-common-story-helpers.umd.js.map +1 -1
  59. package/bundles/theseam-ui-common-tabbed.umd.js +5 -5
  60. package/bundles/theseam-ui-common-tabbed.umd.js.map +1 -1
  61. package/bundles/theseam-ui-common-table-cell-type.umd.js +5 -7
  62. package/bundles/theseam-ui-common-table-cell-type.umd.js.map +1 -1
  63. package/bundles/theseam-ui-common-table-cell-types.umd.js +16 -16
  64. package/bundles/theseam-ui-common-table-cell-types.umd.js.map +1 -1
  65. package/bundles/theseam-ui-common-table.umd.js +5 -5
  66. package/bundles/theseam-ui-common-table.umd.js.map +1 -1
  67. package/bundles/theseam-ui-common-tel-input.umd.js +6 -6
  68. package/bundles/theseam-ui-common-tel-input.umd.js.map +1 -1
  69. package/bundles/theseam-ui-common-testing.umd.js +568 -0
  70. package/bundles/theseam-ui-common-testing.umd.js.map +1 -0
  71. package/bundles/theseam-ui-common-tiled-select.umd.js +56 -39
  72. package/bundles/theseam-ui-common-tiled-select.umd.js.map +1 -1
  73. package/bundles/theseam-ui-common-toggle-edit.umd.js +8 -10
  74. package/bundles/theseam-ui-common-toggle-edit.umd.js.map +1 -1
  75. package/bundles/theseam-ui-common-toggle-group.umd.js +4 -4
  76. package/bundles/theseam-ui-common-toggle-group.umd.js.map +1 -1
  77. package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js +5 -7
  78. package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js.map +1 -1
  79. package/bundles/theseam-ui-common-utils.umd.js +174 -81
  80. package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
  81. package/bundles/theseam-ui-common-validators.umd.js +3 -3
  82. package/bundles/theseam-ui-common-viewers.umd.js +6 -8
  83. package/bundles/theseam-ui-common-viewers.umd.js.map +1 -1
  84. package/bundles/theseam-ui-common-widget.umd.js +18 -20
  85. package/bundles/theseam-ui-common-widget.umd.js.map +1 -1
  86. package/bundles/theseam-ui-common.umd.js +2 -2
  87. package/buttons/theseam-ui-common-buttons.metadata.json +1 -1
  88. package/card/theseam-ui-common-card.metadata.json +1 -1
  89. package/data-filters/data-filter.d.ts +10 -6
  90. package/data-filters/theseam-ui-common-data-filters.metadata.json +1 -1
  91. package/datatable/datatable/datatable.component.d.ts +46 -32
  92. package/datatable/datatable-column/datatable-column.component.d.ts +26 -25
  93. package/datatable/datatable-column-preferences/datatable-column-preferences.component.d.ts +7 -5
  94. package/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.d.ts +7 -1
  95. package/datatable/datatable-menu-bar/datatable-menu-bar.component.d.ts +1 -1
  96. package/datatable/directives/datatable-filter.directive.d.ts +1 -1
  97. package/datatable/models/columns-alteration.d.ts +61 -0
  98. package/datatable/models/columns-alterations/hide-column.columns-alteration.d.ts +15 -0
  99. package/datatable/models/columns-alterations/order.columns-alteration.d.ts +20 -0
  100. package/datatable/models/columns-alterations/sort.columns-alteration.d.ts +14 -0
  101. package/datatable/models/columns-alterations/width.columns-alteration.d.ts +16 -0
  102. package/datatable/models/datatable-accessor.d.ts +5 -3
  103. package/datatable/models/internal-column-props.d.ts +7 -0
  104. package/datatable/models/page-info.d.ts +12 -0
  105. package/datatable/models/preferences-accessor.d.ts +1 -1
  106. package/datatable/models/preferences.d.ts +11 -3
  107. package/datatable/models/sort-item.d.ts +2 -1
  108. package/datatable/services/columns-alterations-manager.service.d.ts +39 -0
  109. package/datatable/services/columns-manager.service.d.ts +55 -0
  110. package/datatable/services/datatable-preferences.service.d.ts +10 -7
  111. package/datatable/theseam-ui-common-datatable.d.ts +2 -0
  112. package/datatable/theseam-ui-common-datatable.metadata.json +1 -1
  113. package/datatable/tokens/datatable-preferences-accessor.d.ts +2 -2
  114. package/datatable/utils/create-action-menu-column.d.ts +3 -0
  115. package/datatable/utils/create-checkbox-column.d.ts +3 -0
  116. package/datatable/utils/get-column-prop.d.ts +5 -0
  117. package/datatable/utils/map-columns-alterations-states.d.ts +2 -0
  118. package/datatable/utils/remove-unused-diffs.d.ts +7 -0
  119. package/datatable/utils/set-column-defaults.d.ts +2 -0
  120. package/datatable/utils/translate-templates.d.ts +2 -0
  121. package/datatable/utils/with-stored-column-info.d.ts +2 -2
  122. package/datatable-dynamic/theseam-ui-common-datatable-dynamic.metadata.json +1 -1
  123. package/esm2015/buttons/progress-circle-button/progress-circle-button.component.js +1 -1
  124. package/esm2015/card/card-action/card-action.component.js +1 -1
  125. package/esm2015/card/card-body/card-body.component.js +1 -1
  126. package/esm2015/data-filters/data-filter.js +5 -2
  127. package/esm2015/data-filters/filters/data-filter-search/data-filter-search.component.js +1 -1
  128. package/esm2015/data-filters/filters/data-filter-text/data-filter-text.component.js +1 -1
  129. package/esm2015/datatable/datatable/datatable.component.js +195 -211
  130. package/esm2015/datatable/datatable-action-menu/datatable-action-menu.component.js +1 -1
  131. package/esm2015/datatable/datatable-column/datatable-column.component.js +1 -1
  132. package/esm2015/datatable/datatable-column-preferences/datatable-column-preferences.component.js +42 -19
  133. package/esm2015/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.js +38 -4
  134. package/esm2015/datatable/datatable-export-button/datatable-export-button.component.js +1 -1
  135. package/esm2015/datatable/datatable-menu-bar/datatable-menu-bar.component.js +1 -1
  136. package/esm2015/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.js +1 -1
  137. package/esm2015/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.js +1 -1
  138. package/esm2015/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.js +1 -1
  139. package/esm2015/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.js +1 -1
  140. package/esm2015/datatable/models/columns-alteration.js +38 -0
  141. package/esm2015/datatable/models/columns-alterations/hide-column.columns-alteration.js +38 -0
  142. package/esm2015/datatable/models/columns-alterations/order.columns-alteration.js +81 -0
  143. package/esm2015/datatable/models/columns-alterations/sort.columns-alteration.js +33 -0
  144. package/esm2015/datatable/models/columns-alterations/width.columns-alteration.js +41 -0
  145. package/esm2015/datatable/models/datatable-accessor.js +1 -1
  146. package/esm2015/datatable/models/internal-column-props.js +15 -0
  147. package/esm2015/datatable/models/page-info.js +1 -1
  148. package/esm2015/datatable/models/preferences-accessor.js +1 -1
  149. package/esm2015/datatable/models/preferences.js +6 -2
  150. package/esm2015/datatable/models/sort-item.js +1 -1
  151. package/esm2015/datatable/services/columns-alterations-manager.service.js +134 -0
  152. package/esm2015/datatable/services/columns-manager.service.js +257 -0
  153. package/esm2015/datatable/services/datatable-preferences.service.js +78 -32
  154. package/esm2015/datatable/theseam-ui-common-datatable.js +3 -1
  155. package/esm2015/datatable/tokens/datatable-preferences-accessor.js +2 -2
  156. package/esm2015/datatable/utils/create-action-menu-column.js +18 -0
  157. package/esm2015/datatable/utils/create-checkbox-column.js +15 -0
  158. package/esm2015/datatable/utils/get-column-prop.js +9 -0
  159. package/esm2015/datatable/utils/map-columns-alterations-states.js +39 -0
  160. package/esm2015/datatable/utils/remove-unused-diffs.js +9 -0
  161. package/esm2015/datatable/utils/set-column-defaults.js +10 -0
  162. package/esm2015/datatable/utils/translate-templates.js +12 -0
  163. package/esm2015/datatable/utils/with-stored-column-info.js +1 -1
  164. package/esm2015/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.js +1 -1
  165. package/esm2015/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.js +1 -1
  166. package/esm2015/datatable-dynamic/datatable-dynamic.component.js +1 -1
  167. package/esm2015/form-field/form-field.component.js +1 -1
  168. package/esm2015/form-field-error/form-field-error/form-field-error.component.js +1 -1
  169. package/esm2015/framework/base-layout/base-layout.component.js +1 -1
  170. package/esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets.component.js +1 -1
  171. package/esm2015/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.js +1 -1
  172. package/esm2015/framework/schema-form-controls/schema-form-input/schema-form-input.component.js +1 -1
  173. package/esm2015/framework/schema-form-controls/schema-form-number/schema-form-number.component.js +1 -1
  174. package/esm2015/framework/schema-form-controls/schema-form-select/schema-form-select.component.js +1 -1
  175. package/esm2015/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.js +1 -1
  176. package/esm2015/framework/side-nav/side-nav-item/side-nav-item.component.js +1 -1
  177. package/esm2015/framework/side-nav/side-nav-toggle/side-nav-toggle.component.js +1 -1
  178. package/esm2015/framework/side-nav/side-nav.component.js +1 -1
  179. package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +1 -1
  180. package/esm2015/framework/top-bar/top-bar-title/top-bar-title.component.js +1 -1
  181. package/esm2015/framework/top-bar/top-bar.component.js +1 -1
  182. package/esm2015/graphql/datatable/create-page-info-observable.js +38 -0
  183. package/esm2015/graphql/datatable/datatable-graphql-query-ref.js +236 -0
  184. package/esm2015/graphql/datatable/datatable-graphql.service.js +35 -0
  185. package/esm2015/graphql/datatable/datatable-helpers.js +170 -0
  186. package/esm2015/graphql/datatable/get-page-info.js +11 -0
  187. package/esm2015/graphql/datatable/index.js +7 -0
  188. package/esm2015/graphql/datatable/map-filter-states.js +64 -0
  189. package/esm2015/graphql/datatable/map-page-info.js +14 -0
  190. package/esm2015/graphql/datatable/mapper-context.js +2 -0
  191. package/esm2015/graphql/models/gql-datatable-accessor.js +2 -0
  192. package/esm2015/graphql/models/index.js +2 -1
  193. package/esm2015/graphql/models/query-processing-config.js +1 -1
  194. package/esm2015/graphql/public-api.js +2 -1
  195. package/esm2015/graphql/utils/parse-hints.js +3 -3
  196. package/esm2015/icon/icon/icon.component.js +1 -1
  197. package/esm2015/loading/loading/loading.component.js +1 -1
  198. package/esm2015/menu/menu.component.js +1 -1
  199. package/esm2015/modal/modal-body/modal-body.component.js +1 -1
  200. package/esm2015/modal/modal-container/modal-container.component.js +1 -1
  201. package/esm2015/popover/popover/popover.component.js +1 -1
  202. package/esm2015/progress/progress-circle/progress-circle.component.js +1 -1
  203. package/esm2015/tabbed/tabbed.component.js +1 -1
  204. package/esm2015/table/table/table.component.js +1 -1
  205. package/esm2015/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.js +1 -1
  206. package/esm2015/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.js +1 -1
  207. package/esm2015/tel-input/tel-input/tel-input.component.js +1 -1
  208. package/esm2015/testing/current-tick-time.js +16 -0
  209. package/esm2015/testing/fake-toastr.js +29 -0
  210. package/esm2015/testing/get-harness.js +16 -0
  211. package/esm2015/testing/public-api.js +7 -0
  212. package/esm2015/testing/render-story.js +12 -0
  213. package/esm2015/testing/story-expect.js +39 -0
  214. package/esm2015/testing/theseam-ui-common-testing.js +5 -0
  215. package/esm2015/testing/tick-helper.js +74 -0
  216. package/esm2015/tiled-select/components/tiled-select/tiled-select.component.js +25 -17
  217. package/esm2015/tiled-select/components/tiled-select-tile/tiled-select-tile.component.js +5 -2
  218. package/esm2015/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.js +1 -1
  219. package/esm2015/tiled-select/public-api.js +2 -1
  220. package/esm2015/tiled-select/tiled-select.models.js +1 -1
  221. package/esm2015/tiled-select/tiled-select.module.js +4 -4
  222. package/esm2015/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.js +1 -1
  223. package/esm2015/toggle-edit/toggle-edit.component.js +1 -1
  224. package/esm2015/utils/array-move.js +62 -0
  225. package/esm2015/utils/public-api.js +2 -1
  226. package/esm2015/utils/router/is-empty-url-route.js +1 -1
  227. package/esm2015/utils/subscriber-count.js +31 -4
  228. package/esm2015/widget/widget/widget.component.js +1 -1
  229. package/esm2015/widget/widget-content-components/widget-button-group/widget-button-group.component.js +1 -1
  230. package/esm2015/widget/widget-content-components/widget-content-header/widget-content-header.component.js +1 -1
  231. package/esm2015/widget/widget-content-components/widget-empty-label/widget-empty-label.component.js +1 -1
  232. package/esm2015/widget/widget-content-components/widget-footer-link/widget-footer-link.component.js +1 -1
  233. package/esm2015/widget/widget-content-components/widget-footer-text/widget-footer-text.component.js +1 -1
  234. package/esm2015/widget/widget-content-components/widget-header-badge/widget-header-badge.component.js +1 -1
  235. package/esm2015/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.js +1 -1
  236. package/esm2015/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.js +1 -1
  237. package/esm2015/widget/widget-content-components/widget-tile/widget-tile.component.js +1 -1
  238. package/esm2015/widget/widget-content-components/widget-tile-list/widget-tile-list.component.js +1 -1
  239. package/esm2015/widget/widget-footer/widget-footer.component.js +1 -1
  240. package/fesm2015/theseam-ui-common-buttons.js +1 -1
  241. package/fesm2015/theseam-ui-common-card.js +2 -2
  242. package/fesm2015/theseam-ui-common-data-filters.js +6 -3
  243. package/fesm2015/theseam-ui-common-data-filters.js.map +1 -1
  244. package/fesm2015/theseam-ui-common-datatable-dynamic.js +3 -3
  245. package/fesm2015/theseam-ui-common-datatable.js +1101 -316
  246. package/fesm2015/theseam-ui-common-datatable.js.map +1 -1
  247. package/fesm2015/theseam-ui-common-form-field-error.js +1 -1
  248. package/fesm2015/theseam-ui-common-form-field.js +1 -1
  249. package/fesm2015/theseam-ui-common-framework.js +13 -13
  250. package/fesm2015/theseam-ui-common-graphql.js +555 -5
  251. package/fesm2015/theseam-ui-common-graphql.js.map +1 -1
  252. package/fesm2015/theseam-ui-common-icon.js +1 -1
  253. package/fesm2015/theseam-ui-common-loading.js +1 -1
  254. package/fesm2015/theseam-ui-common-menu.js +1 -1
  255. package/fesm2015/theseam-ui-common-modal.js +2 -2
  256. package/fesm2015/theseam-ui-common-popover.js +1 -1
  257. package/fesm2015/theseam-ui-common-progress.js +1 -1
  258. package/fesm2015/theseam-ui-common-tabbed.js +1 -1
  259. package/fesm2015/theseam-ui-common-table-cell-types.js +2 -2
  260. package/fesm2015/theseam-ui-common-table.js +1 -1
  261. package/fesm2015/theseam-ui-common-tel-input.js +1 -1
  262. package/fesm2015/theseam-ui-common-testing.js +191 -0
  263. package/fesm2015/theseam-ui-common-testing.js.map +1 -0
  264. package/fesm2015/theseam-ui-common-tiled-select.js +34 -21
  265. package/fesm2015/theseam-ui-common-tiled-select.js.map +1 -1
  266. package/fesm2015/theseam-ui-common-toggle-edit.js +2 -2
  267. package/fesm2015/theseam-ui-common-utils.js +92 -4
  268. package/fesm2015/theseam-ui-common-utils.js.map +1 -1
  269. package/fesm2015/theseam-ui-common-widget.js +12 -12
  270. package/form-field/theseam-ui-common-form-field.metadata.json +1 -1
  271. package/form-field-error/theseam-ui-common-form-field-error.metadata.json +1 -1
  272. package/framework/theseam-ui-common-framework.metadata.json +1 -1
  273. package/graphql/datatable/create-page-info-observable.d.ts +4 -0
  274. package/graphql/datatable/datatable-graphql-query-ref.d.ts +65 -0
  275. package/graphql/datatable/datatable-graphql.service.d.ts +26 -0
  276. package/graphql/datatable/datatable-helpers.d.ts +12 -0
  277. package/graphql/datatable/get-page-info.d.ts +4 -0
  278. package/graphql/datatable/index.d.ts +6 -0
  279. package/graphql/datatable/map-filter-states.d.ts +18 -0
  280. package/graphql/datatable/map-page-info.d.ts +11 -0
  281. package/graphql/datatable/mapper-context.d.ts +6 -0
  282. package/graphql/models/gql-datatable-accessor.d.ts +9 -0
  283. package/graphql/models/index.d.ts +1 -0
  284. package/graphql/models/query-processing-config.d.ts +4 -0
  285. package/graphql/public-api.d.ts +1 -0
  286. package/graphql/theseam-ui-common-graphql.metadata.json +1 -1
  287. package/icon/theseam-ui-common-icon.metadata.json +1 -1
  288. package/loading/theseam-ui-common-loading.metadata.json +1 -1
  289. package/menu/theseam-ui-common-menu.metadata.json +1 -1
  290. package/modal/theseam-ui-common-modal.metadata.json +1 -1
  291. package/package.json +1 -1
  292. package/popover/theseam-ui-common-popover.metadata.json +1 -1
  293. package/progress/theseam-ui-common-progress.metadata.json +1 -1
  294. package/tabbed/theseam-ui-common-tabbed.metadata.json +1 -1
  295. package/table/theseam-ui-common-table.metadata.json +1 -1
  296. package/table-cell-types/theseam-ui-common-table-cell-types.metadata.json +1 -1
  297. package/tel-input/theseam-ui-common-tel-input.metadata.json +1 -1
  298. package/testing/current-tick-time.d.ts +13 -0
  299. package/testing/fake-toastr.d.ts +30 -0
  300. package/testing/get-harness.d.ts +7 -0
  301. package/testing/package.json +11 -0
  302. package/testing/public-api.d.ts +6 -0
  303. package/testing/render-story.d.ts +2 -0
  304. package/testing/story-expect.d.ts +5 -0
  305. package/{test-helpers/theseam-ui-common-test-helpers.d.ts → testing/theseam-ui-common-testing.d.ts} +0 -0
  306. package/testing/theseam-ui-common-testing.metadata.json +1 -0
  307. package/{test-helpers → testing}/tick-helper.d.ts +0 -0
  308. package/tiled-select/components/tiled-select/tiled-select.component.d.ts +7 -3
  309. package/tiled-select/components/tiled-select-tile/tiled-select-tile.component.d.ts +1 -0
  310. package/tiled-select/theseam-ui-common-tiled-select.metadata.json +1 -1
  311. package/tiled-select/tiled-select.models.d.ts +3 -1
  312. package/toggle-edit/theseam-ui-common-toggle-edit.metadata.json +1 -1
  313. package/utils/array-move.d.ts +49 -0
  314. package/utils/public-api.d.ts +1 -0
  315. package/utils/subscriber-count.d.ts +13 -1
  316. package/utils/theseam-ui-common-utils.metadata.json +1 -1
  317. package/widget/theseam-ui-common-widget.metadata.json +1 -1
  318. package/bundles/theseam-ui-common-test-helpers.umd.js +0 -94
  319. package/bundles/theseam-ui-common-test-helpers.umd.js.map +0 -1
  320. package/esm2015/test-helpers/public-api.js +0 -2
  321. package/esm2015/test-helpers/theseam-ui-common-test-helpers.js +0 -5
  322. package/esm2015/test-helpers/tick-helper.js +0 -74
  323. package/fesm2015/theseam-ui-common-test-helpers.js +0 -81
  324. package/fesm2015/theseam-ui-common-test-helpers.js.map +0 -1
  325. package/test-helpers/package.json +0 -11
  326. package/test-helpers/public-api.d.ts +0 -1
  327. package/test-helpers/theseam-ui-common-test-helpers.metadata.json +0 -1
@@ -3,7 +3,7 @@ import { NgModule } from '@angular/core';
3
3
  import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
4
4
  import { TiledSelectTileIconComponent } from './components/tiled-select-tile-icon/tiled-select-tile-icon.component';
5
5
  import { TiledSelectTileComponent } from './components/tiled-select-tile/tiled-select-tile.component';
6
- import { TiledSelectComponent } from './components/tiled-select/tiled-select.component';
6
+ import { TheSeamTiledSelectComponent } from './components/tiled-select/tiled-select.component';
7
7
  import { TiledSelectTileIconTplDirective } from './directives/tiled-select-tile-icon-tpl.directive';
8
8
  import { TiledSelectTileLabelTplDirective } from './directives/tiled-select-tile-label-tpl.directive';
9
9
  import { TiledSelectTileOverlayDirective } from './directives/tiled-select-tile-overlay.directive';
@@ -16,7 +16,7 @@ TheSeamTiledSelectModule.decorators = [
16
16
  FontAwesomeModule
17
17
  ],
18
18
  declarations: [
19
- TiledSelectComponent,
19
+ TheSeamTiledSelectComponent,
20
20
  TiledSelectTileComponent,
21
21
  TiledSelectTileOverlayDirective,
22
22
  TiledSelectTileIconComponent,
@@ -24,7 +24,7 @@ TheSeamTiledSelectModule.decorators = [
24
24
  TiledSelectTileLabelTplDirective
25
25
  ],
26
26
  exports: [
27
- TiledSelectComponent,
27
+ TheSeamTiledSelectComponent,
28
28
  TiledSelectTileComponent,
29
29
  TiledSelectTileOverlayDirective,
30
30
  TiledSelectTileIconTplDirective,
@@ -32,4 +32,4 @@ TheSeamTiledSelectModule.decorators = [
32
32
  ]
33
33
  },] }
34
34
  ];
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZWQtc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90aWxlZC1zZWxlY3QvdGlsZWQtc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV4QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUVwRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQTtBQUNuSCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQTtBQUNyRyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQUN2RixPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQTtBQUNuRyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxvREFBb0QsQ0FBQTtBQUNyRyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQXVCbEcsTUFBTSxPQUFPLHdCQUF3Qjs7O1lBckJwQyxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO2lCQUNsQjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1osb0JBQW9CO29CQUNwQix3QkFBd0I7b0JBQ3hCLCtCQUErQjtvQkFDL0IsNEJBQTRCO29CQUM1QiwrQkFBK0I7b0JBQy9CLGdDQUFnQztpQkFDakM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLG9CQUFvQjtvQkFDcEIsd0JBQXdCO29CQUN4QiwrQkFBK0I7b0JBQy9CLCtCQUErQjtvQkFDL0IsZ0NBQWdDO2lCQUNqQzthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5pbXBvcnQgeyBGb250QXdlc29tZU1vZHVsZSB9IGZyb20gJ0Bmb3J0YXdlc29tZS9hbmd1bGFyLWZvbnRhd2Vzb21lJ1xuXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC10aWxlLWljb24vdGlsZWQtc2VsZWN0LXRpbGUtaWNvbi5jb21wb25lbnQnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGlsZWQtc2VsZWN0LXRpbGUvdGlsZWQtc2VsZWN0LXRpbGUuY29tcG9uZW50J1xuaW1wb3J0IHsgVGlsZWRTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGlsZWQtc2VsZWN0L3RpbGVkLXNlbGVjdC5jb21wb25lbnQnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVJY29uVHBsRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL3RpbGVkLXNlbGVjdC10aWxlLWljb24tdHBsLmRpcmVjdGl2ZSdcbmltcG9ydCB7IFRpbGVkU2VsZWN0VGlsZUxhYmVsVHBsRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL3RpbGVkLXNlbGVjdC10aWxlLWxhYmVsLXRwbC5kaXJlY3RpdmUnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVPdmVybGF5RGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL3RpbGVkLXNlbGVjdC10aWxlLW92ZXJsYXkuZGlyZWN0aXZlJ1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvbnRBd2Vzb21lTW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFRpbGVkU2VsZWN0Q29tcG9uZW50LFxuICAgIFRpbGVkU2VsZWN0VGlsZUNvbXBvbmVudCxcbiAgICBUaWxlZFNlbGVjdFRpbGVPdmVybGF5RGlyZWN0aXZlLFxuICAgIFRpbGVkU2VsZWN0VGlsZUljb25Db21wb25lbnQsXG4gICAgVGlsZWRTZWxlY3RUaWxlSWNvblRwbERpcmVjdGl2ZSxcbiAgICBUaWxlZFNlbGVjdFRpbGVMYWJlbFRwbERpcmVjdGl2ZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgVGlsZWRTZWxlY3RDb21wb25lbnQsXG4gICAgVGlsZWRTZWxlY3RUaWxlQ29tcG9uZW50LFxuICAgIFRpbGVkU2VsZWN0VGlsZU92ZXJsYXlEaXJlY3RpdmUsXG4gICAgVGlsZWRTZWxlY3RUaWxlSWNvblRwbERpcmVjdGl2ZSxcbiAgICBUaWxlZFNlbGVjdFRpbGVMYWJlbFRwbERpcmVjdGl2ZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1UaWxlZFNlbGVjdE1vZHVsZSB7IH1cbiJdfQ==
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZWQtc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90aWxlZC1zZWxlY3QvdGlsZWQtc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV4QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUVwRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQTtBQUNuSCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQTtBQUNyRyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQUM5RixPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQTtBQUNuRyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxvREFBb0QsQ0FBQTtBQUNyRyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQXVCbEcsTUFBTSxPQUFPLHdCQUF3Qjs7O1lBckJwQyxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO2lCQUNsQjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1osMkJBQTJCO29CQUMzQix3QkFBd0I7b0JBQ3hCLCtCQUErQjtvQkFDL0IsNEJBQTRCO29CQUM1QiwrQkFBK0I7b0JBQy9CLGdDQUFnQztpQkFDakM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLDJCQUEyQjtvQkFDM0Isd0JBQXdCO29CQUN4QiwrQkFBK0I7b0JBQy9CLCtCQUErQjtvQkFDL0IsZ0NBQWdDO2lCQUNqQzthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5pbXBvcnQgeyBGb250QXdlc29tZU1vZHVsZSB9IGZyb20gJ0Bmb3J0YXdlc29tZS9hbmd1bGFyLWZvbnRhd2Vzb21lJ1xuXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC10aWxlLWljb24vdGlsZWQtc2VsZWN0LXRpbGUtaWNvbi5jb21wb25lbnQnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGlsZWQtc2VsZWN0LXRpbGUvdGlsZWQtc2VsZWN0LXRpbGUuY29tcG9uZW50J1xuaW1wb3J0IHsgVGhlU2VhbVRpbGVkU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC90aWxlZC1zZWxlY3QuY29tcG9uZW50J1xuaW1wb3J0IHsgVGlsZWRTZWxlY3RUaWxlSWNvblRwbERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1pY29uLXRwbC5kaXJlY3RpdmUnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVMYWJlbFRwbERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1sYWJlbC10cGwuZGlyZWN0aXZlJ1xuaW1wb3J0IHsgVGlsZWRTZWxlY3RUaWxlT3ZlcmxheURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1vdmVybGF5LmRpcmVjdGl2ZSdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb250QXdlc29tZU1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBUaGVTZWFtVGlsZWRTZWxlY3RDb21wb25lbnQsXG4gICAgVGlsZWRTZWxlY3RUaWxlQ29tcG9uZW50LFxuICAgIFRpbGVkU2VsZWN0VGlsZU92ZXJsYXlEaXJlY3RpdmUsXG4gICAgVGlsZWRTZWxlY3RUaWxlSWNvbkNvbXBvbmVudCxcbiAgICBUaWxlZFNlbGVjdFRpbGVJY29uVHBsRGlyZWN0aXZlLFxuICAgIFRpbGVkU2VsZWN0VGlsZUxhYmVsVHBsRGlyZWN0aXZlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUaGVTZWFtVGlsZWRTZWxlY3RDb21wb25lbnQsXG4gICAgVGlsZWRTZWxlY3RUaWxlQ29tcG9uZW50LFxuICAgIFRpbGVkU2VsZWN0VGlsZU92ZXJsYXlEaXJlY3RpdmUsXG4gICAgVGlsZWRTZWxlY3RUaWxlSWNvblRwbERpcmVjdGl2ZSxcbiAgICBUaWxlZFNlbGVjdFRpbGVMYWJlbFRwbERpcmVjdGl2ZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1UaWxlZFNlbGVjdE1vZHVsZSB7IH1cbiJdfQ==
@@ -8,7 +8,7 @@ ToggleEditActionsContainerComponent.decorators = [
8
8
  { type: Component, args: [{
9
9
  selector: 'seam-toggle-edit-actions-container',
10
10
  template: "<ng-content></ng-content>\n",
11
- styles: [":host{display:block}"]
11
+ styles: [":host{display:block}\n"]
12
12
  },] }
13
13
  ];
14
14
  ToggleEditActionsContainerComponent.ctorParameters = () => [];
@@ -368,7 +368,7 @@ ToggleEditComponent.decorators = [
368
368
  { type: Component, args: [{
369
369
  selector: 'seam-toggle-edit',
370
370
  template: "<div class=\"toggle-edit-not-editing rounded\"\n [class.w-100]=\"editing\"\n [class.toggle-edit-editing]=\"editing\"\n [class.is-disabled]=\"disabled\"\n (seamElemResized)=\"resized()\">\n <div class=\"toggle-edit-content-container\">\n <div class=\"toggle-edit-content\" (click)=\"toggleEditing(true)\">\n <ng-container *ngIf=\"editing; else notEditingTpl\">\n <ng-content></ng-content>\n </ng-container>\n <ng-template #notEditingTpl>\n <ng-container *ngIf=\"displayTpl; else noDisplayTpl\">\n <ng-template [ngTemplateOutlet]=\"displayTpl.template\" [ngTemplateOutletContext]=\"{ $implicit: getValue() || placeholder }\"></ng-template>\n </ng-container>\n <ng-template #noDisplayTpl>\n <div class=\"pl-1 pr-1\">\n {{ getValue() || placeholder }}\n </div>\n </ng-template>\n </ng-template>\n </div>\n <div>\n <ng-template *ngIf=\"!editing\" [cdkPortalOutlet]=\"templatePortal\"></ng-template>\n <ng-template #templatePortalContent>\n <seam-toggle-edit-actions-container\n [class.bg-light]=\"editing\"\n tabindex=\"-1\"\n cdkMonitorSubtreeFocus\n (cdkFocusChange)=\"actionsFocusChange($event)\">\n <button *ngIf=\"!editing\"\n type=\"button\"\n class=\"toggle-edit-edit-btn btn text-secondary bg-transparent p-1 border-0\"\n (click)=\"toggleEditing(true)\">\n <fa-icon [icon]=\"faPen\"></fa-icon>\n </button>\n <button *ngIf=\"editing\"\n type=\"button\"\n [disabled]=\"!canSubmit()\"\n class=\"toggle-edit-submit-btn btn text-secondary bg-transparent p-1 border-0\"\n (click)=\"submitEdit()\">\n <fa-icon [icon]=\"faCheck\"></fa-icon>\n </button>\n <button *ngIf=\"editing\"\n type=\"button\"\n class=\"toggle-edit-cancel-btn btn text-secondary bg-transparent p-1 border-0\"\n (click)=\"cancelEdit()\">\n <fa-icon [icon]=\"faTimes\"></fa-icon>\n </button>\n </seam-toggle-edit-actions-container>\n </ng-template>\n </div>\n </div>\n</div>\n\n<seam-loading *ngIf=\"isSubmitting()\"></seam-loading>\n",
371
- styles: [":host{display:block;position:relative}.toggle-edit-not-editing{transition:background-color .25s ease-in-out}.toggle-edit-not-editing .toggle-edit-content-container{display:flex;flex-direction:row}.toggle-edit-not-editing .toggle-edit-content-container .toggle-edit-content{flex:1 1 auto;display:flex;align-items:center}.toggle-edit-not-editing:not(.is-disabled).toggle-edit-editing,.toggle-edit-not-editing:not(.is-disabled):hover{background-color:#f8f9fa}.toggle-edit-not-editing:not(.is-disabled).toggle-edit-editing .toggle-edit-edit-btn,.toggle-edit-not-editing:not(.is-disabled):hover .toggle-edit-edit-btn{opacity:1;visibility:visible}.toggle-edit-not-editing .toggle-edit-edit-btn{opacity:0;visibility:hidden}.toggle-edit-not-editing .toggle-edit-cancel-btn,.toggle-edit-not-editing .toggle-edit-edit-btn,.toggle-edit-not-editing .toggle-edit-submit-btn{transition:.25s ease-in-out}.toggle-edit-not-editing .toggle-edit-edit-btn{border-top-left-radius:0;border-bottom-left-radius:0}.toggle-edit-not-editing .toggle-edit-submit-btn{border-radius:0}.toggle-edit-not-editing .toggle-edit-cancel-btn{border-top-left-radius:0;border-bottom-left-radius:0}"]
371
+ styles: [":host{display:block;position:relative}.toggle-edit-not-editing{transition:.25s ease-in-out background-color}.toggle-edit-not-editing .toggle-edit-content-container{display:flex;flex-direction:row}.toggle-edit-not-editing .toggle-edit-content-container .toggle-edit-content{flex:1 1 auto;display:flex;align-items:center}.toggle-edit-not-editing:not(.is-disabled):hover,.toggle-edit-not-editing:not(.is-disabled).toggle-edit-editing{background-color:#f8f9fa}.toggle-edit-not-editing:not(.is-disabled):hover .toggle-edit-edit-btn,.toggle-edit-not-editing:not(.is-disabled).toggle-edit-editing .toggle-edit-edit-btn{opacity:1;visibility:visible}.toggle-edit-not-editing .toggle-edit-edit-btn{opacity:0;visibility:hidden}.toggle-edit-not-editing .toggle-edit-edit-btn,.toggle-edit-not-editing .toggle-edit-submit-btn,.toggle-edit-not-editing .toggle-edit-cancel-btn{transition:.25s ease-in-out}.toggle-edit-not-editing .toggle-edit-edit-btn{border-top-left-radius:0;border-bottom-left-radius:0}.toggle-edit-not-editing .toggle-edit-submit-btn{border-radius:0}.toggle-edit-not-editing .toggle-edit-cancel-btn{border-top-left-radius:0;border-bottom-left-radius:0}\n"]
372
372
  },] }
373
373
  ];
374
374
  ToggleEditComponent.ctorParameters = () => [
@@ -0,0 +1,62 @@
1
+ // Based on source: https://github.com/sindresorhus/array-move/blob/main/index.js
2
+ /**
3
+ Moves the item to the new position in the input array. Useful for huge arrays
4
+ where absolute performance is needed.
5
+
6
+ @param array - The array to modify.
7
+ @param fromIndex - The index of item to move. If negative, it will begin that
8
+ many elements from the end.
9
+ @param toIndex - The index of where to move the item. If negative, it will
10
+ begin that many elements from the end.
11
+ @example
12
+ ```
13
+ import { arrayMoveMutable } from '@theseam/ui-common/utils';
14
+
15
+ const input = ['a', 'b', 'c'];
16
+ arrayMoveMutable(input, 1, 2);
17
+ console.log(input);
18
+ //=> ['a', 'c', 'b']
19
+ ```
20
+ */
21
+ export function arrayMoveMutable(array, fromIndex, toIndex) {
22
+ const startIndex = fromIndex < 0 ? array.length + fromIndex : fromIndex;
23
+ if (startIndex >= 0 && startIndex < array.length) {
24
+ const endIndex = toIndex < 0 ? array.length + toIndex : toIndex;
25
+ const [item] = array.splice(fromIndex, 1);
26
+ array.splice(endIndex, 0, item);
27
+ }
28
+ }
29
+ /**
30
+ Clones the given `array`, moves the item to a new position in the new array,
31
+ and then returns the new array. The given `array` is not mutated.
32
+
33
+ @param array - The array with the item to move.
34
+ @param fromIndex - The index of item to move. If negative, it will begin that
35
+ many elements from the end.
36
+ @param toIndex - The index of where to move the item. If negative, it will
37
+ begin that many elements from the end.
38
+ @returns A new array with the item moved to the new position.
39
+ @example
40
+ ```
41
+ import { arrayMoveImmutable } from '@theseam/ui-common/utils';
42
+
43
+ const input = ['a', 'b', 'c'];
44
+ const array1 = arrayMoveImmutable(input, 1, 2);
45
+ console.log(array1);
46
+ //=> ['a', 'c', 'b']
47
+
48
+ const array2 = arrayMoveImmutable(input, -1, 0);
49
+ console.log(array2);
50
+ //=> ['c', 'a', 'b']
51
+
52
+ const array3 = arrayMoveImmutable(input, -2, -3);
53
+ console.log(array3);
54
+ //=> ['b', 'a', 'c']
55
+ ```
56
+ */
57
+ export function arrayMoveImmutable(array, fromIndex, toIndex) {
58
+ const newArray = [...array];
59
+ arrayMoveMutable(newArray, fromIndex, toIndex);
60
+ return newArray;
61
+ }
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXktbW92ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi91dGlscy9hcnJheS1tb3ZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGlGQUFpRjtBQUVqRjs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBa0JFO0FBQ0YsTUFBTSxVQUFVLGdCQUFnQixDQUM5QixLQUFnQixFQUNoQixTQUFpQixFQUNqQixPQUFlO0lBRWhCLE1BQU0sVUFBVSxHQUFHLFNBQVMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFFeEUsSUFBSSxVQUFVLElBQUksQ0FBQyxJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUMsTUFBTSxFQUFFO1FBQ2pELE1BQU0sUUFBUSxHQUFHLE9BQU8sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7UUFFaEUsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQzFDLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztLQUNoQztBQUNGLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBMkJFO0FBQ0YsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxLQUEyQixFQUMzQixTQUFpQixFQUNqQixPQUFlO0lBRWhCLE1BQU0sUUFBUSxHQUFHLENBQUUsR0FBRyxLQUFLLENBQUUsQ0FBQTtJQUM3QixnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFBO0lBQzlDLE9BQU8sUUFBUSxDQUFBO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBCYXNlZCBvbiBzb3VyY2U6IGh0dHBzOi8vZ2l0aHViLmNvbS9zaW5kcmVzb3JodXMvYXJyYXktbW92ZS9ibG9iL21haW4vaW5kZXguanNcclxuXHJcbi8qKlxyXG4gIE1vdmVzIHRoZSBpdGVtIHRvIHRoZSBuZXcgcG9zaXRpb24gaW4gdGhlIGlucHV0IGFycmF5LiBVc2VmdWwgZm9yIGh1Z2UgYXJyYXlzXHJcbiAgd2hlcmUgYWJzb2x1dGUgcGVyZm9ybWFuY2UgaXMgbmVlZGVkLlxyXG5cclxuICBAcGFyYW0gYXJyYXkgLSBUaGUgYXJyYXkgdG8gbW9kaWZ5LlxyXG4gIEBwYXJhbSBmcm9tSW5kZXggLSBUaGUgaW5kZXggb2YgaXRlbSB0byBtb3ZlLiBJZiBuZWdhdGl2ZSwgaXQgd2lsbCBiZWdpbiB0aGF0XHJcbiAgbWFueSBlbGVtZW50cyBmcm9tIHRoZSBlbmQuXHJcbiAgQHBhcmFtIHRvSW5kZXggLSBUaGUgaW5kZXggb2Ygd2hlcmUgdG8gbW92ZSB0aGUgaXRlbS4gSWYgbmVnYXRpdmUsIGl0IHdpbGxcclxuICBiZWdpbiB0aGF0IG1hbnkgZWxlbWVudHMgZnJvbSB0aGUgZW5kLlxyXG4gIEBleGFtcGxlXHJcbiAgYGBgXHJcbiAgaW1wb3J0IHsgYXJyYXlNb3ZlTXV0YWJsZSB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi91dGlscyc7XHJcblxyXG4gIGNvbnN0IGlucHV0ID0gWydhJywgJ2InLCAnYyddO1xyXG4gIGFycmF5TW92ZU11dGFibGUoaW5wdXQsIDEsIDIpO1xyXG4gIGNvbnNvbGUubG9nKGlucHV0KTtcclxuICAvLz0+IFsnYScsICdjJywgJ2InXVxyXG4gIGBgYFxyXG4qL1xyXG5leHBvcnQgZnVuY3Rpb24gYXJyYXlNb3ZlTXV0YWJsZShcclxuICBhcnJheTogdW5rbm93bltdLFxyXG4gIGZyb21JbmRleDogbnVtYmVyLFxyXG4gIHRvSW5kZXg6IG51bWJlclxyXG4pOiB2b2lkIHtcclxuXHRjb25zdCBzdGFydEluZGV4ID0gZnJvbUluZGV4IDwgMCA/IGFycmF5Lmxlbmd0aCArIGZyb21JbmRleCA6IGZyb21JbmRleDtcclxuXHJcblx0aWYgKHN0YXJ0SW5kZXggPj0gMCAmJiBzdGFydEluZGV4IDwgYXJyYXkubGVuZ3RoKSB7XHJcblx0XHRjb25zdCBlbmRJbmRleCA9IHRvSW5kZXggPCAwID8gYXJyYXkubGVuZ3RoICsgdG9JbmRleCA6IHRvSW5kZXg7XHJcblxyXG5cdFx0Y29uc3QgW2l0ZW1dID0gYXJyYXkuc3BsaWNlKGZyb21JbmRleCwgMSk7XHJcblx0XHRhcnJheS5zcGxpY2UoZW5kSW5kZXgsIDAsIGl0ZW0pO1xyXG5cdH1cclxufVxyXG5cclxuLyoqXHJcbiAgQ2xvbmVzIHRoZSBnaXZlbiBgYXJyYXlgLCBtb3ZlcyB0aGUgaXRlbSB0byBhIG5ldyBwb3NpdGlvbiBpbiB0aGUgbmV3IGFycmF5LFxyXG4gIGFuZCB0aGVuIHJldHVybnMgdGhlIG5ldyBhcnJheS4gVGhlIGdpdmVuIGBhcnJheWAgaXMgbm90IG11dGF0ZWQuXHJcblxyXG4gIEBwYXJhbSBhcnJheSAtIFRoZSBhcnJheSB3aXRoIHRoZSBpdGVtIHRvIG1vdmUuXHJcbiAgQHBhcmFtIGZyb21JbmRleCAtIFRoZSBpbmRleCBvZiBpdGVtIHRvIG1vdmUuIElmIG5lZ2F0aXZlLCBpdCB3aWxsIGJlZ2luIHRoYXRcclxuICBtYW55IGVsZW1lbnRzIGZyb20gdGhlIGVuZC5cclxuICBAcGFyYW0gdG9JbmRleCAtIFRoZSBpbmRleCBvZiB3aGVyZSB0byBtb3ZlIHRoZSBpdGVtLiBJZiBuZWdhdGl2ZSwgaXQgd2lsbFxyXG4gIGJlZ2luIHRoYXQgbWFueSBlbGVtZW50cyBmcm9tIHRoZSBlbmQuXHJcbiAgQHJldHVybnMgQSBuZXcgYXJyYXkgd2l0aCB0aGUgaXRlbSBtb3ZlZCB0byB0aGUgbmV3IHBvc2l0aW9uLlxyXG4gIEBleGFtcGxlXHJcbiAgYGBgXHJcbiAgaW1wb3J0IHsgYXJyYXlNb3ZlSW1tdXRhYmxlIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL3V0aWxzJztcclxuXHJcbiAgY29uc3QgaW5wdXQgPSBbJ2EnLCAnYicsICdjJ107XHJcbiAgY29uc3QgYXJyYXkxID0gYXJyYXlNb3ZlSW1tdXRhYmxlKGlucHV0LCAxLCAyKTtcclxuICBjb25zb2xlLmxvZyhhcnJheTEpO1xyXG4gIC8vPT4gWydhJywgJ2MnLCAnYiddXHJcblxyXG4gIGNvbnN0IGFycmF5MiA9IGFycmF5TW92ZUltbXV0YWJsZShpbnB1dCwgLTEsIDApO1xyXG4gIGNvbnNvbGUubG9nKGFycmF5Mik7XHJcbiAgLy89PiBbJ2MnLCAnYScsICdiJ11cclxuXHJcbiAgY29uc3QgYXJyYXkzID0gYXJyYXlNb3ZlSW1tdXRhYmxlKGlucHV0LCAtMiwgLTMpO1xyXG4gIGNvbnNvbGUubG9nKGFycmF5Myk7XHJcbiAgLy89PiBbJ2InLCAnYScsICdjJ11cclxuICBgYGBcclxuKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGFycmF5TW92ZUltbXV0YWJsZTxWYWx1ZVR5cGU+KFxyXG4gIGFycmF5OiByZWFkb25seSBWYWx1ZVR5cGVbXSxcclxuICBmcm9tSW5kZXg6IG51bWJlcixcclxuICB0b0luZGV4OiBudW1iZXJcclxuKTogVmFsdWVUeXBlW10ge1xyXG5cdGNvbnN0IG5ld0FycmF5ID0gWyAuLi5hcnJheSBdXHJcblx0YXJyYXlNb3ZlTXV0YWJsZShuZXdBcnJheSwgZnJvbUluZGV4LCB0b0luZGV4KVxyXG5cdHJldHVybiBuZXdBcnJheVxyXG59XHJcbiJdfQ==
@@ -11,6 +11,7 @@ export * from './form/has-required-control';
11
11
  export * from './form/is-empty-input-value';
12
12
  export * from './operators/index';
13
13
  export * from './router/index';
14
+ export * from './array-move';
14
15
  export * from './calc-percentage';
15
16
  export * from './toggle-attribute';
16
17
  export * from './get-attribute';
@@ -35,4 +36,4 @@ export * from './pad-start';
35
36
  export * from './create-padding';
36
37
  export * from './is-numeric';
37
38
  export * from './fractional-digits-count';
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi91dGlscy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUNBQW1DLENBQUE7QUFFakQsY0FBYyx5QkFBeUIsQ0FBQTtBQUN2QyxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYywrQkFBK0IsQ0FBQTtBQUM3QyxjQUFjLDhCQUE4QixDQUFBO0FBQzVDLGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYyw4QkFBOEIsQ0FBQTtBQUM1QyxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsNkJBQTZCLENBQUE7QUFDM0MsY0FBYyw2QkFBNkIsQ0FBQTtBQUUzQyxjQUFjLG1CQUFtQixDQUFBO0FBRWpDLGNBQWMsZ0JBQWdCLENBQUE7QUFFOUIsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsaUJBQWlCLENBQUE7QUFDL0IsY0FBYyxlQUFlLENBQUE7QUFDN0IsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLGNBQWMsQ0FBQTtBQUM1QixjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsY0FBYyxDQUFBO0FBQzVCLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYywyQkFBMkIsQ0FBQTtBQUN6QyxjQUFjLGtCQUFrQixDQUFBO0FBQ2hDLGNBQWMsZUFBZSxDQUFBO0FBQzdCLGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxpQkFBaUIsQ0FBQTtBQUMvQixjQUFjLHNCQUFzQixDQUFBO0FBQ3BDLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYywyQkFBMkIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2RrL2dldC1jbG9zZXN0LXdpZGdldC1jZGstZHJhZydcblxuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2dldC1jb250cm9sLW5hbWUnXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vZ2V0LWNvbnRyb2wtcGF0aCdcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS9vYnNlcnZlLWNvbnRyb2wtaXMtZGlmZmVyZW50J1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL29ic2VydmUtY29udHJvbC1zdGF0dXMnXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vb2JzZXJ2ZS1jb250cm9sLXZhbGlkJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL29ic2VydmUtY29udHJvbC12YWx1ZS1jaGFuZ2UnXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vb2JzZXJ2ZS1jb250cm9sLXZhbHVlJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL3dhaXQtb24tbm9uLXBlbmRpbmctc3RhdHVzJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2hhcy1yZXF1aXJlZC1jb250cm9sJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2lzLWVtcHR5LWlucHV0LXZhbHVlJ1xuXG5leHBvcnQgKiBmcm9tICcuL29wZXJhdG9ycy9pbmRleCdcblxuZXhwb3J0ICogZnJvbSAnLi9yb3V0ZXIvaW5kZXgnXG5cbmV4cG9ydCAqIGZyb20gJy4vY2FsYy1wZXJjZW50YWdlJ1xuZXhwb3J0ICogZnJvbSAnLi90b2dnbGUtYXR0cmlidXRlJ1xuZXhwb3J0ICogZnJvbSAnLi9nZXQtYXR0cmlidXRlJ1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1tYXNrcydcbmV4cG9ydCAqIGZyb20gJy4vaXMtbnVsbC1vci11bmRlZmluZWQnXG5leHBvcnQgKiBmcm9tICcuL2xvYWQtc3R5bGUnXG5leHBvcnQgKiBmcm9tICcuL2xvYWQtc3R5bGUtc2hlZXQnXG5leHBvcnQgKiBmcm9tICcuL29iai11dGlscydcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS11dGlscydcbmV4cG9ydCAqIGZyb20gJy4vbm90LW51bGwtb3ItdW5kZWZpbmVkJ1xuZXhwb3J0ICogZnJvbSAnLi93YWl0LW9uLWNvbmRpdGlvbi1hc3luYydcbmV4cG9ydCAqIGZyb20gJy4vcG9sbGluZy10aWNrZXInXG5leHBvcnQgKiBmcm9tICcuL3JlZnJlc2hhYmxlJ1xuZXhwb3J0ICogZnJvbSAnLi93cmFwLWludG8tb2JzZXJ2YWJsZSdcbmV4cG9ydCAqIGZyb20gJy4vaXMtYWJzb2x1dGUtdXJsJ1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpYmVyLWNvdW50J1xuZXhwb3J0ICogZnJvbSAnLi9oYXMtcHJvcGVydHknXG5leHBvcnQgKiBmcm9tICcuL2hhcy1hdHRyaWJ1dGUnXG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcXVlcnktbGlzdCdcbmV4cG9ydCAqIGZyb20gJy4vcGFkLWVuZCdcbmV4cG9ydCAqIGZyb20gJy4vcGFkLXN0YXJ0J1xuZXhwb3J0ICogZnJvbSAnLi9jcmVhdGUtcGFkZGluZydcbmV4cG9ydCAqIGZyb20gJy4vaXMtbnVtZXJpYydcbmV4cG9ydCAqIGZyb20gJy4vZnJhY3Rpb25hbC1kaWdpdHMtY291bnQnXG4iXX0=
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi91dGlscy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUNBQW1DLENBQUE7QUFFakQsY0FBYyx5QkFBeUIsQ0FBQTtBQUN2QyxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYywrQkFBK0IsQ0FBQTtBQUM3QyxjQUFjLDhCQUE4QixDQUFBO0FBQzVDLGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYyw4QkFBOEIsQ0FBQTtBQUM1QyxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsNkJBQTZCLENBQUE7QUFDM0MsY0FBYyw2QkFBNkIsQ0FBQTtBQUUzQyxjQUFjLG1CQUFtQixDQUFBO0FBRWpDLGNBQWMsZ0JBQWdCLENBQUE7QUFFOUIsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsaUJBQWlCLENBQUE7QUFDL0IsY0FBYyxlQUFlLENBQUE7QUFDN0IsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLGNBQWMsQ0FBQTtBQUM1QixjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsY0FBYyxDQUFBO0FBQzVCLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYywyQkFBMkIsQ0FBQTtBQUN6QyxjQUFjLGtCQUFrQixDQUFBO0FBQ2hDLGNBQWMsZUFBZSxDQUFBO0FBQzdCLGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxpQkFBaUIsQ0FBQTtBQUMvQixjQUFjLHNCQUFzQixDQUFBO0FBQ3BDLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYywyQkFBMkIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2RrL2dldC1jbG9zZXN0LXdpZGdldC1jZGstZHJhZydcblxuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2dldC1jb250cm9sLW5hbWUnXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vZ2V0LWNvbnRyb2wtcGF0aCdcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS9vYnNlcnZlLWNvbnRyb2wtaXMtZGlmZmVyZW50J1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL29ic2VydmUtY29udHJvbC1zdGF0dXMnXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vb2JzZXJ2ZS1jb250cm9sLXZhbGlkJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL29ic2VydmUtY29udHJvbC12YWx1ZS1jaGFuZ2UnXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vb2JzZXJ2ZS1jb250cm9sLXZhbHVlJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL3dhaXQtb24tbm9uLXBlbmRpbmctc3RhdHVzJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2hhcy1yZXF1aXJlZC1jb250cm9sJ1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2lzLWVtcHR5LWlucHV0LXZhbHVlJ1xuXG5leHBvcnQgKiBmcm9tICcuL29wZXJhdG9ycy9pbmRleCdcblxuZXhwb3J0ICogZnJvbSAnLi9yb3V0ZXIvaW5kZXgnXG5cbmV4cG9ydCAqIGZyb20gJy4vYXJyYXktbW92ZSdcbmV4cG9ydCAqIGZyb20gJy4vY2FsYy1wZXJjZW50YWdlJ1xuZXhwb3J0ICogZnJvbSAnLi90b2dnbGUtYXR0cmlidXRlJ1xuZXhwb3J0ICogZnJvbSAnLi9nZXQtYXR0cmlidXRlJ1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1tYXNrcydcbmV4cG9ydCAqIGZyb20gJy4vaXMtbnVsbC1vci11bmRlZmluZWQnXG5leHBvcnQgKiBmcm9tICcuL2xvYWQtc3R5bGUnXG5leHBvcnQgKiBmcm9tICcuL2xvYWQtc3R5bGUtc2hlZXQnXG5leHBvcnQgKiBmcm9tICcuL29iai11dGlscydcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS11dGlscydcbmV4cG9ydCAqIGZyb20gJy4vbm90LW51bGwtb3ItdW5kZWZpbmVkJ1xuZXhwb3J0ICogZnJvbSAnLi93YWl0LW9uLWNvbmRpdGlvbi1hc3luYydcbmV4cG9ydCAqIGZyb20gJy4vcG9sbGluZy10aWNrZXInXG5leHBvcnQgKiBmcm9tICcuL3JlZnJlc2hhYmxlJ1xuZXhwb3J0ICogZnJvbSAnLi93cmFwLWludG8tb2JzZXJ2YWJsZSdcbmV4cG9ydCAqIGZyb20gJy4vaXMtYWJzb2x1dGUtdXJsJ1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpYmVyLWNvdW50J1xuZXhwb3J0ICogZnJvbSAnLi9oYXMtcHJvcGVydHknXG5leHBvcnQgKiBmcm9tICcuL2hhcy1hdHRyaWJ1dGUnXG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcXVlcnktbGlzdCdcbmV4cG9ydCAqIGZyb20gJy4vcGFkLWVuZCdcbmV4cG9ydCAqIGZyb20gJy4vcGFkLXN0YXJ0J1xuZXhwb3J0ICogZnJvbSAnLi9jcmVhdGUtcGFkZGluZydcbmV4cG9ydCAqIGZyb20gJy4vaXMtbnVtZXJpYydcbmV4cG9ydCAqIGZyb20gJy4vZnJhY3Rpb25hbC1kaWdpdHMtY291bnQnXG4iXX0=
@@ -1,4 +1,4 @@
1
1
  export function isEmptyUrlRoute(activatedRoute) {
2
2
  return activatedRoute.snapshot.url.length === 0;
3
3
  }
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZW1wdHktdXJsLXJvdXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3V0aWxzL3JvdXRlci9pcy1lbXB0eS11cmwtcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLGVBQWUsQ0FBQyxjQUE4QjtJQUM1RCxPQUFPLGNBQWMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUE7QUFDakQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2YXRlZFJvdXRlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJ1xuXG5leHBvcnQgZnVuY3Rpb24gaXNFbXB0eVVybFJvdXRlKGFjdGl2YXRlZFJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSk6IGJvb2xlYW4ge1xuICByZXR1cm4gYWN0aXZhdGVkUm91dGUuc25hcHNob3QudXJsLmxlbmd0aCA9PT0gMFxufVxuIl19
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZW1wdHktdXJsLXJvdXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3V0aWxzL3JvdXRlci9pcy1lbXB0eS11cmwtcm91dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLGVBQWUsQ0FBQyxjQUE4QjtJQUM1RCxPQUFPLGNBQWMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUE7QUFDakQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2YXRlZFJvdXRlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJ1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGlzRW1wdHlVcmxSb3V0ZShhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUpOiBib29sZWFuIHtcclxuICByZXR1cm4gYWN0aXZhdGVkUm91dGUuc25hcHNob3QudXJsLmxlbmd0aCA9PT0gMFxyXG59XHJcbiJdfQ==
@@ -2,18 +2,45 @@ import { Observable } from 'rxjs';
2
2
  /**
3
3
  * This is just for helping debug observables that aren't being unsubscribed
4
4
  * from correctly.
5
+ *
6
+ * If description is 'foo' then you can check the how many observers are
7
+ * subscribed with the expression `__subscriberCounts['foo']`. In a debugger you
8
+ * can add the expression to the "Watch" expressions or in Chrome Devtools
9
+ * Console you can add it to the live expressions(Add live expressions by
10
+ * clicking the eye the the left of the Console filter input).
5
11
  */
6
- function subscriberCount(sourceObservable, description) {
12
+ export function subscriberCount(sourceObservable, description, countChangedFn = logOnChange) {
7
13
  let counter = 0;
8
14
  return new Observable((subscriber) => {
9
15
  const subscription = sourceObservable.subscribe(subscriber);
10
16
  counter++;
11
- console.log(`${description} subscriptions: ${counter}`);
17
+ if (countChangedFn !== undefined && countChangedFn !== null) {
18
+ countChangedFn(description, counter, 'subscribed');
19
+ }
20
+ setGlobalSubscriberCount(description, counter);
12
21
  return () => {
13
22
  subscription.unsubscribe();
14
23
  counter--;
15
- console.log(`${description} subscriptions: ${counter}`);
24
+ if (countChangedFn !== undefined && countChangedFn !== null) {
25
+ countChangedFn(description, counter, 'unsubscribed');
26
+ }
27
+ setGlobalSubscriberCount(description, counter);
16
28
  };
17
29
  });
18
30
  }
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Vic2NyaWJlci1jb3VudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi91dGlscy9zdWJzY3JpYmVyLWNvdW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWMsTUFBTSxNQUFNLENBQUE7QUFFN0M7OztHQUdHO0FBQ0gsU0FBUyxlQUFlLENBQUksZ0JBQStCLEVBQUUsV0FBbUI7SUFDOUUsSUFBSSxPQUFPLEdBQUcsQ0FBQyxDQUFBO0lBQ2YsT0FBTyxJQUFJLFVBQVUsQ0FBQyxDQUFDLFVBQXlCLEVBQUUsRUFBRTtRQUNsRCxNQUFNLFlBQVksR0FBRyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQUE7UUFDM0QsT0FBTyxFQUFFLENBQUE7UUFDVCxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsV0FBVyxtQkFBbUIsT0FBTyxFQUFFLENBQUMsQ0FBQTtRQUV2RCxPQUFPLEdBQUcsRUFBRTtZQUNWLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQTtZQUMxQixPQUFPLEVBQUUsQ0FBQTtZQUNULE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxXQUFXLG1CQUFtQixPQUFPLEVBQUUsQ0FBQyxDQUFBO1FBQ3pELENBQUMsQ0FBQTtJQUNILENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIFN1YnNjcmliZXIgfSBmcm9tICdyeGpzJ1xuXG4vKipcbiAqIFRoaXMgaXMganVzdCBmb3IgaGVscGluZyBkZWJ1ZyBvYnNlcnZhYmxlcyB0aGF0IGFyZW4ndCBiZWluZyB1bnN1YnNjcmliZWRcbiAqIGZyb20gY29ycmVjdGx5LlxuICovXG5mdW5jdGlvbiBzdWJzY3JpYmVyQ291bnQ8VD4oc291cmNlT2JzZXJ2YWJsZTogT2JzZXJ2YWJsZTxUPiwgZGVzY3JpcHRpb246IHN0cmluZykge1xuICBsZXQgY291bnRlciA9IDBcbiAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChzdWJzY3JpYmVyOiBTdWJzY3JpYmVyPFQ+KSA9PiB7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gc291cmNlT2JzZXJ2YWJsZS5zdWJzY3JpYmUoc3Vic2NyaWJlcilcbiAgICBjb3VudGVyKytcbiAgICBjb25zb2xlLmxvZyhgJHtkZXNjcmlwdGlvbn0gc3Vic2NyaXB0aW9uczogJHtjb3VudGVyfWApXG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKClcbiAgICAgIGNvdW50ZXItLVxuICAgICAgY29uc29sZS5sb2coYCR7ZGVzY3JpcHRpb259IHN1YnNjcmlwdGlvbnM6ICR7Y291bnRlcn1gKVxuICAgIH1cbiAgfSlcbn1cbiJdfQ==
31
+ const logOnChange = (description, count, reason) => {
32
+ console.log(`${description} subscriptions: ${count} [${reason}]`);
33
+ };
34
+ const ɵ0 = logOnChange;
35
+ function getGlobalSubscriberCounts() {
36
+ const w = window;
37
+ if (w.__subscriberCounts === undefined || w.__subscriberCounts === null) {
38
+ w.__subscriberCounts = {};
39
+ }
40
+ return w.__subscriberCounts;
41
+ }
42
+ function setGlobalSubscriberCount(description, count) {
43
+ getGlobalSubscriberCounts()[description] = count;
44
+ }
45
+ export { ɵ0 };
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Vic2NyaWJlci1jb3VudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi91dGlscy9zdWJzY3JpYmVyLWNvdW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWMsTUFBTSxNQUFNLENBQUE7QUFJN0M7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FDN0IsZ0JBQStCLEVBQy9CLFdBQW1CLEVBQ25CLGlCQUE4RCxXQUFXO0lBRXpFLElBQUksT0FBTyxHQUFHLENBQUMsQ0FBQTtJQUNmLE9BQU8sSUFBSSxVQUFVLENBQUMsQ0FBQyxVQUF5QixFQUFFLEVBQUU7UUFDbEQsTUFBTSxZQUFZLEdBQUcsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBQzNELE9BQU8sRUFBRSxDQUFBO1FBQ1QsSUFBSSxjQUFjLEtBQUssU0FBUyxJQUFJLGNBQWMsS0FBSyxJQUFJLEVBQUU7WUFDM0QsY0FBYyxDQUFDLFdBQVcsRUFBRSxPQUFPLEVBQUUsWUFBWSxDQUFDLENBQUE7U0FDbkQ7UUFDRCx3QkFBd0IsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUE7UUFFOUMsT0FBTyxHQUFHLEVBQUU7WUFDVixZQUFZLENBQUMsV0FBVyxFQUFFLENBQUE7WUFDMUIsT0FBTyxFQUFFLENBQUE7WUFDVCxJQUFJLGNBQWMsS0FBSyxTQUFTLElBQUksY0FBYyxLQUFLLElBQUksRUFBRTtnQkFDM0QsY0FBYyxDQUFDLFdBQVcsRUFBRSxPQUFPLEVBQUUsY0FBYyxDQUFDLENBQUE7YUFDckQ7WUFDRCx3QkFBd0IsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUE7UUFDaEQsQ0FBQyxDQUFBO0lBQ0gsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDO0FBRUQsTUFBTSxXQUFXLEdBQTZCLENBQUMsV0FBbUIsRUFBRSxLQUFhLEVBQUUsTUFBcUMsRUFBRSxFQUFFO0lBQzFILE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxXQUFXLG1CQUFtQixLQUFLLE1BQU0sTUFBTSxHQUFHLENBQUMsQ0FBQTtBQUNwRSxDQUFDLENBQUE7O0FBRUQsU0FBUyx5QkFBeUI7SUFDaEMsTUFBTSxDQUFDLEdBQUcsTUFBYSxDQUFBO0lBQ3ZCLElBQUksQ0FBQyxDQUFDLGtCQUFrQixLQUFLLFNBQVMsSUFBSSxDQUFDLENBQUMsa0JBQWtCLEtBQUssSUFBSSxFQUFFO1FBQ3ZFLENBQUMsQ0FBQyxrQkFBa0IsR0FBRyxFQUFFLENBQUE7S0FDMUI7SUFDRCxPQUFPLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQTtBQUM3QixDQUFDO0FBRUQsU0FBUyx3QkFBd0IsQ0FBQyxXQUFtQixFQUFFLEtBQWE7SUFDbEUseUJBQXlCLEVBQUUsQ0FBQyxXQUFXLENBQUMsR0FBRyxLQUFLLENBQUE7QUFDbEQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIFN1YnNjcmliZXIgfSBmcm9tICdyeGpzJ1xuXG5leHBvcnQgdHlwZSBTdWJzY3JpYmVyQ291bnRDaGFuZ2VkRm4gPSAoZGVzY3JpcHRpb246IHN0cmluZywgY291bnQ6IG51bWJlciwgcmVhc29uOiAnc3Vic2NyaWJlZCcgfCAndW5zdWJzY3JpYmVkJykgPT4gdm9pZFxuXG4vKipcbiAqIFRoaXMgaXMganVzdCBmb3IgaGVscGluZyBkZWJ1ZyBvYnNlcnZhYmxlcyB0aGF0IGFyZW4ndCBiZWluZyB1bnN1YnNjcmliZWRcbiAqIGZyb20gY29ycmVjdGx5LlxuICpcbiAqIElmIGRlc2NyaXB0aW9uIGlzICdmb28nIHRoZW4geW91IGNhbiBjaGVjayB0aGUgaG93IG1hbnkgb2JzZXJ2ZXJzIGFyZVxuICogc3Vic2NyaWJlZCB3aXRoIHRoZSBleHByZXNzaW9uIGBfX3N1YnNjcmliZXJDb3VudHNbJ2ZvbyddYC4gSW4gYSBkZWJ1Z2dlciB5b3VcbiAqIGNhbiBhZGQgdGhlIGV4cHJlc3Npb24gdG8gdGhlIFwiV2F0Y2hcIiBleHByZXNzaW9ucyBvciBpbiBDaHJvbWUgRGV2dG9vbHNcbiAqIENvbnNvbGUgeW91IGNhbiBhZGQgaXQgdG8gdGhlIGxpdmUgZXhwcmVzc2lvbnMoQWRkIGxpdmUgZXhwcmVzc2lvbnMgYnlcbiAqIGNsaWNraW5nIHRoZSBleWUgdGhlIHRoZSBsZWZ0IG9mIHRoZSBDb25zb2xlIGZpbHRlciBpbnB1dCkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzdWJzY3JpYmVyQ291bnQ8VD4oXG4gIHNvdXJjZU9ic2VydmFibGU6IE9ic2VydmFibGU8VD4sXG4gIGRlc2NyaXB0aW9uOiBzdHJpbmcsXG4gIGNvdW50Q2hhbmdlZEZuOiBTdWJzY3JpYmVyQ291bnRDaGFuZ2VkRm4gfCB1bmRlZmluZWQgfCBudWxsID0gbG9nT25DaGFuZ2Vcbikge1xuICBsZXQgY291bnRlciA9IDBcbiAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChzdWJzY3JpYmVyOiBTdWJzY3JpYmVyPFQ+KSA9PiB7XG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gc291cmNlT2JzZXJ2YWJsZS5zdWJzY3JpYmUoc3Vic2NyaWJlcilcbiAgICBjb3VudGVyKytcbiAgICBpZiAoY291bnRDaGFuZ2VkRm4gIT09IHVuZGVmaW5lZCAmJiBjb3VudENoYW5nZWRGbiAhPT0gbnVsbCkge1xuICAgICAgY291bnRDaGFuZ2VkRm4oZGVzY3JpcHRpb24sIGNvdW50ZXIsICdzdWJzY3JpYmVkJylcbiAgICB9XG4gICAgc2V0R2xvYmFsU3Vic2NyaWJlckNvdW50KGRlc2NyaXB0aW9uLCBjb3VudGVyKVxuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpXG4gICAgICBjb3VudGVyLS1cbiAgICAgIGlmIChjb3VudENoYW5nZWRGbiAhPT0gdW5kZWZpbmVkICYmIGNvdW50Q2hhbmdlZEZuICE9PSBudWxsKSB7XG4gICAgICAgIGNvdW50Q2hhbmdlZEZuKGRlc2NyaXB0aW9uLCBjb3VudGVyLCAndW5zdWJzY3JpYmVkJylcbiAgICAgIH1cbiAgICAgIHNldEdsb2JhbFN1YnNjcmliZXJDb3VudChkZXNjcmlwdGlvbiwgY291bnRlcilcbiAgICB9XG4gIH0pXG59XG5cbmNvbnN0IGxvZ09uQ2hhbmdlOiBTdWJzY3JpYmVyQ291bnRDaGFuZ2VkRm4gPSAoZGVzY3JpcHRpb246IHN0cmluZywgY291bnQ6IG51bWJlciwgcmVhc29uOiAnc3Vic2NyaWJlZCcgfCAndW5zdWJzY3JpYmVkJykgPT4ge1xuICBjb25zb2xlLmxvZyhgJHtkZXNjcmlwdGlvbn0gc3Vic2NyaXB0aW9uczogJHtjb3VudH0gIFske3JlYXNvbn1dYClcbn1cblxuZnVuY3Rpb24gZ2V0R2xvYmFsU3Vic2NyaWJlckNvdW50cygpOiB7IFtkZXNjcmlwdGlvbjogc3RyaW5nXTogbnVtYmVyIH0ge1xuICBjb25zdCB3ID0gd2luZG93IGFzIGFueVxuICBpZiAody5fX3N1YnNjcmliZXJDb3VudHMgPT09IHVuZGVmaW5lZCB8fCB3Ll9fc3Vic2NyaWJlckNvdW50cyA9PT0gbnVsbCkge1xuICAgIHcuX19zdWJzY3JpYmVyQ291bnRzID0ge31cbiAgfVxuICByZXR1cm4gdy5fX3N1YnNjcmliZXJDb3VudHNcbn1cblxuZnVuY3Rpb24gc2V0R2xvYmFsU3Vic2NyaWJlckNvdW50KGRlc2NyaXB0aW9uOiBzdHJpbmcsIGNvdW50OiBudW1iZXIpOiB2b2lkIHtcbiAgZ2V0R2xvYmFsU3Vic2NyaWJlckNvdW50cygpW2Rlc2NyaXB0aW9uXSA9IGNvdW50XG59XG4iXX0=
@@ -87,7 +87,7 @@ WidgetComponent.decorators = [
87
87
  ])
88
88
  ])
89
89
  ],
90
- styles: ["seam-widget{display:block;font-size:15px}seam-widget .seam-widget{background:#fff}seam-widget .widget-header{display:flex;flex-direction:row;border-bottom:1px solid #dee2e6;background:#f4f4f4;font-size:17px}seam-widget .widget-header .widget-header-content{flex:1 1 100%}seam-widget .widget-header .widget-header-btns-container{display:flex;flex-direction:row}seam-widget .widget-header .widget-header-btns-container>div{display:flex;flex-direction:column;justify-content:center;padding:4px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:15px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-title{font-size:17px}seam-widget .widget-header-icon{display:inline-block;vertical-align:top;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header-icon .widget-header-icon--img{height:100%;max-height:20px;max-width:20px}"]
90
+ styles: ["seam-widget{display:block;font-size:15px}seam-widget .seam-widget{background:#FFFFFF}seam-widget .widget-header{display:flex;flex-direction:row;border-bottom:1px solid #dee2e6;background:#F4F4F4;font-size:17px}seam-widget .widget-header .widget-header-content{flex:1 1 100%}seam-widget .widget-header .widget-header-btns-container{display:flex;flex-direction:row}seam-widget .widget-header .widget-header-btns-container>div{display:flex;flex-direction:column;justify-content:center;padding:4px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:15px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-title{font-size:17px}seam-widget .widget-header-icon{display:inline-block;vertical-align:top;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header-icon .widget-header-icon--img{height:100%;max-height:20px;max-width:20px}\n"]
91
91
  },] }
92
92
  ];
93
93
  WidgetComponent.ctorParameters = () => [];
@@ -9,7 +9,7 @@ WidgetButtonGroupComponent.decorators = [
9
9
  selector: 'seam-widget-button-group',
10
10
  template: "<ng-content select=\"[seamButton]\"></ng-content>\n",
11
11
  changeDetection: ChangeDetectionStrategy.OnPush,
12
- styles: [":host{display:block}"]
12
+ styles: [":host{display:block}\n"]
13
13
  },] }
14
14
  ];
15
15
  WidgetButtonGroupComponent.ctorParameters = () => [];
@@ -9,7 +9,7 @@ WidgetContentHeaderComponent.decorators = [
9
9
  selector: 'seam-widget-content-header',
10
10
  template: "<ng-content></ng-content>\n",
11
11
  encapsulation: ViewEncapsulation.None,
12
- styles: ["seam-widget-content-header{display:block;padding:.5rem .5rem 1rem}"]
12
+ styles: ["seam-widget-content-header{display:block;padding:.5rem .5rem 1rem}\n"]
13
13
  },] }
14
14
  ];
15
15
  WidgetContentHeaderComponent.ctorParameters = () => [];
@@ -24,7 +24,7 @@ WidgetEmptyLabelComponent.decorators = [
24
24
  selector: 'seam-widget-empty-label,a[seam-widget-empty-label],button[seam-widget-empty-label]',
25
25
  template: "<ng-content></ng-content>\n",
26
26
  encapsulation: ViewEncapsulation.None,
27
- styles: ["seam-widget-empty-label{display:block;width:100%;text-align:left;font-size:15px;padding:.5rem}"]
27
+ styles: ["seam-widget-empty-label{display:block;width:100%;text-align:left;font-size:15px;padding:.5rem}\n"]
28
28
  },] }
29
29
  ];
30
30
  WidgetEmptyLabelComponent.ctorParameters = () => [
@@ -9,7 +9,7 @@ WidgetFooterLinkComponent.decorators = [
9
9
  selector: 'a[seam-widget-footer-link]',
10
10
  template: "<ng-content></ng-content>\n",
11
11
  encapsulation: ViewEncapsulation.None,
12
- styles: ["a[seam-widget-footer-link]{display:block;text-align:center;margin-top:.5rem}"]
12
+ styles: ["a[seam-widget-footer-link]{display:block;text-align:center;margin-top:.5rem}\n"]
13
13
  },] }
14
14
  ];
15
15
  WidgetFooterLinkComponent.ctorParameters = () => [];
@@ -9,7 +9,7 @@ WidgetFooterTextComponent.decorators = [
9
9
  selector: 'seam-widget-footer-text',
10
10
  template: "<em>\n <ng-content></ng-content>\n</em>\n",
11
11
  encapsulation: ViewEncapsulation.None,
12
- styles: ["seam-widget-footer-text{display:block;font-size:13px;margin-top:.5rem}"]
12
+ styles: ["seam-widget-footer-text{display:block;font-size:13px;margin-top:.5rem}\n"]
13
13
  },] }
14
14
  ];
15
15
  WidgetFooterTextComponent.ctorParameters = () => [];
@@ -22,7 +22,7 @@ WidgetHeaderBadgeComponent.decorators = [
22
22
  },
23
23
  encapsulation: ViewEncapsulation.None,
24
24
  changeDetection: ChangeDetectionStrategy.OnPush,
25
- styles: ["seam-widget-header-badge.badge{font-size:17px}"]
25
+ styles: ["seam-widget-header-badge.badge{font-size:17px}\n"]
26
26
  },] }
27
27
  ];
28
28
  WidgetHeaderBadgeComponent.ctorParameters = () => [
@@ -25,7 +25,7 @@ WidgetTileFooterItemComponent.decorators = [
25
25
  class: 'btn btn-link py-0 px-1'
26
26
  },
27
27
  changeDetection: ChangeDetectionStrategy.OnPush,
28
- styles: [":host{font-size:12px}"]
28
+ styles: [":host{font-size:12px}\n"]
29
29
  },] }
30
30
  ];
31
31
  WidgetTileFooterItemComponent.ctorParameters = () => [
@@ -9,7 +9,7 @@ WidgetTileGroupComponent.decorators = [
9
9
  selector: 'seam-widget-tile-group',
10
10
  template: "<ng-content select=\"[seam-widget-tile],seam-widget-tile\"></ng-content>\n<ng-content select=\"seam-widget-tile-footer\"></ng-content>\n",
11
11
  changeDetection: ChangeDetectionStrategy.OnPush,
12
- styles: [":host{display:block;margin-bottom:.5rem}:host:last-child{margin-bottom:0}:host ::ng-deep [seam-widget-tile]{margin-bottom:0}"]
12
+ styles: [":host{display:block;margin-bottom:.5rem}:host:last-child{margin-bottom:0}:host ::ng-deep [seam-widget-tile]{margin-bottom:0}\n"]
13
13
  },] }
14
14
  ];
15
15
  WidgetTileGroupComponent.ctorParameters = () => [];
@@ -79,7 +79,7 @@ WidgetTileComponent.decorators = [
79
79
  inputs: ['disabled'],
80
80
  exportAs: 'seamWidgetTile',
81
81
  encapsulation: ViewEncapsulation.None,
82
- styles: ["a[seam-widget-tile],button[seam-widget-tile],seam-widget-tile{display:block;width:100%;padding:4px;text-decoration:none;color:#212529;font-size:14px;font-weight:400;line-height:18px;border:1px solid #dee2e6;border-radius:10px;margin-bottom:.5rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}a[seam-widget-tile]:hover,button[seam-widget-tile]:hover,seam-widget-tile:hover{color:#212529;background-color:#f4f4f4;text-decoration:none}a[seam-widget-tile].focus,a[seam-widget-tile]:focus,button[seam-widget-tile].focus,button[seam-widget-tile]:focus,seam-widget-tile.focus,seam-widget-tile:focus{box-shadow:0 0 0 .2rem rgba(53,126,189,.25);outline:0}a[seam-widget-tile].disabled,a[seam-widget-tile]:disabled,button[seam-widget-tile].disabled,button[seam-widget-tile]:disabled,seam-widget-tile.disabled,seam-widget-tile:disabled{opacity:.65;pointer-events:none;cursor:default;filter:grayscale(1)}a[seam-widget-tile]:last-child,button[seam-widget-tile]:last-child,seam-widget-tile:last-child{margin-bottom:0}a[seam-widget-tile] .widget-tile--notification-icon,button[seam-widget-tile] .widget-tile--notification-icon,seam-widget-tile .widget-tile--notification-icon{position:absolute;bottom:-3px;right:-3px;width:15px!important;height:15px!important}a[seam-widget-tile] seam-icon img[src$=\".svg\"],button[seam-widget-tile] seam-icon img[src$=\".svg\"],seam-widget-tile seam-icon img[src$=\".svg\"]{height:100%}"]
82
+ styles: ["seam-widget-tile,a[seam-widget-tile],button[seam-widget-tile]{display:block;width:100%;padding:4px;text-decoration:none;color:#212529;font-size:14px;font-weight:400;line-height:18px;border:1px solid #dee2e6;border-radius:10px;margin-bottom:.5rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}seam-widget-tile:hover,a[seam-widget-tile]:hover,button[seam-widget-tile]:hover{color:#212529;background-color:#f4f4f4;text-decoration:none}seam-widget-tile:focus,seam-widget-tile.focus,a[seam-widget-tile]:focus,a[seam-widget-tile].focus,button[seam-widget-tile]:focus,button[seam-widget-tile].focus{box-shadow:0 0 0 .2rem #357ebd40;outline:0}seam-widget-tile.disabled,seam-widget-tile:disabled,a[seam-widget-tile].disabled,a[seam-widget-tile]:disabled,button[seam-widget-tile].disabled,button[seam-widget-tile]:disabled{opacity:.65;pointer-events:none;cursor:default;filter:grayscale(1)}seam-widget-tile:last-child,a[seam-widget-tile]:last-child,button[seam-widget-tile]:last-child{margin-bottom:0}seam-widget-tile .widget-tile--notification-icon,a[seam-widget-tile] .widget-tile--notification-icon,button[seam-widget-tile] .widget-tile--notification-icon{position:absolute;bottom:-3px;right:-3px;width:15px!important;height:15px!important}seam-widget-tile seam-icon img[src$=\".svg\"],a[seam-widget-tile] seam-icon img[src$=\".svg\"],button[seam-widget-tile] seam-icon img[src$=\".svg\"]{height:100%}\n"]
83
83
  },] }
84
84
  ];
85
85
  WidgetTileComponent.ctorParameters = () => [
@@ -8,7 +8,7 @@ WidgetTileListComponent.decorators = [
8
8
  { type: Component, args: [{
9
9
  selector: 'seam-widget-tile-list',
10
10
  template: "<ng-content select=\"[seam-widget-tile],seam-widget-tile,seam-widget-tile-group\"></ng-content>\n",
11
- styles: [":host{display:flex;flex-direction:column}"]
11
+ styles: [":host{display:flex;flex-direction:column}\n"]
12
12
  },] }
13
13
  ];
14
14
  WidgetTileListComponent.ctorParameters = () => [];
@@ -9,7 +9,7 @@ WidgetFooterComponent.decorators = [
9
9
  template: "<div class=\"widget-footer--left\">\n <ng-content select=\"seam-widget-footer-text\"></ng-content>\n</div>\n<div class=\"widget-footer--right\">\n <ng-content select=\"seam-widget-button-group\"></ng-content>\n</div>\n",
10
10
  changeDetection: ChangeDetectionStrategy.OnPush,
11
11
  encapsulation: ViewEncapsulation.None,
12
- styles: ["seam-widget-footer{display:flex;flex-direction:row;margin:.25rem}seam-widget-footer .widget-footer--left{flex:1 1 100%}seam-widget-footer .widget-footer--right{flex:0 0 auto}"]
12
+ styles: ["seam-widget-footer{display:flex;flex-direction:row;margin:.25rem}seam-widget-footer .widget-footer--left{flex:1 1 100%}seam-widget-footer .widget-footer--right{flex:0 0 auto}\n"]
13
13
  },] }
14
14
  ];
15
15
  WidgetFooterComponent.ctorParameters = () => [];
@@ -219,7 +219,7 @@ ProgressCircleButtonComponent.decorators = [
219
219
  '[attr.aria-disabled]': 'disabled.toString()',
220
220
  '[attr.disabled]': 'disabled || null'
221
221
  },
222
- styles: [":host{padding-right:45px;position:relative}:host.btn-sm{padding-right:40px}:host.btn-sm ::ng-deep .seam-progress-circle{padding:8px}:host.btn-lg{padding-right:50px}:host.btn-lg ::ng-deep .seam-progress-circle{padding:0}:host seam-progress-circle.progress-circle-btn--icon{top:0;right:0;height:100%;width:45px;position:absolute}"]
222
+ styles: [":host{padding-right:45px;position:relative}:host.btn-sm{padding-right:40px}:host.btn-sm ::ng-deep .seam-progress-circle{padding:8px}:host.btn-lg{padding-right:50px}:host.btn-lg ::ng-deep .seam-progress-circle{padding:0}:host seam-progress-circle.progress-circle-btn--icon{top:0;right:0;height:100%;width:45px;position:absolute}\n"]
223
223
  },] }
224
224
  ];
225
225
  ProgressCircleButtonComponent.ctorParameters = () => [
@@ -16,7 +16,7 @@ CardActionComponent.decorators = [
16
16
  { type: Component, args: [{
17
17
  selector: 'seam-card-action',
18
18
  template: "<button type=\"button\"\n class=\"btn border-0 h-100\"\n [seamHoverClassToggle]=\"{ default: 'btn-outline-lightgray', hover: 'btn-outline-' + theme }\"\n [attr.title]=\"title\"\n [attr.data-last-action]=\"isLastAction ? 'true' : 'false'\">\n <ng-content></ng-content>\n</button>\n",
19
- styles: [":host{display:block}.btn{transition:.5s ease-in-out}.btn:not([data-last-action=true]){border-radius:0}.btn[data-last-action=true]{border-radius:.25rem;border-top-right-radius:0;border-top-left-radius:0;border-bottom-left-radius:0}"]
19
+ styles: [":host{display:block}.btn{transition:.5s ease-in-out}.btn:not([data-last-action=true]){border-radius:0}.btn[data-last-action=true]{border-radius:0 0 .25rem}\n"]
20
20
  },] }
21
21
  ];
22
22
  CardActionComponent.propDecorators = {
@@ -48,7 +48,7 @@ CardBodyComponent.decorators = [
48
48
  { type: Component, args: [{
49
49
  selector: 'seam-card-body',
50
50
  template: "<div class=\"card-content p-2\">\n <ng-content></ng-content>\n</div>\n<div class=\"card--actions\">\n <ng-content select=\"seam-card-action\"></ng-content>\n</div>\n",
51
- styles: [":host{display:flex;flex-direction:row}.card-content{flex:1 1 auto}.card--actions,.card-content{display:flex;flex-direction:row}"]
51
+ styles: [":host{display:flex;flex-direction:row}.card-content{flex:1 1 auto;display:flex;flex-direction:row}.card--actions{display:flex;flex-direction:row}\n"]
52
52
  },] }
53
53
  ];
54
54
  CardBodyComponent.ctorParameters = () => [];
@@ -1,5 +1,5 @@
1
1
  import { InjectionToken, forwardRef, Component, Inject, Optional, Input, ChangeDetectionStrategy, NgModule } from '@angular/core';
2
- import { combineLatest, of } from 'rxjs';
2
+ import { of, combineLatest } from 'rxjs';
3
3
  import { switchMap, startWith, map, shareReplay, tap } from 'rxjs/operators';
4
4
  import { CommonModule } from '@angular/common';
5
5
  import { FormControl, ReactiveFormsModule } from '@angular/forms';
@@ -29,6 +29,9 @@ function composeDataFilters(filters) {
29
29
  };
30
30
  }
31
31
  function composeDataFilterStates(filters) {
32
+ if (filters.length === 0) {
33
+ return of([]);
34
+ }
32
35
  return combineLatest(filters.map(f => f.filterStateChanges.pipe(startWith(undefined), map(() => f.filterState()))));
33
36
  }
34
37
 
@@ -142,7 +145,7 @@ DataFilterTextComponent.decorators = [
142
145
  selector: 'seam-data-filter-text',
143
146
  template: "<div class=\"position-relative\"\n [class.data-filter-text-has-icon]=\"iconTpl\"\n (click)=\"inp.focus()\">\n <label [attr.for]=\"inp.id\" class=\"sr-only\">Text filter</label>\n <input seamInput #inp=\"seamInput\" seamInputSize=\"sm\" [formControl]=\"_control\" [placeholder]=\"placeholder\">\n <ng-container *ngIf=\"iconTpl\">\n <ng-container *ngTemplateOutlet=\"iconTpl\"></ng-container>\n </ng-container>\n</div>\n",
144
147
  providers: [DATA_FILTER_TEXT],
145
- styles: [":host{display:block}.data-filter-text-has-icon>input{padding-left:30px}.data-filter-text-has-icon ::ng-deep fa-icon{position:absolute;top:3px;left:10px;bottom:0}.data-filter-text-has-icon ::ng-deep fa-icon .svg-inline--fa{vertical-align:middle}"]
148
+ styles: [":host{display:block}.data-filter-text-has-icon>input{padding-left:30px}.data-filter-text-has-icon ::ng-deep fa-icon{position:absolute;top:3px;left:10px;bottom:0px}.data-filter-text-has-icon ::ng-deep fa-icon .svg-inline--fa{vertical-align:middle}\n"]
146
149
  },] }
147
150
  ];
148
151
  DataFilterTextComponent.ctorParameters = () => [
@@ -240,7 +243,7 @@ DataFilterSearchComponent.decorators = [
240
243
  template: "<div class=\"position-relative\"\n [class.data-filter-search-has-icon]=\"iconTpl || icon\"\n (click)=\"inp.focus()\">\n <label [attr.for]=\"inp.id\" class=\"sr-only\">Search filter</label>\n <input seamInput #inp=\"seamInput\" seamInputSize=\"sm\" [formControl]=\"_control\" [placeholder]=\"placeholder\">\n <ng-container *ngIf=\"iconTpl; else searchIconTpl\">\n <div class=\"data-filter-search--icon-wrapper\">\n <ng-container *ngTemplateOutlet=\"iconTpl\"></ng-container>\n </div>\n </ng-container>\n <ng-template #searchIconTpl>\n <ng-container *ngIf=\"icon\">\n <div class=\"data-filter-search--icon-wrapper\">\n <seam-icon [icon]=\"icon\" class=\"text-muted\"></seam-icon>\n </div>\n </ng-container>\n </ng-template>\n</div>\n",
241
244
  providers: [DATA_FILTER_SEARCH],
242
245
  changeDetection: ChangeDetectionStrategy.OnPush,
243
- styles: [":host{display:flex;flex:0 1 300px}.data-filter-search-has-icon{width:100%}.data-filter-search-has-icon>input{padding-left:30px}.data-filter-search-has-icon .data-filter-search--icon-wrapper{position:absolute;top:3px;left:10px;bottom:0}.data-filter-search-has-icon .data-filter-search--icon-wrapper ::ng-deep .svg-inline--fa{vertical-align:middle}"]
246
+ styles: [":host{display:flex;flex:0 1 300px}.data-filter-search-has-icon{width:100%}.data-filter-search-has-icon>input{padding-left:30px}.data-filter-search-has-icon .data-filter-search--icon-wrapper{position:absolute;top:3px;left:10px;bottom:0px}.data-filter-search-has-icon .data-filter-search--icon-wrapper ::ng-deep .svg-inline--fa{vertical-align:middle}\n"]
244
247
  },] }
245
248
  ];
246
249
  DataFilterSearchComponent.ctorParameters = () => [