@elderbyte/ngx-starter 15.17.3 → 15.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +2 -2
- package/esm2020/lib/components/data-view/master-detail/elder-detail-dialog/elder-detail-dialog.component.mjs +6 -6
- package/esm2020/lib/components/data-view/master-detail/elder-detail.directive.mjs +8 -6
- package/esm2020/lib/components/data-view/master-detail/elder-master-activation.directive.mjs +26 -11
- package/esm2020/lib/components/data-view/master-detail/elder-master-detail-activation-event.mjs +12 -0
- package/esm2020/lib/components/data-view/master-detail/elder-master-detail-provider.mjs +7 -7
- package/esm2020/lib/components/data-view/master-detail/elder-master-detail.component.mjs +8 -8
- package/esm2020/lib/components/data-view/master-detail/elder-master-detail.module.mjs +3 -2
- package/esm2020/lib/components/data-view/master-detail/elder-master-detail.service.mjs +73 -0
- package/esm2020/lib/components/data-view/table/activation/activation-event-source.mjs +7 -0
- package/esm2020/lib/components/data-view/table/activation/active-item-event.mjs +9 -0
- package/esm2020/lib/components/data-view/table/activation/elder-activation-context.mjs +2 -0
- package/esm2020/lib/components/data-view/table/activation/elder-delete-active.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +27 -17
- package/esm2020/lib/components/data-view/table/activation/item-activation-options.mjs +7 -0
- package/esm2020/lib/components/data-view/table/activation/public_api.mjs +8 -0
- package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +6 -3
- package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +28 -15
- package/esm2020/lib/components/data-view/table/elder-table.module.mjs +6 -8
- package/fesm2015/elderbyte-ngx-starter.mjs +151 -82
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +151 -82
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/data-view/master-detail/elder-detail-dialog/elder-detail-dialog.component.d.ts +2 -2
- package/lib/components/data-view/master-detail/elder-detail.directive.d.ts +2 -2
- package/lib/components/data-view/master-detail/elder-master-activation.directive.d.ts +11 -4
- package/lib/components/data-view/master-detail/elder-master-detail-activation-event.d.ts +8 -0
- package/lib/components/data-view/master-detail/elder-master-detail-provider.d.ts +5 -5
- package/lib/components/data-view/master-detail/elder-master-detail.component.d.ts +2 -2
- package/lib/components/data-view/master-detail/elder-master-detail.module.d.ts +2 -1
- package/lib/components/data-view/master-detail/{master-detail.service.d.ts → elder-master-detail.service.d.ts} +8 -7
- package/lib/components/data-view/table/activation/activation-event-source.d.ts +5 -0
- package/lib/components/data-view/table/activation/active-item-event.d.ts +8 -0
- package/lib/components/data-view/table/activation/elder-activation-context.d.ts +7 -0
- package/lib/components/data-view/table/activation/elder-table-activation.directive.d.ts +10 -5
- package/lib/components/data-view/table/activation/item-activation-options.d.ts +6 -0
- package/lib/components/data-view/table/activation/public_api.d.ts +7 -0
- package/lib/components/data-view/table/elder-table/elder-table.component.d.ts +1 -0
- package/lib/components/data-view/table/elder-table-row.directive.d.ts +5 -5
- package/lib/components/data-view/table/elder-table.module.d.ts +5 -7
- package/package.json +1 -1
- package/src/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.scss +0 -3
- package/src/lib/components/data-view/table/elder-table/elder-table.component.scss +1 -1
- package/esm2020/lib/components/data-view/master-detail/master-detail.service.mjs +0 -70
- package/esm2020/lib/components/data-view/table/activation/elder-item-activator.mjs +0 -2
- package/lib/components/data-view/table/activation/elder-item-activator.d.ts +0 -3
|
@@ -35,10 +35,10 @@ export class DataContextStateIndicatorComponent {
|
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
DataContextStateIndicatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataContextStateIndicatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
-
DataContextStateIndicatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DataContextStateIndicatorComponent, selector: "elder-data-context-state-indicator", inputs: { dataContext: "dataContext" }, ngImport: i0, template: "<ng-container *ngIf=\"dataContext$ | async as dataContext\">\n\n <ng-container *ngIf=\"dataContext else noDataContext\">\n\n <ng-container *ngIf=\"(dataContext.isStarted$ | async) else dataContextNotStarted\">\n\n <ng-container *ngIf=\"!(dataContext?.status | async)?.hasError else dataContextHasError\">\n\n <ng-container *ngIf=\"(dataContext?.data | async)?.length === 0\">\n <ng-template [ngTemplateOutlet]=\"dataContextNoData\"></ng-template>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n</ng-container>\n\n<ng-template #noDataContext>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'No data context'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNotStarted>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'Data context not started'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextHasError>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', iconColor: 'warn', text: 'Error while loading data'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNoData>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'info', text: 'No data available'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #indicator let-icon=\"icon\" let-iconColor=\"iconColor\" let-text=\"text\">\n\n <div class=\"layout-col place-center-center full elder-dc-indicator-container mat-body-2\">\n <div class=\"layout-row place-center-center gap-lg\">\n <mat-icon [color]=\"iconColor\">{{icon}}</mat-icon>\n <span class=\"hint mat-body-2\">{{text | translate}}</span>\n </div>\n </div>\n\n</ng-template>\n", styles: [".elder-dc-indicator-container{color:gray
|
|
38
|
+
DataContextStateIndicatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DataContextStateIndicatorComponent, selector: "elder-data-context-state-indicator", inputs: { dataContext: "dataContext" }, ngImport: i0, template: "<ng-container *ngIf=\"dataContext$ | async as dataContext\">\n\n <ng-container *ngIf=\"dataContext else noDataContext\">\n\n <ng-container *ngIf=\"(dataContext.isStarted$ | async) else dataContextNotStarted\">\n\n <ng-container *ngIf=\"!(dataContext?.status | async)?.hasError else dataContextHasError\">\n\n <ng-container *ngIf=\"(dataContext?.data | async)?.length === 0\">\n <ng-template [ngTemplateOutlet]=\"dataContextNoData\"></ng-template>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n</ng-container>\n\n<ng-template #noDataContext>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'No data context'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNotStarted>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'Data context not started'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextHasError>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', iconColor: 'warn', text: 'Error while loading data'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNoData>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'info', text: 'No data available'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #indicator let-icon=\"icon\" let-iconColor=\"iconColor\" let-text=\"text\">\n\n <div class=\"layout-col place-center-center full elder-dc-indicator-container mat-body-2\">\n <div class=\"layout-row place-center-center gap-lg\">\n <mat-icon [color]=\"iconColor\">{{icon}}</mat-icon>\n <span class=\"hint mat-body-2\">{{text | translate}}</span>\n </div>\n </div>\n\n</ng-template>\n", styles: [".elder-dc-indicator-container{color:gray}\n"], dependencies: [{ 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.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
39
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataContextStateIndicatorComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
|
-
args: [{ selector: 'elder-data-context-state-indicator', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"dataContext$ | async as dataContext\">\n\n <ng-container *ngIf=\"dataContext else noDataContext\">\n\n <ng-container *ngIf=\"(dataContext.isStarted$ | async) else dataContextNotStarted\">\n\n <ng-container *ngIf=\"!(dataContext?.status | async)?.hasError else dataContextHasError\">\n\n <ng-container *ngIf=\"(dataContext?.data | async)?.length === 0\">\n <ng-template [ngTemplateOutlet]=\"dataContextNoData\"></ng-template>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n</ng-container>\n\n<ng-template #noDataContext>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'No data context'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNotStarted>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'Data context not started'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextHasError>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', iconColor: 'warn', text: 'Error while loading data'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNoData>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'info', text: 'No data available'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #indicator let-icon=\"icon\" let-iconColor=\"iconColor\" let-text=\"text\">\n\n <div class=\"layout-col place-center-center full elder-dc-indicator-container mat-body-2\">\n <div class=\"layout-row place-center-center gap-lg\">\n <mat-icon [color]=\"iconColor\">{{icon}}</mat-icon>\n <span class=\"hint mat-body-2\">{{text | translate}}</span>\n </div>\n </div>\n\n</ng-template>\n", styles: [".elder-dc-indicator-container{color:gray
|
|
41
|
+
args: [{ selector: 'elder-data-context-state-indicator', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"dataContext$ | async as dataContext\">\n\n <ng-container *ngIf=\"dataContext else noDataContext\">\n\n <ng-container *ngIf=\"(dataContext.isStarted$ | async) else dataContextNotStarted\">\n\n <ng-container *ngIf=\"!(dataContext?.status | async)?.hasError else dataContextHasError\">\n\n <ng-container *ngIf=\"(dataContext?.data | async)?.length === 0\">\n <ng-template [ngTemplateOutlet]=\"dataContextNoData\"></ng-template>\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n </ng-container>\n\n</ng-container>\n\n<ng-template #noDataContext>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'No data context'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNotStarted>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', text: 'Data context not started'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextHasError>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'warning', iconColor: 'warn', text: 'Error while loading data'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #dataContextNoData>\n <ng-container *ngTemplateOutlet=\"indicator; context:{icon: 'info', text: 'No data available'}\">\n </ng-container>\n</ng-template>\n\n<ng-template #indicator let-icon=\"icon\" let-iconColor=\"iconColor\" let-text=\"text\">\n\n <div class=\"layout-col place-center-center full elder-dc-indicator-container mat-body-2\">\n <div class=\"layout-row place-center-center gap-lg\">\n <mat-icon [color]=\"iconColor\">{{icon}}</mat-icon>\n <span class=\"hint mat-body-2\">{{text | translate}}</span>\n </div>\n </div>\n\n</ng-template>\n", styles: [".elder-dc-indicator-container{color:gray}\n"] }]
|
|
42
42
|
}], ctorParameters: function () { return []; }, propDecorators: { dataContext: [{
|
|
43
43
|
type: Input
|
|
44
44
|
}] } });
|
|
@@ -4,7 +4,7 @@ import { BehaviorSubject, Subject } from 'rxjs';
|
|
|
4
4
|
import { takeUntil } from 'rxjs/operators';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/material/dialog";
|
|
7
|
-
import * as i2 from "../master-detail.service";
|
|
7
|
+
import * as i2 from "../elder-master-detail.service";
|
|
8
8
|
import * as i3 from "@angular/common";
|
|
9
9
|
import * as i4 from "@angular/material/icon";
|
|
10
10
|
import * as i5 from "@angular/material/button";
|
|
@@ -27,10 +27,10 @@ export class ElderDetailDialogComponent {
|
|
|
27
27
|
**************************************************************************/
|
|
28
28
|
this.destroy$ = new Subject();
|
|
29
29
|
this.entity$ = new BehaviorSubject(null);
|
|
30
|
-
this.masterDetailService.
|
|
30
|
+
this.masterDetailService.activationEvent$
|
|
31
31
|
.pipe(takeUntil(this.destroy$))
|
|
32
32
|
.subscribe({ next: active => {
|
|
33
|
-
this.entity$.next(active);
|
|
33
|
+
this.entity$.next(active.item);
|
|
34
34
|
} });
|
|
35
35
|
}
|
|
36
36
|
/***************************************************************************
|
|
@@ -51,7 +51,7 @@ export class ElderDetailDialogComponent {
|
|
|
51
51
|
this.dialogRef.close(this.entity$.getValue());
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
|
-
ElderDetailDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderDetailDialogComponent, deps: [{ token: i1.MatDialogRef, optional: true }, { token: MAT_DIALOG_DATA, optional: true }, { token: i2.
|
|
54
|
+
ElderDetailDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderDetailDialogComponent, deps: [{ token: i1.MatDialogRef, optional: true }, { token: MAT_DIALOG_DATA, optional: true }, { token: i2.ElderMasterDetailService }], target: i0.ɵɵFactoryTarget.Component });
|
|
55
55
|
ElderDetailDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderDetailDialogComponent, selector: "elder-detail-dialog", ngImport: i0, template: "<div class=\"layout-col full\">\n\n <span style=\"width: 100vw;\"></span>\n\n <!-- Header Section -->\n <elder-toolbar class=\"gap-md\" *ngIf=\"entity$ | async as entity\">\n <button (click)=\"close()\" mat-icon-button *elderToolbarColumn=\"'left.begin'\">\n <mat-icon>close</mat-icon>\n </button>\n </elder-toolbar>\n\n <div class=\"layout-row flex gap-md\">\n <ng-container *ngTemplateOutlet=\"data.detailTemplateRef\"></ng-container>\n </div>\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.ElderToolbarComponent, selector: "elder-toolbar", inputs: ["color"] }, { kind: "directive", type: i7.ElderToolbarColumnDirective, selector: "[elderToolbarColumn]", inputs: ["elderToolbarColumn", "elderToolbarDefault"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
56
56
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderDetailDialogComponent, decorators: [{
|
|
57
57
|
type: Component,
|
|
@@ -63,5 +63,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
63
63
|
}, {
|
|
64
64
|
type: Inject,
|
|
65
65
|
args: [MAT_DIALOG_DATA]
|
|
66
|
-
}] }, { type: i2.
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
}] }, { type: i2.ElderMasterDetailService }]; } });
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9tYXN0ZXItZGV0YWlsL2VsZGVyLWRldGFpbC1kaWFsb2cvZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9tYXN0ZXItZGV0YWlsL2VsZGVyLWRldGFpbC1kaWFsb2cvZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBYSxRQUFRLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFDM0csT0FBTyxFQUFDLGVBQWUsRUFBZSxNQUFNLDBCQUEwQixDQUFDO0FBQ3ZFLE9BQU8sRUFBQyxlQUFlLEVBQUUsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBRTlDLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7Ozs7O0FBY3pDLE1BQU0sT0FBTywwQkFBMEI7SUFXckM7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ3FCLFNBQW1ELEVBQzFCLElBQStCLEVBQ25FLG1CQUFnRDtRQUZyQyxjQUFTLEdBQVQsU0FBUyxDQUEwQztRQUMxQixTQUFJLEdBQUosSUFBSSxDQUEyQjtRQUNuRSx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQTZCO1FBbEIxRDs7OztvRkFJNEU7UUFFM0QsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsWUFBTyxHQUFHLElBQUksZUFBZSxDQUFJLElBQUksQ0FBQyxDQUFDO1FBYXJELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxnQkFBZ0I7YUFDeEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDOUIsU0FBUyxDQUFDLEVBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxFQUFFO2dCQUN6QixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUE7WUFDaEMsQ0FBQyxFQUFDLENBQUMsQ0FBQTtJQUNMLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsV0FBVztRQUNoQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVyRSxLQUFLO1FBQ1YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ2hELENBQUM7O3VIQWhEVSwwQkFBMEIsOERBbUJmLGVBQWU7MkdBbkIxQiwwQkFBMEIsMkRDbEJ2QywrZEFnQkE7MkZERWEsMEJBQTBCO2tCQU50QyxTQUFTOytCQUNFLHFCQUFxQixtQkFHZCx1QkFBdUIsQ0FBQyxNQUFNOzswQkFvQjVDLFFBQVE7OzBCQUNSLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5qZWN0LCBPbkRlc3Ryb3ksIE9wdGlvbmFsLCBUZW1wbGF0ZVJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIFN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtFbGRlck1hc3RlckRldGFpbFNlcnZpY2V9IGZyb20gJy4uL2VsZGVyLW1hc3Rlci1kZXRhaWwuc2VydmljZSc7XG5pbXBvcnQge3Rha2VVbnRpbH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElFbGRlckRldGFpbERpYWxvZ09wdGlvbnM8VCA9IGFueT4ge1xuICBlbnRpdHk6IFQsXG4gIGRldGFpbFRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+XG59XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZWxkZXItZGV0YWlsLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9lbGRlci1kZXRhaWwtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckRldGFpbERpYWxvZ0NvbXBvbmVudDxUID0gYW55PiBpbXBsZW1lbnRzIE9uRGVzdHJveXtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGRlc3Ryb3kkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcbiAgcHVibGljIHJlYWRvbmx5IGVudGl0eSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFQ+KG51bGwpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBPcHRpb25hbCgpIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxFbGRlckRldGFpbERpYWxvZ0NvbXBvbmVudD4sXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBJRWxkZXJEZXRhaWxEaWFsb2dPcHRpb25zLFxuICAgIHByaXZhdGUgbWFzdGVyRGV0YWlsU2VydmljZTogRWxkZXJNYXN0ZXJEZXRhaWxTZXJ2aWNlPFQ+XG4gICkge1xuICAgIHRoaXMubWFzdGVyRGV0YWlsU2VydmljZS5hY3RpdmF0aW9uRXZlbnQkXG4gICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKVxuICAgIC5zdWJzY3JpYmUoe25leHQ6IGFjdGl2ZSA9PiB7XG4gICAgICB0aGlzLmVudGl0eSQubmV4dChhY3RpdmUuaXRlbSlcbiAgICB9fSlcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBMaWZlIEN5Y2xlICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmRlc3Ryb3kkLm5leHQoKTtcbiAgICB0aGlzLmRlc3Ryb3kkLmNvbXBsZXRlKCk7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHVibGljIEFQSSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgY2xvc2UoKSB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UodGhpcy5lbnRpdHkkLmdldFZhbHVlKCkpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwibGF5b3V0LWNvbCBmdWxsXCI+XG5cbiAgPHNwYW4gc3R5bGU9XCJ3aWR0aDogMTAwdnc7XCI+PC9zcGFuPlxuXG4gIDwhLS0gSGVhZGVyIFNlY3Rpb24gLS0+XG4gIDxlbGRlci10b29sYmFyIGNsYXNzPVwiZ2FwLW1kXCIgKm5nSWY9XCJlbnRpdHkkIHwgYXN5bmMgYXMgZW50aXR5XCI+XG4gICAgPGJ1dHRvbiAoY2xpY2spPVwiY2xvc2UoKVwiIG1hdC1pY29uLWJ1dHRvbiAqZWxkZXJUb29sYmFyQ29sdW1uPVwiJ2xlZnQuYmVnaW4nXCI+XG4gICAgICA8bWF0LWljb24+Y2xvc2U8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuICA8L2VsZGVyLXRvb2xiYXI+XG5cbiAgPGRpdiBjbGFzcz1cImxheW91dC1yb3cgZmxleCBnYXAtbWRcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiZGF0YS5kZXRhaWxUZW1wbGF0ZVJlZlwiPjwvbmctY29udGFpbmVyPlxuICA8L2Rpdj5cblxuPC9kaXY+XG4iXX0=
|
|
@@ -2,7 +2,7 @@ import { Directive } from '@angular/core';
|
|
|
2
2
|
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "./master-detail.service";
|
|
5
|
+
import * as i1 from "./elder-master-detail.service";
|
|
6
6
|
export class ElderDetailDirective {
|
|
7
7
|
/***************************************************************************
|
|
8
8
|
* *
|
|
@@ -20,17 +20,19 @@ export class ElderDetailDirective {
|
|
|
20
20
|
**************************************************************************/
|
|
21
21
|
this.log = LoggerFactory.getLogger(this.constructor.name);
|
|
22
22
|
this.activeDetailItem$ = new BehaviorSubject(null);
|
|
23
|
-
this.masterDetailService?.
|
|
23
|
+
this.masterDetailService?.activationEvent$.subscribe({
|
|
24
24
|
next: active => {
|
|
25
|
-
|
|
25
|
+
if (active?.item) {
|
|
26
|
+
this.activeDetailItem$.next(active.item);
|
|
27
|
+
}
|
|
26
28
|
}
|
|
27
29
|
});
|
|
28
30
|
}
|
|
29
31
|
}
|
|
30
|
-
ElderDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderDetailDirective, deps: [{ token: i1.
|
|
32
|
+
ElderDetailDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderDetailDirective, deps: [{ token: i1.ElderMasterDetailService }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
31
33
|
ElderDetailDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: ElderDetailDirective, selector: "[elderDataDetail]", ngImport: i0 });
|
|
32
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderDetailDirective, decorators: [{
|
|
33
35
|
type: Directive,
|
|
34
36
|
args: [{ selector: '[elderDataDetail]' }]
|
|
35
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
}], ctorParameters: function () { return [{ type: i1.ElderMasterDetailService }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZGV0YWlsLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS12aWV3L21hc3Rlci1kZXRhaWwvZWxkZXItZGV0YWlsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFnQyxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBQ3JDLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBR25ELE1BQU0sT0FBTyxvQkFBb0I7SUFZL0I7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ1UsbUJBQWdELEVBQ2pELFdBQTZCLEVBQzdCLGFBQStCO1FBRjlCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBNkI7UUFDakQsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBQzdCLGtCQUFhLEdBQWIsYUFBYSxDQUFrQjtRQW5CeEM7Ozs7b0ZBSTRFO1FBRTNELFFBQUcsR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUE7UUFFcEQsc0JBQWlCLEdBQUcsSUFBSSxlQUFlLENBQUksSUFBSSxDQUFDLENBQUM7UUFhaEUsSUFBSSxDQUFDLG1CQUFtQixFQUFFLGdCQUFnQixDQUFDLFNBQVMsQ0FDbEQ7WUFDRSxJQUFJLEVBQUUsTUFBTSxDQUFDLEVBQUU7Z0JBQ2IsSUFBSSxNQUFNLEVBQUUsSUFBSSxFQUFFO29CQUNoQixJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQTtpQkFDekM7WUFDSCxDQUFDO1NBQ0YsQ0FDRixDQUFDO0lBQ0osQ0FBQzs7aUhBaENVLG9CQUFvQjtxR0FBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBRGhDLFNBQVM7bUJBQUMsRUFBQyxRQUFRLEVBQUUsbUJBQW1CLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgVGVtcGxhdGVSZWYsIFZpZXdDb250YWluZXJSZWZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtFbGRlck1hc3RlckRldGFpbFNlcnZpY2V9IGZyb20gJy4vZWxkZXItbWFzdGVyLWRldGFpbC5zZXJ2aWNlJztcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7TG9nZ2VyRmFjdG9yeX0gZnJvbSAnQGVsZGVyYnl0ZS90cy1sb2dnZXInO1xuXG5ARGlyZWN0aXZlKHtzZWxlY3RvcjogJ1tlbGRlckRhdGFEZXRhaWxdJ30pXG5leHBvcnQgY2xhc3MgRWxkZXJEZXRhaWxEaXJlY3RpdmU8VD4ge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbG9nID0gTG9nZ2VyRmFjdG9yeS5nZXRMb2dnZXIodGhpcy5jb25zdHJ1Y3Rvci5uYW1lKVxuXG4gIHByaXZhdGUgcmVhZG9ubHkgYWN0aXZlRGV0YWlsSXRlbSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFQ+KG51bGwpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgbWFzdGVyRGV0YWlsU2VydmljZTogRWxkZXJNYXN0ZXJEZXRhaWxTZXJ2aWNlPFQ+LFxuICAgIHB1YmxpYyB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICBwdWJsaWMgdmlld0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZlxuICApIHtcbiAgICB0aGlzLm1hc3RlckRldGFpbFNlcnZpY2U/LmFjdGl2YXRpb25FdmVudCQuc3Vic2NyaWJlKFxuICAgICAge1xuICAgICAgICBuZXh0OiBhY3RpdmUgPT4ge1xuICAgICAgICAgIGlmIChhY3RpdmU/Lml0ZW0pIHtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlRGV0YWlsSXRlbSQubmV4dChhY3RpdmUuaXRlbSlcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICApO1xuICB9XG59XG4iXX0=
|
package/esm2020/lib/components/data-view/master-detail/elder-master-activation.directive.mjs
CHANGED
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import { Directive } from '@angular/core';
|
|
2
2
|
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
3
3
|
import { ElderMasterDetailMode } from './elder-master-detail-mode';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { takeUntil } from 'rxjs/operators';
|
|
6
|
+
import { ItemActivationOptions } from '../table/activation/item-activation-options';
|
|
7
|
+
import { ActivationEventSource } from '../table/activation/activation-event-source';
|
|
4
8
|
import * as i0 from "@angular/core";
|
|
5
9
|
import * as i1 from "../../toasts/elder-toast.service";
|
|
6
10
|
import * as i2 from "../table/activation/elder-table-activation.directive";
|
|
7
|
-
import * as i3 from "./master-detail.service";
|
|
11
|
+
import * as i3 from "./elder-master-detail.service";
|
|
8
12
|
export class ElderMasterActivationDirective {
|
|
9
13
|
/***************************************************************************
|
|
10
14
|
* *
|
|
@@ -20,6 +24,7 @@ export class ElderMasterActivationDirective {
|
|
|
20
24
|
* Fields *
|
|
21
25
|
* *
|
|
22
26
|
**************************************************************************/
|
|
27
|
+
this.destroy$ = new Subject();
|
|
23
28
|
this.log = LoggerFactory.getLogger(this.constructor.name);
|
|
24
29
|
}
|
|
25
30
|
/***************************************************************************
|
|
@@ -27,21 +32,31 @@ export class ElderMasterActivationDirective {
|
|
|
27
32
|
* Life Cycle *
|
|
28
33
|
* *
|
|
29
34
|
**************************************************************************/
|
|
35
|
+
ngOnDestroy() {
|
|
36
|
+
this.destroy$.next();
|
|
37
|
+
this.destroy$.complete();
|
|
38
|
+
}
|
|
30
39
|
ngOnInit() {
|
|
31
|
-
this.tableActivation.
|
|
32
|
-
next:
|
|
33
|
-
this.log.
|
|
34
|
-
this.masterDetailService.onItemActivated(
|
|
40
|
+
this.tableActivation.activeItemEventChange.pipe(takeUntil(this.destroy$)).subscribe({
|
|
41
|
+
next: event => {
|
|
42
|
+
this.log.debug('Table-Activation changed, notifying master-detail', event);
|
|
43
|
+
this.masterDetailService.onItemActivated(event);
|
|
35
44
|
},
|
|
36
45
|
error: err => this.toastService.error("Failed to set active item", err)
|
|
37
46
|
});
|
|
38
|
-
this.masterDetailService.itemActivationRequested.subscribe({
|
|
47
|
+
this.masterDetailService.itemActivationRequested.pipe(takeUntil(this.destroy$)).subscribe({
|
|
39
48
|
next: item => {
|
|
40
|
-
this.tableActivation.activate(item)
|
|
49
|
+
this.tableActivation.activate(item, new ItemActivationOptions(ActivationEventSource.SYSTEM, true) // TODO keyboard, arrow?
|
|
50
|
+
); // Maybe support activationRequest.source and map
|
|
41
51
|
}
|
|
42
52
|
});
|
|
43
|
-
this.masterDetailService.mode$.subscribe({ next: mode => this.onModeChange(mode) });
|
|
53
|
+
this.masterDetailService.mode$.pipe(takeUntil(this.destroy$)).subscribe({ next: mode => this.onModeChange(mode) });
|
|
44
54
|
}
|
|
55
|
+
/***************************************************************************
|
|
56
|
+
* *
|
|
57
|
+
* Private Methods *
|
|
58
|
+
* *
|
|
59
|
+
**************************************************************************/
|
|
45
60
|
onModeChange(mode) {
|
|
46
61
|
if (mode == ElderMasterDetailMode.EMBEDDED) {
|
|
47
62
|
this.tableActivation.activationOptions = { mode: 'once', row: 'first' };
|
|
@@ -51,12 +66,12 @@ export class ElderMasterActivationDirective {
|
|
|
51
66
|
}
|
|
52
67
|
}
|
|
53
68
|
}
|
|
54
|
-
ElderMasterActivationDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterActivationDirective, deps: [{ token: i1.ElderToastService }, { token: i2.ElderTableActivationDirective }, { token: i3.
|
|
69
|
+
ElderMasterActivationDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterActivationDirective, deps: [{ token: i1.ElderToastService }, { token: i2.ElderTableActivationDirective }, { token: i3.ElderMasterDetailService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
55
70
|
ElderMasterActivationDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.7", type: ElderMasterActivationDirective, selector: "[elderMasterActivation]", ngImport: i0 });
|
|
56
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterActivationDirective, decorators: [{
|
|
57
72
|
type: Directive,
|
|
58
73
|
args: [{
|
|
59
74
|
selector: '[elderMasterActivation]',
|
|
60
75
|
}]
|
|
61
|
-
}], ctorParameters: function () { return [{ type: i1.ElderToastService }, { type: i2.ElderTableActivationDirective }, { type: i3.
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.ElderToastService }, { type: i2.ElderTableActivationDirective }, { type: i3.ElderMasterDetailService }]; } });
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-master-activation.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/master-detail/elder-master-activation.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAoB,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAC,qBAAqB,EAAC,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,qBAAqB,EAAC,MAAM,6CAA6C,CAAC;AAClF,OAAO,EAAC,qBAAqB,EAAC,MAAM,6CAA6C,CAAC;;;;;AAKlF,MAAM,OAAO,8BAA8B;IAWzC;;;;gFAI4E;IAE5E,YACU,YAA+B,EAC/B,eAAiD,EACjD,mBAAgD;QAFhD,iBAAY,GAAZ,YAAY,CAAmB;QAC/B,oBAAe,GAAf,eAAe,CAAkC;QACjD,wBAAmB,GAAnB,mBAAmB,CAA6B;QAlB1D;;;;oFAI4E;QAE3D,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC/B,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAatE,CAAC;IAED;;;;gFAI4E;IAErE,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CACjF;YACE,IAAI,EAAE,KAAK,CAAC,EAAE;gBACZ,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,mDAAmD,EAAE,KAAK,CAAC,CAAC;gBAC3E,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YAClD,CAAC;YACD,KAAK,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,2BAA2B,EAAE,GAAG,CAAC;SACxE,CACF,CAAC;QAEF,IAAI,CAAC,mBAAmB,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;YACxF,IAAI,EAAE,IAAI,CAAC,EAAE;gBACX,IAAI,CAAC,eAAe,CAAC,QAAQ,CAC3B,IAAI,EACJ,IAAI,qBAAqB,CAAC,qBAAqB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,wBAAwB;iBACvF,CAAA,CAAC,iDAAiD;YACrD,CAAC;SACF,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,CAAC,CAAA;IACnH,CAAC;IAED;;;;gFAI4E;IAEpE,YAAY,CAAC,IAA2B;QAC9C,IAAI,IAAI,IAAI,qBAAqB,CAAC,QAAQ,EAAE;YAC1C,IAAI,CAAC,eAAe,CAAC,iBAAiB,GAAG,EAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAC,CAAA;SACtE;QAED,IAAI,IAAI,IAAI,qBAAqB,CAAC,MAAM,EAAE;YACxC,IAAI,CAAC,eAAe,CAAC,iBAAiB,GAAG,EAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAC,CAAA;SACrE;IACH,CAAC;;2HAvEU,8BAA8B;+GAA9B,8BAA8B;2FAA9B,8BAA8B;kBAH1C,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;iBACpC","sourcesContent":["import {Directive, OnDestroy, OnInit} from '@angular/core';\nimport {ElderMasterDetailService} from './elder-master-detail.service';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderToastService} from '../../toasts/elder-toast.service';\nimport {ElderTableActivationDirective} from '../table/activation/elder-table-activation.directive';\nimport {ElderMasterDetailMode} from './elder-master-detail-mode';\nimport {Subject} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\nimport {ItemActivationOptions} from '../table/activation/item-activation-options';\nimport {ActivationEventSource} from '../table/activation/activation-event-source';\n\n@Directive({\n  selector: '[elderMasterActivation]',\n})\nexport class ElderMasterActivationDirective<T> implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly destroy$ = new Subject<void>();\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private toastService: ElderToastService,\n    private tableActivation: ElderTableActivationDirective<T>,\n    private masterDetailService: ElderMasterDetailService<T>\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  public ngOnInit(): void {\n    this.tableActivation.activeItemEventChange.pipe(takeUntil(this.destroy$)).subscribe(\n      {\n        next: event => {\n          this.log.debug('Table-Activation changed, notifying master-detail', event);\n          this.masterDetailService.onItemActivated(event);\n        },\n        error: err => this.toastService.error(\"Failed to set active item\", err)\n      }\n    );\n\n    this.masterDetailService.itemActivationRequested.pipe(takeUntil(this.destroy$)).subscribe({\n      next: item => {\n        this.tableActivation.activate(\n          item,\n          new ItemActivationOptions(ActivationEventSource.SYSTEM, true) // TODO keyboard, arrow?\n        ) // Maybe support activationRequest.source and map\n      }\n    });\n    this.masterDetailService.mode$.pipe(takeUntil(this.destroy$)).subscribe({ next: mode => this.onModeChange(mode)})\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private onModeChange(mode: ElderMasterDetailMode) {\n    if (mode == ElderMasterDetailMode.EMBEDDED) {\n      this.tableActivation.activationOptions = {mode: 'once', row: 'first'}\n    }\n\n    if (mode == ElderMasterDetailMode.DIALOG) {\n      this.tableActivation.activationOptions = {mode: 'once', row: 'none'}\n    }\n  }\n}\n"]}
|
package/esm2020/lib/components/data-view/master-detail/elder-master-detail-activation-event.mjs
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export class ElderMasterDetailActivationEvent {
|
|
2
|
+
constructor(item, creating, source) {
|
|
3
|
+
this.item = item;
|
|
4
|
+
this.creating = creating;
|
|
5
|
+
this.source = source;
|
|
6
|
+
this.deactivate = false;
|
|
7
|
+
if (item == null) {
|
|
8
|
+
this.deactivate = true;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbWFzdGVyLWRldGFpbC1hY3RpdmF0aW9uLWV2ZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9kYXRhLXZpZXcvbWFzdGVyLWRldGFpbC9lbGRlci1tYXN0ZXItZGV0YWlsLWFjdGl2YXRpb24tZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLGdDQUFnQztJQUczQyxZQUNTLElBQU8sRUFDUCxRQUFpQixFQUNqQixNQUE2QjtRQUY3QixTQUFJLEdBQUosSUFBSSxDQUFHO1FBQ1AsYUFBUSxHQUFSLFFBQVEsQ0FBUztRQUNqQixXQUFNLEdBQU4sTUFBTSxDQUF1QjtRQUovQixlQUFVLEdBQVksS0FBSyxDQUFDO1FBTWpDLElBQUksSUFBSSxJQUFJLElBQUksRUFBRTtZQUNoQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztTQUN4QjtJQUNMLENBQUM7Q0FDQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QWN0aXZhdGlvbkV2ZW50U291cmNlfSBmcm9tICcuLi90YWJsZS9hY3RpdmF0aW9uL2FjdGl2YXRpb24tZXZlbnQtc291cmNlJztcblxuZXhwb3J0IGNsYXNzIEVsZGVyTWFzdGVyRGV0YWlsQWN0aXZhdGlvbkV2ZW50PFQ+IHtcblxuICBwdWJsaWMgZGVhY3RpdmF0ZTogYm9vbGVhbiA9IGZhbHNlO1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgaXRlbTogVCxcbiAgICBwdWJsaWMgY3JlYXRpbmc6IGJvb2xlYW4sXG4gICAgcHVibGljIHNvdXJjZTogQWN0aXZhdGlvbkV2ZW50U291cmNlXG4pIHtcbiAgICBpZiAoaXRlbSA9PSBudWxsKSB7XG4gICAgICB0aGlzLmRlYWN0aXZhdGUgPSB0cnVlO1xuICAgIH1cbn1cbn1cbiJdfQ==
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
import { Optional, SkipSelf } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { ElderMasterDetailService } from './elder-master-detail.service';
|
|
3
3
|
export function existingOrNewMasterDetailService(serviceProvider) {
|
|
4
4
|
return serviceProvider ?? newMasterDetailService();
|
|
5
5
|
}
|
|
6
6
|
export function newMasterDetailService() {
|
|
7
|
-
return new
|
|
7
|
+
return new ElderMasterDetailService();
|
|
8
8
|
}
|
|
9
9
|
export class ElderMasterDetailProvider {
|
|
10
10
|
}
|
|
11
11
|
/**
|
|
12
|
-
* Uses the existing
|
|
13
|
-
* Otherwise, creates a new
|
|
12
|
+
* Uses the existing ElderMasterDetailService from a parent if available.
|
|
13
|
+
* Otherwise, creates a new ElderMasterDetailService and provides it.
|
|
14
14
|
*/
|
|
15
15
|
ElderMasterDetailProvider.ExistingOrNewMasterDetailService = {
|
|
16
|
-
provide:
|
|
16
|
+
provide: ElderMasterDetailService,
|
|
17
17
|
useFactory: existingOrNewMasterDetailService,
|
|
18
|
-
deps: [[new Optional(), new SkipSelf(),
|
|
18
|
+
deps: [[new Optional(), new SkipSelf(), ElderMasterDetailService]]
|
|
19
19
|
};
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbWFzdGVyLWRldGFpbC1wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS12aWV3L21hc3Rlci1kZXRhaWwvZWxkZXItbWFzdGVyLWRldGFpbC1wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFZLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUMzRCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUd2RSxNQUFNLFVBQVUsZ0NBQWdDLENBQy9DLGVBQXFEO0lBRXBELE9BQU8sZUFBZSxJQUFJLHNCQUFzQixFQUFFLENBQUM7QUFDckQsQ0FBQztBQUVELE1BQU0sVUFBVSxzQkFBc0I7SUFDcEMsT0FBTyxJQUFJLHdCQUF3QixFQUFFLENBQUM7QUFDeEMsQ0FBQztBQUVELE1BQU0sT0FBTyx5QkFBeUI7O0FBQ3BDOzs7R0FHRztBQUNvQiwwREFBZ0MsR0FBYTtJQUNsRSxPQUFPLEVBQUUsd0JBQXdCO0lBQ2pDLFVBQVUsRUFBRSxnQ0FBZ0M7SUFDNUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLFFBQVEsRUFBRSxFQUFFLElBQUksUUFBUSxFQUFFLEVBQUUsd0JBQXdCLENBQUMsQ0FBQztDQUNuRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtPcHRpb25hbCwgUHJvdmlkZXIsIFNraXBTZWxmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RWxkZXJNYXN0ZXJEZXRhaWxTZXJ2aWNlfSBmcm9tICcuL2VsZGVyLW1hc3Rlci1kZXRhaWwuc2VydmljZSc7XG5cblxuZXhwb3J0IGZ1bmN0aW9uIGV4aXN0aW5nT3JOZXdNYXN0ZXJEZXRhaWxTZXJ2aWNlKFxuIHNlcnZpY2VQcm92aWRlcjogRWxkZXJNYXN0ZXJEZXRhaWxTZXJ2aWNlPGFueT4gfCBudWxsXG4pOiBFbGRlck1hc3RlckRldGFpbFNlcnZpY2U8YW55PiB7XG4gIHJldHVybiBzZXJ2aWNlUHJvdmlkZXIgPz8gbmV3TWFzdGVyRGV0YWlsU2VydmljZSgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbmV3TWFzdGVyRGV0YWlsU2VydmljZSgpOiBFbGRlck1hc3RlckRldGFpbFNlcnZpY2U8YW55PiB7XG4gIHJldHVybiBuZXcgRWxkZXJNYXN0ZXJEZXRhaWxTZXJ2aWNlKCk7XG59XG5cbmV4cG9ydCBjbGFzcyBFbGRlck1hc3RlckRldGFpbFByb3ZpZGVyPFQ+IHtcbiAgLyoqXG4gICAqIFVzZXMgdGhlIGV4aXN0aW5nIEVsZGVyTWFzdGVyRGV0YWlsU2VydmljZSBmcm9tIGEgcGFyZW50IGlmIGF2YWlsYWJsZS5cbiAgICogT3RoZXJ3aXNlLCBjcmVhdGVzIGEgbmV3IEVsZGVyTWFzdGVyRGV0YWlsU2VydmljZSBhbmQgcHJvdmlkZXMgaXQuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IEV4aXN0aW5nT3JOZXdNYXN0ZXJEZXRhaWxTZXJ2aWNlID0gPFByb3ZpZGVyPntcbiAgICBwcm92aWRlOiBFbGRlck1hc3RlckRldGFpbFNlcnZpY2UsXG4gICAgdXNlRmFjdG9yeTogZXhpc3RpbmdPck5ld01hc3RlckRldGFpbFNlcnZpY2UsXG4gICAgZGVwczogW1tuZXcgT3B0aW9uYWwoKSwgbmV3IFNraXBTZWxmKCksIEVsZGVyTWFzdGVyRGV0YWlsU2VydmljZV1dXG4gIH07XG59XG4iXX0=
|
|
@@ -8,7 +8,7 @@ import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
|
8
8
|
import { ElderMasterDetailMode } from './elder-master-detail-mode';
|
|
9
9
|
import { ElderMasterDetailProvider } from './elder-master-detail-provider';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "./master-detail.service";
|
|
11
|
+
import * as i1 from "./elder-master-detail.service";
|
|
12
12
|
import * as i2 from "@angular/material/dialog";
|
|
13
13
|
import * as i3 from "@angular/common";
|
|
14
14
|
export class ElderMasterDetailComponent {
|
|
@@ -32,15 +32,15 @@ export class ElderMasterDetailComponent {
|
|
|
32
32
|
this.ElderMasterDetailMode = ElderMasterDetailMode;
|
|
33
33
|
this.mode$
|
|
34
34
|
.pipe(takeUntil(this.destroy$))
|
|
35
|
-
.subscribe({ next: mode => this.masterDetailService.mode$.next(mode) });
|
|
36
|
-
this.masterDetailService.
|
|
35
|
+
.subscribe({ next: mode => { this.masterDetailService.mode$.next(mode); } });
|
|
36
|
+
this.masterDetailService.activationEvent$
|
|
37
37
|
.pipe(takeUntil(this.destroy$))
|
|
38
38
|
.subscribe({
|
|
39
39
|
next: active => {
|
|
40
40
|
if (this.mode$.getValue() == ElderMasterDetailMode.DIALOG) {
|
|
41
|
-
if (active
|
|
41
|
+
if (active.item) {
|
|
42
42
|
this.closeDialog();
|
|
43
|
-
this.openDetailDialog(active);
|
|
43
|
+
this.openDetailDialog(active?.item);
|
|
44
44
|
}
|
|
45
45
|
else {
|
|
46
46
|
this.closeDialog();
|
|
@@ -98,7 +98,7 @@ export class ElderMasterDetailComponent {
|
|
|
98
98
|
}
|
|
99
99
|
}
|
|
100
100
|
}
|
|
101
|
-
ElderMasterDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailComponent, deps: [{ token: i1.
|
|
101
|
+
ElderMasterDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailComponent, deps: [{ token: i1.ElderMasterDetailService }, { token: i2.MatDialog }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
102
102
|
ElderMasterDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMasterDetailComponent, selector: "elder-master-detail", inputs: { mode: "mode" }, providers: [
|
|
103
103
|
ElderMasterDetailProvider.ExistingOrNewMasterDetailService
|
|
104
104
|
], queries: [{ propertyName: "master", first: true, predicate: ElderMasterDirective, descendants: true, read: TemplateRef }, { propertyName: "detail", first: true, predicate: ElderDetailDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "\n<div class=\"layout-row full\" *ngIf=\"mode$ | async as mode\">\n\n <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n </div>\n\n <div class=\"layout-row full gap-md\" *ngIf=\"mode == ElderMasterDetailMode.EMBEDDED\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container >\n <ng-container *ngTemplateOutlet=\"detail\"></ng-container>\n </div>\n\n\n</div>\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
@@ -107,7 +107,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
107
107
|
args: [{ selector: 'elder-master-detail', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
108
108
|
ElderMasterDetailProvider.ExistingOrNewMasterDetailService
|
|
109
109
|
], template: "\n<div class=\"layout-row full\" *ngIf=\"mode$ | async as mode\">\n\n <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n </div>\n\n <div class=\"layout-row full gap-md\" *ngIf=\"mode == ElderMasterDetailMode.EMBEDDED\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container >\n <ng-container *ngTemplateOutlet=\"detail\"></ng-container>\n </div>\n\n\n</div>\n\n\n" }]
|
|
110
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
110
|
+
}], ctorParameters: function () { return [{ type: i1.ElderMasterDetailService }, { type: i2.MatDialog }, { type: i0.ViewContainerRef }]; }, propDecorators: { master: [{
|
|
111
111
|
type: ContentChild,
|
|
112
112
|
args: [ElderMasterDirective, { read: TemplateRef, static: false }]
|
|
113
113
|
}], detail: [{
|
|
@@ -116,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
116
116
|
}], mode: [{
|
|
117
117
|
type: Input
|
|
118
118
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-master-detail.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/master-detail/elder-master-detail.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/master-detail/elder-master-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild, forwardRef,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\nimport {ElderMasterDirective} from './elder-master.directive';\nimport {ElderDetailDirective} from './elder-detail.directive';\nimport {MasterDetailService} from './master-detail.service';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ElderDetailDialogComponent,\n  IElderDetailDialogOptions\n} from './elder-detail-dialog/elder-detail-dialog.component';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderMasterDetailMode} from './elder-master-detail-mode';\nimport {ElderMasterDetailProvider} from './elder-master-detail-provider';\n\n@Component({\n  selector: 'elder-master-detail',\n  templateUrl: './elder-master-detail.component.html',\n  styleUrls: ['./elder-master-detail.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    ElderMasterDetailProvider.ExistingOrNewMasterDetailService\n  ]\n})\nexport class ElderMasterDetailComponent<T> implements 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  @ContentChild(ElderMasterDirective, {read: TemplateRef, static: false})\n  public master: TemplateRef<any>;\n\n  @ContentChild(ElderDetailDirective, {read: TemplateRef, static: false})\n  public detail: TemplateRef<any>;\n\n  public readonly mode$ = new BehaviorSubject<ElderMasterDetailMode>(null);\n\n  public ElderMasterDetailMode = ElderMasterDetailMode;\n\n  public dialogRef: MatDialogRef<ElderDetailDialogComponent>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private masterDetailService: MasterDetailService<T>,\n    public dialog: MatDialog,\n    private viewContainerRef: ViewContainerRef\n  ) {\n\n    this.mode$\n    .pipe(takeUntil(this.destroy$))\n    .subscribe({ next: mode => this.masterDetailService.mode$.next(mode) })\n\n    this.masterDetailService.activeOrCreatingItem$\n    .pipe(takeUntil(this.destroy$))\n    .subscribe({\n      next: active => {\n        if (this.mode$.getValue() == ElderMasterDetailMode.DIALOG) {\n          if (active != null) {\n            this.closeDialog();\n            this.openDetailDialog(active);\n          } else {\n            this.closeDialog();\n          }\n        }\n      }\n    })\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n  @Input()\n  public set mode(mode: ElderMasterDetailMode) {\n    this.mode$.next(mode);\n\n    if (this.mode == ElderMasterDetailMode.EMBEDDED && this.dialogRef) {\n      this.dialogRef.close();\n    }\n  }\n\n  public get mode() {\n    return this.mode$.getValue();\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openDetailDialog(entity: T): void {\n    this.dialogRef = this.dialog.open(ElderDetailDialogComponent, {\n      viewContainerRef: this.viewContainerRef,\n      data: <IElderDetailDialogOptions> {\n        entity: entity,\n        detailTemplateRef: this.detail\n      },\n      width: '80vw',\n      height: '80vh',\n      panelClass: 'custom-dialog-container'\n    });\n\n    this.dialogRef.afterClosed().subscribe(result => {\n      console.log('The dialog was closed');\n    });\n  }\n\n  private closeDialog() {\n    if (this.dialogRef != null) {\n      this.dialogRef.close();\n    }\n  }\n}\n\n\n\n","\n<div class=\"layout-row full\" *ngIf=\"mode$ | async as mode\">\n\n  <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n    <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n  </div>\n\n  <div class=\"layout-row full gap-md\" *ngIf=\"mode == ElderMasterDetailMode.EMBEDDED\">\n    <ng-container *ngTemplateOutlet=\"master\"></ng-container >\n    <ng-container *ngTemplateOutlet=\"detail\"></ng-container>\n  </div>\n\n\n</div>\n\n\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-master-detail.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/master-detail/elder-master-detail.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/master-detail/elder-master-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\nimport {ElderMasterDirective} from './elder-master.directive';\nimport {ElderDetailDirective} from './elder-detail.directive';\nimport {ElderMasterDetailService} from './elder-master-detail.service';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ElderDetailDialogComponent,\n  IElderDetailDialogOptions\n} from './elder-detail-dialog/elder-detail-dialog.component';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderMasterDetailMode} from './elder-master-detail-mode';\nimport {ElderMasterDetailProvider} from './elder-master-detail-provider';\n\n@Component({\n  selector: 'elder-master-detail',\n  templateUrl: './elder-master-detail.component.html',\n  styleUrls: ['./elder-master-detail.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    ElderMasterDetailProvider.ExistingOrNewMasterDetailService\n  ]\n})\nexport class ElderMasterDetailComponent<T> implements 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  @ContentChild(ElderMasterDirective, {read: TemplateRef, static: false})\n  public master: TemplateRef<any>;\n\n  @ContentChild(ElderDetailDirective, {read: TemplateRef, static: false})\n  public detail: TemplateRef<any>;\n\n  public readonly mode$ = new BehaviorSubject<ElderMasterDetailMode>(null);\n\n  public ElderMasterDetailMode = ElderMasterDetailMode;\n\n  public dialogRef: MatDialogRef<ElderDetailDialogComponent>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private masterDetailService: ElderMasterDetailService<T>,\n    public dialog: MatDialog,\n    private viewContainerRef: ViewContainerRef\n  ) {\n\n    this.mode$\n    .pipe(takeUntil(this.destroy$))\n    .subscribe({ next: mode => { this.masterDetailService.mode$.next(mode)}})\n\n    this.masterDetailService.activationEvent$\n    .pipe(takeUntil(this.destroy$))\n    .subscribe({\n        next: active => {\n          if (this.mode$.getValue() == ElderMasterDetailMode.DIALOG) {\n            if (active.item) {\n              this.closeDialog();\n              this.openDetailDialog(active?.item);\n            } else {\n              this.closeDialog();\n            }\n          }\n        }\n      }\n    )\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n  @Input()\n  public set mode(mode: ElderMasterDetailMode) {\n    this.mode$.next(mode);\n\n    if (this.mode == ElderMasterDetailMode.EMBEDDED && this.dialogRef) {\n      this.dialogRef.close();\n    }\n  }\n\n  public get mode() {\n    return this.mode$.getValue();\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openDetailDialog(entity: T): void {\n    this.dialogRef = this.dialog.open(ElderDetailDialogComponent, {\n      viewContainerRef: this.viewContainerRef,\n      data: <IElderDetailDialogOptions>{\n        entity: entity,\n        detailTemplateRef: this.detail\n      },\n      width: '80vw',\n      height: '80vh',\n      panelClass: 'custom-dialog-container'\n    });\n\n    this.dialogRef.afterClosed().subscribe(result => {\n      console.log('The dialog was closed');\n    });\n  }\n\n  private closeDialog() {\n    if (this.dialogRef != null) {\n      this.dialogRef.close();\n    }\n  }\n}\n\n\n\n","\n<div class=\"layout-row full\" *ngIf=\"mode$ | async as mode\">\n\n  <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n    <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n  </div>\n\n  <div class=\"layout-row full gap-md\" *ngIf=\"mode == ElderMasterDetailMode.EMBEDDED\">\n    <ng-container *ngTemplateOutlet=\"master\"></ng-container >\n    <ng-container *ngTemplateOutlet=\"detail\"></ng-container>\n  </div>\n\n\n</div>\n\n\n"]}
|
|
@@ -26,7 +26,8 @@ export * from './elder-master.directive';
|
|
|
26
26
|
export * from './elder-detail.directive';
|
|
27
27
|
export * from './elder-master-activation.directive';
|
|
28
28
|
export * from './elder-master-detail-mode';
|
|
29
|
-
export * from './master-detail.service';
|
|
29
|
+
export * from './elder-master-detail.service';
|
|
30
|
+
export * from './elder-master-detail-activation-event';
|
|
30
31
|
export * from './elder-detail-dialog/elder-detail-dialog.component';
|
|
31
32
|
export * from './elder-master-detail.component';
|
|
32
33
|
export class ElderMasterDetailModule {
|
|
@@ -112,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
112
113
|
]
|
|
113
114
|
}]
|
|
114
115
|
}] });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbWFzdGVyLWRldGFpbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9tYXN0ZXItZGV0YWlsL2VsZGVyLW1hc3Rlci1kZXRhaWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyw4QkFBOEIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ25GLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ3pELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUMvRixPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUM3RCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUN6RSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDekUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDbkUsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFDaEcsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sK0NBQStDLENBQUM7O0FBR2pGLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxpQ0FBaUMsQ0FBQztBQXFDaEQsTUFBTSxPQUFPLHVCQUF1Qjs7b0hBQXZCLHVCQUF1QjtxSEFBdkIsdUJBQXVCLGlCQWpDaEMsMEJBQTBCO1FBQzFCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsOEJBQThCO1FBQzlCLDBCQUEwQixhQUcxQixZQUFZO1FBQ1osYUFBYTtRQUNiLGNBQWM7UUFDZCxnQkFBZ0I7UUFDaEIsbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixXQUFXO1FBQ1gsY0FBYztRQUNkLGVBQWU7UUFDZixlQUFlO1FBQ2YsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixpQkFBaUI7UUFDakIsMEJBQTBCO1FBQzFCLGtCQUFrQjtRQUNsQixnQkFBZ0I7UUFDaEIsb0JBQW9CLGFBR3BCLDBCQUEwQjtRQUMxQixvQkFBb0I7UUFDcEIsb0JBQW9CO1FBQ3BCLDhCQUE4QjtRQUM5QiwwQkFBMEI7cUhBR2pCLHVCQUF1QixZQTFCaEMsWUFBWTtRQUNaLGFBQWE7UUFDYixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsV0FBVztRQUNYLGNBQWM7UUFDZCxlQUFlO1FBQ2YsZUFBZTtRQUNmLGNBQWM7UUFDZCxnQkFBZ0I7UUFDaEIsaUJBQWlCO1FBQ2pCLDBCQUEwQjtRQUMxQixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLG9CQUFvQjsyRkFVWCx1QkFBdUI7a0JBbkNuQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWiwwQkFBMEI7d0JBQzFCLG9CQUFvQjt3QkFDcEIsb0JBQW9CO3dCQUNwQiw4QkFBOEI7d0JBQzlCLDBCQUEwQjtxQkFDM0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsbUJBQW1CO3dCQUNuQixhQUFhO3dCQUNiLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxlQUFlO3dCQUNmLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLGlCQUFpQjt3QkFDakIsMEJBQTBCO3dCQUMxQixrQkFBa0I7d0JBQ2xCLGdCQUFnQjt3QkFDaEIsb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMEJBQTBCO3dCQUMxQixvQkFBb0I7d0JBQ3BCLG9CQUFvQjt3QkFDcEIsOEJBQThCO3dCQUM5QiwwQkFBMEI7cUJBQzNCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7RWxkZXJEZXRhaWxEaXJlY3RpdmV9IGZyb20gJy4vZWxkZXItZGV0YWlsLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0VsZGVyTWFzdGVyRGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLW1hc3Rlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlck1hc3RlckRldGFpbENvbXBvbmVudH0gZnJvbSAnLi9lbGRlci1tYXN0ZXItZGV0YWlsLmNvbXBvbmVudCc7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtNYXRUYWJsZU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xuaW1wb3J0IHtNYXRTb3J0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zb3J0JztcbmltcG9ydCB7RWxkZXJNYXN0ZXJBY3RpdmF0aW9uRGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLW1hc3Rlci1hY3RpdmF0aW9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge01hdElucHV0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7TWF0QmFkZ2VNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2JhZGdlJztcbmltcG9ydCB7TWF0VG9vbHRpcE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5pbXBvcnQge0VsZGVyRGV0YWlsRGlhbG9nQ29tcG9uZW50fSBmcm9tICcuL2VsZGVyLWRldGFpbC1kaWFsb2cvZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRUb29sYmFyTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sYmFyJztcbmltcG9ydCB7TWF0U2xpZGVUb2dnbGVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NsaWRlLXRvZ2dsZSc7XG5pbXBvcnQge0VsZGVyVGFibGVNb2R1bGV9IGZyb20gJy4uL3RhYmxlL2VsZGVyLXRhYmxlLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyTWVhc3VyZXNNb2R1bGV9IGZyb20gJy4uLy4uL21lYXN1cmVzL2VsZGVyLW1lYXN1cmVzLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyQ2FyZE1vZHVsZX0gZnJvbSAnLi4vLi4vY2FyZHMvZWxkZXItY2FyZC9lbGRlci1jYXJkLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyU2VsZWN0TW9kdWxlfSBmcm9tICcuLi8uLi9zZWxlY3QvZWxkZXItc2VsZWN0Lm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyRm9ybXNEaXJlY3RpdmVzTW9kdWxlfSBmcm9tICcuLi8uLi9mb3Jtcy9kaXJlY3RpdmVzL2VsZGVyLWZvcm1zLWRpcmVjdGl2ZXMubW9kdWxlJztcbmltcG9ydCB7RWxkZXJUb29sYmFyTW9kdWxlfSBmcm9tICcuLi8uLi9uYXZpZ2F0aW9uL3Rvb2xiYXIvZWxkZXItdG9vbGJhci5tb2R1bGUnO1xuXG5cbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbWFzdGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2VsZGVyLWRldGFpbC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1tYXN0ZXItYWN0aXZhdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1tYXN0ZXItZGV0YWlsLW1vZGUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1tYXN0ZXItZGV0YWlsLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1tYXN0ZXItZGV0YWlsLWFjdGl2YXRpb24tZXZlbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1kZXRhaWwtZGlhbG9nL2VsZGVyLWRldGFpbC1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbWFzdGVyLWRldGFpbC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFbGRlck1hc3RlckRldGFpbENvbXBvbmVudCxcbiAgICBFbGRlckRldGFpbERpcmVjdGl2ZSxcbiAgICBFbGRlck1hc3RlckRpcmVjdGl2ZSxcbiAgICBFbGRlck1hc3RlckFjdGl2YXRpb25EaXJlY3RpdmUsXG4gICAgRWxkZXJEZXRhaWxEaWFsb2dDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdFRhYmxlTW9kdWxlLFxuICAgIEVsZGVyVGFibGVNb2R1bGUsXG4gICAgRWxkZXJNZWFzdXJlc01vZHVsZSxcbiAgICBNYXRTb3J0TW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIEVsZGVyQ2FyZE1vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0QmFkZ2VNb2R1bGUsXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcbiAgICBFbGRlclNlbGVjdE1vZHVsZSxcbiAgICBFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZSxcbiAgICBFbGRlclRvb2xiYXJNb2R1bGUsXG4gICAgTWF0VG9vbGJhck1vZHVsZSxcbiAgICBNYXRTbGlkZVRvZ2dsZU1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWxkZXJNYXN0ZXJEZXRhaWxDb21wb25lbnQsXG4gICAgRWxkZXJEZXRhaWxEaXJlY3RpdmUsXG4gICAgRWxkZXJNYXN0ZXJEaXJlY3RpdmUsXG4gICAgRWxkZXJNYXN0ZXJBY3RpdmF0aW9uRGlyZWN0aXZlLFxuICAgIEVsZGVyRGV0YWlsRGlhbG9nQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJNYXN0ZXJEZXRhaWxNb2R1bGUge1xufVxuIl19
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, merge, Subject } from 'rxjs';
|
|
3
|
+
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
4
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { ActiveItemEvent } from '../table/activation/active-item-event';
|
|
6
|
+
import { ElderMasterDetailActivationEvent } from './elder-master-detail-activation-event';
|
|
7
|
+
import { ActivationEventSource } from '../table/activation/activation-event-source';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class ElderMasterDetailService {
|
|
10
|
+
/***************************************************************************
|
|
11
|
+
* *
|
|
12
|
+
* Constructor *
|
|
13
|
+
* *
|
|
14
|
+
**************************************************************************/
|
|
15
|
+
constructor() {
|
|
16
|
+
/***************************************************************************
|
|
17
|
+
* *
|
|
18
|
+
* Fields *
|
|
19
|
+
* *
|
|
20
|
+
**************************************************************************/
|
|
21
|
+
this.destroy$ = new Subject();
|
|
22
|
+
this.mode$ = new BehaviorSubject(null);
|
|
23
|
+
this.logger = LoggerFactory.getLogger(this.constructor.name);
|
|
24
|
+
this._itemActivationRequest$ = new Subject();
|
|
25
|
+
this._activeItem$ = new BehaviorSubject(null);
|
|
26
|
+
this._creatingItem$ = new BehaviorSubject(null);
|
|
27
|
+
this._activationEvent$ = new BehaviorSubject(null);
|
|
28
|
+
merge(this._creatingItem$, this._activeItem$)
|
|
29
|
+
.pipe(filter(event => event !== null), takeUntil(this.destroy$)).subscribe({
|
|
30
|
+
next: creatingOrActive => {
|
|
31
|
+
this._activationEvent$.next(new ElderMasterDetailActivationEvent(creatingOrActive?.item, creatingOrActive.creating, creatingOrActive.source));
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
/***************************************************************************
|
|
36
|
+
* *
|
|
37
|
+
* Life Cycle *
|
|
38
|
+
* *
|
|
39
|
+
**************************************************************************/
|
|
40
|
+
ngOnDestroy() {
|
|
41
|
+
this.destroy$.next();
|
|
42
|
+
this.destroy$.complete();
|
|
43
|
+
}
|
|
44
|
+
/***************************************************************************
|
|
45
|
+
* *
|
|
46
|
+
* Properties *
|
|
47
|
+
* *
|
|
48
|
+
**************************************************************************/
|
|
49
|
+
get activationEvent$() {
|
|
50
|
+
return this._activationEvent$.asObservable();
|
|
51
|
+
}
|
|
52
|
+
get itemActivationRequested() {
|
|
53
|
+
return this._itemActivationRequest$.asObservable();
|
|
54
|
+
}
|
|
55
|
+
/* public get activeItem$(): Observable<T> {
|
|
56
|
+
return this._activeItem$.pipe(map(active => active.item));
|
|
57
|
+
}*/
|
|
58
|
+
onItemActivated(event) {
|
|
59
|
+
this._activeItem$.next(event);
|
|
60
|
+
}
|
|
61
|
+
requestItemActivation(item) {
|
|
62
|
+
this._itemActivationRequest$.next(item);
|
|
63
|
+
}
|
|
64
|
+
activateCreatingItem(item) {
|
|
65
|
+
this._creatingItem$.next(new ActiveItemEvent(item, ActivationEventSource.USER_MOUSE_CLICK, false, true));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
ElderMasterDetailService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
69
|
+
ElderMasterDetailService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailService });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailService, decorators: [{
|
|
71
|
+
type: Injectable
|
|
72
|
+
}], ctorParameters: function () { return []; } });
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-master-detail.service.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/master-detail/elder-master-detail.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAY,MAAM,eAAe,CAAC;AACpD,OAAO,EAAC,eAAe,EAAE,KAAK,EAAc,OAAO,EAAC,MAAM,MAAM,CAAC;AACjE,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,MAAM,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEjD,OAAO,EAAC,eAAe,EAAC,MAAM,uCAAuC,CAAC;AACtE,OAAO,EAAC,gCAAgC,EAAC,MAAM,wCAAwC,CAAC;AACxF,OAAO,EAAC,qBAAqB,EAAC,MAAM,6CAA6C,CAAC;;AAGlF,MAAM,OAAO,wBAAwB;IAoBnC;;;;gFAI4E;IAE5E;QAxBA;;;;oFAI4E;QAEzD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAElC,UAAK,GAAG,IAAI,eAAe,CAAwB,IAAI,CAAC,CAAC;QAExD,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxD,4BAAuB,GAAG,IAAI,OAAO,EAAK,CAAC;QAE3C,iBAAY,GAAG,IAAI,eAAe,CAAqB,IAAI,CAAC,CAAC;QAC7D,mBAAc,GAAG,IAAI,eAAe,CAAqB,IAAI,CAAC,CAAC;QAE/D,sBAAiB,GAAG,IAAI,eAAe,CAAsC,IAAI,CAAC,CAAC;QASlG,KAAK,CACH,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,YAAY,CAClB;aACA,IAAI,CACH,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,EAC/B,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CACzB,CAAC,SAAS,CAAC;YACV,IAAI,EAAE,gBAAgB,CAAC,EAAE;gBACvB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CACzB,IAAI,gCAAgC,CAClC,gBAAgB,EAAE,IAAI,EACtB,gBAAgB,CAAC,QAAQ,EACzB,gBAAgB,CAAC,MAAM,CACxB,CACF,CAAC;YACJ,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;gFAI4E;IAErE,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED;;;;gFAI4E;IAG5E,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;IAC/C,CAAC;IAED,IAAW,uBAAuB;QAChC,OAAO,IAAI,CAAC,uBAAuB,CAAC,YAAY,EAAE,CAAC;IACrD,CAAC;IAEH;;SAEK;IAEI,eAAe,CAAC,KAAyB;QAC9C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAEM,qBAAqB,CAAC,IAAO;QAClC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAEM,oBAAoB,CAAC,IAAO;QACjC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,eAAe,CAAI,IAAI,EAAE,qBAAqB,CAAC,gBAAgB,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;IAC9G,CAAC;;qHAvFU,wBAAwB;yHAAxB,wBAAwB;2FAAxB,wBAAwB;kBADpC,UAAU","sourcesContent":["import {Injectable, OnDestroy} from '@angular/core';\nimport {BehaviorSubject, merge, Observable, Subject} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {filter, takeUntil} from 'rxjs/operators';\nimport {ElderMasterDetailMode} from './elder-master-detail-mode';\nimport {ActiveItemEvent} from '../table/activation/active-item-event';\nimport {ElderMasterDetailActivationEvent} from './elder-master-detail-activation-event';\nimport {ActivationEventSource} from '../table/activation/activation-event-source';\n\n@Injectable()\nexport class ElderMasterDetailService<T> implements OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  protected readonly destroy$ = new Subject<void>();\n\n  public readonly mode$ = new BehaviorSubject<ElderMasterDetailMode>(null);\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _itemActivationRequest$ = new Subject<T>();\n\n  private readonly _activeItem$ = new BehaviorSubject<ActiveItemEvent<T>>(null);\n  private readonly _creatingItem$ = new BehaviorSubject<ActiveItemEvent<T>>(null);\n\n  private readonly _activationEvent$ = new BehaviorSubject<ElderMasterDetailActivationEvent<T>>(null);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    merge(\n      this._creatingItem$,\n      this._activeItem$\n    )\n    .pipe(\n      filter(event => event !== null),\n      takeUntil(this.destroy$)\n    ).subscribe({\n      next: creatingOrActive => {\n        this._activationEvent$.next(\n          new ElderMasterDetailActivationEvent<T>(\n            creatingOrActive?.item,\n            creatingOrActive.creating,\n            creatingOrActive.source\n          )\n        );\n      }\n    });\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n\n  public get activationEvent$(): Observable<ElderMasterDetailActivationEvent<T>> {\n    return this._activationEvent$.asObservable();\n  }\n\n  public get itemActivationRequested(): Observable<T> {\n    return this._itemActivationRequest$.asObservable();\n  }\n\n/*  public get activeItem$(): Observable<T> {\n    return this._activeItem$.pipe(map(active => active.item));\n  }*/\n\n  public onItemActivated(event: ActiveItemEvent<T>) {\n    this._activeItem$.next(event);\n  }\n\n  public requestItemActivation(item: T): void {\n    this._itemActivationRequest$.next(item);\n  }\n\n  public activateCreatingItem(item: T) {\n    this._creatingItem$.next(new ActiveItemEvent<T>(item, ActivationEventSource.USER_MOUSE_CLICK, false, true));\n  }\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export var ActivationEventSource;
|
|
2
|
+
(function (ActivationEventSource) {
|
|
3
|
+
ActivationEventSource["USER_MOUSE_CLICK"] = "USER_MOUSE_CLICK";
|
|
4
|
+
ActivationEventSource["USER_KEYBOARD"] = "USER_KEYBOARD";
|
|
5
|
+
ActivationEventSource["SYSTEM"] = "SYSTEM";
|
|
6
|
+
})(ActivationEventSource || (ActivationEventSource = {}));
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZhdGlvbi1ldmVudC1zb3VyY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy90YWJsZS9hY3RpdmF0aW9uL2FjdGl2YXRpb24tZXZlbnQtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBTixJQUFZLHFCQUlYO0FBSkQsV0FBWSxxQkFBcUI7SUFDL0IsOERBQXFDLENBQUE7SUFDckMsd0RBQStCLENBQUE7SUFDL0IsMENBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUpXLHFCQUFxQixLQUFyQixxQkFBcUIsUUFJaEMiLCJzb3VyY2VzQ29udGVudCI6WyJcblxuZXhwb3J0IGVudW0gQWN0aXZhdGlvbkV2ZW50U291cmNlIHtcbiAgVVNFUl9NT1VTRV9DTElDSyA9ICdVU0VSX01PVVNFX0NMSUNLJyxcbiAgVVNFUl9LRVlCT0FSRCA9ICdVU0VSX0tFWUJPQVJEJyxcbiAgU1lTVEVNID0gJ1NZU1RFTSdcbn1cbiJdfQ==
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export class ActiveItemEvent {
|
|
2
|
+
constructor(item, source, focus, creating) {
|
|
3
|
+
this.item = item;
|
|
4
|
+
this.source = source;
|
|
5
|
+
this.focus = focus;
|
|
6
|
+
this.creating = creating;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZlLWl0ZW0tZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy90YWJsZS9hY3RpdmF0aW9uL2FjdGl2ZS1pdGVtLWV2ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQ2tCLElBQU8sRUFDUCxNQUE2QixFQUM3QixLQUFjLEVBQ2QsUUFBaUI7UUFIakIsU0FBSSxHQUFKLElBQUksQ0FBRztRQUNQLFdBQU0sR0FBTixNQUFNLENBQXVCO1FBQzdCLFVBQUssR0FBTCxLQUFLLENBQVM7UUFDZCxhQUFRLEdBQVIsUUFBUSxDQUFTO0lBQ2hDLENBQUM7Q0FDTCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QWN0aXZhdGlvbkV2ZW50U291cmNlfSBmcm9tICcuL2FjdGl2YXRpb24tZXZlbnQtc291cmNlJztcblxuZXhwb3J0IGNsYXNzIEFjdGl2ZUl0ZW1FdmVudDxUPiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBpdGVtOiBULFxuICAgIHB1YmxpYyByZWFkb25seSBzb3VyY2U6IEFjdGl2YXRpb25FdmVudFNvdXJjZSxcbiAgICBwdWJsaWMgcmVhZG9ubHkgZm9jdXM6IGJvb2xlYW4sXG4gICAgcHVibGljIHJlYWRvbmx5IGNyZWF0aW5nOiBib29sZWFuXG4gICkge31cbn1cblxuXG4iXX0=
|