angular-slickgrid 6.2.1 → 6.3.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/README.md CHANGED
@@ -43,6 +43,9 @@ You like to use **Angular-Slickgrid**? Be sure to upvote :star: and maybe suppor
43
43
 
44
44
  <a href='https://ko-fi.com/ghiscoding' target='_blank'><img height='32' style='border:0px;height:32px;' src='https://az743702.vo.msecnd.net/cdn/kofi3.png?v=0' border='0' alt='Buy Me a Coffee at ko-fi.com' />
45
45
 
46
+ ### Contributions
47
+ If you wish to contribute then make sure to follow the steps shown in the [CONTRIBUTING](https://github.com/ghiscoding/Angular-Slickgrid/blob/master/CONTRIBUTING.md) guide.
48
+
46
49
  ## Latest News & Releases
47
50
  Check out the [Releases](https://github.com/ghiscoding/Angular-Slickgrid/releases) section for all latest News & Releases.
48
51
 
@@ -53,13 +56,13 @@ For common issues, see the [Troubleshooting Section](#troubleshooting-section) b
53
56
 
54
57
  ## Angular Compatibility
55
58
 
56
- > **Note** please be aware that only the latest version of Angular-Slickgrid, shown in the table below, is supported and can receive bug fixes. It's already a lot of work for a single developer like me, so hopefully you will understand.
59
+ > **Note** please be aware that only the latest version of Angular-Slickgrid is supported and will receive bug fixes. The reason older versions are not supported is simply because it's already a lot of work to maintain for a single developer.
57
60
 
58
61
  | Angular-Slickgrid | Angular version | Migration Guide | Notes |
59
62
  |-------------------|-----------------------|-----------------|------|
60
- | 6.x | >=16.0 | [Migration 6.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-6.x) | removal of jQuery (now uses browser native code), it uses Slickgrid-Universal [3.x](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v3.0.0) version |
61
- | 5.x | >=14.0 | [Migration 5.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-5.x) | removal of jQueryUI, it uses Slickgrid-Universal [2.x](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v2.0.0) version |
62
- | 4.x | >=13.0 | [Migration 4.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-4.x) | for Ivy build only, it uses Slickgrid-Universal [1.x](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v1.1.1) version |
63
+ | 6.x | >=16.0 | [Migration 6.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-6.x) | removal of jQuery (now uses browser native code), requires Slickgrid-Universal [3.x](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v3.0.0) version |
64
+ | 5.x | >=14.0 | [Migration 5.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-5.x) | removal of jQueryUI, requires Slickgrid-Universal [2.x](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v2.0.0) version |
65
+ | 4.x | >=13.0 | [Migration 4.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-4.x) | for Ivy build only, requires Slickgrid-Universal [1.x](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v1.1.1) version |
63
66
  | 3.x | >=12.0 | [Migration 3.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-3.x) | the lib now uses [Slickgrid-Universal](https://github.com/ghiscoding/slickgrid-universal) monorepo [v0.19.2](https://github.com/ghiscoding/slickgrid-universal/releases/tag/v0.19.2). Also, IE11 is EOL and no longer supported. |
64
67
  | 2.x | 7-11.x | [Migration 2.x](https://github.com/ghiscoding/Angular-Slickgrid/wiki/Migration-to-2.x) | support multiple grids on same page |
65
68
  | 1.x | 4-6.x | | |
@@ -116,7 +119,6 @@ This is no longer the case. Verify if you need this module and configure a polyf
116
119
  ```
117
120
  "options": {
118
121
  "allowedCommonJsDependencies": [
119
- "assign-deep",
120
122
  "excel-builder-webpacker",
121
123
  "stream"
122
124
  ],
@@ -1,11 +1,37 @@
1
1
  import { ViewContainerRef } from '@angular/core';
2
+ import type { EnvironmentInjector, Injector, NgModuleRef, Type } from '@angular/core';
2
3
  import type { AngularComponentOutput } from '../models/angularComponentOutput.interface';
3
4
  import * as i0 from "@angular/core";
5
+ interface CreateComponentOption {
6
+ index?: number;
7
+ injector?: Injector;
8
+ ngModuleRef?: NgModuleRef<unknown>;
9
+ environmentInjector?: EnvironmentInjector | NgModuleRef<unknown>;
10
+ projectableNodes?: Node[][];
11
+ }
4
12
  export declare class AngularUtilService {
5
13
  private vcr;
6
14
  constructor(vcr: ViewContainerRef);
7
- createAngularComponent(component: any): AngularComponentOutput;
8
- createAngularComponentAppendToDom(component: any, targetElement?: HTMLElement | Element, clearTargetContent?: boolean): AngularComponentOutput;
15
+ /**
16
+ * Dynamically create an Angular component, user could also provide optional arguments for target, data & createComponent options
17
+ * @param {Component} component
18
+ * @param {HTMLElement} [targetElement]
19
+ * @param {*} [data]
20
+ * @param {CreateComponentOption} [createCompOptions]
21
+ * @returns
22
+ */
23
+ createAngularComponent<C>(component: Type<C>, targetElement?: Element, data?: any, createCompOptions?: CreateComponentOption): AngularComponentOutput;
24
+ /**
25
+ * Dynamically create an Angular component and append it to the DOM unless a target element is provided,
26
+ * user could also provide other optional arguments for data & createComponent options.
27
+ * @param {Component} component
28
+ * @param {HTMLElement} [targetElement]
29
+ * @param {*} [data]
30
+ * @param {CreateComponentOption} [createCompOptions]
31
+ * @returns
32
+ */
33
+ createAngularComponentAppendToDom<C>(component: Type<C>, targetElement?: Element, data?: any, createCompOptions?: CreateComponentOption): AngularComponentOutput;
9
34
  static ɵfac: i0.ɵɵFactoryDeclaration<AngularUtilService, never>;
10
35
  static ɵprov: i0.ɵɵInjectableDeclaration<AngularUtilService>;
11
36
  }
37
+ export {};
@@ -1193,15 +1193,15 @@ export class AngularSlickgridComponent {
1193
1193
  currentEditor.renderDomElement(newCollection);
1194
1194
  }
1195
1195
  }
1196
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularSlickgridComponent, deps: [{ token: i1.AngularUtilService }, { token: i0.ApplicationRef }, { token: i0.ChangeDetectorRef }, { token: i2.ContainerService }, { token: i0.ElementRef }, { token: i3.TranslateService, optional: true }, { token: i4.TranslaterService, optional: true }, { token: 'config' }, { token: 'externalService' }], target: i0.ɵɵFactoryTarget.Component });
1197
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: AngularSlickgridComponent, selector: "angular-slickgrid", inputs: { customDataView: "customDataView", gridId: "gridId", gridOptions: "gridOptions", paginationOptions: "paginationOptions", columnDefinitions: "columnDefinitions", dataset: "dataset", datasetHierarchical: "datasetHierarchical" }, outputs: { columnDefinitionsChange: "columnDefinitionsChange" }, providers: [
1196
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularSlickgridComponent, deps: [{ token: i1.AngularUtilService }, { token: i0.ApplicationRef }, { token: i0.ChangeDetectorRef }, { token: i2.ContainerService }, { token: i0.ElementRef }, { token: i3.TranslateService, optional: true }, { token: i4.TranslaterService, optional: true }, { token: 'config' }, { token: 'externalService' }], target: i0.ɵɵFactoryTarget.Component });
1197
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.8", type: AngularSlickgridComponent, selector: "angular-slickgrid", inputs: { customDataView: "customDataView", gridId: "gridId", gridOptions: "gridOptions", paginationOptions: "paginationOptions", columnDefinitions: "columnDefinitions", dataset: "dataset", datasetHierarchical: "datasetHierarchical" }, outputs: { columnDefinitionsChange: "columnDefinitionsChange" }, providers: [
1198
1198
  // make everything transient (non-singleton)
1199
1199
  AngularUtilService,
1200
1200
  ApplicationRef,
1201
1201
  TranslaterService,
1202
1202
  ], ngImport: i0, template: "<div id=\"slickGridContainer-{{gridId}}\" class=\"gridPane\">\n <div attr.id='{{gridId}}' class=\"slickgrid-container\" style=\"width: 100%\">\n </div>\n</div>" });
1203
1203
  }
1204
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularSlickgridComponent, decorators: [{
1204
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularSlickgridComponent, decorators: [{
1205
1205
  type: Component,
1206
1206
  args: [{ selector: 'angular-slickgrid', providers: [
1207
1207
  // make everything transient (non-singleton)
@@ -193,24 +193,22 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
193
193
  /** Render (or re-render) the View Component (Row Detail) */
194
194
  renderPreloadView() {
195
195
  const containerElements = this.gridContainerElement.getElementsByClassName(`${PRELOAD_CONTAINER_PREFIX}`);
196
- if (containerElements?.length >= 0) {
197
- this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1], true);
196
+ if (this._preloadComponent && containerElements?.length >= 0) {
197
+ this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1]);
198
198
  }
199
199
  }
200
200
  /** Render (or re-render) the View Component (Row Detail) */
201
201
  renderViewModel(item) {
202
202
  const containerElements = this.gridContainerElement.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`);
203
- if (containerElements?.length > 0) {
204
- const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], true);
205
- if (componentOutput && componentOutput.componentRef && componentOutput.componentRef.instance) {
206
- // pass a few properties to the Row Detail template component
207
- Object.assign(componentOutput.componentRef.instance, {
208
- model: item,
209
- addon: this,
210
- grid: this._grid,
211
- dataView: this.dataView,
212
- parent: this.rowDetailViewOptions?.parent,
213
- });
203
+ if (this._viewComponent && containerElements?.length > 0) {
204
+ const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], {
205
+ model: item,
206
+ addon: this,
207
+ grid: this._grid,
208
+ dataView: this.dataView,
209
+ parent: this.rowDetailViewOptions?.parent,
210
+ });
211
+ if (componentOutput?.componentRef) {
214
212
  const viewObj = this._views.find(obj => obj.id === item[this.datasetIdPropName]);
215
213
  if (viewObj) {
216
214
  viewObj.componentRef = componentOutput.componentRef;
@@ -304,4 +302,4 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
304
302
  }
305
303
  }
306
304
  }
307
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slickRowDetailView.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/extensions/slickRowDetailView.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAEvI,OAAO,EAAE,kBAAkB,IAAI,2BAA2B,EAAE,MAAM,6CAA6C,CAAC;AAChH,OAAO,EAAE,UAAU,EAAW,MAAM,MAAM,CAAC;AAC3C,OAAO,KAAK,SAAS,MAAM,WAAW,CAAC;AAKvC,MAAM,2BAA2B,GAAG,YAAY,CAAC;AACjD,MAAM,wBAAwB,GAAG,mBAAmB,CAAC;AAQrD,MAAM,OAAO,kBAAmB,SAAQ,2BAA2B;IAS5C;IACA;IACA;IACA;IACT;IAZZ,kBAAkB,CAAoB;IAC5B,iBAAiB,CAA2B;IAC5C,MAAM,GAAkB,EAAE,CAAC;IAC3B,cAAc,CAAgB;IAC9B,cAAc,GAAwB,EAAE,CAAC;IACzC,cAAc,CAAgE;IAExF,YACqB,kBAAsC,EACtC,MAAsB,EACtB,kBAAsC,EACtC,oBAAoC,EAC7C,IAAiB;QAE3B,KAAK,CAAC,kBAAkB,CAAC,CAAC;QANP,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,WAAM,GAAN,MAAM,CAAgB;QACtB,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,yBAAoB,GAApB,oBAAoB,CAAgB;QAC7C,SAAI,GAAJ,IAAI,CAAa;IAG7B,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC;IAED,IAAc,iBAAiB;QAC7B,OAAO,IAAI,CAAC,WAAW,CAAC,qBAAqB,IAAI,IAAI,CAAC;IACxD,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,YAAY,CAAC,YAA+B;QAC9C,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;IACpC,CAAC;IAED,iEAAiE;IACjE,IAAI,WAAW;QACb,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,CAAe,CAAC;IACxD,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;IACxC,CAAC;IAED,eAAe,CAAC,IAAgB;QAC9B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,6CAA6C;IAC7C,OAAO;QACL,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,0CAA0C;QACrG,KAAK,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC;IAED,0EAA0E;IAC1E,wBAAwB;QACtB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,mEAAmE;IACnE,gBAAgB;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC,IAAe;QAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,iBAAiB,EAAE,CAAC,CAAC;IAC3C,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,kBAA2C;QAClD,IAAI,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO,KAAK,UAAU,EAAE;YACjE,yFAAyF;YACzF,kHAAkH;YAClH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAsC,CAAC,CAAgB,6BAA6B;YACzI,IAAI,CAAC,YAAY,CAAC,OAAO,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAE,gDAAgD;SACjH;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,4GAA4G,CAAC,CAAC;SAC/H;QAED,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE;YACjD,4FAA4F;YAC5F,yJAAyJ;YACzJ,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,WAAW,EAAE;gBAC/C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,gBAAgB,CAAC;gBAC3E,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,wBAAwB,UAAU,CAAC,CAAC;aAC7G;YACD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,EAAE;gBAChD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,aAAa,CAAC;gBACrE,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,CAAC,UAAe,EAAE,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,2BAA2B,GAAG,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;aACrK;YAED,sEAAsE;YACtE,IAAI,CAAC,kBAAkB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,EAAE;gBAC1D,kBAAkB,GAAG,IAAI,sBAAsB,CAAC,IAAI,CAAC,WAAW,CAAC,mBAAmB,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC;gBACnH,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC;aAClD;YAED,kBAAkB;YAClB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,oBAAoB,EAAE;gBAC3C,IAAI,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,EAAE;oBACnD,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;iBACvD;gBAED,IAAI,IAAI,CAAC,eAAe,EAAE;oBACxB,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;wBAChE,IAAI,IAAI,CAAC,oBAAoB,IAAI,OAAO,IAAI,CAAC,oBAAoB,CAAC,eAAe,KAAK,UAAU,EAAE;4BAChG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;yBACxD;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,IAAI,IAAI,CAAC,gBAAgB,EAAE;oBACzB,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAM,EAAE,IAAqC,EAAE,EAAE;wBACnG,2DAA2D;wBAC3D,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;wBAEjC,IAAI,IAAI,CAAC,oBAAoB,IAAI,OAAO,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,KAAK,UAAU,EAAE;4BACjG,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;yBACrD;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,IAAI,IAAI,CAAC,sBAAsB,EAAE;oBAC/B,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAM,EAAE,IAA6D,EAAE,EAAE;wBACjI,iFAAiF;wBACjF,wGAAwG;wBACxG,IAAI,CAAC,iBAAiB,EAAE,CAAC;wBACzB,IAAI,CAAC,uBAAuB,EAAE,CAAC;wBAE/B,IAAI,IAAI,CAAC,oBAAoB,IAAI,OAAO,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,KAAK,UAAU,EAAE;4BACvG,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;yBAC3D;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,IAAI,IAAI,CAAC,uBAAuB,EAAE;oBAChC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE;wBACpE,mFAAmF;wBACnF,IAAI,CAAC,6BAA6B,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;wBAE5C,IAAI,IAAI,CAAC,oBAAoB,IAAI,OAAO,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,KAAK,UAAU,EAAE;4BACxG,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;yBAC5D;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,IAAI,IAAI,CAAC,wBAAwB,EAAE;oBACjC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC,CAAM,EAAE,IAA0H,EAAE,EAAE;wBAChM,8EAA8E;wBAC9E,IAAI,CAAC,8BAA8B,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;wBAE7C,IAAI,IAAI,CAAC,oBAAoB,IAAI,OAAO,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,KAAK,UAAU,EAAE;4BACzG,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;yBAC7D;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,IAAI,IAAI,CAAC,uBAAuB,EAAE;oBAChC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAM,EAAE,IAA0H,EAAE,EAAE;wBAC/L,IAAI,IAAI,CAAC,oBAAoB,IAAI,OAAO,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,KAAK,UAAU,EAAE;4BACxG,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;yBAC5D;oBACH,CAAC,CAAC,CAAC;iBACJ;gBAED,KAAK;gBACL,+CAA+C;gBAE/C,wFAAwF;gBACxF,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;gBAEpG,mDAAmD;gBACnD,IAAI,IAAI,CAAC,WAAW,CAAC,kBAAkB,IAAI,IAAI,CAAC,WAAW,CAAC,sBAAsB,EAAE;oBAClF,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,qBAAqB,EAAE,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;iBACxG;gBAED,mFAAmF;gBACnF,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;gBAEzF,oDAAoD;gBACpD,IAAI,CAAC,cAAc,CAAC,IAAI,CACtB,IAAI,CAAC,kBAAkB,EAAE,SAAS,CAAC,iBAAiB,EAAE,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAC9F,IAAI,CAAC,kBAAkB,EAAE,SAAS,CAAC,2BAA2B,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC,EACvH,IAAI,CAAC,kBAAkB,EAAE,SAAS,CAAC,2BAA2B,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC,CACxH,CAAC;aACH;SACF;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,qEAAqE;IACrE,uBAAuB;QACrB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC9B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,yDAAyD;IACzD,uBAAuB;QACrB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC3B,IAAI,IAAI,EAAE,WAAW,EAAE;gBACrB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACxC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,0CAA0C;IAC1C,mBAAmB,CAAC,WAAwB;QAC1C,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC,GAAG,2BAA2B,GAAG,WAAW,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9H,IAAI,iBAAiB,EAAE,MAAM,IAAI,CAAC,EAAE;YAClC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;SAC/C;IACH,CAAC;IAED,4DAA4D;IAC5D,iBAAiB;QACf,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC,GAAG,wBAAwB,EAAE,CAAC,CAAC;QAC1G,IAAI,iBAAiB,EAAE,MAAM,IAAI,CAAC,EAAE;YAClC,IAAI,CAAC,kBAAkB,CAAC,iCAAiC,CAAC,IAAI,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SAC1I;IACH,CAAC;IAED,4DAA4D;IAC5D,eAAe,CAAC,IAAS;QACvB,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC,GAAG,2BAA2B,GAAG,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QAC5I,IAAI,iBAAiB,EAAE,MAAM,GAAG,CAAC,EAAE;YACjC,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,iCAAiC,CAAC,IAAI,CAAC,cAAc,EAAE,iBAAiB,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAC9J,IAAI,eAAe,IAAI,eAAe,CAAC,YAAY,IAAI,eAAe,CAAC,YAAY,CAAC,QAAQ,EAAE;gBAC5F,6DAA6D;gBAC7D,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,QAAQ,EAAE;oBACnD,KAAK,EAAE,IAAI;oBACX,KAAK,EAAE,IAAI;oBACX,IAAI,EAAE,IAAI,CAAC,KAAK;oBAChB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,MAAM,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM;iBAC1C,CAAC,CAAC;gBAEH,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBACjF,IAAI,OAAO,EAAE;oBACX,OAAO,CAAC,YAAY,GAAG,eAAe,CAAC,YAAY,CAAC;iBACrD;gBACD,OAAO,OAAO,CAAC;aAChB;SACF;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,KAAK;IACL,sBAAsB;IACtB,qBAAqB;IAEX,oBAAoB,CAAC,YAAyB;QACtD,MAAM,OAAO,GAAG,YAAY,EAAE,YAAY,CAAC;QAC3C,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YACzC,IAAI,OAAO,EAAE,OAAO,EAAE;gBACpB,OAAO,CAAC,OAAO,EAAE,CAAC;aACnB;YACD,OAAO,YAAY,CAAC;SACrB;IACH,CAAC;IAED;;;;OAIG;IACO,cAAc,CAAC,IAAS;QAChC,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;SACxD;IACH,CAAC;IAED;;;OAGG;IACO,KAAK,CAAC,YAAY,CAAC,IAAS;QACpC,IAAI,IAAI,IAAI,OAAO,IAAI,CAAC,cAAc,KAAK,UAAU,EAAE;YACrD,IAAI,iBAAsB,CAAC;YAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAEhD,oFAAoF;YACpF,MAAM,QAAQ,GAAgB,MAAM,aAAa,CAAC;YAElD,IAAI,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE;gBACnD,iBAAiB,GAAG,QAAQ,CAAC,CAAC,eAAe;aAC9C;iBAAM,IAAI,QAAQ,IAAI,QAAQ,YAAY,UAAU,IAAI,QAAQ,YAAY,OAAO,EAAE;gBACpF,iBAAiB,GAAG,MAAM,uBAAuB,CAAC,IAAI,CAAC,IAAkB,EAAE,QAAQ,CAAC,CAAC,CAAC,2BAA2B;aAClH;YAED,IAAI,CAAC,iBAAiB,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE;gBACnF,MAAM,IAAI,KAAK,CAAC;0GACkF,IAAI,CAAC,iBAAiB,YAAY,CAAC,CAAC;aACvI;YAED,8CAA8C;YAC9C,IAAI,CAAC,cAAc,CAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;SAC9C;IACH,CAAC;IAED;;;;;OAKG;IACO,6BAA6B,CAAC,CAAQ,EAAE,IAAqC;QACrF,YAAY;QACZ,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YAC9C,uBAAuB;YACvB,MAAM,QAAQ,GAAgB;gBAC5B,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC;gBACrC,WAAW,EAAE,IAAI,CAAC,IAAI;aACvB,CAAC;YACF,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,IAAI,IAAI,CAAC;YAClE,uBAAuB,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;SAC5D;aAAM;YACL,+CAA+C;YAC/C,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAiB,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;YACnH,IAAI,cAAc,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE;gBACrE,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC;gBACzD,IAAI,OAAO,EAAE;oBACX,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;oBACzC,OAAO,CAAC,OAAO,EAAE,CAAC;iBACnB;gBACD,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;aACvC;SACF;IACH,CAAC;IAED,wEAAwE;IAC9D,8BAA8B,CAAC,CAAQ,EAAE,IAA0H;QAC3K,IAAI,IAAI,EAAE,IAAI,EAAE;YACd,IAAI,CAAC,uBAAuB,EAAE,CAAC;SAChC;IACH,CAAC;CACF","sourcesContent":["import { ApplicationRef, ComponentRef, Type, ViewContainerRef } from '@angular/core';\nimport type { EventSubscription, RxJsFacade, SlickEventHandler, SlickGrid } from '@slickgrid-universal/common';\nimport { addToArrayWhenNotExists, castObservableToPromise, SlickRowSelectionModel, unsubscribeAll } from '@slickgrid-universal/common';\nimport { EventPubSubService } from '@slickgrid-universal/event-pub-sub';\nimport { SlickRowDetailView as UniversalSlickRowDetailView } from '@slickgrid-universal/row-detail-view-plugin';\nimport { Observable, Subject } from 'rxjs';\nimport * as DOMPurify from 'dompurify';\n\nimport { GridOption, RowDetailView } from '../models/index';\nimport { AngularUtilService } from '../services/angularUtil.service';\n\nconst ROW_DETAIL_CONTAINER_PREFIX = 'container_';\nconst PRELOAD_CONTAINER_PREFIX = 'container_loading';\n\nexport interface CreatedView {\n  id: string | number;\n  dataContext: any;\n  componentRef?: ComponentRef<any>;\n}\n\nexport class SlickRowDetailView extends UniversalSlickRowDetailView {\n  rowDetailContainer!: ViewContainerRef;\n  protected _preloadComponent: Type<object> | undefined;\n  protected _views: CreatedView[] = [];\n  protected _viewComponent!: Type<object>;\n  protected _subscriptions: EventSubscription[] = [];\n  protected _userProcessFn!: (item: any) => Promise<any> | Observable<any> | Subject<any>;\n\n  constructor(\n    protected readonly angularUtilService: AngularUtilService,\n    protected readonly appRef: ApplicationRef,\n    protected readonly eventPubSubService: EventPubSubService,\n    protected readonly gridContainerElement: HTMLDivElement,\n    protected rxjs?: RxJsFacade,\n  ) {\n    super(eventPubSubService);\n  }\n\n  get addonOptions() {\n    return this.getOptions();\n  }\n\n  protected get datasetIdPropName(): string {\n    return this.gridOptions.datasetIdPropertyName || 'id';\n  }\n\n  get eventHandler(): SlickEventHandler {\n    return this._eventHandler;\n  }\n  set eventHandler(eventHandler: SlickEventHandler) {\n    this._eventHandler = eventHandler;\n  }\n\n  /** Getter for the Grid Options pulled through the Grid Object */\n  get gridOptions(): GridOption {\n    return (this._grid?.getOptions() || {}) as GridOption;\n  }\n\n  get rowDetailViewOptions(): RowDetailView | undefined {\n    return this.gridOptions.rowDetailView;\n  }\n\n  addRxJsResource(rxjs: RxJsFacade) {\n    this.rxjs = rxjs;\n  }\n\n  /** Dispose of the RowDetailView Extension */\n  dispose() {\n    this.disposeAllViewComponents();\n    this._subscriptions = unsubscribeAll(this._subscriptions); // also unsubscribe all RxJS subscriptions\n    super.dispose();\n  }\n\n  /** Dispose of all the opened Row Detail Panels Angular View Components */\n  disposeAllViewComponents() {\n    this._views.forEach((compRef) => this.disposeViewComponent(compRef));\n    this._views = [];\n  }\n\n  /** Get the instance of the SlickGrid addon (control or plugin). */\n  getAddonInstance(): SlickRowDetailView | null {\n    return this;\n  }\n\n  init(grid: SlickGrid) {\n    this._grid = grid;\n    super.init(this._grid);\n    this.register(grid?.getSelectionModel());\n  }\n\n  /**\n   * Create the plugin before the Grid creation, else it will behave oddly.\n   * Mostly because the column definitions might change after the grid creation\n   */\n  register(rowSelectionPlugin?: SlickRowSelectionModel) {\n    if (typeof this.gridOptions.rowDetailView?.process === 'function') {\n      // we need to keep the user \"process\" method and replace it with our own execution method\n      // we do this because when we get the item detail, we need to call \"onAsyncResponse.notify\" for the plugin to work\n      this._userProcessFn = this.gridOptions.rowDetailView.process as (item: any) => Promise<any>;                // keep user's process method\n      this.addonOptions.process = (item) => this.onProcessing(item);  // replace process method & run our internal one\n    } else {\n      throw new Error('[Angular-Slickgrid] You need to provide a \"process\" function for the Row Detail Extension to work properly');\n    }\n\n    if (this._grid && this.gridOptions?.rowDetailView) {\n      // load the Preload & RowDetail Templates (could be straight HTML or Angular View/ViewModel)\n      // when those are Angular View/ViewModel, we need to create View Component & provide the html containers to the Plugin (preTemplate/postTemplate methods)\n      if (!this.gridOptions.rowDetailView.preTemplate) {\n        this._preloadComponent = this.gridOptions?.rowDetailView?.preloadComponent;\n        this.addonOptions.preTemplate = () => DOMPurify.sanitize(`<div class=\"${PRELOAD_CONTAINER_PREFIX}\"></div>`);\n      }\n      if (!this.gridOptions.rowDetailView.postTemplate) {\n        this._viewComponent = this.gridOptions?.rowDetailView?.viewComponent;\n        this.addonOptions.postTemplate = (itemDetail: any) => DOMPurify.sanitize(`<div class=\"${ROW_DETAIL_CONTAINER_PREFIX}${itemDetail[this.datasetIdPropName]}\"></div>`);\n      }\n\n      // this also requires the Row Selection Model to be registered as well\n      if (!rowSelectionPlugin || !this._grid.getSelectionModel()) {\n        rowSelectionPlugin = new SlickRowSelectionModel(this.gridOptions.rowSelectionOptions || { selectActiveRow: true });\n        this._grid.setSelectionModel(rowSelectionPlugin);\n      }\n\n      // hook all events\n      if (this._grid && this.rowDetailViewOptions) {\n        if (this.rowDetailViewOptions.onExtensionRegistered) {\n          this.rowDetailViewOptions.onExtensionRegistered(this);\n        }\n\n        if (this.onAsyncResponse) {\n          this.eventHandler.subscribe(this.onAsyncResponse, (event, args) => {\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncResponse === 'function') {\n              this.rowDetailViewOptions.onAsyncResponse(event, args);\n            }\n          });\n        }\n\n        if (this.onAsyncEndUpdate) {\n          this.eventHandler.subscribe(this.onAsyncEndUpdate, (e: any, args: { grid: SlickGrid; item: any; }) => {\n            // triggers after backend called \"onAsyncResponse.notify()\"\n            this.renderViewModel(args?.item);\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncEndUpdate === 'function') {\n              this.rowDetailViewOptions.onAsyncEndUpdate(e, args);\n            }\n          });\n        }\n\n        if (this.onAfterRowDetailToggle) {\n          this.eventHandler.subscribe(this.onAfterRowDetailToggle, (e: any, args: { grid: SlickGrid; item: any; expandedRows: number[]; }) => {\n            // display preload template & re-render all the other Detail Views after toggling\n            // the preload View will eventually go away once the data gets loaded after the \"onAsyncEndUpdate\" event\n            this.renderPreloadView();\n            this.renderAllViewComponents();\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAfterRowDetailToggle === 'function') {\n              this.rowDetailViewOptions.onAfterRowDetailToggle(e, args);\n            }\n          });\n        }\n\n        if (this.onBeforeRowDetailToggle) {\n          this.eventHandler.subscribe(this.onBeforeRowDetailToggle, (e, args) => {\n            // before toggling row detail, we need to create View Component if it doesn't exist\n            this.handleOnBeforeRowDetailToggle(e, args);\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onBeforeRowDetailToggle === 'function') {\n              this.rowDetailViewOptions.onBeforeRowDetailToggle(e, args);\n            }\n          });\n        }\n\n        if (this.onRowBackToViewportRange) {\n          this.eventHandler.subscribe(this.onRowBackToViewportRange, (e: any, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) => {\n            // when row is back to viewport range, we will re-render the View Component(s)\n            this.handleOnRowBackToViewportRange(e, args);\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowBackToViewportRange === 'function') {\n              this.rowDetailViewOptions.onRowBackToViewportRange(e, args);\n            }\n          });\n        }\n\n        if (this.onRowOutOfViewportRange) {\n          this.eventHandler.subscribe(this.onRowOutOfViewportRange, (e: any, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) => {\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowOutOfViewportRange === 'function') {\n              this.rowDetailViewOptions.onRowOutOfViewportRange(e, args);\n            }\n          });\n        }\n\n        // --\n        // hook some events needed by the Plugin itself\n\n        // we need to redraw the open detail views if we change column position (column reorder)\n        this.eventHandler.subscribe(this._grid.onColumnsReordered, this.redrawAllViewComponents.bind(this));\n\n        // on row selection changed, we also need to redraw\n        if (this.gridOptions.enableRowSelection || this.gridOptions.enableCheckboxSelector) {\n          this.eventHandler.subscribe(this._grid.onSelectedRowsChanged, this.redrawAllViewComponents.bind(this));\n        }\n\n        // on sort, all row detail are collapsed so we can dispose of all the Views as well\n        this.eventHandler.subscribe(this._grid.onSort, this.disposeAllViewComponents.bind(this));\n\n        // on filter changed, we need to re-render all Views\n        this._subscriptions.push(\n          this.eventPubSubService?.subscribe('onFilterChanged', this.redrawAllViewComponents.bind(this)),\n          this.eventPubSubService?.subscribe('onGridMenuClearAllFilters', () => setTimeout(() => this.redrawAllViewComponents())),\n          this.eventPubSubService?.subscribe('onGridMenuClearAllSorting', () => setTimeout(() => this.redrawAllViewComponents())),\n        );\n      }\n    }\n    return this;\n  }\n\n  /** Redraw (re-render) all the expanded row detail View Components */\n  redrawAllViewComponents() {\n    this._views.forEach((compRef) => {\n      this.redrawViewComponent(compRef);\n    });\n  }\n\n  /** Render all the expanded row detail View Components */\n  renderAllViewComponents() {\n    this._views.forEach((view) => {\n      if (view?.dataContext) {\n        this.renderViewModel(view.dataContext);\n      }\n    });\n  }\n\n  /** Redraw the necessary View Component */\n  redrawViewComponent(createdView: CreatedView) {\n    const containerElements = this.gridContainerElement.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${createdView.id}`);\n    if (containerElements?.length >= 0) {\n      this.renderViewModel(createdView.dataContext);\n    }\n  }\n\n  /** Render (or re-render) the View Component (Row Detail) */\n  renderPreloadView() {\n    const containerElements = this.gridContainerElement.getElementsByClassName(`${PRELOAD_CONTAINER_PREFIX}`);\n    if (containerElements?.length >= 0) {\n      this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1], true);\n    }\n  }\n\n  /** Render (or re-render) the View Component (Row Detail) */\n  renderViewModel(item: any): CreatedView | undefined {\n    const containerElements = this.gridContainerElement.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`);\n    if (containerElements?.length > 0) {\n      const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], true);\n      if (componentOutput && componentOutput.componentRef && componentOutput.componentRef.instance) {\n        // pass a few properties to the Row Detail template component\n        Object.assign(componentOutput.componentRef.instance, {\n          model: item,\n          addon: this,\n          grid: this._grid,\n          dataView: this.dataView,\n          parent: this.rowDetailViewOptions?.parent,\n        });\n\n        const viewObj = this._views.find(obj => obj.id === item[this.datasetIdPropName]);\n        if (viewObj) {\n          viewObj.componentRef = componentOutput.componentRef;\n        }\n        return viewObj;\n      }\n    }\n    return undefined;\n  }\n\n  // --\n  // protected functions\n  // ------------------\n\n  protected disposeViewComponent(expandedView: CreatedView): CreatedView | void {\n    const compRef = expandedView?.componentRef;\n    if (compRef) {\n      this.appRef.detachView(compRef.hostView);\n      if (compRef?.destroy) {\n        compRef.destroy();\n      }\n      return expandedView;\n    }\n  }\n\n  /**\n   * notify the onAsyncResponse with the \"args.item\" (required property)\n   * the plugin will then use item to populate the row detail panel with the \"postTemplate\"\n   * @param item\n   */\n  protected notifyTemplate(item: any) {\n    if (this.onAsyncResponse) {\n      this.onAsyncResponse.notify({ item }, undefined, this);\n    }\n  }\n\n  /**\n   * On Processing, we will notify the plugin with the new item detail once backend server call completes\n   * @param item\n   */\n  protected async onProcessing(item: any) {\n    if (item && typeof this._userProcessFn === 'function') {\n      let awaitedItemDetail: any;\n      const userProcessFn = this._userProcessFn(item);\n\n      // wait for the \"userProcessFn\", once resolved we will save it into the \"collection\"\n      const response: any | any[] = await userProcessFn;\n\n      if (response.hasOwnProperty(this.datasetIdPropName)) {\n        awaitedItemDetail = response; // from Promise\n      } else if (response && response instanceof Observable || response instanceof Promise) {\n        awaitedItemDetail = await castObservableToPromise(this.rxjs as RxJsFacade, response); // from Angular-http-client\n      }\n\n      if (!awaitedItemDetail || !awaitedItemDetail.hasOwnProperty(this.datasetIdPropName)) {\n        throw new Error(`[Angular-Slickgrid] could not process the Row Detail, you must make sure that your \"process\" callback\n          (a Promise or an HttpClient call returning an Observable) returns an item object that has an \"${this.datasetIdPropName}\" property`);\n      }\n\n      // notify the plugin with the new item details\n      this.notifyTemplate(awaitedItemDetail || {});\n    }\n  }\n\n  /**\n   * Just before the row get expanded or collapsed we will do the following\n   * First determine if the row is expanding or collapsing,\n   * if it's expanding we will add it to our View Components reference array if we don't already have it\n   * or if it's collapsing we will remove it from our View Components reference array\n   */\n  protected handleOnBeforeRowDetailToggle(e: Event, args: { grid: SlickGrid; item: any; }) {\n    // expanding\n    if (args && args.item && args.item.__collapsed) {\n      // expanding row detail\n      const viewInfo: CreatedView = {\n        id: args.item[this.datasetIdPropName],\n        dataContext: args.item\n      };\n      const idPropName = this.gridOptions.datasetIdPropertyName || 'id';\n      addToArrayWhenNotExists(this._views, viewInfo, idPropName);\n    } else {\n      // collapsing, so dispose of the View/Component\n      const foundViewIndex = this._views.findIndex((view: CreatedView) => view.id === args.item[this.datasetIdPropName]);\n      if (foundViewIndex >= 0 && this._views.hasOwnProperty(foundViewIndex)) {\n        const compRef = this._views[foundViewIndex].componentRef;\n        if (compRef) {\n          this.appRef.detachView(compRef.hostView);\n          compRef.destroy();\n        }\n        this._views.splice(foundViewIndex, 1);\n      }\n    }\n  }\n\n  /** When Row comes back to Viewport Range, we need to redraw the View */\n  protected handleOnRowBackToViewportRange(e: Event, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) {\n    if (args?.item) {\n      this.redrawAllViewComponents();\n    }\n  }\n}\n"]}
305
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slickRowDetailView.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/extensions/slickRowDetailView.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, ComponentRef, Type, ViewContainerRef } from '@angular/core';\nimport type { EventSubscription, RxJsFacade, SlickEventHandler, SlickGrid } from '@slickgrid-universal/common';\nimport { addToArrayWhenNotExists, castObservableToPromise, SlickRowSelectionModel, unsubscribeAll } from '@slickgrid-universal/common';\nimport { EventPubSubService } from '@slickgrid-universal/event-pub-sub';\nimport { SlickRowDetailView as UniversalSlickRowDetailView } from '@slickgrid-universal/row-detail-view-plugin';\nimport { Observable, Subject } from 'rxjs';\nimport * as DOMPurify from 'dompurify';\n\nimport { GridOption, RowDetailView } from '../models/index';\nimport { AngularUtilService } from '../services/angularUtil.service';\n\nconst ROW_DETAIL_CONTAINER_PREFIX = 'container_';\nconst PRELOAD_CONTAINER_PREFIX = 'container_loading';\n\nexport interface CreatedView {\n  id: string | number;\n  dataContext: any;\n  componentRef?: ComponentRef<any>;\n}\n\nexport class SlickRowDetailView extends UniversalSlickRowDetailView {\n  rowDetailContainer!: ViewContainerRef;\n  protected _preloadComponent: Type<object> | undefined;\n  protected _views: CreatedView[] = [];\n  protected _viewComponent!: Type<object>;\n  protected _subscriptions: EventSubscription[] = [];\n  protected _userProcessFn!: (item: any) => Promise<any> | Observable<any> | Subject<any>;\n\n  constructor(\n    protected readonly angularUtilService: AngularUtilService,\n    protected readonly appRef: ApplicationRef,\n    protected readonly eventPubSubService: EventPubSubService,\n    protected readonly gridContainerElement: HTMLDivElement,\n    protected rxjs?: RxJsFacade,\n  ) {\n    super(eventPubSubService);\n  }\n\n  get addonOptions() {\n    return this.getOptions();\n  }\n\n  protected get datasetIdPropName(): string {\n    return this.gridOptions.datasetIdPropertyName || 'id';\n  }\n\n  get eventHandler(): SlickEventHandler {\n    return this._eventHandler;\n  }\n  set eventHandler(eventHandler: SlickEventHandler) {\n    this._eventHandler = eventHandler;\n  }\n\n  /** Getter for the Grid Options pulled through the Grid Object */\n  get gridOptions(): GridOption {\n    return (this._grid?.getOptions() || {}) as GridOption;\n  }\n\n  get rowDetailViewOptions(): RowDetailView | undefined {\n    return this.gridOptions.rowDetailView;\n  }\n\n  addRxJsResource(rxjs: RxJsFacade) {\n    this.rxjs = rxjs;\n  }\n\n  /** Dispose of the RowDetailView Extension */\n  dispose() {\n    this.disposeAllViewComponents();\n    this._subscriptions = unsubscribeAll(this._subscriptions); // also unsubscribe all RxJS subscriptions\n    super.dispose();\n  }\n\n  /** Dispose of all the opened Row Detail Panels Angular View Components */\n  disposeAllViewComponents() {\n    this._views.forEach((compRef) => this.disposeViewComponent(compRef));\n    this._views = [];\n  }\n\n  /** Get the instance of the SlickGrid addon (control or plugin). */\n  getAddonInstance(): SlickRowDetailView | null {\n    return this;\n  }\n\n  init(grid: SlickGrid) {\n    this._grid = grid;\n    super.init(this._grid);\n    this.register(grid?.getSelectionModel());\n  }\n\n  /**\n   * Create the plugin before the Grid creation, else it will behave oddly.\n   * Mostly because the column definitions might change after the grid creation\n   */\n  register(rowSelectionPlugin?: SlickRowSelectionModel) {\n    if (typeof this.gridOptions.rowDetailView?.process === 'function') {\n      // we need to keep the user \"process\" method and replace it with our own execution method\n      // we do this because when we get the item detail, we need to call \"onAsyncResponse.notify\" for the plugin to work\n      this._userProcessFn = this.gridOptions.rowDetailView.process as (item: any) => Promise<any>;                // keep user's process method\n      this.addonOptions.process = (item) => this.onProcessing(item);  // replace process method & run our internal one\n    } else {\n      throw new Error('[Angular-Slickgrid] You need to provide a \"process\" function for the Row Detail Extension to work properly');\n    }\n\n    if (this._grid && this.gridOptions?.rowDetailView) {\n      // load the Preload & RowDetail Templates (could be straight HTML or Angular View/ViewModel)\n      // when those are Angular View/ViewModel, we need to create View Component & provide the html containers to the Plugin (preTemplate/postTemplate methods)\n      if (!this.gridOptions.rowDetailView.preTemplate) {\n        this._preloadComponent = this.gridOptions?.rowDetailView?.preloadComponent;\n        this.addonOptions.preTemplate = () => DOMPurify.sanitize(`<div class=\"${PRELOAD_CONTAINER_PREFIX}\"></div>`);\n      }\n      if (!this.gridOptions.rowDetailView.postTemplate) {\n        this._viewComponent = this.gridOptions?.rowDetailView?.viewComponent;\n        this.addonOptions.postTemplate = (itemDetail: any) => DOMPurify.sanitize(`<div class=\"${ROW_DETAIL_CONTAINER_PREFIX}${itemDetail[this.datasetIdPropName]}\"></div>`);\n      }\n\n      // this also requires the Row Selection Model to be registered as well\n      if (!rowSelectionPlugin || !this._grid.getSelectionModel()) {\n        rowSelectionPlugin = new SlickRowSelectionModel(this.gridOptions.rowSelectionOptions || { selectActiveRow: true });\n        this._grid.setSelectionModel(rowSelectionPlugin);\n      }\n\n      // hook all events\n      if (this._grid && this.rowDetailViewOptions) {\n        if (this.rowDetailViewOptions.onExtensionRegistered) {\n          this.rowDetailViewOptions.onExtensionRegistered(this);\n        }\n\n        if (this.onAsyncResponse) {\n          this.eventHandler.subscribe(this.onAsyncResponse, (event, args) => {\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncResponse === 'function') {\n              this.rowDetailViewOptions.onAsyncResponse(event, args);\n            }\n          });\n        }\n\n        if (this.onAsyncEndUpdate) {\n          this.eventHandler.subscribe(this.onAsyncEndUpdate, (e: any, args: { grid: SlickGrid; item: any; }) => {\n            // triggers after backend called \"onAsyncResponse.notify()\"\n            this.renderViewModel(args?.item);\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncEndUpdate === 'function') {\n              this.rowDetailViewOptions.onAsyncEndUpdate(e, args);\n            }\n          });\n        }\n\n        if (this.onAfterRowDetailToggle) {\n          this.eventHandler.subscribe(this.onAfterRowDetailToggle, (e: any, args: { grid: SlickGrid; item: any; expandedRows: number[]; }) => {\n            // display preload template & re-render all the other Detail Views after toggling\n            // the preload View will eventually go away once the data gets loaded after the \"onAsyncEndUpdate\" event\n            this.renderPreloadView();\n            this.renderAllViewComponents();\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAfterRowDetailToggle === 'function') {\n              this.rowDetailViewOptions.onAfterRowDetailToggle(e, args);\n            }\n          });\n        }\n\n        if (this.onBeforeRowDetailToggle) {\n          this.eventHandler.subscribe(this.onBeforeRowDetailToggle, (e, args) => {\n            // before toggling row detail, we need to create View Component if it doesn't exist\n            this.handleOnBeforeRowDetailToggle(e, args);\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onBeforeRowDetailToggle === 'function') {\n              this.rowDetailViewOptions.onBeforeRowDetailToggle(e, args);\n            }\n          });\n        }\n\n        if (this.onRowBackToViewportRange) {\n          this.eventHandler.subscribe(this.onRowBackToViewportRange, (e: any, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) => {\n            // when row is back to viewport range, we will re-render the View Component(s)\n            this.handleOnRowBackToViewportRange(e, args);\n\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowBackToViewportRange === 'function') {\n              this.rowDetailViewOptions.onRowBackToViewportRange(e, args);\n            }\n          });\n        }\n\n        if (this.onRowOutOfViewportRange) {\n          this.eventHandler.subscribe(this.onRowOutOfViewportRange, (e: any, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) => {\n            if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowOutOfViewportRange === 'function') {\n              this.rowDetailViewOptions.onRowOutOfViewportRange(e, args);\n            }\n          });\n        }\n\n        // --\n        // hook some events needed by the Plugin itself\n\n        // we need to redraw the open detail views if we change column position (column reorder)\n        this.eventHandler.subscribe(this._grid.onColumnsReordered, this.redrawAllViewComponents.bind(this));\n\n        // on row selection changed, we also need to redraw\n        if (this.gridOptions.enableRowSelection || this.gridOptions.enableCheckboxSelector) {\n          this.eventHandler.subscribe(this._grid.onSelectedRowsChanged, this.redrawAllViewComponents.bind(this));\n        }\n\n        // on sort, all row detail are collapsed so we can dispose of all the Views as well\n        this.eventHandler.subscribe(this._grid.onSort, this.disposeAllViewComponents.bind(this));\n\n        // on filter changed, we need to re-render all Views\n        this._subscriptions.push(\n          this.eventPubSubService?.subscribe('onFilterChanged', this.redrawAllViewComponents.bind(this)),\n          this.eventPubSubService?.subscribe('onGridMenuClearAllFilters', () => setTimeout(() => this.redrawAllViewComponents())),\n          this.eventPubSubService?.subscribe('onGridMenuClearAllSorting', () => setTimeout(() => this.redrawAllViewComponents())),\n        );\n      }\n    }\n    return this;\n  }\n\n  /** Redraw (re-render) all the expanded row detail View Components */\n  redrawAllViewComponents() {\n    this._views.forEach((compRef) => {\n      this.redrawViewComponent(compRef);\n    });\n  }\n\n  /** Render all the expanded row detail View Components */\n  renderAllViewComponents() {\n    this._views.forEach((view) => {\n      if (view?.dataContext) {\n        this.renderViewModel(view.dataContext);\n      }\n    });\n  }\n\n  /** Redraw the necessary View Component */\n  redrawViewComponent(createdView: CreatedView) {\n    const containerElements = this.gridContainerElement.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${createdView.id}`);\n    if (containerElements?.length >= 0) {\n      this.renderViewModel(createdView.dataContext);\n    }\n  }\n\n  /** Render (or re-render) the View Component (Row Detail) */\n  renderPreloadView() {\n    const containerElements = this.gridContainerElement.getElementsByClassName(`${PRELOAD_CONTAINER_PREFIX}`) as HTMLCollectionOf<HTMLElement>;\n    if (this._preloadComponent && containerElements?.length >= 0) {\n      this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1]);\n    }\n  }\n\n  /** Render (or re-render) the View Component (Row Detail) */\n  renderViewModel(item: any): CreatedView | undefined {\n    const containerElements = this.gridContainerElement.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`) as HTMLCollectionOf<HTMLElement>;\n    if (this._viewComponent && containerElements?.length > 0) {\n      const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], {\n        model: item,\n        addon: this,\n        grid: this._grid,\n        dataView: this.dataView,\n        parent: this.rowDetailViewOptions?.parent,\n      });\n      if (componentOutput?.componentRef) {\n        const viewObj = this._views.find(obj => obj.id === item[this.datasetIdPropName]);\n        if (viewObj) {\n          viewObj.componentRef = componentOutput.componentRef;\n        }\n        return viewObj;\n      }\n    }\n    return undefined;\n  }\n\n  // --\n  // protected functions\n  // ------------------\n\n  protected disposeViewComponent(expandedView: CreatedView): CreatedView | void {\n    const compRef = expandedView?.componentRef;\n    if (compRef) {\n      this.appRef.detachView(compRef.hostView);\n      if (compRef?.destroy) {\n        compRef.destroy();\n      }\n      return expandedView;\n    }\n  }\n\n  /**\n   * notify the onAsyncResponse with the \"args.item\" (required property)\n   * the plugin will then use item to populate the row detail panel with the \"postTemplate\"\n   * @param item\n   */\n  protected notifyTemplate(item: any) {\n    if (this.onAsyncResponse) {\n      this.onAsyncResponse.notify({ item }, undefined, this);\n    }\n  }\n\n  /**\n   * On Processing, we will notify the plugin with the new item detail once backend server call completes\n   * @param item\n   */\n  protected async onProcessing(item: any) {\n    if (item && typeof this._userProcessFn === 'function') {\n      let awaitedItemDetail: any;\n      const userProcessFn = this._userProcessFn(item);\n\n      // wait for the \"userProcessFn\", once resolved we will save it into the \"collection\"\n      const response: any | any[] = await userProcessFn;\n\n      if (response.hasOwnProperty(this.datasetIdPropName)) {\n        awaitedItemDetail = response; // from Promise\n      } else if (response && response instanceof Observable || response instanceof Promise) {\n        awaitedItemDetail = await castObservableToPromise(this.rxjs as RxJsFacade, response); // from Angular-http-client\n      }\n\n      if (!awaitedItemDetail || !awaitedItemDetail.hasOwnProperty(this.datasetIdPropName)) {\n        throw new Error(`[Angular-Slickgrid] could not process the Row Detail, you must make sure that your \"process\" callback\n          (a Promise or an HttpClient call returning an Observable) returns an item object that has an \"${this.datasetIdPropName}\" property`);\n      }\n\n      // notify the plugin with the new item details\n      this.notifyTemplate(awaitedItemDetail || {});\n    }\n  }\n\n  /**\n   * Just before the row get expanded or collapsed we will do the following\n   * First determine if the row is expanding or collapsing,\n   * if it's expanding we will add it to our View Components reference array if we don't already have it\n   * or if it's collapsing we will remove it from our View Components reference array\n   */\n  protected handleOnBeforeRowDetailToggle(e: Event, args: { grid: SlickGrid; item: any; }) {\n    // expanding\n    if (args && args.item && args.item.__collapsed) {\n      // expanding row detail\n      const viewInfo: CreatedView = {\n        id: args.item[this.datasetIdPropName],\n        dataContext: args.item\n      };\n      const idPropName = this.gridOptions.datasetIdPropertyName || 'id';\n      addToArrayWhenNotExists(this._views, viewInfo, idPropName);\n    } else {\n      // collapsing, so dispose of the View/Component\n      const foundViewIndex = this._views.findIndex((view: CreatedView) => view.id === args.item[this.datasetIdPropName]);\n      if (foundViewIndex >= 0 && this._views.hasOwnProperty(foundViewIndex)) {\n        const compRef = this._views[foundViewIndex].componentRef;\n        if (compRef) {\n          this.appRef.detachView(compRef.hostView);\n          compRef.destroy();\n        }\n        this._views.splice(foundViewIndex, 1);\n      }\n    }\n  }\n\n  /** When Row comes back to Viewport Range, we need to redraw the View */\n  protected handleOnRowBackToViewportRange(e: Event, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) {\n    if (args?.item) {\n      this.redrawAllViewComponents();\n    }\n  }\n}\n"]}
@@ -17,13 +17,13 @@ export class AngularSlickgridModule {
17
17
  ]
18
18
  };
19
19
  }
20
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularSlickgridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
21
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.3", ngImport: i0, type: AngularSlickgridModule, declarations: [AngularSlickgridComponent], imports: [CommonModule,
20
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularSlickgridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
21
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.8", ngImport: i0, type: AngularSlickgridModule, declarations: [AngularSlickgridComponent], imports: [CommonModule,
22
22
  TranslateModule], exports: [AngularSlickgridComponent] });
23
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularSlickgridModule, imports: [CommonModule,
23
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularSlickgridModule, imports: [CommonModule,
24
24
  TranslateModule] });
25
25
  }
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularSlickgridModule, decorators: [{
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularSlickgridModule, decorators: [{
27
27
  type: NgModule,
28
28
  args: [{
29
29
  imports: [
@@ -5,35 +5,62 @@ export class AngularUtilService {
5
5
  constructor(vcr) {
6
6
  this.vcr = vcr;
7
7
  }
8
- createAngularComponent(component) {
8
+ /**
9
+ * Dynamically create an Angular component, user could also provide optional arguments for target, data & createComponent options
10
+ * @param {Component} component
11
+ * @param {HTMLElement} [targetElement]
12
+ * @param {*} [data]
13
+ * @param {CreateComponentOption} [createCompOptions]
14
+ * @returns
15
+ */
16
+ createAngularComponent(component, targetElement, data, createCompOptions) {
9
17
  // Create a component reference from the component
10
- const componentRef = this.vcr.createComponent(component);
18
+ const componentRef = this.vcr.createComponent(component, createCompOptions);
19
+ // user could provide data to assign to the component instance
20
+ if (componentRef?.instance && data) {
21
+ Object.assign(componentRef.instance, data);
22
+ // NOTE: detectChanges() MUST be doene BEFORE returning the DOM element in the next step,
23
+ // because if we do it only after returning the rootNodes (domElement) then it won't have the instance data yet
24
+ // and we would have to wait an extra cycle to see the result, this basically helps with Example22
25
+ componentRef.changeDetectorRef.detectChanges();
26
+ }
11
27
  // Get DOM element from component
12
- let domElem;
28
+ let domElem = null;
13
29
  const viewRef = componentRef.hostView;
30
+ // get DOM element from the new dynamic Component, make sure this is read after any data and detectChanges()
14
31
  if (viewRef && Array.isArray(viewRef.rootNodes) && viewRef.rootNodes[0]) {
15
32
  domElem = viewRef.rootNodes[0];
33
+ // when user provides the DOM element target, we will read the new Component html and use it to replace the target html
34
+ if (targetElement && domElem) {
35
+ targetElement.innerHTML = domElem.innerHTML;
36
+ }
16
37
  }
17
38
  return { componentRef, domElement: domElem };
18
39
  }
19
- createAngularComponentAppendToDom(component, targetElement, clearTargetContent = false) {
20
- const componentOutput = this.createAngularComponent(component);
40
+ /**
41
+ * Dynamically create an Angular component and append it to the DOM unless a target element is provided,
42
+ * user could also provide other optional arguments for data & createComponent options.
43
+ * @param {Component} component
44
+ * @param {HTMLElement} [targetElement]
45
+ * @param {*} [data]
46
+ * @param {CreateComponentOption} [createCompOptions]
47
+ * @returns
48
+ */
49
+ createAngularComponentAppendToDom(component, targetElement, data, createCompOptions) {
50
+ const componentOutput = this.createAngularComponent(component, targetElement, data, createCompOptions);
21
51
  // Append DOM element to the HTML element specified
22
- if (targetElement?.appendChild) {
23
- if (clearTargetContent && targetElement.innerHTML) {
24
- targetElement.innerHTML = '';
25
- }
26
- targetElement.appendChild(componentOutput.domElement);
52
+ if (targetElement?.replaceChildren) {
53
+ targetElement.replaceChildren(componentOutput.domElement);
27
54
  }
28
55
  else {
29
56
  document.body.appendChild(componentOutput.domElement); // when no target provided, we'll simply add it to the HTML Body
30
57
  }
31
58
  return componentOutput;
32
59
  }
33
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularUtilService, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Injectable });
34
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularUtilService });
60
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularUtilService, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Injectable });
61
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularUtilService });
35
62
  }
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AngularUtilService, decorators: [{
63
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: AngularUtilService, decorators: [{
37
64
  type: Injectable
38
65
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhclV0aWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9hbmd1bGFyLXNsaWNrZ3JpZC9zZXJ2aWNlcy9hbmd1bGFyVXRpbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBbUIsVUFBVSxFQUFvQixNQUFNLGVBQWUsQ0FBQzs7QUFLOUUsTUFBTSxPQUFPLGtCQUFrQjtJQUVUO0lBQXBCLFlBQW9CLEdBQXFCO1FBQXJCLFFBQUcsR0FBSCxHQUFHLENBQWtCO0lBQUksQ0FBQztJQUU5QyxzQkFBc0IsQ0FBQyxTQUFjO1FBQ25DLGtEQUFrRDtRQUNsRCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUV6RCxpQ0FBaUM7UUFDakMsSUFBSSxPQUFPLENBQUM7UUFDWixNQUFNLE9BQU8sR0FBSSxZQUFZLENBQUMsUUFBaUMsQ0FBQztRQUNoRSxJQUFJLE9BQU8sSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3ZFLE9BQU8sR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBZ0IsQ0FBQztTQUMvQztRQUVELE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE9BQXNCLEVBQUUsQ0FBQztJQUM5RCxDQUFDO0lBRUQsaUNBQWlDLENBQUMsU0FBYyxFQUFFLGFBQXFDLEVBQUUsa0JBQWtCLEdBQUcsS0FBSztRQUNqSCxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsU0FBUyxDQUFDLENBQUM7UUFFL0QsbURBQW1EO1FBQ25ELElBQUksYUFBYSxFQUFFLFdBQVcsRUFBRTtZQUM5QixJQUFJLGtCQUFrQixJQUFJLGFBQWEsQ0FBQyxTQUFTLEVBQUU7Z0JBQ2pELGFBQWEsQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO2FBQzlCO1lBQ0QsYUFBYSxDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLENBQUM7U0FDdkQ7YUFBTTtZQUNMLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLGdFQUFnRTtTQUN4SDtRQUVELE9BQU8sZUFBZSxDQUFDO0lBQ3pCLENBQUM7dUdBaENVLGtCQUFrQjsyR0FBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRW1iZWRkZWRWaWV3UmVmLCBJbmplY3RhYmxlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB0eXBlIHsgQW5ndWxhckNvbXBvbmVudE91dHB1dCB9IGZyb20gJy4uL21vZGVscy9hbmd1bGFyQ29tcG9uZW50T3V0cHV0LmludGVyZmFjZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBBbmd1bGFyVXRpbFNlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdmNyOiBWaWV3Q29udGFpbmVyUmVmKSB7IH1cblxuICBjcmVhdGVBbmd1bGFyQ29tcG9uZW50KGNvbXBvbmVudDogYW55KTogQW5ndWxhckNvbXBvbmVudE91dHB1dCB7XG4gICAgLy8gQ3JlYXRlIGEgY29tcG9uZW50IHJlZmVyZW5jZSBmcm9tIHRoZSBjb21wb25lbnRcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLnZjci5jcmVhdGVDb21wb25lbnQoY29tcG9uZW50KTtcblxuICAgIC8vIEdldCBET00gZWxlbWVudCBmcm9tIGNvbXBvbmVudFxuICAgIGxldCBkb21FbGVtO1xuICAgIGNvbnN0IHZpZXdSZWYgPSAoY29tcG9uZW50UmVmLmhvc3RWaWV3IGFzIEVtYmVkZGVkVmlld1JlZjxhbnk+KTtcbiAgICBpZiAodmlld1JlZiAmJiBBcnJheS5pc0FycmF5KHZpZXdSZWYucm9vdE5vZGVzKSAmJiB2aWV3UmVmLnJvb3ROb2Rlc1swXSkge1xuICAgICAgZG9tRWxlbSA9IHZpZXdSZWYucm9vdE5vZGVzWzBdIGFzIEhUTUxFbGVtZW50O1xuICAgIH1cblxuICAgIHJldHVybiB7IGNvbXBvbmVudFJlZiwgZG9tRWxlbWVudDogZG9tRWxlbSBhcyBIVE1MRWxlbWVudCB9O1xuICB9XG5cbiAgY3JlYXRlQW5ndWxhckNvbXBvbmVudEFwcGVuZFRvRG9tKGNvbXBvbmVudDogYW55LCB0YXJnZXRFbGVtZW50PzogSFRNTEVsZW1lbnQgfCBFbGVtZW50LCBjbGVhclRhcmdldENvbnRlbnQgPSBmYWxzZSk6IEFuZ3VsYXJDb21wb25lbnRPdXRwdXQge1xuICAgIGNvbnN0IGNvbXBvbmVudE91dHB1dCA9IHRoaXMuY3JlYXRlQW5ndWxhckNvbXBvbmVudChjb21wb25lbnQpO1xuXG4gICAgLy8gQXBwZW5kIERPTSBlbGVtZW50IHRvIHRoZSBIVE1MIGVsZW1lbnQgc3BlY2lmaWVkXG4gICAgaWYgKHRhcmdldEVsZW1lbnQ/LmFwcGVuZENoaWxkKSB7XG4gICAgICBpZiAoY2xlYXJUYXJnZXRDb250ZW50ICYmIHRhcmdldEVsZW1lbnQuaW5uZXJIVE1MKSB7XG4gICAgICAgIHRhcmdldEVsZW1lbnQuaW5uZXJIVE1MID0gJyc7XG4gICAgICB9XG4gICAgICB0YXJnZXRFbGVtZW50LmFwcGVuZENoaWxkKGNvbXBvbmVudE91dHB1dC5kb21FbGVtZW50KTtcbiAgICB9IGVsc2Uge1xuICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChjb21wb25lbnRPdXRwdXQuZG9tRWxlbWVudCk7IC8vIHdoZW4gbm8gdGFyZ2V0IHByb3ZpZGVkLCB3ZSdsbCBzaW1wbHkgYWRkIGl0IHRvIHRoZSBIVE1MIEJvZHlcbiAgICB9XG5cbiAgICByZXR1cm4gY29tcG9uZW50T3V0cHV0O1xuICB9XG59XG4iXX0=
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhclV0aWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9hbmd1bGFyLXNsaWNrZ3JpZC9zZXJ2aWNlcy9hbmd1bGFyVXRpbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQW9CLE1BQU0sZUFBZSxDQUFDOztBQWU3RCxNQUFNLE9BQU8sa0JBQWtCO0lBRVQ7SUFBcEIsWUFBb0IsR0FBcUI7UUFBckIsUUFBRyxHQUFILEdBQUcsQ0FBa0I7SUFBSSxDQUFDO0lBRTlDOzs7Ozs7O09BT0c7SUFDSCxzQkFBc0IsQ0FBSSxTQUFrQixFQUFFLGFBQXVCLEVBQUUsSUFBVSxFQUFFLGlCQUF5QztRQUMxSCxrREFBa0Q7UUFDbEQsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsU0FBUyxFQUFFLGlCQUFpQixDQUFDLENBQUM7UUFFNUUsOERBQThEO1FBQzlELElBQUksWUFBWSxFQUFFLFFBQVEsSUFBSSxJQUFJLEVBQUU7WUFDbEMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsUUFBZSxFQUFFLElBQUksQ0FBQyxDQUFDO1lBRWxELHlGQUF5RjtZQUN6RiwrR0FBK0c7WUFDL0csa0dBQWtHO1lBQ2xHLFlBQVksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztTQUNoRDtRQUVELGlDQUFpQztRQUNqQyxJQUFJLE9BQU8sR0FBdUIsSUFBSSxDQUFDO1FBQ3ZDLE1BQU0sT0FBTyxHQUFJLFlBQVksQ0FBQyxRQUFpQyxDQUFDO1FBRWhFLDRHQUE0RztRQUM1RyxJQUFJLE9BQU8sSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3ZFLE9BQU8sR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBZ0IsQ0FBQztZQUU5Qyx1SEFBdUg7WUFDdkgsSUFBSSxhQUFhLElBQUksT0FBTyxFQUFFO2dCQUM1QixhQUFhLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUM7YUFDN0M7U0FDRjtRQUVELE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE9BQXNCLEVBQUUsQ0FBQztJQUM5RCxDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSCxpQ0FBaUMsQ0FBSSxTQUFrQixFQUFFLGFBQXVCLEVBQUUsSUFBVSxFQUFFLGlCQUF5QztRQUNySSxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsU0FBUyxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztRQUV2RyxtREFBbUQ7UUFDbkQsSUFBSSxhQUFhLEVBQUUsZUFBZSxFQUFFO1lBQ2xDLGFBQWEsQ0FBQyxlQUFlLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQzNEO2FBQU07WUFDTCxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxnRUFBZ0U7U0FDeEg7UUFFRCxPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDO3VHQS9EVSxrQkFBa0I7MkdBQWxCLGtCQUFrQjs7MkZBQWxCLGtCQUFrQjtrQkFEOUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHsgRW1iZWRkZWRWaWV3UmVmLCBFbnZpcm9ubWVudEluamVjdG9yLCBJbmplY3RvciwgTmdNb2R1bGVSZWYsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHR5cGUgeyBBbmd1bGFyQ29tcG9uZW50T3V0cHV0IH0gZnJvbSAnLi4vbW9kZWxzL2FuZ3VsYXJDb21wb25lbnRPdXRwdXQuaW50ZXJmYWNlJztcblxuXG5pbnRlcmZhY2UgQ3JlYXRlQ29tcG9uZW50T3B0aW9uIHtcbiAgaW5kZXg/OiBudW1iZXI7XG4gIGluamVjdG9yPzogSW5qZWN0b3I7XG4gIG5nTW9kdWxlUmVmPzogTmdNb2R1bGVSZWY8dW5rbm93bj47XG4gIGVudmlyb25tZW50SW5qZWN0b3I/OiBFbnZpcm9ubWVudEluamVjdG9yIHwgTmdNb2R1bGVSZWY8dW5rbm93bj47XG4gIHByb2plY3RhYmxlTm9kZXM/OiBOb2RlW11bXTtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEFuZ3VsYXJVdGlsU2VydmljZSB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB2Y3I6IFZpZXdDb250YWluZXJSZWYpIHsgfVxuXG4gIC8qKlxuICAgKiBEeW5hbWljYWxseSBjcmVhdGUgYW4gQW5ndWxhciBjb21wb25lbnQsIHVzZXIgY291bGQgYWxzbyBwcm92aWRlIG9wdGlvbmFsIGFyZ3VtZW50cyBmb3IgdGFyZ2V0LCBkYXRhICYgY3JlYXRlQ29tcG9uZW50IG9wdGlvbnNcbiAgICogQHBhcmFtIHtDb21wb25lbnR9IGNvbXBvbmVudFxuICAgKiBAcGFyYW0ge0hUTUxFbGVtZW50fSBbdGFyZ2V0RWxlbWVudF1cbiAgICogQHBhcmFtIHsqfSBbZGF0YV1cbiAgICogQHBhcmFtIHtDcmVhdGVDb21wb25lbnRPcHRpb259IFtjcmVhdGVDb21wT3B0aW9uc11cbiAgICogQHJldHVybnNcbiAgICovXG4gIGNyZWF0ZUFuZ3VsYXJDb21wb25lbnQ8Qz4oY29tcG9uZW50OiBUeXBlPEM+LCB0YXJnZXRFbGVtZW50PzogRWxlbWVudCwgZGF0YT86IGFueSwgY3JlYXRlQ29tcE9wdGlvbnM/OiBDcmVhdGVDb21wb25lbnRPcHRpb24pOiBBbmd1bGFyQ29tcG9uZW50T3V0cHV0IHtcbiAgICAvLyBDcmVhdGUgYSBjb21wb25lbnQgcmVmZXJlbmNlIGZyb20gdGhlIGNvbXBvbmVudFxuICAgIGNvbnN0IGNvbXBvbmVudFJlZiA9IHRoaXMudmNyLmNyZWF0ZUNvbXBvbmVudChjb21wb25lbnQsIGNyZWF0ZUNvbXBPcHRpb25zKTtcblxuICAgIC8vIHVzZXIgY291bGQgcHJvdmlkZSBkYXRhIHRvIGFzc2lnbiB0byB0aGUgY29tcG9uZW50IGluc3RhbmNlXG4gICAgaWYgKGNvbXBvbmVudFJlZj8uaW5zdGFuY2UgJiYgZGF0YSkge1xuICAgICAgT2JqZWN0LmFzc2lnbihjb21wb25lbnRSZWYuaW5zdGFuY2UgYXMgYW55LCBkYXRhKTtcblxuICAgICAgLy8gTk9URTogZGV0ZWN0Q2hhbmdlcygpIE1VU1QgYmUgZG9lbmUgQkVGT1JFIHJldHVybmluZyB0aGUgRE9NIGVsZW1lbnQgaW4gdGhlIG5leHQgc3RlcCxcbiAgICAgIC8vIGJlY2F1c2UgaWYgd2UgZG8gaXQgb25seSBhZnRlciByZXR1cm5pbmcgdGhlIHJvb3ROb2RlcyAoZG9tRWxlbWVudCkgdGhlbiBpdCB3b24ndCBoYXZlIHRoZSBpbnN0YW5jZSBkYXRhIHlldFxuICAgICAgLy8gYW5kIHdlIHdvdWxkIGhhdmUgdG8gd2FpdCBhbiBleHRyYSBjeWNsZSB0byBzZWUgdGhlIHJlc3VsdCwgdGhpcyBiYXNpY2FsbHkgaGVscHMgd2l0aCBFeGFtcGxlMjJcbiAgICAgIGNvbXBvbmVudFJlZi5jaGFuZ2VEZXRlY3RvclJlZi5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgfVxuXG4gICAgLy8gR2V0IERPTSBlbGVtZW50IGZyb20gY29tcG9uZW50XG4gICAgbGV0IGRvbUVsZW06IEhUTUxFbGVtZW50IHwgbnVsbCA9IG51bGw7XG4gICAgY29uc3Qgdmlld1JlZiA9IChjb21wb25lbnRSZWYuaG9zdFZpZXcgYXMgRW1iZWRkZWRWaWV3UmVmPGFueT4pO1xuXG4gICAgLy8gZ2V0IERPTSBlbGVtZW50IGZyb20gdGhlIG5ldyBkeW5hbWljIENvbXBvbmVudCwgbWFrZSBzdXJlIHRoaXMgaXMgcmVhZCBhZnRlciBhbnkgZGF0YSBhbmQgZGV0ZWN0Q2hhbmdlcygpXG4gICAgaWYgKHZpZXdSZWYgJiYgQXJyYXkuaXNBcnJheSh2aWV3UmVmLnJvb3ROb2RlcykgJiYgdmlld1JlZi5yb290Tm9kZXNbMF0pIHtcbiAgICAgIGRvbUVsZW0gPSB2aWV3UmVmLnJvb3ROb2Rlc1swXSBhcyBIVE1MRWxlbWVudDtcblxuICAgICAgLy8gd2hlbiB1c2VyIHByb3ZpZGVzIHRoZSBET00gZWxlbWVudCB0YXJnZXQsIHdlIHdpbGwgcmVhZCB0aGUgbmV3IENvbXBvbmVudCBodG1sIGFuZCB1c2UgaXQgdG8gcmVwbGFjZSB0aGUgdGFyZ2V0IGh0bWxcbiAgICAgIGlmICh0YXJnZXRFbGVtZW50ICYmIGRvbUVsZW0pIHtcbiAgICAgICAgdGFyZ2V0RWxlbWVudC5pbm5lckhUTUwgPSBkb21FbGVtLmlubmVySFRNTDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4geyBjb21wb25lbnRSZWYsIGRvbUVsZW1lbnQ6IGRvbUVsZW0gYXMgSFRNTEVsZW1lbnQgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBEeW5hbWljYWxseSBjcmVhdGUgYW4gQW5ndWxhciBjb21wb25lbnQgYW5kIGFwcGVuZCBpdCB0byB0aGUgRE9NIHVubGVzcyBhIHRhcmdldCBlbGVtZW50IGlzIHByb3ZpZGVkLFxuICAgKiB1c2VyIGNvdWxkIGFsc28gcHJvdmlkZSBvdGhlciBvcHRpb25hbCBhcmd1bWVudHMgZm9yIGRhdGEgJiBjcmVhdGVDb21wb25lbnQgb3B0aW9ucy5cbiAgICogQHBhcmFtIHtDb21wb25lbnR9IGNvbXBvbmVudFxuICAgKiBAcGFyYW0ge0hUTUxFbGVtZW50fSBbdGFyZ2V0RWxlbWVudF1cbiAgICogQHBhcmFtIHsqfSBbZGF0YV1cbiAgICogQHBhcmFtIHtDcmVhdGVDb21wb25lbnRPcHRpb259IFtjcmVhdGVDb21wT3B0aW9uc11cbiAgICogQHJldHVybnNcbiAgICovXG4gIGNyZWF0ZUFuZ3VsYXJDb21wb25lbnRBcHBlbmRUb0RvbTxDPihjb21wb25lbnQ6IFR5cGU8Qz4sIHRhcmdldEVsZW1lbnQ/OiBFbGVtZW50LCBkYXRhPzogYW55LCBjcmVhdGVDb21wT3B0aW9ucz86IENyZWF0ZUNvbXBvbmVudE9wdGlvbik6IEFuZ3VsYXJDb21wb25lbnRPdXRwdXQge1xuICAgIGNvbnN0IGNvbXBvbmVudE91dHB1dCA9IHRoaXMuY3JlYXRlQW5ndWxhckNvbXBvbmVudChjb21wb25lbnQsIHRhcmdldEVsZW1lbnQsIGRhdGEsIGNyZWF0ZUNvbXBPcHRpb25zKTtcblxuICAgIC8vIEFwcGVuZCBET00gZWxlbWVudCB0byB0aGUgSFRNTCBlbGVtZW50IHNwZWNpZmllZFxuICAgIGlmICh0YXJnZXRFbGVtZW50Py5yZXBsYWNlQ2hpbGRyZW4pIHtcbiAgICAgIHRhcmdldEVsZW1lbnQucmVwbGFjZUNoaWxkcmVuKGNvbXBvbmVudE91dHB1dC5kb21FbGVtZW50KTtcbiAgICB9IGVsc2Uge1xuICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChjb21wb25lbnRPdXRwdXQuZG9tRWxlbWVudCk7IC8vIHdoZW4gbm8gdGFyZ2V0IHByb3ZpZGVkLCB3ZSdsbCBzaW1wbHkgYWRkIGl0IHRvIHRoZSBIVE1MIEJvZHlcbiAgICB9XG5cbiAgICByZXR1cm4gY29tcG9uZW50T3V0cHV0O1xuICB9XG59XG4iXX0=
@@ -18,10 +18,10 @@ export class ContainerService {
18
18
  this.dependencies.push({ key, instance });
19
19
  }
20
20
  }
21
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
22
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerService });
21
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: ContainerService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
22
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: ContainerService });
23
23
  }
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ContainerService, decorators: [{
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: ContainerService, decorators: [{
25
25
  type: Injectable
26
26
  }] });
27
27
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvYW5ndWxhci1zbGlja2dyaWQvc2VydmljZXMvY29udGFpbmVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQixZQUFZLEdBQXdCLEVBQUUsQ0FBQztJQUV2QyxHQUFHLENBQVUsR0FBVztRQUN0QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEtBQUssR0FBRyxDQUFDLENBQUM7UUFDbEUsSUFBSSxVQUFVLEVBQUUsUUFBUSxFQUFFO1lBQ3hCLE9BQU8sVUFBVSxDQUFDLFFBQVEsQ0FBQztTQUM1QjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsWUFBWSxHQUFHLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsR0FBVyxFQUFFLFFBQWE7UUFDekMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDZixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1NBQzNDO0lBQ0gsQ0FBQzt1R0FwQlUsZ0JBQWdCOzJHQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBRDVCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyB0eXBlIENvbnRhaW5lckluc3RhbmNlLCBDb250YWluZXJTZXJ2aWNlIGFzIFVuaXZlcnNhbENvbnRhaW5lclNlcnZpY2UgfSBmcm9tICdAc2xpY2tncmlkLXVuaXZlcnNhbC9jb21tb24nO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgQ29udGFpbmVyU2VydmljZSBpbXBsZW1lbnRzIFVuaXZlcnNhbENvbnRhaW5lclNlcnZpY2Uge1xuICBkZXBlbmRlbmNpZXM6IENvbnRhaW5lckluc3RhbmNlW10gPSBbXTtcblxuICBnZXQ8VCA9IGFueT4oa2V5OiBzdHJpbmcpOiBUIHwgbnVsbCB7XG4gICAgY29uc3QgZGVwZW5kZW5jeSA9IHRoaXMuZGVwZW5kZW5jaWVzLmZpbmQoZGVwID0+IGRlcC5rZXkgPT09IGtleSk7XG4gICAgaWYgKGRlcGVuZGVuY3k/Lmluc3RhbmNlKSB7XG4gICAgICByZXR1cm4gZGVwZW5kZW5jeS5pbnN0YW5jZTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBkaXNwb3NlKCkge1xuICAgIHRoaXMuZGVwZW5kZW5jaWVzID0gW107XG4gIH1cblxuICByZWdpc3Rlckluc3RhbmNlKGtleTogc3RyaW5nLCBpbnN0YW5jZTogYW55KSB7XG4gICAgY29uc3QgZGVwZW5kZW5jeSA9IHRoaXMuZGVwZW5kZW5jaWVzLnNvbWUoZGVwID0+IGRlcC5rZXkgPT09IGtleSk7XG4gICAgaWYgKCFkZXBlbmRlbmN5KSB7XG4gICAgICB0aGlzLmRlcGVuZGVuY2llcy5wdXNoKHsga2V5LCBpbnN0YW5jZSB9KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -33,10 +33,10 @@ export class TranslaterService {
33
33
  translate(translationKey) {
34
34
  return this.translateService?.instant?.(translationKey || ' ');
35
35
  }
36
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TranslaterService, deps: [{ token: i1.TranslateService, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
37
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TranslaterService });
36
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: TranslaterService, deps: [{ token: i1.TranslateService, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
37
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: TranslaterService });
38
38
  }
39
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TranslaterService, decorators: [{
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.8", ngImport: i0, type: TranslaterService, decorators: [{
40
40
  type: Injectable
41
41
  }], ctorParameters: function () { return [{ type: i1.TranslateService, decorators: [{
42
42
  type: Optional