@dotglitch/ngx-common 1.0.14 → 1.0.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.
- package/esm2020/directives/tooltip.directive.mjs +2 -2
- package/esm2020/public-api.mjs +2 -1
- package/esm2020/services/file.service.mjs +42 -0
- package/fesm2015/dotglitch-ngx-common.mjs +43 -4
- package/fesm2015/dotglitch-ngx-common.mjs.map +1 -1
- package/fesm2020/dotglitch-ngx-common.mjs +41 -2
- package/fesm2020/dotglitch-ngx-common.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/services/file.service.d.ts +12 -0
|
@@ -42,7 +42,7 @@ export class TooltipDirective {
|
|
|
42
42
|
return;
|
|
43
43
|
// If the click trigger is set, we will immediately open the tooltip.
|
|
44
44
|
// This will bypass all other triggers.
|
|
45
|
-
if (this.config
|
|
45
|
+
if (this.config?.triggers?.includes("click")) {
|
|
46
46
|
if (!this.dialogInstance) {
|
|
47
47
|
const el = this.viewContainer.element.nativeElement;
|
|
48
48
|
const data = this.data;
|
|
@@ -132,4 +132,4 @@ export const openTooltip = async (dialog, template, data, el, config, focusTrap
|
|
|
132
132
|
});
|
|
133
133
|
});
|
|
134
134
|
};
|
|
135
|
-
//# 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, MatDialogRef } from '@angular/material/dialog';\nimport { getPosition } from './utils';\nimport {  } from '../types/popup';import { TooltipComponent, calcTooltipBounds } from '../components/tooltip/tooltip.component';\nimport { TooltipOptions } from '../types/tooltip';\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            document.body.addEventListener(\"keydown\", this.onKeyDownEvt);\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.isFreezeOnKeyCodeBound) {\n            document.body.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    // Needs to be public so we can manually open the dialog\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 the click trigger is set, we will immediately open the tooltip.\n        // This will bypass all other triggers.\n        if (this.config.triggers.includes(\"click\")) {\n            if (!this.dialogInstance) {\n                const el = this.viewContainer.element.nativeElement;\n                const data = this.data;\n                data.isLockedOpen = true;\n                this.dialogInstance = await openTooltip(this.dialog, this.template, this.data, el, this.config);\n            }\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            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        }, 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) => {\n\n    const rect = await calcTooltipBounds(template, data);\n    const ownerCords = el.getBoundingClientRect();\n    const cords = getPosition(el, config, rect);\n    const specificId = crypto.randomUUID();\n\n    return new Promise(res => {\n        dialog.open(TooltipComponent, {\n            autoFocus: focusTrap,\n            restoreFocus: focusTrap,\n            data: {\n                data: data,\n                template: template,\n                config: config,\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        })\n            .afterClosed()\n            .subscribe(s => {\n                res(s);\n            })\n    }) as Promise<any>;\n};\n"]}
|
|
135
|
+
//# 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, MatDialogRef } from '@angular/material/dialog';\nimport { getPosition } from './utils';\nimport {  } from '../types/popup';import { TooltipComponent, calcTooltipBounds } from '../components/tooltip/tooltip.component';\nimport { TooltipOptions } from '../types/tooltip';\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            document.body.addEventListener(\"keydown\", this.onKeyDownEvt);\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.isFreezeOnKeyCodeBound) {\n            document.body.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    // Needs to be public so we can manually open the dialog\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 the click trigger is set, we will immediately open the tooltip.\n        // This will bypass all other triggers.\n        if (this.config?.triggers?.includes(\"click\")) {\n            if (!this.dialogInstance) {\n                const el = this.viewContainer.element.nativeElement;\n                const data = this.data;\n                data.isLockedOpen = true;\n                this.dialogInstance = await openTooltip(this.dialog, this.template, this.data, el, this.config);\n            }\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            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        }, 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) => {\n\n    const rect = await calcTooltipBounds(template, data);\n    const ownerCords = el.getBoundingClientRect();\n    const cords = getPosition(el, config, rect);\n    const specificId = crypto.randomUUID();\n\n    return new Promise(res => {\n        dialog.open(TooltipComponent, {\n            autoFocus: focusTrap,\n            restoreFocus: focusTrap,\n            data: {\n                data: data,\n                template: template,\n                config: config,\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        })\n            .afterClosed()\n            .subscribe(s => {\n                res(s);\n            })\n    }) as Promise<any>;\n};\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -26,6 +26,7 @@ export * from './services/dependency.service';
|
|
|
26
26
|
export * from './services/dialog.service';
|
|
27
27
|
export * from './services/fetch.service';
|
|
28
28
|
export * from './services/keyboard.service';
|
|
29
|
+
export * from './services/file.service';
|
|
29
30
|
// export * from './services/serviceworker.service';
|
|
30
31
|
/**
|
|
31
32
|
** Lazy loader component & service
|
|
@@ -41,4 +42,4 @@ export * from './components/dynamic-html/dynamic-html.service';
|
|
|
41
42
|
export * from './components/dynamic-html/dynamic-html.module';
|
|
42
43
|
export * from './components/dynamic-html/dynamic-html.component';
|
|
43
44
|
export * from './components/dynamic-html/types';
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL2NvbW1vbi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVIOztHQUVHO0FBQ0gsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxlQUFlLENBQUM7QUFFOUI7O0dBRUc7QUFDSCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNkJBQTZCLENBQUM7QUFFNUM7O0dBRUc7QUFDSCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUM7QUFFeEM7O0VBRUU7QUFDRixjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsb0RBQW9EO0FBRXBEOztFQUVFO0FBQ0YsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxnQ0FBZ0MsQ0FBQztBQUUvQzs7RUFFRTtBQUNGLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsaUNBQWlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHBhY2thZ2VcbiAqL1xuXG4vKipcbiAqKiBUeXBlc1xuICovXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzL21lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy9wb3B1cCc7XG5cbi8qKlxuICoqIERpcmVjdGl2ZXNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3Rvb2x0aXAuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9tZW51LmRpcmVjdGl2ZSc7XG5cbi8qKlxuICoqIFBpcGVzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvaHRtbC1ieXBhc3MucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3Jlc291cmNlLWJ5cGFzcy5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvc2NyaXB0LWJ5cGFzcy5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvc3R5bGUtYnlwYXNzLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9waXBlcy91cmwtYnlwYXNzLnBpcGUnO1xuXG4vKipcbioqIFNlcnZpY2VzXG4qL1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9kZXBlbmRlbmN5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9kaWFsb2cuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2VzL2ZldGNoLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9rZXlib2FyZC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvZmlsZS5zZXJ2aWNlJztcbi8vIGV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvc2VydmljZXdvcmtlci5zZXJ2aWNlJztcblxuLyoqXG4qKiBMYXp5IGxvYWRlciBjb21wb25lbnQgJiBzZXJ2aWNlXG4qL1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2xhenktbG9hZGVyL2xhenktbG9hZGVyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2xhenktbG9hZGVyL2xhenktbG9hZGVyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvbGF6eS1sb2FkZXIvbGF6eS1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9sYXp5LWxvYWRlci90eXBlcyc7XG5cbi8qKlxuKiogU2VydmljZXNcbiovXG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZHluYW1pYy1odG1sL2R5bmFtaWMtaHRtbC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9keW5hbWljLWh0bWwvZHluYW1pYy1odG1sLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZHluYW1pYy1odG1sL2R5bmFtaWMtaHRtbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2R5bmFtaWMtaHRtbC90eXBlcyc7XG4iXX0=
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./fetch.service";
|
|
4
|
+
/**
|
|
5
|
+
* Service that listens for global keyboard events
|
|
6
|
+
*/
|
|
7
|
+
export class FileService {
|
|
8
|
+
constructor(fetch) {
|
|
9
|
+
this.fetch = fetch;
|
|
10
|
+
this.chooseFile = (accept, multiple = false, formMetadata = {}) => {
|
|
11
|
+
return new Promise(r => {
|
|
12
|
+
const inEl = document.createElement('input');
|
|
13
|
+
inEl.setAttribute('type', 'file');
|
|
14
|
+
if (multiple)
|
|
15
|
+
inEl.setAttribute('multiple', '');
|
|
16
|
+
if (accept)
|
|
17
|
+
inEl.setAttribute('accept', accept);
|
|
18
|
+
inEl.click();
|
|
19
|
+
let formData = new FormData();
|
|
20
|
+
inEl.addEventListener('change', () => {
|
|
21
|
+
Object.keys(inEl.files).forEach(k => {
|
|
22
|
+
const file = inEl.files[k];
|
|
23
|
+
const name = file.name;
|
|
24
|
+
formData.append(name, file);
|
|
25
|
+
});
|
|
26
|
+
formData.append("data", JSON.stringify(formMetadata));
|
|
27
|
+
inEl.remove();
|
|
28
|
+
r(formData);
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
FileService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FileService, deps: [{ token: i1.Fetch }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
35
|
+
FileService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FileService, providedIn: 'root' });
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FileService, decorators: [{
|
|
37
|
+
type: Injectable,
|
|
38
|
+
args: [{
|
|
39
|
+
providedIn: 'root'
|
|
40
|
+
}]
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i1.Fetch }]; } });
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tbW9uL3NyYy9zZXJ2aWNlcy9maWxlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBSTNDOztHQUVHO0FBSUgsTUFBTSxPQUFPLFdBQVc7SUFFcEIsWUFBb0IsS0FBWTtRQUFaLFVBQUssR0FBTCxLQUFLLENBQU87UUFFaEMsZUFBVSxHQUFHLENBQUMsTUFBZSxFQUFFLFFBQVEsR0FBRyxLQUFLLEVBQUUsWUFBWSxHQUFHLEVBQUUsRUFBSSxFQUFFO1lBQ3BFLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQ25CLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQzdDLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO2dCQUNsQyxJQUFJLFFBQVE7b0JBQ1IsSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ3RDLElBQUksTUFBTTtvQkFDTixJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQztnQkFFeEMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO2dCQUViLElBQUksUUFBUSxHQUFHLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBRTlCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsR0FBRyxFQUFFO29CQUNqQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUU7d0JBQ2hDLE1BQU0sSUFBSSxHQU1OLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7d0JBRWxCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7d0JBQ3ZCLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQVcsQ0FBQyxDQUFDO29CQUN2QyxDQUFDLENBQUMsQ0FBQztvQkFDSCxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7b0JBQ3RELElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztvQkFDZCxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ2hCLENBQUMsQ0FBQyxDQUFDO1lBQ1AsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUM7SUFqQ2tDLENBQUM7O3dHQUY1QixXQUFXOzRHQUFYLFdBQVcsY0FGUixNQUFNOzJGQUVULFdBQVc7a0JBSHZCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmV0Y2ggfSBmcm9tICcuL2ZldGNoLnNlcnZpY2UnO1xuXG5cbi8qKlxuICogU2VydmljZSB0aGF0IGxpc3RlbnMgZm9yIGdsb2JhbCBrZXlib2FyZCBldmVudHNcbiAqL1xuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBGaWxlU2VydmljZSB7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGZldGNoOiBGZXRjaCkgeyB9XG5cbiAgICBjaG9vc2VGaWxlID0gKGFjY2VwdD86IHN0cmluZywgbXVsdGlwbGUgPSBmYWxzZSwgZm9ybU1ldGFkYXRhID0ge30sICkgPT4ge1xuICAgICAgICByZXR1cm4gbmV3IFByb21pc2UociA9PiB7XG4gICAgICAgICAgICBjb25zdCBpbkVsID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnaW5wdXQnKTtcbiAgICAgICAgICAgIGluRWwuc2V0QXR0cmlidXRlKCd0eXBlJywgJ2ZpbGUnKTtcbiAgICAgICAgICAgIGlmIChtdWx0aXBsZSlcbiAgICAgICAgICAgICAgICBpbkVsLnNldEF0dHJpYnV0ZSgnbXVsdGlwbGUnLCAnJyk7XG4gICAgICAgICAgICBpZiAoYWNjZXB0KVxuICAgICAgICAgICAgICAgIGluRWwuc2V0QXR0cmlidXRlKCdhY2NlcHQnLCBhY2NlcHQpO1xuXG4gICAgICAgICAgICBpbkVsLmNsaWNrKCk7XG5cbiAgICAgICAgICAgIGxldCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuXG4gICAgICAgICAgICBpbkVsLmFkZEV2ZW50TGlzdGVuZXIoJ2NoYW5nZScsICgpID0+IHtcbiAgICAgICAgICAgICAgICBPYmplY3Qua2V5cyhpbkVsLmZpbGVzKS5mb3JFYWNoKGsgPT4ge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBmaWxlOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBsYXN0TW9kaWZpZWQ6IG51bWJlcixcbiAgICAgICAgICAgICAgICAgICAgICAgIGxhc3RNb2RpZmllZERhdGU6IERhdGUsXG4gICAgICAgICAgICAgICAgICAgICAgICBuYW1lOiBzdHJpbmcsXG4gICAgICAgICAgICAgICAgICAgICAgICBzaXplOiBudW1iZXIsXG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlOiBzdHJpbmc7XG4gICAgICAgICAgICAgICAgICAgIH0gPSBpbkVsLmZpbGVzW2tdO1xuXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IG5hbWUgPSBmaWxlLm5hbWU7XG4gICAgICAgICAgICAgICAgICAgIGZvcm1EYXRhLmFwcGVuZChuYW1lLCBmaWxlIGFzIGFueSk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgZm9ybURhdGEuYXBwZW5kKFwiZGF0YVwiLCBKU09OLnN0cmluZ2lmeShmb3JtTWV0YWRhdGEpKTtcbiAgICAgICAgICAgICAgICBpbkVsLnJlbW92ZSgpO1xuICAgICAgICAgICAgICAgIHIoZm9ybURhdGEpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH07XG5cbiAgICAvLyB1cGxvYWRGaWxlID0gKGNvbmZpZzogTmd4RmlsZU1hbmFnZXJDb25maWd1cmF0aW9uLCBjdXJyZW50RGlyZWN0b3J5OiBzdHJpbmcsIHRhcmdldFBhdGg/OiBzdHJpbmcpID0+IHtcbiAgICAvLyAgICAgcmV0dXJuIG5ldyBQcm9taXNlKHIgPT4ge1xuICAgIC8vICAgICAgICAgY29uc3QgaW5FbCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2lucHV0Jyk7XG4gICAgLy8gICAgICAgICBpbkVsLnNldEF0dHJpYnV0ZSgndHlwZScsICdmaWxlJyk7XG4gICAgLy8gICAgICAgICBpbkVsLnNldEF0dHJpYnV0ZSgnbXVsdGlwbGUnLCAnJyk7XG4gICAgLy8gICAgICAgICBpbkVsLmNsaWNrKCk7XG5cbiAgICAvLyAgICAgICAgIGxldCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuXG4gICAgLy8gICAgICAgICBpbkVsLmFkZEV2ZW50TGlzdGVuZXIoJ2NoYW5nZScsICgpID0+IHtcbiAgICAvLyAgICAgICAgICAgICBPYmplY3Qua2V5cyhpbkVsLmZpbGVzKS5mb3JFYWNoKGsgPT4ge1xuICAgIC8vICAgICAgICAgICAgICAgICBjb25zdCBmaWxlOiB7XG4gICAgLy8gICAgICAgICAgICAgICAgICAgICBsYXN0TW9kaWZpZWQ6IG51bWJlcixcbiAgICAvLyAgICAgICAgICAgICAgICAgICAgIGxhc3RNb2RpZmllZERhdGU6IERhdGUsXG4gICAgLy8gICAgICAgICAgICAgICAgICAgICBuYW1lOiBzdHJpbmcsXG4gICAgLy8gICAgICAgICAgICAgICAgICAgICBzaXplOiBudW1iZXIsXG4gICAgLy8gICAgICAgICAgICAgICAgICAgICB0eXBlOiBzdHJpbmc7XG4gICAgLy8gICAgICAgICAgICAgICAgIH0gPSBpbkVsLmZpbGVzW2tdO1xuXG4gICAgLy8gICAgICAgICAgICAgICAgIGNvbnN0IG5hbWUgPSBmaWxlLm5hbWU7XG4gICAgLy8gICAgICAgICAgICAgICAgIGZvcm1EYXRhLmFwcGVuZChuYW1lLCBmaWxlIGFzIGFueSk7XG4gICAgLy8gICAgICAgICAgICAgfSk7XG4gICAgLy8gICAgICAgICAgICAgZm9ybURhdGEuYXBwZW5kKFwiZGF0YVwiLCBKU09OLnN0cmluZ2lmeSh7XG4gICAgLy8gICAgICAgICAgICAgICAgIHBhdGg6IGN1cnJlbnREaXJlY3RvcnlcbiAgICAvLyAgICAgICAgICAgICB9KSk7XG5cbiAgICAvLyAgICAgICAgICAgICBjb25zdCB1cmwgPSBjb25maWcuYXBpU2V0dGluZ3MudXBsb2FkRW50cnlVcmxUZW1wbGF0ZVxuICAgIC8vICAgICAgICAgICAgICAgICA/IGNvbmZpZy5hcGlTZXR0aW5ncy51cGxvYWRFbnRyeVVybFRlbXBsYXRlKHRhcmdldFBhdGggPz8gY3VycmVudERpcmVjdG9yeSlcbiAgICAvLyAgICAgICAgICAgICAgICAgOiBjb25maWcuYXBpU2V0dGluZ3MudXBsb2FkRW50cnlVcmw7XG5cbiAgICAvLyAgICAgICAgICAgICByKHRoaXMuZmV0Y2gucG9zdCh1cmwsIGZvcm1EYXRhKS50aGVuKHJlcyA9PiB7XG4gICAgLy8gICAgICAgICAgICAgICAgIGluRWwucmVtb3ZlKCk7XG4gICAgLy8gICAgICAgICAgICAgICAgIHJldHVybiByZXM7XG4gICAgLy8gICAgICAgICAgICAgfSkpO1xuICAgIC8vICAgICAgICAgfSk7XG4gICAgLy8gICAgIH0pO1xuICAgIC8vIH07XG59XG4iXX0=
|
|
@@ -306,14 +306,14 @@ class TooltipDirective {
|
|
|
306
306
|
}
|
|
307
307
|
// Needs to be public so we can manually open the dialog
|
|
308
308
|
onPointerEnter(evt) {
|
|
309
|
-
var _a;
|
|
309
|
+
var _a, _b, _c;
|
|
310
310
|
return __awaiter(this, void 0, void 0, function* () {
|
|
311
311
|
// If the template is not a template ref, do nothing.
|
|
312
312
|
if (!(this.template instanceof TemplateRef))
|
|
313
313
|
return;
|
|
314
314
|
// If the click trigger is set, we will immediately open the tooltip.
|
|
315
315
|
// This will bypass all other triggers.
|
|
316
|
-
if (this.config.triggers.includes("click")) {
|
|
316
|
+
if ((_b = (_a = this.config) === null || _a === void 0 ? void 0 : _a.triggers) === null || _b === void 0 ? void 0 : _b.includes("click")) {
|
|
317
317
|
if (!this.dialogInstance) {
|
|
318
318
|
const el = this.viewContainer.element.nativeElement;
|
|
319
319
|
const data = this.data;
|
|
@@ -331,7 +331,7 @@ class TooltipDirective {
|
|
|
331
331
|
const el = this.viewContainer.element.nativeElement;
|
|
332
332
|
this.dialogInstance = yield openTooltip(this.dialog, this.template, this.data, el, this.config);
|
|
333
333
|
}
|
|
334
|
-
}), (
|
|
334
|
+
}), (_c = this.config.delay) !== null && _c !== void 0 ? _c : 250);
|
|
335
335
|
});
|
|
336
336
|
}
|
|
337
337
|
onPointerLeave(evt) {
|
|
@@ -1294,6 +1294,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
1294
1294
|
args: ["window:resize"]
|
|
1295
1295
|
}] } });
|
|
1296
1296
|
|
|
1297
|
+
/**
|
|
1298
|
+
* Service that listens for global keyboard events
|
|
1299
|
+
*/
|
|
1300
|
+
class FileService {
|
|
1301
|
+
constructor(fetch) {
|
|
1302
|
+
this.fetch = fetch;
|
|
1303
|
+
this.chooseFile = (accept, multiple = false, formMetadata = {}) => {
|
|
1304
|
+
return new Promise(r => {
|
|
1305
|
+
const inEl = document.createElement('input');
|
|
1306
|
+
inEl.setAttribute('type', 'file');
|
|
1307
|
+
if (multiple)
|
|
1308
|
+
inEl.setAttribute('multiple', '');
|
|
1309
|
+
if (accept)
|
|
1310
|
+
inEl.setAttribute('accept', accept);
|
|
1311
|
+
inEl.click();
|
|
1312
|
+
let formData = new FormData();
|
|
1313
|
+
inEl.addEventListener('change', () => {
|
|
1314
|
+
Object.keys(inEl.files).forEach(k => {
|
|
1315
|
+
const file = inEl.files[k];
|
|
1316
|
+
const name = file.name;
|
|
1317
|
+
formData.append(name, file);
|
|
1318
|
+
});
|
|
1319
|
+
formData.append("data", JSON.stringify(formMetadata));
|
|
1320
|
+
inEl.remove();
|
|
1321
|
+
r(formData);
|
|
1322
|
+
});
|
|
1323
|
+
});
|
|
1324
|
+
};
|
|
1325
|
+
}
|
|
1326
|
+
}
|
|
1327
|
+
FileService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FileService, deps: [{ token: Fetch }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1328
|
+
FileService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FileService, providedIn: 'root' });
|
|
1329
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FileService, decorators: [{
|
|
1330
|
+
type: Injectable,
|
|
1331
|
+
args: [{
|
|
1332
|
+
providedIn: 'root'
|
|
1333
|
+
}]
|
|
1334
|
+
}], ctorParameters: function () { return [{ type: Fetch }]; } });
|
|
1335
|
+
|
|
1297
1336
|
var ComponentResolveStrategy;
|
|
1298
1337
|
(function (ComponentResolveStrategy) {
|
|
1299
1338
|
/**
|
|
@@ -2056,5 +2095,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
2056
2095
|
* Generated bundle index. Do not edit.
|
|
2057
2096
|
*/
|
|
2058
2097
|
|
|
2059
|
-
export { ComponentResolveStrategy, DependencyService, DialogService, DynamicHTMLComponent, DynamicHTMLOptions, DynamicHTMLRenderer, Fetch, HtmlBypass, KeyboardService, LazyLoaderComponent, LazyLoaderModule, LazyLoaderService, MenuDirective, NGX_DYNAMIC_CONFIG, NGX_LAZY_LOADER_CONFIG, NgxDynamicHTMLModule, OnMount, ResourceBypass, ScriptBypass, StyleBypass, TooltipDirective, UrlBypass, openMenu, openTooltip };
|
|
2098
|
+
export { ComponentResolveStrategy, DependencyService, DialogService, DynamicHTMLComponent, DynamicHTMLOptions, DynamicHTMLRenderer, Fetch, FileService, HtmlBypass, KeyboardService, LazyLoaderComponent, LazyLoaderModule, LazyLoaderService, MenuDirective, NGX_DYNAMIC_CONFIG, NGX_LAZY_LOADER_CONFIG, NgxDynamicHTMLModule, OnMount, ResourceBypass, ScriptBypass, StyleBypass, TooltipDirective, UrlBypass, openMenu, openTooltip };
|
|
2060
2099
|
//# sourceMappingURL=dotglitch-ngx-common.mjs.map
|