UNPKG

@coreui/angular

Version:

CoreUI for Angular UI components library

191 lines 24 kB
import { Directive, HostBinding, Inject, Input } from '@angular/core'; import { DOCUMENT } from '@angular/common'; import { createPopper } from '@popperjs/core'; import { PopoverComponent } from './popover/popover.component'; import { ListenersService } from '../services/listeners.service'; import * as i0 from "@angular/core"; import * as i1 from "../services/listeners.service"; export class PopoverDirective { constructor(document, renderer, hostElement, componentFactoryResolver, viewContainerRef, listenersService) { this.document = document; this.renderer = renderer; this.hostElement = hostElement; this.componentFactoryResolver = componentFactoryResolver; this.viewContainerRef = viewContainerRef; this.listenersService = listenersService; /** * Content of popover * @type {string | TemplateRef} */ this.content = ''; /** * Describes the placement of your component after Popper.js has applied all the modifiers that may have flipped or altered the originally provided placement property. */ this.placement = 'top'; /** * Sets which event handlers you’d like provided to your toggle prop. You can specify one trigger or an array of them. * @type {'hover' | 'focus' | 'click'} */ this.trigger = 'hover'; this._visible = false; this._popperOptions = { modifiers: [ { name: 'offset', options: { offset: [0, 8], }, }, ], }; } /** * Optional popper Options object, takes precedence over cPopoverPlacement prop * @type Partial<Options> */ set popperOptions(value) { this._popperOptions = { ...this._popperOptions, placement: this.placement, ...value }; } ; get popperOptions() { return { placement: this.placement, ...this._popperOptions }; } /** * Toggle the visibility of popover component. */ set visible(value) { this._visible = value; } get visible() { return this._visible; } ngOnChanges(changes) { if (changes['visible']) { changes['visible'].currentValue ? this.addPopoverElement() : this.removePopoverElement(); } } get ariaDescribedBy() { return this.popoverId ? this.popoverId : null; } ngOnDestroy() { this.clearListeners(); this.destroyPopoverElement(); } ngOnInit() { // this.createPopoverElement(); this.setListeners(); } setListeners() { const config = { hostElement: this.hostElement, trigger: this.trigger, callbackToggle: () => { this.visible = !this.visible; this.visible ? this.addPopoverElement() : this.removePopoverElement(); }, callbackOff: () => { this.visible = false; this.removePopoverElement(); }, callbackOn: () => { this.visible = true; this.addPopoverElement(); } }; this.listenersService.setListeners(config); } clearListeners() { this.listenersService.clearListeners(); } getUID(prefix) { let uid = prefix ?? 'random-id'; do { uid = `${prefix}-${Math.floor(Math.random() * 1000000).toString(10)}`; } while (this.document.getElementById(uid)); return uid; } createPopoverElement() { if (!this.popoverRef) { const popoverComponent = this.componentFactoryResolver.resolveComponentFactory(PopoverComponent); this.popoverRef = popoverComponent.create(this.viewContainerRef.injector); } } destroyPopoverElement() { this.popover?.remove(); this.popoverRef?.destroy(); // @ts-ignore this.popoverRef = undefined; this.popperInstance?.destroy(); this.viewContainerRef.detach(); this.viewContainerRef.clear(); } addPopoverElement() { if (!this.popoverRef) { this.createPopoverElement(); } this.popoverRef.instance.content = this.content; this.popover = this.popoverRef.location.nativeElement; this.renderer.addClass(this.popover, 'fade'); // this.renderer.setStyle(this.popover, 'visibility', 'hidden') setTimeout(() => { this.popperInstance = createPopper(this.hostElement.nativeElement, this.popover, { ...this.popperOptions }); this.viewContainerRef.insert(this.popoverRef.hostView); setTimeout(() => { this.popoverId = this.getUID('popover'); this.popoverRef.instance.id = this.popoverId; this.popoverRef.instance.visible = this.visible; // this.renderer.removeStyle(this.popover, 'visibility'); this.renderer.appendChild(this.document.body, this.popover); this.popperInstance.forceUpdate(); // this.popoverRef.changeDetectorRef.detectChanges(); }, 100); }); } removePopoverElement() { if (!this.popoverRef) { return; } this.popoverRef.instance.visible = this.visible; // this.popoverRef.changeDetectorRef?.detectChanges(); this.popoverRef.instance.id = undefined; setTimeout(() => { this.viewContainerRef.detach(); // this.viewContainerRef.remove(); // this.renderer.removeChild(this.document.body, this.popover); this.popperInstance?.destroy(); this.popoverId = ''; }, 300); } } PopoverDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: PopoverDirective, deps: [{ token: DOCUMENT }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: i1.ListenersService }], target: i0.ɵɵFactoryTarget.Directive }); PopoverDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: PopoverDirective, selector: "[cPopover]", inputs: { content: ["cPopover", "content"], popperOptions: ["cPopoverOptions", "popperOptions"], placement: ["cPopoverPlacement", "placement"], trigger: ["cPopoverTrigger", "trigger"], visible: ["cPopoverVisible", "visible"] }, host: { properties: { "attr.aria-describedby": "this.ariaDescribedBy" } }, providers: [ListenersService], exportAs: ["cPopover"], usesOnChanges: true, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: PopoverDirective, decorators: [{ type: Directive, args: [{ selector: '[cPopover]', exportAs: 'cPopover', providers: [ListenersService] }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }, { type: i1.ListenersService }]; }, propDecorators: { content: [{ type: Input, args: ['cPopover'] }], popperOptions: [{ type: Input, args: ['cPopoverOptions'] }], placement: [{ type: Input, args: ['cPopoverPlacement'] }], trigger: [{ type: Input, args: ['cPopoverTrigger'] }], visible: [{ type: Input, args: ['cPopoverVisible'] }], ariaDescribedBy: [{ type: HostBinding, args: ['attr.aria-describedby'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"","sources":["../../../../../projects/coreui-angular/src/lib/popover/popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ComponentFactoryResolver,\r\n  ComponentRef,\r\n  Directive,\r\n  ElementRef,\r\n  HostBinding,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { createPopper, Instance, Options } from '@popperjs/core';\r\n\r\nimport { Triggers } from '../coreui.types';\r\nimport { PopoverComponent } from './popover/popover.component';\r\nimport { IListenersConfig, ListenersService } from '../services/listeners.service';\r\n\r\n@Directive({\r\n  selector: '[cPopover]',\r\n  exportAs: 'cPopover',\r\n  providers: [ListenersService]\r\n})\r\nexport class PopoverDirective implements OnChanges, OnDestroy, OnInit {\r\n\r\n  /**\r\n   * Content of popover\r\n   * @type {string | TemplateRef}\r\n   */\r\n  @Input('cPopover') content: string | TemplateRef<any> = '';\r\n\r\n  /**\r\n   * Optional popper Options object, takes precedence over cPopoverPlacement prop\r\n   * @type Partial<Options>\r\n   */\r\n  @Input('cPopoverOptions')\r\n  set popperOptions(value: Partial<Options>) {\r\n    this._popperOptions = {...this._popperOptions, placement: this.placement, ...value};\r\n  };\r\n  get popperOptions(): Partial<Options> {\r\n    return {placement: this.placement, ...this._popperOptions};\r\n  }\r\n\r\n  /**\r\n   * Describes the placement of your component after Popper.js has applied all the modifiers that may have flipped or altered the originally provided placement property.\r\n   */\r\n  @Input('cPopoverPlacement') placement: 'top' | 'bottom' | 'left' | 'right' = 'top';\r\n  /**\r\n   * Sets which event handlers you’d like provided to your toggle prop. You can specify one trigger or an array of them.\r\n   * @type {'hover' | 'focus' | 'click'}\r\n   */\r\n  @Input('cPopoverTrigger') trigger?: Triggers | Triggers[] = 'hover';\r\n\r\n  /**\r\n   * Toggle the visibility of popover component.\r\n   */\r\n  @Input('cPopoverVisible')\r\n  set visible(value: boolean) {\r\n    this._visible = value;\r\n  }\r\n  get visible() {\r\n    return this._visible;\r\n  }\r\n  private _visible = false;\r\n\r\n  private popover!: HTMLDivElement;\r\n  private popoverId!: string;\r\n  private popoverRef!: ComponentRef<PopoverComponent>;\r\n  private popperInstance!: Instance;\r\n\r\n  private _popperOptions: Partial<Options> = {\r\n    modifiers: [\r\n      {\r\n        name: 'offset',\r\n        options: {\r\n          offset: [0, 8],\r\n        },\r\n      },\r\n    ],\r\n  };\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: any,\r\n    private renderer: Renderer2,\r\n    private hostElement: ElementRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private listenersService: ListenersService\r\n  ) {}\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['visible']) {\r\n      changes['visible'].currentValue ? this.addPopoverElement() : this.removePopoverElement();\r\n    }\r\n  }\r\n\r\n  @HostBinding('attr.aria-describedby') get ariaDescribedBy(): string | null {\r\n    return this.popoverId ? this.popoverId : null;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.clearListeners();\r\n    this.destroyPopoverElement();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // this.createPopoverElement();\r\n    this.setListeners();\r\n  }\r\n\r\n  private setListeners(): void {\r\n    const config: IListenersConfig = {\r\n      hostElement: this.hostElement,\r\n      trigger: this.trigger,\r\n      callbackToggle: () => {\r\n        this.visible = !this.visible;\r\n        this.visible ? this.addPopoverElement() : this.removePopoverElement();\r\n      },\r\n      callbackOff: () => {\r\n        this.visible = false;\r\n        this.removePopoverElement();\r\n      },\r\n      callbackOn: () => {\r\n        this.visible = true;\r\n        this.addPopoverElement();\r\n      }\r\n    }\r\n    this.listenersService.setListeners(config)\r\n  }\r\n\r\n  private clearListeners(): void {\r\n    this.listenersService.clearListeners();\r\n  }\r\n\r\n  private getUID(prefix: string): string {\r\n    let uid = prefix ?? 'random-id';\r\n    do {\r\n      uid = `${prefix}-${Math.floor(Math.random() * 1000000).toString(10)}`;\r\n    } while (this.document.getElementById(uid));\r\n\r\n    return uid;\r\n  }\r\n\r\n  private createPopoverElement(): void {\r\n    if (!this.popoverRef) {\r\n      const popoverComponent =\r\n        this.componentFactoryResolver.resolveComponentFactory(PopoverComponent);\r\n      this.popoverRef = popoverComponent.create(this.viewContainerRef.injector);\r\n    }\r\n  }\r\n\r\n  private destroyPopoverElement(): void {\r\n    this.popover?.remove();\r\n    this.popoverRef?.destroy();\r\n    // @ts-ignore\r\n    this.popoverRef = undefined;\r\n    this.popperInstance?.destroy();\r\n    this.viewContainerRef.detach();\r\n    this.viewContainerRef.clear();\r\n  }\r\n\r\n  private addPopoverElement(): void {\r\n    if (!this.popoverRef) {\r\n      this.createPopoverElement();\r\n    }\r\n    this.popoverRef.instance.content = this.content;\r\n    this.popover = this.popoverRef.location.nativeElement;\r\n    this.renderer.addClass(this.popover, 'fade');\r\n    // this.renderer.setStyle(this.popover, 'visibility', 'hidden')\r\n\r\n    setTimeout(() => {\r\n      this.popperInstance = createPopper(\r\n        this.hostElement.nativeElement,\r\n        this.popover,\r\n        {...this.popperOptions}\r\n      );\r\n      this.viewContainerRef.insert(this.popoverRef.hostView);\r\n      setTimeout(() => {\r\n        this.popoverId = this.getUID('popover');\r\n        this.popoverRef.instance.id = this.popoverId;\r\n        this.popoverRef.instance.visible = this.visible;\r\n        // this.renderer.removeStyle(this.popover, 'visibility');\r\n        this.renderer.appendChild(this.document.body, this.popover);\r\n        this.popperInstance.forceUpdate();\r\n        // this.popoverRef.changeDetectorRef.detectChanges();\r\n      }, 100);\r\n    })\r\n  }\r\n\r\n  private removePopoverElement(): void {\r\n    if (!this.popoverRef) {\r\n      return;\r\n    }\r\n    this.popoverRef.instance.visible = this.visible;\r\n    // this.popoverRef.changeDetectorRef?.detectChanges();\r\n    this.popoverRef.instance.id = undefined;\r\n    setTimeout(() => {\r\n      this.viewContainerRef.detach();\r\n      // this.viewContainerRef.remove();\r\n      // this.renderer.removeChild(this.document.body, this.popover);\r\n      this.popperInstance?.destroy();\r\n      this.popoverId = '';\r\n    }, 300);\r\n  }\r\n}\r\n"]}