UNPKG

ng-block-ui

Version:
106 lines 15.7 kB
import { Directive, Input } from '@angular/core'; import { BlockUIContentComponent } from '../components/block-ui-content/block-ui-content.component'; import { BlockUIDefaultName } from '../constants/block-ui-default-name.constant'; import * as i0 from "@angular/core"; import * as i1 from "../services/block-ui.service"; import * as i2 from "../services/block-ui-instance.service"; export class BlockUIDirective { constructor(blockUIService, blockUIInstanceService, viewRef, templateRef, renderer, componentFactoryResolver) { this.blockUIService = blockUIService; this.blockUIInstanceService = blockUIInstanceService; this.viewRef = viewRef; this.templateRef = templateRef; this.renderer = renderer; this.componentFactoryResolver = componentFactoryResolver; } set blockUI(name) { this.blockTarget = name; } ; set blockUIMessage(message) { this.message = message; } ; set blockUITemplate(template) { this.template = template; } ; set blockUIDelayStart(delayStart) { this.delayStart = delayStart ? Number(delayStart) : null; } ; set blockUIDelayStop(delayStop) { this.delayStop = delayStop ? Number(delayStop) : null; } ; ngOnInit() { try { this.viewRef.createEmbeddedView(this.templateRef); const parentElement = this.getParentElement(); if (parentElement && !this.isComponentInTemplate(parentElement)) { this.renderer.addClass(parentElement, 'block-ui__element'); this.blockUIComponentRef = this.createComponent(); let blockUIContent = this.findContentNode(this.viewRef.element.nativeElement); if (blockUIContent) { const settings = this.blockUIInstanceService.getSettings(); parentElement.appendChild(blockUIContent); this.blockUIComponentRef.instance.className = 'block-ui-wrapper--element'; this.blockUIComponentRef.instance.name = this.blockTarget || BlockUIDefaultName; if (this.message) this.blockUIComponentRef.instance.defaultMessage = this.message; if (this.delayStart) this.blockUIComponentRef.instance.delayStart = this.delayStart; if (this.delayStop) this.blockUIComponentRef.instance.delayStop = this.delayStop; if (this.template || settings.template) this.blockUIComponentRef.instance.templateCmp = this.template || settings.template; } } } catch (error) { console.error('ng-block-ui:', error); } } isComponentInTemplate(element) { // Needed because of https://github.com/microsoft/TypeScript/issues/26235 const targetElement = element || {}; let { children } = targetElement; children = Array.from(children || []).reverse(); return children.some((el) => el && el.localName === 'block-ui'); } getParentElement() { const embeddedView = this.viewRef.get(0); return embeddedView.rootNodes[0]; } // Needed for IE (#17) findContentNode(element) { const nextSibling = element.nextSibling || {}; const previousSibling = element.previousSibling || {}; return [ nextSibling, nextSibling.nextSibling, previousSibling, previousSibling.previousSibling ].find((e) => e && e.localName === 'block-ui-content'); } createComponent() { const resolvedBlockUIComponent = this.componentFactoryResolver.resolveComponentFactory(BlockUIContentComponent); return this.viewRef.createComponent(resolvedBlockUIComponent); } ngOnDestroy() { if (this.blockTarget) { this.blockUIService.reset(this.blockTarget); } } } BlockUIDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BlockUIDirective, deps: [{ token: i1.BlockUIService }, { token: i2.BlockUIInstanceService }, { token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive }); BlockUIDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: BlockUIDirective, selector: "[blockUI]", inputs: { blockUI: "blockUI", blockUIMessage: "blockUIMessage", blockUITemplate: "blockUITemplate", blockUIDelayStart: "blockUIDelayStart", blockUIDelayStop: "blockUIDelayStop" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BlockUIDirective, decorators: [{ type: Directive, args: [{ selector: '[blockUI]' }] }], ctorParameters: function () { return [{ type: i1.BlockUIService }, { type: i2.BlockUIInstanceService }, { type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { blockUI: [{ type: Input }], blockUIMessage: [{ type: Input }], blockUITemplate: [{ type: Input }], blockUIDelayStart: [{ type: Input }], blockUIDelayStop: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block-ui.directive.js","sourceRoot":"","sources":["../../../lib/directives/block-ui.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EASN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,2DAA2D,CAAC;AAEpG,OAAO,EAAE,kBAAkB,EAAE,MAAM,6CAA6C,CAAC;;;;AAIjF,MAAM,OAAO,gBAAgB;IAuB3B,YACU,cAA8B,EAC9B,sBAA8C,EAC9C,OAAyB,EACzB,WAA6B,EAC7B,QAAmB,EACnB,wBAAkD;QALlD,mBAAc,GAAd,cAAc,CAAgB;QAC9B,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,YAAO,GAAP,OAAO,CAAkB;QACzB,gBAAW,GAAX,WAAW,CAAkB;QAC7B,aAAQ,GAAR,QAAQ,CAAW;QACnB,6BAAwB,GAAxB,wBAAwB,CAA0B;IACxD,CAAC;IAtBL,IACI,OAAO,CAAC,IAAS,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC;IAAA,CAAC;IACpD,IACI,cAAc,CAAC,OAAY,IAAI,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;IAAA,CAAC;IAC7D,IACI,eAAe,CAAC,QAAa,IAAI,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC;IAAA,CAAC;IACjE,IACI,iBAAiB,CAAC,UAAe;QACnC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3D,CAAC;IAAA,CAAC;IACF,IACI,gBAAgB,CAAC,SAAc;QACjC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxD,CAAC;IAAA,CAAC;IAWF,QAAQ;QACN,IAAI;YACF,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAClD,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAE9C,IAAI,aAAa,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,EAAE;gBAC/D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,EAAE,mBAAmB,CAAC,CAAC;gBAC3D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;gBAClD,IAAI,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;gBAE9E,IAAI,cAAc,EAAE;oBAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,sBAAsB,CAAC,WAAW,EAAE,CAAC;oBAE3D,aAAa,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;oBAC1C,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,SAAS,GAAG,2BAA2B,CAAC;oBAC1E,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,IAAI,kBAAkB,CAAC;oBAChF,IAAI,IAAI,CAAC,OAAO;wBAAE,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC;oBAClF,IAAI,IAAI,CAAC,UAAU;wBAAE,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;oBACpF,IAAI,IAAI,CAAC,SAAS;wBAAE,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;oBACjF,IAAI,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ;wBACpC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ,CAAC;iBACtF;aACF;SACF;QAAC,OAAO,KAAK,EAAE;YACd,OAAO,CAAC,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;SACtC;IACH,CAAC;IAEO,qBAAqB,CAAC,OAAY;QACxC,yEAAyE;QACzE,MAAM,aAAa,GAAG,OAAO,IAAI,EAAE,CAAC;QACpC,IAAI,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC;QACjC,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;QAChD,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,SAAS,KAAK,UAAU,CAAC,CAAC;IACvE,CAAC;IAEO,gBAAgB;QACtB,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAyB,CAAC;QAEjE,OAAO,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAEnC,CAAC;IAED,sBAAsB;IACd,eAAe,CAAC,OAAY;QAClC,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;QAC9C,MAAM,eAAe,GAAG,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC;QAEtD,OAAO;YACL,WAAW;YACX,WAAW,CAAC,WAAW;YACvB,eAAe;YACf,eAAe,CAAC,eAAe;SAChC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,KAAK,kBAAkB,CAAC,CAAC;IACzD,CAAC;IAEO,eAAe;QACrB,MAAM,wBAAwB,GAAG,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,uBAAuB,CAAC,CAAC;QAChH,OAAO,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC;IAChE,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC7C;IACH,CAAC;;6GAjGU,gBAAgB;iGAAhB,gBAAgB;2FAAhB,gBAAgB;kBAD5B,SAAS;mBAAC,EAAE,QAAQ,EAAE,WAAW,EAAE;kQAU9B,OAAO;sBADV,KAAK;gBAGF,cAAc;sBADjB,KAAK;gBAGF,eAAe;sBADlB,KAAK;gBAGF,iBAAiB;sBADpB,KAAK;gBAKF,gBAAgB;sBADnB,KAAK","sourcesContent":["import {\n  Directive,\n  Input,\n  OnInit,\n  OnDestroy,\n  ComponentRef,\n  ComponentFactoryResolver,\n  ViewContainerRef,\n  TemplateRef,\n  Renderer2,\n  EmbeddedViewRef\n} from '@angular/core';\nimport { BlockUIContentComponent } from '../components/block-ui-content/block-ui-content.component';\nimport { BlockUIInstanceService } from '../services/block-ui-instance.service';\nimport { BlockUIDefaultName } from '../constants/block-ui-default-name.constant';\nimport { BlockUIService } from '../services/block-ui.service';\n\n@Directive({ selector: '[blockUI]' })\nexport class BlockUIDirective implements OnInit, OnDestroy {\n  private blockUIComponentRef: ComponentRef<BlockUIContentComponent>;\n  blockTarget: string;\n  message: any;\n  template: any;\n  delayStart: any;\n  delayStop: any;\n\n  @Input()\n  set blockUI(name: any) { this.blockTarget = name; };\n  @Input()\n  set blockUIMessage(message: any) { this.message = message; };\n  @Input()\n  set blockUITemplate(template: any) { this.template = template; };\n  @Input()\n  set blockUIDelayStart(delayStart: any) {\n    this.delayStart = delayStart ? Number(delayStart) : null;\n  };\n  @Input()\n  set blockUIDelayStop(delayStop: any) {\n    this.delayStop = delayStop ? Number(delayStop) : null;\n  };\n\n  constructor(\n    private blockUIService: BlockUIService,\n    private blockUIInstanceService: BlockUIInstanceService,\n    private viewRef: ViewContainerRef,\n    private templateRef: TemplateRef<any>,\n    private renderer: Renderer2,\n    private componentFactoryResolver: ComponentFactoryResolver\n  ) { }\n\n  ngOnInit() {\n    try {\n      this.viewRef.createEmbeddedView(this.templateRef);\n      const parentElement = this.getParentElement();\n\n      if (parentElement && !this.isComponentInTemplate(parentElement)) {\n        this.renderer.addClass(parentElement, 'block-ui__element');\n        this.blockUIComponentRef = this.createComponent();\n        let blockUIContent = this.findContentNode(this.viewRef.element.nativeElement);\n\n        if (blockUIContent) {\n          const settings = this.blockUIInstanceService.getSettings();\n\n          parentElement.appendChild(blockUIContent);\n          this.blockUIComponentRef.instance.className = 'block-ui-wrapper--element';\n          this.blockUIComponentRef.instance.name = this.blockTarget || BlockUIDefaultName;\n          if (this.message) this.blockUIComponentRef.instance.defaultMessage = this.message;\n          if (this.delayStart) this.blockUIComponentRef.instance.delayStart = this.delayStart;\n          if (this.delayStop) this.blockUIComponentRef.instance.delayStop = this.delayStop;\n          if (this.template || settings.template)\n            this.blockUIComponentRef.instance.templateCmp = this.template || settings.template;\n        }\n      }\n    } catch (error) {\n      console.error('ng-block-ui:', error);\n    }\n  }\n\n  private isComponentInTemplate(element: any): boolean {\n    // Needed because of https://github.com/microsoft/TypeScript/issues/26235\n    const targetElement = element || {};\n    let { children } = targetElement;\n    children = Array.from(children || []).reverse();\n    return children.some((el: any) => el && el.localName === 'block-ui');\n  }\n\n  private getParentElement(): Element {\n    const embeddedView = this.viewRef.get(0) as EmbeddedViewRef<any>;\n\n    return embeddedView.rootNodes[0];\n\n  }\n\n  // Needed for IE (#17)\n  private findContentNode(element: any) {\n    const nextSibling = element.nextSibling || {};\n    const previousSibling = element.previousSibling || {};\n\n    return [\n      nextSibling,\n      nextSibling.nextSibling,\n      previousSibling,\n      previousSibling.previousSibling\n    ].find((e) => e && e.localName === 'block-ui-content');\n  }\n\n  private createComponent() {\n    const resolvedBlockUIComponent = this.componentFactoryResolver.resolveComponentFactory(BlockUIContentComponent);\n    return this.viewRef.createComponent(resolvedBlockUIComponent);\n  }\n\n  ngOnDestroy() {\n    if (this.blockTarget) {\n      this.blockUIService.reset(this.blockTarget);\n    }\n  }\n}\n"]}