UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

107 lines (106 loc) 12.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { AsiDialog } from './dialog/asi-dialog.component'; import { AsiDialogContainer } from './container/asi-dialog-container.component'; import { Injectable, ComponentFactoryResolver, ApplicationRef } from '@angular/core'; export class AsiDialogService { /** * @param {?} resolver * @param {?} appRef */ constructor(resolver, appRef) { this.resolver = resolver; this.appRef = appRef; } /** * @template T * @param {?} content * @param {?} config * @return {?} */ fromComponent(content, config) { /** @type {?} */ let containerRef = this.getContainer(); if (!this.dialogEmptySubscription || this.dialogEmptySubscription.closed) { this.dialogEmptySubscription = containerRef.instance.onContainerEmpty().subscribe(() => { this.dialogEmptySubscription.unsubscribe(); this.dialogContainer.destroy(); this.dialogContainer = null; }); } /** @type {?} */ let dialogRef = this.createDialog(content, containerRef, config); containerRef.instance.addDialog(dialogRef); return dialogRef.instance; } /** * @return {?} */ getContainer() { if (this.dialogContainer == null) { /** @type {?} */ const rootComponent = this.appRef.components[0].instance; if (!rootComponent.viewContainerRef) { /** @type {?} */ const appName = this.appRef.componentTypes[0].name; // tslint:disable-next-line:max-line-length throw new Error('AsiDialog: Please add "viewContainerRef : ViewContainerRef" declaration in your root component constructor : ' + appName); } /** @type {?} */ const asiDialogContainerFactory = this.resolver.resolveComponentFactory(AsiDialogContainer); /** @type {?} */ let containerRef = rootComponent.viewContainerRef.createComponent(asiDialogContainerFactory, 0); this.dialogContainer = containerRef; } return this.dialogContainer; } /** * @template T * @param {?} content * @param {?} containerRef * @param {?} config * @return {?} */ createDialog(content, containerRef, config) { /** @type {?} */ const asiDialogFactory = this.resolver.resolveComponentFactory(AsiDialog); /** @type {?} */ let asiDialogRef = containerRef.instance.viewContainerRef.createComponent(asiDialogFactory, 0); asiDialogRef.instance.setConfig(config); // Moving dialog in div dialog-container containerRef.location.nativeElement.children[0].appendChild(asiDialogRef.location.nativeElement); /** @type {?} */ const contentFactory = this.resolver.resolveComponentFactory(content); /** @type {?} */ let contentRef = asiDialogRef.instance.viewContainerRef.createComponent(contentFactory); /** @type {?} */ let contentComponent = contentRef.instance; // Ajout de la reference du composant dans le AsiDialog asiDialogRef.instance['_component'] = contentComponent; contentComponent.registerDialog(asiDialogRef.instance); // Deplacement du contenu dans la div dialog-panel asiDialogRef.location.nativeElement.children[0].appendChild(contentRef.location.nativeElement); return asiDialogRef; } } AsiDialogService.decorators = [ { type: Injectable } ]; /** @nocollapse */ AsiDialogService.ctorParameters = () => [ { type: ComponentFactoryResolver }, { type: ApplicationRef } ]; if (false) { /** @type {?} */ AsiDialogService.prototype.dialogContainer; /** @type {?} */ AsiDialogService.prototype.dialogEmptySubscription; /** @type {?} */ AsiDialogService.prototype.resolver; /** @type {?} */ AsiDialogService.prototype.appRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-dialog.service.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-dialog/asi-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsiDialogView } from './asi-dialog-view';\r\nimport { AsiDialog } from './dialog/asi-dialog.component';\r\nimport { AsiDialogConfig } from './asi-dialog-config';\r\nimport { AsiDialogContainer } from './container/asi-dialog-container.component';\r\nimport { ComponentType } from './../common/component-type';\r\nimport { Injectable, ComponentFactory, ComponentFactoryResolver, ComponentRef, ApplicationRef } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\n@Injectable()\r\nexport class AsiDialogService {\r\n\r\n  private dialogContainer: ComponentRef<AsiDialogContainer>;\r\n  private dialogEmptySubscription: Subscription;\r\n\r\n  constructor(private resolver: ComponentFactoryResolver, private appRef: ApplicationRef) {\r\n  }\r\n\r\n  fromComponent<T extends AsiDialogView>(content: ComponentType<T>, config: AsiDialogConfig): AsiDialog<T> {\r\n    let containerRef = this.getContainer();\r\n\r\n    if (!this.dialogEmptySubscription || this.dialogEmptySubscription.closed) {\r\n      this.dialogEmptySubscription = containerRef.instance.onContainerEmpty().subscribe(() => {\r\n        this.dialogEmptySubscription.unsubscribe();\r\n        this.dialogContainer.destroy();\r\n        this.dialogContainer = null;\r\n      });\r\n    }\r\n\r\n    let dialogRef = this.createDialog(content, containerRef, config);\r\n    containerRef.instance.addDialog(dialogRef);\r\n\r\n    return dialogRef.instance;\r\n  }\r\n\r\n  private getContainer(): ComponentRef<AsiDialogContainer> {\r\n    if (this.dialogContainer == null) {\r\n      // Récuperation du rootComponent\r\n      const rootComponent = this.appRef.components[0].instance;\r\n      if (!rootComponent.viewContainerRef) {\r\n        const appName = this.appRef.componentTypes[0].name;\r\n        // tslint:disable-next-line:max-line-length\r\n        throw new Error('AsiDialog: Please add \"viewContainerRef : ViewContainerRef\" declaration in your root component constructor : ' + appName);\r\n      }\r\n      // Création d'un AsiDialogContainer\r\n      const asiDialogContainerFactory: ComponentFactory<AsiDialogContainer> = this.resolver.resolveComponentFactory(AsiDialogContainer);\r\n      let containerRef: ComponentRef<AsiDialogContainer> = rootComponent.viewContainerRef.createComponent(asiDialogContainerFactory, 0);\r\n      this.dialogContainer = containerRef;\r\n    }\r\n    return this.dialogContainer;\r\n  }\r\n\r\n  private createDialog<T extends AsiDialogView>(content: ComponentType<T>, containerRef: ComponentRef<AsiDialogContainer>,\r\n    config: AsiDialogConfig): ComponentRef<AsiDialog<T>> {\r\n\r\n    // Creation de la dialog\r\n    const asiDialogFactory: ComponentFactory<AsiDialog<T>> = this.resolver.resolveComponentFactory<AsiDialog<T>>(AsiDialog);\r\n    let asiDialogRef = containerRef.instance.viewContainerRef.createComponent(asiDialogFactory, 0);\r\n\r\n    asiDialogRef.instance.setConfig(config);\r\n\r\n    // Moving dialog in div dialog-container\r\n    containerRef.location.nativeElement.children[0].appendChild(asiDialogRef.location.nativeElement);\r\n\r\n    //  Create component\r\n    const contentFactory = this.resolver.resolveComponentFactory(content);\r\n    let contentRef = asiDialogRef.instance.viewContainerRef.createComponent(contentFactory);\r\n\r\n    let contentComponent = contentRef.instance;\r\n\r\n    // Ajout de la reference du composant dans le AsiDialog\r\n    asiDialogRef.instance['_component'] = contentComponent;\r\n\r\n    contentComponent.registerDialog(asiDialogRef.instance);\r\n\r\n    // Deplacement du contenu dans la div dialog-panel\r\n    asiDialogRef.location.nativeElement.children[0].appendChild(contentRef.location.nativeElement);\r\n\r\n    return asiDialogRef;\r\n  }\r\n}\r\n"]}