@dotglitch/ngx-common 1.1.14 → 1.1.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -16,14 +16,10 @@ export declare class TooltipDirective {
16
16
  * Arbitrary data to pass into the template
17
17
  */
18
18
  data: any;
19
- private dialogInstance;
20
19
  private isCursorOverTarget;
21
- private isFreezeOnKeyCodeBound;
20
+ private dialogIsOpen;
22
21
  constructor(dialog: MatDialog, viewContainer: ViewContainerRef);
23
22
  ngAfterViewInit(): void;
24
- ngOnDestroy(): void;
25
- onKeyDown(evt: any): void;
26
- private onKeyDownEvt;
27
23
  open(): Promise<void>;
28
24
  onPointerEnter(evt: PointerEvent): Promise<void>;
29
25
  onPointerLeave(evt: PointerEvent): Promise<void>;
@@ -18,36 +18,24 @@ export class TooltipDirective {
18
18
  */
19
19
  this.data = {};
20
20
  this.isCursorOverTarget = false;
21
- this.isFreezeOnKeyCodeBound = false;
22
- this.onKeyDownEvt = this.onKeyDown.bind(this);
23
- if (this.config.freezeOnKeyCode !== null) {
24
- this.isFreezeOnKeyCodeBound = true;
25
- window.addEventListener("keydown", this.onKeyDownEvt);
26
- }
21
+ this.dialogIsOpen = false;
27
22
  }
28
23
  ngAfterViewInit() {
29
24
  const el = this.viewContainer.element.nativeElement;
30
25
  this.config?.triggers?.forEach(t => {
31
26
  el.addEventListener(t, () => {
27
+ if (t == "click")
28
+ this.config.stayOpen = true;
32
29
  this.open();
33
30
  });
34
31
  });
35
32
  }
36
- ngOnDestroy() {
37
- if (this.isFreezeOnKeyCodeBound) {
38
- window.removeEventListener("keydown", this.onKeyDownEvt);
39
- }
40
- }
41
- onKeyDown(evt) {
42
- // TODO: fade message 'tooltip is locked open'
43
- if (evt.code == ("F2")) {
44
- this.dialogInstance.componentInstance.isLockedOpen = true;
45
- }
46
- }
47
33
  async open() {
48
- if (!this.dialogInstance) {
34
+ if (!this.dialogIsOpen) {
49
35
  const el = this.viewContainer.element.nativeElement;
50
- this.dialogInstance = await openTooltip(this.dialog, this.template, this.data, el, this.config);
36
+ this.dialogIsOpen = true;
37
+ await openTooltip(this.dialog, this.template, this.data, el, this.config);
38
+ this.dialogIsOpen = false;
51
39
  }
52
40
  }
53
41
  async onPointerEnter(evt) {
@@ -138,4 +126,4 @@ export const openTooltip = async (dialog, template, data, el, config, focusTrap
138
126
  });
139
127
  });
140
128
  };
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../packages/common/src/directives/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, HostListener, TemplateRef, Type, ViewContainerRef } from '@angular/core';\nimport { MatDialog, MatDialogConfig, MatDialogRef } from '@angular/material/dialog';\nimport { getPosition } from './utils';\nimport { TooltipComponent, calcTooltipBounds } from '../components/tooltip/tooltip.component';\nimport { TooltipOptions } from '../types/tooltip';\nimport { ulid } from 'ulidx';\n\n@Directive({\n    selector: '[ngxTooltip],[ngx-tooltip]',\n    providers: [\n        MatDialog\n    ],\n    standalone: true\n})\nexport class TooltipDirective {\n\n    /**\n     */\n    @Input(\"ngxTooltip\")\n    @Input(\"ngx-tooltip\") template: TemplateRef<any> | Type<any>;\n\n    /**\n     * Configuration for opening the app menu\n     */\n    @Input(\"ngxTooltipConfig\")\n    @Input(\"ngx-tooltip-config\") config: TooltipOptions = {};\n\n    /**\n     * Arbitrary data to pass into the template\n     */\n    @Input(\"ngxTooltipContext\")\n    @Input(\"ngx-tooltip-context\") data: any = {};\n\n\n    private dialogInstance: MatDialogRef<any>;\n    private isCursorOverTarget = false;\n    private isFreezeOnKeyCodeBound = false;\n\n    constructor(\n        private dialog: MatDialog,\n        private viewContainer: ViewContainerRef\n    ) {\n        if (this.config.freezeOnKeyCode !== null) {\n            this.isFreezeOnKeyCodeBound = true;\n            window.addEventListener(\"keydown\", this.onKeyDownEvt);\n        }\n    }\n\n    ngAfterViewInit() {\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n\n        this.config?.triggers?.forEach(t => {\n            el.addEventListener(t, () => {\n                this.open();\n            })\n        })\n    }\n\n    ngOnDestroy() {\n        if (this.isFreezeOnKeyCodeBound) {\n            window.removeEventListener(\"keydown\", this.onKeyDownEvt);\n        }\n    }\n\n    onKeyDown(evt) {\n        // TODO: fade message 'tooltip is locked open'\n        if (evt.code == (\"F2\")) {\n            this.dialogInstance.componentInstance.isLockedOpen = true;\n        }\n    }\n    private onKeyDownEvt = this.onKeyDown.bind(this);\n\n    async open() {\n        if (!this.dialogInstance) {\n            const el = this.viewContainer.element.nativeElement;\n            this.dialogInstance = await openTooltip(this.dialog, this.template, this.data, el, this.config);\n        }\n    }\n\n    @HostListener('pointerenter', ['$event'])\n    public async onPointerEnter(evt: PointerEvent) {\n        // If the template is not a template ref, do nothing.\n        if (!(this.template instanceof TemplateRef))\n            return;\n\n        if (Array.isArray(this.config?.triggers) && !this.config.triggers.includes(\"hover\")) {\n            return;\n        }\n\n        this.isCursorOverTarget = true;\n\n        setTimeout(async () => {\n            // If the cursor moved away in the time\n            if (!this.isCursorOverTarget)\n                return;\n\n            this.open();\n        }, this.config.delay ?? 250);\n    }\n\n    @HostListener('pointerleave', ['$event'])\n    public async onPointerLeave(evt: PointerEvent) {\n        this.isCursorOverTarget = false;\n    }\n}\n\n// Helper to open the context menu without using the directive.\nexport const openTooltip = async (\n    dialog: MatDialog,\n    template: TemplateRef<any> | Type<any>,\n    data: any,\n    el: HTMLElement,\n    config?: TooltipOptions,\n    focusTrap = false,\n    matPopupOptions?: MatDialogConfig<any>\n) => {\n\n    const rect = await calcTooltipBounds(template, data, matPopupOptions);\n    const ownerCords = el.getBoundingClientRect();\n    const cords = getPosition(el, config, rect);\n    const specificId = ulid();\n\n    return new Promise(res => {\n        dialog.open(TooltipComponent, {\n            autoFocus: focusTrap,\n            restoreFocus: focusTrap,\n            data: {\n                dialog,\n                data: data,\n                template: template,\n                config: config,\n                matPopupOptions,\n                ownerCords: ownerCords,\n                selfCords: cords,\n                id: specificId\n            },\n            panelClass: [\"ngx-tooltip\", 'ngx-' + specificId].concat(config?.customClass || []),\n            position: cords,\n            hasBackdrop: false,\n            ...matPopupOptions\n        })\n            .afterClosed()\n            .subscribe(s => {\n                res(s);\n            })\n    }) as Promise<any>;\n};\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../packages/common/src/directives/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, HostListener, TemplateRef, Type, ViewContainerRef } from '@angular/core';\nimport { MatDialog, MatDialogConfig, MatDialogRef } from '@angular/material/dialog';\nimport { getPosition } from './utils';\nimport { TooltipComponent, calcTooltipBounds } from '../components/tooltip/tooltip.component';\nimport { TooltipOptions } from '../types/tooltip';\nimport { ulid } from 'ulidx';\n\n@Directive({\n    selector: '[ngxTooltip],[ngx-tooltip]',\n    providers: [\n        MatDialog\n    ],\n    standalone: true\n})\nexport class TooltipDirective {\n\n    /**\n     */\n    @Input(\"ngxTooltip\")\n    @Input(\"ngx-tooltip\") template: TemplateRef<any> | Type<any>;\n\n    /**\n     * Configuration for opening the app menu\n     */\n    @Input(\"ngxTooltipConfig\")\n    @Input(\"ngx-tooltip-config\") config: TooltipOptions = {};\n\n    /**\n     * Arbitrary data to pass into the template\n     */\n    @Input(\"ngxTooltipContext\")\n    @Input(\"ngx-tooltip-context\") data: any = {};\n\n    private isCursorOverTarget = false;\n    private dialogIsOpen = false;\n\n    constructor(\n        private dialog: MatDialog,\n        private viewContainer: ViewContainerRef\n    ) {\n    }\n\n    ngAfterViewInit() {\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n\n        this.config?.triggers?.forEach(t => {\n            el.addEventListener(t, () => {\n                if (t == \"click\")\n                    this.config.stayOpen = true;\n\n                this.open();\n            })\n        })\n    }\n\n    async open() {\n        if (!this.dialogIsOpen) {\n            const el = this.viewContainer.element.nativeElement;\n            this.dialogIsOpen = true;\n            await openTooltip(this.dialog, this.template, this.data, el, this.config);\n            this.dialogIsOpen = false;\n        }\n    }\n\n    @HostListener('pointerenter', ['$event'])\n    public async onPointerEnter(evt: PointerEvent) {\n        // If the template is not a template ref, do nothing.\n        if (!(this.template instanceof TemplateRef))\n            return;\n\n        if (Array.isArray(this.config?.triggers) && !this.config.triggers.includes(\"hover\")) {\n            return;\n        }\n\n        this.isCursorOverTarget = true;\n\n        setTimeout(async () => {\n            // If the cursor moved away in the time\n            if (!this.isCursorOverTarget)\n                return;\n\n            this.open();\n        }, this.config.delay ?? 250);\n    }\n\n    @HostListener('pointerleave', ['$event'])\n    public async onPointerLeave(evt: PointerEvent) {\n        this.isCursorOverTarget = false;\n    }\n}\n\n// Helper to open the context menu without using the directive.\nexport const openTooltip = async (\n    dialog: MatDialog,\n    template: TemplateRef<any> | Type<any>,\n    data: any,\n    el: HTMLElement,\n    config?: TooltipOptions,\n    focusTrap = false,\n    matPopupOptions?: MatDialogConfig<any>\n) => {\n\n    const rect = await calcTooltipBounds(template, data, matPopupOptions);\n    const ownerCords = el.getBoundingClientRect();\n    const cords = getPosition(el, config, rect);\n    const specificId = ulid();\n\n    return new Promise(res => {\n        dialog.open(TooltipComponent, {\n            autoFocus: focusTrap,\n            restoreFocus: focusTrap,\n            data: {\n                dialog,\n                data: data,\n                template: template,\n                config: config,\n                matPopupOptions,\n                ownerCords: ownerCords,\n                selfCords: cords,\n                id: specificId\n            },\n            panelClass: [\"ngx-tooltip\", 'ngx-' + specificId].concat(config?.customClass || []),\n            position: cords,\n            hasBackdrop: false,\n            ...matPopupOptions\n        })\n            .afterClosed()\n            .subscribe(s => {\n                res(s);\n            })\n    }) as Promise<any>;\n};\n"]}
@@ -369,36 +369,24 @@ class TooltipDirective {
369
369
  */
370
370
  this.data = {};
371
371
  this.isCursorOverTarget = false;
372
- this.isFreezeOnKeyCodeBound = false;
373
- this.onKeyDownEvt = this.onKeyDown.bind(this);
374
- if (this.config.freezeOnKeyCode !== null) {
375
- this.isFreezeOnKeyCodeBound = true;
376
- window.addEventListener("keydown", this.onKeyDownEvt);
377
- }
372
+ this.dialogIsOpen = false;
378
373
  }
379
374
  ngAfterViewInit() {
380
375
  const el = this.viewContainer.element.nativeElement;
381
376
  this.config?.triggers?.forEach(t => {
382
377
  el.addEventListener(t, () => {
378
+ if (t == "click")
379
+ this.config.stayOpen = true;
383
380
  this.open();
384
381
  });
385
382
  });
386
383
  }
387
- ngOnDestroy() {
388
- if (this.isFreezeOnKeyCodeBound) {
389
- window.removeEventListener("keydown", this.onKeyDownEvt);
390
- }
391
- }
392
- onKeyDown(evt) {
393
- // TODO: fade message 'tooltip is locked open'
394
- if (evt.code == ("F2")) {
395
- this.dialogInstance.componentInstance.isLockedOpen = true;
396
- }
397
- }
398
384
  async open() {
399
- if (!this.dialogInstance) {
385
+ if (!this.dialogIsOpen) {
400
386
  const el = this.viewContainer.element.nativeElement;
401
- this.dialogInstance = await openTooltip(this.dialog, this.template, this.data, el, this.config);
387
+ this.dialogIsOpen = true;
388
+ await openTooltip(this.dialog, this.template, this.data, el, this.config);
389
+ this.dialogIsOpen = false;
402
390
  }
403
391
  }
404
392
  async onPointerEnter(evt) {