@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.
- package/_index.scss +2 -0
- package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -4
- package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -8
- package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +9 -13
- package/esm2020/lib/components/auditing/elder-audit.module.mjs +1 -5
- package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -4
- package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -8
- package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -5
- package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +5 -6
- package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -5
- package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -5
- package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +3 -5
- package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -5
- package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -5
- package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -8
- package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -4
- package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -5
- package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -4
- package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -5
- package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +6 -7
- package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +5 -6
- package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -5
- package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -5
- package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +3 -4
- package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -5
- package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -4
- package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +39 -26
- package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +1 -5
- package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -5
- package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +8 -9
- package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -5
- package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +9 -7
- package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +6 -5
- package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +10 -3
- package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +11 -9
- package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -5
- package/esm2020/lib/components/errors/elder-error.module.mjs +4 -8
- package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -4
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -5
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -5
- package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +3 -4
- package/esm2020/lib/components/files/elder-file.module.mjs +4 -5
- package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +11 -12
- package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -5
- package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +5 -6
- package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -5
- package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -5
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -11
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -8
- package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -5
- package/esm2020/lib/components/headers/elder-header.module.mjs +4 -5
- package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +1 -5
- package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +10 -11
- package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +8 -9
- package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +14 -15
- package/esm2020/lib/components/i18n/language/elder-language.module.mjs +1 -5
- package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +5 -6
- package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +4 -5
- package/esm2020/lib/components/iframes/elder-iframe.module.mjs +1 -5
- package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -5
- package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +6 -7
- package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -5
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -5
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +1 -5
- package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +5 -16
- package/esm2020/lib/components/measures/elder-measures.module.mjs +1 -5
- package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +12 -13
- package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +12 -13
- package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -5
- package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -5
- package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +3 -4
- package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -5
- package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -5
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -5
- package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +6 -7
- package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +2 -2
- package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +2 -2
- package/esm2020/lib/components/overlays/elder-overlay.component.mjs +2 -2
- package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -4
- package/esm2020/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +3 -4
- package/esm2020/lib/components/panels/elder-panel.module.mjs +3 -7
- package/esm2020/lib/components/select/elder-select.module.mjs +4 -5
- package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +9 -10
- package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +5 -6
- package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +8 -9
- package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -6
- package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -5
- package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -5
- package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -4
- package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -4
- package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -5
- package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -5
- package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +4 -5
- package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -8
- package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +7 -8
- package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +9 -10
- package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +7 -8
- package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +7 -8
- package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +12 -13
- package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +9 -10
- package/esm2020/lib/components/time/elder-time.module.mjs +1 -11
- package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +7 -8
- package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -5
- package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +5 -6
- package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +1 -5
- package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -5
- package/fesm2015/elderbyte-ngx-starter.mjs +451 -507
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +450 -507
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/access-denied/elder-access-denied.module.d.ts +1 -2
- package/lib/components/auditing/audited-entity/elder-audited-entity.component.d.ts +1 -2
- package/lib/components/auditing/elder-audit.module.d.ts +5 -6
- package/lib/components/button-group/elder-button-group.module.d.ts +1 -2
- package/lib/components/card-organizer/elder-card-organizer.module.d.ts +3 -4
- package/lib/components/cards/elder-card/elder-card.module.d.ts +2 -3
- package/lib/components/connectivity/elder-connectivity.module.d.ts +6 -7
- package/lib/components/containers/elder-containers.module.d.ts +1 -2
- package/lib/components/data-transfer/elder-data-transfer.module.d.ts +4 -5
- package/lib/components/data-view/common/elder-data-common.module.d.ts +1 -2
- package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -3
- package/lib/components/data-view/grid/elder-grid.module.d.ts +6 -7
- package/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.d.ts +4 -5
- package/lib/components/data-view/table/elder-table.module.d.ts +4 -5
- package/lib/components/dialogs/elder-dialog.module.d.ts +4 -3
- package/lib/components/dialogs/elder-dialog.service.d.ts +1 -0
- package/lib/components/errors/elder-error.module.d.ts +1 -2
- package/lib/components/expand-toggle-button/elder-expand-toggle-button.module.d.ts +1 -2
- package/lib/components/files/elder-file.module.d.ts +6 -7
- package/lib/components/forms/search/elder-search.module.d.ts +2 -3
- package/lib/components/global-search/elder-global-search.module.d.ts +2 -3
- package/lib/components/graph/elder-progress-bar/elder-progress-bar.component.d.ts +1 -8
- package/lib/components/graph/elder-progress-bar/elder-progress-bar.module.d.ts +1 -2
- package/lib/components/headers/elder-header.module.d.ts +2 -3
- package/lib/components/i18n/entities/elder-i18n-entities.module.d.ts +15 -16
- package/lib/components/i18n/language/elder-language.module.d.ts +2 -3
- package/lib/components/iframes/elder-iframe.module.d.ts +5 -6
- package/lib/components/input/autocomplete/elder-autocomplete.module.d.ts +2 -3
- package/lib/components/measures/dimensions-input/elder-dimensions-input.component.d.ts +1 -3
- package/lib/components/measures/elder-measures.module.d.ts +5 -6
- package/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.d.ts +8 -9
- package/lib/components/navigation/nav/elder-nav.module.d.ts +1 -2
- package/lib/components/navigation/nav/nav-list/elder-nav-list.component.d.ts +1 -3
- package/lib/components/navigation/toolbar/elder-toolbar.module.d.ts +8 -9
- package/lib/components/panels/elder-panel.module.d.ts +1 -2
- package/lib/components/select/elder-select.module.d.ts +10 -11
- package/lib/components/select-chip-list/elder-chip-list-select.module.d.ts +3 -4
- package/lib/components/select-list/elder-select-list.module.d.ts +1 -2
- package/lib/components/shell/elder-shell.module.d.ts +4 -5
- package/lib/components/tabs/elder-tab.module.d.ts +1 -2
- package/lib/components/time/elder-time.module.d.ts +9 -10
- package/lib/components/toasts/elder-toast.module.d.ts +3 -4
- package/lib/components/url-fragment/elder-url-fragment.module.d.ts +2 -3
- package/package.json +1 -2
- package/src/lib/components/graph/elder-progress-bar/elder-progress-bar.component.scss +5 -0
- package/src/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.scss +3 -1
- package/src/lib/components/navigation/nav/nav-list/elder-nav-list.component.scss +5 -6
- package/src/lib/components/select/single/elder-select/elder-select.component.scss +1 -4
- package/theming/_elder-common.scss +32 -0
- package/theming/_elder-flex-layout.scss +562 -0
- package/theming/_elder-style-fixes.scss +3 -0
package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs
CHANGED
|
@@ -8,8 +8,7 @@ import { ElderDataViewOptions } from '../../../data-view/base/elder-data-view-op
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "../../../data-view/base/elder-data-view-options-provider";
|
|
10
10
|
import * as i2 from "../../../../common/selection/selection-model";
|
|
11
|
-
import * as i3 from "
|
|
12
|
-
import * as i4 from "../../iframe-host/iframe-host.component";
|
|
11
|
+
import * as i3 from "../../iframe-host/iframe-host.component";
|
|
13
12
|
/**
|
|
14
13
|
* Container for displaying a remote data view in an iframe.
|
|
15
14
|
* Provides capabilities to communicate between remote data view (child)
|
|
@@ -105,10 +104,10 @@ export class DataViewIframeComponent {
|
|
|
105
104
|
}
|
|
106
105
|
}
|
|
107
106
|
DataViewIframeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: DataViewIframeComponent, deps: [{ token: i1.ElderDataViewOptionsProvider, optional: true }, { token: i2.SelectionModel, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
108
|
-
DataViewIframeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: DataViewIframeComponent, selector: "elder-data-view-iframe", inputs: { srcUrl: "srcUrl", idField: "idField", initialSelection: "initialSelection", dataViewOptions: "dataViewOptions" }, viewQueries: [{ propertyName: "iframeHost", first: true, predicate: IframeHostComponent, descendants: true }], ngImport: i0, template: "<div
|
|
107
|
+
DataViewIframeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: DataViewIframeComponent, selector: "elder-data-view-iframe", inputs: { srcUrl: "srcUrl", idField: "idField", initialSelection: "initialSelection", dataViewOptions: "dataViewOptions" }, viewQueries: [{ propertyName: "iframeHost", first: true, predicate: IframeHostComponent, descendants: true }], ngImport: i0, template: "<div class=\"layout-col full\">\n <elder-i-frame-host class=\"flex\"\n [iframeParams]=\"{srcUrl: srcUrl, hideActionBar: true}\"\n (message)=\"onMessageFromChild($event)\">\n </elder-i-frame-host>\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: i3.IframeHostComponent, selector: "elder-i-frame-host", inputs: ["iframeParams"], outputs: ["message", "close"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
109
108
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: DataViewIframeComponent, decorators: [{
|
|
110
109
|
type: Component,
|
|
111
|
-
args: [{ selector: 'elder-data-view-iframe', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div
|
|
110
|
+
args: [{ selector: 'elder-data-view-iframe', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-col full\">\n <elder-i-frame-host class=\"flex\"\n [iframeParams]=\"{srcUrl: srcUrl, hideActionBar: true}\"\n (message)=\"onMessageFromChild($event)\">\n </elder-i-frame-host>\n</div>\n" }]
|
|
112
111
|
}], ctorParameters: function () { return [{ type: i1.ElderDataViewOptionsProvider, decorators: [{
|
|
113
112
|
type: Optional
|
|
114
113
|
}] }, { type: i2.SelectionModel, decorators: [{
|
|
@@ -125,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
125
124
|
}], dataViewOptions: [{
|
|
126
125
|
type: Input
|
|
127
126
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view-iframe.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional, SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport {IframeHostComponent} from '../../iframe-host/iframe-host.component';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {filter, takeUntil} from 'rxjs/operators';\nimport {DataViewMessage, DataViewSelection, DataViewSelectionInit, TypedEventMessage} from '../../typed-event-message';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderDataViewOptionsProvider} from '../../../data-view/base/elder-data-view-options-provider';\nimport {ElderDataViewOptions} from '../../../data-view/base/elder-data-view-options';\n\n/**\n * Container for displaying a remote data view in an iframe.\n * Provides capabilities to communicate between remote data view (child)\n * and iframe parent.\n */\n@Component({\n  selector: 'elder-data-view-iframe',\n  templateUrl: './data-view-iframe.component.html',\n  styleUrls: ['./data-view-iframe.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataViewIframeComponent implements OnInit, OnDestroy, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _dataViewOptions$ = new BehaviorSubject<ElderDataViewOptions>(ElderDataViewOptions.defaultOptions());\n\n  private readonly _destroy$ = new Subject<void>();\n\n  @Input()\n  public srcUrl: string;\n\n  @Input()\n  public idField: string;\n\n  @Input()\n  public initialSelection: any[];\n\n  @ViewChild(IframeHostComponent)\n  public iframeHost: IframeHostComponent;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() private dataViewOptionsProvider: ElderDataViewOptionsProvider,\n    @Optional() private selectionModel: SelectionModel<any>\n  ) {\n    if (dataViewOptionsProvider) {\n      dataViewOptionsProvider.options$.pipe(\n        takeUntil(this._destroy$)\n      ).subscribe(options => this.dataViewOptions = options)\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  public ngAfterViewInit(): void {\n    // iframe is only available after view init\n    this.setupDataViewOptionsBridge(this.iframeHost);\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataViewOptions(): ElderDataViewOptions {\n    return this._dataViewOptions$.getValue();\n  }\n\n  @Input()\n  public set dataViewOptions(options: ElderDataViewOptions) {\n    const newOptions = this.dataViewOptions.withOptions(options);\n    this._dataViewOptions$.next(newOptions);\n  }\n\n  public get dataViewOptions$(): Observable<ElderDataViewOptions> {\n    return this._dataViewOptions$.asObservable();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onMessageFromChild(message: TypedEventMessage<any,any>): void {\n    if (DataViewMessage.isOfType(message)){\n      switch (message.type) {\n        case 'SELECTION_SELECTED':\n          this.handleSelectionMessage(message.data);\n          break;\n      }\n    }\n\n  }\n\n  public sendMessageToChild(message: DataViewMessage<any>) {\n    this.log.debug(\"Sending message to iframe child:\", message);\n    this.iframeHost.sendMessageToChild(message)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleSelectionMessage(dataViewSelection: DataViewSelection<any>): void {\n    if (this.selectionModel) {\n      this.selectionModel.replaceSelection(dataViewSelection.selection);\n    }\n  }\n\n  private setupDataViewOptionsBridge(\n    iframeHost: IframeHostComponent\n  ) {\n    combineLatest([\n      this._dataViewOptions$,\n      iframeHost.iframeState$\n    ]).pipe(\n      takeUntil(this._destroy$),\n      filter(([options, state]) => !!options && state.hasLoaded)\n    ).subscribe(\n      ([options, state]) => this.sendMessageToChild(\n        this.buildDataViewInitMessage(options, this.initialSelection)\n      )\n    )\n  }\n\n  private buildDataViewInitMessage(\n    options: ElderDataViewOptions,\n    initialSelection: any[]\n  ): DataViewMessage<DataViewSelectionInit<any>> {\n    return DataViewMessage.initialSelection(\n      new DataViewSelectionInit(options, initialSelection, this.idField)\n    );\n  }\n\n\n}\n","<div fxLayout=\"column\" fxFill>\n\n  <elder-i-frame-host fxFlex\n                      [iframeParams]=\"{srcUrl: srcUrl, hideActionBar: true}\"\n                      (message)=\"onMessageFromChild($event)\">\n  </elder-i-frame-host>\n\n</div>\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view-iframe.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional, SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport {IframeHostComponent} from '../../iframe-host/iframe-host.component';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {filter, takeUntil} from 'rxjs/operators';\nimport {DataViewMessage, DataViewSelection, DataViewSelectionInit, TypedEventMessage} from '../../typed-event-message';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderDataViewOptionsProvider} from '../../../data-view/base/elder-data-view-options-provider';\nimport {ElderDataViewOptions} from '../../../data-view/base/elder-data-view-options';\n\n/**\n * Container for displaying a remote data view in an iframe.\n * Provides capabilities to communicate between remote data view (child)\n * and iframe parent.\n */\n@Component({\n  selector: 'elder-data-view-iframe',\n  templateUrl: './data-view-iframe.component.html',\n  styleUrls: ['./data-view-iframe.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataViewIframeComponent implements OnInit, OnDestroy, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _dataViewOptions$ = new BehaviorSubject<ElderDataViewOptions>(ElderDataViewOptions.defaultOptions());\n\n  private readonly _destroy$ = new Subject<void>();\n\n  @Input()\n  public srcUrl: string;\n\n  @Input()\n  public idField: string;\n\n  @Input()\n  public initialSelection: any[];\n\n  @ViewChild(IframeHostComponent)\n  public iframeHost: IframeHostComponent;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() private dataViewOptionsProvider: ElderDataViewOptionsProvider,\n    @Optional() private selectionModel: SelectionModel<any>\n  ) {\n    if (dataViewOptionsProvider) {\n      dataViewOptionsProvider.options$.pipe(\n        takeUntil(this._destroy$)\n      ).subscribe(options => this.dataViewOptions = options)\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  public ngAfterViewInit(): void {\n    // iframe is only available after view init\n    this.setupDataViewOptionsBridge(this.iframeHost);\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataViewOptions(): ElderDataViewOptions {\n    return this._dataViewOptions$.getValue();\n  }\n\n  @Input()\n  public set dataViewOptions(options: ElderDataViewOptions) {\n    const newOptions = this.dataViewOptions.withOptions(options);\n    this._dataViewOptions$.next(newOptions);\n  }\n\n  public get dataViewOptions$(): Observable<ElderDataViewOptions> {\n    return this._dataViewOptions$.asObservable();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onMessageFromChild(message: TypedEventMessage<any,any>): void {\n    if (DataViewMessage.isOfType(message)){\n      switch (message.type) {\n        case 'SELECTION_SELECTED':\n          this.handleSelectionMessage(message.data);\n          break;\n      }\n    }\n\n  }\n\n  public sendMessageToChild(message: DataViewMessage<any>) {\n    this.log.debug(\"Sending message to iframe child:\", message);\n    this.iframeHost.sendMessageToChild(message)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleSelectionMessage(dataViewSelection: DataViewSelection<any>): void {\n    if (this.selectionModel) {\n      this.selectionModel.replaceSelection(dataViewSelection.selection);\n    }\n  }\n\n  private setupDataViewOptionsBridge(\n    iframeHost: IframeHostComponent\n  ) {\n    combineLatest([\n      this._dataViewOptions$,\n      iframeHost.iframeState$\n    ]).pipe(\n      takeUntil(this._destroy$),\n      filter(([options, state]) => !!options && state.hasLoaded)\n    ).subscribe(\n      ([options, state]) => this.sendMessageToChild(\n        this.buildDataViewInitMessage(options, this.initialSelection)\n      )\n    )\n  }\n\n  private buildDataViewInitMessage(\n    options: ElderDataViewOptions,\n    initialSelection: any[]\n  ): DataViewMessage<DataViewSelectionInit<any>> {\n    return DataViewMessage.initialSelection(\n      new DataViewSelectionInit(options, initialSelection, this.idField)\n    );\n  }\n\n\n}\n","<div class=\"layout-col full\">\n  <elder-i-frame-host class=\"flex\"\n                      [iframeParams]=\"{srcUrl: srcUrl, hideActionBar: true}\"\n                      (message)=\"onMessageFromChild($event)\">\n  </elder-i-frame-host>\n</div>\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { MatIconModule } from '@angular/material/icon';
|
|
4
|
-
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
5
4
|
import { FormsModule } from '@angular/forms';
|
|
6
5
|
import { RouterModule } from '@angular/router';
|
|
7
6
|
import { TranslateModule } from '@ngx-translate/core';
|
|
@@ -36,7 +35,6 @@ ElderIFrameModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versi
|
|
|
36
35
|
RouterModule,
|
|
37
36
|
FormsModule,
|
|
38
37
|
// Third Party
|
|
39
|
-
FlexLayoutModule,
|
|
40
38
|
TranslateModule,
|
|
41
39
|
// Angular Material
|
|
42
40
|
MatIconModule,
|
|
@@ -54,7 +52,6 @@ ElderIFrameModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versi
|
|
|
54
52
|
RouterModule,
|
|
55
53
|
FormsModule,
|
|
56
54
|
// Third Party
|
|
57
|
-
FlexLayoutModule,
|
|
58
55
|
TranslateModule,
|
|
59
56
|
// Angular Material
|
|
60
57
|
MatIconModule,
|
|
@@ -70,7 +67,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
70
67
|
RouterModule,
|
|
71
68
|
FormsModule,
|
|
72
69
|
// Third Party
|
|
73
|
-
FlexLayoutModule,
|
|
74
70
|
TranslateModule,
|
|
75
71
|
// Angular Material
|
|
76
72
|
MatIconModule,
|
|
@@ -96,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
96
92
|
]
|
|
97
93
|
}]
|
|
98
94
|
}] });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItaWZyYW1lLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvaWZyYW1lcy9lbGRlci1pZnJhbWUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUN4RSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUMvRixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDaEUsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDbEcsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sZ0RBQWdELENBQUM7O0FBRTlGLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxnREFBZ0QsQ0FBQTtBQXFDOUQsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQWhCMUIsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQiwwQkFBMEI7UUFDMUIsb0JBQW9CO1FBQ3BCLHVCQUF1QjtRQUN2Qiw4QkFBOEI7UUFyQjlCLFVBQVU7UUFDVixZQUFZO1FBQ1osWUFBWTtRQUNaLFdBQVc7UUFFWCxjQUFjO1FBQ2QsZUFBZTtRQUVmLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsZUFBZTtRQUVmLFlBQVk7UUFDWixnQkFBZ0IsYUFXaEIsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQiwwQkFBMEI7UUFDMUIsb0JBQW9CO1FBQ3BCLHVCQUF1QjtRQUN2Qiw4QkFBOEI7Z0hBR3JCLGlCQUFpQjtRQWhDMUIsVUFBVTtRQUNWLFlBQVk7UUFDWixZQUFZO1FBQ1osV0FBVztRQUVYLGNBQWM7UUFDZCxlQUFlO1FBRWYsbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixlQUFlO1FBRWYsWUFBWTtRQUNaLGdCQUFnQjs0RkFtQlAsaUJBQWlCO2tCQW5DN0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBRVAsVUFBVTt3QkFDVixZQUFZO3dCQUNaLFlBQVk7d0JBQ1osV0FBVzt3QkFFWCxjQUFjO3dCQUNkLGVBQWU7d0JBRWYsbUJBQW1CO3dCQUNuQixhQUFhO3dCQUNiLGVBQWU7d0JBRWYsWUFBWTt3QkFDWixnQkFBZ0I7cUJBQ2pCO29CQUNELFlBQVksRUFBRTt3QkFDWixtQkFBbUI7d0JBQ25CLHFCQUFxQjt3QkFDckIsMEJBQTBCO3dCQUMxQixvQkFBb0I7d0JBQ3BCLHVCQUF1Qjt3QkFDdkIsOEJBQThCO3FCQUMvQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLDBCQUEwQjt3QkFDMUIsb0JBQW9CO3dCQUNwQix1QkFBdUI7d0JBQ3ZCLDhCQUE4QjtxQkFDL0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtNYXRJY29uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7Um91dGVyTW9kdWxlfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtJZnJhbWVIb3N0Q29tcG9uZW50fSBmcm9tICcuL2lmcmFtZS1ob3N0L2lmcmFtZS1ob3N0LmNvbXBvbmVudCc7XG5pbXBvcnQge0lmcmFtZURpYWxvZ0NvbXBvbmVudH0gZnJvbSAnLi9pZnJhbWUtZGlhbG9nL2lmcmFtZS1kaWFsb2cuY29tcG9uZW50JztcbmltcG9ydCB7SWZyYW1lU2lkZUNvbnRlbnRDb21wb25lbnR9IGZyb20gJy4vaWZyYW1lLXNpZGUtY29udGVudC9pZnJhbWUtc2lkZS1jb250ZW50LmNvbXBvbmVudCc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7RWxkZXJQaXBlc01vZHVsZX0gZnJvbSAnLi4vLi4vcGlwZXMvZWxkZXItcGlwZXMubW9kdWxlJztcbmltcG9ydCB7SWZyYW1lQ2xvc2VEaXJlY3RpdmV9IGZyb20gJy4vaWZyYW1lLWNsb3NlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYXRhVmlld0lmcmFtZUNvbXBvbmVudCB9IGZyb20gJy4vZGF0YS12aWV3L2RhdGEtdmlldy1pZnJhbWUvZGF0YS12aWV3LWlmcmFtZS5jb21wb25lbnQnO1xuaW1wb3J0IHtEYXRhVmlld0lmcmFtZUFkYXB0ZXJEaXJlY3RpdmV9IGZyb20gJy4vZGF0YS12aWV3L2RhdGEtdmlldy1pZnJhbWUtYWRhcHRlci5kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2lmcmFtZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vaWZyYW1lLWNsb3NlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2lmcmFtZS1ob3N0L2lmcmFtZS1ob3N0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2lmcmFtZS1zaWRlLWNvbnRlbnQvaWZyYW1lLXNpZGUtY29udGVudC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pZnJhbWUtZGlhbG9nL2lmcmFtZS1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZWQtZXZlbnQtbWVzc2FnZSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGEtdmlldy9kYXRhLXZpZXctaWZyYW1lL2RhdGEtdmlldy1pZnJhbWUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhLXZpZXcvZGF0YS12aWV3LWlmcmFtZS1hZGFwdGVyLmRpcmVjdGl2ZSdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuXG4gICAgLy8gQW5ndWxhclxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBSb3V0ZXJNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG5cbiAgICAvLyBUaGlyZCBQYXJ0eVxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcblxuICAgIC8vIEFuZ3VsYXIgTWF0ZXJpYWxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcblxuICAgIC8vIEVsZGVyQnl0ZVxuICAgIEVsZGVyUGlwZXNNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgSWZyYW1lSG9zdENvbXBvbmVudCxcbiAgICBJZnJhbWVEaWFsb2dDb21wb25lbnQsXG4gICAgSWZyYW1lU2lkZUNvbnRlbnRDb21wb25lbnQsXG4gICAgSWZyYW1lQ2xvc2VEaXJlY3RpdmUsXG4gICAgRGF0YVZpZXdJZnJhbWVDb21wb25lbnQsXG4gICAgRGF0YVZpZXdJZnJhbWVBZGFwdGVyRGlyZWN0aXZlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBJZnJhbWVIb3N0Q29tcG9uZW50LFxuICAgIElmcmFtZURpYWxvZ0NvbXBvbmVudCxcbiAgICBJZnJhbWVTaWRlQ29udGVudENvbXBvbmVudCxcbiAgICBJZnJhbWVDbG9zZURpcmVjdGl2ZSxcbiAgICBEYXRhVmlld0lmcmFtZUNvbXBvbmVudCxcbiAgICBEYXRhVmlld0lmcmFtZUFkYXB0ZXJEaXJlY3RpdmVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlcklGcmFtZU1vZHVsZSB7XG59XG4iXX0=
|
|
@@ -5,8 +5,7 @@ import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/material/dialog";
|
|
7
7
|
import * as i2 from "@angular/common";
|
|
8
|
-
import * as i3 from "
|
|
9
|
-
import * as i4 from "../iframe-host/iframe-host.component";
|
|
8
|
+
import * as i3 from "../iframe-host/iframe-host.component";
|
|
10
9
|
export class IframeDialogComponent {
|
|
11
10
|
/***************************************************************************
|
|
12
11
|
* *
|
|
@@ -41,12 +40,12 @@ export class IframeDialogComponent {
|
|
|
41
40
|
}
|
|
42
41
|
}
|
|
43
42
|
IframeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: IframeDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
44
|
-
IframeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: IframeDialogComponent, selector: "elder-i-frame-dialog", ngImport: i0, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\"
|
|
43
|
+
IframeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: IframeDialogComponent, selector: "elder-i-frame-dialog", ngImport: i0, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\" class=\"full\">\n <elder-i-frame-host class=\"full\"\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n</div>\n\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.IframeHostComponent, selector: "elder-i-frame-host", inputs: ["iframeParams"], outputs: ["message", "close"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
45
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: IframeDialogComponent, decorators: [{
|
|
46
45
|
type: Component,
|
|
47
|
-
args: [{ selector: 'elder-i-frame-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\"
|
|
46
|
+
args: [{ selector: 'elder-i-frame-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\" class=\"full\">\n <elder-i-frame-host class=\"full\"\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n</div>\n\n\n\n" }]
|
|
48
47
|
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
49
48
|
type: Inject,
|
|
50
49
|
args: [MAT_DIALOG_DATA]
|
|
51
50
|
}] }]; } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZyYW1lLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2lmcmFtZXMvaWZyYW1lLWRpYWxvZy9pZnJhbWUtZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvaWZyYW1lcy9pZnJhbWUtZGlhbG9nL2lmcmFtZS1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDakYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDckMsT0FBTyxFQUFDLGVBQWUsRUFBZ0MsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7QUFTeEYsTUFBTSxPQUFPLHFCQUFxQjtJQVloQzs7OztnRkFJNEU7SUFFNUUsWUFDUyxTQUE4QyxFQUNyQixJQUFrQjtRQUQzQyxjQUFTLEdBQVQsU0FBUyxDQUFxQztRQUNyQixTQUFJLEdBQUosSUFBSSxDQUFjO1FBbEJwRDs7OztvRkFJNEU7UUFFM0QsV0FBTSxHQUFHLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV6RCxrQkFBYSxHQUFHLElBQUksZUFBZSxDQUFlLElBQUksQ0FBQyxDQUFDO1FBWXRFLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsUUFBUSxLQUFXLENBQUM7SUFFM0I7Ozs7Z0ZBSTRFO0lBRXJFLEtBQUssQ0FBQyxJQUFVO1FBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdCLENBQUM7O21IQXpDVSxxQkFBcUIsOENBb0J0QixlQUFlO3VHQXBCZCxxQkFBcUIsNERDWmxDLHNRQVNBOzRGREdhLHFCQUFxQjtrQkFOakMsU0FBUzsrQkFDRSxzQkFBc0IsbUJBR2YsdUJBQXVCLENBQUMsTUFBTTs7MEJBc0I1QyxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEluamVjdCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TG9nZ2VyRmFjdG9yeX0gZnJvbSAnQGVsZGVyYnl0ZS90cy1sb2dnZXInO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtNQVRfRElBTE9HX0RBVEEsIE1hdERpYWxvZ0NvbmZpZywgTWF0RGlhbG9nUmVmfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHtJRnJhbWVQYXJhbXN9IGZyb20gJy4uL2lmcmFtZS1ob3N0L2lmcmFtZS1ob3N0LmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLWktZnJhbWUtZGlhbG9nJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2lmcmFtZS1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9pZnJhbWUtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIElmcmFtZURpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHJpdmF0ZSByZWFkb25seSBsb2dnZXIgPSBMb2dnZXJGYWN0b3J5LmdldExvZ2dlcih0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuXG4gIHB1YmxpYyByZWFkb25seSBpZnJhbWVQYXJhbXMkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxJRnJhbWVQYXJhbXM+KG51bGwpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxJZnJhbWVEaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogSUZyYW1lUGFyYW1zXG4gICkge1xuICAgIHRoaXMuaWZyYW1lUGFyYW1zJC5uZXh0KGRhdGEpO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIExpZmVjeWNsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQgeyB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFB1YmxpYyBBUEkgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIGNsb3NlKGRhdGE/OiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZShkYXRhKTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5cbn1cbiIsIjxkaXYgKm5nSWY9XCJpZnJhbWVQYXJhbXMkIHwgYXN5bmMgYXMgaUZyYW1lUGFyYW1zXCIgY2xhc3M9XCJmdWxsXCI+XG4gICAgPGVsZGVyLWktZnJhbWUtaG9zdCBjbGFzcz1cImZ1bGxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgW2lmcmFtZVBhcmFtc109XCJpRnJhbWVQYXJhbXNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGNsb3NlKT1cImNsb3NlKCRldmVudClcIj5cbiAgICA8L2VsZGVyLWktZnJhbWUtaG9zdD5cbjwvZGl2PlxuXG5cblxuIl19
|
|
@@ -4,10 +4,9 @@ import { BehaviorSubject } from 'rxjs';
|
|
|
4
4
|
import { TypedEventMessage } from '../typed-event-message';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
7
|
-
import * as i2 from "@angular/
|
|
8
|
-
import * as i3 from "@angular/material/
|
|
9
|
-
import * as i4 from "
|
|
10
|
-
import * as i5 from "../../../pipes/elder-safe-url.pipe";
|
|
7
|
+
import * as i2 from "@angular/material/icon";
|
|
8
|
+
import * as i3 from "@angular/material/button";
|
|
9
|
+
import * as i4 from "../../../pipes/elder-safe-url.pipe";
|
|
11
10
|
export class IFrameState {
|
|
12
11
|
constructor(type, message = null) {
|
|
13
12
|
this.type = type;
|
|
@@ -107,10 +106,10 @@ export class IframeHostComponent {
|
|
|
107
106
|
}
|
|
108
107
|
}
|
|
109
108
|
IframeHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: IframeHostComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
110
|
-
IframeHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: IframeHostComponent, selector: "elder-i-frame-host", inputs: { iframeParams: "iframeParams" }, outputs: { message: "message", close: "close" }, host: { listeners: { "window:message": "onWindowMessage($event)" } }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframe"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"{state: iframeState$ | async, params: iframeParams$ | async} as ctx\">\n\n <div
|
|
109
|
+
IframeHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: IframeHostComponent, selector: "elder-i-frame-host", inputs: { iframeParams: "iframeParams" }, outputs: { message: "message", close: "close" }, host: { listeners: { "window:message": "onWindowMessage($event)" } }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframe"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"{state: iframeState$ | async, params: iframeParams$ | async} as ctx\">\n\n <div class=\"layout-col full\">\n\n <!-- In Case of Error -->\n <div *ngIf=\"ctx.state.hasError\"\n class=\"layout-row place-center-center flex\"\n >\n <span>Failed to load Iframe: {{ctx.state.message}}</span>\n </div>\n\n <!-- IFrame -->\n <iframe #iframe\n *ngIf=\"!ctx.state.hasError\"\n (load)=\"onIframeLoadEvent($event)\"\n (error)=\"onIframeErrorEvent($event)\"\n [src]=\"ctx.params.srcUrl | elderSafeUrl\"\n class=\"iframe flex\"\n allow=\"clipboard *;clipboard-read *;clipboard-write *;\"\n ></iframe>\n\n <!-- Bottom Toolbar -->\n <div *ngIf=\"!ctx.params.hideActionBar\" class=\"layout-row place-between-center flex-none toolbar\">\n\n <a mat-icon-button (click)=\"doClose($event)\" class=\"dense-button\">\n <mat-icon class=\"small-icon\">close</mat-icon>\n </a>\n\n <a mat-icon-button class=\"dense-button\"\n [href]=\"ctx.params.srcUrl | elderSafeUrl\" target=\"_blank\">\n <mat-icon class=\"small-icon\">open_in_new</mat-icon>\n </a>\n\n </div>\n\n </div>\n\n</ng-container>\n\n\n\n", styles: [".iframe{margin:0;border:0;height:100%;background-color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-icon-button], a[mat-fab], a[mat-mini-fab], a[mat-stroked-button], a[mat-flat-button]", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matButton", "matAnchor"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.ElderSafeUrlPipe, name: "elderSafeUrl" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
111
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: IframeHostComponent, decorators: [{
|
|
112
111
|
type: Component,
|
|
113
|
-
args: [{ selector: 'elder-i-frame-host', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"{state: iframeState$ | async, params: iframeParams$ | async} as ctx\">\n\n <div
|
|
112
|
+
args: [{ selector: 'elder-i-frame-host', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"{state: iframeState$ | async, params: iframeParams$ | async} as ctx\">\n\n <div class=\"layout-col full\">\n\n <!-- In Case of Error -->\n <div *ngIf=\"ctx.state.hasError\"\n class=\"layout-row place-center-center flex\"\n >\n <span>Failed to load Iframe: {{ctx.state.message}}</span>\n </div>\n\n <!-- IFrame -->\n <iframe #iframe\n *ngIf=\"!ctx.state.hasError\"\n (load)=\"onIframeLoadEvent($event)\"\n (error)=\"onIframeErrorEvent($event)\"\n [src]=\"ctx.params.srcUrl | elderSafeUrl\"\n class=\"iframe flex\"\n allow=\"clipboard *;clipboard-read *;clipboard-write *;\"\n ></iframe>\n\n <!-- Bottom Toolbar -->\n <div *ngIf=\"!ctx.params.hideActionBar\" class=\"layout-row place-between-center flex-none toolbar\">\n\n <a mat-icon-button (click)=\"doClose($event)\" class=\"dense-button\">\n <mat-icon class=\"small-icon\">close</mat-icon>\n </a>\n\n <a mat-icon-button class=\"dense-button\"\n [href]=\"ctx.params.srcUrl | elderSafeUrl\" target=\"_blank\">\n <mat-icon class=\"small-icon\">open_in_new</mat-icon>\n </a>\n\n </div>\n\n </div>\n\n</ng-container>\n\n\n\n", styles: [".iframe{margin:0;border:0;height:100%;background-color:#fff}\n"] }]
|
|
114
113
|
}], ctorParameters: function () { return []; }, propDecorators: { iframe: [{
|
|
115
114
|
type: ViewChild,
|
|
116
115
|
args: ['iframe']
|
|
@@ -124,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
124
123
|
}], iframeParams: [{
|
|
125
124
|
type: Input
|
|
126
125
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iframe-host.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/iframe-host/iframe-host.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/iframe-host/iframe-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject} from 'rxjs';\nimport {TypedEventMessage} from '../typed-event-message';\n\nexport type IFrameStateType = 'LOADING' | 'LOADED' | 'ERROR';\n\nexport class IFrameState {\n\n  constructor(\n    public readonly type: IFrameStateType,\n    public readonly message: string | null = null\n  ) {\n  }\n\n  public get isLoading(): boolean {\n    return this.type === 'LOADING'\n  }\n\n  public get hasLoaded(): boolean {\n    return this.type == 'LOADED'\n  }\n\n  public get hasError(): boolean {\n    return this.type === 'ERROR';\n  }\n\n}\n\nexport interface IFrameParams {\n\n  /**\n   * Source URL of iframe.\n   */\n  readonly srcUrl: string;\n\n  /**\n   * Width of the iframe.\n   */\n  readonly width?: string;\n\n  /**\n   * Height of the iframe.\n   */\n  readonly height?: string;\n\n  /**\n   * If true, the bottom action bar\n   * is hidden.\n   */\n  readonly hideActionBar?: boolean;\n\n}\n\n\n@Component({\n  selector: 'elder-i-frame-host',\n  templateUrl: './iframe-host.component.html',\n  styleUrls: ['./iframe-host.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class IframeHostComponent implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly iframeParams$ = new BehaviorSubject<IFrameParams>(null);\n  public readonly iframeState$ = new BehaviorSubject<IFrameState>(new IFrameState('LOADING'));\n\n  @ViewChild('iframe')\n  public iframe: ElementRef;\n\n  @Output()\n  public message = new EventEmitter<TypedEventMessage<any, any>>();\n\n  @Output()\n  public close = new EventEmitter<any>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {}\n\n  /***************************************************************************\n   *                                                                         *\n   * Listeners                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Listens for messages from window.\n   * Makes it possible to react upon messages from iframe child window.\n   *\n   * @param event message from child window\n   */\n  @HostListener('window:message', ['$event'])\n  public onWindowMessage(event: MessageEvent): boolean {\n    this.log.debug('Received message from child:', event);\n    if (event) {\n      if (TypedEventMessage.isOfType(event.data))\n      this.handleMessageFromChild(event.data);\n    }\n    return true;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Lifecycle                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set iframeParams(params: IFrameParams) {\n    this.iframeParams$.next(params);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onIframeLoadEvent(event: Event): void {\n    this.log.debug('Finished loading iframe', event);\n    this.iframeState$.next(new IFrameState('LOADED'));\n  }\n\n  public onIframeErrorEvent(err: any): void {\n    this.log.warn('Failed to load iframe', err);\n    this.iframeState$.next(new IFrameState('ERROR', err + ''));\n  }\n\n  public sendMessageToChild(msg: TypedEventMessage<any,any>): void {\n    this.log.debug('Sending message to iframe child:', msg);\n    this.iframe.nativeElement.contentWindow.postMessage(msg, \"*\");\n  }\n\n  public doClose(event?: Event): void {\n    this.close.emit();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleMessageFromChild(message: TypedEventMessage<any, any>): void {\n    this.message.next(message);\n\n    if (message.type === 'CLOSE') {\n      this.close.emit(message.data);\n    }\n  }\n\n}\n","<ng-container *ngIf=\"{state: iframeState$ | async, params: iframeParams$ | async} as ctx\">\n\n    <div fxLayout=\"column\" fxFill>\n\n        <!-- In Case of Error -->\n        <div *ngIf=\"ctx.state.hasError\"\n             fxLayout=\"row\"\n             fxLayoutAlign=\"center center\"\n             fxFlex\n        >\n            <span>Failed to load Iframe: {{ctx.state.message}}</span>\n        </div>\n\n        <!-- IFrame -->\n        <iframe fxFlex #iframe\n                *ngIf=\"!ctx.state.hasError\"\n                (load)=\"onIframeLoadEvent($event)\"\n                (error)=\"onIframeErrorEvent($event)\"\n                [src]=\"ctx.params.srcUrl | elderSafeUrl\"\n                class=\"iframe\"\n                allow=\"clipboard *;clipboard-read *;clipboard-write *;\"\n        ></iframe>\n\n        <!-- Bottom Toolbar -->\n        <div *ngIf=\"!ctx.params.hideActionBar\" fxLayout=\"row\" fxLayoutAlign=\"space-between center\" fxFlex=\"none\" class=\"toolbar\">\n\n            <a mat-icon-button (click)=\"doClose($event)\" class=\"dense-button\">\n                <mat-icon class=\"small-icon\">close</mat-icon>\n            </a>\n\n            <a mat-icon-button class=\"dense-button\"\n               [href]=\"ctx.params.srcUrl | elderSafeUrl\" target=\"_blank\">\n                <mat-icon class=\"small-icon\">open_in_new</mat-icon>\n            </a>\n\n        </div>\n\n  </div>\n\n</ng-container>\n\n\n\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iframe-host.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/iframe-host/iframe-host.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/iframe-host/iframe-host.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AAC3I,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAC,MAAM,MAAM,CAAC;AACrC,OAAO,EAAC,iBAAiB,EAAC,MAAM,wBAAwB,CAAC;;;;;;AAIzD,MAAM,OAAO,WAAW;IAEtB,YACkB,IAAqB,EACrB,UAAyB,IAAI;QAD7B,SAAI,GAAJ,IAAI,CAAiB;QACrB,YAAO,GAAP,OAAO,CAAsB;IAE/C,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,IAAI,KAAK,SAAS,CAAA;IAChC,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,IAAI,IAAI,QAAQ,CAAA;IAC9B,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC;IAC/B,CAAC;CAEF;AAkCD,MAAM,OAAO,mBAAmB;IAsB9B;;;;gFAI4E;IAE5E;QA1BA;;;;oFAI4E;QAE3D,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEtD,kBAAa,GAAG,IAAI,eAAe,CAAe,IAAI,CAAC,CAAC;QACxD,iBAAY,GAAG,IAAI,eAAe,CAAc,IAAI,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC;QAMrF,YAAO,GAAG,IAAI,YAAY,EAA+B,CAAC;QAG1D,UAAK,GAAG,IAAI,YAAY,EAAO,CAAC;IAQxB,CAAC;IAEhB;;;;gFAI4E;IAE5E;;;;;OAKG;IAEI,eAAe,CAAC,KAAmB;QACxC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,8BAA8B,EAAE,KAAK,CAAC,CAAC;QACtD,IAAI,KAAK,EAAE;YACT,IAAI,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC;gBAC1C,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SACzC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ,KAAW,CAAC;IAE3B;;;;gFAI4E;IAE5E,IACW,YAAY,CAAC,MAAoB;QAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED;;;;gFAI4E;IAErE,iBAAiB,CAAC,KAAY;QACnC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,yBAAyB,EAAE,KAAK,CAAC,CAAC;QACjD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;IACpD,CAAC;IAEM,kBAAkB,CAAC,GAAQ;QAChC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,WAAW,CAAC,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IAEM,kBAAkB,CAAC,GAA+B;QACvD,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,kCAAkC,EAAE,GAAG,CAAC,CAAC;QACxD,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAChE,CAAC;IAEM,OAAO,CAAC,KAAa;QAC1B,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAED;;;;gFAI4E;IAEpE,sBAAsB,CAAC,OAAoC;QACjE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE3B,IAAI,OAAO,CAAC,IAAI,KAAK,OAAO,EAAE;YAC5B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAC/B;IACH,CAAC;;iHA5GU,mBAAmB;qGAAnB,mBAAmB,6TC7DhC,21CAyCA;4FDoBa,mBAAmB;kBAN/B,SAAS;+BACE,oBAAoB,mBAGb,uBAAuB,CAAC,MAAM;0EAgBxC,MAAM;sBADZ,SAAS;uBAAC,QAAQ;gBAIZ,OAAO;sBADb,MAAM;gBAIA,KAAK;sBADX,MAAM;gBAwBA,eAAe;sBADrB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAyB/B,YAAY;sBADtB,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject} from 'rxjs';\nimport {TypedEventMessage} from '../typed-event-message';\n\nexport type IFrameStateType = 'LOADING' | 'LOADED' | 'ERROR';\n\nexport class IFrameState {\n\n  constructor(\n    public readonly type: IFrameStateType,\n    public readonly message: string | null = null\n  ) {\n  }\n\n  public get isLoading(): boolean {\n    return this.type === 'LOADING'\n  }\n\n  public get hasLoaded(): boolean {\n    return this.type == 'LOADED'\n  }\n\n  public get hasError(): boolean {\n    return this.type === 'ERROR';\n  }\n\n}\n\nexport interface IFrameParams {\n\n  /**\n   * Source URL of iframe.\n   */\n  readonly srcUrl: string;\n\n  /**\n   * Width of the iframe.\n   */\n  readonly width?: string;\n\n  /**\n   * Height of the iframe.\n   */\n  readonly height?: string;\n\n  /**\n   * If true, the bottom action bar\n   * is hidden.\n   */\n  readonly hideActionBar?: boolean;\n\n}\n\n\n@Component({\n  selector: 'elder-i-frame-host',\n  templateUrl: './iframe-host.component.html',\n  styleUrls: ['./iframe-host.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class IframeHostComponent implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly iframeParams$ = new BehaviorSubject<IFrameParams>(null);\n  public readonly iframeState$ = new BehaviorSubject<IFrameState>(new IFrameState('LOADING'));\n\n  @ViewChild('iframe')\n  public iframe: ElementRef;\n\n  @Output()\n  public message = new EventEmitter<TypedEventMessage<any, any>>();\n\n  @Output()\n  public close = new EventEmitter<any>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {}\n\n  /***************************************************************************\n   *                                                                         *\n   * Listeners                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Listens for messages from window.\n   * Makes it possible to react upon messages from iframe child window.\n   *\n   * @param event message from child window\n   */\n  @HostListener('window:message', ['$event'])\n  public onWindowMessage(event: MessageEvent): boolean {\n    this.log.debug('Received message from child:', event);\n    if (event) {\n      if (TypedEventMessage.isOfType(event.data))\n      this.handleMessageFromChild(event.data);\n    }\n    return true;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Lifecycle                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set iframeParams(params: IFrameParams) {\n    this.iframeParams$.next(params);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onIframeLoadEvent(event: Event): void {\n    this.log.debug('Finished loading iframe', event);\n    this.iframeState$.next(new IFrameState('LOADED'));\n  }\n\n  public onIframeErrorEvent(err: any): void {\n    this.log.warn('Failed to load iframe', err);\n    this.iframeState$.next(new IFrameState('ERROR', err + ''));\n  }\n\n  public sendMessageToChild(msg: TypedEventMessage<any,any>): void {\n    this.log.debug('Sending message to iframe child:', msg);\n    this.iframe.nativeElement.contentWindow.postMessage(msg, \"*\");\n  }\n\n  public doClose(event?: Event): void {\n    this.close.emit();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleMessageFromChild(message: TypedEventMessage<any, any>): void {\n    this.message.next(message);\n\n    if (message.type === 'CLOSE') {\n      this.close.emit(message.data);\n    }\n  }\n\n}\n","<ng-container *ngIf=\"{state: iframeState$ | async, params: iframeParams$ | async} as ctx\">\n\n    <div class=\"layout-col full\">\n\n        <!-- In Case of Error -->\n        <div *ngIf=\"ctx.state.hasError\"\n             class=\"layout-row place-center-center flex\"\n        >\n            <span>Failed to load Iframe: {{ctx.state.message}}</span>\n        </div>\n\n        <!-- IFrame -->\n        <iframe #iframe\n                *ngIf=\"!ctx.state.hasError\"\n                (load)=\"onIframeLoadEvent($event)\"\n                (error)=\"onIframeErrorEvent($event)\"\n                [src]=\"ctx.params.srcUrl | elderSafeUrl\"\n                class=\"iframe flex\"\n                allow=\"clipboard *;clipboard-read *;clipboard-write *;\"\n        ></iframe>\n\n        <!-- Bottom Toolbar -->\n        <div *ngIf=\"!ctx.params.hideActionBar\" class=\"layout-row place-between-center flex-none toolbar\">\n\n            <a mat-icon-button (click)=\"doClose($event)\" class=\"dense-button\">\n                <mat-icon class=\"small-icon\">close</mat-icon>\n            </a>\n\n            <a mat-icon-button class=\"dense-button\"\n               [href]=\"ctx.params.srcUrl | elderSafeUrl\" target=\"_blank\">\n                <mat-icon class=\"small-icon\">open_in_new</mat-icon>\n            </a>\n\n        </div>\n\n  </div>\n\n</ng-container>\n\n\n\n"]}
|
package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs
CHANGED
|
@@ -6,8 +6,7 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
import * as i1 from "@angular/router";
|
|
7
7
|
import * as i2 from "../../shell/elder-shell.service";
|
|
8
8
|
import * as i3 from "@angular/common";
|
|
9
|
-
import * as i4 from "
|
|
10
|
-
import * as i5 from "../iframe-host/iframe-host.component";
|
|
9
|
+
import * as i4 from "../iframe-host/iframe-host.component";
|
|
11
10
|
export class IframeSideContentComponent {
|
|
12
11
|
/***************************************************************************
|
|
13
12
|
* *
|
|
@@ -71,9 +70,9 @@ export class IframeSideContentComponent {
|
|
|
71
70
|
IframeSideContentComponent.QUERY_PARAM_SRC_URL = 'srcUrl';
|
|
72
71
|
IframeSideContentComponent.QUERY_PARAM_WIDTH = 'width';
|
|
73
72
|
IframeSideContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: IframeSideContentComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.ElderShellService }], target: i0.ɵɵFactoryTarget.Component });
|
|
74
|
-
IframeSideContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: IframeSideContentComponent, selector: "elder-i-frame-side-host", ngImport: i0, template: "
|
|
73
|
+
IframeSideContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: IframeSideContentComponent, selector: "elder-i-frame-side-host", ngImport: i0, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\"\n [style.width]=\"iFrameParams.width\" class=\"full\"\n>\n <elder-i-frame-host class=\"full\"\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.IframeHostComponent, selector: "elder-i-frame-host", inputs: ["iframeParams"], outputs: ["message", "close"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
75
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: IframeSideContentComponent, decorators: [{
|
|
76
75
|
type: Component,
|
|
77
|
-
args: [{ selector: 'elder-i-frame-side-host', changeDetection: ChangeDetectionStrategy.OnPush, template: "
|
|
76
|
+
args: [{ selector: 'elder-i-frame-side-host', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\"\n [style.width]=\"iFrameParams.width\" class=\"full\"\n>\n <elder-i-frame-host class=\"full\"\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n</div>\n" }]
|
|
78
77
|
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.ElderShellService }]; } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iframe-side-content.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/iframe-side-content/iframe-side-content.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/iframe-side-content/iframe-side-content.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAkC,MAAM,eAAe,CAAC;AAElG,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AAE9C,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;;;;;;AASnD,MAAM,OAAO,0BAA0B;IAiBrC;;;;gFAI4E;IAE5E,YACU,MAAc,EACd,KAAqB,EACrB,YAA+B;QAF/B,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAgB;QACrB,iBAAY,GAAZ,YAAY,CAAmB;QAfxB,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAExD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEhC,kBAAa,GAAG,IAAI,eAAe,CAAe,IAAI,CAAC,CAAC;QAatE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CACzB,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CACzB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB;gBACE,MAAM,EAAE,MAAM,CAAC,0BAA0B,CAAC,mBAAmB,CAAC;gBAC9D,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,IAAI,QAAQ;aACnC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ,KAAW,CAAC;IAEpB,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED;;;;gFAI4E;IAErE,KAAK,CAAC,IAAU;QACrB,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,CAAC,IAAI,CACrC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CACxB;YACE,0BAA0B,CAAC,mBAAmB;YAC9C,0BAA0B,CAAC,iBAAiB;SAC7C,CACJ,CACJ,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAEpE,iBAAiB,CAAC,UAAoB;QAC5C,MAAM,MAAM,GAAW,EAAE,CAAC;QAC1B,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,CAAC;QAE1D,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE;YACvB,WAAW,EAAE,MAAM;YACnB,mBAAmB,EAAE,OAAO;SAC7B,CAAC,CAAC;IACL,CAAC;;AAlFD;;;;4EAI4E;AAEpD,8CAAmB,GAAG,QAAS,CAAA;AAC/B,4CAAiB,GAAG,OAAQ,CAAA;wHATzC,0BAA0B;4GAA1B,0BAA0B,+DCdvC,6SAQA;4FDMa,0BAA0B;kBANtC,SAAS;+BACE,yBAAyB,mBAGlB,uBAAuB,CAAC,MAAM","sourcesContent":["import {ChangeDetectionStrategy, Component, HostListener, OnDestroy, OnInit} from '@angular/core';\nimport {ActivatedRoute, Params, Router} from '@angular/router';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {IFrameParams} from '../iframe-host/iframe-host.component';\nimport {takeUntil} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderShellService} from '../../shell/elder-shell.service';\n\n@Component({\n  selector: 'elder-i-frame-side-host',\n  templateUrl: './iframe-side-content.component.html',\n  styleUrls: ['./iframe-side-content.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class IframeSideContentComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private static readonly QUERY_PARAM_SRC_URL = 'srcUrl';\n  private static readonly QUERY_PARAM_WIDTH = 'width';\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject<void>();\n\n  public readonly iframeParams$ = new BehaviorSubject<IFrameParams>(null);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private shellService: ElderShellService\n  ) {\n    this.route.queryParams.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(params => {\n      this.iframeParams$.next(\n        {\n          srcUrl: params[IframeSideContentComponent.QUERY_PARAM_SRC_URL],\n          width: params['width'] || '1000px'\n        }\n      );\n    });\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Lifecycle                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public close(data?: any): void {\n    this.shellService.closeSideContent().then(\n        () => this.removeQueryParams(\n            [\n              IframeSideContentComponent.QUERY_PARAM_SRC_URL,\n              IframeSideContentComponent.QUERY_PARAM_WIDTH\n            ]\n        )\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private removeQueryParams(paramNames: string[]): void {\n    const params: Params = {};\n    paramNames.forEach(paramName => params[paramName] = null);\n\n    this.router.navigate([], {\n      queryParams: params,\n      queryParamsHandling: 'merge'\n    });\n  }\n\n\n}\n","<div *ngIf=\"iframeParams$ | async as iFrameParams\"\n     [style.width]=\"iFrameParams.width\" class=\"full\"\n>\n    <elder-i-frame-host class=\"full\"\n                        [iframeParams]=\"iFrameParams\"\n                        (close)=\"close($event)\">\n    </elder-i-frame-host>\n</div>\n"]}
|
|
@@ -14,8 +14,7 @@ import * as i3 from "@angular/material/core";
|
|
|
14
14
|
import * as i4 from "../../../infinitescroll/elder-infinite-scroll.directive";
|
|
15
15
|
import * as i5 from "../../../infinitescroll/elder-infinite-autocomplete.directive";
|
|
16
16
|
import * as i6 from "@angular/material/icon";
|
|
17
|
-
import * as i7 from "@angular/
|
|
18
|
-
import * as i8 from "@angular/material/progress-bar";
|
|
17
|
+
import * as i7 from "@angular/material/progress-bar";
|
|
19
18
|
export class ElderAutocompleteComponent {
|
|
20
19
|
/***************************************************************************
|
|
21
20
|
* *
|
|
@@ -157,10 +156,10 @@ export class ElderAutocompleteComponent {
|
|
|
157
156
|
}
|
|
158
157
|
}
|
|
159
158
|
ElderAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderAutocompleteComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
160
|
-
ElderAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: { isOptionDisabledFn: "isOptionDisabledFn", isOptionHiddenFn: "isOptionHiddenFn", optionValueConverterFn: "optionValueConverterFn", enabled: "enabled", valueTemplate: "valueTemplate", dataContext: "dataContext", displayPropertyResolver: "displayPropertyResolver" }, outputs: { optionSelected: "optionSelected" }, queries: [{ propertyName: "valueTemplateQuery", first: true, predicate: ElderSelectValueDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "matAutocomplete", first: true, predicate: ["auto"], descendants: true }], exportAs: ["elderAutocomplete"], ngImport: i0, template: "<mat-autocomplete\n #auto=\"matAutocomplete\"\n [autoActiveFirstOption]=\"true\"\n (opened)=\"onAutocompleteOpened($event)\"\n (optionSelected)=\"onOptionSelected($event)\"\n elderInfiniteScroll elderElderInfiniteAutocomplete (closeToEnd)=\"onAutoCompleteCloseToEnd($event)\"\n>\n <!--\n <mat-option *ngIf=\"allowNull\" [value]=\"null\">{{nullDisplay | translate}}</mat-option>\n -->\n\n <mat-option disabled *ngIf=\"!(dataContext$ | async)\">\n <span class=\"mat-caption\">No DataSource / DataContext!</span>\n </mat-option>\n\n <ng-container *ngIf=\"dataContext$ | async as dc\">\n\n <mat-option disabled *ngIf=\"dc.isClosed\">\n <div
|
|
159
|
+
ElderAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: { isOptionDisabledFn: "isOptionDisabledFn", isOptionHiddenFn: "isOptionHiddenFn", optionValueConverterFn: "optionValueConverterFn", enabled: "enabled", valueTemplate: "valueTemplate", dataContext: "dataContext", displayPropertyResolver: "displayPropertyResolver" }, outputs: { optionSelected: "optionSelected" }, queries: [{ propertyName: "valueTemplateQuery", first: true, predicate: ElderSelectValueDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "matAutocomplete", first: true, predicate: ["auto"], descendants: true }], exportAs: ["elderAutocomplete"], ngImport: i0, template: "<mat-autocomplete\n #auto=\"matAutocomplete\"\n [autoActiveFirstOption]=\"true\"\n (opened)=\"onAutocompleteOpened($event)\"\n (optionSelected)=\"onOptionSelected($event)\"\n elderInfiniteScroll elderElderInfiniteAutocomplete (closeToEnd)=\"onAutoCompleteCloseToEnd($event)\"\n>\n <!--\n <mat-option *ngIf=\"allowNull\" [value]=\"null\">{{nullDisplay | translate}}</mat-option>\n -->\n\n <mat-option disabled *ngIf=\"!(dataContext$ | async)\">\n <span class=\"mat-caption\">No DataSource / DataContext!</span>\n </mat-option>\n\n <ng-container *ngIf=\"dataContext$ | async as dc\">\n\n <mat-option disabled *ngIf=\"dc.isClosed\">\n <div class=\"layout-row place-start-center gap-sm\">\n <mat-icon color=\"warn\">warning</mat-icon>\n <span class=\"mat-caption\">DataContext Closed!</span>\n </div>\n </mat-option>\n\n <ng-container *ngIf=\"availableSuggestions$ | async as suggestions\">\n\n <mat-option *ngIf=\"suggestions.length === 0\" disabled>\n No Data.\n </mat-option>\n\n <ng-container *ngFor=\"let suggestion of suggestions\">\n <mat-option\n *ngIf=\"isOptionVisible(suggestion)\"\n [value]=\"toOptionValue(suggestion)\"\n [id]=\"getIdAsString(suggestion)\"\n [disabled]=\"!isOptionAvailable(suggestion)\"\n >\n <ng-container\n *ngTemplateOutlet=\"valueTemplate || simpleValueTemplate; context: {$implicit: suggestion}\">\n </ng-container>\n <!--\n <span class=\"mat-caption\">value: {{toOptionValue(suggestion)}}</span>\n -->\n </mat-option>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"dataState$ | async as state\">\n\n <mat-option disabled *ngIf=\"!state.idle || state.loading\">\n <mat-progress-bar\n [value]=\"100\"\n [mode]=\"state.loading ? 'query' : 'determinate'\"\n [color]=\"state.error ? 'warn' : 'primary'\"\n ></mat-progress-bar>\n </mat-option>\n\n </ng-container>\n</mat-autocomplete>\n\n<ng-template #simpleValueTemplate let-value>\n <ng-container *ngIf=\"displayPropertyResolver$ | async as propertyResolver\">\n <span class=\"noselect\">{{propertyResolver(value)}}</span>\n </ng-container>\n</ng-template>\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: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i3.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i4.ElderInfiniteScrollDirective, selector: "[elderInfiniteScroll]", inputs: ["listenToHost", "eventThrottle", "offsetFactor", "ignoreScrollEvent", "containerId", "scrollContainer"], outputs: ["closeToEnd", "scrolling"] }, { kind: "directive", type: i5.ElderInfiniteAutocompleteDirective, selector: "mat-autocomplete[elderElderInfiniteAutocomplete]" }, { 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: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
161
160
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderAutocompleteComponent, decorators: [{
|
|
162
161
|
type: Component,
|
|
163
|
-
args: [{ selector: 'elder-autocomplete', exportAs: 'elderAutocomplete', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-autocomplete\n #auto=\"matAutocomplete\"\n [autoActiveFirstOption]=\"true\"\n (opened)=\"onAutocompleteOpened($event)\"\n (optionSelected)=\"onOptionSelected($event)\"\n elderInfiniteScroll elderElderInfiniteAutocomplete (closeToEnd)=\"onAutoCompleteCloseToEnd($event)\"\n>\n <!--\n <mat-option *ngIf=\"allowNull\" [value]=\"null\">{{nullDisplay | translate}}</mat-option>\n -->\n\n <mat-option disabled *ngIf=\"!(dataContext$ | async)\">\n <span class=\"mat-caption\">No DataSource / DataContext!</span>\n </mat-option>\n\n <ng-container *ngIf=\"dataContext$ | async as dc\">\n\n <mat-option disabled *ngIf=\"dc.isClosed\">\n <div
|
|
162
|
+
args: [{ selector: 'elder-autocomplete', exportAs: 'elderAutocomplete', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-autocomplete\n #auto=\"matAutocomplete\"\n [autoActiveFirstOption]=\"true\"\n (opened)=\"onAutocompleteOpened($event)\"\n (optionSelected)=\"onOptionSelected($event)\"\n elderInfiniteScroll elderElderInfiniteAutocomplete (closeToEnd)=\"onAutoCompleteCloseToEnd($event)\"\n>\n <!--\n <mat-option *ngIf=\"allowNull\" [value]=\"null\">{{nullDisplay | translate}}</mat-option>\n -->\n\n <mat-option disabled *ngIf=\"!(dataContext$ | async)\">\n <span class=\"mat-caption\">No DataSource / DataContext!</span>\n </mat-option>\n\n <ng-container *ngIf=\"dataContext$ | async as dc\">\n\n <mat-option disabled *ngIf=\"dc.isClosed\">\n <div class=\"layout-row place-start-center gap-sm\">\n <mat-icon color=\"warn\">warning</mat-icon>\n <span class=\"mat-caption\">DataContext Closed!</span>\n </div>\n </mat-option>\n\n <ng-container *ngIf=\"availableSuggestions$ | async as suggestions\">\n\n <mat-option *ngIf=\"suggestions.length === 0\" disabled>\n No Data.\n </mat-option>\n\n <ng-container *ngFor=\"let suggestion of suggestions\">\n <mat-option\n *ngIf=\"isOptionVisible(suggestion)\"\n [value]=\"toOptionValue(suggestion)\"\n [id]=\"getIdAsString(suggestion)\"\n [disabled]=\"!isOptionAvailable(suggestion)\"\n >\n <ng-container\n *ngTemplateOutlet=\"valueTemplate || simpleValueTemplate; context: {$implicit: suggestion}\">\n </ng-container>\n <!--\n <span class=\"mat-caption\">value: {{toOptionValue(suggestion)}}</span>\n -->\n </mat-option>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"dataState$ | async as state\">\n\n <mat-option disabled *ngIf=\"!state.idle || state.loading\">\n <mat-progress-bar\n [value]=\"100\"\n [mode]=\"state.loading ? 'query' : 'determinate'\"\n [color]=\"state.error ? 'warn' : 'primary'\"\n ></mat-progress-bar>\n </mat-option>\n\n </ng-container>\n</mat-autocomplete>\n\n<ng-template #simpleValueTemplate let-value>\n <ng-container *ngIf=\"displayPropertyResolver$ | async as propertyResolver\">\n <span class=\"noselect\">{{propertyResolver(value)}}</span>\n </ng-container>\n</ng-template>\n" }]
|
|
164
163
|
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { valueTemplateQuery: [{
|
|
165
164
|
type: ContentChild,
|
|
166
165
|
args: [ElderSelectValueDirective, { read: TemplateRef, static: true }]
|
|
@@ -184,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
184
183
|
}], displayPropertyResolver: [{
|
|
185
184
|
type: Input
|
|
186
185
|
}] } });
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChild, Input, NgZone, OnInit, Output, TemplateRef, ViewChild} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, of, Subject} from 'rxjs';\nimport {IDataContext, isContinuableDataContext} from '../../../../common/data/data-context/data-context';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {filter, switchMap} from 'rxjs/operators';\nimport {runInZone} from '../../../../common/utils/ng-zone-utils';\nimport {DataContextStatus} from '../../../../common/data/data-context/data-context-status';\nimport {MatAutocomplete, MatAutocompleteSelectedEvent} from '@angular/material/autocomplete';\nimport {ElderSelectValueDirective} from '../../../select/elder-select-value.directive';\nimport {ElderAutocompleteOptionSelected} from './elder-autocomplete-option-selected';\n\ntype TextResolverFn = (value: any) => string;\n\n@Component({\n  selector: 'elder-autocomplete',\n  exportAs: 'elderAutocomplete',\n  templateUrl: './elder-autocomplete.component.html',\n  styleUrls: ['./elder-autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderAutocompleteComponent<T = any, TId = any> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  /**\n   * Is this auto-complete enabled?\n   */\n  private _enabled = true;\n\n  /**\n   * The value template to customize the ui look.\n   */\n  @ContentChild(ElderSelectValueDirective, {read: TemplateRef, static: true})\n  public valueTemplateQuery: TemplateRef<any>;\n  private _valueTemplate: TemplateRef<any>;\n\n  /**\n   * The underlying Material Autocomplete\n   */\n  public readonly matAutocomplete$ = new BehaviorSubject<MatAutocomplete>(null);\n\n  @ViewChild('auto')\n  public set matAutocomplete(auto: MatAutocomplete) {\n    this.matAutocomplete$.next(auto);\n  }\n\n  @Input()\n  public isOptionDisabledFn: (option: T) => boolean;\n\n  @Input()\n  public isOptionHiddenFn: (option: T) => boolean;\n\n  @Input()\n  public optionValueConverterFn: (option: T) => any;\n\n  /**\n   * The DataContext which holds the autocomplete suggestions.\n   */\n  public readonly dataContext$ = new BehaviorSubject<IDataContext<T>>(null);\n\n  public readonly triggerReload$ = new Subject<any>();\n\n  public readonly displayPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: T) => this.propertyStringValue(value, null));\n\n  public readonly dataState$: Observable<DataContextStatus>;\n\n  public readonly availableSuggestions$: Observable<T[]>;\n\n  @Output()\n  public readonly optionSelected = new Subject<ElderAutocompleteOptionSelected>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly zone: NgZone,\n  ) {\n    this.dataState$ = this.dataContext$.pipe(\n      filter(dc => !!dc),\n      switchMap(dc => dc.status),\n      runInZone(this.zone)\n    );\n\n    this.availableSuggestions$ = this.dataContext$.pipe(\n      switchMap(dc => dc ? dc.data : of([])),\n      runInZone(this.zone)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set enabled(value: boolean) {\n    this._enabled = coerceBooleanProperty(value);\n  }\n\n  public get enabled(): boolean {\n    return this._enabled;\n  }\n\n  @Input()\n  public set valueTemplate(template: TemplateRef<any>) {\n    this._valueTemplate = template;\n  }\n\n  public get valueTemplate(): TemplateRef<any> {\n    return this._valueTemplate || this.valueTemplateQuery;\n  }\n\n  @Input()\n  public set dataContext(data: IDataContext<T>) {\n    this.dataContext$.next(data);\n  }\n\n  public get dataContext(): IDataContext<T> {\n    return this.dataContext$.getValue();\n  }\n\n  @Input()\n  public set displayPropertyResolver(resolver: TextResolverFn) {\n    this.displayPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    const option = event.option;\n    const id = option.id as unknown as TId;\n    this.optionSelected.next(\n      new ElderAutocompleteOptionSelected(\n        this,\n        id,\n        this.getEntityById(id),\n        option.value\n      )\n    );\n  }\n\n  private getEntityById(id: TId): T | undefined {\n    const dc = this.dataContext;\n    if(dc){\n      return dc.snapshot.data.find(e => this.getId(e) == id);\n    }\n    return undefined;\n  }\n\n  public onAutocompleteOpened(event: any): void {\n    this.logger.debug('Autocomplete opened:', event);\n    if (this.enabled) {\n      this.triggerReload$.next(null);\n    }\n  }\n\n  public onAutoCompleteCloseToEnd(event: UIEvent): void {\n    // this.logger.debug('Autocomplete is close to end!');\n    if (isContinuableDataContext(this.dataContext)) {\n      if (!this.dataContext.snapshot.isLoading) {\n        this.dataContext.loadMore();\n      }\n    }\n  }\n\n  public getIdAsString(value: T): string {\n    return String(this.getId(value));\n  }\n\n  public getId(value: T): TId {\n    return this.dataContext?.dataSource?.getId(value) || value;\n  }\n\n  public isOptionAvailable(option: T): boolean {\n    if (this.isOptionDisabledFn) {\n      return !this.isOptionDisabledFn(option);\n    } else {\n      return true;\n    }\n  }\n\n  public isOptionVisible(option: T): boolean {\n    if (this.isOptionHiddenFn) {\n      return !this.isOptionHiddenFn(option);\n    } else {\n      return true;\n    }\n  }\n\n  public toOptionValue(option: T): any {\n    if (this.optionValueConverterFn) {\n      return this.optionValueConverterFn(option);\n    } else {\n      return option;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * TODO Duplicate in elder-select\n   */\n  private propertyStringValue(value: T, property: string): string | null {\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    if (property) {\n      return (<any>value)[property];\n    }\n\n    return String(value);\n  }\n}\n","<mat-autocomplete\n  #auto=\"matAutocomplete\"\n  [autoActiveFirstOption]=\"true\"\n  (opened)=\"onAutocompleteOpened($event)\"\n  (optionSelected)=\"onOptionSelected($event)\"\n  elderInfiniteScroll elderElderInfiniteAutocomplete (closeToEnd)=\"onAutoCompleteCloseToEnd($event)\"\n>\n  <!--\n  <mat-option *ngIf=\"allowNull\" [value]=\"null\">{{nullDisplay | translate}}</mat-option>\n  -->\n\n  <mat-option disabled  *ngIf=\"!(dataContext$ | async)\">\n    <span class=\"mat-caption\">No DataSource / DataContext!</span>\n  </mat-option>\n\n  <ng-container *ngIf=\"dataContext$ | async as dc\">\n\n    <mat-option disabled  *ngIf=\"dc.isClosed\">\n      <div fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"8px\">\n        <mat-icon color=\"warn\">warning</mat-icon>\n        <span class=\"mat-caption\">DataContext Closed!</span>\n      </div>\n    </mat-option>\n\n    <ng-container *ngIf=\"availableSuggestions$ | async as suggestions\">\n\n      <mat-option *ngIf=\"suggestions.length === 0\" disabled>\n        No Data.\n      </mat-option>\n\n      <ng-container *ngFor=\"let suggestion of suggestions\">\n        <mat-option\n          *ngIf=\"isOptionVisible(suggestion)\"\n          [value]=\"toOptionValue(suggestion)\"\n          [id]=\"getIdAsString(suggestion)\"\n          [disabled]=\"!isOptionAvailable(suggestion)\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"valueTemplate || simpleValueTemplate; context: {$implicit: suggestion}\">\n          </ng-container>\n          <!--\n          <span class=\"mat-caption\">value: {{toOptionValue(suggestion)}}</span>\n          -->\n        </mat-option>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"dataState$ | async as state\">\n\n    <mat-option disabled *ngIf=\"!state.idle || state.loading\">\n      <mat-progress-bar\n        [value]=\"100\"\n        [mode]=\"state.loading ? 'query' : 'determinate'\"\n        [color]=\"state.error ? 'warn' : 'primary'\"\n      ></mat-progress-bar>\n    </mat-option>\n\n  </ng-container>\n</mat-autocomplete>\n\n<ng-template #simpleValueTemplate let-value>\n  <ng-container *ngIf=\"displayPropertyResolver$ | async as propertyResolver\">\n    <span class=\"noselect\">{{propertyResolver(value)}}</span>\n  </ng-container>\n</ng-template>\n"]}
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAkB,MAAM,EAAE,WAAW,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AACtI,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAc,EAAE,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AAC9D,OAAO,EAAe,wBAAwB,EAAC,MAAM,mDAAmD,CAAC;AACzG,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAC,MAAM,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAC,SAAS,EAAC,MAAM,wCAAwC,CAAC;AAGjE,OAAO,EAAC,yBAAyB,EAAC,MAAM,8CAA8C,CAAC;AACvF,OAAO,EAAC,+BAA+B,EAAC,MAAM,sCAAsC,CAAC;;;;;;;;;AAWrF,MAAM,OAAO,0BAA0B;IAyDrC;;;;gFAI4E;IAE5E,YACmB,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;QA9D/B;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEzE;;WAEG;QACK,aAAQ,GAAG,IAAI,CAAC;QASxB;;WAEG;QACa,qBAAgB,GAAG,IAAI,eAAe,CAAkB,IAAI,CAAC,CAAC;QAgB9E;;WAEG;QACa,iBAAY,GAAG,IAAI,eAAe,CAAkB,IAAI,CAAC,CAAC;QAE1D,mBAAc,GAAG,IAAI,OAAO,EAAO,CAAC;QAEpC,6BAAwB,GAAG,IAAI,eAAe,CAAiB,CAAC,KAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;QAOpH,mBAAc,GAAG,IAAI,OAAO,EAAmC,CAAC;QAW9E,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACtC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAClB,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,EAC1B,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CACrB,CAAC;QAEF,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACjD,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EACtC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CACrB,CAAC;IACJ,CAAC;IAjDD,IACW,eAAe,CAAC,IAAqB;QAC9C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAgDD;;;;gFAI4E;IAE5E,IACW,OAAO,CAAC,KAAc;QAC/B,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IACW,aAAa,CAAC,QAA0B;QACjD,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;IACjC,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,kBAAkB,CAAC;IACxD,CAAC;IAED,IACW,WAAW,CAAC,IAAqB;QAC1C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IACtC,CAAC;IAED,IACW,uBAAuB,CAAC,QAAwB;QACzD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAED;;;;gFAI4E;IAErE,gBAAgB,CAAC,KAAmC;QACzD,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,MAAM,EAAE,GAAG,MAAM,CAAC,EAAoB,CAAC;QACvC,IAAI,CAAC,cAAc,CAAC,IAAI,CACtB,IAAI,+BAA+B,CACjC,IAAI,EACJ,EAAE,EACF,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,EACtB,MAAM,CAAC,KAAK,CACb,CACF,CAAC;IACJ,CAAC;IAEO,aAAa,CAAC,EAAO;QAC3B,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC;QAC5B,IAAG,EAAE,EAAC;YACJ,OAAO,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;SACxD;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAEM,oBAAoB,CAAC,KAAU;QACpC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;QACjD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAChC;IACH,CAAC;IAEM,wBAAwB,CAAC,KAAc;QAC5C,sDAAsD;QACtD,IAAI,wBAAwB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,SAAS,EAAE;gBACxC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;aAC7B;SACF;IACH,CAAC;IAEM,aAAa,CAAC,KAAQ;QAC3B,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;IACnC,CAAC;IAEM,KAAK,CAAC,KAAQ;QACnB,OAAO,IAAI,CAAC,WAAW,EAAE,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC;IAC7D,CAAC;IAEM,iBAAiB,CAAC,MAAS;QAChC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;SACzC;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAEM,eAAe,CAAC,MAAS;QAC9B,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;SACvC;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAEM,aAAa,CAAC,MAAS;QAC5B,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC/B,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;SAC5C;aAAM;YACL,OAAO,MAAM,CAAC;SACf;IACH,CAAC;IAED;;;;gFAI4E;IAE5E;;OAEG;IACK,mBAAmB,CAAC,KAAQ,EAAE,QAAgB;QACpD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;YACzC,OAAO,IAAI,CAAC;SACb;QAED,IAAI,QAAQ,EAAE;YACZ,OAAa,KAAM,CAAC,QAAQ,CAAC,CAAC;SAC/B;QAED,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;;wHAlNU,0BAA0B;4GAA1B,0BAA0B,2aAkBvB,yBAAyB,2BAAS,WAAW,qLCvC7D,qwEAkEA;4FD7Ca,0BAA0B;kBAPtC,SAAS;+BACE,oBAAoB,YACpB,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM;6FAqBxC,kBAAkB;sBADxB,YAAY;uBAAC,yBAAyB,EAAE,EAAC,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAC;gBAU/D,eAAe;sBADzB,SAAS;uBAAC,MAAM;gBAMV,kBAAkB;sBADxB,KAAK;gBAIC,gBAAgB;sBADtB,KAAK;gBAIC,sBAAsB;sBAD5B,KAAK;gBAiBU,cAAc;sBAD7B,MAAM;gBA+BI,OAAO;sBADjB,KAAK;gBAUK,aAAa;sBADvB,KAAK;gBAUK,WAAW;sBADrB,KAAK;gBAUK,uBAAuB;sBADjC,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChild, Input, NgZone, OnInit, Output, TemplateRef, ViewChild} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, of, Subject} from 'rxjs';\nimport {IDataContext, isContinuableDataContext} from '../../../../common/data/data-context/data-context';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {filter, switchMap} from 'rxjs/operators';\nimport {runInZone} from '../../../../common/utils/ng-zone-utils';\nimport {DataContextStatus} from '../../../../common/data/data-context/data-context-status';\nimport {MatAutocomplete, MatAutocompleteSelectedEvent} from '@angular/material/autocomplete';\nimport {ElderSelectValueDirective} from '../../../select/elder-select-value.directive';\nimport {ElderAutocompleteOptionSelected} from './elder-autocomplete-option-selected';\n\ntype TextResolverFn = (value: any) => string;\n\n@Component({\n  selector: 'elder-autocomplete',\n  exportAs: 'elderAutocomplete',\n  templateUrl: './elder-autocomplete.component.html',\n  styleUrls: ['./elder-autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderAutocompleteComponent<T = any, TId = any> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  /**\n   * Is this auto-complete enabled?\n   */\n  private _enabled = true;\n\n  /**\n   * The value template to customize the ui look.\n   */\n  @ContentChild(ElderSelectValueDirective, {read: TemplateRef, static: true})\n  public valueTemplateQuery: TemplateRef<any>;\n  private _valueTemplate: TemplateRef<any>;\n\n  /**\n   * The underlying Material Autocomplete\n   */\n  public readonly matAutocomplete$ = new BehaviorSubject<MatAutocomplete>(null);\n\n  @ViewChild('auto')\n  public set matAutocomplete(auto: MatAutocomplete) {\n    this.matAutocomplete$.next(auto);\n  }\n\n  @Input()\n  public isOptionDisabledFn: (option: T) => boolean;\n\n  @Input()\n  public isOptionHiddenFn: (option: T) => boolean;\n\n  @Input()\n  public optionValueConverterFn: (option: T) => any;\n\n  /**\n   * The DataContext which holds the autocomplete suggestions.\n   */\n  public readonly dataContext$ = new BehaviorSubject<IDataContext<T>>(null);\n\n  public readonly triggerReload$ = new Subject<any>();\n\n  public readonly displayPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: T) => this.propertyStringValue(value, null));\n\n  public readonly dataState$: Observable<DataContextStatus>;\n\n  public readonly availableSuggestions$: Observable<T[]>;\n\n  @Output()\n  public readonly optionSelected = new Subject<ElderAutocompleteOptionSelected>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly zone: NgZone,\n  ) {\n    this.dataState$ = this.dataContext$.pipe(\n      filter(dc => !!dc),\n      switchMap(dc => dc.status),\n      runInZone(this.zone)\n    );\n\n    this.availableSuggestions$ = this.dataContext$.pipe(\n      switchMap(dc => dc ? dc.data : of([])),\n      runInZone(this.zone)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set enabled(value: boolean) {\n    this._enabled = coerceBooleanProperty(value);\n  }\n\n  public get enabled(): boolean {\n    return this._enabled;\n  }\n\n  @Input()\n  public set valueTemplate(template: TemplateRef<any>) {\n    this._valueTemplate = template;\n  }\n\n  public get valueTemplate(): TemplateRef<any> {\n    return this._valueTemplate || this.valueTemplateQuery;\n  }\n\n  @Input()\n  public set dataContext(data: IDataContext<T>) {\n    this.dataContext$.next(data);\n  }\n\n  public get dataContext(): IDataContext<T> {\n    return this.dataContext$.getValue();\n  }\n\n  @Input()\n  public set displayPropertyResolver(resolver: TextResolverFn) {\n    this.displayPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    const option = event.option;\n    const id = option.id as unknown as TId;\n    this.optionSelected.next(\n      new ElderAutocompleteOptionSelected(\n        this,\n        id,\n        this.getEntityById(id),\n        option.value\n      )\n    );\n  }\n\n  private getEntityById(id: TId): T | undefined {\n    const dc = this.dataContext;\n    if(dc){\n      return dc.snapshot.data.find(e => this.getId(e) == id);\n    }\n    return undefined;\n  }\n\n  public onAutocompleteOpened(event: any): void {\n    this.logger.debug('Autocomplete opened:', event);\n    if (this.enabled) {\n      this.triggerReload$.next(null);\n    }\n  }\n\n  public onAutoCompleteCloseToEnd(event: UIEvent): void {\n    // this.logger.debug('Autocomplete is close to end!');\n    if (isContinuableDataContext(this.dataContext)) {\n      if (!this.dataContext.snapshot.isLoading) {\n        this.dataContext.loadMore();\n      }\n    }\n  }\n\n  public getIdAsString(value: T): string {\n    return String(this.getId(value));\n  }\n\n  public getId(value: T): TId {\n    return this.dataContext?.dataSource?.getId(value) || value;\n  }\n\n  public isOptionAvailable(option: T): boolean {\n    if (this.isOptionDisabledFn) {\n      return !this.isOptionDisabledFn(option);\n    } else {\n      return true;\n    }\n  }\n\n  public isOptionVisible(option: T): boolean {\n    if (this.isOptionHiddenFn) {\n      return !this.isOptionHiddenFn(option);\n    } else {\n      return true;\n    }\n  }\n\n  public toOptionValue(option: T): any {\n    if (this.optionValueConverterFn) {\n      return this.optionValueConverterFn(option);\n    } else {\n      return option;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * TODO Duplicate in elder-select\n   */\n  private propertyStringValue(value: T, property: string): string | null {\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    if (property) {\n      return (<any>value)[property];\n    }\n\n    return String(value);\n  }\n}\n","<mat-autocomplete\n  #auto=\"matAutocomplete\"\n  [autoActiveFirstOption]=\"true\"\n  (opened)=\"onAutocompleteOpened($event)\"\n  (optionSelected)=\"onOptionSelected($event)\"\n  elderInfiniteScroll elderElderInfiniteAutocomplete (closeToEnd)=\"onAutoCompleteCloseToEnd($event)\"\n>\n  <!--\n  <mat-option *ngIf=\"allowNull\" [value]=\"null\">{{nullDisplay | translate}}</mat-option>\n  -->\n\n  <mat-option disabled  *ngIf=\"!(dataContext$ | async)\">\n    <span class=\"mat-caption\">No DataSource / DataContext!</span>\n  </mat-option>\n\n  <ng-container *ngIf=\"dataContext$ | async as dc\">\n\n    <mat-option disabled  *ngIf=\"dc.isClosed\">\n      <div class=\"layout-row place-start-center gap-sm\">\n        <mat-icon color=\"warn\">warning</mat-icon>\n        <span class=\"mat-caption\">DataContext Closed!</span>\n      </div>\n    </mat-option>\n\n    <ng-container *ngIf=\"availableSuggestions$ | async as suggestions\">\n\n      <mat-option *ngIf=\"suggestions.length === 0\" disabled>\n        No Data.\n      </mat-option>\n\n      <ng-container *ngFor=\"let suggestion of suggestions\">\n        <mat-option\n          *ngIf=\"isOptionVisible(suggestion)\"\n          [value]=\"toOptionValue(suggestion)\"\n          [id]=\"getIdAsString(suggestion)\"\n          [disabled]=\"!isOptionAvailable(suggestion)\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"valueTemplate || simpleValueTemplate; context: {$implicit: suggestion}\">\n          </ng-container>\n          <!--\n          <span class=\"mat-caption\">value: {{toOptionValue(suggestion)}}</span>\n          -->\n        </mat-option>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"dataState$ | async as state\">\n\n    <mat-option disabled *ngIf=\"!state.idle || state.loading\">\n      <mat-progress-bar\n        [value]=\"100\"\n        [mode]=\"state.loading ? 'query' : 'determinate'\"\n        [color]=\"state.error ? 'warn' : 'primary'\"\n      ></mat-progress-bar>\n    </mat-option>\n\n  </ng-container>\n</mat-autocomplete>\n\n<ng-template #simpleValueTemplate let-value>\n  <ng-container *ngIf=\"displayPropertyResolver$ | async as propertyResolver\">\n    <span class=\"noselect\">{{propertyResolver(value)}}</span>\n  </ng-container>\n</ng-template>\n"]}
|