@elderbyte/ngx-starter 14.11.0 → 14.12.0-beta2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (161) hide show
  1. package/_index.scss +2 -0
  2. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -4
  3. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -8
  4. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +9 -13
  5. package/esm2020/lib/components/auditing/elder-audit.module.mjs +1 -5
  6. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -4
  7. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -8
  8. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -5
  9. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +5 -6
  10. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -5
  11. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -5
  12. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +3 -5
  13. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -5
  14. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -5
  15. package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -8
  16. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -4
  17. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -5
  18. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -4
  19. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -5
  20. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +6 -7
  21. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +5 -6
  22. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -5
  23. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -5
  24. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +3 -4
  25. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -5
  26. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -4
  27. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +39 -26
  28. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +1 -5
  29. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -5
  30. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +8 -9
  31. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -5
  32. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +9 -7
  33. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +6 -5
  34. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +10 -3
  35. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +11 -9
  36. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -5
  37. package/esm2020/lib/components/errors/elder-error.module.mjs +4 -8
  38. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -4
  39. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -5
  40. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -5
  41. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +3 -4
  42. package/esm2020/lib/components/files/elder-file.module.mjs +4 -5
  43. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +11 -12
  44. package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -5
  45. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +5 -6
  46. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -5
  47. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -5
  48. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -11
  49. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -8
  50. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -5
  51. package/esm2020/lib/components/headers/elder-header.module.mjs +4 -5
  52. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +1 -5
  53. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +10 -11
  54. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +8 -9
  55. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +14 -15
  56. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +1 -5
  57. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +5 -6
  58. package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +4 -5
  59. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +1 -5
  60. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -5
  61. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +6 -7
  62. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -5
  63. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -5
  64. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +1 -5
  65. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +5 -16
  66. package/esm2020/lib/components/measures/elder-measures.module.mjs +1 -5
  67. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +12 -13
  68. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +12 -13
  69. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -5
  70. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -5
  71. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +3 -4
  72. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -5
  73. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -5
  74. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -5
  75. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +6 -7
  76. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +2 -2
  77. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +2 -2
  78. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +2 -2
  79. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -4
  80. package/esm2020/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +3 -4
  81. package/esm2020/lib/components/panels/elder-panel.module.mjs +3 -7
  82. package/esm2020/lib/components/select/elder-select.module.mjs +4 -5
  83. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +9 -10
  84. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +5 -6
  85. package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +8 -9
  86. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -6
  87. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -5
  88. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -5
  89. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -4
  90. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -4
  91. package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -5
  92. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -5
  93. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +4 -5
  94. package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -8
  95. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +7 -8
  96. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +9 -10
  97. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +7 -8
  98. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +7 -8
  99. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +12 -13
  100. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +9 -10
  101. package/esm2020/lib/components/time/elder-time.module.mjs +1 -11
  102. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +7 -8
  103. package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -5
  104. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +5 -6
  105. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +1 -5
  106. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -5
  107. package/fesm2015/elderbyte-ngx-starter.mjs +451 -507
  108. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  109. package/fesm2020/elderbyte-ngx-starter.mjs +450 -507
  110. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  111. package/lib/components/access-denied/elder-access-denied.module.d.ts +1 -2
  112. package/lib/components/auditing/audited-entity/elder-audited-entity.component.d.ts +1 -2
  113. package/lib/components/auditing/elder-audit.module.d.ts +5 -6
  114. package/lib/components/button-group/elder-button-group.module.d.ts +1 -2
  115. package/lib/components/card-organizer/elder-card-organizer.module.d.ts +3 -4
  116. package/lib/components/cards/elder-card/elder-card.module.d.ts +2 -3
  117. package/lib/components/connectivity/elder-connectivity.module.d.ts +6 -7
  118. package/lib/components/containers/elder-containers.module.d.ts +1 -2
  119. package/lib/components/data-transfer/elder-data-transfer.module.d.ts +4 -5
  120. package/lib/components/data-view/common/elder-data-common.module.d.ts +1 -2
  121. package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -3
  122. package/lib/components/data-view/grid/elder-grid.module.d.ts +6 -7
  123. package/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.d.ts +4 -5
  124. package/lib/components/data-view/table/elder-table.module.d.ts +4 -5
  125. package/lib/components/dialogs/elder-dialog.module.d.ts +4 -3
  126. package/lib/components/dialogs/elder-dialog.service.d.ts +1 -0
  127. package/lib/components/errors/elder-error.module.d.ts +1 -2
  128. package/lib/components/expand-toggle-button/elder-expand-toggle-button.module.d.ts +1 -2
  129. package/lib/components/files/elder-file.module.d.ts +6 -7
  130. package/lib/components/forms/search/elder-search.module.d.ts +2 -3
  131. package/lib/components/global-search/elder-global-search.module.d.ts +2 -3
  132. package/lib/components/graph/elder-progress-bar/elder-progress-bar.component.d.ts +1 -8
  133. package/lib/components/graph/elder-progress-bar/elder-progress-bar.module.d.ts +1 -2
  134. package/lib/components/headers/elder-header.module.d.ts +2 -3
  135. package/lib/components/i18n/entities/elder-i18n-entities.module.d.ts +15 -16
  136. package/lib/components/i18n/language/elder-language.module.d.ts +2 -3
  137. package/lib/components/iframes/elder-iframe.module.d.ts +5 -6
  138. package/lib/components/input/autocomplete/elder-autocomplete.module.d.ts +2 -3
  139. package/lib/components/measures/dimensions-input/elder-dimensions-input.component.d.ts +1 -3
  140. package/lib/components/measures/elder-measures.module.d.ts +5 -6
  141. package/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.d.ts +8 -9
  142. package/lib/components/navigation/nav/elder-nav.module.d.ts +1 -2
  143. package/lib/components/navigation/nav/nav-list/elder-nav-list.component.d.ts +1 -3
  144. package/lib/components/navigation/toolbar/elder-toolbar.module.d.ts +8 -9
  145. package/lib/components/panels/elder-panel.module.d.ts +1 -2
  146. package/lib/components/select/elder-select.module.d.ts +10 -11
  147. package/lib/components/select-chip-list/elder-chip-list-select.module.d.ts +3 -4
  148. package/lib/components/select-list/elder-select-list.module.d.ts +1 -2
  149. package/lib/components/shell/elder-shell.module.d.ts +4 -5
  150. package/lib/components/tabs/elder-tab.module.d.ts +1 -2
  151. package/lib/components/time/elder-time.module.d.ts +9 -10
  152. package/lib/components/toasts/elder-toast.module.d.ts +3 -4
  153. package/lib/components/url-fragment/elder-url-fragment.module.d.ts +2 -3
  154. package/package.json +1 -2
  155. package/src/lib/components/graph/elder-progress-bar/elder-progress-bar.component.scss +5 -0
  156. package/src/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.scss +3 -1
  157. package/src/lib/components/navigation/nav/nav-list/elder-nav-list.component.scss +5 -6
  158. package/src/lib/components/select/single/elder-select/elder-select.component.scss +1 -4
  159. package/theming/_elder-common.scss +32 -0
  160. package/theming/_elder-flex-layout.scss +562 -0
  161. package/theming/_elder-style-fixes.scss +3 -0
@@ -9,7 +9,6 @@ import * as i1 from "../../../common/http/http-client-pristine";
9
9
  import * as i2 from "@angular/platform-browser";
10
10
  import * as i3 from "../../toasts/elder-toast.service";
11
11
  import * as i4 from "@angular/common";
12
- import * as i5 from "@angular/flex-layout/flex";
13
12
  class BlobContext {
14
13
  constructor(safeUrl, mimeType, text = null) {
15
14
  this.safeUrl = safeUrl;
@@ -208,10 +207,10 @@ export class ElderBlobViewerComponent {
208
207
  }
209
208
  }
210
209
  ElderBlobViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderBlobViewerComponent, deps: [{ token: i1.HttpClientPristine }, { token: i2.DomSanitizer }, { token: i3.ElderToastService }], target: i0.ɵɵFactoryTarget.Component });
211
- ElderBlobViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderBlobViewerComponent, selector: "elder-blob-viewer", inputs: { displayUnknownAsText: "displayUnknownAsText", blob: "blob", blobUrl: "blobUrl", url: "url", mimeType: "mimeType" }, ngImport: i0, template: "<div fxLayout=\"column\" fxLayoutAlign=\"center center\" class=\"document-viewer\" fxFill>\n\n <ng-container *ngIf=\"blobContext$ | async as blobContext\">\n\n <!-- Video -->\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.mimeType.isVideo\" fxFill>\n <video class=\"video\"\n controls autoplay loop\n\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 video.\n </video>\n </div>\n\n <!-- Audio -->\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.mimeType.isAudio\" fxFill>\n <audio class=\"audio\"\n controls autoplay loop\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 audio.\n </audio>\n </div>\n\n <!-- Image -->\n <div fxLayout=\"column\" *ngIf=\"blobContext.mimeType.isImage\" style=\"overflow: hidden\" fxFill>\n <img class=\"cover\" fxFlex\n [src]=\"blobContext.safeUrl\" alt=\"blob image\"/>\n </div>\n\n <!-- Embedded (PDFs etc) -->\n <div fxLayout=\"column\" *ngIf=\"blobContext.displayEmbedded\" fxFill>\n <div style=\"width: 100%;height: 100%\">\n <embed class=\"embedded\" [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\" width=\"100%\" height=\"100%\">\n </div>\n </div>\n\n <!-- Plain Text -->\n <div fxLayout=\"column\" *ngIf=\"blobContext.displayAsText\" fxFill>\n <textarea\n class=\"document-content\"\n placeholder=\"Content\"\n [value]=\"blobContext.text\" wrap=\"off\"\n readonly\n ></textarea>\n </div>\n\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.cantDisplay\" fxFill>\n <p>Cant display {{blobContext.mimeType.value}}!</p>\n </div>\n\n </ng-container>\n\n <ng-container *ngIf=\"!(blobContext$ | async)\">\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\n <p>No Document.</p>\n </div>\n </ng-container>\n\n\n</div>\n", styles: [":host{overflow:hidden}.document-viewer{background-color:#dedede;color:#1f1e1e}.video,.audio{width:100%;height:auto}.embedded{width:100%;height:100%}.cover{-o-object-fit:scale-down;object-fit:scale-down;width:100%;height:auto;overflow:hidden}.document-content{font-family:Courier,monospace;font-size:14px;background-color:#575757;color:#ccc;outline:none;resize:none;width:100%;height:100%;box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;border-radius:0;box-shadow:0 2px 14px #000;border-top:1px solid #FFF;border-bottom:1px solid #FFF}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i5.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i5.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i5.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
210
+ ElderBlobViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderBlobViewerComponent, selector: "elder-blob-viewer", inputs: { displayUnknownAsText: "displayUnknownAsText", blob: "blob", blobUrl: "blobUrl", url: "url", mimeType: "mimeType" }, ngImport: i0, template: "<div class=\"layout-col full place-center-center document-viewer\">\n\n <ng-container *ngIf=\"blobContext$ | async as blobContext\">\n\n <!-- Video -->\n <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.mimeType.isVideo\">\n <video class=\"video\"\n controls autoplay loop\n\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 video.\n </video>\n </div>\n\n <!-- Audio -->\n <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.mimeType.isAudio\">\n <audio class=\"audio\"\n controls autoplay loop\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 audio.\n </audio>\n </div>\n\n <!-- Image -->\n <div class=\"layout-col full\" *ngIf=\"blobContext.mimeType.isImage\" style=\"overflow: hidden\">\n <img class=\"cover flex\"\n [src]=\"blobContext.safeUrl\" alt=\"blob image\"/>\n </div>\n\n <!-- Embedded (PDFs etc) -->\n <div class=\"layout-col full\" *ngIf=\"blobContext.displayEmbedded\">\n <div class=\"full\">\n <embed class=\"embedded\" [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\" width=\"100%\" height=\"100%\">\n </div>\n </div>\n\n <!-- Plain Text -->\n <div class=\"layout-col full\" *ngIf=\"blobContext.displayAsText\">\n <textarea\n class=\"document-content\"\n placeholder=\"Content\"\n [value]=\"blobContext.text\" wrap=\"off\"\n readonly\n ></textarea>\n </div>\n\n <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.cantDisplay\">\n <p>Cant display {{blobContext.mimeType.value}}!</p>\n </div>\n\n </ng-container>\n\n <ng-container *ngIf=\"!(blobContext$ | async)\">\n <div class=\"layout-col place-center-center full\">\n <p>No Document.</p>\n </div>\n </ng-container>\n\n\n</div>\n", styles: [":host{overflow:hidden}.document-viewer{background-color:#dedede;color:#1f1e1e}.video,.audio{width:100%;height:auto}.embedded{width:100%;height:100%}.cover{-o-object-fit:scale-down;object-fit:scale-down;width:100%;height:auto;overflow:hidden}.document-content{font-family:Courier,monospace;font-size:14px;background-color:#575757;color:#ccc;outline:none;resize:none;width:100%;height:100%;box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;border-radius:0;box-shadow:0 2px 14px #000;border-top:1px solid #FFF;border-bottom:1px solid #FFF}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
212
211
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderBlobViewerComponent, decorators: [{
213
212
  type: Component,
214
- args: [{ selector: 'elder-blob-viewer', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div fxLayout=\"column\" fxLayoutAlign=\"center center\" class=\"document-viewer\" fxFill>\n\n <ng-container *ngIf=\"blobContext$ | async as blobContext\">\n\n <!-- Video -->\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.mimeType.isVideo\" fxFill>\n <video class=\"video\"\n controls autoplay loop\n\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 video.\n </video>\n </div>\n\n <!-- Audio -->\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.mimeType.isAudio\" fxFill>\n <audio class=\"audio\"\n controls autoplay loop\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 audio.\n </audio>\n </div>\n\n <!-- Image -->\n <div fxLayout=\"column\" *ngIf=\"blobContext.mimeType.isImage\" style=\"overflow: hidden\" fxFill>\n <img class=\"cover\" fxFlex\n [src]=\"blobContext.safeUrl\" alt=\"blob image\"/>\n </div>\n\n <!-- Embedded (PDFs etc) -->\n <div fxLayout=\"column\" *ngIf=\"blobContext.displayEmbedded\" fxFill>\n <div style=\"width: 100%;height: 100%\">\n <embed class=\"embedded\" [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\" width=\"100%\" height=\"100%\">\n </div>\n </div>\n\n <!-- Plain Text -->\n <div fxLayout=\"column\" *ngIf=\"blobContext.displayAsText\" fxFill>\n <textarea\n class=\"document-content\"\n placeholder=\"Content\"\n [value]=\"blobContext.text\" wrap=\"off\"\n readonly\n ></textarea>\n </div>\n\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.cantDisplay\" fxFill>\n <p>Cant display {{blobContext.mimeType.value}}!</p>\n </div>\n\n </ng-container>\n\n <ng-container *ngIf=\"!(blobContext$ | async)\">\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\n <p>No Document.</p>\n </div>\n </ng-container>\n\n\n</div>\n", styles: [":host{overflow:hidden}.document-viewer{background-color:#dedede;color:#1f1e1e}.video,.audio{width:100%;height:auto}.embedded{width:100%;height:100%}.cover{-o-object-fit:scale-down;object-fit:scale-down;width:100%;height:auto;overflow:hidden}.document-content{font-family:Courier,monospace;font-size:14px;background-color:#575757;color:#ccc;outline:none;resize:none;width:100%;height:100%;box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;border-radius:0;box-shadow:0 2px 14px #000;border-top:1px solid #FFF;border-bottom:1px solid #FFF}\n"] }]
213
+ args: [{ selector: 'elder-blob-viewer', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-col full place-center-center document-viewer\">\n\n <ng-container *ngIf=\"blobContext$ | async as blobContext\">\n\n <!-- Video -->\n <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.mimeType.isVideo\">\n <video class=\"video\"\n controls autoplay loop\n\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 video.\n </video>\n </div>\n\n <!-- Audio -->\n <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.mimeType.isAudio\">\n <audio class=\"audio\"\n controls autoplay loop\n >\n <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n Your browser does not support HTML5 audio.\n </audio>\n </div>\n\n <!-- Image -->\n <div class=\"layout-col full\" *ngIf=\"blobContext.mimeType.isImage\" style=\"overflow: hidden\">\n <img class=\"cover flex\"\n [src]=\"blobContext.safeUrl\" alt=\"blob image\"/>\n </div>\n\n <!-- Embedded (PDFs etc) -->\n <div class=\"layout-col full\" *ngIf=\"blobContext.displayEmbedded\">\n <div class=\"full\">\n <embed class=\"embedded\" [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\" width=\"100%\" height=\"100%\">\n </div>\n </div>\n\n <!-- Plain Text -->\n <div class=\"layout-col full\" *ngIf=\"blobContext.displayAsText\">\n <textarea\n class=\"document-content\"\n placeholder=\"Content\"\n [value]=\"blobContext.text\" wrap=\"off\"\n readonly\n ></textarea>\n </div>\n\n <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.cantDisplay\">\n <p>Cant display {{blobContext.mimeType.value}}!</p>\n </div>\n\n </ng-container>\n\n <ng-container *ngIf=\"!(blobContext$ | async)\">\n <div class=\"layout-col place-center-center full\">\n <p>No Document.</p>\n </div>\n </ng-container>\n\n\n</div>\n", styles: [":host{overflow:hidden}.document-viewer{background-color:#dedede;color:#1f1e1e}.video,.audio{width:100%;height:auto}.embedded{width:100%;height:100%}.cover{-o-object-fit:scale-down;object-fit:scale-down;width:100%;height:auto;overflow:hidden}.document-content{font-family:Courier,monospace;font-size:14px;background-color:#575757;color:#ccc;outline:none;resize:none;width:100%;height:100%;box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;border-radius:0;box-shadow:0 2px 14px #000;border-top:1px solid #FFF;border-bottom:1px solid #FFF}\n"] }]
215
214
  }], ctorParameters: function () { return [{ type: i1.HttpClientPristine }, { type: i2.DomSanitizer }, { type: i3.ElderToastService }]; }, propDecorators: { displayUnknownAsText: [{
216
215
  type: Input
217
216
  }], blob: [{
@@ -223,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
223
222
  }], mimeType: [{
224
223
  type: Input
225
224
  }] } });
226
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-blob-viewer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/blob-viewer/elder-blob-viewer.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/blob-viewer/elder-blob-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit} from '@angular/core';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {BlobUrl} from '../blob-url';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {HttpClientPristine} from '../../../common/http/http-client-pristine';\nimport {ElderToastService} from '../../toasts/elder-toast.service';\nimport {filter, map, takeUntil} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\nclass BlobContext {\n\n  public static textBlob(\n    text: string,\n    mimeType: BlobMimeType\n  ) {\n    return new BlobContext(null, mimeType, text);\n  }\n\n  public static safeUrl(\n    safeUrl: SafeUrl,\n    mimeType: BlobMimeType,\n  ): BlobContext {\n    return new BlobContext(safeUrl, mimeType, null);\n  }\n\n  constructor(\n    public readonly safeUrl: SafeUrl,\n    public readonly mimeType: BlobMimeType,\n    public readonly text: string = null\n  ) {\n  }\n\n  public get displayAsText(): boolean {\n    return !!this.text;\n  }\n\n  public get cantDisplay(): boolean {\n    return !this.displayAsText && !this.displayEmbedded\n      && !this.mimeType.isAudio && !this.mimeType.isImage && !this.mimeType.isVideo;\n  }\n\n  public get displayEmbedded(): boolean {\n    return this.mimeType.isPdf;\n  }\n\n}\n\nclass BlobMimeType {\n\n  public static readonly OCTET_STREAM = new BlobMimeType('application/octet-stream');\n\n  public static parse(mimeType: string): BlobMimeType {\n    if (mimeType) {\n      return new BlobMimeType(mimeType);\n    } else {\n      return BlobMimeType.OCTET_STREAM;\n    }\n  }\n\n  constructor(\n    public readonly value: string\n  ) {  }\n\n  public get isOctetStream(): boolean {\n    return this.value.startsWith('application/octet-stream');\n  }\n\n  public get isVideo(): boolean {\n    return this.value.startsWith('video/');\n  }\n\n  public get isImage(): boolean {\n    return this.value.startsWith('image/');\n  }\n\n  public get isAudio(): boolean {\n    return this.value.startsWith('audio/');\n  }\n\n  public get isJson(): boolean {\n    return this.value.startsWith('application/json');\n  }\n\n  public get isPdf(): boolean {\n    return this.value.startsWith('application/pdf');\n  }\n\n  public get isText(): boolean {\n    return this.value.startsWith('text/') || this.isJson;\n  }\n\n}\n\n@Component({\n  selector: 'elder-blob-viewer',\n  templateUrl: './elder-blob-viewer.component.html',\n  styleUrls: ['./elder-blob-viewer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderBlobViewerComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly blobContext$ = new BehaviorSubject<BlobContext>(null);\n\n\n  private readonly _url$ = new BehaviorSubject<string>(null);\n  private readonly _mimeType$ = new BehaviorSubject<string>(null);\n  private readonly destroy$ = new Subject<void>();\n  private _displayUnknownAsText = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private httpPristine: HttpClientPristine,\n    private domSanitizer: DomSanitizer,\n    private toastService: ElderToastService\n  ) {  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    combineLatest([this._url$, this._mimeType$]).pipe(\n      takeUntil(this.destroy$),\n      filter(([url, mimeType]) => !!url),\n      map(([url, mimeType]) => BlobUrl.from(url, mimeType))\n    ).subscribe(\n      blobUrl => this.blobUrl = blobUrl\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Attempt to display unknown blobs as text. (i.e. mime-type is octet-stream)\n   * @param unknownAsText\n   */\n  @Input()\n  public set displayUnknownAsText(unknownAsText: boolean) {\n\n    // TODO FIX RACE CONDITION:\n    //    Since this property is not reactive, it must be set first.\n    //    Otherwise, it will still be false, even if set to true!\n\n    this._displayUnknownAsText = coerceBooleanProperty(unknownAsText);\n  }\n\n  /**\n   * Set a in memory blob to display.\n   * @param blob\n   */\n  @Input()\n  public set blob(blob: Blob) {\n    this.handleBlob(blob);\n  }\n\n  /**\n   * Set a blob-url to display.\n   * @param blobUrl\n   */\n  @Input()\n  public set blobUrl(blobUrl: BlobUrl) {\n    this.handleBlobUrl(blobUrl);\n  }\n\n\n  /**\n   * Set a url to display. Requires the mimeType to be set aswell.\n   * @param url\n   */\n  @Input()\n  public set url(url: string) {\n    this._url$.next(url);\n  }\n\n  /**\n   * Set the mime-type for the url to display. Only considered if url is set.\n   * @param mimeType\n   */\n  @Input()\n  public set mimeType(mimeType: string) {\n    this._mimeType$.next(mimeType);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private handleBlob(blob: Blob): void {\n\n    const safeUrl = this.createSafeUrlFromBlob(blob);\n    const mimeType = BlobMimeType.parse(blob.type);\n\n    if (this.canDisplayAsText(mimeType)) {\n      this.textContext(blob, mimeType);\n    } else {\n      this.nextBlob(\n        BlobContext.safeUrl(safeUrl, mimeType)\n      );\n    }\n  }\n\n  private textContext(blob: Blob, mimeType: BlobMimeType): void {\n    blob.text().then(\n      text => {\n        this.nextBlob(\n          BlobContext.textBlob(text, mimeType)\n        );\n      }\n    );\n  }\n\n  private handleBlobUrl(blobUrl: BlobUrl): void {\n\n    const safeUrl = this.createSafeUrlFromDataUrl(blobUrl.url);\n    const mimeType = BlobMimeType.parse(blobUrl.mimeType);\n\n    if (this.canDisplayAsText(mimeType)) {\n      this.loadAsText(blobUrl.url, mimeType);\n    } else {\n      this.nextBlob(\n        BlobContext.safeUrl(safeUrl, mimeType)\n      );\n    }\n  }\n\n  private nextBlob(blobContext: BlobContext): void {\n    this.blobContext$.next(blobContext);\n  }\n\n  private createSafeUrlFromBlob(blob: Blob): SafeUrl {\n    const blobUrl = URL.createObjectURL(blob);\n    return this.domSanitizer.bypassSecurityTrustResourceUrl(blobUrl);\n  }\n\n  private createSafeUrlFromDataUrl(url: string): SafeUrl {\n    return this.domSanitizer.bypassSecurityTrustResourceUrl(url);\n  }\n\n  private loadAsText(pristineUrl: string, mimeType: BlobMimeType): void {\n\n    this.nextBlob(\n      BlobContext.textBlob('Loading...', mimeType)\n    );\n\n    this.downloadAsText(pristineUrl).subscribe(\n      text => {\n        this.nextBlob(\n          BlobContext.textBlob(text, mimeType)\n        );\n      },\n      err => {\n        this.nextBlob(\n          BlobContext.textBlob('Failed to download content!', mimeType)\n        );\n        this.toastService.warn('Failed to download content!', err);\n      }\n    );\n  }\n\n  private canDisplayAsText(mimeType: BlobMimeType): boolean {\n\n    const can = mimeType.isText || (this._displayUnknownAsText && mimeType.isOctetStream);\n\n    // TODO _displayUnknownAsText might be null due race condition see todo above.\n    // this.logger.debug('canDisplayAsText(' + mimeType.value + ') --> '\n    //  + can + ' ---> this._displayUnknownAsText:' + this._displayUnknownAsText, mimeType);\n\n    return can;\n  }\n\n  private downloadAsText(pristineUrl: string): Observable<string> {\n    return this.httpPristine.get(pristineUrl, {\n      responseType: 'text'\n    });\n  }\n}\n","<div fxLayout=\"column\" fxLayoutAlign=\"center center\" class=\"document-viewer\" fxFill>\n\n  <ng-container *ngIf=\"blobContext$ | async as blobContext\">\n\n    <!-- Video -->\n    <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.mimeType.isVideo\" fxFill>\n      <video class=\"video\"\n             controls autoplay loop\n\n      >\n        <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n        Your browser does not support HTML5 video.\n      </video>\n    </div>\n\n    <!-- Audio -->\n    <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.mimeType.isAudio\" fxFill>\n      <audio class=\"audio\"\n             controls autoplay loop\n      >\n        <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n        Your browser does not support HTML5 audio.\n      </audio>\n    </div>\n\n    <!-- Image -->\n    <div fxLayout=\"column\" *ngIf=\"blobContext.mimeType.isImage\" style=\"overflow: hidden\" fxFill>\n      <img class=\"cover\" fxFlex\n           [src]=\"blobContext.safeUrl\" alt=\"blob image\"/>\n    </div>\n\n    <!-- Embedded (PDFs etc) -->\n    <div fxLayout=\"column\" *ngIf=\"blobContext.displayEmbedded\" fxFill>\n      <div style=\"width: 100%;height: 100%\">\n        <embed class=\"embedded\" [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\" width=\"100%\" height=\"100%\">\n      </div>\n    </div>\n\n    <!-- Plain Text -->\n    <div fxLayout=\"column\" *ngIf=\"blobContext.displayAsText\" fxFill>\n      <textarea\n        class=\"document-content\"\n        placeholder=\"Content\"\n        [value]=\"blobContext.text\" wrap=\"off\"\n        readonly\n      ></textarea>\n    </div>\n\n    <div fxLayout=\"column\" fxLayoutAlign=\"center center\" *ngIf=\"blobContext.cantDisplay\" fxFill>\n      <p>Cant display {{blobContext.mimeType.value}}!</p>\n    </div>\n\n  </ng-container>\n\n  <ng-container *ngIf=\"!(blobContext$ | async)\">\n    <div fxLayout=\"column\" fxLayoutAlign=\"center center\" fxFill>\n      <p>No Document.</p>\n    </div>\n  </ng-container>\n\n\n</div>\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-blob-viewer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/blob-viewer/elder-blob-viewer.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/blob-viewer/elder-blob-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit} from '@angular/core';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {BlobUrl} from '../blob-url';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {HttpClientPristine} from '../../../common/http/http-client-pristine';\nimport {ElderToastService} from '../../toasts/elder-toast.service';\nimport {filter, map, takeUntil} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\nclass BlobContext {\n\n  public static textBlob(\n    text: string,\n    mimeType: BlobMimeType\n  ) {\n    return new BlobContext(null, mimeType, text);\n  }\n\n  public static safeUrl(\n    safeUrl: SafeUrl,\n    mimeType: BlobMimeType,\n  ): BlobContext {\n    return new BlobContext(safeUrl, mimeType, null);\n  }\n\n  constructor(\n    public readonly safeUrl: SafeUrl,\n    public readonly mimeType: BlobMimeType,\n    public readonly text: string = null\n  ) {\n  }\n\n  public get displayAsText(): boolean {\n    return !!this.text;\n  }\n\n  public get cantDisplay(): boolean {\n    return !this.displayAsText && !this.displayEmbedded\n      && !this.mimeType.isAudio && !this.mimeType.isImage && !this.mimeType.isVideo;\n  }\n\n  public get displayEmbedded(): boolean {\n    return this.mimeType.isPdf;\n  }\n\n}\n\nclass BlobMimeType {\n\n  public static readonly OCTET_STREAM = new BlobMimeType('application/octet-stream');\n\n  public static parse(mimeType: string): BlobMimeType {\n    if (mimeType) {\n      return new BlobMimeType(mimeType);\n    } else {\n      return BlobMimeType.OCTET_STREAM;\n    }\n  }\n\n  constructor(\n    public readonly value: string\n  ) {  }\n\n  public get isOctetStream(): boolean {\n    return this.value.startsWith('application/octet-stream');\n  }\n\n  public get isVideo(): boolean {\n    return this.value.startsWith('video/');\n  }\n\n  public get isImage(): boolean {\n    return this.value.startsWith('image/');\n  }\n\n  public get isAudio(): boolean {\n    return this.value.startsWith('audio/');\n  }\n\n  public get isJson(): boolean {\n    return this.value.startsWith('application/json');\n  }\n\n  public get isPdf(): boolean {\n    return this.value.startsWith('application/pdf');\n  }\n\n  public get isText(): boolean {\n    return this.value.startsWith('text/') || this.isJson;\n  }\n\n}\n\n@Component({\n  selector: 'elder-blob-viewer',\n  templateUrl: './elder-blob-viewer.component.html',\n  styleUrls: ['./elder-blob-viewer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderBlobViewerComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly blobContext$ = new BehaviorSubject<BlobContext>(null);\n\n\n  private readonly _url$ = new BehaviorSubject<string>(null);\n  private readonly _mimeType$ = new BehaviorSubject<string>(null);\n  private readonly destroy$ = new Subject<void>();\n  private _displayUnknownAsText = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private httpPristine: HttpClientPristine,\n    private domSanitizer: DomSanitizer,\n    private toastService: ElderToastService\n  ) {  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    combineLatest([this._url$, this._mimeType$]).pipe(\n      takeUntil(this.destroy$),\n      filter(([url, mimeType]) => !!url),\n      map(([url, mimeType]) => BlobUrl.from(url, mimeType))\n    ).subscribe(\n      blobUrl => this.blobUrl = blobUrl\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Attempt to display unknown blobs as text. (i.e. mime-type is octet-stream)\n   * @param unknownAsText\n   */\n  @Input()\n  public set displayUnknownAsText(unknownAsText: boolean) {\n\n    // TODO FIX RACE CONDITION:\n    //    Since this property is not reactive, it must be set first.\n    //    Otherwise, it will still be false, even if set to true!\n\n    this._displayUnknownAsText = coerceBooleanProperty(unknownAsText);\n  }\n\n  /**\n   * Set a in memory blob to display.\n   * @param blob\n   */\n  @Input()\n  public set blob(blob: Blob) {\n    this.handleBlob(blob);\n  }\n\n  /**\n   * Set a blob-url to display.\n   * @param blobUrl\n   */\n  @Input()\n  public set blobUrl(blobUrl: BlobUrl) {\n    this.handleBlobUrl(blobUrl);\n  }\n\n\n  /**\n   * Set a url to display. Requires the mimeType to be set aswell.\n   * @param url\n   */\n  @Input()\n  public set url(url: string) {\n    this._url$.next(url);\n  }\n\n  /**\n   * Set the mime-type for the url to display. Only considered if url is set.\n   * @param mimeType\n   */\n  @Input()\n  public set mimeType(mimeType: string) {\n    this._mimeType$.next(mimeType);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private handleBlob(blob: Blob): void {\n\n    const safeUrl = this.createSafeUrlFromBlob(blob);\n    const mimeType = BlobMimeType.parse(blob.type);\n\n    if (this.canDisplayAsText(mimeType)) {\n      this.textContext(blob, mimeType);\n    } else {\n      this.nextBlob(\n        BlobContext.safeUrl(safeUrl, mimeType)\n      );\n    }\n  }\n\n  private textContext(blob: Blob, mimeType: BlobMimeType): void {\n    blob.text().then(\n      text => {\n        this.nextBlob(\n          BlobContext.textBlob(text, mimeType)\n        );\n      }\n    );\n  }\n\n  private handleBlobUrl(blobUrl: BlobUrl): void {\n\n    const safeUrl = this.createSafeUrlFromDataUrl(blobUrl.url);\n    const mimeType = BlobMimeType.parse(blobUrl.mimeType);\n\n    if (this.canDisplayAsText(mimeType)) {\n      this.loadAsText(blobUrl.url, mimeType);\n    } else {\n      this.nextBlob(\n        BlobContext.safeUrl(safeUrl, mimeType)\n      );\n    }\n  }\n\n  private nextBlob(blobContext: BlobContext): void {\n    this.blobContext$.next(blobContext);\n  }\n\n  private createSafeUrlFromBlob(blob: Blob): SafeUrl {\n    const blobUrl = URL.createObjectURL(blob);\n    return this.domSanitizer.bypassSecurityTrustResourceUrl(blobUrl);\n  }\n\n  private createSafeUrlFromDataUrl(url: string): SafeUrl {\n    return this.domSanitizer.bypassSecurityTrustResourceUrl(url);\n  }\n\n  private loadAsText(pristineUrl: string, mimeType: BlobMimeType): void {\n\n    this.nextBlob(\n      BlobContext.textBlob('Loading...', mimeType)\n    );\n\n    this.downloadAsText(pristineUrl).subscribe(\n      text => {\n        this.nextBlob(\n          BlobContext.textBlob(text, mimeType)\n        );\n      },\n      err => {\n        this.nextBlob(\n          BlobContext.textBlob('Failed to download content!', mimeType)\n        );\n        this.toastService.warn('Failed to download content!', err);\n      }\n    );\n  }\n\n  private canDisplayAsText(mimeType: BlobMimeType): boolean {\n\n    const can = mimeType.isText || (this._displayUnknownAsText && mimeType.isOctetStream);\n\n    // TODO _displayUnknownAsText might be null due race condition see todo above.\n    // this.logger.debug('canDisplayAsText(' + mimeType.value + ') --> '\n    //  + can + ' ---> this._displayUnknownAsText:' + this._displayUnknownAsText, mimeType);\n\n    return can;\n  }\n\n  private downloadAsText(pristineUrl: string): Observable<string> {\n    return this.httpPristine.get(pristineUrl, {\n      responseType: 'text'\n    });\n  }\n}\n","<div class=\"layout-col full place-center-center document-viewer\">\n\n  <ng-container *ngIf=\"blobContext$ | async as blobContext\">\n\n    <!-- Video -->\n    <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.mimeType.isVideo\">\n      <video class=\"video\"\n             controls autoplay loop\n\n      >\n        <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n        Your browser does not support HTML5 video.\n      </video>\n    </div>\n\n    <!-- Audio -->\n    <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.mimeType.isAudio\">\n      <audio class=\"audio\"\n             controls autoplay loop\n      >\n        <source [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\">\n        Your browser does not support HTML5 audio.\n      </audio>\n    </div>\n\n    <!-- Image -->\n    <div class=\"layout-col full\" *ngIf=\"blobContext.mimeType.isImage\" style=\"overflow: hidden\">\n      <img class=\"cover flex\"\n           [src]=\"blobContext.safeUrl\" alt=\"blob image\"/>\n    </div>\n\n    <!-- Embedded (PDFs etc) -->\n    <div class=\"layout-col full\" *ngIf=\"blobContext.displayEmbedded\">\n      <div class=\"full\">\n        <embed class=\"embedded\" [src]=\"blobContext.safeUrl\" [type]=\"blobContext.mimeType.value\" width=\"100%\" height=\"100%\">\n      </div>\n    </div>\n\n    <!-- Plain Text -->\n    <div class=\"layout-col full\" *ngIf=\"blobContext.displayAsText\">\n      <textarea\n        class=\"document-content\"\n        placeholder=\"Content\"\n        [value]=\"blobContext.text\" wrap=\"off\"\n        readonly\n      ></textarea>\n    </div>\n\n    <div class=\"layout-col place-center-center full\" *ngIf=\"blobContext.cantDisplay\">\n      <p>Cant display {{blobContext.mimeType.value}}!</p>\n    </div>\n\n  </ng-container>\n\n  <ng-container *ngIf=\"!(blobContext$ | async)\">\n    <div class=\"layout-col place-center-center full\">\n      <p>No Document.</p>\n    </div>\n  </ng-container>\n\n\n</div>\n"]}
@@ -5,7 +5,6 @@ import { MatButtonModule } from '@angular/material/button';
5
5
  import { MatIconModule } from '@angular/material/icon';
6
6
  import { MatListModule } from '@angular/material/list';
7
7
  import { MatProgressBarModule } from '@angular/material/progress-bar';
8
- import { FlexLayoutModule } from '@angular/flex-layout';
9
8
  import { ElderPipesModule } from '../../pipes/elder-pipes.module';
10
9
  import { ElderFileUploadComponent } from './file-upload/file-upload.component';
11
10
  import { ElderFileSelectDirective } from './elder-file-select.directive';
@@ -26,7 +25,7 @@ ElderFileModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
26
25
  ElderFileSelectDirective,
27
26
  ElderFileDropZoneDirective,
28
27
  ElderBlobViewerComponent], imports: [CommonModule,
29
- FlexLayoutModule, MatListModule,
28
+ MatListModule,
30
29
  MatButtonModule, MatIconModule,
31
30
  MatProgressBarModule,
32
31
  ElderPipesModule], exports: [ElderFileSelectComponent,
@@ -35,7 +34,7 @@ ElderFileModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
35
34
  ElderFileDropZoneDirective,
36
35
  ElderBlobViewerComponent] });
37
36
  ElderFileModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderFileModule, imports: [CommonModule,
38
- FlexLayoutModule, MatListModule,
37
+ MatListModule,
39
38
  MatButtonModule, MatIconModule,
40
39
  MatProgressBarModule,
41
40
  ElderPipesModule] });
@@ -44,7 +43,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
44
43
  args: [{
45
44
  imports: [
46
45
  CommonModule,
47
- FlexLayoutModule, MatListModule,
46
+ MatListModule,
48
47
  MatButtonModule, MatIconModule,
49
48
  MatProgressBarModule,
50
49
  ElderPipesModule
@@ -65,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
65
64
  ]
66
65
  }]
67
66
  }] });
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZmlsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2VsZGVyLWZpbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ2hFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ3ZFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDOztBQUVuRixPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNuRixPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sWUFBWSxDQUFDO0FBNkJuQyxNQUFNLE9BQU8sZUFBZTs7NkdBQWYsZUFBZTs4R0FBZixlQUFlLGlCQWR4Qix3QkFBd0I7UUFDeEIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4QiwwQkFBMEI7UUFDMUIsd0JBQXdCLGFBZnhCLFlBQVk7UUFFWixnQkFBZ0IsRUFBRSxhQUFhO1FBRS9CLGVBQWUsRUFBRSxhQUFhO1FBRTlCLG9CQUFvQjtRQUVwQixnQkFBZ0IsYUFVaEIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4Qix3QkFBd0I7UUFDeEIsMEJBQTBCO1FBQzFCLHdCQUF3Qjs4R0FHZixlQUFlLFlBekJ4QixZQUFZO1FBRVosZ0JBQWdCLEVBQUUsYUFBYTtRQUUvQixlQUFlLEVBQUUsYUFBYTtRQUU5QixvQkFBb0I7UUFFcEIsZ0JBQWdCOzRGQWlCUCxlQUFlO2tCQTNCM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFFWixnQkFBZ0IsRUFBRSxhQUFhO3dCQUUvQixlQUFlLEVBQUUsYUFBYTt3QkFFOUIsb0JBQW9CO3dCQUVwQixnQkFBZ0I7cUJBQ2pCO29CQUNELFlBQVksRUFBRTt3QkFDWix3QkFBd0I7d0JBQ3hCLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4QiwwQkFBMEI7d0JBQzFCLHdCQUF3QjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4Qix3QkFBd0I7d0JBQ3hCLDBCQUEwQjt3QkFDMUIsd0JBQXdCO3FCQUN6QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0VsZGVyRmlsZVNlbGVjdENvbXBvbmVudH0gZnJvbSAnLi9maWxlLXNlbGVjdC9maWxlLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtNYXRMaXN0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcbmltcG9ydCB7TWF0UHJvZ3Jlc3NCYXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLWJhcic7XG5pbXBvcnQge0ZsZXhMYXlvdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcbmltcG9ydCB7RWxkZXJQaXBlc01vZHVsZX0gZnJvbSAnLi4vLi4vcGlwZXMvZWxkZXItcGlwZXMubW9kdWxlJztcbmltcG9ydCB7RWxkZXJGaWxlVXBsb2FkQ29tcG9uZW50fSBmcm9tICcuL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyRmlsZVNlbGVjdERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlckZpbGVEcm9wWm9uZURpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLWRyb3Atem9uZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlckJsb2JWaWV3ZXJDb21wb25lbnR9IGZyb20gJy4vYmxvYi12aWV3ZXIvZWxkZXItYmxvYi12aWV3ZXIuY29tcG9uZW50JztcblxuZXhwb3J0IHtFbGRlckZpbGVTZWxlY3RDb21wb25lbnR9IGZyb20gJy4vZmlsZS1zZWxlY3QvZmlsZS1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJGaWxlVXBsb2FkQ29tcG9uZW50fSBmcm9tICcuL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5leHBvcnQge0VsZGVyRmlsZVNlbGVjdERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtFbGRlckZpbGVEcm9wWm9uZURpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLWRyb3Atem9uZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHtFbGRlckJsb2JWaWV3ZXJDb21wb25lbnR9IGZyb20gJy4vYmxvYi12aWV3ZXIvZWxkZXItYmxvYi12aWV3ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7QmxvYlVybH0gZnJvbSAnLi9ibG9iLXVybCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG5cbiAgICBGbGV4TGF5b3V0TW9kdWxlLCBNYXRMaXN0TW9kdWxlLFxuXG4gICAgTWF0QnV0dG9uTW9kdWxlLCBNYXRJY29uTW9kdWxlLFxuXG4gICAgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUsXG5cbiAgICBFbGRlclBpcGVzTW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEVsZGVyRmlsZVNlbGVjdENvbXBvbmVudCxcbiAgICBFbGRlckZpbGVVcGxvYWRDb21wb25lbnQsXG4gICAgRWxkZXJGaWxlU2VsZWN0RGlyZWN0aXZlLFxuICAgIEVsZGVyRmlsZURyb3Bab25lRGlyZWN0aXZlLFxuICAgIEVsZGVyQmxvYlZpZXdlckNvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWxkZXJGaWxlU2VsZWN0Q29tcG9uZW50LFxuICAgIEVsZGVyRmlsZVVwbG9hZENvbXBvbmVudCxcbiAgICBFbGRlckZpbGVTZWxlY3REaXJlY3RpdmUsXG4gICAgRWxkZXJGaWxlRHJvcFpvbmVEaXJlY3RpdmUsXG4gICAgRWxkZXJCbG9iVmlld2VyQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJGaWxlTW9kdWxlIHtcbn1cbiJdfQ==
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZmlsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2VsZGVyLWZpbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ2hFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ3ZFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDOztBQUVuRixPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNuRixPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sWUFBWSxDQUFDO0FBNkJuQyxNQUFNLE9BQU8sZUFBZTs7NkdBQWYsZUFBZTs4R0FBZixlQUFlLGlCQWR4Qix3QkFBd0I7UUFDeEIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4QiwwQkFBMEI7UUFDMUIsd0JBQXdCLGFBZnhCLFlBQVk7UUFFWixhQUFhO1FBRWIsZUFBZSxFQUFFLGFBQWE7UUFFOUIsb0JBQW9CO1FBRXBCLGdCQUFnQixhQVVoQix3QkFBd0I7UUFDeEIsd0JBQXdCO1FBQ3hCLHdCQUF3QjtRQUN4QiwwQkFBMEI7UUFDMUIsd0JBQXdCOzhHQUdmLGVBQWUsWUF6QnhCLFlBQVk7UUFFWixhQUFhO1FBRWIsZUFBZSxFQUFFLGFBQWE7UUFFOUIsb0JBQW9CO1FBRXBCLGdCQUFnQjs0RkFpQlAsZUFBZTtrQkEzQjNCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBRVosYUFBYTt3QkFFYixlQUFlLEVBQUUsYUFBYTt3QkFFOUIsb0JBQW9CO3dCQUVwQixnQkFBZ0I7cUJBQ2pCO29CQUNELFlBQVksRUFBRTt3QkFDWix3QkFBd0I7d0JBQ3hCLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4QiwwQkFBMEI7d0JBQzFCLHdCQUF3QjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4Qix3QkFBd0I7d0JBQ3hCLDBCQUEwQjt3QkFDMUIsd0JBQXdCO3FCQUN6QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0VsZGVyRmlsZVNlbGVjdENvbXBvbmVudH0gZnJvbSAnLi9maWxlLXNlbGVjdC9maWxlLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtNYXRMaXN0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcbmltcG9ydCB7TWF0UHJvZ3Jlc3NCYXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLWJhcic7XG5pbXBvcnQge0VsZGVyUGlwZXNNb2R1bGV9IGZyb20gJy4uLy4uL3BpcGVzL2VsZGVyLXBpcGVzLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyRmlsZVVwbG9hZENvbXBvbmVudH0gZnJvbSAnLi9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5jb21wb25lbnQnO1xuaW1wb3J0IHtFbGRlckZpbGVTZWxlY3REaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItZmlsZS1zZWxlY3QuZGlyZWN0aXZlJztcbmltcG9ydCB7RWxkZXJGaWxlRHJvcFpvbmVEaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItZmlsZS1kcm9wLXpvbmUuZGlyZWN0aXZlJztcbmltcG9ydCB7RWxkZXJCbG9iVmlld2VyQ29tcG9uZW50fSBmcm9tICcuL2Jsb2Itdmlld2VyL2VsZGVyLWJsb2Itdmlld2VyLmNvbXBvbmVudCc7XG5cbmV4cG9ydCB7RWxkZXJGaWxlU2VsZWN0Q29tcG9uZW50fSBmcm9tICcuL2ZpbGUtc2VsZWN0L2ZpbGUtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQge0VsZGVyRmlsZVVwbG9hZENvbXBvbmVudH0gZnJvbSAnLi9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5jb21wb25lbnQnO1xuZXhwb3J0IHtFbGRlckZpbGVTZWxlY3REaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItZmlsZS1zZWxlY3QuZGlyZWN0aXZlJztcbmV4cG9ydCB7RWxkZXJGaWxlRHJvcFpvbmVEaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItZmlsZS1kcm9wLXpvbmUuZGlyZWN0aXZlJztcbmV4cG9ydCB7RWxkZXJCbG9iVmlld2VyQ29tcG9uZW50fSBmcm9tICcuL2Jsb2Itdmlld2VyL2VsZGVyLWJsb2Itdmlld2VyLmNvbXBvbmVudCc7XG5leHBvcnQge0Jsb2JVcmx9IGZyb20gJy4vYmxvYi11cmwnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuXG4gICAgTWF0TGlzdE1vZHVsZSxcblxuICAgIE1hdEJ1dHRvbk1vZHVsZSwgTWF0SWNvbk1vZHVsZSxcblxuICAgIE1hdFByb2dyZXNzQmFyTW9kdWxlLFxuXG4gICAgRWxkZXJQaXBlc01vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFbGRlckZpbGVTZWxlY3RDb21wb25lbnQsXG4gICAgRWxkZXJGaWxlVXBsb2FkQ29tcG9uZW50LFxuICAgIEVsZGVyRmlsZVNlbGVjdERpcmVjdGl2ZSxcbiAgICBFbGRlckZpbGVEcm9wWm9uZURpcmVjdGl2ZSxcbiAgICBFbGRlckJsb2JWaWV3ZXJDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyRmlsZVNlbGVjdENvbXBvbmVudCxcbiAgICBFbGRlckZpbGVVcGxvYWRDb21wb25lbnQsXG4gICAgRWxkZXJGaWxlU2VsZWN0RGlyZWN0aXZlLFxuICAgIEVsZGVyRmlsZURyb3Bab25lRGlyZWN0aXZlLFxuICAgIEVsZGVyQmxvYlZpZXdlckNvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyRmlsZU1vZHVsZSB7XG59XG4iXX0=
@@ -2,15 +2,14 @@ import { Component, Input } from '@angular/core';
2
2
  import { forkJoin } from 'rxjs';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
- import * as i2 from "@angular/flex-layout/flex";
6
- import * as i3 from "@angular/material/list";
7
- import * as i4 from "@angular/material/core";
8
- import * as i5 from "@angular/material/button";
9
- import * as i6 from "@angular/material/icon";
10
- import * as i7 from "@angular/material/progress-bar";
11
- import * as i8 from "../file-select/file-select.component";
12
- import * as i9 from "../../../pipes/bytes.pipe";
13
- import * as i10 from "../../../pipes/time-ago.pipe";
5
+ import * as i2 from "@angular/material/list";
6
+ import * as i3 from "@angular/material/core";
7
+ import * as i4 from "@angular/material/button";
8
+ import * as i5 from "@angular/material/icon";
9
+ import * as i6 from "@angular/material/progress-bar";
10
+ import * as i7 from "../file-select/file-select.component";
11
+ import * as i8 from "../../../pipes/bytes.pipe";
12
+ import * as i9 from "../../../pipes/time-ago.pipe";
14
13
  export class ElderFileUploadComponent {
15
14
  /***************************************************************************
16
15
  * *
@@ -59,10 +58,10 @@ export class ElderFileUploadComponent {
59
58
  }
60
59
  }
61
60
  ElderFileUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderFileUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
62
- ElderFileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderFileUploadComponent, selector: "elder-file-upload, ebs-file-upload", inputs: { files: "files", multiple: "multiple", accept: "accept", uploadClient: "uploadClient" }, ngImport: i0, template: "\n\n<div fxLayout=\"column\">\n\n <div fxLayout=\"row\" fxLayoutGap=\"10px\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.size === 0\">\n <mat-icon>cloud_upload</mat-icon>\n </button>\n\n <elder-file-select\n [multiple]=\"multiple\"\n [accept]=\"accept\"\n (filesChange)=\"files = $event\"\n ></elder-file-select>\n\n </div>\n\n <mat-list>\n <h2 mat-subheader>Selected Files ({{files.size}})</h2>\n <mat-list-item *ngFor=\"let file of files\">\n <mat-icon mat-list-icon>attach_file</mat-icon>\n <h4 mat-line>{{file.name}}</h4>\n <p mat-line> {{file.size | bytes}} - {{file.lastModified | timeAgo}}</p>\n\n <mat-progress-bar *ngIf=\"(transferOf(file)?.state$ | async) as state\"\n [color]=\"(state.hasFailed ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\">\n </mat-progress-bar>\n\n </mat-list-item>\n </mat-list>\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "component", type: i3.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { kind: "component", type: i3.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["disableRipple", "disabled"], exportAs: ["matListItem"] }, { kind: "directive", type: i4.MatLine, selector: "[mat-line], [matLine]" }, { kind: "directive", type: i3.MatListIconCssMatStyler, selector: "[mat-list-icon], [matListIcon]" }, { kind: "directive", type: i3.MatListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i8.ElderFileSelectComponent, selector: "elder-file-select, ebs-file-select", inputs: ["multiple", "accept", "icon", "color"], outputs: ["filesChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.BytesPipe, name: "bytes" }, { kind: "pipe", type: i10.TimeAgoPipe, name: "timeAgo" }] });
61
+ ElderFileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderFileUploadComponent, selector: "elder-file-upload, ebs-file-upload", inputs: { files: "files", multiple: "multiple", accept: "accept", uploadClient: "uploadClient" }, ngImport: i0, template: "\n\n<div class=\"layout-col\">\n\n <div class=\"layout-row gap-md\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.size === 0\">\n <mat-icon>cloud_upload</mat-icon>\n </button>\n\n <elder-file-select\n [multiple]=\"multiple\"\n [accept]=\"accept\"\n (filesChange)=\"files = $event\"\n ></elder-file-select>\n\n </div>\n\n <mat-list>\n <h2 mat-subheader>Selected Files ({{files.size}})</h2>\n <mat-list-item *ngFor=\"let file of files\">\n <mat-icon mat-list-icon>attach_file</mat-icon>\n <h4 mat-line>{{file.name}}</h4>\n <p mat-line> {{file.size | bytes}} - {{file.lastModified | timeAgo}}</p>\n\n <mat-progress-bar *ngIf=\"(transferOf(file)?.state$ | async) as state\"\n [color]=\"(state.hasFailed ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\">\n </mat-progress-bar>\n\n </mat-list-item>\n </mat-list>\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { kind: "component", type: i2.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["disableRipple", "disabled"], exportAs: ["matListItem"] }, { kind: "directive", type: i3.MatLine, selector: "[mat-line], [matLine]" }, { kind: "directive", type: i2.MatListIconCssMatStyler, selector: "[mat-list-icon], [matListIcon]" }, { kind: "directive", type: i2.MatListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i7.ElderFileSelectComponent, selector: "elder-file-select, ebs-file-select", inputs: ["multiple", "accept", "icon", "color"], outputs: ["filesChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.BytesPipe, name: "bytes" }, { kind: "pipe", type: i9.TimeAgoPipe, name: "timeAgo" }] });
63
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderFileUploadComponent, decorators: [{
64
63
  type: Component,
65
- args: [{ selector: 'elder-file-upload, ebs-file-upload', template: "\n\n<div fxLayout=\"column\">\n\n <div fxLayout=\"row\" fxLayoutGap=\"10px\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.size === 0\">\n <mat-icon>cloud_upload</mat-icon>\n </button>\n\n <elder-file-select\n [multiple]=\"multiple\"\n [accept]=\"accept\"\n (filesChange)=\"files = $event\"\n ></elder-file-select>\n\n </div>\n\n <mat-list>\n <h2 mat-subheader>Selected Files ({{files.size}})</h2>\n <mat-list-item *ngFor=\"let file of files\">\n <mat-icon mat-list-icon>attach_file</mat-icon>\n <h4 mat-line>{{file.name}}</h4>\n <p mat-line> {{file.size | bytes}} - {{file.lastModified | timeAgo}}</p>\n\n <mat-progress-bar *ngIf=\"(transferOf(file)?.state$ | async) as state\"\n [color]=\"(state.hasFailed ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\">\n </mat-progress-bar>\n\n </mat-list-item>\n </mat-list>\n\n</div>\n" }]
64
+ args: [{ selector: 'elder-file-upload, ebs-file-upload', template: "\n\n<div class=\"layout-col\">\n\n <div class=\"layout-row gap-md\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.size === 0\">\n <mat-icon>cloud_upload</mat-icon>\n </button>\n\n <elder-file-select\n [multiple]=\"multiple\"\n [accept]=\"accept\"\n (filesChange)=\"files = $event\"\n ></elder-file-select>\n\n </div>\n\n <mat-list>\n <h2 mat-subheader>Selected Files ({{files.size}})</h2>\n <mat-list-item *ngFor=\"let file of files\">\n <mat-icon mat-list-icon>attach_file</mat-icon>\n <h4 mat-line>{{file.name}}</h4>\n <p mat-line> {{file.size | bytes}} - {{file.lastModified | timeAgo}}</p>\n\n <mat-progress-bar *ngIf=\"(transferOf(file)?.state$ | async) as state\"\n [color]=\"(state.hasFailed ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\">\n </mat-progress-bar>\n\n </mat-list-item>\n </mat-list>\n\n</div>\n" }]
66
65
  }], ctorParameters: function () { return []; }, propDecorators: { files: [{
67
66
  type: Input
68
67
  }], multiple: [{
@@ -72,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
72
71
  }], uploadClient: [{
73
72
  type: Input
74
73
  }] } });
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9maWxlcy9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBQyxRQUFRLEVBQWEsTUFBTSxNQUFNLENBQUM7Ozs7Ozs7Ozs7OztBQVMxQyxNQUFNLE9BQU8sd0JBQXdCO0lBdUJuQzs7OztnRkFJNEU7SUFFNUU7UUExQkE7Ozs7b0ZBSTRFO1FBR3JFLFVBQUssR0FBYyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBSzdCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsV0FBTSxHQUFXLFNBQVMsQ0FBQztJQVlsQyxDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRXJFLFFBQVE7SUFFZixDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRXJFLFdBQVcsQ0FBQyxLQUFVO1FBQzNCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVNLFVBQVUsQ0FBQyxJQUFVO1FBQzFCLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUN2QixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3RDO1FBQ0QsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVwRSxjQUFjLENBQUMsS0FBZ0I7UUFDckMsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMzRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDaEQsQ0FBQzs7c0hBcEVVLHdCQUF3QjswR0FBeEIsd0JBQXdCLDRLQ1ZyQyxtbUNBb0NBOzRGRDFCYSx3QkFBd0I7a0JBTHBDLFNBQVM7K0JBQ0Usb0NBQW9DOzBFQWN2QyxLQUFLO3NCQURYLEtBQUs7Z0JBTUMsUUFBUTtzQkFEZCxLQUFLO2dCQUlDLE1BQU07c0JBRFosS0FBSztnQkFJQyxZQUFZO3NCQURsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIElucHV0LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtmb3JrSm9pbiwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0lGaWxlVXBsb2FkQ2xpZW50fSBmcm9tICcuLi8uLi8uLi9jb21tb24vaHR0cC91cGxvYWQvZmlsZS11cGxvYWQtY2xpZW50JztcbmltcG9ydCB7SHR0cERhdGFUcmFuc2Zlcn0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2h0dHAvdHJhbnNmZXIvaHR0cC1kYXRhLXRyYW5zZmVyJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZWxkZXItZmlsZS11cGxvYWQsIGVicy1maWxlLXVwbG9hZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWxlLXVwbG9hZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJGaWxlVXBsb2FkQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBmaWxlczogU2V0PEZpbGU+ID0gbmV3IFNldCgpO1xuICBwdWJsaWMgdXBsb2FkUHJvZ3Jlc3M6IE1hcDxGaWxlLCBIdHRwRGF0YVRyYW5zZmVyPjtcbiAgcHVibGljIHRvdGFsUHJvZ3Jlc3M6IE9ic2VydmFibGU8YW55PjtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgbXVsdGlwbGUgPSBmYWxzZTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgYWNjZXB0OiBzdHJpbmcgPSB1bmRlZmluZWQ7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHVwbG9hZENsaWVudDogSUZpbGVVcGxvYWRDbGllbnQ7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIENvbnN0cnVjdG9yICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogTGlmZSBDeWNsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG5cbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBzdGFydFVwbG9hZChldmVudDogYW55KTogdm9pZCB7XG4gICAgdGhpcy50b3RhbFByb2dyZXNzID0gdGhpcy51cGxvYWRBbGxGaWxlcyh0aGlzLmZpbGVzKTtcbiAgfVxuXG4gIHB1YmxpYyB0cmFuc2Zlck9mKGZpbGU6IEZpbGUpOiBIdHRwRGF0YVRyYW5zZmVyIHtcbiAgICBpZiAodGhpcy51cGxvYWRQcm9ncmVzcykge1xuICAgICAgcmV0dXJuIHRoaXMudXBsb2FkUHJvZ3Jlc3MuZ2V0KGZpbGUpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFByaXZhdGUgbWV0aG9kcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHJpdmF0ZSB1cGxvYWRBbGxGaWxlcyhmaWxlczogU2V0PEZpbGU+KTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICB0aGlzLnVwbG9hZFByb2dyZXNzID0gdGhpcy51cGxvYWRDbGllbnQudXBsb2FkRmlsZXMoZmlsZXMpO1xuICAgIHJldHVybiBmb3JrSm9pbih0aGlzLnVwbG9hZFByb2dyZXNzLnZhbHVlcygpKTtcbiAgfVxuXG59XG4iLCJcblxuPGRpdiBmeExheW91dD1cImNvbHVtblwiPlxuXG4gIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEdhcD1cIjEwcHhcIj5cblxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIHR5cGU9XCJidXR0b25cIiBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgKm5nSWY9XCJ1cGxvYWRDbGllbnRcIiAgKGNsaWNrKT1cInN0YXJ0VXBsb2FkKCRldmVudClcIiBbZGlzYWJsZWRdPVwiZmlsZXMuc2l6ZSA9PT0gMFwiPlxuICAgICAgPG1hdC1pY29uPmNsb3VkX3VwbG9hZDwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG5cbiAgICA8ZWxkZXItZmlsZS1zZWxlY3RcbiAgICAgICAgICAgIFttdWx0aXBsZV09XCJtdWx0aXBsZVwiXG4gICAgICAgICAgICBbYWNjZXB0XT1cImFjY2VwdFwiXG4gICAgICAgICAgICAoZmlsZXNDaGFuZ2UpPVwiZmlsZXMgPSAkZXZlbnRcIlxuICAgID48L2VsZGVyLWZpbGUtc2VsZWN0PlxuXG4gIDwvZGl2PlxuXG4gIDxtYXQtbGlzdD5cbiAgICA8aDIgbWF0LXN1YmhlYWRlcj5TZWxlY3RlZCBGaWxlcyAoe3tmaWxlcy5zaXplfX0pPC9oMj5cbiAgICA8bWF0LWxpc3QtaXRlbSAqbmdGb3I9XCJsZXQgZmlsZSBvZiBmaWxlc1wiPlxuICAgICAgPG1hdC1pY29uIG1hdC1saXN0LWljb24+YXR0YWNoX2ZpbGU8L21hdC1pY29uPlxuICAgICAgPGg0IG1hdC1saW5lPnt7ZmlsZS5uYW1lfX08L2g0PlxuICAgICAgPHAgbWF0LWxpbmU+IHt7ZmlsZS5zaXplIHwgYnl0ZXN9fSAgLSB7e2ZpbGUubGFzdE1vZGlmaWVkIHwgdGltZUFnb319PC9wPlxuXG4gICAgICA8bWF0LXByb2dyZXNzLWJhciAqbmdJZj1cIih0cmFuc2Zlck9mKGZpbGUpPy5zdGF0ZSQgfCBhc3luYykgYXMgc3RhdGVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgW2NvbG9yXT1cIihzdGF0ZS5oYXNGYWlsZWQgPyAnd2FybicgOiAnJylcIlxuICAgICAgICAgICAgICAgICAgICAgICAgbW9kZT1cImRldGVybWluYXRlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFt2YWx1ZV09XCJzdGF0ZS5wcm9ncmVzcy5wZXJjZW50RG9uZVwiPlxuICAgICAgPC9tYXQtcHJvZ3Jlc3MtYmFyPlxuXG4gICAgPC9tYXQtbGlzdC1pdGVtPlxuICA8L21hdC1saXN0PlxuXG48L2Rpdj5cbiJdfQ==
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9maWxlcy9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBQyxRQUFRLEVBQWEsTUFBTSxNQUFNLENBQUM7Ozs7Ozs7Ozs7O0FBUzFDLE1BQU0sT0FBTyx3QkFBd0I7SUF1Qm5DOzs7O2dGQUk0RTtJQUU1RTtRQTFCQTs7OztvRkFJNEU7UUFHckUsVUFBSyxHQUFjLElBQUksR0FBRyxFQUFFLENBQUM7UUFLN0IsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUdqQixXQUFNLEdBQVcsU0FBUyxDQUFDO0lBWWxDLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsUUFBUTtJQUVmLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsV0FBVyxDQUFDLEtBQVU7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU0sVUFBVSxDQUFDLElBQVU7UUFDMUIsSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3ZCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDdEM7UUFDRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRXBFLGNBQWMsQ0FBQyxLQUFnQjtRQUNyQyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUNoRCxDQUFDOztzSEFwRVUsd0JBQXdCOzBHQUF4Qix3QkFBd0IsNEtDVnJDLDBsQ0FvQ0E7NEZEMUJhLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxvQ0FBb0M7MEVBY3ZDLEtBQUs7c0JBRFgsS0FBSztnQkFNQyxRQUFRO3NCQURkLEtBQUs7Z0JBSUMsTUFBTTtzQkFEWixLQUFLO2dCQUlDLFlBQVk7c0JBRGxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge2ZvcmtKb2luLCBPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7SUZpbGVVcGxvYWRDbGllbnR9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9odHRwL3VwbG9hZC9maWxlLXVwbG9hZC1jbGllbnQnO1xuaW1wb3J0IHtIdHRwRGF0YVRyYW5zZmVyfSBmcm9tICcuLi8uLi8uLi9jb21tb24vaHR0cC90cmFuc2Zlci9odHRwLWRhdGEtdHJhbnNmZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlbGRlci1maWxlLXVwbG9hZCwgZWJzLWZpbGUtdXBsb2FkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsZS11cGxvYWQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckZpbGVVcGxvYWRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgQElucHV0KClcbiAgcHVibGljIGZpbGVzOiBTZXQ8RmlsZT4gPSBuZXcgU2V0KCk7XG4gIHB1YmxpYyB1cGxvYWRQcm9ncmVzczogTWFwPEZpbGUsIEh0dHBEYXRhVHJhbnNmZXI+O1xuICBwdWJsaWMgdG90YWxQcm9ncmVzczogT2JzZXJ2YWJsZTxhbnk+O1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBtdWx0aXBsZSA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBhY2NlcHQ6IHN0cmluZyA9IHVuZGVmaW5lZDtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgdXBsb2FkQ2xpZW50OiBJRmlsZVVwbG9hZENsaWVudDtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBMaWZlIEN5Y2xlICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcblxuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFB1YmxpYyBBUEkgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIHN0YXJ0VXBsb2FkKGV2ZW50OiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLnRvdGFsUHJvZ3Jlc3MgPSB0aGlzLnVwbG9hZEFsbEZpbGVzKHRoaXMuZmlsZXMpO1xuICB9XG5cbiAgcHVibGljIHRyYW5zZmVyT2YoZmlsZTogRmlsZSk6IEh0dHBEYXRhVHJhbnNmZXIge1xuICAgIGlmICh0aGlzLnVwbG9hZFByb2dyZXNzKSB7XG4gICAgICByZXR1cm4gdGhpcy51cGxvYWRQcm9ncmVzcy5nZXQoZmlsZSk7XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHJpdmF0ZSBtZXRob2RzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHVwbG9hZEFsbEZpbGVzKGZpbGVzOiBTZXQ8RmlsZT4pOiBPYnNlcnZhYmxlPGFueT4ge1xuICAgIHRoaXMudXBsb2FkUHJvZ3Jlc3MgPSB0aGlzLnVwbG9hZENsaWVudC51cGxvYWRGaWxlcyhmaWxlcyk7XG4gICAgcmV0dXJuIGZvcmtKb2luKHRoaXMudXBsb2FkUHJvZ3Jlc3MudmFsdWVzKCkpO1xuICB9XG5cbn1cbiIsIlxuXG48ZGl2IGNsYXNzPVwibGF5b3V0LWNvbFwiPlxuXG4gIDxkaXYgY2xhc3M9XCJsYXlvdXQtcm93IGdhcC1tZFwiPlxuXG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gdHlwZT1cImJ1dHRvblwiIGNvbG9yPVwicHJpbWFyeVwiXG4gICAgICAgICAgICAqbmdJZj1cInVwbG9hZENsaWVudFwiICAoY2xpY2spPVwic3RhcnRVcGxvYWQoJGV2ZW50KVwiIFtkaXNhYmxlZF09XCJmaWxlcy5zaXplID09PSAwXCI+XG4gICAgICA8bWF0LWljb24+Y2xvdWRfdXBsb2FkPC9tYXQtaWNvbj5cbiAgICA8L2J1dHRvbj5cblxuICAgIDxlbGRlci1maWxlLXNlbGVjdFxuICAgICAgICAgICAgW211bHRpcGxlXT1cIm11bHRpcGxlXCJcbiAgICAgICAgICAgIFthY2NlcHRdPVwiYWNjZXB0XCJcbiAgICAgICAgICAgIChmaWxlc0NoYW5nZSk9XCJmaWxlcyA9ICRldmVudFwiXG4gICAgPjwvZWxkZXItZmlsZS1zZWxlY3Q+XG5cbiAgPC9kaXY+XG5cbiAgPG1hdC1saXN0PlxuICAgIDxoMiBtYXQtc3ViaGVhZGVyPlNlbGVjdGVkIEZpbGVzICh7e2ZpbGVzLnNpemV9fSk8L2gyPlxuICAgIDxtYXQtbGlzdC1pdGVtICpuZ0Zvcj1cImxldCBmaWxlIG9mIGZpbGVzXCI+XG4gICAgICA8bWF0LWljb24gbWF0LWxpc3QtaWNvbj5hdHRhY2hfZmlsZTwvbWF0LWljb24+XG4gICAgICA8aDQgbWF0LWxpbmU+e3tmaWxlLm5hbWV9fTwvaDQ+XG4gICAgICA8cCBtYXQtbGluZT4ge3tmaWxlLnNpemUgfCBieXRlc319ICAtIHt7ZmlsZS5sYXN0TW9kaWZpZWQgfCB0aW1lQWdvfX08L3A+XG5cbiAgICAgIDxtYXQtcHJvZ3Jlc3MtYmFyICpuZ0lmPVwiKHRyYW5zZmVyT2YoZmlsZSk/LnN0YXRlJCB8IGFzeW5jKSBhcyBzdGF0ZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBbY29sb3JdPVwiKHN0YXRlLmhhc0ZhaWxlZCA/ICd3YXJuJyA6ICcnKVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBtb2RlPVwiZGV0ZXJtaW5hdGVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgW3ZhbHVlXT1cInN0YXRlLnByb2dyZXNzLnBlcmNlbnREb25lXCI+XG4gICAgICA8L21hdC1wcm9ncmVzcy1iYXI+XG5cbiAgICA8L21hdC1saXN0LWl0ZW0+XG4gIDwvbWF0LWxpc3Q+XG5cbjwvZGl2PlxuIl19
@@ -3,7 +3,6 @@ import { CommonModule } from '@angular/common';
3
3
  import { ElderSearchContextDirective } from './elder-search-context.directive';
4
4
  import { ElderSearchInputDirective } from './elder-search-input.directive';
5
5
  import { ElderSearchBoxComponent } from './search-box/elder-search-box.component';
6
- import { FlexLayoutModule } from '@angular/flex-layout';
7
6
  import { FormsModule } from '@angular/forms';
8
7
  import { MatBadgeModule } from '@angular/material/badge';
9
8
  import { MatButtonModule } from '@angular/material/button';
@@ -31,7 +30,7 @@ ElderSearchModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versi
31
30
  ElderOverlayModule,
32
31
  ElderPanelModule,
33
32
  ElderFormsDirectivesModule,
34
- FlexLayoutModule, TranslateModule], exports: [ElderSearchContextDirective, ElderSearchInputDirective,
33
+ TranslateModule], exports: [ElderSearchContextDirective, ElderSearchInputDirective,
35
34
  ElderSearchBoxComponent, ElderSearchPanelComponent] });
36
35
  ElderSearchModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSearchModule, imports: [CommonModule, FormsModule,
37
36
  MatInputModule, MatButtonModule, MatIconModule,
@@ -40,7 +39,7 @@ ElderSearchModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versi
40
39
  ElderOverlayModule,
41
40
  ElderPanelModule,
42
41
  ElderFormsDirectivesModule,
43
- FlexLayoutModule, TranslateModule] });
42
+ TranslateModule] });
44
43
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSearchModule, decorators: [{
45
44
  type: NgModule,
46
45
  args: [{
@@ -52,7 +51,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
52
51
  ElderOverlayModule,
53
52
  ElderPanelModule,
54
53
  ElderFormsDirectivesModule,
55
- FlexLayoutModule, TranslateModule
54
+ TranslateModule
56
55
  ],
57
56
  declarations: [
58
57
  ElderSearchContextDirective, ElderSearchInputDirective,
@@ -64,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
64
63
  ],
65
64
  }]
66
65
  }] });
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2VhcmNoLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvc2VhcmNoL2VsZGVyLXNlYXJjaC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDN0UsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDekUsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDN0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ3BGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLDZDQUE2QyxDQUFDOztBQUd2RixPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUM3RSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQTBCcEYsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQVIxQiwyQkFBMkIsRUFBRSx5QkFBeUI7UUFDdEQsdUJBQXVCLEVBQUUseUJBQXlCLGFBZmxELFlBQVksRUFBRSxXQUFXO1FBRXpCLGNBQWMsRUFBRSxlQUFlLEVBQUUsYUFBYTtRQUM5QyxjQUFjO1FBRWQsVUFBVTtRQUVWLGtCQUFrQjtRQUNsQixnQkFBZ0I7UUFDaEIsMEJBQTBCO1FBRTFCLGdCQUFnQixFQUFFLGVBQWUsYUFPakMsMkJBQTJCLEVBQUUseUJBQXlCO1FBQ3RELHVCQUF1QixFQUFFLHlCQUF5QjtnSEFHekMsaUJBQWlCLFlBdEIxQixZQUFZLEVBQUUsV0FBVztRQUV6QixjQUFjLEVBQUUsZUFBZSxFQUFFLGFBQWE7UUFDOUMsY0FBYztRQUVkLFVBQVU7UUFFVixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLDBCQUEwQjtRQUUxQixnQkFBZ0IsRUFBRSxlQUFlOzRGQVd4QixpQkFBaUI7a0JBeEI3QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZLEVBQUUsV0FBVzt3QkFFekIsY0FBYyxFQUFFLGVBQWUsRUFBRSxhQUFhO3dCQUM5QyxjQUFjO3dCQUVkLFVBQVU7d0JBRVYsa0JBQWtCO3dCQUNsQixnQkFBZ0I7d0JBQ2hCLDBCQUEwQjt3QkFFMUIsZ0JBQWdCLEVBQUUsZUFBZTtxQkFDbEM7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLDJCQUEyQixFQUFFLHlCQUF5Qjt3QkFDdEQsdUJBQXVCLEVBQUUseUJBQXlCO3FCQUNuRDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMkJBQTJCLEVBQUUseUJBQXlCO3dCQUN0RCx1QkFBdUIsRUFBRSx5QkFBeUI7cUJBQ25EO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0VsZGVyU2VhcmNoQ29udGV4dERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1zZWFyY2gtY29udGV4dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlclNlYXJjaElucHV0RGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLXNlYXJjaC1pbnB1dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlclNlYXJjaEJveENvbXBvbmVudH0gZnJvbSAnLi9zZWFyY2gtYm94L2VsZGVyLXNlYXJjaC1ib3guY29tcG9uZW50JztcbmltcG9ydCB7RmxleExheW91dE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZmxleC1sYXlvdXQnO1xuaW1wb3J0IHtGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0QmFkZ2VNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9iYWRnZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQge0ExMXlNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7VHJhbnNsYXRlTW9kdWxlfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7RWxkZXJPdmVybGF5TW9kdWxlfSBmcm9tICcuLi8uLi9vdmVybGF5cy9lbGRlci1vdmVybGF5Lm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyU2VhcmNoUGFuZWxDb21wb25lbnR9IGZyb20gJy4vc2VhcmNoLWJveC9lbGRlci1zZWFyY2gtcGFuZWwuY29tcG9uZW50JztcbmltcG9ydCB7RWxkZXJQYW5lbE1vZHVsZX0gZnJvbSAnLi4vLi4vcGFuZWxzL2VsZGVyLXBhbmVsLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyRm9ybXNEaXJlY3RpdmVzTW9kdWxlfSBmcm9tICcuLi9kaXJlY3RpdmVzL2VsZGVyLWZvcm1zLWRpcmVjdGl2ZXMubW9kdWxlJztcblxuXG5leHBvcnQge0VsZGVyU2VhcmNoQ29udGV4dERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1zZWFyY2gtY29udGV4dC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtFbGRlclNlYXJjaElucHV0RGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLXNlYXJjaC1pbnB1dC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtFbGRlclNlYXJjaEJveENvbXBvbmVudH0gZnJvbSAnLi9zZWFyY2gtYm94L2VsZGVyLXNlYXJjaC1ib3guY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJTZWFyY2hQYW5lbENvbXBvbmVudH0gZnJvbSAnLi9zZWFyY2gtYm94L2VsZGVyLXNlYXJjaC1wYW5lbC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSxcblxuICAgIE1hdElucHV0TW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0QmFkZ2VNb2R1bGUsXG5cbiAgICBBMTF5TW9kdWxlLFxuXG4gICAgRWxkZXJPdmVybGF5TW9kdWxlLFxuICAgIEVsZGVyUGFuZWxNb2R1bGUsXG4gICAgRWxkZXJGb3Jtc0RpcmVjdGl2ZXNNb2R1bGUsXG5cbiAgICBGbGV4TGF5b3V0TW9kdWxlLCBUcmFuc2xhdGVNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWxkZXJTZWFyY2hDb250ZXh0RGlyZWN0aXZlLCBFbGRlclNlYXJjaElucHV0RGlyZWN0aXZlLFxuICAgIEVsZGVyU2VhcmNoQm94Q29tcG9uZW50LCBFbGRlclNlYXJjaFBhbmVsQ29tcG9uZW50XG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBFbGRlclNlYXJjaENvbnRleHREaXJlY3RpdmUsIEVsZGVyU2VhcmNoSW5wdXREaXJlY3RpdmUsXG4gICAgRWxkZXJTZWFyY2hCb3hDb21wb25lbnQsIEVsZGVyU2VhcmNoUGFuZWxDb21wb25lbnRcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJTZWFyY2hNb2R1bGUgeyB9XG4iXX0=
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2VhcmNoLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvc2VhcmNoL2VsZGVyLXNlYXJjaC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDN0UsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDekUsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDaEYsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDN0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ3BGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLDZDQUE2QyxDQUFDOztBQUd2RixPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUM3RSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQTBCcEYsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQVIxQiwyQkFBMkIsRUFBRSx5QkFBeUI7UUFDdEQsdUJBQXVCLEVBQUUseUJBQXlCLGFBZmxELFlBQVksRUFBRSxXQUFXO1FBRXpCLGNBQWMsRUFBRSxlQUFlLEVBQUUsYUFBYTtRQUM5QyxjQUFjO1FBRWQsVUFBVTtRQUVWLGtCQUFrQjtRQUNsQixnQkFBZ0I7UUFDaEIsMEJBQTBCO1FBRTFCLGVBQWUsYUFPZiwyQkFBMkIsRUFBRSx5QkFBeUI7UUFDdEQsdUJBQXVCLEVBQUUseUJBQXlCO2dIQUd6QyxpQkFBaUIsWUF0QjFCLFlBQVksRUFBRSxXQUFXO1FBRXpCLGNBQWMsRUFBRSxlQUFlLEVBQUUsYUFBYTtRQUM5QyxjQUFjO1FBRWQsVUFBVTtRQUVWLGtCQUFrQjtRQUNsQixnQkFBZ0I7UUFDaEIsMEJBQTBCO1FBRTFCLGVBQWU7NEZBV04saUJBQWlCO2tCQXhCN0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWSxFQUFFLFdBQVc7d0JBRXpCLGNBQWMsRUFBRSxlQUFlLEVBQUUsYUFBYTt3QkFDOUMsY0FBYzt3QkFFZCxVQUFVO3dCQUVWLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3dCQUNoQiwwQkFBMEI7d0JBRTFCLGVBQWU7cUJBQ2hCO29CQUNELFlBQVksRUFBRTt3QkFDWiwyQkFBMkIsRUFBRSx5QkFBeUI7d0JBQ3RELHVCQUF1QixFQUFFLHlCQUF5QjtxQkFDbkQ7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDJCQUEyQixFQUFFLHlCQUF5Qjt3QkFDdEQsdUJBQXVCLEVBQUUseUJBQXlCO3FCQUNuRDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtFbGRlclNlYXJjaENvbnRleHREaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItc2VhcmNoLWNvbnRleHQuZGlyZWN0aXZlJztcbmltcG9ydCB7RWxkZXJTZWFyY2hJbnB1dERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1zZWFyY2gtaW5wdXQuZGlyZWN0aXZlJztcbmltcG9ydCB7RWxkZXJTZWFyY2hCb3hDb21wb25lbnR9IGZyb20gJy4vc2VhcmNoLWJveC9lbGRlci1zZWFyY2gtYm94LmNvbXBvbmVudCc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRCYWRnZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2JhZGdlJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7QTExeU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtFbGRlck92ZXJsYXlNb2R1bGV9IGZyb20gJy4uLy4uL292ZXJsYXlzL2VsZGVyLW92ZXJsYXkubW9kdWxlJztcbmltcG9ydCB7RWxkZXJTZWFyY2hQYW5lbENvbXBvbmVudH0gZnJvbSAnLi9zZWFyY2gtYm94L2VsZGVyLXNlYXJjaC1wYW5lbC5jb21wb25lbnQnO1xuaW1wb3J0IHtFbGRlclBhbmVsTW9kdWxlfSBmcm9tICcuLi8uLi9wYW5lbHMvZWxkZXItcGFuZWwubW9kdWxlJztcbmltcG9ydCB7RWxkZXJGb3Jtc0RpcmVjdGl2ZXNNb2R1bGV9IGZyb20gJy4uL2RpcmVjdGl2ZXMvZWxkZXItZm9ybXMtZGlyZWN0aXZlcy5tb2R1bGUnO1xuXG5cbmV4cG9ydCB7RWxkZXJTZWFyY2hDb250ZXh0RGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLXNlYXJjaC1jb250ZXh0LmRpcmVjdGl2ZSc7XG5leHBvcnQge0VsZGVyU2VhcmNoSW5wdXREaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItc2VhcmNoLWlucHV0LmRpcmVjdGl2ZSc7XG5leHBvcnQge0VsZGVyU2VhcmNoQm94Q29tcG9uZW50fSBmcm9tICcuL3NlYXJjaC1ib3gvZWxkZXItc2VhcmNoLWJveC5jb21wb25lbnQnO1xuZXhwb3J0IHtFbGRlclNlYXJjaFBhbmVsQ29tcG9uZW50fSBmcm9tICcuL3NlYXJjaC1ib3gvZWxkZXItc2VhcmNoLXBhbmVsLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsIEZvcm1zTW9kdWxlLFxuXG4gICAgTWF0SW5wdXRNb2R1bGUsIE1hdEJ1dHRvbk1vZHVsZSwgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRCYWRnZU1vZHVsZSxcblxuICAgIEExMXlNb2R1bGUsXG5cbiAgICBFbGRlck92ZXJsYXlNb2R1bGUsXG4gICAgRWxkZXJQYW5lbE1vZHVsZSxcbiAgICBFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZSxcblxuICAgIFRyYW5zbGF0ZU1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFbGRlclNlYXJjaENvbnRleHREaXJlY3RpdmUsIEVsZGVyU2VhcmNoSW5wdXREaXJlY3RpdmUsXG4gICAgRWxkZXJTZWFyY2hCb3hDb21wb25lbnQsIEVsZGVyU2VhcmNoUGFuZWxDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyU2VhcmNoQ29udGV4dERpcmVjdGl2ZSwgRWxkZXJTZWFyY2hJbnB1dERpcmVjdGl2ZSxcbiAgICBFbGRlclNlYXJjaEJveENvbXBvbmVudCwgRWxkZXJTZWFyY2hQYW5lbENvbXBvbmVudFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlclNlYXJjaE1vZHVsZSB7IH1cbiJdfQ==
@@ -17,9 +17,8 @@ import * as i10 from "../../../overlays/elder-overlay-trigger.directive";
17
17
  import * as i11 from "../../../overlays/elder-overlay-origin.directive";
18
18
  import * as i12 from "../../../panels/elder-dialog-panel/elder-dialog-panel.component";
19
19
  import * as i13 from "../../directives/elder-form-field-dense.directive";
20
- import * as i14 from "@angular/flex-layout/flex";
21
- import * as i15 from "../elder-search-input.directive";
22
- import * as i16 from "@ngx-translate/core";
20
+ import * as i14 from "../elder-search-input.directive";
21
+ import * as i15 from "@ngx-translate/core";
23
22
  export class OverlayState {
24
23
  constructor(hasOverlay) {
25
24
  this.hasOverlay = hasOverlay;
@@ -94,10 +93,10 @@ export class ElderSearchBoxComponent {
94
93
  }
95
94
  }
96
95
  ElderSearchBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSearchBoxComponent, deps: [{ token: i1.ElderSearchContextDirective }], target: i0.ɵɵFactoryTarget.Component });
97
- ElderSearchBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderSearchBoxComponent, selector: "elder-search-box", inputs: { autoPanel: "autoPanel", name: "name", queryKey: "queryKey", placeholder: "placeholder", label: "label", hint: "hint", autocomplete: "autocomplete", dense: "dense" }, queries: [{ propertyName: "advancedSearch", first: true, predicate: ElderSearchPanelComponent, descendants: true }], viewQueries: [{ propertyName: "search", first: true, predicate: ["search"], descendants: true }], exportAs: ["elderSearchBox"], ngImport: i0, template: "<div fxLayout=\"row\" fxFlex>\n\n <!-- Main search input -->\n <mat-form-field\n *ngIf=\"overlayState$ | async as overlayState\"\n fxFlex=\"grow\" fxFlexAlign=\"center\"\n [elderDense]=\"dense\">\n\n <button matPrefix mat-icon-button type=\"button\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n >\n <mat-icon>search</mat-icon>\n </button>\n\n <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n ngModel\n elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n [elderOverlayOrigin]=\"searchPanel\"\n [elderOverlayTrigger]=\"searchPanel\"\n [elderOverlayTriggerType]=\"'focus'\"\n [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n >\n <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n <div fxLayout=\"row\" matSuffix *ngIf=\"searchModel.userDefinedAttributes$ | async as userDefinedFilters\">\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"userDefinedFilters.length > 0\"\n (click)=\"clearSearch($event)\"\n name=\"clear\" aria-label=\"Clear\">\n <mat-icon>close</mat-icon>\n </button>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n [matBadge]=\"userDefinedFilters.length\"\n [matBadgeHidden]=\"userDefinedFilters.length == 0\"\n matBadgeColor=\"accent\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n <mat-icon [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\">filter_list</mat-icon>\n </button>\n\n </div>\n </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n <elder-dialog-panel class=\"elder-search-panel-container\">\n\n <!-- Project the users search inputs here -->\n <ng-content select=\"elder-search-panel\"></ng-content>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">\n <button mat-raised-button type=\"button\" name=\"clear\"\n (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n </button>\n\n <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n (click)=\"searchPanel.closeOverlay()\">Ok\n </button>\n </div>\n </elder-dialog-panel>\n</elder-overlay>\n", styles: [".elder-search-panel-container{min-width:250px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix]" }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i6.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i8.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "component", type: i9.ElderOverlayComponent, selector: "elder-overlay", inputs: ["originX", "originY", "overlayX", "overlayY", "offsetY", "offsetX", "backdrop", "backdropVisible", "origin", "positionStrategy", "overlaySize"], outputs: ["keydownEvents", "attachedChange"], exportAs: ["elderOverlay"] }, { kind: "directive", type: i10.ElderOverlayTriggerDirective, selector: "[elderOverlayTrigger]", inputs: ["elderOverlayTrigger", "elderOverlayTriggerType", "elderOverlayTriggerEnabled"] }, { kind: "directive", type: i11.ElderOverlayOriginDirective, selector: "[elderOverlayOrigin]", inputs: ["elderOverlayOrigin"] }, { kind: "component", type: i12.ElderDialogPanelComponent, selector: "elder-dialog-panel" }, { kind: "directive", type: i13.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { kind: "directive", type: i14.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i14.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i14.DefaultFlexAlignDirective, selector: " [fxFlexAlign], [fxFlexAlign.xs], [fxFlexAlign.sm], [fxFlexAlign.md], [fxFlexAlign.lg], [fxFlexAlign.xl], [fxFlexAlign.lt-sm], [fxFlexAlign.lt-md], [fxFlexAlign.lt-lg], [fxFlexAlign.lt-xl], [fxFlexAlign.gt-xs], [fxFlexAlign.gt-sm], [fxFlexAlign.gt-md], [fxFlexAlign.gt-lg]", inputs: ["fxFlexAlign", "fxFlexAlign.xs", "fxFlexAlign.sm", "fxFlexAlign.md", "fxFlexAlign.lg", "fxFlexAlign.xl", "fxFlexAlign.lt-sm", "fxFlexAlign.lt-md", "fxFlexAlign.lt-lg", "fxFlexAlign.lt-xl", "fxFlexAlign.gt-xs", "fxFlexAlign.gt-sm", "fxFlexAlign.gt-md", "fxFlexAlign.gt-lg"] }, { kind: "directive", type: i14.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i15.ElderSearchInputDirective, selector: "[elderSearchInput]", inputs: ["elderSearchInputKey", "elderSearchInputTransform", "elderSearchInput", "elderSearchInputFallback"], exportAs: ["elderSearchInput"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i16.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
96
+ ElderSearchBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderSearchBoxComponent, selector: "elder-search-box", inputs: { autoPanel: "autoPanel", name: "name", queryKey: "queryKey", placeholder: "placeholder", label: "label", hint: "hint", autocomplete: "autocomplete", dense: "dense" }, queries: [{ propertyName: "advancedSearch", first: true, predicate: ElderSearchPanelComponent, descendants: true }], viewQueries: [{ propertyName: "search", first: true, predicate: ["search"], descendants: true }], exportAs: ["elderSearchBox"], ngImport: i0, template: "<div class=\"layout-row full\">\n\n <!-- Main search input -->\n <mat-form-field\n *ngIf=\"overlayState$ | async as overlayState\"\n class=\"flex-grow\"\n [elderDense]=\"dense\">\n\n <button matPrefix mat-icon-button type=\"button\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n >\n <mat-icon>search</mat-icon>\n </button>\n\n <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n ngModel\n elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n [elderOverlayOrigin]=\"searchPanel\"\n [elderOverlayTrigger]=\"searchPanel\"\n [elderOverlayTriggerType]=\"'focus'\"\n [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n >\n <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n <div class=\"layout-row\" matSuffix *ngIf=\"searchModel.userDefinedAttributes$ | async as userDefinedFilters\">\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"userDefinedFilters.length > 0\"\n (click)=\"clearSearch($event)\"\n name=\"clear\" aria-label=\"Clear\">\n <mat-icon>close</mat-icon>\n </button>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n [matBadge]=\"userDefinedFilters.length\"\n [matBadgeHidden]=\"userDefinedFilters.length == 0\"\n matBadgeColor=\"accent\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n <mat-icon [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\">filter_list</mat-icon>\n </button>\n\n </div>\n </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n <elder-dialog-panel class=\"elder-search-panel-container\">\n\n <!-- Project the users search inputs here -->\n <ng-content select=\"elder-search-panel\"></ng-content>\n\n <div class=\"layout-row place-between-center\">\n <button mat-raised-button type=\"button\" name=\"clear\"\n (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n </button>\n\n <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n (click)=\"searchPanel.closeOverlay()\">Ok\n </button>\n </div>\n </elder-dialog-panel>\n</elder-overlay>\n", styles: [".elder-search-panel-container{min-width:250px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix]" }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i6.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i8.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "component", type: i9.ElderOverlayComponent, selector: "elder-overlay", inputs: ["originX", "originY", "overlayX", "overlayY", "offsetY", "offsetX", "backdrop", "backdropVisible", "origin", "positionStrategy", "overlaySize"], outputs: ["keydownEvents", "attachedChange"], exportAs: ["elderOverlay"] }, { kind: "directive", type: i10.ElderOverlayTriggerDirective, selector: "[elderOverlayTrigger]", inputs: ["elderOverlayTrigger", "elderOverlayTriggerType", "elderOverlayTriggerEnabled"] }, { kind: "directive", type: i11.ElderOverlayOriginDirective, selector: "[elderOverlayOrigin]", inputs: ["elderOverlayOrigin"] }, { kind: "component", type: i12.ElderDialogPanelComponent, selector: "elder-dialog-panel" }, { kind: "directive", type: i13.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { kind: "directive", type: i14.ElderSearchInputDirective, selector: "[elderSearchInput]", inputs: ["elderSearchInputKey", "elderSearchInputTransform", "elderSearchInput", "elderSearchInputFallback"], exportAs: ["elderSearchInput"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i15.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
98
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSearchBoxComponent, decorators: [{
99
98
  type: Component,
100
- args: [{ selector: 'elder-search-box', exportAs: 'elderSearchBox', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div fxLayout=\"row\" fxFlex>\n\n <!-- Main search input -->\n <mat-form-field\n *ngIf=\"overlayState$ | async as overlayState\"\n fxFlex=\"grow\" fxFlexAlign=\"center\"\n [elderDense]=\"dense\">\n\n <button matPrefix mat-icon-button type=\"button\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n >\n <mat-icon>search</mat-icon>\n </button>\n\n <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n ngModel\n elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n [elderOverlayOrigin]=\"searchPanel\"\n [elderOverlayTrigger]=\"searchPanel\"\n [elderOverlayTriggerType]=\"'focus'\"\n [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n >\n <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n <div fxLayout=\"row\" matSuffix *ngIf=\"searchModel.userDefinedAttributes$ | async as userDefinedFilters\">\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"userDefinedFilters.length > 0\"\n (click)=\"clearSearch($event)\"\n name=\"clear\" aria-label=\"Clear\">\n <mat-icon>close</mat-icon>\n </button>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n [matBadge]=\"userDefinedFilters.length\"\n [matBadgeHidden]=\"userDefinedFilters.length == 0\"\n matBadgeColor=\"accent\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n <mat-icon [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\">filter_list</mat-icon>\n </button>\n\n </div>\n </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n <elder-dialog-panel class=\"elder-search-panel-container\">\n\n <!-- Project the users search inputs here -->\n <ng-content select=\"elder-search-panel\"></ng-content>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">\n <button mat-raised-button type=\"button\" name=\"clear\"\n (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n </button>\n\n <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n (click)=\"searchPanel.closeOverlay()\">Ok\n </button>\n </div>\n </elder-dialog-panel>\n</elder-overlay>\n", styles: [".elder-search-panel-container{min-width:250px}\n"] }]
99
+ args: [{ selector: 'elder-search-box', exportAs: 'elderSearchBox', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-row full\">\n\n <!-- Main search input -->\n <mat-form-field\n *ngIf=\"overlayState$ | async as overlayState\"\n class=\"flex-grow\"\n [elderDense]=\"dense\">\n\n <button matPrefix mat-icon-button type=\"button\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n >\n <mat-icon>search</mat-icon>\n </button>\n\n <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n ngModel\n elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n [elderOverlayOrigin]=\"searchPanel\"\n [elderOverlayTrigger]=\"searchPanel\"\n [elderOverlayTriggerType]=\"'focus'\"\n [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n >\n <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n <div class=\"layout-row\" matSuffix *ngIf=\"searchModel.userDefinedAttributes$ | async as userDefinedFilters\">\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"userDefinedFilters.length > 0\"\n (click)=\"clearSearch($event)\"\n name=\"clear\" aria-label=\"Clear\">\n <mat-icon>close</mat-icon>\n </button>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n [matBadge]=\"userDefinedFilters.length\"\n [matBadgeHidden]=\"userDefinedFilters.length == 0\"\n matBadgeColor=\"accent\"\n [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n <mat-icon [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\">filter_list</mat-icon>\n </button>\n\n </div>\n </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n <elder-dialog-panel class=\"elder-search-panel-container\">\n\n <!-- Project the users search inputs here -->\n <ng-content select=\"elder-search-panel\"></ng-content>\n\n <div class=\"layout-row place-between-center\">\n <button mat-raised-button type=\"button\" name=\"clear\"\n (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n </button>\n\n <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n (click)=\"searchPanel.closeOverlay()\">Ok\n </button>\n </div>\n </elder-dialog-panel>\n</elder-overlay>\n", styles: [".elder-search-panel-container{min-width:250px}\n"] }]
101
100
  }], ctorParameters: function () { return [{ type: i1.ElderSearchContextDirective }]; }, propDecorators: { search: [{
102
101
  type: ViewChild,
103
102
  args: ['search']
@@ -121,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
121
120
  }], dense: [{
122
121
  type: Input
123
122
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-search-box.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.html"],"names":[],"mappings":"AAAA,OAAO,EAC4B,uBAAuB,EACxD,SAAS,EAAE,YAAY,EACX,KAAK,EAEjB,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAC,yBAAyB,EAAC,MAAM,gCAAgC,CAAC;AACzE,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;;;;;AAG5D,MAAM,OAAO,YAAY;IACvB,YACS,UAAmB;QAAnB,eAAU,GAAV,UAAU,CAAS;IACxB,CAAC;CACN;AAUD,MAAM,OAAO,uBAAuB;IAmDlC;;;;gFAI4E;IAE5E,YACkB,WAAwC;QAAxC,gBAAW,GAAX,WAAW,CAA6B;QAxD1D;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,yBAAyB,CAAC,CAAC;QAE5D,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOpC,kBAAa,GAAG,IAAI,eAAe,CAAe,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;QAE3F;;;;oFAI4E;QAE5E;;WAEG;QAEI,cAAS,GAAG,IAAI,CAAC;QAGjB,SAAI,GAAG,kBAAkB,CAAC;QAG1B,aAAQ,GAAG,OAAO,CAAC;QAWlB,WAAM,GAAG,KAAK,CAAC;QAGhB,iBAAY,GAAG,KAAK,CAAC;IAW5B,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ;IAEf,CAAC;IAEM,eAAe;IAEtB,CAAC;IAGM,kBAAkB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IACnE,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,KAAK,CAAC,KAAc,IAAI,IAAI,CAAC,MAAM,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChF,IAAW,KAAK,KAAc,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAGnD;;;;gFAI4E;IAErE,SAAS,CAAC,KAAU;QACzB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAU;QAC3B,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;;qHAhHU,uBAAuB;yGAAvB,uBAAuB,oRAepB,yBAAyB,gLC3CzC,2mFAkEA;4FDtCa,uBAAuB;kBAPnC,SAAS;+BACE,kBAAkB,YAClB,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM;kHAe1B,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBAEsB,cAAc;sBAAtD,YAAY;uBAAC,yBAAyB;gBAchC,SAAS;sBADf,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAMC,YAAY;sBADlB,KAAK;gBA6CK,KAAK;sBADf,KAAK","sourcesContent":["import {\n  AfterContentInit, AfterViewInit, ChangeDetectionStrategy,\n  Component, ContentChild,\n  ElementRef, Input, OnDestroy,\n  OnInit,\n  ViewChild, ViewEncapsulation,\n} from '@angular/core';\nimport { LoggerFactory } from '@elderbyte/ts-logger';\nimport {ElderSearchContextDirective} from '../elder-search-context.directive';\nimport {ElderSearchPanelComponent} from './elder-search-panel.component';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\n\nexport class OverlayState {\n  constructor(\n    public hasOverlay: boolean\n  ) { }\n}\n\n\n@Component({\n  selector: 'elder-search-box',\n  exportAs: 'elderSearchBox',\n  templateUrl: './elder-search-box.component.html',\n  styleUrls: ['./elder-search-box.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderSearchBoxComponent implements OnInit, OnDestroy, AfterViewInit, AfterContentInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderSearchBoxComponent');\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  // The search expression input Element\n  @ViewChild('search') search: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSearchPanelComponent) advancedSearch: ElderSearchPanelComponent;\n\n  public readonly overlayState$ = new BehaviorSubject<OverlayState>(new OverlayState(false));\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API Fields                                                       *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Display the search panel immediately when the user enters the search box.\n   */\n  @Input()\n  public autoPanel = true;\n\n  @Input()\n  public name = 'searchExpression';\n\n  @Input()\n  public queryKey = 'query';\n\n  @Input()\n  public placeholder: string;\n\n  @Input()\n  public label: string;\n\n  @Input()\n  public hint: string;\n\n  private _dense = false;\n\n  @Input()\n  public autocomplete = 'off';\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly searchModel: ElderSearchContextDirective,\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngAfterViewInit(): void {\n\n  }\n\n\n  public ngAfterContentInit(): void {\n    this.overlayState$.next(new OverlayState(!!this.advancedSearch));\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set dense(value: boolean) { this._dense = coerceBooleanProperty(value); }\n  public get dense(): boolean { return this._dense; }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public blurFocus(event: any): void {\n    setTimeout(() => this.search.nativeElement.blur(), 0);\n  }\n\n  /**\n   * Occurs when the user clicks the clear search button\n   */\n  public clearSearch(event: any): void {\n    this.searchModel.reset();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n","<div fxLayout=\"row\" fxFlex>\n\n  <!-- Main search input -->\n  <mat-form-field\n    *ngIf=\"overlayState$ | async as overlayState\"\n    fxFlex=\"grow\" fxFlexAlign=\"center\"\n    [elderDense]=\"dense\">\n\n    <button matPrefix mat-icon-button type=\"button\"\n            [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n    >\n      <mat-icon>search</mat-icon>\n    </button>\n\n    <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n           ngModel\n           elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n           [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n           [elderOverlayOrigin]=\"searchPanel\"\n           [elderOverlayTrigger]=\"searchPanel\"\n           [elderOverlayTriggerType]=\"'focus'\"\n           [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n    >\n    <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n    <div fxLayout=\"row\" matSuffix *ngIf=\"searchModel.userDefinedAttributes$ | async as userDefinedFilters\">\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"userDefinedFilters.length > 0\"\n              (click)=\"clearSearch($event)\"\n              name=\"clear\" aria-label=\"Clear\">\n        <mat-icon>close</mat-icon>\n      </button>\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n              [matBadge]=\"userDefinedFilters.length\"\n              [matBadgeHidden]=\"userDefinedFilters.length == 0\"\n              matBadgeColor=\"accent\"\n              [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n        <mat-icon [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\">filter_list</mat-icon>\n      </button>\n\n    </div>\n  </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n  <elder-dialog-panel class=\"elder-search-panel-container\">\n\n    <!-- Project the users search inputs here -->\n    <ng-content select=\"elder-search-panel\"></ng-content>\n\n    <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">\n      <button mat-raised-button type=\"button\" name=\"clear\"\n              (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n      </button>\n\n      <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n              (click)=\"searchPanel.closeOverlay()\">Ok\n      </button>\n    </div>\n  </elder-dialog-panel>\n</elder-overlay>\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-search-box.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.html"],"names":[],"mappings":"AAAA,OAAO,EAC4B,uBAAuB,EACxD,SAAS,EAAE,YAAY,EACX,KAAK,EAEjB,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAC,yBAAyB,EAAC,MAAM,gCAAgC,CAAC;AACzE,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;;;;AAG5D,MAAM,OAAO,YAAY;IACvB,YACS,UAAmB;QAAnB,eAAU,GAAV,UAAU,CAAS;IACxB,CAAC;CACN;AAUD,MAAM,OAAO,uBAAuB;IAmDlC;;;;gFAI4E;IAE5E,YACkB,WAAwC;QAAxC,gBAAW,GAAX,WAAW,CAA6B;QAxD1D;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,yBAAyB,CAAC,CAAC;QAE5D,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOpC,kBAAa,GAAG,IAAI,eAAe,CAAe,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;QAE3F;;;;oFAI4E;QAE5E;;WAEG;QAEI,cAAS,GAAG,IAAI,CAAC;QAGjB,SAAI,GAAG,kBAAkB,CAAC;QAG1B,aAAQ,GAAG,OAAO,CAAC;QAWlB,WAAM,GAAG,KAAK,CAAC;QAGhB,iBAAY,GAAG,KAAK,CAAC;IAW5B,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ;IAEf,CAAC;IAEM,eAAe;IAEtB,CAAC;IAGM,kBAAkB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IACnE,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,KAAK,CAAC,KAAc,IAAI,IAAI,CAAC,MAAM,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChF,IAAW,KAAK,KAAc,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAGnD;;;;gFAI4E;IAErE,SAAS,CAAC,KAAU;QACzB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAU;QAC3B,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;;qHAhHU,uBAAuB;yGAAvB,uBAAuB,oRAepB,yBAAyB,gLC3CzC,glFAkEA;4FDtCa,uBAAuB;kBAPnC,SAAS;+BACE,kBAAkB,YAClB,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM;kHAe1B,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBAEsB,cAAc;sBAAtD,YAAY;uBAAC,yBAAyB;gBAchC,SAAS;sBADf,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAMC,YAAY;sBADlB,KAAK;gBA6CK,KAAK;sBADf,KAAK","sourcesContent":["import {\n  AfterContentInit, AfterViewInit, ChangeDetectionStrategy,\n  Component, ContentChild,\n  ElementRef, Input, OnDestroy,\n  OnInit,\n  ViewChild, ViewEncapsulation,\n} from '@angular/core';\nimport { LoggerFactory } from '@elderbyte/ts-logger';\nimport {ElderSearchContextDirective} from '../elder-search-context.directive';\nimport {ElderSearchPanelComponent} from './elder-search-panel.component';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\n\nexport class OverlayState {\n  constructor(\n    public hasOverlay: boolean\n  ) { }\n}\n\n\n@Component({\n  selector: 'elder-search-box',\n  exportAs: 'elderSearchBox',\n  templateUrl: './elder-search-box.component.html',\n  styleUrls: ['./elder-search-box.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderSearchBoxComponent implements OnInit, OnDestroy, AfterViewInit, AfterContentInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderSearchBoxComponent');\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  // The search expression input Element\n  @ViewChild('search') search: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSearchPanelComponent) advancedSearch: ElderSearchPanelComponent;\n\n  public readonly overlayState$ = new BehaviorSubject<OverlayState>(new OverlayState(false));\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API Fields                                                       *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Display the search panel immediately when the user enters the search box.\n   */\n  @Input()\n  public autoPanel = true;\n\n  @Input()\n  public name = 'searchExpression';\n\n  @Input()\n  public queryKey = 'query';\n\n  @Input()\n  public placeholder: string;\n\n  @Input()\n  public label: string;\n\n  @Input()\n  public hint: string;\n\n  private _dense = false;\n\n  @Input()\n  public autocomplete = 'off';\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly searchModel: ElderSearchContextDirective,\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngAfterViewInit(): void {\n\n  }\n\n\n  public ngAfterContentInit(): void {\n    this.overlayState$.next(new OverlayState(!!this.advancedSearch));\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set dense(value: boolean) { this._dense = coerceBooleanProperty(value); }\n  public get dense(): boolean { return this._dense; }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public blurFocus(event: any): void {\n    setTimeout(() => this.search.nativeElement.blur(), 0);\n  }\n\n  /**\n   * Occurs when the user clicks the clear search button\n   */\n  public clearSearch(event: any): void {\n    this.searchModel.reset();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n","<div class=\"layout-row full\">\n\n  <!-- Main search input -->\n  <mat-form-field\n    *ngIf=\"overlayState$ | async as overlayState\"\n    class=\"flex-grow\"\n    [elderDense]=\"dense\">\n\n    <button matPrefix mat-icon-button type=\"button\"\n            [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n    >\n      <mat-icon>search</mat-icon>\n    </button>\n\n    <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n           ngModel\n           elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n           [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n           [elderOverlayOrigin]=\"searchPanel\"\n           [elderOverlayTrigger]=\"searchPanel\"\n           [elderOverlayTriggerType]=\"'focus'\"\n           [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n    >\n    <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n    <div class=\"layout-row\" matSuffix *ngIf=\"searchModel.userDefinedAttributes$ | async as userDefinedFilters\">\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"userDefinedFilters.length > 0\"\n              (click)=\"clearSearch($event)\"\n              name=\"clear\" aria-label=\"Clear\">\n        <mat-icon>close</mat-icon>\n      </button>\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n              [matBadge]=\"userDefinedFilters.length\"\n              [matBadgeHidden]=\"userDefinedFilters.length == 0\"\n              matBadgeColor=\"accent\"\n              [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n        <mat-icon [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\">filter_list</mat-icon>\n      </button>\n\n    </div>\n  </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n  <elder-dialog-panel class=\"elder-search-panel-container\">\n\n    <!-- Project the users search inputs here -->\n    <ng-content select=\"elder-search-panel\"></ng-content>\n\n    <div class=\"layout-row place-between-center\">\n      <button mat-raised-button type=\"button\" name=\"clear\"\n              (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n      </button>\n\n      <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n              (click)=\"searchPanel.closeOverlay()\">Ok\n      </button>\n    </div>\n  </elder-dialog-panel>\n</elder-overlay>\n"]}