@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.
@@ -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