@coreui/angular
Version:
CoreUI for Angular UI components library
196 lines • 23.5 kB
JavaScript
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, viewContainerRef, listenersService, changeDetectorRef) {
this.document = document;
this.renderer = renderer;
this.hostElement = hostElement;
this.viewContainerRef = viewContainerRef;
this.listenersService = listenersService;
this.changeDetectorRef = changeDetectorRef;
/**
* 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;
}
get ariaDescribedBy() {
return this.popoverId ? this.popoverId : null;
}
ngOnChanges(changes) {
if (changes['visible']) {
changes['visible'].currentValue ? this.addPopoverElement() : this.removePopoverElement();
}
}
ngOnDestroy() {
this.clearListeners();
this.destroyPopoverElement();
}
ngOnInit() {
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) {
this.popoverRef = this.viewContainerRef.createComponent(PopoverComponent);
// this.viewContainerRef.detach();
}
}
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, 'd-none');
this.renderer.addClass(this.popover, 'fade');
this.popperInstance?.destroy();
setTimeout(() => {
this.popperInstance = createPopper(this.hostElement.nativeElement, this.popover, { ...this.popperOptions });
this.viewContainerRef.insert(this.popoverRef.hostView);
this.renderer.appendChild(this.document.body, this.popover);
if (!this.visible) {
this.removePopoverElement();
return;
}
setTimeout(() => {
this.popoverId = this.getUID('popover');
this.popoverRef.instance.id = this.popoverId;
if (!this.visible) {
this.removePopoverElement();
return;
}
this.renderer.removeClass(this.popover, 'd-none');
this.popoverRef.instance.visible = this.visible;
this.popperInstance.forceUpdate();
this.changeDetectorRef.markForCheck();
}, 100);
});
}
removePopoverElement() {
this.popoverId = '';
if (!this.popoverRef) {
return;
}
this.popoverRef.instance.visible = false;
this.popoverRef.instance.id = undefined;
this.changeDetectorRef.markForCheck();
setTimeout(() => {
this.viewContainerRef.detach();
}, 300);
}
}
PopoverDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: PopoverDirective, deps: [{ token: DOCUMENT }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i1.ListenersService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
PopoverDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", 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.7", ngImport: i0, type: PopoverDirective, decorators: [{
type: Directive,
args: [{
selector: '[cPopover]',
exportAs: 'cPopover',
providers: [ListenersService]
}]
}], ctorParameters: function () { return [{ type: Document, decorators: [{
type: Inject,
args: [DOCUMENT]
}] }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.ListenersService }, { type: i0.ChangeDetectorRef }]; }, 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 {\n  ChangeDetectorRef,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { createPopper, Instance, Options } from '@popperjs/core';\n\nimport { Triggers } from '../coreui.types';\nimport { PopoverComponent } from './popover/popover.component';\nimport { IListenersConfig, ListenersService } from '../services/listeners.service';\n\n@Directive({\n  selector: '[cPopover]',\n  exportAs: 'cPopover',\n  providers: [ListenersService]\n})\nexport class PopoverDirective implements OnChanges, OnDestroy, OnInit {\n\n  /**\n   * Content of popover\n   * @type {string | TemplateRef}\n   */\n  @Input('cPopover') content: string | TemplateRef<any> = '';\n\n  /**\n   * Optional popper Options object, takes precedence over cPopoverPlacement prop\n   * @type Partial<Options>\n   */\n  @Input('cPopoverOptions')\n  set popperOptions(value: Partial<Options>) {\n    this._popperOptions = { ...this._popperOptions, placement: this.placement, ...value };\n  };\n\n  get popperOptions(): Partial<Options> {\n    return { placement: this.placement, ...this._popperOptions };\n  }\n\n  /**\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.\n   */\n  @Input('cPopoverPlacement') placement: 'top' | 'bottom' | 'left' | 'right' = 'top';\n  /**\n   * Sets which event handlers you’d like provided to your toggle prop. You can specify one trigger or an array of them.\n   * @type {'hover' | 'focus' | 'click'}\n   */\n  @Input('cPopoverTrigger') trigger?: Triggers | Triggers[] = 'hover';\n\n  /**\n   * Toggle the visibility of popover component.\n   */\n  @Input('cPopoverVisible')\n  set visible(value: boolean) {\n    this._visible = value;\n  }\n\n  get visible() {\n    return this._visible;\n  }\n\n  private _visible = false;\n\n  @HostBinding('attr.aria-describedby') get ariaDescribedBy(): string | null {\n    return this.popoverId ? this.popoverId : null;\n  }\n\n  private popover!: HTMLDivElement;\n  private popoverId!: string;\n  private popoverRef!: ComponentRef<PopoverComponent>;\n  private popperInstance!: Instance;\n\n  private _popperOptions: Partial<Options> = {\n    modifiers: [\n      {\n        name: 'offset',\n        options: {\n          offset: [0, 8]\n        }\n      }\n    ]\n  };\n\n  constructor(\n    @Inject(DOCUMENT) private document: Document,\n    private renderer: Renderer2,\n    private hostElement: ElementRef,\n    private viewContainerRef: ViewContainerRef,\n    private listenersService: ListenersService,\n    private changeDetectorRef: ChangeDetectorRef\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['visible']) {\n      changes['visible'].currentValue ? this.addPopoverElement() : this.removePopoverElement();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.clearListeners();\n    this.destroyPopoverElement();\n  }\n\n  ngOnInit(): void {\n    this.setListeners();\n  }\n\n  private setListeners(): void {\n    const config: IListenersConfig = {\n      hostElement: this.hostElement,\n      trigger: this.trigger,\n      callbackToggle: () => {\n        this.visible = !this.visible;\n        this.visible ? this.addPopoverElement() : this.removePopoverElement();\n      },\n      callbackOff: () => {\n        this.visible = false;\n        this.removePopoverElement();\n      },\n      callbackOn: () => {\n        this.visible = true;\n        this.addPopoverElement();\n      }\n    };\n    this.listenersService.setListeners(config);\n  }\n\n  private clearListeners(): void {\n    this.listenersService.clearListeners();\n  }\n\n  private getUID(prefix: string): string {\n    let uid = prefix ?? 'random-id';\n    do {\n      uid = `${prefix}-${Math.floor(Math.random() * 1000000).toString(10)}`;\n    } while (this.document.getElementById(uid));\n\n    return uid;\n  }\n\n  private createPopoverElement(): void {\n    if (!this.popoverRef) {\n      this.popoverRef = this.viewContainerRef.createComponent<PopoverComponent>(PopoverComponent);\n      // this.viewContainerRef.detach();\n    }\n  }\n\n  private destroyPopoverElement(): void {\n    this.popover?.remove();\n    this.popoverRef?.destroy();\n    // @ts-ignore\n    this.popoverRef = undefined;\n    this.popperInstance?.destroy();\n    this.viewContainerRef?.detach();\n    this.viewContainerRef?.clear();\n  }\n\n  private addPopoverElement(): void {\n    if (!this.popoverRef) {\n      this.createPopoverElement();\n    }\n    this.popoverRef.instance.content = this.content;\n    this.popover = this.popoverRef.location.nativeElement;\n    this.renderer.addClass(this.popover, 'd-none');\n    this.renderer.addClass(this.popover, 'fade');\n\n    this.popperInstance?.destroy();\n\n    setTimeout(() => {\n      this.popperInstance = createPopper(\n        this.hostElement.nativeElement,\n        this.popover,\n        { ...this.popperOptions }\n      );\n      this.viewContainerRef.insert(this.popoverRef.hostView);\n      this.renderer.appendChild(this.document.body, this.popover);\n      if (!this.visible) {\n        this.removePopoverElement();\n        return;\n      }\n      setTimeout(() => {\n        this.popoverId = this.getUID('popover');\n        this.popoverRef.instance.id = this.popoverId;\n        if (!this.visible) {\n          this.removePopoverElement();\n          return;\n        }\n        this.renderer.removeClass(this.popover, 'd-none');\n        this.popoverRef.instance.visible = this.visible;\n        this.popperInstance.forceUpdate();\n        this.changeDetectorRef.markForCheck();\n      }, 100);\n    });\n  }\n\n  private removePopoverElement(): void {\n    this.popoverId = '';\n    if (!this.popoverRef) {\n      return;\n    }\n    this.popoverRef.instance.visible = false;\n    this.popoverRef.instance.id = undefined;\n    this.changeDetectorRef.markForCheck();\n    setTimeout(() => {\n      this.viewContainerRef.detach();\n    }, 300);\n  }\n}\n"]}