@elderbyte/ngx-starter 15.16.0 → 15.16.1
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/master-detail/elder-master-detail-provider.mjs +20 -0
- package/esm2020/lib/components/data-view/master-detail/elder-master-detail.component.mjs +8 -4
- package/fesm2015/elderbyte-ngx-starter.mjs +24 -2
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +24 -2
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/data-view/master-detail/elder-master-detail-provider.d.ts +11 -0
- package/package.json +1 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Optional, SkipSelf } from '@angular/core';
|
|
2
|
+
import { MasterDetailService } from './master-detail.service';
|
|
3
|
+
export function existingOrNewMasterDetailService(serviceProvider) {
|
|
4
|
+
return serviceProvider ?? newMasterDetailService();
|
|
5
|
+
}
|
|
6
|
+
export function newMasterDetailService() {
|
|
7
|
+
return new MasterDetailService();
|
|
8
|
+
}
|
|
9
|
+
export class ElderMasterDetailProvider {
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Uses the existing MasterDetailService from a parent if available.
|
|
13
|
+
* Otherwise, creates a new MasterDetailService and provides it.
|
|
14
|
+
*/
|
|
15
|
+
ElderMasterDetailProvider.ExistingOrNewMasterDetailService = {
|
|
16
|
+
provide: MasterDetailService,
|
|
17
|
+
useFactory: existingOrNewMasterDetailService,
|
|
18
|
+
deps: [[new Optional(), new SkipSelf(), MasterDetailService]]
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbWFzdGVyLWRldGFpbC1wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS12aWV3L21hc3Rlci1kZXRhaWwvZWxkZXItbWFzdGVyLWRldGFpbC1wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFZLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUMzRCxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUc1RCxNQUFNLFVBQVUsZ0NBQWdDLENBQy9DLGVBQWdEO0lBRS9DLE9BQU8sZUFBZSxJQUFJLHNCQUFzQixFQUFFLENBQUM7QUFDckQsQ0FBQztBQUVELE1BQU0sVUFBVSxzQkFBc0I7SUFDcEMsT0FBTyxJQUFJLG1CQUFtQixFQUFFLENBQUM7QUFDbkMsQ0FBQztBQUVELE1BQU0sT0FBTyx5QkFBeUI7O0FBQ3BDOzs7R0FHRztBQUNvQiwwREFBZ0MsR0FBYTtJQUNsRSxPQUFPLEVBQUUsbUJBQW1CO0lBQzVCLFVBQVUsRUFBRSxnQ0FBZ0M7SUFDNUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLFFBQVEsRUFBRSxFQUFFLElBQUksUUFBUSxFQUFFLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztDQUM5RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtPcHRpb25hbCwgUHJvdmlkZXIsIFNraXBTZWxmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWFzdGVyRGV0YWlsU2VydmljZX0gZnJvbSAnLi9tYXN0ZXItZGV0YWlsLnNlcnZpY2UnO1xuXG5cbmV4cG9ydCBmdW5jdGlvbiBleGlzdGluZ09yTmV3TWFzdGVyRGV0YWlsU2VydmljZShcbiBzZXJ2aWNlUHJvdmlkZXI6IE1hc3RlckRldGFpbFNlcnZpY2U8YW55PiB8IG51bGxcbik6IE1hc3RlckRldGFpbFNlcnZpY2U8YW55PiB7XG4gIHJldHVybiBzZXJ2aWNlUHJvdmlkZXIgPz8gbmV3TWFzdGVyRGV0YWlsU2VydmljZSgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbmV3TWFzdGVyRGV0YWlsU2VydmljZSgpOiBNYXN0ZXJEZXRhaWxTZXJ2aWNlPGFueT4ge1xuICByZXR1cm4gbmV3IE1hc3RlckRldGFpbFNlcnZpY2UoKTtcbn1cblxuZXhwb3J0IGNsYXNzIEVsZGVyTWFzdGVyRGV0YWlsUHJvdmlkZXI8VD4ge1xuICAvKipcbiAgICogVXNlcyB0aGUgZXhpc3RpbmcgTWFzdGVyRGV0YWlsU2VydmljZSBmcm9tIGEgcGFyZW50IGlmIGF2YWlsYWJsZS5cbiAgICogT3RoZXJ3aXNlLCBjcmVhdGVzIGEgbmV3IE1hc3RlckRldGFpbFNlcnZpY2UgYW5kIHByb3ZpZGVzIGl0LlxuICAgKi9cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBFeGlzdGluZ09yTmV3TWFzdGVyRGV0YWlsU2VydmljZSA9IDxQcm92aWRlcj57XG4gICAgcHJvdmlkZTogTWFzdGVyRGV0YWlsU2VydmljZSxcbiAgICB1c2VGYWN0b3J5OiBleGlzdGluZ09yTmV3TWFzdGVyRGV0YWlsU2VydmljZSxcbiAgICBkZXBzOiBbW25ldyBPcHRpb25hbCgpLCBuZXcgU2tpcFNlbGYoKSwgTWFzdGVyRGV0YWlsU2VydmljZV1dXG4gIH07XG59XG4iXX0=
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChild, Input, TemplateRef } from '@angular/core';
|
|
2
2
|
import { ElderMasterDirective } from './elder-master.directive';
|
|
3
3
|
import { ElderDetailDirective } from './elder-detail.directive';
|
|
4
|
-
import { MasterDetailService } from './master-detail.service';
|
|
5
4
|
import { BehaviorSubject, Subject } from 'rxjs';
|
|
6
5
|
import { takeUntil } from 'rxjs/operators';
|
|
7
6
|
import { ElderDetailDialogComponent } from './elder-detail-dialog/elder-detail-dialog.component';
|
|
8
7
|
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
9
8
|
import { ElderMasterDetailMode } from './elder-master-detail-mode';
|
|
9
|
+
import { ElderMasterDetailProvider } from './elder-master-detail-provider';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "./master-detail.service";
|
|
12
12
|
import * as i2 from "@angular/material/dialog";
|
|
@@ -95,10 +95,14 @@ export class ElderMasterDetailComponent {
|
|
|
95
95
|
}
|
|
96
96
|
}
|
|
97
97
|
ElderMasterDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailComponent, deps: [{ token: i1.MasterDetailService }, { token: i2.MatDialog }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
98
|
-
ElderMasterDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMasterDetailComponent, selector: "elder-master-detail", inputs: { mode: "mode" }, providers: [
|
|
98
|
+
ElderMasterDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMasterDetailComponent, selector: "elder-master-detail", inputs: { mode: "mode" }, providers: [
|
|
99
|
+
ElderMasterDetailProvider.ExistingOrNewMasterDetailService
|
|
100
|
+
], 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 <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 <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n </div>\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 });
|
|
99
101
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailComponent, decorators: [{
|
|
100
102
|
type: Component,
|
|
101
|
-
args: [{ selector: 'elder-master-detail', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
103
|
+
args: [{ selector: 'elder-master-detail', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
104
|
+
ElderMasterDetailProvider.ExistingOrNewMasterDetailService
|
|
105
|
+
], template: "\n<div class=\"layout-row full\" *ngIf=\"mode$ | async as mode\">\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 <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n </div>\n</div>\n\n\n" }]
|
|
102
106
|
}], ctorParameters: function () { return [{ type: i1.MasterDetailService }, { type: i2.MatDialog }, { type: i0.ViewContainerRef }]; }, propDecorators: { master: [{
|
|
103
107
|
type: ContentChild,
|
|
104
108
|
args: [ElderMasterDirective, { read: TemplateRef, static: false }]
|
|
@@ -108,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
108
112
|
}], mode: [{
|
|
109
113
|
type: Input
|
|
110
114
|
}] } });
|
|
111
|
-
//# 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 {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';\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: [MasterDetailService]\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>(ElderMasterDetailMode.EMBEDDED);\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.masterDetailService.activeOrCreatingItemChange\n    .pipe(takeUntil(this.destroy$))\n    .subscribe({\n      next: active => {\n        if (this.mode$.getValue() == ElderMasterDetailMode.DIALOG) {\n          if (active != null) {\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  <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  <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n    <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n  </div>\n</div>\n\n\n"]}
|
|
115
|
+
//# 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>(ElderMasterDetailMode.EMBEDDED);\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.masterDetailService.activeOrCreatingItemChange\n    .pipe(takeUntil(this.destroy$))\n    .subscribe({\n      next: active => {\n        if (this.mode$.getValue() == ElderMasterDetailMode.DIALOG) {\n          if (active != null) {\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  <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  <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n    <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n  </div>\n</div>\n\n\n"]}
|
|
@@ -18042,6 +18042,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
18042
18042
|
}] }, { type: MasterDetailService }];
|
|
18043
18043
|
} });
|
|
18044
18044
|
|
|
18045
|
+
function existingOrNewMasterDetailService(serviceProvider) {
|
|
18046
|
+
return serviceProvider !== null && serviceProvider !== void 0 ? serviceProvider : newMasterDetailService();
|
|
18047
|
+
}
|
|
18048
|
+
function newMasterDetailService() {
|
|
18049
|
+
return new MasterDetailService();
|
|
18050
|
+
}
|
|
18051
|
+
class ElderMasterDetailProvider {
|
|
18052
|
+
}
|
|
18053
|
+
/**
|
|
18054
|
+
* Uses the existing MasterDetailService from a parent if available.
|
|
18055
|
+
* Otherwise, creates a new MasterDetailService and provides it.
|
|
18056
|
+
*/
|
|
18057
|
+
ElderMasterDetailProvider.ExistingOrNewMasterDetailService = {
|
|
18058
|
+
provide: MasterDetailService,
|
|
18059
|
+
useFactory: existingOrNewMasterDetailService,
|
|
18060
|
+
deps: [[new Optional(), new SkipSelf(), MasterDetailService]]
|
|
18061
|
+
};
|
|
18062
|
+
|
|
18045
18063
|
class ElderMasterDetailComponent {
|
|
18046
18064
|
/***************************************************************************
|
|
18047
18065
|
* *
|
|
@@ -18126,10 +18144,14 @@ class ElderMasterDetailComponent {
|
|
|
18126
18144
|
}
|
|
18127
18145
|
}
|
|
18128
18146
|
ElderMasterDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailComponent, deps: [{ token: MasterDetailService }, { token: i1$7.MatDialog }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
18129
|
-
ElderMasterDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMasterDetailComponent, selector: "elder-master-detail", inputs: { mode: "mode" }, providers: [
|
|
18147
|
+
ElderMasterDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMasterDetailComponent, selector: "elder-master-detail", inputs: { mode: "mode" }, providers: [
|
|
18148
|
+
ElderMasterDetailProvider.ExistingOrNewMasterDetailService
|
|
18149
|
+
], 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 <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 <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n </div>\n</div>\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i1$4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i1$4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18130
18150
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMasterDetailComponent, decorators: [{
|
|
18131
18151
|
type: Component,
|
|
18132
|
-
args: [{ selector: 'elder-master-detail', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
18152
|
+
args: [{ selector: 'elder-master-detail', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
18153
|
+
ElderMasterDetailProvider.ExistingOrNewMasterDetailService
|
|
18154
|
+
], template: "\n<div class=\"layout-row full\" *ngIf=\"mode$ | async as mode\">\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 <div class=\"layout-row full\" *ngIf=\"mode == ElderMasterDetailMode.DIALOG\">\n <ng-container *ngTemplateOutlet=\"master\"></ng-container>\n </div>\n</div>\n\n\n" }]
|
|
18133
18155
|
}], ctorParameters: function () { return [{ type: MasterDetailService }, { type: i1$7.MatDialog }, { type: i0.ViewContainerRef }]; }, propDecorators: { master: [{
|
|
18134
18156
|
type: ContentChild,
|
|
18135
18157
|
args: [ElderMasterDirective, { read: TemplateRef, static: false }]
|