UNPKG

@asi-ngtools/lib

Version:

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

123 lines (122 loc) 14 kB
/** * @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'; var AsiNotificationService = /** @class */ (function () { function AsiNotificationService(resolver, appRef) { this.resolver = resolver; this.appRef = appRef; this.containerByPosition = new Map(); } /** * @template T * @param {?} content * @param {?} config * @return {?} */ AsiNotificationService.prototype.fromComponent = /** * @template T * @param {?} content * @param {?} config * @return {?} */ function (content, config) { /** @type {?} */ var containerRef = this.getContainerForPosition(config.position); /** @type {?} */ var notificationRef = this.createNotificiation(content, containerRef, config); containerRef.instance.addNotification(notificationRef, config); return notificationRef.instance; }; /** * @param {?} position * @return {?} */ AsiNotificationService.prototype.getContainerForPosition = /** * @param {?} position * @return {?} */ function (position) { var _this = this; if (this.containerByPosition.get(position) == null) { /** @type {?} */ var rootComponent = this.appRef.components[0].instance; if (!rootComponent.viewContainerRef) { /** @type {?} */ var 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 {?} */ var asiNotificationContainerFactory = this.resolver.resolveComponentFactory(AsiNotificationContainer); /** @type {?} */ var 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(function (asiNotificationContainer) { /** @type {?} */ var 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 {?} */ AsiNotificationService.prototype.createNotificiation = /** * @template T * @param {?} content * @param {?} containerRef * @param {?} config * @return {?} */ function (content, containerRef, config) { /** @type {?} */ var asiNotificationFactory = this.resolver.resolveComponentFactory(AsiNotification); /** @type {?} */ var 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 {?} */ var contentFactory = this.resolver.resolveComponentFactory(content); /** @type {?} */ var contentRef = asiNotificationRef.instance.viewContainerRef.createComponent(contentFactory); /** @type {?} */ var 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 = function () { return [ { type: ComponentFactoryResolver }, { type: ApplicationRef } ]; }; return AsiNotificationService; }()); export { AsiNotificationService }; 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"]}