@libs-ui/services-dynamic-component 0.2.291 → 0.2.292

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,6 +1,7 @@
1
- import { ComponentRef } from '@angular/core';
1
+ import { ComponentRef, OnDestroy } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- export declare class LibsUiDynamicComponentService {
3
+ export declare class LibsUiDynamicComponentService implements OnDestroy {
4
+ private timeOut?;
4
5
  private elementLayoutContent;
5
6
  private elementBody;
6
7
  private mapStylesToParentDocument;
@@ -8,13 +9,14 @@ export declare class LibsUiDynamicComponentService {
8
9
  private idElementLayoutContentDefault;
9
10
  set IdElementLayoutContentDefault(id: string);
10
11
  resolveComponentFactory(component: any): ComponentRef<any>;
11
- addToBody(componentRef: any, isAddParentDocument?: boolean): string;
12
+ addToBody(componentRef?: ComponentRef<any>, isAddParentDocument?: boolean, timerDelayUpdateStyleToParent?: number): string;
12
13
  addToElement(componentRef: any, elementAdd: any): any;
13
14
  addToElementLayoutContentDefault(componentRef: any, id?: string): void;
14
15
  addToIdAttributeElement(componentRef: any, id: string): HTMLElement | undefined;
15
16
  remove(componentRef: any, frameId?: string, ignoreDestroyComponent?: boolean): void;
16
17
  private updateStyleToParentDocument;
17
18
  private removeStyleToParentDocument;
19
+ ngOnDestroy(): void;
18
20
  static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiDynamicComponentService, never>;
19
21
  static ɵprov: i0.ɵɵInjectableDeclaration<LibsUiDynamicComponentService>;
20
22
  }
@@ -1,11 +1,11 @@
1
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
2
2
  import { ApplicationRef, Injectable, createComponent, inject } from '@angular/core';
3
- import { uuid } from '@libs-ui/utils';
4
3
  import * as i0 from "@angular/core";
5
4
  export class LibsUiDynamicComponentService {
5
+ timeOut;
6
6
  elementLayoutContent = new Map();
7
7
  elementBody;
8
- mapStylesToParentDocument = new Map();
8
+ mapStylesToParentDocument = new WeakMap();
9
9
  appRef = inject(ApplicationRef);
10
10
  idElementLayoutContentDefault = 'libs-ui-layout-content';
11
11
  set IdElementLayoutContentDefault(id) {
@@ -14,7 +14,7 @@ export class LibsUiDynamicComponentService {
14
14
  resolveComponentFactory(component) {
15
15
  return createComponent(component, { environmentInjector: this.appRef.injector });
16
16
  }
17
- addToBody(componentRef, isAddParentDocument) {
17
+ addToBody(componentRef, isAddParentDocument, timerDelayUpdateStyleToParent) {
18
18
  if (!componentRef || !componentRef.hostView) {
19
19
  return '';
20
20
  }
@@ -22,7 +22,8 @@ export class LibsUiDynamicComponentService {
22
22
  const domElem = componentRef.hostView.rootNodes[0];
23
23
  if (isAddParentDocument) {
24
24
  window.parent.document.body.appendChild(domElem);
25
- return this.updateStyleToParentDocument();
25
+ this.updateStyleToParentDocument(componentRef, timerDelayUpdateStyleToParent);
26
+ return '';
26
27
  }
27
28
  if (!this.elementBody) {
28
29
  this.elementBody = document.body;
@@ -52,11 +53,11 @@ export class LibsUiDynamicComponentService {
52
53
  const domElem = componentRef.hostView.rootNodes[0];
53
54
  return this.elementLayoutContent.get(id)?.appendChild(domElem);
54
55
  }
55
- remove(componentRef, frameId = '', ignoreDestroyComponent) {
56
+ remove(componentRef, frameId, ignoreDestroyComponent) {
56
57
  if (!componentRef) {
57
58
  return;
58
59
  }
59
- this.removeStyleToParentDocument(frameId);
60
+ this.removeStyleToParentDocument(componentRef);
60
61
  if (componentRef.hostView) {
61
62
  this.appRef.detachView(componentRef.hostView);
62
63
  }
@@ -64,25 +65,28 @@ export class LibsUiDynamicComponentService {
64
65
  componentRef.destroy();
65
66
  }
66
67
  }
67
- updateStyleToParentDocument() {
68
- const frameId = uuid();
69
- const documentParent = window.parent.document;
70
- if (documentParent && !this.mapStylesToParentDocument.has(frameId)) {
71
- const styleTags = new Array();
72
- Array.from(document.head.querySelectorAll("style")).forEach(styleTag => {
73
- const cloneStyleTag = styleTag.cloneNode(true);
74
- styleTags.push(cloneStyleTag);
75
- documentParent?.head.appendChild(cloneStyleTag);
76
- });
77
- this.mapStylesToParentDocument.set(frameId, styleTags);
68
+ updateStyleToParentDocument(componentRef, timerDelayUpdateStyleToParent) {
69
+ if (this.timeOut) {
70
+ clearTimeout(this.timeOut);
78
71
  }
79
- return frameId;
72
+ this.timeOut = setTimeout(() => {
73
+ const documentParent = window.parent.document;
74
+ if (documentParent && !this.mapStylesToParentDocument.has(componentRef)) {
75
+ const styleTags = new Array();
76
+ Array.from(document.head.querySelectorAll("style")).forEach(styleTag => {
77
+ const cloneStyleTag = styleTag.cloneNode(true);
78
+ styleTags.push(cloneStyleTag);
79
+ documentParent?.head.appendChild(cloneStyleTag);
80
+ });
81
+ this.mapStylesToParentDocument.set(componentRef, styleTags);
82
+ }
83
+ }, timerDelayUpdateStyleToParent || 250);
80
84
  }
81
- removeStyleToParentDocument(frameId) {
82
- if (!frameId) {
85
+ removeStyleToParentDocument(componentRef) {
86
+ if (!componentRef) {
83
87
  return;
84
88
  }
85
- const styleTagsPopup = this.mapStylesToParentDocument.get(frameId);
89
+ const styleTagsPopup = this.mapStylesToParentDocument.get(componentRef);
86
90
  const documentParent = window.parent.document;
87
91
  if (!styleTagsPopup || !styleTagsPopup.length || !documentParent) {
88
92
  return;
@@ -90,7 +94,14 @@ export class LibsUiDynamicComponentService {
90
94
  styleTagsPopup.forEach(styleTag => {
91
95
  documentParent?.head.removeChild(styleTag);
92
96
  });
93
- this.mapStylesToParentDocument.delete(frameId);
97
+ this.mapStylesToParentDocument.delete(componentRef);
98
+ }
99
+ ngOnDestroy() {
100
+ if (this.timeOut) {
101
+ clearTimeout(this.timeOut);
102
+ this.timeOut = undefined;
103
+ }
104
+ this.elementLayoutContent.clear();
94
105
  }
95
106
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDynamicComponentService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
96
107
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDynamicComponentService, providedIn: 'root' });
@@ -101,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
101
112
  providedIn: 'root'
102
113
  }]
103
114
  }] });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-component.service.js","sourceRoot":"","sources":["../../../../../libs-ui/services/dynamic-component/src/dynamic-component.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { ApplicationRef, ComponentRef, EmbeddedViewRef, Injectable, createComponent, inject } from '@angular/core';\nimport { uuid } from '@libs-ui/utils';\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class LibsUiDynamicComponentService {\n  private elementLayoutContent:Map<string, HTMLElement> = new Map();\n  private elementBody!: HTMLElement | null;\n  private mapStylesToParentDocument: Map<string, Array<Node>> = new Map();\n  private appRef = inject(ApplicationRef);\n  private idElementLayoutContentDefault = 'libs-ui-layout-content';\n\n  public set IdElementLayoutContentDefault(id: string) {\n    this.idElementLayoutContentDefault = id;\n  }\n\n  public resolveComponentFactory(component: any): ComponentRef<any> {\n    return createComponent(component, { environmentInjector: this.appRef.injector });\n  }\n\n  public addToBody(componentRef: any, isAddParentDocument?: boolean): string {\n    if (!componentRef || !componentRef.hostView) {\n      return '';\n    }\n\n    this.appRef.attachView(componentRef.hostView);\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n    if (isAddParentDocument) {\n      window.parent.document.body.appendChild(domElem);\n\n      return this.updateStyleToParentDocument();\n    }\n    if (!this.elementBody) {\n      this.elementBody = document.body;\n    }\n    this.elementBody.appendChild(domElem);\n\n    return '';\n  }\n\n  public addToElement(componentRef: any, elementAdd: any) {\n    if (!componentRef || !componentRef.hostView || !elementAdd) {\n      return;\n    }\n    this.appRef.attachView(componentRef.hostView);\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n    return elementAdd.appendChild(domElem);\n  }\n\n  public addToElementLayoutContentDefault(componentRef: any, id: string = this.idElementLayoutContentDefault) {\n   this.addToIdAttributeElement(componentRef, id);\n  }\n\n\n  public addToIdAttributeElement(componentRef: any, id: string) {\n    if (!this.elementLayoutContent.has(id)) {\n      this.elementLayoutContent.set(id, document.getElementById(id) as HTMLElement);\n    }\n    if (!componentRef || !componentRef.hostView) {\n      return;\n    }\n    this.appRef.attachView(componentRef.hostView);\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n    return this.elementLayoutContent.get(id)?.appendChild(domElem);\n  }\n\n  public remove(componentRef: any, frameId = '', ignoreDestroyComponent?: boolean) {\n    if (!componentRef) {\n      return;\n    }\n    this.removeStyleToParentDocument(frameId);\n    if (componentRef.hostView) {\n      this.appRef.detachView(componentRef.hostView);\n    }\n    if (!ignoreDestroyComponent && componentRef.destroy) {\n      componentRef.destroy();\n    }\n  }\n\n  private updateStyleToParentDocument(): string {\n    const frameId = uuid();\n    const documentParent = window.parent.document;\n\n    if (documentParent && !this.mapStylesToParentDocument.has(frameId)) {\n      const styleTags = new Array<Node>();\n\n      Array.from(document.head.querySelectorAll(\"style\")).forEach(styleTag => {\n        const cloneStyleTag = styleTag.cloneNode(true);\n\n        styleTags.push(cloneStyleTag);\n        documentParent?.head.appendChild(cloneStyleTag);\n      });\n      this.mapStylesToParentDocument.set(frameId, styleTags);\n    }\n\n    return frameId;\n  }\n\n  private removeStyleToParentDocument(frameId: string) {\n    if (!frameId) {\n      return;\n    }\n    const styleTagsPopup = this.mapStylesToParentDocument.get(frameId);\n    const documentParent = window.parent.document;\n\n    if (!styleTagsPopup || !styleTagsPopup.length || !documentParent) {\n      return;\n    }\n    styleTagsPopup.forEach(styleTag => {\n      documentParent?.head.removeChild(styleTag);\n    });\n    this.mapStylesToParentDocument.delete(frameId);\n  }\n}"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-component.service.js","sourceRoot":"","sources":["../../../../../libs-ui/services/dynamic-component/src/dynamic-component.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { ApplicationRef, ComponentRef, EmbeddedViewRef, Injectable, createComponent, inject,OnDestroy   } from '@angular/core';\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class LibsUiDynamicComponentService implements OnDestroy {\n  private timeOut?: number;\n  private elementLayoutContent:Map<string, HTMLElement> = new Map();\n  private elementBody!: HTMLElement | null;\n  private mapStylesToParentDocument: WeakMap<ComponentRef<any>, Array<Node>> = new WeakMap();\n  private appRef = inject(ApplicationRef);\n  private idElementLayoutContentDefault = 'libs-ui-layout-content';\n\n  public set IdElementLayoutContentDefault(id: string) {\n    this.idElementLayoutContentDefault = id;\n  }\n\n  public resolveComponentFactory(component: any): ComponentRef<any> {\n    return createComponent(component, { environmentInjector: this.appRef.injector });\n  }\n\n  public addToBody(componentRef?: ComponentRef<any>, isAddParentDocument?: boolean, timerDelayUpdateStyleToParent?: number): string {\n    if (!componentRef || !componentRef.hostView) {\n      return '';\n    }\n\n    this.appRef.attachView(componentRef.hostView);\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n    if (isAddParentDocument) {\n      window.parent.document.body.appendChild(domElem);\n      this.updateStyleToParentDocument(componentRef, timerDelayUpdateStyleToParent);\n\n      return '';\n    }\n    if (!this.elementBody) {\n      this.elementBody = document.body;\n    }\n    this.elementBody.appendChild(domElem);\n\n    return '';\n  }\n\n  public addToElement(componentRef: any, elementAdd: any) {\n    if (!componentRef || !componentRef.hostView || !elementAdd) {\n      return;\n    }\n    this.appRef.attachView(componentRef.hostView);\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n    return elementAdd.appendChild(domElem);\n  }\n\n  public addToElementLayoutContentDefault(componentRef: any, id: string = this.idElementLayoutContentDefault) {\n   this.addToIdAttributeElement(componentRef, id);\n  }\n\n  public addToIdAttributeElement(componentRef: any, id: string) {\n    if (!this.elementLayoutContent.has(id)) {\n      this.elementLayoutContent.set(id, document.getElementById(id) as HTMLElement);\n    }\n    if (!componentRef || !componentRef.hostView) {\n      return;\n    }\n    this.appRef.attachView(componentRef.hostView);\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n    return this.elementLayoutContent.get(id)?.appendChild(domElem);\n  }\n\n  public remove(componentRef: any, frameId?:string, ignoreDestroyComponent?: boolean) {\n    if (!componentRef) {\n      return;\n    }\n    this.removeStyleToParentDocument(componentRef);\n    if (componentRef.hostView) {\n      this.appRef.detachView(componentRef.hostView);\n    }\n    if (!ignoreDestroyComponent && componentRef.destroy) {\n      componentRef.destroy();\n    }\n  }\n\n  private updateStyleToParentDocument(componentRef: ComponentRef<any>, timerDelayUpdateStyleToParent?: number) {\n    if (this.timeOut) {\n      clearTimeout(this.timeOut);\n    }\n    this.timeOut = setTimeout(() => {\n      const documentParent = window.parent.document;\n  \n      if (documentParent && !this.mapStylesToParentDocument.has(componentRef)) {\n        const styleTags = new Array<Node>();\n  \n        Array.from(document.head.querySelectorAll(\"style\")).forEach(styleTag => {\n          const cloneStyleTag = styleTag.cloneNode(true);\n  \n          styleTags.push(cloneStyleTag);\n          documentParent?.head.appendChild(cloneStyleTag);\n        });\n        this.mapStylesToParentDocument.set(componentRef, styleTags);\n      }\n    }, timerDelayUpdateStyleToParent || 250);\n  }\n\n  private removeStyleToParentDocument(componentRef: ComponentRef<any>) {\n    if (!componentRef) {\n      return;\n    }\n    const styleTagsPopup = this.mapStylesToParentDocument.get(componentRef);\n    const documentParent = window.parent.document;\n\n    if (!styleTagsPopup || !styleTagsPopup.length || !documentParent) {\n      return;\n    }\n    styleTagsPopup.forEach(styleTag => {\n      documentParent?.head.removeChild(styleTag);\n    });\n    this.mapStylesToParentDocument.delete(componentRef);\n  }\n\n  ngOnDestroy() {\n      if (this.timeOut) {\n        clearTimeout(this.timeOut);\n        this.timeOut = undefined;\n      }\n  \n      this.elementLayoutContent.clear();\n  }\n}"]}
@@ -1,12 +1,12 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { inject, ApplicationRef, createComponent, Injectable } from '@angular/core';
3
- import { uuid } from '@libs-ui/utils';
4
3
 
5
4
  /* eslint-disable @typescript-eslint/no-explicit-any */
6
5
  class LibsUiDynamicComponentService {
6
+ timeOut;
7
7
  elementLayoutContent = new Map();
8
8
  elementBody;
9
- mapStylesToParentDocument = new Map();
9
+ mapStylesToParentDocument = new WeakMap();
10
10
  appRef = inject(ApplicationRef);
11
11
  idElementLayoutContentDefault = 'libs-ui-layout-content';
12
12
  set IdElementLayoutContentDefault(id) {
@@ -15,7 +15,7 @@ class LibsUiDynamicComponentService {
15
15
  resolveComponentFactory(component) {
16
16
  return createComponent(component, { environmentInjector: this.appRef.injector });
17
17
  }
18
- addToBody(componentRef, isAddParentDocument) {
18
+ addToBody(componentRef, isAddParentDocument, timerDelayUpdateStyleToParent) {
19
19
  if (!componentRef || !componentRef.hostView) {
20
20
  return '';
21
21
  }
@@ -23,7 +23,8 @@ class LibsUiDynamicComponentService {
23
23
  const domElem = componentRef.hostView.rootNodes[0];
24
24
  if (isAddParentDocument) {
25
25
  window.parent.document.body.appendChild(domElem);
26
- return this.updateStyleToParentDocument();
26
+ this.updateStyleToParentDocument(componentRef, timerDelayUpdateStyleToParent);
27
+ return '';
27
28
  }
28
29
  if (!this.elementBody) {
29
30
  this.elementBody = document.body;
@@ -53,11 +54,11 @@ class LibsUiDynamicComponentService {
53
54
  const domElem = componentRef.hostView.rootNodes[0];
54
55
  return this.elementLayoutContent.get(id)?.appendChild(domElem);
55
56
  }
56
- remove(componentRef, frameId = '', ignoreDestroyComponent) {
57
+ remove(componentRef, frameId, ignoreDestroyComponent) {
57
58
  if (!componentRef) {
58
59
  return;
59
60
  }
60
- this.removeStyleToParentDocument(frameId);
61
+ this.removeStyleToParentDocument(componentRef);
61
62
  if (componentRef.hostView) {
62
63
  this.appRef.detachView(componentRef.hostView);
63
64
  }
@@ -65,25 +66,28 @@ class LibsUiDynamicComponentService {
65
66
  componentRef.destroy();
66
67
  }
67
68
  }
68
- updateStyleToParentDocument() {
69
- const frameId = uuid();
70
- const documentParent = window.parent.document;
71
- if (documentParent && !this.mapStylesToParentDocument.has(frameId)) {
72
- const styleTags = new Array();
73
- Array.from(document.head.querySelectorAll("style")).forEach(styleTag => {
74
- const cloneStyleTag = styleTag.cloneNode(true);
75
- styleTags.push(cloneStyleTag);
76
- documentParent?.head.appendChild(cloneStyleTag);
77
- });
78
- this.mapStylesToParentDocument.set(frameId, styleTags);
69
+ updateStyleToParentDocument(componentRef, timerDelayUpdateStyleToParent) {
70
+ if (this.timeOut) {
71
+ clearTimeout(this.timeOut);
79
72
  }
80
- return frameId;
73
+ this.timeOut = setTimeout(() => {
74
+ const documentParent = window.parent.document;
75
+ if (documentParent && !this.mapStylesToParentDocument.has(componentRef)) {
76
+ const styleTags = new Array();
77
+ Array.from(document.head.querySelectorAll("style")).forEach(styleTag => {
78
+ const cloneStyleTag = styleTag.cloneNode(true);
79
+ styleTags.push(cloneStyleTag);
80
+ documentParent?.head.appendChild(cloneStyleTag);
81
+ });
82
+ this.mapStylesToParentDocument.set(componentRef, styleTags);
83
+ }
84
+ }, timerDelayUpdateStyleToParent || 250);
81
85
  }
82
- removeStyleToParentDocument(frameId) {
83
- if (!frameId) {
86
+ removeStyleToParentDocument(componentRef) {
87
+ if (!componentRef) {
84
88
  return;
85
89
  }
86
- const styleTagsPopup = this.mapStylesToParentDocument.get(frameId);
90
+ const styleTagsPopup = this.mapStylesToParentDocument.get(componentRef);
87
91
  const documentParent = window.parent.document;
88
92
  if (!styleTagsPopup || !styleTagsPopup.length || !documentParent) {
89
93
  return;
@@ -91,7 +95,14 @@ class LibsUiDynamicComponentService {
91
95
  styleTagsPopup.forEach(styleTag => {
92
96
  documentParent?.head.removeChild(styleTag);
93
97
  });
94
- this.mapStylesToParentDocument.delete(frameId);
98
+ this.mapStylesToParentDocument.delete(componentRef);
99
+ }
100
+ ngOnDestroy() {
101
+ if (this.timeOut) {
102
+ clearTimeout(this.timeOut);
103
+ this.timeOut = undefined;
104
+ }
105
+ this.elementLayoutContent.clear();
95
106
  }
96
107
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDynamicComponentService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
97
108
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDynamicComponentService, providedIn: 'root' });
@@ -1 +1 @@
1
- {"version":3,"file":"libs-ui-services-dynamic-component.mjs","sources":["../../../../../libs-ui/services/dynamic-component/src/dynamic-component.service.ts","../../../../../libs-ui/services/dynamic-component/src/set-inputs.ts","../../../../../libs-ui/services/dynamic-component/src/libs-ui-services-dynamic-component.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { ApplicationRef, ComponentRef, EmbeddedViewRef, Injectable, createComponent, inject } from '@angular/core';\nimport { uuid } from '@libs-ui/utils';\n@Injectable({\n providedIn: 'root'\n})\n\nexport class LibsUiDynamicComponentService {\n private elementLayoutContent:Map<string, HTMLElement> = new Map();\n private elementBody!: HTMLElement | null;\n private mapStylesToParentDocument: Map<string, Array<Node>> = new Map();\n private appRef = inject(ApplicationRef);\n private idElementLayoutContentDefault = 'libs-ui-layout-content';\n\n public set IdElementLayoutContentDefault(id: string) {\n this.idElementLayoutContentDefault = id;\n }\n\n public resolveComponentFactory(component: any): ComponentRef<any> {\n return createComponent(component, { environmentInjector: this.appRef.injector });\n }\n\n public addToBody(componentRef: any, isAddParentDocument?: boolean): string {\n if (!componentRef || !componentRef.hostView) {\n return '';\n }\n\n this.appRef.attachView(componentRef.hostView);\n const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n if (isAddParentDocument) {\n window.parent.document.body.appendChild(domElem);\n\n return this.updateStyleToParentDocument();\n }\n if (!this.elementBody) {\n this.elementBody = document.body;\n }\n this.elementBody.appendChild(domElem);\n\n return '';\n }\n\n public addToElement(componentRef: any, elementAdd: any) {\n if (!componentRef || !componentRef.hostView || !elementAdd) {\n return;\n }\n this.appRef.attachView(componentRef.hostView);\n const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n return elementAdd.appendChild(domElem);\n }\n\n public addToElementLayoutContentDefault(componentRef: any, id: string = this.idElementLayoutContentDefault) {\n this.addToIdAttributeElement(componentRef, id);\n }\n\n\n public addToIdAttributeElement(componentRef: any, id: string) {\n if (!this.elementLayoutContent.has(id)) {\n this.elementLayoutContent.set(id, document.getElementById(id) as HTMLElement);\n }\n if (!componentRef || !componentRef.hostView) {\n return;\n }\n this.appRef.attachView(componentRef.hostView);\n const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n return this.elementLayoutContent.get(id)?.appendChild(domElem);\n }\n\n public remove(componentRef: any, frameId = '', ignoreDestroyComponent?: boolean) {\n if (!componentRef) {\n return;\n }\n this.removeStyleToParentDocument(frameId);\n if (componentRef.hostView) {\n this.appRef.detachView(componentRef.hostView);\n }\n if (!ignoreDestroyComponent && componentRef.destroy) {\n componentRef.destroy();\n }\n }\n\n private updateStyleToParentDocument(): string {\n const frameId = uuid();\n const documentParent = window.parent.document;\n\n if (documentParent && !this.mapStylesToParentDocument.has(frameId)) {\n const styleTags = new Array<Node>();\n\n Array.from(document.head.querySelectorAll(\"style\")).forEach(styleTag => {\n const cloneStyleTag = styleTag.cloneNode(true);\n\n styleTags.push(cloneStyleTag);\n documentParent?.head.appendChild(cloneStyleTag);\n });\n this.mapStylesToParentDocument.set(frameId, styleTags);\n }\n\n return frameId;\n }\n\n private removeStyleToParentDocument(frameId: string) {\n if (!frameId) {\n return;\n }\n const styleTagsPopup = this.mapStylesToParentDocument.get(frameId);\n const documentParent = window.parent.document;\n\n if (!styleTagsPopup || !styleTagsPopup.length || !documentParent) {\n return;\n }\n styleTagsPopup.forEach(styleTag => {\n documentParent?.head.removeChild(styleTag);\n });\n this.mapStylesToParentDocument.delete(frameId);\n }\n}","import { ComponentRef } from \"@angular/core\";\nimport { Inputs } from \"./inputs.type\";\n\nexport const setInputs = <T>(componentRef: ComponentRef<T>, inputs: Inputs<T>): void => {\n Object.entries(inputs).forEach(([key, value]) => componentRef.setInput(key, value));\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"libs-ui-services-dynamic-component.mjs","sources":["../../../../../libs-ui/services/dynamic-component/src/dynamic-component.service.ts","../../../../../libs-ui/services/dynamic-component/src/set-inputs.ts","../../../../../libs-ui/services/dynamic-component/src/libs-ui-services-dynamic-component.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { ApplicationRef, ComponentRef, EmbeddedViewRef, Injectable, createComponent, inject,OnDestroy } from '@angular/core';\n@Injectable({\n providedIn: 'root'\n})\n\nexport class LibsUiDynamicComponentService implements OnDestroy {\n private timeOut?: number;\n private elementLayoutContent:Map<string, HTMLElement> = new Map();\n private elementBody!: HTMLElement | null;\n private mapStylesToParentDocument: WeakMap<ComponentRef<any>, Array<Node>> = new WeakMap();\n private appRef = inject(ApplicationRef);\n private idElementLayoutContentDefault = 'libs-ui-layout-content';\n\n public set IdElementLayoutContentDefault(id: string) {\n this.idElementLayoutContentDefault = id;\n }\n\n public resolveComponentFactory(component: any): ComponentRef<any> {\n return createComponent(component, { environmentInjector: this.appRef.injector });\n }\n\n public addToBody(componentRef?: ComponentRef<any>, isAddParentDocument?: boolean, timerDelayUpdateStyleToParent?: number): string {\n if (!componentRef || !componentRef.hostView) {\n return '';\n }\n\n this.appRef.attachView(componentRef.hostView);\n const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n if (isAddParentDocument) {\n window.parent.document.body.appendChild(domElem);\n this.updateStyleToParentDocument(componentRef, timerDelayUpdateStyleToParent);\n\n return '';\n }\n if (!this.elementBody) {\n this.elementBody = document.body;\n }\n this.elementBody.appendChild(domElem);\n\n return '';\n }\n\n public addToElement(componentRef: any, elementAdd: any) {\n if (!componentRef || !componentRef.hostView || !elementAdd) {\n return;\n }\n this.appRef.attachView(componentRef.hostView);\n const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n return elementAdd.appendChild(domElem);\n }\n\n public addToElementLayoutContentDefault(componentRef: any, id: string = this.idElementLayoutContentDefault) {\n this.addToIdAttributeElement(componentRef, id);\n }\n\n public addToIdAttributeElement(componentRef: any, id: string) {\n if (!this.elementLayoutContent.has(id)) {\n this.elementLayoutContent.set(id, document.getElementById(id) as HTMLElement);\n }\n if (!componentRef || !componentRef.hostView) {\n return;\n }\n this.appRef.attachView(componentRef.hostView);\n const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n return this.elementLayoutContent.get(id)?.appendChild(domElem);\n }\n\n public remove(componentRef: any, frameId?:string, ignoreDestroyComponent?: boolean) {\n if (!componentRef) {\n return;\n }\n this.removeStyleToParentDocument(componentRef);\n if (componentRef.hostView) {\n this.appRef.detachView(componentRef.hostView);\n }\n if (!ignoreDestroyComponent && componentRef.destroy) {\n componentRef.destroy();\n }\n }\n\n private updateStyleToParentDocument(componentRef: ComponentRef<any>, timerDelayUpdateStyleToParent?: number) {\n if (this.timeOut) {\n clearTimeout(this.timeOut);\n }\n this.timeOut = setTimeout(() => {\n const documentParent = window.parent.document;\n \n if (documentParent && !this.mapStylesToParentDocument.has(componentRef)) {\n const styleTags = new Array<Node>();\n \n Array.from(document.head.querySelectorAll(\"style\")).forEach(styleTag => {\n const cloneStyleTag = styleTag.cloneNode(true);\n \n styleTags.push(cloneStyleTag);\n documentParent?.head.appendChild(cloneStyleTag);\n });\n this.mapStylesToParentDocument.set(componentRef, styleTags);\n }\n }, timerDelayUpdateStyleToParent || 250);\n }\n\n private removeStyleToParentDocument(componentRef: ComponentRef<any>) {\n if (!componentRef) {\n return;\n }\n const styleTagsPopup = this.mapStylesToParentDocument.get(componentRef);\n const documentParent = window.parent.document;\n\n if (!styleTagsPopup || !styleTagsPopup.length || !documentParent) {\n return;\n }\n styleTagsPopup.forEach(styleTag => {\n documentParent?.head.removeChild(styleTag);\n });\n this.mapStylesToParentDocument.delete(componentRef);\n }\n\n ngOnDestroy() {\n if (this.timeOut) {\n clearTimeout(this.timeOut);\n this.timeOut = undefined;\n }\n \n this.elementLayoutContent.clear();\n }\n}","import { ComponentRef } from \"@angular/core\";\nimport { Inputs } from \"./inputs.type\";\n\nexport const setInputs = <T>(componentRef: ComponentRef<T>, inputs: Inputs<T>): void => {\n Object.entries(inputs).forEach(([key, value]) => componentRef.setInput(key, value));\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@libs-ui/services-dynamic-component",
3
- "version": "0.2.291",
3
+ "version": "0.2.292",
4
4
  "peerDependencies": {
5
5
  "@angular/core": ">=18.0.0",
6
- "@libs-ui/utils": "0.2.291"
6
+ "@libs-ui/utils": "0.2.292"
7
7
  },
8
8
  "sideEffects": false,
9
9
  "module": "fesm2022/libs-ui-services-dynamic-component.mjs",