@ngutil/graphics 0.0.51 → 0.0.52
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/cover.service.d.ts +47 -11
- package/esm2022/cover.service.mjs +117 -25
- package/esm2022/index.mjs +3 -3
- package/esm2022/ripple/ripple.directive.mjs +2 -6
- package/esm2022/util/animation-observable.mjs +2 -1
- package/esm2022/util/index.mjs +3 -0
- package/esm2022/util/polygon.mjs +60 -0
- package/fesm2022/ngutil-graphics.mjs +194 -47
- package/fesm2022/ngutil-graphics.mjs.map +1 -1
- package/index.d.ts +2 -2
- package/package.json +3 -3
- package/util/index.d.ts +2 -0
- package/util/polygon.d.ts +7 -0
package/cover.service.d.ts
CHANGED
|
@@ -1,20 +1,38 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ElementRef } from "@angular/core";
|
|
2
|
+
import { Observable, ObservableInput, Subscriber, TeardownLogic } from "rxjs";
|
|
2
3
|
import { ElementInput } from "@ngutil/common";
|
|
3
|
-
import { Rect } from "@ngutil/style";
|
|
4
|
+
import { Rect, RectWatcher, SidesInput } from "@ngutil/style";
|
|
5
|
+
import { Polygon } from "./util";
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
|
-
export interface
|
|
6
|
-
container: ElementInput;
|
|
7
|
+
export interface CommonCoverOptions {
|
|
7
8
|
color: "transparent" | string;
|
|
9
|
+
style?: Partial<CSSStyleDeclaration>;
|
|
8
10
|
}
|
|
9
|
-
export interface SolidCoverOptions extends
|
|
11
|
+
export interface SolidCoverOptions extends CommonCoverOptions {
|
|
12
|
+
type: "solid";
|
|
10
13
|
}
|
|
11
|
-
export interface CropCoverOptions extends
|
|
14
|
+
export interface CropCoverOptions extends CommonCoverOptions {
|
|
15
|
+
type: "crop";
|
|
12
16
|
/**
|
|
13
17
|
* Element that will be interactive while the cover is visible
|
|
14
18
|
*/
|
|
15
|
-
crop: ElementInput |
|
|
19
|
+
crop: ElementInput | ObservableInput<Rect | ElementInput>;
|
|
20
|
+
shape: CropShapeOptions;
|
|
21
|
+
expand?: SidesInput;
|
|
22
|
+
contract?: SidesInput;
|
|
23
|
+
disablePointerEvents?: boolean;
|
|
16
24
|
}
|
|
17
|
-
export
|
|
25
|
+
export type CropShapeOptions = CropRectOptions | CropCircleOptions | CropShapeCustom;
|
|
26
|
+
export interface CropRectOptions {
|
|
27
|
+
type: "rect";
|
|
28
|
+
borderRadius?: number;
|
|
29
|
+
}
|
|
30
|
+
export interface CropCircleOptions {
|
|
31
|
+
type: "circle";
|
|
32
|
+
}
|
|
33
|
+
export type CropShapeCustom = (container: Rect, crop: Rect) => Polygon;
|
|
34
|
+
export interface RevealCoverOptions extends CommonCoverOptions {
|
|
35
|
+
type: "reveal";
|
|
18
36
|
/**
|
|
19
37
|
* Left and right coordinates inside the container
|
|
20
38
|
*/
|
|
@@ -23,11 +41,29 @@ export interface RevealCoverOptions extends CoverOptions {
|
|
|
23
41
|
top: number;
|
|
24
42
|
};
|
|
25
43
|
}
|
|
44
|
+
export type CoverOptions = SolidCoverOptions | CropCoverOptions | RevealCoverOptions;
|
|
45
|
+
export declare abstract class CoverRef<O extends CommonCoverOptions, R = void> extends ElementRef<HTMLElement> {
|
|
46
|
+
readonly container: ElementInput;
|
|
47
|
+
readonly options: O;
|
|
48
|
+
protected readonly watcher: RectWatcher;
|
|
49
|
+
constructor(container: ElementInput, options: O, watcher: RectWatcher);
|
|
50
|
+
show(): Observable<R>;
|
|
51
|
+
protected applyStyle(mask: HTMLElement): void;
|
|
52
|
+
protected abstract _show(dest: Subscriber<unknown>): TeardownLogic;
|
|
53
|
+
}
|
|
54
|
+
export declare class SolidCoverRef extends CoverRef<SolidCoverOptions> {
|
|
55
|
+
protected _show(dest: Subscriber<unknown>): TeardownLogic;
|
|
56
|
+
}
|
|
57
|
+
export declare class CropCoverRef extends CoverRef<CropCoverOptions> {
|
|
58
|
+
#private;
|
|
59
|
+
protected _show(dest: Subscriber<unknown>): TeardownLogic;
|
|
60
|
+
}
|
|
61
|
+
export declare class RevealCoverRef extends CoverRef<RevealCoverOptions> {
|
|
62
|
+
protected _show(dest: Subscriber<unknown>): TeardownLogic;
|
|
63
|
+
}
|
|
26
64
|
export declare class CoverService {
|
|
27
65
|
#private;
|
|
28
|
-
|
|
29
|
-
crop(options: CropCoverOptions): Observable<HTMLDivElement>;
|
|
30
|
-
reveal(options: RevealCoverOptions): Observable<HTMLDivElement>;
|
|
66
|
+
create(container: ElementInput, options: CoverOptions): SolidCoverRef | CropCoverRef | RevealCoverRef;
|
|
31
67
|
static ɵfac: i0.ɵɵFactoryDeclaration<CoverService, never>;
|
|
32
68
|
static ɵprov: i0.ɵɵInjectableDeclaration<CoverService>;
|
|
33
69
|
}
|
|
@@ -1,36 +1,128 @@
|
|
|
1
|
-
import { Injectable } from "@angular/core";
|
|
2
|
-
import { Observable, of } from "rxjs";
|
|
3
|
-
import { coerceElement } from "@ngutil/common";
|
|
1
|
+
import { ElementRef, inject, Injectable } from "@angular/core";
|
|
2
|
+
import { combineLatest, filter, from, map, Observable, of, switchMap } from "rxjs";
|
|
3
|
+
import { coerceElement, isElementInput } from "@ngutil/common";
|
|
4
|
+
import { rectContract, rectExpand, RectWatcher } from "@ngutil/style";
|
|
5
|
+
import { maxPossibleRadius, polygonArc, polygonRect, polygonRoundedRect, polygonToCss } from "./util";
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
|
-
export class
|
|
6
|
-
|
|
7
|
+
export class CoverRef extends ElementRef {
|
|
8
|
+
constructor(container, options, watcher) {
|
|
9
|
+
super(document.createElement("div"));
|
|
10
|
+
this.container = container;
|
|
11
|
+
this.options = options;
|
|
12
|
+
this.watcher = watcher;
|
|
13
|
+
Object.assign(this.nativeElement.style, {
|
|
14
|
+
position: "absolute",
|
|
15
|
+
inset: "0px"
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
show() {
|
|
7
19
|
return new Observable(dest => {
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
return () => {
|
|
13
|
-
cover.parentElement?.removeChild(cover);
|
|
14
|
-
};
|
|
20
|
+
const element = this.nativeElement;
|
|
21
|
+
coerceElement(this.container).appendChild(element);
|
|
22
|
+
dest.add(() => element.parentElement?.removeChild(element));
|
|
23
|
+
return this._show(dest);
|
|
15
24
|
});
|
|
16
25
|
}
|
|
17
|
-
|
|
18
|
-
|
|
26
|
+
applyStyle(mask) {
|
|
27
|
+
const options = this.options;
|
|
28
|
+
const backgroundColor = options.color === "transparent" ? "rgba(255, 255, 255, 0.0001)" : options.color;
|
|
29
|
+
if (options.style) {
|
|
30
|
+
Object.assign(mask.style, { backgroundColor, ...options.style });
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
Object.assign(mask.style, { backgroundColor });
|
|
34
|
+
}
|
|
19
35
|
}
|
|
20
|
-
|
|
21
|
-
|
|
36
|
+
}
|
|
37
|
+
export class SolidCoverRef extends CoverRef {
|
|
38
|
+
_show(dest) {
|
|
39
|
+
this.applyStyle(this.nativeElement);
|
|
22
40
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
41
|
+
}
|
|
42
|
+
export class CropCoverRef extends CoverRef {
|
|
43
|
+
_show(dest) {
|
|
44
|
+
const options = this.options;
|
|
45
|
+
const crop = isElementInput(options.crop) ? of(options.crop) : from(options.crop);
|
|
46
|
+
let maskEl = this.nativeElement;
|
|
47
|
+
// TODO: a backdrop filter kicsit ksőbb jelenik meg így
|
|
48
|
+
if (this.options.disablePointerEvents) {
|
|
49
|
+
maskEl = document.createElement("div");
|
|
50
|
+
Object.assign(maskEl.style, {
|
|
51
|
+
position: "absolute",
|
|
52
|
+
inset: "0px"
|
|
53
|
+
});
|
|
54
|
+
this.applyStyle(maskEl);
|
|
55
|
+
// maskEl.style.backdropFilter = null as any
|
|
56
|
+
this.nativeElement.appendChild(maskEl);
|
|
57
|
+
this.nativeElement.style.background = "rgba(0, 0, 0, 0.1)";
|
|
58
|
+
// this.nativeElement.style.backdropFilter = this.options.style?.backdropFilter as any
|
|
29
59
|
}
|
|
30
60
|
else {
|
|
31
|
-
|
|
61
|
+
this.applyStyle(this.nativeElement);
|
|
62
|
+
}
|
|
63
|
+
return combineLatest({
|
|
64
|
+
container: this.watcher.watch(this.container, "border-box"),
|
|
65
|
+
crop: crop.pipe(filter(value => value != null), switchMap(crop => {
|
|
66
|
+
if (isElementInput(crop)) {
|
|
67
|
+
return this.watcher.watch(coerceElement(crop), "border-box");
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
return of(crop);
|
|
71
|
+
}
|
|
72
|
+
}), map(crop => {
|
|
73
|
+
if (this.options.expand) {
|
|
74
|
+
crop = rectExpand(crop, this.options.expand);
|
|
75
|
+
}
|
|
76
|
+
if (this.options.contract) {
|
|
77
|
+
crop = rectContract(crop, this.options.contract);
|
|
78
|
+
}
|
|
79
|
+
return crop;
|
|
80
|
+
}))
|
|
81
|
+
}).subscribe(({ container, crop }) => {
|
|
82
|
+
const outer = polygonRect({ x: 0, y: 0 }, { x: container.width, y: container.height });
|
|
83
|
+
const croppedArea = this.#polygon(container, crop).reverse();
|
|
84
|
+
const polygon = [...outer, ...croppedArea];
|
|
85
|
+
maskEl.style.clipPath = polygonToCss(polygon);
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
#polygon(container, crop) {
|
|
89
|
+
const shape = this.options.shape;
|
|
90
|
+
if (typeof shape === "function") {
|
|
91
|
+
return shape(container, crop);
|
|
92
|
+
}
|
|
93
|
+
else if (shape.type === "circle") {
|
|
94
|
+
const r = maxPossibleRadius(crop.x, crop.y, crop.width, crop.height);
|
|
95
|
+
return polygonArc({ x: crop.x + r, y: crop.y + r }, r, 0, Math.PI * 2);
|
|
96
|
+
}
|
|
97
|
+
else if (shape.type === "rect") {
|
|
98
|
+
const top = Math.round(Math.max(crop.y - container.y, 0));
|
|
99
|
+
const right = Math.round(Math.max(crop.x + crop.width));
|
|
100
|
+
const bottom = Math.round(Math.max(crop.y + crop.height));
|
|
101
|
+
const left = Math.round(Math.max(crop.x - container.x));
|
|
102
|
+
if (shape.borderRadius != null) {
|
|
103
|
+
return polygonRoundedRect({ x: left, y: top }, { x: right, y: bottom }, shape.borderRadius);
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
return polygonRect({ x: left, y: top }, { x: right, y: bottom });
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return [];
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
export class RevealCoverRef extends CoverRef {
|
|
113
|
+
_show(dest) { }
|
|
114
|
+
}
|
|
115
|
+
export class CoverService {
|
|
116
|
+
#watcher = inject(RectWatcher);
|
|
117
|
+
create(container, options) {
|
|
118
|
+
switch (options.type) {
|
|
119
|
+
case "solid":
|
|
120
|
+
return new SolidCoverRef(container, options, this.#watcher);
|
|
121
|
+
case "crop":
|
|
122
|
+
return new CropCoverRef(container, options, this.#watcher);
|
|
123
|
+
case "reveal":
|
|
124
|
+
return new RevealCoverRef(container, options, this.#watcher);
|
|
32
125
|
}
|
|
33
|
-
return el;
|
|
34
126
|
}
|
|
35
127
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: CoverService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
36
128
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: CoverService, providedIn: "root" }); }
|
|
@@ -39,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
|
|
|
39
131
|
type: Injectable,
|
|
40
132
|
args: [{ providedIn: "root" }]
|
|
41
133
|
}] });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY292ZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyYXBoaWNzL3NyYy9jb3Zlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUE7QUFFckMsT0FBTyxFQUFFLGFBQWEsRUFBZ0IsTUFBTSxnQkFBZ0IsQ0FBQTs7QUF5QjVELE1BQU0sT0FBTyxZQUFZO0lBQ3JCLEtBQUssQ0FBQyxPQUEwQjtRQUM1QixPQUFPLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3pCLE1BQU0sU0FBUyxHQUFHLGFBQWEsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUE7WUFDbEQsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQTtZQUMxQyxTQUFTLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQzVCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7WUFFaEIsT0FBTyxHQUFHLEVBQUU7Z0JBQ1IsS0FBSyxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUE7WUFDM0MsQ0FBQyxDQUFBO1FBQ0wsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDO0lBRUQsSUFBSSxDQUFDLE9BQXlCO1FBQzFCLE9BQU8sRUFBRSxFQUFFLENBQUE7SUFDZixDQUFDO0lBRUQsTUFBTSxDQUFDLE9BQTJCO1FBQzlCLE9BQU8sRUFBRSxFQUFFLENBQUE7SUFDZixDQUFDO0lBRUQsY0FBYyxDQUFDLE9BQXFCO1FBQ2hDLE1BQU0sRUFBRSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDeEMsRUFBRSxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsVUFBVSxDQUFBO1FBQzlCLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQTtRQUV2RSxJQUFJLE9BQU8sQ0FBQyxLQUFLLEtBQUssYUFBYSxFQUFFLENBQUM7WUFDbEMsRUFBRSxDQUFDLEtBQUssQ0FBQyxlQUFlLEdBQUcsNkJBQTZCLENBQUE7UUFDNUQsQ0FBQzthQUFNLENBQUM7WUFDSixFQUFFLENBQUMsS0FBSyxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFBO1FBQzVDLENBQUM7UUFFRCxPQUFPLEVBQUUsQ0FBQTtJQUNiLENBQUM7OEdBbENRLFlBQVk7a0hBQVosWUFBWSxjQURDLE1BQU07OzJGQUNuQixZQUFZO2tCQUR4QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgeyBjb2VyY2VFbGVtZW50LCBFbGVtZW50SW5wdXQgfSBmcm9tIFwiQG5ndXRpbC9jb21tb25cIlxuaW1wb3J0IHsgUmVjdCB9IGZyb20gXCJAbmd1dGlsL3N0eWxlXCJcblxuZXhwb3J0IGludGVyZmFjZSBDb3Zlck9wdGlvbnMge1xuICAgIGNvbnRhaW5lcjogRWxlbWVudElucHV0XG4gICAgY29sb3I6IFwidHJhbnNwYXJlbnRcIiB8IHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNvbGlkQ292ZXJPcHRpb25zIGV4dGVuZHMgQ292ZXJPcHRpb25zIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3JvcENvdmVyT3B0aW9ucyBleHRlbmRzIENvdmVyT3B0aW9ucyB7XG4gICAgLyoqXG4gICAgICogRWxlbWVudCB0aGF0IHdpbGwgYmUgaW50ZXJhY3RpdmUgd2hpbGUgdGhlIGNvdmVyIGlzIHZpc2libGVcbiAgICAgKi9cbiAgICBjcm9wOiBFbGVtZW50SW5wdXQgfCBPYnNlcnZhYmxlPFJlY3Q+XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmV2ZWFsQ292ZXJPcHRpb25zIGV4dGVuZHMgQ292ZXJPcHRpb25zIHtcbiAgICAvKipcbiAgICAgKiBMZWZ0IGFuZCByaWdodCBjb29yZGluYXRlcyBpbnNpZGUgdGhlIGNvbnRhaW5lclxuICAgICAqL1xuICAgIG9yaWdpbjogeyBsZWZ0OiBudW1iZXI7IHRvcDogbnVtYmVyIH1cbn1cblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiBcInJvb3RcIiB9KVxuZXhwb3J0IGNsYXNzIENvdmVyU2VydmljZSB7XG4gICAgc29saWQob3B0aW9uczogU29saWRDb3Zlck9wdGlvbnMpOiBPYnNlcnZhYmxlPEhUTUxEaXZFbGVtZW50PiB7XG4gICAgICAgIHJldHVybiBuZXcgT2JzZXJ2YWJsZShkZXN0ID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGNvbnRhaW5lciA9IGNvZXJjZUVsZW1lbnQob3B0aW9ucy5jb250YWluZXIpXG4gICAgICAgICAgICBjb25zdCBjb3ZlciA9IHRoaXMuI2NyZWF0ZUVsZW1lbnQob3B0aW9ucylcbiAgICAgICAgICAgIGNvbnRhaW5lci5hcHBlbmRDaGlsZChjb3ZlcilcbiAgICAgICAgICAgIGRlc3QubmV4dChjb3ZlcilcblxuICAgICAgICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgICAgICAgICBjb3Zlci5wYXJlbnRFbGVtZW50Py5yZW1vdmVDaGlsZChjb3ZlcilcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICB9XG5cbiAgICBjcm9wKG9wdGlvbnM6IENyb3BDb3Zlck9wdGlvbnMpOiBPYnNlcnZhYmxlPEhUTUxEaXZFbGVtZW50PiB7XG4gICAgICAgIHJldHVybiBvZigpXG4gICAgfVxuXG4gICAgcmV2ZWFsKG9wdGlvbnM6IFJldmVhbENvdmVyT3B0aW9ucyk6IE9ic2VydmFibGU8SFRNTERpdkVsZW1lbnQ+IHtcbiAgICAgICAgcmV0dXJuIG9mKClcbiAgICB9XG5cbiAgICAjY3JlYXRlRWxlbWVudChvcHRpb25zOiBDb3Zlck9wdGlvbnMpIHtcbiAgICAgICAgY29uc3QgZWwgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpXG4gICAgICAgIGVsLnN0eWxlLnBvc2l0aW9uID0gXCJhYnNvbHV0ZVwiXG4gICAgICAgIGVsLnN0eWxlLnRvcCA9IGVsLnN0eWxlLnJpZ2h0ID0gZWwuc3R5bGUuYm90dG9tID0gZWwuc3R5bGUubGVmdCA9IFwiMHB4XCJcblxuICAgICAgICBpZiAob3B0aW9ucy5jb2xvciA9PT0gXCJ0cmFuc3BhcmVudFwiKSB7XG4gICAgICAgICAgICBlbC5zdHlsZS5iYWNrZ3JvdW5kQ29sb3IgPSBcInJnYmEoMjU1LCAyNTUsIDI1NSwgMC4wMDAxKVwiXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBlbC5zdHlsZS5iYWNrZ3JvdW5kQ29sb3IgPSBvcHRpb25zLmNvbG9yXG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gZWxcbiAgICB9XG59XG4iXX0=
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cover.service.js","sourceRoot":"","sources":["../../../../packages/graphics/src/cover.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, inject, Injectable } from \"@angular/core\"\n\nimport {\n    combineLatest,\n    filter,\n    from,\n    map,\n    Observable,\n    ObservableInput,\n    of,\n    Subscriber,\n    switchMap,\n    TeardownLogic\n} from \"rxjs\"\n\nimport { coerceElement, ElementInput, isElementInput } from \"@ngutil/common\"\nimport { Rect, rectContract, rectExpand, RectWatcher, SidesInput } from \"@ngutil/style\"\n\nimport { maxPossibleRadius, Polygon, polygonArc, polygonRect, polygonRoundedRect, polygonToCss } from \"./util\"\n\nexport interface CommonCoverOptions {\n    color: \"transparent\" | string\n    style?: Partial<CSSStyleDeclaration>\n}\n\nexport interface SolidCoverOptions extends CommonCoverOptions {\n    type: \"solid\"\n}\n\nexport interface CropCoverOptions extends CommonCoverOptions {\n    type: \"crop\"\n    /**\n     * Element that will be interactive while the cover is visible\n     */\n    crop: ElementInput | ObservableInput<Rect | ElementInput>\n    shape: CropShapeOptions\n    expand?: SidesInput\n    contract?: SidesInput\n    disablePointerEvents?: boolean\n}\n\nexport type CropShapeOptions = CropRectOptions | CropCircleOptions | CropShapeCustom\n\nexport interface CropRectOptions {\n    type: \"rect\"\n    borderRadius?: number\n}\n\nexport interface CropCircleOptions {\n    type: \"circle\"\n}\n\nexport type CropShapeCustom = (container: Rect, crop: Rect) => Polygon\n\nexport interface RevealCoverOptions extends CommonCoverOptions {\n    type: \"reveal\"\n    /**\n     * Left and right coordinates inside the container\n     */\n    origin: { left: number; top: number }\n}\n\nexport type CoverOptions = SolidCoverOptions | CropCoverOptions | RevealCoverOptions\n\nexport abstract class CoverRef<O extends CommonCoverOptions, R = void> extends ElementRef<HTMLElement> {\n    protected readonly watcher: RectWatcher\n\n    constructor(\n        readonly container: ElementInput,\n        readonly options: O,\n        watcher: RectWatcher\n    ) {\n        super(document.createElement(\"div\"))\n        this.watcher = watcher\n\n        Object.assign(this.nativeElement.style, {\n            position: \"absolute\",\n            inset: \"0px\"\n        })\n    }\n\n    show(): Observable<R> {\n        return new Observable(dest => {\n            const element = this.nativeElement\n            coerceElement(this.container).appendChild(element)\n            dest.add(() => element.parentElement?.removeChild(element))\n            return this._show(dest)\n        })\n    }\n\n    protected applyStyle(mask: HTMLElement) {\n        const options = this.options\n        const backgroundColor = options.color === \"transparent\" ? \"rgba(255, 255, 255, 0.0001)\" : options.color\n\n        if (options.style) {\n            Object.assign(mask.style, { backgroundColor, ...options.style })\n        } else {\n            Object.assign(mask.style, { backgroundColor })\n        }\n    }\n\n    protected abstract _show(dest: Subscriber<unknown>): TeardownLogic\n}\n\nexport class SolidCoverRef extends CoverRef<SolidCoverOptions> {\n    protected override _show(dest: Subscriber<unknown>): TeardownLogic {\n        this.applyStyle(this.nativeElement)\n    }\n}\n\nexport class CropCoverRef extends CoverRef<CropCoverOptions> {\n    protected override _show(dest: Subscriber<unknown>): TeardownLogic {\n        const options = this.options\n        const crop = isElementInput(options.crop) ? of(options.crop) : from(options.crop)\n        let maskEl = this.nativeElement\n\n        // TODO: a backdrop filter kicsit ksőbb jelenik meg így\n        if (this.options.disablePointerEvents) {\n            maskEl = document.createElement(\"div\")\n            Object.assign(maskEl.style, {\n                position: \"absolute\",\n                inset: \"0px\"\n            })\n            this.applyStyle(maskEl)\n            // maskEl.style.backdropFilter = null as any\n            this.nativeElement.appendChild(maskEl)\n            this.nativeElement.style.background = \"rgba(0, 0, 0, 0.1)\"\n            // this.nativeElement.style.backdropFilter = this.options.style?.backdropFilter as any\n        } else {\n            this.applyStyle(this.nativeElement)\n        }\n\n        return combineLatest({\n            container: this.watcher.watch(this.container, \"border-box\"),\n            crop: crop.pipe(\n                filter(value => value != null),\n                switchMap(crop => {\n                    if (isElementInput(crop)) {\n                        return this.watcher.watch(coerceElement(crop), \"border-box\")\n                    } else {\n                        return of(crop)\n                    }\n                }),\n                map(crop => {\n                    if (this.options.expand) {\n                        crop = rectExpand(crop, this.options.expand)\n                    }\n\n                    if (this.options.contract) {\n                        crop = rectContract(crop, this.options.contract)\n                    }\n\n                    return crop\n                })\n            )\n        }).subscribe(({ container, crop }) => {\n            const outer = polygonRect({ x: 0, y: 0 }, { x: container.width, y: container.height })\n            const croppedArea = this.#polygon(container, crop).reverse()\n            const polygon = [...outer, ...croppedArea]\n\n            maskEl.style.clipPath = polygonToCss(polygon)\n        })\n    }\n\n    #polygon(container: Rect, crop: Rect): Polygon {\n        const shape = this.options.shape\n        if (typeof shape === \"function\") {\n            return shape(container, crop)\n        } else if (shape.type === \"circle\") {\n            const r = maxPossibleRadius(crop.x, crop.y, crop.width, crop.height)\n            return polygonArc({ x: crop.x + r, y: crop.y + r }, r, 0, Math.PI * 2)\n        } else if (shape.type === \"rect\") {\n            const top = Math.round(Math.max(crop.y - container.y, 0))\n            const right = Math.round(Math.max(crop.x + crop.width))\n            const bottom = Math.round(Math.max(crop.y + crop.height))\n            const left = Math.round(Math.max(crop.x - container.x))\n\n            if (shape.borderRadius != null) {\n                return polygonRoundedRect({ x: left, y: top }, { x: right, y: bottom }, shape.borderRadius)\n            } else {\n                return polygonRect({ x: left, y: top }, { x: right, y: bottom })\n            }\n        }\n        return []\n    }\n}\n\nexport class RevealCoverRef extends CoverRef<RevealCoverOptions> {\n    protected override _show(dest: Subscriber<unknown>): TeardownLogic {}\n}\n\n@Injectable({ providedIn: \"root\" })\nexport class CoverService {\n    readonly #watcher = inject(RectWatcher)\n\n    create(container: ElementInput, options: CoverOptions) {\n        switch (options.type) {\n            case \"solid\":\n                return new SolidCoverRef(container, options, this.#watcher)\n            case \"crop\":\n                return new CropCoverRef(container, options, this.#watcher)\n            case \"reveal\":\n                return new RevealCoverRef(container, options, this.#watcher)\n        }\n    }\n}\n"]}
|
package/esm2022/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export * from "./ripple/ripple.directive";
|
|
2
|
-
export
|
|
3
|
-
export * from "./util
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export * from "./cover.service";
|
|
3
|
+
export * from "./util";
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmFwaGljcy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQTtBQUN6QyxjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vcmlwcGxlL3JpcHBsZS5kaXJlY3RpdmVcIlxuZXhwb3J0ICogZnJvbSBcIi4vY292ZXIuc2VydmljZVwiXG5leHBvcnQgKiBmcm9tIFwiLi91dGlsXCJcbiJdfQ==
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Directive, ElementRef, NgZone, TemplateRef } from "@angular/core";
|
|
2
2
|
import { Destructible } from "@ngutil/common";
|
|
3
|
+
import { maxPossibleRadius } from "../util";
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export class RippleDirective extends Destructible {
|
|
5
6
|
#current;
|
|
@@ -151,9 +152,4 @@ export class Ripple {
|
|
|
151
152
|
this.el.style.opacity = "0";
|
|
152
153
|
}
|
|
153
154
|
}
|
|
154
|
-
function maxPossibleRadius(x, y, w, h) {
|
|
155
|
-
const distX = Math.max(x, Math.abs(w - x));
|
|
156
|
-
const distY = Math.max(y, Math.abs(h - y));
|
|
157
|
-
return Math.sqrt(distX * distX + distY * distY);
|
|
158
|
-
}
|
|
159
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ripple.directive.js","sourceRoot":"","sources":["../../../../../packages/graphics/src/ripple/ripple.directive.ts"],"names":[],"mappings":"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","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            el.addEventListener(\"transitioncancel\", 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        this.el.removeEventListener(\"transitioncancel\", 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"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ripple.directive.js","sourceRoot":"","sources":["../../../../../packages/graphics/src/ripple/ripple.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, NgZone, TemplateRef } from \"@angular/core\"\n\nimport { Destructible, IDisposable } from \"@ngutil/common\"\n\nimport { maxPossibleRadius } from \"../util\"\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            el.addEventListener(\"transitioncancel\", 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        this.el.removeEventListener(\"transitioncancel\", 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"]}
|
|
@@ -12,8 +12,9 @@ export function animationObservable({ builder, animation, element, options }) {
|
|
|
12
12
|
player.onDone(done);
|
|
13
13
|
player.play();
|
|
14
14
|
return () => {
|
|
15
|
+
player.pause();
|
|
15
16
|
player.destroy();
|
|
16
17
|
};
|
|
17
18
|
});
|
|
18
19
|
}
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9uLW9ic2VydmFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmFwaGljcy9zcmMvdXRpbC9hbmltYXRpb24tb2JzZXJ2YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsVUFBVSxFQUFjLE1BQU0sTUFBTSxDQUFBO0FBRTdDLE9BQU8sRUFBRSxhQUFhLEVBQWdCLE1BQU0sZ0JBQWdCLENBQUE7QUFTNUQsTUFBTSxVQUFVLG1CQUFtQixDQUFDLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUE2QjtJQUNuRyxPQUFPLElBQUksVUFBVSxDQUFDLENBQUMsR0FBcUIsRUFBRSxFQUFFO1FBQzVDLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUE7UUFDeEMsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUE7UUFFOUQsTUFBTSxJQUFJLEdBQUcsR0FBRyxFQUFFO1lBQ2QsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFBO1lBQ1YsR0FBRyxDQUFDLFFBQVEsRUFBRSxDQUFBO1FBQ2xCLENBQUMsQ0FBQTtRQUVELE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDdEIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUNuQixNQUFNLENBQUMsSUFBSSxFQUFFLENBQUE7UUFFYixPQUFPLEdBQUcsRUFBRTtZQUNSLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQTtZQUNkLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQTtRQUNwQixDQUFDLENBQUE7SUFDTCxDQUFDLENBQUMsQ0FBQTtBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbmltYXRpb25CdWlsZGVyLCBBbmltYXRpb25NZXRhZGF0YSwgQW5pbWF0aW9uT3B0aW9ucyB9IGZyb20gXCJAYW5ndWxhci9hbmltYXRpb25zXCJcblxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3Vic2NyaWJlciB9IGZyb20gXCJyeGpzXCJcblxuaW1wb3J0IHsgY29lcmNlRWxlbWVudCwgRWxlbWVudElucHV0IH0gZnJvbSBcIkBuZ3V0aWwvY29tbW9uXCJcblxuZXhwb3J0IGludGVyZmFjZSBBbmltYXRpb25PYnNlcnZhYmxlUGFyYW1zIHtcbiAgICBidWlsZGVyOiBBbmltYXRpb25CdWlsZGVyXG4gICAgYW5pbWF0aW9uOiBBbmltYXRpb25NZXRhZGF0YSB8IEFuaW1hdGlvbk1ldGFkYXRhW11cbiAgICBlbGVtZW50OiBFbGVtZW50SW5wdXRcbiAgICBvcHRpb25zPzogQW5pbWF0aW9uT3B0aW9uc1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYW5pbWF0aW9uT2JzZXJ2YWJsZSh7IGJ1aWxkZXIsIGFuaW1hdGlvbiwgZWxlbWVudCwgb3B0aW9ucyB9OiBBbmltYXRpb25PYnNlcnZhYmxlUGFyYW1zKSB7XG4gICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChkc3Q6IFN1YnNjcmliZXI8dm9pZD4pID0+IHtcbiAgICAgICAgY29uc3QgZmFjdG9yeSA9IGJ1aWxkZXIuYnVpbGQoYW5pbWF0aW9uKVxuICAgICAgICBjb25zdCBwbGF5ZXIgPSBmYWN0b3J5LmNyZWF0ZShjb2VyY2VFbGVtZW50KGVsZW1lbnQpLCBvcHRpb25zKVxuXG4gICAgICAgIGNvbnN0IGRvbmUgPSAoKSA9PiB7XG4gICAgICAgICAgICBkc3QubmV4dCgpXG4gICAgICAgICAgICBkc3QuY29tcGxldGUoKVxuICAgICAgICB9XG5cbiAgICAgICAgcGxheWVyLm9uRGVzdHJveShkb25lKVxuICAgICAgICBwbGF5ZXIub25Eb25lKGRvbmUpXG4gICAgICAgIHBsYXllci5wbGF5KClcblxuICAgICAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICAgICAgcGxheWVyLnBhdXNlKClcbiAgICAgICAgICAgIHBsYXllci5kZXN0cm95KClcbiAgICAgICAgfVxuICAgIH0pXG59XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from "./animation-observable";
|
|
2
|
+
export * from "./polygon";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmFwaGljcy9zcmMvdXRpbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMsV0FBVyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYW5pbWF0aW9uLW9ic2VydmFibGVcIlxuZXhwb3J0ICogZnJvbSBcIi4vcG9seWdvblwiXG4iXX0=
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
export function polygonRect(topLeft, bottomRight) {
|
|
2
|
+
const result = [];
|
|
3
|
+
result.push(topLeft);
|
|
4
|
+
result.push({ x: bottomRight.x, y: topLeft.y });
|
|
5
|
+
result.push(bottomRight);
|
|
6
|
+
result.push({ x: topLeft.x, y: bottomRight.y });
|
|
7
|
+
result.push(topLeft);
|
|
8
|
+
return result;
|
|
9
|
+
}
|
|
10
|
+
const OctoAngle = (Math.PI * 2) / 8;
|
|
11
|
+
export function polygonRoundedRect(topLeft, bottomRight, radius) {
|
|
12
|
+
if (radius <= 0) {
|
|
13
|
+
return polygonRect(topLeft, bottomRight);
|
|
14
|
+
}
|
|
15
|
+
const result = [];
|
|
16
|
+
const maxR = Math.min(bottomRight.x - topLeft.x, bottomRight.y - topLeft.y) / 2;
|
|
17
|
+
const r = Math.min(radius, maxR);
|
|
18
|
+
// top left half
|
|
19
|
+
result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 3, OctoAngle * 2));
|
|
20
|
+
result.push({ x: topLeft.x + r, y: topLeft.y });
|
|
21
|
+
result.push({ x: bottomRight.x - r, y: topLeft.y });
|
|
22
|
+
// top right
|
|
23
|
+
result.push(...polygonArc({ x: bottomRight.x - r, y: topLeft.y + r }, r, OctoAngle * 2, OctoAngle * 0));
|
|
24
|
+
result.push({ x: bottomRight.x, y: topLeft.y + r });
|
|
25
|
+
// bottom right
|
|
26
|
+
result.push(...polygonArc({ x: bottomRight.x - r, y: bottomRight.y - r }, r, OctoAngle * 0, -OctoAngle * 2));
|
|
27
|
+
result.push({ x: bottomRight.x - r, y: bottomRight.y });
|
|
28
|
+
// bottom left
|
|
29
|
+
result.push(...polygonArc({ x: topLeft.x + r, y: bottomRight.y - r }, r, OctoAngle * 6, OctoAngle * 4));
|
|
30
|
+
result.push({ x: topLeft.x, y: bottomRight.y - r });
|
|
31
|
+
// top left half
|
|
32
|
+
result.push({ x: topLeft.x, y: topLeft.y + r });
|
|
33
|
+
result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 4, OctoAngle * 3));
|
|
34
|
+
result.push(result[0]);
|
|
35
|
+
return result;
|
|
36
|
+
}
|
|
37
|
+
export function polygonArc(center, radius, startAngle, endAngle) {
|
|
38
|
+
const result = [];
|
|
39
|
+
if (radius === 0) {
|
|
40
|
+
return result;
|
|
41
|
+
}
|
|
42
|
+
const reversed = startAngle > endAngle;
|
|
43
|
+
let angle = Math.min(startAngle, endAngle);
|
|
44
|
+
const end = Math.max(startAngle, endAngle);
|
|
45
|
+
for (; angle < end; angle += 0.1) {
|
|
46
|
+
const x = center.x + radius * Math.cos(angle);
|
|
47
|
+
const y = center.y - radius * Math.sin(angle);
|
|
48
|
+
result.push({ x, y });
|
|
49
|
+
}
|
|
50
|
+
return reversed ? result.reverse() : result;
|
|
51
|
+
}
|
|
52
|
+
export function polygonToCss(polygon) {
|
|
53
|
+
return `polygon(${polygon.map(p => `${p.x}px ${p.y}px`).join(",")})`;
|
|
54
|
+
}
|
|
55
|
+
export function maxPossibleRadius(x, y, w, h) {
|
|
56
|
+
const distX = Math.max(x, Math.abs(w - x));
|
|
57
|
+
const distY = Math.max(y, Math.abs(h - y));
|
|
58
|
+
return Math.sqrt(distX * distX + distY * distY);
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"polygon.js","sourceRoot":"","sources":["../../../../../packages/graphics/src/util/polygon.ts"],"names":[],"mappings":"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","sourcesContent":["import { Position } from \"@ngutil/style\"\n\nexport type Polygon = Position[]\n\nexport function polygonRect(topLeft: Position, bottomRight: Position): Polygon {\n    const result: Polygon = []\n\n    result.push(topLeft)\n    result.push({ x: bottomRight.x, y: topLeft.y })\n    result.push(bottomRight)\n    result.push({ x: topLeft.x, y: bottomRight.y })\n    result.push(topLeft)\n\n    return result\n}\n\nconst OctoAngle = (Math.PI * 2) / 8\n\nexport function polygonRoundedRect(topLeft: Position, bottomRight: Position, radius: number): Polygon {\n    if (radius <= 0) {\n        return polygonRect(topLeft, bottomRight)\n    }\n\n    const result: Polygon = []\n    const maxR = Math.min(bottomRight.x - topLeft.x, bottomRight.y - topLeft.y) / 2\n    const r = Math.min(radius, maxR)\n\n    // top left half\n    result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 3, OctoAngle * 2))\n    result.push({ x: topLeft.x + r, y: topLeft.y })\n    result.push({ x: bottomRight.x - r, y: topLeft.y })\n\n    // top right\n    result.push(...polygonArc({ x: bottomRight.x - r, y: topLeft.y + r }, r, OctoAngle * 2, OctoAngle * 0))\n    result.push({ x: bottomRight.x, y: topLeft.y + r })\n\n    // bottom right\n    result.push(...polygonArc({ x: bottomRight.x - r, y: bottomRight.y - r }, r, OctoAngle * 0, -OctoAngle * 2))\n    result.push({ x: bottomRight.x - r, y: bottomRight.y })\n\n    // bottom left\n    result.push(...polygonArc({ x: topLeft.x + r, y: bottomRight.y - r }, r, OctoAngle * 6, OctoAngle * 4))\n    result.push({ x: topLeft.x, y: bottomRight.y - r })\n\n    // top left half\n    result.push({ x: topLeft.x, y: topLeft.y + r })\n    result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 4, OctoAngle * 3))\n\n    result.push(result[0])\n\n    return result\n}\n\nexport function polygonArc(center: Position, radius: number, startAngle: number, endAngle: number): Polygon {\n    const result: Polygon = []\n\n    if (radius === 0) {\n        return result\n    }\n\n    const reversed = startAngle > endAngle\n    let angle = Math.min(startAngle, endAngle)\n    const end = Math.max(startAngle, endAngle)\n\n    for (; angle < end; angle += 0.1) {\n        const x = center.x + radius * Math.cos(angle)\n        const y = center.y - radius * Math.sin(angle)\n        result.push({ x, y })\n    }\n\n    return reversed ? result.reverse() : result\n}\n\nexport function polygonToCss(polygon: Polygon): string {\n    return `polygon(${polygon.map(p => `${p.x}px ${p.y}px`).join(\",\")})`\n}\n\nexport function 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,7 +1,86 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Directive, Injectable } from '@angular/core';
|
|
3
|
-
import { Destructible,
|
|
4
|
-
import { Observable, of } from 'rxjs';
|
|
2
|
+
import { Directive, ElementRef, inject, Injectable } from '@angular/core';
|
|
3
|
+
import { coerceElement, Destructible, isElementInput } from '@ngutil/common';
|
|
4
|
+
import { Observable, of, from, combineLatest, filter, switchMap, map } from 'rxjs';
|
|
5
|
+
import { rectExpand, rectContract, RectWatcher } from '@ngutil/style';
|
|
6
|
+
|
|
7
|
+
function animationObservable({ builder, animation, element, options }) {
|
|
8
|
+
return new Observable((dst) => {
|
|
9
|
+
const factory = builder.build(animation);
|
|
10
|
+
const player = factory.create(coerceElement(element), options);
|
|
11
|
+
const done = () => {
|
|
12
|
+
dst.next();
|
|
13
|
+
dst.complete();
|
|
14
|
+
};
|
|
15
|
+
player.onDestroy(done);
|
|
16
|
+
player.onDone(done);
|
|
17
|
+
player.play();
|
|
18
|
+
return () => {
|
|
19
|
+
player.pause();
|
|
20
|
+
player.destroy();
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
function polygonRect(topLeft, bottomRight) {
|
|
26
|
+
const result = [];
|
|
27
|
+
result.push(topLeft);
|
|
28
|
+
result.push({ x: bottomRight.x, y: topLeft.y });
|
|
29
|
+
result.push(bottomRight);
|
|
30
|
+
result.push({ x: topLeft.x, y: bottomRight.y });
|
|
31
|
+
result.push(topLeft);
|
|
32
|
+
return result;
|
|
33
|
+
}
|
|
34
|
+
const OctoAngle = (Math.PI * 2) / 8;
|
|
35
|
+
function polygonRoundedRect(topLeft, bottomRight, radius) {
|
|
36
|
+
if (radius <= 0) {
|
|
37
|
+
return polygonRect(topLeft, bottomRight);
|
|
38
|
+
}
|
|
39
|
+
const result = [];
|
|
40
|
+
const maxR = Math.min(bottomRight.x - topLeft.x, bottomRight.y - topLeft.y) / 2;
|
|
41
|
+
const r = Math.min(radius, maxR);
|
|
42
|
+
// top left half
|
|
43
|
+
result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 3, OctoAngle * 2));
|
|
44
|
+
result.push({ x: topLeft.x + r, y: topLeft.y });
|
|
45
|
+
result.push({ x: bottomRight.x - r, y: topLeft.y });
|
|
46
|
+
// top right
|
|
47
|
+
result.push(...polygonArc({ x: bottomRight.x - r, y: topLeft.y + r }, r, OctoAngle * 2, OctoAngle * 0));
|
|
48
|
+
result.push({ x: bottomRight.x, y: topLeft.y + r });
|
|
49
|
+
// bottom right
|
|
50
|
+
result.push(...polygonArc({ x: bottomRight.x - r, y: bottomRight.y - r }, r, OctoAngle * 0, -OctoAngle * 2));
|
|
51
|
+
result.push({ x: bottomRight.x - r, y: bottomRight.y });
|
|
52
|
+
// bottom left
|
|
53
|
+
result.push(...polygonArc({ x: topLeft.x + r, y: bottomRight.y - r }, r, OctoAngle * 6, OctoAngle * 4));
|
|
54
|
+
result.push({ x: topLeft.x, y: bottomRight.y - r });
|
|
55
|
+
// top left half
|
|
56
|
+
result.push({ x: topLeft.x, y: topLeft.y + r });
|
|
57
|
+
result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 4, OctoAngle * 3));
|
|
58
|
+
result.push(result[0]);
|
|
59
|
+
return result;
|
|
60
|
+
}
|
|
61
|
+
function polygonArc(center, radius, startAngle, endAngle) {
|
|
62
|
+
const result = [];
|
|
63
|
+
if (radius === 0) {
|
|
64
|
+
return result;
|
|
65
|
+
}
|
|
66
|
+
const reversed = startAngle > endAngle;
|
|
67
|
+
let angle = Math.min(startAngle, endAngle);
|
|
68
|
+
const end = Math.max(startAngle, endAngle);
|
|
69
|
+
for (; angle < end; angle += 0.1) {
|
|
70
|
+
const x = center.x + radius * Math.cos(angle);
|
|
71
|
+
const y = center.y - radius * Math.sin(angle);
|
|
72
|
+
result.push({ x, y });
|
|
73
|
+
}
|
|
74
|
+
return reversed ? result.reverse() : result;
|
|
75
|
+
}
|
|
76
|
+
function polygonToCss(polygon) {
|
|
77
|
+
return `polygon(${polygon.map(p => `${p.x}px ${p.y}px`).join(",")})`;
|
|
78
|
+
}
|
|
79
|
+
function maxPossibleRadius(x, y, w, h) {
|
|
80
|
+
const distX = Math.max(x, Math.abs(w - x));
|
|
81
|
+
const distY = Math.max(y, Math.abs(h - y));
|
|
82
|
+
return Math.sqrt(distX * distX + distY * distY);
|
|
83
|
+
}
|
|
5
84
|
|
|
6
85
|
class RippleDirective extends Destructible {
|
|
7
86
|
#current;
|
|
@@ -153,41 +232,126 @@ class Ripple {
|
|
|
153
232
|
this.el.style.opacity = "0";
|
|
154
233
|
}
|
|
155
234
|
}
|
|
156
|
-
function maxPossibleRadius(x, y, w, h) {
|
|
157
|
-
const distX = Math.max(x, Math.abs(w - x));
|
|
158
|
-
const distY = Math.max(y, Math.abs(h - y));
|
|
159
|
-
return Math.sqrt(distX * distX + distY * distY);
|
|
160
|
-
}
|
|
161
235
|
|
|
162
|
-
class
|
|
163
|
-
|
|
236
|
+
class CoverRef extends ElementRef {
|
|
237
|
+
constructor(container, options, watcher) {
|
|
238
|
+
super(document.createElement("div"));
|
|
239
|
+
this.container = container;
|
|
240
|
+
this.options = options;
|
|
241
|
+
this.watcher = watcher;
|
|
242
|
+
Object.assign(this.nativeElement.style, {
|
|
243
|
+
position: "absolute",
|
|
244
|
+
inset: "0px"
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
show() {
|
|
164
248
|
return new Observable(dest => {
|
|
165
|
-
const
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
return () => {
|
|
170
|
-
cover.parentElement?.removeChild(cover);
|
|
171
|
-
};
|
|
249
|
+
const element = this.nativeElement;
|
|
250
|
+
coerceElement(this.container).appendChild(element);
|
|
251
|
+
dest.add(() => element.parentElement?.removeChild(element));
|
|
252
|
+
return this._show(dest);
|
|
172
253
|
});
|
|
173
254
|
}
|
|
174
|
-
|
|
175
|
-
|
|
255
|
+
applyStyle(mask) {
|
|
256
|
+
const options = this.options;
|
|
257
|
+
const backgroundColor = options.color === "transparent" ? "rgba(255, 255, 255, 0.0001)" : options.color;
|
|
258
|
+
if (options.style) {
|
|
259
|
+
Object.assign(mask.style, { backgroundColor, ...options.style });
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
Object.assign(mask.style, { backgroundColor });
|
|
263
|
+
}
|
|
176
264
|
}
|
|
177
|
-
|
|
178
|
-
|
|
265
|
+
}
|
|
266
|
+
class SolidCoverRef extends CoverRef {
|
|
267
|
+
_show(dest) {
|
|
268
|
+
this.applyStyle(this.nativeElement);
|
|
179
269
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
270
|
+
}
|
|
271
|
+
class CropCoverRef extends CoverRef {
|
|
272
|
+
_show(dest) {
|
|
273
|
+
const options = this.options;
|
|
274
|
+
const crop = isElementInput(options.crop) ? of(options.crop) : from(options.crop);
|
|
275
|
+
let maskEl = this.nativeElement;
|
|
276
|
+
// TODO: a backdrop filter kicsit ksőbb jelenik meg így
|
|
277
|
+
if (this.options.disablePointerEvents) {
|
|
278
|
+
maskEl = document.createElement("div");
|
|
279
|
+
Object.assign(maskEl.style, {
|
|
280
|
+
position: "absolute",
|
|
281
|
+
inset: "0px"
|
|
282
|
+
});
|
|
283
|
+
this.applyStyle(maskEl);
|
|
284
|
+
// maskEl.style.backdropFilter = null as any
|
|
285
|
+
this.nativeElement.appendChild(maskEl);
|
|
286
|
+
this.nativeElement.style.background = "rgba(0, 0, 0, 0.1)";
|
|
287
|
+
// this.nativeElement.style.backdropFilter = this.options.style?.backdropFilter as any
|
|
186
288
|
}
|
|
187
289
|
else {
|
|
188
|
-
|
|
290
|
+
this.applyStyle(this.nativeElement);
|
|
291
|
+
}
|
|
292
|
+
return combineLatest({
|
|
293
|
+
container: this.watcher.watch(this.container, "border-box"),
|
|
294
|
+
crop: crop.pipe(filter(value => value != null), switchMap(crop => {
|
|
295
|
+
if (isElementInput(crop)) {
|
|
296
|
+
return this.watcher.watch(coerceElement(crop), "border-box");
|
|
297
|
+
}
|
|
298
|
+
else {
|
|
299
|
+
return of(crop);
|
|
300
|
+
}
|
|
301
|
+
}), map(crop => {
|
|
302
|
+
if (this.options.expand) {
|
|
303
|
+
crop = rectExpand(crop, this.options.expand);
|
|
304
|
+
}
|
|
305
|
+
if (this.options.contract) {
|
|
306
|
+
crop = rectContract(crop, this.options.contract);
|
|
307
|
+
}
|
|
308
|
+
return crop;
|
|
309
|
+
}))
|
|
310
|
+
}).subscribe(({ container, crop }) => {
|
|
311
|
+
const outer = polygonRect({ x: 0, y: 0 }, { x: container.width, y: container.height });
|
|
312
|
+
const croppedArea = this.#polygon(container, crop).reverse();
|
|
313
|
+
const polygon = [...outer, ...croppedArea];
|
|
314
|
+
maskEl.style.clipPath = polygonToCss(polygon);
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
#polygon(container, crop) {
|
|
318
|
+
const shape = this.options.shape;
|
|
319
|
+
if (typeof shape === "function") {
|
|
320
|
+
return shape(container, crop);
|
|
321
|
+
}
|
|
322
|
+
else if (shape.type === "circle") {
|
|
323
|
+
const r = maxPossibleRadius(crop.x, crop.y, crop.width, crop.height);
|
|
324
|
+
return polygonArc({ x: crop.x + r, y: crop.y + r }, r, 0, Math.PI * 2);
|
|
325
|
+
}
|
|
326
|
+
else if (shape.type === "rect") {
|
|
327
|
+
const top = Math.round(Math.max(crop.y - container.y, 0));
|
|
328
|
+
const right = Math.round(Math.max(crop.x + crop.width));
|
|
329
|
+
const bottom = Math.round(Math.max(crop.y + crop.height));
|
|
330
|
+
const left = Math.round(Math.max(crop.x - container.x));
|
|
331
|
+
if (shape.borderRadius != null) {
|
|
332
|
+
return polygonRoundedRect({ x: left, y: top }, { x: right, y: bottom }, shape.borderRadius);
|
|
333
|
+
}
|
|
334
|
+
else {
|
|
335
|
+
return polygonRect({ x: left, y: top }, { x: right, y: bottom });
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
return [];
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
class RevealCoverRef extends CoverRef {
|
|
342
|
+
_show(dest) { }
|
|
343
|
+
}
|
|
344
|
+
class CoverService {
|
|
345
|
+
#watcher = inject(RectWatcher);
|
|
346
|
+
create(container, options) {
|
|
347
|
+
switch (options.type) {
|
|
348
|
+
case "solid":
|
|
349
|
+
return new SolidCoverRef(container, options, this.#watcher);
|
|
350
|
+
case "crop":
|
|
351
|
+
return new CropCoverRef(container, options, this.#watcher);
|
|
352
|
+
case "reveal":
|
|
353
|
+
return new RevealCoverRef(container, options, this.#watcher);
|
|
189
354
|
}
|
|
190
|
-
return el;
|
|
191
355
|
}
|
|
192
356
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: CoverService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
193
357
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: CoverService, providedIn: "root" }); }
|
|
@@ -197,26 +361,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
|
|
|
197
361
|
args: [{ providedIn: "root" }]
|
|
198
362
|
}] });
|
|
199
363
|
|
|
200
|
-
function animationObservable({ builder, animation, element, options }) {
|
|
201
|
-
return new Observable((dst) => {
|
|
202
|
-
const factory = builder.build(animation);
|
|
203
|
-
const player = factory.create(coerceElement(element), options);
|
|
204
|
-
const done = () => {
|
|
205
|
-
dst.next();
|
|
206
|
-
dst.complete();
|
|
207
|
-
};
|
|
208
|
-
player.onDestroy(done);
|
|
209
|
-
player.onDone(done);
|
|
210
|
-
player.play();
|
|
211
|
-
return () => {
|
|
212
|
-
player.destroy();
|
|
213
|
-
};
|
|
214
|
-
});
|
|
215
|
-
}
|
|
216
|
-
|
|
217
364
|
/**
|
|
218
365
|
* Generated bundle index. Do not edit.
|
|
219
366
|
*/
|
|
220
367
|
|
|
221
|
-
export { CoverService, Ripple, RippleDirective, animationObservable };
|
|
368
|
+
export { CoverRef, CoverService, CropCoverRef, RevealCoverRef, Ripple, RippleDirective, SolidCoverRef, animationObservable, maxPossibleRadius, polygonArc, polygonRect, polygonRoundedRect, polygonToCss };
|
|
222
369
|
//# sourceMappingURL=ngutil-graphics.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ngutil-graphics.mjs","sources":["../../../../packages/graphics/src/ripple/ripple.directive.ts","../../../../packages/graphics/src/cover.service.ts","../../../../packages/graphics/src/util/animation-observable.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 el.addEventListener(\"transitioncancel\", 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 this.el.removeEventListener(\"transitioncancel\", 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","import { Injectable } from \"@angular/core\"\n\nimport { Observable, of } from \"rxjs\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\nimport { Rect } from \"@ngutil/style\"\n\nexport interface CoverOptions {\n container: ElementInput\n color: \"transparent\" | string\n}\n\nexport interface SolidCoverOptions extends CoverOptions {}\n\nexport interface CropCoverOptions extends CoverOptions {\n /**\n * Element that will be interactive while the cover is visible\n */\n crop: ElementInput | Observable<Rect>\n}\n\nexport interface RevealCoverOptions extends CoverOptions {\n /**\n * Left and right coordinates inside the container\n */\n origin: { left: number; top: number }\n}\n\n@Injectable({ providedIn: \"root\" })\nexport class CoverService {\n solid(options: SolidCoverOptions): Observable<HTMLDivElement> {\n return new Observable(dest => {\n const container = coerceElement(options.container)\n const cover = this.#createElement(options)\n container.appendChild(cover)\n dest.next(cover)\n\n return () => {\n cover.parentElement?.removeChild(cover)\n }\n })\n }\n\n crop(options: CropCoverOptions): Observable<HTMLDivElement> {\n return of()\n }\n\n reveal(options: RevealCoverOptions): Observable<HTMLDivElement> {\n return of()\n }\n\n #createElement(options: CoverOptions) {\n const el = document.createElement(\"div\")\n el.style.position = \"absolute\"\n el.style.top = el.style.right = el.style.bottom = el.style.left = \"0px\"\n\n if (options.color === \"transparent\") {\n el.style.backgroundColor = \"rgba(255, 255, 255, 0.0001)\"\n } else {\n el.style.backgroundColor = options.color\n }\n\n return el\n }\n}\n","import { AnimationBuilder, AnimationMetadata, AnimationOptions } from \"@angular/animations\"\n\nimport { Observable, Subscriber } from \"rxjs\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\n\nexport interface AnimationObservableParams {\n builder: AnimationBuilder\n animation: AnimationMetadata | AnimationMetadata[]\n element: ElementInput\n options?: AnimationOptions\n}\n\nexport function animationObservable({ builder, animation, element, options }: AnimationObservableParams) {\n return new Observable((dst: Subscriber<void>) => {\n const factory = builder.build(animation)\n const player = factory.create(coerceElement(element), options)\n\n const done = () => {\n dst.next()\n dst.complete()\n }\n\n player.onDestroy(done)\n player.onDone(done)\n player.play()\n\n return () => {\n player.destroy()\n }\n })\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ngutil-graphics.mjs","sources":["../../../../packages/graphics/src/util/animation-observable.ts","../../../../packages/graphics/src/util/polygon.ts","../../../../packages/graphics/src/ripple/ripple.directive.ts","../../../../packages/graphics/src/cover.service.ts","../../../../packages/graphics/src/ngutil-graphics.ts"],"sourcesContent":["import { AnimationBuilder, AnimationMetadata, AnimationOptions } from \"@angular/animations\"\n\nimport { Observable, Subscriber } from \"rxjs\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\n\nexport interface AnimationObservableParams {\n builder: AnimationBuilder\n animation: AnimationMetadata | AnimationMetadata[]\n element: ElementInput\n options?: AnimationOptions\n}\n\nexport function animationObservable({ builder, animation, element, options }: AnimationObservableParams) {\n return new Observable((dst: Subscriber<void>) => {\n const factory = builder.build(animation)\n const player = factory.create(coerceElement(element), options)\n\n const done = () => {\n dst.next()\n dst.complete()\n }\n\n player.onDestroy(done)\n player.onDone(done)\n player.play()\n\n return () => {\n player.pause()\n player.destroy()\n }\n })\n}\n","import { Position } from \"@ngutil/style\"\n\nexport type Polygon = Position[]\n\nexport function polygonRect(topLeft: Position, bottomRight: Position): Polygon {\n const result: Polygon = []\n\n result.push(topLeft)\n result.push({ x: bottomRight.x, y: topLeft.y })\n result.push(bottomRight)\n result.push({ x: topLeft.x, y: bottomRight.y })\n result.push(topLeft)\n\n return result\n}\n\nconst OctoAngle = (Math.PI * 2) / 8\n\nexport function polygonRoundedRect(topLeft: Position, bottomRight: Position, radius: number): Polygon {\n if (radius <= 0) {\n return polygonRect(topLeft, bottomRight)\n }\n\n const result: Polygon = []\n const maxR = Math.min(bottomRight.x - topLeft.x, bottomRight.y - topLeft.y) / 2\n const r = Math.min(radius, maxR)\n\n // top left half\n result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 3, OctoAngle * 2))\n result.push({ x: topLeft.x + r, y: topLeft.y })\n result.push({ x: bottomRight.x - r, y: topLeft.y })\n\n // top right\n result.push(...polygonArc({ x: bottomRight.x - r, y: topLeft.y + r }, r, OctoAngle * 2, OctoAngle * 0))\n result.push({ x: bottomRight.x, y: topLeft.y + r })\n\n // bottom right\n result.push(...polygonArc({ x: bottomRight.x - r, y: bottomRight.y - r }, r, OctoAngle * 0, -OctoAngle * 2))\n result.push({ x: bottomRight.x - r, y: bottomRight.y })\n\n // bottom left\n result.push(...polygonArc({ x: topLeft.x + r, y: bottomRight.y - r }, r, OctoAngle * 6, OctoAngle * 4))\n result.push({ x: topLeft.x, y: bottomRight.y - r })\n\n // top left half\n result.push({ x: topLeft.x, y: topLeft.y + r })\n result.push(...polygonArc({ x: topLeft.x + r, y: topLeft.y + r }, r, OctoAngle * 4, OctoAngle * 3))\n\n result.push(result[0])\n\n return result\n}\n\nexport function polygonArc(center: Position, radius: number, startAngle: number, endAngle: number): Polygon {\n const result: Polygon = []\n\n if (radius === 0) {\n return result\n }\n\n const reversed = startAngle > endAngle\n let angle = Math.min(startAngle, endAngle)\n const end = Math.max(startAngle, endAngle)\n\n for (; angle < end; angle += 0.1) {\n const x = center.x + radius * Math.cos(angle)\n const y = center.y - radius * Math.sin(angle)\n result.push({ x, y })\n }\n\n return reversed ? result.reverse() : result\n}\n\nexport function polygonToCss(polygon: Polygon): string {\n return `polygon(${polygon.map(p => `${p.x}px ${p.y}px`).join(\",\")})`\n}\n\nexport function 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","import { Directive, ElementRef, NgZone, TemplateRef } from \"@angular/core\"\n\nimport { Destructible, IDisposable } from \"@ngutil/common\"\n\nimport { maxPossibleRadius } from \"../util\"\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 el.addEventListener(\"transitioncancel\", 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 this.el.removeEventListener(\"transitioncancel\", 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","import { ElementRef, inject, Injectable } from \"@angular/core\"\n\nimport {\n combineLatest,\n filter,\n from,\n map,\n Observable,\n ObservableInput,\n of,\n Subscriber,\n switchMap,\n TeardownLogic\n} from \"rxjs\"\n\nimport { coerceElement, ElementInput, isElementInput } from \"@ngutil/common\"\nimport { Rect, rectContract, rectExpand, RectWatcher, SidesInput } from \"@ngutil/style\"\n\nimport { maxPossibleRadius, Polygon, polygonArc, polygonRect, polygonRoundedRect, polygonToCss } from \"./util\"\n\nexport interface CommonCoverOptions {\n color: \"transparent\" | string\n style?: Partial<CSSStyleDeclaration>\n}\n\nexport interface SolidCoverOptions extends CommonCoverOptions {\n type: \"solid\"\n}\n\nexport interface CropCoverOptions extends CommonCoverOptions {\n type: \"crop\"\n /**\n * Element that will be interactive while the cover is visible\n */\n crop: ElementInput | ObservableInput<Rect | ElementInput>\n shape: CropShapeOptions\n expand?: SidesInput\n contract?: SidesInput\n disablePointerEvents?: boolean\n}\n\nexport type CropShapeOptions = CropRectOptions | CropCircleOptions | CropShapeCustom\n\nexport interface CropRectOptions {\n type: \"rect\"\n borderRadius?: number\n}\n\nexport interface CropCircleOptions {\n type: \"circle\"\n}\n\nexport type CropShapeCustom = (container: Rect, crop: Rect) => Polygon\n\nexport interface RevealCoverOptions extends CommonCoverOptions {\n type: \"reveal\"\n /**\n * Left and right coordinates inside the container\n */\n origin: { left: number; top: number }\n}\n\nexport type CoverOptions = SolidCoverOptions | CropCoverOptions | RevealCoverOptions\n\nexport abstract class CoverRef<O extends CommonCoverOptions, R = void> extends ElementRef<HTMLElement> {\n protected readonly watcher: RectWatcher\n\n constructor(\n readonly container: ElementInput,\n readonly options: O,\n watcher: RectWatcher\n ) {\n super(document.createElement(\"div\"))\n this.watcher = watcher\n\n Object.assign(this.nativeElement.style, {\n position: \"absolute\",\n inset: \"0px\"\n })\n }\n\n show(): Observable<R> {\n return new Observable(dest => {\n const element = this.nativeElement\n coerceElement(this.container).appendChild(element)\n dest.add(() => element.parentElement?.removeChild(element))\n return this._show(dest)\n })\n }\n\n protected applyStyle(mask: HTMLElement) {\n const options = this.options\n const backgroundColor = options.color === \"transparent\" ? \"rgba(255, 255, 255, 0.0001)\" : options.color\n\n if (options.style) {\n Object.assign(mask.style, { backgroundColor, ...options.style })\n } else {\n Object.assign(mask.style, { backgroundColor })\n }\n }\n\n protected abstract _show(dest: Subscriber<unknown>): TeardownLogic\n}\n\nexport class SolidCoverRef extends CoverRef<SolidCoverOptions> {\n protected override _show(dest: Subscriber<unknown>): TeardownLogic {\n this.applyStyle(this.nativeElement)\n }\n}\n\nexport class CropCoverRef extends CoverRef<CropCoverOptions> {\n protected override _show(dest: Subscriber<unknown>): TeardownLogic {\n const options = this.options\n const crop = isElementInput(options.crop) ? of(options.crop) : from(options.crop)\n let maskEl = this.nativeElement\n\n // TODO: a backdrop filter kicsit ksőbb jelenik meg így\n if (this.options.disablePointerEvents) {\n maskEl = document.createElement(\"div\")\n Object.assign(maskEl.style, {\n position: \"absolute\",\n inset: \"0px\"\n })\n this.applyStyle(maskEl)\n // maskEl.style.backdropFilter = null as any\n this.nativeElement.appendChild(maskEl)\n this.nativeElement.style.background = \"rgba(0, 0, 0, 0.1)\"\n // this.nativeElement.style.backdropFilter = this.options.style?.backdropFilter as any\n } else {\n this.applyStyle(this.nativeElement)\n }\n\n return combineLatest({\n container: this.watcher.watch(this.container, \"border-box\"),\n crop: crop.pipe(\n filter(value => value != null),\n switchMap(crop => {\n if (isElementInput(crop)) {\n return this.watcher.watch(coerceElement(crop), \"border-box\")\n } else {\n return of(crop)\n }\n }),\n map(crop => {\n if (this.options.expand) {\n crop = rectExpand(crop, this.options.expand)\n }\n\n if (this.options.contract) {\n crop = rectContract(crop, this.options.contract)\n }\n\n return crop\n })\n )\n }).subscribe(({ container, crop }) => {\n const outer = polygonRect({ x: 0, y: 0 }, { x: container.width, y: container.height })\n const croppedArea = this.#polygon(container, crop).reverse()\n const polygon = [...outer, ...croppedArea]\n\n maskEl.style.clipPath = polygonToCss(polygon)\n })\n }\n\n #polygon(container: Rect, crop: Rect): Polygon {\n const shape = this.options.shape\n if (typeof shape === \"function\") {\n return shape(container, crop)\n } else if (shape.type === \"circle\") {\n const r = maxPossibleRadius(crop.x, crop.y, crop.width, crop.height)\n return polygonArc({ x: crop.x + r, y: crop.y + r }, r, 0, Math.PI * 2)\n } else if (shape.type === \"rect\") {\n const top = Math.round(Math.max(crop.y - container.y, 0))\n const right = Math.round(Math.max(crop.x + crop.width))\n const bottom = Math.round(Math.max(crop.y + crop.height))\n const left = Math.round(Math.max(crop.x - container.x))\n\n if (shape.borderRadius != null) {\n return polygonRoundedRect({ x: left, y: top }, { x: right, y: bottom }, shape.borderRadius)\n } else {\n return polygonRect({ x: left, y: top }, { x: right, y: bottom })\n }\n }\n return []\n }\n}\n\nexport class RevealCoverRef extends CoverRef<RevealCoverOptions> {\n protected override _show(dest: Subscriber<unknown>): TeardownLogic {}\n}\n\n@Injectable({ providedIn: \"root\" })\nexport class CoverService {\n readonly #watcher = inject(RectWatcher)\n\n create(container: ElementInput, options: CoverOptions) {\n switch (options.type) {\n case \"solid\":\n return new SolidCoverRef(container, options, this.#watcher)\n case \"crop\":\n return new CropCoverRef(container, options, this.#watcher)\n case \"reveal\":\n return new RevealCoverRef(container, options, this.#watcher)\n }\n }\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,3 +1,3 @@
|
|
|
1
1
|
export * from "./ripple/ripple.directive";
|
|
2
|
-
export
|
|
3
|
-
export * from "./util
|
|
2
|
+
export * from "./cover.service";
|
|
3
|
+
export * from "./util";
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ngutil/graphics",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.52",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/animations": "^17.3.6",
|
|
6
6
|
"@angular/common": "^17.3.6",
|
|
7
7
|
"@angular/core": "^17.3.6",
|
|
8
8
|
"rxjs": "^7.8.1",
|
|
9
|
-
"@ngutil/common": "0.0.
|
|
10
|
-
"@ngutil/style": "0.0.
|
|
9
|
+
"@ngutil/common": "0.0.52",
|
|
10
|
+
"@ngutil/style": "0.0.52"
|
|
11
11
|
},
|
|
12
12
|
"publishConfig": {
|
|
13
13
|
"access": "public",
|
package/util/index.d.ts
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Position } from "@ngutil/style";
|
|
2
|
+
export type Polygon = Position[];
|
|
3
|
+
export declare function polygonRect(topLeft: Position, bottomRight: Position): Polygon;
|
|
4
|
+
export declare function polygonRoundedRect(topLeft: Position, bottomRight: Position, radius: number): Polygon;
|
|
5
|
+
export declare function polygonArc(center: Position, radius: number, startAngle: number, endAngle: number): Polygon;
|
|
6
|
+
export declare function polygonToCss(polygon: Polygon): string;
|
|
7
|
+
export declare function maxPossibleRadius(x: number, y: number, w: number, h: number): number;
|