@ngutil/style 0.0.80 → 0.0.82
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/fesm2022/ngutil-style.mjs +16 -16
- package/fesm2022/ngutil-style.mjs.map +1 -1
- package/package.json +5 -6
- package/esm2022/index.mjs +0 -12
- package/esm2022/ngutil-style.mjs +0 -5
- package/esm2022/sass/animation/vars/index.mjs +0 -24
- package/esm2022/sass/index.mjs +0 -2
- package/esm2022/services/color-scheme.service.mjs +0 -19
- package/esm2022/services/dimension-watcher.service.mjs +0 -120
- package/esm2022/services/media-watcher.service.mjs +0 -39
- package/esm2022/services/position-watcher.service.mjs +0 -52
- package/esm2022/services/rect-watcher.service.mjs +0 -26
- package/esm2022/util/alignment.mjs +0 -55
- package/esm2022/util/floating-position.mjs +0 -276
- package/esm2022/util/in-animation.mjs +0 -70
- package/esm2022/util/rect.mjs +0 -90
- package/esm2022/util/sides.mjs +0 -26
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
import { DOCUMENT } from "@angular/common";
|
|
2
|
-
import { inject, Injectable, NgZone } from "@angular/core";
|
|
3
|
-
import { distinctUntilChanged, Observable, shareReplay } from "rxjs";
|
|
4
|
-
import { coerceElement } from "@ngutil/common";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class DimensionWatcher {
|
|
7
|
-
#zone = inject(NgZone);
|
|
8
|
-
#document = inject(DOCUMENT);
|
|
9
|
-
#watches = {};
|
|
10
|
-
watch(element, box) {
|
|
11
|
-
element = coerceElement(element);
|
|
12
|
-
let watches = this.#watches[box];
|
|
13
|
-
if (watches == null) {
|
|
14
|
-
watches = new Map();
|
|
15
|
-
this.#watches[box] = watches;
|
|
16
|
-
}
|
|
17
|
-
let watcher = watches.get(element);
|
|
18
|
-
if (watcher == null) {
|
|
19
|
-
if (element instanceof Window) {
|
|
20
|
-
watcher = this.#createWindowResizeWatcher();
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
if (box === "scroll-box") {
|
|
24
|
-
watcher = this.#createScollWatcher(watches, element);
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
watcher = this.#createResizeWatcher(watches, element, box);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
watches.set(element, watcher);
|
|
31
|
-
}
|
|
32
|
-
return watcher;
|
|
33
|
-
}
|
|
34
|
-
#createResizeWatcher(watches, el, box) {
|
|
35
|
-
if (box !== "border-box") {
|
|
36
|
-
throw new Error(`Currently not implemented box mode: ${box}`);
|
|
37
|
-
}
|
|
38
|
-
return this.#zone.runOutsideAngular(() => new Observable((sub) => {
|
|
39
|
-
const observer = new ResizeObserver(entries => {
|
|
40
|
-
if (!this.#document.contains(el)) {
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
for (const entry of entries) {
|
|
44
|
-
if (entry.borderBoxSize) {
|
|
45
|
-
sub.next({
|
|
46
|
-
width: entry.borderBoxSize[0].inlineSize,
|
|
47
|
-
height: entry.borderBoxSize[0].blockSize
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
sub.next({
|
|
52
|
-
width: el.offsetWidth,
|
|
53
|
-
height: el.offsetHeight
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
observer.observe(el, { box: box });
|
|
59
|
-
return () => {
|
|
60
|
-
observer.disconnect();
|
|
61
|
-
watches.delete(el);
|
|
62
|
-
};
|
|
63
|
-
}).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
|
|
64
|
-
}
|
|
65
|
-
#createScollWatcher(watches, el) {
|
|
66
|
-
const borderBox = this.watch(el, "border-box");
|
|
67
|
-
return this.#zone.runOutsideAngular(() => new Observable((sub) => {
|
|
68
|
-
let lastSw = NaN;
|
|
69
|
-
let lastSh = NaN;
|
|
70
|
-
const emit = () => {
|
|
71
|
-
const sw = el.scrollWidth;
|
|
72
|
-
const sh = el.scrollHeight;
|
|
73
|
-
if (lastSw !== sw || lastSh !== sh) {
|
|
74
|
-
lastSw = sw;
|
|
75
|
-
lastSh = sh;
|
|
76
|
-
sub.next({ width: lastSw, height: lastSh });
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
const dimSum = borderBox.subscribe(emit);
|
|
80
|
-
const mutation = new MutationObserver(emit);
|
|
81
|
-
mutation.observe(el, {
|
|
82
|
-
subtree: true,
|
|
83
|
-
childList: true,
|
|
84
|
-
attributes: true,
|
|
85
|
-
characterData: true
|
|
86
|
-
});
|
|
87
|
-
emit();
|
|
88
|
-
return () => {
|
|
89
|
-
dimSum.unsubscribe();
|
|
90
|
-
mutation.disconnect();
|
|
91
|
-
watches.delete(el);
|
|
92
|
-
};
|
|
93
|
-
}).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
|
|
94
|
-
}
|
|
95
|
-
#createWindowResizeWatcher() {
|
|
96
|
-
return this.#zone.runOutsideAngular(() => new Observable((sub) => {
|
|
97
|
-
const onResize = () => {
|
|
98
|
-
sub.next({
|
|
99
|
-
width: window.innerWidth,
|
|
100
|
-
height: window.innerHeight
|
|
101
|
-
});
|
|
102
|
-
};
|
|
103
|
-
onResize();
|
|
104
|
-
window.addEventListener("resize", onResize);
|
|
105
|
-
return () => {
|
|
106
|
-
window.removeEventListener("resize", onResize);
|
|
107
|
-
};
|
|
108
|
-
}).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
|
|
109
|
-
}
|
|
110
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DimensionWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
111
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DimensionWatcher, providedIn: "root" }); }
|
|
112
|
-
}
|
|
113
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DimensionWatcher, decorators: [{
|
|
114
|
-
type: Injectable,
|
|
115
|
-
args: [{ providedIn: "root" }]
|
|
116
|
-
}] });
|
|
117
|
-
function dimensionIsEq(a, b) {
|
|
118
|
-
return a && b && a.width === b.width && a.height === b.height;
|
|
119
|
-
}
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dimension-watcher.service.js","sourceRoot":"","sources":["../../../../../packages/style/src/services/dimension-watcher.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from \"@angular/common\"\nimport { inject, Injectable, NgZone } from \"@angular/core\"\n\nimport { distinctUntilChanged, Observable, shareReplay, Subscriber } from \"rxjs\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\n\nimport { Dimension } from \"../util/rect\"\n\nexport type WatchBox = ResizeObserverBoxOptions | \"scroll-box\"\nexport type Watches = Map<HTMLElement | Window, Observable<Dimension>>\n\n@Injectable({ providedIn: \"root\" })\nexport class DimensionWatcher {\n    readonly #zone = inject(NgZone)\n    readonly #document = inject(DOCUMENT)\n    readonly #watches: { [key in WatchBox]?: Watches } = {}\n\n    watch(element: ElementInput | Window, box: WatchBox): Observable<Dimension> {\n        element = coerceElement(element)\n\n        let watches = this.#watches[box]\n        if (watches == null) {\n            watches = new Map()\n            this.#watches[box] = watches\n        }\n\n        let watcher = watches.get(element)\n        if (watcher == null) {\n            if (element instanceof Window) {\n                watcher = this.#createWindowResizeWatcher()\n            } else {\n                if (box === \"scroll-box\") {\n                    watcher = this.#createScollWatcher(watches, element)\n                } else {\n                    watcher = this.#createResizeWatcher(watches, element, box)\n                }\n            }\n\n            watches.set(element, watcher)\n        }\n\n        return watcher\n    }\n\n    #createResizeWatcher(watches: Watches, el: HTMLElement, box: WatchBox): Observable<Dimension> {\n        if (box !== \"border-box\") {\n            throw new Error(`Currently not implemented box mode: ${box}`)\n        }\n\n        return this.#zone.runOutsideAngular(() =>\n            new Observable((sub: Subscriber<Dimension>) => {\n                const observer = new ResizeObserver(entries => {\n                    if (!this.#document.contains(el)) {\n                        return\n                    }\n\n                    for (const entry of entries) {\n                        if (entry.borderBoxSize) {\n                            sub.next({\n                                width: entry.borderBoxSize[0].inlineSize,\n                                height: entry.borderBoxSize[0].blockSize\n                            })\n                        } else {\n                            sub.next({\n                                width: el.offsetWidth,\n                                height: el.offsetHeight\n                            })\n                        }\n                    }\n                })\n                observer.observe(el, { box: box as ResizeObserverBoxOptions })\n\n                return () => {\n                    observer.disconnect()\n                    watches.delete(el)\n                }\n            }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1))\n        )\n    }\n\n    #createScollWatcher(watches: Watches, el: HTMLElement): Observable<Dimension> {\n        const borderBox = this.watch(el, \"border-box\")\n        return this.#zone.runOutsideAngular(() =>\n            new Observable((sub: Subscriber<Dimension>) => {\n                let lastSw: number = NaN\n                let lastSh: number = NaN\n\n                const emit = () => {\n                    const sw = el.scrollWidth\n                    const sh = el.scrollHeight\n                    if (lastSw !== sw || lastSh !== sh) {\n                        lastSw = sw\n                        lastSh = sh\n                        sub.next({ width: lastSw, height: lastSh })\n                    }\n                }\n\n                const dimSum = borderBox.subscribe(emit)\n                const mutation = new MutationObserver(emit)\n                mutation.observe(el, {\n                    subtree: true,\n                    childList: true,\n                    attributes: true,\n                    characterData: true\n                })\n                emit()\n\n                return () => {\n                    dimSum.unsubscribe()\n                    mutation.disconnect()\n                    watches.delete(el)\n                }\n            }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1))\n        )\n    }\n\n    #createWindowResizeWatcher(): Observable<Dimension> {\n        return this.#zone.runOutsideAngular(() =>\n            new Observable((sub: Subscriber<Dimension>) => {\n                const onResize = () => {\n                    sub.next({\n                        width: window.innerWidth,\n                        height: window.innerHeight\n                    })\n                }\n                onResize()\n                window.addEventListener(\"resize\", onResize)\n                return () => {\n                    window.removeEventListener(\"resize\", onResize)\n                }\n            }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1))\n        )\n    }\n}\n\nfunction dimensionIsEq(a: Dimension, b: Dimension) {\n    return a && b && a.width === b.width && a.height === b.height\n}\n"]}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { inject, Injectable, NgZone } from "@angular/core";
|
|
2
|
-
import { distinctUntilChanged, Observable, shareReplay } from "rxjs";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class MediaWatcher {
|
|
5
|
-
#zone = inject(NgZone);
|
|
6
|
-
#watches = {};
|
|
7
|
-
/**
|
|
8
|
-
* svc.watch("(display-mode: standalone)").subscribe(match => {})
|
|
9
|
-
*/
|
|
10
|
-
watch(query) {
|
|
11
|
-
let watcher = this.#watches[query];
|
|
12
|
-
if (!watcher) {
|
|
13
|
-
watcher = this.#newWatcher(query);
|
|
14
|
-
this.#watches[query] = watcher;
|
|
15
|
-
}
|
|
16
|
-
return watcher;
|
|
17
|
-
}
|
|
18
|
-
#newWatcher(query) {
|
|
19
|
-
return this.#zone.runOutsideAngular(() => new Observable((sub) => {
|
|
20
|
-
const queryWatcher = window.matchMedia(query);
|
|
21
|
-
const listener = (event) => {
|
|
22
|
-
sub.next(event.matches);
|
|
23
|
-
};
|
|
24
|
-
queryWatcher.addEventListener("change", listener);
|
|
25
|
-
sub.next(queryWatcher.matches);
|
|
26
|
-
return () => {
|
|
27
|
-
queryWatcher.removeEventListener("change", listener);
|
|
28
|
-
delete this.#watches[query];
|
|
29
|
-
};
|
|
30
|
-
}).pipe(distinctUntilChanged(), shareReplay(1)));
|
|
31
|
-
}
|
|
32
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: MediaWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
33
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: MediaWatcher, providedIn: "root" }); }
|
|
34
|
-
}
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: MediaWatcher, decorators: [{
|
|
36
|
-
type: Injectable,
|
|
37
|
-
args: [{ providedIn: "root" }]
|
|
38
|
-
}] });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVkaWEtd2F0Y2hlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3R5bGUvc3JjL3NlcnZpY2VzL21lZGlhLXdhdGNoZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQWMsTUFBTSxNQUFNLENBQUE7O0FBR2hGLE1BQU0sT0FBTyxZQUFZO0lBQ1osS0FBSyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQTtJQUMvQixRQUFRLEdBQTJDLEVBQUUsQ0FBQTtJQUVyRDs7T0FFRztJQUNILEtBQUssQ0FBQyxLQUFhO1FBQ2YsSUFBSSxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUNsQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDWCxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUNqQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLE9BQU8sQ0FBQTtRQUNsQyxDQUFDO1FBQ0QsT0FBTyxPQUFPLENBQUE7SUFDbEIsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFhO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUUsQ0FDckMsSUFBSSxVQUFVLENBQUMsQ0FBQyxHQUF3QixFQUFFLEVBQUU7WUFDeEMsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUM3QyxNQUFNLFFBQVEsR0FBRyxDQUFDLEtBQTBCLEVBQUUsRUFBRTtnQkFDNUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUE7WUFDM0IsQ0FBQyxDQUFBO1lBQ0QsWUFBWSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQTtZQUNqRCxHQUFHLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQTtZQUM5QixPQUFPLEdBQUcsRUFBRTtnQkFDUixZQUFZLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFBO2dCQUNwRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUE7WUFDL0IsQ0FBQyxDQUFBO1FBQ0wsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQ2xELENBQUE7SUFDTCxDQUFDOzhHQS9CUSxZQUFZO2tIQUFaLFlBQVksY0FEQyxNQUFNOzsyRkFDbkIsWUFBWTtrQkFEeEIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUsIE5nWm9uZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIE9ic2VydmFibGUsIHNoYXJlUmVwbGF5LCBTdWJzY3JpYmVyIH0gZnJvbSBcInJ4anNcIlxuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46IFwicm9vdFwiIH0pXG5leHBvcnQgY2xhc3MgTWVkaWFXYXRjaGVyIHtcbiAgICByZWFkb25seSAjem9uZSA9IGluamVjdChOZ1pvbmUpXG4gICAgI3dhdGNoZXM6IHsgW2tleTogc3RyaW5nXTogT2JzZXJ2YWJsZTxib29sZWFuPiB9ID0ge31cblxuICAgIC8qKlxuICAgICAqIHN2Yy53YXRjaChcIihkaXNwbGF5LW1vZGU6IHN0YW5kYWxvbmUpXCIpLnN1YnNjcmliZShtYXRjaCA9PiB7fSlcbiAgICAgKi9cbiAgICB3YXRjaChxdWVyeTogc3RyaW5nKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgICAgIGxldCB3YXRjaGVyID0gdGhpcy4jd2F0Y2hlc1txdWVyeV1cbiAgICAgICAgaWYgKCF3YXRjaGVyKSB7XG4gICAgICAgICAgICB3YXRjaGVyID0gdGhpcy4jbmV3V2F0Y2hlcihxdWVyeSlcbiAgICAgICAgICAgIHRoaXMuI3dhdGNoZXNbcXVlcnldID0gd2F0Y2hlclxuICAgICAgICB9XG4gICAgICAgIHJldHVybiB3YXRjaGVyXG4gICAgfVxuXG4gICAgI25ld1dhdGNoZXIocXVlcnk6IHN0cmluZyk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgICAgICByZXR1cm4gdGhpcy4jem9uZS5ydW5PdXRzaWRlQW5ndWxhcigoKSA9PlxuICAgICAgICAgICAgbmV3IE9ic2VydmFibGUoKHN1YjogU3Vic2NyaWJlcjxib29sZWFuPikgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnN0IHF1ZXJ5V2F0Y2hlciA9IHdpbmRvdy5tYXRjaE1lZGlhKHF1ZXJ5KVxuICAgICAgICAgICAgICAgIGNvbnN0IGxpc3RlbmVyID0gKGV2ZW50OiBNZWRpYVF1ZXJ5TGlzdEV2ZW50KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHN1Yi5uZXh0KGV2ZW50Lm1hdGNoZXMpXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHF1ZXJ5V2F0Y2hlci5hZGRFdmVudExpc3RlbmVyKFwiY2hhbmdlXCIsIGxpc3RlbmVyKVxuICAgICAgICAgICAgICAgIHN1Yi5uZXh0KHF1ZXJ5V2F0Y2hlci5tYXRjaGVzKVxuICAgICAgICAgICAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHF1ZXJ5V2F0Y2hlci5yZW1vdmVFdmVudExpc3RlbmVyKFwiY2hhbmdlXCIsIGxpc3RlbmVyKVxuICAgICAgICAgICAgICAgICAgICBkZWxldGUgdGhpcy4jd2F0Y2hlc1txdWVyeV1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KS5waXBlKGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksIHNoYXJlUmVwbGF5KDEpKVxuICAgICAgICApXG4gICAgfVxufVxuIl19
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { DOCUMENT } from "@angular/common";
|
|
2
|
-
import { inject, Injectable, NgZone } from "@angular/core";
|
|
3
|
-
import { distinctUntilChanged, Observable, of, shareReplay } from "rxjs";
|
|
4
|
-
import { isEqual } from "lodash-es";
|
|
5
|
-
import { coerceElement } from "@ngutil/common";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class PositionWatcher {
|
|
8
|
-
#zone = inject(NgZone);
|
|
9
|
-
#document = inject(DOCUMENT);
|
|
10
|
-
#watches = new Map();
|
|
11
|
-
watch(element) {
|
|
12
|
-
if (element instanceof Window) {
|
|
13
|
-
return of({ x: 0, y: 0 });
|
|
14
|
-
}
|
|
15
|
-
element = coerceElement(element);
|
|
16
|
-
let watcher = this.#watches.get(element);
|
|
17
|
-
if (watcher == null) {
|
|
18
|
-
watcher = this.#createWatcher(element);
|
|
19
|
-
this.#watches.set(element, watcher);
|
|
20
|
-
}
|
|
21
|
-
return watcher;
|
|
22
|
-
}
|
|
23
|
-
#createWatcher(element) {
|
|
24
|
-
return this.#zone.runOutsideAngular(() => new Observable((dest) => {
|
|
25
|
-
let rafId = undefined;
|
|
26
|
-
const emit = () => {
|
|
27
|
-
if (!this.#document.contains(element)) {
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
const rect = element.getBoundingClientRect();
|
|
31
|
-
dest.next({
|
|
32
|
-
x: rect.x,
|
|
33
|
-
y: rect.y
|
|
34
|
-
});
|
|
35
|
-
if (!dest.closed) {
|
|
36
|
-
rafId = requestAnimationFrame(emit);
|
|
37
|
-
}
|
|
38
|
-
};
|
|
39
|
-
emit();
|
|
40
|
-
return () => {
|
|
41
|
-
rafId && cancelAnimationFrame(rafId);
|
|
42
|
-
};
|
|
43
|
-
}).pipe(distinctUntilChanged(isEqual), shareReplay(1)));
|
|
44
|
-
}
|
|
45
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PositionWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
46
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PositionWatcher, providedIn: "root" }); }
|
|
47
|
-
}
|
|
48
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: PositionWatcher, decorators: [{
|
|
49
|
-
type: Injectable,
|
|
50
|
-
args: [{ providedIn: "root" }]
|
|
51
|
-
}] });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb24td2F0Y2hlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3R5bGUvc3JjL3NlcnZpY2VzL3Bvc2l0aW9uLXdhdGNoZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDMUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRTFELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxVQUFVLEVBQUUsRUFBRSxFQUFFLFdBQVcsRUFBYyxNQUFNLE1BQU0sQ0FBQTtBQUVwRixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sV0FBVyxDQUFBO0FBRW5DLE9BQU8sRUFBRSxhQUFhLEVBQWdCLE1BQU0sZ0JBQWdCLENBQUE7O0FBSzVELE1BQU0sT0FBTyxlQUFlO0lBQ2YsS0FBSyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQTtJQUN0QixTQUFTLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFBO0lBQzVCLFFBQVEsR0FBMkMsSUFBSSxHQUFHLEVBQUUsQ0FBQTtJQUVyRSxLQUFLLENBQUMsT0FBOEI7UUFDaEMsSUFBSSxPQUFPLFlBQVksTUFBTSxFQUFFLENBQUM7WUFDNUIsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBQzdCLENBQUM7UUFFRCxPQUFPLEdBQUcsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBRWhDLElBQUksT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQ3hDLElBQUksT0FBTyxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ2xCLE9BQU8sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFBO1lBQ3RDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQTtRQUN2QyxDQUFDO1FBRUQsT0FBTyxPQUFPLENBQUE7SUFDbEIsQ0FBQztJQUVELGNBQWMsQ0FBQyxPQUFvQjtRQUMvQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFLENBQ3JDLElBQUksVUFBVSxDQUFDLENBQUMsSUFBMEIsRUFBRSxFQUFFO1lBQzFDLElBQUksS0FBSyxHQUF1QixTQUFTLENBQUE7WUFDekMsTUFBTSxJQUFJLEdBQUcsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO29CQUNwQyxPQUFNO2dCQUNWLENBQUM7Z0JBRUQsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLHFCQUFxQixFQUFFLENBQUE7Z0JBQzVDLElBQUksQ0FBQyxJQUFJLENBQUM7b0JBQ04sQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO29CQUNULENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztpQkFDWixDQUFDLENBQUE7Z0JBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztvQkFDZixLQUFLLEdBQUcscUJBQXFCLENBQUMsSUFBSSxDQUFDLENBQUE7Z0JBQ3ZDLENBQUM7WUFDTCxDQUFDLENBQUE7WUFDRCxJQUFJLEVBQUUsQ0FBQTtZQUNOLE9BQU8sR0FBRyxFQUFFO2dCQUNSLEtBQUssSUFBSSxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUN4QyxDQUFDLENBQUE7UUFDTCxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQ3pELENBQUE7SUFDTCxDQUFDOzhHQTdDUSxlQUFlO2tIQUFmLGVBQWUsY0FERixNQUFNOzsyRkFDbkIsZUFBZTtrQkFEM0IsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIlxuaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlLCBOZ1pvbmUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB7IGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBPYnNlcnZhYmxlLCBvZiwgc2hhcmVSZXBsYXksIFN1YnNjcmliZXIgfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB7IGlzRXF1YWwgfSBmcm9tIFwibG9kYXNoLWVzXCJcblxuaW1wb3J0IHsgY29lcmNlRWxlbWVudCwgRWxlbWVudElucHV0IH0gZnJvbSBcIkBuZ3V0aWwvY29tbW9uXCJcblxuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tIFwiLi4vdXRpbC9yZWN0XCJcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiBcInJvb3RcIiB9KVxuZXhwb3J0IGNsYXNzIFBvc2l0aW9uV2F0Y2hlciB7XG4gICAgcmVhZG9ubHkgI3pvbmUgPSBpbmplY3QoTmdab25lKVxuICAgIHJlYWRvbmx5ICNkb2N1bWVudCA9IGluamVjdChET0NVTUVOVClcbiAgICByZWFkb25seSAjd2F0Y2hlczogTWFwPEhUTUxFbGVtZW50LCBPYnNlcnZhYmxlPFBvc2l0aW9uPj4gPSBuZXcgTWFwKClcblxuICAgIHdhdGNoKGVsZW1lbnQ6IEVsZW1lbnRJbnB1dCB8IFdpbmRvdyk6IE9ic2VydmFibGU8UG9zaXRpb24+IHtcbiAgICAgICAgaWYgKGVsZW1lbnQgaW5zdGFuY2VvZiBXaW5kb3cpIHtcbiAgICAgICAgICAgIHJldHVybiBvZih7IHg6IDAsIHk6IDAgfSlcbiAgICAgICAgfVxuXG4gICAgICAgIGVsZW1lbnQgPSBjb2VyY2VFbGVtZW50KGVsZW1lbnQpXG5cbiAgICAgICAgbGV0IHdhdGNoZXIgPSB0aGlzLiN3YXRjaGVzLmdldChlbGVtZW50KVxuICAgICAgICBpZiAod2F0Y2hlciA9PSBudWxsKSB7XG4gICAgICAgICAgICB3YXRjaGVyID0gdGhpcy4jY3JlYXRlV2F0Y2hlcihlbGVtZW50KVxuICAgICAgICAgICAgdGhpcy4jd2F0Y2hlcy5zZXQoZWxlbWVudCwgd2F0Y2hlcilcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB3YXRjaGVyXG4gICAgfVxuXG4gICAgI2NyZWF0ZVdhdGNoZXIoZWxlbWVudDogSFRNTEVsZW1lbnQpOiBPYnNlcnZhYmxlPFBvc2l0aW9uPiB7XG4gICAgICAgIHJldHVybiB0aGlzLiN6b25lLnJ1bk91dHNpZGVBbmd1bGFyKCgpID0+XG4gICAgICAgICAgICBuZXcgT2JzZXJ2YWJsZSgoZGVzdDogU3Vic2NyaWJlcjxQb3NpdGlvbj4pID0+IHtcbiAgICAgICAgICAgICAgICBsZXQgcmFmSWQ6IG51bWJlciB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZFxuICAgICAgICAgICAgICAgIGNvbnN0IGVtaXQgPSAoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmICghdGhpcy4jZG9jdW1lbnQuY29udGFpbnMoZWxlbWVudCkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVyblxuICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgY29uc3QgcmVjdCA9IGVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgICAgICAgICAgICAgICAgICAgZGVzdC5uZXh0KHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHg6IHJlY3QueCxcbiAgICAgICAgICAgICAgICAgICAgICAgIHk6IHJlY3QueVxuICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgICAgICBpZiAoIWRlc3QuY2xvc2VkKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByYWZJZCA9IHJlcXVlc3RBbmltYXRpb25GcmFtZShlbWl0KVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGVtaXQoKVxuICAgICAgICAgICAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJhZklkICYmIGNhbmNlbEFuaW1hdGlvbkZyYW1lKHJhZklkKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoaXNFcXVhbCksIHNoYXJlUmVwbGF5KDEpKVxuICAgICAgICApXG4gICAgfVxufVxuIl19
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { inject, Injectable } from "@angular/core";
|
|
2
|
-
import { combineLatest, map, Observable } from "rxjs";
|
|
3
|
-
import { DimensionWatcher } from "./dimension-watcher.service";
|
|
4
|
-
import { PositionWatcher } from "./position-watcher.service";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class RectWatcher {
|
|
7
|
-
#dimWatcher = inject(DimensionWatcher);
|
|
8
|
-
#posWatcher = inject(PositionWatcher);
|
|
9
|
-
watch(element, watchBox) {
|
|
10
|
-
return new Observable((dest) => combineLatest({
|
|
11
|
-
dim: this.#dimWatcher.watch(element, watchBox),
|
|
12
|
-
pos: this.#posWatcher.watch(element)
|
|
13
|
-
})
|
|
14
|
-
.pipe(map(({ dim, pos }) => {
|
|
15
|
-
return { ...dim, ...pos };
|
|
16
|
-
}))
|
|
17
|
-
.subscribe(dest));
|
|
18
|
-
}
|
|
19
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RectWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
20
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RectWatcher, providedIn: "root" }); }
|
|
21
|
-
}
|
|
22
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RectWatcher, decorators: [{
|
|
23
|
-
type: Injectable,
|
|
24
|
-
args: [{ providedIn: "root" }]
|
|
25
|
-
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdC13YXRjaGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdHlsZS9zcmMvc2VydmljZXMvcmVjdC13YXRjaGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFbEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxHQUFHLEVBQUUsVUFBVSxFQUFjLE1BQU0sTUFBTSxDQUFBO0FBS2pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBWSxNQUFNLDZCQUE2QixDQUFBO0FBQ3hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTs7QUFHNUQsTUFBTSxPQUFPLFdBQVc7SUFDWCxXQUFXLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUE7SUFDdEMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQTtJQUU5QyxLQUFLLENBQUMsT0FBOEIsRUFBRSxRQUFrQjtRQUNwRCxPQUFPLElBQUksVUFBVSxDQUFDLENBQUMsSUFBc0IsRUFBRSxFQUFFLENBQzdDLGFBQWEsQ0FBQztZQUNWLEdBQUcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDO1lBQzlDLEdBQUcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7U0FDdkMsQ0FBQzthQUNHLElBQUksQ0FDRCxHQUFHLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFO1lBQ2pCLE9BQU8sRUFBRSxHQUFHLEdBQUcsRUFBRSxHQUFHLEdBQUcsRUFBRSxDQUFBO1FBQzdCLENBQUMsQ0FBQyxDQUNMO2FBQ0EsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUN2QixDQUFBO0lBQ0wsQ0FBQzs4R0FqQlEsV0FBVztrSEFBWCxXQUFXLGNBREUsTUFBTTs7MkZBQ25CLFdBQVc7a0JBRHZCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5pbXBvcnQgeyBjb21iaW5lTGF0ZXN0LCBtYXAsIE9ic2VydmFibGUsIFN1YnNjcmliZXIgfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB7IEVsZW1lbnRJbnB1dCB9IGZyb20gXCJAbmd1dGlsL2NvbW1vblwiXG5cbmltcG9ydCB7IFJlY3QgfSBmcm9tIFwiLi4vdXRpbC9yZWN0XCJcbmltcG9ydCB7IERpbWVuc2lvbldhdGNoZXIsIFdhdGNoQm94IH0gZnJvbSBcIi4vZGltZW5zaW9uLXdhdGNoZXIuc2VydmljZVwiXG5pbXBvcnQgeyBQb3NpdGlvbldhdGNoZXIgfSBmcm9tIFwiLi9wb3NpdGlvbi13YXRjaGVyLnNlcnZpY2VcIlxuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46IFwicm9vdFwiIH0pXG5leHBvcnQgY2xhc3MgUmVjdFdhdGNoZXIge1xuICAgIHJlYWRvbmx5ICNkaW1XYXRjaGVyID0gaW5qZWN0KERpbWVuc2lvbldhdGNoZXIpXG4gICAgcmVhZG9ubHkgI3Bvc1dhdGNoZXIgPSBpbmplY3QoUG9zaXRpb25XYXRjaGVyKVxuXG4gICAgd2F0Y2goZWxlbWVudDogRWxlbWVudElucHV0IHwgV2luZG93LCB3YXRjaEJveDogV2F0Y2hCb3gpOiBPYnNlcnZhYmxlPFJlY3Q+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChkZXN0OiBTdWJzY3JpYmVyPFJlY3Q+KSA9PlxuICAgICAgICAgICAgY29tYmluZUxhdGVzdCh7XG4gICAgICAgICAgICAgICAgZGltOiB0aGlzLiNkaW1XYXRjaGVyLndhdGNoKGVsZW1lbnQsIHdhdGNoQm94KSxcbiAgICAgICAgICAgICAgICBwb3M6IHRoaXMuI3Bvc1dhdGNoZXIud2F0Y2goZWxlbWVudClcbiAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgLnBpcGUoXG4gICAgICAgICAgICAgICAgICAgIG1hcCgoeyBkaW0sIHBvcyB9KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4geyAuLi5kaW0sIC4uLnBvcyB9XG4gICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoZGVzdClcbiAgICAgICAgKVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { isPlainObject } from "@ngutil/common";
|
|
2
|
-
const HORIZONTAL = ["start", "left", "center", "end", "right"];
|
|
3
|
-
export const AlignHorizontalOpposite = {
|
|
4
|
-
start: "end",
|
|
5
|
-
left: "right",
|
|
6
|
-
center: "center",
|
|
7
|
-
end: "start",
|
|
8
|
-
right: "left"
|
|
9
|
-
};
|
|
10
|
-
const VERTICAL = ["top", "middle", "bottom"];
|
|
11
|
-
export const AlignVerticalOpposite = {
|
|
12
|
-
top: "bottom",
|
|
13
|
-
middle: "middle",
|
|
14
|
-
bottom: "top"
|
|
15
|
-
};
|
|
16
|
-
const DEFAULT = { horizontal: "center", vertical: "middle" };
|
|
17
|
-
export function alignmentNormalize(value) {
|
|
18
|
-
if (value == null) {
|
|
19
|
-
return DEFAULT;
|
|
20
|
-
}
|
|
21
|
-
if (isPlainObject(value)) {
|
|
22
|
-
if ("horizontal" in value && "vertical" in value) {
|
|
23
|
-
return value;
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
throw new Error(`Invalid alignment: ${value}`);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
if (typeof value !== "string") {
|
|
30
|
-
throw new Error(`Invalid alignment: ${value}`);
|
|
31
|
-
}
|
|
32
|
-
const entries = Array.from(new Set(value.split(/\s+/g)));
|
|
33
|
-
if (entries.length > 2) {
|
|
34
|
-
throw new Error(`Cannot parse: ${value}`);
|
|
35
|
-
}
|
|
36
|
-
const horizontal = HORIZONTAL.find(v => entries[0] === v || entries[1] === v) || "center";
|
|
37
|
-
const vertical = VERTICAL.find(v => entries[0] === v || entries[1] === v) || "middle";
|
|
38
|
-
return { horizontal, vertical };
|
|
39
|
-
}
|
|
40
|
-
const HorizontalOrigin = {
|
|
41
|
-
start: "left",
|
|
42
|
-
left: "left",
|
|
43
|
-
center: "center",
|
|
44
|
-
right: "right",
|
|
45
|
-
end: "right"
|
|
46
|
-
};
|
|
47
|
-
const VerticalOrigin = {
|
|
48
|
-
top: "top",
|
|
49
|
-
middle: "center",
|
|
50
|
-
bottom: "bottom"
|
|
51
|
-
};
|
|
52
|
-
export function alignmentToTransformOrigin(alignment) {
|
|
53
|
-
return `${HorizontalOrigin[alignment.horizontal] || "center"} ${VerticalOrigin[alignment.vertical] || "center"}`;
|
|
54
|
-
}
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxpZ25tZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3R5bGUvc3JjL3V0aWwvYWxpZ25tZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUU5QyxNQUFNLFVBQVUsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxPQUFPLENBQVUsQ0FBQTtBQUd2RSxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBNkM7SUFDN0UsS0FBSyxFQUFFLEtBQUs7SUFDWixJQUFJLEVBQUUsT0FBTztJQUNiLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLEdBQUcsRUFBRSxPQUFPO0lBQ1osS0FBSyxFQUFFLE1BQU07Q0FDaEIsQ0FBQTtBQUVELE1BQU0sUUFBUSxHQUFHLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRSxRQUFRLENBQVUsQ0FBQTtBQUdyRCxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBeUM7SUFDdkUsR0FBRyxFQUFFLFFBQVE7SUFDYixNQUFNLEVBQUUsUUFBUTtJQUNoQixNQUFNLEVBQUUsS0FBSztDQUNoQixDQUFBO0FBY0QsTUFBTSxPQUFPLEdBQWMsRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQTtBQUV2RSxNQUFNLFVBQVUsa0JBQWtCLENBQUMsS0FBc0I7SUFDckQsSUFBSSxLQUFLLElBQUksSUFBSSxFQUFFLENBQUM7UUFDaEIsT0FBTyxPQUFPLENBQUE7SUFDbEIsQ0FBQztJQUVELElBQUksYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDdkIsSUFBSSxZQUFZLElBQUksS0FBSyxJQUFJLFVBQVUsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUMvQyxPQUFPLEtBQUssQ0FBQTtRQUNoQixDQUFDO2FBQU0sQ0FBQztZQUNKLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLEtBQUssRUFBRSxDQUFDLENBQUE7UUFDbEQsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDbEQsQ0FBQztJQUVELE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFxQixDQUFBO0lBQzVFLElBQUksT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixLQUFLLEVBQUUsQ0FBQyxDQUFBO0lBQzdDLENBQUM7SUFFRCxNQUFNLFVBQVUsR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksUUFBUSxDQUFBO0lBQ3pGLE1BQU0sUUFBUSxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxRQUFRLENBQUE7SUFFckYsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsQ0FBQTtBQUNuQyxDQUFDO0FBRUQsTUFBTSxnQkFBZ0IsR0FBeUQ7SUFDM0UsS0FBSyxFQUFFLE1BQU07SUFDYixJQUFJLEVBQUUsTUFBTTtJQUNaLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLEtBQUssRUFBRSxPQUFPO0lBQ2QsR0FBRyxFQUFFLE9BQU87Q0FDZixDQUFBO0FBRUQsTUFBTSxjQUFjLEdBQXVEO0lBQ3ZFLEdBQUcsRUFBRSxLQUFLO0lBQ1YsTUFBTSxFQUFFLFFBQVE7SUFDaEIsTUFBTSxFQUFFLFFBQVE7Q0FDbkIsQ0FBQTtBQUVELE1BQU0sVUFBVSwwQkFBMEIsQ0FBQyxTQUFvQjtJQUMzRCxPQUFPLEdBQUcsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxJQUFJLFFBQVEsSUFBSSxjQUFjLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLFFBQVEsRUFBRSxDQUFBO0FBQ3BILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1BsYWluT2JqZWN0IH0gZnJvbSBcIkBuZ3V0aWwvY29tbW9uXCJcblxuY29uc3QgSE9SSVpPTlRBTCA9IFtcInN0YXJ0XCIsIFwibGVmdFwiLCBcImNlbnRlclwiLCBcImVuZFwiLCBcInJpZ2h0XCJdIGFzIGNvbnN0XG5leHBvcnQgdHlwZSBBbGlnbkhvcml6b250YWwgPSAodHlwZW9mIEhPUklaT05UQUwpW251bWJlcl1cblxuZXhwb3J0IGNvbnN0IEFsaWduSG9yaXpvbnRhbE9wcG9zaXRlOiBSZWNvcmQ8QWxpZ25Ib3Jpem9udGFsLCBBbGlnbkhvcml6b250YWw+ID0ge1xuICAgIHN0YXJ0OiBcImVuZFwiLFxuICAgIGxlZnQ6IFwicmlnaHRcIixcbiAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgZW5kOiBcInN0YXJ0XCIsXG4gICAgcmlnaHQ6IFwibGVmdFwiXG59XG5cbmNvbnN0IFZFUlRJQ0FMID0gW1widG9wXCIsIFwibWlkZGxlXCIsIFwiYm90dG9tXCJdIGFzIGNvbnN0XG5leHBvcnQgdHlwZSBBbGlnblZlcnRpY2FsID0gKHR5cGVvZiBWRVJUSUNBTClbbnVtYmVyXVxuXG5leHBvcnQgY29uc3QgQWxpZ25WZXJ0aWNhbE9wcG9zaXRlOiBSZWNvcmQ8QWxpZ25WZXJ0aWNhbCwgQWxpZ25WZXJ0aWNhbD4gPSB7XG4gICAgdG9wOiBcImJvdHRvbVwiLFxuICAgIG1pZGRsZTogXCJtaWRkbGVcIixcbiAgICBib3R0b206IFwidG9wXCJcbn1cblxuZXhwb3J0IHR5cGUgQWxpZ25tZW50SW5wdXQgPVxuICAgIHwgYCR7QWxpZ25Ib3Jpem9udGFsfSAke0FsaWduVmVydGljYWx9YFxuICAgIHwgYCR7QWxpZ25WZXJ0aWNhbH0gJHtBbGlnbkhvcml6b250YWx9YFxuICAgIHwgQWxpZ25WZXJ0aWNhbFxuICAgIHwgQWxpZ25Ib3Jpem9udGFsXG4gICAgfCBBbGlnbm1lbnRcblxuZXhwb3J0IGludGVyZmFjZSBBbGlnbm1lbnQge1xuICAgIGhvcml6b250YWw6IEFsaWduSG9yaXpvbnRhbFxuICAgIHZlcnRpY2FsOiBBbGlnblZlcnRpY2FsXG59XG5cbmNvbnN0IERFRkFVTFQ6IEFsaWdubWVudCA9IHsgaG9yaXpvbnRhbDogXCJjZW50ZXJcIiwgdmVydGljYWw6IFwibWlkZGxlXCIgfVxuXG5leHBvcnQgZnVuY3Rpb24gYWxpZ25tZW50Tm9ybWFsaXplKHZhbHVlPzogQWxpZ25tZW50SW5wdXQpOiBBbGlnbm1lbnQge1xuICAgIGlmICh2YWx1ZSA9PSBudWxsKSB7XG4gICAgICAgIHJldHVybiBERUZBVUxUXG4gICAgfVxuXG4gICAgaWYgKGlzUGxhaW5PYmplY3QodmFsdWUpKSB7XG4gICAgICAgIGlmIChcImhvcml6b250YWxcIiBpbiB2YWx1ZSAmJiBcInZlcnRpY2FsXCIgaW4gdmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGFsaWdubWVudDogJHt2YWx1ZX1gKVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gXCJzdHJpbmdcIikge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgYWxpZ25tZW50OiAke3ZhbHVlfWApXG4gICAgfVxuXG4gICAgY29uc3QgZW50cmllcyA9IEFycmF5LmZyb20obmV3IFNldCh2YWx1ZS5zcGxpdCgvXFxzKy9nKSkpIGFzIFtzdHJpbmcsIHN0cmluZ11cbiAgICBpZiAoZW50cmllcy5sZW5ndGggPiAyKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IHBhcnNlOiAke3ZhbHVlfWApXG4gICAgfVxuXG4gICAgY29uc3QgaG9yaXpvbnRhbCA9IEhPUklaT05UQUwuZmluZCh2ID0+IGVudHJpZXNbMF0gPT09IHYgfHwgZW50cmllc1sxXSA9PT0gdikgfHwgXCJjZW50ZXJcIlxuICAgIGNvbnN0IHZlcnRpY2FsID0gVkVSVElDQUwuZmluZCh2ID0+IGVudHJpZXNbMF0gPT09IHYgfHwgZW50cmllc1sxXSA9PT0gdikgfHwgXCJtaWRkbGVcIlxuXG4gICAgcmV0dXJuIHsgaG9yaXpvbnRhbCwgdmVydGljYWwgfVxufVxuXG5jb25zdCBIb3Jpem9udGFsT3JpZ2luOiBSZWNvcmQ8QWxpZ25Ib3Jpem9udGFsLCBcImxlZnRcIiB8IFwiY2VudGVyXCIgfCBcInJpZ2h0XCI+ID0ge1xuICAgIHN0YXJ0OiBcImxlZnRcIixcbiAgICBsZWZ0OiBcImxlZnRcIixcbiAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgcmlnaHQ6IFwicmlnaHRcIixcbiAgICBlbmQ6IFwicmlnaHRcIlxufVxuXG5jb25zdCBWZXJ0aWNhbE9yaWdpbjogUmVjb3JkPEFsaWduVmVydGljYWwsIFwidG9wXCIgfCBcImNlbnRlclwiIHwgXCJib3R0b21cIj4gPSB7XG4gICAgdG9wOiBcInRvcFwiLFxuICAgIG1pZGRsZTogXCJjZW50ZXJcIixcbiAgICBib3R0b206IFwiYm90dG9tXCJcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFsaWdubWVudFRvVHJhbnNmb3JtT3JpZ2luKGFsaWdubWVudDogQWxpZ25tZW50KTogc3RyaW5nIHtcbiAgICByZXR1cm4gYCR7SG9yaXpvbnRhbE9yaWdpblthbGlnbm1lbnQuaG9yaXpvbnRhbF0gfHwgXCJjZW50ZXJcIn0gJHtWZXJ0aWNhbE9yaWdpblthbGlnbm1lbnQudmVydGljYWxdIHx8IFwiY2VudGVyXCJ9YFxufVxuIl19
|