@elderbyte/ngx-starter 14.4.0-beta.16 → 14.4.0-beta.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/esm2020/lib/components/data-view/base/data-view-options-provider-binding.mjs +63 -0
  2. package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +53 -10
  3. package/esm2020/lib/components/data-view/base/elder-data-view-options-provider.mjs +44 -0
  4. package/esm2020/lib/components/data-view/base/elder-data-view-options.mjs +42 -0
  5. package/esm2020/lib/components/data-view/base/public_api.mjs +5 -0
  6. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +8 -22
  7. package/esm2020/lib/components/data-view/public_api.mjs +2 -2
  8. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +9 -43
  9. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +2 -2
  10. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +1 -1
  11. package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +119 -0
  12. package/esm2020/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +137 -0
  13. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +18 -6
  14. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +1 -1
  15. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +56 -30
  16. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +1 -1
  17. package/esm2020/lib/components/iframes/iframe.service.mjs +2 -2
  18. package/esm2020/lib/components/iframes/typed-event-message.mjs +42 -0
  19. package/esm2020/lib/components/select/elder-select-base.mjs +1 -1
  20. package/esm2020/lib/components/select/elder-select.module.mjs +2 -2
  21. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +21 -39
  22. package/esm2020/lib/components/select/public_api.mjs +2 -1
  23. package/fesm2015/elderbyte-ngx-starter.mjs +1783 -1365
  24. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  25. package/fesm2020/elderbyte-ngx-starter.mjs +1764 -1348
  26. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  27. package/lib/components/data-view/base/data-view-options-provider-binding.d.ts +39 -0
  28. package/lib/components/data-view/base/elder-data-view-base.d.ts +29 -6
  29. package/lib/components/data-view/base/elder-data-view-options-provider.d.ts +38 -0
  30. package/lib/components/data-view/base/elder-data-view-options.d.ts +33 -0
  31. package/lib/components/data-view/base/public_api.d.ts +4 -0
  32. package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -6
  33. package/lib/components/data-view/public_api.d.ts +1 -1
  34. package/lib/components/data-view/table/elder-table/elder-table.component.d.ts +5 -19
  35. package/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.d.ts +66 -0
  36. package/lib/components/iframes/data-view/data-view-iframe-adapter.directive.d.ts +62 -0
  37. package/lib/components/iframes/elder-iframe.module.d.ts +14 -10
  38. package/lib/components/iframes/iframe-host/iframe-host.component.d.ts +28 -10
  39. package/lib/components/iframes/iframe.service.d.ts +3 -3
  40. package/lib/components/iframes/typed-event-message.d.ts +26 -0
  41. package/lib/components/select/elder-select.module.d.ts +1 -1
  42. package/lib/components/select/popup/selection-model-popup.directive.d.ts +7 -27
  43. package/lib/components/select/public_api.d.ts +1 -0
  44. package/package.json +1 -1
  45. package/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.scss +0 -0
  46. package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +0 -18
  47. package/esm2020/lib/components/iframes/iframe-message.mjs +0 -2
  48. package/lib/components/data-view/base/elder-data-view-base.module.d.ts +0 -9
  49. package/lib/components/iframes/iframe-message.d.ts +0 -5
@@ -5,24 +5,16 @@ import { switchMap } from 'rxjs/operators';
5
5
  import { EMPTY, of } from 'rxjs';
6
6
  import { SelectionModel } from '../../../common/selection/selection-model';
7
7
  import { ElderTableProviders } from '../../data-view/table/model/elder-table-model-provider';
8
+ import { ElderDataViewOptionsProvider } from '../../data-view/base/elder-data-view-options-provider';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@angular/material/dialog";
10
- import * as i2 from "../../../common/selection/selection-model";
11
- /**
12
- * Configures the selection mode on supporting components.
13
- */
14
- export class ElderDataViewSelectionMode {
15
- constructor() {
16
- this.sorts = [];
17
- this.filters = [];
18
- this.multi = false;
19
- }
20
- }
11
+ import * as i2 from "../../data-view/base/elder-data-view-options-provider";
12
+ import * as i3 from "../../../common/selection/selection-model";
21
13
  export function createSelectionModel() {
22
14
  return new SelectionModel();
23
15
  }
24
- export function createDataViewSelection() {
25
- return new ElderDataViewSelectionMode();
16
+ export function createDataViewOptionsProvider() {
17
+ return new ElderDataViewOptionsProvider();
26
18
  }
27
19
  export class SelectionModelPopupDirective {
28
20
  /***************************************************************************
@@ -30,11 +22,11 @@ export class SelectionModelPopupDirective {
30
22
  * Constructor *
31
23
  * *
32
24
  **************************************************************************/
33
- constructor(templateRef, viewContainer, dialog, dataViewSelectionMode, selectionModel, changeDetectorRef) {
25
+ constructor(templateRef, viewContainer, dialog, dataViewOptionsProvider, selectionModel, changeDetectorRef) {
34
26
  this.templateRef = templateRef;
35
27
  this.viewContainer = viewContainer;
36
28
  this.dialog = dialog;
37
- this.dataViewSelectionMode = dataViewSelectionMode;
29
+ this.dataViewOptionsProvider = dataViewOptionsProvider;
38
30
  this.selectionModel = selectionModel;
39
31
  this.changeDetectorRef = changeDetectorRef;
40
32
  /***************************************************************************
@@ -47,18 +39,6 @@ export class SelectionModelPopupDirective {
47
39
  set elderSelectionModelPopupTransform(fn) {
48
40
  this._transformerFn = fn;
49
41
  }
50
- /***************************************************************************
51
- * *
52
- * Host Listeners *
53
- * *
54
- **************************************************************************/
55
- /***************************************************************************
56
- * *
57
- * Life Cycle *
58
- * *
59
- **************************************************************************/
60
- ngOnInit() { }
61
- ngOnDestroy() { }
62
42
  /***************************************************************************
63
43
  * *
64
44
  * Public API *
@@ -68,9 +48,10 @@ export class SelectionModelPopupDirective {
68
48
  * Let the user choose some entities and return the selection.
69
49
  */
70
50
  choose(keyGetter, currentSelection, filters, sorts, multi = false) {
71
- this.dataViewSelectionMode.filters = filters || [];
72
- this.dataViewSelectionMode.sorts = sorts || [];
73
- this.dataViewSelectionMode.multi = multi;
51
+ this.dataViewOptionsProvider.updateOptions(options => options
52
+ .withFilters(filters || [])
53
+ .withSorts(sorts || [])
54
+ .withSelectionMultiEnabled(multi));
74
55
  this.selectionModel.isMultipleSelection = multi;
75
56
  this.selectionModel.keyGetterFn = keyGetter;
76
57
  this.selectionModel.replaceSelection(currentSelection);
@@ -78,7 +59,7 @@ export class SelectionModelPopupDirective {
78
59
  const dialogRef = this.openSelectDialog();
79
60
  // This fixes dialog rendering when the browser template
80
61
  // view container is outside the invoking control, which
81
- // happens when use ng-content projection.
62
+ // happens when using ng-content projection.
82
63
  this.changeDetectorRef.markForCheck();
83
64
  return dialogRef.afterClosed().pipe(switchMap((chosenEntities) => {
84
65
  if (chosenEntities) {
@@ -108,36 +89,37 @@ export class SelectionModelPopupDirective {
108
89
  });
109
90
  }
110
91
  }
111
- SelectionModelPopupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: SelectionModelPopupDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i1.MatDialog }, { token: ElderDataViewSelectionMode }, { token: i2.SelectionModel }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
92
+ SelectionModelPopupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: SelectionModelPopupDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i1.MatDialog }, { token: i2.ElderDataViewOptionsProvider }, { token: i3.SelectionModel }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
112
93
  SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.6", type: SelectionModelPopupDirective, selector: "[elderSelectionModelPopup]", inputs: { elderSelectionModelPopupTransform: "elderSelectionModelPopupTransform" }, providers: [
113
94
  {
114
95
  provide: SelectionModel,
115
96
  useFactory: createSelectionModel
116
97
  },
117
98
  {
118
- provide: ElderDataViewSelectionMode,
119
- useFactory: createDataViewSelection
99
+ provide: ElderDataViewOptionsProvider,
100
+ useFactory: createDataViewOptionsProvider
120
101
  },
121
102
  ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box
122
- ], ngImport: i0 });
103
+ ], exportAs: ["elderSelectionModelPopup"], ngImport: i0 });
123
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: SelectionModelPopupDirective, decorators: [{
124
105
  type: Directive,
125
106
  args: [{
126
107
  selector: '[elderSelectionModelPopup]',
108
+ exportAs: 'elderSelectionModelPopup',
127
109
  providers: [
128
110
  {
129
111
  provide: SelectionModel,
130
112
  useFactory: createSelectionModel
131
113
  },
132
114
  {
133
- provide: ElderDataViewSelectionMode,
134
- useFactory: createDataViewSelection
115
+ provide: ElderDataViewOptionsProvider,
116
+ useFactory: createDataViewOptionsProvider
135
117
  },
136
118
  ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box
137
119
  ]
138
120
  }]
139
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i1.MatDialog }, { type: ElderDataViewSelectionMode }, { type: i2.SelectionModel }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { elderSelectionModelPopupTransform: [{
121
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i1.MatDialog }, { type: i2.ElderDataViewOptionsProvider }, { type: i3.SelectionModel }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { elderSelectionModelPopupTransform: [{
140
122
  type: Input,
141
123
  args: ['elderSelectionModelPopupTransform']
142
124
  }] } });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-model-popup.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/popup/selection-model-popup.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,KAAK,EAAmD,MAAM,eAAe,CAAC;AACpH,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EAEL,iCAAiC,EAClC,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,KAAK,EAAc,EAAE,EAAC,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAc,cAAc,EAAC,MAAM,2CAA2C,CAAC;AAGtF,OAAO,EAAC,mBAAmB,EAAC,MAAM,wDAAwD,CAAC;;;;AAG3F;;GAEG;AACH,MAAM,OAAO,0BAA0B;IAMrC;QAJO,UAAK,GAAW,EAAE,CAAC;QACnB,YAAO,GAAa,EAAE,CAAC;QACvB,UAAK,GAAY,KAAK,CAAC;IAEd,CAAC;CAClB;AAED,MAAM,UAAU,oBAAoB;IAClC,OAAO,IAAI,cAAc,EAAO,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,uBAAuB;IACrC,OAAO,IAAI,0BAA0B,EAAE,CAAC;AAC1C,CAAC;AAgBD,MAAM,OAAO,4BAA4B;IAiBvC;;;;gFAI4E;IAE5E,YACmB,WAA6B,EAC7B,aAA+B,EAC/B,MAAiB,EACjB,qBAAiD,EACjD,cAAmC,EACnC,iBAAoC;QALpC,gBAAW,GAAX,WAAW,CAAkB;QAC7B,kBAAa,GAAb,aAAa,CAAkB;QAC/B,WAAM,GAAN,MAAM,CAAW;QACjB,0BAAqB,GAArB,qBAAqB,CAA4B;QACjD,mBAAc,GAAd,cAAc,CAAqB;QACnC,sBAAiB,GAAjB,iBAAiB,CAAmB;QA3BvD;;;;oFAI4E;QAE3D,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAsBlE,CAAC;IAlBL,IACW,iCAAiC,CAAC,EAAmB;QAC9D,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;IAC3B,CAAC;IAiBD;;;;gFAI4E;IAG5E;;;;gFAI4E;IAErE,QAAQ,KAAW,CAAC;IAEpB,WAAW,KAAW,CAAC;IAE9B;;;;gFAI4E;IAE5E;;OAEG;IACI,MAAM,CACX,SAA2B,EAC3B,gBAAuB,EACvB,OAAkB,EAClB,KAAc,EACd,KAAK,GAAG,KAAK;QAGb,IAAI,CAAC,qBAAqB,CAAC,OAAO,GAAG,OAAO,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,qBAAqB,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;QAC/C,IAAI,CAAC,qBAAqB,CAAC,KAAK,GAAG,KAAK,CAAC;QAEzC,IAAI,CAAC,cAAc,CAAC,mBAAmB,GAAG,KAAK,CAAC;QAChD,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,SAAS,CAAC;QAC5C,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;QAEvD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,wCAAwC,GAAC,gBAAgB,CAAC,MAAM,GAAC,YAAY,EAAE,gBAAgB,CAAC,CAAA;QAE9G,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAE1C,wDAAwD;QACxD,wDAAwD;QACxD,0CAA0C;QAC1C,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QAEtC,OAAO,SAAS,CAAC,WAAW,EAAE,CAAC,IAAI,CACjC,SAAS,CAAC,CAAC,cAAqB,EAAE,EAAE;YAClC,IAAI,cAAc,EAAE;gBAClB,OAAO,IAAI,CAAC,cAAc;oBACxB,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;oBAC7D,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;aACxB;iBAAM;gBACL,OAAO,KAAK,CAAC;aACd;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAEpE,gBAAgB;QACtB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CACrB,iCAAiC,EACjC;YACE,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,UAAU,EAAE,yBAAyB;YACrC,IAAI,EAAiC;gBACnC,0BAA0B,EAAE,IAAI,CAAC,WAAW;aAC7C;YACD,gBAAgB,EAAE,IAAI,CAAC,aAAa;SACrC,CACF,CAAC;IACJ,CAAC;;yHAnHU,4BAA4B,sGA2BG,0BAA0B;6GA3BzD,4BAA4B,yIAZ5B;QACT;YACE,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,oBAAoB;SACjC;QACD;YACE,OAAO,EAAE,0BAA0B;YACnC,UAAU,EAAE,uBAAuB;SACpC;QACD,mBAAmB,CAAC,eAAe,CAAC,uEAAuE;KAC5G;2FAEU,4BAA4B;kBAdxC,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,cAAc;4BACvB,UAAU,EAAE,oBAAoB;yBACjC;wBACD;4BACE,OAAO,EAAE,0BAA0B;4BACnC,UAAU,EAAE,uBAAuB;yBACpC;wBACD,mBAAmB,CAAC,eAAe,CAAC,uEAAuE;qBAC5G;iBACF;2IA4B2C,0BAA0B,uFAdzD,iCAAiC;sBAD3C,KAAK;uBAAC,mCAAmC","sourcesContent":["import {ChangeDetectorRef, Directive, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ISelectionModelDialogOptions,\n  TemplatedSelectionDialogComponent\n} from './templated-selection-dialog/templated-selection-dialog.component';\nimport {switchMap} from 'rxjs/operators';\nimport {EMPTY, Observable, of} from 'rxjs';\nimport {KeyGetterFn, SelectionModel} from '../../../common/selection/selection-model';\nimport {Sort} from '../../../common/data/sort';\nimport {Filter} from '../../../common/data/filter';\nimport {ElderTableProviders} from '../../data-view/table/model/elder-table-model-provider';\n\n\n/**\n * Configures the selection mode on supporting components.\n */\nexport class ElderDataViewSelectionMode {\n\n  public sorts: Sort[] = [];\n  public filters: Filter[] = [];\n  public multi: boolean = false;\n\n  constructor() { }\n}\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataViewSelection(): ElderDataViewSelectionMode {\n  return new ElderDataViewSelectionMode();\n}\n\n@Directive({\n  selector: '[elderSelectionModelPopup]',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewSelectionMode,\n      useFactory: createDataViewSelection\n    },\n    ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box\n  ]\n})\nexport class SelectionModelPopupDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _transformerFn: (o: any) => any;\n\n  @Input('elderSelectionModelPopupTransform')\n  public set elderSelectionModelPopupTransform(fn: (o: any) => any) {\n    this._transformerFn = fn;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    private readonly viewContainer: ViewContainerRef,\n    private readonly dialog: MatDialog,\n    private readonly dataViewSelectionMode: ElderDataViewSelectionMode,\n    private readonly selectionModel: SelectionModel<any>,\n    private readonly changeDetectorRef: ChangeDetectorRef\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  public ngOnDestroy(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Let the user choose some entities and return the selection.\n   */\n  public choose(\n    keyGetter: KeyGetterFn<any>,\n    currentSelection: any[],\n    filters?: Filter[],\n    sorts?: Sort[],\n    multi = false\n  ): Observable<any[]> {\n\n    this.dataViewSelectionMode.filters = filters || [];\n    this.dataViewSelectionMode.sorts = sorts || [];\n    this.dataViewSelectionMode.multi = multi;\n\n    this.selectionModel.isMultipleSelection = multi;\n    this.selectionModel.keyGetterFn = keyGetter;\n    this.selectionModel.replaceSelection(currentSelection);\n\n    this.log.info('Replaced selection popup with current '+currentSelection.length+' entities:', currentSelection)\n\n    const dialogRef = this.openSelectDialog();\n\n    // This fixes dialog rendering when the browser template\n    // view container is outside the invoking control, which\n    // happens when use ng-content projection.\n    this.changeDetectorRef.markForCheck();\n\n    return dialogRef.afterClosed().pipe(\n      switchMap((chosenEntities: any[]) => {\n        if (chosenEntities) {\n          return this._transformerFn\n            ? of(chosenEntities.map(value => this._transformerFn(value)))\n            : of(chosenEntities);\n        } else {\n          return EMPTY;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openSelectDialog(): MatDialogRef<TemplatedSelectionDialogComponent> {\n    return this.dialog.open(\n      TemplatedSelectionDialogComponent,\n      {\n        width: '90vw',\n        height: '90vh',\n        panelClass: 'custom-dialog-container',\n        data: <ISelectionModelDialogOptions> {\n          selectionComponentTemplate: this.templateRef\n        },\n        viewContainerRef: this.viewContainer\n      }\n    );\n  }\n\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-model-popup.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/popup/selection-model-popup.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Directive, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ISelectionModelDialogOptions,\n  TemplatedSelectionDialogComponent\n} from './templated-selection-dialog/templated-selection-dialog.component';\nimport {switchMap} from 'rxjs/operators';\nimport {EMPTY, Observable, of} from 'rxjs';\nimport {KeyGetterFn, SelectionModel} from '../../../common/selection/selection-model';\nimport {Sort} from '../../../common/data/sort';\nimport {Filter} from '../../../common/data/filter';\nimport {ElderTableProviders} from '../../data-view/table/model/elder-table-model-provider';\nimport {ElderDataViewOptionsProvider} from '../../data-view/base/elder-data-view-options-provider';\n\n\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataViewOptionsProvider(): ElderDataViewOptionsProvider {\n  return new ElderDataViewOptionsProvider();\n}\n\n@Directive({\n  selector: '[elderSelectionModelPopup]',\n  exportAs: 'elderSelectionModelPopup',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewOptionsProvider,\n      useFactory: createDataViewOptionsProvider\n    },\n    ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box\n  ]\n})\nexport class SelectionModelPopupDirective {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _transformerFn: (o: any) => any;\n\n  @Input('elderSelectionModelPopupTransform')\n  public set elderSelectionModelPopupTransform(fn: (o: any) => any) {\n    this._transformerFn = fn;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    private readonly viewContainer: ViewContainerRef,\n    private readonly dialog: MatDialog,\n    private readonly dataViewOptionsProvider: ElderDataViewOptionsProvider,\n    private readonly selectionModel: SelectionModel<any>,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Let the user choose some entities and return the selection.\n   */\n  public choose(\n    keyGetter: KeyGetterFn<any>,\n    currentSelection: any[],\n    filters?: Filter[],\n    sorts?: Sort[],\n    multi = false\n  ): Observable<any[]> {\n\n    this.dataViewOptionsProvider.updateOptions(\n      options => options\n        .withFilters(filters || [])\n        .withSorts(sorts || [])\n        .withSelectionMultiEnabled(multi)\n    )\n\n    this.selectionModel.isMultipleSelection = multi;\n    this.selectionModel.keyGetterFn = keyGetter;\n    this.selectionModel.replaceSelection(currentSelection);\n\n    this.log.info('Replaced selection popup with current '+currentSelection.length+' entities:', currentSelection)\n\n    const dialogRef = this.openSelectDialog();\n\n    // This fixes dialog rendering when the browser template\n    // view container is outside the invoking control, which\n    // happens when using ng-content projection.\n    this.changeDetectorRef.markForCheck();\n\n    return dialogRef.afterClosed().pipe(\n      switchMap((chosenEntities: any[]) => {\n        if (chosenEntities) {\n          return this._transformerFn\n            ? of(chosenEntities.map(value => this._transformerFn(value)))\n            : of(chosenEntities);\n        } else {\n          return EMPTY;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openSelectDialog(): MatDialogRef<TemplatedSelectionDialogComponent> {\n    return this.dialog.open(\n      TemplatedSelectionDialogComponent,\n      {\n        width: '90vw',\n        height: '90vh',\n        panelClass: 'custom-dialog-container',\n        data: <ISelectionModelDialogOptions> {\n          selectionComponentTemplate: this.templateRef\n        },\n        viewContainerRef: this.viewContainer\n      }\n    );\n  }\n\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  export * from './elder-select.module';
2
+ export * from './elder-select-base';
2
3
  export * from './single/elder-select-form-field';
3
4
  export * from './multi/elder-multi-select-base';
4
5
  export * from './multi/elder-multi-select-form-field';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0L3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGtDQUFrQyxDQUFBO0FBQ2hELGNBQWMsaUNBQWlDLENBQUE7QUFDL0MsY0FBYyx1Q0FBdUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZWxkZXItc2VsZWN0Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NpbmdsZS9lbGRlci1zZWxlY3QtZm9ybS1maWVsZCdcbmV4cG9ydCAqIGZyb20gJy4vbXVsdGkvZWxkZXItbXVsdGktc2VsZWN0LWJhc2UnXG5leHBvcnQgKiBmcm9tICcuL211bHRpL2VsZGVyLW11bHRpLXNlbGVjdC1mb3JtLWZpZWxkJ1xuIl19
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0L3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsa0NBQWtDLENBQUE7QUFDaEQsY0FBYyxpQ0FBaUMsQ0FBQTtBQUMvQyxjQUFjLHVDQUF1QyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lbGRlci1zZWxlY3QubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItc2VsZWN0LWJhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zaW5nbGUvZWxkZXItc2VsZWN0LWZvcm0tZmllbGQnXG5leHBvcnQgKiBmcm9tICcuL211bHRpL2VsZGVyLW11bHRpLXNlbGVjdC1iYXNlJ1xuZXhwb3J0ICogZnJvbSAnLi9tdWx0aS9lbGRlci1tdWx0aS1zZWxlY3QtZm9ybS1maWVsZCdcbiJdfQ==