@theseam/ui-common 0.4.30 → 1.0.0-beta.0

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 (1895) hide show
  1. package/ai/index.d.ts +2 -0
  2. package/asset-reader/index.d.ts +67 -5
  3. package/breadcrumbs/index.d.ts +46 -5
  4. package/buttons/index.d.ts +220 -5
  5. package/card/index.d.ts +46 -5
  6. package/carousel/index.d.ts +100 -5
  7. package/checkbox/index.d.ts +200 -5
  8. package/confirm-dialog/index.d.ts +64 -5
  9. package/core/index.d.ts +139 -5
  10. package/data-exporter/index.d.ts +60 -5
  11. package/data-filters/index.d.ts +219 -5
  12. package/datatable/index.d.ts +1339 -5
  13. package/datatable-alterations-display/index.d.ts +101 -0
  14. package/datatable-dynamic/index.d.ts +548 -5
  15. package/dynamic/index.d.ts +469 -5
  16. package/dynamic-component-loader/index.d.ts +42 -5
  17. package/fesm2022/theseam-ui-common-ai.mjs +6 -0
  18. package/fesm2022/theseam-ui-common-ai.mjs.map +1 -0
  19. package/fesm2022/theseam-ui-common-asset-reader.mjs +193 -0
  20. package/fesm2022/theseam-ui-common-asset-reader.mjs.map +1 -0
  21. package/fesm2022/theseam-ui-common-breadcrumbs.mjs +171 -0
  22. package/fesm2022/theseam-ui-common-breadcrumbs.mjs.map +1 -0
  23. package/fesm2022/theseam-ui-common-buttons.mjs +478 -0
  24. package/fesm2022/theseam-ui-common-buttons.mjs.map +1 -0
  25. package/fesm2022/theseam-ui-common-card.mjs +128 -0
  26. package/fesm2022/theseam-ui-common-card.mjs.map +1 -0
  27. package/fesm2022/theseam-ui-common-carousel.mjs +269 -0
  28. package/fesm2022/theseam-ui-common-carousel.mjs.map +1 -0
  29. package/fesm2022/theseam-ui-common-checkbox.mjs +393 -0
  30. package/fesm2022/theseam-ui-common-checkbox.mjs.map +1 -0
  31. package/fesm2022/theseam-ui-common-confirm-dialog.mjs +183 -0
  32. package/fesm2022/theseam-ui-common-confirm-dialog.mjs.map +1 -0
  33. package/fesm2022/theseam-ui-common-core.mjs +229 -0
  34. package/fesm2022/theseam-ui-common-core.mjs.map +1 -0
  35. package/fesm2022/theseam-ui-common-data-exporter.mjs +89 -0
  36. package/fesm2022/theseam-ui-common-data-exporter.mjs.map +1 -0
  37. package/fesm2022/theseam-ui-common-data-filters.mjs +516 -0
  38. package/fesm2022/theseam-ui-common-data-filters.mjs.map +1 -0
  39. package/fesm2022/theseam-ui-common-datatable-alterations-display.mjs +350 -0
  40. package/fesm2022/theseam-ui-common-datatable-alterations-display.mjs.map +1 -0
  41. package/fesm2022/theseam-ui-common-datatable-dynamic.mjs +1096 -0
  42. package/fesm2022/theseam-ui-common-datatable-dynamic.mjs.map +1 -0
  43. package/fesm2022/theseam-ui-common-datatable.mjs +4263 -0
  44. package/fesm2022/theseam-ui-common-datatable.mjs.map +1 -0
  45. package/fesm2022/theseam-ui-common-dynamic-component-loader.mjs +134 -0
  46. package/fesm2022/theseam-ui-common-dynamic-component-loader.mjs.map +1 -0
  47. package/fesm2022/theseam-ui-common-dynamic.mjs +699 -0
  48. package/fesm2022/theseam-ui-common-dynamic.mjs.map +1 -0
  49. package/fesm2022/theseam-ui-common-footer-bar.mjs +38 -0
  50. package/fesm2022/theseam-ui-common-footer-bar.mjs.map +1 -0
  51. package/fesm2022/theseam-ui-common-form-field-error.mjs +494 -0
  52. package/fesm2022/theseam-ui-common-form-field-error.mjs.map +1 -0
  53. package/fesm2022/theseam-ui-common-form-field.mjs +675 -0
  54. package/fesm2022/theseam-ui-common-form-field.mjs.map +1 -0
  55. package/fesm2022/theseam-ui-common-framework.mjs +4018 -0
  56. package/fesm2022/theseam-ui-common-framework.mjs.map +1 -0
  57. package/fesm2022/theseam-ui-common-google-maps.mjs +2191 -0
  58. package/fesm2022/theseam-ui-common-google-maps.mjs.map +1 -0
  59. package/fesm2022/theseam-ui-common-graphql.mjs +1745 -0
  60. package/fesm2022/theseam-ui-common-graphql.mjs.map +1 -0
  61. package/fesm2022/theseam-ui-common-icon.mjs +646 -0
  62. package/fesm2022/theseam-ui-common-icon.mjs.map +1 -0
  63. package/fesm2022/theseam-ui-common-layout.mjs +118 -0
  64. package/fesm2022/theseam-ui-common-layout.mjs.map +1 -0
  65. package/fesm2022/theseam-ui-common-loading.mjs +130 -0
  66. package/fesm2022/theseam-ui-common-loading.mjs.map +1 -0
  67. package/fesm2022/theseam-ui-common-menu.mjs +1322 -0
  68. package/fesm2022/theseam-ui-common-menu.mjs.map +1 -0
  69. package/fesm2022/theseam-ui-common-modal.mjs +1447 -0
  70. package/fesm2022/theseam-ui-common-modal.mjs.map +1 -0
  71. package/fesm2022/theseam-ui-common-models.mjs +55 -0
  72. package/fesm2022/theseam-ui-common-models.mjs.map +1 -0
  73. package/fesm2022/theseam-ui-common-navigation-reload.mjs +72 -0
  74. package/fesm2022/theseam-ui-common-navigation-reload.mjs.map +1 -0
  75. package/fesm2022/theseam-ui-common-popover.mjs +520 -0
  76. package/fesm2022/theseam-ui-common-popover.mjs.map +1 -0
  77. package/fesm2022/theseam-ui-common-progress.mjs +97 -0
  78. package/fesm2022/theseam-ui-common-progress.mjs.map +1 -0
  79. package/fesm2022/theseam-ui-common-rich-text.mjs +782 -0
  80. package/fesm2022/theseam-ui-common-rich-text.mjs.map +1 -0
  81. package/fesm2022/theseam-ui-common-scrollbar.mjs +158 -0
  82. package/fesm2022/theseam-ui-common-scrollbar.mjs.map +1 -0
  83. package/fesm2022/theseam-ui-common-services.mjs +281 -0
  84. package/fesm2022/theseam-ui-common-services.mjs.map +1 -0
  85. package/fesm2022/theseam-ui-common-shared.mjs +719 -0
  86. package/fesm2022/theseam-ui-common-shared.mjs.map +1 -0
  87. package/fesm2022/theseam-ui-common-storage.mjs +146 -0
  88. package/fesm2022/theseam-ui-common-storage.mjs.map +1 -0
  89. package/fesm2022/theseam-ui-common-story-helpers.mjs +512 -0
  90. package/fesm2022/theseam-ui-common-story-helpers.mjs.map +1 -0
  91. package/fesm2022/theseam-ui-common-tabbed.mjs +292 -0
  92. package/fesm2022/theseam-ui-common-tabbed.mjs.map +1 -0
  93. package/fesm2022/theseam-ui-common-table-cell-type.mjs +211 -0
  94. package/fesm2022/theseam-ui-common-table-cell-type.mjs.map +1 -0
  95. package/fesm2022/theseam-ui-common-table-cell-types.mjs +1207 -0
  96. package/fesm2022/theseam-ui-common-table-cell-types.mjs.map +1 -0
  97. package/fesm2022/theseam-ui-common-table.mjs +341 -0
  98. package/fesm2022/theseam-ui-common-table.mjs.map +1 -0
  99. package/fesm2022/theseam-ui-common-tel-input.mjs +843 -0
  100. package/fesm2022/theseam-ui-common-tel-input.mjs.map +1 -0
  101. package/fesm2022/theseam-ui-common-testing.mjs +315 -0
  102. package/fesm2022/theseam-ui-common-testing.mjs.map +1 -0
  103. package/fesm2022/theseam-ui-common-tiled-select.mjs +584 -0
  104. package/fesm2022/theseam-ui-common-tiled-select.mjs.map +1 -0
  105. package/fesm2022/theseam-ui-common-toggle-edit.mjs +517 -0
  106. package/fesm2022/theseam-ui-common-toggle-edit.mjs.map +1 -0
  107. package/fesm2022/theseam-ui-common-toggle-group.mjs +269 -0
  108. package/fesm2022/theseam-ui-common-toggle-group.mjs.map +1 -0
  109. package/fesm2022/theseam-ui-common-tooltip.mjs +592 -0
  110. package/fesm2022/theseam-ui-common-tooltip.mjs.map +1 -0
  111. package/fesm2022/theseam-ui-common-unsaved-changes-dialog.mjs +78 -0
  112. package/fesm2022/theseam-ui-common-unsaved-changes-dialog.mjs.map +1 -0
  113. package/fesm2022/theseam-ui-common-utils.mjs +1366 -0
  114. package/fesm2022/theseam-ui-common-utils.mjs.map +1 -0
  115. package/fesm2022/theseam-ui-common-validators.mjs +94 -0
  116. package/fesm2022/theseam-ui-common-validators.mjs.map +1 -0
  117. package/fesm2022/theseam-ui-common-vertical-list-filter.mjs +85 -0
  118. package/fesm2022/theseam-ui-common-vertical-list-filter.mjs.map +1 -0
  119. package/fesm2022/theseam-ui-common-viewers.mjs +566 -0
  120. package/fesm2022/theseam-ui-common-viewers.mjs.map +1 -0
  121. package/fesm2022/theseam-ui-common-widget.mjs +1466 -0
  122. package/fesm2022/theseam-ui-common-widget.mjs.map +1 -0
  123. package/fesm2022/theseam-ui-common.mjs +7 -0
  124. package/fesm2022/theseam-ui-common.mjs.map +1 -0
  125. package/footer-bar/index.d.ts +15 -5
  126. package/form-field/index.d.ts +255 -5
  127. package/form-field-error/index.d.ts +102 -5
  128. package/framework/index.d.ts +1372 -5
  129. package/framework/nav/nav-item/nav-item.component.scss +3 -1
  130. package/framework/nav/styles/_themes/light/_variables.scss +6 -4
  131. package/framework/nav/styles/_themes/primary/_variables.scss +6 -4
  132. package/framework/side-nav/side-nav-item/side-nav-item.component.scss +3 -1
  133. package/framework/side-nav/styles/_themes/light/_variables.scss +3 -1
  134. package/framework/side-nav/styles/_themes/primary/_variables.scss +7 -5
  135. package/google-maps/index.d.ts +657 -5
  136. package/graphql/index.d.ts +336 -5
  137. package/icon/index.d.ts +193 -5
  138. package/index.d.ts +2 -5
  139. package/layout/index.d.ts +61 -5
  140. package/loading/index.d.ts +42 -5
  141. package/menu/index.d.ts +437 -5
  142. package/modal/index.d.ts +531 -5
  143. package/models/index.d.ts +36 -5
  144. package/navigation-reload/index.d.ts +24 -5
  145. package/package.json +185 -316
  146. package/popover/index.d.ts +127 -5
  147. package/progress/index.d.ts +38 -5
  148. package/progress/progress-circle/styles/_variables.scss +5 -3
  149. package/rich-text/index.d.ts +537 -5
  150. package/scrollbar/index.d.ts +95 -5
  151. package/services/index.d.ts +129 -5
  152. package/shared/index.d.ts +229 -5
  153. package/storage/index.d.ts +35 -5
  154. package/story-helpers/index.d.ts +184 -5
  155. package/styles/bootstrap/_bs-variables.scss +5 -3
  156. package/styles/vendor/ngx-datatable/_ngx-datatable.scss +1 -1
  157. package/styles/vendor/ngx-datatable/_themes/bootstrap/_variables.scss +6 -4
  158. package/styles/vendor/quill/_quill.scss +2 -2
  159. package/tabbed/index.d.ts +108 -5
  160. package/table/index.d.ts +110 -5
  161. package/table-cell-type/index.d.ts +145 -5
  162. package/table-cell-types/index.d.ts +537 -5
  163. package/tel-input/index.d.ts +532 -5
  164. package/testing/index.d.ts +220 -5
  165. package/tiled-select/index.d.ts +179 -5
  166. package/toggle-edit/index.d.ts +160 -5
  167. package/toggle-group/index.d.ts +61 -5
  168. package/tooltip/index.d.ts +118 -0
  169. package/unsaved-changes-dialog/index.d.ts +24 -5
  170. package/utils/index.d.ts +434 -5
  171. package/validators/index.d.ts +49 -5
  172. package/vertical-list-filter/index.d.ts +31 -5
  173. package/viewers/index.d.ts +173 -5
  174. package/widget/index.d.ts +535 -5
  175. package/asset-reader/asset-reader-helper.service.d.ts +0 -10
  176. package/asset-reader/asset-reader.module.d.ts +0 -7
  177. package/asset-reader/encrypted-asset-link.directive.d.ts +0 -26
  178. package/asset-reader/encrypted-asset-reader.d.ts +0 -24
  179. package/asset-reader/public-api.d.ts +0 -4
  180. package/breadcrumbs/breadcrumb.d.ts +0 -11
  181. package/breadcrumbs/breadcrumbs/breadcrumbs.component.d.ts +0 -11
  182. package/breadcrumbs/breadcrumbs-resolver.d.ts +0 -5
  183. package/breadcrumbs/breadcrumbs.module.d.ts +0 -9
  184. package/breadcrumbs/breadcrumbs.service.d.ts +0 -23
  185. package/breadcrumbs/public-api.d.ts +0 -5
  186. package/buttons/badge-button/badge-button.component.d.ts +0 -23
  187. package/buttons/button/button.component.d.ts +0 -35
  188. package/buttons/buttons.module.d.ts +0 -12
  189. package/buttons/progress-circle-button/progress-circle-button.component.d.ts +0 -22
  190. package/buttons/public-api.d.ts +0 -6
  191. package/buttons/testing/anchor-badge-button.harness.d.ts +0 -16
  192. package/buttons/testing/anchor-button.harness.d.ts +0 -16
  193. package/buttons/testing/badge-button.harness.d.ts +0 -15
  194. package/buttons/testing/base-badge-button.harness.d.ts +0 -15
  195. package/buttons/testing/base-button.harness.d.ts +0 -19
  196. package/buttons/testing/button.harness.d.ts +0 -15
  197. package/buttons/testing/index.d.ts +0 -5
  198. package/buttons/testing/toggle-button.harness.d.ts +0 -21
  199. package/buttons/toggle-button/toggle-button.component.d.ts +0 -29
  200. package/card/card-action/card-action.component.d.ts +0 -12
  201. package/card/card-body/card-body.component.d.ts +0 -13
  202. package/card/card-footer/card-footer.component.d.ts +0 -5
  203. package/card/card-header/card-header.component.d.ts +0 -7
  204. package/card/card.component.d.ts +0 -6
  205. package/card/card.module.d.ts +0 -13
  206. package/card/public-api.d.ts +0 -6
  207. package/carousel/carousel-slide.directive.d.ts +0 -8
  208. package/carousel/carousel.component.d.ts +0 -85
  209. package/carousel/carousel.module.d.ts +0 -11
  210. package/carousel/public-api.d.ts +0 -3
  211. package/checkbox/checkbox.component.d.ts +0 -141
  212. package/checkbox/checkbox.module.d.ts +0 -8
  213. package/checkbox/public-api.d.ts +0 -3
  214. package/checkbox/testing/checkbox.harness.d.ts +0 -49
  215. package/checkbox/testing/index.d.ts +0 -1
  216. package/confirm-dialog/confirm-click.directive.d.ts +0 -31
  217. package/confirm-dialog/confirm-dialog.component.d.ts +0 -16
  218. package/confirm-dialog/confirm-dialog.module.d.ts +0 -12
  219. package/confirm-dialog/confirm-dialog.service.d.ts +0 -18
  220. package/confirm-dialog/public-api.d.ts +0 -4
  221. package/core/common-behaviors/active.d.ts +0 -8
  222. package/core/common-behaviors/constructor.d.ts +0 -9
  223. package/core/common-behaviors/disabled.d.ts +0 -17
  224. package/core/common-behaviors/element-ref.d.ts +0 -4
  225. package/core/common-behaviors/index.d.ts +0 -9
  226. package/core/common-behaviors/initialized.d.ts +0 -30
  227. package/core/common-behaviors/renderer2.d.ts +0 -4
  228. package/core/common-behaviors/size.d.ts +0 -9
  229. package/core/common-behaviors/tabindex.d.ts +0 -18
  230. package/core/common-behaviors/theme.d.ts +0 -10
  231. package/core/input-decorators/index.d.ts +0 -2
  232. package/core/input-decorators/input-boolean.decorator.d.ts +0 -12
  233. package/core/input-decorators/input-number.decorator.d.ts +0 -12
  234. package/core/public-api.d.ts +0 -2
  235. package/data-exporter/data-exporter.d.ts +0 -30
  236. package/data-exporter/data-exporter.module.d.ts +0 -6
  237. package/data-exporter/exporters/csv-exporter.d.ts +0 -11
  238. package/data-exporter/exporters/xlsx-exporter.d.ts +0 -11
  239. package/data-exporter/public-api.d.ts +0 -4
  240. package/data-filters/data-filter-container.d.ts +0 -8
  241. package/data-filters/data-filter-def.d.ts +0 -10
  242. package/data-filters/data-filter.d.ts +0 -53
  243. package/data-filters/data-filters.module.d.ts +0 -15
  244. package/data-filters/filters/data-filter-search/data-filter-search.component.d.ts +0 -39
  245. package/data-filters/filters/data-filter-search/search-filter-options.d.ts +0 -2
  246. package/data-filters/filters/data-filter-text/data-filter-text.component.d.ts +0 -37
  247. package/data-filters/filters/data-filter-text/text-filter-options.d.ts +0 -25
  248. package/data-filters/filters/data-filter-toggle-buttons/data-filter-toggle-buttons.component.d.ts +0 -46
  249. package/data-filters/public-api.d.ts +0 -9
  250. package/datatable/datatable/datatable.component.d.ts +0 -266
  251. package/datatable/datatable-action-menu/datatable-action-menu.component.d.ts +0 -23
  252. package/datatable/datatable-action-menu-item/datatable-action-menu-item.component.d.ts +0 -33
  253. package/datatable/datatable-column/datatable-column.component.d.ts +0 -44
  254. package/datatable/datatable-column-filter-menu/datatable-column-filter-menu.component.d.ts +0 -25
  255. package/datatable/datatable-column-filter-search-date/datatable-column-filter-search-date.component.d.ts +0 -18
  256. package/datatable/datatable-column-filter-search-numeric/datatable-column-filter-search-numeric.component.d.ts +0 -16
  257. package/datatable/datatable-column-filter-search-text/datatable-column-filter-search-text.component.d.ts +0 -15
  258. package/datatable/datatable-column-preferences/datatable-column-preferences.component.d.ts +0 -18
  259. package/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.d.ts +0 -13
  260. package/datatable/datatable-export-button/datatable-export-button.component.d.ts +0 -25
  261. package/datatable/datatable-footer/datatable-footer-tpl.directive.d.ts +0 -8
  262. package/datatable/datatable-footer/datatable-footer.directive.d.ts +0 -9
  263. package/datatable/datatable-menu-bar/datatable-menu-bar.component.d.ts +0 -17
  264. package/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.d.ts +0 -5
  265. package/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.d.ts +0 -5
  266. package/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.d.ts +0 -5
  267. package/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.d.ts +0 -5
  268. package/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.d.ts +0 -11
  269. package/datatable/datatable-row-detail/datatable-row-detail-tpl.directive.d.ts +0 -8
  270. package/datatable/datatable-row-detail/datatable-row-detail.directive.d.ts +0 -40
  271. package/datatable/datatable.module.d.ts +0 -56
  272. package/datatable/directives/datatable-action-menu-item.directive.d.ts +0 -36
  273. package/datatable/directives/datatable-action-menu-toggle.directive.d.ts +0 -30
  274. package/datatable/directives/datatable-cell-tpl.directive.d.ts +0 -8
  275. package/datatable/directives/datatable-column-filter-tpl.directive.d.ts +0 -8
  276. package/datatable/directives/datatable-column-filter.directive.d.ts +0 -10
  277. package/datatable/directives/datatable-filter.directive.d.ts +0 -9
  278. package/datatable/directives/datatable-row-action-item.directive.d.ts +0 -8
  279. package/datatable/models/action-item-column-position.d.ts +0 -13
  280. package/datatable/models/columns-alteration.d.ts +0 -61
  281. package/datatable/models/columns-alterations/hide-column.columns-alteration.d.ts +0 -15
  282. package/datatable/models/columns-alterations/order.columns-alteration.d.ts +0 -20
  283. package/datatable/models/columns-alterations/sort.columns-alteration.d.ts +0 -14
  284. package/datatable/models/columns-alterations/width.columns-alteration.d.ts +0 -16
  285. package/datatable/models/columns-data-filter.d.ts +0 -57
  286. package/datatable/models/columns-data-filters/models.d.ts +0 -65
  287. package/datatable/models/columns-data-filters/search-date.columns-data-filter.d.ts +0 -23
  288. package/datatable/models/columns-data-filters/search-numeric.columns-data-filter.d.ts +0 -22
  289. package/datatable/models/columns-data-filters/search-text.columns-data-filter.d.ts +0 -21
  290. package/datatable/models/columns-data-filters/utils.d.ts +0 -15
  291. package/datatable/models/datatable-accessor.d.ts +0 -21
  292. package/datatable/models/datatable-config.d.ts +0 -97
  293. package/datatable/models/datatable-data-source.d.ts +0 -14
  294. package/datatable/models/datatable-gql-data-source.d.ts +0 -7
  295. package/datatable/models/internal-column-props.d.ts +0 -7
  296. package/datatable/models/menubar-item-data.d.ts +0 -3
  297. package/datatable/models/page-info.d.ts +0 -18
  298. package/datatable/models/preferences-accessor.d.ts +0 -3
  299. package/datatable/models/preferences.d.ts +0 -18
  300. package/datatable/models/sort-event.d.ts +0 -4
  301. package/datatable/models/sort-item.d.ts +0 -5
  302. package/datatable/models/table-column.d.ts +0 -35
  303. package/datatable/public-api.d.ts +0 -54
  304. package/datatable/services/columns-alterations-manager.service.d.ts +0 -42
  305. package/datatable/services/columns-filters.service.d.ts +0 -29
  306. package/datatable/services/columns-manager.service.d.ts +0 -65
  307. package/datatable/services/datatable-column-changes.service.d.ts +0 -9
  308. package/datatable/services/datatable-preferences.service.d.ts +0 -22
  309. package/datatable/services/datatable-scrollbar-helper.service.d.ts +0 -22
  310. package/datatable/tokens/datatable-accessor.d.ts +0 -3
  311. package/datatable/tokens/datatable-preferences-accessor.d.ts +0 -3
  312. package/datatable/tokens/menubar-item-data.d.ts +0 -3
  313. package/datatable/utils/create-action-menu-column.d.ts +0 -3
  314. package/datatable/utils/create-checkbox-column.d.ts +0 -3
  315. package/datatable/utils/get-column-prop.d.ts +0 -5
  316. package/datatable/utils/map-columns-alterations-states.d.ts +0 -2
  317. package/datatable/utils/remove-unused-diffs.d.ts +0 -7
  318. package/datatable/utils/set-column-defaults.d.ts +0 -2
  319. package/datatable/utils/translate-templates.d.ts +0 -2
  320. package/datatable/utils/with-stored-column-info.d.ts +0 -3
  321. package/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.d.ts +0 -33
  322. package/datatable-dynamic/datatable-dynamic-def.d.ts +0 -71
  323. package/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.d.ts +0 -18
  324. package/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.d.ts +0 -63
  325. package/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.d.ts +0 -16
  326. package/datatable-dynamic/datatable-dynamic-menu-bar-token.d.ts +0 -3
  327. package/datatable-dynamic/datatable-dynamic.component.d.ts +0 -89
  328. package/datatable-dynamic/datatable-dynamic.module.d.ts +0 -22
  329. package/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.d.ts +0 -75
  330. package/datatable-dynamic/dynamic-datatable-def.service.d.ts +0 -62
  331. package/datatable-dynamic/dynamic-datatable-row-actions.service.d.ts +0 -19
  332. package/datatable-dynamic/models/dynamic-datatable-action-menu-record.d.ts +0 -17
  333. package/datatable-dynamic/models/dynamic-datatable-filter-menu-item.d.ts +0 -7
  334. package/datatable-dynamic/models/dynamic-datatable-menu-bar.d.ts +0 -63
  335. package/datatable-dynamic/models/dynamic-datatable-row-action-context.d.ts +0 -5
  336. package/datatable-dynamic/models/dynamic-datatable-row-action.d.ts +0 -17
  337. package/datatable-dynamic/models/index.d.ts +0 -5
  338. package/datatable-dynamic/public-api.d.ts +0 -13
  339. package/datatable-dynamic/utils/defaults/set-dynamic-datatable-columns-defaults.d.ts +0 -2
  340. package/datatable-dynamic/utils/defaults/set-dynamic-datatable-def-defaults.d.ts +0 -2
  341. package/datatable-dynamic/utils/defaults/set-dynamic-datatable-filter-menu-defaults.d.ts +0 -2
  342. package/datatable-dynamic/utils/defaults/set-dynamic-datatable-options-defaults.d.ts +0 -2
  343. package/datatable-dynamic/utils/index.d.ts +0 -4
  344. package/dynamic/action/api/dynamic-action-api-def.d.ts +0 -35
  345. package/dynamic/action/api/dynamic-action-api-errors.d.ts +0 -1
  346. package/dynamic/action/api/dynamic-action-api.d.ts +0 -3
  347. package/dynamic/action/api/dynamic-action-api.service.d.ts +0 -33
  348. package/dynamic/action/dynamic-action-helper.service.d.ts +0 -39
  349. package/dynamic/action/index.d.ts +0 -10
  350. package/dynamic/action/link/dynamic-action-link-def.d.ts +0 -58
  351. package/dynamic/action/link/dynamic-action-link.d.ts +0 -3
  352. package/dynamic/action/link/dynamic-action-link.service.d.ts +0 -17
  353. package/dynamic/action/modal/dynamic-action-modal-def.d.ts +0 -10
  354. package/dynamic/action/modal/dynamic-action-modal.d.ts +0 -3
  355. package/dynamic/action/modal/dynamic-action-modal.service.d.ts +0 -32
  356. package/dynamic/dynamic-value-helper.service.d.ts +0 -38
  357. package/dynamic/evaluators/exporters-data-evaluator/exporters-data-evaluator.d.ts +0 -19
  358. package/dynamic/evaluators/exporters-data-evaluator/exporters-data-value.d.ts +0 -8
  359. package/dynamic/evaluators/exporters-data-evaluator/index.d.ts +0 -2
  360. package/dynamic/evaluators/index.d.ts +0 -2
  361. package/dynamic/evaluators/jexl-evaluator/index.d.ts +0 -2
  362. package/dynamic/evaluators/jexl-evaluator/jexl-evaluator.d.ts +0 -13
  363. package/dynamic/evaluators/jexl-evaluator/jexl-value.d.ts +0 -11
  364. package/dynamic/models/dynamic-action-confirm-def.d.ts +0 -10
  365. package/dynamic/models/dynamic-action-context.d.ts +0 -2
  366. package/dynamic/models/dynamic-action-def.d.ts +0 -9
  367. package/dynamic/models/dynamic-action-ui-anchor-def.d.ts +0 -39
  368. package/dynamic/models/dynamic-action-ui-button-def.d.ts +0 -13
  369. package/dynamic/models/dynamic-action-ui-def.d.ts +0 -37
  370. package/dynamic/models/dynamic-action.d.ts +0 -11
  371. package/dynamic/models/dynamic-value-base-type.d.ts +0 -4
  372. package/dynamic/models/dynamic-value-evaluatable-type.d.ts +0 -3
  373. package/dynamic/models/dynamic-value-evaluator.d.ts +0 -6
  374. package/dynamic/models/dynamic-value-primitive.d.ts +0 -1
  375. package/dynamic/models/dynamic-value-type.d.ts +0 -4
  376. package/dynamic/models/dynamic-value.d.ts +0 -3
  377. package/dynamic/models/index.d.ts +0 -13
  378. package/dynamic/public-api.d.ts +0 -6
  379. package/dynamic/tokens/api-config.d.ts +0 -30
  380. package/dynamic/tokens/dynamic-action.d.ts +0 -3
  381. package/dynamic/tokens/dynamic-data.d.ts +0 -2
  382. package/dynamic/tokens/dynamic-value-evaluator.d.ts +0 -3
  383. package/dynamic/tokens/index.d.ts +0 -4
  384. package/dynamic/utils/index.d.ts +0 -1
  385. package/dynamic/utils/is-action-type.d.ts +0 -2
  386. package/dynamic-component-loader/dynamic-component-loader.module.d.ts +0 -11
  387. package/dynamic-component-loader/dynamic-component-loader.service.d.ts +0 -16
  388. package/dynamic-component-loader/dynamic-component-manifest.d.ts +0 -9
  389. package/dynamic-component-loader/dynamic-component-tokens.d.ts +0 -4
  390. package/dynamic-component-loader/public-api.d.ts +0 -4
  391. package/esm2020/asset-reader/asset-reader-helper.service.mjs +0 -70
  392. package/esm2020/asset-reader/asset-reader.module.mjs +0 -20
  393. package/esm2020/asset-reader/encrypted-asset-link.directive.mjs +0 -74
  394. package/esm2020/asset-reader/encrypted-asset-reader.mjs +0 -20
  395. package/esm2020/asset-reader/public-api.mjs +0 -5
  396. package/esm2020/asset-reader/theseam-ui-common-asset-reader.mjs +0 -5
  397. package/esm2020/breadcrumbs/breadcrumb.mjs +0 -2
  398. package/esm2020/breadcrumbs/breadcrumbs/breadcrumbs.component.mjs +0 -18
  399. package/esm2020/breadcrumbs/breadcrumbs-resolver.mjs +0 -2
  400. package/esm2020/breadcrumbs/breadcrumbs.module.mjs +0 -28
  401. package/esm2020/breadcrumbs/breadcrumbs.service.mjs +0 -156
  402. package/esm2020/breadcrumbs/public-api.mjs +0 -6
  403. package/esm2020/breadcrumbs/theseam-ui-common-breadcrumbs.mjs +0 -5
  404. package/esm2020/buttons/badge-button/badge-button.component.mjs +0 -62
  405. package/esm2020/buttons/button/button.component.mjs +0 -85
  406. package/esm2020/buttons/buttons.module.mjs +0 -51
  407. package/esm2020/buttons/progress-circle-button/progress-circle-button.component.mjs +0 -52
  408. package/esm2020/buttons/public-api.mjs +0 -7
  409. package/esm2020/buttons/testing/anchor-badge-button.harness.mjs +0 -18
  410. package/esm2020/buttons/testing/anchor-button.harness.mjs +0 -18
  411. package/esm2020/buttons/testing/badge-button.harness.mjs +0 -14
  412. package/esm2020/buttons/testing/base-badge-button.harness.mjs +0 -29
  413. package/esm2020/buttons/testing/base-button.harness.mjs +0 -41
  414. package/esm2020/buttons/testing/button.harness.mjs +0 -16
  415. package/esm2020/buttons/testing/index.mjs +0 -6
  416. package/esm2020/buttons/testing/toggle-button.harness.mjs +0 -25
  417. package/esm2020/buttons/theseam-ui-common-buttons.mjs +0 -5
  418. package/esm2020/buttons/toggle-button/toggle-button.component.mjs +0 -79
  419. package/esm2020/card/card-action/card-action.component.mjs +0 -31
  420. package/esm2020/card/card-body/card-body.component.mjs +0 -32
  421. package/esm2020/card/card-footer/card-footer.component.mjs +0 -11
  422. package/esm2020/card/card-header/card-header.component.mjs +0 -21
  423. package/esm2020/card/card.component.mjs +0 -17
  424. package/esm2020/card/card.module.mjs +0 -48
  425. package/esm2020/card/public-api.mjs +0 -7
  426. package/esm2020/card/theseam-ui-common-card.mjs +0 -5
  427. package/esm2020/carousel/carousel-slide.directive.mjs +0 -16
  428. package/esm2020/carousel/carousel.component.mjs +0 -212
  429. package/esm2020/carousel/carousel.module.mjs +0 -38
  430. package/esm2020/carousel/public-api.mjs +0 -4
  431. package/esm2020/carousel/theseam-ui-common-carousel.mjs +0 -5
  432. package/esm2020/checkbox/checkbox.component.mjs +0 -285
  433. package/esm2020/checkbox/checkbox.module.mjs +0 -21
  434. package/esm2020/checkbox/public-api.mjs +0 -4
  435. package/esm2020/checkbox/testing/checkbox.harness.mjs +0 -63
  436. package/esm2020/checkbox/testing/index.mjs +0 -2
  437. package/esm2020/checkbox/theseam-ui-common-checkbox.mjs +0 -5
  438. package/esm2020/confirm-dialog/confirm-click.directive.mjs +0 -71
  439. package/esm2020/confirm-dialog/confirm-dialog.component.mjs +0 -38
  440. package/esm2020/confirm-dialog/confirm-dialog.module.mjs +0 -47
  441. package/esm2020/confirm-dialog/confirm-dialog.service.mjs +0 -41
  442. package/esm2020/confirm-dialog/public-api.mjs +0 -5
  443. package/esm2020/confirm-dialog/theseam-ui-common-confirm-dialog.mjs +0 -5
  444. package/esm2020/core/common-behaviors/active.mjs +0 -14
  445. package/esm2020/core/common-behaviors/constructor.mjs +0 -9
  446. package/esm2020/core/common-behaviors/disabled.mjs +0 -21
  447. package/esm2020/core/common-behaviors/element-ref.mjs +0 -2
  448. package/esm2020/core/common-behaviors/index.mjs +0 -10
  449. package/esm2020/core/common-behaviors/initialized.mjs +0 -63
  450. package/esm2020/core/common-behaviors/renderer2.mjs +0 -2
  451. package/esm2020/core/common-behaviors/size.mjs +0 -24
  452. package/esm2020/core/common-behaviors/tabindex.mjs +0 -23
  453. package/esm2020/core/common-behaviors/theme.mjs +0 -24
  454. package/esm2020/core/input-decorators/index.mjs +0 -3
  455. package/esm2020/core/input-decorators/input-boolean.decorator.mjs +0 -26
  456. package/esm2020/core/input-decorators/input-number.decorator.mjs +0 -26
  457. package/esm2020/core/public-api.mjs +0 -3
  458. package/esm2020/core/theseam-ui-common-core.mjs +0 -5
  459. package/esm2020/data-exporter/data-exporter.mjs +0 -7
  460. package/esm2020/data-exporter/data-exporter.module.mjs +0 -25
  461. package/esm2020/data-exporter/exporters/csv-exporter.mjs +0 -35
  462. package/esm2020/data-exporter/exporters/xlsx-exporter.mjs +0 -33
  463. package/esm2020/data-exporter/public-api.mjs +0 -5
  464. package/esm2020/data-exporter/theseam-ui-common-data-exporter.mjs +0 -5
  465. package/esm2020/data-filters/data-filter-container.mjs +0 -3
  466. package/esm2020/data-filters/data-filter-def.mjs +0 -3
  467. package/esm2020/data-filters/data-filter.mjs +0 -25
  468. package/esm2020/data-filters/data-filters.module.mjs +0 -66
  469. package/esm2020/data-filters/filters/data-filter-search/data-filter-search.component.mjs +0 -121
  470. package/esm2020/data-filters/filters/data-filter-search/search-filter-options.mjs +0 -2
  471. package/esm2020/data-filters/filters/data-filter-text/data-filter-text.component.mjs +0 -148
  472. package/esm2020/data-filters/filters/data-filter-text/text-filter-options.mjs +0 -2
  473. package/esm2020/data-filters/filters/data-filter-toggle-buttons/data-filter-toggle-buttons.component.mjs +0 -166
  474. package/esm2020/data-filters/public-api.mjs +0 -10
  475. package/esm2020/data-filters/theseam-ui-common-data-filters.mjs +0 -5
  476. package/esm2020/datatable/datatable/datatable.component.mjs +0 -879
  477. package/esm2020/datatable/datatable-action-menu/datatable-action-menu.component.mjs +0 -112
  478. package/esm2020/datatable/datatable-action-menu-item/datatable-action-menu-item.component.mjs +0 -50
  479. package/esm2020/datatable/datatable-column/datatable-column.component.mjs +0 -107
  480. package/esm2020/datatable/datatable-column-filter-menu/datatable-column-filter-menu.component.mjs +0 -55
  481. package/esm2020/datatable/datatable-column-filter-search-date/datatable-column-filter-search-date.component.mjs +0 -54
  482. package/esm2020/datatable/datatable-column-filter-search-numeric/datatable-column-filter-search-numeric.component.mjs +0 -48
  483. package/esm2020/datatable/datatable-column-filter-search-text/datatable-column-filter-search-text.component.mjs +0 -44
  484. package/esm2020/datatable/datatable-column-preferences/datatable-column-preferences.component.mjs +0 -67
  485. package/esm2020/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.mjs +0 -51
  486. package/esm2020/datatable/datatable-export-button/datatable-export-button.component.mjs +0 -106
  487. package/esm2020/datatable/datatable-footer/datatable-footer-tpl.directive.mjs +0 -16
  488. package/esm2020/datatable/datatable-footer/datatable-footer.directive.mjs +0 -24
  489. package/esm2020/datatable/datatable-menu-bar/datatable-menu-bar.component.mjs +0 -49
  490. package/esm2020/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.mjs +0 -11
  491. package/esm2020/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.mjs +0 -11
  492. package/esm2020/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.mjs +0 -11
  493. package/esm2020/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.mjs +0 -11
  494. package/esm2020/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.mjs +0 -30
  495. package/esm2020/datatable/datatable-row-detail/datatable-row-detail-tpl.directive.mjs +0 -16
  496. package/esm2020/datatable/datatable-row-detail/datatable-row-detail.directive.mjs +0 -77
  497. package/esm2020/datatable/datatable.module.mjs +0 -247
  498. package/esm2020/datatable/directives/datatable-action-menu-item.directive.mjs +0 -62
  499. package/esm2020/datatable/directives/datatable-action-menu-toggle.directive.mjs +0 -137
  500. package/esm2020/datatable/directives/datatable-cell-tpl.directive.mjs +0 -16
  501. package/esm2020/datatable/directives/datatable-column-filter-tpl.directive.mjs +0 -16
  502. package/esm2020/datatable/directives/datatable-column-filter.directive.mjs +0 -26
  503. package/esm2020/datatable/directives/datatable-filter.directive.mjs +0 -27
  504. package/esm2020/datatable/directives/datatable-row-action-item.directive.mjs +0 -16
  505. package/esm2020/datatable/models/action-item-column-position.mjs +0 -5
  506. package/esm2020/datatable/models/columns-alteration.mjs +0 -38
  507. package/esm2020/datatable/models/columns-alterations/hide-column.columns-alteration.mjs +0 -38
  508. package/esm2020/datatable/models/columns-alterations/order.columns-alteration.mjs +0 -83
  509. package/esm2020/datatable/models/columns-alterations/sort.columns-alteration.mjs +0 -33
  510. package/esm2020/datatable/models/columns-alterations/width.columns-alteration.mjs +0 -41
  511. package/esm2020/datatable/models/columns-data-filter.mjs +0 -10
  512. package/esm2020/datatable/models/columns-data-filters/models.mjs +0 -74
  513. package/esm2020/datatable/models/columns-data-filters/search-date.columns-data-filter.mjs +0 -113
  514. package/esm2020/datatable/models/columns-data-filters/search-numeric.columns-data-filter.mjs +0 -104
  515. package/esm2020/datatable/models/columns-data-filters/search-text.columns-data-filter.mjs +0 -86
  516. package/esm2020/datatable/models/columns-data-filters/utils.mjs +0 -28
  517. package/esm2020/datatable/models/datatable-accessor.mjs +0 -2
  518. package/esm2020/datatable/models/datatable-config.mjs +0 -3
  519. package/esm2020/datatable/models/datatable-data-source.mjs +0 -42
  520. package/esm2020/datatable/models/datatable-gql-data-source.mjs +0 -15
  521. package/esm2020/datatable/models/internal-column-props.mjs +0 -15
  522. package/esm2020/datatable/models/menubar-item-data.mjs +0 -2
  523. package/esm2020/datatable/models/page-info.mjs +0 -2
  524. package/esm2020/datatable/models/preferences-accessor.mjs +0 -2
  525. package/esm2020/datatable/models/preferences.mjs +0 -6
  526. package/esm2020/datatable/models/sort-event.mjs +0 -2
  527. package/esm2020/datatable/models/sort-item.mjs +0 -2
  528. package/esm2020/datatable/models/table-column.mjs +0 -2
  529. package/esm2020/datatable/public-api.mjs +0 -55
  530. package/esm2020/datatable/services/columns-alterations-manager.service.mjs +0 -136
  531. package/esm2020/datatable/services/columns-filters.service.mjs +0 -109
  532. package/esm2020/datatable/services/columns-manager.service.mjs +0 -286
  533. package/esm2020/datatable/services/datatable-column-changes.service.mjs +0 -20
  534. package/esm2020/datatable/services/datatable-preferences.service.mjs +0 -94
  535. package/esm2020/datatable/services/datatable-scrollbar-helper.service.mjs +0 -50
  536. package/esm2020/datatable/theseam-ui-common-datatable.mjs +0 -5
  537. package/esm2020/datatable/tokens/datatable-accessor.mjs +0 -3
  538. package/esm2020/datatable/tokens/datatable-preferences-accessor.mjs +0 -3
  539. package/esm2020/datatable/tokens/menubar-item-data.mjs +0 -3
  540. package/esm2020/datatable/utils/create-action-menu-column.mjs +0 -19
  541. package/esm2020/datatable/utils/create-checkbox-column.mjs +0 -15
  542. package/esm2020/datatable/utils/get-column-prop.mjs +0 -9
  543. package/esm2020/datatable/utils/map-columns-alterations-states.mjs +0 -42
  544. package/esm2020/datatable/utils/remove-unused-diffs.mjs +0 -9
  545. package/esm2020/datatable/utils/set-column-defaults.mjs +0 -10
  546. package/esm2020/datatable/utils/translate-templates.mjs +0 -12
  547. package/esm2020/datatable/utils/with-stored-column-info.mjs +0 -20
  548. package/esm2020/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.mjs +0 -118
  549. package/esm2020/datatable-dynamic/datatable-dynamic-def.mjs +0 -2
  550. package/esm2020/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.mjs +0 -50
  551. package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.mjs +0 -148
  552. package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.mjs +0 -2
  553. package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-token.mjs +0 -3
  554. package/esm2020/datatable-dynamic/datatable-dynamic.component.mjs +0 -75
  555. package/esm2020/datatable-dynamic/datatable-dynamic.module.mjs +0 -80
  556. package/esm2020/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.mjs +0 -400
  557. package/esm2020/datatable-dynamic/dynamic-datatable-def.service.mjs +0 -88
  558. package/esm2020/datatable-dynamic/dynamic-datatable-row-actions.service.mjs +0 -46
  559. package/esm2020/datatable-dynamic/models/dynamic-datatable-action-menu-record.mjs +0 -2
  560. package/esm2020/datatable-dynamic/models/dynamic-datatable-filter-menu-item.mjs +0 -2
  561. package/esm2020/datatable-dynamic/models/dynamic-datatable-menu-bar.mjs +0 -2
  562. package/esm2020/datatable-dynamic/models/dynamic-datatable-row-action-context.mjs +0 -2
  563. package/esm2020/datatable-dynamic/models/dynamic-datatable-row-action.mjs +0 -2
  564. package/esm2020/datatable-dynamic/models/index.mjs +0 -6
  565. package/esm2020/datatable-dynamic/public-api.mjs +0 -14
  566. package/esm2020/datatable-dynamic/theseam-ui-common-datatable-dynamic.mjs +0 -5
  567. package/esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-columns-defaults.mjs +0 -8
  568. package/esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-def-defaults.mjs +0 -13
  569. package/esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-filter-menu-defaults.mjs +0 -6
  570. package/esm2020/datatable-dynamic/utils/defaults/set-dynamic-datatable-options-defaults.mjs +0 -6
  571. package/esm2020/datatable-dynamic/utils/index.mjs +0 -5
  572. package/esm2020/dynamic/action/api/dynamic-action-api-def.mjs +0 -2
  573. package/esm2020/dynamic/action/api/dynamic-action-api-errors.mjs +0 -4
  574. package/esm2020/dynamic/action/api/dynamic-action-api.mjs +0 -2
  575. package/esm2020/dynamic/action/api/dynamic-action-api.service.mjs +0 -209
  576. package/esm2020/dynamic/action/dynamic-action-helper.service.mjs +0 -158
  577. package/esm2020/dynamic/action/index.mjs +0 -11
  578. package/esm2020/dynamic/action/link/dynamic-action-link-def.mjs +0 -2
  579. package/esm2020/dynamic/action/link/dynamic-action-link.mjs +0 -2
  580. package/esm2020/dynamic/action/link/dynamic-action-link.service.mjs +0 -47
  581. package/esm2020/dynamic/action/modal/dynamic-action-modal-def.mjs +0 -2
  582. package/esm2020/dynamic/action/modal/dynamic-action-modal.mjs +0 -2
  583. package/esm2020/dynamic/action/modal/dynamic-action-modal.service.mjs +0 -85
  584. package/esm2020/dynamic/dynamic-value-helper.service.mjs +0 -105
  585. package/esm2020/dynamic/evaluators/exporters-data-evaluator/exporters-data-evaluator.mjs +0 -30
  586. package/esm2020/dynamic/evaluators/exporters-data-evaluator/exporters-data-value.mjs +0 -2
  587. package/esm2020/dynamic/evaluators/exporters-data-evaluator/index.mjs +0 -3
  588. package/esm2020/dynamic/evaluators/index.mjs +0 -3
  589. package/esm2020/dynamic/evaluators/jexl-evaluator/index.mjs +0 -3
  590. package/esm2020/dynamic/evaluators/jexl-evaluator/jexl-evaluator.mjs +0 -32
  591. package/esm2020/dynamic/evaluators/jexl-evaluator/jexl-value.mjs +0 -2
  592. package/esm2020/dynamic/models/dynamic-action-confirm-def.mjs +0 -2
  593. package/esm2020/dynamic/models/dynamic-action-context.mjs +0 -2
  594. package/esm2020/dynamic/models/dynamic-action-def.mjs +0 -3
  595. package/esm2020/dynamic/models/dynamic-action-ui-anchor-def.mjs +0 -2
  596. package/esm2020/dynamic/models/dynamic-action-ui-button-def.mjs +0 -2
  597. package/esm2020/dynamic/models/dynamic-action-ui-def.mjs +0 -2
  598. package/esm2020/dynamic/models/dynamic-action.mjs +0 -2
  599. package/esm2020/dynamic/models/dynamic-value-base-type.mjs +0 -2
  600. package/esm2020/dynamic/models/dynamic-value-evaluatable-type.mjs +0 -2
  601. package/esm2020/dynamic/models/dynamic-value-evaluator.mjs +0 -2
  602. package/esm2020/dynamic/models/dynamic-value-primitive.mjs +0 -2
  603. package/esm2020/dynamic/models/dynamic-value-type.mjs +0 -2
  604. package/esm2020/dynamic/models/dynamic-value.mjs +0 -2
  605. package/esm2020/dynamic/models/index.mjs +0 -14
  606. package/esm2020/dynamic/public-api.mjs +0 -7
  607. package/esm2020/dynamic/theseam-ui-common-dynamic.mjs +0 -5
  608. package/esm2020/dynamic/tokens/api-config.mjs +0 -29
  609. package/esm2020/dynamic/tokens/dynamic-action.mjs +0 -3
  610. package/esm2020/dynamic/tokens/dynamic-data.mjs +0 -3
  611. package/esm2020/dynamic/tokens/dynamic-value-evaluator.mjs +0 -3
  612. package/esm2020/dynamic/tokens/index.mjs +0 -5
  613. package/esm2020/dynamic/utils/index.mjs +0 -2
  614. package/esm2020/dynamic/utils/is-action-type.mjs +0 -4
  615. package/esm2020/dynamic-component-loader/dynamic-component-loader.module.mjs +0 -50
  616. package/esm2020/dynamic-component-loader/dynamic-component-loader.service.mjs +0 -78
  617. package/esm2020/dynamic-component-loader/dynamic-component-manifest.mjs +0 -2
  618. package/esm2020/dynamic-component-loader/dynamic-component-tokens.mjs +0 -5
  619. package/esm2020/dynamic-component-loader/public-api.mjs +0 -5
  620. package/esm2020/dynamic-component-loader/theseam-ui-common-dynamic-component-loader.mjs +0 -5
  621. package/esm2020/footer-bar/footer-bar/footer-bar.component.mjs +0 -11
  622. package/esm2020/footer-bar/footer-bar.module.mjs +0 -20
  623. package/esm2020/footer-bar/public-api.mjs +0 -3
  624. package/esm2020/footer-bar/theseam-ui-common-footer-bar.mjs +0 -5
  625. package/esm2020/form-field/form-field-error.directive.mjs +0 -30
  626. package/esm2020/form-field/form-field-help-text.directive.mjs +0 -16
  627. package/esm2020/form-field/form-field-label-tpl.directive.mjs +0 -16
  628. package/esm2020/form-field/form-field-required-indicator.component.mjs +0 -61
  629. package/esm2020/form-field/form-field-tokens.mjs +0 -3
  630. package/esm2020/form-field/form-field.component.mjs +0 -221
  631. package/esm2020/form-field/form-field.module.mjs +0 -61
  632. package/esm2020/form-field/input.directive.mjs +0 -227
  633. package/esm2020/form-field/public-api.mjs +0 -10
  634. package/esm2020/form-field/testing/form-field-required-indicator.harness.mjs +0 -8
  635. package/esm2020/form-field/testing/form-field.harness.mjs +0 -45
  636. package/esm2020/form-field/testing/index.mjs +0 -3
  637. package/esm2020/form-field/theseam-ui-common-form-field.mjs +0 -5
  638. package/esm2020/form-field-error/form-field-error/form-field-error.component.mjs +0 -26
  639. package/esm2020/form-field-error/form-field-error-list/form-field-error-list-item-tpl.directive.mjs +0 -26
  640. package/esm2020/form-field-error/form-field-error-list/form-field-error-list-item.directive.mjs +0 -18
  641. package/esm2020/form-field-error/form-field-error-list/form-field-error-list.component.mjs +0 -384
  642. package/esm2020/form-field-error/form-field-error.module.mjs +0 -39
  643. package/esm2020/form-field-error/public-api.mjs +0 -6
  644. package/esm2020/form-field-error/theseam-ui-common-form-field-error.mjs +0 -5
  645. package/esm2020/framework/base-layout/base-layout-action.mjs +0 -2
  646. package/esm2020/framework/base-layout/base-layout-nav.mjs +0 -2
  647. package/esm2020/framework/base-layout/base-layout-ref.mjs +0 -2
  648. package/esm2020/framework/base-layout/base-layout-tokens.mjs +0 -3
  649. package/esm2020/framework/base-layout/base-layout.component.mjs +0 -133
  650. package/esm2020/framework/base-layout/base-layout.module.mjs +0 -80
  651. package/esm2020/framework/base-layout/directives/base-layout-content-footer.directive.mjs +0 -16
  652. package/esm2020/framework/base-layout/directives/base-layout-content-header.directive.mjs +0 -16
  653. package/esm2020/framework/base-layout/directives/base-layout-content.directive.mjs +0 -16
  654. package/esm2020/framework/base-layout/directives/base-layout-nav-toggle.directive.mjs +0 -66
  655. package/esm2020/framework/base-layout/directives/base-layout-side-bar-footer.directive.mjs +0 -16
  656. package/esm2020/framework/base-layout/directives/base-layout-side-bar-header.directive.mjs +0 -16
  657. package/esm2020/framework/base-layout/directives/base-layout-side-bar.directive.mjs +0 -16
  658. package/esm2020/framework/base-layout/directives/base-layout-top-bar.directive.mjs +0 -16
  659. package/esm2020/framework/base-layout/index.mjs +0 -15
  660. package/esm2020/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.mjs +0 -16
  661. package/esm2020/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.mjs +0 -23
  662. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widget-portal-outlet.directive.mjs +0 -119
  663. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-item.mjs +0 -2
  664. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor-token.mjs +0 -3
  665. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor.mjs +0 -2
  666. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences.service.mjs +0 -177
  667. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.component.mjs +0 -207
  668. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.service.mjs +0 -181
  669. package/esm2020/framework/dashboard/dashboard-widgets-tokens.mjs +0 -3
  670. package/esm2020/framework/dashboard/dashboard.component.mjs +0 -24
  671. package/esm2020/framework/dashboard/dashboard.module.mjs +0 -60
  672. package/esm2020/framework/dashboard/index.mjs +0 -12
  673. package/esm2020/framework/dynamic-router/dynamic-route-def.mjs +0 -2
  674. package/esm2020/framework/dynamic-router/dynamic-router.module.mjs +0 -28
  675. package/esm2020/framework/dynamic-router/hierarchy-router-outlet/hierarchy-route-animations.mjs +0 -256
  676. package/esm2020/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.mjs +0 -116
  677. package/esm2020/framework/dynamic-router/index.mjs +0 -6
  678. package/esm2020/framework/dynamic-router/resolvers/hierarchy-level.resolver.mjs +0 -26
  679. package/esm2020/framework/nav/horizontal-nav/horizontal-nav.component.mjs +0 -55
  680. package/esm2020/framework/nav/index.mjs +0 -6
  681. package/esm2020/framework/nav/nav-item/nav-item.component.mjs +0 -227
  682. package/esm2020/framework/nav/nav-utils.mjs +0 -107
  683. package/esm2020/framework/nav/nav.models.mjs +0 -2
  684. package/esm2020/framework/nav/nav.module.mjs +0 -67
  685. package/esm2020/framework/nav/nav.service.mjs +0 -204
  686. package/esm2020/framework/public-api.mjs +0 -8
  687. package/esm2020/framework/schema-form/index.mjs +0 -5
  688. package/esm2020/framework/schema-form/schema-form-framework.component.mjs +0 -21
  689. package/esm2020/framework/schema-form/schema-form-framework.mjs +0 -85
  690. package/esm2020/framework/schema-form/schema-form-widget.mjs +0 -2
  691. package/esm2020/framework/schema-form/schema-form.module.mjs +0 -45
  692. package/esm2020/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.mjs +0 -53
  693. package/esm2020/framework/schema-form-controls/schema-form-divider/schema-form-divider.component.mjs +0 -20
  694. package/esm2020/framework/schema-form-controls/schema-form-input/schema-form-input.component.mjs +0 -43
  695. package/esm2020/framework/schema-form-controls/schema-form-number/schema-form-number.component.mjs +0 -49
  696. package/esm2020/framework/schema-form-controls/schema-form-select/schema-form-select.component.mjs +0 -48
  697. package/esm2020/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.mjs +0 -54
  698. package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +0 -156
  699. package/esm2020/framework/schema-form-controls/schema-form-tel/schema-form-tel.component.mjs +0 -48
  700. package/esm2020/framework/schema-form-controls/schema-form-tiled-select/schema-form-tiled-select.component.mjs +0 -57
  701. package/esm2020/framework/side-nav/index.mjs +0 -8
  702. package/esm2020/framework/side-nav/side-nav-item/side-nav-item.component.mjs +0 -186
  703. package/esm2020/framework/side-nav/side-nav-toggle/side-nav-toggle.component.mjs +0 -40
  704. package/esm2020/framework/side-nav/side-nav-tokens.mjs +0 -7
  705. package/esm2020/framework/side-nav/side-nav-utils.mjs +0 -90
  706. package/esm2020/framework/side-nav/side-nav.component.mjs +0 -408
  707. package/esm2020/framework/side-nav/side-nav.models.mjs +0 -2
  708. package/esm2020/framework/side-nav/side-nav.module.mjs +0 -32
  709. package/esm2020/framework/side-nav/side-nav.service.mjs +0 -178
  710. package/esm2020/framework/theseam-ui-common-framework.mjs +0 -5
  711. package/esm2020/framework/top-bar/index.mjs +0 -10
  712. package/esm2020/framework/top-bar/top-bar-compact-menu-btn-detail.directive.mjs +0 -16
  713. package/esm2020/framework/top-bar/top-bar-item.directive.mjs +0 -22
  714. package/esm2020/framework/top-bar/top-bar-menu-btn-detail.directive.mjs +0 -16
  715. package/esm2020/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.mjs +0 -56
  716. package/esm2020/framework/top-bar/top-bar-menu.directive.mjs +0 -19
  717. package/esm2020/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.mjs +0 -16
  718. package/esm2020/framework/top-bar/top-bar-title/top-bar-title.component.mjs +0 -17
  719. package/esm2020/framework/top-bar/top-bar.component.mjs +0 -141
  720. package/esm2020/framework/top-bar/top-bar.module.mjs +0 -83
  721. package/esm2020/google-maps/google-maps/google-maps.component.mjs +0 -333
  722. package/esm2020/google-maps/google-maps-api-loader/google-maps-api-loader.mjs +0 -3
  723. package/esm2020/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.mjs +0 -104
  724. package/esm2020/google-maps/google-maps-api-loader/noop-google-maps-api-loader.mjs +0 -25
  725. package/esm2020/google-maps/google-maps-contextmenu.mjs +0 -114
  726. package/esm2020/google-maps/google-maps-controls.service.mjs +0 -67
  727. package/esm2020/google-maps/google-maps-feature-helpers.mjs +0 -223
  728. package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.mjs +0 -209
  729. package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.mjs +0 -165
  730. package/esm2020/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.mjs +0 -58
  731. package/esm2020/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.mjs +0 -115
  732. package/esm2020/google-maps/google-maps.module.mjs +0 -72
  733. package/esm2020/google-maps/google-maps.service.mjs +0 -429
  734. package/esm2020/google-maps/map-control.component.mjs +0 -66
  735. package/esm2020/google-maps/map-controls-service.mjs +0 -4
  736. package/esm2020/google-maps/map-file-drop/map-file-drop.component.mjs +0 -128
  737. package/esm2020/google-maps/map-value-manager.service.mjs +0 -48
  738. package/esm2020/google-maps/public-api.mjs +0 -18
  739. package/esm2020/google-maps/theseam-ui-common-google-maps.mjs +0 -5
  740. package/esm2020/graphql/datatable/create-page-info-observable.mjs +0 -38
  741. package/esm2020/graphql/datatable/datatable-graphql-query-ref.mjs +0 -212
  742. package/esm2020/graphql/datatable/datatable-graphql.service.mjs +0 -50
  743. package/esm2020/graphql/datatable/datatable-helpers.mjs +0 -175
  744. package/esm2020/graphql/datatable/get-page-info.mjs +0 -10
  745. package/esm2020/graphql/datatable/index.mjs +0 -10
  746. package/esm2020/graphql/datatable/map-filter-states.mjs +0 -63
  747. package/esm2020/graphql/datatable/map-page-info.mjs +0 -14
  748. package/esm2020/graphql/datatable/map-search-date-columns-data-filter-state-to-gql.mjs +0 -139
  749. package/esm2020/graphql/datatable/map-search-numeric-columns-data-filter-state-to-gql.mjs +0 -75
  750. package/esm2020/graphql/datatable/map-search-text-columns-data-filter-state-to-gql.mjs +0 -44
  751. package/esm2020/graphql/datatable/mapper-context.mjs +0 -2
  752. package/esm2020/graphql/models/direction.mjs +0 -8
  753. package/esm2020/graphql/models/gql-datatable-accessor.mjs +0 -2
  754. package/esm2020/graphql/models/hint-definition.mjs +0 -2
  755. package/esm2020/graphql/models/hint-transform-operation.mjs +0 -2
  756. package/esm2020/graphql/models/hint-transformer.mjs +0 -2
  757. package/esm2020/graphql/models/hints-kind.mjs +0 -9
  758. package/esm2020/graphql/models/hints-token.mjs +0 -2
  759. package/esm2020/graphql/models/index.mjs +0 -10
  760. package/esm2020/graphql/models/query-processing-config.mjs +0 -2
  761. package/esm2020/graphql/models/variable.mjs +0 -7
  762. package/esm2020/graphql/public-api.mjs +0 -3
  763. package/esm2020/graphql/theseam-ui-common-graphql.mjs +0 -5
  764. package/esm2020/graphql/utils/contains-variable.mjs +0 -14
  765. package/esm2020/graphql/utils/gql-var.mjs +0 -4
  766. package/esm2020/graphql/utils/hints-tokens-containing-hint.mjs +0 -4
  767. package/esm2020/graphql/utils/index.mjs +0 -11
  768. package/esm2020/graphql/utils/inline-variables.mjs +0 -51
  769. package/esm2020/graphql/utils/parse-comments.mjs +0 -24
  770. package/esm2020/graphql/utils/parse-hints.mjs +0 -108
  771. package/esm2020/graphql/utils/remove-variable-definition.mjs +0 -14
  772. package/esm2020/graphql/utils/remove-variable-definitions-not-defined.mjs +0 -19
  773. package/esm2020/graphql/utils/remove-variable.mjs +0 -22
  774. package/esm2020/graphql/utils/to-gql.mjs +0 -40
  775. package/esm2020/icon/icon/icon.component.mjs +0 -139
  776. package/esm2020/icon/icon-btn/icon-btn.component.mjs +0 -183
  777. package/esm2020/icon/icon-notification/icon-notification.component.mjs +0 -124
  778. package/esm2020/icon/icon.mjs +0 -2
  779. package/esm2020/icon/icon.module.mjs +0 -38
  780. package/esm2020/icon/public-api.mjs +0 -7
  781. package/esm2020/icon/theseam-ui-common-icon.mjs +0 -5
  782. package/esm2020/icon/utils/file-extension-icon.mjs +0 -33
  783. package/esm2020/icon/utils/get-known-icon.mjs +0 -82
  784. package/esm2020/icon/utils/index.mjs +0 -3
  785. package/esm2020/layout/breakpoint-aliases.mjs +0 -11
  786. package/esm2020/layout/layout.module.mjs +0 -25
  787. package/esm2020/layout/layout.service.mjs +0 -32
  788. package/esm2020/layout/observe-media-query.mjs +0 -41
  789. package/esm2020/layout/public-api.mjs +0 -5
  790. package/esm2020/layout/theseam-ui-common-layout.mjs +0 -5
  791. package/esm2020/loading/loading/loading.component.mjs +0 -26
  792. package/esm2020/loading/loading-overlay.service.mjs +0 -58
  793. package/esm2020/loading/loading-themes.mjs +0 -18
  794. package/esm2020/loading/loading.models.mjs +0 -2
  795. package/esm2020/loading/loading.module.mjs +0 -41
  796. package/esm2020/loading/public-api.mjs +0 -6
  797. package/esm2020/loading/theseam-ui-common-loading.mjs +0 -5
  798. package/esm2020/menu/menu-animations.mjs +0 -58
  799. package/esm2020/menu/menu-divider.component.mjs +0 -13
  800. package/esm2020/menu/menu-footer/menu-footer.component.mjs +0 -32
  801. package/esm2020/menu/menu-footer-action/menu-footer-action.component.mjs +0 -54
  802. package/esm2020/menu/menu-header/menu-header.component.mjs +0 -32
  803. package/esm2020/menu/menu-item.component.mjs +0 -158
  804. package/esm2020/menu/menu-panel-token.mjs +0 -6
  805. package/esm2020/menu/menu-panel.mjs +0 -2
  806. package/esm2020/menu/menu-toggle.directive.mjs +0 -427
  807. package/esm2020/menu/menu.component.mjs +0 -200
  808. package/esm2020/menu/menu.module.mjs +0 -67
  809. package/esm2020/menu/public-api.mjs +0 -16
  810. package/esm2020/menu/testing/menu-footer.harness.mjs +0 -28
  811. package/esm2020/menu/testing/menu-header.harness.mjs +0 -23
  812. package/esm2020/menu/testing/menu-item.harness.mjs +0 -59
  813. package/esm2020/menu/testing/menu.harness.mjs +0 -163
  814. package/esm2020/menu/testing/utils.mjs +0 -13
  815. package/esm2020/menu/theseam-ui-common-menu.mjs +0 -5
  816. package/esm2020/modal/directives/modal-close.directive.mjs +0 -74
  817. package/esm2020/modal/directives/modal-footer-tpl.directive.mjs +0 -16
  818. package/esm2020/modal/directives/modal-header-icon-tpl.directive.mjs +0 -16
  819. package/esm2020/modal/directives/modal-header-title-tpl.directive.mjs +0 -16
  820. package/esm2020/modal/directives/modal-title.directive.mjs +0 -20
  821. package/esm2020/modal/directives/modal.directive.mjs +0 -25
  822. package/esm2020/modal/modal/modal.component.mjs +0 -162
  823. package/esm2020/modal/modal-body/modal-body.component.mjs +0 -21
  824. package/esm2020/modal/modal-config.mjs +0 -47
  825. package/esm2020/modal/modal-container/modal-container.component.mjs +0 -245
  826. package/esm2020/modal/modal-footer/modal-footer.component.mjs +0 -17
  827. package/esm2020/modal/modal-header/modal-header.component.mjs +0 -28
  828. package/esm2020/modal/modal-injectors.mjs +0 -23
  829. package/esm2020/modal/modal-ref.mjs +0 -171
  830. package/esm2020/modal/modal-utils.mjs +0 -14
  831. package/esm2020/modal/modal.models.mjs +0 -3
  832. package/esm2020/modal/modal.module.mjs +0 -127
  833. package/esm2020/modal/modal.service.mjs +0 -352
  834. package/esm2020/modal/public-api.mjs +0 -20
  835. package/esm2020/modal/route-modal/route-modal.component.mjs +0 -62
  836. package/esm2020/modal/theseam-ui-common-modal.mjs +0 -5
  837. package/esm2020/models/component-type.mjs +0 -4
  838. package/esm2020/models/http-status-codes.mjs +0 -20
  839. package/esm2020/models/public-api.mjs +0 -8
  840. package/esm2020/models/size-prefixes.mjs +0 -2
  841. package/esm2020/models/size-types.mjs +0 -2
  842. package/esm2020/models/theme-names.mjs +0 -26
  843. package/esm2020/models/theme-prefixes.mjs +0 -2
  844. package/esm2020/models/theme-types.mjs +0 -2
  845. package/esm2020/models/theseam-ui-common-models.mjs +0 -5
  846. package/esm2020/navigation-reload/navigation-reload.config.mjs +0 -2
  847. package/esm2020/navigation-reload/navigation-reload.provider.mjs +0 -14
  848. package/esm2020/navigation-reload/navigation-reload.service.mjs +0 -54
  849. package/esm2020/navigation-reload/public-api.mjs +0 -4
  850. package/esm2020/navigation-reload/theseam-ui-common-navigation-reload.mjs +0 -5
  851. package/esm2020/popover/popover/popover.component.mjs +0 -160
  852. package/esm2020/popover/popover-animations.mjs +0 -46
  853. package/esm2020/popover/popover.directive.mjs +0 -264
  854. package/esm2020/popover/popover.module.mjs +0 -40
  855. package/esm2020/popover/public-api.mjs +0 -5
  856. package/esm2020/popover/theseam-ui-common-popover.mjs +0 -5
  857. package/esm2020/progress/progress-circle/progress-circle.component.mjs +0 -65
  858. package/esm2020/progress/progress.module.mjs +0 -24
  859. package/esm2020/progress/public-api.mjs +0 -3
  860. package/esm2020/progress/theseam-ui-common-progress.mjs +0 -5
  861. package/esm2020/public_api.mjs +0 -2
  862. package/esm2020/rich-text/public-api.mjs +0 -5
  863. package/esm2020/rich-text/rich-text/rich-text.component.mjs +0 -594
  864. package/esm2020/rich-text/rich-text.module.mjs +0 -32
  865. package/esm2020/rich-text/theseam-ui-common-rich-text.mjs +0 -5
  866. package/esm2020/rich-text/utils/models.mjs +0 -24
  867. package/esm2020/rich-text/utils/utils.mjs +0 -123
  868. package/esm2020/scrollbar/overlay-scrollbar.directive.mjs +0 -60
  869. package/esm2020/scrollbar/overlay-scrollbars-config-model.mjs +0 -2
  870. package/esm2020/scrollbar/overlay-scrollbars-config.mjs +0 -13
  871. package/esm2020/scrollbar/overlay-scrollbars.service.mjs +0 -83
  872. package/esm2020/scrollbar/public-api.mjs +0 -6
  873. package/esm2020/scrollbar/scrollbar.module.mjs +0 -30
  874. package/esm2020/scrollbar/theseam-ui-common-scrollbar.mjs +0 -5
  875. package/esm2020/services/asset-loader.service.mjs +0 -32
  876. package/esm2020/services/font-loader.service.mjs +0 -83
  877. package/esm2020/services/preferences/preferences-accessor.mjs +0 -2
  878. package/esm2020/services/preferences/preferences-manager.service.mjs +0 -69
  879. package/esm2020/services/preferences/preferences-record.mjs +0 -72
  880. package/esm2020/services/preferences/preferences.models.mjs +0 -2
  881. package/esm2020/services/public-api.mjs +0 -8
  882. package/esm2020/services/router-helpers.service.mjs +0 -25
  883. package/esm2020/services/theseam-ui-common-services.mjs +0 -5
  884. package/esm2020/shared/components/index.mjs +0 -2
  885. package/esm2020/shared/components/password-input-reveal/password-input-reveal.component.mjs +0 -49
  886. package/esm2020/shared/directives/auto-focus.directive.mjs +0 -54
  887. package/esm2020/shared/directives/click-outside.directive.mjs +0 -52
  888. package/esm2020/shared/directives/disable-control.directive.mjs +0 -27
  889. package/esm2020/shared/directives/elem-resized.directive.mjs +0 -28
  890. package/esm2020/shared/directives/hover-class-toggle.directive.mjs +0 -88
  891. package/esm2020/shared/directives/hover-class.directive.mjs +0 -82
  892. package/esm2020/shared/directives/index.mjs +0 -9
  893. package/esm2020/shared/directives/ng-select-extra.directive.mjs +0 -184
  894. package/esm2020/shared/directives/ngx-quill-extra.directive.mjs +0 -61
  895. package/esm2020/shared/pipes/index.mjs +0 -3
  896. package/esm2020/shared/pipes/mask-chars.pipe.mjs +0 -25
  897. package/esm2020/shared/pipes/truncate.pipe.mjs +0 -23
  898. package/esm2020/shared/public-api.mjs +0 -5
  899. package/esm2020/shared/shared.module.mjs +0 -93
  900. package/esm2020/shared/theseam-ui-common-shared.mjs +0 -5
  901. package/esm2020/storage/local-storage.service.mjs +0 -78
  902. package/esm2020/storage/localstorage-memory.mjs +0 -64
  903. package/esm2020/storage/public-api.mjs +0 -2
  904. package/esm2020/storage/theseam-ui-common-storage.mjs +0 -5
  905. package/esm2020/story-helpers/arg-type-helpers.mjs +0 -31
  906. package/esm2020/story-helpers/args-to-tpl.mjs +0 -83
  907. package/esm2020/story-helpers/initial-route-factory.mjs +0 -4
  908. package/esm2020/story-helpers/initial-route.service.mjs +0 -27
  909. package/esm2020/story-helpers/on-story-bootstrapped-exec.mjs +0 -61
  910. package/esm2020/story-helpers/on-story-bootstrapped-trigger.mjs +0 -39
  911. package/esm2020/story-helpers/public-api.mjs +0 -16
  912. package/esm2020/story-helpers/route-button.mjs +0 -12
  913. package/esm2020/story-helpers/routes-arg-type.mjs +0 -19
  914. package/esm2020/story-helpers/story-empty-with-route.component.mjs +0 -12
  915. package/esm2020/story-helpers/story-empty.component.mjs +0 -11
  916. package/esm2020/story-helpers/story-helper-components.module.mjs +0 -42
  917. package/esm2020/story-helpers/story-initial-route.mjs +0 -28
  918. package/esm2020/story-helpers/story-modal-container.component.mjs +0 -90
  919. package/esm2020/story-helpers/story-preferences-accessor.service.mjs +0 -34
  920. package/esm2020/story-helpers/story-toastr.service.mjs +0 -36
  921. package/esm2020/story-helpers/theseam-ui-common-story-helpers.mjs +0 -5
  922. package/esm2020/tabbed/directives/tabbed-tab-content.directive.mjs +0 -17
  923. package/esm2020/tabbed/directives/tabbed-tab.directive.mjs +0 -37
  924. package/esm2020/tabbed/public-api.mjs +0 -9
  925. package/esm2020/tabbed/tabbed-content/tabbed-content.component.mjs +0 -16
  926. package/esm2020/tabbed/tabbed-item/tabbed-item.component.mjs +0 -33
  927. package/esm2020/tabbed/tabbed-models.mjs +0 -2
  928. package/esm2020/tabbed/tabbed.component.mjs +0 -119
  929. package/esm2020/tabbed/tabbed.module.mjs +0 -54
  930. package/esm2020/tabbed/tabbed.service.mjs +0 -30
  931. package/esm2020/tabbed/theseam-ui-common-tabbed.mjs +0 -5
  932. package/esm2020/table/public-api.mjs +0 -6
  933. package/esm2020/table/table/table.component.mjs +0 -181
  934. package/esm2020/table/table-cell-tpl.directive.mjs +0 -17
  935. package/esm2020/table/table-column-header-tpl.directive.mjs +0 -17
  936. package/esm2020/table/table-column.component.mjs +0 -68
  937. package/esm2020/table/table.module.mjs +0 -48
  938. package/esm2020/table/theseam-ui-common-table.mjs +0 -5
  939. package/esm2020/table-cell-type/public-api.mjs +0 -12
  940. package/esm2020/table-cell-type/services/table-cell-types-helpers.service.mjs +0 -67
  941. package/esm2020/table-cell-type/table-cell-type-action.mjs +0 -2
  942. package/esm2020/table-cell-type/table-cell-type-column.mjs +0 -2
  943. package/esm2020/table-cell-type/table-cell-type-config.mjs +0 -2
  944. package/esm2020/table-cell-type/table-cell-type-export-props.mjs +0 -2
  945. package/esm2020/table-cell-type/table-cell-type-manifest-provider.mjs +0 -2
  946. package/esm2020/table-cell-type/table-cell-type-models.mjs +0 -2
  947. package/esm2020/table-cell-type/table-cell-type-name.mjs +0 -2
  948. package/esm2020/table-cell-type/table-cell-type-selector.component.mjs +0 -100
  949. package/esm2020/table-cell-type/table-cell-type-tokens.mjs +0 -4
  950. package/esm2020/table-cell-type/table-cell-type.module.mjs +0 -29
  951. package/esm2020/table-cell-type/theseam-ui-common-table-cell-type.mjs +0 -5
  952. package/esm2020/table-cell-types/public-api.mjs +0 -23
  953. package/esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.mjs +0 -2
  954. package/esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.mjs +0 -86
  955. package/esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency.mjs +0 -2
  956. package/esm2020/table-cell-types/table-cell-type-date/table-cell-type-date-config.mjs +0 -2
  957. package/esm2020/table-cell-types/table-cell-type-date/table-cell-type-date.component.mjs +0 -52
  958. package/esm2020/table-cell-types/table-cell-type-date/table-cell-type-date.mjs +0 -2
  959. package/esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.mjs +0 -2
  960. package/esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.mjs +0 -84
  961. package/esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.mjs +0 -2
  962. package/esm2020/table-cell-types/table-cell-type-icon/table-cell-type-icon-config.mjs +0 -2
  963. package/esm2020/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.mjs +0 -175
  964. package/esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.mjs +0 -2
  965. package/esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.mjs +0 -82
  966. package/esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer.mjs +0 -2
  967. package/esm2020/table-cell-types/table-cell-type-manifests.mjs +0 -92
  968. package/esm2020/table-cell-types/table-cell-type-phone/table-cell-type-phone-config.mjs +0 -2
  969. package/esm2020/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.mjs +0 -67
  970. package/esm2020/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle-config.mjs +0 -2
  971. package/esm2020/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.mjs +0 -168
  972. package/esm2020/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon-config.mjs +0 -2
  973. package/esm2020/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.mjs +0 -77
  974. package/esm2020/table-cell-types/table-cell-type-string/table-cell-type-string-config.mjs +0 -2
  975. package/esm2020/table-cell-types/table-cell-type-string/table-cell-type-string.component.mjs +0 -197
  976. package/esm2020/table-cell-types/table-cell-types.module.mjs +0 -118
  977. package/esm2020/table-cell-types/theseam-ui-common-table-cell-types.mjs +0 -5
  978. package/esm2020/tel-input/intl-tel-input.mjs +0 -55
  979. package/esm2020/tel-input/models/index.mjs +0 -3
  980. package/esm2020/tel-input/models/tel-input-country-data.mjs +0 -2
  981. package/esm2020/tel-input/models/tel-input-number-format-name.mjs +0 -8
  982. package/esm2020/tel-input/phone-number.pipe.mjs +0 -49
  983. package/esm2020/tel-input/public-api.mjs +0 -11
  984. package/esm2020/tel-input/tel-input/tel-input.component.mjs +0 -198
  985. package/esm2020/tel-input/tel-input-constants.mjs +0 -18
  986. package/esm2020/tel-input/tel-input-validator.mjs +0 -27
  987. package/esm2020/tel-input/tel-input.directive.mjs +0 -209
  988. package/esm2020/tel-input/tel-input.module.mjs +0 -43
  989. package/esm2020/tel-input/testing/tel-input.harness.mjs +0 -49
  990. package/esm2020/tel-input/theseam-ui-common-tel-input.mjs +0 -5
  991. package/esm2020/tel-input/utils/add-country-code.mjs +0 -23
  992. package/esm2020/tel-input/utils/coerce-phone-number-format.mjs +0 -22
  993. package/esm2020/tel-input/utils/get-country-code.mjs +0 -9
  994. package/esm2020/tel-input/utils/get-dial-code.mjs +0 -45
  995. package/esm2020/tel-input/utils/get-global-intl-tel-input-globals.mjs +0 -4
  996. package/esm2020/tel-input/utils/get-global-intl-tel-input-utils.mjs +0 -4
  997. package/esm2020/tel-input/utils/get-intl-tel-input-utils.mjs +0 -17
  998. package/esm2020/tel-input/utils/get-validation-error-message.mjs +0 -12
  999. package/esm2020/tel-input/utils/index.mjs +0 -10
  1000. package/esm2020/tel-input/utils/process-country-codes.mjs +0 -46
  1001. package/esm2020/testing/current-tick-time.mjs +0 -16
  1002. package/esm2020/testing/fake-toastr.mjs +0 -29
  1003. package/esm2020/testing/get-harness.mjs +0 -19
  1004. package/esm2020/testing/harnesses/ng-select-dropdown.harness.mjs +0 -39
  1005. package/esm2020/testing/harnesses/ng-select-option.harness.mjs +0 -26
  1006. package/esm2020/testing/harnesses/ng-select.harness.mjs +0 -104
  1007. package/esm2020/testing/public-api.mjs +0 -10
  1008. package/esm2020/testing/render-story.mjs +0 -10
  1009. package/esm2020/testing/story-expect.mjs +0 -40
  1010. package/esm2020/testing/theseam-ui-common-testing.mjs +0 -5
  1011. package/esm2020/testing/tick-helper.mjs +0 -74
  1012. package/esm2020/theseam-ui-common.mjs +0 -5
  1013. package/esm2020/tiled-select/components/tiled-select/tiled-select.component.mjs +0 -214
  1014. package/esm2020/tiled-select/components/tiled-select-tile/tiled-select-tile.component.mjs +0 -159
  1015. package/esm2020/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.mjs +0 -63
  1016. package/esm2020/tiled-select/directives/tiled-select-tile-icon-tpl.directive.mjs +0 -17
  1017. package/esm2020/tiled-select/directives/tiled-select-tile-label-tpl.directive.mjs +0 -16
  1018. package/esm2020/tiled-select/directives/tiled-select-tile-overlay.directive.mjs +0 -19
  1019. package/esm2020/tiled-select/public-api.mjs +0 -10
  1020. package/esm2020/tiled-select/testing/index.mjs +0 -3
  1021. package/esm2020/tiled-select/testing/tiled-select-harness.mjs +0 -21
  1022. package/esm2020/tiled-select/testing/tiled-select-tile-harness.mjs +0 -23
  1023. package/esm2020/tiled-select/theseam-ui-common-tiled-select.mjs +0 -5
  1024. package/esm2020/tiled-select/tiled-select.models.mjs +0 -2
  1025. package/esm2020/tiled-select/tiled-select.module.mjs +0 -51
  1026. package/esm2020/toggle-edit/models/can-toggle-edit.mjs +0 -2
  1027. package/esm2020/toggle-edit/models/index.mjs +0 -3
  1028. package/esm2020/toggle-edit/models/toggle-edit-ref.mjs +0 -2
  1029. package/esm2020/toggle-edit/public-api.mjs +0 -7
  1030. package/esm2020/toggle-edit/theseam-ui-common-toggle-edit.mjs +0 -5
  1031. package/esm2020/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.mjs +0 -11
  1032. package/esm2020/toggle-edit/toggle-edit-display-tpl.directive.mjs +0 -16
  1033. package/esm2020/toggle-edit/toggle-edit-keyboard-listener.service.mjs +0 -57
  1034. package/esm2020/toggle-edit/toggle-edit.component.mjs +0 -414
  1035. package/esm2020/toggle-edit/toggle-edit.module.mjs +0 -64
  1036. package/esm2020/toggle-group/public-api.mjs +0 -4
  1037. package/esm2020/toggle-group/theseam-ui-common-toggle-group.mjs +0 -5
  1038. package/esm2020/toggle-group/toggle-group-option.directive.mjs +0 -47
  1039. package/esm2020/toggle-group/toggle-group.directive.mjs +0 -199
  1040. package/esm2020/toggle-group/toggle-group.module.mjs +0 -33
  1041. package/esm2020/unsaved-changes-dialog/public-api.mjs +0 -5
  1042. package/esm2020/unsaved-changes-dialog/theseam-ui-common-unsaved-changes-dialog.mjs +0 -5
  1043. package/esm2020/unsaved-changes-dialog/unsaved-changes-can-deactivate.mjs +0 -30
  1044. package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.component.mjs +0 -21
  1045. package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.guard.mjs +0 -38
  1046. package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.module.mjs +0 -17
  1047. package/esm2020/utils/array-move.mjs +0 -62
  1048. package/esm2020/utils/calc-percentage.mjs +0 -4
  1049. package/esm2020/utils/cdk/get-closest-widget-cdk-drag.mjs +0 -18
  1050. package/esm2020/utils/create-padding.mjs +0 -17
  1051. package/esm2020/utils/file-utils.mjs +0 -49
  1052. package/esm2020/utils/form/get-control-name.mjs +0 -31
  1053. package/esm2020/utils/form/get-control-path.mjs +0 -38
  1054. package/esm2020/utils/form/has-required-control.mjs +0 -50
  1055. package/esm2020/utils/form/is-empty-input-value.mjs +0 -6
  1056. package/esm2020/utils/form/observe-control-is-different.mjs +0 -18
  1057. package/esm2020/utils/form/observe-control-status.mjs +0 -17
  1058. package/esm2020/utils/form/observe-control-valid.mjs +0 -30
  1059. package/esm2020/utils/form/observe-control-value-change.mjs +0 -10
  1060. package/esm2020/utils/form/observe-control-value.mjs +0 -11
  1061. package/esm2020/utils/form/wait-on-non-pending-status.mjs +0 -18
  1062. package/esm2020/utils/fractional-digits-count.mjs +0 -19
  1063. package/esm2020/utils/geo-json/close-polygons.mjs +0 -38
  1064. package/esm2020/utils/geo-json/coerce-feature-collection.mjs +0 -44
  1065. package/esm2020/utils/geo-json/geo-json-to-area.mjs +0 -11
  1066. package/esm2020/utils/geo-json/is-feature-collection.validator.mjs +0 -21
  1067. package/esm2020/utils/geo-json/is-only-geometry-types.mjs +0 -23
  1068. package/esm2020/utils/geo-json/is-only-geometry-types.validator.mjs +0 -32
  1069. package/esm2020/utils/geo-json/merge-polygons.mjs +0 -35
  1070. package/esm2020/utils/geo-json/min-max-points.validator.mjs +0 -56
  1071. package/esm2020/utils/geo-json/no-empty-feature-collection.validator.mjs +0 -24
  1072. package/esm2020/utils/geo-json/no-inner-rings.validator.mjs +0 -63
  1073. package/esm2020/utils/geo-json/no-kinks.validator.mjs +0 -39
  1074. package/esm2020/utils/geo-json/read-geo-file.mjs +0 -93
  1075. package/esm2020/utils/geo-json/split-multi-polygons.mjs +0 -29
  1076. package/esm2020/utils/get-attribute.mjs +0 -7
  1077. package/esm2020/utils/has-attribute.mjs +0 -7
  1078. package/esm2020/utils/has-property.mjs +0 -7
  1079. package/esm2020/utils/input-masks.mjs +0 -2
  1080. package/esm2020/utils/is-absolute-url.mjs +0 -17
  1081. package/esm2020/utils/is-null-or-undefined-or-empty.mjs +0 -4
  1082. package/esm2020/utils/is-null-or-undefined.mjs +0 -4
  1083. package/esm2020/utils/is-numeric.mjs +0 -4
  1084. package/esm2020/utils/load-style-sheet.mjs +0 -14
  1085. package/esm2020/utils/load-style.mjs +0 -13
  1086. package/esm2020/utils/not-null-or-undefined-or-empty.mjs +0 -4
  1087. package/esm2020/utils/not-null-or-undefined.mjs +0 -4
  1088. package/esm2020/utils/obj-utils.mjs +0 -26
  1089. package/esm2020/utils/observe-query-list.mjs +0 -5
  1090. package/esm2020/utils/operators/index.mjs +0 -3
  1091. package/esm2020/utils/operators/map-each.mjs +0 -6
  1092. package/esm2020/utils/operators/tap-first.mjs +0 -14
  1093. package/esm2020/utils/pad-end.mjs +0 -9
  1094. package/esm2020/utils/pad-start.mjs +0 -9
  1095. package/esm2020/utils/polling-ticker.mjs +0 -121
  1096. package/esm2020/utils/public-api.mjs +0 -54
  1097. package/esm2020/utils/refreshable.mjs +0 -65
  1098. package/esm2020/utils/router/index.mjs +0 -7
  1099. package/esm2020/utils/router/is-empty-url-route.mjs +0 -4
  1100. package/esm2020/utils/router/leaf-child-route.mjs +0 -8
  1101. package/esm2020/utils/router/operators/activated-routes-with-data-property.mjs +0 -11
  1102. package/esm2020/utils/router/route-snapshot-path-full.mjs +0 -5
  1103. package/esm2020/utils/router/route-snapshot-path-relative.mjs +0 -4
  1104. package/esm2020/utils/router/will-have-data-prop.mjs +0 -10
  1105. package/esm2020/utils/subscriber-count.mjs +0 -45
  1106. package/esm2020/utils/theseam-ui-common-utils.mjs +0 -5
  1107. package/esm2020/utils/toggle-attribute.mjs +0 -36
  1108. package/esm2020/utils/wait-on-condition-async.mjs +0 -30
  1109. package/esm2020/utils/wrap-into-observable.mjs +0 -8
  1110. package/esm2020/validators/decimal.validator.mjs +0 -25
  1111. package/esm2020/validators/email-exists.validator.mjs +0 -18
  1112. package/esm2020/validators/integer.validator.mjs +0 -25
  1113. package/esm2020/validators/phone-length.validator.mjs +0 -8
  1114. package/esm2020/validators/public-api.mjs +0 -6
  1115. package/esm2020/validators/tax-id.validator.mjs +0 -13
  1116. package/esm2020/validators/theseam-ui-common-validators.mjs +0 -5
  1117. package/esm2020/vertical-list-filter/public-api.mjs +0 -3
  1118. package/esm2020/vertical-list-filter/testing/index.mjs +0 -2
  1119. package/esm2020/vertical-list-filter/testing/vertical-list-filter.harness.mjs +0 -28
  1120. package/esm2020/vertical-list-filter/theseam-ui-common-vertical-list-filter.mjs +0 -5
  1121. package/esm2020/vertical-list-filter/vertical-list-filter.component.mjs +0 -52
  1122. package/esm2020/viewers/html-template-viewer/html-template-viewer.component.mjs +0 -219
  1123. package/esm2020/viewers/html-template-viewer/html-template-viewer.module.mjs +0 -32
  1124. package/esm2020/viewers/html-template-viewer/index.mjs +0 -3
  1125. package/esm2020/viewers/pdf-viewer/index.mjs +0 -4
  1126. package/esm2020/viewers/pdf-viewer/pdf-page/pdf-page.component.mjs +0 -143
  1127. package/esm2020/viewers/pdf-viewer/pdf-renderer.service.mjs +0 -28
  1128. package/esm2020/viewers/pdf-viewer/pdf-viewer.component.mjs +0 -164
  1129. package/esm2020/viewers/pdf-viewer/pdf-viewer.module.mjs +0 -33
  1130. package/esm2020/viewers/public-api.mjs +0 -3
  1131. package/esm2020/viewers/theseam-ui-common-viewers.mjs +0 -5
  1132. package/esm2020/widget/directives/widget-drag-handle.directive.mjs +0 -150
  1133. package/esm2020/widget/directives/widget-icon-tpl.directive.mjs +0 -16
  1134. package/esm2020/widget/directives/widget-title-tpl.directive.mjs +0 -16
  1135. package/esm2020/widget/preferences/widget-preferences.models.mjs +0 -5
  1136. package/esm2020/widget/preferences/widget-preferences.service.mjs +0 -78
  1137. package/esm2020/widget/preferences/widget-preferences.token.mjs +0 -3
  1138. package/esm2020/widget/public-api.mjs +0 -42
  1139. package/esm2020/widget/theseam-ui-common-widget.mjs +0 -5
  1140. package/esm2020/widget/widget/widget.component.mjs +0 -214
  1141. package/esm2020/widget/widget-content-components/widget-button-group/widget-button-group.component.mjs +0 -11
  1142. package/esm2020/widget/widget-content-components/widget-button-group/widget-button-group.module.mjs +0 -30
  1143. package/esm2020/widget/widget-content-components/widget-content-header/widget-content-header.component.mjs +0 -11
  1144. package/esm2020/widget/widget-content-components/widget-content-header/widget-content-header.module.mjs +0 -24
  1145. package/esm2020/widget/widget-content-components/widget-description/widget-description.component.mjs +0 -11
  1146. package/esm2020/widget/widget-content-components/widget-description/widget-description.module.mjs +0 -24
  1147. package/esm2020/widget/widget-content-components/widget-empty-label/widget-empty-label.component.mjs +0 -39
  1148. package/esm2020/widget/widget-content-components/widget-empty-label/widget-empty-label.module.mjs +0 -24
  1149. package/esm2020/widget/widget-content-components/widget-footer-link/widget-footer-link.component.mjs +0 -11
  1150. package/esm2020/widget/widget-content-components/widget-footer-link/widget-footer-link.module.mjs +0 -24
  1151. package/esm2020/widget/widget-content-components/widget-footer-text/widget-footer-text.component.mjs +0 -11
  1152. package/esm2020/widget/widget-content-components/widget-footer-text/widget-footer-text.module.mjs +0 -24
  1153. package/esm2020/widget/widget-content-components/widget-header-badge/widget-header-badge.component.mjs +0 -22
  1154. package/esm2020/widget/widget-content-components/widget-header-badge/widget-header-badge.module.mjs +0 -24
  1155. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item-icon-tpl.directive.mjs +0 -17
  1156. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.mjs +0 -124
  1157. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group.component.mjs +0 -14
  1158. package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group.module.mjs +0 -46
  1159. package/esm2020/widget/widget-content-components/widget-table/widget-table.component.mjs +0 -38
  1160. package/esm2020/widget/widget-content-components/widget-table/widget-table.module.mjs +0 -32
  1161. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.mjs +0 -13
  1162. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.mjs +0 -41
  1163. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.mjs +0 -11
  1164. package/esm2020/widget/widget-content-components/widget-tile/widget-tile-secondary-icon.directive.mjs +0 -17
  1165. package/esm2020/widget/widget-content-components/widget-tile/widget-tile.component.mjs +0 -122
  1166. package/esm2020/widget/widget-content-components/widget-tile/widget-tile.module.mjs +0 -48
  1167. package/esm2020/widget/widget-content-components/widget-tile-list/widget-tile-list.component.mjs +0 -11
  1168. package/esm2020/widget/widget-content-components/widget-tile-list/widget-tile-list.module.mjs +0 -27
  1169. package/esm2020/widget/widget-footer/widget-footer.component.mjs +0 -11
  1170. package/esm2020/widget/widget-registry.models.mjs +0 -2
  1171. package/esm2020/widget/widget-registry.service.mjs +0 -56
  1172. package/esm2020/widget/widget-token.mjs +0 -5
  1173. package/esm2020/widget/widget.models.mjs +0 -2
  1174. package/esm2020/widget/widget.module.mjs +0 -125
  1175. package/fesm2015/theseam-ui-common-asset-reader.mjs +0 -186
  1176. package/fesm2015/theseam-ui-common-asset-reader.mjs.map +0 -1
  1177. package/fesm2015/theseam-ui-common-breadcrumbs.mjs +0 -201
  1178. package/fesm2015/theseam-ui-common-breadcrumbs.mjs.map +0 -1
  1179. package/fesm2015/theseam-ui-common-buttons.mjs +0 -492
  1180. package/fesm2015/theseam-ui-common-buttons.mjs.map +0 -1
  1181. package/fesm2015/theseam-ui-common-card.mjs +0 -153
  1182. package/fesm2015/theseam-ui-common-card.mjs.map +0 -1
  1183. package/fesm2015/theseam-ui-common-carousel.mjs +0 -266
  1184. package/fesm2015/theseam-ui-common-carousel.mjs.map +0 -1
  1185. package/fesm2015/theseam-ui-common-checkbox.mjs +0 -391
  1186. package/fesm2015/theseam-ui-common-checkbox.mjs.map +0 -1
  1187. package/fesm2015/theseam-ui-common-confirm-dialog.mjs +0 -192
  1188. package/fesm2015/theseam-ui-common-confirm-dialog.mjs.map +0 -1
  1189. package/fesm2015/theseam-ui-common-core.mjs +0 -225
  1190. package/fesm2015/theseam-ui-common-core.mjs.map +0 -1
  1191. package/fesm2015/theseam-ui-common-data-exporter.mjs +0 -93
  1192. package/fesm2015/theseam-ui-common-data-exporter.mjs.map +0 -1
  1193. package/fesm2015/theseam-ui-common-data-filters.mjs +0 -508
  1194. package/fesm2015/theseam-ui-common-data-filters.mjs.map +0 -1
  1195. package/fesm2015/theseam-ui-common-datatable-dynamic.mjs +0 -998
  1196. package/fesm2015/theseam-ui-common-datatable-dynamic.mjs.map +0 -1
  1197. package/fesm2015/theseam-ui-common-datatable.mjs +0 -3685
  1198. package/fesm2015/theseam-ui-common-datatable.mjs.map +0 -1
  1199. package/fesm2015/theseam-ui-common-dynamic-component-loader.mjs +0 -135
  1200. package/fesm2015/theseam-ui-common-dynamic-component-loader.mjs.map +0 -1
  1201. package/fesm2015/theseam-ui-common-dynamic.mjs +0 -722
  1202. package/fesm2015/theseam-ui-common-dynamic.mjs.map +0 -1
  1203. package/fesm2015/theseam-ui-common-footer-bar.mjs +0 -35
  1204. package/fesm2015/theseam-ui-common-footer-bar.mjs.map +0 -1
  1205. package/fesm2015/theseam-ui-common-form-field-error.mjs +0 -479
  1206. package/fesm2015/theseam-ui-common-form-field-error.mjs.map +0 -1
  1207. package/fesm2015/theseam-ui-common-form-field.mjs +0 -670
  1208. package/fesm2015/theseam-ui-common-form-field.mjs.map +0 -1
  1209. package/fesm2015/theseam-ui-common-framework.mjs +0 -3891
  1210. package/fesm2015/theseam-ui-common-framework.mjs.map +0 -1
  1211. package/fesm2015/theseam-ui-common-google-maps.mjs +0 -2083
  1212. package/fesm2015/theseam-ui-common-google-maps.mjs.map +0 -1
  1213. package/fesm2015/theseam-ui-common-graphql.mjs +0 -1115
  1214. package/fesm2015/theseam-ui-common-graphql.mjs.map +0 -1
  1215. package/fesm2015/theseam-ui-common-icon.mjs +0 -587
  1216. package/fesm2015/theseam-ui-common-icon.mjs.map +0 -1
  1217. package/fesm2015/theseam-ui-common-layout.mjs +0 -101
  1218. package/fesm2015/theseam-ui-common-layout.mjs.map +0 -1
  1219. package/fesm2015/theseam-ui-common-loading.mjs +0 -139
  1220. package/fesm2015/theseam-ui-common-loading.mjs.map +0 -1
  1221. package/fesm2015/theseam-ui-common-menu.mjs +0 -1361
  1222. package/fesm2015/theseam-ui-common-menu.mjs.map +0 -1
  1223. package/fesm2015/theseam-ui-common-modal.mjs +0 -1378
  1224. package/fesm2015/theseam-ui-common-modal.mjs.map +0 -1
  1225. package/fesm2015/theseam-ui-common-models.mjs +0 -52
  1226. package/fesm2015/theseam-ui-common-models.mjs.map +0 -1
  1227. package/fesm2015/theseam-ui-common-navigation-reload.mjs +0 -75
  1228. package/fesm2015/theseam-ui-common-navigation-reload.mjs.map +0 -1
  1229. package/fesm2015/theseam-ui-common-popover.mjs +0 -506
  1230. package/fesm2015/theseam-ui-common-popover.mjs.map +0 -1
  1231. package/fesm2015/theseam-ui-common-progress.mjs +0 -93
  1232. package/fesm2015/theseam-ui-common-progress.mjs.map +0 -1
  1233. package/fesm2015/theseam-ui-common-rich-text.mjs +0 -767
  1234. package/fesm2015/theseam-ui-common-rich-text.mjs.map +0 -1
  1235. package/fesm2015/theseam-ui-common-scrollbar.mjs +0 -184
  1236. package/fesm2015/theseam-ui-common-scrollbar.mjs.map +0 -1
  1237. package/fesm2015/theseam-ui-common-services.mjs +0 -273
  1238. package/fesm2015/theseam-ui-common-services.mjs.map +0 -1
  1239. package/fesm2015/theseam-ui-common-shared.mjs +0 -739
  1240. package/fesm2015/theseam-ui-common-shared.mjs.map +0 -1
  1241. package/fesm2015/theseam-ui-common-storage.mjs +0 -148
  1242. package/fesm2015/theseam-ui-common-storage.mjs.map +0 -1
  1243. package/fesm2015/theseam-ui-common-story-helpers.mjs +0 -514
  1244. package/fesm2015/theseam-ui-common-story-helpers.mjs.map +0 -1
  1245. package/fesm2015/theseam-ui-common-tabbed.mjs +0 -288
  1246. package/fesm2015/theseam-ui-common-tabbed.mjs.map +0 -1
  1247. package/fesm2015/theseam-ui-common-table-cell-type.mjs +0 -201
  1248. package/fesm2015/theseam-ui-common-table-cell-type.mjs.map +0 -1
  1249. package/fesm2015/theseam-ui-common-table-cell-types.mjs +0 -1134
  1250. package/fesm2015/theseam-ui-common-table-cell-types.mjs.map +0 -1
  1251. package/fesm2015/theseam-ui-common-table.mjs +0 -320
  1252. package/fesm2015/theseam-ui-common-table.mjs.map +0 -1
  1253. package/fesm2015/theseam-ui-common-tel-input.mjs +0 -841
  1254. package/fesm2015/theseam-ui-common-tel-input.mjs.map +0 -1
  1255. package/fesm2015/theseam-ui-common-testing.mjs +0 -395
  1256. package/fesm2015/theseam-ui-common-testing.mjs.map +0 -1
  1257. package/fesm2015/theseam-ui-common-tiled-select.mjs +0 -571
  1258. package/fesm2015/theseam-ui-common-tiled-select.mjs.map +0 -1
  1259. package/fesm2015/theseam-ui-common-toggle-edit.mjs +0 -560
  1260. package/fesm2015/theseam-ui-common-toggle-edit.mjs.map +0 -1
  1261. package/fesm2015/theseam-ui-common-toggle-group.mjs +0 -281
  1262. package/fesm2015/theseam-ui-common-toggle-group.mjs.map +0 -1
  1263. package/fesm2015/theseam-ui-common-unsaved-changes-dialog.mjs +0 -106
  1264. package/fesm2015/theseam-ui-common-unsaved-changes-dialog.mjs.map +0 -1
  1265. package/fesm2015/theseam-ui-common-utils.mjs +0 -1387
  1266. package/fesm2015/theseam-ui-common-utils.mjs.map +0 -1
  1267. package/fesm2015/theseam-ui-common-validators.mjs +0 -94
  1268. package/fesm2015/theseam-ui-common-validators.mjs.map +0 -1
  1269. package/fesm2015/theseam-ui-common-vertical-list-filter.mjs +0 -96
  1270. package/fesm2015/theseam-ui-common-vertical-list-filter.mjs.map +0 -1
  1271. package/fesm2015/theseam-ui-common-viewers.mjs +0 -602
  1272. package/fesm2015/theseam-ui-common-viewers.mjs.map +0 -1
  1273. package/fesm2015/theseam-ui-common-widget.mjs +0 -1395
  1274. package/fesm2015/theseam-ui-common-widget.mjs.map +0 -1
  1275. package/fesm2015/theseam-ui-common.mjs +0 -6
  1276. package/fesm2015/theseam-ui-common.mjs.map +0 -1
  1277. package/fesm2020/theseam-ui-common-asset-reader.mjs +0 -184
  1278. package/fesm2020/theseam-ui-common-asset-reader.mjs.map +0 -1
  1279. package/fesm2020/theseam-ui-common-breadcrumbs.mjs +0 -201
  1280. package/fesm2020/theseam-ui-common-breadcrumbs.mjs.map +0 -1
  1281. package/fesm2020/theseam-ui-common-buttons.mjs +0 -466
  1282. package/fesm2020/theseam-ui-common-buttons.mjs.map +0 -1
  1283. package/fesm2020/theseam-ui-common-card.mjs +0 -151
  1284. package/fesm2020/theseam-ui-common-card.mjs.map +0 -1
  1285. package/fesm2020/theseam-ui-common-carousel.mjs +0 -266
  1286. package/fesm2020/theseam-ui-common-carousel.mjs.map +0 -1
  1287. package/fesm2020/theseam-ui-common-checkbox.mjs +0 -373
  1288. package/fesm2020/theseam-ui-common-checkbox.mjs.map +0 -1
  1289. package/fesm2020/theseam-ui-common-confirm-dialog.mjs +0 -192
  1290. package/fesm2020/theseam-ui-common-confirm-dialog.mjs.map +0 -1
  1291. package/fesm2020/theseam-ui-common-core.mjs +0 -233
  1292. package/fesm2020/theseam-ui-common-core.mjs.map +0 -1
  1293. package/fesm2020/theseam-ui-common-data-exporter.mjs +0 -93
  1294. package/fesm2020/theseam-ui-common-data-exporter.mjs.map +0 -1
  1295. package/fesm2020/theseam-ui-common-data-filters.mjs +0 -500
  1296. package/fesm2020/theseam-ui-common-data-filters.mjs.map +0 -1
  1297. package/fesm2020/theseam-ui-common-datatable-dynamic.mjs +0 -986
  1298. package/fesm2020/theseam-ui-common-datatable-dynamic.mjs.map +0 -1
  1299. package/fesm2020/theseam-ui-common-datatable.mjs +0 -3662
  1300. package/fesm2020/theseam-ui-common-datatable.mjs.map +0 -1
  1301. package/fesm2020/theseam-ui-common-dynamic-component-loader.mjs +0 -133
  1302. package/fesm2020/theseam-ui-common-dynamic-component-loader.mjs.map +0 -1
  1303. package/fesm2020/theseam-ui-common-dynamic.mjs +0 -689
  1304. package/fesm2020/theseam-ui-common-dynamic.mjs.map +0 -1
  1305. package/fesm2020/theseam-ui-common-footer-bar.mjs +0 -35
  1306. package/fesm2020/theseam-ui-common-footer-bar.mjs.map +0 -1
  1307. package/fesm2020/theseam-ui-common-form-field-error.mjs +0 -483
  1308. package/fesm2020/theseam-ui-common-form-field-error.mjs.map +0 -1
  1309. package/fesm2020/theseam-ui-common-form-field.mjs +0 -659
  1310. package/fesm2020/theseam-ui-common-form-field.mjs.map +0 -1
  1311. package/fesm2020/theseam-ui-common-framework.mjs +0 -3883
  1312. package/fesm2020/theseam-ui-common-framework.mjs.map +0 -1
  1313. package/fesm2020/theseam-ui-common-google-maps.mjs +0 -2072
  1314. package/fesm2020/theseam-ui-common-google-maps.mjs.map +0 -1
  1315. package/fesm2020/theseam-ui-common-graphql.mjs +0 -1121
  1316. package/fesm2020/theseam-ui-common-graphql.mjs.map +0 -1
  1317. package/fesm2020/theseam-ui-common-icon.mjs +0 -587
  1318. package/fesm2020/theseam-ui-common-icon.mjs.map +0 -1
  1319. package/fesm2020/theseam-ui-common-layout.mjs +0 -111
  1320. package/fesm2020/theseam-ui-common-layout.mjs.map +0 -1
  1321. package/fesm2020/theseam-ui-common-loading.mjs +0 -138
  1322. package/fesm2020/theseam-ui-common-loading.mjs.map +0 -1
  1323. package/fesm2020/theseam-ui-common-menu.mjs +0 -1288
  1324. package/fesm2020/theseam-ui-common-menu.mjs.map +0 -1
  1325. package/fesm2020/theseam-ui-common-modal.mjs +0 -1370
  1326. package/fesm2020/theseam-ui-common-modal.mjs.map +0 -1
  1327. package/fesm2020/theseam-ui-common-models.mjs +0 -55
  1328. package/fesm2020/theseam-ui-common-models.mjs.map +0 -1
  1329. package/fesm2020/theseam-ui-common-navigation-reload.mjs +0 -74
  1330. package/fesm2020/theseam-ui-common-navigation-reload.mjs.map +0 -1
  1331. package/fesm2020/theseam-ui-common-popover.mjs +0 -503
  1332. package/fesm2020/theseam-ui-common-popover.mjs.map +0 -1
  1333. package/fesm2020/theseam-ui-common-progress.mjs +0 -93
  1334. package/fesm2020/theseam-ui-common-progress.mjs.map +0 -1
  1335. package/fesm2020/theseam-ui-common-rich-text.mjs +0 -773
  1336. package/fesm2020/theseam-ui-common-rich-text.mjs.map +0 -1
  1337. package/fesm2020/theseam-ui-common-scrollbar.mjs +0 -184
  1338. package/fesm2020/theseam-ui-common-scrollbar.mjs.map +0 -1
  1339. package/fesm2020/theseam-ui-common-services.mjs +0 -274
  1340. package/fesm2020/theseam-ui-common-services.mjs.map +0 -1
  1341. package/fesm2020/theseam-ui-common-shared.mjs +0 -733
  1342. package/fesm2020/theseam-ui-common-shared.mjs.map +0 -1
  1343. package/fesm2020/theseam-ui-common-storage.mjs +0 -148
  1344. package/fesm2020/theseam-ui-common-storage.mjs.map +0 -1
  1345. package/fesm2020/theseam-ui-common-story-helpers.mjs +0 -512
  1346. package/fesm2020/theseam-ui-common-story-helpers.mjs.map +0 -1
  1347. package/fesm2020/theseam-ui-common-tabbed.mjs +0 -286
  1348. package/fesm2020/theseam-ui-common-tabbed.mjs.map +0 -1
  1349. package/fesm2020/theseam-ui-common-table-cell-type.mjs +0 -198
  1350. package/fesm2020/theseam-ui-common-table-cell-type.mjs.map +0 -1
  1351. package/fesm2020/theseam-ui-common-table-cell-types.mjs +0 -1109
  1352. package/fesm2020/theseam-ui-common-table-cell-types.mjs.map +0 -1
  1353. package/fesm2020/theseam-ui-common-table.mjs +0 -322
  1354. package/fesm2020/theseam-ui-common-table.mjs.map +0 -1
  1355. package/fesm2020/theseam-ui-common-tel-input.mjs +0 -810
  1356. package/fesm2020/theseam-ui-common-tel-input.mjs.map +0 -1
  1357. package/fesm2020/theseam-ui-common-testing.mjs +0 -359
  1358. package/fesm2020/theseam-ui-common-testing.mjs.map +0 -1
  1359. package/fesm2020/theseam-ui-common-tiled-select.mjs +0 -557
  1360. package/fesm2020/theseam-ui-common-tiled-select.mjs.map +0 -1
  1361. package/fesm2020/theseam-ui-common-toggle-edit.mjs +0 -553
  1362. package/fesm2020/theseam-ui-common-toggle-edit.mjs.map +0 -1
  1363. package/fesm2020/theseam-ui-common-toggle-group.mjs +0 -277
  1364. package/fesm2020/theseam-ui-common-toggle-group.mjs.map +0 -1
  1365. package/fesm2020/theseam-ui-common-unsaved-changes-dialog.mjs +0 -106
  1366. package/fesm2020/theseam-ui-common-unsaved-changes-dialog.mjs.map +0 -1
  1367. package/fesm2020/theseam-ui-common-utils.mjs +0 -1364
  1368. package/fesm2020/theseam-ui-common-utils.mjs.map +0 -1
  1369. package/fesm2020/theseam-ui-common-validators.mjs +0 -94
  1370. package/fesm2020/theseam-ui-common-validators.mjs.map +0 -1
  1371. package/fesm2020/theseam-ui-common-vertical-list-filter.mjs +0 -87
  1372. package/fesm2020/theseam-ui-common-vertical-list-filter.mjs.map +0 -1
  1373. package/fesm2020/theseam-ui-common-viewers.mjs +0 -598
  1374. package/fesm2020/theseam-ui-common-viewers.mjs.map +0 -1
  1375. package/fesm2020/theseam-ui-common-widget.mjs +0 -1387
  1376. package/fesm2020/theseam-ui-common-widget.mjs.map +0 -1
  1377. package/fesm2020/theseam-ui-common.mjs +0 -6
  1378. package/fesm2020/theseam-ui-common.mjs.map +0 -1
  1379. package/footer-bar/footer-bar/footer-bar.component.d.ts +0 -5
  1380. package/footer-bar/footer-bar.module.d.ts +0 -8
  1381. package/footer-bar/public-api.d.ts +0 -2
  1382. package/form-field/form-field-error.directive.d.ts +0 -15
  1383. package/form-field/form-field-help-text.directive.d.ts +0 -8
  1384. package/form-field/form-field-label-tpl.directive.d.ts +0 -8
  1385. package/form-field/form-field-required-indicator.component.d.ts +0 -16
  1386. package/form-field/form-field-tokens.d.ts +0 -2
  1387. package/form-field/form-field.component.d.ts +0 -117
  1388. package/form-field/form-field.module.d.ts +0 -16
  1389. package/form-field/input.directive.d.ts +0 -70
  1390. package/form-field/public-api.d.ts +0 -9
  1391. package/form-field/testing/form-field-required-indicator.harness.d.ts +0 -5
  1392. package/form-field/testing/form-field.harness.d.ts +0 -14
  1393. package/form-field/testing/index.d.ts +0 -2
  1394. package/form-field-error/form-field-error/form-field-error.component.d.ts +0 -8
  1395. package/form-field-error/form-field-error-list/form-field-error-list-item-tpl.directive.d.ts +0 -12
  1396. package/form-field-error/form-field-error-list/form-field-error-list-item.directive.d.ts +0 -9
  1397. package/form-field-error/form-field-error-list/form-field-error-list.component.d.ts +0 -65
  1398. package/form-field-error/form-field-error.module.d.ts +0 -11
  1399. package/form-field-error/public-api.d.ts +0 -5
  1400. package/framework/base-layout/base-layout-action.d.ts +0 -31
  1401. package/framework/base-layout/base-layout-nav.d.ts +0 -18
  1402. package/framework/base-layout/base-layout-ref.d.ts +0 -14
  1403. package/framework/base-layout/base-layout-tokens.d.ts +0 -3
  1404. package/framework/base-layout/base-layout.component.d.ts +0 -48
  1405. package/framework/base-layout/base-layout.module.d.ts +0 -20
  1406. package/framework/base-layout/directives/base-layout-content-footer.directive.d.ts +0 -9
  1407. package/framework/base-layout/directives/base-layout-content-header.directive.d.ts +0 -9
  1408. package/framework/base-layout/directives/base-layout-content.directive.d.ts +0 -9
  1409. package/framework/base-layout/directives/base-layout-nav-toggle.directive.d.ts +0 -22
  1410. package/framework/base-layout/directives/base-layout-side-bar-footer.directive.d.ts +0 -9
  1411. package/framework/base-layout/directives/base-layout-side-bar-header.directive.d.ts +0 -9
  1412. package/framework/base-layout/directives/base-layout-side-bar.directive.d.ts +0 -9
  1413. package/framework/base-layout/directives/base-layout-top-bar.directive.d.ts +0 -9
  1414. package/framework/base-layout/index.d.ts +0 -14
  1415. package/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.d.ts +0 -9
  1416. package/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.d.ts +0 -13
  1417. package/framework/dashboard/dashboard-widgets/dashboard-widget-portal-outlet.directive.d.ts +0 -50
  1418. package/framework/dashboard/dashboard-widgets/dashboard-widgets-item.d.ts +0 -43
  1419. package/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor-token.d.ts +0 -3
  1420. package/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences-accessor.d.ts +0 -15
  1421. package/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences.service.d.ts +0 -30
  1422. package/framework/dashboard/dashboard-widgets/dashboard-widgets.component.d.ts +0 -62
  1423. package/framework/dashboard/dashboard-widgets/dashboard-widgets.service.d.ts +0 -37
  1424. package/framework/dashboard/dashboard-widgets-tokens.d.ts +0 -7
  1425. package/framework/dashboard/dashboard.component.d.ts +0 -10
  1426. package/framework/dashboard/dashboard.module.d.ts +0 -17
  1427. package/framework/dashboard/index.d.ts +0 -11
  1428. package/framework/dynamic-router/dynamic-route-def.d.ts +0 -8
  1429. package/framework/dynamic-router/dynamic-router.module.d.ts +0 -9
  1430. package/framework/dynamic-router/hierarchy-router-outlet/hierarchy-route-animations.d.ts +0 -5
  1431. package/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.d.ts +0 -25
  1432. package/framework/dynamic-router/index.d.ts +0 -5
  1433. package/framework/dynamic-router/resolvers/hierarchy-level.resolver.d.ts +0 -9
  1434. package/framework/nav/horizontal-nav/horizontal-nav.component.d.ts +0 -25
  1435. package/framework/nav/index.d.ts +0 -5
  1436. package/framework/nav/nav-item/nav-item.component.d.ts +0 -74
  1437. package/framework/nav/nav-utils.d.ts +0 -20
  1438. package/framework/nav/nav.models.d.ts +0 -77
  1439. package/framework/nav/nav.module.d.ts +0 -17
  1440. package/framework/nav/nav.service.d.ts +0 -27
  1441. package/framework/public-api.d.ts +0 -7
  1442. package/framework/schema-form/index.d.ts +0 -4
  1443. package/framework/schema-form/schema-form-framework.component.d.ts +0 -8
  1444. package/framework/schema-form/schema-form-framework.d.ts +0 -32
  1445. package/framework/schema-form/schema-form-widget.d.ts +0 -61
  1446. package/framework/schema-form/schema-form.module.d.ts +0 -9
  1447. package/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.d.ts +0 -25
  1448. package/framework/schema-form-controls/schema-form-divider/schema-form-divider.component.d.ts +0 -12
  1449. package/framework/schema-form-controls/schema-form-input/schema-form-input.component.d.ts +0 -23
  1450. package/framework/schema-form-controls/schema-form-number/schema-form-number.component.d.ts +0 -26
  1451. package/framework/schema-form-controls/schema-form-select/schema-form-select.component.d.ts +0 -24
  1452. package/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.d.ts +0 -22
  1453. package/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.d.ts +0 -38
  1454. package/framework/schema-form-controls/schema-form-tel/schema-form-tel.component.d.ts +0 -23
  1455. package/framework/schema-form-controls/schema-form-tiled-select/schema-form-tiled-select.component.d.ts +0 -32
  1456. package/framework/side-nav/index.d.ts +0 -7
  1457. package/framework/side-nav/side-nav-item/side-nav-item.component.d.ts +0 -70
  1458. package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.d.ts +0 -14
  1459. package/framework/side-nav/side-nav-tokens.d.ts +0 -14
  1460. package/framework/side-nav/side-nav-utils.d.ts +0 -24
  1461. package/framework/side-nav/side-nav.component.d.ts +0 -66
  1462. package/framework/side-nav/side-nav.models.d.ts +0 -93
  1463. package/framework/side-nav/side-nav.module.d.ts +0 -9
  1464. package/framework/side-nav/side-nav.service.d.ts +0 -24
  1465. package/framework/top-bar/index.d.ts +0 -9
  1466. package/framework/top-bar/top-bar-compact-menu-btn-detail.directive.d.ts +0 -8
  1467. package/framework/top-bar/top-bar-item.directive.d.ts +0 -11
  1468. package/framework/top-bar/top-bar-menu-btn-detail.directive.d.ts +0 -8
  1469. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +0 -26
  1470. package/framework/top-bar/top-bar-menu.directive.d.ts +0 -8
  1471. package/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.d.ts +0 -8
  1472. package/framework/top-bar/top-bar-title/top-bar-title.component.d.ts +0 -7
  1473. package/framework/top-bar/top-bar.component.d.ts +0 -85
  1474. package/framework/top-bar/top-bar.module.d.ts +0 -21
  1475. package/google-maps/google-maps/google-maps.component.d.ts +0 -105
  1476. package/google-maps/google-maps-api-loader/google-maps-api-loader.d.ts +0 -4
  1477. package/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.d.ts +0 -74
  1478. package/google-maps/google-maps-api-loader/noop-google-maps-api-loader.d.ts +0 -13
  1479. package/google-maps/google-maps-contextmenu.d.ts +0 -15
  1480. package/google-maps/google-maps-controls.service.d.ts +0 -26
  1481. package/google-maps/google-maps-feature-helpers.d.ts +0 -41
  1482. package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.d.ts +0 -106
  1483. package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.d.ts +0 -83
  1484. package/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.d.ts +0 -24
  1485. package/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.d.ts +0 -37
  1486. package/google-maps/google-maps.module.d.ts +0 -20
  1487. package/google-maps/google-maps.service.d.ts +0 -65
  1488. package/google-maps/map-control.component.d.ts +0 -23
  1489. package/google-maps/map-controls-service.d.ts +0 -13
  1490. package/google-maps/map-file-drop/map-file-drop.component.d.ts +0 -37
  1491. package/google-maps/map-value-manager.service.d.ts +0 -21
  1492. package/google-maps/public-api.d.ts +0 -17
  1493. package/graphql/datatable/create-page-info-observable.d.ts +0 -4
  1494. package/graphql/datatable/datatable-graphql-query-ref.d.ts +0 -64
  1495. package/graphql/datatable/datatable-graphql.service.d.ts +0 -29
  1496. package/graphql/datatable/datatable-helpers.d.ts +0 -12
  1497. package/graphql/datatable/get-page-info.d.ts +0 -4
  1498. package/graphql/datatable/index.d.ts +0 -9
  1499. package/graphql/datatable/map-filter-states.d.ts +0 -18
  1500. package/graphql/datatable/map-page-info.d.ts +0 -11
  1501. package/graphql/datatable/map-search-date-columns-data-filter-state-to-gql.d.ts +0 -4
  1502. package/graphql/datatable/map-search-numeric-columns-data-filter-state-to-gql.d.ts +0 -4
  1503. package/graphql/datatable/map-search-text-columns-data-filter-state-to-gql.d.ts +0 -4
  1504. package/graphql/datatable/mapper-context.d.ts +0 -6
  1505. package/graphql/models/direction.d.ts +0 -6
  1506. package/graphql/models/gql-datatable-accessor.d.ts +0 -9
  1507. package/graphql/models/hint-definition.d.ts +0 -7
  1508. package/graphql/models/hint-transform-operation.d.ts +0 -5
  1509. package/graphql/models/hint-transformer.d.ts +0 -3
  1510. package/graphql/models/hints-kind.d.ts +0 -7
  1511. package/graphql/models/hints-token.d.ts +0 -7
  1512. package/graphql/models/index.d.ts +0 -9
  1513. package/graphql/models/query-processing-config.d.ts +0 -13
  1514. package/graphql/models/variable.d.ts +0 -5
  1515. package/graphql/public-api.d.ts +0 -2
  1516. package/graphql/utils/contains-variable.d.ts +0 -2
  1517. package/graphql/utils/gql-var.d.ts +0 -3
  1518. package/graphql/utils/hints-tokens-containing-hint.d.ts +0 -2
  1519. package/graphql/utils/index.d.ts +0 -10
  1520. package/graphql/utils/inline-variables.d.ts +0 -2
  1521. package/graphql/utils/parse-comments.d.ts +0 -2
  1522. package/graphql/utils/parse-hints.d.ts +0 -17
  1523. package/graphql/utils/remove-variable-definition.d.ts +0 -2
  1524. package/graphql/utils/remove-variable-definitions-not-defined.d.ts +0 -3
  1525. package/graphql/utils/remove-variable.d.ts +0 -2
  1526. package/graphql/utils/to-gql.d.ts +0 -1
  1527. package/icon/icon/icon.component.d.ts +0 -57
  1528. package/icon/icon-btn/icon-btn.component.d.ts +0 -76
  1529. package/icon/icon-notification/icon-notification.component.d.ts +0 -50
  1530. package/icon/icon.d.ts +0 -2
  1531. package/icon/icon.module.d.ts +0 -11
  1532. package/icon/public-api.d.ts +0 -6
  1533. package/icon/utils/file-extension-icon.d.ts +0 -3
  1534. package/icon/utils/get-known-icon.d.ts +0 -2
  1535. package/icon/utils/index.d.ts +0 -2
  1536. package/layout/breakpoint-aliases.d.ts +0 -20
  1537. package/layout/layout.module.d.ts +0 -8
  1538. package/layout/layout.service.d.ts +0 -23
  1539. package/layout/observe-media-query.d.ts +0 -8
  1540. package/layout/public-api.d.ts +0 -4
  1541. package/loading/loading/loading.component.d.ts +0 -9
  1542. package/loading/loading-overlay.service.d.ts +0 -16
  1543. package/loading/loading-themes.d.ts +0 -3
  1544. package/loading/loading.models.d.ts +0 -1
  1545. package/loading/loading.module.d.ts +0 -13
  1546. package/loading/public-api.d.ts +0 -5
  1547. package/menu/menu-animations.d.ts +0 -8
  1548. package/menu/menu-divider.component.d.ts +0 -5
  1549. package/menu/menu-footer/menu-footer.component.d.ts +0 -12
  1550. package/menu/menu-footer-action/menu-footer-action.component.d.ts +0 -22
  1551. package/menu/menu-header/menu-header.component.d.ts +0 -12
  1552. package/menu/menu-item.component.d.ts +0 -54
  1553. package/menu/menu-panel-token.d.ts +0 -6
  1554. package/menu/menu-panel.d.ts +0 -20
  1555. package/menu/menu-toggle.directive.d.ts +0 -83
  1556. package/menu/menu.component.d.ts +0 -79
  1557. package/menu/menu.module.d.ts +0 -16
  1558. package/menu/public-api.d.ts +0 -15
  1559. package/menu/testing/menu-footer.harness.d.ts +0 -22
  1560. package/menu/testing/menu-header.harness.d.ts +0 -18
  1561. package/menu/testing/menu-item.harness.d.ts +0 -37
  1562. package/menu/testing/menu.harness.d.ts +0 -74
  1563. package/menu/testing/utils.d.ts +0 -5
  1564. package/modal/directives/modal-close.directive.d.ts +0 -23
  1565. package/modal/directives/modal-footer-tpl.directive.d.ts +0 -8
  1566. package/modal/directives/modal-header-icon-tpl.directive.d.ts +0 -8
  1567. package/modal/directives/modal-header-title-tpl.directive.d.ts +0 -8
  1568. package/modal/directives/modal-title.directive.d.ts +0 -9
  1569. package/modal/directives/modal.directive.d.ts +0 -11
  1570. package/modal/modal/modal.component.d.ts +0 -58
  1571. package/modal/modal-body/modal-body.component.d.ts +0 -7
  1572. package/modal/modal-config.d.ts +0 -93
  1573. package/modal/modal-container/modal-container.component.d.ts +0 -81
  1574. package/modal/modal-footer/modal-footer.component.d.ts +0 -6
  1575. package/modal/modal-header/modal-header.component.d.ts +0 -11
  1576. package/modal/modal-injectors.d.ts +0 -23
  1577. package/modal/modal-ref.d.ts +0 -52
  1578. package/modal/modal-utils.d.ts +0 -8
  1579. package/modal/modal.models.d.ts +0 -24
  1580. package/modal/modal.module.d.ts +0 -25
  1581. package/modal/modal.service.d.ts +0 -98
  1582. package/modal/public-api.d.ts +0 -19
  1583. package/modal/route-modal/route-modal.component.d.ts +0 -18
  1584. package/models/component-type.d.ts +0 -2
  1585. package/models/http-status-codes.d.ts +0 -18
  1586. package/models/public-api.d.ts +0 -7
  1587. package/models/size-prefixes.d.ts +0 -1
  1588. package/models/size-types.d.ts +0 -1
  1589. package/models/theme-names.d.ts +0 -2
  1590. package/models/theme-prefixes.d.ts +0 -1
  1591. package/models/theme-types.d.ts +0 -2
  1592. package/navigation-reload/navigation-reload.config.d.ts +0 -5
  1593. package/navigation-reload/navigation-reload.provider.d.ts +0 -3
  1594. package/navigation-reload/navigation-reload.service.d.ts +0 -13
  1595. package/navigation-reload/public-api.d.ts +0 -3
  1596. package/popover/popover/popover.component.d.ts +0 -50
  1597. package/popover/popover-animations.d.ts +0 -4
  1598. package/popover/popover.directive.d.ts +0 -61
  1599. package/popover/popover.module.d.ts +0 -11
  1600. package/popover/public-api.d.ts +0 -4
  1601. package/progress/progress-circle/progress-circle.component.d.ts +0 -29
  1602. package/progress/progress.module.d.ts +0 -8
  1603. package/progress/public-api.d.ts +0 -2
  1604. package/public_api.d.ts +0 -2
  1605. package/rich-text/public-api.d.ts +0 -4
  1606. package/rich-text/rich-text/rich-text.component.d.ts +0 -194
  1607. package/rich-text/rich-text.module.d.ts +0 -10
  1608. package/rich-text/utils/models.d.ts +0 -343
  1609. package/rich-text/utils/utils.d.ts +0 -14
  1610. package/scrollbar/overlay-scrollbar.directive.d.ts +0 -23
  1611. package/scrollbar/overlay-scrollbars-config-model.d.ts +0 -2
  1612. package/scrollbar/overlay-scrollbars-config.d.ts +0 -51
  1613. package/scrollbar/overlay-scrollbars.service.d.ts +0 -23
  1614. package/scrollbar/public-api.d.ts +0 -5
  1615. package/scrollbar/scrollbar.module.d.ts +0 -8
  1616. package/services/asset-loader.service.d.ts +0 -15
  1617. package/services/font-loader.service.d.ts +0 -45
  1618. package/services/preferences/preferences-accessor.d.ts +0 -15
  1619. package/services/preferences/preferences-manager.service.d.ts +0 -15
  1620. package/services/preferences/preferences-record.d.ts +0 -28
  1621. package/services/preferences/preferences.models.d.ts +0 -3
  1622. package/services/public-api.d.ts +0 -7
  1623. package/services/router-helpers.service.d.ts +0 -10
  1624. package/shared/components/index.d.ts +0 -1
  1625. package/shared/components/password-input-reveal/password-input-reveal.component.d.ts +0 -17
  1626. package/shared/directives/auto-focus.directive.d.ts +0 -18
  1627. package/shared/directives/click-outside.directive.d.ts +0 -13
  1628. package/shared/directives/disable-control.directive.d.ts +0 -9
  1629. package/shared/directives/elem-resized.directive.d.ts +0 -20
  1630. package/shared/directives/hover-class-toggle.directive.d.ts +0 -36
  1631. package/shared/directives/hover-class.directive.d.ts +0 -31
  1632. package/shared/directives/index.d.ts +0 -8
  1633. package/shared/directives/ng-select-extra.directive.d.ts +0 -42
  1634. package/shared/directives/ngx-quill-extra.directive.d.ts +0 -23
  1635. package/shared/pipes/index.d.ts +0 -2
  1636. package/shared/pipes/mask-chars.pipe.d.ts +0 -7
  1637. package/shared/pipes/truncate.pipe.d.ts +0 -7
  1638. package/shared/public-api.d.ts +0 -4
  1639. package/shared/shared.module.d.ts +0 -22
  1640. package/storage/local-storage.service.d.ts +0 -31
  1641. package/storage/localstorage-memory.d.ts +0 -37
  1642. package/storage/public-api.d.ts +0 -1
  1643. package/story-helpers/arg-type-helpers.d.ts +0 -6
  1644. package/story-helpers/args-to-tpl.d.ts +0 -25
  1645. package/story-helpers/initial-route-factory.d.ts +0 -2
  1646. package/story-helpers/initial-route.service.d.ts +0 -10
  1647. package/story-helpers/on-story-bootstrapped-exec.d.ts +0 -24
  1648. package/story-helpers/on-story-bootstrapped-trigger.d.ts +0 -23
  1649. package/story-helpers/public-api.d.ts +0 -15
  1650. package/story-helpers/route-button.d.ts +0 -5
  1651. package/story-helpers/routes-arg-type.d.ts +0 -7
  1652. package/story-helpers/story-empty-with-route.component.d.ts +0 -5
  1653. package/story-helpers/story-empty.component.d.ts +0 -5
  1654. package/story-helpers/story-helper-components.module.d.ts +0 -12
  1655. package/story-helpers/story-initial-route.d.ts +0 -8
  1656. package/story-helpers/story-modal-container.component.d.ts +0 -23
  1657. package/story-helpers/story-preferences-accessor.service.d.ts +0 -19
  1658. package/story-helpers/story-toastr.service.d.ts +0 -33
  1659. package/tabbed/directives/tabbed-tab-content.directive.d.ts +0 -7
  1660. package/tabbed/directives/tabbed-tab.directive.d.ts +0 -13
  1661. package/tabbed/public-api.d.ts +0 -8
  1662. package/tabbed/tabbed-content/tabbed-content.component.d.ts +0 -7
  1663. package/tabbed/tabbed-item/tabbed-item.component.d.ts +0 -16
  1664. package/tabbed/tabbed-models.d.ts +0 -12
  1665. package/tabbed/tabbed.component.d.ts +0 -44
  1666. package/tabbed/tabbed.module.d.ts +0 -14
  1667. package/tabbed/tabbed.service.d.ts +0 -10
  1668. package/table/public-api.d.ts +0 -5
  1669. package/table/table/table.component.d.ts +0 -63
  1670. package/table/table-cell-tpl.directive.d.ts +0 -7
  1671. package/table/table-column-header-tpl.directive.d.ts +0 -7
  1672. package/table/table-column.component.d.ts +0 -24
  1673. package/table/table.module.d.ts +0 -13
  1674. package/table-cell-type/public-api.d.ts +0 -11
  1675. package/table-cell-type/services/table-cell-types-helpers.service.d.ts +0 -18
  1676. package/table-cell-type/table-cell-type-action.d.ts +0 -13
  1677. package/table-cell-type/table-cell-type-column.d.ts +0 -12
  1678. package/table-cell-type/table-cell-type-config.d.ts +0 -12
  1679. package/table-cell-type/table-cell-type-export-props.d.ts +0 -15
  1680. package/table-cell-type/table-cell-type-manifest-provider.d.ts +0 -7
  1681. package/table-cell-type/table-cell-type-models.d.ts +0 -39
  1682. package/table-cell-type/table-cell-type-name.d.ts +0 -1
  1683. package/table-cell-type/table-cell-type-selector.component.d.ts +0 -27
  1684. package/table-cell-type/table-cell-type-tokens.d.ts +0 -4
  1685. package/table-cell-type/table-cell-type.module.d.ts +0 -9
  1686. package/table-cell-types/public-api.d.ts +0 -22
  1687. package/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.d.ts +0 -44
  1688. package/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.d.ts +0 -21
  1689. package/table-cell-types/table-cell-type-currency/table-cell-type-currency.d.ts +0 -3
  1690. package/table-cell-types/table-cell-type-date/table-cell-type-date-config.d.ts +0 -9
  1691. package/table-cell-types/table-cell-type-date/table-cell-type-date.component.d.ts +0 -14
  1692. package/table-cell-types/table-cell-type-date/table-cell-type-date.d.ts +0 -3
  1693. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.d.ts +0 -38
  1694. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.d.ts +0 -21
  1695. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.d.ts +0 -3
  1696. package/table-cell-types/table-cell-type-icon/table-cell-type-icon-config.d.ts +0 -34
  1697. package/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.d.ts +0 -55
  1698. package/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.d.ts +0 -30
  1699. package/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.d.ts +0 -21
  1700. package/table-cell-types/table-cell-type-integer/table-cell-type-integer.d.ts +0 -3
  1701. package/table-cell-types/table-cell-type-manifests.d.ts +0 -11
  1702. package/table-cell-types/table-cell-type-phone/table-cell-type-phone-config.d.ts +0 -13
  1703. package/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.d.ts +0 -19
  1704. package/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle-config.d.ts +0 -29
  1705. package/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.d.ts +0 -50
  1706. package/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon-config.d.ts +0 -49
  1707. package/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.d.ts +0 -23
  1708. package/table-cell-types/table-cell-type-string/table-cell-type-string-config.d.ts +0 -18
  1709. package/table-cell-types/table-cell-type-string/table-cell-type-string.component.d.ts +0 -57
  1710. package/table-cell-types/table-cell-types.module.d.ts +0 -26
  1711. package/tel-input/intl-tel-input.d.ts +0 -300
  1712. package/tel-input/models/index.d.ts +0 -2
  1713. package/tel-input/models/tel-input-country-data.d.ts +0 -9
  1714. package/tel-input/models/tel-input-number-format-name.d.ts +0 -4
  1715. package/tel-input/phone-number.pipe.d.ts +0 -14
  1716. package/tel-input/public-api.d.ts +0 -10
  1717. package/tel-input/tel-input/tel-input.component.d.ts +0 -86
  1718. package/tel-input/tel-input-constants.d.ts +0 -4
  1719. package/tel-input/tel-input-validator.d.ts +0 -7
  1720. package/tel-input/tel-input.directive.d.ts +0 -35
  1721. package/tel-input/tel-input.module.d.ts +0 -12
  1722. package/tel-input/testing/tel-input.harness.d.ts +0 -19
  1723. package/tel-input/utils/add-country-code.d.ts +0 -7
  1724. package/tel-input/utils/coerce-phone-number-format.d.ts +0 -7
  1725. package/tel-input/utils/get-country-code.d.ts +0 -2
  1726. package/tel-input/utils/get-dial-code.d.ts +0 -9
  1727. package/tel-input/utils/get-global-intl-tel-input-globals.d.ts +0 -2
  1728. package/tel-input/utils/get-global-intl-tel-input-utils.d.ts +0 -2
  1729. package/tel-input/utils/get-intl-tel-input-utils.d.ts +0 -2
  1730. package/tel-input/utils/get-validation-error-message.d.ts +0 -5
  1731. package/tel-input/utils/index.d.ts +0 -9
  1732. package/tel-input/utils/process-country-codes.d.ts +0 -8
  1733. package/testing/current-tick-time.d.ts +0 -13
  1734. package/testing/fake-toastr.d.ts +0 -30
  1735. package/testing/get-harness.d.ts +0 -7
  1736. package/testing/harnesses/ng-select-dropdown.harness.d.ts +0 -23
  1737. package/testing/harnesses/ng-select-option.harness.d.ts +0 -18
  1738. package/testing/harnesses/ng-select.harness.d.ts +0 -50
  1739. package/testing/public-api.d.ts +0 -9
  1740. package/testing/render-story.d.ts +0 -2
  1741. package/testing/story-expect.d.ts +0 -6
  1742. package/testing/tick-helper.d.ts +0 -70
  1743. package/tiled-select/components/tiled-select/tiled-select.component.d.ts +0 -56
  1744. package/tiled-select/components/tiled-select-tile/tiled-select-tile.component.d.ts +0 -45
  1745. package/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.d.ts +0 -26
  1746. package/tiled-select/directives/tiled-select-tile-icon-tpl.directive.d.ts +0 -8
  1747. package/tiled-select/directives/tiled-select-tile-label-tpl.directive.d.ts +0 -8
  1748. package/tiled-select/directives/tiled-select-tile-overlay.directive.d.ts +0 -10
  1749. package/tiled-select/public-api.d.ts +0 -9
  1750. package/tiled-select/testing/index.d.ts +0 -2
  1751. package/tiled-select/testing/tiled-select-harness.d.ts +0 -9
  1752. package/tiled-select/testing/tiled-select-tile-harness.d.ts +0 -17
  1753. package/tiled-select/tiled-select.models.d.ts +0 -13
  1754. package/tiled-select/tiled-select.module.d.ts +0 -14
  1755. package/toggle-edit/models/can-toggle-edit.d.ts +0 -7
  1756. package/toggle-edit/models/index.d.ts +0 -2
  1757. package/toggle-edit/models/toggle-edit-ref.d.ts +0 -30
  1758. package/toggle-edit/public-api.d.ts +0 -6
  1759. package/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.d.ts +0 -5
  1760. package/toggle-edit/toggle-edit-display-tpl.directive.d.ts +0 -8
  1761. package/toggle-edit/toggle-edit-keyboard-listener.service.d.ts +0 -17
  1762. package/toggle-edit/toggle-edit.component.d.ts +0 -93
  1763. package/toggle-edit/toggle-edit.module.d.ts +0 -18
  1764. package/toggle-group/public-api.d.ts +0 -3
  1765. package/toggle-group/toggle-group-option.directive.d.ts +0 -18
  1766. package/toggle-group/toggle-group.directive.d.ts +0 -38
  1767. package/toggle-group/toggle-group.module.d.ts +0 -10
  1768. package/unsaved-changes-dialog/public-api.d.ts +0 -4
  1769. package/unsaved-changes-dialog/unsaved-changes-can-deactivate.d.ts +0 -7
  1770. package/unsaved-changes-dialog/unsaved-changes-dialog.component.d.ts +0 -5
  1771. package/unsaved-changes-dialog/unsaved-changes-dialog.guard.d.ts +0 -11
  1772. package/unsaved-changes-dialog/unsaved-changes-dialog.module.d.ts +0 -7
  1773. package/utils/array-move.d.ts +0 -49
  1774. package/utils/calc-percentage.d.ts +0 -1
  1775. package/utils/cdk/get-closest-widget-cdk-drag.d.ts +0 -8
  1776. package/utils/create-padding.d.ts +0 -1
  1777. package/utils/file-utils.d.ts +0 -12
  1778. package/utils/form/get-control-name.d.ts +0 -22
  1779. package/utils/form/get-control-path.d.ts +0 -27
  1780. package/utils/form/has-required-control.d.ts +0 -31
  1781. package/utils/form/is-empty-input-value.d.ts +0 -1
  1782. package/utils/form/observe-control-is-different.d.ts +0 -13
  1783. package/utils/form/observe-control-status.d.ts +0 -7
  1784. package/utils/form/observe-control-valid.d.ts +0 -14
  1785. package/utils/form/observe-control-value-change.d.ts +0 -9
  1786. package/utils/form/observe-control-value.d.ts +0 -6
  1787. package/utils/form/wait-on-non-pending-status.d.ts +0 -12
  1788. package/utils/fractional-digits-count.d.ts +0 -8
  1789. package/utils/geo-json/close-polygons.d.ts +0 -9
  1790. package/utils/geo-json/coerce-feature-collection.d.ts +0 -2
  1791. package/utils/geo-json/geo-json-to-area.d.ts +0 -6
  1792. package/utils/geo-json/is-feature-collection.validator.d.ts +0 -3
  1793. package/utils/geo-json/is-only-geometry-types.d.ts +0 -5
  1794. package/utils/geo-json/is-only-geometry-types.validator.d.ts +0 -4
  1795. package/utils/geo-json/merge-polygons.d.ts +0 -9
  1796. package/utils/geo-json/min-max-points.validator.d.ts +0 -3
  1797. package/utils/geo-json/no-empty-feature-collection.validator.d.ts +0 -3
  1798. package/utils/geo-json/no-inner-rings.validator.d.ts +0 -10
  1799. package/utils/geo-json/no-kinks.validator.d.ts +0 -3
  1800. package/utils/geo-json/read-geo-file.d.ts +0 -7
  1801. package/utils/geo-json/split-multi-polygons.d.ts +0 -8
  1802. package/utils/get-attribute.d.ts +0 -4
  1803. package/utils/has-attribute.d.ts +0 -4
  1804. package/utils/has-property.d.ts +0 -1
  1805. package/utils/input-masks.d.ts +0 -1
  1806. package/utils/is-absolute-url.d.ts +0 -1
  1807. package/utils/is-null-or-undefined-or-empty.d.ts +0 -1
  1808. package/utils/is-null-or-undefined.d.ts +0 -1
  1809. package/utils/is-numeric.d.ts +0 -1
  1810. package/utils/load-style-sheet.d.ts +0 -1
  1811. package/utils/load-style.d.ts +0 -1
  1812. package/utils/not-null-or-undefined-or-empty.d.ts +0 -1
  1813. package/utils/not-null-or-undefined.d.ts +0 -1
  1814. package/utils/obj-utils.d.ts +0 -8
  1815. package/utils/observe-query-list.d.ts +0 -3
  1816. package/utils/operators/index.d.ts +0 -2
  1817. package/utils/operators/map-each.d.ts +0 -2
  1818. package/utils/operators/tap-first.d.ts +0 -5
  1819. package/utils/pad-end.d.ts +0 -1
  1820. package/utils/pad-start.d.ts +0 -1
  1821. package/utils/polling-ticker.d.ts +0 -13
  1822. package/utils/public-api.d.ts +0 -53
  1823. package/utils/refreshable.d.ts +0 -20
  1824. package/utils/router/index.d.ts +0 -6
  1825. package/utils/router/is-empty-url-route.d.ts +0 -2
  1826. package/utils/router/leaf-child-route.d.ts +0 -2
  1827. package/utils/router/operators/activated-routes-with-data-property.d.ts +0 -7
  1828. package/utils/router/route-snapshot-path-full.d.ts +0 -2
  1829. package/utils/router/route-snapshot-path-relative.d.ts +0 -2
  1830. package/utils/router/will-have-data-prop.d.ts +0 -2
  1831. package/utils/subscriber-count.d.ts +0 -13
  1832. package/utils/toggle-attribute.d.ts +0 -16
  1833. package/utils/wait-on-condition-async.d.ts +0 -1
  1834. package/utils/wrap-into-observable.d.ts +0 -2
  1835. package/validators/decimal.validator.d.ts +0 -9
  1836. package/validators/email-exists.validator.d.ts +0 -10
  1837. package/validators/integer.validator.d.ts +0 -9
  1838. package/validators/phone-length.validator.d.ts +0 -7
  1839. package/validators/public-api.d.ts +0 -5
  1840. package/validators/tax-id.validator.d.ts +0 -11
  1841. package/vertical-list-filter/public-api.d.ts +0 -2
  1842. package/vertical-list-filter/testing/index.d.ts +0 -1
  1843. package/vertical-list-filter/testing/vertical-list-filter.harness.d.ts +0 -9
  1844. package/vertical-list-filter/vertical-list-filter.component.d.ts +0 -17
  1845. package/viewers/html-template-viewer/html-template-viewer.component.d.ts +0 -70
  1846. package/viewers/html-template-viewer/html-template-viewer.module.d.ts +0 -10
  1847. package/viewers/html-template-viewer/index.d.ts +0 -2
  1848. package/viewers/pdf-viewer/index.d.ts +0 -3
  1849. package/viewers/pdf-viewer/pdf-page/pdf-page.component.d.ts +0 -42
  1850. package/viewers/pdf-viewer/pdf-renderer.service.d.ts +0 -9
  1851. package/viewers/pdf-viewer/pdf-viewer.component.d.ts +0 -62
  1852. package/viewers/pdf-viewer/pdf-viewer.module.d.ts +0 -10
  1853. package/viewers/public-api.d.ts +0 -2
  1854. package/widget/directives/widget-drag-handle.directive.d.ts +0 -56
  1855. package/widget/directives/widget-icon-tpl.directive.d.ts +0 -8
  1856. package/widget/directives/widget-title-tpl.directive.d.ts +0 -8
  1857. package/widget/preferences/widget-preferences.models.d.ts +0 -8
  1858. package/widget/preferences/widget-preferences.service.d.ts +0 -21
  1859. package/widget/preferences/widget-preferences.token.d.ts +0 -3
  1860. package/widget/public-api.d.ts +0 -41
  1861. package/widget/widget/widget.component.d.ts +0 -85
  1862. package/widget/widget-content-components/widget-button-group/widget-button-group.component.d.ts +0 -5
  1863. package/widget/widget-content-components/widget-button-group/widget-button-group.module.d.ts +0 -9
  1864. package/widget/widget-content-components/widget-content-header/widget-content-header.component.d.ts +0 -5
  1865. package/widget/widget-content-components/widget-content-header/widget-content-header.module.d.ts +0 -8
  1866. package/widget/widget-content-components/widget-description/widget-description.component.d.ts +0 -5
  1867. package/widget/widget-content-components/widget-description/widget-description.module.d.ts +0 -8
  1868. package/widget/widget-content-components/widget-empty-label/widget-empty-label.component.d.ts +0 -17
  1869. package/widget/widget-content-components/widget-empty-label/widget-empty-label.module.d.ts +0 -8
  1870. package/widget/widget-content-components/widget-footer-link/widget-footer-link.component.d.ts +0 -5
  1871. package/widget/widget-content-components/widget-footer-link/widget-footer-link.module.d.ts +0 -8
  1872. package/widget/widget-content-components/widget-footer-text/widget-footer-text.component.d.ts +0 -5
  1873. package/widget/widget-content-components/widget-footer-text/widget-footer-text.module.d.ts +0 -8
  1874. package/widget/widget-content-components/widget-header-badge/widget-header-badge.component.d.ts +0 -14
  1875. package/widget/widget-content-components/widget-header-badge/widget-header-badge.module.d.ts +0 -8
  1876. package/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item-icon-tpl.directive.d.ts +0 -8
  1877. package/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.d.ts +0 -65
  1878. package/widget/widget-content-components/widget-list-group/widget-list-group.component.d.ts +0 -5
  1879. package/widget/widget-content-components/widget-list-group/widget-list-group.module.d.ts +0 -11
  1880. package/widget/widget-content-components/widget-table/widget-table.component.d.ts +0 -16
  1881. package/widget/widget-content-components/widget-table/widget-table.module.d.ts +0 -10
  1882. package/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.d.ts +0 -5
  1883. package/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.d.ts +0 -17
  1884. package/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.d.ts +0 -5
  1885. package/widget/widget-content-components/widget-tile/widget-tile-secondary-icon.directive.d.ts +0 -8
  1886. package/widget/widget-content-components/widget-tile/widget-tile.component.d.ts +0 -51
  1887. package/widget/widget-content-components/widget-tile/widget-tile.module.d.ts +0 -13
  1888. package/widget/widget-content-components/widget-tile-list/widget-tile-list.component.d.ts +0 -5
  1889. package/widget/widget-content-components/widget-tile-list/widget-tile-list.module.d.ts +0 -9
  1890. package/widget/widget-footer/widget-footer.component.d.ts +0 -5
  1891. package/widget/widget-registry.models.d.ts +0 -20
  1892. package/widget/widget-registry.service.d.ts +0 -19
  1893. package/widget/widget-token.d.ts +0 -6
  1894. package/widget/widget.models.d.ts +0 -7
  1895. package/widget/widget.module.d.ts +0 -30
@@ -1,3891 +0,0 @@
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, Injector, ViewChildren, Self, ContentChildren, inject } 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_DATA, 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 { JsonSchemaFormModule, isArray, buildTitleMap, hasOwn, Framework, WidgetLibraryModule, JsonSchemaFormService, FrameworkLibraryService, WidgetLibraryService } from '@ajsf/core';
41
- import * as i3$3 from '@angular/forms';
42
- import { ReactiveFormsModule } from '@angular/forms';
43
- import { TheSeamCheckboxComponent } from '@theseam/ui-common/checkbox';
44
- import * as i4$3 from '@theseam/ui-common/form-field';
45
- import { TheSeamFormFieldModule } from '@theseam/ui-common/form-field';
46
- import * as i5$1 from '@ng-select/ng-select';
47
- import { NgSelectModule } from '@ng-select/ng-select';
48
- import * as i5$2 from '@theseam/ui-common/tel-input';
49
- import { TheSeamTelInputModule } from '@theseam/ui-common/tel-input';
50
- import * as i6$1 from '@theseam/ui-common/tiled-select';
51
- import { TheSeamTiledSelectModule } from '@theseam/ui-common/tiled-select';
52
- import * as i2$3 from '@angular/cdk/platform';
53
-
54
- class BaseLayoutContentFooterDirective {
55
- constructor(_elementRef) {
56
- this._elementRef = _elementRef;
57
- }
58
- }
59
- BaseLayoutContentFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutContentFooterDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
60
- BaseLayoutContentFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutContentFooterDirective, selector: "[seamBaseLayoutContentFooter]", ngImport: i0 });
61
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutContentFooterDirective, decorators: [{
62
- type: Directive,
63
- args: [{
64
- selector: '[seamBaseLayoutContentFooter]'
65
- }]
66
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
67
-
68
- class BaseLayoutContentHeaderDirective {
69
- constructor(_elementRef) {
70
- this._elementRef = _elementRef;
71
- }
72
- }
73
- BaseLayoutContentHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutContentHeaderDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
74
- BaseLayoutContentHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutContentHeaderDirective, selector: "[seamBaseLayoutContentHeader]", ngImport: i0 });
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutContentHeaderDirective, decorators: [{
76
- type: Directive,
77
- args: [{
78
- selector: '[seamBaseLayoutContentHeader]'
79
- }]
80
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
81
-
82
- class BaseLayoutContentDirective {
83
- constructor(_elementRef) {
84
- this._elementRef = _elementRef;
85
- }
86
- }
87
- BaseLayoutContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutContentDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
88
- BaseLayoutContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutContentDirective, selector: "[seamBaseLayoutContent]", ngImport: i0 });
89
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutContentDirective, decorators: [{
90
- type: Directive,
91
- args: [{
92
- selector: '[seamBaseLayoutContent]'
93
- }]
94
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
95
-
96
- const THESEAM_BASE_LAYOUT_REF = new InjectionToken('seamBaseLayoutRef');
97
-
98
- /**
99
- * Can be used to toggle the expand state of the registered nav.
100
- */
101
- class BaseLayoutNavToggleDirective {
102
- get _attrType() { return this.type; }
103
- get _attrAriaLabel() { return this.ariaLabel || null; }
104
- _onClick() {
105
- if (this.baseLayout && this.baseLayout.registeredNav) {
106
- this.baseLayout.registeredNav.toggle();
107
- }
108
- }
109
- constructor(_cdr, _baseLayout) {
110
- this._cdr = _cdr;
111
- this.type = 'button';
112
- /** Screenreader label for the button. */
113
- this.ariaLabel = 'Navigation toggle';
114
- this._toggleClass = true;
115
- this._expandedClass = false;
116
- this.baseLayout = _baseLayout;
117
- }
118
- ngOnInit() {
119
- var _a, _b;
120
- (_b = (_a = this.baseLayout) === null || _a === void 0 ? void 0 : _a.registeredNav) === null || _b === void 0 ? void 0 : _b.expanded$.pipe(tap(exp => {
121
- this._expandedClass = exp;
122
- this._cdr.markForCheck();
123
- })).subscribe();
124
- }
125
- }
126
- BaseLayoutNavToggleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutNavToggleDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: THESEAM_BASE_LAYOUT_REF, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
127
- BaseLayoutNavToggleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", 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 });
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutNavToggleDirective, decorators: [{
129
- type: Directive,
130
- args: [{
131
- selector: 'button[seamBaseLayoutNavToggle]',
132
- exportAs: 'seamBaseLayoutNavToggle'
133
- }]
134
- }], ctorParameters: function () {
135
- return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
136
- type: Optional
137
- }, {
138
- type: Inject,
139
- args: [THESEAM_BASE_LAYOUT_REF]
140
- }] }];
141
- }, propDecorators: { _attrType: [{
142
- type: HostBinding,
143
- args: ['attr.type']
144
- }], type: [{
145
- type: Input
146
- }], _attrAriaLabel: [{
147
- type: HostBinding,
148
- args: ['attr.aria-label']
149
- }], ariaLabel: [{
150
- type: Input,
151
- args: ['aria-label']
152
- }], _toggleClass: [{
153
- type: HostBinding,
154
- args: ['class.base-layout-nav-toggle']
155
- }], _expandedClass: [{
156
- type: HostBinding,
157
- args: ['class.base-layout-nav-toggle--expanded']
158
- }], _onClick: [{
159
- type: HostListener,
160
- args: ['click']
161
- }] } });
162
-
163
- class BaseLayoutSideBarFooterDirective {
164
- constructor(_elementRef) {
165
- this._elementRef = _elementRef;
166
- }
167
- }
168
- BaseLayoutSideBarFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutSideBarFooterDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
169
- BaseLayoutSideBarFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutSideBarFooterDirective, selector: "[seamBaseLayoutSideBarFooter]", ngImport: i0 });
170
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutSideBarFooterDirective, decorators: [{
171
- type: Directive,
172
- args: [{
173
- selector: '[seamBaseLayoutSideBarFooter]'
174
- }]
175
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
176
-
177
- class BaseLayoutSideBarDirective {
178
- constructor(_elementRef) {
179
- this._elementRef = _elementRef;
180
- }
181
- }
182
- BaseLayoutSideBarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutSideBarDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
183
- BaseLayoutSideBarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutSideBarDirective, selector: "[seamBaseLayoutSideBar]", ngImport: i0 });
184
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutSideBarDirective, decorators: [{
185
- type: Directive,
186
- args: [{
187
- selector: '[seamBaseLayoutSideBar]'
188
- }]
189
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
190
-
191
- class BaseLayoutTopBarDirective {
192
- constructor(_elementRef) {
193
- this._elementRef = _elementRef;
194
- }
195
- }
196
- BaseLayoutTopBarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutTopBarDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
197
- BaseLayoutTopBarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutTopBarDirective, selector: "[seamBaseLayoutTopBar]", ngImport: i0 });
198
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutTopBarDirective, decorators: [{
199
- type: Directive,
200
- args: [{
201
- selector: '[seamBaseLayoutTopBar]'
202
- }]
203
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
204
-
205
- class BaseLayoutSideBarHeaderDirective {
206
- constructor(_elementRef) {
207
- this._elementRef = _elementRef;
208
- }
209
- }
210
- BaseLayoutSideBarHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutSideBarHeaderDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
211
- BaseLayoutSideBarHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BaseLayoutSideBarHeaderDirective, selector: "[seamBaseLayoutSideBarHeader]", ngImport: i0 });
212
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseLayoutSideBarHeaderDirective, decorators: [{
213
- type: Directive,
214
- args: [{
215
- selector: '[seamBaseLayoutSideBarHeader]'
216
- }]
217
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
218
-
219
- const THE_SEAM_BASE_LAYOUT = {
220
- provide: THESEAM_BASE_LAYOUT_REF,
221
- // tslint:disable-next-line:no-use-before-declare
222
- useExisting: forwardRef(() => TheSeamBaseLayoutComponent),
223
- multi: false,
224
- };
225
- class TheSeamBaseLayoutComponent {
226
- get registeredNav() { return this._registeredNav.value; }
227
- get registeredActions() { return this._registeredActions.value; }
228
- constructor(_viewContainerRef, _layout) {
229
- this._viewContainerRef = _viewContainerRef;
230
- this._layout = _layout;
231
- this.faAngleDoubleRight = faAngleDoubleRight;
232
- this.faAngleDoubleLeft = faAngleDoubleLeft;
233
- this.overlayNav = false;
234
- this.showSidebar = true;
235
- this._hasSideBar = new BehaviorSubject(false);
236
- this._registeredNav = new BehaviorSubject(undefined);
237
- this.registeredNav$ = this._registeredNav.asObservable();
238
- this._registeredActions = new BehaviorSubject([]);
239
- this.registeredActions$ = this._registeredActions.asObservable();
240
- this.isMobile$ = this._layout.isMobile$;
241
- this.hasSideBar$ = this._hasSideBar.asObservable();
242
- }
243
- ngOnInit() {
244
- if (this.mobileBreakpoint) {
245
- this._layout.setMobileBreakpoint(this.mobileBreakpoint);
246
- }
247
- if (this._topBarTpl) {
248
- this._topBarPortal = new TemplatePortal(this._topBarTpl, this._viewContainerRef);
249
- }
250
- if (this._sideBarTpl) {
251
- this._sideBarPortal = new TemplatePortal(this._sideBarTpl, this._viewContainerRef);
252
- if (this.showSidebar) {
253
- this._hasSideBar.next(true);
254
- }
255
- }
256
- if (this._contentTpl) {
257
- this._contentPortal = new TemplatePortal(this._contentTpl, this._viewContainerRef);
258
- }
259
- if (this._contentHeaderTpl) {
260
- this._contentHeaderPortal = new TemplatePortal(this._contentHeaderTpl, this._viewContainerRef);
261
- }
262
- if (this._contentFooterTpl) {
263
- this._contentFooterPortal = new TemplatePortal(this._contentFooterTpl, this._viewContainerRef);
264
- }
265
- }
266
- registerNav(nav) {
267
- // TODO: Allow multiple registered navs
268
- // if (this.registeredNav) {
269
- // throw new Error('[TheSeamBaseLayoutComponent] A nav is already registered.')
270
- // }
271
- // console.log('register nav', nav)
272
- this._registeredNav.next(nav);
273
- }
274
- unregisterNav(nav) {
275
- if (this.registeredNav === nav) {
276
- this._registeredNav.next(undefined);
277
- }
278
- }
279
- registerAction(action) {
280
- const actions = this._registeredActions.value;
281
- if (actions.findIndex(a => a.name === action.name) !== -1) {
282
- if (isDevMode()) {
283
- // eslint-disable-next-line no-console
284
- console.warn(`[TheSeamBaseLayoutComponent] registerAction(): Action ${action.name} not ` +
285
- 'registered, because another action by that name is already registered.');
286
- }
287
- return;
288
- }
289
- actions.push(action);
290
- }
291
- unregisterAction(action) {
292
- const actionName = typeof action === 'string' ? action : action.name;
293
- const actions = this._registeredActions.value;
294
- this._registeredActions.next(actions.filter(f => f.name !== actionName));
295
- }
296
- isActionRegistered(actionName) {
297
- const actions = this._registeredActions.value;
298
- const action = actions.find(f => f.name === actionName);
299
- return !!action;
300
- }
301
- _handleButtonAction(action) {
302
- this._execButtonAction(action).subscribe();
303
- }
304
- _execButtonAction(action) {
305
- const fnRes = action.exec();
306
- return isObservable(fnRes) ? fnRes : from(Promise.resolve(fnRes));
307
- }
308
- }
309
- TheSeamBaseLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamBaseLayoutComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TheSeamLayoutService }], target: i0.ɵɵFactoryTarget.Component });
310
- TheSeamBaseLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
311
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamBaseLayoutComponent, decorators: [{
312
- type: Component,
313
- 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"] }]
314
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i1.TheSeamLayoutService }]; }, propDecorators: { overlayNav: [{
315
- type: Input
316
- }], mobileBreakpoint: [{
317
- type: Input
318
- }], showSidebar: [{
319
- type: Input
320
- }], _topBarTpl: [{
321
- type: ContentChild,
322
- args: [BaseLayoutTopBarDirective, { static: true, read: TemplateRef }]
323
- }], _sideBarTpl: [{
324
- type: ContentChild,
325
- args: [BaseLayoutSideBarDirective, { static: true, read: TemplateRef }]
326
- }], _contentTpl: [{
327
- type: ContentChild,
328
- args: [BaseLayoutContentDirective, { static: true, read: TemplateRef }]
329
- }], _contentHeaderTpl: [{
330
- type: ContentChild,
331
- args: [BaseLayoutContentHeaderDirective, { static: true, read: TemplateRef }]
332
- }], _contentFooterTpl: [{
333
- type: ContentChild,
334
- args: [BaseLayoutContentFooterDirective, { static: true, read: TemplateRef }]
335
- }] } });
336
-
337
- class TheSeamBaseLayoutModule {
338
- }
339
- TheSeamBaseLayoutModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamBaseLayoutModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
340
- TheSeamBaseLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamBaseLayoutModule, declarations: [TheSeamBaseLayoutComponent,
341
- BaseLayoutContentDirective,
342
- BaseLayoutSideBarDirective,
343
- BaseLayoutSideBarFooterDirective,
344
- BaseLayoutSideBarHeaderDirective,
345
- BaseLayoutTopBarDirective,
346
- BaseLayoutNavToggleDirective,
347
- BaseLayoutContentHeaderDirective,
348
- BaseLayoutContentFooterDirective], imports: [CommonModule,
349
- PortalModule,
350
- TheSeamScrollbarModule,
351
- TheSeamIconModule,
352
- TheSeamButtonsModule], exports: [TheSeamBaseLayoutComponent,
353
- BaseLayoutContentDirective,
354
- BaseLayoutSideBarDirective,
355
- BaseLayoutSideBarFooterDirective,
356
- BaseLayoutSideBarHeaderDirective,
357
- BaseLayoutTopBarDirective,
358
- BaseLayoutNavToggleDirective,
359
- BaseLayoutContentHeaderDirective,
360
- BaseLayoutContentFooterDirective] });
361
- TheSeamBaseLayoutModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamBaseLayoutModule, imports: [CommonModule,
362
- PortalModule,
363
- TheSeamScrollbarModule,
364
- TheSeamIconModule,
365
- TheSeamButtonsModule] });
366
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamBaseLayoutModule, decorators: [{
367
- type: NgModule,
368
- args: [{
369
- declarations: [
370
- TheSeamBaseLayoutComponent,
371
- BaseLayoutContentDirective,
372
- BaseLayoutSideBarDirective,
373
- BaseLayoutSideBarFooterDirective,
374
- BaseLayoutSideBarHeaderDirective,
375
- BaseLayoutTopBarDirective,
376
- BaseLayoutNavToggleDirective,
377
- BaseLayoutContentHeaderDirective,
378
- BaseLayoutContentFooterDirective
379
- ],
380
- imports: [
381
- CommonModule,
382
- PortalModule,
383
- TheSeamScrollbarModule,
384
- TheSeamIconModule,
385
- TheSeamButtonsModule
386
- ],
387
- exports: [
388
- TheSeamBaseLayoutComponent,
389
- BaseLayoutContentDirective,
390
- BaseLayoutSideBarDirective,
391
- BaseLayoutSideBarFooterDirective,
392
- BaseLayoutSideBarHeaderDirective,
393
- BaseLayoutTopBarDirective,
394
- BaseLayoutNavToggleDirective,
395
- BaseLayoutContentHeaderDirective,
396
- BaseLayoutContentFooterDirective
397
- ]
398
- }]
399
- }] });
400
-
401
- class DashboardWidgetContainerComponent {
402
- }
403
- DashboardWidgetContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
404
- DashboardWidgetContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
405
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetContainerComponent, decorators: [{
406
- type: Component,
407
- args: [{ selector: 'seam-dashboard-widget-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template><ng-content></ng-content></ng-template>\n" }]
408
- }], propDecorators: { def: [{
409
- type: Input
410
- }], templateRef: [{
411
- type: ViewChild,
412
- args: [TemplateRef]
413
- }] } });
414
-
415
- const THESEAM_DASHBOARD_WIDGETS_ACCESSOR = new InjectionToken('THESEAM_DASHBOARD_WIDGETS_ACCESSOR');
416
-
417
- class DashboardWidgetTemplateContainerComponent {
418
- constructor(_dashboardWidgetsComponent) {
419
- this._dashboardWidgetsComponent = _dashboardWidgetsComponent;
420
- 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));
421
- }
422
- }
423
- DashboardWidgetTemplateContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetTemplateContainerComponent, deps: [{ token: THESEAM_DASHBOARD_WIDGETS_ACCESSOR }], target: i0.ɵɵFactoryTarget.Component });
424
- DashboardWidgetTemplateContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
425
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetTemplateContainerComponent, decorators: [{
426
- type: Component,
427
- args: [{ selector: 'seam-dashboard-widget-template-container', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template [ngTemplateOutlet]=\"$any(template$ | async)\"></ng-template>\n" }]
428
- }], ctorParameters: function () {
429
- return [{ type: undefined, decorators: [{
430
- type: Inject,
431
- args: [THESEAM_DASHBOARD_WIDGETS_ACCESSOR]
432
- }] }];
433
- }, propDecorators: { item: [{
434
- type: Input
435
- }] } });
436
-
437
- /**
438
- * Mostly copied from
439
- * `https://github.com/angular/components/blob/master/src/cdk/portal/portal-directives.ts`
440
- * until I can figure out how to hold off removing the DOM nodes with the
441
- * cdkPortalOutlet. When we update to Angular 9 I may be able to do this better
442
- * with the new DomPortal.
443
- *
444
- * Directive version of a PortalOutlet. Because the directive *is* a
445
- * PortalOutlet, portals can be directly attached to it, enabling declarative
446
- * use.
447
- *
448
- * Usage: `<ng-template [cdkPortalOutlet]="greeting"></ng-template>`
449
- */
450
- class DashboardWidgetPortalOutletDirective extends BasePortalOutlet {
451
- constructor(_componentFactoryResolver, _viewContainerRef, _elementRef) {
452
- super();
453
- this._componentFactoryResolver = _componentFactoryResolver;
454
- this._viewContainerRef = _viewContainerRef;
455
- this._elementRef = _elementRef;
456
- /** Whether the portal component is initialized. */
457
- this._isInitialized = false;
458
- /** Emits when a portal is attached to the outlet. */
459
- this.attached = new EventEmitter();
460
- }
461
- /** Portal associated with the Portal outlet. */
462
- get portal() {
463
- return this._attachedPortal;
464
- }
465
- set portal(portal) {
466
- // console.log('[DashboardWidgetPortalOutletDirective] set portal', portal, this.hasAttached())
467
- // Ignore the cases where the `portal` is set to a falsy value before the lifecycle hooks have
468
- // run. This handles the cases where the user might do something like `<div cdkPortalOutlet>`
469
- // and attach a portal programmatically in the parent component. When Angular does the first CD
470
- // round, it will fire the setter with empty string, causing the user's content to be cleared.
471
- if (this.hasAttached() && !portal && !this._isInitialized) {
472
- return;
473
- }
474
- if (this.hasAttached()) {
475
- super.detach();
476
- }
477
- if (portal) {
478
- super.attach(portal);
479
- }
480
- this._attachedPortal = portal;
481
- }
482
- /** Component or view reference that is attached to the portal. */
483
- get attachedRef() {
484
- return this._attachedRef;
485
- }
486
- ngOnInit() {
487
- this._isInitialized = true;
488
- }
489
- ngOnDestroy() {
490
- // console.log('[DashboardWidgetPortalOutletDirective] ngOnDestroy')
491
- // TODO: Figure out the right way to call dispose without messing up
492
- // animation. This setTimeout way assumes the transition is 500ms, but that
493
- // may not always be the case and isn't guaranteed to match the animation ms
494
- // duration, since setTimeout isn't really meant for accurate timing. It
495
- // also makes debugging animations difficult, because you can pause an
496
- // animation, but the timeout will still run.
497
- setTimeout(() => {
498
- super.dispose();
499
- this._attachedPortal = null;
500
- this._attachedRef = null;
501
- }, 500);
502
- }
503
- /**
504
- * Attach the given ComponentPortal to this PortalOutlet using the ComponentFactoryResolver.
505
- *
506
- * @param portal Portal to be attached to the portal outlet.
507
- * @returns Reference to the created component.
508
- */
509
- attachComponentPortal(portal) {
510
- portal.setAttachedHost(this);
511
- // If the portal specifies an origin, use that as the logical location of the component
512
- // in the application tree. Otherwise use the location of this PortalOutlet.
513
- const viewContainerRef = portal.viewContainerRef != null
514
- ? portal.viewContainerRef
515
- : this._viewContainerRef;
516
- const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;
517
- const componentFactory = resolver.resolveComponentFactory(portal.component);
518
- const ref = viewContainerRef.createComponent(componentFactory, viewContainerRef.length, portal.injector || viewContainerRef.injector);
519
- super.setDisposeFn(() => ref.destroy());
520
- this._attachedPortal = portal;
521
- this._attachedRef = ref;
522
- this.attached.emit(ref);
523
- return ref;
524
- }
525
- /**
526
- * Attach the given TemplatePortal to this PortlHost as an embedded View.
527
- * @param portal Portal to be attached.
528
- * @returns Reference to the created embedded view.
529
- */
530
- attachTemplatePortal(portal) {
531
- portal.setAttachedHost(this);
532
- const viewRef = this._viewContainerRef.createEmbeddedView(portal.templateRef, portal.context);
533
- super.setDisposeFn(() => this._viewContainerRef.clear());
534
- this._attachedPortal = portal;
535
- this._attachedRef = viewRef;
536
- this.attached.emit(viewRef);
537
- return viewRef;
538
- }
539
- }
540
- DashboardWidgetPortalOutletDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetPortalOutletDirective, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
541
- DashboardWidgetPortalOutletDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: DashboardWidgetPortalOutletDirective, selector: "[seamDashboardWidgetPortalOutlet]", inputs: { portal: ["seamDashboardWidgetPortalOutlet", "portal"] }, outputs: { attached: "attached" }, exportAs: ["seamDashboardWidgetPortalOutlet"], usesInheritance: true, ngImport: i0 });
542
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetPortalOutletDirective, decorators: [{
543
- type: Directive,
544
- args: [{
545
- selector: '[seamDashboardWidgetPortalOutlet]',
546
- exportAs: 'seamDashboardWidgetPortalOutlet',
547
- inputs: ['portal: seamDashboardWidgetPortalOutlet']
548
- }]
549
- }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }]; }, propDecorators: { attached: [{
550
- type: Output
551
- }] } });
552
-
553
- const THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR = new InjectionToken('ITheSeamDashboardWidgetsPreferencesAccessor');
554
-
555
- // TODO: This needs a unit test to make sure it will not cause a race condition
556
- // if update is called faster than the previous can respond.
557
- //
558
- // The ideal approach I am thinking, without steping through the process too
559
- // thoroughly is to hold the new data emit until all pending updates are done.
560
- // Any pending updates other than the most recently requested will be ignored
561
- // and just wait on the most recent, and if already running it should be
562
- // canceled if possible. Also, incase something happens that causes the new data
563
- // emissions to get held up too long, there could be a threshold time that the
564
- // new data can be held up.
565
- /**
566
- * Manages anything dealing with retrieving and updating dashboard widget
567
- * preference data from the provided accessor.
568
- */
569
- class DashboardWidgetsPreferencesService {
570
- // private _pending = false
571
- // public get pending() { return this._pending }
572
- constructor(_prefsAccessor) {
573
- this._prefsAccessor = _prefsAccessor;
574
- this._tablePrefsMap = new Map();
575
- }
576
- preferences(preferenceKey) {
577
- let prefs = this._tablePrefsMap.get(preferenceKey);
578
- if (!prefs) {
579
- const refreshSubject = new Subject();
580
- prefs = {
581
- observable: this._createObservable(refreshSubject, preferenceKey),
582
- refresh: refreshSubject
583
- };
584
- this._tablePrefsMap.set(preferenceKey, prefs);
585
- }
586
- return prefs.observable;
587
- }
588
- _createObservable(refreshSubject, prefKey) {
589
- if (!this._prefsAccessor) {
590
- return of({});
591
- }
592
- const accessor = (key) => this._prefsAccessor ? this._prefsAccessor.get(key) : of('{}');
593
- return refreshSubject.pipe(startWith({}),
594
- // tap(() => console.log('Start requesting: ', prefKey)),
595
- switchMap(() => accessor(prefKey).pipe(map(v => {
596
- if (!v) {
597
- return null;
598
- }
599
- // TODO: Add a schema validator and migration tool to avoid parsing issues.
600
- try {
601
- return JSON.parse(v);
602
- }
603
- catch (error) {
604
- if (isDevMode()) {
605
- // eslint-disable-next-line no-console
606
- console.error(error);
607
- }
608
- return null;
609
- }
610
- }), map(v => v || {}))), shareReplay({ bufferSize: 1, refCount: true }));
611
- }
612
- refresh(preferenceKey) {
613
- const prefs = this._tablePrefsMap.get(preferenceKey);
614
- if (prefs) {
615
- // this._pending = true
616
- // prefs.refresh.next()
617
- return prefs.observable.pipe(
618
- // tap(() => prefs.refresh.next()),
619
- tap(() => setTimeout(() => { prefs.refresh.next(); }, 0)), mapTo(undefined), take(1));
620
- }
621
- return of(undefined);
622
- }
623
- selectLayout(preferenceKey, layoutName) {
624
- return this.preferences(preferenceKey).pipe(map(prefs => (prefs.layouts || []).find(l => l.name === layoutName)));
625
- }
626
- // TODO: Improve this updating to not be more generic, so we can quickly add
627
- // edits for different preference schema's.
628
- //
629
- // TODO: Decide if a send queue/merging of pending queue is needed to avoid
630
- // out of order updates. This shouldn't be an issue, with how fast preferences
631
- // will most likely be changing, but it could happen in situations, such as
632
- // network issues.
633
- updateLayout(preferenceKey, layout) {
634
- if (!this._prefsAccessor) {
635
- return of(undefined);
636
- }
637
- if (!hasProperty(layout, 'name')) {
638
- throw Error(`Unable to save layout preference. 'name' is required for a layout preference.`);
639
- }
640
- const _layout = this.toSerializeableLayout(layout);
641
- // this._pending = true
642
- return this.preferences(preferenceKey).pipe(map(prefs => {
643
- // Making the preferences immutable may not be necessary, but for now
644
- // this obj->str->obj will work as a naive clone.
645
- const layouts = JSON.parse(JSON.stringify(prefs.layouts || []));
646
- const _layoutPref = layouts.find((c) => c.name === _layout.name);
647
- // console.log('has', _layoutPref)
648
- if (_layoutPref) {
649
- if (hasProperty(_layout, 'name')) {
650
- _layoutPref.name = _layout.name;
651
- }
652
- if (hasProperty(_layout, 'label')) {
653
- _layoutPref.label = _layout.label;
654
- }
655
- if (hasProperty(_layout, 'items')) {
656
- _layoutPref.items = _layout.items;
657
- }
658
- }
659
- else {
660
- layouts.push(Object.assign({}, _layout));
661
- }
662
- const newPrefs = Object.assign(Object.assign({}, prefs), { layouts });
663
- return newPrefs;
664
- }),
665
- // tap(v => console.log('newPrefs', v)),
666
- take(1), switchMap(newPrefs => this._prefsAccessor
667
- ? this._prefsAccessor.update(preferenceKey, JSON.stringify(newPrefs))
668
- : of(newPrefs)), switchMap(() => this.refresh(preferenceKey).pipe(mapTo(undefined))));
669
- // .subscribe()
670
- }
671
- toSerializeableLayout(layout) {
672
- const serialized = {
673
- name: layout.name,
674
- label: layout.label,
675
- items: this.toSerializeableItems(layout.items) || []
676
- };
677
- return serialized;
678
- }
679
- // public toDeserializedLayout(layout: IDashboardWidgetItemLayoutSerialized): IDashboardWidgetItemLayoutDef {
680
- // // For now there is nothing to do. Eventually this should have at least
681
- // // validation on the deserialized object.
682
- // return layout
683
- // }
684
- /**
685
- * Returns the serializable widget items as objects that can be serialized to
686
- * a JSON string for storage.
687
- */
688
- toSerializeableItems(widgets) {
689
- const serialized = [];
690
- for (const w of widgets) {
691
- // if (!w.__itemDef.component || typeof w.__itemDef.component !== 'string') {
692
- // console.warn(`[DashboardWidgetsService] Widget item def must have a string 'component' property to be serialized.`, w)
693
- // continue
694
- // }
695
- // serialized.push({
696
- // widgetId: w.widgetId,
697
- // col: w.col,
698
- // order: w.order,
699
- // component: w.__itemDef.component
700
- // })
701
- // TODO: Remove this, it is only here for initial dev debugging.
702
- serialized.push({
703
- widgetId: w.widgetId,
704
- col: w.col,
705
- order: w.order,
706
- // component: w.__itemDef.component as string
707
- });
708
- }
709
- return serialized;
710
- }
711
- }
712
- DashboardWidgetsPreferencesService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsPreferencesService, deps: [{ token: THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
713
- DashboardWidgetsPreferencesService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsPreferencesService, providedIn: 'root' });
714
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsPreferencesService, decorators: [{
715
- type: Injectable,
716
- args: [{
717
- providedIn: 'root'
718
- }]
719
- }], ctorParameters: function () {
720
- return [{ type: undefined, decorators: [{
721
- type: Optional
722
- }, {
723
- type: Inject,
724
- args: [THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR]
725
- }] }];
726
- } });
727
-
728
- class DashboardWidgetsService {
729
- get widgets() { return this._widgets.value; }
730
- set widgets(value) { this._widgets.next(value); }
731
- get numColumns() { return this._numColumns.value; }
732
- set numColumns(value) {
733
- if (value !== this._numColumns.value) {
734
- this._numColumns.next(value);
735
- }
736
- }
737
- constructor(_dynamicComponentLoaderModule, _preferences) {
738
- this._dynamicComponentLoaderModule = _dynamicComponentLoaderModule;
739
- this._preferences = _preferences;
740
- this.preferenceKey = 'datatable-widgets';
741
- this.defaultNumColumns = 3;
742
- /** Used for operations, such as 'addWidget', if the column is not specified. */
743
- this.defaultColumn = 0;
744
- this._widgets = new BehaviorSubject([]);
745
- this._numColumns = new BehaviorSubject(this.defaultNumColumns);
746
- this._viewContainerRefSubject = new BehaviorSubject(undefined);
747
- this.numColumns$ = this._numColumns.asObservable();
748
- // Widget items without preferences
749
- const _widgetItems$ = combineLatest([this._widgets, this._viewContainerRefSubject])
750
- .pipe(switchMap(([defs, vcr]) => this.createWidgetItems(defs, vcr)));
751
- // Widget items with preferences
752
- this.widgetItems$ = combineLatest([_widgetItems$, this.numColumns$])
753
- .pipe(
754
- // Wait until the current tick is done, incase both the widgets and
755
- // number of columns are set durring the same tick. Without the audit,
756
- // this would get called twice when the component is initialized with
757
- // both inputs set one after the other individually.
758
- 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 }));
759
- this.widgetColumns$ = this.widgetItems$
760
- .pipe(map(items => this.toColumnRecords(items)), shareReplay({ bufferSize: 1, refCount: true }));
761
- }
762
- _layoutName(numColumns) {
763
- return `columns-${numColumns}`;
764
- }
765
- setViewContainerRef(vcr) {
766
- this._viewContainerRefSubject.next(vcr);
767
- }
768
- createWidgetItems(defs, vcr) {
769
- const _createObservables = (defs || []).map(d => this.createWidgetItem(d, vcr));
770
- const items$ = _createObservables.length > 0 ? combineLatest(_createObservables) : of([]);
771
- return items$.pipe(map(items => items.filter(notNullOrUndefined)), tap(items => {
772
- if (isDevMode()) {
773
- const ids = items.map(v => v.widgetId);
774
- if ((new Set(ids)).size !== ids.length) {
775
- // eslint-disable-next-line no-console
776
- console.warn(`[DashboardWidgetsService] Duplicate widget's with the same 'widgetId' found.`);
777
- }
778
- }
779
- }));
780
- }
781
- createWidgetItem(def, vcr) {
782
- if (!def.widgetId || typeof def.widgetId !== 'string' || def.widgetId.length < 1) {
783
- if (isDevMode()) {
784
- // eslint-disable-next-line no-console
785
- console.warn(`[DashboardWidgetsService] Widget ignored. All widgets must have a 'widgetId'.`, def);
786
- }
787
- return of(undefined);
788
- }
789
- 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 }))));
790
- }
791
- createWidgetPortal(def, vcr) {
792
- var _a;
793
- const injector = Injector.create({ providers: [
794
- { provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }
795
- ], parent: (_a = this._viewContainerRefSubject.value) === null || _a === void 0 ? void 0 : _a.injector });
796
- // TODO: I still use the ViewContainerRef injector, but I don't pass it to
797
- // the portal, because it throws an error and I am not sure why. I would
798
- // like to find out why, even though I don't think it is needed, because our
799
- // code has been leaving it undefined for a while, when I thought it was
800
- // being used.
801
- if (typeof def.component === 'string') {
802
- return this._dynamicComponentLoaderModule
803
- .getComponentFactory(def.component)
804
- .pipe(map(componentFactory => {
805
- return new ComponentPortal(componentFactory.componentType, undefined, injector, componentFactory /* ComponentFactoryBoundToModule */.ngModule.componentFactoryResolver);
806
- }), take(1));
807
- }
808
- return def.componentFactoryResolver
809
- ? of(new ComponentPortal(def.component, undefined, injector, def.componentFactoryResolver))
810
- : of(new ComponentPortal(def.component, undefined, injector));
811
- }
812
- updateOrder() {
813
- return this.widgetColumns$
814
- .pipe(take(1), tap(columns => columns.forEach(col => {
815
- let i = 0;
816
- col.items.forEach(itm => itm.order = i++);
817
- })), mapTo(undefined));
818
- }
819
- toColumnRecords(items) {
820
- let columns = [];
821
- for (let i = 0; i < this.numColumns; i++) {
822
- columns.push({ column: i, items: [] });
823
- }
824
- const colNotFound = [];
825
- // Distribute items into columns
826
- for (const item of items) {
827
- const col = columns.find(c => c.column === item.col);
828
- if (!col) {
829
- // columns.push({ column: item.col, items: [ item ] })
830
- // if (item.col < 0) {
831
- // const col0: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === 0)
832
- // if (col0) {
833
- // col0.items.push(item)
834
- // }
835
- // } else if (item.col > this.numColumns - 1) {
836
- // const colMax: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === this.numColumns - 1)
837
- // if (colMax) {
838
- // colMax.items.push(item)
839
- // }
840
- // }
841
- colNotFound.push(item);
842
- }
843
- else {
844
- col.items.push(item);
845
- }
846
- }
847
- for (let i = 0; i < colNotFound.length; i++) {
848
- const item = colNotFound[i];
849
- const col = columns
850
- .find(c => c.column === i % this.numColumns);
851
- if (col) {
852
- col.items.push(item);
853
- }
854
- }
855
- // Sort columns
856
- columns = columns.sort((a, b) => a.column - b.column);
857
- // Sort columns items
858
- columns.forEach(col => col.items.sort((a, b) => a.order - b.order));
859
- return columns;
860
- }
861
- withLayoutPreferences(items, layout) {
862
- const _items = [];
863
- for (const item of items) {
864
- const itemPref = layout.items.find(x => x.widgetId === item.widgetId);
865
- _items.push(Object.assign(Object.assign({}, item), (itemPref || {})));
866
- }
867
- return _items;
868
- }
869
- savePreferences() {
870
- // Right now the items are moved between the column record arrays, but the
871
- // 'col' prop is not updated, so it is mapped to corrected items here from
872
- // the column records.
873
- const items$ = this.widgetColumns$.pipe(map(columns => []
874
- .concat(...(columns.map(c => c.items.map(itm => (Object.assign(Object.assign({}, itm), { col: c.column }))))))));
875
- return combineLatest([items$, this.numColumns$]).pipe(auditTime(0), take(1), switchMap(([items, numColumns]) => {
876
- return this._preferences.updateLayout(this.preferenceKey, {
877
- name: this._layoutName(numColumns),
878
- items
879
- });
880
- }), mapTo(undefined));
881
- }
882
- }
883
- DashboardWidgetsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsService, deps: [{ token: i1$1.TheSeamDynamicComponentLoader }, { token: DashboardWidgetsPreferencesService }], target: i0.ɵɵFactoryTarget.Injectable });
884
- DashboardWidgetsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsService, providedIn: 'root' });
885
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsService, decorators: [{
886
- type: Injectable,
887
- args: [{
888
- providedIn: 'root'
889
- }]
890
- }], ctorParameters: function () { return [{ type: i1$1.TheSeamDynamicComponentLoader }, { type: DashboardWidgetsPreferencesService }]; } });
891
-
892
- class DashboardWidgetsComponent {
893
- get gapSize() { return this._gapSize.value; }
894
- set gapSize(val) {
895
- this._gapSize.next(coerceNumberProperty(val));
896
- }
897
- get dragToggleVisible() { return this._dragToggleVisible.value; }
898
- set dragToggleVisible(val) {
899
- this._dragToggleVisible.next(coerceBooleanProperty(val));
900
- }
901
- get numColumns() { return this._dashboardWidgets.numColumns; }
902
- set numColumns(val) {
903
- this._dashboardWidgets.numColumns = coerceNumberProperty(val);
904
- }
905
- set widgets(value) { this._dashboardWidgets.widgets = value || []; }
906
- get widgets() { return this._dashboardWidgets.widgets; }
907
- constructor(_dashboardWidgets, _viewContainerRef, _cdr, _baseLayoutRef) {
908
- this._dashboardWidgets = _dashboardWidgets;
909
- this._viewContainerRef = _viewContainerRef;
910
- this._cdr = _cdr;
911
- this._baseLayoutRef = _baseLayoutRef;
912
- this.faLock = faLock;
913
- this.faUnlock = faUnlock;
914
- this._actionWidgetDragToggleName = 'widget-drag-toggle';
915
- this._ngUnsubscribe = new Subject();
916
- this._gapSize = new BehaviorSubject(30);
917
- this.widgetsDraggable = false;
918
- this._dragToggleVisible = new BehaviorSubject(true);
919
- this._containers = new BehaviorSubject([]);
920
- this._layoutChange = new Subject();
921
- this.widgetsChange = new EventEmitter();
922
- this._widthChange = new Subject();
923
- this._dashboardWidgets.setViewContainerRef(this._viewContainerRef);
924
- this.containers$ = this._containers.asObservable();
925
- this._gapStyleSize$ = this._gapSize.pipe(auditTime(0), map(size => size / 2), shareReplay({ bufferSize: 1, refCount: true }));
926
- this._widthChange.pipe(debounceTime(30), tap(width => {
927
- if (width > 1300) {
928
- this.numColumns = 3;
929
- }
930
- else if (width > 800) {
931
- this.numColumns = 2;
932
- }
933
- else {
934
- this.numColumns = 1;
935
- }
936
- }), takeUntil(this._ngUnsubscribe)).subscribe();
937
- this.widgetItems$ = this._dashboardWidgets.widgetItems$;
938
- this.widgetColumns$ = this._dashboardWidgets.widgetColumns$;
939
- }
940
- ngOnInit() {
941
- // this._dashboardWidgets.setViewContainerRef(this._viewContainerRef)
942
- this._layoutChange.pipe(switchMap(() => this.widgetItems$.pipe(take(1), tap(widgetItems => this.widgetsChange.emit(widgetItems)),
943
- // map(widgetItems => this._dashboardWidgets.toSerializeableItems(widgetItems)),
944
- // tap(v => console.log('serializable', v)),
945
- switchMap(() => this._dashboardWidgets.savePreferences()))), takeUntil(this._ngUnsubscribe)).subscribe();
946
- }
947
- ngOnDestroy() {
948
- this._unregisterToggleAction();
949
- this._ngUnsubscribe.next(undefined);
950
- this._ngUnsubscribe.complete();
951
- }
952
- ngAfterViewInit() {
953
- var _a;
954
- if (this._baseLayoutRef) {
955
- this._dragToggleVisible.pipe(distinctUntilChanged(), tap(visible => {
956
- const isRegistered = this._isActionToggleActionRegistered();
957
- if (visible && !isRegistered) {
958
- this._registerToggleAction();
959
- }
960
- else if (!visible && isRegistered) {
961
- this._unregisterToggleAction();
962
- }
963
- }), takeUntil(this._ngUnsubscribe)).subscribe();
964
- }
965
- (_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));
966
- }
967
- _registerToggleAction() {
968
- if (this._baseLayoutRef) {
969
- // This should probably use a component dynamically created from the
970
- // config and return a ref to it, instead of using a template.
971
- if (this._toggleBtnTpl) {
972
- this._baseLayoutRef.registerAction({
973
- // type: 'button',
974
- type: 'template',
975
- name: this._actionWidgetDragToggleName,
976
- label: 'Toggle Widget Dragging',
977
- // exec: () => {
978
- // console.log('toggle')
979
- // },
980
- template: this._toggleBtnTpl
981
- });
982
- }
983
- }
984
- }
985
- _unregisterToggleAction() {
986
- if (this._baseLayoutRef) {
987
- this._baseLayoutRef.unregisterAction(this._actionWidgetDragToggleName);
988
- }
989
- }
990
- _isActionToggleActionRegistered() {
991
- if (!this._baseLayoutRef) {
992
- return false;
993
- }
994
- return this._baseLayoutRef.isActionRegistered(this._actionWidgetDragToggleName);
995
- }
996
- drop(event) {
997
- if (event.previousContainer === event.container) {
998
- moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
999
- this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next());
1000
- }
1001
- else {
1002
- transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);
1003
- this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next());
1004
- }
1005
- }
1006
- _containerTrackByFn(index, item) {
1007
- return item.widgetId;
1008
- }
1009
- _columnsTrackByFn(index, record) {
1010
- return record.column;
1011
- }
1012
- toggleDragging() {
1013
- this.widgetsDraggable = !this.widgetsDraggable;
1014
- this._cdr.detectChanges();
1015
- }
1016
- _resized(event) {
1017
- this._widthChange.next(event.size.width);
1018
- }
1019
- }
1020
- DashboardWidgetsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsComponent, deps: [{ token: DashboardWidgetsService }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: THESEAM_BASE_LAYOUT_REF, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1021
- DashboardWidgetsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DashboardWidgetsComponent, selector: "seam-dashboard-widgets", inputs: { gapSize: "gapSize", widgetsDraggable: "widgetsDraggable", dragToggleVisible: "dragToggleVisible", numColumns: "numColumns", widgets: "widgets" }, outputs: { widgetsChange: "widgetsChange" }, providers: [
1022
- {
1023
- provide: THESEAM_WIDGET_ACCESSOR,
1024
- // tslint:disable-next-line:no-use-before-declare
1025
- useExisting: forwardRef(() => DashboardWidgetsComponent)
1026
- },
1027
- {
1028
- provide: THESEAM_DASHBOARD_WIDGETS_ACCESSOR,
1029
- // tslint:disable-next-line:no-use-before-declare
1030
- useExisting: forwardRef(() => DashboardWidgetsComponent)
1031
- },
1032
- ], 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.TheSeamButtonComponent, 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 });
1033
- __decorate([
1034
- InputBoolean()
1035
- ], DashboardWidgetsComponent.prototype, "widgetsDraggable", void 0);
1036
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetsComponent, decorators: [{
1037
- type: Component,
1038
- args: [{ selector: 'seam-dashboard-widgets', providers: [
1039
- {
1040
- provide: THESEAM_WIDGET_ACCESSOR,
1041
- // tslint:disable-next-line:no-use-before-declare
1042
- useExisting: forwardRef(() => DashboardWidgetsComponent)
1043
- },
1044
- {
1045
- provide: THESEAM_DASHBOARD_WIDGETS_ACCESSOR,
1046
- // tslint:disable-next-line:no-use-before-declare
1047
- useExisting: forwardRef(() => DashboardWidgetsComponent)
1048
- },
1049
- ], 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"] }]
1050
- }], ctorParameters: function () {
1051
- return [{ type: DashboardWidgetsService }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
1052
- type: Optional
1053
- }, {
1054
- type: Inject,
1055
- args: [THESEAM_BASE_LAYOUT_REF]
1056
- }] }];
1057
- }, propDecorators: { gapSize: [{
1058
- type: Input
1059
- }], widgetsDraggable: [{
1060
- type: Input
1061
- }], dragToggleVisible: [{
1062
- type: Input
1063
- }], numColumns: [{
1064
- type: Input
1065
- }], widgets: [{
1066
- type: Input
1067
- }], containers: [{
1068
- type: ViewChildren,
1069
- args: [DashboardWidgetContainerComponent]
1070
- }], cdkDragDirectives: [{
1071
- type: ViewChildren,
1072
- args: [CdkDrag]
1073
- }], _toggleBtnTpl: [{
1074
- type: ViewChild,
1075
- args: ['toggleBtnTpl', { static: true }]
1076
- }], widgetsChange: [{
1077
- type: Output
1078
- }] } });
1079
-
1080
- class DashboardComponent {
1081
- constructor() {
1082
- this.widgetsDraggable = true;
1083
- }
1084
- }
1085
- DashboardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1086
- DashboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
1087
- __decorate([
1088
- InputBoolean()
1089
- ], DashboardComponent.prototype, "widgetsDraggable", void 0);
1090
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, decorators: [{
1091
- type: Component,
1092
- args: [{ selector: 'seam-dashboard', changeDetection: ChangeDetectionStrategy.OnPush, template: "<seam-dashboard-widgets [widgets]=\"widgets\" [widgetsDraggable]=\"widgetsDraggable\"></seam-dashboard-widgets>\n" }]
1093
- }], propDecorators: { widgets: [{
1094
- type: Input
1095
- }], widgetsDraggable: [{
1096
- type: Input
1097
- }] } });
1098
-
1099
- class TheSeamDashboardModule {
1100
- }
1101
- TheSeamDashboardModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDashboardModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1102
- TheSeamDashboardModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDashboardModule, declarations: [DashboardComponent,
1103
- DashboardWidgetsComponent,
1104
- DashboardWidgetContainerComponent,
1105
- DashboardWidgetTemplateContainerComponent,
1106
- DashboardWidgetPortalOutletDirective], imports: [CommonModule,
1107
- PortalModule,
1108
- DragDropModule,
1109
- TheSeamButtonsModule,
1110
- TheSeamIconModule,
1111
- TheSeamSharedModule], exports: [DashboardComponent,
1112
- DashboardWidgetsComponent,
1113
- DashboardWidgetPortalOutletDirective] });
1114
- TheSeamDashboardModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDashboardModule, imports: [CommonModule,
1115
- PortalModule,
1116
- DragDropModule,
1117
- TheSeamButtonsModule,
1118
- TheSeamIconModule,
1119
- TheSeamSharedModule] });
1120
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDashboardModule, decorators: [{
1121
- type: NgModule,
1122
- args: [{
1123
- declarations: [
1124
- DashboardComponent,
1125
- DashboardWidgetsComponent,
1126
- DashboardWidgetContainerComponent,
1127
- DashboardWidgetTemplateContainerComponent,
1128
- DashboardWidgetPortalOutletDirective
1129
- ],
1130
- imports: [
1131
- CommonModule,
1132
- PortalModule,
1133
- DragDropModule,
1134
- TheSeamButtonsModule,
1135
- TheSeamIconModule,
1136
- TheSeamSharedModule
1137
- ],
1138
- exports: [
1139
- DashboardComponent,
1140
- DashboardWidgetsComponent,
1141
- DashboardWidgetPortalOutletDirective
1142
- ]
1143
- }]
1144
- }] });
1145
-
1146
- const THESEAM_SIDE_NAV_ACCESSOR = new InjectionToken('THESEAM_SIDE_NAV_ACCESSOR');
1147
- const THESEAM_SIDE_NAV_CONFIG = new InjectionToken('THESEAM_SIDE_NAV_CONFIG');
1148
- const DEFAULT_SIDE_NAV_CONFIG = {
1149
- activeNavigatable: false
1150
- };
1151
-
1152
- const EXPANDED_STATE$1 = 'expanded';
1153
- const COLLAPSED_STATE$1 = 'collapsed';
1154
- class SideNavItemComponent {
1155
- set link(value) { this._link.next(value); }
1156
- get link() { return this._link.value; }
1157
- set expanded(value) { this._expanded.next(coerceBooleanProperty(value)); }
1158
- get expanded() { return this._expanded.value; }
1159
- set compact(value) { this._compact.next(coerceBooleanProperty(value)); }
1160
- get compact() { return this._compact.value; }
1161
- get badgeTooltip() { return this._badgeTooltip; }
1162
- set badgeTooltip(value) {
1163
- if (value !== null && value !== undefined) {
1164
- if (typeof value === 'string') {
1165
- this._badgeTooltip = {
1166
- tooltip: value,
1167
- placement: 'auto',
1168
- container: 'body',
1169
- disabled: false
1170
- };
1171
- }
1172
- else {
1173
- this._badgeTooltip = Object.assign(Object.assign({}, value), { placement: value.placement || 'auto', container: value.container || 'body', disabled: typeof (value === null || value === void 0 ? void 0 : value.disabled) === 'boolean'
1174
- ? value.disabled
1175
- : typeof value.tooltip === 'string' });
1176
- }
1177
- }
1178
- else {
1179
- this._badgeTooltip = undefined;
1180
- }
1181
- }
1182
- get _isActiveCssClass() { return this.active; }
1183
- get _isClickableWhenActiveCssClass() { return this.activeNavigatable; }
1184
- get _attrDataHierLevel() { return this.hierLevel; }
1185
- constructor(_sideNav) {
1186
- this._sideNav = _sideNav;
1187
- this._ngUnsubscribe = new Subject();
1188
- this.faAngleLeft = faAngleLeft;
1189
- this._linkHistoryState = { seamReload: true, triggeredByNavBar: true };
1190
- this.active = false;
1191
- this.activeNavigatable = false;
1192
- this._link = new BehaviorSubject(undefined);
1193
- this.link$ = this._link.asObservable();
1194
- this.hierLevel = 0;
1195
- this.indentSize = 10;
1196
- this._expanded = new BehaviorSubject(false);
1197
- this.expanded$ = this._expanded.asObservable();
1198
- this._compact = new BehaviorSubject(false);
1199
- this.compact$ = this._compact.asObservable();
1200
- this.badgeTheme = 'danger';
1201
- this.childGroupAnimState$ = this.expanded$
1202
- .pipe(map$1(expanded => expanded ? EXPANDED_STATE$1 : COLLAPSED_STATE$1));
1203
- }
1204
- ngOnDestroy() {
1205
- this._ngUnsubscribe.next(undefined);
1206
- this._ngUnsubscribe.complete();
1207
- }
1208
- get hasChildren() {
1209
- return Array.isArray(this.children) && this.children.length > 0;
1210
- }
1211
- toggleChildren() {
1212
- this.expanded = !this.expanded;
1213
- }
1214
- _linkClicked() {
1215
- // Close nav when link is clicked while in overlay state
1216
- if (this._sideNav.overlay) {
1217
- this._sideNav.collapse();
1218
- }
1219
- }
1220
- get showIconBlock() {
1221
- return notNullOrUndefined(this.icon) || this.hideEmptyIcon !== true;
1222
- }
1223
- }
1224
- SideNavItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SideNavItemComponent, deps: [{ token: THESEAM_SIDE_NAV_ACCESSOR }], target: i0.ɵɵFactoryTarget.Component });
1225
- SideNavItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SideNavItemComponent, isStandalone: true, selector: "seam-side-nav-item", inputs: { itemType: "itemType", icon: "icon", hideEmptyIcon: "hideEmptyIcon", label: "label", active: "active", activeNavigatable: "activeNavigatable", link: "link", queryParams: "queryParams", children: "children", hierLevel: "hierLevel", indentSize: "indentSize", expanded: "expanded", compact: "compact", isMobile: "isMobile", badgeText: "badgeText", badgeTheme: "badgeTheme", badgeSrContent: "badgeSrContent", badgeTooltip: "badgeTooltip", menuItemTooltipConfig: "menuItemTooltipConfig", menuItemTooltipDisabled: "menuItemTooltipDisabled" }, host: { properties: { "class.seam-side-nav-item--active": "this._isActiveCssClass", "class.active-clickable": "this._isClickableWhenActiveCssClass", "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 [isMobile]=\"isMobile\"\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 [menuItemTooltipConfig]=\"menuItemTooltipConfig\"\n [menuItemTooltipDisabled]=\"menuItemTooltipDisabled\"\n [activeNavigatable]=\"$any(child).activeNavigatable\">\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 [ngbTooltip]=\"label\"\n [tooltipClass]=\"$any(menuItemTooltipConfig)?.class\"\n [placement]=\"$any(menuItemTooltipConfig)?.placement\"\n [container]=\"$any(menuItemTooltipConfig)?.container\"\n [disableTooltip]=\"$any(menuItemTooltipDisabled)\"\n [class.active-clickable]=\"activeNavigatable\">\n <div class=\"nav-link d-flex flex-row 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 <div class=\"d-flex flex-row w-100\"\n [ngbTooltip]=\"label\"\n [tooltipClass]=\"$any(menuItemTooltipConfig)?.class\"\n [placement]=\"$any(menuItemTooltipConfig)?.placement\"\n [container]=\"$any(menuItemTooltipConfig)?.container\"\n [disableTooltip]=\"$any(menuItemTooltipDisabled)\">\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 [state]=\"_linkHistoryState\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n (click)=\"_linkClicked()\"\n [class.active-clickable]=\"activeNavigatable\">\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\"\n [class.nav-link__compact]=\"compact\"\n [ngbTooltip]=\"label\"\n [tooltipClass]=\"$any(menuItemTooltipConfig)?.class\"\n [placement]=\"$any(menuItemTooltipConfig)?.placement\"\n [container]=\"$any(menuItemTooltipConfig)?.container\"\n [disableTooltip]=\"$any(menuItemTooltipDisabled)\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\">\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 </div>\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]=\"isMobile || !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:not(.active-clickable){pointer-events:none;cursor:default}seam-side-nav-item .side-nav-item.active:not(.active-clickable) .side-nav-item--badge{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 .side-nav-btn:disabled .side-nav-item--badge,seam-side-nav-item .side-nav-btn.disabled .side-nav-item--badge{pointer-events:none;cursor:default}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", "activeNavigatable", "link", "queryParams", "children", "hierLevel", "indentSize", "expanded", "compact", "isMobile", "badgeText", "badgeTheme", "badgeSrContent", "badgeTooltip", "menuItemTooltipConfig", "menuItemTooltipDisabled"], 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: [
1226
- trigger('childGroupAnim', [
1227
- state(EXPANDED_STATE$1, style({ height: '*' })),
1228
- state(COLLAPSED_STATE$1, style({ height: 0, visibility: 'hidden' })),
1229
- transition(`${EXPANDED_STATE$1} <=> ${COLLAPSED_STATE$1}`, animate('0.2s ease-in-out')),
1230
- ]),
1231
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1232
- __decorate([
1233
- InputBoolean()
1234
- ], SideNavItemComponent.prototype, "active", void 0);
1235
- __decorate([
1236
- InputBoolean()
1237
- ], SideNavItemComponent.prototype, "activeNavigatable", void 0);
1238
- __decorate([
1239
- InputNumber(0)
1240
- ], SideNavItemComponent.prototype, "hierLevel", void 0);
1241
- __decorate([
1242
- InputNumber(10)
1243
- ], SideNavItemComponent.prototype, "indentSize", void 0);
1244
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SideNavItemComponent, decorators: [{
1245
- type: Component,
1246
- args: [{ selector: 'seam-side-nav-item', exportAs: 'seamSideNavItem', animations: [
1247
- trigger('childGroupAnim', [
1248
- state(EXPANDED_STATE$1, style({ height: '*' })),
1249
- state(COLLAPSED_STATE$1, style({ height: 0, visibility: 'hidden' })),
1250
- transition(`${EXPANDED_STATE$1} <=> ${COLLAPSED_STATE$1}`, animate('0.2s ease-in-out')),
1251
- ]),
1252
- ], imports: [
1253
- CommonModule,
1254
- RouterModule,
1255
- TheSeamIconModule,
1256
- A11yModule,
1257
- NgbTooltipModule,
1258
- ], 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 [isMobile]=\"isMobile\"\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 [menuItemTooltipConfig]=\"menuItemTooltipConfig\"\n [menuItemTooltipDisabled]=\"menuItemTooltipDisabled\"\n [activeNavigatable]=\"$any(child).activeNavigatable\">\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 [ngbTooltip]=\"label\"\n [tooltipClass]=\"$any(menuItemTooltipConfig)?.class\"\n [placement]=\"$any(menuItemTooltipConfig)?.placement\"\n [container]=\"$any(menuItemTooltipConfig)?.container\"\n [disableTooltip]=\"$any(menuItemTooltipDisabled)\"\n [class.active-clickable]=\"activeNavigatable\">\n <div class=\"nav-link d-flex flex-row 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 <div class=\"d-flex flex-row w-100\"\n [ngbTooltip]=\"label\"\n [tooltipClass]=\"$any(menuItemTooltipConfig)?.class\"\n [placement]=\"$any(menuItemTooltipConfig)?.placement\"\n [container]=\"$any(menuItemTooltipConfig)?.container\"\n [disableTooltip]=\"$any(menuItemTooltipDisabled)\">\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 [state]=\"_linkHistoryState\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n (click)=\"_linkClicked()\"\n [class.active-clickable]=\"activeNavigatable\">\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\"\n [class.nav-link__compact]=\"compact\"\n [ngbTooltip]=\"label\"\n [tooltipClass]=\"$any(menuItemTooltipConfig)?.class\"\n [placement]=\"$any(menuItemTooltipConfig)?.placement\"\n [container]=\"$any(menuItemTooltipConfig)?.container\"\n [disableTooltip]=\"$any(menuItemTooltipDisabled)\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\">\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 </div>\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]=\"isMobile || !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:not(.active-clickable){pointer-events:none;cursor:default}seam-side-nav-item .side-nav-item.active:not(.active-clickable) .side-nav-item--badge{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 .side-nav-btn:disabled .side-nav-item--badge,seam-side-nav-item .side-nav-btn.disabled .side-nav-item--badge{pointer-events:none;cursor:default}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"] }]
1259
- }], ctorParameters: function () {
1260
- return [{ type: undefined, decorators: [{
1261
- type: Inject,
1262
- args: [THESEAM_SIDE_NAV_ACCESSOR]
1263
- }] }];
1264
- }, propDecorators: { itemType: [{
1265
- type: Input
1266
- }], icon: [{
1267
- type: Input
1268
- }], hideEmptyIcon: [{
1269
- type: Input
1270
- }], label: [{
1271
- type: Input
1272
- }], active: [{
1273
- type: Input
1274
- }], activeNavigatable: [{
1275
- type: Input
1276
- }], link: [{
1277
- type: Input
1278
- }], queryParams: [{
1279
- type: Input
1280
- }], children: [{
1281
- type: Input
1282
- }], hierLevel: [{
1283
- type: Input
1284
- }], indentSize: [{
1285
- type: Input
1286
- }], expanded: [{
1287
- type: Input
1288
- }], compact: [{
1289
- type: Input
1290
- }], isMobile: [{
1291
- type: Input
1292
- }], badgeText: [{
1293
- type: Input
1294
- }], badgeTheme: [{
1295
- type: Input
1296
- }], badgeSrContent: [{
1297
- type: Input
1298
- }], badgeTooltip: [{
1299
- type: Input
1300
- }], menuItemTooltipConfig: [{
1301
- type: Input
1302
- }], menuItemTooltipDisabled: [{
1303
- type: Input
1304
- }], _isActiveCssClass: [{
1305
- type: HostBinding,
1306
- args: ['class.seam-side-nav-item--active']
1307
- }], _isClickableWhenActiveCssClass: [{
1308
- type: HostBinding,
1309
- args: ['class.active-clickable']
1310
- }], _attrDataHierLevel: [{
1311
- type: HostBinding,
1312
- args: ['attr.data-hier-level']
1313
- }] } });
1314
-
1315
- class SideNavToggleComponent {
1316
- constructor() {
1317
- this.expanded = false;
1318
- this.toggleExpand = new EventEmitter();
1319
- }
1320
- toggle() {
1321
- this.toggleExpand.emit();
1322
- }
1323
- }
1324
- SideNavToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SideNavToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1325
- SideNavToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
1326
- __decorate([
1327
- InputBoolean()
1328
- ], SideNavToggleComponent.prototype, "expanded", void 0);
1329
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SideNavToggleComponent, decorators: [{
1330
- type: Component,
1331
- args: [{ selector: 'seam-side-nav-toggle', host: {
1332
- '[class.side-nav-toggle--compact]': '!expanded'
1333
- }, imports: [
1334
- CommonModule,
1335
- TheSeamIconModule,
1336
- ], 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"] }]
1337
- }], propDecorators: { expanded: [{
1338
- type: Input
1339
- }], toggleIcon: [{
1340
- type: Input
1341
- }], toggleTpl: [{
1342
- type: Input
1343
- }], toggleExpand: [{
1344
- type: Output
1345
- }] } });
1346
-
1347
- function isNavItemType(item, type) {
1348
- return item.itemType === type;
1349
- }
1350
- function isNavItemActive(item) {
1351
- var _a, _b;
1352
- return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.active) !== null && _b !== void 0 ? _b : false;
1353
- }
1354
- function isExpanded(item) {
1355
- var _a, _b;
1356
- return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.expanded) !== null && _b !== void 0 ? _b : false;
1357
- }
1358
- function hasChildren(item) {
1359
- return canHaveChildren(item) && hasProperty(item, 'children') && item.children.length > 0;
1360
- }
1361
- function canHaveChildren(item) {
1362
- return isNavItemType(item, 'basic') || isNavItemType(item, 'link');
1363
- }
1364
- function hasActiveChild(item) {
1365
- if (!hasChildren(item)) {
1366
- return false;
1367
- }
1368
- for (const child of item.children) {
1369
- if (getItemStateProp(child, 'active')) {
1370
- return true;
1371
- }
1372
- }
1373
- return false;
1374
- }
1375
- function hasExpandedChild(item) {
1376
- if (!hasChildren(item)) {
1377
- return false;
1378
- }
1379
- for (const child of item.children) {
1380
- if (getItemStateProp(child, 'expanded')) {
1381
- return true;
1382
- }
1383
- }
1384
- return false;
1385
- }
1386
- function canBeActive(item) {
1387
- return isNavItemType(item, 'button') || isNavItemType(item, 'link');
1388
- }
1389
- function canExpand(item) {
1390
- return canHaveChildren(item);
1391
- }
1392
- function findLinkItems(items) {
1393
- const linkItems = [];
1394
- const _fn = (_items) => {
1395
- for (const item of _items) {
1396
- if (isNavItemType(item, 'link')) {
1397
- linkItems.push(item);
1398
- }
1399
- if (canHaveChildren(item) && hasProperty(item, 'children')) {
1400
- _fn(item.children);
1401
- }
1402
- }
1403
- };
1404
- _fn(items);
1405
- return linkItems;
1406
- }
1407
- function setItemStateProp(item, prop, value) {
1408
- if (hasProperty(item, '__state')) {
1409
- item.__state[prop] = value;
1410
- }
1411
- }
1412
- function getItemStateProp(item, prop) {
1413
- return setDefaultState(item).__state[prop];
1414
- }
1415
- function setDefaultState(item) {
1416
- if (hasProperty(item, '__state')) {
1417
- return item;
1418
- }
1419
- item.__state = {
1420
- active: false,
1421
- expanded: false
1422
- };
1423
- // TODO: See if there is a nice way to fix the typing for this.
1424
- return item;
1425
- }
1426
- function applyItemConfig(item, config) {
1427
- if (canBeActive(item)) {
1428
- if (!hasProperty(item, 'activeNavigatable') && hasProperty(config, 'activeNavigatable')) {
1429
- item.activeNavigatable = config.activeNavigatable;
1430
- }
1431
- }
1432
- if (hasChildren(item)) {
1433
- item.children = item.children.map(child => applyItemConfig(child, config));
1434
- }
1435
- return item;
1436
- }
1437
-
1438
- class TheSeamSideNavService {
1439
- constructor(_router) {
1440
- this._router = _router;
1441
- this._updatingCount = new BehaviorSubject(0);
1442
- this.itemChanged = new Subject();
1443
- this.loading$ = this._updatingCount.pipe(map(count => count > 0), distinctUntilChanged(), shareReplay({ bufferSize: 1, refCount: true }));
1444
- }
1445
- createItemsObservable(items) {
1446
- return defer(() => {
1447
- this.updateItemsStates(items);
1448
- return new Observable((subscriber) => {
1449
- const stateChangeSub = this.itemChanged.pipe(switchMap(() => this.loading$.pipe(filter(loading => !loading)))).subscribe(() => {
1450
- subscriber.next(items);
1451
- });
1452
- try {
1453
- this.updateItemsStates(items);
1454
- }
1455
- catch (err) {
1456
- subscriber.error(err);
1457
- }
1458
- // const linkItems = findLinkItems(items)
1459
- const routeChangeSub = this._router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(() => {
1460
- try {
1461
- this.updateItemsStates(items);
1462
- }
1463
- catch (err) {
1464
- subscriber.error(err);
1465
- }
1466
- });
1467
- return () => {
1468
- stateChangeSub.unsubscribe();
1469
- routeChangeSub.unsubscribe();
1470
- };
1471
- }).pipe(startWith(items));
1472
- });
1473
- }
1474
- _incUpdatingCount() {
1475
- this._updatingCount.next(this._updatingCount.value + 1);
1476
- }
1477
- _decrUpdatingCount() {
1478
- this._updatingCount.next(this._updatingCount.value - 1);
1479
- }
1480
- updateItemsStates(items) {
1481
- this._incUpdatingCount();
1482
- try {
1483
- for (const item of items) {
1484
- if (hasChildren(item)) {
1485
- this.updateItemsStates(item.children);
1486
- }
1487
- this.updateItemState(item);
1488
- }
1489
- this._decrUpdatingCount();
1490
- }
1491
- catch (err) {
1492
- this._decrUpdatingCount();
1493
- throw err;
1494
- }
1495
- }
1496
- updateItemState(item) {
1497
- this._incUpdatingCount();
1498
- try {
1499
- setDefaultState(item);
1500
- if (isNavItemType(item, 'link')) {
1501
- const url = this._getUrl(item);
1502
- if (notNullOrUndefined(url)) {
1503
- const opts = this._getMatchOptions(item);
1504
- this.setItemStateProp(item, 'active', this._router.isActive(url, opts));
1505
- }
1506
- }
1507
- // TODO: Implement this in a more optimized way. Unless our apps start
1508
- // having large side-navs constantly updating their state, this shouldn't
1509
- // have much impact on performance.
1510
- this._updateItemExpandedState(item);
1511
- this._decrUpdatingCount();
1512
- }
1513
- catch (err) {
1514
- this._decrUpdatingCount();
1515
- throw err;
1516
- }
1517
- }
1518
- _updateItemsExpandedState(items) {
1519
- for (const item of items) {
1520
- if (hasChildren(item)) {
1521
- this._updateItemsExpandedState(item.children);
1522
- }
1523
- this._updateItemExpandedState(item);
1524
- }
1525
- }
1526
- _updateItemExpandedState(item) {
1527
- if (!canExpand(item)) {
1528
- if (getItemStateProp(item, 'expanded')) {
1529
- this.setItemStateProp(item, 'expanded', false);
1530
- }
1531
- return;
1532
- }
1533
- if (hasChildren(item)) {
1534
- this._updateItemsExpandedState(item.children);
1535
- }
1536
- if (hasActiveChild(item) || hasExpandedChild(item)) {
1537
- if (!getItemStateProp(item, 'expanded')) {
1538
- this.setItemStateProp(item, 'expanded', true);
1539
- }
1540
- }
1541
- else {
1542
- if (getItemStateProp(item, 'expanded')) {
1543
- this.setItemStateProp(item, 'expanded', false);
1544
- }
1545
- }
1546
- }
1547
- _getNavExtras(item) {
1548
- const navigationExtras = {};
1549
- if (hasProperty(item, 'queryParams')) {
1550
- navigationExtras.queryParams = item.queryParams;
1551
- }
1552
- if (hasProperty(item, 'fragment')) {
1553
- navigationExtras.fragment = item.fragment;
1554
- }
1555
- if (hasProperty(item, 'queryParamsHandling')) {
1556
- navigationExtras.queryParamsHandling = item.queryParamsHandling;
1557
- }
1558
- if (hasProperty(item, 'preserveFragment')) {
1559
- navigationExtras.preserveFragment = item.preserveFragment;
1560
- }
1561
- return navigationExtras;
1562
- }
1563
- _getUrl(item) {
1564
- const link = item.link;
1565
- if (typeof link === 'string') {
1566
- return this._router.createUrlTree([link], this._getNavExtras(item)).toString();
1567
- }
1568
- else if (Array.isArray(link)) {
1569
- return this._router.createUrlTree(link, this._getNavExtras(item)).toString();
1570
- }
1571
- return null;
1572
- }
1573
- _getMatchOptions(item) {
1574
- const defaultMatchOpts = {
1575
- paths: 'subset',
1576
- queryParams: 'subset',
1577
- fragment: 'ignored',
1578
- matrixParams: 'ignored'
1579
- };
1580
- if (hasProperty(item, 'matchOptions')) {
1581
- return Object.assign(Object.assign({}, defaultMatchOpts), item.matchOptions);
1582
- }
1583
- return defaultMatchOpts;
1584
- }
1585
- setItemStateProp(item, prop, value) {
1586
- const currentValue = getItemStateProp(item, prop);
1587
- if (currentValue !== value) {
1588
- setItemStateProp(item, prop, value);
1589
- const changed = {
1590
- item,
1591
- prop,
1592
- prevValue: currentValue,
1593
- newValue: value
1594
- };
1595
- this.itemChanged.next(changed);
1596
- }
1597
- }
1598
- }
1599
- TheSeamSideNavService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavService, deps: [{ token: i1$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
1600
- TheSeamSideNavService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavService });
1601
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavService, decorators: [{
1602
- type: Injectable
1603
- }], ctorParameters: function () { return [{ type: i1$2.Router }]; } });
1604
-
1605
- const EXPANDED_STATE = 'expanded';
1606
- const COLLAPSED_STATE = 'collapsed';
1607
- const EXPANDED_OVERLAY_STATE = 'expanded-overlay';
1608
- const COLLAPSED_OVERLAY_STATE = 'collapsed-overlay';
1609
- const EXPANDED_STATES = [EXPANDED_STATE, EXPANDED_OVERLAY_STATE];
1610
- const COLLAPSED_STATES = [COLLAPSED_STATE, COLLAPSED_OVERLAY_STATE];
1611
- const EXPAND_STATES = [...EXPANDED_STATES, ...COLLAPSED_STATES];
1612
- function sideNavExpandStateChangeFn(fromState, toState) {
1613
- // console.log({ fromState, toState })
1614
- return fromState !== toState &&
1615
- (
1616
- // NOTE: The current way the side nav is being used it causes the
1617
- // component to sometimes get placed in the wrong location initially. It
1618
- // is fast enough to not be noticed without an initial animation usually,
1619
- // so it is commented out below until the initial placement issue it
1620
- // fixed.
1621
- //
1622
- // (
1623
- // fromState === 'void' && EXPAND_STATES.indexOf(toState) !== -1
1624
- // ||
1625
- // toState === 'void' && EXPAND_STATES.indexOf(fromState) !== -1
1626
- // )
1627
- // ||
1628
- ((EXPANDED_STATES.indexOf(fromState) !== -1 && COLLAPSED_STATES.indexOf(toState) !== -1) ||
1629
- (EXPANDED_STATES.indexOf(toState) !== -1 && COLLAPSED_STATES.indexOf(fromState) !== -1)));
1630
- }
1631
- class SideNavComponent {
1632
- get items() { return this._items.value; }
1633
- set items(value) { this._items.next(value); }
1634
- get expanded() { return this._expanded.value; }
1635
- set expanded(value) {
1636
- const expanded = coerceBooleanProperty(value);
1637
- const emit = expanded !== this.expanded;
1638
- this._expanded.next(expanded);
1639
- if (emit) {
1640
- this.toggleExpand.emit(coerceBooleanProperty(value));
1641
- }
1642
- }
1643
- get overlay() { return this._overlay.value; }
1644
- set overlay(value) { this._overlay.next(coerceBooleanProperty(value)); }
1645
- get menuItemTooltipConfig() { return this._menuItemTooltipConfig; }
1646
- set menuItemTooltipConfig(value) {
1647
- this._menuItemTooltipConfig = {
1648
- class: value === null || value === void 0 ? void 0 : value.class,
1649
- placement: (value === null || value === void 0 ? void 0 : value.placement) || this._menuItemTooltipConfig.placement,
1650
- container: (value === null || value === void 0 ? void 0 : value.container) || this._menuItemTooltipConfig.container,
1651
- behavior: (value === null || value === void 0 ? void 0 : value.behavior) || this._menuItemTooltipConfig.behavior
1652
- };
1653
- }
1654
- constructor(_viewContainerRef, _layout, _sideNav, _config, _baseLayoutRef) {
1655
- this._viewContainerRef = _viewContainerRef;
1656
- this._layout = _layout;
1657
- this._sideNav = _sideNav;
1658
- this._config = _config;
1659
- this._baseLayoutRef = _baseLayoutRef;
1660
- this._ngUnsubscribe = new Subject();
1661
- this.faBars = faBars;
1662
- // @HostBinding('@sideNavExpand') _sideNavExpand = EXPANDED_STATE
1663
- // _sideNavExpand = EXPANDED_STATE
1664
- // @HostBinding('@sideNavAnim') _sideNavExpand = EXPANDED_STATE
1665
- this._sideNavExpand = 'initial';
1666
- this.hasHeaderToggle = true;
1667
- this.toggleIcon = faBars;
1668
- this._items = new BehaviorSubject([]);
1669
- this.indentSize = 10;
1670
- this._expanded = new BehaviorSubject(true);
1671
- this.expanded$ = this._expanded.asObservable();
1672
- this.expandOrigin = 'left';
1673
- this.expandHeight = '100%';
1674
- this.expandWidth = 'calc(100vw - 50px)';
1675
- this._overlay = new BehaviorSubject(false);
1676
- this.overlay$ = this._overlay.asObservable();
1677
- this._menuItemTooltipConfig = {
1678
- placement: 'right',
1679
- container: 'body',
1680
- behavior: 'always'
1681
- };
1682
- this.toggleExpand = new EventEmitter();
1683
- this._backdropHidden = new BehaviorSubject(true);
1684
- const config = Object.assign(Object.assign({}, DEFAULT_SIDE_NAV_CONFIG), (this._config || {}));
1685
- this.items$ = this._items.asObservable().pipe(map(items => (items && config) ? items.map(itm => applyItemConfig(itm, config)) : []), switchMap(items => items ? this._sideNav.createItemsObservable(items) : []), shareReplay({ bufferSize: 1, refCount: true }));
1686
- this.isMobile$ = this._layout.isMobile$.pipe(tap(isMobile => isMobile ? this.collapse() : this.expand()));
1687
- this.sideNavExpandedState$ = combineLatest([this.expanded$, this.overlay$]).pipe(map(([expanded, overlay]) => expanded
1688
- ? overlay ? EXPANDED_OVERLAY_STATE : EXPANDED_STATE
1689
- : overlay ? COLLAPSED_OVERLAY_STATE : COLLAPSED_STATE), distinctUntilChanged());
1690
- this.menuItemTooltipDisabled$ = combineLatest([this.expanded$, this.overlay$]).pipe(map(([expanded, overlay]) => {
1691
- var _a, _b, _c;
1692
- // never display tooltip on mobile, it breaks the layout
1693
- if (overlay) {
1694
- return true;
1695
- }
1696
- return ((_a = this.menuItemTooltipConfig) === null || _a === void 0 ? void 0 : _a.behavior) === 'always' ? false
1697
- : ((_b = this.menuItemTooltipConfig) === null || _b === void 0 ? void 0 : _b.behavior) === 'never' ? true
1698
- : ((_c = this.menuItemTooltipConfig) === null || _c === void 0 ? void 0 : _c.behavior) === 'collapseOnly' ? expanded : true;
1699
- }), distinctUntilChanged());
1700
- }
1701
- ngOnInit() {
1702
- if (this._baseLayoutRef) {
1703
- this._baseLayoutRef.registerNav(this);
1704
- }
1705
- this.isMobile$
1706
- .pipe(takeUntil(this._ngUnsubscribe))
1707
- .subscribe(b => this.overlay = b);
1708
- this.sideNavExpandedState$
1709
- .pipe(takeUntil(this._ngUnsubscribe))
1710
- .subscribe(v => this._sideNavExpand = v);
1711
- if (this._sideBarHeaderTpl) {
1712
- this._sideBarHeaderPortal = new TemplatePortal(this._sideBarHeaderTpl, this._viewContainerRef);
1713
- }
1714
- if (this._sideBarFooterTpl) {
1715
- this._sideBarFooterPortal = new TemplatePortal(this._sideBarFooterTpl, this._viewContainerRef);
1716
- }
1717
- }
1718
- ngOnDestroy() {
1719
- this._ngUnsubscribe.next(undefined);
1720
- this._ngUnsubscribe.complete();
1721
- if (this._baseLayoutRef) {
1722
- this._baseLayoutRef.unregisterNav(this);
1723
- }
1724
- }
1725
- expand() {
1726
- this.expanded = true;
1727
- }
1728
- collapse() {
1729
- this.expanded = false;
1730
- }
1731
- toggle() {
1732
- this.expanded = !this.expanded;
1733
- }
1734
- animateStart() {
1735
- if (this.expanded) {
1736
- this._backdropHidden.next(false);
1737
- }
1738
- }
1739
- animateEnd() {
1740
- if (!this.expanded) {
1741
- this._backdropHidden.next(true);
1742
- }
1743
- }
1744
- get expandOriginTransform() {
1745
- switch (this.expandOrigin) {
1746
- case 'right':
1747
- return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateX(100vw) translateX(-100%)'
1748
- : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateX(100vw)' : null;
1749
- case 'top':
1750
- return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateY(0)'
1751
- : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateY(-100%)' : null;
1752
- case 'bottom':
1753
- return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateY(100vh) translateY(-100%)'
1754
- : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateY(100vh)' : null;
1755
- case 'left':
1756
- default:
1757
- return this._sideNavExpand === EXPANDED_OVERLAY_STATE ? 'translateX(0)'
1758
- : this._sideNavExpand === COLLAPSED_OVERLAY_STATE ? 'translateX(-100%)' : null;
1759
- }
1760
- }
1761
- }
1762
- SideNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SideNavComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TheSeamLayoutService }, { token: TheSeamSideNavService }, { token: THESEAM_SIDE_NAV_CONFIG, optional: true }, { token: THESEAM_BASE_LAYOUT_REF, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1763
- SideNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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", menuItemTooltipConfig: "menuItemTooltipConfig" }, outputs: { toggleExpand: "toggleExpand" }, host: { properties: { "@sideNavAnim": "this._sideNavExpand" } }, providers: [
1764
- TheSeamSideNavService,
1765
- {
1766
- provide: THESEAM_SIDE_NAV_ACCESSOR,
1767
- useExisting: SideNavComponent
1768
- },
1769
- ], 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\"\r\n [@sideNavBackdrop]=\"_sideNavExpand\"\r\n [class.side-nav-backdrop-hidden]=\"_backdropHidden | async\"\r\n (click)=\"collapse()\"></div>\r\n\r\n<div\r\n class=\"side-nav-inner-wrapper\"\r\n [@sideNavExpand]=\"{\r\n value: _sideNavExpand,\r\n params: {\r\n origin: expandOriginTransform,\r\n height: expandHeight,\r\n width: expandWidth\r\n }\r\n }\"\r\n (@sideNavExpand.start)=\"animateStart()\"\r\n (@sideNavExpand.done)=\"animateEnd()\">\r\n <nav class=\"nav side-nav-content\">\r\n <seam-side-nav-toggle *ngIf=\"hasHeaderToggle\"\r\n [toggleIcon]=\"toggleIcon\"\r\n [toggleTpl]=\"toggleTpl\"\r\n [expanded]=\"expanded$ | async\"\r\n (toggleExpand)=\"toggle()\">\r\n <ng-template [cdkPortalOutlet]=\"_sideBarHeaderPortal\"></ng-template>\r\n </seam-side-nav-toggle>\r\n <div class=\"side-nav-items-container\" seamOverlayScrollbar>\r\n <div class=\"side-nav--group side-nav--group--level-0\">\r\n <seam-side-nav-item *ngFor=\"let item of items$ | async\"\r\n [compact]=\"!(expanded$ | async)\"\r\n [isMobile]=\"isMobile$ | async\"\r\n [itemType]=\"$any(item)?.itemType\"\r\n [icon]=\"$any(item)?.icon\"\r\n [label]=\"$any(item)?.label\"\r\n [link]=\"$any(item)?.link\"\r\n [badgeText]=\"$any(item)?.badge?.text\"\r\n [badgeTheme]=\"$any(item)?.badge?.theme || 'danger'\"\r\n [badgeSrContent]=\"$any(item)?.badge?.srContent\"\r\n [badgeTooltip]=\"$any(item)?.badge?.tooltip\"\r\n [queryParams]=\"$any(item)?.queryParams\"\r\n [children]=\"$any(item)?.children\"\r\n [active]=\"$any(item).__state?.active\"\r\n [expanded]=\"$any(item).__state?.expanded\"\r\n [hideEmptyIcon]=\"hideEmptyIcon\"\r\n [indentSize]=\"indentSize\"\r\n [menuItemTooltipConfig]=\"menuItemTooltipConfig\"\r\n [menuItemTooltipDisabled]=\"menuItemTooltipDisabled$ | async\">\r\n [activeNavigatable]=\"$any(item).activeNavigatable\">\r\n </seam-side-nav-item>\r\n </div>\r\n </div>\r\n <ng-template [cdkPortalOutlet]=\"_sideBarFooterPortal\"></ng-template>\r\n </nav>\r\n</div>\r\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", "activeNavigatable", "link", "queryParams", "children", "hierLevel", "indentSize", "expanded", "compact", "isMobile", "badgeText", "badgeTheme", "badgeSrContent", "badgeTooltip", "menuItemTooltipConfig", "menuItemTooltipDisabled"], exportAs: ["seamSideNavItem"] }, { kind: "component", type: SideNavToggleComponent, selector: "seam-side-nav-toggle", inputs: ["expanded", "toggleIcon", "toggleTpl"], outputs: ["toggleExpand"] }], animations: [
1770
- //
1771
- // TODO: This animation code turned into a mess. Clean it up and make it
1772
- // more smooth.
1773
- //
1774
- trigger('sideNavAnim', [
1775
- transition(sideNavExpandStateChangeFn, [
1776
- group([
1777
- query('@sideNavBackdrop', animateChild(), { optional: true }),
1778
- query('@sideNavExpand', animateChild(), { optional: true }),
1779
- ]),
1780
- ]),
1781
- ]),
1782
- trigger('sideNavBackdrop', [
1783
- state(EXPANDED_OVERLAY_STATE, style({ opacity: '1' })),
1784
- state(COLLAPSED_OVERLAY_STATE, style({ opacity: '0' })),
1785
- // transition((fromState, toState, element, params) => {
1786
- // console.log('sideNavBackdrop v', fromState, toState, element, params)
1787
- // return false
1788
- // }, []),
1789
- transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1790
- ]),
1791
- trigger('sideNavExpand', [
1792
- // TODO: Make width configurable for non-overlay state.
1793
- state(EXPANDED_STATE, style({ width: '260px' })),
1794
- state(COLLAPSED_STATE, style({ width: '50px', 'overflow-x': 'hidden' })),
1795
- state(EXPANDED_OVERLAY_STATE, style({
1796
- position: 'absolute',
1797
- top: 0,
1798
- bottom: 0,
1799
- left: 0,
1800
- height: '{{ height }}',
1801
- width: '{{ width }}',
1802
- transform: '{{ origin }}',
1803
- zIndex: '9999',
1804
- }), {
1805
- params: {
1806
- origin: 'translateX(100%)',
1807
- height: '100%',
1808
- width: 'calc(100vw - 50px)',
1809
- }
1810
- }),
1811
- state(COLLAPSED_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
- 'overflow-x': 'hidden',
1820
- zIndex: '9999',
1821
- }), {
1822
- params: {
1823
- origin: 'translateX(0)',
1824
- height: '100%',
1825
- width: 'calc(100vw - 50px)',
1826
- }
1827
- }),
1828
- // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),
1829
- transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1830
- // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, [
1831
- // // query(':leave', animateChild(), { optional: true }),
1832
- // // query(':enter', animateChild(), { optional: true }),
1833
- // group([
1834
- // query(':leave', animateChild(), { optional: true }),
1835
- // query(':enter', animateChild(), { optional: true }),
1836
- // query('@compactAnim', animateChild(), { optional: true }),
1837
- // animate('5.2s ease-in-out')
1838
- // ])
1839
- // ]),
1840
- ])
1841
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1842
- __decorate([
1843
- InputBoolean()
1844
- ], SideNavComponent.prototype, "hasHeaderToggle", void 0);
1845
- __decorate([
1846
- InputNumber(10)
1847
- ], SideNavComponent.prototype, "indentSize", void 0);
1848
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SideNavComponent, decorators: [{
1849
- type: Component,
1850
- args: [{ selector: 'seam-side-nav', providers: [
1851
- TheSeamSideNavService,
1852
- {
1853
- provide: THESEAM_SIDE_NAV_ACCESSOR,
1854
- useExisting: SideNavComponent
1855
- },
1856
- ], animations: [
1857
- //
1858
- // TODO: This animation code turned into a mess. Clean it up and make it
1859
- // more smooth.
1860
- //
1861
- trigger('sideNavAnim', [
1862
- transition(sideNavExpandStateChangeFn, [
1863
- group([
1864
- query('@sideNavBackdrop', animateChild(), { optional: true }),
1865
- query('@sideNavExpand', animateChild(), { optional: true }),
1866
- ]),
1867
- ]),
1868
- ]),
1869
- trigger('sideNavBackdrop', [
1870
- state(EXPANDED_OVERLAY_STATE, style({ opacity: '1' })),
1871
- state(COLLAPSED_OVERLAY_STATE, style({ opacity: '0' })),
1872
- // transition((fromState, toState, element, params) => {
1873
- // console.log('sideNavBackdrop v', fromState, toState, element, params)
1874
- // return false
1875
- // }, []),
1876
- transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1877
- ]),
1878
- trigger('sideNavExpand', [
1879
- // TODO: Make width configurable for non-overlay state.
1880
- state(EXPANDED_STATE, style({ width: '260px' })),
1881
- state(COLLAPSED_STATE, style({ width: '50px', 'overflow-x': 'hidden' })),
1882
- state(EXPANDED_OVERLAY_STATE, style({
1883
- position: 'absolute',
1884
- top: 0,
1885
- bottom: 0,
1886
- left: 0,
1887
- height: '{{ height }}',
1888
- width: '{{ width }}',
1889
- transform: '{{ origin }}',
1890
- zIndex: '9999',
1891
- }), {
1892
- params: {
1893
- origin: 'translateX(100%)',
1894
- height: '100%',
1895
- width: 'calc(100vw - 50px)',
1896
- }
1897
- }),
1898
- state(COLLAPSED_OVERLAY_STATE, style({
1899
- position: 'absolute',
1900
- top: 0,
1901
- bottom: 0,
1902
- left: 0,
1903
- height: '{{ height }}',
1904
- width: '{{ width }}',
1905
- transform: '{{ origin }}',
1906
- 'overflow-x': 'hidden',
1907
- zIndex: '9999',
1908
- }), {
1909
- params: {
1910
- origin: 'translateX(0)',
1911
- height: '100%',
1912
- width: 'calc(100vw - 50px)',
1913
- }
1914
- }),
1915
- // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),
1916
- transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),
1917
- // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, [
1918
- // // query(':leave', animateChild(), { optional: true }),
1919
- // // query(':enter', animateChild(), { optional: true }),
1920
- // group([
1921
- // query(':leave', animateChild(), { optional: true }),
1922
- // query(':enter', animateChild(), { optional: true }),
1923
- // query('@compactAnim', animateChild(), { optional: true }),
1924
- // animate('5.2s ease-in-out')
1925
- // ])
1926
- // ]),
1927
- ])
1928
- ], imports: [
1929
- CommonModule,
1930
- A11yModule,
1931
- TheSeamScrollbarModule,
1932
- TheSeamLayoutModule,
1933
- PortalModule,
1934
- SideNavItemComponent,
1935
- SideNavToggleComponent,
1936
- ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, template: "<div class=\"side-nav-backdrop\" *ngIf=\"isMobile$ | async\"\r\n [@sideNavBackdrop]=\"_sideNavExpand\"\r\n [class.side-nav-backdrop-hidden]=\"_backdropHidden | async\"\r\n (click)=\"collapse()\"></div>\r\n\r\n<div\r\n class=\"side-nav-inner-wrapper\"\r\n [@sideNavExpand]=\"{\r\n value: _sideNavExpand,\r\n params: {\r\n origin: expandOriginTransform,\r\n height: expandHeight,\r\n width: expandWidth\r\n }\r\n }\"\r\n (@sideNavExpand.start)=\"animateStart()\"\r\n (@sideNavExpand.done)=\"animateEnd()\">\r\n <nav class=\"nav side-nav-content\">\r\n <seam-side-nav-toggle *ngIf=\"hasHeaderToggle\"\r\n [toggleIcon]=\"toggleIcon\"\r\n [toggleTpl]=\"toggleTpl\"\r\n [expanded]=\"expanded$ | async\"\r\n (toggleExpand)=\"toggle()\">\r\n <ng-template [cdkPortalOutlet]=\"_sideBarHeaderPortal\"></ng-template>\r\n </seam-side-nav-toggle>\r\n <div class=\"side-nav-items-container\" seamOverlayScrollbar>\r\n <div class=\"side-nav--group side-nav--group--level-0\">\r\n <seam-side-nav-item *ngFor=\"let item of items$ | async\"\r\n [compact]=\"!(expanded$ | async)\"\r\n [isMobile]=\"isMobile$ | async\"\r\n [itemType]=\"$any(item)?.itemType\"\r\n [icon]=\"$any(item)?.icon\"\r\n [label]=\"$any(item)?.label\"\r\n [link]=\"$any(item)?.link\"\r\n [badgeText]=\"$any(item)?.badge?.text\"\r\n [badgeTheme]=\"$any(item)?.badge?.theme || 'danger'\"\r\n [badgeSrContent]=\"$any(item)?.badge?.srContent\"\r\n [badgeTooltip]=\"$any(item)?.badge?.tooltip\"\r\n [queryParams]=\"$any(item)?.queryParams\"\r\n [children]=\"$any(item)?.children\"\r\n [active]=\"$any(item).__state?.active\"\r\n [expanded]=\"$any(item).__state?.expanded\"\r\n [hideEmptyIcon]=\"hideEmptyIcon\"\r\n [indentSize]=\"indentSize\"\r\n [menuItemTooltipConfig]=\"menuItemTooltipConfig\"\r\n [menuItemTooltipDisabled]=\"menuItemTooltipDisabled$ | async\">\r\n [activeNavigatable]=\"$any(item).activeNavigatable\">\r\n </seam-side-nav-item>\r\n </div>\r\n </div>\r\n <ng-template [cdkPortalOutlet]=\"_sideBarFooterPortal\"></ng-template>\r\n </nav>\r\n</div>\r\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"] }]
1937
- }], ctorParameters: function () {
1938
- return [{ type: i0.ViewContainerRef }, { type: i1.TheSeamLayoutService }, { type: TheSeamSideNavService }, { type: undefined, decorators: [{
1939
- type: Optional
1940
- }, {
1941
- type: Inject,
1942
- args: [THESEAM_SIDE_NAV_CONFIG]
1943
- }] }, { type: undefined, decorators: [{
1944
- type: Optional
1945
- }, {
1946
- type: Inject,
1947
- args: [THESEAM_BASE_LAYOUT_REF]
1948
- }] }];
1949
- }, propDecorators: { _sideNavExpand: [{
1950
- type: HostBinding,
1951
- args: ['@sideNavAnim']
1952
- }], hasHeaderToggle: [{
1953
- type: Input
1954
- }], toggleIcon: [{
1955
- type: Input
1956
- }], toggleTpl: [{
1957
- type: Input
1958
- }], items: [{
1959
- type: Input
1960
- }], hideEmptyIcon: [{
1961
- type: Input
1962
- }], indentSize: [{
1963
- type: Input
1964
- }], expanded: [{
1965
- type: Input
1966
- }], expandOrigin: [{
1967
- type: Input
1968
- }], expandHeight: [{
1969
- type: Input
1970
- }], expandWidth: [{
1971
- type: Input
1972
- }], overlay: [{
1973
- type: Input
1974
- }], menuItemTooltipConfig: [{
1975
- type: Input
1976
- }], toggleExpand: [{
1977
- type: Output
1978
- }], _sideBarHeaderTpl: [{
1979
- type: ContentChild,
1980
- args: [BaseLayoutSideBarHeaderDirective, { static: true, read: TemplateRef }]
1981
- }], _sideBarFooterTpl: [{
1982
- type: ContentChild,
1983
- args: [BaseLayoutSideBarFooterDirective, { static: true, read: TemplateRef }]
1984
- }] } });
1985
-
1986
- class TheSeamSideNavModule {
1987
- }
1988
- TheSeamSideNavModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1989
- TheSeamSideNavModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavModule, imports: [SideNavItemComponent,
1990
- SideNavComponent,
1991
- SideNavToggleComponent], exports: [SideNavItemComponent,
1992
- SideNavComponent,
1993
- SideNavToggleComponent] });
1994
- TheSeamSideNavModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavModule, imports: [SideNavItemComponent,
1995
- SideNavComponent,
1996
- SideNavToggleComponent] });
1997
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSideNavModule, decorators: [{
1998
- type: NgModule,
1999
- args: [{
2000
- imports: [
2001
- SideNavItemComponent,
2002
- SideNavComponent,
2003
- SideNavToggleComponent,
2004
- ],
2005
- exports: [
2006
- SideNavItemComponent,
2007
- SideNavComponent,
2008
- SideNavToggleComponent,
2009
- ]
2010
- }]
2011
- }] });
2012
-
2013
- class TopBarMenuButtonBase {
2014
- }
2015
- const _TopBarMenuButtonMixinBase = mixinDisabled(TopBarMenuButtonBase);
2016
- class TopBarMenuButtonComponent extends _TopBarMenuButtonMixinBase {
2017
- constructor() {
2018
- super(...arguments);
2019
- this.faAngleDown = faAngleDown;
2020
- this.compact = false;
2021
- }
2022
- get _hasCompactClass() { return this.compact; }
2023
- get _hasPadding0Class() { return this.compact; }
2024
- get _hasRoundedClass() { return this.compact; }
2025
- get _hasBtnLinkClass() { return !this.compact; }
2026
- }
2027
- TopBarMenuButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarMenuButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
2028
- TopBarMenuButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
2029
- __decorate([
2030
- InputBoolean()
2031
- ], TopBarMenuButtonComponent.prototype, "compact", void 0);
2032
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarMenuButtonComponent, decorators: [{
2033
- type: Component,
2034
- args: [{ selector: 'button[seamTopBarMenuButton]', encapsulation: ViewEncapsulation.None, exportAs: 'seamButton', inputs: ['disabled'], host: {
2035
- 'attr.type': 'button',
2036
- 'class': 'btn border text-decoration-none py-0 top-bar-menu-button',
2037
- '[attr.aria-disabled]': 'disabled.toString()',
2038
- '[attr.disabled]': 'disabled || null',
2039
- }, 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"] }]
2040
- }], propDecorators: { detailTpl: [{
2041
- type: Input
2042
- }], compactDetailTpl: [{
2043
- type: Input
2044
- }], compact: [{
2045
- type: Input
2046
- }], profileIcon: [{
2047
- type: Input
2048
- }], _hasCompactClass: [{
2049
- type: HostBinding,
2050
- args: ['class.top-bar-menu-button--compact']
2051
- }], _hasPadding0Class: [{
2052
- type: HostBinding,
2053
- args: ['class.p-0']
2054
- }], _hasRoundedClass: [{
2055
- type: HostBinding,
2056
- args: ['class.rounded']
2057
- }], _hasBtnLinkClass: [{
2058
- type: HostBinding,
2059
- args: ['class.btn-link']
2060
- }] } });
2061
-
2062
- class TopBarTitleComponent {
2063
- }
2064
- TopBarTitleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarTitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2065
- TopBarTitleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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 });
2066
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarTitleComponent, decorators: [{
2067
- type: Component,
2068
- 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"] }]
2069
- }], propDecorators: { titleText: [{
2070
- type: Input
2071
- }], subTitleText: [{
2072
- type: Input
2073
- }] } });
2074
-
2075
- class TopBarCompactMenuBtnDetailDirective {
2076
- constructor(template) {
2077
- this.template = template;
2078
- }
2079
- }
2080
- TopBarCompactMenuBtnDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarCompactMenuBtnDetailDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2081
- TopBarCompactMenuBtnDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TopBarCompactMenuBtnDetailDirective, selector: "[seamTopBarCompactMenuBtnDetail]", ngImport: i0 });
2082
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarCompactMenuBtnDetailDirective, decorators: [{
2083
- type: Directive,
2084
- args: [{
2085
- selector: '[seamTopBarCompactMenuBtnDetail]'
2086
- }]
2087
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
2088
-
2089
- class TopBarNavToggleBtnDetailDirective {
2090
- constructor(template) {
2091
- this.template = template;
2092
- }
2093
- }
2094
- TopBarNavToggleBtnDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarNavToggleBtnDetailDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2095
- TopBarNavToggleBtnDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TopBarNavToggleBtnDetailDirective, selector: "[seamTopBarNavToggleBtnDetail]", ngImport: i0 });
2096
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarNavToggleBtnDetailDirective, decorators: [{
2097
- type: Directive,
2098
- args: [{
2099
- selector: '[seamTopBarNavToggleBtnDetail]'
2100
- }]
2101
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
2102
-
2103
- class TopBarItemDirective {
2104
- set seamTopBarItem(value) {
2105
- this.position = value;
2106
- }
2107
- constructor(template) {
2108
- this.template = template;
2109
- this.position = 'right';
2110
- }
2111
- }
2112
- TopBarItemDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarItemDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2113
- TopBarItemDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TopBarItemDirective, selector: "[seamTopBarItem]", inputs: { seamTopBarItem: "seamTopBarItem" }, ngImport: i0 });
2114
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarItemDirective, decorators: [{
2115
- type: Directive,
2116
- args: [{
2117
- selector: '[seamTopBarItem]'
2118
- }]
2119
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; }, propDecorators: { seamTopBarItem: [{
2120
- type: Input
2121
- }] } });
2122
-
2123
- class TopBarMenuBtnDetailDirective {
2124
- constructor(template) {
2125
- this.template = template;
2126
- }
2127
- }
2128
- TopBarMenuBtnDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarMenuBtnDetailDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
2129
- TopBarMenuBtnDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TopBarMenuBtnDetailDirective, selector: "[seamTopBarMenuBtnDetail]", ngImport: i0 });
2130
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarMenuBtnDetailDirective, decorators: [{
2131
- type: Directive,
2132
- args: [{
2133
- selector: '[seamTopBarMenuBtnDetail]'
2134
- }]
2135
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
2136
-
2137
- class TopBarMenuDirective {
2138
- constructor(menu) {
2139
- this.menu = menu;
2140
- }
2141
- }
2142
- TopBarMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarMenuDirective, deps: [{ token: i3$2.MenuComponent, self: true }], target: i0.ɵɵFactoryTarget.Directive });
2143
- TopBarMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TopBarMenuDirective, selector: "seam-menu[seamTopBarMenu]", ngImport: i0 });
2144
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TopBarMenuDirective, decorators: [{
2145
- type: Directive,
2146
- args: [{
2147
- selector: 'seam-menu[seamTopBarMenu]'
2148
- }]
2149
- }], ctorParameters: function () {
2150
- return [{ type: i3$2.MenuComponent, decorators: [{
2151
- type: Self
2152
- }] }];
2153
- } });
2154
-
2155
- /**
2156
- * Top bar of an app.
2157
- *
2158
- * The top bar is fairly opinionated, so most parts are not intended to be
2159
- * customized unless there is an input.
2160
- *
2161
- * > If you have to make a change and apply it externally with a css class or js
2162
- * > make sure there is an issue to get the feature changed, so we don't have
2163
- * > different modifications across our apps. Also, this will help make sure
2164
- * > your change should have even been done.
2165
- */
2166
- class TheSeamTopBarComponent {
2167
- constructor(_layout) {
2168
- this._layout = _layout;
2169
- /** @ignore */
2170
- this._ngUnsubscribe = new Subject();
2171
- /** @ignore */
2172
- this.faBars = faBars;
2173
- /** Link target used when `logoHref` is specified. Defaults to `"_blank"` */
2174
- this.logoHrefTarget = '_blank';
2175
- /** Route to link to when `logo` is clicked. Defaults to `/`. */
2176
- this.logoRoute = '/';
2177
- /** Determines if the title should be displayed. */
2178
- this.hasTitle = false;
2179
- /** Determines if the top bar button should be displayed. */
2180
- this.hasTopBarMenuButton = true;
2181
- /** Icon to display on mobile to activate profile dropdown. Defaults to faUserCircle. */
2182
- this.profileIcon = faUserCircle;
2183
- /** Icon to display for mobile nav toggle. Defaults to faBars. */
2184
- this.toggleIcon = faBars;
2185
- /** Display nav toggle on either left or right side of top bar. Defaults to left. */
2186
- this.navToggleAlign = 'left';
2187
- /** @ignore */
2188
- this._leftItems = new BehaviorSubject([]);
2189
- /** Additional templates to display on left side of top bar */
2190
- this.leftItems$ = this._leftItems.asObservable();
2191
- /** @ignore */
2192
- this._centerItems = new BehaviorSubject([]);
2193
- /** Additional templates to display in center of top bar */
2194
- this.centerItems$ = this._centerItems.asObservable();
2195
- /** @ignore */
2196
- this._rightItems = new BehaviorSubject([]);
2197
- /** Additional templates to display on right side of top bar */
2198
- this.rightItems$ = this._rightItems.asObservable();
2199
- this.isMobile$ = this._layout.isMobile$;
2200
- }
2201
- /** @ignore */
2202
- ngOnDestroy() {
2203
- this._ngUnsubscribe.next(undefined);
2204
- this._ngUnsubscribe.complete();
2205
- }
2206
- /** @ignore */
2207
- ngAfterContentInit() {
2208
- if (this._topBarItems) {
2209
- this._topBarItems.changes.pipe(startWith(undefined), takeUntil(this._ngUnsubscribe), map(() => {
2210
- var _a;
2211
- const items = ((_a = this._topBarItems) === null || _a === void 0 ? void 0 : _a.toArray()) || [];
2212
- const left = items.filter(i => i.position === 'left');
2213
- const right = items.filter(i => i.position === 'right');
2214
- const center = items.filter(i => i.position === 'center');
2215
- this._leftItems.next(left);
2216
- this._rightItems.next(right);
2217
- this._centerItems.next(center);
2218
- }), shareReplay({ bufferSize: 1, refCount: true })).subscribe();
2219
- }
2220
- }
2221
- }
2222
- TheSeamTopBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamTopBarComponent, deps: [{ token: i1.TheSeamLayoutService }], target: i0.ɵɵFactoryTarget.Component });
2223
- TheSeamTopBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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.TheSeamButtonComponent, 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", "seamMenuTogglePositionsOffsetY"], outputs: ["menuToggle", "menuOpened", "menuClosed"], 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 });
2224
- __decorate([
2225
- InputBoolean()
2226
- ], TheSeamTopBarComponent.prototype, "hasTitle", void 0);
2227
- __decorate([
2228
- InputBoolean()
2229
- ], TheSeamTopBarComponent.prototype, "hasTopBarMenuButton", void 0);
2230
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamTopBarComponent, decorators: [{
2231
- type: Component,
2232
- 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"] }]
2233
- }], ctorParameters: function () { return [{ type: i1.TheSeamLayoutService }]; }, propDecorators: { _topBarMenu: [{
2234
- type: ContentChild,
2235
- args: [TopBarMenuDirective, { static: true }]
2236
- }], _topBarItems: [{
2237
- type: ContentChildren,
2238
- args: [TopBarItemDirective]
2239
- }], _topBarMenuBtnDetailTpl: [{
2240
- type: ContentChild,
2241
- args: [TopBarMenuBtnDetailDirective]
2242
- }], _topBarCompactMenuBtnDetailTpl: [{
2243
- type: ContentChild,
2244
- args: [TopBarCompactMenuBtnDetailDirective]
2245
- }], _topBarNavToggleBtnDetailTpl: [{
2246
- type: ContentChild,
2247
- args: [TopBarNavToggleBtnDetailDirective]
2248
- }], logo: [{
2249
- type: Input
2250
- }], logoSm: [{
2251
- type: Input
2252
- }], logoHref: [{
2253
- type: Input
2254
- }], logoHrefTarget: [{
2255
- type: Input
2256
- }], logoRoute: [{
2257
- type: Input
2258
- }], hasTitle: [{
2259
- type: Input
2260
- }], titleText: [{
2261
- type: Input
2262
- }], subTitleText: [{
2263
- type: Input
2264
- }], hasTopBarMenuButton: [{
2265
- type: Input
2266
- }], profileIcon: [{
2267
- type: Input
2268
- }], toggleIcon: [{
2269
- type: Input
2270
- }], navToggleAlign: [{
2271
- type: Input
2272
- }] } });
2273
-
2274
- class TheSeamTopBarModule {
2275
- }
2276
- TheSeamTopBarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamTopBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2277
- TheSeamTopBarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamTopBarModule, declarations: [TheSeamTopBarComponent,
2278
- TopBarTitleComponent,
2279
- TopBarMenuButtonComponent,
2280
- TopBarMenuDirective,
2281
- TopBarItemDirective,
2282
- TopBarMenuBtnDetailDirective,
2283
- TopBarCompactMenuBtnDetailDirective,
2284
- TopBarNavToggleBtnDetailDirective], imports: [CommonModule,
2285
- TheSeamLayoutModule,
2286
- TheSeamButtonsModule,
2287
- TheSeamIconModule,
2288
- TheSeamMenuModule,
2289
- TheSeamBaseLayoutModule,
2290
- RouterModule], exports: [TheSeamTopBarComponent,
2291
- TopBarMenuButtonComponent,
2292
- TopBarMenuDirective,
2293
- TheSeamMenuModule,
2294
- TopBarItemDirective,
2295
- TopBarMenuBtnDetailDirective,
2296
- TopBarCompactMenuBtnDetailDirective,
2297
- TopBarNavToggleBtnDetailDirective] });
2298
- TheSeamTopBarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamTopBarModule, imports: [CommonModule,
2299
- TheSeamLayoutModule,
2300
- TheSeamButtonsModule,
2301
- TheSeamIconModule,
2302
- TheSeamMenuModule,
2303
- TheSeamBaseLayoutModule,
2304
- RouterModule, TheSeamMenuModule] });
2305
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamTopBarModule, decorators: [{
2306
- type: NgModule,
2307
- args: [{
2308
- declarations: [
2309
- TheSeamTopBarComponent,
2310
- TopBarTitleComponent,
2311
- TopBarMenuButtonComponent,
2312
- TopBarMenuDirective,
2313
- TopBarItemDirective,
2314
- TopBarMenuBtnDetailDirective,
2315
- TopBarCompactMenuBtnDetailDirective,
2316
- TopBarNavToggleBtnDetailDirective
2317
- ],
2318
- imports: [
2319
- CommonModule,
2320
- TheSeamLayoutModule,
2321
- TheSeamButtonsModule,
2322
- TheSeamIconModule,
2323
- TheSeamMenuModule,
2324
- TheSeamBaseLayoutModule,
2325
- RouterModule
2326
- ],
2327
- exports: [
2328
- TheSeamTopBarComponent,
2329
- TopBarMenuButtonComponent,
2330
- TopBarMenuDirective,
2331
- TheSeamMenuModule,
2332
- TopBarItemDirective,
2333
- TopBarMenuBtnDetailDirective,
2334
- TopBarCompactMenuBtnDetailDirective,
2335
- TopBarNavToggleBtnDetailDirective
2336
- ]
2337
- }]
2338
- }] });
2339
-
2340
- const fader = trigger('routeAnimations', [
2341
- transition('* <=> *', [
2342
- // Set a default style for enter and leave
2343
- query(':enter, :leave', [
2344
- style({
2345
- position: 'absolute',
2346
- left: 0,
2347
- width: '100%',
2348
- opacity: 0,
2349
- transform: 'scale(0) translateY(100%)',
2350
- }),
2351
- ], { optional: true }),
2352
- // Animate the new page in
2353
- query(':enter', [
2354
- animate('600ms ease', style({ opacity: 1, transform: 'scale(1) translateY(0)' })),
2355
- ], { optional: true })
2356
- ]),
2357
- ]);
2358
- // function slideTo(direction) {
2359
- // return [
2360
- // query(':enter, :leave', [
2361
- // style({
2362
- // position: 'absolute',
2363
- // top: 0,
2364
- // [direction]: 0,
2365
- // width: '100%'
2366
- // })
2367
- // ], { optional: true }),
2368
- // query(':enter', [
2369
- // style({ [direction]: '-100%'})
2370
- // ], { optional: true }),
2371
- // group([
2372
- // query(':leave', [
2373
- // animate('1000ms ease', style({ [direction]: '100%'}))
2374
- // ], { optional: true }),
2375
- // query(':enter', [
2376
- // animate('1000ms ease', style({ [direction]: '0%'}))
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(':leave', animateChild(), { optional: true }),
2382
- // query(':enter', animateChild(), { optional: true }),
2383
- // ]
2384
- // }
2385
- // TODO: Refactor the slider animation, because AOT or ng-packagr, I haven't
2386
- // looked into what exactly is preventing it, doesn't allow the function call.
2387
- // export const slider =
2388
- // trigger('routeAnimations', [
2389
- // transition('* => isLeft', slideTo('left') ),
2390
- // transition('* => isRight', slideTo('right') ),
2391
- // transition('isRight => *', slideTo('left') ),
2392
- // transition('isLeft => *', slideTo('right') )
2393
- // ])
2394
- // export const contentLeave =
2395
- // trigger('contentLeave', [
2396
- // transition(':leave', [
2397
- // ])
2398
- // ])
2399
- const slider = trigger('routeAnimations', [
2400
- transition('* => isLeft', [
2401
- query('.router-container :enter, .router-container :leave', [
2402
- style({
2403
- position: 'absolute',
2404
- top: 0,
2405
- left: 0,
2406
- width: '100%'
2407
- })
2408
- ], { optional: true }),
2409
- query('.router-container :enter', [
2410
- style({ left: '-100%' })
2411
- ], { optional: true }),
2412
- query('.hierarchy-router-outlet--content', [
2413
- style({ left: '0%', position: 'absolute' })
2414
- ], { optional: true }),
2415
- group([
2416
- query('.router-container :leave', [
2417
- animate('1000ms ease', style({ left: '100%' }))
2418
- ], { optional: true }),
2419
- query('.router-container :enter', [
2420
- animate('1000ms ease', style({ left: '0%' }))
2421
- ], { optional: true }),
2422
- query('.hierarchy-router-outlet--content', [
2423
- animate('1000ms ease', style({ left: '-100%' }))
2424
- ], { optional: true }),
2425
- ]),
2426
- // Normalize the page style... Might not be necessary
2427
- // Required only if you have child animations on the page
2428
- query('.router-container :leave', animateChild(), { optional: true }),
2429
- query('.router-container :enter', animateChild(), { optional: true }),
2430
- ]),
2431
- transition('* => isRight', [
2432
- query('.router-container :enter, .router-container :leave', [
2433
- style({
2434
- position: 'absolute',
2435
- top: 0,
2436
- right: 0,
2437
- width: '100%'
2438
- })
2439
- ], { optional: true }),
2440
- query('.router-container :enter', [
2441
- style({ right: '-100%' })
2442
- ], { optional: true }),
2443
- query('.hierarchy-router-outlet--content', [
2444
- style({ left: '0%', position: 'absolute' })
2445
- ], { optional: true }),
2446
- group([
2447
- query('.router-container :leave', [
2448
- animate('1000ms ease', style({ right: '100%' }))
2449
- ], { optional: true }),
2450
- query('.router-container :enter', [
2451
- animate('1000ms ease', style({ right: '0%' }))
2452
- ], { optional: true }),
2453
- query('.hierarchy-router-outlet--content', [
2454
- animate('1000ms ease', style({ left: '-100%' }))
2455
- ], { optional: true }),
2456
- ]),
2457
- // Normalize the page style... Might not be necessary
2458
- // Required only if you have child animations on the page
2459
- query('.router-container :leave', animateChild(), { optional: true }),
2460
- query('.router-container :enter', animateChild(), { optional: true }),
2461
- ]),
2462
- transition('isRight => *', [
2463
- query('.router-container :enter, .router-container :leave', [
2464
- style({
2465
- position: 'absolute',
2466
- top: 0,
2467
- left: 0,
2468
- width: '100%'
2469
- })
2470
- ], { optional: true }),
2471
- query('.router-container :enter', [
2472
- style({ left: '-100%' })
2473
- ], { optional: true }),
2474
- query('.hierarchy-router-outlet--content', [
2475
- style({ left: '0%', position: 'absolute' })
2476
- ], { optional: true }),
2477
- group([
2478
- query('.router-container :leave', [
2479
- animate('1000ms ease', style({ left: '100%' }))
2480
- ], { optional: true }),
2481
- query('.router-container :enter', [
2482
- animate('1000ms ease', style({ left: '0%' }))
2483
- ], { optional: true }),
2484
- query('.hierarchy-router-outlet--content', [
2485
- animate('1000ms ease', style({ left: '-100%' }))
2486
- ], { optional: true }),
2487
- ]),
2488
- // Normalize the page style... Might not be necessary
2489
- // Required only if you have child animations on the page
2490
- query('.router-container :leave', animateChild(), { optional: true }),
2491
- query('.router-container :enter', animateChild(), { optional: true }),
2492
- ]),
2493
- transition('isLeft => *', [
2494
- query('.router-container :enter, .router-container :leave', [
2495
- style({
2496
- position: 'absolute',
2497
- top: 0,
2498
- right: 0,
2499
- width: '100%'
2500
- })
2501
- ], { optional: true }),
2502
- query('.router-container :enter', [
2503
- style({ right: '-100%' })
2504
- ], { optional: true }),
2505
- group([
2506
- query('.router-container :leave', [
2507
- animate('1000ms ease', style({ right: '100%' }))
2508
- ], { optional: true }),
2509
- query('.router-container :enter', [
2510
- animate('1000ms ease', style({ right: '0%' }))
2511
- ], { optional: true })
2512
- ]),
2513
- // Normalize the page style... Might not be necessary
2514
- // Required only if you have child animations on the page
2515
- query('.router-container :leave', animateChild(), { optional: true }),
2516
- query('.router-container :enter', animateChild(), { optional: true }),
2517
- ])
2518
- ]);
2519
- const transformer = trigger('routeAnimations', [
2520
- transition('* => isLeft', transformTo({ x: -100, y: -100, rotate: -720 })),
2521
- transition('* => isRight', transformTo({ x: 100, y: -100, rotate: 90 })),
2522
- transition('isRight => *', transformTo({ x: -100, y: -100, rotate: 360 })),
2523
- transition('isLeft => *', transformTo({ x: 100, y: -100, rotate: -360 }))
2524
- ]);
2525
- function transformTo({ x = 100, y = 0, rotate = 0 }) {
2526
- const optional = { optional: true };
2527
- return [
2528
- query(':enter, :leave', [
2529
- style({
2530
- position: 'absolute',
2531
- top: 0,
2532
- left: 0,
2533
- width: '100%'
2534
- })
2535
- ], optional),
2536
- query(':enter', [
2537
- style({ transform: `translate(${x}%, ${y}%) rotate(${rotate}deg)` })
2538
- ], { optional: true }),
2539
- group([
2540
- query(':leave', [
2541
- animate('600ms ease-out', style({ transform: `translate(${x}%, ${y}%) rotate(${rotate}deg)` }))
2542
- ], optional),
2543
- query(':enter', [
2544
- animate('600ms ease-out', style({ transform: `translate(0, 0) rotate(0)` }))
2545
- ], { optional: true })
2546
- ]),
2547
- ];
2548
- }
2549
- const stepper = trigger('routeAnimations', [
2550
- transition('* <=> *', [
2551
- query(':enter, :leave', [
2552
- style({
2553
- position: 'absolute',
2554
- left: 0,
2555
- width: '100%',
2556
- }),
2557
- ], { optional: true }),
2558
- group([
2559
- query(':enter', [
2560
- animate('2000ms ease', keyframes([
2561
- style({ transform: 'scale(0) translateX(100%)', offset: 0 }),
2562
- style({ transform: 'scale(0.5) translateX(25%)', offset: 0.3 }),
2563
- style({ transform: 'scale(1) translateX(0%)', offset: 1 }),
2564
- ])),
2565
- ], { optional: true }),
2566
- query(':leave', [
2567
- animate('2000ms ease', keyframes([
2568
- style({ transform: 'scale(1)', offset: 0 }),
2569
- style({ transform: 'scale(0.5) translateX(-25%) rotate(0)', offset: 0.35 }),
2570
- style({ opacity: 0, transform: 'translateX(-50%) rotate(-180deg) scale(6)', offset: 1 }),
2571
- ])),
2572
- ], { optional: true })
2573
- ]),
2574
- ])
2575
- ]);
2576
- const sideToSide = trigger('routeAnimations', [
2577
- transition('* => *', [
2578
- style({
2579
- position: 'fixed',
2580
- width: '100%',
2581
- transform: 'translateX(-100%)'
2582
- }),
2583
- animate('1000ms ease', style({ transform: 'translateX(0%)' }))
2584
- ]),
2585
- transition(':leave', [
2586
- style({
2587
- position: 'fixed',
2588
- width: '100%',
2589
- transform: 'translateX(0%)'
2590
- }),
2591
- animate('1000ms ease', style({ transform: 'translateX(-100%)' }))
2592
- ])
2593
- ]);
2594
-
2595
- function routeChanges(router) {
2596
- return router.events.pipe(filter(event => event instanceof NavigationStart || event instanceof NavigationEnd), distinctUntilChanged((x, y) => x.id === y.id), map(event => ({ url: event.url })));
2597
- }
2598
- //
2599
- // TODO: Animation improvement: Try adding a full component animation that
2600
- // queries the <ng-content> and <router-outlet> blocks. When the outlet
2601
- // activates, set the animation state to a transition that moves both blocks
2602
- // together.
2603
- //
2604
- let _uid = 0;
2605
- class HierarchyRouterOutletComponent {
2606
- constructor(_route, _router) {
2607
- this._route = _route;
2608
- this._router = _router;
2609
- this._uid = _uid++;
2610
- this._ngUnsubscribe = new Subject();
2611
- this.animState = 'isRight';
2612
- // animState = ''
2613
- this.outletActive = false;
2614
- this.ngContentVisible = true;
2615
- this._router.events.pipe(filter(event => event instanceof NavigationEnd),
2616
- // tap(v => console.log(`_hasChildren()[${this._uid}]`, this._hasChildren())),
2617
- takeUntil(this._ngUnsubscribe))
2618
- .subscribe();
2619
- // routeChanges(this._router)
2620
- // .pipe(
2621
- // untilDestroyed(this),
2622
- // tap(() => {
2623
- // // if (this._hasChildren()) {
2624
- // // this.animState = 'isLeft'
2625
- // // } else {
2626
- // // this.animState = 'isRight'
2627
- // // }
2628
- // })
2629
- // )
2630
- // .subscribe(v => console.log(`routeChanges[${this._uid}]`, v))
2631
- }
2632
- ngOnDestroy() {
2633
- this._ngUnsubscribe.next(undefined);
2634
- this._ngUnsubscribe.complete();
2635
- }
2636
- _hasChildren() {
2637
- const count = this._route.pathFromRoot.length - 1;
2638
- let countFull = 0;
2639
- if (this._router.parseUrl(this._router.url).root.children.primary) {
2640
- countFull = this._router.parseUrl(this._router.url).root.children.primary.segments.length;
2641
- }
2642
- // console.log(`_hasChildren[${this._uid}]`, { count, countFull })
2643
- return countFull > count;
2644
- }
2645
- prepareRoute(outlet) {
2646
- // console.log(`outlet[${this._uid}]`, outlet, this.animState, this._hasChildren(), this.outletActive)
2647
- if (outlet.isActivated) {
2648
- // console.log(outlet.isActivated)
2649
- // console.log(outlet.component)
2650
- // console.log(this.animState)
2651
- return this.animState;
2652
- }
2653
- else {
2654
- return undefined;
2655
- }
2656
- // console.log(`prepareRoute[${this._uid}]`, this.animState, this._hasChildren())
2657
- // console.log('activatedRouteData', outlet && outlet.activatedRouteData)
2658
- // if (outlet && outlet.isActivated) {
2659
- // console.log('activatedRoute', outlet.activatedRoute && outlet.activatedRoute.snapshot.url)
2660
- // }
2661
- // return outlet && outlet.activatedRouteData && outlet.activatedRouteData['animation']
2662
- // console.log('')
2663
- // return this.animState
2664
- }
2665
- outletActivate(event) {
2666
- // console.log(`outletActivate[${this._uid}]`, event)
2667
- this.outletActive = true;
2668
- }
2669
- outletDeactivate(event) {
2670
- // console.log(`outletDeactivate[${this._uid}]`, event)
2671
- this.outletActive = false;
2672
- }
2673
- routeAnimationsStart(event) {
2674
- // console.log('routeAnimationsStart', event)
2675
- this.ngContentVisible = true;
2676
- }
2677
- routeAnimationsDone(event) {
2678
- // console.log('routeAnimationsDone', event)
2679
- this.ngContentVisible = !this.outletActive;
2680
- }
2681
- }
2682
- HierarchyRouterOutletComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HierarchyRouterOutletComponent, deps: [{ token: i1$2.ActivatedRoute }, { token: i1$2.Router }], target: i0.ɵɵFactoryTarget.Component });
2683
- HierarchyRouterOutletComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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: [
2684
- // fader,
2685
- slider,
2686
- // transformer,
2687
- // stepper,
2688
- // sideToSide
2689
- // contentLeave
2690
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2691
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HierarchyRouterOutletComponent, decorators: [{
2692
- type: Component,
2693
- args: [{ selector: 'seam-hierarchy-router-outlet', animations: [
2694
- // fader,
2695
- slider,
2696
- // transformer,
2697
- // stepper,
2698
- // sideToSide
2699
- // contentLeave
2700
- ], 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"] }]
2701
- }], ctorParameters: function () { return [{ type: i1$2.ActivatedRoute }, { type: i1$2.Router }]; } });
2702
-
2703
- class HierarchyLevelResolver {
2704
- resolve(route, state) {
2705
- // console.log('[HierarchyLevelResolver]', route)
2706
- // console.log('[HierarchyLevelResolver]', state)
2707
- return this._getMaxHierLevel(route);
2708
- }
2709
- _getMaxHierLevel(route) {
2710
- let curr = route;
2711
- while (curr.parent) {
2712
- curr = curr.parent;
2713
- if (curr.data['hierLevel']) {
2714
- return curr.data['hierLevel'] + 1;
2715
- }
2716
- }
2717
- return 0;
2718
- }
2719
- }
2720
- HierarchyLevelResolver.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HierarchyLevelResolver, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2721
- HierarchyLevelResolver.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HierarchyLevelResolver, providedIn: 'root' });
2722
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HierarchyLevelResolver, decorators: [{
2723
- type: Injectable,
2724
- args: [{ providedIn: 'root' }]
2725
- }] });
2726
-
2727
- class TheSeamDynamicRouterModule {
2728
- }
2729
- TheSeamDynamicRouterModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDynamicRouterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2730
- TheSeamDynamicRouterModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDynamicRouterModule, declarations: [HierarchyRouterOutletComponent], imports: [CommonModule,
2731
- RouterModule], exports: [HierarchyRouterOutletComponent] });
2732
- TheSeamDynamicRouterModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDynamicRouterModule, imports: [CommonModule,
2733
- RouterModule] });
2734
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamDynamicRouterModule, decorators: [{
2735
- type: NgModule,
2736
- args: [{
2737
- declarations: [
2738
- HierarchyRouterOutletComponent
2739
- ],
2740
- imports: [
2741
- CommonModule,
2742
- RouterModule
2743
- ],
2744
- exports: [
2745
- HierarchyRouterOutletComponent
2746
- ]
2747
- }]
2748
- }] });
2749
-
2750
- class TheSeamSchemaFormCheckboxComponent {
2751
- constructor(_jsf) {
2752
- this._jsf = _jsf;
2753
- this.controlDisabled = false;
2754
- this.boundControl = false;
2755
- this.trueValue = true;
2756
- this.falseValue = false;
2757
- }
2758
- ngOnInit() {
2759
- var _a, _b;
2760
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
2761
- this._jsf.initializeControl(this);
2762
- if (this.controlValue === null || this.controlValue === undefined) {
2763
- this.controlValue = (_b = this.options) === null || _b === void 0 ? void 0 : _b.title;
2764
- }
2765
- }
2766
- updateValue(event) {
2767
- event.preventDefault();
2768
- this._jsf.updateValue(this, event.target.checked ? this.trueValue : this.falseValue);
2769
- }
2770
- get isChecked() {
2771
- return this._jsf.getFormControlValue(this) === this.trueValue;
2772
- }
2773
- }
2774
- TheSeamSchemaFormCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormCheckboxComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2775
- TheSeamSchemaFormCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormCheckboxComponent, isStandalone: true, 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: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { 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: TheSeamCheckboxComponent, selector: "seam-checkbox", inputs: ["tabIndex", "id", "aria-label", "aria-labelledby", "required", "checked", "disabled", "indeterminate", "name", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["seamCheckbox"] }] });
2776
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormCheckboxComponent, decorators: [{
2777
- type: Component,
2778
- args: [{ selector: 'seam-schema-form-checkbox', standalone: true, imports: [
2779
- CommonModule,
2780
- ReactiveFormsModule,
2781
- JsonSchemaFormModule,
2782
- TheSeamFormFieldModule,
2783
- TheSeamCheckboxComponent,
2784
- ], 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" }]
2785
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2786
- type: Input
2787
- }], layoutIndex: [{
2788
- type: Input
2789
- }], dataIndex: [{
2790
- type: Input
2791
- }] } });
2792
-
2793
- class TheSeamSchemaFormInputComponent {
2794
- constructor(_jsf) {
2795
- this._jsf = _jsf;
2796
- this.controlDisabled = false;
2797
- this.boundControl = false;
2798
- this.autoCompleteList = [];
2799
- }
2800
- ngOnInit() {
2801
- var _a;
2802
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
2803
- this._jsf.initializeControl(this);
2804
- }
2805
- updateValue(event) {
2806
- this._jsf.updateValue(this, event.target.value);
2807
- }
2808
- }
2809
- TheSeamSchemaFormInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormInputComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2810
- TheSeamSchemaFormInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormInputComponent, isStandalone: true, selector: "seam-schema-form-input", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div [class]=\"options?.htmlClass || ''\">\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\" [required]=\"options?.required\"></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\" [required]=\"options?.required\"></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</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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: "ngmodule", type: ReactiveFormsModule }, { 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: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { 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], seam-rich-text[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 });
2811
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormInputComponent, decorators: [{
2812
- type: Component,
2813
- args: [{ selector: 'seam-schema-form-input', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
2814
- CommonModule,
2815
- ReactiveFormsModule,
2816
- JsonSchemaFormModule,
2817
- TheSeamFormFieldModule,
2818
- ], template: "<div [class]=\"options?.htmlClass || ''\">\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\" [required]=\"options?.required\"></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\" [required]=\"options?.required\"></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</div>\n", styles: [":host{display:block}\n"] }]
2819
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2820
- type: Input
2821
- }], layoutIndex: [{
2822
- type: Input
2823
- }], dataIndex: [{
2824
- type: Input
2825
- }] } });
2826
-
2827
- class TheSeamSchemaFormNumberComponent {
2828
- constructor(jsf) {
2829
- this.jsf = jsf;
2830
- this.controlDisabled = false;
2831
- this.boundControl = false;
2832
- this.allowNegative = true;
2833
- this.allowDecimal = true;
2834
- this.allowExponents = false;
2835
- this.lastValidNumber = '';
2836
- }
2837
- ngOnInit() {
2838
- var _a, _b;
2839
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
2840
- this.jsf.initializeControl(this);
2841
- if (((_b = this.layoutNode) === null || _b === void 0 ? void 0 : _b.dataType) === 'integer') {
2842
- this.allowDecimal = false;
2843
- }
2844
- }
2845
- updateValue(event) {
2846
- this.jsf.updateValue(this, event.target.value);
2847
- }
2848
- }
2849
- TheSeamSchemaFormNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormNumberComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2850
- TheSeamSchemaFormNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormNumberComponent, isStandalone: true, 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\" [required]=\"options?.required\"></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\" [required]=\"options?.required\"></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: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { 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], seam-rich-text[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 });
2851
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormNumberComponent, decorators: [{
2852
- type: Component,
2853
- args: [{ selector: 'seam-schema-form-number', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
2854
- CommonModule,
2855
- ReactiveFormsModule,
2856
- JsonSchemaFormModule,
2857
- TheSeamFormFieldModule,
2858
- ], 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\" [required]=\"options?.required\"></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\" [required]=\"options?.required\"></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"] }]
2859
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2860
- type: Input
2861
- }], layoutIndex: [{
2862
- type: Input
2863
- }], dataIndex: [{
2864
- type: Input
2865
- }] } });
2866
-
2867
- class TheSeamSchemaFormSelectComponent {
2868
- constructor(_jsf) {
2869
- this._jsf = _jsf;
2870
- this.controlDisabled = false;
2871
- this.boundControl = false;
2872
- this.selectList = [];
2873
- this.isArray = isArray;
2874
- }
2875
- ngOnInit() {
2876
- var _a;
2877
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
2878
- this.selectList = buildTitleMap(this.options.titleMap || this.options.enumNames, this.options.enum, !!this.options.required, !!this.options.flatList);
2879
- this._jsf.initializeControl(this);
2880
- }
2881
- updateValue(event) {
2882
- this._jsf.updateValue(this, event.value);
2883
- }
2884
- }
2885
- TheSeamSchemaFormSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormSelectComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
2886
- TheSeamSchemaFormSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormSelectComponent, isStandalone: true, selector: "seam-schema-form-select", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div [class]=\"options?.htmlClass || ''\">\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 [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</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { 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], seam-rich-text[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: "ngmodule", type: NgSelectModule }, { kind: "component", type: i5$1.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$1.ɵf, selector: "[ng-option-tmp]" }, { kind: "directive", type: i5$1.ɵh, selector: "[ng-label-tmp]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2887
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormSelectComponent, decorators: [{
2888
- type: Component,
2889
- args: [{ selector: 'seam-schema-form-select', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
2890
- CommonModule,
2891
- ReactiveFormsModule,
2892
- JsonSchemaFormModule,
2893
- TheSeamFormFieldModule,
2894
- NgSelectModule,
2895
- ], template: "<div [class]=\"options?.htmlClass || ''\">\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 [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</div>\n", styles: [":host{display:block}\n"] }]
2896
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
2897
- type: Input
2898
- }], layoutIndex: [{
2899
- type: Input
2900
- }], dataIndex: [{
2901
- type: Input
2902
- }] } });
2903
-
2904
- // NOTE: This component is a little hacky, because I am basically creating a
2905
- // data widget that acts like a data and 'submit' widget at the same time.
2906
- //
2907
- // TODO: Try and think of a nicer way to implement this, but still make sense
2908
- // from a schema definition. The library may need to me forked to actually
2909
- // support this in the way I expect, but maybe there is another way.
2910
- class TheSeamSchemaFormSubmitSplitComponent {
2911
- constructor(_jsf) {
2912
- this._jsf = _jsf;
2913
- /** @ignore */
2914
- this._ngUnsubscribe = new Subject();
2915
- this.controlDisabled = false;
2916
- this.boundControl = false;
2917
- this._buttonLabel = '';
2918
- this._dropdownDisabled = false;
2919
- this._selectList = [];
2920
- }
2921
- /** @ignore */
2922
- ngOnInit() {
2923
- var _a;
2924
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
2925
- this._jsf.initializeControl(this);
2926
- // NOTE: This is commented out, because there is a bug with submit widgets
2927
- // manually defined in layout. All nodes initialized from the provided
2928
- // layout have their options populated from the defaults and 'disabled' is
2929
- // on of the default properties, so the 'disableInvalidSubmit' condition
2930
- // never gets reached.
2931
- //
2932
- // My initial idea for fixing would be to check if the disabled property
2933
- // exists and is a boolean, or possibly anything defined that can coerce
2934
- // into a boolean. I can't think of a reason disabled should be anything
2935
- // else, so that may be an acceptable fix, but I don't want to enable that
2936
- // yet.
2937
- //
2938
- // if (hasOwn(this.options, 'disabled')) {
2939
- // console.log('[TheSeamSchemaFormSubmitSplitComponent] hasDisabled', this.options.disabled)
2940
- // this.controlDisabled = this.options.disabled
2941
- // } else
2942
- if (this._jsf.formOptions.disableInvalidSubmit) {
2943
- this.controlDisabled = !this._jsf.isValid;
2944
- this._jsf.isValidChanges.subscribe(isValid => this.controlDisabled = !isValid);
2945
- }
2946
- if (this.controlValue === null || this.controlValue === undefined) {
2947
- this.controlValue = this.options.title;
2948
- }
2949
- if (hasOwn(this.options, 'title')) {
2950
- this._buttonLabel = this.options.title;
2951
- }
2952
- this._initDropdown();
2953
- // console.log('this', this)
2954
- }
2955
- /** @ignore */
2956
- ngOnDestroy() {
2957
- this._ngUnsubscribe.next(undefined);
2958
- this._ngUnsubscribe.complete();
2959
- }
2960
- updateValue(event) {
2961
- var _a;
2962
- if (typeof ((_a = this.options) === null || _a === void 0 ? void 0 : _a.onClick) === 'function') {
2963
- this.options.onClick(event);
2964
- }
2965
- else {
2966
- this._jsf.updateValue(this, event.target.value);
2967
- }
2968
- }
2969
- _initDropdown() {
2970
- var _a, _b, _c, _d, _e;
2971
- if (!hasOwn(this.layoutNode, 'items') || !(((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.items) || []).length) {
2972
- return;
2973
- }
2974
- if (isDevMode()) {
2975
- if (((_b = this.layoutNode) === null || _b === void 0 ? void 0 : _b.items) && ((_c = this.layoutNode) === null || _c === void 0 ? void 0 : _c.items.length) > 1) {
2976
- // eslint-disable-next-line no-console
2977
- console.warn(`TheSeamSchemaFormSubmitSplitComponent only supports one item.` +
2978
- ` items after index 0 will be ignored.`);
2979
- }
2980
- }
2981
- const idx = 0;
2982
- const item = ((_d = this.layoutNode) === null || _d === void 0 ? void 0 : _d.items)[idx] || {};
2983
- this._dropdownObj = {
2984
- layoutNode: item,
2985
- layoutIndex: (this.layoutIndex || []).concat(idx),
2986
- dataIndex: ((_e = this.layoutNode) === null || _e === void 0 ? void 0 : _e.dataType) === 'array' ? (this.dataIndex || []).concat(idx) : this.dataIndex,
2987
- options: item.options || {}
2988
- };
2989
- this._jsf.initializeControl(this._dropdownObj);
2990
- const items = buildTitleMap(this._dropdownObj.options.titleMap || this._dropdownObj.options.enumNames, this._dropdownObj.options.enum, !!this._dropdownObj.options.required, !!this._dropdownObj.options.flatList);
2991
- this._selectList = items;
2992
- // TODO: Should this be checking if the control is bound?
2993
- const dropdownControl = this._getDropdownControl();
2994
- if (!dropdownControl) {
2995
- return;
2996
- }
2997
- observeControlValue(dropdownControl).pipe(takeUntil(this._ngUnsubscribe)).subscribe(value => {
2998
- this._setSelectListCheckedProp(value);
2999
- this._selectedItem = this._getSelectedItem();
3000
- });
3001
- observeControlStatus(dropdownControl).pipe(takeUntil(this._ngUnsubscribe)).subscribe(value => {
3002
- this._dropdownDisabled = dropdownControl.disabled;
3003
- });
3004
- }
3005
- _getDropdownControl() {
3006
- return this._dropdownObj.formControl;
3007
- }
3008
- _setSelectListCheckedProp(value) {
3009
- const items = this._selectList;
3010
- for (const item of items) {
3011
- if (item.value === value) {
3012
- item.checked = true;
3013
- }
3014
- else if (item.checked) {
3015
- item.checked = false;
3016
- }
3017
- }
3018
- this._selectList = [...items];
3019
- }
3020
- _getSelectedItem() {
3021
- return (this._selectList || []).find(x => x.checked === true);
3022
- }
3023
- _setDropdownValue(value) {
3024
- const formControl = this._getDropdownControl();
3025
- formControl === null || formControl === void 0 ? void 0 : formControl.setValue(value);
3026
- }
3027
- }
3028
- TheSeamSchemaFormSubmitSplitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormSubmitSplitComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
3029
- TheSeamSchemaFormSubmitSplitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormSubmitSplitComponent, isStandalone: true, 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: "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: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { kind: "ngmodule", type: TheSeamMenuModule }, { 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", "seamMenuTogglePositionsOffsetY"], outputs: ["menuToggle", "menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i3$2.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "ngmodule", type: TheSeamButtonsModule }, { kind: "component", type: i4$1.TheSeamButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }] });
3030
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormSubmitSplitComponent, decorators: [{
3031
- type: Component,
3032
- args: [{ selector: 'seam-schema-form-submit-split', standalone: true, imports: [
3033
- CommonModule,
3034
- ReactiveFormsModule,
3035
- JsonSchemaFormModule,
3036
- TheSeamFormFieldModule,
3037
- TheSeamMenuModule,
3038
- TheSeamButtonsModule,
3039
- ], 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"] }]
3040
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
3041
- type: Input
3042
- }], layoutIndex: [{
3043
- type: Input
3044
- }], dataIndex: [{
3045
- type: Input
3046
- }] } });
3047
-
3048
- class TheSeamSchemaFormDividerComponent {
3049
- ngOnInit() {
3050
- this.options = this.layoutNode.options || {};
3051
- }
3052
- }
3053
- TheSeamSchemaFormDividerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormDividerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
3054
- TheSeamSchemaFormDividerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormDividerComponent, isStandalone: true, selector: "seam-schema-form-divider", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: `<hr [class]="options?.htmlClass" />`, isInline: true, styles: [":host{display:block}\n"] });
3055
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormDividerComponent, decorators: [{
3056
- type: Component,
3057
- args: [{ selector: 'seam-schema-form-divider', template: `<hr [class]="options?.htmlClass" />`, standalone: true, styles: [":host{display:block}\n"] }]
3058
- }], propDecorators: { layoutNode: [{
3059
- type: Input
3060
- }], layoutIndex: [{
3061
- type: Input
3062
- }], dataIndex: [{
3063
- type: Input
3064
- }] } });
3065
-
3066
- class TheSeamSchemaFormTelComponent {
3067
- constructor(_jsf) {
3068
- this._jsf = _jsf;
3069
- this.controlDisabled = false;
3070
- this.boundControl = false;
3071
- this.autoCompleteList = [];
3072
- }
3073
- ngOnInit() {
3074
- var _a, _b;
3075
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
3076
- this._jsf.initializeControl(this);
3077
- console.log(this.controlValue);
3078
- console.log((_b = this.formControl) === null || _b === void 0 ? void 0 : _b.value);
3079
- }
3080
- updateValue(event) {
3081
- this._jsf.updateValue(this, event.target.value);
3082
- }
3083
- }
3084
- TheSeamSchemaFormTelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormTelComponent, deps: [{ token: i1$3.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
3085
- TheSeamSchemaFormTelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormTelComponent, isStandalone: true, selector: "seam-schema-form-tel", 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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tel-input\n seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\">\n </seam-tel-input>\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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tel-input\n 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 [readonly]=\"options?.readonly ? 'readonly' : null\"\n [disabled]=\"controlDisabled\">\n </seam-tel-input>\n</seam-form-field>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { 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], seam-rich-text[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: "ngmodule", type: TheSeamTelInputModule }, { kind: "component", type: i5$2.TheSeamTelInputComponent, selector: "seam-tel-input", inputs: ["required", "disabled", "tabIndex", "name", "value"], outputs: ["change"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
3086
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormTelComponent, decorators: [{
3087
- type: Component,
3088
- args: [{ selector: 'seam-schema-form-tel', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
3089
- CommonModule,
3090
- ReactiveFormsModule,
3091
- JsonSchemaFormModule,
3092
- TheSeamFormFieldModule,
3093
- TheSeamTelInputModule,
3094
- ], 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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tel-input\n seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [required]=\"options?.required\"\n [readonly]=\"options?.readonly ? 'readonly' : null\">\n </seam-tel-input>\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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tel-input\n 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 [readonly]=\"options?.readonly ? 'readonly' : null\"\n [disabled]=\"controlDisabled\">\n </seam-tel-input>\n</seam-form-field>\n" }]
3095
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
3096
- type: Input
3097
- }], layoutIndex: [{
3098
- type: Input
3099
- }], dataIndex: [{
3100
- type: Input
3101
- }] } });
3102
-
3103
- class TheSeamSchemaFormTiledSelectComponent {
3104
- constructor(_jsf, _platform) {
3105
- this._jsf = _jsf;
3106
- this._platform = _platform;
3107
- this.controlDisabled = false;
3108
- this.boundControl = false;
3109
- this.tiles = [];
3110
- this.layout = 'grid';
3111
- this.multiple = false;
3112
- this.selectionToggleable = true;
3113
- this.tileBackdrop = false;
3114
- this.showSelectedIcon = true;
3115
- this.animationsDisabled = this._platform.IOS;
3116
- }
3117
- ngOnInit() {
3118
- var _a;
3119
- this.options = ((_a = this.layoutNode) === null || _a === void 0 ? void 0 : _a.options) || {};
3120
- this._jsf.initializeControl(this);
3121
- console.log(this.options);
3122
- console.log(this.layoutNode);
3123
- this.tiles = this.options.tiles || [];
3124
- }
3125
- updateValue(event) {
3126
- this._jsf.updateValue(this, event.target.value);
3127
- }
3128
- }
3129
- TheSeamSchemaFormTiledSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormTiledSelectComponent, deps: [{ token: i1$3.JsonSchemaFormService }, { token: i2$3.Platform }], target: i0.ɵɵFactoryTarget.Component });
3130
- TheSeamSchemaFormTiledSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormTiledSelectComponent, isStandalone: true, selector: "seam-schema-form-tiled-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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tiled-select\n seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [attr.name]=\"controlName\"\n [required]=\"options?.required\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [tiles]=\"tiles\"\n [layout]=\"layout\"\n [multiple]=\"multiple\"\n [selectionToggleable]=\"selectionToggleable\"\n [tileBackdrop]=\"tileBackdrop\"\n [showSelectedIcon]=\"showSelectedIcon\"\n [animationsDisabled]=\"animationsDisabled\">\n </seam-tiled-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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tiled-select\n seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [attr.name]=\"controlName\"\n [attr.required]=\"options?.required\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [value]=\"controlValue\"\n (input)=\"updateValue($event)\"\n [disabled]=\"controlDisabled\"\n [tiles]=\"tiles\"\n [layout]=\"layout\"\n [multiple]=\"multiple\"\n [selectionToggleable]=\"selectionToggleable\"\n [tileBackdrop]=\"tileBackdrop\"\n [showSelectedIcon]=\"showSelectedIcon\"\n [animationsDisabled]=\"animationsDisabled\">\n </seam-tiled-select>\n</seam-form-field>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { 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.FormFieldLabelTplDirective, selector: "[seamFormFieldLabelTpl]" }, { kind: "component", type: i4$3.FormFieldRequiredIndicatorComponent, selector: "seam-form-field-required-indicator", inputs: ["required"] }, { kind: "ngmodule", type: TheSeamTiledSelectModule }, { kind: "component", type: i6$1.TheSeamTiledSelectComponent, selector: "seam-tiled-select", inputs: ["layout", "tiles", "value", "disabled", "multiple", "selectionToggleable", "tileBackdrop", "showSelectedIcon", "animationsDisabled"], outputs: ["change"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
3131
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormTiledSelectComponent, decorators: [{
3132
- type: Component,
3133
- args: [{ selector: 'seam-schema-form-tiled-select', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
3134
- CommonModule,
3135
- ReactiveFormsModule,
3136
- JsonSchemaFormModule,
3137
- TheSeamFormFieldModule,
3138
- TheSeamTiledSelectModule,
3139
- ], 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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tiled-select\n seamInput\n [formControl]=\"$any(formControl)\"\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [attr.name]=\"controlName\"\n [required]=\"options?.required\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [tiles]=\"tiles\"\n [layout]=\"layout\"\n [multiple]=\"multiple\"\n [selectionToggleable]=\"selectionToggleable\"\n [tileBackdrop]=\"tileBackdrop\"\n [showSelectedIcon]=\"showSelectedIcon\"\n [animationsDisabled]=\"animationsDisabled\">\n </seam-tiled-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\" [required]=\"options?.required\"></seam-form-field-required-indicator>\n </ng-container>\n </ng-template>\n <seam-tiled-select\n seamInput\n [ngClass]=\"options?.fieldHtmlClass\"\n [id]=\"'control' + layoutNode?._id\"\n [attr.name]=\"controlName\"\n [attr.required]=\"options?.required\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [value]=\"controlValue\"\n (input)=\"updateValue($event)\"\n [disabled]=\"controlDisabled\"\n [tiles]=\"tiles\"\n [layout]=\"layout\"\n [multiple]=\"multiple\"\n [selectionToggleable]=\"selectionToggleable\"\n [tileBackdrop]=\"tileBackdrop\"\n [showSelectedIcon]=\"showSelectedIcon\"\n [animationsDisabled]=\"animationsDisabled\">\n </seam-tiled-select>\n</seam-form-field>\n" }]
3140
- }], ctorParameters: function () { return [{ type: i1$3.JsonSchemaFormService }, { type: i2$3.Platform }]; }, propDecorators: { layoutNode: [{
3141
- type: Input
3142
- }], layoutIndex: [{
3143
- type: Input
3144
- }], dataIndex: [{
3145
- type: Input
3146
- }] } });
3147
-
3148
- class TheSeamSchemaFormFrameworkComponent {
3149
- }
3150
- TheSeamSchemaFormFrameworkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormFrameworkComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
3151
- TheSeamSchemaFormFrameworkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TheSeamSchemaFormFrameworkComponent, selector: "seam-schema-form-framework", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, host: { properties: { "attr.data-name": "layoutNode?.node", "attr.data-data-pointer": "layoutNode?.dataPointer" } }, 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"] }] });
3152
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormFrameworkComponent, decorators: [{
3153
- type: Component,
3154
- args: [{ selector: 'seam-schema-form-framework', host: {
3155
- '[attr.data-name]': 'layoutNode?.node',
3156
- '[attr.data-data-pointer]': 'layoutNode?.dataPointer',
3157
- }, template: "<select-widget-widget\n [dataIndex]=\"$any(dataIndex)\"\n [layoutIndex]=\"$any(layoutIndex)\"\n [layoutNode]=\"layoutNode\">\n</select-widget-widget>\n" }]
3158
- }], propDecorators: { layoutNode: [{
3159
- type: Input
3160
- }], layoutIndex: [{
3161
- type: Input
3162
- }], dataIndex: [{
3163
- type: Input
3164
- }] } });
3165
-
3166
- const THESEAM_SCHEMA_FRAMEWORK_OVERRIDES = new InjectionToken('THESEAM_SCHEMA_FRAMEWORK_OVERRIDES');
3167
- function extendFramework(toExtend, extendFrameworkOrName) {
3168
- // console.log('extendFramework', toExtend, extendFrameworkOrName)
3169
- const _overrides = inject(Framework, { optional: true });
3170
- const overrides = typeof extendFrameworkOrName === 'string'
3171
- ? (_overrides || []).filter(x => x.name === extendFrameworkOrName)
3172
- : [extendFrameworkOrName];
3173
- // console.log(_overrides, overrides)
3174
- if (overrides) {
3175
- for (const override of overrides) {
3176
- // console.log('override', override)
3177
- if (hasProperty(override, 'framework')) {
3178
- toExtend.framework = override.framework;
3179
- }
3180
- if (hasProperty(override, 'widgets')) {
3181
- toExtend.widgets = Object.assign(Object.assign({}, toExtend.widgets), override.widgets);
3182
- }
3183
- if (hasProperty(override, 'stylesheets')) {
3184
- toExtend.stylesheets = Object.assign(Object.assign({}, toExtend.stylesheets), override.stylesheets);
3185
- }
3186
- if (hasProperty(override, 'scripts')) {
3187
- toExtend.scripts = Object.assign(Object.assign({}, toExtend.scripts), override.scripts);
3188
- }
3189
- }
3190
- }
3191
- }
3192
- class TheSeamFramework extends Framework {
3193
- constructor(_overrides) {
3194
- super();
3195
- this.name = 'seam-framework';
3196
- this.framework = TheSeamSchemaFormFrameworkComponent;
3197
- this.widgets = {
3198
- 'checkbox': TheSeamSchemaFormCheckboxComponent,
3199
- // 'submit': TheSeamSchemaFormSubmitComponent,
3200
- 'submit': TheSeamSchemaFormSubmitSplitComponent,
3201
- 'text': TheSeamSchemaFormInputComponent,
3202
- 'number': TheSeamSchemaFormNumberComponent,
3203
- 'select': TheSeamSchemaFormSelectComponent,
3204
- 'divider': TheSeamSchemaFormDividerComponent,
3205
- 'tel': TheSeamSchemaFormTelComponent,
3206
- 'tiled-select': TheSeamSchemaFormTiledSelectComponent
3207
- // 'date': // TODO: Implement
3208
- // 'file': // TODO: Implement
3209
- // 'image': // TODO: Implement
3210
- // 'richtext': // TODO: Implement
3211
- // 'tabs': // TODO: Implement
3212
- // 'wizard': // TODO: Implement
3213
- // 'card': // TODO: Implement
3214
- // 'map': // TODO: Implement
3215
- };
3216
- // console.log('TheSeamFramework', _overrides, this)
3217
- if (_overrides) {
3218
- for (const override of _overrides) {
3219
- // console.log('override', override)
3220
- if (hasProperty(override, 'widgets')) {
3221
- this.widgets = Object.assign(Object.assign({}, this.widgets), override.widgets);
3222
- }
3223
- }
3224
- }
3225
- }
3226
- }
3227
- TheSeamFramework.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamFramework, deps: [{ token: THESEAM_SCHEMA_FRAMEWORK_OVERRIDES, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
3228
- TheSeamFramework.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamFramework });
3229
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamFramework, decorators: [{
3230
- type: Injectable
3231
- }], ctorParameters: function () {
3232
- return [{ type: undefined, decorators: [{
3233
- type: Optional
3234
- }, {
3235
- type: Inject,
3236
- args: [THESEAM_SCHEMA_FRAMEWORK_OVERRIDES]
3237
- }] }];
3238
- } });
3239
-
3240
- class TheSeamSchemaFormModule {
3241
- }
3242
- TheSeamSchemaFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3243
- TheSeamSchemaFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormModule, declarations: [TheSeamSchemaFormFrameworkComponent], imports: [CommonModule,
3244
- JsonSchemaFormModule,
3245
- WidgetLibraryModule], exports: [TheSeamSchemaFormFrameworkComponent,
3246
- JsonSchemaFormModule] });
3247
- TheSeamSchemaFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormModule, providers: [
3248
- JsonSchemaFormService,
3249
- FrameworkLibraryService,
3250
- WidgetLibraryService,
3251
- { provide: Framework, useClass: TheSeamFramework, multi: true }
3252
- ], imports: [CommonModule,
3253
- JsonSchemaFormModule,
3254
- WidgetLibraryModule, JsonSchemaFormModule] });
3255
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamSchemaFormModule, decorators: [{
3256
- type: NgModule,
3257
- args: [{
3258
- declarations: [
3259
- TheSeamSchemaFormFrameworkComponent
3260
- ],
3261
- imports: [
3262
- CommonModule,
3263
- JsonSchemaFormModule,
3264
- WidgetLibraryModule,
3265
- ],
3266
- providers: [
3267
- JsonSchemaFormService,
3268
- FrameworkLibraryService,
3269
- WidgetLibraryService,
3270
- { provide: Framework, useClass: TheSeamFramework, multi: true }
3271
- ],
3272
- exports: [
3273
- TheSeamSchemaFormFrameworkComponent,
3274
- JsonSchemaFormModule
3275
- ],
3276
- }]
3277
- }] });
3278
-
3279
- function isHorizontalNavItemType(item, type) {
3280
- return item.itemType === type;
3281
- }
3282
- function isHorizontalNavItemActive(item) {
3283
- var _a, _b;
3284
- return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.active) !== null && _b !== void 0 ? _b : false;
3285
- }
3286
- function isHorizontalNavItemExpanded(item) {
3287
- var _a, _b;
3288
- return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.expanded) !== null && _b !== void 0 ? _b : false;
3289
- }
3290
- function isHorizontalNavItemFocused(item) {
3291
- var _a, _b;
3292
- return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.focused) !== null && _b !== void 0 ? _b : false;
3293
- }
3294
- function horizontalNavItemHasChildren(item) {
3295
- return horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children') && item.children.length > 0;
3296
- }
3297
- function horizontalNavItemCanHaveChildren(item) {
3298
- return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link');
3299
- }
3300
- function horizontalNavItemHasActiveChild(item) {
3301
- if (!horizontalNavItemHasChildren(item)) {
3302
- return false;
3303
- }
3304
- for (const child of item.children) {
3305
- if (getHorizontalNavItemStateProp(child, 'active') || horizontalNavItemHasActiveChild(child)) {
3306
- return true;
3307
- }
3308
- }
3309
- return false;
3310
- }
3311
- function horizontalNavItemHasExpandedChild(item) {
3312
- if (!horizontalNavItemHasChildren(item)) {
3313
- return false;
3314
- }
3315
- for (const child of item.children) {
3316
- if (getHorizontalNavItemStateProp(child, 'expanded')) {
3317
- return true;
3318
- }
3319
- }
3320
- return false;
3321
- }
3322
- function horizontalNavItemCanBeActive(item) {
3323
- return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link');
3324
- }
3325
- function horizontalNavItemCanExpand(item) {
3326
- return horizontalNavItemCanHaveChildren(item);
3327
- }
3328
- function findHorizontalNavLinkItems(items) {
3329
- const linkItems = [];
3330
- const _fn = (_items) => {
3331
- for (const item of _items) {
3332
- if (isHorizontalNavItemType(item, 'link')) {
3333
- linkItems.push(item);
3334
- }
3335
- if (horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children')) {
3336
- _fn(item.children);
3337
- }
3338
- }
3339
- };
3340
- _fn(items);
3341
- return linkItems;
3342
- }
3343
- function setHorizontalNavItemStateProp(item, prop, value) {
3344
- if (hasProperty(item, '__state')) {
3345
- item.__state[prop] = value;
3346
- }
3347
- }
3348
- function getHorizontalNavItemStateProp(item, prop) {
3349
- return setDefaultHorizontalNavItemState(item).__state[prop];
3350
- }
3351
- function setDefaultHorizontalNavItemState(item) {
3352
- if (hasProperty(item, '__state')) {
3353
- return item;
3354
- }
3355
- item.__state = {
3356
- active: false,
3357
- expanded: false,
3358
- focused: false
3359
- };
3360
- // TODO: See if there is a nice way to fix the typing for this.
3361
- return item;
3362
- }
3363
- function areSameHorizontalNavItem(item1, item2) {
3364
- if (isNullOrUndefined(item1) || isNullOrUndefined(item2)) {
3365
- return false;
3366
- }
3367
- if (item1.itemType !== item2.itemType) {
3368
- return false;
3369
- }
3370
- if (isHorizontalNavItemType(item1, 'title') && isHorizontalNavItemType(item2, 'title')) {
3371
- return item1.label === item2.label;
3372
- }
3373
- else if (isHorizontalNavItemType(item1, 'divider') && isHorizontalNavItemType(item2, 'divider')) {
3374
- return item1.label === item2.label;
3375
- }
3376
- else if (isHorizontalNavItemType(item1, 'basic') && isHorizontalNavItemType(item2, 'basic')) {
3377
- return item1.label === item2.label;
3378
- }
3379
- else if (isHorizontalNavItemType(item1, 'link') && isHorizontalNavItemType(item2, 'link')) {
3380
- return item1.label === item2.label && item1.link === item2.link;
3381
- }
3382
- else if (isHorizontalNavItemType(item1, 'button') && isHorizontalNavItemType(item2, 'button')) {
3383
- return item1.onClick === item2.onClick;
3384
- }
3385
- return false;
3386
- }
3387
-
3388
- class TheSeamNavService {
3389
- constructor(_router) {
3390
- this._router = _router;
3391
- this._updatingCount = new BehaviorSubject(0);
3392
- this.itemChanged = new Subject();
3393
- this.loading$ = this._updatingCount.pipe(map(count => count > 0), distinctUntilChanged(), shareReplay({ bufferSize: 1, refCount: true }));
3394
- }
3395
- createItemsObservable(items) {
3396
- return defer(() => {
3397
- this.updateItemsStates(items);
3398
- this.updateRouterFocusedItem(items);
3399
- return new Observable((subscriber) => {
3400
- const stateChangeSub = this.itemChanged.pipe(switchMap(change => {
3401
- if (change.prop === 'focused' && change.newValue) {
3402
- this.updateFocusedItem(items, change.item);
3403
- }
3404
- return this.loading$.pipe(filter(loading => !loading));
3405
- })).subscribe(() => {
3406
- subscriber.next(items);
3407
- });
3408
- try {
3409
- this.updateItemsStates(items);
3410
- }
3411
- catch (err) {
3412
- subscriber.error(err);
3413
- }
3414
- const routeChangeSub = this._router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(event => {
3415
- try {
3416
- this.updateItemsStates(items);
3417
- this.updateRouterFocusedItem(items);
3418
- }
3419
- catch (err) {
3420
- subscriber.error(err);
3421
- }
3422
- });
3423
- return () => {
3424
- stateChangeSub.unsubscribe();
3425
- routeChangeSub.unsubscribe();
3426
- };
3427
- }).pipe(startWith(items));
3428
- });
3429
- }
3430
- _incUpdatingCount() {
3431
- this._updatingCount.next(this._updatingCount.value + 1);
3432
- }
3433
- _decrUpdatingCount() {
3434
- this._updatingCount.next(this._updatingCount.value - 1);
3435
- }
3436
- updateItemsStates(items) {
3437
- this._incUpdatingCount();
3438
- try {
3439
- for (const item of items) {
3440
- if (horizontalNavItemHasChildren(item)) {
3441
- this.updateItemsStates(item.children);
3442
- }
3443
- this.updateItemState(item);
3444
- }
3445
- this._decrUpdatingCount();
3446
- }
3447
- catch (err) {
3448
- this._decrUpdatingCount();
3449
- throw err;
3450
- }
3451
- }
3452
- updateItemState(item) {
3453
- this._incUpdatingCount();
3454
- try {
3455
- setDefaultHorizontalNavItemState(item);
3456
- this.setItemStateProp(item, 'active', this.horizontalNavLinkActive(item));
3457
- // TODO: Implement this in a more optimized way. Unless our apps start
3458
- // having large navs constantly updating their state, this shouldn't
3459
- // have much impact on performance.
3460
- this._updateItemExpandedState(item);
3461
- this._decrUpdatingCount();
3462
- }
3463
- catch (err) {
3464
- this._decrUpdatingCount();
3465
- throw err;
3466
- }
3467
- }
3468
- horizontalNavLinkActive(item) {
3469
- if (isHorizontalNavItemType(item, 'link')) {
3470
- const url = this._getUrl(item);
3471
- if (notNullOrUndefined(url)) {
3472
- const opts = this._getMatchOptions(item);
3473
- return this._router.isActive(url, opts);
3474
- }
3475
- }
3476
- return false;
3477
- }
3478
- _updateItemsExpandedState(items) {
3479
- for (const item of items) {
3480
- if (horizontalNavItemHasChildren(item)) {
3481
- this._updateItemsExpandedState(item.children);
3482
- }
3483
- this._updateItemExpandedState(item);
3484
- }
3485
- }
3486
- _updateItemExpandedState(item) {
3487
- if (!horizontalNavItemCanExpand(item)) {
3488
- if (getHorizontalNavItemStateProp(item, 'expanded')) {
3489
- this.setItemStateProp(item, 'expanded', false);
3490
- }
3491
- return;
3492
- }
3493
- if (horizontalNavItemHasChildren(item)) {
3494
- this._updateItemsExpandedState(item.children);
3495
- }
3496
- if (horizontalNavItemHasActiveChild(item) || horizontalNavItemHasExpandedChild(item)) {
3497
- if (!getHorizontalNavItemStateProp(item, 'expanded')) {
3498
- this.setItemStateProp(item, 'expanded', true);
3499
- }
3500
- }
3501
- else {
3502
- if (getHorizontalNavItemStateProp(item, 'expanded')) {
3503
- this.setItemStateProp(item, 'expanded', false);
3504
- }
3505
- }
3506
- }
3507
- updateRouterFocusedItem(items) {
3508
- const focusedItem = items.find(i => isHorizontalNavItemActive(i)) || items.find(i => horizontalNavItemHasActiveChild(i));
3509
- if (notNullOrUndefined(focusedItem)) {
3510
- this.updateFocusedItem(items, focusedItem);
3511
- }
3512
- }
3513
- updateFocusedItem(items, focusedItem) {
3514
- for (const item of items) {
3515
- if (areSameHorizontalNavItem(item, focusedItem)) {
3516
- setHorizontalNavItemStateProp(item, 'focused', true);
3517
- }
3518
- else {
3519
- setHorizontalNavItemStateProp(item, 'focused', false);
3520
- }
3521
- }
3522
- }
3523
- _getNavExtras(item) {
3524
- const navigationExtras = {};
3525
- if (hasProperty(item, 'queryParams')) {
3526
- navigationExtras.queryParams = item.queryParams;
3527
- }
3528
- if (hasProperty(item, 'fragment')) {
3529
- navigationExtras.fragment = item.fragment;
3530
- }
3531
- if (hasProperty(item, 'queryParamsHandling')) {
3532
- navigationExtras.queryParamsHandling = item.queryParamsHandling;
3533
- }
3534
- if (hasProperty(item, 'preserveFragment')) {
3535
- navigationExtras.preserveFragment = item.preserveFragment;
3536
- }
3537
- return navigationExtras;
3538
- }
3539
- _getUrl(item) {
3540
- const link = item.link;
3541
- if (typeof link === 'string') {
3542
- return this._router.createUrlTree([link], this._getNavExtras(item)).toString();
3543
- }
3544
- else if (Array.isArray(link)) {
3545
- return this._router.createUrlTree(link, this._getNavExtras(item)).toString();
3546
- }
3547
- return null;
3548
- }
3549
- _getMatchOptions(item) {
3550
- const defaultMatchOpts = {
3551
- paths: 'subset',
3552
- queryParams: 'subset',
3553
- fragment: 'ignored',
3554
- matrixParams: 'ignored'
3555
- };
3556
- if (hasProperty(item, 'matchOptions')) {
3557
- return Object.assign(Object.assign({}, defaultMatchOpts), item.matchOptions);
3558
- }
3559
- return defaultMatchOpts;
3560
- }
3561
- setItemStateProp(item, prop, value) {
3562
- const currentValue = getHorizontalNavItemStateProp(item, prop);
3563
- if (currentValue !== value) {
3564
- setHorizontalNavItemStateProp(item, prop, value);
3565
- const changed = {
3566
- item,
3567
- prop,
3568
- prevValue: currentValue,
3569
- newValue: value
3570
- };
3571
- this.itemChanged.next(changed);
3572
- }
3573
- }
3574
- }
3575
- TheSeamNavService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavService, deps: [{ token: i1$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
3576
- TheSeamNavService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavService });
3577
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavService, decorators: [{
3578
- type: Injectable
3579
- }], ctorParameters: function () { return [{ type: i1$2.Router }]; } });
3580
-
3581
- class NavItemComponent {
3582
- set link(value) { this._link.next(value); }
3583
- get link() { return this._link.value; }
3584
- set expanded(value) {
3585
- this._expanded.next(coerceBooleanProperty(value));
3586
- }
3587
- get expanded() { return this._expanded.value; }
3588
- set compact(value) { this._compact.next(coerceBooleanProperty(value)); }
3589
- get compact() { return this._compact.value; }
3590
- get badgeTooltip() { return this._badgeTooltip; }
3591
- set badgeTooltip(value) {
3592
- if (value !== null && value !== undefined) {
3593
- if (typeof value === 'string') {
3594
- this._badgeTooltip = {
3595
- tooltip: value,
3596
- placement: 'auto',
3597
- disabled: false
3598
- };
3599
- }
3600
- else {
3601
- this._badgeTooltip = Object.assign(Object.assign({}, value), { placement: value.placement || 'auto', disabled: typeof (value === null || value === void 0 ? void 0 : value.disabled) === 'boolean'
3602
- ? value.disabled
3603
- : typeof value.tooltip !== 'string' });
3604
- }
3605
- }
3606
- else {
3607
- this._badgeTooltip = undefined;
3608
- }
3609
- }
3610
- get _isActiveCssClass() { return this.active; }
3611
- get _isChildActiveCssClass() { return this.hasActiveChild; }
3612
- get _isExpandedCssClass() { return this.expanded; }
3613
- get _isFocusedCssClass() { return this.focused; }
3614
- get _attrDataHierLevel() { return this.hierLevel; }
3615
- constructor(_nav) {
3616
- this._nav = _nav;
3617
- this._ngUnsubscribe = new Subject();
3618
- this.faAngleLeft = faAngleLeft;
3619
- this.active = false;
3620
- this._link = new BehaviorSubject(undefined);
3621
- this.link$ = this._link.asObservable();
3622
- this.hierLevel = 0;
3623
- this.indentSize = 10;
3624
- this._expanded = new BehaviorSubject(false);
3625
- this.expanded$ = this._expanded.asObservable();
3626
- this._compact = new BehaviorSubject(false);
3627
- this.compact$ = this._compact.asObservable();
3628
- this.focused = false;
3629
- this.badgeTheme = 'danger';
3630
- this.childAction = 'menu';
3631
- this.expandAction = 'toggle';
3632
- this.navItemExpanded = new EventEmitter();
3633
- }
3634
- ngOnDestroy() {
3635
- this._ngUnsubscribe.next();
3636
- this._ngUnsubscribe.complete();
3637
- }
3638
- get hasChildren() {
3639
- return Array.isArray(this.children) && this.children.length > 0;
3640
- }
3641
- get hasActiveChild() {
3642
- if (notNullOrUndefined(this.item)) {
3643
- return horizontalNavItemHasActiveChild(this.item);
3644
- }
3645
- return false;
3646
- }
3647
- get hasMenuToggle() {
3648
- return this.hasChildren && this.childAction === 'menu';
3649
- }
3650
- get menuTpl() {
3651
- return this.hasMenuToggle ? this._menu : undefined;
3652
- }
3653
- get hasExpandingChildren() {
3654
- return this.hasChildren && this.childAction === 'expand';
3655
- }
3656
- _toggleChildren(event) {
3657
- let ex = !this.expanded;
3658
- if (this.expandAction === 'expandOnly') {
3659
- ex = true;
3660
- }
3661
- this.expanded = ex;
3662
- this.navItemExpanded.emit(this.expanded);
3663
- if (this.item && this.expanded) {
3664
- this._nav.setItemStateProp(this.item, 'focused', this.expanded);
3665
- }
3666
- // Prevents seam-menu from closing out when toggling child expand
3667
- event.stopPropagation();
3668
- }
3669
- // Updates expanded state when user exits seam-menu
3670
- _menuEvent(menuExpanded) {
3671
- if (menuExpanded === false) {
3672
- this.expanded = false;
3673
- // TODO: figure out why closing seam-menu with expanded submenu messes up animation
3674
- if (this._navItems && this._navItems.length) {
3675
- this._navItems.forEach(navItem => {
3676
- navItem.expanded = false;
3677
- });
3678
- }
3679
- }
3680
- }
3681
- get showIconBlock() {
3682
- return notNullOrUndefined(this.icon) || this.hideEmptyIcon !== true;
3683
- }
3684
- }
3685
- NavItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: NavItemComponent, deps: [{ token: TheSeamNavService }], target: i0.ɵɵFactoryTarget.Component });
3686
- NavItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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", "seamMenuTogglePositionsOffsetY"], outputs: ["menuToggle", "menuOpened", "menuClosed"], 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: [
3687
- trigger('childGroupAnim', [
3688
- transition(':enter', [
3689
- style({ height: 0 }),
3690
- animate('0.2s ease-in-out', style({ height: '*' }))
3691
- ]),
3692
- transition(':leave', [
3693
- style({ height: '*' }),
3694
- animate('0.2s ease-in-out', style({ height: 0 }))
3695
- ])
3696
- ])
3697
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
3698
- __decorate([
3699
- InputBoolean()
3700
- ], NavItemComponent.prototype, "active", void 0);
3701
- __decorate([
3702
- InputNumber(0)
3703
- ], NavItemComponent.prototype, "hierLevel", void 0);
3704
- __decorate([
3705
- InputNumber(10)
3706
- ], NavItemComponent.prototype, "indentSize", void 0);
3707
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: NavItemComponent, decorators: [{
3708
- type: Component,
3709
- args: [{ selector: 'seam-nav-item', exportAs: 'seamNavItem', animations: [
3710
- trigger('childGroupAnim', [
3711
- transition(':enter', [
3712
- style({ height: 0 }),
3713
- animate('0.2s ease-in-out', style({ height: '*' }))
3714
- ]),
3715
- transition(':leave', [
3716
- style({ height: '*' }),
3717
- animate('0.2s ease-in-out', style({ height: 0 }))
3718
- ])
3719
- ])
3720
- ], 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"] }]
3721
- }], ctorParameters: function () { return [{ type: TheSeamNavService }]; }, propDecorators: { item: [{
3722
- type: Input
3723
- }], itemType: [{
3724
- type: Input
3725
- }], icon: [{
3726
- type: Input
3727
- }], hideEmptyIcon: [{
3728
- type: Input
3729
- }], label: [{
3730
- type: Input
3731
- }], active: [{
3732
- type: Input
3733
- }], link: [{
3734
- type: Input
3735
- }], queryParams: [{
3736
- type: Input
3737
- }], children: [{
3738
- type: Input
3739
- }], hierLevel: [{
3740
- type: Input
3741
- }], indentSize: [{
3742
- type: Input
3743
- }], expanded: [{
3744
- type: Input
3745
- }], compact: [{
3746
- type: Input
3747
- }], focused: [{
3748
- type: Input
3749
- }], badgeText: [{
3750
- type: Input
3751
- }], badgeTheme: [{
3752
- type: Input
3753
- }], badgeSrContent: [{
3754
- type: Input
3755
- }], badgeTooltip: [{
3756
- type: Input
3757
- }], childAction: [{
3758
- type: Input
3759
- }], expandAction: [{
3760
- type: Input
3761
- }], navItemExpanded: [{
3762
- type: Output
3763
- }], _isActiveCssClass: [{
3764
- type: HostBinding,
3765
- args: ['class.seam-nav-item--active']
3766
- }], _isChildActiveCssClass: [{
3767
- type: HostBinding,
3768
- args: ['class.seam-nav-item--child-active']
3769
- }], _isExpandedCssClass: [{
3770
- type: HostBinding,
3771
- args: ['class.seam-nav-item--expanded']
3772
- }], _isFocusedCssClass: [{
3773
- type: HostBinding,
3774
- args: ['class.seam-nav-item--focused']
3775
- }], _attrDataHierLevel: [{
3776
- type: HostBinding,
3777
- args: ['attr.data-hier-level']
3778
- }], _menu: [{
3779
- type: ViewChild,
3780
- args: [MenuComponent]
3781
- }], _navItems: [{
3782
- type: ViewChildren,
3783
- args: [NavItemComponent]
3784
- }] } });
3785
-
3786
- class HorizontalNavComponent {
3787
- get items() { return this._items.value; }
3788
- set items(value) {
3789
- this._items.next(value);
3790
- }
3791
- constructor(_nav) {
3792
- this._nav = _nav;
3793
- this._ngUnsubscribe = new Subject();
3794
- this._items = new BehaviorSubject([]);
3795
- this.hideEmptyIcon = true;
3796
- this.hierLevel = 0;
3797
- this.childAction = 'menu';
3798
- this.expandAction = 'toggle';
3799
- this.navItemExpanded = new EventEmitter();
3800
- this.items$ = this._items.asObservable().pipe(switchMap(items => items ? this._nav.createItemsObservable(items) : []), shareReplay({ bufferSize: 1, refCount: true }));
3801
- }
3802
- ngOnDestroy() {
3803
- this._ngUnsubscribe.next();
3804
- this._ngUnsubscribe.complete();
3805
- }
3806
- _navItemExpanded(item, expanded) {
3807
- this.navItemExpanded.emit({ navItem: item, expanded });
3808
- }
3809
- }
3810
- HorizontalNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HorizontalNavComponent, deps: [{ token: TheSeamNavService }], target: i0.ɵɵFactoryTarget.Component });
3811
- HorizontalNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: HorizontalNavComponent, selector: "seam-horizontal-nav", inputs: { items: "items", hideEmptyIcon: "hideEmptyIcon", hierLevel: "hierLevel", childAction: "childAction", expandAction: "expandAction" }, outputs: { navItemExpanded: "navItemExpanded" }, providers: [
3812
- TheSeamNavService
3813
- ], 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 });
3814
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: HorizontalNavComponent, decorators: [{
3815
- type: Component,
3816
- args: [{ selector: 'seam-horizontal-nav', providers: [
3817
- TheSeamNavService
3818
- ], 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"] }]
3819
- }], ctorParameters: function () { return [{ type: TheSeamNavService }]; }, propDecorators: { items: [{
3820
- type: Input
3821
- }], hideEmptyIcon: [{
3822
- type: Input
3823
- }], hierLevel: [{
3824
- type: Input
3825
- }], childAction: [{
3826
- type: Input
3827
- }], expandAction: [{
3828
- type: Input
3829
- }], navItemExpanded: [{
3830
- type: Output
3831
- }] } });
3832
-
3833
- class TheSeamNavModule {
3834
- }
3835
- TheSeamNavModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3836
- TheSeamNavModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavModule, declarations: [NavItemComponent,
3837
- HorizontalNavComponent], imports: [CommonModule,
3838
- RouterModule,
3839
- TheSeamIconModule,
3840
- A11yModule,
3841
- TheSeamScrollbarModule,
3842
- TheSeamLayoutModule,
3843
- NgbTooltipModule,
3844
- PortalModule,
3845
- TheSeamMenuModule], exports: [NavItemComponent,
3846
- HorizontalNavComponent] });
3847
- TheSeamNavModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavModule, providers: [
3848
- TheSeamNavService,
3849
- ], imports: [CommonModule,
3850
- RouterModule,
3851
- TheSeamIconModule,
3852
- A11yModule,
3853
- TheSeamScrollbarModule,
3854
- TheSeamLayoutModule,
3855
- NgbTooltipModule,
3856
- PortalModule,
3857
- TheSeamMenuModule] });
3858
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TheSeamNavModule, decorators: [{
3859
- type: NgModule,
3860
- args: [{
3861
- declarations: [
3862
- NavItemComponent,
3863
- HorizontalNavComponent,
3864
- ],
3865
- imports: [
3866
- CommonModule,
3867
- RouterModule,
3868
- TheSeamIconModule,
3869
- A11yModule,
3870
- TheSeamScrollbarModule,
3871
- TheSeamLayoutModule,
3872
- NgbTooltipModule,
3873
- PortalModule,
3874
- TheSeamMenuModule
3875
- ],
3876
- exports: [
3877
- NavItemComponent,
3878
- HorizontalNavComponent,
3879
- ],
3880
- providers: [
3881
- TheSeamNavService,
3882
- ]
3883
- }]
3884
- }] });
3885
-
3886
- /**
3887
- * Generated bundle index. Do not edit.
3888
- */
3889
-
3890
- export { BaseLayoutContentDirective, BaseLayoutContentFooterDirective, BaseLayoutContentHeaderDirective, BaseLayoutNavToggleDirective, BaseLayoutSideBarDirective, BaseLayoutSideBarFooterDirective, BaseLayoutSideBarHeaderDirective, BaseLayoutTopBarDirective, DEFAULT_SIDE_NAV_CONFIG, DashboardComponent, DashboardWidgetContainerComponent, DashboardWidgetPortalOutletDirective, DashboardWidgetTemplateContainerComponent, DashboardWidgetsComponent, DashboardWidgetsPreferencesService, DashboardWidgetsService, HierarchyLevelResolver, HierarchyRouterOutletComponent, HorizontalNavComponent, NavItemComponent, SideNavComponent, SideNavItemComponent, SideNavToggleComponent, THESEAM_BASE_LAYOUT_REF, THESEAM_DASHBOARD_WIDGETS_PREFERENCES_ACCESSOR, THESEAM_SCHEMA_FRAMEWORK_OVERRIDES, THESEAM_SIDE_NAV_ACCESSOR, THESEAM_SIDE_NAV_CONFIG, THE_SEAM_BASE_LAYOUT, TheSeamBaseLayoutComponent, TheSeamBaseLayoutModule, TheSeamDashboardModule, TheSeamDynamicRouterModule, TheSeamFramework, TheSeamNavModule, TheSeamSchemaFormFrameworkComponent, TheSeamSchemaFormModule, TheSeamSideNavModule, TheSeamTopBarComponent, TheSeamTopBarModule, TopBarCompactMenuBtnDetailDirective, TopBarItemDirective, TopBarMenuBtnDetailDirective, TopBarMenuButtonComponent, TopBarMenuDirective, TopBarNavToggleBtnDetailDirective, TopBarTitleComponent, applyItemConfig, areSameHorizontalNavItem, canBeActive, canExpand, canHaveChildren, extendFramework, 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 };
3891
- //# sourceMappingURL=theseam-ui-common-framework.mjs.map