@ngutil/graphics 0.0.3-dev.13 → 0.0.3-dev.14

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/esm2022/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- export * from "./lib/graphics/graphics.component";
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmFwaGljcy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQ0FBbUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2xpYi9ncmFwaGljcy9ncmFwaGljcy5jb21wb25lbnRcIlxuIl19
1
+ export * from "./ripple/ripple.directive";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmFwaGljcy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL3JpcHBsZS9yaXBwbGUuZGlyZWN0aXZlXCJcbiJdfQ==
@@ -0,0 +1,157 @@
1
+ import { Directive, ElementRef, NgZone, TemplateRef } from "@angular/core";
2
+ import { Destructible } from "@ngutil/common";
3
+ import * as i0 from "@angular/core";
4
+ export class RippleDirective extends Destructible {
5
+ #current;
6
+ constructor(tplRef, zone, el) {
7
+ super();
8
+ this.tplRef = tplRef;
9
+ this.zone = zone;
10
+ this.el = el;
11
+ zone.runOutsideAngular(() => {
12
+ const target = el.nativeElement.parentElement;
13
+ if (target) {
14
+ target.addEventListener("mousedown", this.#onMouseDown);
15
+ this.d.any(() => target.removeEventListener("mousedown", this.#onMouseDown));
16
+ }
17
+ });
18
+ }
19
+ begin(event) {
20
+ this.#current?.autoDestroy();
21
+ const cfg = this.#createRippleConfig(event);
22
+ const ripple = this.#createRipple(cfg);
23
+ this.#current = ripple;
24
+ const refEl = this.tplRef.elementRef.nativeElement;
25
+ refEl.parentNode?.insertBefore(ripple.el, refEl);
26
+ ripple.start();
27
+ }
28
+ end() {
29
+ this.#current?.autoDestroy();
30
+ }
31
+ #createRipple(config) {
32
+ const ripple = new Ripple(config, this.zone, () => {
33
+ if (this.#current === ripple) {
34
+ this.#current = undefined;
35
+ }
36
+ });
37
+ this.d.disposable(ripple);
38
+ return ripple;
39
+ }
40
+ #createRippleConfig(event) {
41
+ const container = event.currentTarget;
42
+ const bounds = container.getBoundingClientRect();
43
+ const w = bounds.width;
44
+ const h = bounds.height;
45
+ const x = event.clientX - bounds.left;
46
+ const y = event.clientY - bounds.top;
47
+ const r = maxPossibleRadius(x, y, w, h) + Math.min(w, h);
48
+ return { x, y, w, h, r, d: 600 };
49
+ }
50
+ #onMouseDown = (event) => {
51
+ this.begin(event);
52
+ };
53
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: RippleDirective, deps: [{ token: i0.TemplateRef }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
54
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.3", type: RippleDirective, isStandalone: true, selector: "ng-template[nuRipple]", exportAs: ["nuRipple"], usesInheritance: true, ngImport: i0 }); }
55
+ }
56
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: RippleDirective, decorators: [{
57
+ type: Directive,
58
+ args: [{
59
+ standalone: true,
60
+ selector: "ng-template[nuRipple]",
61
+ exportAs: "nuRipple"
62
+ }]
63
+ }], ctorParameters: () => [{ type: i0.TemplateRef }, { type: i0.NgZone }, { type: i0.ElementRef }] });
64
+ export class Ripple {
65
+ #autoDestroy;
66
+ #hiding;
67
+ constructor(config, zone, onDestroy) {
68
+ this.onDestroy = onDestroy;
69
+ this.isRunning = false;
70
+ this.#autoDestroy = false;
71
+ this.#hiding = false;
72
+ this.autoDestroy = () => {
73
+ if (this.isRunning) {
74
+ this.#autoDestroy = true;
75
+ }
76
+ else {
77
+ this.#fadeOut();
78
+ }
79
+ };
80
+ this.#transBegin = () => {
81
+ // eslint-disable-next-line no-extra-semi
82
+ ;
83
+ this.isRunning = true;
84
+ };
85
+ this.#transEnd = (event) => {
86
+ if (event.propertyName === "opacity") {
87
+ if (this.#hiding) {
88
+ this.dispose();
89
+ }
90
+ else {
91
+ if (this.#autoDestroy) {
92
+ this.#fadeOut();
93
+ }
94
+ }
95
+ }
96
+ else if (event.propertyName === "transform") {
97
+ // eslint-disable-next-line no-extra-semi
98
+ ;
99
+ this.isRunning = false;
100
+ if (this.#autoDestroy) {
101
+ this.dispose();
102
+ }
103
+ }
104
+ };
105
+ const el = document.createElement("div");
106
+ el.style.position = "absolute";
107
+ el.style.top = `${config.y - config.r}px`;
108
+ el.style.left = `${config.x - config.r}px`;
109
+ el.style.width = `${config.r * 2}px`;
110
+ el.style.height = `${config.r * 2}px`;
111
+ el.style.pointerEvents = "none";
112
+ el.style.backgroundColor = "var(--ripple-color)";
113
+ el.style.borderRadius = "50%";
114
+ el.style.transition = `opacity ${config.d / 2}ms ease-out, transform ${config.d}ms ease-out`;
115
+ el.style.opacity = "0";
116
+ el.style.transformOrigin = "center";
117
+ el.style.transform = "scale(0)";
118
+ this.el = el;
119
+ zone.runOutsideAngular(() => {
120
+ el.addEventListener("transitionstart", this.#transBegin);
121
+ el.addEventListener("transitionend", this.#transEnd);
122
+ document.addEventListener("mouseup", this.autoDestroy, { capture: true, passive: true });
123
+ document.addEventListener("dragend", this.autoDestroy, { capture: true, passive: true });
124
+ });
125
+ }
126
+ start() {
127
+ // eslint-disable-next-line no-extra-semi
128
+ ;
129
+ this.isRunning = true;
130
+ // XXX: force style apply
131
+ const opacity = typeof window !== "undefined" ? Number(window.getComputedStyle(this.el).opacity) : 1;
132
+ this.el.style.opacity = opacity ? "0.3" : "0.3";
133
+ this.el.style.transform = "scale(1)";
134
+ }
135
+ dispose() {
136
+ this.el.removeEventListener("transitionstart", this.#transBegin);
137
+ this.el.removeEventListener("transitionend", this.#transEnd);
138
+ document.removeEventListener("mouseup", this.autoDestroy, { capture: true });
139
+ this.el.parentNode?.removeChild(this.el);
140
+ this.onDestroy();
141
+ }
142
+ #transBegin;
143
+ #transEnd;
144
+ #fadeOut() {
145
+ if (this.#hiding) {
146
+ return;
147
+ }
148
+ this.#hiding = true;
149
+ this.el.style.opacity = "0";
150
+ }
151
+ }
152
+ function maxPossibleRadius(x, y, w, h) {
153
+ const distX = Math.max(x, Math.abs(w - x));
154
+ const distY = Math.max(y, Math.abs(h - y));
155
+ return Math.sqrt(distX * distX + distY * distY);
156
+ }
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ripple.directive.js","sourceRoot":"","sources":["../../../../../packages/graphics/src/ripple/ripple.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE1E,OAAO,EAAE,YAAY,EAAe,MAAM,gBAAgB,CAAA;;AAO1D,MAAM,OAAO,eAAgB,SAAQ,YAAY;IAC7C,QAAQ,CAAS;IAEjB,YACqB,MAAwB,EACxB,IAAY,EACZ,EAAoB;QAErC,KAAK,EAAE,CAAA;QAJU,WAAM,GAAN,MAAM,CAAkB;QACxB,SAAI,GAAJ,IAAI,CAAQ;QACZ,OAAE,GAAF,EAAE,CAAkB;QAGrC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;YACxB,MAAM,MAAM,GAAG,EAAE,CAAC,aAAa,CAAC,aAAa,CAAA;YAC7C,IAAI,MAAM,EAAE,CAAC;gBACT,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;gBACvD,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAA;YAChF,CAAC;QACL,CAAC,CAAC,CAAA;IACN,CAAC;IAED,KAAK,CAAC,KAAiB;QACnB,IAAI,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAA;QAC5B,MAAM,GAAG,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAA;QAC3C,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAA;QACtC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAA;QAEtB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,aAA4B,CAAA;QACjE,KAAK,CAAC,UAAU,EAAE,YAAY,CAAC,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,CAAA;QAChD,MAAM,CAAC,KAAK,EAAE,CAAA;IAClB,CAAC;IAED,GAAG;QACC,IAAI,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAA;IAChC,CAAC;IAED,aAAa,CAAC,MAAoB;QAC9B,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE;YAC9C,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC;gBAC3B,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAA;YAC7B,CAAC;QACL,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;QACzB,OAAO,MAAM,CAAA;IACjB,CAAC;IAED,mBAAmB,CAAC,KAAiB;QACjC,MAAM,SAAS,GAAG,KAAK,CAAC,aAA4B,CAAA;QACpD,MAAM,MAAM,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAA;QAChD,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAA;QACtB,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAA;QACvB,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAA;QACrC,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,GAAG,CAAA;QACpC,MAAM,CAAC,GAAG,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QACxD,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAA;IACpC,CAAC;IAED,YAAY,GAAG,CAAC,KAAiB,EAAE,EAAE;QACjC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACrB,CAAC,CAAA;8GAxDQ,eAAe;kGAAf,eAAe;;2FAAf,eAAe;kBAL3B,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,uBAAuB;oBACjC,QAAQ,EAAE,UAAU;iBACvB;;AA8DD,MAAM,OAAO,MAAM;IAIf,YAAY,CAAQ;IACpB,OAAO,CAAQ;IAEf,YACI,MAAoB,EACpB,IAAY,EACI,SAAqB;QAArB,cAAS,GAAT,SAAS,CAAY;QARzB,cAAS,GAAY,KAAK,CAAA;QAE1C,iBAAY,GAAG,KAAK,CAAA;QACpB,YAAO,GAAG,KAAK,CAAA;QAuCf,gBAAW,GAAG,GAAG,EAAE;YACf,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAA;YAC5B,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,QAAQ,EAAE,CAAA;YACnB,CAAC;QACL,CAAC,CAAA;QAUD,gBAAW,GAAG,GAAG,EAAE;YACf,yCAAyC;YACzC,CAAC;YAAC,IAA+B,CAAC,SAAS,GAAG,IAAI,CAAA;QACtD,CAAC,CAAA;QAED,cAAS,GAAG,CAAC,KAAsB,EAAE,EAAE;YACnC,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,EAAE,CAAC;gBACnC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;oBACf,IAAI,CAAC,OAAO,EAAE,CAAA;gBAClB,CAAC;qBAAM,CAAC;oBACJ,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;wBACpB,IAAI,CAAC,QAAQ,EAAE,CAAA;oBACnB,CAAC;gBACL,CAAC;YACL,CAAC;iBAAM,IAAI,KAAK,CAAC,YAAY,KAAK,WAAW,EAAE,CAAC;gBAC5C,yCAAyC;gBACzC,CAAC;gBAAC,IAA+B,CAAC,SAAS,GAAG,KAAK,CAAA;gBACnD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,IAAI,CAAC,OAAO,EAAE,CAAA;gBAClB,CAAC;YACL,CAAC;QACL,CAAC,CAAA;QArEG,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QACxC,EAAE,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAA;QAC9B,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,IAAI,CAAA;QACzC,EAAE,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,IAAI,CAAA;QAC1C,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAA;QACpC,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAA;QACrC,EAAE,CAAC,KAAK,CAAC,aAAa,GAAG,MAAM,CAAA;QAC/B,EAAE,CAAC,KAAK,CAAC,eAAe,GAAG,qBAAqB,CAAA;QAChD,EAAE,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAA;QAC7B,EAAE,CAAC,KAAK,CAAC,UAAU,GAAG,WAAW,MAAM,CAAC,CAAC,GAAG,CAAC,0BAA0B,MAAM,CAAC,CAAC,aAAa,CAAA;QAC5F,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAA;QACtB,EAAE,CAAC,KAAK,CAAC,eAAe,GAAG,QAAQ,CAAA;QACnC,EAAE,CAAC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAA;QAC/B,IAAI,CAAC,EAAE,GAAG,EAAE,CAAA;QAEZ,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;YACxB,EAAE,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;YACxD,EAAE,CAAC,gBAAgB,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,CAAA;YACpD,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;YACxF,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAC5F,CAAC,CAAC,CAAA;IACN,CAAC;IAED,KAAK;QACD,yCAAyC;QACzC,CAAC;QAAC,IAA+B,CAAC,SAAS,GAAG,IAAI,CAAA;QAClD,yBAAyB;QACzB,MAAM,OAAO,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACpG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAA;QAC/C,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,GAAG,UAAU,CAAA;IACxC,CAAC;IAUD,OAAO;QACH,IAAI,CAAC,EAAE,CAAC,mBAAmB,CAAC,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;QAChE,IAAI,CAAC,EAAE,CAAC,mBAAmB,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,CAAA;QAC5D,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAC5E,IAAI,CAAC,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACxC,IAAI,CAAC,SAAS,EAAE,CAAA;IACpB,CAAC;IAED,WAAW,CAGV;IAED,SAAS,CAgBR;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,OAAM;QACV,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;QACnB,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAA;IAC/B,CAAC;CACJ;AAED,SAAS,iBAAiB,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,CAAS;IACjE,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IAC1C,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC,CAAA;AACnD,CAAC","sourcesContent":["import { Directive, ElementRef, NgZone, TemplateRef } from \"@angular/core\"\n\nimport { Destructible, IDisposable } from \"@ngutil/common\"\n\n@Directive({\n    standalone: true,\n    selector: \"ng-template[nuRipple]\",\n    exportAs: \"nuRipple\"\n})\nexport class RippleDirective extends Destructible {\n    #current?: Ripple\n\n    constructor(\n        private readonly tplRef: TemplateRef<any>,\n        private readonly zone: NgZone,\n        private readonly el: ElementRef<Node>\n    ) {\n        super()\n        zone.runOutsideAngular(() => {\n            const target = el.nativeElement.parentElement\n            if (target) {\n                target.addEventListener(\"mousedown\", this.#onMouseDown)\n                this.d.any(() => target.removeEventListener(\"mousedown\", this.#onMouseDown))\n            }\n        })\n    }\n\n    begin(event: MouseEvent) {\n        this.#current?.autoDestroy()\n        const cfg = this.#createRippleConfig(event)\n        const ripple = this.#createRipple(cfg)\n        this.#current = ripple\n\n        const refEl = this.tplRef.elementRef.nativeElement as HTMLElement\n        refEl.parentNode?.insertBefore(ripple.el, refEl)\n        ripple.start()\n    }\n\n    end() {\n        this.#current?.autoDestroy()\n    }\n\n    #createRipple(config: RippleConfig) {\n        const ripple = new Ripple(config, this.zone, () => {\n            if (this.#current === ripple) {\n                this.#current = undefined\n            }\n        })\n        this.d.disposable(ripple)\n        return ripple\n    }\n\n    #createRippleConfig(event: MouseEvent): RippleConfig {\n        const container = event.currentTarget as HTMLElement\n        const bounds = container.getBoundingClientRect()\n        const w = bounds.width\n        const h = bounds.height\n        const x = event.clientX - bounds.left\n        const y = event.clientY - bounds.top\n        const r = maxPossibleRadius(x, y, w, h) + Math.min(w, h)\n        return { x, y, w, h, r, d: 600 }\n    }\n\n    #onMouseDown = (event: MouseEvent) => {\n        this.begin(event)\n    }\n}\n\ntype RippleConfig = { x: number; y: number; w: number; h: number; r: number; d: number }\n\nexport class Ripple implements IDisposable {\n    public readonly el: HTMLDivElement\n    public readonly isRunning: boolean = false\n\n    #autoDestroy = false\n    #hiding = false\n\n    constructor(\n        config: RippleConfig,\n        zone: NgZone,\n        public readonly onDestroy: () => void\n    ) {\n        const el = document.createElement(\"div\")\n        el.style.position = \"absolute\"\n        el.style.top = `${config.y - config.r}px`\n        el.style.left = `${config.x - config.r}px`\n        el.style.width = `${config.r * 2}px`\n        el.style.height = `${config.r * 2}px`\n        el.style.pointerEvents = \"none\"\n        el.style.backgroundColor = \"var(--ripple-color)\"\n        el.style.borderRadius = \"50%\"\n        el.style.transition = `opacity ${config.d / 2}ms ease-out, transform ${config.d}ms ease-out`\n        el.style.opacity = \"0\"\n        el.style.transformOrigin = \"center\"\n        el.style.transform = \"scale(0)\"\n        this.el = el\n\n        zone.runOutsideAngular(() => {\n            el.addEventListener(\"transitionstart\", this.#transBegin)\n            el.addEventListener(\"transitionend\", this.#transEnd)\n            document.addEventListener(\"mouseup\", this.autoDestroy, { capture: true, passive: true })\n            document.addEventListener(\"dragend\", this.autoDestroy, { capture: true, passive: true })\n        })\n    }\n\n    start() {\n        // eslint-disable-next-line no-extra-semi\n        ;(this as { isRunning: boolean }).isRunning = true\n        // XXX: force style apply\n        const opacity = typeof window !== \"undefined\" ? Number(window.getComputedStyle(this.el).opacity) : 1\n        this.el.style.opacity = opacity ? \"0.3\" : \"0.3\"\n        this.el.style.transform = \"scale(1)\"\n    }\n\n    autoDestroy = () => {\n        if (this.isRunning) {\n            this.#autoDestroy = true\n        } else {\n            this.#fadeOut()\n        }\n    }\n\n    dispose(): void {\n        this.el.removeEventListener(\"transitionstart\", this.#transBegin)\n        this.el.removeEventListener(\"transitionend\", this.#transEnd)\n        document.removeEventListener(\"mouseup\", this.autoDestroy, { capture: true })\n        this.el.parentNode?.removeChild(this.el)\n        this.onDestroy()\n    }\n\n    #transBegin = () => {\n        // eslint-disable-next-line no-extra-semi\n        ;(this as { isRunning: boolean }).isRunning = true\n    }\n\n    #transEnd = (event: TransitionEvent) => {\n        if (event.propertyName === \"opacity\") {\n            if (this.#hiding) {\n                this.dispose()\n            } else {\n                if (this.#autoDestroy) {\n                    this.#fadeOut()\n                }\n            }\n        } else if (event.propertyName === \"transform\") {\n            // eslint-disable-next-line no-extra-semi\n            ;(this as { isRunning: boolean }).isRunning = false\n            if (this.#autoDestroy) {\n                this.dispose()\n            }\n        }\n    }\n\n    #fadeOut() {\n        if (this.#hiding) {\n            return\n        }\n        this.#hiding = true\n        this.el.style.opacity = \"0\"\n    }\n}\n\nfunction maxPossibleRadius(x: number, y: number, w: number, h: number) {\n    const distX = Math.max(x, Math.abs(w - x))\n    const distY = Math.max(y, Math.abs(h - y))\n    return Math.sqrt(distX * distX + distY * distY)\n}\n"]}
@@ -1,19 +1,164 @@
1
- import { CommonModule } from '@angular/common';
2
1
  import * as i0 from '@angular/core';
3
- import { Component } from '@angular/core';
2
+ import { Directive } from '@angular/core';
3
+ import { Destructible } from '@ngutil/common';
4
4
 
5
- class GraphicsComponent {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: GraphicsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: GraphicsComponent, isStandalone: true, selector: "nu-graphics", ngImport: i0, template: `<p>graphics works!</p>`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
5
+ class RippleDirective extends Destructible {
6
+ #current;
7
+ constructor(tplRef, zone, el) {
8
+ super();
9
+ this.tplRef = tplRef;
10
+ this.zone = zone;
11
+ this.el = el;
12
+ zone.runOutsideAngular(() => {
13
+ const target = el.nativeElement.parentElement;
14
+ if (target) {
15
+ target.addEventListener("mousedown", this.#onMouseDown);
16
+ this.d.any(() => target.removeEventListener("mousedown", this.#onMouseDown));
17
+ }
18
+ });
19
+ }
20
+ begin(event) {
21
+ this.#current?.autoDestroy();
22
+ const cfg = this.#createRippleConfig(event);
23
+ const ripple = this.#createRipple(cfg);
24
+ this.#current = ripple;
25
+ const refEl = this.tplRef.elementRef.nativeElement;
26
+ refEl.parentNode?.insertBefore(ripple.el, refEl);
27
+ ripple.start();
28
+ }
29
+ end() {
30
+ this.#current?.autoDestroy();
31
+ }
32
+ #createRipple(config) {
33
+ const ripple = new Ripple(config, this.zone, () => {
34
+ if (this.#current === ripple) {
35
+ this.#current = undefined;
36
+ }
37
+ });
38
+ this.d.disposable(ripple);
39
+ return ripple;
40
+ }
41
+ #createRippleConfig(event) {
42
+ const container = event.currentTarget;
43
+ const bounds = container.getBoundingClientRect();
44
+ const w = bounds.width;
45
+ const h = bounds.height;
46
+ const x = event.clientX - bounds.left;
47
+ const y = event.clientY - bounds.top;
48
+ const r = maxPossibleRadius(x, y, w, h) + Math.min(w, h);
49
+ return { x, y, w, h, r, d: 600 };
50
+ }
51
+ #onMouseDown = (event) => {
52
+ this.begin(event);
53
+ };
54
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: RippleDirective, deps: [{ token: i0.TemplateRef }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
55
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.3", type: RippleDirective, isStandalone: true, selector: "ng-template[nuRipple]", exportAs: ["nuRipple"], usesInheritance: true, ngImport: i0 }); }
56
+ }
57
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: RippleDirective, decorators: [{
58
+ type: Directive,
59
+ args: [{
60
+ standalone: true,
61
+ selector: "ng-template[nuRipple]",
62
+ exportAs: "nuRipple"
63
+ }]
64
+ }], ctorParameters: () => [{ type: i0.TemplateRef }, { type: i0.NgZone }, { type: i0.ElementRef }] });
65
+ class Ripple {
66
+ #autoDestroy;
67
+ #hiding;
68
+ constructor(config, zone, onDestroy) {
69
+ this.onDestroy = onDestroy;
70
+ this.isRunning = false;
71
+ this.#autoDestroy = false;
72
+ this.#hiding = false;
73
+ this.autoDestroy = () => {
74
+ if (this.isRunning) {
75
+ this.#autoDestroy = true;
76
+ }
77
+ else {
78
+ this.#fadeOut();
79
+ }
80
+ };
81
+ this.#transBegin = () => {
82
+ // eslint-disable-next-line no-extra-semi
83
+ ;
84
+ this.isRunning = true;
85
+ };
86
+ this.#transEnd = (event) => {
87
+ if (event.propertyName === "opacity") {
88
+ if (this.#hiding) {
89
+ this.dispose();
90
+ }
91
+ else {
92
+ if (this.#autoDestroy) {
93
+ this.#fadeOut();
94
+ }
95
+ }
96
+ }
97
+ else if (event.propertyName === "transform") {
98
+ // eslint-disable-next-line no-extra-semi
99
+ ;
100
+ this.isRunning = false;
101
+ if (this.#autoDestroy) {
102
+ this.dispose();
103
+ }
104
+ }
105
+ };
106
+ const el = document.createElement("div");
107
+ el.style.position = "absolute";
108
+ el.style.top = `${config.y - config.r}px`;
109
+ el.style.left = `${config.x - config.r}px`;
110
+ el.style.width = `${config.r * 2}px`;
111
+ el.style.height = `${config.r * 2}px`;
112
+ el.style.pointerEvents = "none";
113
+ el.style.backgroundColor = "var(--ripple-color)";
114
+ el.style.borderRadius = "50%";
115
+ el.style.transition = `opacity ${config.d / 2}ms ease-out, transform ${config.d}ms ease-out`;
116
+ el.style.opacity = "0";
117
+ el.style.transformOrigin = "center";
118
+ el.style.transform = "scale(0)";
119
+ this.el = el;
120
+ zone.runOutsideAngular(() => {
121
+ el.addEventListener("transitionstart", this.#transBegin);
122
+ el.addEventListener("transitionend", this.#transEnd);
123
+ document.addEventListener("mouseup", this.autoDestroy, { capture: true, passive: true });
124
+ document.addEventListener("dragend", this.autoDestroy, { capture: true, passive: true });
125
+ });
126
+ }
127
+ start() {
128
+ // eslint-disable-next-line no-extra-semi
129
+ ;
130
+ this.isRunning = true;
131
+ // XXX: force style apply
132
+ const opacity = typeof window !== "undefined" ? Number(window.getComputedStyle(this.el).opacity) : 1;
133
+ this.el.style.opacity = opacity ? "0.3" : "0.3";
134
+ this.el.style.transform = "scale(1)";
135
+ }
136
+ dispose() {
137
+ this.el.removeEventListener("transitionstart", this.#transBegin);
138
+ this.el.removeEventListener("transitionend", this.#transEnd);
139
+ document.removeEventListener("mouseup", this.autoDestroy, { capture: true });
140
+ this.el.parentNode?.removeChild(this.el);
141
+ this.onDestroy();
142
+ }
143
+ #transBegin;
144
+ #transEnd;
145
+ #fadeOut() {
146
+ if (this.#hiding) {
147
+ return;
148
+ }
149
+ this.#hiding = true;
150
+ this.el.style.opacity = "0";
151
+ }
152
+ }
153
+ function maxPossibleRadius(x, y, w, h) {
154
+ const distX = Math.max(x, Math.abs(w - x));
155
+ const distY = Math.max(y, Math.abs(h - y));
156
+ return Math.sqrt(distX * distX + distY * distY);
8
157
  }
9
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: GraphicsComponent, decorators: [{
10
- type: Component,
11
- args: [{ selector: "nu-graphics", standalone: true, imports: [CommonModule], template: `<p>graphics works!</p>` }]
12
- }] });
13
158
 
14
159
  /**
15
160
  * Generated bundle index. Do not edit.
16
161
  */
17
162
 
18
- export { GraphicsComponent };
163
+ export { Ripple, RippleDirective };
19
164
  //# sourceMappingURL=ngutil-graphics.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"ngutil-graphics.mjs","sources":["../../../../packages/graphics/src/lib/graphics/graphics.component.ts","../../../../packages/graphics/src/ngutil-graphics.ts"],"sourcesContent":["import { CommonModule } from \"@angular/common\"\nimport { Component } from \"@angular/core\"\n\n@Component({\n selector: \"nu-graphics\",\n standalone: true,\n imports: [CommonModule],\n template: `<p>graphics works!</p>`,\n styleUrl: \"./graphics.component.scss\"\n})\nexport class GraphicsComponent {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAUa,iBAAiB,CAAA;8GAAjB,iBAAiB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;kGAAjB,iBAAiB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,aAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAHhB,CAAwB,sBAAA,CAAA,EAAA,QAAA,EAAA,IAAA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EADxB,YAAY,EAAA,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAIb,iBAAiB,EAAA,UAAA,EAAA,CAAA;kBAP7B,SAAS;AACI,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,aAAa,cACX,IAAI,EAAA,OAAA,EACP,CAAC,YAAY,CAAC,YACb,CAAwB,sBAAA,CAAA,EAAA,CAAA;;;ACPtC;;AAEG;;;;"}
1
+ {"version":3,"file":"ngutil-graphics.mjs","sources":["../../../../packages/graphics/src/ripple/ripple.directive.ts","../../../../packages/graphics/src/ngutil-graphics.ts"],"sourcesContent":["import { Directive, ElementRef, NgZone, TemplateRef } from \"@angular/core\"\n\nimport { Destructible, IDisposable } from \"@ngutil/common\"\n\n@Directive({\n standalone: true,\n selector: \"ng-template[nuRipple]\",\n exportAs: \"nuRipple\"\n})\nexport class RippleDirective extends Destructible {\n #current?: Ripple\n\n constructor(\n private readonly tplRef: TemplateRef<any>,\n private readonly zone: NgZone,\n private readonly el: ElementRef<Node>\n ) {\n super()\n zone.runOutsideAngular(() => {\n const target = el.nativeElement.parentElement\n if (target) {\n target.addEventListener(\"mousedown\", this.#onMouseDown)\n this.d.any(() => target.removeEventListener(\"mousedown\", this.#onMouseDown))\n }\n })\n }\n\n begin(event: MouseEvent) {\n this.#current?.autoDestroy()\n const cfg = this.#createRippleConfig(event)\n const ripple = this.#createRipple(cfg)\n this.#current = ripple\n\n const refEl = this.tplRef.elementRef.nativeElement as HTMLElement\n refEl.parentNode?.insertBefore(ripple.el, refEl)\n ripple.start()\n }\n\n end() {\n this.#current?.autoDestroy()\n }\n\n #createRipple(config: RippleConfig) {\n const ripple = new Ripple(config, this.zone, () => {\n if (this.#current === ripple) {\n this.#current = undefined\n }\n })\n this.d.disposable(ripple)\n return ripple\n }\n\n #createRippleConfig(event: MouseEvent): RippleConfig {\n const container = event.currentTarget as HTMLElement\n const bounds = container.getBoundingClientRect()\n const w = bounds.width\n const h = bounds.height\n const x = event.clientX - bounds.left\n const y = event.clientY - bounds.top\n const r = maxPossibleRadius(x, y, w, h) + Math.min(w, h)\n return { x, y, w, h, r, d: 600 }\n }\n\n #onMouseDown = (event: MouseEvent) => {\n this.begin(event)\n }\n}\n\ntype RippleConfig = { x: number; y: number; w: number; h: number; r: number; d: number }\n\nexport class Ripple implements IDisposable {\n public readonly el: HTMLDivElement\n public readonly isRunning: boolean = false\n\n #autoDestroy = false\n #hiding = false\n\n constructor(\n config: RippleConfig,\n zone: NgZone,\n public readonly onDestroy: () => void\n ) {\n const el = document.createElement(\"div\")\n el.style.position = \"absolute\"\n el.style.top = `${config.y - config.r}px`\n el.style.left = `${config.x - config.r}px`\n el.style.width = `${config.r * 2}px`\n el.style.height = `${config.r * 2}px`\n el.style.pointerEvents = \"none\"\n el.style.backgroundColor = \"var(--ripple-color)\"\n el.style.borderRadius = \"50%\"\n el.style.transition = `opacity ${config.d / 2}ms ease-out, transform ${config.d}ms ease-out`\n el.style.opacity = \"0\"\n el.style.transformOrigin = \"center\"\n el.style.transform = \"scale(0)\"\n this.el = el\n\n zone.runOutsideAngular(() => {\n el.addEventListener(\"transitionstart\", this.#transBegin)\n el.addEventListener(\"transitionend\", this.#transEnd)\n document.addEventListener(\"mouseup\", this.autoDestroy, { capture: true, passive: true })\n document.addEventListener(\"dragend\", this.autoDestroy, { capture: true, passive: true })\n })\n }\n\n start() {\n // eslint-disable-next-line no-extra-semi\n ;(this as { isRunning: boolean }).isRunning = true\n // XXX: force style apply\n const opacity = typeof window !== \"undefined\" ? Number(window.getComputedStyle(this.el).opacity) : 1\n this.el.style.opacity = opacity ? \"0.3\" : \"0.3\"\n this.el.style.transform = \"scale(1)\"\n }\n\n autoDestroy = () => {\n if (this.isRunning) {\n this.#autoDestroy = true\n } else {\n this.#fadeOut()\n }\n }\n\n dispose(): void {\n this.el.removeEventListener(\"transitionstart\", this.#transBegin)\n this.el.removeEventListener(\"transitionend\", this.#transEnd)\n document.removeEventListener(\"mouseup\", this.autoDestroy, { capture: true })\n this.el.parentNode?.removeChild(this.el)\n this.onDestroy()\n }\n\n #transBegin = () => {\n // eslint-disable-next-line no-extra-semi\n ;(this as { isRunning: boolean }).isRunning = true\n }\n\n #transEnd = (event: TransitionEvent) => {\n if (event.propertyName === \"opacity\") {\n if (this.#hiding) {\n this.dispose()\n } else {\n if (this.#autoDestroy) {\n this.#fadeOut()\n }\n }\n } else if (event.propertyName === \"transform\") {\n // eslint-disable-next-line no-extra-semi\n ;(this as { isRunning: boolean }).isRunning = false\n if (this.#autoDestroy) {\n this.dispose()\n }\n }\n }\n\n #fadeOut() {\n if (this.#hiding) {\n return\n }\n this.#hiding = true\n this.el.style.opacity = \"0\"\n }\n}\n\nfunction maxPossibleRadius(x: number, y: number, w: number, h: number) {\n const distX = Math.max(x, Math.abs(w - x))\n const distY = Math.max(y, Math.abs(h - y))\n return Math.sqrt(distX * distX + distY * distY)\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/index.d.ts CHANGED
@@ -1 +1 @@
1
- export * from "./lib/graphics/graphics.component";
1
+ export * from "./ripple/ripple.directive";
package/package.json CHANGED
@@ -1,13 +1,14 @@
1
1
  {
2
2
  "name": "@ngutil/graphics",
3
- "version": "0.0.3-dev.13",
3
+ "version": "0.0.3-dev.14",
4
4
  "publishConfig": {
5
5
  "access": "public",
6
6
  "directory": "../../dist/packages/graphics/"
7
7
  },
8
8
  "peerDependencies": {
9
9
  "@angular/common": "^17.1.0",
10
- "@angular/core": "^17.1.0"
10
+ "@angular/core": "^17.1.0",
11
+ "@ngutil/common": "0.0.3-dev.14"
11
12
  },
12
13
  "dependencies": {
13
14
  "tslib": "^2.3.0"
@@ -0,0 +1,33 @@
1
+ import { ElementRef, NgZone, TemplateRef } from "@angular/core";
2
+ import { Destructible, IDisposable } from "@ngutil/common";
3
+ import * as i0 from "@angular/core";
4
+ export declare class RippleDirective extends Destructible {
5
+ #private;
6
+ private readonly tplRef;
7
+ private readonly zone;
8
+ private readonly el;
9
+ constructor(tplRef: TemplateRef<any>, zone: NgZone, el: ElementRef<Node>);
10
+ begin(event: MouseEvent): void;
11
+ end(): void;
12
+ static ɵfac: i0.ɵɵFactoryDeclaration<RippleDirective, never>;
13
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RippleDirective, "ng-template[nuRipple]", ["nuRipple"], {}, {}, never, never, true, never>;
14
+ }
15
+ type RippleConfig = {
16
+ x: number;
17
+ y: number;
18
+ w: number;
19
+ h: number;
20
+ r: number;
21
+ d: number;
22
+ };
23
+ export declare class Ripple implements IDisposable {
24
+ #private;
25
+ readonly onDestroy: () => void;
26
+ readonly el: HTMLDivElement;
27
+ readonly isRunning: boolean;
28
+ constructor(config: RippleConfig, zone: NgZone, onDestroy: () => void);
29
+ start(): void;
30
+ autoDestroy: () => void;
31
+ dispose(): void;
32
+ }
33
+ export {};
@@ -1,12 +0,0 @@
1
- import { CommonModule } from "@angular/common";
2
- import { Component } from "@angular/core";
3
- import * as i0 from "@angular/core";
4
- export class GraphicsComponent {
5
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: GraphicsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: GraphicsComponent, isStandalone: true, selector: "nu-graphics", ngImport: i0, template: `<p>graphics works!</p>`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
7
- }
8
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: GraphicsComponent, decorators: [{
9
- type: Component,
10
- args: [{ selector: "nu-graphics", standalone: true, imports: [CommonModule], template: `<p>graphics works!</p>` }]
11
- }] });
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhpY3MuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JhcGhpY3Mvc3JjL2xpYi9ncmFwaGljcy9ncmFwaGljcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBU3pDLE1BQU0sT0FBTyxpQkFBaUI7OEdBQWpCLGlCQUFpQjtrR0FBakIsaUJBQWlCLHVFQUhoQix3QkFBd0IseUVBRHhCLFlBQVk7OzJGQUliLGlCQUFpQjtrQkFQN0IsU0FBUzsrQkFDSSxhQUFhLGNBQ1gsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLFlBQ2Isd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiXG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcIm51LWdyYXBoaWNzXCIsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgICB0ZW1wbGF0ZTogYDxwPmdyYXBoaWNzIHdvcmtzITwvcD5gLFxuICAgIHN0eWxlVXJsOiBcIi4vZ3JhcGhpY3MuY29tcG9uZW50LnNjc3NcIlxufSlcbmV4cG9ydCBjbGFzcyBHcmFwaGljc0NvbXBvbmVudCB7fVxuIl19
@@ -1,5 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- export declare class GraphicsComponent {
3
- static ɵfac: i0.ɵɵFactoryDeclaration<GraphicsComponent, never>;
4
- static ɵcmp: i0.ɵɵComponentDeclaration<GraphicsComponent, "nu-graphics", never, {}, {}, never, never, true, never>;
5
- }