@testgorilla/tgo-ui 2.32.1 → 2.32.2

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 { Provider, TemplateRef, Type } from '@angular/core';
1
+ import { Injector, TemplateRef, Type } from '@angular/core';
2
2
  import { SidePanelConfig } from './side-panel.model';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class SidePanelService {
@@ -9,7 +9,7 @@ export declare class SidePanelService {
9
9
  private injector;
10
10
  private appRef;
11
11
  constructor();
12
- open(content: Type<any> | TemplateRef<any>, config: Partial<SidePanelConfig>, providers?: Provider[]): void;
12
+ open(content: Type<any> | TemplateRef<any>, config: Partial<SidePanelConfig>, parentInjector?: Injector): void;
13
13
  destroyComponent(): void;
14
14
  private createSidePanelInjector;
15
15
  private createSidePanelComponent;
@@ -8,10 +8,10 @@ export class SidePanelService {
8
8
  this.injector = inject(EnvironmentInjector);
9
9
  this.appRef = inject(ApplicationRef);
10
10
  }
11
- open(content, config, providers = []) {
11
+ open(content, config, parentInjector) {
12
12
  const panelConfig = { ...this.defaultSidePanelConfig, ...config };
13
13
  if (!this.SidePanelComponentRef) {
14
- const injector = this.createSidePanelInjector(panelConfig, providers);
14
+ const injector = this.createSidePanelInjector(panelConfig, parentInjector);
15
15
  const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);
16
16
  this.SidePanelComponentRef = SidePanelComponentRef;
17
17
  }
@@ -34,9 +34,10 @@ export class SidePanelService {
34
34
  this.contentComponentRef = undefined;
35
35
  }
36
36
  }
37
- createSidePanelInjector(config, providers = []) {
37
+ createSidePanelInjector(config, parentInjector) {
38
38
  return Injector.create({
39
- providers: [{ provide: SidePanelConfig, useValue: config }, ...providers],
39
+ parent: parentInjector,
40
+ providers: [{ provide: SidePanelConfig, useValue: config }],
40
41
  });
41
42
  }
42
43
  createSidePanelComponent(position, injector) {
@@ -73,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
73
74
  providedIn: 'root',
74
75
  }]
75
76
  }], ctorParameters: () => [] });
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-panel.service.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/side-panel/side-panel.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  createComponent,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  inject,\n  Injectable,\n  Injector,\n  Provider,\n  TemplateRef,\n  Type,\n} from '@angular/core';\nimport { SidePanelComponent } from './side-panel.component';\nimport { SIDE_PANEL_CONFIG, SidePanelConfig, SidePanelPosition } from './side-panel.model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SidePanelService {\n  private SidePanelComponentRef?: ComponentRef<SidePanelComponent>;\n  private contentComponentRef?: ComponentRef<any>;\n  private embeddedViewRef?: EmbeddedViewRef<any>;\n  private defaultSidePanelConfig: SidePanelConfig = inject(SIDE_PANEL_CONFIG);\n  private injector = inject(EnvironmentInjector);\n  private appRef = inject(ApplicationRef);\n\n  constructor() {}\n\n  open(content: Type<any> | TemplateRef<any>, config: Partial<SidePanelConfig>, providers: Provider[] = []): void {\n    const panelConfig: SidePanelConfig = { ...this.defaultSidePanelConfig, ...config };\n\n    if (!this.SidePanelComponentRef) {\n      const injector = this.createSidePanelInjector(panelConfig, providers);\n      const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);\n      this.SidePanelComponentRef = SidePanelComponentRef;\n    }\n\n    if (content instanceof TemplateRef) {\n      this.loadTemplate(content);\n    } else {\n      this.loadComponent(content);\n    }\n\n    this.SidePanelComponentRef.instance.open();\n  }\n\n  destroyComponent(): void {\n    if (this.SidePanelComponentRef) {\n      this.appRef.detachView(this.SidePanelComponentRef.hostView);\n      this.SidePanelComponentRef.destroy();\n      this.SidePanelComponentRef = undefined;\n    }\n\n    if (this.contentComponentRef) {\n      this.contentComponentRef.destroy();\n      this.contentComponentRef = undefined;\n    }\n  }\n\n  private createSidePanelInjector(config: SidePanelConfig, providers: Provider[] = []): Injector {\n    return Injector.create({\n      providers: [{ provide: SidePanelConfig, useValue: config }, ...providers],\n    });\n  }\n\n  private createSidePanelComponent(position: SidePanelPosition, injector: Injector): ComponentRef<SidePanelComponent> {\n    const sidePanelComponentRef = createComponent(SidePanelComponent, {\n      environmentInjector: this.injector,\n      elementInjector: injector,\n    });\n\n    this.appRef.attachView(sidePanelComponentRef.hostView);\n\n    const sidePanelEl = (sidePanelComponentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    sidePanelEl.querySelector('.side-panel')?.classList.add(position);\n\n    document.body.appendChild(sidePanelEl);\n\n    return sidePanelComponentRef;\n  }\n\n  private loadComponent(component: Type<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.contentComponentRef = viewContainerRef().createComponent(component);\n    }\n  }\n\n  private loadTemplate(template: TemplateRef<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.embeddedViewRef = viewContainerRef().createEmbeddedView(template);\n    }\n  }\n}\n"]}
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-panel.service.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/side-panel/side-panel.service.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EAEd,eAAe,EAEf,mBAAmB,EACnB,MAAM,EACN,UAAU,EACV,QAAQ,EACR,WAAW,GAEZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAqB,MAAM,oBAAoB,CAAC;;AAK3F,MAAM,OAAO,gBAAgB;IAQ3B;QAJQ,2BAAsB,GAAoB,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACpE,aAAQ,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACvC,WAAM,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;IAEzB,CAAC;IAEhB,IAAI,CAAC,OAAqC,EAAE,MAAgC,EAAE,cAAyB;QACrG,MAAM,WAAW,GAAoB,EAAE,GAAG,IAAI,CAAC,sBAAsB,EAAE,GAAG,MAAM,EAAE,CAAC;QAEnF,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAChC,MAAM,QAAQ,GAAG,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;YAC3E,MAAM,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,CAAC,WAAW,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC5F,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC;QACrD,CAAC;QAED,IAAI,OAAO,YAAY,WAAW,EAAE,CAAC;YACnC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC9B,CAAC;QAED,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IAC7C,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;YAC5D,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC;YACrC,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC;QACzC,CAAC;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC7B,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;YACnC,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;QACvC,CAAC;IACH,CAAC;IAEO,uBAAuB,CAAC,MAAuB,EAAE,cAAyB;QAChF,OAAO,QAAQ,CAAC,MAAM,CAAC;YACrB,MAAM,EAAE,cAAc;YACtB,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;SAC5D,CAAC,CAAC;IACL,CAAC;IAEO,wBAAwB,CAAC,QAA2B,EAAE,QAAkB;QAC9E,MAAM,qBAAqB,GAAG,eAAe,CAAC,kBAAkB,EAAE;YAChE,mBAAmB,EAAE,IAAI,CAAC,QAAQ;YAClC,eAAe,EAAE,QAAQ;SAC1B,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;QAEvD,MAAM,WAAW,GAAI,qBAAqB,CAAC,QAAiC,CAAC,SAAS,CAAC,CAAC,CAAgB,CAAC;QACzG,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAElE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAEvC,OAAO,qBAAqB,CAAC;IAC/B,CAAC;IAEO,aAAa,CAAC,SAAoB;QACxC,MAAM,gBAAgB,GAAG,IAAI,CAAC,qBAAqB,EAAE,QAAQ,CAAC,kBAAkB,CAAC;QACjF,IAAI,gBAAgB,EAAE,CAAC;YACrB,gBAAgB,EAAE,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,mBAAmB,GAAG,gBAAgB,EAAE,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAC3E,CAAC;IACH,CAAC;IAEO,YAAY,CAAC,QAA0B;QAC7C,MAAM,gBAAgB,GAAG,IAAI,CAAC,qBAAqB,EAAE,QAAQ,CAAC,kBAAkB,CAAC;QACjF,IAAI,gBAAgB,EAAE,CAAC;YACrB,gBAAgB,EAAE,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,GAAG,gBAAgB,EAAE,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;+GA9EU,gBAAgB;mHAAhB,gBAAgB,cAFf,MAAM;;4FAEP,gBAAgB;kBAH5B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  createComponent,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  inject,\n  Injectable,\n  Injector,\n  TemplateRef,\n  Type,\n} from '@angular/core';\nimport { SidePanelComponent } from './side-panel.component';\nimport { SIDE_PANEL_CONFIG, SidePanelConfig, SidePanelPosition } from './side-panel.model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SidePanelService {\n  private SidePanelComponentRef?: ComponentRef<SidePanelComponent>;\n  private contentComponentRef?: ComponentRef<any>;\n  private embeddedViewRef?: EmbeddedViewRef<any>;\n  private defaultSidePanelConfig: SidePanelConfig = inject(SIDE_PANEL_CONFIG);\n  private injector = inject(EnvironmentInjector);\n  private appRef = inject(ApplicationRef);\n\n  constructor() {}\n\n  open(content: Type<any> | TemplateRef<any>, config: Partial<SidePanelConfig>, parentInjector?: Injector): void {\n    const panelConfig: SidePanelConfig = { ...this.defaultSidePanelConfig, ...config };\n\n    if (!this.SidePanelComponentRef) {\n      const injector = this.createSidePanelInjector(panelConfig, parentInjector);\n      const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);\n      this.SidePanelComponentRef = SidePanelComponentRef;\n    }\n\n    if (content instanceof TemplateRef) {\n      this.loadTemplate(content);\n    } else {\n      this.loadComponent(content);\n    }\n\n    this.SidePanelComponentRef.instance.open();\n  }\n\n  destroyComponent(): void {\n    if (this.SidePanelComponentRef) {\n      this.appRef.detachView(this.SidePanelComponentRef.hostView);\n      this.SidePanelComponentRef.destroy();\n      this.SidePanelComponentRef = undefined;\n    }\n\n    if (this.contentComponentRef) {\n      this.contentComponentRef.destroy();\n      this.contentComponentRef = undefined;\n    }\n  }\n\n  private createSidePanelInjector(config: SidePanelConfig, parentInjector?: Injector): Injector {\n    return Injector.create({\n      parent: parentInjector,\n      providers: [{ provide: SidePanelConfig, useValue: config }],\n    });\n  }\n\n  private createSidePanelComponent(position: SidePanelPosition, injector: Injector): ComponentRef<SidePanelComponent> {\n    const sidePanelComponentRef = createComponent(SidePanelComponent, {\n      environmentInjector: this.injector,\n      elementInjector: injector,\n    });\n\n    this.appRef.attachView(sidePanelComponentRef.hostView);\n\n    const sidePanelEl = (sidePanelComponentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    sidePanelEl.querySelector('.side-panel')?.classList.add(position);\n\n    document.body.appendChild(sidePanelEl);\n\n    return sidePanelComponentRef;\n  }\n\n  private loadComponent(component: Type<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.contentComponentRef = viewContainerRef().createComponent(component);\n    }\n  }\n\n  private loadTemplate(template: TemplateRef<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.embeddedViewRef = viewContainerRef().createEmbeddedView(template);\n    }\n  }\n}\n"]}
@@ -15980,10 +15980,10 @@ class SidePanelService {
15980
15980
  this.injector = inject(EnvironmentInjector);
15981
15981
  this.appRef = inject(ApplicationRef);
15982
15982
  }
15983
- open(content, config, providers = []) {
15983
+ open(content, config, parentInjector) {
15984
15984
  const panelConfig = { ...this.defaultSidePanelConfig, ...config };
15985
15985
  if (!this.SidePanelComponentRef) {
15986
- const injector = this.createSidePanelInjector(panelConfig, providers);
15986
+ const injector = this.createSidePanelInjector(panelConfig, parentInjector);
15987
15987
  const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);
15988
15988
  this.SidePanelComponentRef = SidePanelComponentRef;
15989
15989
  }
@@ -16006,9 +16006,10 @@ class SidePanelService {
16006
16006
  this.contentComponentRef = undefined;
16007
16007
  }
16008
16008
  }
16009
- createSidePanelInjector(config, providers = []) {
16009
+ createSidePanelInjector(config, parentInjector) {
16010
16010
  return Injector.create({
16011
- providers: [{ provide: SidePanelConfig, useValue: config }, ...providers],
16011
+ parent: parentInjector,
16012
+ providers: [{ provide: SidePanelConfig, useValue: config }],
16012
16013
  });
16013
16014
  }
16014
16015
  createSidePanelComponent(position, injector) {