@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
JavaScript
/**
* @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"]}