@theseam/ui-common 0.3.15-beta.0 → 0.3.15-beta.1

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 (2113) hide show
  1. package/asset-reader/asset-reader-helper.service.d.ts +3 -0
  2. package/asset-reader/asset-reader.module.d.ts +5 -0
  3. package/asset-reader/encrypted-asset-link.directive.d.ts +3 -0
  4. package/asset-reader/index.d.ts +5 -0
  5. package/assets/storybook-intro.gif +0 -0
  6. package/breadcrumbs/breadcrumb.d.ts +1 -1
  7. package/breadcrumbs/breadcrumbs/breadcrumbs.component.d.ts +4 -3
  8. package/breadcrumbs/breadcrumbs-resolver.d.ts +1 -1
  9. package/breadcrumbs/breadcrumbs.module.d.ts +7 -0
  10. package/breadcrumbs/breadcrumbs.service.d.ts +3 -0
  11. package/breadcrumbs/index.d.ts +5 -0
  12. package/buttons/badge-button/badge-button.component.d.ts +5 -0
  13. package/buttons/button/button.component.d.ts +7 -0
  14. package/buttons/buttons.module.d.ts +10 -0
  15. package/buttons/index.d.ts +5 -0
  16. package/buttons/progress-circle-button/progress-circle-button.component.d.ts +3 -0
  17. package/buttons/toggle-button/toggle-button.component.d.ts +3 -0
  18. package/card/card-action/card-action.component.d.ts +3 -0
  19. package/card/card-body/card-body.component.d.ts +5 -4
  20. package/card/card-footer/card-footer.component.d.ts +4 -4
  21. package/card/card-header/card-header.component.d.ts +4 -4
  22. package/card/card.component.d.ts +4 -4
  23. package/card/card.module.d.ts +11 -0
  24. package/card/index.d.ts +5 -0
  25. package/carousel/carousel-slide.directive.d.ts +8 -0
  26. package/carousel/carousel.component.d.ts +85 -0
  27. package/carousel/carousel.module.d.ts +11 -0
  28. package/carousel/index.d.ts +5 -0
  29. package/carousel/public-api.d.ts +3 -0
  30. package/checkbox/checkbox.component.d.ts +5 -4
  31. package/checkbox/checkbox.module.d.ts +7 -0
  32. package/checkbox/index.d.ts +5 -0
  33. package/checkbox/public-api.d.ts +1 -0
  34. package/checkbox/testing/checkbox.harness.d.ts +49 -0
  35. package/checkbox/testing/index.d.ts +1 -0
  36. package/confirm-dialog/confirm-click.directive.d.ts +3 -0
  37. package/confirm-dialog/confirm-dialog.component.d.ts +3 -0
  38. package/confirm-dialog/confirm-dialog.module.d.ts +10 -0
  39. package/confirm-dialog/confirm-dialog.service.d.ts +3 -0
  40. package/confirm-dialog/index.d.ts +5 -0
  41. package/core/common-behaviors/active.d.ts +2 -2
  42. package/core/common-behaviors/constructor.d.ts +1 -1
  43. package/core/common-behaviors/disabled.d.ts +2 -2
  44. package/core/common-behaviors/initialized.d.ts +2 -2
  45. package/core/common-behaviors/size.d.ts +1 -1
  46. package/core/common-behaviors/tabindex.d.ts +1 -1
  47. package/core/common-behaviors/theme.d.ts +1 -1
  48. package/core/index.d.ts +5 -0
  49. package/core/input-decorators/input-boolean.decorator.d.ts +1 -1
  50. package/core/input-decorators/input-number.decorator.d.ts +1 -1
  51. package/data-exporter/data-exporter.d.ts +1 -1
  52. package/data-exporter/data-exporter.module.d.ts +4 -0
  53. package/data-exporter/exporters/csv-exporter.d.ts +3 -0
  54. package/data-exporter/exporters/xlsx-exporter.d.ts +3 -0
  55. package/data-exporter/index.d.ts +5 -0
  56. package/data-filters/data-filter.d.ts +4 -4
  57. package/data-filters/data-filters.module.d.ts +13 -0
  58. package/data-filters/filters/data-filter-search/data-filter-search.component.d.ts +6 -3
  59. package/data-filters/filters/data-filter-search/search-filter-options.d.ts +1 -1
  60. package/data-filters/filters/data-filter-text/data-filter-text.component.d.ts +5 -2
  61. package/data-filters/filters/data-filter-toggle-buttons/data-filter-toggle-buttons.component.d.ts +5 -2
  62. package/data-filters/index.d.ts +5 -0
  63. package/datatable/datatable/datatable.component.d.ts +3 -0
  64. package/datatable/datatable-action-menu/datatable-action-menu.component.d.ts +3 -0
  65. package/datatable/datatable-action-menu-item/datatable-action-menu-item.component.d.ts +3 -0
  66. package/datatable/datatable-column/datatable-column.component.d.ts +6 -4
  67. package/datatable/datatable-column-preferences/datatable-column-preferences.component.d.ts +5 -2
  68. package/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.d.ts +4 -3
  69. package/datatable/datatable-export-button/datatable-export-button.component.d.ts +4 -3
  70. package/datatable/datatable-footer/datatable-footer-tpl.directive.d.ts +3 -0
  71. package/datatable/datatable-footer/datatable-footer.directive.d.ts +3 -0
  72. package/datatable/datatable-menu-bar/datatable-menu-bar.component.d.ts +5 -5
  73. package/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.d.ts +4 -4
  74. package/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.d.ts +4 -4
  75. package/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.d.ts +4 -4
  76. package/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.d.ts +4 -4
  77. package/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.d.ts +4 -3
  78. package/datatable/datatable-row-detail/datatable-row-detail-tpl.directive.d.ts +3 -0
  79. package/datatable/datatable-row-detail/datatable-row-detail.directive.d.ts +3 -0
  80. package/datatable/datatable.module.d.ts +45 -0
  81. package/datatable/directives/datatable-action-menu-item.directive.d.ts +5 -4
  82. package/datatable/directives/datatable-action-menu-toggle.directive.d.ts +3 -0
  83. package/datatable/directives/datatable-cell-tpl.directive.d.ts +3 -0
  84. package/datatable/directives/datatable-filter.directive.d.ts +3 -0
  85. package/datatable/directives/datatable-row-action-item.directive.d.ts +3 -0
  86. package/datatable/index.d.ts +5 -0
  87. package/datatable/models/action-item-column-position.d.ts +1 -1
  88. package/datatable/models/preferences.d.ts +1 -1
  89. package/datatable/models/table-column.d.ts +1 -1
  90. package/datatable/services/columns-alterations-manager.service.d.ts +3 -0
  91. package/datatable/services/columns-manager.service.d.ts +4 -1
  92. package/datatable/services/datatable-column-changes.service.d.ts +3 -0
  93. package/datatable/services/datatable-preferences.service.d.ts +3 -0
  94. package/datatable/services/datatable-scrollbar-helper.service.d.ts +3 -0
  95. package/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.d.ts +4 -3
  96. package/datatable-dynamic/datatable-dynamic-def.d.ts +3 -3
  97. package/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.d.ts +3 -0
  98. package/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.d.ts +6 -4
  99. package/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.d.ts +1 -1
  100. package/datatable-dynamic/datatable-dynamic.component.d.ts +4 -4
  101. package/datatable-dynamic/datatable-dynamic.module.d.ts +20 -0
  102. package/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.d.ts +6 -4
  103. package/datatable-dynamic/dynamic-datatable-def.service.d.ts +3 -0
  104. package/datatable-dynamic/dynamic-datatable-row-actions.service.d.ts +3 -0
  105. package/datatable-dynamic/index.d.ts +5 -0
  106. package/datatable-dynamic/models/dynamic-datatable-action-menu-record.d.ts +1 -1
  107. package/datatable-dynamic/models/dynamic-datatable-menu-bar.d.ts +2 -2
  108. package/dynamic/action/api/dynamic-action-api.service.d.ts +3 -0
  109. package/dynamic/action/dynamic-action-helper.service.d.ts +3 -0
  110. package/dynamic/action/link/dynamic-action-link.service.d.ts +3 -0
  111. package/dynamic/action/modal/dynamic-action-modal-def.d.ts +1 -1
  112. package/dynamic/action/modal/dynamic-action-modal.service.d.ts +3 -0
  113. package/dynamic/dynamic-value-helper.service.d.ts +8 -4
  114. package/dynamic/evaluators/exporters-data-evaluator/exporters-data-evaluator.d.ts +3 -0
  115. package/dynamic/evaluators/jexl-evaluator/jexl-evaluator.d.ts +6 -2
  116. package/dynamic/index.d.ts +5 -0
  117. package/dynamic/models/dynamic-value-base-type.d.ts +1 -1
  118. package/dynamic/models/dynamic-value-evaluatable-type.d.ts +2 -1
  119. package/dynamic/models/dynamic-value-primitive.d.ts +1 -1
  120. package/dynamic/models/dynamic-value.d.ts +1 -1
  121. package/dynamic/tokens/api-config.d.ts +1 -1
  122. package/dynamic-component-loader/dynamic-component-loader.module.d.ts +7 -3
  123. package/dynamic-component-loader/dynamic-component-loader.service.d.ts +7 -6
  124. package/dynamic-component-loader/dynamic-component-manifest.d.ts +4 -4
  125. package/dynamic-component-loader/index.d.ts +5 -0
  126. package/esm2020/asset-reader/asset-reader-helper.service.mjs +70 -0
  127. package/esm2020/asset-reader/asset-reader.module.mjs +20 -0
  128. package/esm2020/asset-reader/encrypted-asset-link.directive.mjs +74 -0
  129. package/esm2020/breadcrumbs/breadcrumb.mjs +2 -0
  130. package/esm2020/breadcrumbs/breadcrumbs/breadcrumbs.component.mjs +18 -0
  131. package/esm2020/breadcrumbs/breadcrumbs-resolver.mjs +2 -0
  132. package/esm2020/breadcrumbs/breadcrumbs.module.mjs +28 -0
  133. package/esm2020/breadcrumbs/breadcrumbs.service.mjs +156 -0
  134. package/esm2020/buttons/badge-button/badge-button.component.mjs +62 -0
  135. package/esm2020/buttons/button/button.component.mjs +84 -0
  136. package/esm2020/buttons/buttons.module.mjs +51 -0
  137. package/esm2020/buttons/progress-circle-button/progress-circle-button.component.mjs +52 -0
  138. package/esm2020/buttons/toggle-button/toggle-button.component.mjs +79 -0
  139. package/esm2020/card/card-action/card-action.component.mjs +31 -0
  140. package/esm2020/card/card-body/card-body.component.mjs +32 -0
  141. package/esm2020/card/card-footer/card-footer.component.mjs +11 -0
  142. package/esm2020/card/card-header/card-header.component.mjs +21 -0
  143. package/esm2020/card/card.component.mjs +17 -0
  144. package/esm2020/card/card.module.mjs +48 -0
  145. package/esm2020/carousel/carousel-slide.directive.mjs +16 -0
  146. package/esm2020/carousel/carousel.component.mjs +211 -0
  147. package/esm2020/carousel/carousel.module.mjs +38 -0
  148. package/esm2020/carousel/public-api.mjs +4 -0
  149. package/esm2020/carousel/theseam-ui-common-carousel.mjs +5 -0
  150. package/esm2020/checkbox/checkbox.component.mjs +280 -0
  151. package/esm2020/checkbox/checkbox.module.mjs +28 -0
  152. package/esm2020/checkbox/public-api.mjs +4 -0
  153. package/esm2020/checkbox/testing/checkbox.harness.mjs +63 -0
  154. package/esm2020/checkbox/testing/index.mjs +2 -0
  155. package/esm2020/confirm-dialog/confirm-click.directive.mjs +69 -0
  156. package/esm2020/confirm-dialog/confirm-dialog.component.mjs +24 -0
  157. package/esm2020/confirm-dialog/confirm-dialog.module.mjs +47 -0
  158. package/esm2020/confirm-dialog/confirm-dialog.service.mjs +38 -0
  159. package/esm2020/core/common-behaviors/active.mjs +14 -0
  160. package/esm2020/core/common-behaviors/disabled.mjs +21 -0
  161. package/esm2020/core/common-behaviors/initialized.mjs +63 -0
  162. package/esm2020/core/common-behaviors/size.mjs +24 -0
  163. package/esm2020/core/common-behaviors/tabindex.mjs +23 -0
  164. package/esm2020/core/common-behaviors/theme.mjs +24 -0
  165. package/esm2020/core/input-decorators/input-boolean.decorator.mjs +26 -0
  166. package/esm2020/core/input-decorators/input-number.decorator.mjs +26 -0
  167. package/esm2020/data-exporter/data-exporter.module.mjs +25 -0
  168. package/esm2020/data-exporter/exporters/csv-exporter.mjs +35 -0
  169. package/esm2020/data-exporter/exporters/xlsx-exporter.mjs +33 -0
  170. package/esm2020/data-filters/data-filter.mjs +25 -0
  171. package/esm2020/data-filters/data-filters.module.mjs +66 -0
  172. package/esm2020/data-filters/filters/data-filter-search/data-filter-search.component.mjs +121 -0
  173. package/esm2020/data-filters/filters/data-filter-text/data-filter-text.component.mjs +148 -0
  174. package/esm2020/data-filters/filters/data-filter-toggle-buttons/data-filter-toggle-buttons.component.mjs +166 -0
  175. package/esm2020/datatable/datatable/datatable.component.mjs +686 -0
  176. package/esm2020/datatable/datatable-action-menu/datatable-action-menu.component.mjs +100 -0
  177. package/esm2020/datatable/datatable-action-menu-item/datatable-action-menu-item.component.mjs +48 -0
  178. package/esm2020/datatable/datatable-column/datatable-column.component.mjs +107 -0
  179. package/esm2020/datatable/datatable-column-preferences/datatable-column-preferences.component.mjs +67 -0
  180. package/esm2020/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.mjs +51 -0
  181. package/esm2020/datatable/datatable-export-button/datatable-export-button.component.mjs +106 -0
  182. package/esm2020/datatable/datatable-footer/datatable-footer-tpl.directive.mjs +16 -0
  183. package/esm2020/datatable/datatable-footer/datatable-footer.directive.mjs +24 -0
  184. package/esm2020/datatable/datatable-menu-bar/datatable-menu-bar.component.mjs +49 -0
  185. package/esm2020/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.mjs +11 -0
  186. package/esm2020/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.mjs +11 -0
  187. package/esm2020/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.mjs +11 -0
  188. package/esm2020/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.mjs +11 -0
  189. package/esm2020/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.mjs +30 -0
  190. package/esm2020/datatable/datatable-row-detail/datatable-row-detail-tpl.directive.mjs +16 -0
  191. package/esm2020/datatable/datatable-row-detail/datatable-row-detail.directive.mjs +77 -0
  192. package/esm2020/datatable/datatable.module.mjs +205 -0
  193. package/esm2020/datatable/directives/datatable-action-menu-item.directive.mjs +62 -0
  194. package/esm2020/datatable/directives/datatable-action-menu-toggle.directive.mjs +137 -0
  195. package/esm2020/datatable/directives/datatable-cell-tpl.directive.mjs +16 -0
  196. package/esm2020/datatable/directives/datatable-filter.directive.mjs +27 -0
  197. package/esm2020/datatable/directives/datatable-row-action-item.directive.mjs +16 -0
  198. package/esm2020/datatable/models/action-item-column-position.mjs +5 -0
  199. package/esm2020/datatable/models/columns-alteration.mjs +38 -0
  200. package/esm2020/datatable/models/columns-alterations/order.columns-alteration.mjs +83 -0
  201. package/esm2020/datatable/models/datatable-gql-data-source.mjs +15 -0
  202. package/esm2020/datatable/models/internal-column-props.mjs +15 -0
  203. package/esm2020/datatable/models/sort-item.mjs +2 -0
  204. package/esm2020/datatable/services/columns-alterations-manager.service.mjs +136 -0
  205. package/esm2020/datatable/services/columns-manager.service.mjs +286 -0
  206. package/esm2020/datatable/services/datatable-column-changes.service.mjs +20 -0
  207. package/esm2020/datatable/services/datatable-preferences.service.mjs +166 -0
  208. package/esm2020/datatable/services/datatable-scrollbar-helper.service.mjs +50 -0
  209. package/esm2020/datatable/theseam-ui-common-datatable.mjs +5 -0
  210. package/esm2020/datatable/utils/map-columns-alterations-states.mjs +42 -0
  211. package/esm2020/datatable/utils/set-column-defaults.mjs +10 -0
  212. package/esm2020/datatable/utils/with-stored-column-info.mjs +20 -0
  213. package/esm2020/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.mjs +118 -0
  214. package/esm2020/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.mjs +50 -0
  215. package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.mjs +148 -0
  216. package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.mjs +2 -0
  217. package/esm2020/datatable-dynamic/datatable-dynamic.component.mjs +75 -0
  218. package/esm2020/datatable-dynamic/datatable-dynamic.module.mjs +80 -0
  219. package/esm2020/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.mjs +400 -0
  220. package/esm2020/datatable-dynamic/dynamic-datatable-def.service.mjs +88 -0
  221. package/esm2020/datatable-dynamic/dynamic-datatable-row-actions.service.mjs +46 -0
  222. package/esm2020/datatable-dynamic/models/dynamic-datatable-menu-bar.mjs +2 -0
  223. package/esm2020/dynamic/action/api/dynamic-action-api.service.mjs +209 -0
  224. package/esm2020/dynamic/action/dynamic-action-helper.service.mjs +158 -0
  225. package/esm2020/dynamic/action/link/dynamic-action-link.service.mjs +47 -0
  226. package/esm2020/dynamic/action/modal/dynamic-action-modal-def.mjs +2 -0
  227. package/esm2020/dynamic/action/modal/dynamic-action-modal.service.mjs +85 -0
  228. package/esm2020/dynamic/dynamic-value-helper.service.mjs +105 -0
  229. package/esm2020/dynamic/evaluators/exporters-data-evaluator/exporters-data-evaluator.mjs +30 -0
  230. package/esm2020/dynamic/evaluators/jexl-evaluator/jexl-evaluator.mjs +32 -0
  231. package/esm2020/dynamic/models/dynamic-value-evaluatable-type.mjs +2 -0
  232. package/esm2020/dynamic-component-loader/dynamic-component-loader.module.mjs +50 -0
  233. package/esm2020/dynamic-component-loader/dynamic-component-loader.service.mjs +78 -0
  234. package/esm2020/dynamic-component-loader/dynamic-component-manifest.mjs +2 -0
  235. package/esm2020/footer-bar/footer-bar/footer-bar.component.mjs +11 -0
  236. package/esm2020/footer-bar/footer-bar.module.mjs +20 -0
  237. package/esm2020/form-field/form-field-error.directive.mjs +30 -0
  238. package/esm2020/form-field/form-field-help-text.directive.mjs +16 -0
  239. package/esm2020/form-field/form-field-label-tpl.directive.mjs +16 -0
  240. package/esm2020/form-field/form-field-required-indicator.component.mjs +46 -0
  241. package/esm2020/form-field/form-field-tokens.mjs +3 -0
  242. package/esm2020/form-field/form-field.component.mjs +221 -0
  243. package/esm2020/form-field/form-field.module.mjs +61 -0
  244. package/esm2020/form-field/input.directive.mjs +220 -0
  245. package/esm2020/form-field/public-api.mjs +10 -0
  246. package/esm2020/form-field/testing/form-field-required-indicator.harness.mjs +8 -0
  247. package/esm2020/form-field/testing/index.mjs +2 -0
  248. package/esm2020/form-field-error/form-field-error/form-field-error.component.mjs +26 -0
  249. package/esm2020/form-field-error/form-field-error-list/form-field-error-list-item-tpl.directive.mjs +26 -0
  250. package/esm2020/form-field-error/form-field-error-list/form-field-error-list-item.directive.mjs +18 -0
  251. package/esm2020/form-field-error/form-field-error-list/form-field-error-list.component.mjs +384 -0
  252. package/esm2020/form-field-error/form-field-error.module.mjs +39 -0
  253. package/esm2020/framework/base-layout/base-layout.component.mjs +133 -0
  254. package/esm2020/framework/base-layout/base-layout.module.mjs +80 -0
  255. package/esm2020/framework/base-layout/directives/base-layout-content-footer.directive.mjs +16 -0
  256. package/esm2020/framework/base-layout/directives/base-layout-content-header.directive.mjs +16 -0
  257. package/esm2020/framework/base-layout/directives/base-layout-content.directive.mjs +16 -0
  258. package/esm2020/framework/base-layout/directives/base-layout-nav-toggle.directive.mjs +66 -0
  259. package/esm2020/framework/base-layout/directives/base-layout-side-bar-footer.directive.mjs +16 -0
  260. package/esm2020/framework/base-layout/directives/base-layout-side-bar-header.directive.mjs +16 -0
  261. package/esm2020/framework/base-layout/directives/base-layout-side-bar.directive.mjs +16 -0
  262. package/esm2020/framework/base-layout/directives/base-layout-top-bar.directive.mjs +16 -0
  263. package/esm2020/framework/base-layout/index.mjs +15 -0
  264. package/esm2020/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.mjs +16 -0
  265. package/esm2020/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.mjs +23 -0
  266. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widget-portal-outlet.directive.mjs +119 -0
  267. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences.service.mjs +177 -0
  268. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.component.mjs +206 -0
  269. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.service.mjs +172 -0
  270. package/esm2020/framework/dashboard/dashboard-widgets-tokens.mjs +3 -0
  271. package/esm2020/framework/dashboard/dashboard.component.mjs +24 -0
  272. package/esm2020/framework/dashboard/dashboard.module.mjs +60 -0
  273. package/esm2020/framework/dynamic-router/dynamic-route-def.mjs +2 -0
  274. package/esm2020/framework/dynamic-router/dynamic-router.module.mjs +28 -0
  275. package/esm2020/framework/dynamic-router/hierarchy-router-outlet/hierarchy-route-animations.mjs +256 -0
  276. package/esm2020/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.mjs +116 -0
  277. package/esm2020/framework/dynamic-router/resolvers/hierarchy-level.resolver.mjs +26 -0
  278. package/esm2020/framework/nav/horizontal-nav/horizontal-nav.component.mjs +55 -0
  279. package/esm2020/framework/nav/nav-item/nav-item.component.mjs +227 -0
  280. package/esm2020/framework/nav/nav-utils.mjs +107 -0
  281. package/esm2020/framework/nav/nav.module.mjs +67 -0
  282. package/esm2020/framework/nav/nav.service.mjs +204 -0
  283. package/esm2020/framework/schema-form/schema-form-framework.component.mjs +18 -0
  284. package/esm2020/framework/schema-form/schema-form-framework.mjs +30 -0
  285. package/esm2020/framework/schema-form/schema-form.module.mjs +52 -0
  286. package/esm2020/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.mjs +43 -0
  287. package/esm2020/framework/schema-form-controls/schema-form-controls.module.mjs +79 -0
  288. package/esm2020/framework/schema-form-controls/schema-form-input/schema-form-input.component.mjs +34 -0
  289. package/esm2020/framework/schema-form-controls/schema-form-number/schema-form-number.component.mjs +40 -0
  290. package/esm2020/framework/schema-form-controls/schema-form-select/schema-form-select.component.mjs +38 -0
  291. package/esm2020/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.mjs +46 -0
  292. package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +144 -0
  293. package/esm2020/framework/side-nav/index.mjs +8 -0
  294. package/esm2020/framework/side-nav/side-nav-item/side-nav-item.component.mjs +169 -0
  295. package/esm2020/framework/side-nav/side-nav-toggle/side-nav-toggle.component.mjs +40 -0
  296. package/esm2020/framework/side-nav/side-nav-tokens.mjs +3 -0
  297. package/esm2020/framework/side-nav/side-nav-utils.mjs +80 -0
  298. package/esm2020/framework/side-nav/side-nav.component.mjs +372 -0
  299. package/esm2020/framework/side-nav/side-nav.models.mjs +2 -0
  300. package/esm2020/framework/side-nav/side-nav.module.mjs +32 -0
  301. package/esm2020/framework/side-nav/side-nav.service.mjs +178 -0
  302. package/esm2020/framework/theseam-ui-common-framework.mjs +5 -0
  303. package/esm2020/framework/top-bar/index.mjs +10 -0
  304. package/esm2020/framework/top-bar/top-bar-compact-menu-btn-detail.directive.mjs +16 -0
  305. package/esm2020/framework/top-bar/top-bar-item.directive.mjs +22 -0
  306. package/esm2020/framework/top-bar/top-bar-menu-btn-detail.directive.mjs +16 -0
  307. package/esm2020/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.mjs +56 -0
  308. package/esm2020/framework/top-bar/top-bar-menu.directive.mjs +19 -0
  309. package/esm2020/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.mjs +16 -0
  310. package/esm2020/framework/top-bar/top-bar-title/top-bar-title.component.mjs +17 -0
  311. package/esm2020/framework/top-bar/top-bar.component.mjs +141 -0
  312. package/esm2020/framework/top-bar/top-bar.module.mjs +83 -0
  313. package/esm2020/google-maps/google-maps/google-maps.component.mjs +298 -0
  314. package/esm2020/google-maps/google-maps-api-loader/google-maps-api-loader.mjs +3 -0
  315. package/esm2020/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.mjs +103 -0
  316. package/esm2020/google-maps/google-maps-api-loader/noop-google-maps-api-loader.mjs +25 -0
  317. package/esm2020/google-maps/google-maps-contextmenu.mjs +114 -0
  318. package/esm2020/google-maps/google-maps-controls.service.mjs +67 -0
  319. package/esm2020/google-maps/google-maps-feature-helpers.mjs +211 -0
  320. package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.mjs +209 -0
  321. package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.mjs +165 -0
  322. package/esm2020/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.mjs +58 -0
  323. package/esm2020/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.mjs +115 -0
  324. package/esm2020/google-maps/google-maps.module.mjs +70 -0
  325. package/esm2020/google-maps/google-maps.service.mjs +355 -0
  326. package/esm2020/google-maps/map-control.component.mjs +66 -0
  327. package/esm2020/google-maps/map-file-drop/map-file-drop.component.mjs +128 -0
  328. package/esm2020/google-maps/map-value-manager.service.mjs +48 -0
  329. package/esm2020/google-maps/public-api.mjs +17 -0
  330. package/esm2020/google-maps/theseam-ui-common-google-maps.mjs +5 -0
  331. package/esm2020/graphql/datatable/create-page-info-observable.mjs +38 -0
  332. package/esm2020/graphql/datatable/datatable-graphql-query-ref.mjs +212 -0
  333. package/esm2020/graphql/datatable/datatable-graphql.service.mjs +50 -0
  334. package/esm2020/graphql/datatable/datatable-helpers.mjs +175 -0
  335. package/esm2020/graphql/datatable/get-page-info.mjs +10 -0
  336. package/esm2020/graphql/datatable/map-filter-states.mjs +63 -0
  337. package/esm2020/graphql/utils/inline-variables.mjs +51 -0
  338. package/esm2020/graphql/utils/parse-hints.mjs +108 -0
  339. package/esm2020/graphql/utils/to-gql.mjs +40 -0
  340. package/esm2020/icon/icon/icon.component.mjs +139 -0
  341. package/esm2020/icon/icon-btn/icon-btn.component.mjs +183 -0
  342. package/esm2020/icon/icon-notification/icon-notification.component.mjs +124 -0
  343. package/esm2020/icon/icon.module.mjs +38 -0
  344. package/esm2020/icon/utils/get-known-icon.mjs +82 -0
  345. package/esm2020/layout/breakpoint-aliases.mjs +11 -0
  346. package/esm2020/layout/layout.module.mjs +25 -0
  347. package/esm2020/layout/layout.service.mjs +32 -0
  348. package/esm2020/layout/observe-media-query.mjs +41 -0
  349. package/esm2020/loading/loading/loading.component.mjs +26 -0
  350. package/esm2020/loading/loading-overlay.service.mjs +58 -0
  351. package/esm2020/loading/loading.module.mjs +41 -0
  352. package/esm2020/menu/menu-divider.component.mjs +13 -0
  353. package/esm2020/menu/menu-footer/menu-footer.component.mjs +32 -0
  354. package/esm2020/menu/menu-footer-action/menu-footer-action.component.mjs +54 -0
  355. package/esm2020/menu/menu-header/menu-header.component.mjs +32 -0
  356. package/esm2020/menu/menu-item.component.mjs +130 -0
  357. package/esm2020/menu/menu-toggle.directive.mjs +256 -0
  358. package/esm2020/menu/menu.component.mjs +177 -0
  359. package/esm2020/menu/menu.module.mjs +67 -0
  360. package/esm2020/modal/directives/modal-close.directive.mjs +74 -0
  361. package/esm2020/modal/directives/modal-footer-tpl.directive.mjs +16 -0
  362. package/esm2020/modal/directives/modal-header-icon-tpl.directive.mjs +16 -0
  363. package/esm2020/modal/directives/modal-header-title-tpl.directive.mjs +16 -0
  364. package/esm2020/modal/directives/modal-title.directive.mjs +20 -0
  365. package/esm2020/modal/directives/modal.directive.mjs +25 -0
  366. package/esm2020/modal/modal/modal.component.mjs +162 -0
  367. package/esm2020/modal/modal-body/modal-body.component.mjs +21 -0
  368. package/esm2020/modal/modal-config.mjs +47 -0
  369. package/esm2020/modal/modal-container/modal-container.component.mjs +245 -0
  370. package/esm2020/modal/modal-footer/modal-footer.component.mjs +17 -0
  371. package/esm2020/modal/modal-header/modal-header.component.mjs +28 -0
  372. package/esm2020/modal/modal-ref.mjs +171 -0
  373. package/esm2020/modal/modal.models.mjs +3 -0
  374. package/esm2020/modal/modal.module.mjs +127 -0
  375. package/esm2020/modal/modal.service.mjs +352 -0
  376. package/esm2020/modal/route-modal/route-modal.component.mjs +62 -0
  377. package/esm2020/popover/popover/popover.component.mjs +156 -0
  378. package/esm2020/popover/popover.directive.mjs +260 -0
  379. package/esm2020/popover/popover.module.mjs +40 -0
  380. package/esm2020/progress/progress-circle/progress-circle.component.mjs +65 -0
  381. package/esm2020/progress/progress.module.mjs +24 -0
  382. package/esm2020/public_api.mjs +2 -0
  383. package/esm2020/scrollbar/overlay-scrollbar.directive.mjs +60 -0
  384. package/esm2020/scrollbar/overlay-scrollbars-config.mjs +13 -0
  385. package/esm2020/scrollbar/overlay-scrollbars.service.mjs +83 -0
  386. package/esm2020/scrollbar/scrollbar.module.mjs +30 -0
  387. package/esm2020/services/asset-loader.service.mjs +32 -0
  388. package/esm2020/services/font-loader.service.mjs +83 -0
  389. package/esm2020/services/router-helpers.service.mjs +25 -0
  390. package/esm2020/shared/components/password-input-reveal/password-input-reveal.component.mjs +49 -0
  391. package/esm2020/shared/directives/auto-focus.directive.mjs +54 -0
  392. package/esm2020/shared/directives/click-outside.directive.mjs +52 -0
  393. package/esm2020/shared/directives/disable-control.directive.mjs +27 -0
  394. package/esm2020/shared/directives/elem-resized.directive.mjs +28 -0
  395. package/esm2020/shared/directives/hover-class-toggle.directive.mjs +88 -0
  396. package/esm2020/shared/directives/hover-class.directive.mjs +82 -0
  397. package/esm2020/shared/directives/ng-select-extra.directive.mjs +184 -0
  398. package/esm2020/shared/directives/ngx-quill-extra.directive.mjs +61 -0
  399. package/esm2020/shared/pipes/mask-chars.pipe.mjs +25 -0
  400. package/esm2020/shared/pipes/truncate.pipe.mjs +23 -0
  401. package/esm2020/shared/shared.module.mjs +93 -0
  402. package/esm2020/storage/local-storage.service.mjs +78 -0
  403. package/esm2020/storage/localstorage-memory.mjs +64 -0
  404. package/esm2020/story-helpers/arg-type-helpers.mjs +35 -0
  405. package/esm2020/story-helpers/initial-route.service.mjs +27 -0
  406. package/esm2020/story-helpers/on-story-bootstrapped-exec.mjs +61 -0
  407. package/esm2020/story-helpers/on-story-bootstrapped-trigger.mjs +39 -0
  408. package/esm2020/story-helpers/public-api.mjs +15 -0
  409. package/esm2020/story-helpers/routes-arg-type.mjs +19 -0
  410. package/esm2020/story-helpers/story-empty-with-route.component.mjs +12 -0
  411. package/esm2020/story-helpers/story-empty.component.mjs +11 -0
  412. package/esm2020/story-helpers/story-helper-components.module.mjs +42 -0
  413. package/esm2020/story-helpers/story-initial-route.mjs +28 -0
  414. package/esm2020/story-helpers/story-modal-container.component.mjs +90 -0
  415. package/esm2020/story-helpers/story-toastr.service.mjs +36 -0
  416. package/esm2020/tabbed/directives/tabbed-tab-content.directive.mjs +17 -0
  417. package/esm2020/tabbed/directives/tabbed-tab.directive.mjs +37 -0
  418. package/esm2020/tabbed/public-api.mjs +9 -0
  419. package/esm2020/tabbed/tabbed-content/tabbed-content.component.mjs +16 -0
  420. package/esm2020/tabbed/tabbed-item/tabbed-item.component.mjs +33 -0
  421. package/esm2020/tabbed/tabbed-models.mjs +2 -0
  422. package/esm2020/tabbed/tabbed.component.mjs +112 -0
  423. package/esm2020/tabbed/tabbed.module.mjs +54 -0
  424. package/esm2020/tabbed/tabbed.service.mjs +30 -0
  425. package/esm2020/table/table/table.component.mjs +96 -0
  426. package/esm2020/table/table.module.mjs +32 -0
  427. package/esm2020/table-cell-type/services/table-cell-types-helpers.service.mjs +67 -0
  428. package/esm2020/table-cell-type/table-cell-type-export-props.mjs +2 -0
  429. package/esm2020/table-cell-type/table-cell-type-models.mjs +2 -0
  430. package/esm2020/table-cell-type/table-cell-type-selector.component.mjs +100 -0
  431. package/esm2020/table-cell-type/table-cell-type.module.mjs +29 -0
  432. package/esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.mjs +86 -0
  433. package/esm2020/table-cell-types/table-cell-type-date/table-cell-type-date.component.mjs +52 -0
  434. package/esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.mjs +84 -0
  435. package/esm2020/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.mjs +175 -0
  436. package/esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.mjs +82 -0
  437. package/esm2020/table-cell-types/table-cell-type-manifests.mjs +92 -0
  438. package/esm2020/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.mjs +67 -0
  439. package/esm2020/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.mjs +168 -0
  440. package/esm2020/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.mjs +77 -0
  441. package/esm2020/table-cell-types/table-cell-type-string/table-cell-type-string.component.mjs +197 -0
  442. package/esm2020/table-cell-types/table-cell-types.module.mjs +118 -0
  443. package/esm2020/table-cell-types/theseam-ui-common-table-cell-types.mjs +5 -0
  444. package/esm2020/tel-input/intl-tel-input.mjs +55 -0
  445. package/esm2020/tel-input/phone-number.pipe.mjs +49 -0
  446. package/esm2020/tel-input/tel-input/tel-input.component.mjs +186 -0
  447. package/esm2020/tel-input/tel-input-validator.mjs +27 -0
  448. package/esm2020/tel-input/tel-input.directive.mjs +210 -0
  449. package/esm2020/tel-input/tel-input.module.mjs +42 -0
  450. package/esm2020/tel-input/utils/add-country-code.mjs +23 -0
  451. package/esm2020/tel-input/utils/get-validation-error-message.mjs +12 -0
  452. package/esm2020/tel-input/utils/process-country-codes.mjs +46 -0
  453. package/esm2020/testing/get-harness.mjs +13 -0
  454. package/esm2020/testing/render-story.mjs +10 -0
  455. package/esm2020/testing/story-expect.mjs +39 -0
  456. package/esm2020/tiled-select/components/tiled-select/tiled-select.component.mjs +214 -0
  457. package/esm2020/tiled-select/components/tiled-select-tile/tiled-select-tile.component.mjs +159 -0
  458. package/esm2020/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.mjs +63 -0
  459. package/esm2020/tiled-select/directives/tiled-select-tile-icon-tpl.directive.mjs +17 -0
  460. package/esm2020/tiled-select/directives/tiled-select-tile-label-tpl.directive.mjs +16 -0
  461. package/esm2020/tiled-select/directives/tiled-select-tile-overlay.directive.mjs +19 -0
  462. package/esm2020/tiled-select/public-api.mjs +10 -0
  463. package/esm2020/tiled-select/testing/index.mjs +3 -0
  464. package/esm2020/tiled-select/testing/tiled-select-harness.mjs +21 -0
  465. package/esm2020/tiled-select/testing/tiled-select-tile-harness.mjs +23 -0
  466. package/esm2020/tiled-select/tiled-select.module.mjs +51 -0
  467. package/esm2020/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.mjs +11 -0
  468. package/esm2020/toggle-edit/toggle-edit-display-tpl.directive.mjs +16 -0
  469. package/esm2020/toggle-edit/toggle-edit-keyboard-listener.service.mjs +57 -0
  470. package/esm2020/toggle-edit/toggle-edit.component.mjs +414 -0
  471. package/esm2020/toggle-edit/toggle-edit.module.mjs +64 -0
  472. package/esm2020/toggle-group/toggle-group-option.directive.mjs +47 -0
  473. package/esm2020/toggle-group/toggle-group.directive.mjs +198 -0
  474. package/esm2020/toggle-group/toggle-group.module.mjs +33 -0
  475. package/esm2020/unsaved-changes-dialog/unsaved-changes-can-deactivate.mjs +30 -0
  476. package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.component.mjs +21 -0
  477. package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.guard.mjs +38 -0
  478. package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.module.mjs +17 -0
  479. package/esm2020/utils/array-move.mjs +62 -0
  480. package/esm2020/utils/cdk/get-closest-widget-cdk-drag.mjs +18 -0
  481. package/esm2020/utils/file-utils.mjs +49 -0
  482. package/esm2020/utils/form/get-control-path.mjs +38 -0
  483. package/esm2020/utils/geo-json/coerce-feature-collection.mjs +44 -0
  484. package/esm2020/utils/geo-json/geo-json-to-area.mjs +11 -0
  485. package/esm2020/utils/geo-json/is-feature-collection.validator.mjs +21 -0
  486. package/esm2020/utils/geo-json/is-only-geometry-types.mjs +23 -0
  487. package/esm2020/utils/geo-json/is-only-geometry-types.validator.mjs +32 -0
  488. package/esm2020/utils/geo-json/merge-polygons.mjs +35 -0
  489. package/esm2020/utils/geo-json/min-max-points.validator.mjs +56 -0
  490. package/esm2020/utils/geo-json/no-inner-rings.validator.mjs +63 -0
  491. package/esm2020/utils/geo-json/read-geo-file.mjs +93 -0
  492. package/esm2020/utils/geo-json/split-multi-polygons.mjs +29 -0
  493. package/esm2020/utils/has-property.mjs +7 -0
  494. package/esm2020/utils/load-style-sheet.mjs +14 -0
  495. package/esm2020/utils/load-style.mjs +13 -0
  496. package/esm2020/utils/obj-utils.mjs +26 -0
  497. package/esm2020/utils/polling-ticker.mjs +121 -0
  498. package/esm2020/utils/router/operators/activated-routes-with-data-property.mjs +11 -0
  499. package/esm2020/utils/router/route-snapshot-path-full.mjs +5 -0
  500. package/esm2020/utils/router/route-snapshot-path-relative.mjs +4 -0
  501. package/esm2020/utils/router/will-have-data-prop.mjs +10 -0
  502. package/esm2020/utils/subscriber-count.mjs +45 -0
  503. package/esm2020/utils/toggle-attribute.mjs +36 -0
  504. package/esm2020/utils/wait-on-condition-async.mjs +30 -0
  505. package/esm2020/vertical-list-filter/public-api.mjs +3 -0
  506. package/esm2020/vertical-list-filter/testing/index.mjs +2 -0
  507. package/esm2020/vertical-list-filter/testing/vertical-list-filter.harness.mjs +28 -0
  508. package/esm2020/vertical-list-filter/theseam-ui-common-vertical-list-filter.mjs +5 -0
  509. package/esm2020/vertical-list-filter/vertical-list-filter.component.mjs +52 -0
  510. package/esm2020/viewers/html-template-viewer/html-template-viewer.component.mjs +219 -0
  511. package/esm2020/viewers/html-template-viewer/html-template-viewer.module.mjs +32 -0
  512. package/esm2020/viewers/pdf-viewer/pdf-page/pdf-page.component.mjs +143 -0
  513. package/esm2020/viewers/pdf-viewer/pdf-renderer.service.mjs +28 -0
  514. package/esm2020/viewers/pdf-viewer/pdf-viewer.component.mjs +164 -0
  515. package/esm2020/viewers/pdf-viewer/pdf-viewer.module.mjs +33 -0
  516. package/esm2020/widget/directives/widget-drag-handle.directive.mjs +150 -0
  517. package/esm2020/widget/directives/widget-icon-tpl.directive.mjs +16 -0
  518. package/esm2020/widget/directives/widget-title-tpl.directive.mjs +16 -0
  519. package/esm2020/widget/widget/widget.component.mjs +142 -0
  520. package/esm2020/widget/widget-content-components/widget-button-group/widget-button-group.component.mjs +11 -0
  521. package/esm2020/widget/widget-content-components/widget-button-group/widget-button-group.module.mjs +30 -0
  522. package/esm2020/widget/widget-content-components/widget-content-header/widget-content-header.component.mjs +11 -0
  523. package/esm2020/widget/widget-content-components/widget-content-header/widget-content-header.module.mjs +24 -0
  524. package/esm2020/widget/widget-content-components/widget-description/widget-description.component.mjs +11 -0
  525. package/esm2020/widget/widget-content-components/widget-description/widget-description.module.mjs +24 -0
  526. package/esm2020/widget/widget-content-components/widget-empty-label/widget-empty-label.component.mjs +39 -0
  527. package/esm2020/widget/widget-content-components/widget-empty-label/widget-empty-label.module.mjs +24 -0
  528. package/esm2020/widget/widget-content-components/widget-footer-link/widget-footer-link.component.mjs +11 -0
  529. package/esm2020/widget/widget-content-components/widget-footer-link/widget-footer-link.module.mjs +24 -0
  530. package/esm2020/widget/widget-content-components/widget-footer-text/widget-footer-text.component.mjs +11 -0
  531. package/esm2020/widget/widget-content-components/widget-footer-text/widget-footer-text.module.mjs +24 -0
  532. package/esm2020/widget/widget-content-components/widget-header-badge/widget-header-badge.component.mjs +22 -0
  533. package/esm2020/widget/widget-content-components/widget-header-badge/widget-header-badge.module.mjs +24 -0
  534. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item-icon-tpl.directive.mjs +17 -0
  535. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.mjs +124 -0
  536. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group.component.mjs +14 -0
  537. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group.module.mjs +46 -0
  538. package/esm2020/widget/widget-content-components/widget-table/widget-table.component.mjs +38 -0
  539. package/esm2020/widget/widget-content-components/widget-table/widget-table.module.mjs +32 -0
  540. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.mjs +13 -0
  541. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.mjs +41 -0
  542. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.mjs +11 -0
  543. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-secondary-icon.directive.mjs +17 -0
  544. package/esm2020/widget/widget-content-components/widget-tile/widget-tile.component.mjs +122 -0
  545. package/esm2020/widget/widget-content-components/widget-tile/widget-tile.module.mjs +48 -0
  546. package/esm2020/widget/widget-content-components/widget-tile-list/widget-tile-list.component.mjs +11 -0
  547. package/esm2020/widget/widget-content-components/widget-tile-list/widget-tile-list.module.mjs +27 -0
  548. package/esm2020/widget/widget-footer/widget-footer.component.mjs +11 -0
  549. package/esm2020/widget/widget-registry.service.mjs +56 -0
  550. package/esm2020/widget/widget.module.mjs +125 -0
  551. package/fesm2015/theseam-ui-common-asset-reader.mjs +186 -0
  552. package/fesm2015/theseam-ui-common-asset-reader.mjs.map +1 -0
  553. package/fesm2015/theseam-ui-common-breadcrumbs.mjs +201 -0
  554. package/fesm2015/theseam-ui-common-breadcrumbs.mjs.map +1 -0
  555. package/fesm2015/theseam-ui-common-buttons.mjs +314 -0
  556. package/fesm2015/theseam-ui-common-buttons.mjs.map +1 -0
  557. package/fesm2015/theseam-ui-common-card.mjs +153 -0
  558. package/fesm2015/theseam-ui-common-card.mjs.map +1 -0
  559. package/fesm2015/theseam-ui-common-carousel.mjs +265 -0
  560. package/fesm2015/theseam-ui-common-carousel.mjs.map +1 -0
  561. package/fesm2015/theseam-ui-common-checkbox.mjs +393 -0
  562. package/fesm2015/theseam-ui-common-checkbox.mjs.map +1 -0
  563. package/fesm2015/theseam-ui-common-confirm-dialog.mjs +173 -0
  564. package/fesm2015/theseam-ui-common-confirm-dialog.mjs.map +1 -0
  565. package/fesm2015/theseam-ui-common-core.mjs +225 -0
  566. package/fesm2015/theseam-ui-common-core.mjs.map +1 -0
  567. package/fesm2015/theseam-ui-common-data-exporter.mjs +93 -0
  568. package/fesm2015/theseam-ui-common-data-exporter.mjs.map +1 -0
  569. package/fesm2015/theseam-ui-common-data-filters.mjs +508 -0
  570. package/fesm2015/theseam-ui-common-data-filters.mjs.map +1 -0
  571. package/fesm2015/theseam-ui-common-datatable-dynamic.mjs +998 -0
  572. package/fesm2015/theseam-ui-common-datatable-dynamic.mjs.map +1 -0
  573. package/fesm2015/theseam-ui-common-datatable.mjs +2818 -0
  574. package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -0
  575. package/fesm2015/theseam-ui-common-dynamic-component-loader.mjs +135 -0
  576. package/fesm2015/theseam-ui-common-dynamic-component-loader.mjs.map +1 -0
  577. package/fesm2015/theseam-ui-common-dynamic.mjs +722 -0
  578. package/fesm2015/theseam-ui-common-dynamic.mjs.map +1 -0
  579. package/fesm2015/theseam-ui-common-footer-bar.mjs +35 -0
  580. package/fesm2015/theseam-ui-common-footer-bar.mjs.map +1 -0
  581. package/fesm2015/theseam-ui-common-form-field-error.mjs +479 -0
  582. package/fesm2015/theseam-ui-common-form-field-error.mjs.map +1 -0
  583. package/fesm2015/theseam-ui-common-form-field.mjs +601 -0
  584. package/fesm2015/theseam-ui-common-form-field.mjs.map +1 -0
  585. package/fesm2015/theseam-ui-common-framework.mjs +3733 -0
  586. package/fesm2015/theseam-ui-common-framework.mjs.map +1 -0
  587. package/fesm2015/theseam-ui-common-google-maps.mjs +1957 -0
  588. package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -0
  589. package/fesm2015/theseam-ui-common-graphql.mjs +862 -0
  590. package/fesm2015/theseam-ui-common-graphql.mjs.map +1 -0
  591. package/fesm2015/theseam-ui-common-icon.mjs +587 -0
  592. package/fesm2015/theseam-ui-common-icon.mjs.map +1 -0
  593. package/fesm2015/theseam-ui-common-layout.mjs +101 -0
  594. package/fesm2015/theseam-ui-common-layout.mjs.map +1 -0
  595. package/fesm2015/theseam-ui-common-loading.mjs +139 -0
  596. package/fesm2015/theseam-ui-common-loading.mjs.map +1 -0
  597. package/fesm2015/theseam-ui-common-menu.mjs +810 -0
  598. package/fesm2015/theseam-ui-common-menu.mjs.map +1 -0
  599. package/fesm2015/theseam-ui-common-modal.mjs +1378 -0
  600. package/fesm2015/theseam-ui-common-modal.mjs.map +1 -0
  601. package/fesm2015/theseam-ui-common-models.mjs +52 -0
  602. package/fesm2015/theseam-ui-common-models.mjs.map +1 -0
  603. package/fesm2015/theseam-ui-common-popover.mjs +498 -0
  604. package/fesm2015/theseam-ui-common-popover.mjs.map +1 -0
  605. package/fesm2015/theseam-ui-common-progress.mjs +93 -0
  606. package/fesm2015/theseam-ui-common-progress.mjs.map +1 -0
  607. package/fesm2015/theseam-ui-common-scrollbar.mjs +184 -0
  608. package/fesm2015/theseam-ui-common-scrollbar.mjs.map +1 -0
  609. package/fesm2015/theseam-ui-common-services.mjs +139 -0
  610. package/fesm2015/theseam-ui-common-services.mjs.map +1 -0
  611. package/fesm2015/theseam-ui-common-shared.mjs +739 -0
  612. package/fesm2015/theseam-ui-common-shared.mjs.map +1 -0
  613. package/fesm2015/theseam-ui-common-storage.mjs +148 -0
  614. package/fesm2015/theseam-ui-common-storage.mjs.map +1 -0
  615. package/fesm2015/theseam-ui-common-story-helpers.mjs +402 -0
  616. package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -0
  617. package/fesm2015/theseam-ui-common-tabbed.mjs +281 -0
  618. package/fesm2015/theseam-ui-common-tabbed.mjs.map +1 -0
  619. package/fesm2015/theseam-ui-common-table-cell-type.mjs +201 -0
  620. package/fesm2015/theseam-ui-common-table-cell-type.mjs.map +1 -0
  621. package/fesm2015/theseam-ui-common-table-cell-types.mjs +1134 -0
  622. package/fesm2015/theseam-ui-common-table-cell-types.mjs.map +1 -0
  623. package/fesm2015/theseam-ui-common-table.mjs +128 -0
  624. package/fesm2015/theseam-ui-common-table.mjs.map +1 -0
  625. package/fesm2015/theseam-ui-common-tel-input.mjs +765 -0
  626. package/fesm2015/theseam-ui-common-tel-input.mjs.map +1 -0
  627. package/fesm2015/theseam-ui-common-testing.mjs +192 -0
  628. package/fesm2015/theseam-ui-common-testing.mjs.map +1 -0
  629. package/fesm2015/theseam-ui-common-tiled-select.mjs +571 -0
  630. package/fesm2015/theseam-ui-common-tiled-select.mjs.map +1 -0
  631. package/fesm2015/theseam-ui-common-toggle-edit.mjs +560 -0
  632. package/fesm2015/theseam-ui-common-toggle-edit.mjs.map +1 -0
  633. package/fesm2015/theseam-ui-common-toggle-group.mjs +279 -0
  634. package/fesm2015/theseam-ui-common-toggle-group.mjs.map +1 -0
  635. package/fesm2015/theseam-ui-common-unsaved-changes-dialog.mjs +106 -0
  636. package/fesm2015/theseam-ui-common-unsaved-changes-dialog.mjs.map +1 -0
  637. package/fesm2015/theseam-ui-common-utils.mjs +1319 -0
  638. package/fesm2015/theseam-ui-common-utils.mjs.map +1 -0
  639. package/fesm2015/theseam-ui-common-validators.mjs +94 -0
  640. package/fesm2015/theseam-ui-common-validators.mjs.map +1 -0
  641. package/fesm2015/theseam-ui-common-vertical-list-filter.mjs +96 -0
  642. package/fesm2015/theseam-ui-common-vertical-list-filter.mjs.map +1 -0
  643. package/fesm2015/theseam-ui-common-viewers.mjs +602 -0
  644. package/fesm2015/theseam-ui-common-viewers.mjs.map +1 -0
  645. package/fesm2015/theseam-ui-common-widget.mjs +1243 -0
  646. package/fesm2015/theseam-ui-common-widget.mjs.map +1 -0
  647. package/fesm2015/theseam-ui-common.mjs +6 -0
  648. package/fesm2015/theseam-ui-common.mjs.map +1 -0
  649. package/fesm2020/theseam-ui-common-asset-reader.mjs +184 -0
  650. package/fesm2020/theseam-ui-common-asset-reader.mjs.map +1 -0
  651. package/fesm2020/theseam-ui-common-breadcrumbs.mjs +201 -0
  652. package/fesm2020/theseam-ui-common-breadcrumbs.mjs.map +1 -0
  653. package/fesm2020/theseam-ui-common-buttons.mjs +314 -0
  654. package/fesm2020/theseam-ui-common-buttons.mjs.map +1 -0
  655. package/fesm2020/theseam-ui-common-card.mjs +151 -0
  656. package/fesm2020/theseam-ui-common-card.mjs.map +1 -0
  657. package/fesm2020/theseam-ui-common-carousel.mjs +265 -0
  658. package/fesm2020/theseam-ui-common-carousel.mjs.map +1 -0
  659. package/fesm2020/theseam-ui-common-checkbox.mjs +375 -0
  660. package/fesm2020/theseam-ui-common-checkbox.mjs.map +1 -0
  661. package/fesm2020/theseam-ui-common-confirm-dialog.mjs +173 -0
  662. package/fesm2020/theseam-ui-common-confirm-dialog.mjs.map +1 -0
  663. package/fesm2020/theseam-ui-common-core.mjs +233 -0
  664. package/fesm2020/theseam-ui-common-core.mjs.map +1 -0
  665. package/fesm2020/theseam-ui-common-data-exporter.mjs +93 -0
  666. package/fesm2020/theseam-ui-common-data-exporter.mjs.map +1 -0
  667. package/fesm2020/theseam-ui-common-data-filters.mjs +500 -0
  668. package/fesm2020/theseam-ui-common-data-filters.mjs.map +1 -0
  669. package/fesm2020/theseam-ui-common-datatable-dynamic.mjs +986 -0
  670. package/fesm2020/theseam-ui-common-datatable-dynamic.mjs.map +1 -0
  671. package/fesm2020/theseam-ui-common-datatable.mjs +2811 -0
  672. package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -0
  673. package/fesm2020/theseam-ui-common-dynamic-component-loader.mjs +133 -0
  674. package/fesm2020/theseam-ui-common-dynamic-component-loader.mjs.map +1 -0
  675. package/fesm2020/theseam-ui-common-dynamic.mjs +689 -0
  676. package/fesm2020/theseam-ui-common-dynamic.mjs.map +1 -0
  677. package/fesm2020/theseam-ui-common-footer-bar.mjs +35 -0
  678. package/fesm2020/theseam-ui-common-footer-bar.mjs.map +1 -0
  679. package/fesm2020/theseam-ui-common-form-field-error.mjs +483 -0
  680. package/fesm2020/theseam-ui-common-form-field-error.mjs.map +1 -0
  681. package/fesm2020/theseam-ui-common-form-field.mjs +594 -0
  682. package/fesm2020/theseam-ui-common-form-field.mjs.map +1 -0
  683. package/fesm2020/theseam-ui-common-framework.mjs +3734 -0
  684. package/fesm2020/theseam-ui-common-framework.mjs.map +1 -0
  685. package/fesm2020/theseam-ui-common-google-maps.mjs +1948 -0
  686. package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -0
  687. package/fesm2020/theseam-ui-common-graphql.mjs +868 -0
  688. package/fesm2020/theseam-ui-common-graphql.mjs.map +1 -0
  689. package/fesm2020/theseam-ui-common-icon.mjs +587 -0
  690. package/fesm2020/theseam-ui-common-icon.mjs.map +1 -0
  691. package/fesm2020/theseam-ui-common-layout.mjs +111 -0
  692. package/fesm2020/theseam-ui-common-layout.mjs.map +1 -0
  693. package/fesm2020/theseam-ui-common-loading.mjs +138 -0
  694. package/fesm2020/theseam-ui-common-loading.mjs.map +1 -0
  695. package/fesm2020/theseam-ui-common-menu.mjs +797 -0
  696. package/fesm2020/theseam-ui-common-menu.mjs.map +1 -0
  697. package/fesm2020/theseam-ui-common-modal.mjs +1370 -0
  698. package/fesm2020/theseam-ui-common-modal.mjs.map +1 -0
  699. package/fesm2020/theseam-ui-common-models.mjs +55 -0
  700. package/fesm2020/theseam-ui-common-models.mjs.map +1 -0
  701. package/fesm2020/theseam-ui-common-popover.mjs +495 -0
  702. package/fesm2020/theseam-ui-common-popover.mjs.map +1 -0
  703. package/fesm2020/theseam-ui-common-progress.mjs +93 -0
  704. package/fesm2020/theseam-ui-common-progress.mjs.map +1 -0
  705. package/fesm2020/theseam-ui-common-scrollbar.mjs +184 -0
  706. package/fesm2020/theseam-ui-common-scrollbar.mjs.map +1 -0
  707. package/fesm2020/theseam-ui-common-services.mjs +140 -0
  708. package/fesm2020/theseam-ui-common-services.mjs.map +1 -0
  709. package/fesm2020/theseam-ui-common-shared.mjs +733 -0
  710. package/fesm2020/theseam-ui-common-shared.mjs.map +1 -0
  711. package/fesm2020/theseam-ui-common-storage.mjs +148 -0
  712. package/fesm2020/theseam-ui-common-storage.mjs.map +1 -0
  713. package/fesm2020/theseam-ui-common-story-helpers.mjs +402 -0
  714. package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -0
  715. package/fesm2020/theseam-ui-common-tabbed.mjs +279 -0
  716. package/fesm2020/theseam-ui-common-tabbed.mjs.map +1 -0
  717. package/fesm2020/theseam-ui-common-table-cell-type.mjs +198 -0
  718. package/fesm2020/theseam-ui-common-table-cell-type.mjs.map +1 -0
  719. package/fesm2020/theseam-ui-common-table-cell-types.mjs +1109 -0
  720. package/fesm2020/theseam-ui-common-table-cell-types.mjs.map +1 -0
  721. package/fesm2020/theseam-ui-common-table.mjs +132 -0
  722. package/fesm2020/theseam-ui-common-table.mjs.map +1 -0
  723. package/fesm2020/theseam-ui-common-tel-input.mjs +750 -0
  724. package/fesm2020/theseam-ui-common-tel-input.mjs.map +1 -0
  725. package/fesm2020/theseam-ui-common-testing.mjs +188 -0
  726. package/fesm2020/theseam-ui-common-testing.mjs.map +1 -0
  727. package/fesm2020/theseam-ui-common-tiled-select.mjs +557 -0
  728. package/fesm2020/theseam-ui-common-tiled-select.mjs.map +1 -0
  729. package/fesm2020/theseam-ui-common-toggle-edit.mjs +553 -0
  730. package/fesm2020/theseam-ui-common-toggle-edit.mjs.map +1 -0
  731. package/fesm2020/theseam-ui-common-toggle-group.mjs +276 -0
  732. package/fesm2020/theseam-ui-common-toggle-group.mjs.map +1 -0
  733. package/fesm2020/theseam-ui-common-unsaved-changes-dialog.mjs +106 -0
  734. package/fesm2020/theseam-ui-common-unsaved-changes-dialog.mjs.map +1 -0
  735. package/fesm2020/theseam-ui-common-utils.mjs +1296 -0
  736. package/fesm2020/theseam-ui-common-utils.mjs.map +1 -0
  737. package/fesm2020/theseam-ui-common-validators.mjs +94 -0
  738. package/fesm2020/theseam-ui-common-validators.mjs.map +1 -0
  739. package/fesm2020/theseam-ui-common-vertical-list-filter.mjs +87 -0
  740. package/fesm2020/theseam-ui-common-vertical-list-filter.mjs.map +1 -0
  741. package/fesm2020/theseam-ui-common-viewers.mjs +598 -0
  742. package/fesm2020/theseam-ui-common-viewers.mjs.map +1 -0
  743. package/fesm2020/theseam-ui-common-widget.mjs +1239 -0
  744. package/fesm2020/theseam-ui-common-widget.mjs.map +1 -0
  745. package/fesm2020/theseam-ui-common.mjs +6 -0
  746. package/fesm2020/theseam-ui-common.mjs.map +1 -0
  747. package/footer-bar/footer-bar/footer-bar.component.d.ts +4 -4
  748. package/footer-bar/footer-bar.module.d.ts +6 -0
  749. package/footer-bar/index.d.ts +5 -0
  750. package/form-field/form-field-error.directive.d.ts +3 -0
  751. package/form-field/form-field-help-text.directive.d.ts +3 -0
  752. package/form-field/form-field-label-tpl.directive.d.ts +3 -0
  753. package/form-field/form-field-required-indicator.component.d.ts +5 -3
  754. package/form-field/form-field-tokens.d.ts +2 -0
  755. package/form-field/form-field.component.d.ts +3 -0
  756. package/form-field/form-field.module.d.ts +14 -0
  757. package/form-field/index.d.ts +5 -0
  758. package/form-field/input.directive.d.ts +3 -0
  759. package/form-field/public-api.d.ts +2 -0
  760. package/form-field/testing/form-field-required-indicator.harness.d.ts +5 -0
  761. package/form-field/testing/index.d.ts +1 -0
  762. package/form-field-error/form-field-error/form-field-error.component.d.ts +4 -4
  763. package/form-field-error/form-field-error-list/form-field-error-list-item-tpl.directive.d.ts +3 -0
  764. package/form-field-error/form-field-error-list/form-field-error-list-item.directive.d.ts +3 -0
  765. package/form-field-error/form-field-error-list/form-field-error-list.component.d.ts +5 -3
  766. package/form-field-error/form-field-error.module.d.ts +9 -0
  767. package/form-field-error/index.d.ts +5 -0
  768. package/framework/base-layout/base-layout-action.d.ts +1 -1
  769. package/framework/base-layout/base-layout.component.d.ts +3 -0
  770. package/framework/base-layout/base-layout.module.d.ts +18 -0
  771. package/framework/base-layout/directives/base-layout-content-footer.directive.d.ts +3 -0
  772. package/framework/base-layout/directives/base-layout-content-header.directive.d.ts +3 -0
  773. package/framework/base-layout/directives/base-layout-content.directive.d.ts +3 -0
  774. package/framework/base-layout/directives/base-layout-nav-toggle.directive.d.ts +3 -0
  775. package/framework/base-layout/directives/base-layout-side-bar-footer.directive.d.ts +3 -0
  776. package/framework/base-layout/directives/base-layout-side-bar-header.directive.d.ts +3 -0
  777. package/framework/base-layout/directives/base-layout-side-bar.directive.d.ts +3 -0
  778. package/framework/base-layout/directives/base-layout-top-bar.directive.d.ts +3 -0
  779. package/framework/base-layout/index.d.ts +2 -0
  780. package/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.d.ts +5 -4
  781. package/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.d.ts +8 -6
  782. package/framework/dashboard/dashboard-widgets/dashboard-widget-portal-outlet.directive.d.ts +3 -0
  783. package/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences.service.d.ts +3 -0
  784. package/framework/dashboard/dashboard-widgets/dashboard-widgets.component.d.ts +5 -1
  785. package/framework/dashboard/dashboard-widgets/dashboard-widgets.service.d.ts +3 -0
  786. package/framework/dashboard/dashboard-widgets-tokens.d.ts +7 -0
  787. package/framework/dashboard/dashboard.component.d.ts +3 -1
  788. package/framework/dashboard/dashboard.module.d.ts +15 -0
  789. package/framework/dynamic-router/dynamic-router.module.d.ts +7 -0
  790. package/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.d.ts +5 -3
  791. package/framework/dynamic-router/resolvers/hierarchy-level.resolver.d.ts +3 -1
  792. package/framework/index.d.ts +5 -0
  793. package/framework/nav/horizontal-nav/horizontal-nav.component.d.ts +5 -3
  794. package/framework/nav/nav-item/nav-item.component.d.ts +3 -0
  795. package/framework/nav/nav.models.d.ts +3 -3
  796. package/framework/nav/nav.module.d.ts +15 -0
  797. package/framework/nav/nav.service.d.ts +3 -0
  798. package/framework/schema-form/schema-form-framework.component.d.ts +3 -0
  799. package/framework/schema-form/schema-form-framework.d.ts +3 -0
  800. package/framework/schema-form/schema-form.module.d.ts +8 -0
  801. package/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.d.ts +3 -0
  802. package/framework/schema-form-controls/schema-form-controls.module.d.ts +18 -0
  803. package/framework/schema-form-controls/schema-form-input/schema-form-input.component.d.ts +3 -0
  804. package/framework/schema-form-controls/schema-form-number/schema-form-number.component.d.ts +3 -0
  805. package/framework/schema-form-controls/schema-form-select/schema-form-select.component.d.ts +3 -0
  806. package/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.d.ts +3 -0
  807. package/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.d.ts +4 -1
  808. package/framework/side-nav/index.d.ts +1 -0
  809. package/framework/side-nav/side-nav-item/side-nav-item.component.d.ts +7 -13
  810. package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.d.ts +5 -4
  811. package/framework/side-nav/side-nav-tokens.d.ts +6 -0
  812. package/framework/side-nav/side-nav.component.d.ts +5 -2
  813. package/framework/side-nav/side-nav.models.d.ts +8 -2
  814. package/framework/side-nav/side-nav.module.d.ts +7 -0
  815. package/framework/side-nav/side-nav.service.d.ts +3 -0
  816. package/framework/top-bar/index.d.ts +2 -0
  817. package/framework/top-bar/top-bar-compact-menu-btn-detail.directive.d.ts +3 -0
  818. package/framework/top-bar/top-bar-item.directive.d.ts +4 -1
  819. package/framework/top-bar/top-bar-menu-btn-detail.directive.d.ts +3 -0
  820. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +5 -4
  821. package/framework/top-bar/top-bar-menu.directive.d.ts +3 -0
  822. package/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.d.ts +3 -0
  823. package/framework/top-bar/top-bar-title/top-bar-title.component.d.ts +4 -4
  824. package/framework/top-bar/top-bar.component.d.ts +5 -4
  825. package/framework/top-bar/top-bar.module.d.ts +19 -0
  826. package/google-maps/google-maps/google-maps.component.d.ts +18 -11
  827. package/google-maps/google-maps-api-loader/google-maps-api-loader.d.ts +4 -0
  828. package/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.d.ts +73 -0
  829. package/google-maps/google-maps-api-loader/noop-google-maps-api-loader.d.ts +13 -0
  830. package/google-maps/google-maps-contextmenu.d.ts +1 -1
  831. package/google-maps/google-maps-controls.service.d.ts +3 -0
  832. package/google-maps/google-maps-feature-helpers.d.ts +1 -1
  833. package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.d.ts +6 -4
  834. package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.d.ts +4 -1
  835. package/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.d.ts +3 -0
  836. package/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.d.ts +3 -0
  837. package/google-maps/google-maps.module.d.ts +18 -0
  838. package/google-maps/google-maps.service.d.ts +4 -1
  839. package/google-maps/index.d.ts +5 -0
  840. package/google-maps/map-control.component.d.ts +3 -0
  841. package/google-maps/map-controls-service.d.ts +1 -1
  842. package/google-maps/map-file-drop/map-file-drop.component.d.ts +3 -0
  843. package/google-maps/map-value-manager.service.d.ts +4 -1
  844. package/google-maps/public-api.d.ts +3 -0
  845. package/graphql/datatable/datatable-graphql-query-ref.d.ts +2 -3
  846. package/graphql/datatable/datatable-graphql.service.d.ts +4 -1
  847. package/graphql/datatable/datatable-helpers.d.ts +2 -2
  848. package/graphql/datatable/map-filter-states.d.ts +2 -2
  849. package/graphql/datatable/map-page-info.d.ts +1 -1
  850. package/graphql/datatable/mapper-context.d.ts +1 -1
  851. package/graphql/index.d.ts +5 -0
  852. package/graphql/models/gql-datatable-accessor.d.ts +1 -1
  853. package/graphql/models/hint-transformer.d.ts +1 -1
  854. package/icon/icon/icon.component.d.ts +4 -1
  855. package/icon/icon-btn/icon-btn.component.d.ts +5 -3
  856. package/icon/icon-notification/icon-notification.component.d.ts +3 -0
  857. package/icon/icon.d.ts +1 -1
  858. package/icon/icon.module.d.ts +9 -0
  859. package/icon/index.d.ts +5 -0
  860. package/index.d.ts +5 -0
  861. package/layout/breakpoint-aliases.d.ts +1 -1
  862. package/layout/index.d.ts +5 -0
  863. package/layout/layout.module.d.ts +6 -0
  864. package/layout/layout.service.d.ts +3 -0
  865. package/loading/index.d.ts +5 -0
  866. package/loading/loading/loading.component.d.ts +4 -4
  867. package/loading/loading-overlay.service.d.ts +3 -0
  868. package/loading/loading.models.d.ts +1 -1
  869. package/loading/loading.module.d.ts +9 -0
  870. package/menu/index.d.ts +5 -0
  871. package/menu/menu-divider.component.d.ts +3 -0
  872. package/menu/menu-footer/menu-footer.component.d.ts +3 -0
  873. package/menu/menu-footer-action/menu-footer-action.component.d.ts +3 -0
  874. package/menu/menu-header/menu-header.component.d.ts +3 -0
  875. package/menu/menu-item.component.d.ts +5 -3
  876. package/menu/menu-toggle.directive.d.ts +3 -0
  877. package/menu/menu.component.d.ts +3 -0
  878. package/menu/menu.module.d.ts +14 -0
  879. package/modal/README.md +5 -0
  880. package/modal/directives/modal-close.directive.d.ts +3 -0
  881. package/modal/directives/modal-footer-tpl.directive.d.ts +3 -0
  882. package/modal/directives/modal-header-icon-tpl.directive.d.ts +3 -0
  883. package/modal/directives/modal-header-title-tpl.directive.d.ts +3 -0
  884. package/modal/directives/modal-title.directive.d.ts +3 -0
  885. package/modal/directives/modal.directive.d.ts +3 -0
  886. package/modal/index.d.ts +5 -0
  887. package/modal/modal/modal.component.d.ts +8 -6
  888. package/modal/modal-body/modal-body.component.d.ts +4 -4
  889. package/modal/modal-config.d.ts +1 -1
  890. package/modal/modal-container/modal-container.component.d.ts +5 -2
  891. package/modal/modal-footer/modal-footer.component.d.ts +4 -4
  892. package/modal/modal-header/modal-header.component.d.ts +4 -4
  893. package/modal/modal.models.d.ts +2 -2
  894. package/modal/modal.module.d.ts +23 -0
  895. package/modal/modal.service.d.ts +3 -0
  896. package/modal/route-modal/route-modal.component.d.ts +5 -3
  897. package/models/component-type.d.ts +1 -1
  898. package/models/index.d.ts +5 -0
  899. package/models/size-prefixes.d.ts +1 -1
  900. package/models/size-types.d.ts +1 -1
  901. package/models/theme-prefixes.d.ts +1 -1
  902. package/models/theme-types.d.ts +2 -2
  903. package/package.json +417 -23
  904. package/popover/index.d.ts +5 -0
  905. package/popover/popover/popover.component.d.ts +3 -0
  906. package/popover/popover.directive.d.ts +3 -0
  907. package/popover/popover.module.d.ts +9 -0
  908. package/progress/index.d.ts +5 -0
  909. package/progress/progress-circle/progress-circle.component.d.ts +3 -1
  910. package/progress/progress.module.d.ts +6 -0
  911. package/scrollbar/index.d.ts +5 -0
  912. package/scrollbar/overlay-scrollbar.directive.d.ts +5 -3
  913. package/scrollbar/overlay-scrollbars-config-model.d.ts +1 -1
  914. package/scrollbar/overlay-scrollbars.service.d.ts +3 -0
  915. package/scrollbar/scrollbar.module.d.ts +6 -0
  916. package/services/asset-loader.service.d.ts +3 -1
  917. package/services/font-loader.service.d.ts +4 -2
  918. package/services/index.d.ts +5 -0
  919. package/services/router-helpers.service.d.ts +3 -0
  920. package/shared/components/password-input-reveal/password-input-reveal.component.d.ts +3 -0
  921. package/shared/directives/auto-focus.directive.d.ts +3 -0
  922. package/shared/directives/click-outside.directive.d.ts +3 -0
  923. package/shared/directives/disable-control.directive.d.ts +3 -0
  924. package/shared/directives/elem-resized.directive.d.ts +3 -0
  925. package/shared/directives/hover-class-toggle.directive.d.ts +3 -0
  926. package/shared/directives/hover-class.directive.d.ts +3 -0
  927. package/shared/directives/ng-select-extra.directive.d.ts +3 -0
  928. package/shared/directives/ngx-quill-extra.directive.d.ts +3 -0
  929. package/shared/index.d.ts +5 -0
  930. package/shared/pipes/mask-chars.pipe.d.ts +3 -0
  931. package/shared/pipes/truncate.pipe.d.ts +3 -0
  932. package/shared/shared.module.d.ts +20 -0
  933. package/storage/index.d.ts +5 -0
  934. package/storage/local-storage.service.d.ts +3 -0
  935. package/story-helpers/arg-type-helpers.d.ts +2 -1
  936. package/story-helpers/index.d.ts +5 -0
  937. package/story-helpers/initial-route.service.d.ts +3 -0
  938. package/story-helpers/on-story-bootstrapped-exec.d.ts +1 -6
  939. package/story-helpers/public-api.d.ts +0 -1
  940. package/story-helpers/routes-arg-type.d.ts +7 -2
  941. package/story-helpers/story-empty-with-route.component.d.ts +3 -0
  942. package/story-helpers/story-empty.component.d.ts +3 -0
  943. package/story-helpers/story-helper-components.module.d.ts +10 -0
  944. package/story-helpers/story-initial-route.d.ts +4 -0
  945. package/story-helpers/story-modal-container.component.d.ts +3 -0
  946. package/story-helpers/story-toastr.service.d.ts +3 -0
  947. package/styles/bootstrap/_bootstrap.scss +34 -34
  948. package/styles/bootstrap/_bs-utilities.scss +3 -3
  949. package/styles/theme.scss +3 -3
  950. package/styles/vendor/ngx-datatable/_ngx-datatable.scss +1 -1
  951. package/styles/vendor/quill/_quill.scss +3 -3
  952. package/tabbed/directives/tabbed-tab-content.directive.d.ts +5 -2
  953. package/tabbed/directives/tabbed-tab.directive.d.ts +5 -1
  954. package/tabbed/index.d.ts +5 -0
  955. package/tabbed/public-api.d.ts +1 -0
  956. package/tabbed/tabbed-content/tabbed-content.component.d.ts +6 -6
  957. package/tabbed/tabbed-item/tabbed-item.component.d.ts +6 -4
  958. package/tabbed/tabbed-models.d.ts +12 -0
  959. package/tabbed/tabbed.component.d.ts +3 -0
  960. package/tabbed/tabbed.module.d.ts +12 -0
  961. package/tabbed/tabbed.service.d.ts +3 -1
  962. package/table/index.d.ts +5 -0
  963. package/table/table/table.component.d.ts +7 -5
  964. package/table/table.module.d.ts +8 -0
  965. package/table-cell-type/index.d.ts +5 -0
  966. package/table-cell-type/services/table-cell-types-helpers.service.d.ts +3 -0
  967. package/table-cell-type/table-cell-type-models.d.ts +4 -4
  968. package/table-cell-type/table-cell-type-name.d.ts +1 -1
  969. package/table-cell-type/table-cell-type-selector.component.d.ts +6 -4
  970. package/table-cell-type/table-cell-type.module.d.ts +7 -0
  971. package/table-cell-types/index.d.ts +5 -0
  972. package/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.d.ts +1 -1
  973. package/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.d.ts +5 -3
  974. package/table-cell-types/table-cell-type-currency/table-cell-type-currency.d.ts +1 -1
  975. package/table-cell-types/table-cell-type-date/table-cell-type-date.component.d.ts +5 -3
  976. package/table-cell-types/table-cell-type-date/table-cell-type-date.d.ts +1 -1
  977. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.d.ts +1 -1
  978. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.d.ts +5 -3
  979. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.d.ts +1 -1
  980. package/table-cell-types/table-cell-type-icon/table-cell-type-icon-config.d.ts +1 -1
  981. package/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.d.ts +6 -4
  982. package/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.d.ts +1 -1
  983. package/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.d.ts +5 -3
  984. package/table-cell-types/table-cell-type-integer/table-cell-type-integer.d.ts +1 -1
  985. package/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.d.ts +5 -3
  986. package/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle-config.d.ts +1 -1
  987. package/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.d.ts +5 -3
  988. package/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon-config.d.ts +1 -1
  989. package/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.d.ts +5 -3
  990. package/table-cell-types/table-cell-type-string/table-cell-type-string-config.d.ts +1 -1
  991. package/table-cell-types/table-cell-type-string/table-cell-type-string.component.d.ts +4 -1
  992. package/table-cell-types/table-cell-types.module.d.ts +24 -0
  993. package/tel-input/README.md +27 -0
  994. package/tel-input/index.d.ts +5 -0
  995. package/tel-input/phone-number.pipe.d.ts +3 -0
  996. package/tel-input/tel-input/tel-input.component.d.ts +5 -2
  997. package/tel-input/tel-input-validator.d.ts +3 -3
  998. package/tel-input/tel-input.directive.d.ts +3 -0
  999. package/tel-input/tel-input.module.d.ts +10 -0
  1000. package/tel-input/utils/coerce-phone-number-format.d.ts +1 -1
  1001. package/testing/index.d.ts +5 -0
  1002. package/tiled-select/components/tiled-select/tiled-select.component.d.ts +6 -4
  1003. package/tiled-select/components/tiled-select-tile/tiled-select-tile.component.d.ts +3 -0
  1004. package/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.d.ts +4 -4
  1005. package/tiled-select/directives/tiled-select-tile-icon-tpl.directive.d.ts +3 -0
  1006. package/tiled-select/directives/tiled-select-tile-label-tpl.directive.d.ts +3 -0
  1007. package/tiled-select/directives/tiled-select-tile-overlay.directive.d.ts +3 -0
  1008. package/tiled-select/index.d.ts +5 -0
  1009. package/tiled-select/public-api.d.ts +1 -0
  1010. package/tiled-select/testing/index.d.ts +2 -0
  1011. package/tiled-select/testing/tiled-select-harness.d.ts +9 -0
  1012. package/tiled-select/testing/tiled-select-tile-harness.d.ts +17 -0
  1013. package/tiled-select/tiled-select.models.d.ts +2 -2
  1014. package/tiled-select/tiled-select.module.d.ts +12 -0
  1015. package/toggle-edit/index.d.ts +5 -0
  1016. package/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.d.ts +4 -4
  1017. package/toggle-edit/toggle-edit-display-tpl.directive.d.ts +3 -0
  1018. package/toggle-edit/toggle-edit-keyboard-listener.service.d.ts +3 -0
  1019. package/toggle-edit/toggle-edit.component.d.ts +3 -0
  1020. package/toggle-edit/toggle-edit.module.d.ts +16 -0
  1021. package/toggle-group/index.d.ts +5 -0
  1022. package/toggle-group/toggle-group-option.directive.d.ts +3 -0
  1023. package/toggle-group/toggle-group.directive.d.ts +3 -1
  1024. package/toggle-group/toggle-group.module.d.ts +8 -0
  1025. package/unsaved-changes-dialog/index.d.ts +5 -0
  1026. package/unsaved-changes-dialog/unsaved-changes-can-deactivate.d.ts +3 -0
  1027. package/unsaved-changes-dialog/unsaved-changes-dialog.component.d.ts +4 -4
  1028. package/unsaved-changes-dialog/unsaved-changes-dialog.guard.d.ts +3 -0
  1029. package/unsaved-changes-dialog/unsaved-changes-dialog.module.d.ts +5 -0
  1030. package/utils/file-utils.d.ts +1 -1
  1031. package/utils/geo-json/read-geo-file.d.ts +1 -1
  1032. package/utils/index.d.ts +5 -0
  1033. package/utils/obj-utils.d.ts +2 -2
  1034. package/utils/polling-ticker.d.ts +1 -1
  1035. package/utils/subscriber-count.d.ts +1 -1
  1036. package/validators/index.d.ts +5 -0
  1037. package/vertical-list-filter/index.d.ts +5 -0
  1038. package/vertical-list-filter/public-api.d.ts +2 -0
  1039. package/vertical-list-filter/testing/index.d.ts +1 -0
  1040. package/vertical-list-filter/testing/vertical-list-filter.harness.d.ts +9 -0
  1041. package/vertical-list-filter/vertical-list-filter.component.d.ts +17 -0
  1042. package/viewers/html-template-viewer/html-template-viewer.component.d.ts +3 -0
  1043. package/viewers/html-template-viewer/html-template-viewer.module.d.ts +8 -0
  1044. package/viewers/index.d.ts +5 -0
  1045. package/viewers/pdf-viewer/pdf-page/pdf-page.component.d.ts +3 -0
  1046. package/viewers/pdf-viewer/pdf-renderer.service.d.ts +3 -0
  1047. package/viewers/pdf-viewer/pdf-viewer.component.d.ts +3 -0
  1048. package/viewers/pdf-viewer/pdf-viewer.module.d.ts +8 -0
  1049. package/widget/directives/widget-drag-handle.directive.d.ts +4 -1
  1050. package/widget/directives/widget-icon-tpl.directive.d.ts +3 -0
  1051. package/widget/directives/widget-title-tpl.directive.d.ts +3 -0
  1052. package/widget/index.d.ts +5 -0
  1053. package/widget/widget/widget.component.d.ts +4 -6
  1054. package/widget/widget-content-components/widget-button-group/widget-button-group.component.d.ts +4 -4
  1055. package/widget/widget-content-components/widget-button-group/widget-button-group.module.d.ts +7 -0
  1056. package/widget/widget-content-components/widget-content-header/widget-content-header.component.d.ts +4 -4
  1057. package/widget/widget-content-components/widget-content-header/widget-content-header.module.d.ts +6 -0
  1058. package/widget/widget-content-components/widget-description/widget-description.component.d.ts +3 -0
  1059. package/widget/widget-content-components/widget-description/widget-description.module.d.ts +6 -0
  1060. package/widget/widget-content-components/widget-empty-label/widget-empty-label.component.d.ts +5 -3
  1061. package/widget/widget-content-components/widget-empty-label/widget-empty-label.module.d.ts +6 -0
  1062. package/widget/widget-content-components/widget-footer-link/widget-footer-link.component.d.ts +4 -4
  1063. package/widget/widget-content-components/widget-footer-link/widget-footer-link.module.d.ts +6 -0
  1064. package/widget/widget-content-components/widget-footer-text/widget-footer-text.component.d.ts +4 -4
  1065. package/widget/widget-content-components/widget-footer-text/widget-footer-text.module.d.ts +6 -0
  1066. package/widget/widget-content-components/widget-header-badge/widget-header-badge.component.d.ts +5 -3
  1067. package/widget/widget-content-components/widget-header-badge/widget-header-badge.module.d.ts +6 -0
  1068. package/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item-icon-tpl.directive.d.ts +3 -0
  1069. package/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.d.ts +15 -7
  1070. package/widget/widget-content-components/widget-list-group/widget-list-group.component.d.ts +4 -4
  1071. package/widget/widget-content-components/widget-list-group/widget-list-group.module.d.ts +9 -0
  1072. package/widget/widget-content-components/widget-table/widget-table.component.d.ts +3 -1
  1073. package/widget/widget-content-components/widget-table/widget-table.module.d.ts +8 -0
  1074. package/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.d.ts +4 -4
  1075. package/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.d.ts +5 -3
  1076. package/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.d.ts +4 -4
  1077. package/widget/widget-content-components/widget-tile/widget-tile-secondary-icon.directive.d.ts +3 -0
  1078. package/widget/widget-content-components/widget-tile/widget-tile.component.d.ts +5 -0
  1079. package/widget/widget-content-components/widget-tile/widget-tile.module.d.ts +11 -0
  1080. package/widget/widget-content-components/widget-tile-list/widget-tile-list.component.d.ts +4 -4
  1081. package/widget/widget-content-components/widget-tile-list/widget-tile-list.module.d.ts +7 -0
  1082. package/widget/widget-footer/widget-footer.component.d.ts +4 -4
  1083. package/widget/widget-registry.service.d.ts +3 -0
  1084. package/widget/widget.module.d.ts +28 -0
  1085. package/asset-reader/package.json +0 -11
  1086. package/asset-reader/theseam-ui-common-asset-reader.d.ts +0 -4
  1087. package/asset-reader/theseam-ui-common-asset-reader.metadata.json +0 -1
  1088. package/assets/.gitkeep +0 -0
  1089. package/assets/vendor/intl-tel-input/css/intlTelInput.min.css +0 -1
  1090. package/assets/vendor/intl-tel-input/img/flags.png +0 -0
  1091. package/assets/vendor/intl-tel-input/img/flags@2x.png +0 -0
  1092. package/assets/vendor/intl-tel-input/js/utils.js +0 -502
  1093. package/breadcrumbs/package.json +0 -11
  1094. package/breadcrumbs/theseam-ui-common-breadcrumbs.d.ts +0 -4
  1095. package/breadcrumbs/theseam-ui-common-breadcrumbs.metadata.json +0 -1
  1096. package/bundles/theseam-ui-common-asset-reader.umd.js +0 -531
  1097. package/bundles/theseam-ui-common-asset-reader.umd.js.map +0 -1
  1098. package/bundles/theseam-ui-common-breadcrumbs.umd.js +0 -586
  1099. package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +0 -1
  1100. package/bundles/theseam-ui-common-buttons.umd.js +0 -719
  1101. package/bundles/theseam-ui-common-buttons.umd.js.map +0 -1
  1102. package/bundles/theseam-ui-common-card.umd.js +0 -480
  1103. package/bundles/theseam-ui-common-card.umd.js.map +0 -1
  1104. package/bundles/theseam-ui-common-checkbox.umd.js +0 -650
  1105. package/bundles/theseam-ui-common-checkbox.umd.js.map +0 -1
  1106. package/bundles/theseam-ui-common-confirm-dialog.umd.js +0 -491
  1107. package/bundles/theseam-ui-common-confirm-dialog.umd.js.map +0 -1
  1108. package/bundles/theseam-ui-common-core.umd.js +0 -604
  1109. package/bundles/theseam-ui-common-core.umd.js.map +0 -1
  1110. package/bundles/theseam-ui-common-data-exporter.umd.js +0 -96
  1111. package/bundles/theseam-ui-common-data-exporter.umd.js.map +0 -1
  1112. package/bundles/theseam-ui-common-data-filters.umd.js +0 -891
  1113. package/bundles/theseam-ui-common-data-filters.umd.js.map +0 -1
  1114. package/bundles/theseam-ui-common-datatable-dynamic.umd.js +0 -1499
  1115. package/bundles/theseam-ui-common-datatable-dynamic.umd.js.map +0 -1
  1116. package/bundles/theseam-ui-common-datatable.umd.js +0 -3271
  1117. package/bundles/theseam-ui-common-datatable.umd.js.map +0 -1
  1118. package/bundles/theseam-ui-common-dynamic-component-loader.umd.js +0 -178
  1119. package/bundles/theseam-ui-common-dynamic-component-loader.umd.js.map +0 -1
  1120. package/bundles/theseam-ui-common-dynamic.umd.js +0 -1252
  1121. package/bundles/theseam-ui-common-dynamic.umd.js.map +0 -1
  1122. package/bundles/theseam-ui-common-footer-bar.umd.js +0 -49
  1123. package/bundles/theseam-ui-common-footer-bar.umd.js.map +0 -1
  1124. package/bundles/theseam-ui-common-form-field-error.umd.js +0 -884
  1125. package/bundles/theseam-ui-common-form-field-error.umd.js.map +0 -1
  1126. package/bundles/theseam-ui-common-form-field.umd.js +0 -914
  1127. package/bundles/theseam-ui-common-form-field.umd.js.map +0 -1
  1128. package/bundles/theseam-ui-common-framework.umd.js +0 -4270
  1129. package/bundles/theseam-ui-common-framework.umd.js.map +0 -1
  1130. package/bundles/theseam-ui-common-google-maps.umd.js +0 -2234
  1131. package/bundles/theseam-ui-common-google-maps.umd.js.map +0 -1
  1132. package/bundles/theseam-ui-common-graphql.umd.js +0 -1307
  1133. package/bundles/theseam-ui-common-graphql.umd.js.map +0 -1
  1134. package/bundles/theseam-ui-common-icon.umd.js +0 -890
  1135. package/bundles/theseam-ui-common-icon.umd.js.map +0 -1
  1136. package/bundles/theseam-ui-common-layout.umd.js +0 -126
  1137. package/bundles/theseam-ui-common-layout.umd.js.map +0 -1
  1138. package/bundles/theseam-ui-common-loading.umd.js +0 -152
  1139. package/bundles/theseam-ui-common-loading.umd.js.map +0 -1
  1140. package/bundles/theseam-ui-common-menu.umd.js +0 -1157
  1141. package/bundles/theseam-ui-common-menu.umd.js.map +0 -1
  1142. package/bundles/theseam-ui-common-modal.umd.js +0 -1718
  1143. package/bundles/theseam-ui-common-modal.umd.js.map +0 -1
  1144. package/bundles/theseam-ui-common-models.umd.js +0 -63
  1145. package/bundles/theseam-ui-common-models.umd.js.map +0 -1
  1146. package/bundles/theseam-ui-common-popover.umd.js +0 -504
  1147. package/bundles/theseam-ui-common-popover.umd.js.map +0 -1
  1148. package/bundles/theseam-ui-common-progress.umd.js +0 -420
  1149. package/bundles/theseam-ui-common-progress.umd.js.map +0 -1
  1150. package/bundles/theseam-ui-common-scrollbar.umd.js +0 -238
  1151. package/bundles/theseam-ui-common-scrollbar.umd.js.map +0 -1
  1152. package/bundles/theseam-ui-common-services.umd.js +0 -176
  1153. package/bundles/theseam-ui-common-services.umd.js.map +0 -1
  1154. package/bundles/theseam-ui-common-shared.umd.js +0 -1115
  1155. package/bundles/theseam-ui-common-shared.umd.js.map +0 -1
  1156. package/bundles/theseam-ui-common-storage.umd.js +0 -176
  1157. package/bundles/theseam-ui-common-storage.umd.js.map +0 -1
  1158. package/bundles/theseam-ui-common-story-helpers.umd.js +0 -795
  1159. package/bundles/theseam-ui-common-story-helpers.umd.js.map +0 -1
  1160. package/bundles/theseam-ui-common-tabbed.umd.js +0 -628
  1161. package/bundles/theseam-ui-common-tabbed.umd.js.map +0 -1
  1162. package/bundles/theseam-ui-common-table-cell-type.umd.js +0 -220
  1163. package/bundles/theseam-ui-common-table-cell-type.umd.js.map +0 -1
  1164. package/bundles/theseam-ui-common-table-cell-types.umd.js +0 -1484
  1165. package/bundles/theseam-ui-common-table-cell-types.umd.js.map +0 -1
  1166. package/bundles/theseam-ui-common-table.umd.js +0 -475
  1167. package/bundles/theseam-ui-common-table.umd.js.map +0 -1
  1168. package/bundles/theseam-ui-common-tel-input.umd.js +0 -1107
  1169. package/bundles/theseam-ui-common-tel-input.umd.js.map +0 -1
  1170. package/bundles/theseam-ui-common-testing.umd.js +0 -568
  1171. package/bundles/theseam-ui-common-testing.umd.js.map +0 -1
  1172. package/bundles/theseam-ui-common-tiled-select.umd.js +0 -866
  1173. package/bundles/theseam-ui-common-tiled-select.umd.js.map +0 -1
  1174. package/bundles/theseam-ui-common-toggle-edit.umd.js +0 -891
  1175. package/bundles/theseam-ui-common-toggle-edit.umd.js.map +0 -1
  1176. package/bundles/theseam-ui-common-toggle-group.umd.js +0 -629
  1177. package/bundles/theseam-ui-common-toggle-group.umd.js.map +0 -1
  1178. package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js +0 -134
  1179. package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js.map +0 -1
  1180. package/bundles/theseam-ui-common-utils.umd.js +0 -1890
  1181. package/bundles/theseam-ui-common-utils.umd.js.map +0 -1
  1182. package/bundles/theseam-ui-common-validators.umd.js +0 -105
  1183. package/bundles/theseam-ui-common-validators.umd.js.map +0 -1
  1184. package/bundles/theseam-ui-common-viewers.umd.js +0 -962
  1185. package/bundles/theseam-ui-common-viewers.umd.js.map +0 -1
  1186. package/bundles/theseam-ui-common-widget.umd.js +0 -1710
  1187. package/bundles/theseam-ui-common-widget.umd.js.map +0 -1
  1188. package/bundles/theseam-ui-common.umd.js +0 -54
  1189. package/bundles/theseam-ui-common.umd.js.map +0 -1
  1190. package/buttons/package.json +0 -11
  1191. package/buttons/theseam-ui-common-buttons.d.ts +0 -4
  1192. package/buttons/theseam-ui-common-buttons.metadata.json +0 -1
  1193. package/card/package.json +0 -11
  1194. package/card/theseam-ui-common-card.d.ts +0 -4
  1195. package/card/theseam-ui-common-card.metadata.json +0 -1
  1196. package/checkbox/package.json +0 -11
  1197. package/checkbox/theseam-ui-common-checkbox.d.ts +0 -4
  1198. package/checkbox/theseam-ui-common-checkbox.metadata.json +0 -1
  1199. package/confirm-dialog/package.json +0 -11
  1200. package/confirm-dialog/theseam-ui-common-confirm-dialog.d.ts +0 -4
  1201. package/confirm-dialog/theseam-ui-common-confirm-dialog.metadata.json +0 -1
  1202. package/core/package.json +0 -11
  1203. package/core/theseam-ui-common-core.d.ts +0 -4
  1204. package/core/theseam-ui-common-core.metadata.json +0 -1
  1205. package/data-exporter/package.json +0 -11
  1206. package/data-exporter/theseam-ui-common-data-exporter.d.ts +0 -4
  1207. package/data-exporter/theseam-ui-common-data-exporter.metadata.json +0 -1
  1208. package/data-filters/package.json +0 -11
  1209. package/data-filters/theseam-ui-common-data-filters.d.ts +0 -4
  1210. package/data-filters/theseam-ui-common-data-filters.metadata.json +0 -1
  1211. package/datatable/package.json +0 -11
  1212. package/datatable/theseam-ui-common-datatable.d.ts +0 -7
  1213. package/datatable/theseam-ui-common-datatable.metadata.json +0 -1
  1214. package/datatable-dynamic/package.json +0 -11
  1215. package/datatable-dynamic/theseam-ui-common-datatable-dynamic.d.ts +0 -4
  1216. package/datatable-dynamic/theseam-ui-common-datatable-dynamic.metadata.json +0 -1
  1217. package/dynamic/package.json +0 -11
  1218. package/dynamic/theseam-ui-common-dynamic.d.ts +0 -4
  1219. package/dynamic/theseam-ui-common-dynamic.metadata.json +0 -1
  1220. package/dynamic-component-loader/package.json +0 -11
  1221. package/dynamic-component-loader/theseam-ui-common-dynamic-component-loader.d.ts +0 -4
  1222. package/dynamic-component-loader/theseam-ui-common-dynamic-component-loader.metadata.json +0 -1
  1223. package/esm2015/asset-reader/asset-reader-helper.service.js +0 -68
  1224. package/esm2015/asset-reader/asset-reader.module.js +0 -15
  1225. package/esm2015/asset-reader/encrypted-asset-link.directive.js +0 -69
  1226. package/esm2015/breadcrumbs/breadcrumb.js +0 -2
  1227. package/esm2015/breadcrumbs/breadcrumbs/breadcrumbs.component.js +0 -22
  1228. package/esm2015/breadcrumbs/breadcrumbs-resolver.js +0 -2
  1229. package/esm2015/breadcrumbs/breadcrumbs.module.js +0 -21
  1230. package/esm2015/breadcrumbs/breadcrumbs.service.js +0 -158
  1231. package/esm2015/buttons/badge-button/badge-button.component.js +0 -79
  1232. package/esm2015/buttons/button/button.component.js +0 -111
  1233. package/esm2015/buttons/buttons.module.js +0 -34
  1234. package/esm2015/buttons/progress-circle-button/progress-circle-button.component.js +0 -60
  1235. package/esm2015/buttons/toggle-button/toggle-button.component.js +0 -88
  1236. package/esm2015/card/card-action/card-action.component.js +0 -27
  1237. package/esm2015/card/card-body/card-body.component.js +0 -32
  1238. package/esm2015/card/card-footer/card-footer.component.js +0 -15
  1239. package/esm2015/card/card-header/card-header.component.js +0 -22
  1240. package/esm2015/card/card.component.js +0 -20
  1241. package/esm2015/card/card.module.js +0 -33
  1242. package/esm2015/checkbox/checkbox.component.js +0 -276
  1243. package/esm2015/checkbox/checkbox.module.js +0 -21
  1244. package/esm2015/checkbox/public-api.js +0 -3
  1245. package/esm2015/confirm-dialog/confirm-click.directive.js +0 -62
  1246. package/esm2015/confirm-dialog/confirm-dialog.component.js +0 -20
  1247. package/esm2015/confirm-dialog/confirm-dialog.module.js +0 -35
  1248. package/esm2015/confirm-dialog/confirm-dialog.service.js +0 -38
  1249. package/esm2015/core/common-behaviors/active.js +0 -13
  1250. package/esm2015/core/common-behaviors/disabled.js +0 -20
  1251. package/esm2015/core/common-behaviors/initialized.js +0 -62
  1252. package/esm2015/core/common-behaviors/size.js +0 -24
  1253. package/esm2015/core/common-behaviors/tabindex.js +0 -22
  1254. package/esm2015/core/common-behaviors/theme.js +0 -24
  1255. package/esm2015/core/input-decorators/input-boolean.decorator.js +0 -27
  1256. package/esm2015/core/input-decorators/input-number.decorator.js +0 -27
  1257. package/esm2015/data-exporter/data-exporter.module.js +0 -17
  1258. package/esm2015/data-exporter/exporters/csv-exporter.js +0 -32
  1259. package/esm2015/data-exporter/exporters/xlsx-exporter.js +0 -30
  1260. package/esm2015/data-filters/data-filter.js +0 -25
  1261. package/esm2015/data-filters/data-filters.module.js +0 -50
  1262. package/esm2015/data-filters/filters/data-filter-search/data-filter-search.component.js +0 -110
  1263. package/esm2015/data-filters/filters/data-filter-text/data-filter-text.component.js +0 -138
  1264. package/esm2015/data-filters/filters/data-filter-toggle-buttons/data-filter-toggle-buttons.component.js +0 -151
  1265. package/esm2015/datatable/datatable/datatable.component.js +0 -585
  1266. package/esm2015/datatable/datatable-action-menu/datatable-action-menu.component.js +0 -101
  1267. package/esm2015/datatable/datatable-action-menu-item/datatable-action-menu-item.component.js +0 -30
  1268. package/esm2015/datatable/datatable-column/datatable-column.component.js +0 -83
  1269. package/esm2015/datatable/datatable-column-preferences/datatable-column-preferences.component.js +0 -63
  1270. package/esm2015/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.js +0 -52
  1271. package/esm2015/datatable/datatable-export-button/datatable-export-button.component.js +0 -101
  1272. package/esm2015/datatable/datatable-footer/datatable-footer-tpl.directive.js +0 -15
  1273. package/esm2015/datatable/datatable-footer/datatable-footer.directive.js +0 -18
  1274. package/esm2015/datatable/datatable-menu-bar/datatable-menu-bar.component.js +0 -55
  1275. package/esm2015/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.js +0 -16
  1276. package/esm2015/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.js +0 -16
  1277. package/esm2015/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.js +0 -16
  1278. package/esm2015/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.js +0 -16
  1279. package/esm2015/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.js +0 -32
  1280. package/esm2015/datatable/datatable-row-detail/datatable-row-detail-tpl.directive.js +0 -15
  1281. package/esm2015/datatable/datatable-row-detail/datatable-row-detail.directive.js +0 -69
  1282. package/esm2015/datatable/datatable.module.js +0 -126
  1283. package/esm2015/datatable/directives/datatable-action-menu-item.directive.js +0 -46
  1284. package/esm2015/datatable/directives/datatable-action-menu-toggle.directive.js +0 -128
  1285. package/esm2015/datatable/directives/datatable-cell-tpl.directive.js +0 -15
  1286. package/esm2015/datatable/directives/datatable-filter.directive.js +0 -21
  1287. package/esm2015/datatable/directives/datatable-row-action-item.directive.js +0 -15
  1288. package/esm2015/datatable/models/action-item-column-position.js +0 -5
  1289. package/esm2015/datatable/models/columns-alteration.js +0 -38
  1290. package/esm2015/datatable/models/columns-alterations/order.columns-alteration.js +0 -81
  1291. package/esm2015/datatable/models/datatable-gql-data-source.js +0 -15
  1292. package/esm2015/datatable/models/internal-column-props.js +0 -15
  1293. package/esm2015/datatable/models/sort-item.js +0 -2
  1294. package/esm2015/datatable/services/columns-alterations-manager.service.js +0 -134
  1295. package/esm2015/datatable/services/columns-manager.service.js +0 -282
  1296. package/esm2015/datatable/services/datatable-column-changes.service.js +0 -17
  1297. package/esm2015/datatable/services/datatable-preferences.service.js +0 -159
  1298. package/esm2015/datatable/services/datatable-scrollbar-helper.service.js +0 -51
  1299. package/esm2015/datatable/theseam-ui-common-datatable.js +0 -8
  1300. package/esm2015/datatable/utils/map-columns-alterations-states.js +0 -39
  1301. package/esm2015/datatable/utils/set-column-defaults.js +0 -10
  1302. package/esm2015/datatable/utils/with-stored-column-info.js +0 -20
  1303. package/esm2015/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.js +0 -119
  1304. package/esm2015/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.js +0 -53
  1305. package/esm2015/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.js +0 -160
  1306. package/esm2015/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.js +0 -2
  1307. package/esm2015/datatable-dynamic/datatable-dynamic.component.js +0 -75
  1308. package/esm2015/datatable-dynamic/datatable-dynamic.module.js +0 -49
  1309. package/esm2015/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.js +0 -408
  1310. package/esm2015/datatable-dynamic/dynamic-datatable-def.service.js +0 -84
  1311. package/esm2015/datatable-dynamic/dynamic-datatable-row-actions.service.js +0 -47
  1312. package/esm2015/datatable-dynamic/models/dynamic-datatable-menu-bar.js +0 -2
  1313. package/esm2015/dynamic/action/api/dynamic-action-api.service.js +0 -215
  1314. package/esm2015/dynamic/action/dynamic-action-helper.service.js +0 -163
  1315. package/esm2015/dynamic/action/link/dynamic-action-link.service.js +0 -50
  1316. package/esm2015/dynamic/action/modal/dynamic-action-modal-def.js +0 -2
  1317. package/esm2015/dynamic/action/modal/dynamic-action-modal.service.js +0 -92
  1318. package/esm2015/dynamic/dynamic-value-helper.service.js +0 -101
  1319. package/esm2015/dynamic/evaluators/exporters-data-evaluator/exporters-data-evaluator.js +0 -33
  1320. package/esm2015/dynamic/evaluators/jexl-evaluator/jexl-evaluator.js +0 -30
  1321. package/esm2015/dynamic/models/dynamic-value-evaluatable-type.js +0 -2
  1322. package/esm2015/dynamic-component-loader/dynamic-component-loader.module.js +0 -47
  1323. package/esm2015/dynamic-component-loader/dynamic-component-loader.service.js +0 -91
  1324. package/esm2015/dynamic-component-loader/dynamic-component-manifest.js +0 -2
  1325. package/esm2015/footer-bar/footer-bar/footer-bar.component.js +0 -16
  1326. package/esm2015/footer-bar/footer-bar.module.js +0 -15
  1327. package/esm2015/form-field/form-field-error.directive.js +0 -28
  1328. package/esm2015/form-field/form-field-help-text.directive.js +0 -15
  1329. package/esm2015/form-field/form-field-label-tpl.directive.js +0 -15
  1330. package/esm2015/form-field/form-field-required-indicator.component.js +0 -38
  1331. package/esm2015/form-field/form-field.component.js +0 -193
  1332. package/esm2015/form-field/form-field.module.js +0 -40
  1333. package/esm2015/form-field/input.directive.js +0 -195
  1334. package/esm2015/form-field/public-api.js +0 -8
  1335. package/esm2015/form-field-error/form-field-error/form-field-error.component.js +0 -27
  1336. package/esm2015/form-field-error/form-field-error-list/form-field-error-list-item-tpl.directive.js +0 -25
  1337. package/esm2015/form-field-error/form-field-error-list/form-field-error-list-item.directive.js +0 -18
  1338. package/esm2015/form-field-error/form-field-error-list/form-field-error-list.component.js +0 -370
  1339. package/esm2015/form-field-error/form-field-error.module.js +0 -28
  1340. package/esm2015/framework/base-layout/base-layout.component.js +0 -125
  1341. package/esm2015/framework/base-layout/base-layout.module.js +0 -51
  1342. package/esm2015/framework/base-layout/directives/base-layout-content-footer.directive.js +0 -15
  1343. package/esm2015/framework/base-layout/directives/base-layout-content-header.directive.js +0 -15
  1344. package/esm2015/framework/base-layout/directives/base-layout-content.directive.js +0 -15
  1345. package/esm2015/framework/base-layout/directives/base-layout-nav-toggle.directive.js +0 -51
  1346. package/esm2015/framework/base-layout/directives/base-layout-side-bar-footer.directive.js +0 -15
  1347. package/esm2015/framework/base-layout/directives/base-layout-side-bar-header.directive.js +0 -15
  1348. package/esm2015/framework/base-layout/directives/base-layout-side-bar.directive.js +0 -15
  1349. package/esm2015/framework/base-layout/directives/base-layout-top-bar.directive.js +0 -15
  1350. package/esm2015/framework/base-layout/index.js +0 -13
  1351. package/esm2015/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.js +0 -19
  1352. package/esm2015/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.js +0 -25
  1353. package/esm2015/framework/dashboard/dashboard-widgets/dashboard-widget-portal-outlet.directive.js +0 -121
  1354. package/esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences.service.js +0 -173
  1355. package/esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets.component.js +0 -176
  1356. package/esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets.service.js +0 -165
  1357. package/esm2015/framework/dashboard/dashboard.component.js +0 -25
  1358. package/esm2015/framework/dashboard/dashboard.module.js +0 -39
  1359. package/esm2015/framework/dynamic-router/dynamic-route-def.js +0 -2
  1360. package/esm2015/framework/dynamic-router/dynamic-router.module.js +0 -21
  1361. package/esm2015/framework/dynamic-router/hierarchy-router-outlet/hierarchy-route-animations.js +0 -256
  1362. package/esm2015/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.js +0 -114
  1363. package/esm2015/framework/dynamic-router/resolvers/hierarchy-level.resolver.js +0 -26
  1364. package/esm2015/framework/nav/horizontal-nav/horizontal-nav.component.js +0 -53
  1365. package/esm2015/framework/nav/nav-item/nav-item.component.js +0 -180
  1366. package/esm2015/framework/nav/nav-utils.js +0 -110
  1367. package/esm2015/framework/nav/nav.module.js +0 -42
  1368. package/esm2015/framework/nav/nav.service.js +0 -200
  1369. package/esm2015/framework/schema-form/schema-form-framework.component.js +0 -16
  1370. package/esm2015/framework/schema-form/schema-form-framework.js +0 -27
  1371. package/esm2015/framework/schema-form/schema-form.module.js +0 -35
  1372. package/esm2015/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.js +0 -41
  1373. package/esm2015/framework/schema-form-controls/schema-form-controls.module.js +0 -50
  1374. package/esm2015/framework/schema-form-controls/schema-form-input/schema-form-input.component.js +0 -34
  1375. package/esm2015/framework/schema-form-controls/schema-form-number/schema-form-number.component.js +0 -40
  1376. package/esm2015/framework/schema-form-controls/schema-form-select/schema-form-select.component.js +0 -36
  1377. package/esm2015/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.js +0 -46
  1378. package/esm2015/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.js +0 -142
  1379. package/esm2015/framework/side-nav/index.js +0 -7
  1380. package/esm2015/framework/side-nav/side-nav-item/side-nav-item.component.js +0 -157
  1381. package/esm2015/framework/side-nav/side-nav-toggle/side-nav-toggle.component.js +0 -36
  1382. package/esm2015/framework/side-nav/side-nav-utils.js +0 -81
  1383. package/esm2015/framework/side-nav/side-nav.component.js +0 -261
  1384. package/esm2015/framework/side-nav/side-nav.models.js +0 -2
  1385. package/esm2015/framework/side-nav/side-nav.module.js +0 -39
  1386. package/esm2015/framework/side-nav/side-nav.service.js +0 -174
  1387. package/esm2015/framework/theseam-ui-common-framework.js +0 -18
  1388. package/esm2015/framework/top-bar/index.js +0 -8
  1389. package/esm2015/framework/top-bar/top-bar-compact-menu-btn-detail.directive.js +0 -15
  1390. package/esm2015/framework/top-bar/top-bar-item.directive.js +0 -22
  1391. package/esm2015/framework/top-bar/top-bar-menu-btn-detail.directive.js +0 -15
  1392. package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +0 -54
  1393. package/esm2015/framework/top-bar/top-bar-menu.directive.js +0 -16
  1394. package/esm2015/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.js +0 -15
  1395. package/esm2015/framework/top-bar/top-bar-title/top-bar-title.component.js +0 -20
  1396. package/esm2015/framework/top-bar/top-bar.component.js +0 -121
  1397. package/esm2015/framework/top-bar/top-bar.module.js +0 -52
  1398. package/esm2015/google-maps/google-maps/google-maps.component.js +0 -261
  1399. package/esm2015/google-maps/google-maps-contextmenu.js +0 -113
  1400. package/esm2015/google-maps/google-maps-controls.service.js +0 -70
  1401. package/esm2015/google-maps/google-maps-feature-helpers.js +0 -186
  1402. package/esm2015/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.js +0 -195
  1403. package/esm2015/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.js +0 -163
  1404. package/esm2015/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.js +0 -57
  1405. package/esm2015/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.js +0 -119
  1406. package/esm2015/google-maps/google-maps.module.js +0 -45
  1407. package/esm2015/google-maps/google-maps.service.js +0 -354
  1408. package/esm2015/google-maps/map-control.component.js +0 -65
  1409. package/esm2015/google-maps/map-file-drop/map-file-drop.component.js +0 -135
  1410. package/esm2015/google-maps/map-value-manager.service.js +0 -46
  1411. package/esm2015/google-maps/public-api.js +0 -14
  1412. package/esm2015/google-maps/theseam-ui-common-google-maps.js +0 -6
  1413. package/esm2015/graphql/datatable/create-page-info-observable.js +0 -38
  1414. package/esm2015/graphql/datatable/datatable-graphql-query-ref.js +0 -236
  1415. package/esm2015/graphql/datatable/datatable-graphql.service.js +0 -35
  1416. package/esm2015/graphql/datatable/datatable-helpers.js +0 -170
  1417. package/esm2015/graphql/datatable/get-page-info.js +0 -11
  1418. package/esm2015/graphql/datatable/map-filter-states.js +0 -64
  1419. package/esm2015/graphql/utils/inline-variables.js +0 -50
  1420. package/esm2015/graphql/utils/parse-hints.js +0 -116
  1421. package/esm2015/graphql/utils/to-gql.js +0 -40
  1422. package/esm2015/icon/icon/icon.component.js +0 -125
  1423. package/esm2015/icon/icon-btn/icon-btn.component.js +0 -136
  1424. package/esm2015/icon/icon-notification/icon-notification.component.js +0 -120
  1425. package/esm2015/icon/icon.module.js +0 -27
  1426. package/esm2015/icon/utils/get-known-icon.js +0 -82
  1427. package/esm2015/layout/breakpoint-aliases.js +0 -11
  1428. package/esm2015/layout/layout.module.js +0 -18
  1429. package/esm2015/layout/layout.service.js +0 -34
  1430. package/esm2015/layout/observe-media-query.js +0 -41
  1431. package/esm2015/loading/loading/loading.component.js +0 -28
  1432. package/esm2015/loading/loading-overlay.service.js +0 -59
  1433. package/esm2015/loading/loading.module.js +0 -29
  1434. package/esm2015/menu/menu-divider.component.js +0 -15
  1435. package/esm2015/menu/menu-footer/menu-footer.component.js +0 -32
  1436. package/esm2015/menu/menu-footer-action/menu-footer-action.component.js +0 -48
  1437. package/esm2015/menu/menu-header/menu-header.component.js +0 -32
  1438. package/esm2015/menu/menu-item.component.js +0 -127
  1439. package/esm2015/menu/menu-toggle.directive.js +0 -253
  1440. package/esm2015/menu/menu.component.js +0 -174
  1441. package/esm2015/menu/menu.module.js +0 -43
  1442. package/esm2015/modal/directives/modal-close.directive.js +0 -63
  1443. package/esm2015/modal/directives/modal-footer-tpl.directive.js +0 -15
  1444. package/esm2015/modal/directives/modal-header-icon-tpl.directive.js +0 -15
  1445. package/esm2015/modal/directives/modal-header-title-tpl.directive.js +0 -15
  1446. package/esm2015/modal/directives/modal-title.directive.js +0 -19
  1447. package/esm2015/modal/directives/modal.directive.js +0 -25
  1448. package/esm2015/modal/modal/modal.component.js +0 -149
  1449. package/esm2015/modal/modal-body/modal-body.component.js +0 -22
  1450. package/esm2015/modal/modal-config.js +0 -47
  1451. package/esm2015/modal/modal-container/modal-container.component.js +0 -220
  1452. package/esm2015/modal/modal-footer/modal-footer.component.js +0 -20
  1453. package/esm2015/modal/modal-header/modal-header.component.js +0 -26
  1454. package/esm2015/modal/modal-ref.js +0 -171
  1455. package/esm2015/modal/modal.models.js +0 -3
  1456. package/esm2015/modal/modal.module.js +0 -83
  1457. package/esm2015/modal/modal.service.js +0 -343
  1458. package/esm2015/modal/route-modal/route-modal.component.js +0 -68
  1459. package/esm2015/popover/popover/popover.component.js +0 -149
  1460. package/esm2015/popover/popover.directive.js +0 -257
  1461. package/esm2015/popover/popover.module.js +0 -30
  1462. package/esm2015/progress/progress-circle/progress-circle.component.js +0 -63
  1463. package/esm2015/progress/progress.module.js +0 -19
  1464. package/esm2015/public_api.js +0 -43
  1465. package/esm2015/scrollbar/overlay-scrollbar.directive.js +0 -61
  1466. package/esm2015/scrollbar/overlay-scrollbars-config.js +0 -13
  1467. package/esm2015/scrollbar/overlay-scrollbars.service.js +0 -87
  1468. package/esm2015/scrollbar/scrollbar.module.js +0 -25
  1469. package/esm2015/services/asset-loader.service.js +0 -33
  1470. package/esm2015/services/font-loader.service.js +0 -81
  1471. package/esm2015/services/router-helpers.service.js +0 -26
  1472. package/esm2015/shared/components/password-input-reveal/password-input-reveal.component.js +0 -71
  1473. package/esm2015/shared/directives/auto-focus.directive.js +0 -53
  1474. package/esm2015/shared/directives/click-outside.directive.js +0 -49
  1475. package/esm2015/shared/directives/disable-control.directive.js +0 -27
  1476. package/esm2015/shared/directives/elem-resized.directive.js +0 -29
  1477. package/esm2015/shared/directives/hover-class-toggle.directive.js +0 -80
  1478. package/esm2015/shared/directives/hover-class.directive.js +0 -74
  1479. package/esm2015/shared/directives/ng-select-extra.directive.js +0 -177
  1480. package/esm2015/shared/directives/ngx-quill-extra.directive.js +0 -60
  1481. package/esm2015/shared/pipes/mask-chars.pipe.js +0 -21
  1482. package/esm2015/shared/pipes/truncate.pipe.js +0 -19
  1483. package/esm2015/shared/shared.module.js +0 -58
  1484. package/esm2015/storage/local-storage.service.js +0 -77
  1485. package/esm2015/storage/localstorage-memory.js +0 -64
  1486. package/esm2015/story-helpers/arg-type-helpers.js +0 -34
  1487. package/esm2015/story-helpers/args-to-tpl.js +0 -76
  1488. package/esm2015/story-helpers/initial-route.service.js +0 -27
  1489. package/esm2015/story-helpers/on-story-bootstrapped-exec.js +0 -64
  1490. package/esm2015/story-helpers/on-story-bootstrapped-trigger.js +0 -38
  1491. package/esm2015/story-helpers/public-api.js +0 -15
  1492. package/esm2015/story-helpers/routes-arg-type.js +0 -18
  1493. package/esm2015/story-helpers/story-empty-with-route.component.js +0 -7
  1494. package/esm2015/story-helpers/story-empty.component.js +0 -7
  1495. package/esm2015/story-helpers/story-helper-components.module.js +0 -29
  1496. package/esm2015/story-helpers/story-initial-route.js +0 -24
  1497. package/esm2015/story-helpers/story-modal-container.component.js +0 -77
  1498. package/esm2015/story-helpers/story-toastr.service.js +0 -33
  1499. package/esm2015/tabbed/directives/tabbed-tab-content.directive.js +0 -14
  1500. package/esm2015/tabbed/directives/tabbed-tab.directive.js +0 -36
  1501. package/esm2015/tabbed/public-api.js +0 -8
  1502. package/esm2015/tabbed/tabbed-content/tabbed-content.component.js +0 -17
  1503. package/esm2015/tabbed/tabbed-item/tabbed-item.component.js +0 -30
  1504. package/esm2015/tabbed/tabbed.component.js +0 -111
  1505. package/esm2015/tabbed/tabbed.module.js +0 -36
  1506. package/esm2015/tabbed/tabbed.service.js +0 -28
  1507. package/esm2015/table/table/table.component.js +0 -90
  1508. package/esm2015/table/table.module.js +0 -23
  1509. package/esm2015/table-cell-type/services/table-cell-types-helpers.service.js +0 -70
  1510. package/esm2015/table-cell-type/table-cell-type-export-props.js +0 -2
  1511. package/esm2015/table-cell-type/table-cell-type-models.js +0 -2
  1512. package/esm2015/table-cell-type/table-cell-type-selector.component.js +0 -94
  1513. package/esm2015/table-cell-type/table-cell-type.module.js +0 -23
  1514. package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.js +0 -89
  1515. package/esm2015/table-cell-types/table-cell-type-date/table-cell-type-date.component.js +0 -52
  1516. package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.js +0 -87
  1517. package/esm2015/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.js +0 -166
  1518. package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.js +0 -85
  1519. package/esm2015/table-cell-types/table-cell-type-manifests.js +0 -103
  1520. package/esm2015/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.js +0 -66
  1521. package/esm2015/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.js +0 -160
  1522. package/esm2015/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.js +0 -78
  1523. package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string.component.js +0 -180
  1524. package/esm2015/table-cell-types/table-cell-types.module.js +0 -78
  1525. package/esm2015/table-cell-types/theseam-ui-common-table-cell-types.js +0 -5
  1526. package/esm2015/tel-input/intl-tel-input.js +0 -55
  1527. package/esm2015/tel-input/phone-number.pipe.js +0 -51
  1528. package/esm2015/tel-input/tel-input/tel-input.component.js +0 -175
  1529. package/esm2015/tel-input/tel-input-validator.js +0 -27
  1530. package/esm2015/tel-input/tel-input.directive.js +0 -209
  1531. package/esm2015/tel-input/tel-input.module.js +0 -29
  1532. package/esm2015/tel-input/utils/add-country-code.js +0 -23
  1533. package/esm2015/tel-input/utils/get-validation-error-message.js +0 -12
  1534. package/esm2015/tel-input/utils/process-country-codes.js +0 -49
  1535. package/esm2015/testing/get-harness.js +0 -16
  1536. package/esm2015/testing/render-story.js +0 -12
  1537. package/esm2015/testing/story-expect.js +0 -39
  1538. package/esm2015/tiled-select/components/tiled-select/tiled-select.component.js +0 -205
  1539. package/esm2015/tiled-select/components/tiled-select-tile/tiled-select-tile.component.js +0 -128
  1540. package/esm2015/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.js +0 -54
  1541. package/esm2015/tiled-select/directives/tiled-select-tile-icon-tpl.directive.js +0 -16
  1542. package/esm2015/tiled-select/directives/tiled-select-tile-label-tpl.directive.js +0 -15
  1543. package/esm2015/tiled-select/directives/tiled-select-tile-overlay.directive.js +0 -19
  1544. package/esm2015/tiled-select/public-api.js +0 -10
  1545. package/esm2015/tiled-select/tiled-select.module.js +0 -35
  1546. package/esm2015/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.js +0 -15
  1547. package/esm2015/toggle-edit/toggle-edit-display-tpl.directive.js +0 -15
  1548. package/esm2015/toggle-edit/toggle-edit-keyboard-listener.service.js +0 -56
  1549. package/esm2015/toggle-edit/toggle-edit.component.js +0 -403
  1550. package/esm2015/toggle-edit/toggle-edit.module.js +0 -40
  1551. package/esm2015/toggle-group/toggle-group-option.directive.js +0 -44
  1552. package/esm2015/toggle-group/toggle-group.directive.js +0 -192
  1553. package/esm2015/toggle-group/toggle-group.module.js +0 -24
  1554. package/esm2015/unsaved-changes-dialog/unsaved-changes-can-deactivate.js +0 -27
  1555. package/esm2015/unsaved-changes-dialog/unsaved-changes-dialog.component.js +0 -20
  1556. package/esm2015/unsaved-changes-dialog/unsaved-changes-dialog.guard.js +0 -35
  1557. package/esm2015/unsaved-changes-dialog/unsaved-changes-dialog.module.js +0 -12
  1558. package/esm2015/utils/array-move.js +0 -62
  1559. package/esm2015/utils/cdk/get-closest-widget-cdk-drag.js +0 -18
  1560. package/esm2015/utils/file-utils.js +0 -68
  1561. package/esm2015/utils/form/get-control-path.js +0 -37
  1562. package/esm2015/utils/geo-json/coerce-feature-collection.js +0 -44
  1563. package/esm2015/utils/geo-json/geo-json-to-area.js +0 -11
  1564. package/esm2015/utils/geo-json/is-feature-collection.validator.js +0 -21
  1565. package/esm2015/utils/geo-json/is-only-geometry-types.js +0 -23
  1566. package/esm2015/utils/geo-json/is-only-geometry-types.validator.js +0 -32
  1567. package/esm2015/utils/geo-json/merge-polygons.js +0 -35
  1568. package/esm2015/utils/geo-json/min-max-points.validator.js +0 -56
  1569. package/esm2015/utils/geo-json/no-inner-rings.validator.js +0 -63
  1570. package/esm2015/utils/geo-json/read-geo-file.js +0 -99
  1571. package/esm2015/utils/geo-json/split-multi-polygons.js +0 -29
  1572. package/esm2015/utils/has-property.js +0 -7
  1573. package/esm2015/utils/load-style-sheet.js +0 -14
  1574. package/esm2015/utils/load-style.js +0 -13
  1575. package/esm2015/utils/obj-utils.js +0 -27
  1576. package/esm2015/utils/polling-ticker.js +0 -121
  1577. package/esm2015/utils/router/operators/activated-routes-with-data-property.js +0 -11
  1578. package/esm2015/utils/router/route-snapshot-path-full.js +0 -5
  1579. package/esm2015/utils/router/route-snapshot-path-relative.js +0 -4
  1580. package/esm2015/utils/router/will-have-data-prop.js +0 -10
  1581. package/esm2015/utils/subscriber-count.js +0 -46
  1582. package/esm2015/utils/toggle-attribute.js +0 -35
  1583. package/esm2015/utils/wait-on-condition-async.js +0 -33
  1584. package/esm2015/viewers/html-template-viewer/html-template-viewer.component.js +0 -219
  1585. package/esm2015/viewers/html-template-viewer/html-template-viewer.module.js +0 -23
  1586. package/esm2015/viewers/pdf-viewer/pdf-page/pdf-page.component.js +0 -134
  1587. package/esm2015/viewers/pdf-viewer/pdf-renderer.service.js +0 -27
  1588. package/esm2015/viewers/pdf-viewer/pdf-viewer.component.js +0 -149
  1589. package/esm2015/viewers/pdf-viewer/pdf-viewer.module.js +0 -24
  1590. package/esm2015/widget/directives/widget-drag-handle.directive.js +0 -146
  1591. package/esm2015/widget/directives/widget-icon-tpl.directive.js +0 -15
  1592. package/esm2015/widget/directives/widget-title-tpl.directive.js +0 -15
  1593. package/esm2015/widget/widget/widget.component.js +0 -121
  1594. package/esm2015/widget/widget-content-components/widget-button-group/widget-button-group.component.js +0 -16
  1595. package/esm2015/widget/widget-content-components/widget-button-group/widget-button-group.module.js +0 -22
  1596. package/esm2015/widget/widget-content-components/widget-content-header/widget-content-header.component.js +0 -16
  1597. package/esm2015/widget/widget-content-components/widget-content-header/widget-content-header.module.js +0 -19
  1598. package/esm2015/widget/widget-content-components/widget-description/widget-description.component.js +0 -12
  1599. package/esm2015/widget/widget-content-components/widget-description/widget-description.module.js +0 -19
  1600. package/esm2015/widget/widget-content-components/widget-empty-label/widget-empty-label.component.js +0 -39
  1601. package/esm2015/widget/widget-content-components/widget-empty-label/widget-empty-label.module.js +0 -19
  1602. package/esm2015/widget/widget-content-components/widget-footer-link/widget-footer-link.component.js +0 -16
  1603. package/esm2015/widget/widget-content-components/widget-footer-link/widget-footer-link.module.js +0 -19
  1604. package/esm2015/widget/widget-content-components/widget-footer-text/widget-footer-text.component.js +0 -16
  1605. package/esm2015/widget/widget-content-components/widget-footer-text/widget-footer-text.module.js +0 -19
  1606. package/esm2015/widget/widget-content-components/widget-header-badge/widget-header-badge.component.js +0 -31
  1607. package/esm2015/widget/widget-content-components/widget-header-badge/widget-header-badge.module.js +0 -19
  1608. package/esm2015/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item-icon-tpl.directive.js +0 -16
  1609. package/esm2015/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.js +0 -162
  1610. package/esm2015/widget/widget-content-components/widget-list-group/widget-list-group.component.js +0 -19
  1611. package/esm2015/widget/widget-content-components/widget-list-group/widget-list-group.module.js +0 -31
  1612. package/esm2015/widget/widget-content-components/widget-table/widget-table.component.js +0 -35
  1613. package/esm2015/widget/widget-content-components/widget-table/widget-table.module.js +0 -23
  1614. package/esm2015/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.js +0 -19
  1615. package/esm2015/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.js +0 -43
  1616. package/esm2015/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.js +0 -16
  1617. package/esm2015/widget/widget-content-components/widget-tile/widget-tile-secondary-icon.directive.js +0 -16
  1618. package/esm2015/widget/widget-content-components/widget-tile/widget-tile.component.js +0 -110
  1619. package/esm2015/widget/widget-content-components/widget-tile/widget-tile.module.js +0 -33
  1620. package/esm2015/widget/widget-content-components/widget-tile-list/widget-tile-list.component.js +0 -15
  1621. package/esm2015/widget/widget-content-components/widget-tile-list/widget-tile-list.module.js +0 -21
  1622. package/esm2015/widget/widget-footer/widget-footer.component.js +0 -16
  1623. package/esm2015/widget/widget-registry.service.js +0 -56
  1624. package/esm2015/widget/widget.module.js +0 -70
  1625. package/fesm2015/theseam-ui-common-asset-reader.js +0 -173
  1626. package/fesm2015/theseam-ui-common-asset-reader.js.map +0 -1
  1627. package/fesm2015/theseam-ui-common-breadcrumbs.js +0 -203
  1628. package/fesm2015/theseam-ui-common-breadcrumbs.js.map +0 -1
  1629. package/fesm2015/theseam-ui-common-buttons.js +0 -362
  1630. package/fesm2015/theseam-ui-common-buttons.js.map +0 -1
  1631. package/fesm2015/theseam-ui-common-card.js +0 -145
  1632. package/fesm2015/theseam-ui-common-card.js.map +0 -1
  1633. package/fesm2015/theseam-ui-common-checkbox.js +0 -302
  1634. package/fesm2015/theseam-ui-common-checkbox.js.map +0 -1
  1635. package/fesm2015/theseam-ui-common-confirm-dialog.js +0 -153
  1636. package/fesm2015/theseam-ui-common-confirm-dialog.js.map +0 -1
  1637. package/fesm2015/theseam-ui-common-core.js +0 -231
  1638. package/fesm2015/theseam-ui-common-core.js.map +0 -1
  1639. package/fesm2015/theseam-ui-common-data-exporter.js +0 -81
  1640. package/fesm2015/theseam-ui-common-data-exporter.js.map +0 -1
  1641. package/fesm2015/theseam-ui-common-data-filters.js +0 -455
  1642. package/fesm2015/theseam-ui-common-data-filters.js.map +0 -1
  1643. package/fesm2015/theseam-ui-common-datatable-dynamic.js +0 -991
  1644. package/fesm2015/theseam-ui-common-datatable-dynamic.js.map +0 -1
  1645. package/fesm2015/theseam-ui-common-datatable.js +0 -2575
  1646. package/fesm2015/theseam-ui-common-datatable.js.map +0 -1
  1647. package/fesm2015/theseam-ui-common-dynamic-component-loader.js +0 -143
  1648. package/fesm2015/theseam-ui-common-dynamic-component-loader.js.map +0 -1
  1649. package/fesm2015/theseam-ui-common-dynamic.js +0 -700
  1650. package/fesm2015/theseam-ui-common-dynamic.js.map +0 -1
  1651. package/fesm2015/theseam-ui-common-footer-bar.js +0 -36
  1652. package/fesm2015/theseam-ui-common-footer-bar.js.map +0 -1
  1653. package/fesm2015/theseam-ui-common-form-field-error.js +0 -464
  1654. package/fesm2015/theseam-ui-common-form-field-error.js.map +0 -1
  1655. package/fesm2015/theseam-ui-common-form-field.js +0 -506
  1656. package/fesm2015/theseam-ui-common-form-field.js.map +0 -1
  1657. package/fesm2015/theseam-ui-common-framework.js +0 -3400
  1658. package/fesm2015/theseam-ui-common-framework.js.map +0 -1
  1659. package/fesm2015/theseam-ui-common-google-maps.js +0 -1748
  1660. package/fesm2015/theseam-ui-common-google-maps.js.map +0 -1
  1661. package/fesm2015/theseam-ui-common-graphql.js +0 -881
  1662. package/fesm2015/theseam-ui-common-graphql.js.map +0 -1
  1663. package/fesm2015/theseam-ui-common-icon.js +0 -518
  1664. package/fesm2015/theseam-ui-common-icon.js.map +0 -1
  1665. package/fesm2015/theseam-ui-common-layout.js +0 -98
  1666. package/fesm2015/theseam-ui-common-layout.js.map +0 -1
  1667. package/fesm2015/theseam-ui-common-loading.js +0 -131
  1668. package/fesm2015/theseam-ui-common-loading.js.map +0 -1
  1669. package/fesm2015/theseam-ui-common-menu.js +0 -767
  1670. package/fesm2015/theseam-ui-common-menu.js.map +0 -1
  1671. package/fesm2015/theseam-ui-common-modal.js +0 -1282
  1672. package/fesm2015/theseam-ui-common-modal.js.map +0 -1
  1673. package/fesm2015/theseam-ui-common-models.js +0 -54
  1674. package/fesm2015/theseam-ui-common-models.js.map +0 -1
  1675. package/fesm2015/theseam-ui-common-popover.js +0 -476
  1676. package/fesm2015/theseam-ui-common-popover.js.map +0 -1
  1677. package/fesm2015/theseam-ui-common-progress.js +0 -87
  1678. package/fesm2015/theseam-ui-common-progress.js.map +0 -1
  1679. package/fesm2015/theseam-ui-common-scrollbar.js +0 -184
  1680. package/fesm2015/theseam-ui-common-scrollbar.js.map +0 -1
  1681. package/fesm2015/theseam-ui-common-services.js +0 -140
  1682. package/fesm2015/theseam-ui-common-services.js.map +0 -1
  1683. package/fesm2015/theseam-ui-common-shared.js +0 -696
  1684. package/fesm2015/theseam-ui-common-shared.js.map +0 -1
  1685. package/fesm2015/theseam-ui-common-storage.js +0 -147
  1686. package/fesm2015/theseam-ui-common-storage.js.map +0 -1
  1687. package/fesm2015/theseam-ui-common-story-helpers.js +0 -441
  1688. package/fesm2015/theseam-ui-common-story-helpers.js.map +0 -1
  1689. package/fesm2015/theseam-ui-common-tabbed.js +0 -262
  1690. package/fesm2015/theseam-ui-common-tabbed.js.map +0 -1
  1691. package/fesm2015/theseam-ui-common-table-cell-type.js +0 -191
  1692. package/fesm2015/theseam-ui-common-table-cell-type.js.map +0 -1
  1693. package/fesm2015/theseam-ui-common-table-cell-types.js +0 -1079
  1694. package/fesm2015/theseam-ui-common-table-cell-types.js.map +0 -1
  1695. package/fesm2015/theseam-ui-common-table.js +0 -118
  1696. package/fesm2015/theseam-ui-common-table.js.map +0 -1
  1697. package/fesm2015/theseam-ui-common-tel-input.js +0 -733
  1698. package/fesm2015/theseam-ui-common-tel-input.js.map +0 -1
  1699. package/fesm2015/theseam-ui-common-testing.js +0 -191
  1700. package/fesm2015/theseam-ui-common-testing.js.map +0 -1
  1701. package/fesm2015/theseam-ui-common-tiled-select.js +0 -461
  1702. package/fesm2015/theseam-ui-common-tiled-select.js.map +0 -1
  1703. package/fesm2015/theseam-ui-common-toggle-edit.js +0 -521
  1704. package/fesm2015/theseam-ui-common-toggle-edit.js.map +0 -1
  1705. package/fesm2015/theseam-ui-common-toggle-group.js +0 -260
  1706. package/fesm2015/theseam-ui-common-toggle-group.js.map +0 -1
  1707. package/fesm2015/theseam-ui-common-unsaved-changes-dialog.js +0 -97
  1708. package/fesm2015/theseam-ui-common-unsaved-changes-dialog.js.map +0 -1
  1709. package/fesm2015/theseam-ui-common-utils.js +0 -1321
  1710. package/fesm2015/theseam-ui-common-utils.js.map +0 -1
  1711. package/fesm2015/theseam-ui-common-validators.js +0 -94
  1712. package/fesm2015/theseam-ui-common-validators.js.map +0 -1
  1713. package/fesm2015/theseam-ui-common-viewers.js +0 -563
  1714. package/fesm2015/theseam-ui-common-viewers.js.map +0 -1
  1715. package/fesm2015/theseam-ui-common-widget.js +0 -1189
  1716. package/fesm2015/theseam-ui-common-widget.js.map +0 -1
  1717. package/fesm2015/theseam-ui-common.js +0 -47
  1718. package/fesm2015/theseam-ui-common.js.map +0 -1
  1719. package/footer-bar/package.json +0 -11
  1720. package/footer-bar/theseam-ui-common-footer-bar.d.ts +0 -4
  1721. package/footer-bar/theseam-ui-common-footer-bar.metadata.json +0 -1
  1722. package/form-field/package.json +0 -11
  1723. package/form-field/theseam-ui-common-form-field.d.ts +0 -4
  1724. package/form-field/theseam-ui-common-form-field.metadata.json +0 -1
  1725. package/form-field-error/package.json +0 -11
  1726. package/form-field-error/theseam-ui-common-form-field-error.d.ts +0 -4
  1727. package/form-field-error/theseam-ui-common-form-field-error.metadata.json +0 -1
  1728. package/framework/package.json +0 -11
  1729. package/framework/theseam-ui-common-framework.d.ts +0 -17
  1730. package/framework/theseam-ui-common-framework.metadata.json +0 -1
  1731. package/google-maps/package.json +0 -11
  1732. package/google-maps/theseam-ui-common-google-maps.d.ts +0 -5
  1733. package/google-maps/theseam-ui-common-google-maps.metadata.json +0 -1
  1734. package/graphql/package.json +0 -11
  1735. package/graphql/theseam-ui-common-graphql.d.ts +0 -4
  1736. package/graphql/theseam-ui-common-graphql.metadata.json +0 -1
  1737. package/icon/package.json +0 -11
  1738. package/icon/theseam-ui-common-icon.d.ts +0 -4
  1739. package/icon/theseam-ui-common-icon.metadata.json +0 -1
  1740. package/layout/package.json +0 -11
  1741. package/layout/theseam-ui-common-layout.d.ts +0 -4
  1742. package/layout/theseam-ui-common-layout.metadata.json +0 -1
  1743. package/loading/package.json +0 -11
  1744. package/loading/theseam-ui-common-loading.d.ts +0 -4
  1745. package/loading/theseam-ui-common-loading.metadata.json +0 -1
  1746. package/menu/package.json +0 -11
  1747. package/menu/theseam-ui-common-menu.d.ts +0 -4
  1748. package/menu/theseam-ui-common-menu.metadata.json +0 -1
  1749. package/modal/package.json +0 -11
  1750. package/modal/theseam-ui-common-modal.d.ts +0 -4
  1751. package/modal/theseam-ui-common-modal.metadata.json +0 -1
  1752. package/models/package.json +0 -11
  1753. package/models/theseam-ui-common-models.d.ts +0 -4
  1754. package/models/theseam-ui-common-models.metadata.json +0 -1
  1755. package/popover/package.json +0 -11
  1756. package/popover/theseam-ui-common-popover.d.ts +0 -4
  1757. package/popover/theseam-ui-common-popover.metadata.json +0 -1
  1758. package/progress/package.json +0 -11
  1759. package/progress/theseam-ui-common-progress.d.ts +0 -4
  1760. package/progress/theseam-ui-common-progress.metadata.json +0 -1
  1761. package/scrollbar/package.json +0 -11
  1762. package/scrollbar/theseam-ui-common-scrollbar.d.ts +0 -4
  1763. package/scrollbar/theseam-ui-common-scrollbar.metadata.json +0 -1
  1764. package/services/package.json +0 -11
  1765. package/services/theseam-ui-common-services.d.ts +0 -4
  1766. package/services/theseam-ui-common-services.metadata.json +0 -1
  1767. package/shared/package.json +0 -11
  1768. package/shared/theseam-ui-common-shared.d.ts +0 -4
  1769. package/shared/theseam-ui-common-shared.metadata.json +0 -1
  1770. package/storage/package.json +0 -11
  1771. package/storage/theseam-ui-common-storage.d.ts +0 -4
  1772. package/storage/theseam-ui-common-storage.metadata.json +0 -1
  1773. package/story-helpers/args-to-tpl.d.ts +0 -24
  1774. package/story-helpers/package.json +0 -11
  1775. package/story-helpers/theseam-ui-common-story-helpers.d.ts +0 -4
  1776. package/story-helpers/theseam-ui-common-story-helpers.metadata.json +0 -1
  1777. package/tabbed/package.json +0 -11
  1778. package/tabbed/theseam-ui-common-tabbed.d.ts +0 -4
  1779. package/tabbed/theseam-ui-common-tabbed.metadata.json +0 -1
  1780. package/table/package.json +0 -11
  1781. package/table/theseam-ui-common-table.d.ts +0 -4
  1782. package/table/theseam-ui-common-table.metadata.json +0 -1
  1783. package/table-cell-type/package.json +0 -11
  1784. package/table-cell-type/theseam-ui-common-table-cell-type.d.ts +0 -4
  1785. package/table-cell-type/theseam-ui-common-table-cell-type.metadata.json +0 -1
  1786. package/table-cell-types/package.json +0 -11
  1787. package/table-cell-types/theseam-ui-common-table-cell-types.d.ts +0 -6
  1788. package/table-cell-types/theseam-ui-common-table-cell-types.metadata.json +0 -1
  1789. package/tel-input/package.json +0 -11
  1790. package/tel-input/theseam-ui-common-tel-input.d.ts +0 -4
  1791. package/tel-input/theseam-ui-common-tel-input.metadata.json +0 -1
  1792. package/testing/package.json +0 -11
  1793. package/testing/theseam-ui-common-testing.d.ts +0 -4
  1794. package/testing/theseam-ui-common-testing.metadata.json +0 -1
  1795. package/theseam-ui-common.d.ts +0 -4
  1796. package/theseam-ui-common.metadata.json +0 -1
  1797. package/tiled-select/package.json +0 -11
  1798. package/tiled-select/theseam-ui-common-tiled-select.d.ts +0 -4
  1799. package/tiled-select/theseam-ui-common-tiled-select.metadata.json +0 -1
  1800. package/toggle-edit/package.json +0 -11
  1801. package/toggle-edit/theseam-ui-common-toggle-edit.d.ts +0 -4
  1802. package/toggle-edit/theseam-ui-common-toggle-edit.metadata.json +0 -1
  1803. package/toggle-group/package.json +0 -11
  1804. package/toggle-group/theseam-ui-common-toggle-group.d.ts +0 -4
  1805. package/toggle-group/theseam-ui-common-toggle-group.metadata.json +0 -1
  1806. package/unsaved-changes-dialog/package.json +0 -11
  1807. package/unsaved-changes-dialog/theseam-ui-common-unsaved-changes-dialog.d.ts +0 -4
  1808. package/unsaved-changes-dialog/theseam-ui-common-unsaved-changes-dialog.metadata.json +0 -1
  1809. package/utils/package.json +0 -11
  1810. package/utils/theseam-ui-common-utils.d.ts +0 -4
  1811. package/utils/theseam-ui-common-utils.metadata.json +0 -1
  1812. package/validators/package.json +0 -11
  1813. package/validators/theseam-ui-common-validators.d.ts +0 -4
  1814. package/validators/theseam-ui-common-validators.metadata.json +0 -1
  1815. package/viewers/package.json +0 -11
  1816. package/viewers/theseam-ui-common-viewers.d.ts +0 -4
  1817. package/viewers/theseam-ui-common-viewers.metadata.json +0 -1
  1818. package/widget/package.json +0 -11
  1819. package/widget/theseam-ui-common-widget.d.ts +0 -4
  1820. package/widget/theseam-ui-common-widget.metadata.json +0 -1
  1821. /package/{esm2015/asset-reader/encrypted-asset-reader.js → esm2020/asset-reader/encrypted-asset-reader.mjs} +0 -0
  1822. /package/{esm2015/asset-reader/public-api.js → esm2020/asset-reader/public-api.mjs} +0 -0
  1823. /package/{esm2015/asset-reader/theseam-ui-common-asset-reader.js → esm2020/asset-reader/theseam-ui-common-asset-reader.mjs} +0 -0
  1824. /package/{esm2015/breadcrumbs/public-api.js → esm2020/breadcrumbs/public-api.mjs} +0 -0
  1825. /package/{esm2015/breadcrumbs/theseam-ui-common-breadcrumbs.js → esm2020/breadcrumbs/theseam-ui-common-breadcrumbs.mjs} +0 -0
  1826. /package/{esm2015/buttons/public-api.js → esm2020/buttons/public-api.mjs} +0 -0
  1827. /package/{esm2015/buttons/theseam-ui-common-buttons.js → esm2020/buttons/theseam-ui-common-buttons.mjs} +0 -0
  1828. /package/{esm2015/card/public-api.js → esm2020/card/public-api.mjs} +0 -0
  1829. /package/{esm2015/card/theseam-ui-common-card.js → esm2020/card/theseam-ui-common-card.mjs} +0 -0
  1830. /package/{esm2015/checkbox/theseam-ui-common-checkbox.js → esm2020/checkbox/theseam-ui-common-checkbox.mjs} +0 -0
  1831. /package/{esm2015/confirm-dialog/public-api.js → esm2020/confirm-dialog/public-api.mjs} +0 -0
  1832. /package/{esm2015/confirm-dialog/theseam-ui-common-confirm-dialog.js → esm2020/confirm-dialog/theseam-ui-common-confirm-dialog.mjs} +0 -0
  1833. /package/{esm2015/core/common-behaviors/constructor.js → esm2020/core/common-behaviors/constructor.mjs} +0 -0
  1834. /package/{esm2015/core/common-behaviors/element-ref.js → esm2020/core/common-behaviors/element-ref.mjs} +0 -0
  1835. /package/{esm2015/core/common-behaviors/index.js → esm2020/core/common-behaviors/index.mjs} +0 -0
  1836. /package/{esm2015/core/common-behaviors/renderer2.js → esm2020/core/common-behaviors/renderer2.mjs} +0 -0
  1837. /package/{esm2015/core/input-decorators/index.js → esm2020/core/input-decorators/index.mjs} +0 -0
  1838. /package/{esm2015/core/public-api.js → esm2020/core/public-api.mjs} +0 -0
  1839. /package/{esm2015/core/theseam-ui-common-core.js → esm2020/core/theseam-ui-common-core.mjs} +0 -0
  1840. /package/{esm2015/data-exporter/data-exporter.js → esm2020/data-exporter/data-exporter.mjs} +0 -0
  1841. /package/{esm2015/data-exporter/public-api.js → esm2020/data-exporter/public-api.mjs} +0 -0
  1842. /package/{esm2015/data-exporter/theseam-ui-common-data-exporter.js → esm2020/data-exporter/theseam-ui-common-data-exporter.mjs} +0 -0
  1843. /package/{esm2015/data-filters/data-filter-container.js → esm2020/data-filters/data-filter-container.mjs} +0 -0
  1844. /package/{esm2015/data-filters/data-filter-def.js → esm2020/data-filters/data-filter-def.mjs} +0 -0
  1845. /package/{esm2015/data-filters/filters/data-filter-search/search-filter-options.js → esm2020/data-filters/filters/data-filter-search/search-filter-options.mjs} +0 -0
  1846. /package/{esm2015/data-filters/filters/data-filter-text/text-filter-options.js → esm2020/data-filters/filters/data-filter-text/text-filter-options.mjs} +0 -0
  1847. /package/{esm2015/data-filters/public-api.js → esm2020/data-filters/public-api.mjs} +0 -0
  1848. /package/{esm2015/data-filters/theseam-ui-common-data-filters.js → esm2020/data-filters/theseam-ui-common-data-filters.mjs} +0 -0
  1849. /package/{esm2015/datatable/models/columns-alterations/hide-column.columns-alteration.js → esm2020/datatable/models/columns-alterations/hide-column.columns-alteration.mjs} +0 -0
  1850. /package/{esm2015/datatable/models/columns-alterations/sort.columns-alteration.js → esm2020/datatable/models/columns-alterations/sort.columns-alteration.mjs} +0 -0
  1851. /package/{esm2015/datatable/models/columns-alterations/width.columns-alteration.js → esm2020/datatable/models/columns-alterations/width.columns-alteration.mjs} +0 -0
  1852. /package/{esm2015/datatable/models/datatable-accessor.js → esm2020/datatable/models/datatable-accessor.mjs} +0 -0
  1853. /package/{esm2015/datatable/models/datatable-data-source.js → esm2020/datatable/models/datatable-data-source.mjs} +0 -0
  1854. /package/{esm2015/datatable/models/menubar-item-data.js → esm2020/datatable/models/menubar-item-data.mjs} +0 -0
  1855. /package/{esm2015/datatable/models/page-info.js → esm2020/datatable/models/page-info.mjs} +0 -0
  1856. /package/{esm2015/datatable/models/preferences-accessor.js → esm2020/datatable/models/preferences-accessor.mjs} +0 -0
  1857. /package/{esm2015/datatable/models/preferences.js → esm2020/datatable/models/preferences.mjs} +0 -0
  1858. /package/{esm2015/datatable/models/sort-event.js → esm2020/datatable/models/sort-event.mjs} +0 -0
  1859. /package/{esm2015/datatable/models/table-column.js → esm2020/datatable/models/table-column.mjs} +0 -0
  1860. /package/{esm2015/datatable/public-api.js → esm2020/datatable/public-api.mjs} +0 -0
  1861. /package/{esm2015/datatable/tokens/datatable-accessor.js → esm2020/datatable/tokens/datatable-accessor.mjs} +0 -0
  1862. /package/{esm2015/datatable/tokens/datatable-preferences-accessor.js → esm2020/datatable/tokens/datatable-preferences-accessor.mjs} +0 -0
  1863. /package/{esm2015/datatable/tokens/menubar-item-data.js → esm2020/datatable/tokens/menubar-item-data.mjs} +0 -0
  1864. /package/{esm2015/datatable/utils/create-action-menu-column.js → esm2020/datatable/utils/create-action-menu-column.mjs} +0 -0
  1865. /package/{esm2015/datatable/utils/create-checkbox-column.js → esm2020/datatable/utils/create-checkbox-column.mjs} +0 -0
  1866. /package/{esm2015/datatable/utils/get-column-prop.js → esm2020/datatable/utils/get-column-prop.mjs} +0 -0
  1867. /package/{esm2015/datatable/utils/remove-unused-diffs.js → esm2020/datatable/utils/remove-unused-diffs.mjs} +0 -0
  1868. /package/{esm2015/datatable/utils/translate-templates.js → esm2020/datatable/utils/translate-templates.mjs} +0 -0
  1869. /package/{esm2015/datatable-dynamic/datatable-dynamic-def.js → esm2020/datatable-dynamic/datatable-dynamic-def.mjs} +0 -0
  1870. /package/{esm2015/datatable-dynamic/datatable-dynamic-menu-bar-token.js → esm2020/datatable-dynamic/datatable-dynamic-menu-bar-token.mjs} +0 -0
  1871. /package/{esm2015/datatable-dynamic/models/dynamic-datatable-action-menu-record.js → esm2020/datatable-dynamic/models/dynamic-datatable-action-menu-record.mjs} +0 -0
  1872. /package/{esm2015/datatable-dynamic/models/dynamic-datatable-filter-menu-item.js → esm2020/datatable-dynamic/models/dynamic-datatable-filter-menu-item.mjs} +0 -0
  1873. /package/{esm2015/datatable-dynamic/models/dynamic-datatable-row-action-context.js → esm2020/datatable-dynamic/models/dynamic-datatable-row-action-context.mjs} +0 -0
  1874. /package/{esm2015/datatable-dynamic/models/dynamic-datatable-row-action.js → esm2020/datatable-dynamic/models/dynamic-datatable-row-action.mjs} +0 -0
  1875. /package/{esm2015/datatable-dynamic/models/index.js → esm2020/datatable-dynamic/models/index.mjs} +0 -0
  1876. /package/{esm2015/datatable-dynamic/public-api.js → esm2020/datatable-dynamic/public-api.mjs} +0 -0
  1877. /package/{esm2015/datatable-dynamic/theseam-ui-common-datatable-dynamic.js → esm2020/datatable-dynamic/theseam-ui-common-datatable-dynamic.mjs} +0 -0
  1878. /package/{esm2015/datatable-dynamic/utils/defaults/set-dynamic-datatable-columns-defaults.js → esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-columns-defaults.mjs} +0 -0
  1879. /package/{esm2015/datatable-dynamic/utils/defaults/set-dynamic-datatable-def-defaults.js → esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-def-defaults.mjs} +0 -0
  1880. /package/{esm2015/datatable-dynamic/utils/defaults/set-dynamic-datatable-filter-menu-defaults.js → esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-filter-menu-defaults.mjs} +0 -0
  1881. /package/{esm2015/datatable-dynamic/utils/defaults/set-dynamic-datatable-options-defaults.js → esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-options-defaults.mjs} +0 -0
  1882. /package/{esm2015/datatable-dynamic/utils/index.js → esm2020/datatable-dynamic/utils/index.mjs} +0 -0
  1883. /package/{esm2015/dynamic/action/api/dynamic-action-api-def.js → esm2020/dynamic/action/api/dynamic-action-api-def.mjs} +0 -0
  1884. /package/{esm2015/dynamic/action/api/dynamic-action-api-errors.js → esm2020/dynamic/action/api/dynamic-action-api-errors.mjs} +0 -0
  1885. /package/{esm2015/dynamic/action/api/dynamic-action-api.js → esm2020/dynamic/action/api/dynamic-action-api.mjs} +0 -0
  1886. /package/{esm2015/dynamic/action/index.js → esm2020/dynamic/action/index.mjs} +0 -0
  1887. /package/{esm2015/dynamic/action/link/dynamic-action-link-def.js → esm2020/dynamic/action/link/dynamic-action-link-def.mjs} +0 -0
  1888. /package/{esm2015/dynamic/action/link/dynamic-action-link.js → esm2020/dynamic/action/link/dynamic-action-link.mjs} +0 -0
  1889. /package/{esm2015/dynamic/action/modal/dynamic-action-modal.js → esm2020/dynamic/action/modal/dynamic-action-modal.mjs} +0 -0
  1890. /package/{esm2015/dynamic/evaluators/exporters-data-evaluator/exporters-data-value.js → esm2020/dynamic/evaluators/exporters-data-evaluator/exporters-data-value.mjs} +0 -0
  1891. /package/{esm2015/dynamic/evaluators/exporters-data-evaluator/index.js → esm2020/dynamic/evaluators/exporters-data-evaluator/index.mjs} +0 -0
  1892. /package/{esm2015/dynamic/evaluators/index.js → esm2020/dynamic/evaluators/index.mjs} +0 -0
  1893. /package/{esm2015/dynamic/evaluators/jexl-evaluator/index.js → esm2020/dynamic/evaluators/jexl-evaluator/index.mjs} +0 -0
  1894. /package/{esm2015/dynamic/evaluators/jexl-evaluator/jexl-value.js → esm2020/dynamic/evaluators/jexl-evaluator/jexl-value.mjs} +0 -0
  1895. /package/{esm2015/dynamic/models/dynamic-action-confirm-def.js → esm2020/dynamic/models/dynamic-action-confirm-def.mjs} +0 -0
  1896. /package/{esm2015/dynamic/models/dynamic-action-context.js → esm2020/dynamic/models/dynamic-action-context.mjs} +0 -0
  1897. /package/{esm2015/dynamic/models/dynamic-action-def.js → esm2020/dynamic/models/dynamic-action-def.mjs} +0 -0
  1898. /package/{esm2015/dynamic/models/dynamic-action-ui-anchor-def.js → esm2020/dynamic/models/dynamic-action-ui-anchor-def.mjs} +0 -0
  1899. /package/{esm2015/dynamic/models/dynamic-action-ui-button-def.js → esm2020/dynamic/models/dynamic-action-ui-button-def.mjs} +0 -0
  1900. /package/{esm2015/dynamic/models/dynamic-action-ui-def.js → esm2020/dynamic/models/dynamic-action-ui-def.mjs} +0 -0
  1901. /package/{esm2015/dynamic/models/dynamic-action.js → esm2020/dynamic/models/dynamic-action.mjs} +0 -0
  1902. /package/{esm2015/dynamic/models/dynamic-value-base-type.js → esm2020/dynamic/models/dynamic-value-base-type.mjs} +0 -0
  1903. /package/{esm2015/dynamic/models/dynamic-value-evaluator.js → esm2020/dynamic/models/dynamic-value-evaluator.mjs} +0 -0
  1904. /package/{esm2015/dynamic/models/dynamic-value-primitive.js → esm2020/dynamic/models/dynamic-value-primitive.mjs} +0 -0
  1905. /package/{esm2015/dynamic/models/dynamic-value-type.js → esm2020/dynamic/models/dynamic-value-type.mjs} +0 -0
  1906. /package/{esm2015/dynamic/models/dynamic-value.js → esm2020/dynamic/models/dynamic-value.mjs} +0 -0
  1907. /package/{esm2015/dynamic/models/index.js → esm2020/dynamic/models/index.mjs} +0 -0
  1908. /package/{esm2015/dynamic/public-api.js → esm2020/dynamic/public-api.mjs} +0 -0
  1909. /package/{esm2015/dynamic/theseam-ui-common-dynamic.js → esm2020/dynamic/theseam-ui-common-dynamic.mjs} +0 -0
  1910. /package/{esm2015/dynamic/tokens/api-config.js → esm2020/dynamic/tokens/api-config.mjs} +0 -0
  1911. /package/{esm2015/dynamic/tokens/dynamic-action.js → esm2020/dynamic/tokens/dynamic-action.mjs} +0 -0
  1912. /package/{esm2015/dynamic/tokens/dynamic-data.js → esm2020/dynamic/tokens/dynamic-data.mjs} +0 -0
  1913. /package/{esm2015/dynamic/tokens/dynamic-value-evaluator.js → esm2020/dynamic/tokens/dynamic-value-evaluator.mjs} +0 -0
  1914. /package/{esm2015/dynamic/tokens/index.js → esm2020/dynamic/tokens/index.mjs} +0 -0
  1915. /package/{esm2015/dynamic/utils/index.js → esm2020/dynamic/utils/index.mjs} +0 -0
  1916. /package/{esm2015/dynamic/utils/is-action-type.js → esm2020/dynamic/utils/is-action-type.mjs} +0 -0
  1917. /package/{esm2015/dynamic-component-loader/dynamic-component-tokens.js → esm2020/dynamic-component-loader/dynamic-component-tokens.mjs} +0 -0
  1918. /package/{esm2015/dynamic-component-loader/public-api.js → esm2020/dynamic-component-loader/public-api.mjs} +0 -0
  1919. /package/{esm2015/dynamic-component-loader/theseam-ui-common-dynamic-component-loader.js → esm2020/dynamic-component-loader/theseam-ui-common-dynamic-component-loader.mjs} +0 -0
  1920. /package/{esm2015/footer-bar/public-api.js → esm2020/footer-bar/public-api.mjs} +0 -0
  1921. /package/{esm2015/footer-bar/theseam-ui-common-footer-bar.js → esm2020/footer-bar/theseam-ui-common-footer-bar.mjs} +0 -0
  1922. /package/{esm2015/form-field/theseam-ui-common-form-field.js → esm2020/form-field/theseam-ui-common-form-field.mjs} +0 -0
  1923. /package/{esm2015/form-field-error/public-api.js → esm2020/form-field-error/public-api.mjs} +0 -0
  1924. /package/{esm2015/form-field-error/theseam-ui-common-form-field-error.js → esm2020/form-field-error/theseam-ui-common-form-field-error.mjs} +0 -0
  1925. /package/{esm2015/framework/base-layout/base-layout-action.js → esm2020/framework/base-layout/base-layout-action.mjs} +0 -0
  1926. /package/{esm2015/framework/base-layout/base-layout-nav.js → esm2020/framework/base-layout/base-layout-nav.mjs} +0 -0
  1927. /package/{esm2015/framework/base-layout/base-layout-ref.js → esm2020/framework/base-layout/base-layout-ref.mjs} +0 -0
  1928. /package/{esm2015/framework/base-layout/base-layout-tokens.js → esm2020/framework/base-layout/base-layout-tokens.mjs} +0 -0
  1929. /package/{esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets-item.js → esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-item.mjs} +0 -0
  1930. /package/{esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor-token.js → esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor-token.mjs} +0 -0
  1931. /package/{esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor.js → esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor.mjs} +0 -0
  1932. /package/{esm2015/framework/dashboard/index.js → esm2020/framework/dashboard/index.mjs} +0 -0
  1933. /package/{esm2015/framework/dynamic-router/index.js → esm2020/framework/dynamic-router/index.mjs} +0 -0
  1934. /package/{esm2015/framework/nav/index.js → esm2020/framework/nav/index.mjs} +0 -0
  1935. /package/{esm2015/framework/nav/nav.models.js → esm2020/framework/nav/nav.models.mjs} +0 -0
  1936. /package/{esm2015/framework/public-api.js → esm2020/framework/public-api.mjs} +0 -0
  1937. /package/{esm2015/framework/schema-form/index.js → esm2020/framework/schema-form/index.mjs} +0 -0
  1938. /package/{esm2015/google-maps/map-controls-service.js → esm2020/google-maps/map-controls-service.mjs} +0 -0
  1939. /package/{esm2015/graphql/datatable/index.js → esm2020/graphql/datatable/index.mjs} +0 -0
  1940. /package/{esm2015/graphql/datatable/map-page-info.js → esm2020/graphql/datatable/map-page-info.mjs} +0 -0
  1941. /package/{esm2015/graphql/datatable/mapper-context.js → esm2020/graphql/datatable/mapper-context.mjs} +0 -0
  1942. /package/{esm2015/graphql/models/direction.js → esm2020/graphql/models/direction.mjs} +0 -0
  1943. /package/{esm2015/graphql/models/gql-datatable-accessor.js → esm2020/graphql/models/gql-datatable-accessor.mjs} +0 -0
  1944. /package/{esm2015/graphql/models/hint-definition.js → esm2020/graphql/models/hint-definition.mjs} +0 -0
  1945. /package/{esm2015/graphql/models/hint-transform-operation.js → esm2020/graphql/models/hint-transform-operation.mjs} +0 -0
  1946. /package/{esm2015/graphql/models/hint-transformer.js → esm2020/graphql/models/hint-transformer.mjs} +0 -0
  1947. /package/{esm2015/graphql/models/hints-kind.js → esm2020/graphql/models/hints-kind.mjs} +0 -0
  1948. /package/{esm2015/graphql/models/hints-token.js → esm2020/graphql/models/hints-token.mjs} +0 -0
  1949. /package/{esm2015/graphql/models/index.js → esm2020/graphql/models/index.mjs} +0 -0
  1950. /package/{esm2015/graphql/models/query-processing-config.js → esm2020/graphql/models/query-processing-config.mjs} +0 -0
  1951. /package/{esm2015/graphql/models/variable.js → esm2020/graphql/models/variable.mjs} +0 -0
  1952. /package/{esm2015/graphql/public-api.js → esm2020/graphql/public-api.mjs} +0 -0
  1953. /package/{esm2015/graphql/theseam-ui-common-graphql.js → esm2020/graphql/theseam-ui-common-graphql.mjs} +0 -0
  1954. /package/{esm2015/graphql/utils/contains-variable.js → esm2020/graphql/utils/contains-variable.mjs} +0 -0
  1955. /package/{esm2015/graphql/utils/gql-var.js → esm2020/graphql/utils/gql-var.mjs} +0 -0
  1956. /package/{esm2015/graphql/utils/hints-tokens-containing-hint.js → esm2020/graphql/utils/hints-tokens-containing-hint.mjs} +0 -0
  1957. /package/{esm2015/graphql/utils/index.js → esm2020/graphql/utils/index.mjs} +0 -0
  1958. /package/{esm2015/graphql/utils/parse-comments.js → esm2020/graphql/utils/parse-comments.mjs} +0 -0
  1959. /package/{esm2015/graphql/utils/remove-variable-definition.js → esm2020/graphql/utils/remove-variable-definition.mjs} +0 -0
  1960. /package/{esm2015/graphql/utils/remove-variable-definitions-not-defined.js → esm2020/graphql/utils/remove-variable-definitions-not-defined.mjs} +0 -0
  1961. /package/{esm2015/graphql/utils/remove-variable.js → esm2020/graphql/utils/remove-variable.mjs} +0 -0
  1962. /package/{esm2015/icon/icon.js → esm2020/icon/icon.mjs} +0 -0
  1963. /package/{esm2015/icon/public-api.js → esm2020/icon/public-api.mjs} +0 -0
  1964. /package/{esm2015/icon/theseam-ui-common-icon.js → esm2020/icon/theseam-ui-common-icon.mjs} +0 -0
  1965. /package/{esm2015/icon/utils/file-extension-icon.js → esm2020/icon/utils/file-extension-icon.mjs} +0 -0
  1966. /package/{esm2015/icon/utils/index.js → esm2020/icon/utils/index.mjs} +0 -0
  1967. /package/{esm2015/layout/public-api.js → esm2020/layout/public-api.mjs} +0 -0
  1968. /package/{esm2015/layout/theseam-ui-common-layout.js → esm2020/layout/theseam-ui-common-layout.mjs} +0 -0
  1969. /package/{esm2015/loading/loading-themes.js → esm2020/loading/loading-themes.mjs} +0 -0
  1970. /package/{esm2015/loading/loading.models.js → esm2020/loading/loading.models.mjs} +0 -0
  1971. /package/{esm2015/loading/public-api.js → esm2020/loading/public-api.mjs} +0 -0
  1972. /package/{esm2015/loading/theseam-ui-common-loading.js → esm2020/loading/theseam-ui-common-loading.mjs} +0 -0
  1973. /package/{esm2015/menu/menu-animations.js → esm2020/menu/menu-animations.mjs} +0 -0
  1974. /package/{esm2015/menu/menu-panel-token.js → esm2020/menu/menu-panel-token.mjs} +0 -0
  1975. /package/{esm2015/menu/menu-panel.js → esm2020/menu/menu-panel.mjs} +0 -0
  1976. /package/{esm2015/menu/public-api.js → esm2020/menu/public-api.mjs} +0 -0
  1977. /package/{esm2015/menu/theseam-ui-common-menu.js → esm2020/menu/theseam-ui-common-menu.mjs} +0 -0
  1978. /package/{esm2015/modal/modal-injectors.js → esm2020/modal/modal-injectors.mjs} +0 -0
  1979. /package/{esm2015/modal/modal-utils.js → esm2020/modal/modal-utils.mjs} +0 -0
  1980. /package/{esm2015/modal/public-api.js → esm2020/modal/public-api.mjs} +0 -0
  1981. /package/{esm2015/modal/theseam-ui-common-modal.js → esm2020/modal/theseam-ui-common-modal.mjs} +0 -0
  1982. /package/{esm2015/models/component-type.js → esm2020/models/component-type.mjs} +0 -0
  1983. /package/{esm2015/models/http-status-codes.js → esm2020/models/http-status-codes.mjs} +0 -0
  1984. /package/{esm2015/models/public-api.js → esm2020/models/public-api.mjs} +0 -0
  1985. /package/{esm2015/models/size-prefixes.js → esm2020/models/size-prefixes.mjs} +0 -0
  1986. /package/{esm2015/models/size-types.js → esm2020/models/size-types.mjs} +0 -0
  1987. /package/{esm2015/models/theme-names.js → esm2020/models/theme-names.mjs} +0 -0
  1988. /package/{esm2015/models/theme-prefixes.js → esm2020/models/theme-prefixes.mjs} +0 -0
  1989. /package/{esm2015/models/theme-types.js → esm2020/models/theme-types.mjs} +0 -0
  1990. /package/{esm2015/models/theseam-ui-common-models.js → esm2020/models/theseam-ui-common-models.mjs} +0 -0
  1991. /package/{esm2015/popover/popover-animations.js → esm2020/popover/popover-animations.mjs} +0 -0
  1992. /package/{esm2015/popover/public-api.js → esm2020/popover/public-api.mjs} +0 -0
  1993. /package/{esm2015/popover/theseam-ui-common-popover.js → esm2020/popover/theseam-ui-common-popover.mjs} +0 -0
  1994. /package/{esm2015/progress/public-api.js → esm2020/progress/public-api.mjs} +0 -0
  1995. /package/{esm2015/progress/theseam-ui-common-progress.js → esm2020/progress/theseam-ui-common-progress.mjs} +0 -0
  1996. /package/{esm2015/scrollbar/overlay-scrollbars-config-model.js → esm2020/scrollbar/overlay-scrollbars-config-model.mjs} +0 -0
  1997. /package/{esm2015/scrollbar/public-api.js → esm2020/scrollbar/public-api.mjs} +0 -0
  1998. /package/{esm2015/scrollbar/theseam-ui-common-scrollbar.js → esm2020/scrollbar/theseam-ui-common-scrollbar.mjs} +0 -0
  1999. /package/{esm2015/services/public-api.js → esm2020/services/public-api.mjs} +0 -0
  2000. /package/{esm2015/services/theseam-ui-common-services.js → esm2020/services/theseam-ui-common-services.mjs} +0 -0
  2001. /package/{esm2015/shared/components/index.js → esm2020/shared/components/index.mjs} +0 -0
  2002. /package/{esm2015/shared/directives/index.js → esm2020/shared/directives/index.mjs} +0 -0
  2003. /package/{esm2015/shared/pipes/index.js → esm2020/shared/pipes/index.mjs} +0 -0
  2004. /package/{esm2015/shared/public-api.js → esm2020/shared/public-api.mjs} +0 -0
  2005. /package/{esm2015/shared/theseam-ui-common-shared.js → esm2020/shared/theseam-ui-common-shared.mjs} +0 -0
  2006. /package/{esm2015/storage/public-api.js → esm2020/storage/public-api.mjs} +0 -0
  2007. /package/{esm2015/storage/theseam-ui-common-storage.js → esm2020/storage/theseam-ui-common-storage.mjs} +0 -0
  2008. /package/{esm2015/story-helpers/initial-route-factory.js → esm2020/story-helpers/initial-route-factory.mjs} +0 -0
  2009. /package/{esm2015/story-helpers/route-button.js → esm2020/story-helpers/route-button.mjs} +0 -0
  2010. /package/{esm2015/story-helpers/theseam-ui-common-story-helpers.js → esm2020/story-helpers/theseam-ui-common-story-helpers.mjs} +0 -0
  2011. /package/{esm2015/tabbed/theseam-ui-common-tabbed.js → esm2020/tabbed/theseam-ui-common-tabbed.mjs} +0 -0
  2012. /package/{esm2015/table/public-api.js → esm2020/table/public-api.mjs} +0 -0
  2013. /package/{esm2015/table/theseam-ui-common-table.js → esm2020/table/theseam-ui-common-table.mjs} +0 -0
  2014. /package/{esm2015/table-cell-type/public-api.js → esm2020/table-cell-type/public-api.mjs} +0 -0
  2015. /package/{esm2015/table-cell-type/table-cell-type-action.js → esm2020/table-cell-type/table-cell-type-action.mjs} +0 -0
  2016. /package/{esm2015/table-cell-type/table-cell-type-column.js → esm2020/table-cell-type/table-cell-type-column.mjs} +0 -0
  2017. /package/{esm2015/table-cell-type/table-cell-type-config.js → esm2020/table-cell-type/table-cell-type-config.mjs} +0 -0
  2018. /package/{esm2015/table-cell-type/table-cell-type-manifest-provider.js → esm2020/table-cell-type/table-cell-type-manifest-provider.mjs} +0 -0
  2019. /package/{esm2015/table-cell-type/table-cell-type-name.js → esm2020/table-cell-type/table-cell-type-name.mjs} +0 -0
  2020. /package/{esm2015/table-cell-type/table-cell-type-tokens.js → esm2020/table-cell-type/table-cell-type-tokens.mjs} +0 -0
  2021. /package/{esm2015/table-cell-type/theseam-ui-common-table-cell-type.js → esm2020/table-cell-type/theseam-ui-common-table-cell-type.mjs} +0 -0
  2022. /package/{esm2015/table-cell-types/public-api.js → esm2020/table-cell-types/public-api.mjs} +0 -0
  2023. /package/{esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.js → esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.mjs} +0 -0
  2024. /package/{esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.js → esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency.mjs} +0 -0
  2025. /package/{esm2015/table-cell-types/table-cell-type-date/table-cell-type-date-config.js → esm2020/table-cell-types/table-cell-type-date/table-cell-type-date-config.mjs} +0 -0
  2026. /package/{esm2015/table-cell-types/table-cell-type-date/table-cell-type-date.js → esm2020/table-cell-types/table-cell-type-date/table-cell-type-date.mjs} +0 -0
  2027. /package/{esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.js → esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.mjs} +0 -0
  2028. /package/{esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.js → esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.mjs} +0 -0
  2029. /package/{esm2015/table-cell-types/table-cell-type-icon/table-cell-type-icon-config.js → esm2020/table-cell-types/table-cell-type-icon/table-cell-type-icon-config.mjs} +0 -0
  2030. /package/{esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.js → esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.mjs} +0 -0
  2031. /package/{esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.js → esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer.mjs} +0 -0
  2032. /package/{esm2015/table-cell-types/table-cell-type-phone/table-cell-type-phone-config.js → esm2020/table-cell-types/table-cell-type-phone/table-cell-type-phone-config.mjs} +0 -0
  2033. /package/{esm2015/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle-config.js → esm2020/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle-config.mjs} +0 -0
  2034. /package/{esm2015/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon-config.js → esm2020/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon-config.mjs} +0 -0
  2035. /package/{esm2015/table-cell-types/table-cell-type-string/table-cell-type-string-config.js → esm2020/table-cell-types/table-cell-type-string/table-cell-type-string-config.mjs} +0 -0
  2036. /package/{esm2015/tel-input/models/index.js → esm2020/tel-input/models/index.mjs} +0 -0
  2037. /package/{esm2015/tel-input/models/tel-input-country-data.js → esm2020/tel-input/models/tel-input-country-data.mjs} +0 -0
  2038. /package/{esm2015/tel-input/models/tel-input-number-format-name.js → esm2020/tel-input/models/tel-input-number-format-name.mjs} +0 -0
  2039. /package/{esm2015/tel-input/public-api.js → esm2020/tel-input/public-api.mjs} +0 -0
  2040. /package/{esm2015/tel-input/tel-input-constants.js → esm2020/tel-input/tel-input-constants.mjs} +0 -0
  2041. /package/{esm2015/tel-input/theseam-ui-common-tel-input.js → esm2020/tel-input/theseam-ui-common-tel-input.mjs} +0 -0
  2042. /package/{esm2015/tel-input/utils/coerce-phone-number-format.js → esm2020/tel-input/utils/coerce-phone-number-format.mjs} +0 -0
  2043. /package/{esm2015/tel-input/utils/get-country-code.js → esm2020/tel-input/utils/get-country-code.mjs} +0 -0
  2044. /package/{esm2015/tel-input/utils/get-dial-code.js → esm2020/tel-input/utils/get-dial-code.mjs} +0 -0
  2045. /package/{esm2015/tel-input/utils/get-global-intl-tel-input-globals.js → esm2020/tel-input/utils/get-global-intl-tel-input-globals.mjs} +0 -0
  2046. /package/{esm2015/tel-input/utils/get-global-intl-tel-input-utils.js → esm2020/tel-input/utils/get-global-intl-tel-input-utils.mjs} +0 -0
  2047. /package/{esm2015/tel-input/utils/get-intl-tel-input-utils.js → esm2020/tel-input/utils/get-intl-tel-input-utils.mjs} +0 -0
  2048. /package/{esm2015/tel-input/utils/index.js → esm2020/tel-input/utils/index.mjs} +0 -0
  2049. /package/{esm2015/testing/current-tick-time.js → esm2020/testing/current-tick-time.mjs} +0 -0
  2050. /package/{esm2015/testing/fake-toastr.js → esm2020/testing/fake-toastr.mjs} +0 -0
  2051. /package/{esm2015/testing/public-api.js → esm2020/testing/public-api.mjs} +0 -0
  2052. /package/{esm2015/testing/theseam-ui-common-testing.js → esm2020/testing/theseam-ui-common-testing.mjs} +0 -0
  2053. /package/{esm2015/testing/tick-helper.js → esm2020/testing/tick-helper.mjs} +0 -0
  2054. /package/{esm2015/theseam-ui-common.js → esm2020/theseam-ui-common.mjs} +0 -0
  2055. /package/{esm2015/tiled-select/theseam-ui-common-tiled-select.js → esm2020/tiled-select/theseam-ui-common-tiled-select.mjs} +0 -0
  2056. /package/{esm2015/tiled-select/tiled-select.models.js → esm2020/tiled-select/tiled-select.models.mjs} +0 -0
  2057. /package/{esm2015/toggle-edit/models/can-toggle-edit.js → esm2020/toggle-edit/models/can-toggle-edit.mjs} +0 -0
  2058. /package/{esm2015/toggle-edit/models/index.js → esm2020/toggle-edit/models/index.mjs} +0 -0
  2059. /package/{esm2015/toggle-edit/models/toggle-edit-ref.js → esm2020/toggle-edit/models/toggle-edit-ref.mjs} +0 -0
  2060. /package/{esm2015/toggle-edit/public-api.js → esm2020/toggle-edit/public-api.mjs} +0 -0
  2061. /package/{esm2015/toggle-edit/theseam-ui-common-toggle-edit.js → esm2020/toggle-edit/theseam-ui-common-toggle-edit.mjs} +0 -0
  2062. /package/{esm2015/toggle-group/public-api.js → esm2020/toggle-group/public-api.mjs} +0 -0
  2063. /package/{esm2015/toggle-group/theseam-ui-common-toggle-group.js → esm2020/toggle-group/theseam-ui-common-toggle-group.mjs} +0 -0
  2064. /package/{esm2015/unsaved-changes-dialog/public-api.js → esm2020/unsaved-changes-dialog/public-api.mjs} +0 -0
  2065. /package/{esm2015/unsaved-changes-dialog/theseam-ui-common-unsaved-changes-dialog.js → esm2020/unsaved-changes-dialog/theseam-ui-common-unsaved-changes-dialog.mjs} +0 -0
  2066. /package/{esm2015/utils/calc-percentage.js → esm2020/utils/calc-percentage.mjs} +0 -0
  2067. /package/{esm2015/utils/create-padding.js → esm2020/utils/create-padding.mjs} +0 -0
  2068. /package/{esm2015/utils/form/get-control-name.js → esm2020/utils/form/get-control-name.mjs} +0 -0
  2069. /package/{esm2015/utils/form/has-required-control.js → esm2020/utils/form/has-required-control.mjs} +0 -0
  2070. /package/{esm2015/utils/form/is-empty-input-value.js → esm2020/utils/form/is-empty-input-value.mjs} +0 -0
  2071. /package/{esm2015/utils/form/observe-control-is-different.js → esm2020/utils/form/observe-control-is-different.mjs} +0 -0
  2072. /package/{esm2015/utils/form/observe-control-status.js → esm2020/utils/form/observe-control-status.mjs} +0 -0
  2073. /package/{esm2015/utils/form/observe-control-valid.js → esm2020/utils/form/observe-control-valid.mjs} +0 -0
  2074. /package/{esm2015/utils/form/observe-control-value-change.js → esm2020/utils/form/observe-control-value-change.mjs} +0 -0
  2075. /package/{esm2015/utils/form/observe-control-value.js → esm2020/utils/form/observe-control-value.mjs} +0 -0
  2076. /package/{esm2015/utils/form/wait-on-non-pending-status.js → esm2020/utils/form/wait-on-non-pending-status.mjs} +0 -0
  2077. /package/{esm2015/utils/fractional-digits-count.js → esm2020/utils/fractional-digits-count.mjs} +0 -0
  2078. /package/{esm2015/utils/geo-json/no-kinks.validator.js → esm2020/utils/geo-json/no-kinks.validator.mjs} +0 -0
  2079. /package/{esm2015/utils/get-attribute.js → esm2020/utils/get-attribute.mjs} +0 -0
  2080. /package/{esm2015/utils/has-attribute.js → esm2020/utils/has-attribute.mjs} +0 -0
  2081. /package/{esm2015/utils/input-masks.js → esm2020/utils/input-masks.mjs} +0 -0
  2082. /package/{esm2015/utils/is-absolute-url.js → esm2020/utils/is-absolute-url.mjs} +0 -0
  2083. /package/{esm2015/utils/is-null-or-undefined.js → esm2020/utils/is-null-or-undefined.mjs} +0 -0
  2084. /package/{esm2015/utils/is-numeric.js → esm2020/utils/is-numeric.mjs} +0 -0
  2085. /package/{esm2015/utils/not-null-or-undefined.js → esm2020/utils/not-null-or-undefined.mjs} +0 -0
  2086. /package/{esm2015/utils/observe-query-list.js → esm2020/utils/observe-query-list.mjs} +0 -0
  2087. /package/{esm2015/utils/operators/index.js → esm2020/utils/operators/index.mjs} +0 -0
  2088. /package/{esm2015/utils/operators/map-each.js → esm2020/utils/operators/map-each.mjs} +0 -0
  2089. /package/{esm2015/utils/operators/tap-first.js → esm2020/utils/operators/tap-first.mjs} +0 -0
  2090. /package/{esm2015/utils/pad-end.js → esm2020/utils/pad-end.mjs} +0 -0
  2091. /package/{esm2015/utils/pad-start.js → esm2020/utils/pad-start.mjs} +0 -0
  2092. /package/{esm2015/utils/public-api.js → esm2020/utils/public-api.mjs} +0 -0
  2093. /package/{esm2015/utils/refreshable.js → esm2020/utils/refreshable.mjs} +0 -0
  2094. /package/{esm2015/utils/router/index.js → esm2020/utils/router/index.mjs} +0 -0
  2095. /package/{esm2015/utils/router/is-empty-url-route.js → esm2020/utils/router/is-empty-url-route.mjs} +0 -0
  2096. /package/{esm2015/utils/router/leaf-child-route.js → esm2020/utils/router/leaf-child-route.mjs} +0 -0
  2097. /package/{esm2015/utils/theseam-ui-common-utils.js → esm2020/utils/theseam-ui-common-utils.mjs} +0 -0
  2098. /package/{esm2015/utils/wrap-into-observable.js → esm2020/utils/wrap-into-observable.mjs} +0 -0
  2099. /package/{esm2015/validators/decimal.validator.js → esm2020/validators/decimal.validator.mjs} +0 -0
  2100. /package/{esm2015/validators/email-exists.validator.js → esm2020/validators/email-exists.validator.mjs} +0 -0
  2101. /package/{esm2015/validators/integer.validator.js → esm2020/validators/integer.validator.mjs} +0 -0
  2102. /package/{esm2015/validators/phone-length.validator.js → esm2020/validators/phone-length.validator.mjs} +0 -0
  2103. /package/{esm2015/validators/public-api.js → esm2020/validators/public-api.mjs} +0 -0
  2104. /package/{esm2015/validators/tax-id.validator.js → esm2020/validators/tax-id.validator.mjs} +0 -0
  2105. /package/{esm2015/validators/theseam-ui-common-validators.js → esm2020/validators/theseam-ui-common-validators.mjs} +0 -0
  2106. /package/{esm2015/viewers/html-template-viewer/index.js → esm2020/viewers/html-template-viewer/index.mjs} +0 -0
  2107. /package/{esm2015/viewers/pdf-viewer/index.js → esm2020/viewers/pdf-viewer/index.mjs} +0 -0
  2108. /package/{esm2015/viewers/public-api.js → esm2020/viewers/public-api.mjs} +0 -0
  2109. /package/{esm2015/viewers/theseam-ui-common-viewers.js → esm2020/viewers/theseam-ui-common-viewers.mjs} +0 -0
  2110. /package/{esm2015/widget/public-api.js → esm2020/widget/public-api.mjs} +0 -0
  2111. /package/{esm2015/widget/theseam-ui-common-widget.js → esm2020/widget/theseam-ui-common-widget.mjs} +0 -0
  2112. /package/{esm2015/widget/widget-registry.models.js → esm2020/widget/widget-registry.models.mjs} +0 -0
  2113. /package/{esm2015/widget/widget-token.js → esm2020/widget/widget-token.mjs} +0 -0
@@ -0,0 +1,3733 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Directive, InjectionToken, Optional, Inject, HostBinding, Input, HostListener, forwardRef, isDevMode, TemplateRef, Component, ChangeDetectionStrategy, ViewEncapsulation, ContentChild, NgModule, ViewChild, EventEmitter, Output, Injectable, ViewChildren, Self, ContentChildren } from '@angular/core';
3
+ import { tap, map, startWith, switchMap, shareReplay, mapTo, take, auditTime, debounceTime, takeUntil, distinctUntilChanged, finalize, filter } from 'rxjs/operators';
4
+ import * as i3 from '@angular/cdk/portal';
5
+ import { TemplatePortal, PortalModule, BasePortalOutlet, ComponentPortal } from '@angular/cdk/portal';
6
+ import { BehaviorSubject, isObservable, from, Subject, of, combineLatest, map as map$1, defer, Observable } from 'rxjs';
7
+ import { faAngleDoubleRight, faAngleDoubleLeft, faLock, faUnlock, faAngleLeft, faBars, faAngleDown } from '@fortawesome/free-solid-svg-icons';
8
+ import * as i1 from '@theseam/ui-common/layout';
9
+ import { TheSeamLayoutModule } from '@theseam/ui-common/layout';
10
+ import * as i2 from '@angular/common';
11
+ import { CommonModule } from '@angular/common';
12
+ import * as i4 from '@theseam/ui-common/scrollbar';
13
+ import { TheSeamScrollbarModule } from '@theseam/ui-common/scrollbar';
14
+ import * as i4$1 from '@theseam/ui-common/buttons';
15
+ import { TheSeamButtonsModule } from '@theseam/ui-common/buttons';
16
+ import * as i2$1 from '@theseam/ui-common/icon';
17
+ import { TheSeamIconModule } from '@theseam/ui-common/icon';
18
+ import { hasProperty, notNullOrUndefined, observeControlValue, observeControlStatus, isNullOrUndefined } from '@theseam/ui-common/utils';
19
+ import { __decorate } from 'tslib';
20
+ import { coerceNumberProperty, coerceBooleanProperty } from '@angular/cdk/coercion';
21
+ import * as i3$1 from '@angular/cdk/drag-drop';
22
+ import { moveItemInArray, transferArrayItem, CdkDrag, DragDropModule } from '@angular/cdk/drag-drop';
23
+ import { InputBoolean, InputNumber, mixinDisabled } from '@theseam/ui-common/core';
24
+ import { THESEAM_WIDGET_ACCESSOR } from '@theseam/ui-common/widget';
25
+ import * as i1$1 from '@theseam/ui-common/dynamic-component-loader';
26
+ import * as i6 from '@theseam/ui-common/shared';
27
+ import { TheSeamSharedModule } from '@theseam/ui-common/shared';
28
+ import * as i1$2 from '@angular/router';
29
+ import { RouterModule, NavigationEnd, NavigationStart } from '@angular/router';
30
+ import * as i4$2 from '@angular/cdk/a11y';
31
+ import { A11yModule } from '@angular/cdk/a11y';
32
+ import * as i5 from '@ng-bootstrap/ng-bootstrap';
33
+ import { NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';
34
+ import { trigger, state, style, transition, animate, group, query, animateChild, keyframes } from '@angular/animations';
35
+ import * as i2$2 from '@angular/flex-layout/extended';
36
+ import * as i3$2 from '@theseam/ui-common/menu';
37
+ import { TheSeamMenuModule, MenuComponent } from '@theseam/ui-common/menu';
38
+ import { faUserCircle } from '@fortawesome/free-regular-svg-icons';
39
+ import * as i1$3 from '@ajsf/core';
40
+ import { isArray, buildTitleMap, hasOwn, Framework, JsonSchemaFormModule, WidgetLibraryModule, JsonSchemaFormService, FrameworkLibraryService, WidgetLibraryService } from '@ajsf/core';
41
+ import * as i3$3 from '@angular/forms';
42
+ import { ReactiveFormsModule } from '@angular/forms';
43
+ import * as i4$3 from '@theseam/ui-common/form-field';
44
+ import { TheSeamFormFieldModule } from '@theseam/ui-common/form-field';
45
+ import * as i5$1 from '@theseam/ui-common/checkbox';
46
+ import { TheSeamCheckboxModule } from '@theseam/ui-common/checkbox';
47
+ import * as i5$2 from '@ng-select/ng-select';
48
+ import { NgSelectModule } from '@ng-select/ng-select';
49
+
50
+ class BaseLayoutContentFooterDirective {
51
+ constructor(_elementRef) {
52
+ this._elementRef = _elementRef;
53
+ }
54
+ }
55
+ BaseLayoutContentFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutContentFooterDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
56
+ BaseLayoutContentFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutContentFooterDirective, selector: "[seamBaseLayoutContentFooter]", ngImport: i0 });
57
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutContentFooterDirective, decorators: [{
58
+ type: Directive,
59
+ args: [{
60
+ selector: '[seamBaseLayoutContentFooter]'
61
+ }]
62
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
63
+
64
+ class BaseLayoutContentHeaderDirective {
65
+ constructor(_elementRef) {
66
+ this._elementRef = _elementRef;
67
+ }
68
+ }
69
+ BaseLayoutContentHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutContentHeaderDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
70
+ BaseLayoutContentHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutContentHeaderDirective, selector: "[seamBaseLayoutContentHeader]", ngImport: i0 });
71
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutContentHeaderDirective, decorators: [{
72
+ type: Directive,
73
+ args: [{
74
+ selector: '[seamBaseLayoutContentHeader]'
75
+ }]
76
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
77
+
78
+ class BaseLayoutContentDirective {
79
+ constructor(_elementRef) {
80
+ this._elementRef = _elementRef;
81
+ }
82
+ }
83
+ BaseLayoutContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutContentDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
84
+ BaseLayoutContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutContentDirective, selector: "[seamBaseLayoutContent]", ngImport: i0 });
85
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutContentDirective, decorators: [{
86
+ type: Directive,
87
+ args: [{
88
+ selector: '[seamBaseLayoutContent]'
89
+ }]
90
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
91
+
92
+ const THESEAM_BASE_LAYOUT_REF = new InjectionToken('seamBaseLayoutRef');
93
+
94
+ /**
95
+ * Can be used to toggle the expand state of the registered nav.
96
+ */
97
+ class BaseLayoutNavToggleDirective {
98
+ get _attrType() { return this.type; }
99
+ get _attrAriaLabel() { return this.ariaLabel || null; }
100
+ _onClick() {
101
+ if (this.baseLayout && this.baseLayout.registeredNav) {
102
+ this.baseLayout.registeredNav.toggle();
103
+ }
104
+ }
105
+ constructor(_cdr, _baseLayout) {
106
+ this._cdr = _cdr;
107
+ this.type = 'button';
108
+ /** Screenreader label for the button. */
109
+ this.ariaLabel = 'Navigation toggle';
110
+ this._toggleClass = true;
111
+ this._expandedClass = false;
112
+ this.baseLayout = _baseLayout;
113
+ }
114
+ ngOnInit() {
115
+ var _a, _b;
116
+ (_b = (_a = this.baseLayout) === null || _a === void 0 ? void 0 : _a.registeredNav) === null || _b === void 0 ? void 0 : _b.expanded$.pipe(tap(exp => {
117
+ this._expandedClass = exp;
118
+ this._cdr.markForCheck();
119
+ })).subscribe();
120
+ }
121
+ }
122
+ BaseLayoutNavToggleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutNavToggleDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: THESEAM_BASE_LAYOUT_REF, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
123
+ BaseLayoutNavToggleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutNavToggleDirective, selector: "button[seamBaseLayoutNavToggle]", inputs: { type: "type", ariaLabel: ["aria-label", "ariaLabel"] }, host: { listeners: { "click": "_onClick()" }, properties: { "attr.type": "this._attrType", "attr.aria-label": "this._attrAriaLabel", "class.base-layout-nav-toggle": "this._toggleClass", "class.base-layout-nav-toggle--expanded": "this._expandedClass" } }, exportAs: ["seamBaseLayoutNavToggle"], ngImport: i0 });
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutNavToggleDirective, decorators: [{
125
+ type: Directive,
126
+ args: [{
127
+ selector: 'button[seamBaseLayoutNavToggle]',
128
+ exportAs: 'seamBaseLayoutNavToggle'
129
+ }]
130
+ }], ctorParameters: function () {
131
+ return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
132
+ type: Optional
133
+ }, {
134
+ type: Inject,
135
+ args: [THESEAM_BASE_LAYOUT_REF]
136
+ }] }];
137
+ }, propDecorators: { _attrType: [{
138
+ type: HostBinding,
139
+ args: ['attr.type']
140
+ }], type: [{
141
+ type: Input
142
+ }], _attrAriaLabel: [{
143
+ type: HostBinding,
144
+ args: ['attr.aria-label']
145
+ }], ariaLabel: [{
146
+ type: Input,
147
+ args: ['aria-label']
148
+ }], _toggleClass: [{
149
+ type: HostBinding,
150
+ args: ['class.base-layout-nav-toggle']
151
+ }], _expandedClass: [{
152
+ type: HostBinding,
153
+ args: ['class.base-layout-nav-toggle--expanded']
154
+ }], _onClick: [{
155
+ type: HostListener,
156
+ args: ['click']
157
+ }] } });
158
+
159
+ class BaseLayoutSideBarFooterDirective {
160
+ constructor(_elementRef) {
161
+ this._elementRef = _elementRef;
162
+ }
163
+ }
164
+ BaseLayoutSideBarFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutSideBarFooterDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
165
+ BaseLayoutSideBarFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutSideBarFooterDirective, selector: "[seamBaseLayoutSideBarFooter]", ngImport: i0 });
166
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutSideBarFooterDirective, decorators: [{
167
+ type: Directive,
168
+ args: [{
169
+ selector: '[seamBaseLayoutSideBarFooter]'
170
+ }]
171
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
172
+
173
+ class BaseLayoutSideBarDirective {
174
+ constructor(_elementRef) {
175
+ this._elementRef = _elementRef;
176
+ }
177
+ }
178
+ BaseLayoutSideBarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutSideBarDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
179
+ BaseLayoutSideBarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutSideBarDirective, selector: "[seamBaseLayoutSideBar]", ngImport: i0 });
180
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutSideBarDirective, decorators: [{
181
+ type: Directive,
182
+ args: [{
183
+ selector: '[seamBaseLayoutSideBar]'
184
+ }]
185
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
186
+
187
+ class BaseLayoutTopBarDirective {
188
+ constructor(_elementRef) {
189
+ this._elementRef = _elementRef;
190
+ }
191
+ }
192
+ BaseLayoutTopBarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutTopBarDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
193
+ BaseLayoutTopBarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutTopBarDirective, selector: "[seamBaseLayoutTopBar]", ngImport: i0 });
194
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutTopBarDirective, decorators: [{
195
+ type: Directive,
196
+ args: [{
197
+ selector: '[seamBaseLayoutTopBar]'
198
+ }]
199
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
200
+
201
+ class BaseLayoutSideBarHeaderDirective {
202
+ constructor(_elementRef) {
203
+ this._elementRef = _elementRef;
204
+ }
205
+ }
206
+ BaseLayoutSideBarHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutSideBarHeaderDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
207
+ BaseLayoutSideBarHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: BaseLayoutSideBarHeaderDirective, selector: "[seamBaseLayoutSideBarHeader]", ngImport: i0 });
208
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: BaseLayoutSideBarHeaderDirective, decorators: [{
209
+ type: Directive,
210
+ args: [{
211
+ selector: '[seamBaseLayoutSideBarHeader]'
212
+ }]
213
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
214
+
215
+ const THE_SEAM_BASE_LAYOUT = {
216
+ provide: THESEAM_BASE_LAYOUT_REF,
217
+ // tslint:disable-next-line:no-use-before-declare
218
+ useExisting: forwardRef(() => TheSeamBaseLayoutComponent),
219
+ multi: false,
220
+ };
221
+ class TheSeamBaseLayoutComponent {
222
+ get registeredNav() { return this._registeredNav.value; }
223
+ get registeredActions() { return this._registeredActions.value; }
224
+ constructor(_viewContainerRef, _layout) {
225
+ this._viewContainerRef = _viewContainerRef;
226
+ this._layout = _layout;
227
+ this.faAngleDoubleRight = faAngleDoubleRight;
228
+ this.faAngleDoubleLeft = faAngleDoubleLeft;
229
+ this.overlayNav = false;
230
+ this.showSidebar = true;
231
+ this._hasSideBar = new BehaviorSubject(false);
232
+ this._registeredNav = new BehaviorSubject(undefined);
233
+ this.registeredNav$ = this._registeredNav.asObservable();
234
+ this._registeredActions = new BehaviorSubject([]);
235
+ this.registeredActions$ = this._registeredActions.asObservable();
236
+ this.isMobile$ = this._layout.isMobile$;
237
+ this.hasSideBar$ = this._hasSideBar.asObservable();
238
+ }
239
+ ngOnInit() {
240
+ if (this.mobileBreakpoint) {
241
+ this._layout.setMobileBreakpoint(this.mobileBreakpoint);
242
+ }
243
+ if (this._topBarTpl) {
244
+ this._topBarPortal = new TemplatePortal(this._topBarTpl, this._viewContainerRef);
245
+ }
246
+ if (this._sideBarTpl) {
247
+ this._sideBarPortal = new TemplatePortal(this._sideBarTpl, this._viewContainerRef);
248
+ if (this.showSidebar) {
249
+ this._hasSideBar.next(true);
250
+ }
251
+ }
252
+ if (this._contentTpl) {
253
+ this._contentPortal = new TemplatePortal(this._contentTpl, this._viewContainerRef);
254
+ }
255
+ if (this._contentHeaderTpl) {
256
+ this._contentHeaderPortal = new TemplatePortal(this._contentHeaderTpl, this._viewContainerRef);
257
+ }
258
+ if (this._contentFooterTpl) {
259
+ this._contentFooterPortal = new TemplatePortal(this._contentFooterTpl, this._viewContainerRef);
260
+ }
261
+ }
262
+ registerNav(nav) {
263
+ // TODO: Allow multiple registered navs
264
+ // if (this.registeredNav) {
265
+ // throw new Error('[TheSeamBaseLayoutComponent] A nav is already registered.')
266
+ // }
267
+ // console.log('register nav', nav)
268
+ this._registeredNav.next(nav);
269
+ }
270
+ unregisterNav(nav) {
271
+ if (this.registeredNav === nav) {
272
+ this._registeredNav.next(undefined);
273
+ }
274
+ }
275
+ registerAction(action) {
276
+ const actions = this._registeredActions.value;
277
+ if (actions.findIndex(a => a.name === action.name) !== -1) {
278
+ if (isDevMode()) {
279
+ // eslint-disable-next-line no-console
280
+ console.warn(`[TheSeamBaseLayoutComponent] registerAction(): Action ${action.name} not ` +
281
+ 'registered, because another action by that name is already registered.');
282
+ }
283
+ return;
284
+ }
285
+ actions.push(action);
286
+ }
287
+ unregisterAction(action) {
288
+ const actionName = typeof action === 'string' ? action : action.name;
289
+ const actions = this._registeredActions.value;
290
+ this._registeredActions.next(actions.filter(f => f.name !== actionName));
291
+ }
292
+ isActionRegistered(actionName) {
293
+ const actions = this._registeredActions.value;
294
+ const action = actions.find(f => f.name === actionName);
295
+ return !!action;
296
+ }
297
+ _handleButtonAction(action) {
298
+ this._execButtonAction(action).subscribe();
299
+ }
300
+ _execButtonAction(action) {
301
+ const fnRes = action.exec();
302
+ return isObservable(fnRes) ? fnRes : from(Promise.resolve(fnRes));
303
+ }
304
+ }
305
+ TheSeamBaseLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamBaseLayoutComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TheSeamLayoutService }], target: i0.ɵɵFactoryTarget.Component });
306
+ TheSeamBaseLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamBaseLayoutComponent, selector: "seam-base-layout", inputs: { overlayNav: "overlayNav", mobileBreakpoint: "mobileBreakpoint", showSidebar: "showSidebar" }, providers: [THE_SEAM_BASE_LAYOUT], queries: [{ propertyName: "_topBarTpl", first: true, predicate: BaseLayoutTopBarDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "_sideBarTpl", first: true, predicate: BaseLayoutSideBarDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "_contentTpl", first: true, predicate: BaseLayoutContentDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "_contentHeaderTpl", first: true, predicate: BaseLayoutContentHeaderDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "_contentFooterTpl", first: true, predicate: BaseLayoutContentFooterDirective, descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"base-layout-side-bar-nav-content-mobile\" *ngIf=\"isMobile$ | async\">\n <ng-template [cdkPortalOutlet]=\"_sideBarPortal\"></ng-template>\n</div>\n\n<div class=\"base-layout-top-bar-container\">\n <ng-template [cdkPortalOutlet]=\"_topBarPortal\"></ng-template>\n</div>\n<div class=\"base-layout-main-container\">\n <div *ngIf=\"hasSideBar$ | async\"\n class=\"base-layout-side-bar-container\">\n <div class=\"base-layout-side-bar-nav-content\" *ngIf=\"!(isMobile$ | async)\">\n <ng-template [cdkPortalOutlet]=\"_sideBarPortal\"></ng-template>\n </div>\n </div>\n <div class=\"base-layout-content-container\">\n <div class=\"base-layout-content-container-header d-flex flex-row\">\n <div class=\"base-layout-content-container-header-left flex-grow-1\">\n <ng-template [cdkPortalOutlet]=\"_contentHeaderPortal\"></ng-template>\n </div>\n <div class=\"base-layout-content-container-header-right d-flex\">\n <ng-container *ngFor=\"let action of registeredActions$ | async; first as isFirst\">\n <div class=\"base-layout-registered-action\">\n <ng-container [ngTemplateOutlet]=\"$any(action)?.template\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n <div class=\"base-layout-content-container-inner\" seamOverlayScrollbar>\n <ng-template [cdkPortalOutlet]=\"_contentPortal\"></ng-template>\n </div>\n <div class=\"base-layout-content-container-footer\">\n <ng-template [cdkPortalOutlet]=\"_contentFooterPortal\"></ng-template>\n </div>\n </div>\n</div>\n", styles: ["seam-base-layout{display:flex;flex-direction:column;height:100%;width:100%}seam-base-layout .base-layout-side-bar-nav-content-mobile{position:absolute;top:0;bottom:0;left:0;z-index:999}seam-base-layout .base-layout-side-bar-container{flex:0 0 auto;display:flex;flex-direction:column;border-top:none;border-right:1px solid #dee2e6;border-bottom:none;border-left:none}seam-base-layout .base-layout-side-bar-container .base-layout-side-bar-nav-content{flex:1 1 0}seam-base-layout .base-layout-main-container{flex:1 1 100%;display:flex;flex-direction:row;transform:translateZ(0)}seam-base-layout .base-layout-top-bar-container{flex:0 0 auto;border-top:none;border-right:none;border-bottom:1px solid #dee2e6;border-left:none}seam-base-layout .base-layout-content-container{flex:1 1 auto;display:flex;flex-direction:column}seam-base-layout .base-layout-content-container .base-layout-content-container-header{flex:0 0 auto;background:none;margin:.25rem;padding:0;border-radius:0;overflow:hidden}seam-base-layout .base-layout-content-container .base-layout-content-container-header-left{background:none;padding:0rem;margin:0;border-radius:0}seam-base-layout .base-layout-content-container .base-layout-content-container-header-right{background:none;padding:0rem;margin:0;border-radius:0}seam-base-layout .base-layout-content-container .base-layout-content-container-inner{flex:1 1 auto}seam-base-layout .base-layout-content-container .base-layout-content-container-footer{flex:0 0 auto}seam-base-layout .btn-baselayout-action{margin:0 0 0 .25rem;color:#212529;background-color:#e9ecef;border-color:#e9ecef;padding:.5rem 1rem;font-size:1rem;line-height:1.5;border-radius:.25rem;border:none;color:#6c757d}seam-base-layout .btn-baselayout-action:hover{color:#212529;background-color:#d3d9df;border-color:#cbd3da}seam-base-layout .btn-baselayout-action:focus,seam-base-layout .btn-baselayout-action.focus{color:#212529;background-color:#d3d9df;border-color:#cbd3da;box-shadow:0 0 0 .2rem #cbced180}seam-base-layout .btn-baselayout-action.disabled,seam-base-layout .btn-baselayout-action:disabled{color:#212529;background-color:#e9ecef;border-color:#e9ecef}seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled):active,seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled).active,.show>seam-base-layout .btn-baselayout-action.dropdown-toggle{color:#212529;background-color:#d3d9df;border-color:#c4ccd4}seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled):active:focus,seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled).active:focus,.show>seam-base-layout .btn-baselayout-action.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #cbced180}seam-base-layout .btn-baselayout-action:hover{color:#6c757d}seam-base-layout .btn-baselayout-action:focus,seam-base-layout .btn-baselayout-action.focus{color:#6c757d}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "directive", type: i4.OverlayScrollbarDirective, selector: "[seamOverlayScrollbar]", inputs: ["seamOverlayScrollbar", "overlayScrollbarEnabled"], exportAs: ["seamOverlayScrollbar"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
307
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamBaseLayoutComponent, decorators: [{
308
+ type: Component,
309
+ args: [{ selector: 'seam-base-layout', providers: [THE_SEAM_BASE_LAYOUT], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"base-layout-side-bar-nav-content-mobile\" *ngIf=\"isMobile$ | async\">\n <ng-template [cdkPortalOutlet]=\"_sideBarPortal\"></ng-template>\n</div>\n\n<div class=\"base-layout-top-bar-container\">\n <ng-template [cdkPortalOutlet]=\"_topBarPortal\"></ng-template>\n</div>\n<div class=\"base-layout-main-container\">\n <div *ngIf=\"hasSideBar$ | async\"\n class=\"base-layout-side-bar-container\">\n <div class=\"base-layout-side-bar-nav-content\" *ngIf=\"!(isMobile$ | async)\">\n <ng-template [cdkPortalOutlet]=\"_sideBarPortal\"></ng-template>\n </div>\n </div>\n <div class=\"base-layout-content-container\">\n <div class=\"base-layout-content-container-header d-flex flex-row\">\n <div class=\"base-layout-content-container-header-left flex-grow-1\">\n <ng-template [cdkPortalOutlet]=\"_contentHeaderPortal\"></ng-template>\n </div>\n <div class=\"base-layout-content-container-header-right d-flex\">\n <ng-container *ngFor=\"let action of registeredActions$ | async; first as isFirst\">\n <div class=\"base-layout-registered-action\">\n <ng-container [ngTemplateOutlet]=\"$any(action)?.template\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n <div class=\"base-layout-content-container-inner\" seamOverlayScrollbar>\n <ng-template [cdkPortalOutlet]=\"_contentPortal\"></ng-template>\n </div>\n <div class=\"base-layout-content-container-footer\">\n <ng-template [cdkPortalOutlet]=\"_contentFooterPortal\"></ng-template>\n </div>\n </div>\n</div>\n", styles: ["seam-base-layout{display:flex;flex-direction:column;height:100%;width:100%}seam-base-layout .base-layout-side-bar-nav-content-mobile{position:absolute;top:0;bottom:0;left:0;z-index:999}seam-base-layout .base-layout-side-bar-container{flex:0 0 auto;display:flex;flex-direction:column;border-top:none;border-right:1px solid #dee2e6;border-bottom:none;border-left:none}seam-base-layout .base-layout-side-bar-container .base-layout-side-bar-nav-content{flex:1 1 0}seam-base-layout .base-layout-main-container{flex:1 1 100%;display:flex;flex-direction:row;transform:translateZ(0)}seam-base-layout .base-layout-top-bar-container{flex:0 0 auto;border-top:none;border-right:none;border-bottom:1px solid #dee2e6;border-left:none}seam-base-layout .base-layout-content-container{flex:1 1 auto;display:flex;flex-direction:column}seam-base-layout .base-layout-content-container .base-layout-content-container-header{flex:0 0 auto;background:none;margin:.25rem;padding:0;border-radius:0;overflow:hidden}seam-base-layout .base-layout-content-container .base-layout-content-container-header-left{background:none;padding:0rem;margin:0;border-radius:0}seam-base-layout .base-layout-content-container .base-layout-content-container-header-right{background:none;padding:0rem;margin:0;border-radius:0}seam-base-layout .base-layout-content-container .base-layout-content-container-inner{flex:1 1 auto}seam-base-layout .base-layout-content-container .base-layout-content-container-footer{flex:0 0 auto}seam-base-layout .btn-baselayout-action{margin:0 0 0 .25rem;color:#212529;background-color:#e9ecef;border-color:#e9ecef;padding:.5rem 1rem;font-size:1rem;line-height:1.5;border-radius:.25rem;border:none;color:#6c757d}seam-base-layout .btn-baselayout-action:hover{color:#212529;background-color:#d3d9df;border-color:#cbd3da}seam-base-layout .btn-baselayout-action:focus,seam-base-layout .btn-baselayout-action.focus{color:#212529;background-color:#d3d9df;border-color:#cbd3da;box-shadow:0 0 0 .2rem #cbced180}seam-base-layout .btn-baselayout-action.disabled,seam-base-layout .btn-baselayout-action:disabled{color:#212529;background-color:#e9ecef;border-color:#e9ecef}seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled):active,seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled).active,.show>seam-base-layout .btn-baselayout-action.dropdown-toggle{color:#212529;background-color:#d3d9df;border-color:#c4ccd4}seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled):active:focus,seam-base-layout .btn-baselayout-action:not(:disabled):not(.disabled).active:focus,.show>seam-base-layout .btn-baselayout-action.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #cbced180}seam-base-layout .btn-baselayout-action:hover{color:#6c757d}seam-base-layout .btn-baselayout-action:focus,seam-base-layout .btn-baselayout-action.focus{color:#6c757d}\n"] }]
310
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i1.TheSeamLayoutService }]; }, propDecorators: { overlayNav: [{
311
+ type: Input
312
+ }], mobileBreakpoint: [{
313
+ type: Input
314
+ }], showSidebar: [{
315
+ type: Input
316
+ }], _topBarTpl: [{
317
+ type: ContentChild,
318
+ args: [BaseLayoutTopBarDirective, { static: true, read: TemplateRef }]
319
+ }], _sideBarTpl: [{
320
+ type: ContentChild,
321
+ args: [BaseLayoutSideBarDirective, { static: true, read: TemplateRef }]
322
+ }], _contentTpl: [{
323
+ type: ContentChild,
324
+ args: [BaseLayoutContentDirective, { static: true, read: TemplateRef }]
325
+ }], _contentHeaderTpl: [{
326
+ type: ContentChild,
327
+ args: [BaseLayoutContentHeaderDirective, { static: true, read: TemplateRef }]
328
+ }], _contentFooterTpl: [{
329
+ type: ContentChild,
330
+ args: [BaseLayoutContentFooterDirective, { static: true, read: TemplateRef }]
331
+ }] } });
332
+
333
+ class TheSeamBaseLayoutModule {
334
+ }
335
+ TheSeamBaseLayoutModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamBaseLayoutModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
336
+ TheSeamBaseLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamBaseLayoutModule, declarations: [TheSeamBaseLayoutComponent,
337
+ BaseLayoutContentDirective,
338
+ BaseLayoutSideBarDirective,
339
+ BaseLayoutSideBarFooterDirective,
340
+ BaseLayoutSideBarHeaderDirective,
341
+ BaseLayoutTopBarDirective,
342
+ BaseLayoutNavToggleDirective,
343
+ BaseLayoutContentHeaderDirective,
344
+ BaseLayoutContentFooterDirective], imports: [CommonModule,
345
+ PortalModule,
346
+ TheSeamScrollbarModule,
347
+ TheSeamIconModule,
348
+ TheSeamButtonsModule], exports: [TheSeamBaseLayoutComponent,
349
+ BaseLayoutContentDirective,
350
+ BaseLayoutSideBarDirective,
351
+ BaseLayoutSideBarFooterDirective,
352
+ BaseLayoutSideBarHeaderDirective,
353
+ BaseLayoutTopBarDirective,
354
+ BaseLayoutNavToggleDirective,
355
+ BaseLayoutContentHeaderDirective,
356
+ BaseLayoutContentFooterDirective] });
357
+ TheSeamBaseLayoutModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamBaseLayoutModule, imports: [CommonModule,
358
+ PortalModule,
359
+ TheSeamScrollbarModule,
360
+ TheSeamIconModule,
361
+ TheSeamButtonsModule] });
362
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamBaseLayoutModule, decorators: [{
363
+ type: NgModule,
364
+ args: [{
365
+ declarations: [
366
+ TheSeamBaseLayoutComponent,
367
+ BaseLayoutContentDirective,
368
+ BaseLayoutSideBarDirective,
369
+ BaseLayoutSideBarFooterDirective,
370
+ BaseLayoutSideBarHeaderDirective,
371
+ BaseLayoutTopBarDirective,
372
+ BaseLayoutNavToggleDirective,
373
+ BaseLayoutContentHeaderDirective,
374
+ BaseLayoutContentFooterDirective
375
+ ],
376
+ imports: [
377
+ CommonModule,
378
+ PortalModule,
379
+ TheSeamScrollbarModule,
380
+ TheSeamIconModule,
381
+ TheSeamButtonsModule
382
+ ],
383
+ exports: [
384
+ TheSeamBaseLayoutComponent,
385
+ BaseLayoutContentDirective,
386
+ BaseLayoutSideBarDirective,
387
+ BaseLayoutSideBarFooterDirective,
388
+ BaseLayoutSideBarHeaderDirective,
389
+ BaseLayoutTopBarDirective,
390
+ BaseLayoutNavToggleDirective,
391
+ BaseLayoutContentHeaderDirective,
392
+ BaseLayoutContentFooterDirective
393
+ ]
394
+ }]
395
+ }] });
396
+
397
+ class DashboardWidgetContainerComponent {
398
+ }
399
+ DashboardWidgetContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
400
+ DashboardWidgetContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DashboardWidgetContainerComponent, selector: "seam-dashboard-widget-container", inputs: { def: "def" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-template><ng-content></ng-content></ng-template>\n", styles: [""], changeDetection: i0.ChangeDetectionStrategy.OnPush });
401
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetContainerComponent, decorators: [{
402
+ type: Component,
403
+ args: [{ selector: 'seam-dashboard-widget-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template><ng-content></ng-content></ng-template>\n" }]
404
+ }], propDecorators: { def: [{
405
+ type: Input
406
+ }], templateRef: [{
407
+ type: ViewChild,
408
+ args: [TemplateRef]
409
+ }] } });
410
+
411
+ const THESEAM_DASHBOARD_WIDGETS_ACCESSOR = new InjectionToken('THESEAM_DASHBOARD_WIDGETS_ACCESSOR');
412
+
413
+ class DashboardWidgetTemplateContainerComponent {
414
+ constructor(_dashboardWidgetsComponent) {
415
+ this._dashboardWidgetsComponent = _dashboardWidgetsComponent;
416
+ this.template$ = this._dashboardWidgetsComponent.containers$.pipe(map(containers => containers.find((c) => { var _a; return c.def.widgetId === ((_a = this.item) === null || _a === void 0 ? void 0 : _a.widgetId); })), map(container => container && container.templateRef));
417
+ }
418
+ }
419
+ DashboardWidgetTemplateContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetTemplateContainerComponent, deps: [{ token: THESEAM_DASHBOARD_WIDGETS_ACCESSOR }], target: i0.ɵɵFactoryTarget.Component });
420
+ DashboardWidgetTemplateContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DashboardWidgetTemplateContainerComponent, selector: "seam-dashboard-widget-template-container", inputs: { item: "item" }, ngImport: i0, template: "<ng-template [ngTemplateOutlet]=\"$any(template$ | async)\"></ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
421
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetTemplateContainerComponent, decorators: [{
422
+ type: Component,
423
+ args: [{ selector: 'seam-dashboard-widget-template-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template [ngTemplateOutlet]=\"$any(template$ | async)\"></ng-template>\n" }]
424
+ }], ctorParameters: function () {
425
+ return [{ type: undefined, decorators: [{
426
+ type: Inject,
427
+ args: [THESEAM_DASHBOARD_WIDGETS_ACCESSOR]
428
+ }] }];
429
+ }, propDecorators: { item: [{
430
+ type: Input
431
+ }] } });
432
+
433
+ /**
434
+ * Mostly copied from
435
+ * `https://github.com/angular/components/blob/master/src/cdk/portal/portal-directives.ts`
436
+ * until I can figure out how to hold off removing the DOM nodes with the
437
+ * cdkPortalOutlet. When we update to Angular 9 I may be able to do this better
438
+ * with the new DomPortal.
439
+ *
440
+ * Directive version of a PortalOutlet. Because the directive *is* a
441
+ * PortalOutlet, portals can be directly attached to it, enabling declarative
442
+ * use.
443
+ *
444
+ * Usage: `<ng-template [cdkPortalOutlet]="greeting"></ng-template>`
445
+ */
446
+ class DashboardWidgetPortalOutletDirective extends BasePortalOutlet {
447
+ constructor(_componentFactoryResolver, _viewContainerRef, _elementRef) {
448
+ super();
449
+ this._componentFactoryResolver = _componentFactoryResolver;
450
+ this._viewContainerRef = _viewContainerRef;
451
+ this._elementRef = _elementRef;
452
+ /** Whether the portal component is initialized. */
453
+ this._isInitialized = false;
454
+ /** Emits when a portal is attached to the outlet. */
455
+ this.attached = new EventEmitter();
456
+ }
457
+ /** Portal associated with the Portal outlet. */
458
+ get portal() {
459
+ return this._attachedPortal;
460
+ }
461
+ set portal(portal) {
462
+ // console.log('[DashboardWidgetPortalOutletDirective] set portal', portal, this.hasAttached())
463
+ // Ignore the cases where the `portal` is set to a falsy value before the lifecycle hooks have
464
+ // run. This handles the cases where the user might do something like `<div cdkPortalOutlet>`
465
+ // and attach a portal programmatically in the parent component. When Angular does the first CD
466
+ // round, it will fire the setter with empty string, causing the user's content to be cleared.
467
+ if (this.hasAttached() && !portal && !this._isInitialized) {
468
+ return;
469
+ }
470
+ if (this.hasAttached()) {
471
+ super.detach();
472
+ }
473
+ if (portal) {
474
+ super.attach(portal);
475
+ }
476
+ this._attachedPortal = portal;
477
+ }
478
+ /** Component or view reference that is attached to the portal. */
479
+ get attachedRef() {
480
+ return this._attachedRef;
481
+ }
482
+ ngOnInit() {
483
+ this._isInitialized = true;
484
+ }
485
+ ngOnDestroy() {
486
+ // console.log('[DashboardWidgetPortalOutletDirective] ngOnDestroy')
487
+ // TODO: Figure out the right way to call dispose without messing up
488
+ // animation. This setTimeout way assumes the transition is 500ms, but that
489
+ // may not always be the case and isn't guaranteed to match the animation ms
490
+ // duration, since setTimeout isn't really meant for accurate timing. It
491
+ // also makes debugging animations difficult, because you can pause an
492
+ // animation, but the timeout will still run.
493
+ setTimeout(() => {
494
+ super.dispose();
495
+ this._attachedPortal = null;
496
+ this._attachedRef = null;
497
+ }, 500);
498
+ }
499
+ /**
500
+ * Attach the given ComponentPortal to this PortalOutlet using the ComponentFactoryResolver.
501
+ *
502
+ * @param portal Portal to be attached to the portal outlet.
503
+ * @returns Reference to the created component.
504
+ */
505
+ attachComponentPortal(portal) {
506
+ portal.setAttachedHost(this);
507
+ // If the portal specifies an origin, use that as the logical location of the component
508
+ // in the application tree. Otherwise use the location of this PortalOutlet.
509
+ const viewContainerRef = portal.viewContainerRef != null
510
+ ? portal.viewContainerRef
511
+ : this._viewContainerRef;
512
+ const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;
513
+ const componentFactory = resolver.resolveComponentFactory(portal.component);
514
+ const ref = viewContainerRef.createComponent(componentFactory, viewContainerRef.length, portal.injector || viewContainerRef.injector);
515
+ super.setDisposeFn(() => ref.destroy());
516
+ this._attachedPortal = portal;
517
+ this._attachedRef = ref;
518
+ this.attached.emit(ref);
519
+ return ref;
520
+ }
521
+ /**
522
+ * Attach the given TemplatePortal to this PortlHost as an embedded View.
523
+ * @param portal Portal to be attached.
524
+ * @returns Reference to the created embedded view.
525
+ */
526
+ attachTemplatePortal(portal) {
527
+ portal.setAttachedHost(this);
528
+ const viewRef = this._viewContainerRef.createEmbeddedView(portal.templateRef, portal.context);
529
+ super.setDisposeFn(() => this._viewContainerRef.clear());
530
+ this._attachedPortal = portal;
531
+ this._attachedRef = viewRef;
532
+ this.attached.emit(viewRef);
533
+ return viewRef;
534
+ }
535
+ }
536
+ DashboardWidgetPortalOutletDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetPortalOutletDirective, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
537
+ DashboardWidgetPortalOutletDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: DashboardWidgetPortalOutletDirective, selector: "[seamDashboardWidgetPortalOutlet]", inputs: { portal: ["seamDashboardWidgetPortalOutlet", "portal"] }, outputs: { attached: "attached" }, exportAs: ["seamDashboardWidgetPortalOutlet"], usesInheritance: true, ngImport: i0 });
538
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetPortalOutletDirective, decorators: [{
539
+ type: Directive,
540
+ args: [{
541
+ selector: '[seamDashboardWidgetPortalOutlet]',
542
+ exportAs: 'seamDashboardWidgetPortalOutlet',
543
+ inputs: ['portal: seamDashboardWidgetPortalOutlet']
544
+ }]
545
+ }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }]; }, propDecorators: { attached: [{
546
+ type: Output
547
+ }] } });
548
+
549
+ const THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR = new InjectionToken('ITheSeamDashboardWidgetsPreferencesAccessor');
550
+
551
+ // TODO: This needs a unit test to make sure it will not cause a race condition
552
+ // if update is called faster than the previous can respond.
553
+ //
554
+ // The ideal approach I am thinking, without steping through the process too
555
+ // thoroughly is to hold the new data emit until all pending updates are done.
556
+ // Any pending updates other than the most recently requested will be ignored
557
+ // and just wait on the most recent, and if already running it should be
558
+ // canceled if possible. Also, incase something happens that causes the new data
559
+ // emissions to get held up too long, there could be a threshold time that the
560
+ // new data can be held up.
561
+ /**
562
+ * Manages anything dealing with retrieving and updating dashboard widget
563
+ * preference data from the provided accessor.
564
+ */
565
+ class DashboardWidgetsPreferencesService {
566
+ // private _pending = false
567
+ // public get pending() { return this._pending }
568
+ constructor(_prefsAccessor) {
569
+ this._prefsAccessor = _prefsAccessor;
570
+ this._tablePrefsMap = new Map();
571
+ }
572
+ preferences(preferenceKey) {
573
+ let prefs = this._tablePrefsMap.get(preferenceKey);
574
+ if (!prefs) {
575
+ const refreshSubject = new Subject();
576
+ prefs = {
577
+ observable: this._createObservable(refreshSubject, preferenceKey),
578
+ refresh: refreshSubject
579
+ };
580
+ this._tablePrefsMap.set(preferenceKey, prefs);
581
+ }
582
+ return prefs.observable;
583
+ }
584
+ _createObservable(refreshSubject, prefKey) {
585
+ if (!this._prefsAccessor) {
586
+ return of({});
587
+ }
588
+ const accessor = (key) => this._prefsAccessor ? this._prefsAccessor.get(key) : of('{}');
589
+ return refreshSubject.pipe(startWith({}),
590
+ // tap(() => console.log('Start requesting: ', prefKey)),
591
+ switchMap(() => accessor(prefKey).pipe(map(v => {
592
+ if (!v) {
593
+ return null;
594
+ }
595
+ // TODO: Add a schema validator and migration tool to avoid parsing issues.
596
+ try {
597
+ return JSON.parse(v);
598
+ }
599
+ catch (error) {
600
+ if (isDevMode()) {
601
+ // eslint-disable-next-line no-console
602
+ console.error(error);
603
+ }
604
+ return null;
605
+ }
606
+ }), map(v => v || {}))), shareReplay({ bufferSize: 1, refCount: true }));
607
+ }
608
+ refresh(preferenceKey) {
609
+ const prefs = this._tablePrefsMap.get(preferenceKey);
610
+ if (prefs) {
611
+ // this._pending = true
612
+ // prefs.refresh.next()
613
+ return prefs.observable.pipe(
614
+ // tap(() => prefs.refresh.next()),
615
+ tap(() => setTimeout(() => { prefs.refresh.next(); }, 0)), mapTo(undefined), take(1));
616
+ }
617
+ return of(undefined);
618
+ }
619
+ selectLayout(preferenceKey, layoutName) {
620
+ return this.preferences(preferenceKey).pipe(map(prefs => (prefs.layouts || []).find(l => l.name === layoutName)));
621
+ }
622
+ // TODO: Improve this updating to not be more generic, so we can quickly add
623
+ // edits for different preference schema's.
624
+ //
625
+ // TODO: Decide if a send queue/merging of pending queue is needed to avoid
626
+ // out of order updates. This shouldn't be an issue, with how fast preferences
627
+ // will most likely be changing, but it could happen in situations, such as
628
+ // network issues.
629
+ updateLayout(preferenceKey, layout) {
630
+ if (!this._prefsAccessor) {
631
+ return of(undefined);
632
+ }
633
+ if (!hasProperty(layout, 'name')) {
634
+ throw Error(`Unable to save layout preference. 'name' is required for a layout preference.`);
635
+ }
636
+ const _layout = this.toSerializeableLayout(layout);
637
+ // this._pending = true
638
+ return this.preferences(preferenceKey).pipe(map(prefs => {
639
+ // Making the preferences immutable may not be necessary, but for now
640
+ // this obj->str->obj will work as a naive clone.
641
+ const layouts = JSON.parse(JSON.stringify(prefs.layouts || []));
642
+ const _layoutPref = layouts.find((c) => c.name === _layout.name);
643
+ // console.log('has', _layoutPref)
644
+ if (_layoutPref) {
645
+ if (hasProperty(_layout, 'name')) {
646
+ _layoutPref.name = _layout.name;
647
+ }
648
+ if (hasProperty(_layout, 'label')) {
649
+ _layoutPref.label = _layout.label;
650
+ }
651
+ if (hasProperty(_layout, 'items')) {
652
+ _layoutPref.items = _layout.items;
653
+ }
654
+ }
655
+ else {
656
+ layouts.push(Object.assign({}, _layout));
657
+ }
658
+ const newPrefs = Object.assign(Object.assign({}, prefs), { layouts });
659
+ return newPrefs;
660
+ }),
661
+ // tap(v => console.log('newPrefs', v)),
662
+ take(1), switchMap(newPrefs => this._prefsAccessor
663
+ ? this._prefsAccessor.update(preferenceKey, JSON.stringify(newPrefs))
664
+ : of(newPrefs)), switchMap(() => this.refresh(preferenceKey).pipe(mapTo(undefined))));
665
+ // .subscribe()
666
+ }
667
+ toSerializeableLayout(layout) {
668
+ const serialized = {
669
+ name: layout.name,
670
+ label: layout.label,
671
+ items: this.toSerializeableItems(layout.items) || []
672
+ };
673
+ return serialized;
674
+ }
675
+ // public toDeserializedLayout(layout: IDashboardWidgetItemLayoutSerialized): IDashboardWidgetItemLayoutDef {
676
+ // // For now there is nothing to do. Eventually this should have at least
677
+ // // validation on the deserialized object.
678
+ // return layout
679
+ // }
680
+ /**
681
+ * Returns the serializable widget items as objects that can be serialized to
682
+ * a JSON string for storage.
683
+ */
684
+ toSerializeableItems(widgets) {
685
+ const serialized = [];
686
+ for (const w of widgets) {
687
+ // if (!w.__itemDef.component || typeof w.__itemDef.component !== 'string') {
688
+ // console.warn(`[DashboardWidgetsService] Widget item def must have a string 'component' property to be serialized.`, w)
689
+ // continue
690
+ // }
691
+ // serialized.push({
692
+ // widgetId: w.widgetId,
693
+ // col: w.col,
694
+ // order: w.order,
695
+ // component: w.__itemDef.component
696
+ // })
697
+ // TODO: Remove this, it is only here for initial dev debugging.
698
+ serialized.push({
699
+ widgetId: w.widgetId,
700
+ col: w.col,
701
+ order: w.order,
702
+ // component: w.__itemDef.component as string
703
+ });
704
+ }
705
+ return serialized;
706
+ }
707
+ }
708
+ DashboardWidgetsPreferencesService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsPreferencesService, deps: [{ token: THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
709
+ DashboardWidgetsPreferencesService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsPreferencesService, providedIn: 'root' });
710
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsPreferencesService, decorators: [{
711
+ type: Injectable,
712
+ args: [{
713
+ providedIn: 'root'
714
+ }]
715
+ }], ctorParameters: function () {
716
+ return [{ type: undefined, decorators: [{
717
+ type: Optional
718
+ }, {
719
+ type: Inject,
720
+ args: [THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR]
721
+ }] }];
722
+ } });
723
+
724
+ class DashboardWidgetsService {
725
+ get widgets() { return this._widgets.value; }
726
+ set widgets(value) { this._widgets.next(value); }
727
+ get numColumns() { return this._numColumns.value; }
728
+ set numColumns(value) {
729
+ if (value !== this._numColumns.value) {
730
+ this._numColumns.next(value);
731
+ }
732
+ }
733
+ constructor(_dynamicComponentLoaderModule, _preferences) {
734
+ this._dynamicComponentLoaderModule = _dynamicComponentLoaderModule;
735
+ this._preferences = _preferences;
736
+ this.preferenceKey = 'datatable-widgets';
737
+ this.defaultNumColumns = 3;
738
+ /** Used for operations, such as 'addWidget', if the column is not specified. */
739
+ this.defaultColumn = 0;
740
+ this._widgets = new BehaviorSubject([]);
741
+ this._numColumns = new BehaviorSubject(this.defaultNumColumns);
742
+ this._viewContainerRefSubject = new BehaviorSubject(undefined);
743
+ this.numColumns$ = this._numColumns.asObservable();
744
+ // Widget items without preferences
745
+ const _widgetItems$ = combineLatest([this._widgets, this._viewContainerRefSubject])
746
+ .pipe(switchMap(([defs, vcr]) => this.createWidgetItems(defs, vcr)));
747
+ // Widget items with preferences
748
+ this.widgetItems$ = combineLatest([_widgetItems$, this.numColumns$])
749
+ .pipe(
750
+ // Wait until the current tick is done, incase both the widgets and
751
+ // number of columns are set durring the same tick. Without the audit,
752
+ // this would get called twice when the component is initialized with
753
+ // both inputs set one after the other individually.
754
+ auditTime(0), switchMap(([items, numColumns]) => this._preferences.selectLayout(this.preferenceKey, this._layoutName(numColumns)).pipe(map(layout => layout ? this.withLayoutPreferences(items, layout) : items))), shareReplay({ bufferSize: 1, refCount: true }));
755
+ this.widgetColumns$ = this.widgetItems$
756
+ .pipe(map(items => this.toColumnRecords(items)), shareReplay({ bufferSize: 1, refCount: true }));
757
+ }
758
+ _layoutName(numColumns) {
759
+ return `columns-${numColumns}`;
760
+ }
761
+ setViewContainerRef(vcr) {
762
+ this._viewContainerRefSubject.next(vcr);
763
+ }
764
+ createWidgetItems(defs, vcr) {
765
+ const _createObservables = (defs || []).map(d => this.createWidgetItem(d, vcr));
766
+ const items$ = _createObservables.length > 0 ? combineLatest(_createObservables) : of([]);
767
+ return items$.pipe(map(items => items.filter(notNullOrUndefined)), tap(items => {
768
+ if (isDevMode()) {
769
+ const ids = items.map(v => v.widgetId);
770
+ if ((new Set(ids)).size !== ids.length) {
771
+ // eslint-disable-next-line no-console
772
+ console.warn(`[DashboardWidgetsService] Duplicate widget's with the same 'widgetId' found.`);
773
+ }
774
+ }
775
+ }));
776
+ }
777
+ createWidgetItem(def, vcr) {
778
+ if (!def.widgetId || typeof def.widgetId !== 'string' || def.widgetId.length < 1) {
779
+ if (isDevMode()) {
780
+ // eslint-disable-next-line no-console
781
+ console.warn(`[DashboardWidgetsService] Widget ignored. All widgets must have a 'widgetId'.`, def);
782
+ }
783
+ return of(undefined);
784
+ }
785
+ return this.createWidgetPortal(def, vcr).pipe(map(portal => (Object.assign(Object.assign({}, def), { col: def.col || this.defaultColumn, order: def.order || 0, portal, __itemDef: def }))));
786
+ }
787
+ createWidgetPortal(def, vcr) {
788
+ if (typeof def.component === 'string') {
789
+ return this._dynamicComponentLoaderModule
790
+ .getComponentFactory(def.component)
791
+ .pipe(map(componentFactory => {
792
+ return new ComponentPortal(componentFactory.componentType, vcr, undefined, componentFactory /* ComponentFactoryBoundToModule */.ngModule.componentFactoryResolver);
793
+ }), take(1));
794
+ }
795
+ return def.componentFactoryResolver
796
+ ? of(new ComponentPortal(def.component, vcr, undefined, def.componentFactoryResolver))
797
+ : of(new ComponentPortal(def.component, vcr));
798
+ }
799
+ updateOrder() {
800
+ return this.widgetColumns$
801
+ .pipe(take(1), tap(columns => columns.forEach(col => {
802
+ let i = 0;
803
+ col.items.forEach(itm => itm.order = i++);
804
+ })), mapTo(undefined));
805
+ }
806
+ toColumnRecords(items) {
807
+ let columns = [];
808
+ for (let i = 0; i < this.numColumns; i++) {
809
+ columns.push({ column: i, items: [] });
810
+ }
811
+ const colNotFound = [];
812
+ // Distribute items into columns
813
+ for (const item of items) {
814
+ const col = columns.find(c => c.column === item.col);
815
+ if (!col) {
816
+ // columns.push({ column: item.col, items: [ item ] })
817
+ // if (item.col < 0) {
818
+ // const col0: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === 0)
819
+ // if (col0) {
820
+ // col0.items.push(item)
821
+ // }
822
+ // } else if (item.col > this.numColumns - 1) {
823
+ // const colMax: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === this.numColumns - 1)
824
+ // if (colMax) {
825
+ // colMax.items.push(item)
826
+ // }
827
+ // }
828
+ colNotFound.push(item);
829
+ }
830
+ else {
831
+ col.items.push(item);
832
+ }
833
+ }
834
+ for (let i = 0; i < colNotFound.length; i++) {
835
+ const item = colNotFound[i];
836
+ const col = columns
837
+ .find(c => c.column === i % this.numColumns);
838
+ if (col) {
839
+ col.items.push(item);
840
+ }
841
+ }
842
+ // Sort columns
843
+ columns = columns.sort((a, b) => a.column - b.column);
844
+ // Sort columns items
845
+ columns.forEach(col => col.items.sort((a, b) => a.order - b.order));
846
+ return columns;
847
+ }
848
+ withLayoutPreferences(items, layout) {
849
+ const _items = [];
850
+ for (const item of items) {
851
+ const itemPref = layout.items.find(x => x.widgetId === item.widgetId);
852
+ _items.push(Object.assign(Object.assign({}, item), (itemPref || {})));
853
+ }
854
+ return _items;
855
+ }
856
+ savePreferences() {
857
+ // Right now the items are moved between the column record arrays, but the
858
+ // 'col' prop is not updated, so it is mapped to corrected items here from
859
+ // the column records.
860
+ const items$ = this.widgetColumns$.pipe(map(columns => []
861
+ .concat(...(columns.map(c => c.items.map(itm => (Object.assign(Object.assign({}, itm), { col: c.column }))))))));
862
+ return combineLatest([items$, this.numColumns$]).pipe(auditTime(0), take(1), switchMap(([items, numColumns]) => {
863
+ return this._preferences.updateLayout(this.preferenceKey, {
864
+ name: this._layoutName(numColumns),
865
+ items
866
+ });
867
+ }), mapTo(undefined));
868
+ }
869
+ }
870
+ DashboardWidgetsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsService, deps: [{ token: i1$1.TheSeamDynamicComponentLoader }, { token: DashboardWidgetsPreferencesService }], target: i0.ɵɵFactoryTarget.Injectable });
871
+ DashboardWidgetsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsService, providedIn: 'root' });
872
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsService, decorators: [{
873
+ type: Injectable,
874
+ args: [{
875
+ providedIn: 'root'
876
+ }]
877
+ }], ctorParameters: function () { return [{ type: i1$1.TheSeamDynamicComponentLoader }, { type: DashboardWidgetsPreferencesService }]; } });
878
+
879
+ class DashboardWidgetsComponent {
880
+ get gapSize() { return this._gapSize.value; }
881
+ set gapSize(val) {
882
+ this._gapSize.next(coerceNumberProperty(val));
883
+ }
884
+ get dragToggleVisible() { return this._dragToggleVisible.value; }
885
+ set dragToggleVisible(val) {
886
+ this._dragToggleVisible.next(coerceBooleanProperty(val));
887
+ }
888
+ get numColumns() { return this._dashboardWidgets.numColumns; }
889
+ set numColumns(val) {
890
+ this._dashboardWidgets.numColumns = coerceNumberProperty(val);
891
+ }
892
+ set widgets(value) { this._dashboardWidgets.widgets = value || []; }
893
+ get widgets() { return this._dashboardWidgets.widgets; }
894
+ constructor(_dashboardWidgets, _viewContainerRef, _cdr, _baseLayoutRef) {
895
+ this._dashboardWidgets = _dashboardWidgets;
896
+ this._viewContainerRef = _viewContainerRef;
897
+ this._cdr = _cdr;
898
+ this._baseLayoutRef = _baseLayoutRef;
899
+ this.faLock = faLock;
900
+ this.faUnlock = faUnlock;
901
+ this._actionWidgetDragToggleName = 'widget-drag-toggle';
902
+ this._ngUnsubscribe = new Subject();
903
+ this._gapSize = new BehaviorSubject(30);
904
+ this.widgetsDraggable = false;
905
+ this._dragToggleVisible = new BehaviorSubject(true);
906
+ this._containers = new BehaviorSubject([]);
907
+ this._layoutChange = new Subject();
908
+ this.widgetsChange = new EventEmitter();
909
+ this._widthChange = new Subject();
910
+ this.containers$ = this._containers.asObservable();
911
+ this._gapStyleSize$ = this._gapSize.pipe(auditTime(0), map(size => size / 2), shareReplay({ bufferSize: 1, refCount: true }));
912
+ this._widthChange.pipe(debounceTime(30), tap(width => {
913
+ if (width > 1300) {
914
+ this.numColumns = 3;
915
+ }
916
+ else if (width > 800) {
917
+ this.numColumns = 2;
918
+ }
919
+ else {
920
+ this.numColumns = 1;
921
+ }
922
+ }), takeUntil(this._ngUnsubscribe)).subscribe();
923
+ this.widgetItems$ = this._dashboardWidgets.widgetItems$;
924
+ this.widgetColumns$ = this._dashboardWidgets.widgetColumns$;
925
+ }
926
+ ngOnInit() {
927
+ // this._dashboardWidgets.setViewContainerRef(this._viewContainerRef)
928
+ this._layoutChange.pipe(switchMap(() => this.widgetItems$.pipe(take(1), tap(widgetItems => this.widgetsChange.emit(widgetItems)),
929
+ // map(widgetItems => this._dashboardWidgets.toSerializeableItems(widgetItems)),
930
+ // tap(v => console.log('serializable', v)),
931
+ switchMap(() => this._dashboardWidgets.savePreferences()))), takeUntil(this._ngUnsubscribe)).subscribe();
932
+ }
933
+ ngOnDestroy() {
934
+ this._unregisterToggleAction();
935
+ this._ngUnsubscribe.next(undefined);
936
+ this._ngUnsubscribe.complete();
937
+ }
938
+ ngAfterViewInit() {
939
+ var _a;
940
+ if (this._baseLayoutRef) {
941
+ this._dragToggleVisible.pipe(distinctUntilChanged(), tap(visible => {
942
+ const isRegistered = this._isActionToggleActionRegistered();
943
+ if (visible && !isRegistered) {
944
+ this._registerToggleAction();
945
+ }
946
+ else if (!visible && isRegistered) {
947
+ this._unregisterToggleAction();
948
+ }
949
+ }), takeUntil(this._ngUnsubscribe)).subscribe();
950
+ }
951
+ (_a = this.containers) === null || _a === void 0 ? void 0 : _a.changes.pipe(startWith(undefined), map(() => { var _a; return ((_a = this.containers) === null || _a === void 0 ? void 0 : _a.toArray()) || []; }), takeUntil(this._ngUnsubscribe), finalize(() => this._containers.next([]))).subscribe(v => this._containers.next(v));
952
+ }
953
+ _registerToggleAction() {
954
+ if (this._baseLayoutRef) {
955
+ // This should probably use a component dynamically created from the
956
+ // config and return a ref to it, instead of using a template.
957
+ if (this._toggleBtnTpl) {
958
+ this._baseLayoutRef.registerAction({
959
+ // type: 'button',
960
+ type: 'template',
961
+ name: this._actionWidgetDragToggleName,
962
+ label: 'Toggle Widget Dragging',
963
+ // exec: () => {
964
+ // console.log('toggle')
965
+ // },
966
+ template: this._toggleBtnTpl
967
+ });
968
+ }
969
+ }
970
+ }
971
+ _unregisterToggleAction() {
972
+ if (this._baseLayoutRef) {
973
+ this._baseLayoutRef.unregisterAction(this._actionWidgetDragToggleName);
974
+ }
975
+ }
976
+ _isActionToggleActionRegistered() {
977
+ if (!this._baseLayoutRef) {
978
+ return false;
979
+ }
980
+ return this._baseLayoutRef.isActionRegistered(this._actionWidgetDragToggleName);
981
+ }
982
+ drop(event) {
983
+ if (event.previousContainer === event.container) {
984
+ moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
985
+ this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next());
986
+ }
987
+ else {
988
+ transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);
989
+ this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next());
990
+ }
991
+ }
992
+ _containerTrackByFn(index, item) {
993
+ return item.widgetId;
994
+ }
995
+ _columnsTrackByFn(index, record) {
996
+ return record.column;
997
+ }
998
+ toggleDragging() {
999
+ this.widgetsDraggable = !this.widgetsDraggable;
1000
+ this._cdr.detectChanges();
1001
+ }
1002
+ _resized(event) {
1003
+ this._widthChange.next(event.size.width);
1004
+ }
1005
+ }
1006
+ DashboardWidgetsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsComponent, deps: [{ token: DashboardWidgetsService }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: THESEAM_BASE_LAYOUT_REF, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1007
+ DashboardWidgetsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DashboardWidgetsComponent, selector: "seam-dashboard-widgets", inputs: { gapSize: "gapSize", widgetsDraggable: "widgetsDraggable", dragToggleVisible: "dragToggleVisible", numColumns: "numColumns", widgets: "widgets" }, outputs: { widgetsChange: "widgetsChange" }, providers: [
1008
+ {
1009
+ provide: THESEAM_WIDGET_ACCESSOR,
1010
+ // tslint:disable-next-line:no-use-before-declare
1011
+ useExisting: forwardRef(() => DashboardWidgetsComponent)
1012
+ },
1013
+ {
1014
+ provide: THESEAM_DASHBOARD_WIDGETS_ACCESSOR,
1015
+ // tslint:disable-next-line:no-use-before-declare
1016
+ useExisting: forwardRef(() => DashboardWidgetsComponent)
1017
+ },
1018
+ ], viewQueries: [{ propertyName: "_toggleBtnTpl", first: true, predicate: ["toggleBtnTpl"], descendants: true, static: true }, { propertyName: "containers", predicate: DashboardWidgetContainerComponent, descendants: true }, { propertyName: "cdkDragDirectives", predicate: CdkDrag, descendants: true }], ngImport: i0, template: "<!--\n This is an ugly trick I am using to render the component into an <ng-content>\n wrapped in an <ng-template> to move the component to different outlets without\n reinitializing it. This way the widget won't reload when moving between\n columns. When I remember how I programatically did this I will remove this\n weirdness.\n -->\n <seam-dashboard-widget-container *ngFor=\"let item of widgetItems$ | async; trackBy: _containerTrackByFn\" [def]=\"$any(item)\">\n <!-- <ng-template [cdkPortalOutlet]=\"item.portal\"></ng-template> -->\n <ng-template [seamDashboardWidgetPortalOutlet]=\"item.portal\"></ng-template>\n</seam-dashboard-widget-container>\n\n<div class=\"dashboard-widgets-base d-flex flex-row justify-content-around\"\n style=\"flex: 1410px;\"\n [style.padding.px]=\"_gapStyleSize$ | async\"\n (seamElemResized)=\"_resized($event)\"\n cdkDropListGroup>\n <div *ngFor=\"let col of widgetColumns$ | async; trackBy: _columnsTrackByFn\"\n class=\"d-flex flex-column flex-grow-1 dashboard-widgets-list\"\n cdkDropList\n [cdkDropListData]=\"col.items\"\n (cdkDropListDropped)=\"drop($any($event))\">\n <div *ngFor=\"let item of col.items; trackBy: _containerTrackByFn\"\n class=\"dashboard-widgets-list-item\"\n [attr.data-widget-id]=\"item.widgetId\"\n cdkDrag\n [cdkDragDisabled]=\"!widgetsDraggable\">\n <div [style.margin.px]=\"_gapStyleSize$ | async\">\n <seam-dashboard-widget-template-container [item]=\"item\"></seam-dashboard-widget-template-container>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #toggleBtnTpl>\n <button seamButton theme=\"baselayout-action\" title=\"{{ widgetsDraggable ? 'Lock the Dashboard' : 'Modify Dashboard' }}\" (click)=\"toggleDragging()\">\n <seam-icon [icon]=\"widgetsDraggable ? faUnlock : faLock\"></seam-icon>\n </button>\n</ng-template>\n", styles: ["seam-dashboard-widgets{display:flex;justify-content:center}seam-dashboard-widgets .dashboard-widgets-base{max-width:1410px}seam-dashboard-widgets .dashboard-widgets-list{flex-basis:400px;max-width:500px}seam-dashboard-widgets .dashboard-widgets-list.cdk-drop-list-dragging .dashboard-widgets-list-item:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.dashboard-widgets-list-item.cdk-drag-preview{box-sizing:border-box}.dashboard-widgets-list-item.cdk-drag-preview>div{border-radius:.25rem;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.dashboard-widgets-list-item.cdk-drag-disabled .cdk-drag-handle{cursor:default}.dashboard-widgets-list-item .cdk-drag-handle{cursor:move}.dashboard-widgets-list-item.cdk-drag-placeholder{opacity:0}.dashboard-widgets-list-item.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3$1.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i3$1.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i3$1.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i4$1.ButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }, { kind: "component", type: i2$1.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "directive", type: i6.ElemResizedDirective, selector: "[seamElemResized]", outputs: ["seamElemResized"] }, { kind: "component", type: DashboardWidgetContainerComponent, selector: "seam-dashboard-widget-container", inputs: ["def"] }, { kind: "component", type: DashboardWidgetTemplateContainerComponent, selector: "seam-dashboard-widget-template-container", inputs: ["item"] }, { kind: "directive", type: DashboardWidgetPortalOutletDirective, selector: "[seamDashboardWidgetPortalOutlet]", inputs: ["seamDashboardWidgetPortalOutlet"], outputs: ["attached"], exportAs: ["seamDashboardWidgetPortalOutlet"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1019
+ __decorate([
1020
+ InputBoolean()
1021
+ ], DashboardWidgetsComponent.prototype, "widgetsDraggable", void 0);
1022
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardWidgetsComponent, decorators: [{
1023
+ type: Component,
1024
+ args: [{ selector: 'seam-dashboard-widgets', providers: [
1025
+ {
1026
+ provide: THESEAM_WIDGET_ACCESSOR,
1027
+ // tslint:disable-next-line:no-use-before-declare
1028
+ useExisting: forwardRef(() => DashboardWidgetsComponent)
1029
+ },
1030
+ {
1031
+ provide: THESEAM_DASHBOARD_WIDGETS_ACCESSOR,
1032
+ // tslint:disable-next-line:no-use-before-declare
1033
+ useExisting: forwardRef(() => DashboardWidgetsComponent)
1034
+ },
1035
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<!--\n This is an ugly trick I am using to render the component into an <ng-content>\n wrapped in an <ng-template> to move the component to different outlets without\n reinitializing it. This way the widget won't reload when moving between\n columns. When I remember how I programatically did this I will remove this\n weirdness.\n -->\n <seam-dashboard-widget-container *ngFor=\"let item of widgetItems$ | async; trackBy: _containerTrackByFn\" [def]=\"$any(item)\">\n <!-- <ng-template [cdkPortalOutlet]=\"item.portal\"></ng-template> -->\n <ng-template [seamDashboardWidgetPortalOutlet]=\"item.portal\"></ng-template>\n</seam-dashboard-widget-container>\n\n<div class=\"dashboard-widgets-base d-flex flex-row justify-content-around\"\n style=\"flex: 1410px;\"\n [style.padding.px]=\"_gapStyleSize$ | async\"\n (seamElemResized)=\"_resized($event)\"\n cdkDropListGroup>\n <div *ngFor=\"let col of widgetColumns$ | async; trackBy: _columnsTrackByFn\"\n class=\"d-flex flex-column flex-grow-1 dashboard-widgets-list\"\n cdkDropList\n [cdkDropListData]=\"col.items\"\n (cdkDropListDropped)=\"drop($any($event))\">\n <div *ngFor=\"let item of col.items; trackBy: _containerTrackByFn\"\n class=\"dashboard-widgets-list-item\"\n [attr.data-widget-id]=\"item.widgetId\"\n cdkDrag\n [cdkDragDisabled]=\"!widgetsDraggable\">\n <div [style.margin.px]=\"_gapStyleSize$ | async\">\n <seam-dashboard-widget-template-container [item]=\"item\"></seam-dashboard-widget-template-container>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #toggleBtnTpl>\n <button seamButton theme=\"baselayout-action\" title=\"{{ widgetsDraggable ? 'Lock the Dashboard' : 'Modify Dashboard' }}\" (click)=\"toggleDragging()\">\n <seam-icon [icon]=\"widgetsDraggable ? faUnlock : faLock\"></seam-icon>\n </button>\n</ng-template>\n", styles: ["seam-dashboard-widgets{display:flex;justify-content:center}seam-dashboard-widgets .dashboard-widgets-base{max-width:1410px}seam-dashboard-widgets .dashboard-widgets-list{flex-basis:400px;max-width:500px}seam-dashboard-widgets .dashboard-widgets-list.cdk-drop-list-dragging .dashboard-widgets-list-item:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.dashboard-widgets-list-item.cdk-drag-preview{box-sizing:border-box}.dashboard-widgets-list-item.cdk-drag-preview>div{border-radius:.25rem;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.dashboard-widgets-list-item.cdk-drag-disabled .cdk-drag-handle{cursor:default}.dashboard-widgets-list-item .cdk-drag-handle{cursor:move}.dashboard-widgets-list-item.cdk-drag-placeholder{opacity:0}.dashboard-widgets-list-item.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}\n"] }]
1036
+ }], ctorParameters: function () {
1037
+ return [{ type: DashboardWidgetsService }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
1038
+ type: Optional
1039
+ }, {
1040
+ type: Inject,
1041
+ args: [THESEAM_BASE_LAYOUT_REF]
1042
+ }] }];
1043
+ }, propDecorators: { gapSize: [{
1044
+ type: Input
1045
+ }], widgetsDraggable: [{
1046
+ type: Input
1047
+ }], dragToggleVisible: [{
1048
+ type: Input
1049
+ }], numColumns: [{
1050
+ type: Input
1051
+ }], widgets: [{
1052
+ type: Input
1053
+ }], containers: [{
1054
+ type: ViewChildren,
1055
+ args: [DashboardWidgetContainerComponent]
1056
+ }], cdkDragDirectives: [{
1057
+ type: ViewChildren,
1058
+ args: [CdkDrag]
1059
+ }], _toggleBtnTpl: [{
1060
+ type: ViewChild,
1061
+ args: ['toggleBtnTpl', { static: true }]
1062
+ }], widgetsChange: [{
1063
+ type: Output
1064
+ }] } });
1065
+
1066
+ class DashboardComponent {
1067
+ constructor() {
1068
+ this.widgetsDraggable = true;
1069
+ }
1070
+ }
1071
+ DashboardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1072
+ DashboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DashboardComponent, selector: "seam-dashboard", inputs: { widgets: "widgets", widgetsDraggable: "widgetsDraggable" }, ngImport: i0, template: "<seam-dashboard-widgets [widgets]=\"widgets\" [widgetsDraggable]=\"widgetsDraggable\"></seam-dashboard-widgets>\n", styles: [""], dependencies: [{ kind: "component", type: DashboardWidgetsComponent, selector: "seam-dashboard-widgets", inputs: ["gapSize", "widgetsDraggable", "dragToggleVisible", "numColumns", "widgets"], outputs: ["widgetsChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
1073
+ __decorate([
1074
+ InputBoolean()
1075
+ ], DashboardComponent.prototype, "widgetsDraggable", void 0);
1076
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DashboardComponent, decorators: [{
1077
+ type: Component,
1078
+ args: [{ selector: 'seam-dashboard', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-dashboard-widgets [widgets]=\"widgets\" [widgetsDraggable]=\"widgetsDraggable\"></seam-dashboard-widgets>\n" }]
1079
+ }], propDecorators: { widgets: [{
1080
+ type: Input
1081
+ }], widgetsDraggable: [{
1082
+ type: Input
1083
+ }] } });
1084
+
1085
+ class TheSeamDashboardModule {
1086
+ }
1087
+ TheSeamDashboardModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDashboardModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1088
+ TheSeamDashboardModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDashboardModule, declarations: [DashboardComponent,
1089
+ DashboardWidgetsComponent,
1090
+ DashboardWidgetContainerComponent,
1091
+ DashboardWidgetTemplateContainerComponent,
1092
+ DashboardWidgetPortalOutletDirective], imports: [CommonModule,
1093
+ PortalModule,
1094
+ DragDropModule,
1095
+ TheSeamButtonsModule,
1096
+ TheSeamIconModule,
1097
+ TheSeamSharedModule], exports: [DashboardComponent,
1098
+ DashboardWidgetsComponent,
1099
+ DashboardWidgetPortalOutletDirective] });
1100
+ TheSeamDashboardModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDashboardModule, imports: [CommonModule,
1101
+ PortalModule,
1102
+ DragDropModule,
1103
+ TheSeamButtonsModule,
1104
+ TheSeamIconModule,
1105
+ TheSeamSharedModule] });
1106
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDashboardModule, decorators: [{
1107
+ type: NgModule,
1108
+ args: [{
1109
+ declarations: [
1110
+ DashboardComponent,
1111
+ DashboardWidgetsComponent,
1112
+ DashboardWidgetContainerComponent,
1113
+ DashboardWidgetTemplateContainerComponent,
1114
+ DashboardWidgetPortalOutletDirective
1115
+ ],
1116
+ imports: [
1117
+ CommonModule,
1118
+ PortalModule,
1119
+ DragDropModule,
1120
+ TheSeamButtonsModule,
1121
+ TheSeamIconModule,
1122
+ TheSeamSharedModule
1123
+ ],
1124
+ exports: [
1125
+ DashboardComponent,
1126
+ DashboardWidgetsComponent,
1127
+ DashboardWidgetPortalOutletDirective
1128
+ ]
1129
+ }]
1130
+ }] });
1131
+
1132
+ const THESEAM_SIDE_NAV_ACCESSOR = new InjectionToken('THESEAM_SIDE_NAV_ACCESSOR');
1133
+
1134
+ const EXPANDED_STATE$1 = 'expanded';
1135
+ const COLLAPSED_STATE$1 = 'collapsed';
1136
+ class SideNavItemComponent {
1137
+ set link(value) { this._link.next(value); }
1138
+ get link() { return this._link.value; }
1139
+ set expanded(value) { this._expanded.next(coerceBooleanProperty(value)); }
1140
+ get expanded() { return this._expanded.value; }
1141
+ set compact(value) { this._compact.next(coerceBooleanProperty(value)); }
1142
+ get compact() { return this._compact.value; }
1143
+ get badgeTooltip() { return this._badgeTooltip; }
1144
+ set badgeTooltip(value) {
1145
+ if (value !== null && value !== undefined) {
1146
+ if (typeof value === 'string') {
1147
+ this._badgeTooltip = {
1148
+ tooltip: value,
1149
+ placement: 'auto',
1150
+ disabled: false,
1151
+ container: 'body'
1152
+ };
1153
+ }
1154
+ else {
1155
+ this._badgeTooltip = Object.assign(Object.assign({}, value), { placement: value.placement || 'auto', disabled: typeof (value === null || value === void 0 ? void 0 : value.disabled) === 'boolean'
1156
+ ? value.disabled
1157
+ : typeof value.tooltip === 'string', container: value.container || 'body' });
1158
+ }
1159
+ }
1160
+ else {
1161
+ this._badgeTooltip = undefined;
1162
+ }
1163
+ }
1164
+ get _isActiveCssClass() { return this.active; }
1165
+ get _attrDataHierLevel() { return this.hierLevel; }
1166
+ constructor(_sideNav) {
1167
+ this._sideNav = _sideNav;
1168
+ this._ngUnsubscribe = new Subject();
1169
+ this.faAngleLeft = faAngleLeft;
1170
+ this.active = false;
1171
+ this._link = new BehaviorSubject(undefined);
1172
+ this.link$ = this._link.asObservable();
1173
+ this.hierLevel = 0;
1174
+ this.indentSize = 10;
1175
+ this._expanded = new BehaviorSubject(false);
1176
+ this.expanded$ = this._expanded.asObservable();
1177
+ this._compact = new BehaviorSubject(false);
1178
+ this.compact$ = this._compact.asObservable();
1179
+ this.badgeTheme = 'danger';
1180
+ this.childGroupAnimState$ = this.expanded$
1181
+ .pipe(map$1(expanded => expanded ? EXPANDED_STATE$1 : COLLAPSED_STATE$1));
1182
+ }
1183
+ ngOnDestroy() {
1184
+ this._ngUnsubscribe.next(undefined);
1185
+ this._ngUnsubscribe.complete();
1186
+ }
1187
+ get hasChildren() {
1188
+ return Array.isArray(this.children) && this.children.length > 0;
1189
+ }
1190
+ toggleChildren() {
1191
+ this.expanded = !this.expanded;
1192
+ }
1193
+ _linkClicked() {
1194
+ // Close nav when link is clicked while in overlay state
1195
+ if (this._sideNav.overlay) {
1196
+ this._sideNav.collapse();
1197
+ }
1198
+ }
1199
+ get showIconBlock() {
1200
+ return notNullOrUndefined(this.icon) || this.hideEmptyIcon !== true;
1201
+ }
1202
+ }
1203
+ SideNavItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SideNavItemComponent, deps: [{ token: THESEAM_SIDE_NAV_ACCESSOR }], target: i0.ɵɵFactoryTarget.Component });
1204
+ SideNavItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SideNavItemComponent, isStandalone: true, selector: "seam-side-nav-item", inputs: { itemType: "itemType", icon: "icon", hideEmptyIcon: "hideEmptyIcon", label: "label", active: "active", link: "link", queryParams: "queryParams", children: "children", hierLevel: "hierLevel", indentSize: "indentSize", expanded: "expanded", compact: "compact", badgeText: "badgeText", badgeTheme: "badgeTheme", badgeSrContent: "badgeSrContent", badgeTooltip: "badgeTooltip" }, host: { properties: { "class.seam-side-nav-item--active": "this._isActiveCssClass", "attr.data-hier-level": "this._attrDataHierLevel" } }, exportAs: ["seamSideNavItem"], ngImport: i0, template: "<div class=\"d-flex flex-row side-nav-item-wrapper\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasChildren\">\n <div class=\"side-nav--group side-nav--group--level-{{ hierLevel + 1 }}\"\n [@childGroupAnim]=\"childGroupAnimState$ | async\">\n <seam-side-nav-item *ngFor=\"let child of children\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state?.active\"\n [expanded]=\"$any(child).__state?.expanded\"\n [hideEmptyIcon]=\"hideEmptyIcon\"\n [indentSize]=\"indentSize\">\n </seam-side-nav-item>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"side-nav-item btn side-nav-btn p-0 d-flex flex-row align-items-stretch rounded-0 text-decoration-none text-nowrap w-100\"\n cdkMonitorElementFocus\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\">\n <div class=\"nav-link d-flex flex-row align-items-center w-100\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" side-nav-item-label style=\"margin-left: 11px;\">\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n\n <div *ngIf=\"hasChildren && !compact\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\">\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n </div>\n </button>\n</ng-template>\n\n<ng-template #itemTypeLink>\n <a *ngIf=\"link; else noLink\" class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\"\n [class.nav-link__compact]=\"compact\"\n [routerLink]=\"link\"\n [queryParams]=\"queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n (click)=\"_linkClicked()\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </a>\n\n <ng-template #noLink>\n <a class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n </a>\n </ng-template>\n\n <button *ngIf=\"hasChildren && !compact\"\n type=\"button\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\"\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\"\n cdkMonitorElementFocus>\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n <span class=\"sr-only\">Group Toggle</span>\n </button>\n</ng-template>\n\n<ng-template #itemTypeDivider>\n <div class=\"px-2 w-100\">\n <hr class=\"side-nav-item--divider\" />\n </div>\n</ng-template>\n\n<ng-template #itemTypeTitle>\n <ng-container *ngIf=\"!compact\">\n <span class=\"side-nav-item--title pt-1\" side-nav-item-label>{{ label }}</span>\n </ng-container>\n</ng-template>\n\n<ng-template #itemBadge>\n <ng-container *ngIf=\"badgeText\">\n <div class=\"badge-spacer flex-grow-1\" *ngIf=\"!compact\"></div>\n <div class=\"side-nav-item--badge\"\n [class.side-nav-item--badge-no-icon]=\"!icon\"\n [ngbTooltip]=\"$any(badgeTooltip)?.tooltip\"\n [tooltipClass]=\"$any(badgeTooltip)?.class\"\n [placement]=\"$any(badgeTooltip)?.placement\"\n [container]=\"$any(badgeTooltip)?.container\"\n [disableTooltip]=\"!badgeTooltip || !!$any(badgeTooltip)?.disabled\">\n <span class=\"badge badge-pill badge-{{ badgeTheme }}\">\n <ng-container *ngIf=\"!compact || !icon\">\n {{ badgeText }}\n </ng-container>\n <span *ngIf=\"badgeSrContent\">{{ badgeSrContent }}</span>\n </span>\n </div>\n </ng-container>\n</ng-template>\n", styles: ["seam-side-nav-item{display:block;transition:.25s ease-in-out background-color}seam-side-nav-item.seam-side-nav-item--active{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .active,seam-side-nav-item.seam-side-nav-item--active:active,seam-side-nav-item.seam-side-nav-item--active .side-nav-item.active:hover{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item.seam-side-nav-item--active .nav-link{color:#fff}seam-side-nav-item.seam-side-nav-item--active .side-nav-btn{color:#fff}seam-side-nav-item .badge{vertical-align:middle}seam-side-nav-item:not(.side-nav-item--icon) .side-nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-side-nav-item .side-nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge{top:-4px;right:-4px;position:absolute}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge.side-nav-item--badge-no-icon{top:0;right:0}seam-side-nav-item .side-nav-item{min-height:45px;transition:.25s ease-in-out background-color}seam-side-nav-item .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item.active{pointer-events:none;cursor:default}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]){color:#ccc}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-side-nav-item .nav-link{color:#fff;padding-right:2px}seam-side-nav-item .nav-link__compact{padding-right:0;padding-left:12px}seam-side-nav-item .nav-link:last-child{padding-right:8px}seam-side-nav-item .side-nav-btn{font-weight:400;color:#fff;text-decoration:none}seam-side-nav-item .side-nav-btn:hover{color:#fff;text-decoration:underline}seam-side-nav-item .side-nav-btn:focus,seam-side-nav-item .side-nav-btn.focus{text-decoration:underline;box-shadow:none}seam-side-nav-item .side-nav-btn:disabled,seam-side-nav-item .side-nav-btn.disabled{color:#ccc;pointer-events:none}seam-side-nav-item .cdk-keyboard-focused{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}seam-side-nav-item .side-nav-item--toggle-btn-container{transition:.25s ease-in-out background-color;padding:.5rem 1rem}seam-side-nav-item button.side-nav-item--toggle-btn-container:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item--toggle-btn .svg-inline--fa{transition:.1s ease-in-out transform}seam-side-nav-item .side-nav-item--toggle-btn.side-nav-item--toggle-btn-expanded .svg-inline--fa{transform:rotate(-90deg)}seam-side-nav-item .side-nav--group{will-change:height;overflow:hidden}seam-side-nav-item .side-nav--group--level-1{background-color:#3276b1}seam-side-nav-item .side-nav--group--level-2{background-color:#2e6ea5}seam-side-nav-item .side-nav--group--level-3{background-color:#2b6699}seam-side-nav-item .side-nav--group--level-4{background-color:#285e8d}seam-side-nav-item .side-nav--group--level-5{background-color:#245681}seam-side-nav-item .side-nav--group--level-6{background-color:#214e75}seam-side-nav-item .side-nav--group--level-7{background-color:#1e4669}seam-side-nav-item .side-nav--group--level-8{background-color:#1a3e5d}seam-side-nav-item .side-nav--group--level-9{background-color:#173651}seam-side-nav-item .side-nav-item--divider{display:block;border-top:1px solid #2a6395;width:100%}seam-side-nav-item .side-nav-item--title{color:#fff;font-size:24px;padding-left:10px}seam-side-nav-item .sr-only{top:0;left:0}\n"], dependencies: [{ kind: "component", type: SideNavItemComponent, selector: "seam-side-nav-item", inputs: ["itemType", "icon", "hideEmptyIcon", "label", "active", "link", "queryParams", "children", "hierLevel", "indentSize", "expanded", "compact", "badgeText", "badgeTheme", "badgeSrContent", "badgeTooltip"], exportAs: ["seamSideNavItem"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i1$2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i1$2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "ngmodule", type: TheSeamIconModule }, { kind: "component", type: i2$1.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "ngmodule", type: A11yModule }, { kind: "directive", type: i4$2.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"], exportAs: ["cdkMonitorFocus"] }, { kind: "ngmodule", type: NgbTooltipModule }, { kind: "directive", type: i5.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }], animations: [
1205
+ trigger('childGroupAnim', [
1206
+ state(EXPANDED_STATE$1, style({ height: '*' })),
1207
+ state(COLLAPSED_STATE$1, style({ height: 0, visibility: 'hidden' })),
1208
+ transition(`${EXPANDED_STATE$1} <=> ${COLLAPSED_STATE$1}`, animate('0.2s ease-in-out')),
1209
+ ]),
1210
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1211
+ __decorate([
1212
+ InputBoolean()
1213
+ ], SideNavItemComponent.prototype, "active", void 0);
1214
+ __decorate([
1215
+ InputNumber(0)
1216
+ ], SideNavItemComponent.prototype, "hierLevel", void 0);
1217
+ __decorate([
1218
+ InputNumber(10)
1219
+ ], SideNavItemComponent.prototype, "indentSize", void 0);
1220
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SideNavItemComponent, decorators: [{
1221
+ type: Component,
1222
+ args: [{ selector: 'seam-side-nav-item', exportAs: 'seamSideNavItem', animations: [
1223
+ trigger('childGroupAnim', [
1224
+ state(EXPANDED_STATE$1, style({ height: '*' })),
1225
+ state(COLLAPSED_STATE$1, style({ height: 0, visibility: 'hidden' })),
1226
+ transition(`${EXPANDED_STATE$1} <=> ${COLLAPSED_STATE$1}`, animate('0.2s ease-in-out')),
1227
+ ]),
1228
+ ], imports: [
1229
+ CommonModule,
1230
+ RouterModule,
1231
+ TheSeamIconModule,
1232
+ A11yModule,
1233
+ NgbTooltipModule,
1234
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, template: "<div class=\"d-flex flex-row side-nav-item-wrapper\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasChildren\">\n <div class=\"side-nav--group side-nav--group--level-{{ hierLevel + 1 }}\"\n [@childGroupAnim]=\"childGroupAnimState$ | async\">\n <seam-side-nav-item *ngFor=\"let child of children\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state?.active\"\n [expanded]=\"$any(child).__state?.expanded\"\n [hideEmptyIcon]=\"hideEmptyIcon\"\n [indentSize]=\"indentSize\">\n </seam-side-nav-item>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"side-nav-item btn side-nav-btn p-0 d-flex flex-row align-items-stretch rounded-0 text-decoration-none text-nowrap w-100\"\n cdkMonitorElementFocus\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\">\n <div class=\"nav-link d-flex flex-row align-items-center w-100\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" side-nav-item-label style=\"margin-left: 11px;\">\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n\n <div *ngIf=\"hasChildren && !compact\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\">\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n </div>\n </button>\n</ng-template>\n\n<ng-template #itemTypeLink>\n <a *ngIf=\"link; else noLink\" class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\"\n [class.nav-link__compact]=\"compact\"\n [routerLink]=\"link\"\n [queryParams]=\"queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n (click)=\"_linkClicked()\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </a>\n\n <ng-template #noLink>\n <a class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n </a>\n </ng-template>\n\n <button *ngIf=\"hasChildren && !compact\"\n type=\"button\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\"\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\"\n cdkMonitorElementFocus>\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n <span class=\"sr-only\">Group Toggle</span>\n </button>\n</ng-template>\n\n<ng-template #itemTypeDivider>\n <div class=\"px-2 w-100\">\n <hr class=\"side-nav-item--divider\" />\n </div>\n</ng-template>\n\n<ng-template #itemTypeTitle>\n <ng-container *ngIf=\"!compact\">\n <span class=\"side-nav-item--title pt-1\" side-nav-item-label>{{ label }}</span>\n </ng-container>\n</ng-template>\n\n<ng-template #itemBadge>\n <ng-container *ngIf=\"badgeText\">\n <div class=\"badge-spacer flex-grow-1\" *ngIf=\"!compact\"></div>\n <div class=\"side-nav-item--badge\"\n [class.side-nav-item--badge-no-icon]=\"!icon\"\n [ngbTooltip]=\"$any(badgeTooltip)?.tooltip\"\n [tooltipClass]=\"$any(badgeTooltip)?.class\"\n [placement]=\"$any(badgeTooltip)?.placement\"\n [container]=\"$any(badgeTooltip)?.container\"\n [disableTooltip]=\"!badgeTooltip || !!$any(badgeTooltip)?.disabled\">\n <span class=\"badge badge-pill badge-{{ badgeTheme }}\">\n <ng-container *ngIf=\"!compact || !icon\">\n {{ badgeText }}\n </ng-container>\n <span *ngIf=\"badgeSrContent\">{{ badgeSrContent }}</span>\n </span>\n </div>\n </ng-container>\n</ng-template>\n", styles: ["seam-side-nav-item{display:block;transition:.25s ease-in-out background-color}seam-side-nav-item.seam-side-nav-item--active{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .active,seam-side-nav-item.seam-side-nav-item--active:active,seam-side-nav-item.seam-side-nav-item--active .side-nav-item.active:hover{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item.seam-side-nav-item--active .nav-link{color:#fff}seam-side-nav-item.seam-side-nav-item--active .side-nav-btn{color:#fff}seam-side-nav-item .badge{vertical-align:middle}seam-side-nav-item:not(.side-nav-item--icon) .side-nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-side-nav-item .side-nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge{top:-4px;right:-4px;position:absolute}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge.side-nav-item--badge-no-icon{top:0;right:0}seam-side-nav-item .side-nav-item{min-height:45px;transition:.25s ease-in-out background-color}seam-side-nav-item .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item.active{pointer-events:none;cursor:default}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]){color:#ccc}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-side-nav-item .nav-link{color:#fff;padding-right:2px}seam-side-nav-item .nav-link__compact{padding-right:0;padding-left:12px}seam-side-nav-item .nav-link:last-child{padding-right:8px}seam-side-nav-item .side-nav-btn{font-weight:400;color:#fff;text-decoration:none}seam-side-nav-item .side-nav-btn:hover{color:#fff;text-decoration:underline}seam-side-nav-item .side-nav-btn:focus,seam-side-nav-item .side-nav-btn.focus{text-decoration:underline;box-shadow:none}seam-side-nav-item .side-nav-btn:disabled,seam-side-nav-item .side-nav-btn.disabled{color:#ccc;pointer-events:none}seam-side-nav-item .cdk-keyboard-focused{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}seam-side-nav-item .side-nav-item--toggle-btn-container{transition:.25s ease-in-out background-color;padding:.5rem 1rem}seam-side-nav-item button.side-nav-item--toggle-btn-container:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item--toggle-btn .svg-inline--fa{transition:.1s ease-in-out transform}seam-side-nav-item .side-nav-item--toggle-btn.side-nav-item--toggle-btn-expanded .svg-inline--fa{transform:rotate(-90deg)}seam-side-nav-item .side-nav--group{will-change:height;overflow:hidden}seam-side-nav-item .side-nav--group--level-1{background-color:#3276b1}seam-side-nav-item .side-nav--group--level-2{background-color:#2e6ea5}seam-side-nav-item .side-nav--group--level-3{background-color:#2b6699}seam-side-nav-item .side-nav--group--level-4{background-color:#285e8d}seam-side-nav-item .side-nav--group--level-5{background-color:#245681}seam-side-nav-item .side-nav--group--level-6{background-color:#214e75}seam-side-nav-item .side-nav--group--level-7{background-color:#1e4669}seam-side-nav-item .side-nav--group--level-8{background-color:#1a3e5d}seam-side-nav-item .side-nav--group--level-9{background-color:#173651}seam-side-nav-item .side-nav-item--divider{display:block;border-top:1px solid #2a6395;width:100%}seam-side-nav-item .side-nav-item--title{color:#fff;font-size:24px;padding-left:10px}seam-side-nav-item .sr-only{top:0;left:0}\n"] }]
1235
+ }], ctorParameters: function () {
1236
+ return [{ type: undefined, decorators: [{
1237
+ type: Inject,
1238
+ args: [THESEAM_SIDE_NAV_ACCESSOR]
1239
+ }] }];
1240
+ }, propDecorators: { itemType: [{
1241
+ type: Input
1242
+ }], icon: [{
1243
+ type: Input
1244
+ }], hideEmptyIcon: [{
1245
+ type: Input
1246
+ }], label: [{
1247
+ type: Input
1248
+ }], active: [{
1249
+ type: Input
1250
+ }], link: [{
1251
+ type: Input
1252
+ }], queryParams: [{
1253
+ type: Input
1254
+ }], children: [{
1255
+ type: Input
1256
+ }], hierLevel: [{
1257
+ type: Input
1258
+ }], indentSize: [{
1259
+ type: Input
1260
+ }], expanded: [{
1261
+ type: Input
1262
+ }], compact: [{
1263
+ type: Input
1264
+ }], badgeText: [{
1265
+ type: Input
1266
+ }], badgeTheme: [{
1267
+ type: Input
1268
+ }], badgeSrContent: [{
1269
+ type: Input
1270
+ }], badgeTooltip: [{
1271
+ type: Input
1272
+ }], _isActiveCssClass: [{
1273
+ type: HostBinding,
1274
+ args: ['class.seam-side-nav-item--active']
1275
+ }], _attrDataHierLevel: [{
1276
+ type: HostBinding,
1277
+ args: ['attr.data-hier-level']
1278
+ }] } });
1279
+
1280
+ class SideNavToggleComponent {
1281
+ constructor() {
1282
+ this.expanded = false;
1283
+ this.toggleExpand = new EventEmitter();
1284
+ }
1285
+ toggle() {
1286
+ this.toggleExpand.emit();
1287
+ }
1288
+ }
1289
+ SideNavToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SideNavToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1290
+ SideNavToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SideNavToggleComponent, isStandalone: true, selector: "seam-side-nav-toggle", inputs: { expanded: "expanded", toggleIcon: "toggleIcon", toggleTpl: "toggleTpl" }, outputs: { toggleExpand: "toggleExpand" }, host: { properties: { "class.side-nav-toggle--compact": "!expanded" } }, ngImport: i0, template: "<div class=\"side-nav-toggle--content\">\n <ng-container *ngIf=\"expanded\">\n <ng-content></ng-content>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"toggleTpl; else iconBtn\">\n <button\n class=\"side-nav-toggle--btn mx-1\"\n (click)=\"toggle()\">\n <span class=\"sr-only\">Toggle sidebar</span>\n <ng-container *ngTemplateOutlet=\"toggleTpl\"></ng-container>\n </button>\n</ng-container>\n\n<ng-template #iconBtn>\n <button seamIconBtn [icon]=\"toggleIcon\"\n iconType=\"borderless-styled-square\"\n btnSize=\"sm\"\n class=\"side-nav-toggle--btn mx-1\"\n (click)=\"toggle()\">\n <span class=\"sr-only\">Toggle sidebar</span>\n </button>\n</ng-template>\n", styles: ["seam-side-nav-toggle{display:flex;flex-direction:row;flex-shrink:0;align-items:center;background:#357ebd;position:relative;height:45px;width:100%}seam-side-nav-toggle .side-nav-toggle--content{flex:1 1 0}seam-side-nav-toggle .side-nav-toggle--btn{color:#fff}seam-side-nav-toggle .side-nav-toggle--btn seam-icon{padding:5px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: TheSeamIconModule }, { kind: "component", type: i2$1.IconBtnComponent, selector: "button[seamIconBtn]", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "iconType", "btnTheme", "badgeTheme", "badgeText", "btnSize", "type", "role"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1291
+ __decorate([
1292
+ InputBoolean()
1293
+ ], SideNavToggleComponent.prototype, "expanded", void 0);
1294
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SideNavToggleComponent, decorators: [{
1295
+ type: Component,
1296
+ args: [{ selector: 'seam-side-nav-toggle', host: {
1297
+ '[class.side-nav-toggle--compact]': '!expanded'
1298
+ }, imports: [
1299
+ CommonModule,
1300
+ TheSeamIconModule,
1301
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, template: "<div class=\"side-nav-toggle--content\">\n <ng-container *ngIf=\"expanded\">\n <ng-content></ng-content>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"toggleTpl; else iconBtn\">\n <button\n class=\"side-nav-toggle--btn mx-1\"\n (click)=\"toggle()\">\n <span class=\"sr-only\">Toggle sidebar</span>\n <ng-container *ngTemplateOutlet=\"toggleTpl\"></ng-container>\n </button>\n</ng-container>\n\n<ng-template #iconBtn>\n <button seamIconBtn [icon]=\"toggleIcon\"\n iconType=\"borderless-styled-square\"\n btnSize=\"sm\"\n class=\"side-nav-toggle--btn mx-1\"\n (click)=\"toggle()\">\n <span class=\"sr-only\">Toggle sidebar</span>\n </button>\n</ng-template>\n", styles: ["seam-side-nav-toggle{display:flex;flex-direction:row;flex-shrink:0;align-items:center;background:#357ebd;position:relative;height:45px;width:100%}seam-side-nav-toggle .side-nav-toggle--content{flex:1 1 0}seam-side-nav-toggle .side-nav-toggle--btn{color:#fff}seam-side-nav-toggle .side-nav-toggle--btn seam-icon{padding:5px}\n"] }]
1302
+ }], propDecorators: { expanded: [{
1303
+ type: Input
1304
+ }], toggleIcon: [{
1305
+ type: Input
1306
+ }], toggleTpl: [{
1307
+ type: Input
1308
+ }], toggleExpand: [{
1309
+ type: Output
1310
+ }] } });
1311
+
1312
+ // eslint-disable-next-line no-redeclare
1313
+ function isNavItemType(item, type) {
1314
+ return item.itemType === type;
1315
+ }
1316
+ function isNavItemActive(item) {
1317
+ var _a, _b;
1318
+ return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.active) !== null && _b !== void 0 ? _b : false;
1319
+ }
1320
+ function isExpanded(item) {
1321
+ var _a, _b;
1322
+ return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.expanded) !== null && _b !== void 0 ? _b : false;
1323
+ }
1324
+ function hasChildren(item) {
1325
+ return canHaveChildren(item) && hasProperty(item, 'children') && item.children.length > 0;
1326
+ }
1327
+ function canHaveChildren(item) {
1328
+ return isNavItemType(item, 'basic') || isNavItemType(item, 'link');
1329
+ }
1330
+ function hasActiveChild(item) {
1331
+ if (!hasChildren(item)) {
1332
+ return false;
1333
+ }
1334
+ for (const child of item.children) {
1335
+ if (getItemStateProp(child, 'active')) {
1336
+ return true;
1337
+ }
1338
+ }
1339
+ return false;
1340
+ }
1341
+ function hasExpandedChild(item) {
1342
+ if (!hasChildren(item)) {
1343
+ return false;
1344
+ }
1345
+ for (const child of item.children) {
1346
+ if (getItemStateProp(child, 'expanded')) {
1347
+ return true;
1348
+ }
1349
+ }
1350
+ return false;
1351
+ }
1352
+ function canBeActive(item) {
1353
+ return isNavItemType(item, 'basic') || isNavItemType(item, 'link');
1354
+ }
1355
+ function canExpand(item) {
1356
+ return canHaveChildren(item);
1357
+ }
1358
+ function findLinkItems(items) {
1359
+ const linkItems = [];
1360
+ const _fn = (_items) => {
1361
+ for (const item of _items) {
1362
+ if (isNavItemType(item, 'link')) {
1363
+ linkItems.push(item);
1364
+ }
1365
+ if (canHaveChildren(item) && hasProperty(item, 'children')) {
1366
+ _fn(item.children);
1367
+ }
1368
+ }
1369
+ };
1370
+ _fn(items);
1371
+ return linkItems;
1372
+ }
1373
+ function setItemStateProp(item, prop, value) {
1374
+ if (hasProperty(item, '__state')) {
1375
+ item.__state[prop] = value;
1376
+ }
1377
+ }
1378
+ function getItemStateProp(item, prop) {
1379
+ return setDefaultState(item).__state[prop];
1380
+ }
1381
+ function setDefaultState(item) {
1382
+ if (hasProperty(item, '__state')) {
1383
+ return item;
1384
+ }
1385
+ item.__state = {
1386
+ active: false,
1387
+ expanded: false
1388
+ };
1389
+ // TODO: See if there is a nice way to fix the typing for this.
1390
+ return item;
1391
+ }
1392
+
1393
+ class TheSeamSideNavService {
1394
+ constructor(_router) {
1395
+ this._router = _router;
1396
+ this._updatingCount = new BehaviorSubject(0);
1397
+ this.itemChanged = new Subject();
1398
+ this.loading$ = this._updatingCount.pipe(map(count => count > 0), distinctUntilChanged(), shareReplay({ bufferSize: 1, refCount: true }));
1399
+ }
1400
+ createItemsObservable(items) {
1401
+ return defer(() => {
1402
+ this.updateItemsStates(items);
1403
+ return new Observable((subscriber) => {
1404
+ const stateChangeSub = this.itemChanged.pipe(switchMap(() => this.loading$.pipe(filter(loading => !loading)))).subscribe(() => {
1405
+ subscriber.next(items);
1406
+ });
1407
+ try {
1408
+ this.updateItemsStates(items);
1409
+ }
1410
+ catch (err) {
1411
+ subscriber.error(err);
1412
+ }
1413
+ // const linkItems = findLinkItems(items)
1414
+ const routeChangeSub = this._router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(() => {
1415
+ try {
1416
+ this.updateItemsStates(items);
1417
+ }
1418
+ catch (err) {
1419
+ subscriber.error(err);
1420
+ }
1421
+ });
1422
+ return () => {
1423
+ stateChangeSub.unsubscribe();
1424
+ routeChangeSub.unsubscribe();
1425
+ };
1426
+ }).pipe(startWith(items));
1427
+ });
1428
+ }
1429
+ _incUpdatingCount() {
1430
+ this._updatingCount.next(this._updatingCount.value + 1);
1431
+ }
1432
+ _decrUpdatingCount() {
1433
+ this._updatingCount.next(this._updatingCount.value - 1);
1434
+ }
1435
+ updateItemsStates(items) {
1436
+ this._incUpdatingCount();
1437
+ try {
1438
+ for (const item of items) {
1439
+ if (hasChildren(item)) {
1440
+ this.updateItemsStates(item.children);
1441
+ }
1442
+ this.updateItemState(item);
1443
+ }
1444
+ this._decrUpdatingCount();
1445
+ }
1446
+ catch (err) {
1447
+ this._decrUpdatingCount();
1448
+ throw err;
1449
+ }
1450
+ }
1451
+ updateItemState(item) {
1452
+ this._incUpdatingCount();
1453
+ try {
1454
+ setDefaultState(item);
1455
+ if (isNavItemType(item, 'link')) {
1456
+ const url = this._getUrl(item);
1457
+ if (notNullOrUndefined(url)) {
1458
+ const opts = this._getMatchOptions(item);
1459
+ this.setItemStateProp(item, 'active', this._router.isActive(url, opts));
1460
+ }
1461
+ }
1462
+ // TODO: Implement this in a more optimized way. Unless our apps start
1463
+ // having large side-navs constantly updating their state, this shouldn't
1464
+ // have much impact on performance.
1465
+ this._updateItemExpandedState(item);
1466
+ this._decrUpdatingCount();
1467
+ }
1468
+ catch (err) {
1469
+ this._decrUpdatingCount();
1470
+ throw err;
1471
+ }
1472
+ }
1473
+ _updateItemsExpandedState(items) {
1474
+ for (const item of items) {
1475
+ if (hasChildren(item)) {
1476
+ this._updateItemsExpandedState(item.children);
1477
+ }
1478
+ this._updateItemExpandedState(item);
1479
+ }
1480
+ }
1481
+ _updateItemExpandedState(item) {
1482
+ if (!canExpand(item)) {
1483
+ if (getItemStateProp(item, 'expanded')) {
1484
+ this.setItemStateProp(item, 'expanded', false);
1485
+ }
1486
+ return;
1487
+ }
1488
+ if (hasChildren(item)) {
1489
+ this._updateItemsExpandedState(item.children);
1490
+ }
1491
+ if (hasActiveChild(item) || hasExpandedChild(item)) {
1492
+ if (!getItemStateProp(item, 'expanded')) {
1493
+ this.setItemStateProp(item, 'expanded', true);
1494
+ }
1495
+ }
1496
+ else {
1497
+ if (getItemStateProp(item, 'expanded')) {
1498
+ this.setItemStateProp(item, 'expanded', false);
1499
+ }
1500
+ }
1501
+ }
1502
+ _getNavExtras(item) {
1503
+ const navigationExtras = {};
1504
+ if (hasProperty(item, 'queryParams')) {
1505
+ navigationExtras.queryParams = item.queryParams;
1506
+ }
1507
+ if (hasProperty(item, 'fragment')) {
1508
+ navigationExtras.fragment = item.fragment;
1509
+ }
1510
+ if (hasProperty(item, 'queryParamsHandling')) {
1511
+ navigationExtras.queryParamsHandling = item.queryParamsHandling;
1512
+ }
1513
+ if (hasProperty(item, 'preserveFragment')) {
1514
+ navigationExtras.preserveFragment = item.preserveFragment;
1515
+ }
1516
+ return navigationExtras;
1517
+ }
1518
+ _getUrl(item) {
1519
+ const link = item.link;
1520
+ if (typeof link === 'string') {
1521
+ return this._router.createUrlTree([link], this._getNavExtras(item)).toString();
1522
+ }
1523
+ else if (Array.isArray(link)) {
1524
+ return this._router.createUrlTree(link, this._getNavExtras(item)).toString();
1525
+ }
1526
+ return null;
1527
+ }
1528
+ _getMatchOptions(item) {
1529
+ const defaultMatchOpts = {
1530
+ paths: 'subset',
1531
+ queryParams: 'subset',
1532
+ fragment: 'ignored',
1533
+ matrixParams: 'ignored'
1534
+ };
1535
+ if (hasProperty(item, 'matchOptions')) {
1536
+ return Object.assign(Object.assign({}, defaultMatchOpts), item.matchOptions);
1537
+ }
1538
+ return defaultMatchOpts;
1539
+ }
1540
+ setItemStateProp(item, prop, value) {
1541
+ const currentValue = getItemStateProp(item, prop);
1542
+ if (currentValue !== value) {
1543
+ setItemStateProp(item, prop, value);
1544
+ const changed = {
1545
+ item,
1546
+ prop,
1547
+ prevValue: currentValue,
1548
+ newValue: value
1549
+ };
1550
+ this.itemChanged.next(changed);
1551
+ }
1552
+ }
1553
+ }
1554
+ TheSeamSideNavService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavService, deps: [{ token: i1$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
1555
+ TheSeamSideNavService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavService });
1556
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavService, decorators: [{
1557
+ type: Injectable
1558
+ }], ctorParameters: function () { return [{ type: i1$2.Router }]; } });
1559
+
1560
+ const EXPANDED_STATE = 'expanded';
1561
+ const COLLAPSED_STATE = 'collapsed';
1562
+ const EXPANDED_OVERLAY_STATE = 'expanded-overlay';
1563
+ const COLLAPSED_OVERLAY_STATE = 'collapsed-overlay';
1564
+ const EXPANDED_STATES = [EXPANDED_STATE, EXPANDED_OVERLAY_STATE];
1565
+ const COLLAPSED_STATES = [COLLAPSED_STATE, COLLAPSED_OVERLAY_STATE];
1566
+ const EXPAND_STATES = [...EXPANDED_STATES, ...COLLAPSED_STATES];
1567
+ function sideNavExpandStateChangeFn(fromState, toState) {
1568
+ // console.log({ fromState, toState })
1569
+ return fromState !== toState &&
1570
+ (
1571
+ // NOTE: The current way the side nav is being used it causes the
1572
+ // component to sometimes get placed in the wrong location initially. It
1573
+ // is fast enough to not be noticed without an initial animation usually,
1574
+ // so it is commented out below until the initial placement issue it
1575
+ // fixed.
1576
+ //
1577
+ // (
1578
+ // fromState === 'void' && EXPAND_STATES.indexOf(toState) !== -1
1579
+ // ||
1580
+ // toState === 'void' && EXPAND_STATES.indexOf(fromState) !== -1
1581
+ // )
1582
+ // ||
1583
+ ((EXPANDED_STATES.indexOf(fromState) !== -1 && COLLAPSED_STATES.indexOf(toState) !== -1) ||
1584
+ (EXPANDED_STATES.indexOf(toState) !== -1 && COLLAPSED_STATES.indexOf(fromState) !== -1)));
1585
+ }
1586
+ class SideNavComponent {
1587
+ get items() { return this._items.value; }
1588
+ set items(value) { this._items.next(value); }
1589
+ get expanded() { return this._expanded.value; }
1590
+ set expanded(value) {
1591
+ const expanded = coerceBooleanProperty(value);
1592
+ const emit = expanded !== this.expanded;
1593
+ this._expanded.next(expanded);
1594
+ if (emit) {
1595
+ this.toggleExpand.emit(coerceBooleanProperty(value));
1596
+ }
1597
+ }
1598
+ get overlay() { return this._overlay.value; }
1599
+ set overlay(value) { this._overlay.next(coerceBooleanProperty(value)); }
1600
+ constructor(_viewContainerRef, _layout, _sideNav, _baseLayoutRef) {
1601
+ this._viewContainerRef = _viewContainerRef;
1602
+ this._layout = _layout;
1603
+ this._sideNav = _sideNav;
1604
+ this._baseLayoutRef = _baseLayoutRef;
1605
+ this._ngUnsubscribe = new Subject();
1606
+ this.faBars = faBars;
1607
+ // @HostBinding('@sideNavExpand') _sideNavExpand = EXPANDED_STATE
1608
+ // _sideNavExpand = EXPANDED_STATE
1609
+ // @HostBinding('@sideNavAnim') _sideNavExpand = EXPANDED_STATE
1610
+ this._sideNavExpand = 'initial';
1611
+ this.hasHeaderToggle = true;
1612
+ this.toggleIcon = faBars;
1613
+ this._items = new BehaviorSubject([]);
1614
+ this.indentSize = 10;
1615
+ this._expanded = new BehaviorSubject(true);
1616
+ this.expanded$ = this._expanded.asObservable();
1617
+ this.expandOrigin = 'left';
1618
+ this.expandHeight = '100%';
1619
+ this.expandWidth = 'calc(100vw - 50px)';
1620
+ this._overlay = new BehaviorSubject(false);
1621
+ this.overlay$ = this._overlay.asObservable();
1622
+ this.toggleExpand = new EventEmitter();
1623
+ this._backdropHidden = new BehaviorSubject(true);
1624
+ this.items$ = this._items.asObservable().pipe(switchMap(items => items ? this._sideNav.createItemsObservable(items) : []), shareReplay({ bufferSize: 1, refCount: true }));
1625
+ this.isMobile$ = this._layout.isMobile$.pipe(tap(isMobile => isMobile ? this.collapse() : this.expand()));
1626
+ this.sideNavExpandedState$ = combineLatest([this.expanded$, this.overlay$]).pipe(map(([expanded, overlay]) => expanded
1627
+ ? overlay ? EXPANDED_OVERLAY_STATE : EXPANDED_STATE
1628
+ : overlay ? COLLAPSED_OVERLAY_STATE : COLLAPSED_STATE), distinctUntilChanged());
1629
+ }
1630
+ ngOnInit() {
1631
+ if (this._baseLayoutRef) {
1632
+ this._baseLayoutRef.registerNav(this);
1633
+ }
1634
+ this.isMobile$
1635
+ .pipe(takeUntil(this._ngUnsubscribe))
1636
+ .subscribe(b => this.overlay = b);
1637
+ this.sideNavExpandedState$
1638
+ .pipe(takeUntil(this._ngUnsubscribe))
1639
+ .subscribe(v => this._sideNavExpand = v);
1640
+ if (this._sideBarHeaderTpl) {
1641
+ this._sideBarHeaderPortal = new TemplatePortal(this._sideBarHeaderTpl, this._viewContainerRef);
1642
+ }
1643
+ if (this._sideBarFooterTpl) {
1644
+ this._sideBarFooterPortal = new TemplatePortal(this._sideBarFooterTpl, this._viewContainerRef);
1645
+ }
1646
+ }
1647
+ ngOnDestroy() {
1648
+ this._ngUnsubscribe.next(undefined);
1649
+ this._ngUnsubscribe.complete();
1650
+ if (this._baseLayoutRef) {
1651
+ this._baseLayoutRef.unregisterNav(this);
1652
+ }
1653
+ }
1654
+ expand() {
1655
+ this.expanded = true;
1656
+ }
1657
+ collapse() {
1658
+ this.expanded = false;
1659
+ }
1660
+ toggle() {
1661
+ this.expanded = !this.expanded;
1662
+ }
1663
+ animateStart() {
1664
+ if (this.expanded) {
1665
+ this._backdropHidden.next(false);
1666
+ }
1667
+ }
1668
+ animateEnd() {
1669
+ if (!this.expanded) {
1670
+ this._backdropHidden.next(true);
1671
+ }
1672
+ }
1673
+ get expandOriginTransform() {
1674
+ switch (this.expandOrigin) {
1675
+ case 'right':
1676
+ return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateX(100vw) translateX(-100%)'
1677
+ : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateX(100vw)' : null;
1678
+ case 'top':
1679
+ return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateY(0)'
1680
+ : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateY(-100%)' : null;
1681
+ case 'bottom':
1682
+ return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateY(100vh) translateY(-100%)'
1683
+ : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateY(100vh)' : null;
1684
+ case 'left':
1685
+ default:
1686
+ return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateX(0)'
1687
+ : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateX(-100%)' : null;
1688
+ }
1689
+ }
1690
+ }
1691
+ SideNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SideNavComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TheSeamLayoutService }, { token: TheSeamSideNavService }, { token: THESEAM_BASE_LAYOUT_REF, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1692
+ SideNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SideNavComponent, isStandalone: true, selector: "seam-side-nav", inputs: { hasHeaderToggle: "hasHeaderToggle", toggleIcon: "toggleIcon", toggleTpl: "toggleTpl", items: "items", hideEmptyIcon: "hideEmptyIcon", indentSize: "indentSize", expanded: "expanded", expandOrigin: "expandOrigin", expandHeight: "expandHeight", expandWidth: "expandWidth", overlay: "overlay" }, outputs: { toggleExpand: "toggleExpand" }, host: { properties: { "@sideNavAnim": "this._sideNavExpand" } }, providers: [
1693
+ TheSeamSideNavService,
1694
+ {
1695
+ provide: THESEAM_SIDE_NAV_ACCESSOR,
1696
+ useExisting: SideNavComponent
1697
+ },
1698
+ ], queries: [{ propertyName: "_sideBarHeaderTpl", first: true, predicate: BaseLayoutSideBarHeaderDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "_sideBarFooterTpl", first: true, predicate: BaseLayoutSideBarFooterDirective, descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"side-nav-backdrop\" *ngIf=\"isMobile$ | async\"\n [@sideNavBackdrop]=\"_sideNavExpand\"\n [class.side-nav-backdrop-hidden]=\"_backdropHidden | async\"\n (click)=\"collapse()\"></div>\n\n<div\n class=\"side-nav-inner-wrapper\"\n [@sideNavExpand]=\"{\n value: _sideNavExpand,\n params: {\n origin: expandOriginTransform,\n height: expandHeight,\n width: expandWidth\n }\n }\"\n (@sideNavExpand.start)=\"animateStart()\"\n (@sideNavExpand.done)=\"animateEnd()\">\n <nav class=\"nav side-nav-content\">\n <seam-side-nav-toggle *ngIf=\"hasHeaderToggle\"\n [toggleIcon]=\"toggleIcon\"\n [toggleTpl]=\"toggleTpl\"\n [expanded]=\"expanded$ | async\"\n (toggleExpand)=\"toggle()\">\n <ng-template [cdkPortalOutlet]=\"_sideBarHeaderPortal\"></ng-template>\n </seam-side-nav-toggle>\n <div class=\"side-nav-items-container\" seamOverlayScrollbar>\n <div class=\"side-nav--group side-nav--group--level-0\">\n <seam-side-nav-item *ngFor=\"let item of items$ | async\"\n [compact]=\"!(expanded$ | async)\"\n [itemType]=\"$any(item)?.itemType\"\n [icon]=\"$any(item)?.icon\"\n [label]=\"$any(item)?.label\"\n [link]=\"$any(item)?.link\"\n [badgeText]=\"$any(item)?.badge?.text\"\n [badgeTheme]=\"$any(item)?.badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(item)?.badge?.srContent\"\n [badgeTooltip]=\"$any(item)?.badge?.tooltip\"\n [queryParams]=\"$any(item)?.queryParams\"\n [children]=\"$any(item)?.children\"\n [active]=\"$any(item).__state?.active\"\n [expanded]=\"$any(item).__state?.expanded\"\n [hideEmptyIcon]=\"hideEmptyIcon\"\n [indentSize]=\"indentSize\">\n </seam-side-nav-item>\n </div>\n </div>\n <ng-template [cdkPortalOutlet]=\"_sideBarFooterPortal\"></ng-template>\n </nav>\n</div>\n", styles: ["seam-side-nav,.seam-side-nav{display:block;height:100%;position:relative;z-index:2;overflow:hidden}seam-side-nav .side-nav-inner-wrapper,.seam-side-nav .side-nav-inner-wrapper{background:#357ebd;height:100%}seam-side-nav .side-nav-backdrop,.seam-side-nav .side-nav-backdrop{background:rgba(52,58,64,.6);width:100vw;height:100vh}seam-side-nav .side-nav-backdrop.side-nav-backdrop-hidden,.seam-side-nav .side-nav-backdrop.side-nav-backdrop-hidden{display:none;width:0;height:0;padding:0;margin:0}seam-side-nav .side-nav-content,.seam-side-nav .side-nav-content{display:flex;flex-direction:column;height:100%;flex-wrap:nowrap}seam-side-nav .side-nav-items-container,.seam-side-nav .side-nav-items-container{display:flex;flex-direction:column;width:100%;flex:1 1 100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: A11yModule }, { kind: "ngmodule", type: TheSeamScrollbarModule }, { kind: "directive", type: i4.OverlayScrollbarDirective, selector: "[seamOverlayScrollbar]", inputs: ["seamOverlayScrollbar", "overlayScrollbarEnabled"], exportAs: ["seamOverlayScrollbar"] }, { kind: "ngmodule", type: TheSeamLayoutModule }, { kind: "ngmodule", type: PortalModule }, { kind: "directive", type: i3.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: SideNavItemComponent, selector: "seam-side-nav-item", inputs: ["itemType", "icon", "hideEmptyIcon", "label", "active", "link", "queryParams", "children", "hierLevel", "indentSize", "expanded", "compact", "badgeText", "badgeTheme", "badgeSrContent", "badgeTooltip"], exportAs: ["seamSideNavItem"] }, { kind: "component", type: SideNavToggleComponent, selector: "seam-side-nav-toggle", inputs: ["expanded", "toggleIcon", "toggleTpl"], outputs: ["toggleExpand"] }], animations: [
1699
+ //
1700
+ // TODO: This animation code turned into a mess. Clean it up and make it
1701
+ // more smooth.
1702
+ //
1703
+ trigger('sideNavAnim', [
1704
+ transition(sideNavExpandStateChangeFn, [
1705
+ group([
1706
+ query('@sideNavBackdrop', animateChild(), { optional: true }),
1707
+ query('@sideNavExpand', animateChild(), { optional: true }),
1708
+ ]),
1709
+ ]),
1710
+ ]),
1711
+ trigger('sideNavBackdrop', [
1712
+ state(EXPANDED_OVERLAY_STATE, style({ opacity: '1' })),
1713
+ state(COLLAPSED_OVERLAY_STATE, style({ opacity: '0' })),
1714
+ // transition((fromState, toState, element, params) => {
1715
+ // console.log('sideNavBackdrop v', fromState, toState, element, params)
1716
+ // return false
1717
+ // }, []),
1718
+ transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1719
+ ]),
1720
+ trigger('sideNavExpand', [
1721
+ // TODO: Make width configurable for non-overlay state.
1722
+ state(EXPANDED_STATE, style({ width: '260px' })),
1723
+ state(COLLAPSED_STATE, style({ width: '50px', 'overflow-x': 'hidden' })),
1724
+ state(EXPANDED_OVERLAY_STATE, style({
1725
+ position: 'absolute',
1726
+ top: 0,
1727
+ bottom: 0,
1728
+ left: 0,
1729
+ height: '{{ height }}',
1730
+ width: '{{ width }}',
1731
+ transform: '{{ origin }}',
1732
+ zIndex: '9999',
1733
+ }), {
1734
+ params: {
1735
+ origin: 'translateX(100%)',
1736
+ height: '100%',
1737
+ width: 'calc(100vw - 50px)',
1738
+ }
1739
+ }),
1740
+ state(COLLAPSED_OVERLAY_STATE, style({
1741
+ position: 'absolute',
1742
+ top: 0,
1743
+ bottom: 0,
1744
+ left: 0,
1745
+ height: '{{ height }}',
1746
+ width: '{{ width }}',
1747
+ transform: '{{ origin }}',
1748
+ 'overflow-x': 'hidden',
1749
+ zIndex: '9999',
1750
+ }), {
1751
+ params: {
1752
+ origin: 'translateX(0)',
1753
+ height: '100%',
1754
+ width: 'calc(100vw - 50px)',
1755
+ }
1756
+ }),
1757
+ // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),
1758
+ transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1759
+ // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, [
1760
+ // // query(':leave', animateChild(), { optional: true }),
1761
+ // // query(':enter', animateChild(), { optional: true }),
1762
+ // group([
1763
+ // query(':leave', animateChild(), { optional: true }),
1764
+ // query(':enter', animateChild(), { optional: true }),
1765
+ // query('@compactAnim', animateChild(), { optional: true }),
1766
+ // animate('5.2s ease-in-out')
1767
+ // ])
1768
+ // ]),
1769
+ ])
1770
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1771
+ __decorate([
1772
+ InputBoolean()
1773
+ ], SideNavComponent.prototype, "hasHeaderToggle", void 0);
1774
+ __decorate([
1775
+ InputNumber(10)
1776
+ ], SideNavComponent.prototype, "indentSize", void 0);
1777
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SideNavComponent, decorators: [{
1778
+ type: Component,
1779
+ args: [{ selector: 'seam-side-nav', providers: [
1780
+ TheSeamSideNavService,
1781
+ {
1782
+ provide: THESEAM_SIDE_NAV_ACCESSOR,
1783
+ useExisting: SideNavComponent
1784
+ },
1785
+ ], animations: [
1786
+ //
1787
+ // TODO: This animation code turned into a mess. Clean it up and make it
1788
+ // more smooth.
1789
+ //
1790
+ trigger('sideNavAnim', [
1791
+ transition(sideNavExpandStateChangeFn, [
1792
+ group([
1793
+ query('@sideNavBackdrop', animateChild(), { optional: true }),
1794
+ query('@sideNavExpand', animateChild(), { optional: true }),
1795
+ ]),
1796
+ ]),
1797
+ ]),
1798
+ trigger('sideNavBackdrop', [
1799
+ state(EXPANDED_OVERLAY_STATE, style({ opacity: '1' })),
1800
+ state(COLLAPSED_OVERLAY_STATE, style({ opacity: '0' })),
1801
+ // transition((fromState, toState, element, params) => {
1802
+ // console.log('sideNavBackdrop v', fromState, toState, element, params)
1803
+ // return false
1804
+ // }, []),
1805
+ transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1806
+ ]),
1807
+ trigger('sideNavExpand', [
1808
+ // TODO: Make width configurable for non-overlay state.
1809
+ state(EXPANDED_STATE, style({ width: '260px' })),
1810
+ state(COLLAPSED_STATE, style({ width: '50px', 'overflow-x': 'hidden' })),
1811
+ state(EXPANDED_OVERLAY_STATE, style({
1812
+ position: 'absolute',
1813
+ top: 0,
1814
+ bottom: 0,
1815
+ left: 0,
1816
+ height: '{{ height }}',
1817
+ width: '{{ width }}',
1818
+ transform: '{{ origin }}',
1819
+ zIndex: '9999',
1820
+ }), {
1821
+ params: {
1822
+ origin: 'translateX(100%)',
1823
+ height: '100%',
1824
+ width: 'calc(100vw - 50px)',
1825
+ }
1826
+ }),
1827
+ state(COLLAPSED_OVERLAY_STATE, style({
1828
+ position: 'absolute',
1829
+ top: 0,
1830
+ bottom: 0,
1831
+ left: 0,
1832
+ height: '{{ height }}',
1833
+ width: '{{ width }}',
1834
+ transform: '{{ origin }}',
1835
+ 'overflow-x': 'hidden',
1836
+ zIndex: '9999',
1837
+ }), {
1838
+ params: {
1839
+ origin: 'translateX(0)',
1840
+ height: '100%',
1841
+ width: 'calc(100vw - 50px)',
1842
+ }
1843
+ }),
1844
+ // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),
1845
+ transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1846
+ // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, [
1847
+ // // query(':leave', animateChild(), { optional: true }),
1848
+ // // query(':enter', animateChild(), { optional: true }),
1849
+ // group([
1850
+ // query(':leave', animateChild(), { optional: true }),
1851
+ // query(':enter', animateChild(), { optional: true }),
1852
+ // query('@compactAnim', animateChild(), { optional: true }),
1853
+ // animate('5.2s ease-in-out')
1854
+ // ])
1855
+ // ]),
1856
+ ])
1857
+ ], imports: [
1858
+ CommonModule,
1859
+ A11yModule,
1860
+ TheSeamScrollbarModule,
1861
+ TheSeamLayoutModule,
1862
+ PortalModule,
1863
+ SideNavItemComponent,
1864
+ SideNavToggleComponent,
1865
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, template: "<div class=\"side-nav-backdrop\" *ngIf=\"isMobile$ | async\"\n [@sideNavBackdrop]=\"_sideNavExpand\"\n [class.side-nav-backdrop-hidden]=\"_backdropHidden | async\"\n (click)=\"collapse()\"></div>\n\n<div\n class=\"side-nav-inner-wrapper\"\n [@sideNavExpand]=\"{\n value: _sideNavExpand,\n params: {\n origin: expandOriginTransform,\n height: expandHeight,\n width: expandWidth\n }\n }\"\n (@sideNavExpand.start)=\"animateStart()\"\n (@sideNavExpand.done)=\"animateEnd()\">\n <nav class=\"nav side-nav-content\">\n <seam-side-nav-toggle *ngIf=\"hasHeaderToggle\"\n [toggleIcon]=\"toggleIcon\"\n [toggleTpl]=\"toggleTpl\"\n [expanded]=\"expanded$ | async\"\n (toggleExpand)=\"toggle()\">\n <ng-template [cdkPortalOutlet]=\"_sideBarHeaderPortal\"></ng-template>\n </seam-side-nav-toggle>\n <div class=\"side-nav-items-container\" seamOverlayScrollbar>\n <div class=\"side-nav--group side-nav--group--level-0\">\n <seam-side-nav-item *ngFor=\"let item of items$ | async\"\n [compact]=\"!(expanded$ | async)\"\n [itemType]=\"$any(item)?.itemType\"\n [icon]=\"$any(item)?.icon\"\n [label]=\"$any(item)?.label\"\n [link]=\"$any(item)?.link\"\n [badgeText]=\"$any(item)?.badge?.text\"\n [badgeTheme]=\"$any(item)?.badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(item)?.badge?.srContent\"\n [badgeTooltip]=\"$any(item)?.badge?.tooltip\"\n [queryParams]=\"$any(item)?.queryParams\"\n [children]=\"$any(item)?.children\"\n [active]=\"$any(item).__state?.active\"\n [expanded]=\"$any(item).__state?.expanded\"\n [hideEmptyIcon]=\"hideEmptyIcon\"\n [indentSize]=\"indentSize\">\n </seam-side-nav-item>\n </div>\n </div>\n <ng-template [cdkPortalOutlet]=\"_sideBarFooterPortal\"></ng-template>\n </nav>\n</div>\n", styles: ["seam-side-nav,.seam-side-nav{display:block;height:100%;position:relative;z-index:2;overflow:hidden}seam-side-nav .side-nav-inner-wrapper,.seam-side-nav .side-nav-inner-wrapper{background:#357ebd;height:100%}seam-side-nav .side-nav-backdrop,.seam-side-nav .side-nav-backdrop{background:rgba(52,58,64,.6);width:100vw;height:100vh}seam-side-nav .side-nav-backdrop.side-nav-backdrop-hidden,.seam-side-nav .side-nav-backdrop.side-nav-backdrop-hidden{display:none;width:0;height:0;padding:0;margin:0}seam-side-nav .side-nav-content,.seam-side-nav .side-nav-content{display:flex;flex-direction:column;height:100%;flex-wrap:nowrap}seam-side-nav .side-nav-items-container,.seam-side-nav .side-nav-items-container{display:flex;flex-direction:column;width:100%;flex:1 1 100%}\n"] }]
1866
+ }], ctorParameters: function () {
1867
+ return [{ type: i0.ViewContainerRef }, { type: i1.TheSeamLayoutService }, { type: TheSeamSideNavService }, { type: undefined, decorators: [{
1868
+ type: Optional
1869
+ }, {
1870
+ type: Inject,
1871
+ args: [THESEAM_BASE_LAYOUT_REF]
1872
+ }] }];
1873
+ }, propDecorators: { _sideNavExpand: [{
1874
+ type: HostBinding,
1875
+ args: ['@sideNavAnim']
1876
+ }], hasHeaderToggle: [{
1877
+ type: Input
1878
+ }], toggleIcon: [{
1879
+ type: Input
1880
+ }], toggleTpl: [{
1881
+ type: Input
1882
+ }], items: [{
1883
+ type: Input
1884
+ }], hideEmptyIcon: [{
1885
+ type: Input
1886
+ }], indentSize: [{
1887
+ type: Input
1888
+ }], expanded: [{
1889
+ type: Input
1890
+ }], expandOrigin: [{
1891
+ type: Input
1892
+ }], expandHeight: [{
1893
+ type: Input
1894
+ }], expandWidth: [{
1895
+ type: Input
1896
+ }], overlay: [{
1897
+ type: Input
1898
+ }], toggleExpand: [{
1899
+ type: Output
1900
+ }], _sideBarHeaderTpl: [{
1901
+ type: ContentChild,
1902
+ args: [BaseLayoutSideBarHeaderDirective, { static: true, read: TemplateRef }]
1903
+ }], _sideBarFooterTpl: [{
1904
+ type: ContentChild,
1905
+ args: [BaseLayoutSideBarFooterDirective, { static: true, read: TemplateRef }]
1906
+ }] } });
1907
+
1908
+ class TheSeamSideNavModule {
1909
+ }
1910
+ TheSeamSideNavModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1911
+ TheSeamSideNavModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavModule, imports: [SideNavItemComponent,
1912
+ SideNavComponent,
1913
+ SideNavToggleComponent], exports: [SideNavItemComponent,
1914
+ SideNavComponent,
1915
+ SideNavToggleComponent] });
1916
+ TheSeamSideNavModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavModule, imports: [SideNavItemComponent,
1917
+ SideNavComponent,
1918
+ SideNavToggleComponent] });
1919
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSideNavModule, decorators: [{
1920
+ type: NgModule,
1921
+ args: [{
1922
+ imports: [
1923
+ SideNavItemComponent,
1924
+ SideNavComponent,
1925
+ SideNavToggleComponent,
1926
+ ],
1927
+ exports: [
1928
+ SideNavItemComponent,
1929
+ SideNavComponent,
1930
+ SideNavToggleComponent,
1931
+ ]
1932
+ }]
1933
+ }] });
1934
+
1935
+ class TopBarMenuButtonBase {
1936
+ }
1937
+ const _TopBarMenuButtonMixinBase = mixinDisabled(TopBarMenuButtonBase);
1938
+ class TopBarMenuButtonComponent extends _TopBarMenuButtonMixinBase {
1939
+ constructor() {
1940
+ super(...arguments);
1941
+ this.faAngleDown = faAngleDown;
1942
+ this.compact = false;
1943
+ }
1944
+ get _hasCompactClass() { return this.compact; }
1945
+ get _hasPadding0Class() { return this.compact; }
1946
+ get _hasRoundedClass() { return this.compact; }
1947
+ get _hasBtnLinkClass() { return !this.compact; }
1948
+ }
1949
+ TopBarMenuButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarMenuButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
1950
+ TopBarMenuButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TopBarMenuButtonComponent, selector: "button[seamTopBarMenuButton]", inputs: { disabled: "disabled", detailTpl: "detailTpl", compactDetailTpl: "compactDetailTpl", compact: "compact", profileIcon: "profileIcon" }, host: { attributes: { "attr.type": "button" }, properties: { "attr.aria-disabled": "disabled.toString()", "attr.disabled": "disabled || null", "class.top-bar-menu-button--compact": "this._hasCompactClass", "class.p-0": "this._hasPadding0Class", "class.rounded": "this._hasRoundedClass", "class.btn-link": "this._hasBtnLinkClass" }, classAttribute: "btn border text-decoration-none py-0 top-bar-menu-button" }, exportAs: ["seamButton"], usesInheritance: true, ngImport: i0, template: "<div class=\"d-flex flex-row\" *ngIf=\"!compact; else compactTpl\">\n <div class=\"text-left flex-grow-1 text-truncate\">\n <ng-template [ngTemplateOutlet]=\"$any(detailTpl)\"></ng-template>\n </div>\n <!-- Arrow Button -->\n <div class=\"pl-2 d-flex flex-column\">\n <div class=\"flex-grow-1\"></div>\n <seam-icon class=\"d-block\" [icon]=\"faAngleDown\"></seam-icon>\n <div class=\"flex-grow-1\"></div>\n </div>\n</div>\n<ng-template #compactTpl>\n <ng-container *ngIf=\"compactDetailTpl; else iconTpl\">\n <ng-template [ngTemplateOutlet]=\"$any(compactDetailTpl)\"></ng-template>\n </ng-container>\n <ng-template #iconTpl>\n <seam-icon [icon]=\"profileIcon\" iconType=\"borderless-styled-square\"></seam-icon>\n </ng-template>\n</ng-template>\n", styles: ["button[seamTopBarMenuButton]{min-width:200px;border-radius:0;border-top:0!important;border-bottom:0!important;border-right:0!important}button[seamTopBarMenuButton].top-bar-menu-button--compact{min-width:40px;border-left:0!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2$1.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1951
+ __decorate([
1952
+ InputBoolean()
1953
+ ], TopBarMenuButtonComponent.prototype, "compact", void 0);
1954
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarMenuButtonComponent, decorators: [{
1955
+ type: Component,
1956
+ args: [{ selector: 'button[seamTopBarMenuButton]', encapsulation: ViewEncapsulation.None, exportAs: 'seamButton', inputs: ['disabled'], host: {
1957
+ 'attr.type': 'button',
1958
+ 'class': 'btn border text-decoration-none py-0 top-bar-menu-button',
1959
+ '[attr.aria-disabled]': 'disabled.toString()',
1960
+ '[attr.disabled]': 'disabled || null',
1961
+ }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"d-flex flex-row\" *ngIf=\"!compact; else compactTpl\">\n <div class=\"text-left flex-grow-1 text-truncate\">\n <ng-template [ngTemplateOutlet]=\"$any(detailTpl)\"></ng-template>\n </div>\n <!-- Arrow Button -->\n <div class=\"pl-2 d-flex flex-column\">\n <div class=\"flex-grow-1\"></div>\n <seam-icon class=\"d-block\" [icon]=\"faAngleDown\"></seam-icon>\n <div class=\"flex-grow-1\"></div>\n </div>\n</div>\n<ng-template #compactTpl>\n <ng-container *ngIf=\"compactDetailTpl; else iconTpl\">\n <ng-template [ngTemplateOutlet]=\"$any(compactDetailTpl)\"></ng-template>\n </ng-container>\n <ng-template #iconTpl>\n <seam-icon [icon]=\"profileIcon\" iconType=\"borderless-styled-square\"></seam-icon>\n </ng-template>\n</ng-template>\n", styles: ["button[seamTopBarMenuButton]{min-width:200px;border-radius:0;border-top:0!important;border-bottom:0!important;border-right:0!important}button[seamTopBarMenuButton].top-bar-menu-button--compact{min-width:40px;border-left:0!important}\n"] }]
1962
+ }], propDecorators: { detailTpl: [{
1963
+ type: Input
1964
+ }], compactDetailTpl: [{
1965
+ type: Input
1966
+ }], compact: [{
1967
+ type: Input
1968
+ }], profileIcon: [{
1969
+ type: Input
1970
+ }], _hasCompactClass: [{
1971
+ type: HostBinding,
1972
+ args: ['class.top-bar-menu-button--compact']
1973
+ }], _hasPadding0Class: [{
1974
+ type: HostBinding,
1975
+ args: ['class.p-0']
1976
+ }], _hasRoundedClass: [{
1977
+ type: HostBinding,
1978
+ args: ['class.rounded']
1979
+ }], _hasBtnLinkClass: [{
1980
+ type: HostBinding,
1981
+ args: ['class.btn-link']
1982
+ }] } });
1983
+
1984
+ class TopBarTitleComponent {
1985
+ }
1986
+ TopBarTitleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarTitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1987
+ TopBarTitleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TopBarTitleComponent, selector: "seam-top-bar-title", inputs: { titleText: "titleText", subTitleText: "subTitleText" }, ngImport: i0, template: "<h2 class=\"mb-0\" [ngStyle]=\"{ 'font-size.px': 32 }\" [ngStyle.lt-md]=\"{ 'font-size.px': 26 }\" [ngStyle.lt-sm]=\"{ 'font-size.px': 20, 'line-height': 1 }\">\n {{ titleText }}\n <br fxHide.gt-sm>\n <small *ngIf=\"subTitleText\" class=\"text-muted\">{{ subTitleText }}</small>\n</h2>\n", styles: ["seam-top-bar-title{flex:1 1 auto;display:flex;flex-direction:row;align-items:center}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2$2.DefaultShowHideDirective, selector: " [fxShow], [fxShow.print], [fxShow.xs], [fxShow.sm], [fxShow.md], [fxShow.lg], [fxShow.xl], [fxShow.lt-sm], [fxShow.lt-md], [fxShow.lt-lg], [fxShow.lt-xl], [fxShow.gt-xs], [fxShow.gt-sm], [fxShow.gt-md], [fxShow.gt-lg], [fxHide], [fxHide.print], [fxHide.xs], [fxHide.sm], [fxHide.md], [fxHide.lg], [fxHide.xl], [fxHide.lt-sm], [fxHide.lt-md], [fxHide.lt-lg], [fxHide.lt-xl], [fxHide.gt-xs], [fxHide.gt-sm], [fxHide.gt-md], [fxHide.gt-lg]", inputs: ["fxShow", "fxShow.print", "fxShow.xs", "fxShow.sm", "fxShow.md", "fxShow.lg", "fxShow.xl", "fxShow.lt-sm", "fxShow.lt-md", "fxShow.lt-lg", "fxShow.lt-xl", "fxShow.gt-xs", "fxShow.gt-sm", "fxShow.gt-md", "fxShow.gt-lg", "fxHide", "fxHide.print", "fxHide.xs", "fxHide.sm", "fxHide.md", "fxHide.lg", "fxHide.xl", "fxHide.lt-sm", "fxHide.lt-md", "fxHide.lt-lg", "fxHide.lt-xl", "fxHide.gt-xs", "fxHide.gt-sm", "fxHide.gt-md", "fxHide.gt-lg"] }, { kind: "directive", type: i2$2.DefaultStyleDirective, selector: " [ngStyle], [ngStyle.xs], [ngStyle.sm], [ngStyle.md], [ngStyle.lg], [ngStyle.xl], [ngStyle.lt-sm], [ngStyle.lt-md], [ngStyle.lt-lg], [ngStyle.lt-xl], [ngStyle.gt-xs], [ngStyle.gt-sm], [ngStyle.gt-md], [ngStyle.gt-lg]", inputs: ["ngStyle", "ngStyle.xs", "ngStyle.sm", "ngStyle.md", "ngStyle.lg", "ngStyle.xl", "ngStyle.lt-sm", "ngStyle.lt-md", "ngStyle.lt-lg", "ngStyle.lt-xl", "ngStyle.gt-xs", "ngStyle.gt-sm", "ngStyle.gt-md", "ngStyle.gt-lg"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1988
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarTitleComponent, decorators: [{
1989
+ type: Component,
1990
+ args: [{ selector: 'seam-top-bar-title', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<h2 class=\"mb-0\" [ngStyle]=\"{ 'font-size.px': 32 }\" [ngStyle.lt-md]=\"{ 'font-size.px': 26 }\" [ngStyle.lt-sm]=\"{ 'font-size.px': 20, 'line-height': 1 }\">\n {{ titleText }}\n <br fxHide.gt-sm>\n <small *ngIf=\"subTitleText\" class=\"text-muted\">{{ subTitleText }}</small>\n</h2>\n", styles: ["seam-top-bar-title{flex:1 1 auto;display:flex;flex-direction:row;align-items:center}\n"] }]
1991
+ }], propDecorators: { titleText: [{
1992
+ type: Input
1993
+ }], subTitleText: [{
1994
+ type: Input
1995
+ }] } });
1996
+
1997
+ class TopBarCompactMenuBtnDetailDirective {
1998
+ constructor(template) {
1999
+ this.template = template;
2000
+ }
2001
+ }
2002
+ TopBarCompactMenuBtnDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarCompactMenuBtnDetailDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2003
+ TopBarCompactMenuBtnDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TopBarCompactMenuBtnDetailDirective, selector: "[seamTopBarCompactMenuBtnDetail]", ngImport: i0 });
2004
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarCompactMenuBtnDetailDirective, decorators: [{
2005
+ type: Directive,
2006
+ args: [{
2007
+ selector: '[seamTopBarCompactMenuBtnDetail]'
2008
+ }]
2009
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
2010
+
2011
+ class TopBarNavToggleBtnDetailDirective {
2012
+ constructor(template) {
2013
+ this.template = template;
2014
+ }
2015
+ }
2016
+ TopBarNavToggleBtnDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarNavToggleBtnDetailDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2017
+ TopBarNavToggleBtnDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TopBarNavToggleBtnDetailDirective, selector: "[seamTopBarNavToggleBtnDetail]", ngImport: i0 });
2018
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarNavToggleBtnDetailDirective, decorators: [{
2019
+ type: Directive,
2020
+ args: [{
2021
+ selector: '[seamTopBarNavToggleBtnDetail]'
2022
+ }]
2023
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
2024
+
2025
+ class TopBarItemDirective {
2026
+ set seamTopBarItem(value) {
2027
+ this.position = value;
2028
+ }
2029
+ constructor(template) {
2030
+ this.template = template;
2031
+ this.position = 'right';
2032
+ }
2033
+ }
2034
+ TopBarItemDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarItemDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2035
+ TopBarItemDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TopBarItemDirective, selector: "[seamTopBarItem]", inputs: { seamTopBarItem: "seamTopBarItem" }, ngImport: i0 });
2036
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarItemDirective, decorators: [{
2037
+ type: Directive,
2038
+ args: [{
2039
+ selector: '[seamTopBarItem]'
2040
+ }]
2041
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; }, propDecorators: { seamTopBarItem: [{
2042
+ type: Input
2043
+ }] } });
2044
+
2045
+ class TopBarMenuBtnDetailDirective {
2046
+ constructor(template) {
2047
+ this.template = template;
2048
+ }
2049
+ }
2050
+ TopBarMenuBtnDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarMenuBtnDetailDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2051
+ TopBarMenuBtnDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TopBarMenuBtnDetailDirective, selector: "[seamTopBarMenuBtnDetail]", ngImport: i0 });
2052
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarMenuBtnDetailDirective, decorators: [{
2053
+ type: Directive,
2054
+ args: [{
2055
+ selector: '[seamTopBarMenuBtnDetail]'
2056
+ }]
2057
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
2058
+
2059
+ class TopBarMenuDirective {
2060
+ constructor(menu) {
2061
+ this.menu = menu;
2062
+ }
2063
+ }
2064
+ TopBarMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarMenuDirective, deps: [{ token: i3$2.MenuComponent, self: true }], target: i0.ɵɵFactoryTarget.Directive });
2065
+ TopBarMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TopBarMenuDirective, selector: "seam-menu[seamTopBarMenu]", ngImport: i0 });
2066
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TopBarMenuDirective, decorators: [{
2067
+ type: Directive,
2068
+ args: [{
2069
+ selector: 'seam-menu[seamTopBarMenu]'
2070
+ }]
2071
+ }], ctorParameters: function () {
2072
+ return [{ type: i3$2.MenuComponent, decorators: [{
2073
+ type: Self
2074
+ }] }];
2075
+ } });
2076
+
2077
+ /**
2078
+ * Top bar of an app.
2079
+ *
2080
+ * The top bar is fairly opinionated, so most parts are not intended to be
2081
+ * customized unless there is an input.
2082
+ *
2083
+ * > If you have to make a change and apply it externally with a css class or js
2084
+ * > make sure there is an issue to get the feature changed, so we don't have
2085
+ * > different modifications across our apps. Also, this will help make sure
2086
+ * > your change should have even been done.
2087
+ */
2088
+ class TheSeamTopBarComponent {
2089
+ constructor(_layout) {
2090
+ this._layout = _layout;
2091
+ /** @ignore */
2092
+ this._ngUnsubscribe = new Subject();
2093
+ /** @ignore */
2094
+ this.faBars = faBars;
2095
+ /** Link target used when `logoHref` is specified. Defaults to `"_blank"` */
2096
+ this.logoHrefTarget = '_blank';
2097
+ /** Route to link to when `logo` is clicked. Defaults to `/`. */
2098
+ this.logoRoute = '/';
2099
+ /** Determines if the title should be displayed. */
2100
+ this.hasTitle = false;
2101
+ /** Determines if the top bar button should be displayed. */
2102
+ this.hasTopBarMenuButton = true;
2103
+ /** Icon to display on mobile to activate profile dropdown. Defaults to faUserCircle. */
2104
+ this.profileIcon = faUserCircle;
2105
+ /** Icon to display for mobile nav toggle. Defaults to faBars. */
2106
+ this.toggleIcon = faBars;
2107
+ /** Display nav toggle on either left or right side of top bar. Defaults to left. */
2108
+ this.navToggleAlign = 'left';
2109
+ /** @ignore */
2110
+ this._leftItems = new BehaviorSubject([]);
2111
+ /** Additional templates to display on left side of top bar */
2112
+ this.leftItems$ = this._leftItems.asObservable();
2113
+ /** @ignore */
2114
+ this._centerItems = new BehaviorSubject([]);
2115
+ /** Additional templates to display in center of top bar */
2116
+ this.centerItems$ = this._centerItems.asObservable();
2117
+ /** @ignore */
2118
+ this._rightItems = new BehaviorSubject([]);
2119
+ /** Additional templates to display on right side of top bar */
2120
+ this.rightItems$ = this._rightItems.asObservable();
2121
+ this.isMobile$ = this._layout.isMobile$;
2122
+ }
2123
+ /** @ignore */
2124
+ ngOnDestroy() {
2125
+ this._ngUnsubscribe.next(undefined);
2126
+ this._ngUnsubscribe.complete();
2127
+ }
2128
+ /** @ignore */
2129
+ ngAfterContentInit() {
2130
+ if (this._topBarItems) {
2131
+ this._topBarItems.changes.pipe(startWith(undefined), takeUntil(this._ngUnsubscribe), map(() => {
2132
+ var _a;
2133
+ const items = ((_a = this._topBarItems) === null || _a === void 0 ? void 0 : _a.toArray()) || [];
2134
+ const left = items.filter(i => i.position === 'left');
2135
+ const right = items.filter(i => i.position === 'right');
2136
+ const center = items.filter(i => i.position === 'center');
2137
+ this._leftItems.next(left);
2138
+ this._rightItems.next(right);
2139
+ this._centerItems.next(center);
2140
+ }), shareReplay({ bufferSize: 1, refCount: true })).subscribe();
2141
+ }
2142
+ }
2143
+ }
2144
+ TheSeamTopBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamTopBarComponent, deps: [{ token: i1.TheSeamLayoutService }], target: i0.ɵɵFactoryTarget.Component });
2145
+ TheSeamTopBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamTopBarComponent, selector: "seam-top-bar", inputs: { logo: "logo", logoSm: "logoSm", logoHref: "logoHref", logoHrefTarget: "logoHrefTarget", logoRoute: "logoRoute", hasTitle: "hasTitle", titleText: "titleText", subTitleText: "subTitleText", hasTopBarMenuButton: "hasTopBarMenuButton", profileIcon: "profileIcon", toggleIcon: "toggleIcon", navToggleAlign: "navToggleAlign" }, queries: [{ propertyName: "_topBarMenu", first: true, predicate: TopBarMenuDirective, descendants: true, static: true }, { propertyName: "_topBarMenuBtnDetailTpl", first: true, predicate: TopBarMenuBtnDetailDirective, descendants: true }, { propertyName: "_topBarCompactMenuBtnDetailTpl", first: true, predicate: TopBarCompactMenuBtnDetailDirective, descendants: true }, { propertyName: "_topBarNavToggleBtnDetailTpl", first: true, predicate: TopBarNavToggleBtnDetailDirective, descendants: true }, { propertyName: "_topBarItems", predicate: TopBarItemDirective }], exportAs: ["seamTopBar"], ngImport: i0, template: "<div class=\"top-bar--left d-flex\">\n <!-- Nav Toggle -->\n <ng-container *ngIf=\"navToggleAlign === 'left'\">\n <ng-container *ngTemplateOutlet=\"navToggle\"></ng-container>\n </ng-container>\n\n <!-- Logo -->\n <div class=\"top-bar--logo d-flex flex-column justify-content-center\" *ngIf=\"logoHref; else useLogoRoute\"\n [class.top-bar--logo-mobile]=\"isMobile$ | async\">\n <a [href]=\"logoHref\" [target]=\"logoHrefTarget\">\n <ng-container *ngTemplateOutlet=\"logoTpl\"></ng-container>\n </a>\n </div>\n\n <ng-template #useLogoRoute>\n <div class=\"top-bar--logo d-flex flex-column justify-content-center\" [routerLink]=\"logoRoute\"\n [class.top-bar--logo-mobile]=\"isMobile$ | async\">\n <ng-container *ngTemplateOutlet=\"logoTpl\"></ng-container>\n </div>\n </ng-template>\n\n <ng-template #logoTpl>\n <div>\n <img *ngIf=\"logo\" [src]=\"logo\" [src.lt-md]=\"logoSm ? logoSm : logo\" alt=\"Logo\">\n </div>\n </ng-template>\n\n <!-- Title -->\n <div class=\"d-flex flex-column\" *ngIf=\"hasTitle\">\n <seam-top-bar-title\n [titleText]=\"titleText\"\n [subTitleText]=\"subTitleText\"\n [class.ml-2]=\"isMobile$ | async\">\n </seam-top-bar-title>\n </div>\n\n <!-- Items -->\n <div class=\"top-bar-items top-bar-items--left mr-2\">\n <ng-container *ngFor=\"let item of leftItems$ | async\">\n <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n </ng-container>\n </div>\n</div>\n\n<div class=\"top-bar--center\">\n <!-- Items -->\n <div class=\"top-bar-items top-bar-items--center mr-2\">\n <ng-container *ngFor=\"let item of centerItems$ | async\">\n <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n </ng-container>\n </div>\n</div>\n\n<div class=\"top-bar--right d-flex\">\n <!-- Items -->\n <div class=\"top-bar-items top-bar-items--right mr-2\">\n <ng-container *ngFor=\"let item of rightItems$ | async\">\n <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n </ng-container>\n </div>\n\n <!-- Menu -->\n <button\n *ngIf=\"hasTopBarMenuButton\"\n seamTopBarMenuButton\n [seamMenuToggle]=\"_topBarMenu?.menu\"\n [detailTpl]=\"_topBarMenuBtnDetailTpl?.template\"\n [compactDetailTpl]=\"_topBarCompactMenuBtnDetailTpl?.template\"\n [compact]=\"isMobile$ | async\"\n [profileIcon]=\"profileIcon\">\n </button>\n\n <ng-container *ngIf=\"navToggleAlign === 'right'\">\n <ng-container *ngTemplateOutlet=\"navToggle\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #navToggle>\n <div class=\"d-flex flex-column justify-content-center pr-2\" *ngIf=\"isMobile$ | async\">\n <ng-container *ngIf=\"_topBarNavToggleBtnDetailTpl; else iconBtn\">\n <button seamButton seamBaseLayoutNavToggle>\n <ng-template [ngTemplateOutlet]=\"_topBarNavToggleBtnDetailTpl?.template || null\"></ng-template>\n </button>\n </ng-container>\n <ng-template #iconBtn>\n <button seamBaseLayoutNavToggle seamIconBtn [icon]=\"toggleIcon\" iconType=\"borderless-styled-square\"></button>\n </ng-template>\n </div>\n</ng-template>\n\n", styles: ["seam-top-bar{display:flex;flex:1 1 100%;flex-direction:row;background:white;margin:0;padding:8px;border-radius:0;box-shadow:none}.top-bar--logo{flex:0 0 auto;overflow:hidden;cursor:pointer}.top-bar--logo img{height:auto;max-height:60px;width:auto;max-width:200px}.top-bar--logo.top-bar--logo-mobile img{height:auto;max-height:40px;width:auto;max-width:150px}.top-bar--left{flex-grow:1}.top-bar-items{display:flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$2.DefaultImgSrcDirective, selector: " img[src.xs], img[src.sm], img[src.md], img[src.lg], img[src.xl], img[src.lt-sm], img[src.lt-md], img[src.lt-lg], img[src.lt-xl], img[src.gt-xs], img[src.gt-sm], img[src.gt-md], img[src.gt-lg]", inputs: ["src.xs", "src.sm", "src.md", "src.lg", "src.xl", "src.lt-sm", "src.lt-md", "src.lt-lg", "src.lt-xl", "src.gt-xs", "src.gt-sm", "src.gt-md", "src.gt-lg"] }, { kind: "component", type: i4$1.ButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }, { kind: "component", type: i2$1.IconBtnComponent, selector: "button[seamIconBtn]", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "iconType", "btnTheme", "badgeTheme", "badgeText", "btnSize", "type", "role"] }, { kind: "directive", type: i3$2.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions"], outputs: ["menuToggle"], exportAs: ["seamMenuToggle"] }, { kind: "directive", type: BaseLayoutNavToggleDirective, selector: "button[seamBaseLayoutNavToggle]", inputs: ["type", "aria-label"], exportAs: ["seamBaseLayoutNavToggle"] }, { kind: "directive", type: i1$2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: TopBarTitleComponent, selector: "seam-top-bar-title", inputs: ["titleText", "subTitleText"] }, { kind: "component", type: TopBarMenuButtonComponent, selector: "button[seamTopBarMenuButton]", inputs: ["disabled", "detailTpl", "compactDetailTpl", "compact", "profileIcon"], exportAs: ["seamButton"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
2146
+ __decorate([
2147
+ InputBoolean()
2148
+ ], TheSeamTopBarComponent.prototype, "hasTitle", void 0);
2149
+ __decorate([
2150
+ InputBoolean()
2151
+ ], TheSeamTopBarComponent.prototype, "hasTopBarMenuButton", void 0);
2152
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamTopBarComponent, decorators: [{
2153
+ type: Component,
2154
+ args: [{ selector: 'seam-top-bar', encapsulation: ViewEncapsulation.None, exportAs: 'seamTopBar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"top-bar--left d-flex\">\n <!-- Nav Toggle -->\n <ng-container *ngIf=\"navToggleAlign === 'left'\">\n <ng-container *ngTemplateOutlet=\"navToggle\"></ng-container>\n </ng-container>\n\n <!-- Logo -->\n <div class=\"top-bar--logo d-flex flex-column justify-content-center\" *ngIf=\"logoHref; else useLogoRoute\"\n [class.top-bar--logo-mobile]=\"isMobile$ | async\">\n <a [href]=\"logoHref\" [target]=\"logoHrefTarget\">\n <ng-container *ngTemplateOutlet=\"logoTpl\"></ng-container>\n </a>\n </div>\n\n <ng-template #useLogoRoute>\n <div class=\"top-bar--logo d-flex flex-column justify-content-center\" [routerLink]=\"logoRoute\"\n [class.top-bar--logo-mobile]=\"isMobile$ | async\">\n <ng-container *ngTemplateOutlet=\"logoTpl\"></ng-container>\n </div>\n </ng-template>\n\n <ng-template #logoTpl>\n <div>\n <img *ngIf=\"logo\" [src]=\"logo\" [src.lt-md]=\"logoSm ? logoSm : logo\" alt=\"Logo\">\n </div>\n </ng-template>\n\n <!-- Title -->\n <div class=\"d-flex flex-column\" *ngIf=\"hasTitle\">\n <seam-top-bar-title\n [titleText]=\"titleText\"\n [subTitleText]=\"subTitleText\"\n [class.ml-2]=\"isMobile$ | async\">\n </seam-top-bar-title>\n </div>\n\n <!-- Items -->\n <div class=\"top-bar-items top-bar-items--left mr-2\">\n <ng-container *ngFor=\"let item of leftItems$ | async\">\n <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n </ng-container>\n </div>\n</div>\n\n<div class=\"top-bar--center\">\n <!-- Items -->\n <div class=\"top-bar-items top-bar-items--center mr-2\">\n <ng-container *ngFor=\"let item of centerItems$ | async\">\n <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n </ng-container>\n </div>\n</div>\n\n<div class=\"top-bar--right d-flex\">\n <!-- Items -->\n <div class=\"top-bar-items top-bar-items--right mr-2\">\n <ng-container *ngFor=\"let item of rightItems$ | async\">\n <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n </ng-container>\n </div>\n\n <!-- Menu -->\n <button\n *ngIf=\"hasTopBarMenuButton\"\n seamTopBarMenuButton\n [seamMenuToggle]=\"_topBarMenu?.menu\"\n [detailTpl]=\"_topBarMenuBtnDetailTpl?.template\"\n [compactDetailTpl]=\"_topBarCompactMenuBtnDetailTpl?.template\"\n [compact]=\"isMobile$ | async\"\n [profileIcon]=\"profileIcon\">\n </button>\n\n <ng-container *ngIf=\"navToggleAlign === 'right'\">\n <ng-container *ngTemplateOutlet=\"navToggle\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #navToggle>\n <div class=\"d-flex flex-column justify-content-center pr-2\" *ngIf=\"isMobile$ | async\">\n <ng-container *ngIf=\"_topBarNavToggleBtnDetailTpl; else iconBtn\">\n <button seamButton seamBaseLayoutNavToggle>\n <ng-template [ngTemplateOutlet]=\"_topBarNavToggleBtnDetailTpl?.template || null\"></ng-template>\n </button>\n </ng-container>\n <ng-template #iconBtn>\n <button seamBaseLayoutNavToggle seamIconBtn [icon]=\"toggleIcon\" iconType=\"borderless-styled-square\"></button>\n </ng-template>\n </div>\n</ng-template>\n\n", styles: ["seam-top-bar{display:flex;flex:1 1 100%;flex-direction:row;background:white;margin:0;padding:8px;border-radius:0;box-shadow:none}.top-bar--logo{flex:0 0 auto;overflow:hidden;cursor:pointer}.top-bar--logo img{height:auto;max-height:60px;width:auto;max-width:200px}.top-bar--logo.top-bar--logo-mobile img{height:auto;max-height:40px;width:auto;max-width:150px}.top-bar--left{flex-grow:1}.top-bar-items{display:flex;align-items:center}\n"] }]
2155
+ }], ctorParameters: function () { return [{ type: i1.TheSeamLayoutService }]; }, propDecorators: { _topBarMenu: [{
2156
+ type: ContentChild,
2157
+ args: [TopBarMenuDirective, { static: true }]
2158
+ }], _topBarItems: [{
2159
+ type: ContentChildren,
2160
+ args: [TopBarItemDirective]
2161
+ }], _topBarMenuBtnDetailTpl: [{
2162
+ type: ContentChild,
2163
+ args: [TopBarMenuBtnDetailDirective]
2164
+ }], _topBarCompactMenuBtnDetailTpl: [{
2165
+ type: ContentChild,
2166
+ args: [TopBarCompactMenuBtnDetailDirective]
2167
+ }], _topBarNavToggleBtnDetailTpl: [{
2168
+ type: ContentChild,
2169
+ args: [TopBarNavToggleBtnDetailDirective]
2170
+ }], logo: [{
2171
+ type: Input
2172
+ }], logoSm: [{
2173
+ type: Input
2174
+ }], logoHref: [{
2175
+ type: Input
2176
+ }], logoHrefTarget: [{
2177
+ type: Input
2178
+ }], logoRoute: [{
2179
+ type: Input
2180
+ }], hasTitle: [{
2181
+ type: Input
2182
+ }], titleText: [{
2183
+ type: Input
2184
+ }], subTitleText: [{
2185
+ type: Input
2186
+ }], hasTopBarMenuButton: [{
2187
+ type: Input
2188
+ }], profileIcon: [{
2189
+ type: Input
2190
+ }], toggleIcon: [{
2191
+ type: Input
2192
+ }], navToggleAlign: [{
2193
+ type: Input
2194
+ }] } });
2195
+
2196
+ class TheSeamTopBarModule {
2197
+ }
2198
+ TheSeamTopBarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamTopBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2199
+ TheSeamTopBarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamTopBarModule, declarations: [TheSeamTopBarComponent,
2200
+ TopBarTitleComponent,
2201
+ TopBarMenuButtonComponent,
2202
+ TopBarMenuDirective,
2203
+ TopBarItemDirective,
2204
+ TopBarMenuBtnDetailDirective,
2205
+ TopBarCompactMenuBtnDetailDirective,
2206
+ TopBarNavToggleBtnDetailDirective], imports: [CommonModule,
2207
+ TheSeamLayoutModule,
2208
+ TheSeamButtonsModule,
2209
+ TheSeamIconModule,
2210
+ TheSeamMenuModule,
2211
+ TheSeamBaseLayoutModule,
2212
+ RouterModule], exports: [TheSeamTopBarComponent,
2213
+ TopBarMenuButtonComponent,
2214
+ TopBarMenuDirective,
2215
+ TheSeamMenuModule,
2216
+ TopBarItemDirective,
2217
+ TopBarMenuBtnDetailDirective,
2218
+ TopBarCompactMenuBtnDetailDirective,
2219
+ TopBarNavToggleBtnDetailDirective] });
2220
+ TheSeamTopBarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamTopBarModule, imports: [CommonModule,
2221
+ TheSeamLayoutModule,
2222
+ TheSeamButtonsModule,
2223
+ TheSeamIconModule,
2224
+ TheSeamMenuModule,
2225
+ TheSeamBaseLayoutModule,
2226
+ RouterModule, TheSeamMenuModule] });
2227
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamTopBarModule, decorators: [{
2228
+ type: NgModule,
2229
+ args: [{
2230
+ declarations: [
2231
+ TheSeamTopBarComponent,
2232
+ TopBarTitleComponent,
2233
+ TopBarMenuButtonComponent,
2234
+ TopBarMenuDirective,
2235
+ TopBarItemDirective,
2236
+ TopBarMenuBtnDetailDirective,
2237
+ TopBarCompactMenuBtnDetailDirective,
2238
+ TopBarNavToggleBtnDetailDirective
2239
+ ],
2240
+ imports: [
2241
+ CommonModule,
2242
+ TheSeamLayoutModule,
2243
+ TheSeamButtonsModule,
2244
+ TheSeamIconModule,
2245
+ TheSeamMenuModule,
2246
+ TheSeamBaseLayoutModule,
2247
+ RouterModule
2248
+ ],
2249
+ exports: [
2250
+ TheSeamTopBarComponent,
2251
+ TopBarMenuButtonComponent,
2252
+ TopBarMenuDirective,
2253
+ TheSeamMenuModule,
2254
+ TopBarItemDirective,
2255
+ TopBarMenuBtnDetailDirective,
2256
+ TopBarCompactMenuBtnDetailDirective,
2257
+ TopBarNavToggleBtnDetailDirective
2258
+ ]
2259
+ }]
2260
+ }] });
2261
+
2262
+ const fader = trigger('routeAnimations', [
2263
+ transition('* <=> *', [
2264
+ // Set a default style for enter and leave
2265
+ query(':enter, :leave', [
2266
+ style({
2267
+ position: 'absolute',
2268
+ left: 0,
2269
+ width: '100%',
2270
+ opacity: 0,
2271
+ transform: 'scale(0) translateY(100%)',
2272
+ }),
2273
+ ], { optional: true }),
2274
+ // Animate the new page in
2275
+ query(':enter', [
2276
+ animate('600ms ease', style({ opacity: 1, transform: 'scale(1) translateY(0)' })),
2277
+ ], { optional: true })
2278
+ ]),
2279
+ ]);
2280
+ // function slideTo(direction) {
2281
+ // return [
2282
+ // query(':enter, :leave', [
2283
+ // style({
2284
+ // position: 'absolute',
2285
+ // top: 0,
2286
+ // [direction]: 0,
2287
+ // width: '100%'
2288
+ // })
2289
+ // ], { optional: true }),
2290
+ // query(':enter', [
2291
+ // style({ [direction]: '-100%'})
2292
+ // ], { optional: true }),
2293
+ // group([
2294
+ // query(':leave', [
2295
+ // animate('1000ms ease', style({ [direction]: '100%'}))
2296
+ // ], { optional: true }),
2297
+ // query(':enter', [
2298
+ // animate('1000ms ease', style({ [direction]: '0%'}))
2299
+ // ], { optional: true })
2300
+ // ]),
2301
+ // // Normalize the page style... Might not be necessary
2302
+ // // Required only if you have child animations on the page
2303
+ // query(':leave', animateChild(), { optional: true }),
2304
+ // query(':enter', animateChild(), { optional: true }),
2305
+ // ]
2306
+ // }
2307
+ // TODO: Refactor the slider animation, because AOT or ng-packagr, I haven't
2308
+ // looked into what exactly is preventing it, doesn't allow the function call.
2309
+ // export const slider =
2310
+ // trigger('routeAnimations', [
2311
+ // transition('* => isLeft', slideTo('left') ),
2312
+ // transition('* => isRight', slideTo('right') ),
2313
+ // transition('isRight => *', slideTo('left') ),
2314
+ // transition('isLeft => *', slideTo('right') )
2315
+ // ])
2316
+ // export const contentLeave =
2317
+ // trigger('contentLeave', [
2318
+ // transition(':leave', [
2319
+ // ])
2320
+ // ])
2321
+ const slider = trigger('routeAnimations', [
2322
+ transition('* => isLeft', [
2323
+ query('.router-container :enter, .router-container :leave', [
2324
+ style({
2325
+ position: 'absolute',
2326
+ top: 0,
2327
+ left: 0,
2328
+ width: '100%'
2329
+ })
2330
+ ], { optional: true }),
2331
+ query('.router-container :enter', [
2332
+ style({ left: '-100%' })
2333
+ ], { optional: true }),
2334
+ query('.hierarchy-router-outlet--content', [
2335
+ style({ left: '0%', position: 'absolute' })
2336
+ ], { optional: true }),
2337
+ group([
2338
+ query('.router-container :leave', [
2339
+ animate('1000ms ease', style({ left: '100%' }))
2340
+ ], { optional: true }),
2341
+ query('.router-container :enter', [
2342
+ animate('1000ms ease', style({ left: '0%' }))
2343
+ ], { optional: true }),
2344
+ query('.hierarchy-router-outlet--content', [
2345
+ animate('1000ms ease', style({ left: '-100%' }))
2346
+ ], { optional: true }),
2347
+ ]),
2348
+ // Normalize the page style... Might not be necessary
2349
+ // Required only if you have child animations on the page
2350
+ query('.router-container :leave', animateChild(), { optional: true }),
2351
+ query('.router-container :enter', animateChild(), { optional: true }),
2352
+ ]),
2353
+ transition('* => isRight', [
2354
+ query('.router-container :enter, .router-container :leave', [
2355
+ style({
2356
+ position: 'absolute',
2357
+ top: 0,
2358
+ right: 0,
2359
+ width: '100%'
2360
+ })
2361
+ ], { optional: true }),
2362
+ query('.router-container :enter', [
2363
+ style({ right: '-100%' })
2364
+ ], { optional: true }),
2365
+ query('.hierarchy-router-outlet--content', [
2366
+ style({ left: '0%', position: 'absolute' })
2367
+ ], { optional: true }),
2368
+ group([
2369
+ query('.router-container :leave', [
2370
+ animate('1000ms ease', style({ right: '100%' }))
2371
+ ], { optional: true }),
2372
+ query('.router-container :enter', [
2373
+ animate('1000ms ease', style({ right: '0%' }))
2374
+ ], { optional: true }),
2375
+ query('.hierarchy-router-outlet--content', [
2376
+ animate('1000ms ease', style({ left: '-100%' }))
2377
+ ], { optional: true }),
2378
+ ]),
2379
+ // Normalize the page style... Might not be necessary
2380
+ // Required only if you have child animations on the page
2381
+ query('.router-container :leave', animateChild(), { optional: true }),
2382
+ query('.router-container :enter', animateChild(), { optional: true }),
2383
+ ]),
2384
+ transition('isRight => *', [
2385
+ query('.router-container :enter, .router-container :leave', [
2386
+ style({
2387
+ position: 'absolute',
2388
+ top: 0,
2389
+ left: 0,
2390
+ width: '100%'
2391
+ })
2392
+ ], { optional: true }),
2393
+ query('.router-container :enter', [
2394
+ style({ left: '-100%' })
2395
+ ], { optional: true }),
2396
+ query('.hierarchy-router-outlet--content', [
2397
+ style({ left: '0%', position: 'absolute' })
2398
+ ], { optional: true }),
2399
+ group([
2400
+ query('.router-container :leave', [
2401
+ animate('1000ms ease', style({ left: '100%' }))
2402
+ ], { optional: true }),
2403
+ query('.router-container :enter', [
2404
+ animate('1000ms ease', style({ left: '0%' }))
2405
+ ], { optional: true }),
2406
+ query('.hierarchy-router-outlet--content', [
2407
+ animate('1000ms ease', style({ left: '-100%' }))
2408
+ ], { optional: true }),
2409
+ ]),
2410
+ // Normalize the page style... Might not be necessary
2411
+ // Required only if you have child animations on the page
2412
+ query('.router-container :leave', animateChild(), { optional: true }),
2413
+ query('.router-container :enter', animateChild(), { optional: true }),
2414
+ ]),
2415
+ transition('isLeft => *', [
2416
+ query('.router-container :enter, .router-container :leave', [
2417
+ style({
2418
+ position: 'absolute',
2419
+ top: 0,
2420
+ right: 0,
2421
+ width: '100%'
2422
+ })
2423
+ ], { optional: true }),
2424
+ query('.router-container :enter', [
2425
+ style({ right: '-100%' })
2426
+ ], { optional: true }),
2427
+ group([
2428
+ query('.router-container :leave', [
2429
+ animate('1000ms ease', style({ right: '100%' }))
2430
+ ], { optional: true }),
2431
+ query('.router-container :enter', [
2432
+ animate('1000ms ease', style({ right: '0%' }))
2433
+ ], { optional: true })
2434
+ ]),
2435
+ // Normalize the page style... Might not be necessary
2436
+ // Required only if you have child animations on the page
2437
+ query('.router-container :leave', animateChild(), { optional: true }),
2438
+ query('.router-container :enter', animateChild(), { optional: true }),
2439
+ ])
2440
+ ]);
2441
+ const transformer = trigger('routeAnimations', [
2442
+ transition('* => isLeft', transformTo({ x: -100, y: -100, rotate: -720 })),
2443
+ transition('* => isRight', transformTo({ x: 100, y: -100, rotate: 90 })),
2444
+ transition('isRight => *', transformTo({ x: -100, y: -100, rotate: 360 })),
2445
+ transition('isLeft => *', transformTo({ x: 100, y: -100, rotate: -360 }))
2446
+ ]);
2447
+ function transformTo({ x = 100, y = 0, rotate = 0 }) {
2448
+ const optional = { optional: true };
2449
+ return [
2450
+ query(':enter, :leave', [
2451
+ style({
2452
+ position: 'absolute',
2453
+ top: 0,
2454
+ left: 0,
2455
+ width: '100%'
2456
+ })
2457
+ ], optional),
2458
+ query(':enter', [
2459
+ style({ transform: `translate(${x}%, ${y}%) rotate(${rotate}deg)` })
2460
+ ], { optional: true }),
2461
+ group([
2462
+ query(':leave', [
2463
+ animate('600ms ease-out', style({ transform: `translate(${x}%, ${y}%) rotate(${rotate}deg)` }))
2464
+ ], optional),
2465
+ query(':enter', [
2466
+ animate('600ms ease-out', style({ transform: `translate(0, 0) rotate(0)` }))
2467
+ ], { optional: true })
2468
+ ]),
2469
+ ];
2470
+ }
2471
+ const stepper = trigger('routeAnimations', [
2472
+ transition('* <=> *', [
2473
+ query(':enter, :leave', [
2474
+ style({
2475
+ position: 'absolute',
2476
+ left: 0,
2477
+ width: '100%',
2478
+ }),
2479
+ ], { optional: true }),
2480
+ group([
2481
+ query(':enter', [
2482
+ animate('2000ms ease', keyframes([
2483
+ style({ transform: 'scale(0) translateX(100%)', offset: 0 }),
2484
+ style({ transform: 'scale(0.5) translateX(25%)', offset: 0.3 }),
2485
+ style({ transform: 'scale(1) translateX(0%)', offset: 1 }),
2486
+ ])),
2487
+ ], { optional: true }),
2488
+ query(':leave', [
2489
+ animate('2000ms ease', keyframes([
2490
+ style({ transform: 'scale(1)', offset: 0 }),
2491
+ style({ transform: 'scale(0.5) translateX(-25%) rotate(0)', offset: 0.35 }),
2492
+ style({ opacity: 0, transform: 'translateX(-50%) rotate(-180deg) scale(6)', offset: 1 }),
2493
+ ])),
2494
+ ], { optional: true })
2495
+ ]),
2496
+ ])
2497
+ ]);
2498
+ const sideToSide = trigger('routeAnimations', [
2499
+ transition('* => *', [
2500
+ style({
2501
+ position: 'fixed',
2502
+ width: '100%',
2503
+ transform: 'translateX(-100%)'
2504
+ }),
2505
+ animate('1000ms ease', style({ transform: 'translateX(0%)' }))
2506
+ ]),
2507
+ transition(':leave', [
2508
+ style({
2509
+ position: 'fixed',
2510
+ width: '100%',
2511
+ transform: 'translateX(0%)'
2512
+ }),
2513
+ animate('1000ms ease', style({ transform: 'translateX(-100%)' }))
2514
+ ])
2515
+ ]);
2516
+
2517
+ function routeChanges(router) {
2518
+ return router.events.pipe(filter(event => event instanceof NavigationStart || event instanceof NavigationEnd), distinctUntilChanged((x, y) => x.id === y.id), map(event => ({ url: event.url })));
2519
+ }
2520
+ //
2521
+ // TODO: Animation improvement: Try adding a full component animation that
2522
+ // queries the <ng-content> and <router-outlet> blocks. When the outlet
2523
+ // activates, set the animation state to a transition that moves both blocks
2524
+ // together.
2525
+ //
2526
+ let _uid = 0;
2527
+ class HierarchyRouterOutletComponent {
2528
+ constructor(_route, _router) {
2529
+ this._route = _route;
2530
+ this._router = _router;
2531
+ this._uid = _uid++;
2532
+ this._ngUnsubscribe = new Subject();
2533
+ this.animState = 'isRight';
2534
+ // animState = ''
2535
+ this.outletActive = false;
2536
+ this.ngContentVisible = true;
2537
+ this._router.events.pipe(filter(event => event instanceof NavigationEnd),
2538
+ // tap(v => console.log(`_hasChildren()[${this._uid}]`, this._hasChildren())),
2539
+ takeUntil(this._ngUnsubscribe))
2540
+ .subscribe();
2541
+ // routeChanges(this._router)
2542
+ // .pipe(
2543
+ // untilDestroyed(this),
2544
+ // tap(() => {
2545
+ // // if (this._hasChildren()) {
2546
+ // // this.animState = 'isLeft'
2547
+ // // } else {
2548
+ // // this.animState = 'isRight'
2549
+ // // }
2550
+ // })
2551
+ // )
2552
+ // .subscribe(v => console.log(`routeChanges[${this._uid}]`, v))
2553
+ }
2554
+ ngOnDestroy() {
2555
+ this._ngUnsubscribe.next(undefined);
2556
+ this._ngUnsubscribe.complete();
2557
+ }
2558
+ _hasChildren() {
2559
+ const count = this._route.pathFromRoot.length - 1;
2560
+ let countFull = 0;
2561
+ if (this._router.parseUrl(this._router.url).root.children.primary) {
2562
+ countFull = this._router.parseUrl(this._router.url).root.children.primary.segments.length;
2563
+ }
2564
+ // console.log(`_hasChildren[${this._uid}]`, { count, countFull })
2565
+ return countFull > count;
2566
+ }
2567
+ prepareRoute(outlet) {
2568
+ // console.log(`outlet[${this._uid}]`, outlet, this.animState, this._hasChildren(), this.outletActive)
2569
+ if (outlet.isActivated) {
2570
+ // console.log(outlet.isActivated)
2571
+ // console.log(outlet.component)
2572
+ // console.log(this.animState)
2573
+ return this.animState;
2574
+ }
2575
+ else {
2576
+ return undefined;
2577
+ }
2578
+ // console.log(`prepareRoute[${this._uid}]`, this.animState, this._hasChildren())
2579
+ // console.log('activatedRouteData', outlet && outlet.activatedRouteData)
2580
+ // if (outlet && outlet.isActivated) {
2581
+ // console.log('activatedRoute', outlet.activatedRoute && outlet.activatedRoute.snapshot.url)
2582
+ // }
2583
+ // return outlet && outlet.activatedRouteData && outlet.activatedRouteData['animation']
2584
+ // console.log('')
2585
+ // return this.animState
2586
+ }
2587
+ outletActivate(event) {
2588
+ // console.log(`outletActivate[${this._uid}]`, event)
2589
+ this.outletActive = true;
2590
+ }
2591
+ outletDeactivate(event) {
2592
+ // console.log(`outletDeactivate[${this._uid}]`, event)
2593
+ this.outletActive = false;
2594
+ }
2595
+ routeAnimationsStart(event) {
2596
+ // console.log('routeAnimationsStart', event)
2597
+ this.ngContentVisible = true;
2598
+ }
2599
+ routeAnimationsDone(event) {
2600
+ // console.log('routeAnimationsDone', event)
2601
+ this.ngContentVisible = !this.outletActive;
2602
+ }
2603
+ }
2604
+ HierarchyRouterOutletComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HierarchyRouterOutletComponent, deps: [{ token: i1$2.ActivatedRoute }, { token: i1$2.Router }], target: i0.ɵɵFactoryTarget.Component });
2605
+ HierarchyRouterOutletComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: HierarchyRouterOutletComponent, selector: "seam-hierarchy-router-outlet", ngImport: i0, template: "<div class=\"h-100\"\n [@routeAnimations]=\"prepareRoute(outlet)\"\n (@routeAnimations.start)=\"routeAnimationsStart($event)\"\n (@routeAnimations.done)=\"routeAnimationsDone($event)\">\n <div class=\"hierarchy-router-outlet--content h-100\" *ngIf=\"ngContentVisible\">\n <!-- {{ animState }} -->\n <div class=\"border border-info h-100\">\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"router-container\"\n [class.h-100]=\"!ngContentVisible\"\n >\n <!-- <div [@routeAnimations]=\"animState\"> -->\n <!-- <div class=\"hierarchy-router-outlet--route-content\"> -->\n <router-outlet #outlet=\"outlet\"\n (activate)=\"outletActivate($event)\"\n (deactivate)=\"outletDeactivate($event)\">\n </router-outlet>\n </div>\n</div>\n", styles: [":host{display:block;height:100%}:host ::ng-deep router-outlet+*{background-color:#fff;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], animations: [
2606
+ // fader,
2607
+ slider,
2608
+ // transformer,
2609
+ // stepper,
2610
+ // sideToSide
2611
+ // contentLeave
2612
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2613
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HierarchyRouterOutletComponent, decorators: [{
2614
+ type: Component,
2615
+ args: [{ selector: 'seam-hierarchy-router-outlet', animations: [
2616
+ // fader,
2617
+ slider,
2618
+ // transformer,
2619
+ // stepper,
2620
+ // sideToSide
2621
+ // contentLeave
2622
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"h-100\"\n [@routeAnimations]=\"prepareRoute(outlet)\"\n (@routeAnimations.start)=\"routeAnimationsStart($event)\"\n (@routeAnimations.done)=\"routeAnimationsDone($event)\">\n <div class=\"hierarchy-router-outlet--content h-100\" *ngIf=\"ngContentVisible\">\n <!-- {{ animState }} -->\n <div class=\"border border-info h-100\">\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"router-container\"\n [class.h-100]=\"!ngContentVisible\"\n >\n <!-- <div [@routeAnimations]=\"animState\"> -->\n <!-- <div class=\"hierarchy-router-outlet--route-content\"> -->\n <router-outlet #outlet=\"outlet\"\n (activate)=\"outletActivate($event)\"\n (deactivate)=\"outletDeactivate($event)\">\n </router-outlet>\n </div>\n</div>\n", styles: [":host{display:block;height:100%}:host ::ng-deep router-outlet+*{background-color:#fff;height:100%}\n"] }]
2623
+ }], ctorParameters: function () { return [{ type: i1$2.ActivatedRoute }, { type: i1$2.Router }]; } });
2624
+
2625
+ class HierarchyLevelResolver {
2626
+ resolve(route, state) {
2627
+ // console.log('[HierarchyLevelResolver]', route)
2628
+ // console.log('[HierarchyLevelResolver]', state)
2629
+ return this._getMaxHierLevel(route);
2630
+ }
2631
+ _getMaxHierLevel(route) {
2632
+ let curr = route;
2633
+ while (curr.parent) {
2634
+ curr = curr.parent;
2635
+ if (curr.data['hierLevel']) {
2636
+ return curr.data['hierLevel'] + 1;
2637
+ }
2638
+ }
2639
+ return 0;
2640
+ }
2641
+ }
2642
+ HierarchyLevelResolver.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HierarchyLevelResolver, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2643
+ HierarchyLevelResolver.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HierarchyLevelResolver, providedIn: 'root' });
2644
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HierarchyLevelResolver, decorators: [{
2645
+ type: Injectable,
2646
+ args: [{ providedIn: 'root' }]
2647
+ }] });
2648
+
2649
+ class TheSeamDynamicRouterModule {
2650
+ }
2651
+ TheSeamDynamicRouterModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDynamicRouterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2652
+ TheSeamDynamicRouterModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDynamicRouterModule, declarations: [HierarchyRouterOutletComponent], imports: [CommonModule,
2653
+ RouterModule], exports: [HierarchyRouterOutletComponent] });
2654
+ TheSeamDynamicRouterModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDynamicRouterModule, imports: [CommonModule,
2655
+ RouterModule] });
2656
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamDynamicRouterModule, decorators: [{
2657
+ type: NgModule,
2658
+ args: [{
2659
+ declarations: [
2660
+ HierarchyRouterOutletComponent
2661
+ ],
2662
+ imports: [
2663
+ CommonModule,
2664
+ RouterModule
2665
+ ],
2666
+ exports: [
2667
+ HierarchyRouterOutletComponent
2668
+ ]
2669
+ }]
2670
+ }] });
2671
+
2672
+ class TheSeamSchemaFormCheckboxComponent {
2673
+ constructor(jsf) {
2674
+ this.jsf = jsf;
2675
+ this.controlDisabled = false;
2676
+ this.boundControl = false;
2677
+ this.trueValue = true;
2678
+ this.falseValue = false;
2679
+ }
2680
+ ngOnInit() {
2681
+ this.options = this.layoutNode.options || {};
2682
+ this.jsf.initializeControl(this);
2683
+ if (this.controlValue === null || this.controlValue === undefined) {
2684
+ this.controlValue = this.options.title;
2685
+ }
2686
+ }
2687
+ updateValue(event) {
2688
+ event.preventDefault();
2689
+ this.jsf.updateValue(this, event.target.checked ? this.trueValue : this.falseValue);
2690
+ }
2691
+ get isChecked() {
2692
+ return this.jsf.getFormControlValue(this) === this.trueValue;
2693
+ }
2694
+ }
2695
+ TheSeamSchemaFormCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormCheckboxComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2696
+ TheSeamSchemaFormCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormCheckboxComponent, selector: "seam-schema-form-checkbox", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div class=\"mb-3\">\n <seam-form-field *ngIf=\"boundControl\">\n <seam-checkbox seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </seam-checkbox>\n </seam-form-field>\n\n <seam-form-field *ngIf=\"!boundControl\">\n <seam-checkbox seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [value]=\"controlValue\"\n (change)=\"updateValue($event)\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </seam-checkbox>\n </seam-form-field>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4$3.TheSeamFormFieldComponent, selector: "seam-form-field", inputs: ["inline", "label", "labelPosition", "labelClass", "maxErrors", "numPaddingErrors", "labelId", "helpText", "helpTextId"] }, { kind: "component", type: i4$3.FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: ["required"] }, { kind: "component", type: i5$1.TheSeamCheckboxComponent, selector: "seam-checkbox", inputs: ["tabIndex", "id", "aria-label", "aria-labelledby", "required", "checked", "disabled", "indeterminate", "name", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["seamCheckbox"] }] });
2697
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormCheckboxComponent, decorators: [{
2698
+ type: Component,
2699
+ args: [{ selector: 'seam-schema-form-checkbox', template: "<div class=\"mb-3\">\n <seam-form-field *ngIf=\"boundControl\">\n <seam-checkbox seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </seam-checkbox>\n </seam-form-field>\n\n <seam-form-field *ngIf=\"!boundControl\">\n <seam-checkbox seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [value]=\"controlValue\"\n (change)=\"updateValue($event)\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </seam-checkbox>\n </seam-form-field>\n</div>\n" }]
2700
+ }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2701
+ type: Input
2702
+ }], layoutIndex: [{
2703
+ type: Input
2704
+ }], dataIndex: [{
2705
+ type: Input
2706
+ }] } });
2707
+
2708
+ class TheSeamSchemaFormInputComponent {
2709
+ constructor(jsf) {
2710
+ this.jsf = jsf;
2711
+ this.controlDisabled = false;
2712
+ this.boundControl = false;
2713
+ this.autoCompleteList = [];
2714
+ }
2715
+ ngOnInit() {
2716
+ this.options = this.layoutNode.options || {};
2717
+ this.jsf.initializeControl(this);
2718
+ }
2719
+ updateValue(event) {
2720
+ this.jsf.updateValue(this, event.target.value);
2721
+ }
2722
+ }
2723
+ TheSeamSchemaFormInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormInputComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2724
+ TheSeamSchemaFormInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormInputComponent, selector: "seam-schema-form-input", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<seam-form-field *ngIf=\"boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type\">\n <datalist *ngIf=\"options?.typeahead?.source\"\n [id]=\"'control' + layoutNode?._id + 'Autocomplete'\">\n <option *ngFor=\"let word of options?.typeahead?.source\" [value]=\"word\">\n </datalist>\n</seam-form-field>\n\n<seam-form-field *ngIf=\"!boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [value]=\"controlValue\"\n (input)=\"updateValue($event)\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type\"\n [disabled]=\"controlDisabled\">\n <datalist *ngIf=\"options?.typeahead?.source\"\n [id]=\"'control' + layoutNode?._id + 'Autocomplete'\">\n <option *ngFor=\"let word of options?.typeahead?.source\" [value]=\"word\">\n </datalist>\n</seam-form-field>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3$3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3$3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3$3.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i3$3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3$3.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i3$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4$3.TheSeamFormFieldComponent, selector: "seam-form-field", inputs: ["inline", "label", "labelPosition", "labelClass", "maxErrors", "numPaddingErrors", "labelId", "helpText", "helpTextId"] }, { kind: "directive", type: i4$3.InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: ["seamInputSize", "id", "type", "placeholder", "required", "disabled", "readonly"], exportAs: ["seamInput"] }, { kind: "directive", type: i4$3.FormFieldLabelTplDirective, selector: "[seamFormFieldLabelTpl]" }, { kind: "component", type: i4$3.FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: ["required"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2725
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormInputComponent, decorators: [{
2726
+ type: Component,
2727
+ args: [{ selector: 'seam-schema-form-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-form-field *ngIf=\"boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type\">\n <datalist *ngIf=\"options?.typeahead?.source\"\n [id]=\"'control' + layoutNode?._id + 'Autocomplete'\">\n <option *ngFor=\"let word of options?.typeahead?.source\" [value]=\"word\">\n </datalist>\n</seam-form-field>\n\n<seam-form-field *ngIf=\"!boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [value]=\"controlValue\"\n (input)=\"updateValue($event)\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type\"\n [disabled]=\"controlDisabled\">\n <datalist *ngIf=\"options?.typeahead?.source\"\n [id]=\"'control' + layoutNode?._id + 'Autocomplete'\">\n <option *ngFor=\"let word of options?.typeahead?.source\" [value]=\"word\">\n </datalist>\n</seam-form-field>\n", styles: [":host{display:block}\n"] }]
2728
+ }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2729
+ type: Input
2730
+ }], layoutIndex: [{
2731
+ type: Input
2732
+ }], dataIndex: [{
2733
+ type: Input
2734
+ }] } });
2735
+
2736
+ class TheSeamSchemaFormNumberComponent {
2737
+ constructor(jsf) {
2738
+ this.jsf = jsf;
2739
+ this.controlDisabled = false;
2740
+ this.boundControl = false;
2741
+ this.allowNegative = true;
2742
+ this.allowDecimal = true;
2743
+ this.allowExponents = false;
2744
+ this.lastValidNumber = '';
2745
+ }
2746
+ ngOnInit() {
2747
+ this.options = this.layoutNode.options || {};
2748
+ this.jsf.initializeControl(this);
2749
+ if (this.layoutNode.dataType === 'integer') {
2750
+ this.allowDecimal = false;
2751
+ }
2752
+ }
2753
+ updateValue(event) {
2754
+ this.jsf.updateValue(this, event.target.value);
2755
+ }
2756
+ }
2757
+ TheSeamSchemaFormNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormNumberComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2758
+ TheSeamSchemaFormNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormNumberComponent, selector: "seam-schema-form-number", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<seam-form-field *ngIf=\"boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [attr.max]=\"options?.maximum\"\n [attr.min]=\"options?.minimum\"\n [attr.step]=\"options?.multipleOf || options?.step || 'any'\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type === 'range' ? 'range' : 'number'\">\n <span *ngIf=\"layoutNode?.type === 'range'\" [innerHTML]=\"controlValue\"></span>\n</seam-form-field>\n\n<seam-form-field *ngIf=\"!boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [attr.max]=\"options?.maximum\"\n [attr.min]=\"options?.minimum\"\n [attr.step]=\"options?.multipleOf || options?.step || 'any'\"\n [value]=\"controlValue\"\n (input)=\"updateValue($event)\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type === 'range' ? 'range' : 'number'\"\n [disabled]=\"controlDisabled\">\n <span *ngIf=\"layoutNode?.type === 'range'\" [innerHTML]=\"controlValue\"></span>\n</seam-form-field>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3$3.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i3$3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3$3.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i3$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4$3.TheSeamFormFieldComponent, selector: "seam-form-field", inputs: ["inline", "label", "labelPosition", "labelClass", "maxErrors", "numPaddingErrors", "labelId", "helpText", "helpTextId"] }, { kind: "directive", type: i4$3.InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: ["seamInputSize", "id", "type", "placeholder", "required", "disabled", "readonly"], exportAs: ["seamInput"] }, { kind: "directive", type: i4$3.FormFieldLabelTplDirective, selector: "[seamFormFieldLabelTpl]" }, { kind: "component", type: i4$3.FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: ["required"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2759
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormNumberComponent, decorators: [{
2760
+ type: Component,
2761
+ args: [{ selector: 'seam-schema-form-number', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-form-field *ngIf=\"boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [attr.max]=\"options?.maximum\"\n [attr.min]=\"options?.minimum\"\n [attr.step]=\"options?.multipleOf || options?.step || 'any'\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type === 'range' ? 'range' : 'number'\">\n <span *ngIf=\"layoutNode?.type === 'range'\" [innerHTML]=\"controlValue\"></span>\n</seam-form-field>\n\n<seam-form-field *ngIf=\"!boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <input seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [attr.max]=\"options?.maximum\"\n [attr.min]=\"options?.minimum\"\n [attr.step]=\"options?.multipleOf || options?.step || 'any'\"\n [value]=\"controlValue\"\n (input)=\"updateValue($event)\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.list]=\"'control' + layoutNode?._id + 'Autocomplete'\"\n [attr.maxlength]=\"options?.maxLength\"\n [attr.minlength]=\"options?.minLength\"\n [attr.pattern]=\"options?.pattern\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\"\n [type]=\"layoutNode?.type === 'range' ? 'range' : 'number'\"\n [disabled]=\"controlDisabled\">\n <span *ngIf=\"layoutNode?.type === 'range'\" [innerHTML]=\"controlValue\"></span>\n</seam-form-field>\n", styles: [":host{display:block}\n"] }]
2762
+ }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2763
+ type: Input
2764
+ }], layoutIndex: [{
2765
+ type: Input
2766
+ }], dataIndex: [{
2767
+ type: Input
2768
+ }] } });
2769
+
2770
+ class TheSeamSchemaFormSelectComponent {
2771
+ constructor(jsf) {
2772
+ this.jsf = jsf;
2773
+ this.controlDisabled = false;
2774
+ this.boundControl = false;
2775
+ this.selectList = [];
2776
+ this.isArray = isArray;
2777
+ }
2778
+ ngOnInit() {
2779
+ this.options = this.layoutNode.options || {};
2780
+ this.selectList = buildTitleMap(this.options.titleMap || this.options.enumNames, this.options.enum, !!this.options.required, !!this.options.flatList);
2781
+ this.jsf.initializeControl(this);
2782
+ }
2783
+ updateValue(event) {
2784
+ this.jsf.updateValue(this, event.value);
2785
+ }
2786
+ }
2787
+ TheSeamSchemaFormSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormSelectComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2788
+ TheSeamSchemaFormSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormSelectComponent, selector: "seam-schema-form-select", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<seam-form-field *ngIf=\"boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <ng-select seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [required]=\"options?.required\"\n [items]=\"selectList\"\n bindLabel=\"name\"\n bindValue=\"value\"\n [clearable]=\"false\"\n appendTo=\"body\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? true : false\">\n <ng-template ng-label-tmp let-item=\"item\">\n <span [innerHTML]=\"item.name\"></span>\n </ng-template>\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\n <span [innerHTML]=\"item.name\"></span>\n </ng-template>\n </ng-select>\n</seam-form-field>\n\n<seam-form-field *ngIf=\"!boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <ng-select seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [required]=\"options?.required\"\n [items]=\"selectList\"\n bindLabel=\"name\"\n bindValue=\"value\"\n [clearable]=\"false\"\n (change)=\"updateValue($event)\"\n appendTo=\"body\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? true : false\"\n [disabled]=\"controlDisabled\">\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\n <span [innerHTML]=\"item.name\"></span>\n </ng-template>\n </ng-select>\n</seam-form-field>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4$3.TheSeamFormFieldComponent, selector: "seam-form-field", inputs: ["inline", "label", "labelPosition", "labelClass", "maxErrors", "numPaddingErrors", "labelId", "helpText", "helpTextId"] }, { kind: "directive", type: i4$3.InputDirective, selector: "input[seamInput], textarea[seamInput], ng-select[seamInput], seam-checkbox[seamInput] [ngbRadioGroup], seam-tel-input[seamInput], quill-editor[seamInput], seam-google-maps[seamInput]", inputs: ["seamInputSize", "id", "type", "placeholder", "required", "disabled", "readonly"], exportAs: ["seamInput"] }, { kind: "directive", type: i4$3.FormFieldLabelTplDirective, selector: "[seamFormFieldLabelTpl]" }, { kind: "component", type: i4$3.FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: ["required"] }, { kind: "component", type: i5$2.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i5$2.ɵf, selector: "[ng-option-tmp]" }, { kind: "directive", type: i5$2.ɵh, selector: "[ng-label-tmp]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2789
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormSelectComponent, decorators: [{
2790
+ type: Component,
2791
+ args: [{ selector: 'seam-schema-form-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-form-field *ngIf=\"boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <ng-select seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [required]=\"options?.required\"\n [items]=\"selectList\"\n bindLabel=\"name\"\n bindValue=\"value\"\n [clearable]=\"false\"\n appendTo=\"body\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? true : false\">\n <ng-template ng-label-tmp let-item=\"item\">\n <span [innerHTML]=\"item.name\"></span>\n </ng-template>\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\n <span [innerHTML]=\"item.name\"></span>\n </ng-template>\n </ng-select>\n</seam-form-field>\n\n<seam-form-field *ngIf=\"!boundControl\">\n <ng-template seamFormFieldLabelTpl let-required=\"required\">\n <ng-container *ngIf=\"!options?.notitle\">\n {{ options?.title }}<seam-form-field-required-indicator class=\"pl-1\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <ng-select seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [required]=\"options?.required\"\n [items]=\"selectList\"\n bindLabel=\"name\"\n bindValue=\"value\"\n [clearable]=\"false\"\n (change)=\"updateValue($event)\"\n appendTo=\"body\"\n\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.placeholder]=\"options?.placeholder\"\n [attr.required]=\"options?.required\"\n [readonly]=\"options?.readonly ? true : false\"\n [disabled]=\"controlDisabled\">\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\n <span [innerHTML]=\"item.name\"></span>\n </ng-template>\n </ng-select>\n</seam-form-field>\n", styles: [":host{display:block}\n"] }]
2792
+ }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2793
+ type: Input
2794
+ }], layoutIndex: [{
2795
+ type: Input
2796
+ }], dataIndex: [{
2797
+ type: Input
2798
+ }] } });
2799
+
2800
+ // NOTE: This component is a little hacky, because I am basically creating a
2801
+ // data widget that acts like a data and 'submit' widget at the same time.
2802
+ //
2803
+ // TODO: Try and think of a nicer way to implement this, but still make sense
2804
+ // from a schema definition. The library may need to me forked to actually
2805
+ // support this in the way I expect, but maybe there is another way.
2806
+ class TheSeamSchemaFormSubmitSplitComponent {
2807
+ constructor(jsf) {
2808
+ this.jsf = jsf;
2809
+ /** @ignore */
2810
+ this._ngUnsubscribe = new Subject();
2811
+ this.controlDisabled = false;
2812
+ this.boundControl = false;
2813
+ this._buttonLabel = '';
2814
+ this._dropdownDisabled = false;
2815
+ this._selectList = [];
2816
+ }
2817
+ /** @ignore */
2818
+ ngOnInit() {
2819
+ this.options = this.layoutNode.options || {};
2820
+ this.jsf.initializeControl(this);
2821
+ // NOTE: This is commented out, because there is a bug with submit widgets
2822
+ // manually defined in layout. All nodes initialized from the provided
2823
+ // layout have their options populated from the defaults and 'disabled' is
2824
+ // on of the default properties, so the 'disableInvalidSubmit' condition
2825
+ // never gets reached.
2826
+ //
2827
+ // My initial idea for fixing would be to check if the disabled property
2828
+ // exists and is a boolean, or possibly anything defined that can coerce
2829
+ // into a boolean. I can't think of a reason disabled should be anything
2830
+ // else, so that may be an acceptable fix, but I don't want to enable that
2831
+ // yet.
2832
+ //
2833
+ // if (hasOwn(this.options, 'disabled')) {
2834
+ // console.log('[TheSeamSchemaFormSubmitSplitComponent] hasDisabled', this.options.disabled)
2835
+ // this.controlDisabled = this.options.disabled
2836
+ // } else
2837
+ if (this.jsf.formOptions.disableInvalidSubmit) {
2838
+ this.controlDisabled = !this.jsf.isValid;
2839
+ this.jsf.isValidChanges.subscribe(isValid => this.controlDisabled = !isValid);
2840
+ }
2841
+ if (this.controlValue === null || this.controlValue === undefined) {
2842
+ this.controlValue = this.options.title;
2843
+ }
2844
+ if (hasOwn(this.options, 'title')) {
2845
+ this._buttonLabel = this.options.title;
2846
+ }
2847
+ this._initDropdown();
2848
+ // console.log('this', this)
2849
+ }
2850
+ /** @ignore */
2851
+ ngOnDestroy() {
2852
+ this._ngUnsubscribe.next(undefined);
2853
+ this._ngUnsubscribe.complete();
2854
+ }
2855
+ updateValue(event) {
2856
+ if (typeof this.options.onClick === 'function') {
2857
+ this.options.onClick(event);
2858
+ }
2859
+ else {
2860
+ this.jsf.updateValue(this, event.target.value);
2861
+ }
2862
+ }
2863
+ _initDropdown() {
2864
+ var _a;
2865
+ if (!hasOwn(this.layoutNode, 'items') || !(this.layoutNode.items || []).length) {
2866
+ return;
2867
+ }
2868
+ if (isDevMode()) {
2869
+ if (this.layoutNode.items.length > 1) {
2870
+ // eslint-disable-next-line no-console
2871
+ console.warn(`TheSeamSchemaFormSubmitSplitComponent only supports one item.` +
2872
+ ` items after index 0 will be ignored.`);
2873
+ }
2874
+ }
2875
+ const idx = 0;
2876
+ const item = this.layoutNode.items[idx];
2877
+ this._dropdownObj = {
2878
+ layoutNode: item,
2879
+ layoutIndex: (this.layoutIndex || []).concat(idx),
2880
+ dataIndex: ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.dataType) === 'array' ? (this.dataIndex || []).concat(idx) : this.dataIndex,
2881
+ options: item.options || {}
2882
+ };
2883
+ this.jsf.initializeControl(this._dropdownObj);
2884
+ const items = buildTitleMap(this._dropdownObj.options.titleMap || this._dropdownObj.options.enumNames, this._dropdownObj.options.enum, !!this._dropdownObj.options.required, !!this._dropdownObj.options.flatList);
2885
+ this._selectList = items;
2886
+ // TODO: Should this be checking if the control is bound?
2887
+ const dropdownControl = this._getDropdownControl();
2888
+ if (!dropdownControl) {
2889
+ return;
2890
+ }
2891
+ observeControlValue(dropdownControl).pipe(takeUntil(this._ngUnsubscribe)).subscribe(value => {
2892
+ this._setSelectListCheckedProp(value);
2893
+ this._selectedItem = this._getSelectedItem();
2894
+ });
2895
+ observeControlStatus(dropdownControl).pipe(takeUntil(this._ngUnsubscribe)).subscribe(value => {
2896
+ this._dropdownDisabled = dropdownControl.disabled;
2897
+ });
2898
+ }
2899
+ _getDropdownControl() {
2900
+ return this._dropdownObj.formControl;
2901
+ }
2902
+ _setSelectListCheckedProp(value) {
2903
+ const items = this._selectList;
2904
+ for (const item of items) {
2905
+ if (item.value === value) {
2906
+ item.checked = true;
2907
+ }
2908
+ else if (item.checked) {
2909
+ item.checked = false;
2910
+ }
2911
+ }
2912
+ this._selectList = [...items];
2913
+ }
2914
+ _getSelectedItem() {
2915
+ return (this._selectList || []).find(x => x.checked === true);
2916
+ }
2917
+ _setDropdownValue(value) {
2918
+ const formControl = this._getDropdownControl();
2919
+ formControl === null || formControl === void 0 ? void 0 : formControl.setValue(value);
2920
+ }
2921
+ }
2922
+ TheSeamSchemaFormSubmitSplitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormSubmitSplitComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2923
+ TheSeamSchemaFormSubmitSplitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormSubmitSplitComponent, selector: "seam-schema-form-submit-split", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div\n [class]=\"options?.htmlClass || ''\">\n <div [class.btn-group]=\"_dropdownObj\">\n <button seamButton theme=\"primary\" type=\"submit\"\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [attr.required]=\"options?.required\"\n [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n [disabled]=\"controlDisabled\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [value]=\"controlValue\"\n (click)=\"updateValue($event)\">\n {{ _buttonLabel }}\n <span *ngIf=\"_selectedItem\">\n [{{ _selectedItem.name }}]\n </span>\n </button>\n <ng-container *ngIf=\"_dropdownObj\">\n <button\n [seamMenuToggle]=\"menu\" seamButton theme=\"primary\"\n class=\"dropdown-toggle dropdown-toggle-split\"\n [disabled]=\"_dropdownDisabled\">\n <span class=\"sr-only\">Toggle Dropdown</span>\n </button>\n <seam-menu #menu>\n <ng-container *ngFor=\"let item of _selectList\">\n <button seamMenuItem\n [class.active]=\"item.checked\"\n (click)=\"_setDropdownValue(item.value)\">\n {{ item.name }}\n </button>\n </ng-container>\n </seam-menu>\n </ng-container>\n </div>\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$2.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i3$2.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions"], outputs: ["menuToggle"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i3$2.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "component", type: i4$1.ButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }] });
2924
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormSubmitSplitComponent, decorators: [{
2925
+ type: Component,
2926
+ args: [{ selector: 'seam-schema-form-submit-split', template: "<div\n [class]=\"options?.htmlClass || ''\">\n <div [class.btn-group]=\"_dropdownObj\">\n <button seamButton theme=\"primary\" type=\"submit\"\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [attr.required]=\"options?.required\"\n [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n [disabled]=\"controlDisabled\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [value]=\"controlValue\"\n (click)=\"updateValue($event)\">\n {{ _buttonLabel }}\n <span *ngIf=\"_selectedItem\">\n [{{ _selectedItem.name }}]\n </span>\n </button>\n <ng-container *ngIf=\"_dropdownObj\">\n <button\n [seamMenuToggle]=\"menu\" seamButton theme=\"primary\"\n class=\"dropdown-toggle dropdown-toggle-split\"\n [disabled]=\"_dropdownDisabled\">\n <span class=\"sr-only\">Toggle Dropdown</span>\n </button>\n <seam-menu #menu>\n <ng-container *ngFor=\"let item of _selectList\">\n <button seamMenuItem\n [class.active]=\"item.checked\"\n (click)=\"_setDropdownValue(item.value)\">\n {{ item.name }}\n </button>\n </ng-container>\n </seam-menu>\n </ng-container>\n </div>\n</div>\n", styles: [":host{display:block}\n"] }]
2927
+ }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2928
+ type: Input
2929
+ }], layoutIndex: [{
2930
+ type: Input
2931
+ }], dataIndex: [{
2932
+ type: Input
2933
+ }] } });
2934
+
2935
+ class TheSeamSchemaFormFrameworkComponent {
2936
+ }
2937
+ TheSeamSchemaFormFrameworkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormFrameworkComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2938
+ TheSeamSchemaFormFrameworkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormFrameworkComponent, selector: "seam-schema-form-framework", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<select-widget-widget\n [dataIndex]=\"$any(dataIndex)\"\n [layoutIndex]=\"$any(layoutIndex)\"\n [layoutNode]=\"layoutNode\">\n</select-widget-widget>\n", styles: [""], dependencies: [{ kind: "component", type: i1$3.SelectWidgetComponent, selector: "select-widget-widget", inputs: ["layoutNode", "layoutIndex", "dataIndex"] }] });
2939
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormFrameworkComponent, decorators: [{
2940
+ type: Component,
2941
+ args: [{ selector: 'seam-schema-form-framework', template: "<select-widget-widget\n [dataIndex]=\"$any(dataIndex)\"\n [layoutIndex]=\"$any(layoutIndex)\"\n [layoutNode]=\"layoutNode\">\n</select-widget-widget>\n" }]
2942
+ }], propDecorators: { layoutNode: [{
2943
+ type: Input
2944
+ }], layoutIndex: [{
2945
+ type: Input
2946
+ }], dataIndex: [{
2947
+ type: Input
2948
+ }] } });
2949
+
2950
+ class TheSeamFramework extends Framework {
2951
+ constructor() {
2952
+ super(...arguments);
2953
+ this.name = 'seam-framework';
2954
+ this.framework = TheSeamSchemaFormFrameworkComponent;
2955
+ this.widgets = {
2956
+ 'checkbox': TheSeamSchemaFormCheckboxComponent,
2957
+ // 'submit': TheSeamSchemaFormSubmitComponent,
2958
+ 'submit': TheSeamSchemaFormSubmitSplitComponent,
2959
+ 'text': TheSeamSchemaFormInputComponent,
2960
+ 'number': TheSeamSchemaFormNumberComponent,
2961
+ 'select': TheSeamSchemaFormSelectComponent
2962
+ };
2963
+ }
2964
+ }
2965
+ TheSeamFramework.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamFramework, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
2966
+ TheSeamFramework.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamFramework });
2967
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamFramework, decorators: [{
2968
+ type: Injectable
2969
+ }] });
2970
+
2971
+ class TheSeamSchemaFormSubmitComponent {
2972
+ constructor(jsf) {
2973
+ this.jsf = jsf;
2974
+ this.controlDisabled = false;
2975
+ this.boundControl = false;
2976
+ }
2977
+ ngOnInit() {
2978
+ this.options = this.layoutNode.options || {};
2979
+ this.jsf.initializeControl(this);
2980
+ if (hasOwn(this.options, 'disabled')) {
2981
+ this.controlDisabled = this.options.disabled;
2982
+ }
2983
+ else if (this.jsf.formOptions.disableInvalidSubmit) {
2984
+ this.controlDisabled = !this.jsf.isValid;
2985
+ this.jsf.isValidChanges.subscribe(isValid => this.controlDisabled = !isValid);
2986
+ }
2987
+ if (this.controlValue === null || this.controlValue === undefined) {
2988
+ this.controlValue = this.options.title;
2989
+ }
2990
+ }
2991
+ updateValue(event) {
2992
+ if (typeof this.options.onClick === 'function') {
2993
+ this.options.onClick(event);
2994
+ }
2995
+ else {
2996
+ this.jsf.updateValue(this, event.target.value);
2997
+ }
2998
+ }
2999
+ }
3000
+ TheSeamSchemaFormSubmitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormSubmitComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
3001
+ TheSeamSchemaFormSubmitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TheSeamSchemaFormSubmitComponent, selector: "seam-schema-form-submit", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div\n [class]=\"options?.htmlClass || ''\">\n <input\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [attr.required]=\"options?.required\"\n [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n [disabled]=\"controlDisabled\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [type]=\"layoutNode?.type\"\n [value]=\"controlValue\"\n (click)=\"updateValue($event)\">\n</div>\n" });
3002
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormSubmitComponent, decorators: [{
3003
+ type: Component,
3004
+ args: [{ selector: 'seam-schema-form-submit', template: "<div\n [class]=\"options?.htmlClass || ''\">\n <input\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [attr.required]=\"options?.required\"\n [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n [disabled]=\"controlDisabled\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [type]=\"layoutNode?.type\"\n [value]=\"controlValue\"\n (click)=\"updateValue($event)\">\n</div>\n" }]
3005
+ }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
3006
+ type: Input
3007
+ }], layoutIndex: [{
3008
+ type: Input
3009
+ }], dataIndex: [{
3010
+ type: Input
3011
+ }] } });
3012
+
3013
+ const controls = [
3014
+ TheSeamSchemaFormCheckboxComponent,
3015
+ TheSeamSchemaFormSubmitComponent,
3016
+ TheSeamSchemaFormSelectComponent,
3017
+ TheSeamSchemaFormInputComponent,
3018
+ TheSeamSchemaFormNumberComponent,
3019
+ TheSeamSchemaFormSubmitSplitComponent
3020
+ ];
3021
+ class TheSeamSchemaFormControlsModule {
3022
+ }
3023
+ TheSeamSchemaFormControlsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormControlsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3024
+ TheSeamSchemaFormControlsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormControlsModule, declarations: [TheSeamSchemaFormCheckboxComponent,
3025
+ TheSeamSchemaFormSubmitComponent,
3026
+ TheSeamSchemaFormSelectComponent,
3027
+ TheSeamSchemaFormInputComponent,
3028
+ TheSeamSchemaFormNumberComponent,
3029
+ TheSeamSchemaFormSubmitSplitComponent], imports: [CommonModule,
3030
+ ReactiveFormsModule,
3031
+ JsonSchemaFormModule,
3032
+ TheSeamFormFieldModule,
3033
+ TheSeamCheckboxModule,
3034
+ TheSeamMenuModule,
3035
+ TheSeamButtonsModule,
3036
+ NgSelectModule], exports: [TheSeamSchemaFormCheckboxComponent,
3037
+ TheSeamSchemaFormSubmitComponent,
3038
+ TheSeamSchemaFormSelectComponent,
3039
+ TheSeamSchemaFormInputComponent,
3040
+ TheSeamSchemaFormNumberComponent,
3041
+ TheSeamSchemaFormSubmitSplitComponent, JsonSchemaFormModule] });
3042
+ TheSeamSchemaFormControlsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormControlsModule, imports: [CommonModule,
3043
+ ReactiveFormsModule,
3044
+ JsonSchemaFormModule,
3045
+ TheSeamFormFieldModule,
3046
+ TheSeamCheckboxModule,
3047
+ TheSeamMenuModule,
3048
+ TheSeamButtonsModule,
3049
+ NgSelectModule, JsonSchemaFormModule] });
3050
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormControlsModule, decorators: [{
3051
+ type: NgModule,
3052
+ args: [{
3053
+ declarations: [
3054
+ ...controls
3055
+ ],
3056
+ imports: [
3057
+ CommonModule,
3058
+ ReactiveFormsModule,
3059
+ JsonSchemaFormModule,
3060
+ TheSeamFormFieldModule,
3061
+ TheSeamCheckboxModule,
3062
+ TheSeamMenuModule,
3063
+ TheSeamButtonsModule,
3064
+ NgSelectModule
3065
+ ],
3066
+ exports: [
3067
+ ...controls,
3068
+ JsonSchemaFormModule
3069
+ ],
3070
+ entryComponents: [
3071
+ ...controls
3072
+ ]
3073
+ }]
3074
+ }] });
3075
+
3076
+ class TheSeamSchemaFormModule {
3077
+ }
3078
+ TheSeamSchemaFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3079
+ TheSeamSchemaFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormModule, declarations: [TheSeamSchemaFormFrameworkComponent], imports: [CommonModule,
3080
+ JsonSchemaFormModule,
3081
+ TheSeamSchemaFormControlsModule,
3082
+ WidgetLibraryModule], exports: [TheSeamSchemaFormFrameworkComponent,
3083
+ JsonSchemaFormModule] });
3084
+ TheSeamSchemaFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormModule, providers: [
3085
+ JsonSchemaFormService,
3086
+ FrameworkLibraryService,
3087
+ WidgetLibraryService,
3088
+ { provide: Framework, useClass: TheSeamFramework, multi: true }
3089
+ ], imports: [CommonModule,
3090
+ JsonSchemaFormModule,
3091
+ TheSeamSchemaFormControlsModule,
3092
+ WidgetLibraryModule, JsonSchemaFormModule] });
3093
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamSchemaFormModule, decorators: [{
3094
+ type: NgModule,
3095
+ args: [{
3096
+ declarations: [
3097
+ TheSeamSchemaFormFrameworkComponent
3098
+ ],
3099
+ imports: [
3100
+ CommonModule,
3101
+ JsonSchemaFormModule,
3102
+ TheSeamSchemaFormControlsModule,
3103
+ WidgetLibraryModule,
3104
+ ],
3105
+ providers: [
3106
+ JsonSchemaFormService,
3107
+ FrameworkLibraryService,
3108
+ WidgetLibraryService,
3109
+ { provide: Framework, useClass: TheSeamFramework, multi: true }
3110
+ ],
3111
+ exports: [
3112
+ TheSeamSchemaFormFrameworkComponent,
3113
+ JsonSchemaFormModule
3114
+ ],
3115
+ entryComponents: [
3116
+ TheSeamSchemaFormFrameworkComponent
3117
+ ]
3118
+ }]
3119
+ }] });
3120
+
3121
+ function isHorizontalNavItemType(item, type) {
3122
+ return item.itemType === type;
3123
+ }
3124
+ function isHorizontalNavItemActive(item) {
3125
+ var _a, _b;
3126
+ return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.active) !== null && _b !== void 0 ? _b : false;
3127
+ }
3128
+ function isHorizontalNavItemExpanded(item) {
3129
+ var _a, _b;
3130
+ return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.expanded) !== null && _b !== void 0 ? _b : false;
3131
+ }
3132
+ function isHorizontalNavItemFocused(item) {
3133
+ var _a, _b;
3134
+ return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.focused) !== null && _b !== void 0 ? _b : false;
3135
+ }
3136
+ function horizontalNavItemHasChildren(item) {
3137
+ return horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children') && item.children.length > 0;
3138
+ }
3139
+ function horizontalNavItemCanHaveChildren(item) {
3140
+ return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link');
3141
+ }
3142
+ function horizontalNavItemHasActiveChild(item) {
3143
+ if (!horizontalNavItemHasChildren(item)) {
3144
+ return false;
3145
+ }
3146
+ for (const child of item.children) {
3147
+ if (getHorizontalNavItemStateProp(child, 'active') || horizontalNavItemHasActiveChild(child)) {
3148
+ return true;
3149
+ }
3150
+ }
3151
+ return false;
3152
+ }
3153
+ function horizontalNavItemHasExpandedChild(item) {
3154
+ if (!horizontalNavItemHasChildren(item)) {
3155
+ return false;
3156
+ }
3157
+ for (const child of item.children) {
3158
+ if (getHorizontalNavItemStateProp(child, 'expanded')) {
3159
+ return true;
3160
+ }
3161
+ }
3162
+ return false;
3163
+ }
3164
+ function horizontalNavItemCanBeActive(item) {
3165
+ return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link');
3166
+ }
3167
+ function horizontalNavItemCanExpand(item) {
3168
+ return horizontalNavItemCanHaveChildren(item);
3169
+ }
3170
+ function findHorizontalNavLinkItems(items) {
3171
+ const linkItems = [];
3172
+ const _fn = (_items) => {
3173
+ for (const item of _items) {
3174
+ if (isHorizontalNavItemType(item, 'link')) {
3175
+ linkItems.push(item);
3176
+ }
3177
+ if (horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children')) {
3178
+ _fn(item.children);
3179
+ }
3180
+ }
3181
+ };
3182
+ _fn(items);
3183
+ return linkItems;
3184
+ }
3185
+ function setHorizontalNavItemStateProp(item, prop, value) {
3186
+ if (hasProperty(item, '__state')) {
3187
+ item.__state[prop] = value;
3188
+ }
3189
+ }
3190
+ function getHorizontalNavItemStateProp(item, prop) {
3191
+ return setDefaultHorizontalNavItemState(item).__state[prop];
3192
+ }
3193
+ function setDefaultHorizontalNavItemState(item) {
3194
+ if (hasProperty(item, '__state')) {
3195
+ return item;
3196
+ }
3197
+ item.__state = {
3198
+ active: false,
3199
+ expanded: false,
3200
+ focused: false
3201
+ };
3202
+ // TODO: See if there is a nice way to fix the typing for this.
3203
+ return item;
3204
+ }
3205
+ function areSameHorizontalNavItem(item1, item2) {
3206
+ if (isNullOrUndefined(item1) || isNullOrUndefined(item2)) {
3207
+ return false;
3208
+ }
3209
+ if (item1.itemType !== item2.itemType) {
3210
+ return false;
3211
+ }
3212
+ if (isHorizontalNavItemType(item1, 'title') && isHorizontalNavItemType(item2, 'title')) {
3213
+ return item1.label === item2.label;
3214
+ }
3215
+ else if (isHorizontalNavItemType(item1, 'divider') && isHorizontalNavItemType(item2, 'divider')) {
3216
+ return item1.label === item2.label;
3217
+ }
3218
+ else if (isHorizontalNavItemType(item1, 'basic') && isHorizontalNavItemType(item2, 'basic')) {
3219
+ return item1.label === item2.label;
3220
+ }
3221
+ else if (isHorizontalNavItemType(item1, 'link') && isHorizontalNavItemType(item2, 'link')) {
3222
+ return item1.label === item2.label && item1.link === item2.link;
3223
+ }
3224
+ else if (isHorizontalNavItemType(item1, 'button') && isHorizontalNavItemType(item2, 'button')) {
3225
+ return item1.onClick === item2.onClick;
3226
+ }
3227
+ return false;
3228
+ }
3229
+
3230
+ class TheSeamNavService {
3231
+ constructor(_router) {
3232
+ this._router = _router;
3233
+ this._updatingCount = new BehaviorSubject(0);
3234
+ this.itemChanged = new Subject();
3235
+ this.loading$ = this._updatingCount.pipe(map(count => count > 0), distinctUntilChanged(), shareReplay({ bufferSize: 1, refCount: true }));
3236
+ }
3237
+ createItemsObservable(items) {
3238
+ return defer(() => {
3239
+ this.updateItemsStates(items);
3240
+ this.updateRouterFocusedItem(items);
3241
+ return new Observable((subscriber) => {
3242
+ const stateChangeSub = this.itemChanged.pipe(switchMap(change => {
3243
+ if (change.prop === 'focused' && change.newValue) {
3244
+ this.updateFocusedItem(items, change.item);
3245
+ }
3246
+ return this.loading$.pipe(filter(loading => !loading));
3247
+ })).subscribe(() => {
3248
+ subscriber.next(items);
3249
+ });
3250
+ try {
3251
+ this.updateItemsStates(items);
3252
+ }
3253
+ catch (err) {
3254
+ subscriber.error(err);
3255
+ }
3256
+ const routeChangeSub = this._router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(event => {
3257
+ try {
3258
+ this.updateItemsStates(items);
3259
+ this.updateRouterFocusedItem(items);
3260
+ }
3261
+ catch (err) {
3262
+ subscriber.error(err);
3263
+ }
3264
+ });
3265
+ return () => {
3266
+ stateChangeSub.unsubscribe();
3267
+ routeChangeSub.unsubscribe();
3268
+ };
3269
+ }).pipe(startWith(items));
3270
+ });
3271
+ }
3272
+ _incUpdatingCount() {
3273
+ this._updatingCount.next(this._updatingCount.value + 1);
3274
+ }
3275
+ _decrUpdatingCount() {
3276
+ this._updatingCount.next(this._updatingCount.value - 1);
3277
+ }
3278
+ updateItemsStates(items) {
3279
+ this._incUpdatingCount();
3280
+ try {
3281
+ for (const item of items) {
3282
+ if (horizontalNavItemHasChildren(item)) {
3283
+ this.updateItemsStates(item.children);
3284
+ }
3285
+ this.updateItemState(item);
3286
+ }
3287
+ this._decrUpdatingCount();
3288
+ }
3289
+ catch (err) {
3290
+ this._decrUpdatingCount();
3291
+ throw err;
3292
+ }
3293
+ }
3294
+ updateItemState(item) {
3295
+ this._incUpdatingCount();
3296
+ try {
3297
+ setDefaultHorizontalNavItemState(item);
3298
+ this.setItemStateProp(item, 'active', this.horizontalNavLinkActive(item));
3299
+ // TODO: Implement this in a more optimized way. Unless our apps start
3300
+ // having large navs constantly updating their state, this shouldn't
3301
+ // have much impact on performance.
3302
+ this._updateItemExpandedState(item);
3303
+ this._decrUpdatingCount();
3304
+ }
3305
+ catch (err) {
3306
+ this._decrUpdatingCount();
3307
+ throw err;
3308
+ }
3309
+ }
3310
+ horizontalNavLinkActive(item) {
3311
+ if (isHorizontalNavItemType(item, 'link')) {
3312
+ const url = this._getUrl(item);
3313
+ if (notNullOrUndefined(url)) {
3314
+ const opts = this._getMatchOptions(item);
3315
+ return this._router.isActive(url, opts);
3316
+ }
3317
+ }
3318
+ return false;
3319
+ }
3320
+ _updateItemsExpandedState(items) {
3321
+ for (const item of items) {
3322
+ if (horizontalNavItemHasChildren(item)) {
3323
+ this._updateItemsExpandedState(item.children);
3324
+ }
3325
+ this._updateItemExpandedState(item);
3326
+ }
3327
+ }
3328
+ _updateItemExpandedState(item) {
3329
+ if (!horizontalNavItemCanExpand(item)) {
3330
+ if (getHorizontalNavItemStateProp(item, 'expanded')) {
3331
+ this.setItemStateProp(item, 'expanded', false);
3332
+ }
3333
+ return;
3334
+ }
3335
+ if (horizontalNavItemHasChildren(item)) {
3336
+ this._updateItemsExpandedState(item.children);
3337
+ }
3338
+ if (horizontalNavItemHasActiveChild(item) || horizontalNavItemHasExpandedChild(item)) {
3339
+ if (!getHorizontalNavItemStateProp(item, 'expanded')) {
3340
+ this.setItemStateProp(item, 'expanded', true);
3341
+ }
3342
+ }
3343
+ else {
3344
+ if (getHorizontalNavItemStateProp(item, 'expanded')) {
3345
+ this.setItemStateProp(item, 'expanded', false);
3346
+ }
3347
+ }
3348
+ }
3349
+ updateRouterFocusedItem(items) {
3350
+ const focusedItem = items.find(i => isHorizontalNavItemActive(i)) || items.find(i => horizontalNavItemHasActiveChild(i));
3351
+ if (notNullOrUndefined(focusedItem)) {
3352
+ this.updateFocusedItem(items, focusedItem);
3353
+ }
3354
+ }
3355
+ updateFocusedItem(items, focusedItem) {
3356
+ for (const item of items) {
3357
+ if (areSameHorizontalNavItem(item, focusedItem)) {
3358
+ setHorizontalNavItemStateProp(item, 'focused', true);
3359
+ }
3360
+ else {
3361
+ setHorizontalNavItemStateProp(item, 'focused', false);
3362
+ }
3363
+ }
3364
+ }
3365
+ _getNavExtras(item) {
3366
+ const navigationExtras = {};
3367
+ if (hasProperty(item, 'queryParams')) {
3368
+ navigationExtras.queryParams = item.queryParams;
3369
+ }
3370
+ if (hasProperty(item, 'fragment')) {
3371
+ navigationExtras.fragment = item.fragment;
3372
+ }
3373
+ if (hasProperty(item, 'queryParamsHandling')) {
3374
+ navigationExtras.queryParamsHandling = item.queryParamsHandling;
3375
+ }
3376
+ if (hasProperty(item, 'preserveFragment')) {
3377
+ navigationExtras.preserveFragment = item.preserveFragment;
3378
+ }
3379
+ return navigationExtras;
3380
+ }
3381
+ _getUrl(item) {
3382
+ const link = item.link;
3383
+ if (typeof link === 'string') {
3384
+ return this._router.createUrlTree([link], this._getNavExtras(item)).toString();
3385
+ }
3386
+ else if (Array.isArray(link)) {
3387
+ return this._router.createUrlTree(link, this._getNavExtras(item)).toString();
3388
+ }
3389
+ return null;
3390
+ }
3391
+ _getMatchOptions(item) {
3392
+ const defaultMatchOpts = {
3393
+ paths: 'subset',
3394
+ queryParams: 'subset',
3395
+ fragment: 'ignored',
3396
+ matrixParams: 'ignored'
3397
+ };
3398
+ if (hasProperty(item, 'matchOptions')) {
3399
+ return Object.assign(Object.assign({}, defaultMatchOpts), item.matchOptions);
3400
+ }
3401
+ return defaultMatchOpts;
3402
+ }
3403
+ setItemStateProp(item, prop, value) {
3404
+ const currentValue = getHorizontalNavItemStateProp(item, prop);
3405
+ if (currentValue !== value) {
3406
+ setHorizontalNavItemStateProp(item, prop, value);
3407
+ const changed = {
3408
+ item,
3409
+ prop,
3410
+ prevValue: currentValue,
3411
+ newValue: value
3412
+ };
3413
+ this.itemChanged.next(changed);
3414
+ }
3415
+ }
3416
+ }
3417
+ TheSeamNavService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavService, deps: [{ token: i1$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
3418
+ TheSeamNavService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavService });
3419
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavService, decorators: [{
3420
+ type: Injectable
3421
+ }], ctorParameters: function () { return [{ type: i1$2.Router }]; } });
3422
+
3423
+ class NavItemComponent {
3424
+ set link(value) { this._link.next(value); }
3425
+ get link() { return this._link.value; }
3426
+ set expanded(value) {
3427
+ this._expanded.next(coerceBooleanProperty(value));
3428
+ }
3429
+ get expanded() { return this._expanded.value; }
3430
+ set compact(value) { this._compact.next(coerceBooleanProperty(value)); }
3431
+ get compact() { return this._compact.value; }
3432
+ get badgeTooltip() { return this._badgeTooltip; }
3433
+ set badgeTooltip(value) {
3434
+ if (value !== null && value !== undefined) {
3435
+ if (typeof value === 'string') {
3436
+ this._badgeTooltip = {
3437
+ tooltip: value,
3438
+ placement: 'auto',
3439
+ disabled: false
3440
+ };
3441
+ }
3442
+ else {
3443
+ this._badgeTooltip = Object.assign(Object.assign({}, value), { placement: value.placement || 'auto', disabled: typeof (value === null || value === void 0 ? void 0 : value.disabled) === 'boolean'
3444
+ ? value.disabled
3445
+ : typeof value.tooltip !== 'string' });
3446
+ }
3447
+ }
3448
+ else {
3449
+ this._badgeTooltip = undefined;
3450
+ }
3451
+ }
3452
+ get _isActiveCssClass() { return this.active; }
3453
+ get _isChildActiveCssClass() { return this.hasActiveChild; }
3454
+ get _isExpandedCssClass() { return this.expanded; }
3455
+ get _isFocusedCssClass() { return this.focused; }
3456
+ get _attrDataHierLevel() { return this.hierLevel; }
3457
+ constructor(_nav) {
3458
+ this._nav = _nav;
3459
+ this._ngUnsubscribe = new Subject();
3460
+ this.faAngleLeft = faAngleLeft;
3461
+ this.active = false;
3462
+ this._link = new BehaviorSubject(undefined);
3463
+ this.link$ = this._link.asObservable();
3464
+ this.hierLevel = 0;
3465
+ this.indentSize = 10;
3466
+ this._expanded = new BehaviorSubject(false);
3467
+ this.expanded$ = this._expanded.asObservable();
3468
+ this._compact = new BehaviorSubject(false);
3469
+ this.compact$ = this._compact.asObservable();
3470
+ this.focused = false;
3471
+ this.badgeTheme = 'danger';
3472
+ this.childAction = 'menu';
3473
+ this.expandAction = 'toggle';
3474
+ this.navItemExpanded = new EventEmitter();
3475
+ }
3476
+ ngOnDestroy() {
3477
+ this._ngUnsubscribe.next();
3478
+ this._ngUnsubscribe.complete();
3479
+ }
3480
+ get hasChildren() {
3481
+ return Array.isArray(this.children) && this.children.length > 0;
3482
+ }
3483
+ get hasActiveChild() {
3484
+ if (notNullOrUndefined(this.item)) {
3485
+ return horizontalNavItemHasActiveChild(this.item);
3486
+ }
3487
+ return false;
3488
+ }
3489
+ get hasMenuToggle() {
3490
+ return this.hasChildren && this.childAction === 'menu';
3491
+ }
3492
+ get menuTpl() {
3493
+ return this.hasMenuToggle ? this._menu : undefined;
3494
+ }
3495
+ get hasExpandingChildren() {
3496
+ return this.hasChildren && this.childAction === 'expand';
3497
+ }
3498
+ _toggleChildren(event) {
3499
+ let ex = !this.expanded;
3500
+ if (this.expandAction === 'expandOnly') {
3501
+ ex = true;
3502
+ }
3503
+ this.expanded = ex;
3504
+ this.navItemExpanded.emit(this.expanded);
3505
+ if (this.item && this.expanded) {
3506
+ this._nav.setItemStateProp(this.item, 'focused', this.expanded);
3507
+ }
3508
+ // Prevents seam-menu from closing out when toggling child expand
3509
+ event.stopPropagation();
3510
+ }
3511
+ // Updates expanded state when user exits seam-menu
3512
+ _menuEvent(menuExpanded) {
3513
+ if (menuExpanded === false) {
3514
+ this.expanded = false;
3515
+ // TODO: figure out why closing seam-menu with expanded submenu messes up animation
3516
+ if (this._navItems && this._navItems.length) {
3517
+ this._navItems.forEach(navItem => {
3518
+ navItem.expanded = false;
3519
+ });
3520
+ }
3521
+ }
3522
+ }
3523
+ get showIconBlock() {
3524
+ return notNullOrUndefined(this.icon) || this.hideEmptyIcon !== true;
3525
+ }
3526
+ }
3527
+ NavItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NavItemComponent, deps: [{ token: TheSeamNavService }], target: i0.ɵɵFactoryTarget.Component });
3528
+ NavItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NavItemComponent, selector: "seam-nav-item", inputs: { item: "item", itemType: "itemType", icon: "icon", hideEmptyIcon: "hideEmptyIcon", label: "label", active: "active", link: "link", queryParams: "queryParams", children: "children", hierLevel: "hierLevel", indentSize: "indentSize", expanded: "expanded", compact: "compact", focused: "focused", badgeText: "badgeText", badgeTheme: "badgeTheme", badgeSrContent: "badgeSrContent", badgeTooltip: "badgeTooltip", childAction: "childAction", expandAction: "expandAction" }, outputs: { navItemExpanded: "navItemExpanded" }, host: { properties: { "class.seam-nav-item--active": "this._isActiveCssClass", "class.seam-nav-item--child-active": "this._isChildActiveCssClass", "class.seam-nav-item--expanded": "this._isExpandedCssClass", "class.seam-nav-item--focused": "this._isFocusedCssClass", "attr.data-hier-level": "this._attrDataHierLevel" } }, viewQueries: [{ propertyName: "_menu", first: true, predicate: MenuComponent, descendants: true }, { propertyName: "_navItems", predicate: NavItemComponent, descendants: true }], exportAs: ["seamNavItem"], ngImport: i0, template: "<div class=\"d-flex flex-row h-100\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasExpandingChildren\">\n <div class=\"nav--group nav--group--level-{{ hierLevel + 1 }}\"\n *ngIf=\"expanded$ | async\" @childGroupAnim>\n <ng-container *ngTemplateOutlet=\"navChildren\"></ng-container>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"nav-item btn nav-btn p-0 d-flex align-items-stretch flex-row text-decoration-none w-100\"\n cdkMonitorElementFocus\n (click)=\"_toggleChildren($event)\"\n [seamMenuToggle]=\"menuTpl\"\n (menuToggle)=\"_menuEvent($event)\"\n [attr.aria-expanded]=\"expanded$ | async\">\n <div class=\"nav-link d-flex flex-row align-items-center w-100\" [class.nav-link__compact]=\"compact\">\n <div class=\"nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon [icon]=\"icon\" *ngIf=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n\n <div *ngIf=\"hasChildren && !compact\"\n class=\"btn nav-btn nav-item--toggle-btn-container d-flex align-items-center\">\n <seam-icon\n class=\"nav-item--toggle-btn\"\n [class.nav-item--toggle-btn-expanded]=\"expanded$ | async\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n </div>\n </button>\n</ng-template>\n\n<ng-template #itemTypeLink>\n <a *ngIf=\"link; else noLink\" class=\"nav-item nav-link d-flex flex-row w-100 align-items-center\"\n [class.nav-link__compact]=\"compact\"\n [routerLink]=\"link\"\n [queryParams]=\"queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\">\n <div class=\"nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon [icon]=\"icon\" *ngIf=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </a>\n\n <ng-template #noLink>\n <a class=\"nav-item nav-link d-flex flex-row w-100 align-items-center\" [class.nav-link__compact]=\"compact\">\n <div class=\"nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon [icon]=\"icon\" *ngIf=\"icon\"></seam-icon>\n </div>\n <span *ngIf=\"!compact\" nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" nav-item-label>{{ label }}</span>\n </a>\n </ng-template>\n\n <button *ngIf=\"hasChildren && !compact\"\n type=\"button\"\n class=\"btn nav-btn nav-item--toggle-btn-container\"\n (click)=\"_toggleChildren($event)\"\n [seamMenuToggle]=\"menuTpl\"\n (menuToggle)=\"_menuEvent($event)\"\n [attr.aria-expanded]=\"expanded$ | async\"\n cdkMonitorElementFocus>\n <seam-icon\n class=\"nav-item--toggle-btn\"\n [class.nav-item--toggle-btn-expanded]=\"expanded$ | async\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n <span class=\"sr-only\">Group Toggle</span>\n </button>\n</ng-template>\n\n<ng-template #itemTypeDivider>\n <div class=\"px-2 w-100\">\n <hr class=\"nav-item--divider\" />\n </div>\n</ng-template>\n\n<ng-template #itemTypeTitle>\n <ng-container *ngIf=\"!compact\">\n <span class=\"nav-item--title pt-1\" nav-item-label>{{ label }}</span>\n </ng-container>\n</ng-template>\n\n<ng-template #itemBadge>\n <ng-container *ngIf=\"badgeText\">\n <div class=\"badge-spacer flex-grow-1\" *ngIf=\"!compact\"></div>\n <div class=\"nav-item--badge\"\n [class.nav-item--badge-no-icon]=\"!icon\"\n [ngbTooltip]=\"$any(badgeTooltip)?.tooltip\"\n [tooltipClass]=\"$any(badgeTooltip)?.class\"\n [placement]=\"$any(badgeTooltip)?.placement\"\n [container]=\"$any(badgeTooltip)?.container\"\n [disableTooltip]=\"!badgeTooltip || !!$any(badgeTooltip)?.disabled\">\n <span class=\"badge badge-pill badge-{{ badgeTheme }}\">\n <ng-container *ngIf=\"!compact || !icon\">\n {{ badgeText }}\n </ng-container>\n <span *ngIf=\"badgeSrContent\">{{ badgeSrContent }}</span>\n </span>\n </div>\n </ng-container>\n</ng-template>\n\n<seam-menu #menu *ngIf=\"hasMenuToggle\">\n <ng-container *ngTemplateOutlet=\"navChildren\"></ng-container>\n</seam-menu>\n\n<ng-template #navChildren>\n <seam-nav-item *ngFor=\"let child of children\"\n [item]=\"child\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state?.active\"\n [expanded]=\"$any(child).__state?.expanded\"\n [focused]=\"$any(child).__state?.focused\"\n childAction=\"expand\"\n [hideEmptyIcon]=\"hideEmptyIcon\">\n </seam-nav-item>\n</ng-template>\n\n", styles: ["seam-nav-item{display:block;transition:.25s ease-in-out background-color;text-align:inherit;border-radius:0;overflow:hidden;background:transparent;margin:0}seam-nav-item.seam-nav-item--expanded{background-color:transparent}seam-nav-item.seam-nav-item--expanded .nav-link{color:#000}seam-nav-item.seam-nav-item--child-active{background-color:#dae0e5}seam-nav-item.seam-nav-item--child-active .nav-link{color:#000}seam-nav-item.seam-nav-item--active{background-color:#dae0e5}seam-nav-item.seam-nav-item--active .active,seam-nav-item.seam-nav-item--active:active,seam-nav-item.seam-nav-item--active .nav-item.active:hover{background-color:#dae0e5}seam-nav-item.seam-nav-item--active .nav-item:hover{background-color:#e9ecef}seam-nav-item.seam-nav-item--active .nav-link{color:#000}seam-nav-item .badge{vertical-align:middle}seam-nav-item:not(.nav-item--icon) .nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-nav-item .nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center;margin-right:.5rem}seam-nav-item .nav-item--icon .nav-item--badge{top:-4px;right:-4px;position:absolute}seam-nav-item .nav-item--icon .nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-nav-item .nav-item--icon .nav-item--badge.nav-item--badge-no-icon{top:0;right:0}seam-nav-item .nav-item{transition:.25s ease-in-out background-color}seam-nav-item .nav-item:hover{background-color:#e9ecef}seam-nav-item .nav-item.active{pointer-events:none;cursor:default}seam-nav-item a.nav-item:not([href]):not([tabindex]){color:#000}seam-nav-item a.nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-nav-item .nav-link{color:#000}seam-nav-item .nav-btn{font-weight:400;color:#000;text-decoration:none;border-radius:0;border:0 solid #dee2e6}seam-nav-item .nav-btn:hover{color:#000;text-decoration:underline}seam-nav-item .nav-btn:focus,seam-nav-item .nav-btn.focus{text-decoration:underline;box-shadow:none}seam-nav-item .nav-btn:disabled,seam-nav-item .nav-btn.disabled{color:#000;pointer-events:none}seam-nav-item .cdk-keyboard-focused{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}seam-nav-item .nav-item--toggle-btn-container{transition:.25s ease-in-out background-color;padding:0 .5rem}seam-nav-item button.nav-item--toggle-btn-container:hover{background-color:#e9ecef}seam-nav-item .nav-item--toggle-btn .svg-inline--fa{transition:.1s ease-in-out transform;transform:none}seam-nav-item .nav-item--toggle-btn.nav-item--toggle-btn-expanded .svg-inline--fa{transform:rotate(-90deg)}seam-nav-item .nav--group{will-change:height;overflow:hidden}seam-nav-item .nav--group--level-1{background-color:#eff1f4}seam-nav-item .nav--group--level-2{background-color:#e6eaed}seam-nav-item .nav--group--level-3{background-color:#dde2e7}seam-nav-item .nav--group--level-4{background-color:#d4dae1}seam-nav-item .nav--group--level-5{background-color:#cbd3da}seam-nav-item .nav--group--level-6{background-color:#c2cbd4}seam-nav-item .nav--group--level-7{background-color:#bac3cd}seam-nav-item .nav--group--level-8{background-color:#b1bcc7}seam-nav-item .nav--group--level-9{background-color:#a8b4c1}seam-nav-item .nav-item--divider{display:block;border-top:1px solid #dae0e5;width:100%}seam-nav-item .nav-item--title{color:#000;font-size:24px;padding-left:10px}seam-nav-item .sr-only{top:0;left:0}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i1$2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "component", type: i2$1.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "directive", type: i4$2.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"], exportAs: ["cdkMonitorFocus"] }, { kind: "directive", type: i5.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type: i3$2.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i3$2.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions"], outputs: ["menuToggle"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: NavItemComponent, selector: "seam-nav-item", inputs: ["item", "itemType", "icon", "hideEmptyIcon", "label", "active", "link", "queryParams", "children", "hierLevel", "indentSize", "expanded", "compact", "focused", "badgeText", "badgeTheme", "badgeSrContent", "badgeTooltip", "childAction", "expandAction"], outputs: ["navItemExpanded"], exportAs: ["seamNavItem"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], animations: [
3529
+ trigger('childGroupAnim', [
3530
+ transition(':enter', [
3531
+ style({ height: 0 }),
3532
+ animate('0.2s ease-in-out', style({ height: '*' }))
3533
+ ]),
3534
+ transition(':leave', [
3535
+ style({ height: '*' }),
3536
+ animate('0.2s ease-in-out', style({ height: 0 }))
3537
+ ])
3538
+ ])
3539
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
3540
+ __decorate([
3541
+ InputBoolean()
3542
+ ], NavItemComponent.prototype, "active", void 0);
3543
+ __decorate([
3544
+ InputNumber(0)
3545
+ ], NavItemComponent.prototype, "hierLevel", void 0);
3546
+ __decorate([
3547
+ InputNumber(10)
3548
+ ], NavItemComponent.prototype, "indentSize", void 0);
3549
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NavItemComponent, decorators: [{
3550
+ type: Component,
3551
+ args: [{ selector: 'seam-nav-item', exportAs: 'seamNavItem', animations: [
3552
+ trigger('childGroupAnim', [
3553
+ transition(':enter', [
3554
+ style({ height: 0 }),
3555
+ animate('0.2s ease-in-out', style({ height: '*' }))
3556
+ ]),
3557
+ transition(':leave', [
3558
+ style({ height: '*' }),
3559
+ animate('0.2s ease-in-out', style({ height: 0 }))
3560
+ ])
3561
+ ])
3562
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"d-flex flex-row h-100\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasExpandingChildren\">\n <div class=\"nav--group nav--group--level-{{ hierLevel + 1 }}\"\n *ngIf=\"expanded$ | async\" @childGroupAnim>\n <ng-container *ngTemplateOutlet=\"navChildren\"></ng-container>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"nav-item btn nav-btn p-0 d-flex align-items-stretch flex-row text-decoration-none w-100\"\n cdkMonitorElementFocus\n (click)=\"_toggleChildren($event)\"\n [seamMenuToggle]=\"menuTpl\"\n (menuToggle)=\"_menuEvent($event)\"\n [attr.aria-expanded]=\"expanded$ | async\">\n <div class=\"nav-link d-flex flex-row align-items-center w-100\" [class.nav-link__compact]=\"compact\">\n <div class=\"nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon [icon]=\"icon\" *ngIf=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n\n <div *ngIf=\"hasChildren && !compact\"\n class=\"btn nav-btn nav-item--toggle-btn-container d-flex align-items-center\">\n <seam-icon\n class=\"nav-item--toggle-btn\"\n [class.nav-item--toggle-btn-expanded]=\"expanded$ | async\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n </div>\n </button>\n</ng-template>\n\n<ng-template #itemTypeLink>\n <a *ngIf=\"link; else noLink\" class=\"nav-item nav-link d-flex flex-row w-100 align-items-center\"\n [class.nav-link__compact]=\"compact\"\n [routerLink]=\"link\"\n [queryParams]=\"queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\">\n <div class=\"nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon [icon]=\"icon\" *ngIf=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </a>\n\n <ng-template #noLink>\n <a class=\"nav-item nav-link d-flex flex-row w-100 align-items-center\" [class.nav-link__compact]=\"compact\">\n <div class=\"nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon [icon]=\"icon\" *ngIf=\"icon\"></seam-icon>\n </div>\n <span *ngIf=\"!compact\" nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" nav-item-label>{{ label }}</span>\n </a>\n </ng-template>\n\n <button *ngIf=\"hasChildren && !compact\"\n type=\"button\"\n class=\"btn nav-btn nav-item--toggle-btn-container\"\n (click)=\"_toggleChildren($event)\"\n [seamMenuToggle]=\"menuTpl\"\n (menuToggle)=\"_menuEvent($event)\"\n [attr.aria-expanded]=\"expanded$ | async\"\n cdkMonitorElementFocus>\n <seam-icon\n class=\"nav-item--toggle-btn\"\n [class.nav-item--toggle-btn-expanded]=\"expanded$ | async\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n <span class=\"sr-only\">Group Toggle</span>\n </button>\n</ng-template>\n\n<ng-template #itemTypeDivider>\n <div class=\"px-2 w-100\">\n <hr class=\"nav-item--divider\" />\n </div>\n</ng-template>\n\n<ng-template #itemTypeTitle>\n <ng-container *ngIf=\"!compact\">\n <span class=\"nav-item--title pt-1\" nav-item-label>{{ label }}</span>\n </ng-container>\n</ng-template>\n\n<ng-template #itemBadge>\n <ng-container *ngIf=\"badgeText\">\n <div class=\"badge-spacer flex-grow-1\" *ngIf=\"!compact\"></div>\n <div class=\"nav-item--badge\"\n [class.nav-item--badge-no-icon]=\"!icon\"\n [ngbTooltip]=\"$any(badgeTooltip)?.tooltip\"\n [tooltipClass]=\"$any(badgeTooltip)?.class\"\n [placement]=\"$any(badgeTooltip)?.placement\"\n [container]=\"$any(badgeTooltip)?.container\"\n [disableTooltip]=\"!badgeTooltip || !!$any(badgeTooltip)?.disabled\">\n <span class=\"badge badge-pill badge-{{ badgeTheme }}\">\n <ng-container *ngIf=\"!compact || !icon\">\n {{ badgeText }}\n </ng-container>\n <span *ngIf=\"badgeSrContent\">{{ badgeSrContent }}</span>\n </span>\n </div>\n </ng-container>\n</ng-template>\n\n<seam-menu #menu *ngIf=\"hasMenuToggle\">\n <ng-container *ngTemplateOutlet=\"navChildren\"></ng-container>\n</seam-menu>\n\n<ng-template #navChildren>\n <seam-nav-item *ngFor=\"let child of children\"\n [item]=\"child\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state?.active\"\n [expanded]=\"$any(child).__state?.expanded\"\n [focused]=\"$any(child).__state?.focused\"\n childAction=\"expand\"\n [hideEmptyIcon]=\"hideEmptyIcon\">\n </seam-nav-item>\n</ng-template>\n\n", styles: ["seam-nav-item{display:block;transition:.25s ease-in-out background-color;text-align:inherit;border-radius:0;overflow:hidden;background:transparent;margin:0}seam-nav-item.seam-nav-item--expanded{background-color:transparent}seam-nav-item.seam-nav-item--expanded .nav-link{color:#000}seam-nav-item.seam-nav-item--child-active{background-color:#dae0e5}seam-nav-item.seam-nav-item--child-active .nav-link{color:#000}seam-nav-item.seam-nav-item--active{background-color:#dae0e5}seam-nav-item.seam-nav-item--active .active,seam-nav-item.seam-nav-item--active:active,seam-nav-item.seam-nav-item--active .nav-item.active:hover{background-color:#dae0e5}seam-nav-item.seam-nav-item--active .nav-item:hover{background-color:#e9ecef}seam-nav-item.seam-nav-item--active .nav-link{color:#000}seam-nav-item .badge{vertical-align:middle}seam-nav-item:not(.nav-item--icon) .nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-nav-item .nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center;margin-right:.5rem}seam-nav-item .nav-item--icon .nav-item--badge{top:-4px;right:-4px;position:absolute}seam-nav-item .nav-item--icon .nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-nav-item .nav-item--icon .nav-item--badge.nav-item--badge-no-icon{top:0;right:0}seam-nav-item .nav-item{transition:.25s ease-in-out background-color}seam-nav-item .nav-item:hover{background-color:#e9ecef}seam-nav-item .nav-item.active{pointer-events:none;cursor:default}seam-nav-item a.nav-item:not([href]):not([tabindex]){color:#000}seam-nav-item a.nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-nav-item .nav-link{color:#000}seam-nav-item .nav-btn{font-weight:400;color:#000;text-decoration:none;border-radius:0;border:0 solid #dee2e6}seam-nav-item .nav-btn:hover{color:#000;text-decoration:underline}seam-nav-item .nav-btn:focus,seam-nav-item .nav-btn.focus{text-decoration:underline;box-shadow:none}seam-nav-item .nav-btn:disabled,seam-nav-item .nav-btn.disabled{color:#000;pointer-events:none}seam-nav-item .cdk-keyboard-focused{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}seam-nav-item .nav-item--toggle-btn-container{transition:.25s ease-in-out background-color;padding:0 .5rem}seam-nav-item button.nav-item--toggle-btn-container:hover{background-color:#e9ecef}seam-nav-item .nav-item--toggle-btn .svg-inline--fa{transition:.1s ease-in-out transform;transform:none}seam-nav-item .nav-item--toggle-btn.nav-item--toggle-btn-expanded .svg-inline--fa{transform:rotate(-90deg)}seam-nav-item .nav--group{will-change:height;overflow:hidden}seam-nav-item .nav--group--level-1{background-color:#eff1f4}seam-nav-item .nav--group--level-2{background-color:#e6eaed}seam-nav-item .nav--group--level-3{background-color:#dde2e7}seam-nav-item .nav--group--level-4{background-color:#d4dae1}seam-nav-item .nav--group--level-5{background-color:#cbd3da}seam-nav-item .nav--group--level-6{background-color:#c2cbd4}seam-nav-item .nav--group--level-7{background-color:#bac3cd}seam-nav-item .nav--group--level-8{background-color:#b1bcc7}seam-nav-item .nav--group--level-9{background-color:#a8b4c1}seam-nav-item .nav-item--divider{display:block;border-top:1px solid #dae0e5;width:100%}seam-nav-item .nav-item--title{color:#000;font-size:24px;padding-left:10px}seam-nav-item .sr-only{top:0;left:0}\n"] }]
3563
+ }], ctorParameters: function () { return [{ type: TheSeamNavService }]; }, propDecorators: { item: [{
3564
+ type: Input
3565
+ }], itemType: [{
3566
+ type: Input
3567
+ }], icon: [{
3568
+ type: Input
3569
+ }], hideEmptyIcon: [{
3570
+ type: Input
3571
+ }], label: [{
3572
+ type: Input
3573
+ }], active: [{
3574
+ type: Input
3575
+ }], link: [{
3576
+ type: Input
3577
+ }], queryParams: [{
3578
+ type: Input
3579
+ }], children: [{
3580
+ type: Input
3581
+ }], hierLevel: [{
3582
+ type: Input
3583
+ }], indentSize: [{
3584
+ type: Input
3585
+ }], expanded: [{
3586
+ type: Input
3587
+ }], compact: [{
3588
+ type: Input
3589
+ }], focused: [{
3590
+ type: Input
3591
+ }], badgeText: [{
3592
+ type: Input
3593
+ }], badgeTheme: [{
3594
+ type: Input
3595
+ }], badgeSrContent: [{
3596
+ type: Input
3597
+ }], badgeTooltip: [{
3598
+ type: Input
3599
+ }], childAction: [{
3600
+ type: Input
3601
+ }], expandAction: [{
3602
+ type: Input
3603
+ }], navItemExpanded: [{
3604
+ type: Output
3605
+ }], _isActiveCssClass: [{
3606
+ type: HostBinding,
3607
+ args: ['class.seam-nav-item--active']
3608
+ }], _isChildActiveCssClass: [{
3609
+ type: HostBinding,
3610
+ args: ['class.seam-nav-item--child-active']
3611
+ }], _isExpandedCssClass: [{
3612
+ type: HostBinding,
3613
+ args: ['class.seam-nav-item--expanded']
3614
+ }], _isFocusedCssClass: [{
3615
+ type: HostBinding,
3616
+ args: ['class.seam-nav-item--focused']
3617
+ }], _attrDataHierLevel: [{
3618
+ type: HostBinding,
3619
+ args: ['attr.data-hier-level']
3620
+ }], _menu: [{
3621
+ type: ViewChild,
3622
+ args: [MenuComponent]
3623
+ }], _navItems: [{
3624
+ type: ViewChildren,
3625
+ args: [NavItemComponent]
3626
+ }] } });
3627
+
3628
+ class HorizontalNavComponent {
3629
+ get items() { return this._items.value; }
3630
+ set items(value) {
3631
+ this._items.next(value);
3632
+ }
3633
+ constructor(_nav) {
3634
+ this._nav = _nav;
3635
+ this._ngUnsubscribe = new Subject();
3636
+ this._items = new BehaviorSubject([]);
3637
+ this.hideEmptyIcon = true;
3638
+ this.hierLevel = 0;
3639
+ this.childAction = 'menu';
3640
+ this.expandAction = 'toggle';
3641
+ this.navItemExpanded = new EventEmitter();
3642
+ this.items$ = this._items.asObservable().pipe(switchMap(items => items ? this._nav.createItemsObservable(items) : []), shareReplay({ bufferSize: 1, refCount: true }));
3643
+ }
3644
+ ngOnDestroy() {
3645
+ this._ngUnsubscribe.next();
3646
+ this._ngUnsubscribe.complete();
3647
+ }
3648
+ _navItemExpanded(item, expanded) {
3649
+ this.navItemExpanded.emit({ navItem: item, expanded });
3650
+ }
3651
+ }
3652
+ HorizontalNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HorizontalNavComponent, deps: [{ token: TheSeamNavService }], target: i0.ɵɵFactoryTarget.Component });
3653
+ HorizontalNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: HorizontalNavComponent, selector: "seam-horizontal-nav", inputs: { items: "items", hideEmptyIcon: "hideEmptyIcon", hierLevel: "hierLevel", childAction: "childAction", expandAction: "expandAction" }, outputs: { navItemExpanded: "navItemExpanded" }, providers: [
3654
+ TheSeamNavService
3655
+ ], ngImport: i0, template: "<div class=\"nav-inner-wrapper\" class=\"nav-inner-wrapper-{{hierLevel}}\">\n <div class=\"nav-items-row\">\n <seam-nav-item *ngFor=\"let item of items$ | async\"\n class=\"flex-shrink-0\"\n [item]=\"item\"\n [itemType]=\"$any(item)?.itemType\"\n [icon]=\"$any(item)?.icon\"\n [label]=\"$any(item)?.label\"\n [link]=\"$any(item)?.link\"\n [badgeText]=\"$any(item)?.badge?.text\"\n [badgeTheme]=\"$any(item)?.badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(item)?.badge?.srContent\"\n [badgeTooltip]=\"$any(item)?.badge?.tooltip\"\n [queryParams]=\"$any(item)?.queryParams\"\n [children]=\"$any(item)?.children\"\n [active]=\"$any(item).__state?.active\"\n [expanded]=\"$any(item).__state?.expanded\"\n [focused]=\"$any(item).__state?.focused\"\n [hierLevel]=\"hierLevel\"\n [childAction]=\"childAction\"\n [expandAction]=\"expandAction\"\n (navItemExpanded)=\"_navItemExpanded(item, $event)\"\n [hideEmptyIcon]=\"hideEmptyIcon\">\n </seam-nav-item>\n </div>\n</div>\n", styles: ["seam-horizontal-nav,.seam-horizontal-nav{display:block;height:100%;position:relative;z-index:2}seam-horizontal-nav .nav-inner-wrapper,.seam-horizontal-nav .nav-inner-wrapper{background:none;height:100%}seam-horizontal-nav .nav-backdrop,.seam-horizontal-nav .nav-backdrop{background:rgba(52,58,64,.6);width:100vw;height:100vh}seam-horizontal-nav .nav-backdrop.nav-backdrop-hidden,.seam-horizontal-nav .nav-backdrop.nav-backdrop-hidden{display:none;width:0;height:0;padding:0;margin:0}seam-horizontal-nav .nav-content,.seam-horizontal-nav .nav-content{display:flex;flex-direction:column;height:100%;flex-wrap:nowrap}seam-horizontal-nav .nav-items-container,.seam-horizontal-nav .nav-items-container{display:flex;flex-direction:column;width:100%;flex:1 1 100%}seam-horizontal-nav .nav-items-row,.seam-horizontal-nav .nav-items-row{height:100%;display:flex;padding:.25rem .5rem}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: NavItemComponent, selector: "seam-nav-item", inputs: ["item", "itemType", "icon", "hideEmptyIcon", "label", "active", "link", "queryParams", "children", "hierLevel", "indentSize", "expanded", "compact", "focused", "badgeText", "badgeTheme", "badgeSrContent", "badgeTooltip", "childAction", "expandAction"], outputs: ["navItemExpanded"], exportAs: ["seamNavItem"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
3656
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: HorizontalNavComponent, decorators: [{
3657
+ type: Component,
3658
+ args: [{ selector: 'seam-horizontal-nav', providers: [
3659
+ TheSeamNavService
3660
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"nav-inner-wrapper\" class=\"nav-inner-wrapper-{{hierLevel}}\">\n <div class=\"nav-items-row\">\n <seam-nav-item *ngFor=\"let item of items$ | async\"\n class=\"flex-shrink-0\"\n [item]=\"item\"\n [itemType]=\"$any(item)?.itemType\"\n [icon]=\"$any(item)?.icon\"\n [label]=\"$any(item)?.label\"\n [link]=\"$any(item)?.link\"\n [badgeText]=\"$any(item)?.badge?.text\"\n [badgeTheme]=\"$any(item)?.badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(item)?.badge?.srContent\"\n [badgeTooltip]=\"$any(item)?.badge?.tooltip\"\n [queryParams]=\"$any(item)?.queryParams\"\n [children]=\"$any(item)?.children\"\n [active]=\"$any(item).__state?.active\"\n [expanded]=\"$any(item).__state?.expanded\"\n [focused]=\"$any(item).__state?.focused\"\n [hierLevel]=\"hierLevel\"\n [childAction]=\"childAction\"\n [expandAction]=\"expandAction\"\n (navItemExpanded)=\"_navItemExpanded(item, $event)\"\n [hideEmptyIcon]=\"hideEmptyIcon\">\n </seam-nav-item>\n </div>\n</div>\n", styles: ["seam-horizontal-nav,.seam-horizontal-nav{display:block;height:100%;position:relative;z-index:2}seam-horizontal-nav .nav-inner-wrapper,.seam-horizontal-nav .nav-inner-wrapper{background:none;height:100%}seam-horizontal-nav .nav-backdrop,.seam-horizontal-nav .nav-backdrop{background:rgba(52,58,64,.6);width:100vw;height:100vh}seam-horizontal-nav .nav-backdrop.nav-backdrop-hidden,.seam-horizontal-nav .nav-backdrop.nav-backdrop-hidden{display:none;width:0;height:0;padding:0;margin:0}seam-horizontal-nav .nav-content,.seam-horizontal-nav .nav-content{display:flex;flex-direction:column;height:100%;flex-wrap:nowrap}seam-horizontal-nav .nav-items-container,.seam-horizontal-nav .nav-items-container{display:flex;flex-direction:column;width:100%;flex:1 1 100%}seam-horizontal-nav .nav-items-row,.seam-horizontal-nav .nav-items-row{height:100%;display:flex;padding:.25rem .5rem}\n"] }]
3661
+ }], ctorParameters: function () { return [{ type: TheSeamNavService }]; }, propDecorators: { items: [{
3662
+ type: Input
3663
+ }], hideEmptyIcon: [{
3664
+ type: Input
3665
+ }], hierLevel: [{
3666
+ type: Input
3667
+ }], childAction: [{
3668
+ type: Input
3669
+ }], expandAction: [{
3670
+ type: Input
3671
+ }], navItemExpanded: [{
3672
+ type: Output
3673
+ }] } });
3674
+
3675
+ class TheSeamNavModule {
3676
+ }
3677
+ TheSeamNavModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3678
+ TheSeamNavModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavModule, declarations: [NavItemComponent,
3679
+ HorizontalNavComponent], imports: [CommonModule,
3680
+ RouterModule,
3681
+ TheSeamIconModule,
3682
+ A11yModule,
3683
+ TheSeamScrollbarModule,
3684
+ TheSeamLayoutModule,
3685
+ NgbTooltipModule,
3686
+ PortalModule,
3687
+ TheSeamMenuModule], exports: [NavItemComponent,
3688
+ HorizontalNavComponent] });
3689
+ TheSeamNavModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavModule, providers: [
3690
+ TheSeamNavService,
3691
+ ], imports: [CommonModule,
3692
+ RouterModule,
3693
+ TheSeamIconModule,
3694
+ A11yModule,
3695
+ TheSeamScrollbarModule,
3696
+ TheSeamLayoutModule,
3697
+ NgbTooltipModule,
3698
+ PortalModule,
3699
+ TheSeamMenuModule] });
3700
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamNavModule, decorators: [{
3701
+ type: NgModule,
3702
+ args: [{
3703
+ declarations: [
3704
+ NavItemComponent,
3705
+ HorizontalNavComponent,
3706
+ ],
3707
+ imports: [
3708
+ CommonModule,
3709
+ RouterModule,
3710
+ TheSeamIconModule,
3711
+ A11yModule,
3712
+ TheSeamScrollbarModule,
3713
+ TheSeamLayoutModule,
3714
+ NgbTooltipModule,
3715
+ PortalModule,
3716
+ TheSeamMenuModule
3717
+ ],
3718
+ exports: [
3719
+ NavItemComponent,
3720
+ HorizontalNavComponent,
3721
+ ],
3722
+ providers: [
3723
+ TheSeamNavService,
3724
+ ]
3725
+ }]
3726
+ }] });
3727
+
3728
+ /**
3729
+ * Generated bundle index. Do not edit.
3730
+ */
3731
+
3732
+ export { BaseLayoutContentDirective, BaseLayoutContentFooterDirective, BaseLayoutContentHeaderDirective, BaseLayoutNavToggleDirective, BaseLayoutSideBarDirective, BaseLayoutSideBarFooterDirective, BaseLayoutSideBarHeaderDirective, BaseLayoutTopBarDirective, DashboardComponent, DashboardWidgetContainerComponent, DashboardWidgetPortalOutletDirective, DashboardWidgetTemplateContainerComponent, DashboardWidgetsComponent, DashboardWidgetsPreferencesService, DashboardWidgetsService, HierarchyLevelResolver, HierarchyRouterOutletComponent, HorizontalNavComponent, NavItemComponent, SideNavComponent, SideNavItemComponent, SideNavToggleComponent, THESEAM_BASE_LAYOUT_REF, THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR, THESEAM_SIDE_NAV_ACCESSOR, THE_SEAM_BASE_LAYOUT, TheSeamBaseLayoutComponent, TheSeamBaseLayoutModule, TheSeamDashboardModule, TheSeamDynamicRouterModule, TheSeamFramework, TheSeamNavModule, TheSeamSchemaFormFrameworkComponent, TheSeamSchemaFormModule, TheSeamSideNavModule, TheSeamTopBarComponent, TheSeamTopBarModule, TopBarCompactMenuBtnDetailDirective, TopBarItemDirective, TopBarMenuBtnDetailDirective, TopBarMenuButtonComponent, TopBarMenuDirective, TopBarNavToggleBtnDetailDirective, TopBarTitleComponent, areSameHorizontalNavItem, canBeActive, canExpand, canHaveChildren, fader, findHorizontalNavLinkItems, findLinkItems, getHorizontalNavItemStateProp, getItemStateProp, hasActiveChild, hasChildren, hasExpandedChild, horizontalNavItemCanBeActive, horizontalNavItemCanExpand, horizontalNavItemCanHaveChildren, horizontalNavItemHasActiveChild, horizontalNavItemHasChildren, horizontalNavItemHasExpandedChild, isExpanded, isHorizontalNavItemActive, isHorizontalNavItemExpanded, isHorizontalNavItemFocused, isHorizontalNavItemType, isNavItemActive, isNavItemType, routeChanges, setDefaultHorizontalNavItemState, setDefaultState, setHorizontalNavItemStateProp, setItemStateProp, sideNavExpandStateChangeFn, sideToSide, slider, stepper, transformer };
3733
+ //# sourceMappingURL=theseam-ui-common-framework.mjs.map