@elderbyte/ngx-starter 14.4.0-beta.18 → 14.4.0-beta.19
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/esm2020/lib/components/data-view/base/data-view-options-provider-binding.mjs +63 -0
- package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +53 -10
- package/esm2020/lib/components/data-view/base/elder-data-view-options-provider.mjs +44 -0
- package/esm2020/lib/components/data-view/base/elder-data-view-options.mjs +42 -0
- package/esm2020/lib/components/data-view/base/public_api.mjs +5 -0
- package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +8 -22
- package/esm2020/lib/components/data-view/public_api.mjs +2 -2
- package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +9 -43
- package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +1 -1
- package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +119 -0
- package/esm2020/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +137 -0
- package/esm2020/lib/components/iframes/elder-iframe.module.mjs +18 -6
- package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +1 -1
- package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +56 -30
- package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +1 -1
- package/esm2020/lib/components/iframes/iframe.service.mjs +2 -2
- package/esm2020/lib/components/iframes/typed-event-message.mjs +42 -0
- package/esm2020/lib/components/select/elder-select.module.mjs +2 -2
- package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +21 -39
- package/fesm2015/elderbyte-ngx-starter.mjs +1764 -1346
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +1784 -1368
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/data-view/base/data-view-options-provider-binding.d.ts +39 -0
- package/lib/components/data-view/base/elder-data-view-base.d.ts +29 -6
- package/lib/components/data-view/base/elder-data-view-options-provider.d.ts +38 -0
- package/lib/components/data-view/base/elder-data-view-options.d.ts +33 -0
- package/lib/components/data-view/base/public_api.d.ts +4 -0
- package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -6
- package/lib/components/data-view/public_api.d.ts +1 -1
- package/lib/components/data-view/table/elder-table/elder-table.component.d.ts +5 -19
- package/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.d.ts +66 -0
- package/lib/components/iframes/data-view/data-view-iframe-adapter.directive.d.ts +62 -0
- package/lib/components/iframes/elder-iframe.module.d.ts +14 -10
- package/lib/components/iframes/iframe-host/iframe-host.component.d.ts +28 -10
- package/lib/components/iframes/iframe.service.d.ts +3 -3
- package/lib/components/iframes/typed-event-message.d.ts +26 -0
- package/lib/components/select/elder-select.module.d.ts +1 -1
- package/lib/components/select/popup/selection-model-popup.directive.d.ts +7 -27
- package/package.json +1 -1
- package/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.scss +0 -0
- package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +0 -18
- package/esm2020/lib/components/iframes/iframe-message.mjs +0 -2
- package/lib/components/data-view/base/elder-data-view-base.module.d.ts +0 -9
- package/lib/components/iframes/iframe-message.d.ts +0 -5
|
@@ -131,7 +131,7 @@ export class ElderLocalizedInputTableComponent extends FormFieldBaseComponent {
|
|
|
131
131
|
}
|
|
132
132
|
}
|
|
133
133
|
ElderLocalizedInputTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ElderLocalizedInputTableComponent, deps: [{ token: i1.ElderToastService }, { token: i2.ElderLanguageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
134
|
-
ElderLocalizedInputTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: ElderLocalizedInputTableComponent, selector: "elder-localized-input-table", inputs: { dense: "dense", float: "float", embedded: "embedded", textColumns: "textColumns", defaultLanguageTags: "defaultLanguageTags" }, providers: buildFormIntegrationProviders(ElderLocalizedInputTableComponent), queries: [{ propertyName: "textColumnsQuery", predicate: ElderLocalizedTextColumnDirective }], usesInheritance: true, ngImport: i0, template: "<div fxLayout=\"column\" fxFill>\n <elder-table matSort fxFlex\n [data]=\"data\"\n [selectionVisible]=\"true\"\n [selectionMultiEnabled]=\"true\"\n [dense]=\"dense\"\n [float]=\"float\"\n [embedded]=\"embedded\"\n >\n\n <elder-data-toolbar\n *elderTableToolbar\n [canAdd]=\"!isLocked\"\n [canRemove]=\"!isLocked\"\n [canMore]=\"false\"\n (requestNew)=\"onNewRequested()\"\n (requestRemove)=\"onRemoveRequested($event)\"\n >\n\n <ng-template elderToolbarContent=\"left.actions\">\n <div fxLayout=\"column\" fxLayoutAlign=\"start center\">\n <h4 elderCardSubtitle style=\"margin: 0\">{{label ?? placeholder}}</h4>\n </div>\n </ng-template>\n\n </elder-data-toolbar>\n\n <ng-container matColumnDef=\"locale\">\n <th mat-header-cell *matHeaderCellDef style=\"width: 100px\" mat-sort-header>Locale</th>\n <td mat-cell *matCellDef=\"let localized\">\n <mat-chip-list><mat-chip>{{localized.locale}}</mat-chip></mat-chip-list>\n </td>\n </ng-container>\n\n <ng-container *ngFor=\"let textColumn of textColumns$ | async\" matColumnDef=\"{{textColumn.name}}\">\n <th mat-header-cell *matHeaderCellDef>{{textColumn.title | translate}}</th>\n <td mat-cell *matCellDef=\"let localized\">\n <mat-form-field class=\"full-width\">\n <input\n matInput\n type=\"text\"\n name=\"i18n-{{localized.locale}}-{{textColumn.name}}\"\n [ngModel]=\"localized[textColumn.name]\" [ngModelOptions]=\"{updateOn: 'blur'}\"\n (ngModelChange)=\"onColumnTextUpdated(localized, textColumn, $event)\"\n [required]=\"required && textColumn.required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n />\n <mat-hint>{{textColumn.title | translate}} ({{localized.locale}})</mat-hint>\n <mat-error>Required</mat-error>\n </mat-form-field>\n </td>\n </ng-container>\n\n </elder-table>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i4.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i4.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i4.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i5.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i5.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i5.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i5.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i5.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i6.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i6.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "directive", type: i7.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i10.ElderTableComponent, selector: "elder-table, ebs-table", inputs: ["idField", "removingField", "hiddenField", "pageSizeOptions", "
|
|
134
|
+
ElderLocalizedInputTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: ElderLocalizedInputTableComponent, selector: "elder-localized-input-table", inputs: { dense: "dense", float: "float", embedded: "embedded", textColumns: "textColumns", defaultLanguageTags: "defaultLanguageTags" }, providers: buildFormIntegrationProviders(ElderLocalizedInputTableComponent), queries: [{ propertyName: "textColumnsQuery", predicate: ElderLocalizedTextColumnDirective }], usesInheritance: true, ngImport: i0, template: "<div fxLayout=\"column\" fxFill>\n <elder-table matSort fxFlex\n [data]=\"data\"\n [selectionVisible]=\"true\"\n [selectionMultiEnabled]=\"true\"\n [dense]=\"dense\"\n [float]=\"float\"\n [embedded]=\"embedded\"\n >\n\n <elder-data-toolbar\n *elderTableToolbar\n [canAdd]=\"!isLocked\"\n [canRemove]=\"!isLocked\"\n [canMore]=\"false\"\n (requestNew)=\"onNewRequested()\"\n (requestRemove)=\"onRemoveRequested($event)\"\n >\n\n <ng-template elderToolbarContent=\"left.actions\">\n <div fxLayout=\"column\" fxLayoutAlign=\"start center\">\n <h4 elderCardSubtitle style=\"margin: 0\">{{label ?? placeholder}}</h4>\n </div>\n </ng-template>\n\n </elder-data-toolbar>\n\n <ng-container matColumnDef=\"locale\">\n <th mat-header-cell *matHeaderCellDef style=\"width: 100px\" mat-sort-header>Locale</th>\n <td mat-cell *matCellDef=\"let localized\">\n <mat-chip-list><mat-chip>{{localized.locale}}</mat-chip></mat-chip-list>\n </td>\n </ng-container>\n\n <ng-container *ngFor=\"let textColumn of textColumns$ | async\" matColumnDef=\"{{textColumn.name}}\">\n <th mat-header-cell *matHeaderCellDef>{{textColumn.title | translate}}</th>\n <td mat-cell *matCellDef=\"let localized\">\n <mat-form-field class=\"full-width\">\n <input\n matInput\n type=\"text\"\n name=\"i18n-{{localized.locale}}-{{textColumn.name}}\"\n [ngModel]=\"localized[textColumn.name]\" [ngModelOptions]=\"{updateOn: 'blur'}\"\n (ngModelChange)=\"onColumnTextUpdated(localized, textColumn, $event)\"\n [required]=\"required && textColumn.required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n />\n <mat-hint>{{textColumn.title | translate}} ({{localized.locale}})</mat-hint>\n <mat-error>Required</mat-error>\n </mat-form-field>\n </td>\n </ng-container>\n\n </elder-table>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i4.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i4.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i4.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i5.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i5.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i5.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i5.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i5.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i6.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i6.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "directive", type: i7.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i10.ElderTableComponent, selector: "elder-table, ebs-table", inputs: ["idField", "removingField", "hiddenField", "pageSizeOptions", "keepSelection", "showFooter", "toolbarTemplate", "data", "displayedColumns", "selectionVisible"] }, { kind: "directive", type: i11.ElderTableToolbarDirective, selector: "[elderTableToolbar]" }, { kind: "component", type: i12.ElderDataToolbarComponent, selector: "elder-data-toolbar", inputs: ["canAdd", "canRemove", "canMore", "confirmRemoval", "keepSelectionAfterRemoval", "selectionModel"], outputs: ["requestNew", "requestRemove"] }, { kind: "directive", type: i12.ElderToolbarContentDirective, selector: "[elderToolbarContent]", inputs: ["elderToolbarContent"] }, { kind: "component", type: i13.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i13.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i14.ElderCardSubtitleDirective, selector: "elder-card-subtitle, [elder-card-subtitle], [elderCardSubtitle]" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i15.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
135
135
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ElderLocalizedInputTableComponent, decorators: [{
|
|
136
136
|
type: Component,
|
|
137
137
|
args: [{ selector: 'elder-localized-input-table', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderLocalizedInputTableComponent), template: "<div fxLayout=\"column\" fxFill>\n <elder-table matSort fxFlex\n [data]=\"data\"\n [selectionVisible]=\"true\"\n [selectionMultiEnabled]=\"true\"\n [dense]=\"dense\"\n [float]=\"float\"\n [embedded]=\"embedded\"\n >\n\n <elder-data-toolbar\n *elderTableToolbar\n [canAdd]=\"!isLocked\"\n [canRemove]=\"!isLocked\"\n [canMore]=\"false\"\n (requestNew)=\"onNewRequested()\"\n (requestRemove)=\"onRemoveRequested($event)\"\n >\n\n <ng-template elderToolbarContent=\"left.actions\">\n <div fxLayout=\"column\" fxLayoutAlign=\"start center\">\n <h4 elderCardSubtitle style=\"margin: 0\">{{label ?? placeholder}}</h4>\n </div>\n </ng-template>\n\n </elder-data-toolbar>\n\n <ng-container matColumnDef=\"locale\">\n <th mat-header-cell *matHeaderCellDef style=\"width: 100px\" mat-sort-header>Locale</th>\n <td mat-cell *matCellDef=\"let localized\">\n <mat-chip-list><mat-chip>{{localized.locale}}</mat-chip></mat-chip-list>\n </td>\n </ng-container>\n\n <ng-container *ngFor=\"let textColumn of textColumns$ | async\" matColumnDef=\"{{textColumn.name}}\">\n <th mat-header-cell *matHeaderCellDef>{{textColumn.title | translate}}</th>\n <td mat-cell *matCellDef=\"let localized\">\n <mat-form-field class=\"full-width\">\n <input\n matInput\n type=\"text\"\n name=\"i18n-{{localized.locale}}-{{textColumn.name}}\"\n [ngModel]=\"localized[textColumn.name]\" [ngModelOptions]=\"{updateOn: 'blur'}\"\n (ngModelChange)=\"onColumnTextUpdated(localized, textColumn, $event)\"\n [required]=\"required && textColumn.required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n />\n <mat-hint>{{textColumn.title | translate}} ({{localized.locale}})</mat-hint>\n <mat-error>Required</mat-error>\n </mat-form-field>\n </td>\n </ng-container>\n\n </elder-table>\n</div>\n" }]
|
package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs
ADDED
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, Optional, ViewChild } from '@angular/core';
|
|
2
|
+
import { IframeHostComponent } from '../../iframe-host/iframe-host.component';
|
|
3
|
+
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
|
|
4
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { DataViewMessage, DataViewSelectionInit } from '../../typed-event-message';
|
|
6
|
+
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../../../common/selection/selection-model";
|
|
9
|
+
import * as i2 from "@angular/flex-layout/flex";
|
|
10
|
+
import * as i3 from "../../iframe-host/iframe-host.component";
|
|
11
|
+
/**
|
|
12
|
+
* Container for displaying a remote data view in an iframe.
|
|
13
|
+
* Provides capabilities to communicate between remote data view (child)
|
|
14
|
+
* and iframe parent.
|
|
15
|
+
*/
|
|
16
|
+
export class DataViewIframeComponent {
|
|
17
|
+
/***************************************************************************
|
|
18
|
+
* *
|
|
19
|
+
* Constructor *
|
|
20
|
+
* *
|
|
21
|
+
**************************************************************************/
|
|
22
|
+
constructor(selectionModel) {
|
|
23
|
+
this.selectionModel = selectionModel;
|
|
24
|
+
/***************************************************************************
|
|
25
|
+
* *
|
|
26
|
+
* Fields *
|
|
27
|
+
* *
|
|
28
|
+
**************************************************************************/
|
|
29
|
+
this.log = LoggerFactory.getLogger(this.constructor.name);
|
|
30
|
+
this._dataViewOptions$ = new BehaviorSubject(null);
|
|
31
|
+
this._destroy$ = new Subject();
|
|
32
|
+
}
|
|
33
|
+
/***************************************************************************
|
|
34
|
+
* *
|
|
35
|
+
* Life Cycle *
|
|
36
|
+
* *
|
|
37
|
+
**************************************************************************/
|
|
38
|
+
ngOnInit() {
|
|
39
|
+
}
|
|
40
|
+
ngAfterViewInit() {
|
|
41
|
+
// iframe is only available after view init
|
|
42
|
+
this.setupDataViewOptionsBridge(this.iframeHost);
|
|
43
|
+
}
|
|
44
|
+
ngOnDestroy() {
|
|
45
|
+
this._destroy$.next();
|
|
46
|
+
this._destroy$.complete();
|
|
47
|
+
}
|
|
48
|
+
/***************************************************************************
|
|
49
|
+
* *
|
|
50
|
+
* Properties *
|
|
51
|
+
* *
|
|
52
|
+
**************************************************************************/
|
|
53
|
+
get dataViewOptions() {
|
|
54
|
+
return this._dataViewOptions$.getValue();
|
|
55
|
+
}
|
|
56
|
+
set dataViewOptions(options) {
|
|
57
|
+
this._dataViewOptions$.next(options);
|
|
58
|
+
}
|
|
59
|
+
get dataViewOptions$() {
|
|
60
|
+
return this._dataViewOptions$.asObservable();
|
|
61
|
+
}
|
|
62
|
+
/***************************************************************************
|
|
63
|
+
* *
|
|
64
|
+
* Public API *
|
|
65
|
+
* *
|
|
66
|
+
**************************************************************************/
|
|
67
|
+
onMessageFromChild(message) {
|
|
68
|
+
if (DataViewMessage.isOfType(message)) {
|
|
69
|
+
switch (message.type) {
|
|
70
|
+
case 'SELECTION_SELECTED':
|
|
71
|
+
this.handleSelectionMessage(message.data);
|
|
72
|
+
break;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
sendMessageToChild(message) {
|
|
77
|
+
this.log.debug("Sending message to iframe child:", message);
|
|
78
|
+
this.iframeHost.sendMessageToChild(message);
|
|
79
|
+
}
|
|
80
|
+
/***************************************************************************
|
|
81
|
+
* *
|
|
82
|
+
* Private Methods *
|
|
83
|
+
* *
|
|
84
|
+
**************************************************************************/
|
|
85
|
+
handleSelectionMessage(dataViewSelection) {
|
|
86
|
+
if (this.selectionModel) {
|
|
87
|
+
this.selectionModel.replaceSelection(dataViewSelection.selection);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
setupDataViewOptionsBridge(iframeHost) {
|
|
91
|
+
combineLatest([
|
|
92
|
+
this._dataViewOptions$,
|
|
93
|
+
iframeHost.iframeState$
|
|
94
|
+
]).pipe(takeUntil(this._destroy$), filter(([options, state]) => !!options && state.hasLoaded)).subscribe(([options, state]) => this.sendMessageToChild(this.buildDataViewInitMessage(options, this.initialSelection)));
|
|
95
|
+
}
|
|
96
|
+
buildDataViewInitMessage(options, initialSelection) {
|
|
97
|
+
return DataViewMessage.initialSelection(new DataViewSelectionInit(options, initialSelection, this.idField));
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
DataViewIframeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DataViewIframeComponent, deps: [{ token: i1.SelectionModel, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
+
DataViewIframeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", 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 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", styles: [""], dependencies: [{ kind: "directive", type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i2.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i2.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i3.IframeHostComponent, selector: "elder-i-frame-host", inputs: ["iframeParams"], outputs: ["message", "close"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DataViewIframeComponent, decorators: [{
|
|
103
|
+
type: Component,
|
|
104
|
+
args: [{ selector: 'elder-data-view-iframe', changeDetection: ChangeDetectionStrategy.OnPush, template: "<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" }]
|
|
105
|
+
}], ctorParameters: function () { return [{ type: i1.SelectionModel, decorators: [{
|
|
106
|
+
type: Optional
|
|
107
|
+
}] }]; }, propDecorators: { srcUrl: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], idField: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], initialSelection: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], iframeHost: [{
|
|
114
|
+
type: ViewChild,
|
|
115
|
+
args: [IframeHostComponent]
|
|
116
|
+
}], dataViewOptions: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}] } });
|
|
119
|
+
//# 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,\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>(null);\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 selectionModel: SelectionModel<any>\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    this._dataViewOptions$.next(options);\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"]}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { Directive, HostListener, } from '@angular/core';
|
|
2
|
+
import { SelectionModel } from '../../../common/selection/selection-model';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { DataViewMessage, DataViewSelection } from '../typed-event-message';
|
|
6
|
+
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
7
|
+
import { ElderDataViewOptionsProvider } from '../../data-view/base/elder-data-view-options-provider';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../iframe.service";
|
|
10
|
+
import * as i2 from "../../../common/selection/selection-model";
|
|
11
|
+
import * as i3 from "../../data-view/base/elder-data-view-options-provider";
|
|
12
|
+
export function createSelectionModel() {
|
|
13
|
+
return new SelectionModel();
|
|
14
|
+
}
|
|
15
|
+
export function createDataOptionsProvider() {
|
|
16
|
+
return new ElderDataViewOptionsProvider();
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* An adapter bridging communication between
|
|
20
|
+
* a data view displayed in an iframe and its parent.
|
|
21
|
+
*
|
|
22
|
+
* For example propagates selection model changes
|
|
23
|
+
* to the iframe parent.
|
|
24
|
+
*/
|
|
25
|
+
export class DataViewIframeAdapterDirective {
|
|
26
|
+
/***************************************************************************
|
|
27
|
+
* *
|
|
28
|
+
* Constructor *
|
|
29
|
+
* *
|
|
30
|
+
**************************************************************************/
|
|
31
|
+
constructor(iframeService, selectionModel, dataViewOptionsProvider) {
|
|
32
|
+
this.iframeService = iframeService;
|
|
33
|
+
this.selectionModel = selectionModel;
|
|
34
|
+
this.dataViewOptionsProvider = dataViewOptionsProvider;
|
|
35
|
+
/***************************************************************************
|
|
36
|
+
* *
|
|
37
|
+
* Fields *
|
|
38
|
+
* *
|
|
39
|
+
**************************************************************************/
|
|
40
|
+
this.log = LoggerFactory.getLogger(this.constructor.name);
|
|
41
|
+
this._destroy$ = new Subject();
|
|
42
|
+
selectionModel.selection.pipe(takeUntil(this._destroy$)).subscribe(selection => this.propagateSelectionToParent(selection));
|
|
43
|
+
}
|
|
44
|
+
/***************************************************************************
|
|
45
|
+
* *
|
|
46
|
+
* Listeners *
|
|
47
|
+
* *
|
|
48
|
+
**************************************************************************/
|
|
49
|
+
/**
|
|
50
|
+
* Listens for messages from parent window.
|
|
51
|
+
* Makes it possible to react upon messages from iframe parent.
|
|
52
|
+
*
|
|
53
|
+
* @param event message from parent window
|
|
54
|
+
*/
|
|
55
|
+
onWindowsMessage(event) {
|
|
56
|
+
this.log.debug('Received message event from parent:', event);
|
|
57
|
+
if (event) {
|
|
58
|
+
if (DataViewMessage.isOfType(event.data)) {
|
|
59
|
+
this.log.debug('Received data view message from parent:', event);
|
|
60
|
+
this.handleMessageFromParent(event.data);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return true;
|
|
64
|
+
}
|
|
65
|
+
/***************************************************************************
|
|
66
|
+
* *
|
|
67
|
+
* Life Cycle *
|
|
68
|
+
* *
|
|
69
|
+
**************************************************************************/
|
|
70
|
+
ngOnInit() {
|
|
71
|
+
}
|
|
72
|
+
ngOnDestroy() {
|
|
73
|
+
this._destroy$.next();
|
|
74
|
+
this._destroy$.complete();
|
|
75
|
+
}
|
|
76
|
+
/***************************************************************************
|
|
77
|
+
* *
|
|
78
|
+
* Private Methods *
|
|
79
|
+
* *
|
|
80
|
+
**************************************************************************/
|
|
81
|
+
handleMessageFromParent(message) {
|
|
82
|
+
switch (message.type) {
|
|
83
|
+
case 'SELECTION_INIT':
|
|
84
|
+
this.initializeDataView(message.data);
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
initializeDataView(init) {
|
|
89
|
+
this.dataViewOptionsProvider.updateOptions(options => options
|
|
90
|
+
.withSorts(init.options.sorts)
|
|
91
|
+
.withFilters(init.options.filters));
|
|
92
|
+
this.selectionModel.keyGetterFn = (entity) => entity[init.idField];
|
|
93
|
+
this.selectionModel.isMultipleSelection = init.options.selectionMultiEnabled;
|
|
94
|
+
if (init.initialSelection) {
|
|
95
|
+
this.selectionModel.replaceSelection(init.initialSelection);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
propagateSelectionToParent(selection) {
|
|
99
|
+
this.log.debug('Propagating selection to iframe parent:', selection);
|
|
100
|
+
const message = this.buildSelectionMessage(selection);
|
|
101
|
+
this.iframeService.postDataMessage(message);
|
|
102
|
+
}
|
|
103
|
+
buildSelectionMessage(selection) {
|
|
104
|
+
return DataViewMessage.selection(new DataViewSelection(selection));
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
DataViewIframeAdapterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DataViewIframeAdapterDirective, deps: [{ token: i1.IframeService }, { token: i2.SelectionModel }, { token: i3.ElderDataViewOptionsProvider }], target: i0.ɵɵFactoryTarget.Directive });
|
|
108
|
+
DataViewIframeAdapterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.6", type: DataViewIframeAdapterDirective, selector: "[elderDataViewIframeAdapter]", host: { listeners: { "window:message": "onWindowsMessage($event)" } }, providers: [
|
|
109
|
+
{
|
|
110
|
+
provide: SelectionModel,
|
|
111
|
+
useFactory: createSelectionModel
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
provide: ElderDataViewOptionsProvider,
|
|
115
|
+
useFactory: createDataOptionsProvider
|
|
116
|
+
}
|
|
117
|
+
], ngImport: i0 });
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DataViewIframeAdapterDirective, decorators: [{
|
|
119
|
+
type: Directive,
|
|
120
|
+
args: [{
|
|
121
|
+
selector: '[elderDataViewIframeAdapter]',
|
|
122
|
+
providers: [
|
|
123
|
+
{
|
|
124
|
+
provide: SelectionModel,
|
|
125
|
+
useFactory: createSelectionModel
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
provide: ElderDataViewOptionsProvider,
|
|
129
|
+
useFactory: createDataOptionsProvider
|
|
130
|
+
}
|
|
131
|
+
]
|
|
132
|
+
}]
|
|
133
|
+
}], ctorParameters: function () { return [{ type: i1.IframeService }, { type: i2.SelectionModel }, { type: i3.ElderDataViewOptionsProvider }]; }, propDecorators: { onWindowsMessage: [{
|
|
134
|
+
type: HostListener,
|
|
135
|
+
args: ['window:message', ['$event']]
|
|
136
|
+
}] } });
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view-iframe-adapter.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/iframes/data-view/data-view-iframe-adapter.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  HostListener,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport {SelectionModel} from '../../../common/selection/selection-model';\nimport {Subject} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\nimport {DataViewMessage, DataViewSelection, DataViewSelectionInit} from '../typed-event-message';\nimport {IframeService} from '../iframe.service';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderDataViewOptionsProvider} from '../../data-view/base/elder-data-view-options-provider';\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataOptionsProvider(): ElderDataViewOptionsProvider {\n  return new ElderDataViewOptionsProvider();\n}\n\n/**\n * An adapter bridging communication between\n * a data view displayed in an iframe and its parent.\n *\n * For example propagates selection model changes\n * to the iframe parent.\n */\n@Directive({\n  selector: '[elderDataViewIframeAdapter]',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewOptionsProvider,\n      useFactory: createDataOptionsProvider\n    }\n  ]\n})\nexport class DataViewIframeAdapterDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _destroy$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly iframeService: IframeService,\n    private readonly selectionModel: SelectionModel<any>,\n    private readonly dataViewOptionsProvider: ElderDataViewOptionsProvider\n  ) {\n    selectionModel.selection.pipe(\n      takeUntil(this._destroy$)\n    ).subscribe(\n      selection => this.propagateSelectionToParent(selection)\n    )\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Listeners                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Listens for messages from parent window.\n   * Makes it possible to react upon messages from iframe parent.\n   *\n   * @param event message from parent window\n   */\n  @HostListener('window:message', ['$event'])\n  public onWindowsMessage(event: MessageEvent): boolean {\n    this.log.debug('Received message event from parent:', event);\n    if (event) {\n      if (DataViewMessage.isOfType(event.data)) {\n        this.log.debug('Received data view message from parent:', event);\n        this.handleMessageFromParent(event.data);\n      }\n    }\n    return true;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleMessageFromParent(message: DataViewMessage<any, any>): void {\n    switch (message.type) {\n      case 'SELECTION_INIT':\n        this.initializeDataView(message.data)\n        break;\n    }\n  }\n\n  private initializeDataView(init: DataViewSelectionInit<any>): void {\n\n    this.dataViewOptionsProvider.updateOptions(\n      options => options\n        .withSorts(init.options.sorts)\n        .withFilters(init.options.filters)\n    )\n\n    this.selectionModel.keyGetterFn = (entity) => entity[init.idField];\n    this.selectionModel.isMultipleSelection = init.options.selectionMultiEnabled;\n    if (init.initialSelection) {\n      this.selectionModel.replaceSelection(init.initialSelection);\n    }\n  }\n\n  private propagateSelectionToParent(selection: any[]): void {\n    this.log.debug('Propagating selection to iframe parent:', selection);\n\n    const message = this.buildSelectionMessage(selection);\n    this.iframeService.postDataMessage(message);\n  }\n\n  private buildSelectionMessage(selection: any[]): DataViewMessage<any> {\n    return DataViewMessage.selection(new DataViewSelection(selection));\n  }\n\n}\n"]}
|
|
@@ -11,20 +11,26 @@ import { IframeSideContentComponent } from './iframe-side-content/iframe-side-co
|
|
|
11
11
|
import { MatButtonModule } from '@angular/material/button';
|
|
12
12
|
import { ElderPipesModule } from '../../pipes/elder-pipes.module';
|
|
13
13
|
import { IframeCloseDirective } from './iframe-close.directive';
|
|
14
|
+
import { DataViewIframeComponent } from './data-view/data-view-iframe/data-view-iframe.component';
|
|
15
|
+
import { DataViewIframeAdapterDirective } from './data-view/data-view-iframe-adapter.directive';
|
|
14
16
|
import * as i0 from "@angular/core";
|
|
15
17
|
export * from './iframe.service';
|
|
16
18
|
export * from './iframe-close.directive';
|
|
17
19
|
export * from './iframe-host/iframe-host.component';
|
|
18
20
|
export * from './iframe-side-content/iframe-side-content.component';
|
|
19
21
|
export * from './iframe-dialog/iframe-dialog.component';
|
|
20
|
-
export * from './
|
|
22
|
+
export * from './typed-event-message';
|
|
23
|
+
export * from './data-view/data-view-iframe/data-view-iframe.component';
|
|
24
|
+
export * from './data-view/data-view-iframe-adapter.directive';
|
|
21
25
|
export class ElderIFrameModule {
|
|
22
26
|
}
|
|
23
27
|
ElderIFrameModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ElderIFrameModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
24
28
|
ElderIFrameModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.6", ngImport: i0, type: ElderIFrameModule, declarations: [IframeHostComponent,
|
|
25
29
|
IframeDialogComponent,
|
|
26
30
|
IframeSideContentComponent,
|
|
27
|
-
IframeCloseDirective
|
|
31
|
+
IframeCloseDirective,
|
|
32
|
+
DataViewIframeComponent,
|
|
33
|
+
DataViewIframeAdapterDirective], imports: [
|
|
28
34
|
// Angular
|
|
29
35
|
CommonModule,
|
|
30
36
|
RouterModule,
|
|
@@ -39,7 +45,9 @@ ElderIFrameModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versi
|
|
|
39
45
|
ElderPipesModule], exports: [IframeHostComponent,
|
|
40
46
|
IframeDialogComponent,
|
|
41
47
|
IframeSideContentComponent,
|
|
42
|
-
IframeCloseDirective
|
|
48
|
+
IframeCloseDirective,
|
|
49
|
+
DataViewIframeComponent,
|
|
50
|
+
DataViewIframeAdapterDirective] });
|
|
43
51
|
ElderIFrameModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ElderIFrameModule, imports: [
|
|
44
52
|
// Angular
|
|
45
53
|
CommonModule,
|
|
@@ -74,14 +82,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImpor
|
|
|
74
82
|
IframeHostComponent,
|
|
75
83
|
IframeDialogComponent,
|
|
76
84
|
IframeSideContentComponent,
|
|
77
|
-
IframeCloseDirective
|
|
85
|
+
IframeCloseDirective,
|
|
86
|
+
DataViewIframeComponent,
|
|
87
|
+
DataViewIframeAdapterDirective
|
|
78
88
|
],
|
|
79
89
|
exports: [
|
|
80
90
|
IframeHostComponent,
|
|
81
91
|
IframeDialogComponent,
|
|
82
92
|
IframeSideContentComponent,
|
|
83
|
-
IframeCloseDirective
|
|
93
|
+
IframeCloseDirective,
|
|
94
|
+
DataViewIframeComponent,
|
|
95
|
+
DataViewIframeAdapterDirective
|
|
84
96
|
]
|
|
85
97
|
}]
|
|
86
98
|
}] });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItaWZyYW1lLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvaWZyYW1lcy9lbGRlci1pZnJhbWUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUN4RSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUMvRixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDaEUsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDbEcsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sZ0RBQWdELENBQUM7O0FBRTlGLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxnREFBZ0QsQ0FBQTtBQXNDOUQsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQWhCMUIsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQiwwQkFBMEI7UUFDMUIsb0JBQW9CO1FBQ3BCLHVCQUF1QjtRQUN2Qiw4QkFBOEI7UUF0QjlCLFVBQVU7UUFDVixZQUFZO1FBQ1osWUFBWTtRQUNaLFdBQVc7UUFFWCxjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFFZixtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLGVBQWU7UUFFZixZQUFZO1FBQ1osZ0JBQWdCLGFBV2hCLG1CQUFtQjtRQUNuQixxQkFBcUI7UUFDckIsMEJBQTBCO1FBQzFCLG9CQUFvQjtRQUNwQix1QkFBdUI7UUFDdkIsOEJBQThCOytHQUdyQixpQkFBaUI7UUFqQzFCLFVBQVU7UUFDVixZQUFZO1FBQ1osWUFBWTtRQUNaLFdBQVc7UUFFWCxjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFFZixtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLGVBQWU7UUFFZixZQUFZO1FBQ1osZ0JBQWdCOzJGQW1CUCxpQkFBaUI7a0JBcEM3QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFFUCxVQUFVO3dCQUNWLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixXQUFXO3dCQUVYLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixlQUFlO3dCQUVmLG1CQUFtQjt3QkFDbkIsYUFBYTt3QkFDYixlQUFlO3dCQUVmLFlBQVk7d0JBQ1osZ0JBQWdCO3FCQUNqQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLDBCQUEwQjt3QkFDMUIsb0JBQW9CO3dCQUNwQix1QkFBdUI7d0JBQ3ZCLDhCQUE4QjtxQkFDL0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjt3QkFDbkIscUJBQXFCO3dCQUNyQiwwQkFBMEI7d0JBQzFCLG9CQUFvQjt3QkFDcEIsdUJBQXVCO3dCQUN2Qiw4QkFBOEI7cUJBQy9CO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TWF0SWNvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQge0ZsZXhMYXlvdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7Um91dGVyTW9kdWxlfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtJZnJhbWVIb3N0Q29tcG9uZW50fSBmcm9tICcuL2lmcmFtZS1ob3N0L2lmcmFtZS1ob3N0LmNvbXBvbmVudCc7XG5pbXBvcnQge0lmcmFtZURpYWxvZ0NvbXBvbmVudH0gZnJvbSAnLi9pZnJhbWUtZGlhbG9nL2lmcmFtZS1kaWFsb2cuY29tcG9uZW50JztcbmltcG9ydCB7SWZyYW1lU2lkZUNvbnRlbnRDb21wb25lbnR9IGZyb20gJy4vaWZyYW1lLXNpZGUtY29udGVudC9pZnJhbWUtc2lkZS1jb250ZW50LmNvbXBvbmVudCc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7RWxkZXJQaXBlc01vZHVsZX0gZnJvbSAnLi4vLi4vcGlwZXMvZWxkZXItcGlwZXMubW9kdWxlJztcbmltcG9ydCB7SWZyYW1lQ2xvc2VEaXJlY3RpdmV9IGZyb20gJy4vaWZyYW1lLWNsb3NlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYXRhVmlld0lmcmFtZUNvbXBvbmVudCB9IGZyb20gJy4vZGF0YS12aWV3L2RhdGEtdmlldy1pZnJhbWUvZGF0YS12aWV3LWlmcmFtZS5jb21wb25lbnQnO1xuaW1wb3J0IHtEYXRhVmlld0lmcmFtZUFkYXB0ZXJEaXJlY3RpdmV9IGZyb20gJy4vZGF0YS12aWV3L2RhdGEtdmlldy1pZnJhbWUtYWRhcHRlci5kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2lmcmFtZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vaWZyYW1lLWNsb3NlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2lmcmFtZS1ob3N0L2lmcmFtZS1ob3N0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2lmcmFtZS1zaWRlLWNvbnRlbnQvaWZyYW1lLXNpZGUtY29udGVudC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pZnJhbWUtZGlhbG9nL2lmcmFtZS1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZWQtZXZlbnQtbWVzc2FnZSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGEtdmlldy9kYXRhLXZpZXctaWZyYW1lL2RhdGEtdmlldy1pZnJhbWUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhLXZpZXcvZGF0YS12aWV3LWlmcmFtZS1hZGFwdGVyLmRpcmVjdGl2ZSdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuXG4gICAgLy8gQW5ndWxhclxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBSb3V0ZXJNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG5cbiAgICAvLyBUaGlyZCBQYXJ0eVxuICAgIEZsZXhMYXlvdXRNb2R1bGUsXG4gICAgVHJhbnNsYXRlTW9kdWxlLFxuXG4gICAgLy8gQW5ndWxhciBNYXRlcmlhbFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuXG4gICAgLy8gRWxkZXJCeXRlXG4gICAgRWxkZXJQaXBlc01vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBJZnJhbWVIb3N0Q29tcG9uZW50LFxuICAgIElmcmFtZURpYWxvZ0NvbXBvbmVudCxcbiAgICBJZnJhbWVTaWRlQ29udGVudENvbXBvbmVudCxcbiAgICBJZnJhbWVDbG9zZURpcmVjdGl2ZSxcbiAgICBEYXRhVmlld0lmcmFtZUNvbXBvbmVudCxcbiAgICBEYXRhVmlld0lmcmFtZUFkYXB0ZXJEaXJlY3RpdmVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIElmcmFtZUhvc3RDb21wb25lbnQsXG4gICAgSWZyYW1lRGlhbG9nQ29tcG9uZW50LFxuICAgIElmcmFtZVNpZGVDb250ZW50Q29tcG9uZW50LFxuICAgIElmcmFtZUNsb3NlRGlyZWN0aXZlLFxuICAgIERhdGFWaWV3SWZyYW1lQ29tcG9uZW50LFxuICAgIERhdGFWaWV3SWZyYW1lQWRhcHRlckRpcmVjdGl2ZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVySUZyYW1lTW9kdWxlIHtcbn1cbiJdfQ==
|
|
@@ -41,7 +41,7 @@ export class IframeDialogComponent {
|
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
IframeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", 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.0.6", type: IframeDialogComponent, selector: "elder-i-frame-dialog", ngImport: i0, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\" fxFill>\n\n <elder-i-frame-host fxFlex\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n\n</div>\n\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i3.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i4.IframeHostComponent, selector: "elder-i-frame-host", inputs: ["iframeParams"], outputs: ["
|
|
44
|
+
IframeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: IframeDialogComponent, selector: "elder-i-frame-dialog", ngImport: i0, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\" fxFill>\n\n <elder-i-frame-host fxFlex\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n\n</div>\n\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i3.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i4.IframeHostComponent, selector: "elder-i-frame-host", inputs: ["iframeParams"], outputs: ["message", "close"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
45
45
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: IframeDialogComponent, decorators: [{
|
|
46
46
|
type: Component,
|
|
47
47
|
args: [{ selector: 'elder-i-frame-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"iframeParams$ | async as iFrameParams\" fxFill>\n\n <elder-i-frame-host fxFlex\n [iframeParams]=\"iFrameParams\"\n (close)=\"close($event)\">\n </elder-i-frame-host>\n\n</div>\n\n\n\n" }]
|