angular-slickgrid 8.13.0 → 8.13.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,4 @@
1
- import { addToArrayWhenNotExists, castObservableToPromise, SlickRowSelectionModel, unsubscribeAll, } from '@slickgrid-universal/common';
1
+ import { addToArrayWhenNotExists, castObservableToPromise, SlickEventData, SlickRowSelectionModel, unsubscribeAll, } from '@slickgrid-universal/common';
2
2
  import { SlickRowDetailView as UniversalSlickRowDetailView } from '@slickgrid-universal/row-detail-view-plugin';
3
3
  import { Observable } from 'rxjs';
4
4
  const ROW_DETAIL_CONTAINER_PREFIX = 'container_';
@@ -11,6 +11,7 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
11
11
  rxjs;
12
12
  rowDetailContainer;
13
13
  _preloadComponent;
14
+ _preloadCompRef;
14
15
  _views = [];
15
16
  _viewComponent;
16
17
  _subscriptions = [];
@@ -53,8 +54,12 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
53
54
  }
54
55
  /** Dispose of all the opened Row Detail Panels Angular View Components */
55
56
  disposeAllViewComponents() {
56
- this._views.forEach((compRef) => this.disposeViewComponent(compRef));
57
- this._views = [];
57
+ do {
58
+ const view = this._views.pop();
59
+ if (view) {
60
+ this.disposeView(view);
61
+ }
62
+ } while (this._views.length > 0);
58
63
  }
59
64
  /** Get the instance of the SlickGrid addon (control or plugin). */
60
65
  getAddonInstance() {
@@ -109,6 +114,8 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
109
114
  }
110
115
  if (this.onAsyncEndUpdate) {
111
116
  this.eventHandler.subscribe(this.onAsyncEndUpdate, (e, args) => {
117
+ // destroy preload if exists
118
+ this._preloadCompRef?.destroy();
112
119
  // triggers after backend called "onAsyncResponse.notify()"
113
120
  this.renderViewModel(args?.item);
114
121
  if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncEndUpdate === 'function') {
@@ -121,7 +128,6 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
121
128
  // display preload template & re-render all the other Detail Views after toggling
122
129
  // the preload View will eventually go away once the data gets loaded after the "onAsyncEndUpdate" event
123
130
  this.renderPreloadView();
124
- this.renderAllViewComponents();
125
131
  if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAfterRowDetailToggle === 'function') {
126
132
  this.rowDetailViewOptions.onAfterRowDetailToggle(e, args);
127
133
  }
@@ -146,6 +152,14 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
146
152
  }
147
153
  });
148
154
  }
155
+ if (this.onBeforeRowOutOfViewportRange) {
156
+ this._eventHandler.subscribe(this.onBeforeRowOutOfViewportRange, (event, args) => {
157
+ if (typeof this.rowDetailViewOptions?.onBeforeRowOutOfViewportRange === 'function') {
158
+ this.rowDetailViewOptions.onBeforeRowOutOfViewportRange(event, args);
159
+ }
160
+ this.disposeViewByItem(args.item);
161
+ });
162
+ }
149
163
  if (this.onRowOutOfViewportRange) {
150
164
  this.eventHandler.subscribe(this.onRowOutOfViewportRange, (e, args) => {
151
165
  if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowOutOfViewportRange === 'function') {
@@ -171,15 +185,10 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
171
185
  }
172
186
  /** Redraw (re-render) all the expanded row detail View Components */
173
187
  redrawAllViewComponents() {
174
- this._views.forEach((compRef) => {
175
- this.redrawViewComponent(compRef);
176
- });
177
- }
178
- /** Render all the expanded row detail View Components */
179
- renderAllViewComponents() {
188
+ this.resetRenderedRows();
180
189
  this._views.forEach((view) => {
181
- if (view?.dataContext) {
182
- this.renderViewModel(view.dataContext);
190
+ if (!view.rendered) {
191
+ this.redrawViewComponent(view);
183
192
  }
184
193
  });
185
194
  }
@@ -194,24 +203,29 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
194
203
  renderPreloadView() {
195
204
  const containerElements = this.gridContainerElement.getElementsByClassName(`${PRELOAD_CONTAINER_PREFIX}`);
196
205
  if (this._preloadComponent && containerElements?.length >= 0) {
197
- this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1]);
206
+ const preloadComp = this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1], {}, { sanitizer: this._grid.sanitizeHtmlString });
207
+ this._preloadCompRef = preloadComp.componentRef;
198
208
  }
199
209
  }
200
210
  /** Render (or re-render) the View Component (Row Detail) */
201
211
  renderViewModel(item) {
202
212
  const containerElements = this.gridContainerElement.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`);
203
213
  if (this._viewComponent && containerElements?.length > 0) {
214
+ // render row detail
204
215
  const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], {
205
216
  model: item,
206
217
  addon: this,
207
218
  grid: this._grid,
208
219
  dataView: this.dataView,
209
220
  parent: this.rowDetailViewOptions?.parent,
221
+ }, {
222
+ sanitizer: this._grid.sanitizeHtmlString,
210
223
  });
211
224
  if (componentOutput?.componentRef) {
212
225
  const viewObj = this._views.find((obj) => obj.id === item[this.datasetIdPropName]);
213
226
  if (viewObj) {
214
227
  viewObj.componentRef = componentOutput.componentRef;
228
+ viewObj.rendered = true;
215
229
  }
216
230
  return viewObj;
217
231
  }
@@ -221,12 +235,23 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
221
235
  // --
222
236
  // protected functions
223
237
  // ------------------
224
- disposeViewComponent(expandedView) {
238
+ disposeViewByItem(item, removeFromArray = false) {
239
+ const foundViewIndex = this._views.findIndex((view) => view.id === item[this.datasetIdPropName]);
240
+ if (foundViewIndex >= 0 && foundViewIndex in this._views) {
241
+ const expandedView = this._views[foundViewIndex];
242
+ this.disposeView(expandedView);
243
+ if (removeFromArray) {
244
+ this._views.splice(foundViewIndex, 1);
245
+ }
246
+ }
247
+ }
248
+ disposeView(expandedView) {
225
249
  const compRef = expandedView?.componentRef;
226
250
  if (compRef) {
227
251
  this.appRef.detachView(compRef.hostView);
228
252
  if (compRef?.destroy) {
229
253
  compRef.destroy();
254
+ expandedView.rendered = false;
230
255
  }
231
256
  return expandedView;
232
257
  }
@@ -238,7 +263,7 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
238
263
  */
239
264
  notifyTemplate(item) {
240
265
  if (this.onAsyncResponse) {
241
- this.onAsyncResponse.notify({ item, itemDetail: item }, undefined, this);
266
+ this.onAsyncResponse.notify({ item, itemDetail: item }, new SlickEventData(), this);
242
267
  }
243
268
  }
244
269
  /**
@@ -278,28 +303,22 @@ export class SlickRowDetailView extends UniversalSlickRowDetailView {
278
303
  const viewInfo = {
279
304
  id: args.item[this.datasetIdPropName],
280
305
  dataContext: args.item,
306
+ rendered: false,
281
307
  };
282
308
  const idPropName = this.gridOptions.datasetIdPropertyName || 'id';
283
309
  addToArrayWhenNotExists(this._views, viewInfo, idPropName);
284
310
  }
285
311
  else {
286
312
  // collapsing, so dispose of the View/Component
287
- const foundViewIndex = this._views.findIndex((view) => view.id === args.item[this.datasetIdPropName]);
288
- if (foundViewIndex >= 0 && foundViewIndex in this._views) {
289
- const compRef = this._views[foundViewIndex].componentRef;
290
- if (compRef) {
291
- this.appRef.detachView(compRef.hostView);
292
- compRef.destroy();
293
- }
294
- this._views.splice(foundViewIndex, 1);
295
- }
313
+ this.disposeViewByItem(args.item, true);
296
314
  }
297
315
  }
298
316
  /** When Row comes back to Viewport Range, we need to redraw the View */
299
317
  handleOnRowBackToViewportRange(_e, args) {
300
- if (args?.item) {
301
- this.redrawAllViewComponents();
318
+ const viewModel = Array.from(this._views).find((x) => x.id === args.rowId);
319
+ if (viewModel && !viewModel.rendered) {
320
+ this.redrawViewComponent(viewModel);
302
321
  }
303
322
  }
304
323
  }
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 type { ApplicationRef, ComponentRef, Type, ViewContainerRef } from '@angular/core';\nimport type {\n  EventSubscription,\n  OnBeforeRowDetailToggleArgs,\n  OnRowBackToViewportRangeArgs,\n  RxJsFacade,\n  SlickEventData,\n  SlickEventHandler,\n  SlickGrid,\n} from '@slickgrid-universal/common';\nimport {\n  addToArrayWhenNotExists,\n  castObservableToPromise,\n  SlickRowSelectionModel,\n  unsubscribeAll,\n} from '@slickgrid-universal/common';\nimport type { EventPubSubService } from '@slickgrid-universal/event-pub-sub';\nimport { SlickRowDetailView as UniversalSlickRowDetailView } from '@slickgrid-universal/row-detail-view-plugin';\nimport { Observable, type Subject } from 'rxjs';\n\nimport type { GridOption, RowDetailView } from '../models/index';\nimport type { 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() as SlickRowSelectionModel);\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(\n        '[Angular-Slickgrid] You need to provide a \"process\" function for the Row Detail Extension to work properly'\n      );\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 = () =>\n          this._grid.sanitizeHtmlString(`<div class=\"${PRELOAD_CONTAINER_PREFIX}\"></div>`) as string;\n      }\n      if (!this.gridOptions.rowDetailView.postTemplate) {\n        this._viewComponent = this.gridOptions?.rowDetailView?.viewComponent;\n        this.addonOptions.postTemplate = (itemDetail: any) =>\n          this._grid.sanitizeHtmlString(\n            `<div class=\"${ROW_DETAIL_CONTAINER_PREFIX}${itemDetail[this.datasetIdPropName]}\"></div>`\n          ) as string;\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, args) => {\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(\n            this.onAfterRowDetailToggle,\n            (e: any, args: { grid: SlickGrid; item: any; expandedRows: Array<number | string> }) => {\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\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              return this.rowDetailViewOptions.onBeforeRowDetailToggle(e, args);\n            }\n            return true;\n          });\n        }\n\n        if (this.onRowBackToViewportRange) {\n          this.eventHandler.subscribe(this.onRowBackToViewportRange, (e, args) => {\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, args) => {\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        // redraw all Views whenever certain events are triggered\n        this._subscriptions.push(\n          this.eventPubSubService?.subscribe(\n            ['onFilterChanged', 'onGridMenuColumnsChanged', 'onColumnPickerColumnsChanged'],\n            this.redrawAllViewComponents.bind(this)\n          ),\n          this.eventPubSubService?.subscribe(['onGridMenuClearAllFilters', 'onGridMenuClearAllSorting'], () =>\n            window.setTimeout(() => this.redrawAllViewComponents())\n          )\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(\n      `${PRELOAD_CONTAINER_PREFIX}`\n    ) as HTMLCollectionOf<HTMLElement>;\n    if (this._preloadComponent && containerElements?.length >= 0) {\n      this.angularUtilService.createAngularComponentAppendToDom(\n        this._preloadComponent,\n        containerElements[containerElements.length - 1]\n      );\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(\n      `${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`\n    ) as HTMLCollectionOf<HTMLElement>;\n    if (this._viewComponent && containerElements?.length > 0) {\n      const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(\n        this._viewComponent,\n        containerElements[containerElements.length - 1],\n        {\n          model: item,\n          addon: this,\n          grid: this._grid,\n          dataView: this.dataView,\n          parent: this.rowDetailViewOptions?.parent,\n        }\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, itemDetail: 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 (this.datasetIdPropName in response) {\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 || !(this.datasetIdPropName in awaitedItemDetail)) {\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: SlickEventData<OnBeforeRowDetailToggleArgs>, args: { grid: SlickGrid; item: any }) {\n    // expanding\n    if (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 && foundViewIndex in this._views) {\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: SlickEventData<OnRowBackToViewportRangeArgs>, args: OnRowBackToViewportRangeArgs) {\n    if (args?.item) {\n      this.redrawAllViewComponents();\n    }\n  }\n}\n"]}
324
+ //# 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 type { ApplicationRef, ComponentRef, Type, ViewContainerRef } from '@angular/core';\nimport type {\n  EventSubscription,\n  OnBeforeRowDetailToggleArgs,\n  OnRowBackToViewportRangeArgs,\n  RxJsFacade,\n  SlickEventHandler,\n  SlickGrid,\n} from '@slickgrid-universal/common';\nimport {\n  addToArrayWhenNotExists,\n  castObservableToPromise,\n  SlickEventData,\n  SlickRowSelectionModel,\n  unsubscribeAll,\n} from '@slickgrid-universal/common';\nimport type { EventPubSubService } from '@slickgrid-universal/event-pub-sub';\nimport { SlickRowDetailView as UniversalSlickRowDetailView } from '@slickgrid-universal/row-detail-view-plugin';\nimport { Observable, type Subject } from 'rxjs';\n\nimport type { GridOption, RowDetailView } from '../models/index';\nimport type { 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  rendered?: boolean;\n}\n\nexport class SlickRowDetailView extends UniversalSlickRowDetailView {\n  rowDetailContainer!: ViewContainerRef;\n  protected _preloadComponent: Type<object> | undefined;\n  protected _preloadCompRef?: ComponentRef<any>;\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    do {\n      const view = this._views.pop();\n      if (view) {\n        this.disposeView(view);\n      }\n    } while (this._views.length > 0);\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() as SlickRowSelectionModel);\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(\n        '[Angular-Slickgrid] You need to provide a \"process\" function for the Row Detail Extension to work properly'\n      );\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 = () =>\n          this._grid.sanitizeHtmlString(`<div class=\"${PRELOAD_CONTAINER_PREFIX}\"></div>`) as string;\n      }\n      if (!this.gridOptions.rowDetailView.postTemplate) {\n        this._viewComponent = this.gridOptions?.rowDetailView?.viewComponent;\n        this.addonOptions.postTemplate = (itemDetail: any) =>\n          this._grid.sanitizeHtmlString(\n            `<div class=\"${ROW_DETAIL_CONTAINER_PREFIX}${itemDetail[this.datasetIdPropName]}\"></div>`\n          ) as string;\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, args) => {\n            // destroy preload if exists\n            this._preloadCompRef?.destroy();\n\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(\n            this.onAfterRowDetailToggle,\n            (e: any, args: { grid: SlickGrid; item: any; expandedRows: Array<number | string> }) => {\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\n              if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAfterRowDetailToggle === 'function') {\n                this.rowDetailViewOptions.onAfterRowDetailToggle(e, args);\n              }\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              return this.rowDetailViewOptions.onBeforeRowDetailToggle(e, args);\n            }\n            return true;\n          });\n        }\n\n        if (this.onRowBackToViewportRange) {\n          this.eventHandler.subscribe(this.onRowBackToViewportRange, (e, args) => {\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.onBeforeRowOutOfViewportRange) {\n          this._eventHandler.subscribe(this.onBeforeRowOutOfViewportRange, (event, args) => {\n            if (typeof this.rowDetailViewOptions?.onBeforeRowOutOfViewportRange === 'function') {\n              this.rowDetailViewOptions.onBeforeRowOutOfViewportRange(event, args);\n            }\n            this.disposeViewByItem(args.item);\n          });\n        }\n\n        if (this.onRowOutOfViewportRange) {\n          this.eventHandler.subscribe(this.onRowOutOfViewportRange, (e, args) => {\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        // redraw all Views whenever certain events are triggered\n        this._subscriptions.push(\n          this.eventPubSubService?.subscribe(\n            ['onFilterChanged', 'onGridMenuColumnsChanged', 'onColumnPickerColumnsChanged'],\n            this.redrawAllViewComponents.bind(this)\n          ),\n          this.eventPubSubService?.subscribe(['onGridMenuClearAllFilters', 'onGridMenuClearAllSorting'], () =>\n            window.setTimeout(() => this.redrawAllViewComponents())\n          )\n        );\n      }\n    }\n    return this;\n  }\n\n  /** Redraw (re-render) all the expanded row detail View Components */\n  redrawAllViewComponents() {\n    this.resetRenderedRows();\n    this._views.forEach((view) => {\n      if (!view.rendered) {\n        this.redrawViewComponent(view);\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(\n      `${PRELOAD_CONTAINER_PREFIX}`\n    ) as HTMLCollectionOf<HTMLElement>;\n    if (this._preloadComponent && containerElements?.length >= 0) {\n      const preloadComp = this.angularUtilService.createAngularComponentAppendToDom(\n        this._preloadComponent,\n        containerElements[containerElements.length - 1],\n        {},\n        { sanitizer: this._grid.sanitizeHtmlString }\n      );\n      this._preloadCompRef = preloadComp.componentRef;\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(\n      `${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`\n    ) as HTMLCollectionOf<HTMLElement>;\n\n    if (this._viewComponent && containerElements?.length > 0) {\n      // render row detail\n      const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(\n        this._viewComponent,\n        containerElements[containerElements.length - 1],\n        {\n          model: item,\n          addon: this,\n          grid: this._grid,\n          dataView: this.dataView,\n          parent: this.rowDetailViewOptions?.parent,\n        },\n        {\n          sanitizer: this._grid.sanitizeHtmlString,\n        }\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          viewObj.rendered = true;\n        }\n        return viewObj;\n      }\n    }\n    return undefined;\n  }\n\n  // --\n  // protected functions\n  // ------------------\n\n  protected disposeViewByItem(item: any, removeFromArray = false): void {\n    const foundViewIndex = this._views.findIndex((view: CreatedView) => view.id === item[this.datasetIdPropName]);\n    if (foundViewIndex >= 0 && foundViewIndex in this._views) {\n      const expandedView = this._views[foundViewIndex];\n      this.disposeView(expandedView);\n      if (removeFromArray) {\n        this._views.splice(foundViewIndex, 1);\n      }\n    }\n  }\n\n  protected disposeView(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        expandedView.rendered = false;\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, itemDetail: item }, new SlickEventData(), 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 (this.datasetIdPropName in response) {\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 || !(this.datasetIdPropName in awaitedItemDetail)) {\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: SlickEventData<OnBeforeRowDetailToggleArgs>, args: { grid: SlickGrid; item: any }) {\n    // expanding\n    if (args?.item?.__collapsed) {\n      // expanding row detail\n      const viewInfo: CreatedView = {\n        id: args.item[this.datasetIdPropName],\n        dataContext: args.item,\n        rendered: false,\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      this.disposeViewByItem(args.item, true);\n    }\n  }\n\n  /** When Row comes back to Viewport Range, we need to redraw the View */\n  protected handleOnRowBackToViewportRange(_e: SlickEventData<OnRowBackToViewportRangeArgs>, args: OnRowBackToViewportRangeArgs) {\n    const viewModel = Array.from(this._views).find((x) => x.id === args.rowId);\n    if (viewModel && !viewModel.rendered) {\n      this.redrawViewComponent(viewModel);\n    }\n  }\n}\n"]}
@@ -220,7 +220,6 @@ export const GlobalGridOptions = {
220
220
  panelRows: 1,
221
221
  keyPrefix: '__',
222
222
  useRowClick: false,
223
- useSimpleViewportCalc: true,
224
223
  saveDetailViewOnScroll: false,
225
224
  },
226
225
  rowHeight: 35,
@@ -261,4 +260,4 @@ function pickerHeaderColumnValueExtractor(column, gridOptions) {
261
260
  }
262
261
  return colName;
263
262
  }
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-grid-options.js","sourceRoot":"","sources":["../../../../../src/app/modules/angular-slickgrid/global-grid-options.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  type Column,\n  DelimiterType,\n  EventNamingStyle,\n  FileType,\n  Filters,\n  type GridOption as GridOptionUniversal,\n  OperatorType,\n  type TreeDataOption,\n} from '@slickgrid-universal/common';\nimport type { GridOption, RowDetailView } from './models/index';\n\n/** Global Grid Options Defaults */\nexport const GlobalGridOptions: Partial<GridOption> = {\n  alwaysShowVerticalScroll: true,\n  autoEdit: false,\n  asyncEditorLoading: false,\n  autoFitColumnsOnFirstLoad: true,\n  autoResize: {\n    applyResizeToContainer: true,\n    autoHeight: true,\n    autoHeightRecalcRow: 100,\n    calculateAvailableSizeBy: 'window',\n    bottomPadding: 20,\n    minHeight: 250,\n    minWidth: 300,\n    rightPadding: 0,\n  },\n  cellHighlightCssClass: 'slick-cell-modified',\n  checkboxSelector: {\n    cssClass: 'slick-cell-checkboxsel',\n  },\n  columnPicker: {\n    hideForceFitButton: false,\n    hideSyncResizeButton: true,\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor,\n  },\n  cellMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideCommandSection: false,\n    hideOptionSection: false,\n  },\n  contextMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideClearAllGrouping: false,\n    hideCollapseAllGroups: false,\n    hideCommandSection: false,\n    hideCopyCellValueCommand: false,\n    hideExpandAllGroups: false,\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideMenuOnScroll: true,\n    hideOptionSection: false,\n    iconCollapseAllGroupsCommand: 'mdi mdi-arrow-collapse',\n    iconExpandAllGroupsCommand: 'mdi mdi-arrow-expand',\n    iconClearGroupingCommand: 'mdi mdi-close',\n    iconCopyCellValueCommand: 'mdi mdi-content-copy',\n    iconExportCsvCommand: 'mdi mdi-download',\n    iconExportExcelCommand: 'mdi mdi-file-excel-outline',\n    iconExportTextDelimitedCommand: 'mdi mdi-download',\n    showBulletWhenIconMissing: true,\n    subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270',\n  },\n  customFooterOptions: {\n    dateFormat: 'YYYY-MM-DD, hh:mm a',\n    hideRowSelectionCount: false,\n    hideTotalItemCount: false,\n    hideLastUpdateTimestamp: true,\n    footerHeight: 25,\n    leftContainerClass: 'col-xs-12 col-sm-5',\n    rightContainerClass: 'col-xs-6 col-sm-7',\n    metricSeparator: '|',\n    metricTexts: {\n      items: 'items',\n      itemsKey: 'ITEMS',\n      itemsSelected: 'items selected',\n      itemsSelectedKey: 'ITEMS_SELECTED',\n      of: 'of',\n      ofKey: 'OF',\n    },\n  },\n  dataView: {\n    // when enabled, this will preserve the row selection even after filtering/sorting/grouping\n    syncGridSelection: {\n      preserveHidden: false,\n      preserveHiddenOnSelectionChange: true,\n    },\n    syncGridSelectionWithBackendService: false, // but disable it when using backend services\n  },\n  datasetIdPropertyName: 'id',\n  defaultFilter: Filters.input,\n  defaultBackendServiceFilterTypingDebounce: 500,\n  defaultColumnSortFieldId: 'id',\n  defaultFilterPlaceholder: '🔎︎',\n  defaultFilterRangeOperator: OperatorType.rangeInclusive,\n  editable: false,\n  enableAutoResize: true,\n  enableAutoSizeColumns: true,\n  enableCellNavigation: false,\n  enableColumnPicker: true,\n  enableColumnReorder: true,\n  enableColumnResizeOnDoubleClick: true,\n  enableContextMenu: true,\n  enableExcelExport: false,\n  enableTextExport: false, // CSV/Text with Tab Delimited\n  enableFilterTrimWhiteSpace: false, // do we want to trim white spaces on all Filters?\n  enableGridMenu: true,\n  enableHeaderMenu: true,\n  enableEmptyDataWarningMessage: true,\n  emptyDataWarning: {\n    className: 'slick-empty-data-warning',\n    message: 'No data to display.',\n    messageKey: 'EMPTY_DATA_WARNING_MESSAGE',\n    hideFrozenLeftWarning: false,\n    hideFrozenRightWarning: false,\n    leftViewportMarginLeft: '40%',\n    rightViewportMarginLeft: '40%',\n    frozenLeftViewportMarginLeft: '0px',\n    frozenRightViewportMarginLeft: '40%',\n  },\n  enableMouseHoverHighlightRow: true,\n  enableSorting: true,\n  enableTextSelectionOnCells: true,\n  eventNamingStyle: EventNamingStyle.camelCase,\n  explicitInitialization: true,\n  excelExportOptions: {\n    addGroupIndentation: true,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.xlsx,\n    groupingColumnHeaderTitle: 'Group By',\n    groupCollapsedSymbol: '⮞',\n    groupExpandedSymbol: '⮟',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n  },\n  textExportOptions: {\n    delimiter: DelimiterType.comma,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.csv,\n    groupingColumnHeaderTitle: 'Group By',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n    useUtf8WithBom: true,\n  },\n  filterTypingDebounce: 0,\n  forceFitColumns: false,\n  frozenHeaderWidthCalcDifferential: 0,\n  gridMenu: {\n    dropSide: 'left',\n    commandLabels: {\n      clearAllFiltersCommandKey: 'CLEAR_ALL_FILTERS',\n      clearAllSortingCommandKey: 'CLEAR_ALL_SORTING',\n      clearFrozenColumnsCommandKey: 'CLEAR_PINNING',\n      exportCsvCommandKey: 'EXPORT_TO_CSV',\n      exportExcelCommandKey: 'EXPORT_TO_EXCEL',\n      exportTextDelimitedCommandKey: 'EXPORT_TO_TAB_DELIMITED',\n      refreshDatasetCommandKey: 'REFRESH_DATASET',\n      toggleDarkModeCommandKey: 'TOGGLE_DARK_MODE',\n      toggleFilterCommandKey: 'TOGGLE_FILTER_ROW',\n      togglePreHeaderCommandKey: 'TOGGLE_PRE_HEADER_ROW',\n    },\n    hideClearAllFiltersCommand: false,\n    hideClearAllSortingCommand: false,\n    hideClearFrozenColumnsCommand: true, // opt-in command\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideForceFitButton: false,\n    hideRefreshDatasetCommand: false,\n    hideSyncResizeButton: true,\n    hideToggleDarkModeCommand: true,\n    hideToggleFilterCommand: false,\n    hideTogglePreHeaderCommand: false,\n    iconCssClass: 'mdi mdi-menu',\n    iconClearAllFiltersCommand: 'mdi mdi-filter-remove-outline',\n    iconClearAllSortingCommand: 'mdi mdi-sort-variant-off',\n    iconClearFrozenColumnsCommand: 'mdi mdi-pin-off-outline',\n    iconExportCsvCommand: 'mdi mdi-download',\n    iconExportExcelCommand: 'mdi mdi-file-excel-outline',\n    iconExportTextDelimitedCommand: 'mdi mdi-download',\n    iconRefreshDatasetCommand: 'mdi mdi-sync',\n    iconToggleDarkModeCommand: 'mdi mdi-brightness-4',\n    iconToggleFilterCommand: 'mdi mdi-flip-vertical',\n    iconTogglePreHeaderCommand: 'mdi mdi-flip-vertical',\n    menuWidth: 16,\n    resizeOnShowHeaderRow: true,\n    subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270',\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor,\n  },\n  headerMenu: {\n    autoAlign: true,\n    autoAlignOffset: 12,\n    minWidth: 140,\n    iconClearFilterCommand: 'mdi mdi-filter-remove-outline',\n    iconClearSortCommand: 'mdi mdi-sort-variant-off',\n    iconFreezeColumns: 'mdi mdi-pin-outline',\n    iconSortAscCommand: 'mdi mdi-sort-ascending',\n    iconSortDescCommand: 'mdi mdi-sort-descending',\n    iconColumnHideCommand: 'mdi mdi-close',\n    iconColumnResizeByContentCommand: 'mdi mdi-arrow-expand-horizontal',\n    hideColumnResizeByContentCommand: false,\n    hideColumnHideCommand: false,\n    hideClearFilterCommand: false,\n    hideClearSortCommand: false,\n    hideFreezeColumnsCommand: true, // opt-in command\n    hideSortCommands: false,\n    subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270',\n  },\n  headerRowHeight: 35,\n  multiColumnSort: true,\n  numberedMultiColumnSort: true,\n  tristateMultiColumnSort: false,\n  sortColNumberInSeparateSpan: true,\n  suppressActiveCellChangeOnEdit: false,\n  pagination: {\n    pageSizes: [10, 15, 20, 25, 30, 40, 50, 75, 100],\n    pageSize: 25,\n    totalItems: 0,\n  },\n  // technically speaking the Row Detail requires the process & viewComponent but we'll ignore it just to set certain options\n  rowDetailView: {\n    collapseAllOnSort: true,\n    cssClass: 'detail-view-toggle',\n    panelRows: 1,\n    keyPrefix: '__',\n    useRowClick: false,\n    useSimpleViewportCalc: true,\n    saveDetailViewOnScroll: false,\n  } as RowDetailView,\n  rowHeight: 35,\n  topPanelHeight: 35,\n  preHeaderPanelWidth: '100%', // mostly useful for Draggable Grouping dropzone to take full width\n  translationNamespaceSeparator: ':',\n  resetFilterSearchValueAfterOnBeforeCancellation: true,\n  resizeByContentOnlyOnFirstLoad: true,\n  resizeByContentOptions: {\n    alwaysRecalculateColumnWidth: false,\n    cellCharWidthInPx: 7.8,\n    cellPaddingWidthInPx: 14,\n    defaultRatioForStringType: 0.88,\n    formatterPaddingWidthInPx: 0,\n    maxItemToInspectCellContentWidth: 1000,\n    maxItemToInspectSingleColumnWidthByContent: 5000,\n    widthToRemoveFromExceededWidthReadjustment: 50,\n  },\n  treeDataOptions: {\n    exportIndentMarginLeft: 5,\n    exportIndentationLeadingChar: '͏͏͏͏͏͏͏͏͏·',\n  } as unknown as TreeDataOption,\n};\n\n/**\n * Value Extractor for both ColumnPicker & GridMenu Picker\n * when using Column Header Grouping, we'll prefix the column group title\n * else we'll simply return the column name title\n */\nfunction pickerHeaderColumnValueExtractor(column: Column, gridOptions?: GridOptionUniversal) {\n  let colName = column?.columnPickerLabel ?? column?.name ?? '';\n  if (colName instanceof HTMLElement || colName instanceof DocumentFragment) {\n    colName = colName.textContent || '';\n  }\n  const headerGroup = column?.columnGroup || '';\n  const columnGroupSeparator = gridOptions?.columnGroupSeparator ?? ' - ';\n  if (headerGroup) {\n    return headerGroup + columnGroupSeparator + colName;\n  }\n  return colName;\n}\n"]}
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-grid-options.js","sourceRoot":"","sources":["../../../../../src/app/modules/angular-slickgrid/global-grid-options.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  type Column,\n  DelimiterType,\n  EventNamingStyle,\n  FileType,\n  Filters,\n  type GridOption as GridOptionUniversal,\n  OperatorType,\n  type TreeDataOption,\n} from '@slickgrid-universal/common';\nimport type { GridOption, RowDetailView } from './models/index';\n\n/** Global Grid Options Defaults */\nexport const GlobalGridOptions: Partial<GridOption> = {\n  alwaysShowVerticalScroll: true,\n  autoEdit: false,\n  asyncEditorLoading: false,\n  autoFitColumnsOnFirstLoad: true,\n  autoResize: {\n    applyResizeToContainer: true,\n    autoHeight: true,\n    autoHeightRecalcRow: 100,\n    calculateAvailableSizeBy: 'window',\n    bottomPadding: 20,\n    minHeight: 250,\n    minWidth: 300,\n    rightPadding: 0,\n  },\n  cellHighlightCssClass: 'slick-cell-modified',\n  checkboxSelector: {\n    cssClass: 'slick-cell-checkboxsel',\n  },\n  columnPicker: {\n    hideForceFitButton: false,\n    hideSyncResizeButton: true,\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor,\n  },\n  cellMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideCommandSection: false,\n    hideOptionSection: false,\n  },\n  contextMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideClearAllGrouping: false,\n    hideCollapseAllGroups: false,\n    hideCommandSection: false,\n    hideCopyCellValueCommand: false,\n    hideExpandAllGroups: false,\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideMenuOnScroll: true,\n    hideOptionSection: false,\n    iconCollapseAllGroupsCommand: 'mdi mdi-arrow-collapse',\n    iconExpandAllGroupsCommand: 'mdi mdi-arrow-expand',\n    iconClearGroupingCommand: 'mdi mdi-close',\n    iconCopyCellValueCommand: 'mdi mdi-content-copy',\n    iconExportCsvCommand: 'mdi mdi-download',\n    iconExportExcelCommand: 'mdi mdi-file-excel-outline',\n    iconExportTextDelimitedCommand: 'mdi mdi-download',\n    showBulletWhenIconMissing: true,\n    subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270',\n  },\n  customFooterOptions: {\n    dateFormat: 'YYYY-MM-DD, hh:mm a',\n    hideRowSelectionCount: false,\n    hideTotalItemCount: false,\n    hideLastUpdateTimestamp: true,\n    footerHeight: 25,\n    leftContainerClass: 'col-xs-12 col-sm-5',\n    rightContainerClass: 'col-xs-6 col-sm-7',\n    metricSeparator: '|',\n    metricTexts: {\n      items: 'items',\n      itemsKey: 'ITEMS',\n      itemsSelected: 'items selected',\n      itemsSelectedKey: 'ITEMS_SELECTED',\n      of: 'of',\n      ofKey: 'OF',\n    },\n  },\n  dataView: {\n    // when enabled, this will preserve the row selection even after filtering/sorting/grouping\n    syncGridSelection: {\n      preserveHidden: false,\n      preserveHiddenOnSelectionChange: true,\n    },\n    syncGridSelectionWithBackendService: false, // but disable it when using backend services\n  },\n  datasetIdPropertyName: 'id',\n  defaultFilter: Filters.input,\n  defaultBackendServiceFilterTypingDebounce: 500,\n  defaultColumnSortFieldId: 'id',\n  defaultFilterPlaceholder: '🔎︎',\n  defaultFilterRangeOperator: OperatorType.rangeInclusive,\n  editable: false,\n  enableAutoResize: true,\n  enableAutoSizeColumns: true,\n  enableCellNavigation: false,\n  enableColumnPicker: true,\n  enableColumnReorder: true,\n  enableColumnResizeOnDoubleClick: true,\n  enableContextMenu: true,\n  enableExcelExport: false,\n  enableTextExport: false, // CSV/Text with Tab Delimited\n  enableFilterTrimWhiteSpace: false, // do we want to trim white spaces on all Filters?\n  enableGridMenu: true,\n  enableHeaderMenu: true,\n  enableEmptyDataWarningMessage: true,\n  emptyDataWarning: {\n    className: 'slick-empty-data-warning',\n    message: 'No data to display.',\n    messageKey: 'EMPTY_DATA_WARNING_MESSAGE',\n    hideFrozenLeftWarning: false,\n    hideFrozenRightWarning: false,\n    leftViewportMarginLeft: '40%',\n    rightViewportMarginLeft: '40%',\n    frozenLeftViewportMarginLeft: '0px',\n    frozenRightViewportMarginLeft: '40%',\n  },\n  enableMouseHoverHighlightRow: true,\n  enableSorting: true,\n  enableTextSelectionOnCells: true,\n  eventNamingStyle: EventNamingStyle.camelCase,\n  explicitInitialization: true,\n  excelExportOptions: {\n    addGroupIndentation: true,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.xlsx,\n    groupingColumnHeaderTitle: 'Group By',\n    groupCollapsedSymbol: '⮞',\n    groupExpandedSymbol: '⮟',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n  },\n  textExportOptions: {\n    delimiter: DelimiterType.comma,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.csv,\n    groupingColumnHeaderTitle: 'Group By',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n    useUtf8WithBom: true,\n  },\n  filterTypingDebounce: 0,\n  forceFitColumns: false,\n  frozenHeaderWidthCalcDifferential: 0,\n  gridMenu: {\n    dropSide: 'left',\n    commandLabels: {\n      clearAllFiltersCommandKey: 'CLEAR_ALL_FILTERS',\n      clearAllSortingCommandKey: 'CLEAR_ALL_SORTING',\n      clearFrozenColumnsCommandKey: 'CLEAR_PINNING',\n      exportCsvCommandKey: 'EXPORT_TO_CSV',\n      exportExcelCommandKey: 'EXPORT_TO_EXCEL',\n      exportTextDelimitedCommandKey: 'EXPORT_TO_TAB_DELIMITED',\n      refreshDatasetCommandKey: 'REFRESH_DATASET',\n      toggleDarkModeCommandKey: 'TOGGLE_DARK_MODE',\n      toggleFilterCommandKey: 'TOGGLE_FILTER_ROW',\n      togglePreHeaderCommandKey: 'TOGGLE_PRE_HEADER_ROW',\n    },\n    hideClearAllFiltersCommand: false,\n    hideClearAllSortingCommand: false,\n    hideClearFrozenColumnsCommand: true, // opt-in command\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideForceFitButton: false,\n    hideRefreshDatasetCommand: false,\n    hideSyncResizeButton: true,\n    hideToggleDarkModeCommand: true,\n    hideToggleFilterCommand: false,\n    hideTogglePreHeaderCommand: false,\n    iconCssClass: 'mdi mdi-menu',\n    iconClearAllFiltersCommand: 'mdi mdi-filter-remove-outline',\n    iconClearAllSortingCommand: 'mdi mdi-sort-variant-off',\n    iconClearFrozenColumnsCommand: 'mdi mdi-pin-off-outline',\n    iconExportCsvCommand: 'mdi mdi-download',\n    iconExportExcelCommand: 'mdi mdi-file-excel-outline',\n    iconExportTextDelimitedCommand: 'mdi mdi-download',\n    iconRefreshDatasetCommand: 'mdi mdi-sync',\n    iconToggleDarkModeCommand: 'mdi mdi-brightness-4',\n    iconToggleFilterCommand: 'mdi mdi-flip-vertical',\n    iconTogglePreHeaderCommand: 'mdi mdi-flip-vertical',\n    menuWidth: 16,\n    resizeOnShowHeaderRow: true,\n    subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270',\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor,\n  },\n  headerMenu: {\n    autoAlign: true,\n    autoAlignOffset: 12,\n    minWidth: 140,\n    iconClearFilterCommand: 'mdi mdi-filter-remove-outline',\n    iconClearSortCommand: 'mdi mdi-sort-variant-off',\n    iconFreezeColumns: 'mdi mdi-pin-outline',\n    iconSortAscCommand: 'mdi mdi-sort-ascending',\n    iconSortDescCommand: 'mdi mdi-sort-descending',\n    iconColumnHideCommand: 'mdi mdi-close',\n    iconColumnResizeByContentCommand: 'mdi mdi-arrow-expand-horizontal',\n    hideColumnResizeByContentCommand: false,\n    hideColumnHideCommand: false,\n    hideClearFilterCommand: false,\n    hideClearSortCommand: false,\n    hideFreezeColumnsCommand: true, // opt-in command\n    hideSortCommands: false,\n    subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270',\n  },\n  headerRowHeight: 35,\n  multiColumnSort: true,\n  numberedMultiColumnSort: true,\n  tristateMultiColumnSort: false,\n  sortColNumberInSeparateSpan: true,\n  suppressActiveCellChangeOnEdit: false,\n  pagination: {\n    pageSizes: [10, 15, 20, 25, 30, 40, 50, 75, 100],\n    pageSize: 25,\n    totalItems: 0,\n  },\n  // technically speaking the Row Detail requires the process & viewComponent but we'll ignore it just to set certain options\n  rowDetailView: {\n    collapseAllOnSort: true,\n    cssClass: 'detail-view-toggle',\n    panelRows: 1,\n    keyPrefix: '__',\n    useRowClick: false,\n    saveDetailViewOnScroll: false,\n  } as RowDetailView,\n  rowHeight: 35,\n  topPanelHeight: 35,\n  preHeaderPanelWidth: '100%', // mostly useful for Draggable Grouping dropzone to take full width\n  translationNamespaceSeparator: ':',\n  resetFilterSearchValueAfterOnBeforeCancellation: true,\n  resizeByContentOnlyOnFirstLoad: true,\n  resizeByContentOptions: {\n    alwaysRecalculateColumnWidth: false,\n    cellCharWidthInPx: 7.8,\n    cellPaddingWidthInPx: 14,\n    defaultRatioForStringType: 0.88,\n    formatterPaddingWidthInPx: 0,\n    maxItemToInspectCellContentWidth: 1000,\n    maxItemToInspectSingleColumnWidthByContent: 5000,\n    widthToRemoveFromExceededWidthReadjustment: 50,\n  },\n  treeDataOptions: {\n    exportIndentMarginLeft: 5,\n    exportIndentationLeadingChar: '͏͏͏͏͏͏͏͏͏·',\n  } as unknown as TreeDataOption,\n};\n\n/**\n * Value Extractor for both ColumnPicker & GridMenu Picker\n * when using Column Header Grouping, we'll prefix the column group title\n * else we'll simply return the column name title\n */\nfunction pickerHeaderColumnValueExtractor(column: Column, gridOptions?: GridOptionUniversal) {\n  let colName = column?.columnPickerLabel ?? column?.name ?? '';\n  if (colName instanceof HTMLElement || colName instanceof DocumentFragment) {\n    colName = colName.textContent || '';\n  }\n  const headerGroup = column?.columnGroup || '';\n  const columnGroupSeparator = gridOptions?.columnGroupSeparator ?? ' - ';\n  if (headerGroup) {\n    return headerGroup + columnGroupSeparator + colName;\n  }\n  return colName;\n}\n"]}
@@ -51,7 +51,10 @@ export class AngularUtilService {
51
51
  domElem = viewRef.rootNodes[0];
52
52
  // when user provides the DOM element target, we will read the new Component html and use it to replace the target html
53
53
  if (targetElement && domElem) {
54
- targetElement.innerHTML = domElem.innerHTML;
54
+ targetElement.innerHTML =
55
+ typeof createCompOptions?.sanitizer === 'function'
56
+ ? createCompOptions.sanitizer(domElem.innerHTML || '')
57
+ : domElem.innerHTML;
55
58
  }
56
59
  }
57
60
  return { componentRef, domElement: domElem };
@@ -82,4 +85,4 @@ export class AngularUtilService {
82
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AngularUtilService, decorators: [{
83
86
  type: Injectable
84
87
  }], ctorParameters: () => [{ type: i0.ViewContainerRef }] });
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angularUtil.service.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/services/angularUtil.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ViewContainerRef } from '@angular/core';\nimport type { EmbeddedViewRef, EnvironmentInjector, Injector, NgModuleRef, Type } from '@angular/core';\n\nimport type { AngularComponentOutput } from '../models/angularComponentOutput.interface';\n\ninterface CreateComponentOption {\n  index?: number;\n  injector?: Injector;\n  ngModuleRef?: NgModuleRef<unknown>;\n  environmentInjector?: EnvironmentInjector | NgModuleRef<unknown>;\n  projectableNodes?: Node[][];\n}\n\n@Injectable()\nexport class AngularUtilService {\n  constructor(private vcr: ViewContainerRef) {}\n\n  createInteractiveAngularComponent<C>(\n    component: Type<C>,\n    targetElement: Element,\n    data?: any,\n    createCompOptions?: CreateComponentOption\n  ): AngularComponentOutput {\n    // Create a component reference from the component\n    const componentRef = this.vcr.createComponent(component, createCompOptions);\n\n    // user could provide data to assign to the component instance\n    if (componentRef?.instance && data) {\n      Object.assign(componentRef.instance as any, data);\n    }\n\n    // Get DOM element from component\n    let domElem: HTMLElement | null = null;\n    const viewRef = componentRef.hostView as EmbeddedViewRef<any>;\n\n    if (viewRef && Array.isArray(viewRef.rootNodes) && viewRef.rootNodes[0]) {\n      domElem = viewRef.rootNodes[0] as HTMLElement;\n\n      // when user provides the DOM element target, we will move the dynamic component into that target (aka portal-ing it)\n      if (targetElement && domElem) {\n        targetElement.replaceChildren(componentRef.location.nativeElement);\n      }\n    }\n\n    return { componentRef, domElement: domElem as HTMLElement };\n  }\n\n  /**\n   * Dynamically create an Angular component, user could also provide optional arguments for target, data & createComponent options\n   * @param {Component} component\n   * @param {HTMLElement} [targetElement]\n   * @param {*} [data]\n   * @param {CreateComponentOption} [createCompOptions]\n   * @returns\n   */\n  createAngularComponent<C>(\n    component: Type<C>,\n    targetElement?: Element,\n    data?: any,\n    createCompOptions?: CreateComponentOption\n  ): AngularComponentOutput {\n    // Create a component reference from the component\n    const componentRef = this.vcr.createComponent(component, createCompOptions);\n\n    // user could provide data to assign to the component instance\n    if (componentRef?.instance && data) {\n      Object.assign(componentRef.instance as any, data);\n\n      // NOTE: detectChanges() MUST be done BEFORE returning the DOM element in the next step,\n      // because if we do it only after returning the rootNodes (domElement) then it won't have the instance data yet\n      // and we would have to wait an extra cycle to see the result, this basically helps with Example22\n      componentRef.changeDetectorRef.detectChanges();\n    }\n\n    // Get DOM element from component\n    let domElem: HTMLElement | null = null;\n    const viewRef = componentRef.hostView as EmbeddedViewRef<any>;\n\n    // get DOM element from the new dynamic Component, make sure this is read after any data and detectChanges()\n    if (viewRef && Array.isArray(viewRef.rootNodes) && viewRef.rootNodes[0]) {\n      domElem = viewRef.rootNodes[0] as HTMLElement;\n\n      // when user provides the DOM element target, we will read the new Component html and use it to replace the target html\n      if (targetElement && domElem) {\n        targetElement.innerHTML = domElem.innerHTML;\n      }\n    }\n\n    return { componentRef, domElement: domElem as HTMLElement };\n  }\n\n  /**\n   * Dynamically create an Angular component and append it to the DOM unless a target element is provided,\n   * user could also provide other optional arguments for data & createComponent options.\n   * @param {Component} component\n   * @param {HTMLElement} [targetElement]\n   * @param {*} [data]\n   * @param {CreateComponentOption} [createCompOptions]\n   * @returns\n   */\n  createAngularComponentAppendToDom<C>(\n    component: Type<C>,\n    targetElement?: Element,\n    data?: any,\n    createCompOptions?: CreateComponentOption\n  ): AngularComponentOutput {\n    const componentOutput = this.createAngularComponent(component, targetElement, data, createCompOptions);\n\n    // Append DOM element to the HTML element specified\n    if (targetElement?.replaceChildren) {\n      targetElement.replaceChildren(componentOutput.domElement);\n    } else {\n      document.body.appendChild(componentOutput.domElement); // when no target provided, we'll simply add it to the HTML Body\n    }\n\n    return componentOutput;\n  }\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angularUtil.service.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/services/angularUtil.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ViewContainerRef } from '@angular/core';\nimport type { EmbeddedViewRef, EnvironmentInjector, Injector, NgModuleRef, Type } from '@angular/core';\n\nimport type { AngularComponentOutput } from '../models/angularComponentOutput.interface';\n\ninterface CreateComponentOption {\n  index?: number;\n  injector?: Injector;\n  ngModuleRef?: NgModuleRef<unknown>;\n  environmentInjector?: EnvironmentInjector | NgModuleRef<unknown>;\n  projectableNodes?: Node[][];\n  sanitizer?: (dirtyHtml: string) => string;\n}\n\n@Injectable()\nexport class AngularUtilService {\n  constructor(private vcr: ViewContainerRef) {}\n\n  createInteractiveAngularComponent<C>(\n    component: Type<C>,\n    targetElement: Element,\n    data?: any,\n    createCompOptions?: CreateComponentOption\n  ): AngularComponentOutput {\n    // Create a component reference from the component\n    const componentRef = this.vcr.createComponent(component, createCompOptions);\n\n    // user could provide data to assign to the component instance\n    if (componentRef?.instance && data) {\n      Object.assign(componentRef.instance as any, data);\n    }\n\n    // Get DOM element from component\n    let domElem: HTMLElement | null = null;\n    const viewRef = componentRef.hostView as EmbeddedViewRef<any>;\n\n    if (viewRef && Array.isArray(viewRef.rootNodes) && viewRef.rootNodes[0]) {\n      domElem = viewRef.rootNodes[0] as HTMLElement;\n\n      // when user provides the DOM element target, we will move the dynamic component into that target (aka portal-ing it)\n      if (targetElement && domElem) {\n        targetElement.replaceChildren(componentRef.location.nativeElement);\n      }\n    }\n\n    return { componentRef, domElement: domElem as HTMLElement };\n  }\n\n  /**\n   * Dynamically create an Angular component, user could also provide optional arguments for target, data & createComponent options\n   * @param {Component} component\n   * @param {HTMLElement} [targetElement]\n   * @param {*} [data]\n   * @param {CreateComponentOption} [createCompOptions]\n   * @returns\n   */\n  createAngularComponent<C>(\n    component: Type<C>,\n    targetElement?: Element,\n    data?: any,\n    createCompOptions?: CreateComponentOption\n  ): AngularComponentOutput {\n    // Create a component reference from the component\n    const componentRef = this.vcr.createComponent(component, createCompOptions);\n\n    // user could provide data to assign to the component instance\n    if (componentRef?.instance && data) {\n      Object.assign(componentRef.instance as any, data);\n\n      // NOTE: detectChanges() MUST be done BEFORE returning the DOM element in the next step,\n      // because if we do it only after returning the rootNodes (domElement) then it won't have the instance data yet\n      // and we would have to wait an extra cycle to see the result, this basically helps with Example22\n      componentRef.changeDetectorRef.detectChanges();\n    }\n\n    // Get DOM element from component\n    let domElem: HTMLElement | null = null;\n    const viewRef = componentRef.hostView as EmbeddedViewRef<any>;\n\n    // get DOM element from the new dynamic Component, make sure this is read after any data and detectChanges()\n    if (viewRef && Array.isArray(viewRef.rootNodes) && viewRef.rootNodes[0]) {\n      domElem = viewRef.rootNodes[0] as HTMLElement;\n\n      // when user provides the DOM element target, we will read the new Component html and use it to replace the target html\n      if (targetElement && domElem) {\n        targetElement.innerHTML =\n          typeof createCompOptions?.sanitizer === 'function'\n            ? createCompOptions.sanitizer(domElem.innerHTML || '')\n            : domElem.innerHTML;\n      }\n    }\n\n    return { componentRef, domElement: domElem as HTMLElement };\n  }\n\n  /**\n   * Dynamically create an Angular component and append it to the DOM unless a target element is provided,\n   * user could also provide other optional arguments for data & createComponent options.\n   * @param {Component} component\n   * @param {HTMLElement} [targetElement]\n   * @param {*} [data]\n   * @param {CreateComponentOption} [createCompOptions]\n   * @returns\n   */\n  createAngularComponentAppendToDom<C>(\n    component: Type<C>,\n    targetElement?: Element,\n    data?: any,\n    createCompOptions?: CreateComponentOption\n  ): AngularComponentOutput {\n    const componentOutput = this.createAngularComponent(component, targetElement, data, createCompOptions);\n\n    // Append DOM element to the HTML element specified\n    if (targetElement?.replaceChildren) {\n      targetElement.replaceChildren(componentOutput.domElement);\n    } else {\n      document.body.appendChild(componentOutput.domElement); // when no target provided, we'll simply add it to the HTML Body\n    }\n\n    return componentOutput;\n  }\n}\n"]}