@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) • 13.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { AsiNotification } from './notification/asi-notification.component';
import { AsiNotificationContainer } from './container/asi-notification-container.component';
import { Injectable, ComponentFactoryResolver, ApplicationRef } from '@angular/core';
export class AsiNotificationService {
/**
* @param {?} resolver
* @param {?} appRef
*/
constructor(resolver, appRef) {
this.resolver = resolver;
this.appRef = appRef;
this.containerByPosition = new Map();
}
/**
* @template T
* @param {?} content
* @param {?} config
* @return {?}
*/
fromComponent(content, config) {
/** @type {?} */
let containerRef = this.getContainerForPosition(config.position);
/** @type {?} */
let notificationRef = this.createNotificiation(content, containerRef, config);
containerRef.instance.addNotification(notificationRef, config);
return notificationRef.instance;
}
/**
* @param {?} position
* @return {?}
*/
getContainerForPosition(position) {
if (this.containerByPosition.get(position) == 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('AsiNotification : Please add "viewContainerRef : ViewContainerRef" declaration in your root component constructor : ' + appName);
}
/** @type {?} */
const asiNotificationContainerFactory = this.resolver.resolveComponentFactory(AsiNotificationContainer);
/** @type {?} */
let containerRef = rootComponent.viewContainerRef.createComponent(asiNotificationContainerFactory, 0);
containerRef.instance.setPosition(position);
this.containerByPosition.set(position, containerRef);
// Ecoute de la mise a vide du container pour le supprimer
containerRef.instance.onContainerEmpty().subscribe((asiNotificationContainer) => {
/** @type {?} */
const containerToDestroy = this.containerByPosition.get(asiNotificationContainer.getPosition());
this.containerByPosition.delete(asiNotificationContainer.getPosition());
containerToDestroy.destroy();
});
}
return this.containerByPosition.get(position);
}
/**
* @template T
* @param {?} content
* @param {?} containerRef
* @param {?} config
* @return {?}
*/
createNotificiation(content, containerRef, config) {
/** @type {?} */
const asiNotificationFactory = this.resolver.resolveComponentFactory(AsiNotification);
/** @type {?} */
let asiNotificationRef = containerRef.instance.viewContainerRef.createComponent(asiNotificationFactory, 0);
asiNotificationRef.instance.setConfig(config);
// Deplacement de la notification dans la div notifications-container
containerRef.location.nativeElement.children[0].appendChild(asiNotificationRef.location.nativeElement);
/** @type {?} */
const contentFactory = this.resolver.resolveComponentFactory(content);
/** @type {?} */
let contentRef = asiNotificationRef.instance.viewContainerRef.createComponent(contentFactory);
/** @type {?} */
let contentComponent = contentRef.instance;
// Ajout de la reference du composant dans le AsiNotification
asiNotificationRef.instance['_component'] = contentComponent;
// Deplacement du contenu dans la div notification-panel
asiNotificationRef.location.nativeElement.appendChild(contentRef.location.nativeElement);
return asiNotificationRef;
}
}
AsiNotificationService.decorators = [
{ type: Injectable }
];
/** @nocollapse */
AsiNotificationService.ctorParameters = () => [
{ type: ComponentFactoryResolver },
{ type: ApplicationRef }
];
if (false) {
/** @type {?} */
AsiNotificationService.prototype.containerByPosition;
/** @type {?} */
AsiNotificationService.prototype.resolver;
/** @type {?} */
AsiNotificationService.prototype.appRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-notification.service.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-notification/asi-notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentType } from './../common/component-type';\r\nimport { AsiNotification } from './notification/asi-notification.component';\r\nimport { AsiNotificationContainer } from './container/asi-notification-container.component';\r\nimport { AsiNotificationConfig, AsiNotificationPosition } from './asi-notification-config';\r\nimport { Injectable, ComponentFactory, ComponentFactoryResolver, ComponentRef, ApplicationRef } from '@angular/core';\r\n\r\n@Injectable()\r\nexport class AsiNotificationService {\r\n\r\n  private containerByPosition = new Map<AsiNotificationPosition, ComponentRef<AsiNotificationContainer>>();\r\n\r\n  constructor(private resolver: ComponentFactoryResolver, private appRef: ApplicationRef) {\r\n  }\r\n\r\n  fromComponent<T>(content: ComponentType<T>, config: AsiNotificationConfig): AsiNotification<T> {\r\n    let containerRef = this.getContainerForPosition(config.position);\r\n\r\n    let notificationRef = this.createNotificiation(content, containerRef, config);\r\n    containerRef.instance.addNotification(notificationRef, config);\r\n\r\n    return notificationRef.instance;\r\n  }\r\n\r\n  private getContainerForPosition(position: AsiNotificationPosition): ComponentRef<AsiNotificationContainer> {\r\n    if (this.containerByPosition.get(position) == 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('AsiNotification : Please add \"viewContainerRef : ViewContainerRef\" declaration in your root component constructor : ' + appName);\r\n      }\r\n      // Création d'un AsiNotificationContainer\r\n      const asiNotificationContainerFactory: ComponentFactory<AsiNotificationContainer> =\r\n        this.resolver.resolveComponentFactory(AsiNotificationContainer);\r\n      let containerRef = rootComponent.viewContainerRef.createComponent(asiNotificationContainerFactory, 0);\r\n      containerRef.instance.setPosition(position);\r\n      this.containerByPosition.set(position, containerRef);\r\n\r\n      // Ecoute de la mise a vide du container pour le supprimer\r\n      containerRef.instance.onContainerEmpty().subscribe((asiNotificationContainer: AsiNotificationContainer) => {\r\n        const containerToDestroy = this.containerByPosition.get(asiNotificationContainer.getPosition());\r\n        this.containerByPosition.delete(asiNotificationContainer.getPosition());\r\n        containerToDestroy.destroy();\r\n      });\r\n    }\r\n    return this.containerByPosition.get(position);\r\n  }\r\n\r\n  private createNotificiation<T>(content: ComponentType<T>, containerRef: ComponentRef<AsiNotificationContainer>,\r\n    config: AsiNotificationConfig): ComponentRef<AsiNotification<T>> {\r\n\r\n    // Creation de la ntoficiation\r\n    const asiNotificationFactory: ComponentFactory<AsiNotification<T>> =\r\n      this.resolver.resolveComponentFactory<AsiNotification<T>>(AsiNotification);\r\n    let asiNotificationRef = containerRef.instance.viewContainerRef.createComponent(asiNotificationFactory, 0);\r\n\r\n    asiNotificationRef.instance.setConfig(config);\r\n\r\n    // Deplacement de la notification dans la div notifications-container\r\n    containerRef.location.nativeElement.children[0].appendChild(asiNotificationRef.location.nativeElement);\r\n\r\n    // Création du composant désiré\r\n    const contentFactory = this.resolver.resolveComponentFactory(content);\r\n    let contentRef = asiNotificationRef.instance.viewContainerRef.createComponent(contentFactory);\r\n\r\n    let contentComponent = contentRef.instance;\r\n\r\n    // Ajout de la reference du composant dans le AsiNotification\r\n    asiNotificationRef.instance['_component'] = contentComponent;\r\n\r\n    // Deplacement du contenu dans la div notification-panel\r\n    asiNotificationRef.location.nativeElement.appendChild(contentRef.location.nativeElement);\r\n\r\n    return asiNotificationRef;\r\n  }\r\n}\r\n"]}