@ngutil/style 0.0.24 → 0.0.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/esm2022/index.mjs CHANGED
@@ -2,4 +2,9 @@ export { MediaWatcher } from "./services/media-watcher.service";
2
2
  export { ColorSchemeService } from "./services/color-scheme.service";
3
3
  export { Ease, Duration } from "./sass";
4
4
  export { DimensionWatcher } from "./services/dimension-watcher.service";
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zdHlsZS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQy9ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQ3BFLE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLE1BQU0sUUFBUSxDQUFBO0FBRXZDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBWSxNQUFNLHNDQUFzQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgTWVkaWFXYXRjaGVyIH0gZnJvbSBcIi4vc2VydmljZXMvbWVkaWEtd2F0Y2hlci5zZXJ2aWNlXCJcbmV4cG9ydCB7IENvbG9yU2NoZW1lU2VydmljZSB9IGZyb20gXCIuL3NlcnZpY2VzL2NvbG9yLXNjaGVtZS5zZXJ2aWNlXCJcbmV4cG9ydCB7IEVhc2UsIER1cmF0aW9uIH0gZnJvbSBcIi4vc2Fzc1wiXG5leHBvcnQgeyBEaW1lbnNpb24sIFJlY3QgfSBmcm9tIFwiLi91dGlsL3JlY3RcIlxuZXhwb3J0IHsgRGltZW5zaW9uV2F0Y2hlciwgV2F0Y2hCb3ggfSBmcm9tIFwiLi9zZXJ2aWNlcy9kaW1lbnNpb24td2F0Y2hlci5zZXJ2aWNlXCJcbiJdfQ==
5
+ export { PositionWatcher } from "./services/position-watcher.service";
6
+ export { RectWatcher } from "./services/rect-watcher.service";
7
+ export { alignmentNormalize } from "./util/alignment";
8
+ export { inAnimation, inTransition, isAnimating } from "./util/in-animation";
9
+ export { sidesNormalize } from "./util/sides";
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zdHlsZS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQy9ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQ3BFLE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLE1BQU0sUUFBUSxDQUFBO0FBQ3ZDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBWSxNQUFNLHNDQUFzQyxDQUFBO0FBQ2pGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQTtBQUNyRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUNBQWlDLENBQUE7QUFFN0QsT0FBTyxFQUFrQixrQkFBa0IsRUFBNkMsTUFBTSxrQkFBa0IsQ0FBQTtBQUNoSCxPQUFPLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUU1RSxPQUFPLEVBQWMsY0FBYyxFQUFTLE1BQU0sY0FBYyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgTWVkaWFXYXRjaGVyIH0gZnJvbSBcIi4vc2VydmljZXMvbWVkaWEtd2F0Y2hlci5zZXJ2aWNlXCJcbmV4cG9ydCB7IENvbG9yU2NoZW1lU2VydmljZSB9IGZyb20gXCIuL3NlcnZpY2VzL2NvbG9yLXNjaGVtZS5zZXJ2aWNlXCJcbmV4cG9ydCB7IEVhc2UsIER1cmF0aW9uIH0gZnJvbSBcIi4vc2Fzc1wiXG5leHBvcnQgeyBEaW1lbnNpb25XYXRjaGVyLCBXYXRjaEJveCB9IGZyb20gXCIuL3NlcnZpY2VzL2RpbWVuc2lvbi13YXRjaGVyLnNlcnZpY2VcIlxuZXhwb3J0IHsgUG9zaXRpb25XYXRjaGVyIH0gZnJvbSBcIi4vc2VydmljZXMvcG9zaXRpb24td2F0Y2hlci5zZXJ2aWNlXCJcbmV4cG9ydCB7IFJlY3RXYXRjaGVyIH0gZnJvbSBcIi4vc2VydmljZXMvcmVjdC13YXRjaGVyLnNlcnZpY2VcIlxuXG5leHBvcnQgeyBBbGlnbm1lbnRJbnB1dCwgYWxpZ25tZW50Tm9ybWFsaXplLCBBbGlnbm1lbnQsIEFsaWduSG9yaXpvbnRhbCwgQWxpZ25WZXJ0aWNhbCB9IGZyb20gXCIuL3V0aWwvYWxpZ25tZW50XCJcbmV4cG9ydCB7IGluQW5pbWF0aW9uLCBpblRyYW5zaXRpb24sIGlzQW5pbWF0aW5nIH0gZnJvbSBcIi4vdXRpbC9pbi1hbmltYXRpb25cIlxuZXhwb3J0IHsgRGltZW5zaW9uLCBSZWN0LCBQb3NpdGlvbiB9IGZyb20gXCIuL3V0aWwvcmVjdFwiXG5leHBvcnQgeyBTaWRlc0lucHV0LCBzaWRlc05vcm1hbGl6ZSwgU2lkZXMgfSBmcm9tIFwiLi91dGlsL3NpZGVzXCJcbiJdfQ==
@@ -1,25 +1,31 @@
1
- import { ElementRef, inject, Injectable, NgZone } from "@angular/core";
1
+ import { inject, Injectable, NgZone } from "@angular/core";
2
2
  import { distinctUntilChanged, Observable, shareReplay } from "rxjs";
3
+ import { coerceElement } from "@ngutil/common";
3
4
  import * as i0 from "@angular/core";
4
5
  export class DimensionWatcher {
5
6
  #zone = inject(NgZone);
6
7
  #watches = {};
7
8
  watch(element, box) {
9
+ element = coerceElement(element);
8
10
  let watches = this.#watches[box];
9
11
  if (watches == null) {
10
12
  watches = new Map();
11
13
  this.#watches[box] = watches;
12
14
  }
13
- const el = element instanceof ElementRef ? element.nativeElement : element;
14
- let watcher = watches.get(el);
15
+ let watcher = watches.get(element);
15
16
  if (watcher == null) {
16
- if (box === "scroll-box") {
17
- watcher = this.#createScollWatcher(watches, el);
17
+ if (element instanceof Window) {
18
+ watcher = this.#createWindowResizeWatcher();
18
19
  }
19
20
  else {
20
- watcher = this.#createResizeWatcher(watches, el, box);
21
+ if (box === "scroll-box") {
22
+ watcher = this.#createScollWatcher(watches, element);
23
+ }
24
+ else {
25
+ watcher = this.#createResizeWatcher(watches, element, box);
26
+ }
21
27
  }
22
- watches.set(el, watcher);
28
+ watches.set(element, watcher);
23
29
  }
24
30
  return watcher;
25
31
  }
@@ -81,6 +87,21 @@ export class DimensionWatcher {
81
87
  };
82
88
  }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
83
89
  }
90
+ #createWindowResizeWatcher() {
91
+ return this.#zone.runOutsideAngular(() => new Observable((sub) => {
92
+ const onResize = () => {
93
+ sub.next({
94
+ width: window.innerWidth,
95
+ height: window.innerHeight
96
+ });
97
+ };
98
+ onResize();
99
+ window.addEventListener("resize", onResize);
100
+ return () => {
101
+ window.removeEventListener("resize", onResize);
102
+ };
103
+ }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
104
+ }
84
105
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DimensionWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
85
106
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DimensionWatcher, providedIn: "root" }); }
86
107
  }
@@ -91,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
91
112
  function dimensionIsEq(a, b) {
92
113
  return a && b && a.width === b.width && a.height === b.height;
93
114
  }
94
- //# 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 { ElementRef, inject, Injectable, NgZone } from \"@angular/core\"\n\nimport { distinctUntilChanged, Observable, shareReplay, Subscriber } from \"rxjs\"\n\nimport { Dimension } from \"../util/rect\"\n\nexport type WatchBox = ResizeObserverBoxOptions | \"scroll-box\"\nexport type Watches = Map<HTMLElement, Observable<Dimension>>\n\n@Injectable({ providedIn: \"root\" })\nexport class DimensionWatcher {\n    readonly #zone = inject(NgZone)\n    readonly #watches: { [key in WatchBox]?: Watches } = {}\n\n    watch(element: HTMLElement | ElementRef<HTMLElement>, box: WatchBox): Observable<Dimension> {\n        let watches = this.#watches[box]\n        if (watches == null) {\n            watches = new Map()\n            this.#watches[box] = watches\n        }\n\n        const el = element instanceof ElementRef ? element.nativeElement : element\n\n        let watcher = watches.get(el)\n        if (watcher == null) {\n            if (box === \"scroll-box\") {\n                watcher = this.#createScollWatcher(watches, el)\n            } else {\n                watcher = this.#createResizeWatcher(watches, el, box)\n            }\n            watches.set(el, 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                    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\nfunction dimensionIsEq(a: Dimension, b: Dimension) {\n    return a && b && a.width === b.width && a.height === b.height\n}\n"]}
115
+ //# 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 { 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 #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                    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"]}
@@ -0,0 +1,47 @@
1
+ import { inject, Injectable, NgZone } from "@angular/core";
2
+ import { distinctUntilChanged, Observable, of, shareReplay } from "rxjs";
3
+ import { isEqual } from "lodash";
4
+ import { coerceElement } from "@ngutil/common";
5
+ import * as i0 from "@angular/core";
6
+ export class PositionWatcher {
7
+ #zone = inject(NgZone);
8
+ #watches = new Map();
9
+ watch(element) {
10
+ if (element instanceof Window) {
11
+ return of({ x: 0, y: 0 });
12
+ }
13
+ element = coerceElement(element);
14
+ let watcher = this.#watches.get(element);
15
+ if (watcher == null) {
16
+ watcher = this.#createWatcher(element);
17
+ this.#watches.set(element, watcher);
18
+ }
19
+ return watcher;
20
+ }
21
+ #createWatcher(element) {
22
+ return this.#zone.runOutsideAngular(() => new Observable((dest) => {
23
+ let rafId = undefined;
24
+ const emit = () => {
25
+ const rect = element.getBoundingClientRect();
26
+ dest.next({
27
+ x: rect.x,
28
+ y: rect.y
29
+ });
30
+ if (!dest.closed) {
31
+ rafId = requestAnimationFrame(emit);
32
+ }
33
+ };
34
+ emit();
35
+ return () => {
36
+ rafId && cancelAnimationFrame(rafId);
37
+ };
38
+ }).pipe(distinctUntilChanged(isEqual), shareReplay(1)));
39
+ }
40
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: PositionWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
41
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: PositionWatcher, providedIn: "root" }); }
42
+ }
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: PositionWatcher, decorators: [{
44
+ type: Injectable,
45
+ args: [{ providedIn: "root" }]
46
+ }] });
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb24td2F0Y2hlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3R5bGUvc3JjL3NlcnZpY2VzL3Bvc2l0aW9uLXdhdGNoZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLFVBQVUsRUFBRSxFQUFFLEVBQUUsV0FBVyxFQUFjLE1BQU0sTUFBTSxDQUFBO0FBRXBGLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxRQUFRLENBQUE7QUFFaEMsT0FBTyxFQUFFLGFBQWEsRUFBZ0IsTUFBTSxnQkFBZ0IsQ0FBQTs7QUFLNUQsTUFBTSxPQUFPLGVBQWU7SUFDZixLQUFLLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ3RCLFFBQVEsR0FBMkMsSUFBSSxHQUFHLEVBQUUsQ0FBQTtJQUVyRSxLQUFLLENBQUMsT0FBOEI7UUFDaEMsSUFBSSxPQUFPLFlBQVksTUFBTSxFQUFFLENBQUM7WUFDNUIsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBQzdCLENBQUM7UUFFRCxPQUFPLEdBQUcsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBRWhDLElBQUksT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQ3hDLElBQUksT0FBTyxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ2xCLE9BQU8sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFBO1lBQ3RDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQTtRQUN2QyxDQUFDO1FBRUQsT0FBTyxPQUFPLENBQUE7SUFDbEIsQ0FBQztJQUVELGNBQWMsQ0FBQyxPQUFvQjtRQUMvQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFLENBQ3JDLElBQUksVUFBVSxDQUFDLENBQUMsSUFBMEIsRUFBRSxFQUFFO1lBQzFDLElBQUksS0FBSyxHQUF1QixTQUFTLENBQUE7WUFDekMsTUFBTSxJQUFJLEdBQUcsR0FBRyxFQUFFO2dCQUNkLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxDQUFBO2dCQUM1QyxJQUFJLENBQUMsSUFBSSxDQUFDO29CQUNOLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztvQkFDVCxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7aUJBQ1osQ0FBQyxDQUFBO2dCQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7b0JBQ2YsS0FBSyxHQUFHLHFCQUFxQixDQUFDLElBQUksQ0FBQyxDQUFBO2dCQUN2QyxDQUFDO1lBQ0wsQ0FBQyxDQUFBO1lBQ0QsSUFBSSxFQUFFLENBQUE7WUFDTixPQUFPLEdBQUcsRUFBRTtnQkFDUixLQUFLLElBQUksb0JBQW9CLENBQUMsS0FBSyxDQUFDLENBQUE7WUFDeEMsQ0FBQyxDQUFBO1FBQ0wsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUN6RCxDQUFBO0lBQ0wsQ0FBQzs4R0F4Q1EsZUFBZTtrSEFBZixlQUFlLGNBREYsTUFBTTs7MkZBQ25CLGVBQWU7a0JBRDNCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlLCBOZ1pvbmUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB7IGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBPYnNlcnZhYmxlLCBvZiwgc2hhcmVSZXBsYXksIFN1YnNjcmliZXIgfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB7IGlzRXF1YWwgfSBmcm9tIFwibG9kYXNoXCJcblxuaW1wb3J0IHsgY29lcmNlRWxlbWVudCwgRWxlbWVudElucHV0IH0gZnJvbSBcIkBuZ3V0aWwvY29tbW9uXCJcblxuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tIFwiLi4vdXRpbC9yZWN0XCJcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiBcInJvb3RcIiB9KVxuZXhwb3J0IGNsYXNzIFBvc2l0aW9uV2F0Y2hlciB7XG4gICAgcmVhZG9ubHkgI3pvbmUgPSBpbmplY3QoTmdab25lKVxuICAgIHJlYWRvbmx5ICN3YXRjaGVzOiBNYXA8SFRNTEVsZW1lbnQsIE9ic2VydmFibGU8UG9zaXRpb24+PiA9IG5ldyBNYXAoKVxuXG4gICAgd2F0Y2goZWxlbWVudDogRWxlbWVudElucHV0IHwgV2luZG93KTogT2JzZXJ2YWJsZTxQb3NpdGlvbj4ge1xuICAgICAgICBpZiAoZWxlbWVudCBpbnN0YW5jZW9mIFdpbmRvdykge1xuICAgICAgICAgICAgcmV0dXJuIG9mKHsgeDogMCwgeTogMCB9KVxuICAgICAgICB9XG5cbiAgICAgICAgZWxlbWVudCA9IGNvZXJjZUVsZW1lbnQoZWxlbWVudClcblxuICAgICAgICBsZXQgd2F0Y2hlciA9IHRoaXMuI3dhdGNoZXMuZ2V0KGVsZW1lbnQpXG4gICAgICAgIGlmICh3YXRjaGVyID09IG51bGwpIHtcbiAgICAgICAgICAgIHdhdGNoZXIgPSB0aGlzLiNjcmVhdGVXYXRjaGVyKGVsZW1lbnQpXG4gICAgICAgICAgICB0aGlzLiN3YXRjaGVzLnNldChlbGVtZW50LCB3YXRjaGVyKVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHdhdGNoZXJcbiAgICB9XG5cbiAgICAjY3JlYXRlV2F0Y2hlcihlbGVtZW50OiBIVE1MRWxlbWVudCk6IE9ic2VydmFibGU8UG9zaXRpb24+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuI3pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT5cbiAgICAgICAgICAgIG5ldyBPYnNlcnZhYmxlKChkZXN0OiBTdWJzY3JpYmVyPFBvc2l0aW9uPikgPT4ge1xuICAgICAgICAgICAgICAgIGxldCByYWZJZDogbnVtYmVyIHwgdW5kZWZpbmVkID0gdW5kZWZpbmVkXG4gICAgICAgICAgICAgICAgY29uc3QgZW1pdCA9ICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgcmVjdCA9IGVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgICAgICAgICAgICAgICAgICAgZGVzdC5uZXh0KHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHg6IHJlY3QueCxcbiAgICAgICAgICAgICAgICAgICAgICAgIHk6IHJlY3QueVxuICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgICAgICBpZiAoIWRlc3QuY2xvc2VkKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByYWZJZCA9IHJlcXVlc3RBbmltYXRpb25GcmFtZShlbWl0KVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGVtaXQoKVxuICAgICAgICAgICAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJhZklkICYmIGNhbmNlbEFuaW1hdGlvbkZyYW1lKHJhZklkKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoaXNFcXVhbCksIHNoYXJlUmVwbGF5KDEpKVxuICAgICAgICApXG4gICAgfVxufVxuIl19
@@ -0,0 +1,29 @@
1
+ import { inject, Injectable } from "@angular/core";
2
+ import { combineLatest, Observable, shareReplay } 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
+ }).subscribe(({ dim, pos }) => {
14
+ dest.next({
15
+ x: pos.x,
16
+ y: pos.y,
17
+ width: dim.width,
18
+ height: dim.height
19
+ });
20
+ })).pipe(shareReplay(1));
21
+ }
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: RectWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
23
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: RectWatcher, providedIn: "root" }); }
24
+ }
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: RectWatcher, decorators: [{
26
+ type: Injectable,
27
+ args: [{ providedIn: "root" }]
28
+ }] });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdC13YXRjaGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdHlsZS9zcmMvc2VydmljZXMvcmVjdC13YXRjaGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFbEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFjLE1BQU0sTUFBTSxDQUFBO0FBS3pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBWSxNQUFNLDZCQUE2QixDQUFBO0FBQ3hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTs7QUFHNUQsTUFBTSxPQUFPLFdBQVc7SUFDWCxXQUFXLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUE7SUFDdEMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQTtJQUU5QyxLQUFLLENBQUMsT0FBOEIsRUFBRSxRQUFrQjtRQUNwRCxPQUFPLElBQUksVUFBVSxDQUFDLENBQUMsSUFBc0IsRUFBRSxFQUFFLENBQzdDLGFBQWEsQ0FBQztZQUNWLEdBQUcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDO1lBQzlDLEdBQUcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7U0FDdkMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUU7WUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQztnQkFDTixDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7Z0JBQ1IsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO2dCQUNSLEtBQUssRUFBRSxHQUFHLENBQUMsS0FBSztnQkFDaEIsTUFBTSxFQUFFLEdBQUcsQ0FBQyxNQUFNO2FBQ3JCLENBQUMsQ0FBQTtRQUNOLENBQUMsQ0FBQyxDQUNMLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQzFCLENBQUM7OEdBbEJRLFdBQVc7a0hBQVgsV0FBVyxjQURFLE1BQU07OzJGQUNuQixXQUFXO2tCQUR2QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgY29tYmluZUxhdGVzdCwgT2JzZXJ2YWJsZSwgc2hhcmVSZXBsYXksIFN1YnNjcmliZXIgfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB7IEVsZW1lbnRJbnB1dCB9IGZyb20gXCJAbmd1dGlsL2NvbW1vblwiXG5cbmltcG9ydCB7IFJlY3QgfSBmcm9tIFwiLi4vdXRpbC9yZWN0XCJcbmltcG9ydCB7IERpbWVuc2lvbldhdGNoZXIsIFdhdGNoQm94IH0gZnJvbSBcIi4vZGltZW5zaW9uLXdhdGNoZXIuc2VydmljZVwiXG5pbXBvcnQgeyBQb3NpdGlvbldhdGNoZXIgfSBmcm9tIFwiLi9wb3NpdGlvbi13YXRjaGVyLnNlcnZpY2VcIlxuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46IFwicm9vdFwiIH0pXG5leHBvcnQgY2xhc3MgUmVjdFdhdGNoZXIge1xuICAgIHJlYWRvbmx5ICNkaW1XYXRjaGVyID0gaW5qZWN0KERpbWVuc2lvbldhdGNoZXIpXG4gICAgcmVhZG9ubHkgI3Bvc1dhdGNoZXIgPSBpbmplY3QoUG9zaXRpb25XYXRjaGVyKVxuXG4gICAgd2F0Y2goZWxlbWVudDogRWxlbWVudElucHV0IHwgV2luZG93LCB3YXRjaEJveDogV2F0Y2hCb3gpOiBPYnNlcnZhYmxlPFJlY3Q+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChkZXN0OiBTdWJzY3JpYmVyPFJlY3Q+KSA9PlxuICAgICAgICAgICAgY29tYmluZUxhdGVzdCh7XG4gICAgICAgICAgICAgICAgZGltOiB0aGlzLiNkaW1XYXRjaGVyLndhdGNoKGVsZW1lbnQsIHdhdGNoQm94KSxcbiAgICAgICAgICAgICAgICBwb3M6IHRoaXMuI3Bvc1dhdGNoZXIud2F0Y2goZWxlbWVudClcbiAgICAgICAgICAgIH0pLnN1YnNjcmliZSgoeyBkaW0sIHBvcyB9KSA9PiB7XG4gICAgICAgICAgICAgICAgZGVzdC5uZXh0KHtcbiAgICAgICAgICAgICAgICAgICAgeDogcG9zLngsXG4gICAgICAgICAgICAgICAgICAgIHk6IHBvcy55LFxuICAgICAgICAgICAgICAgICAgICB3aWR0aDogZGltLndpZHRoLFxuICAgICAgICAgICAgICAgICAgICBoZWlnaHQ6IGRpbS5oZWlnaHRcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgfSlcbiAgICAgICAgKS5waXBlKHNoYXJlUmVwbGF5KDEpKVxuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,19 @@
1
+ const HORIZONTAL = ["start", "center", "end", "max-width"];
2
+ const VERTICAL = ["top", "middle", "bottom", "max-height"];
3
+ const DEFAULT = { horizontal: "center", vertical: "middle" };
4
+ export function alignmentNormalize(value) {
5
+ if (value == null) {
6
+ return DEFAULT;
7
+ }
8
+ if (typeof value !== "string") {
9
+ throw new Error(`Invalid alignment: ${value}`);
10
+ }
11
+ const entries = Array.from(new Set(value.split(/\s+/g)));
12
+ if (entries.length > 2) {
13
+ throw new Error(`Cannot parse: ${value}`);
14
+ }
15
+ const horizontal = HORIZONTAL.find(v => entries[0] === v || entries[1] === v) || "center";
16
+ const vertical = VERTICAL.find(v => entries[0] === v || entries[1] === v) || "middle";
17
+ return { horizontal, vertical };
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxpZ25tZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3R5bGUvc3JjL3V0aWwvYWxpZ25tZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxHQUFHLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsV0FBVyxDQUFVLENBQUE7QUFHbkUsTUFBTSxRQUFRLEdBQUcsQ0FBQyxLQUFLLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxZQUFZLENBQVUsQ0FBQTtBQWNuRSxNQUFNLE9BQU8sR0FBYyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFBO0FBRXZFLE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxLQUFzQjtJQUNyRCxJQUFJLEtBQUssSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNoQixPQUFPLE9BQU8sQ0FBQTtJQUNsQixDQUFDO0lBRUQsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztRQUM1QixNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixLQUFLLEVBQUUsQ0FBQyxDQUFBO0lBQ2xELENBQUM7SUFFRCxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBcUIsQ0FBQTtJQUM1RSxJQUFJLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDckIsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsS0FBSyxFQUFFLENBQUMsQ0FBQTtJQUM3QyxDQUFDO0lBRUQsTUFBTSxVQUFVLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLFFBQVEsQ0FBQTtJQUN6RixNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksUUFBUSxDQUFBO0lBRXJGLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLENBQUE7QUFDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IEhPUklaT05UQUwgPSBbXCJzdGFydFwiLCBcImNlbnRlclwiLCBcImVuZFwiLCBcIm1heC13aWR0aFwiXSBhcyBjb25zdFxuZXhwb3J0IHR5cGUgQWxpZ25Ib3Jpem9udGFsID0gKHR5cGVvZiBIT1JJWk9OVEFMKVtudW1iZXJdXG5cbmNvbnN0IFZFUlRJQ0FMID0gW1widG9wXCIsIFwibWlkZGxlXCIsIFwiYm90dG9tXCIsIFwibWF4LWhlaWdodFwiXSBhcyBjb25zdFxuZXhwb3J0IHR5cGUgQWxpZ25WZXJ0aWNhbCA9ICh0eXBlb2YgVkVSVElDQUwpW251bWJlcl1cblxuZXhwb3J0IHR5cGUgQWxpZ25tZW50SW5wdXQgPVxuICAgIHwgYCR7QWxpZ25Ib3Jpem9udGFsfSAke0FsaWduVmVydGljYWx9YFxuICAgIHwgYCR7QWxpZ25WZXJ0aWNhbH0gJHtBbGlnbkhvcml6b250YWx9YFxuICAgIHwgQWxpZ25WZXJ0aWNhbFxuICAgIHwgQWxpZ25Ib3Jpem9udGFsXG5cbmV4cG9ydCBpbnRlcmZhY2UgQWxpZ25tZW50IHtcbiAgICBob3Jpem9udGFsOiBBbGlnbkhvcml6b250YWxcbiAgICB2ZXJ0aWNhbDogQWxpZ25WZXJ0aWNhbFxufVxuXG5jb25zdCBERUZBVUxUOiBBbGlnbm1lbnQgPSB7IGhvcml6b250YWw6IFwiY2VudGVyXCIsIHZlcnRpY2FsOiBcIm1pZGRsZVwiIH1cblxuZXhwb3J0IGZ1bmN0aW9uIGFsaWdubWVudE5vcm1hbGl6ZSh2YWx1ZT86IEFsaWdubWVudElucHV0KTogQWxpZ25tZW50IHtcbiAgICBpZiAodmFsdWUgPT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gREVGQVVMVFxuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdmFsdWUgIT09IFwic3RyaW5nXCIpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGFsaWdubWVudDogJHt2YWx1ZX1gKVxuICAgIH1cblxuICAgIGNvbnN0IGVudHJpZXMgPSBBcnJheS5mcm9tKG5ldyBTZXQodmFsdWUuc3BsaXQoL1xccysvZykpKSBhcyBbc3RyaW5nLCBzdHJpbmddXG4gICAgaWYgKGVudHJpZXMubGVuZ3RoID4gMikge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBwYXJzZTogJHt2YWx1ZX1gKVxuICAgIH1cblxuICAgIGNvbnN0IGhvcml6b250YWwgPSBIT1JJWk9OVEFMLmZpbmQodiA9PiBlbnRyaWVzWzBdID09PSB2IHx8IGVudHJpZXNbMV0gPT09IHYpIHx8IFwiY2VudGVyXCJcbiAgICBjb25zdCB2ZXJ0aWNhbCA9IFZFUlRJQ0FMLmZpbmQodiA9PiBlbnRyaWVzWzBdID09PSB2IHx8IGVudHJpZXNbMV0gPT09IHYpIHx8IFwibWlkZGxlXCJcblxuICAgIHJldHVybiB7IGhvcml6b250YWwsIHZlcnRpY2FsIH1cbn1cbiJdfQ==
@@ -0,0 +1,70 @@
1
+ import { combineLatest, distinctUntilChanged, map, Observable } from "rxjs";
2
+ import { __zone_symbol__, rawCancelAnimationFrame, rawRequestAnimationFrame } from "@ngutil/common";
3
+ const addEventListener = __zone_symbol__("addEventListener");
4
+ const removeEventListener = __zone_symbol__("removeEventListener");
5
+ export function inAnimation(el, animations) {
6
+ return _in(el, "animationName", "animationstart", "animationiteration", "animationend", "animationcancel", animations);
7
+ }
8
+ export function inTransition(el, properties) {
9
+ return _in(el, "propertyName", "transitionstart", "transitionrun", "transitionend", "transitioncancel", properties);
10
+ }
11
+ export function isAnimating(el) {
12
+ return combineLatest([inAnimation(el), inTransition(el)]).pipe(map(values => !!(values[0] || values[1])), distinctUntilChanged());
13
+ }
14
+ function _in(el, keyName, beginName, doingName, endName, cancelName, keys) {
15
+ return new Observable((dest) => {
16
+ const state = {};
17
+ const start = (event) => {
18
+ const key = event[keyName];
19
+ if (keys && keys.length > 0 && !keys.includes(key)) {
20
+ return;
21
+ }
22
+ if (key in state) {
23
+ state[key]++;
24
+ }
25
+ else {
26
+ state[key] = 1;
27
+ }
28
+ dest.next(Object.keys(state));
29
+ };
30
+ const doing = (event) => {
31
+ const key = event[keyName];
32
+ if (keys && keys.length > 0 && !keys.includes(key)) {
33
+ return;
34
+ }
35
+ if (!(key in state)) {
36
+ state[key] = 1;
37
+ dest.next(Object.keys(state));
38
+ }
39
+ };
40
+ const end = (event) => {
41
+ if (event[keyName] in state) {
42
+ const key = event[keyName];
43
+ state[key]--;
44
+ if (state[key] <= 0) {
45
+ delete state[key];
46
+ }
47
+ }
48
+ if (Object.keys(state).length === 0) {
49
+ dest.next(null);
50
+ }
51
+ };
52
+ el[addEventListener](beginName, start);
53
+ el[addEventListener](doingName, doing);
54
+ el[addEventListener](endName, end);
55
+ el[addEventListener](cancelName, end);
56
+ const raf = rawRequestAnimationFrame(() => {
57
+ if (Object.keys(state).length === 0) {
58
+ dest.next(null);
59
+ }
60
+ });
61
+ return () => {
62
+ rawCancelAnimationFrame(raf);
63
+ el[removeEventListener](beginName, start);
64
+ el[removeEventListener](doingName, doing);
65
+ el[removeEventListener](endName, end);
66
+ el[removeEventListener](cancelName, end);
67
+ };
68
+ }).pipe(distinctUntilChanged());
69
+ }
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"in-animation.js","sourceRoot":"","sources":["../../../../../packages/style/src/util/in-animation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,GAAG,EAAE,UAAU,EAAc,MAAM,MAAM,CAAA;AAEvF,OAAO,EAAE,eAAe,EAAE,uBAAuB,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAA;AAEnG,MAAM,gBAAgB,GAAG,eAAe,CAAC,kBAAkB,CAAC,CAAA;AAC5D,MAAM,mBAAmB,GAAG,eAAe,CAAC,qBAAqB,CAAC,CAAA;AAElE,MAAM,UAAU,WAAW,CAAwB,EAAK,EAAE,UAAqB;IAC3E,OAAO,GAAG,CACN,EAAE,EACF,eAAe,EACf,gBAAgB,EAChB,oBAAoB,EACpB,cAAc,EACd,iBAAiB,EACjB,UAAU,CACb,CAAA;AACL,CAAC;AAED,MAAM,UAAU,YAAY,CAAwB,EAAK,EAAE,UAAqB;IAC5E,OAAO,GAAG,CAAC,EAAE,EAAE,cAAc,EAAE,iBAAiB,EAAE,eAAe,EAAE,eAAe,EAAE,kBAAkB,EAAE,UAAU,CAAC,CAAA;AACvH,CAAC;AAED,MAAM,UAAU,WAAW,CAAwB,EAAK;IACpD,OAAO,aAAa,CAAC,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAC1D,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EACzC,oBAAoB,EAAE,CACzB,CAAA;AACL,CAAC;AAED,SAAS,GAAG,CACR,EAAK,EACL,OAAe,EACf,SAAiB,EACjB,SAAiB,EACjB,OAAe,EACf,UAAkB,EAClB,IAAe;IAEf,OAAO,IAAI,UAAU,CAAC,CAAC,IAAiC,EAAE,EAAE;QACxD,MAAM,KAAK,GAA8B,EAAE,CAAA;QAE3C,MAAM,KAAK,GAAG,CAAC,KAAU,EAAE,EAAE;YACzB,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,CAAA;YAC1B,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBACjD,OAAM;YACV,CAAC;YAED,IAAI,GAAG,IAAI,KAAK,EAAE,CAAC;gBACf,KAAK,CAAC,GAAG,CAAC,EAAE,CAAA;YAChB,CAAC;iBAAM,CAAC;gBACJ,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;YAClB,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;QACjC,CAAC,CAAA;QAED,MAAM,KAAK,GAAG,CAAC,KAAU,EAAE,EAAE;YACzB,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,CAAA;YAC1B,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBACjD,OAAM;YACV,CAAC;YAED,IAAI,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,EAAE,CAAC;gBAClB,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;gBACd,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;YACjC,CAAC;QACL,CAAC,CAAA;QAED,MAAM,GAAG,GAAG,CAAC,KAAU,EAAE,EAAE;YACvB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,KAAK,EAAE,CAAC;gBAC1B,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,CAAA;gBAC1B,KAAK,CAAC,GAAG,CAAC,EAAE,CAAA;gBACZ,IAAI,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;oBAClB,OAAO,KAAK,CAAC,GAAG,CAAC,CAAA;gBACrB,CAAC;YACL,CAAC;YAED,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACnB,CAAC;QACL,CAAC,CAAA;QAED,EAAE,CAAC,gBAAgB,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;QACtC,EAAE,CAAC,gBAAgB,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;QACtC,EAAE,CAAC,gBAAgB,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,CAAA;QAClC,EAAE,CAAC,gBAAgB,CAAC,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;QAErC,MAAM,GAAG,GAAG,wBAAwB,CAAC,GAAG,EAAE;YACtC,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACnB,CAAC;QACL,CAAC,CAAC,CAAA;QAEF,OAAO,GAAG,EAAE;YACR,uBAAuB,CAAC,GAAG,CAAC,CAAA;YAC5B,EAAE,CAAC,mBAAmB,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;YACzC,EAAE,CAAC,mBAAmB,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;YACzC,EAAE,CAAC,mBAAmB,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,CAAA;YACrC,EAAE,CAAC,mBAAmB,CAAC,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;QAC5C,CAAC,CAAA;IACL,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAA;AACnC,CAAC","sourcesContent":["import { combineLatest, distinctUntilChanged, map, Observable, Subscriber } from \"rxjs\"\n\nimport { __zone_symbol__, rawCancelAnimationFrame, rawRequestAnimationFrame } from \"@ngutil/common\"\n\nconst addEventListener = __zone_symbol__(\"addEventListener\")\nconst removeEventListener = __zone_symbol__(\"removeEventListener\")\n\nexport function inAnimation<T extends HTMLElement>(el: T, animations?: string[]) {\n    return _in(\n        el,\n        \"animationName\",\n        \"animationstart\",\n        \"animationiteration\",\n        \"animationend\",\n        \"animationcancel\",\n        animations\n    )\n}\n\nexport function inTransition<T extends HTMLElement>(el: T, properties?: string[]) {\n    return _in(el, \"propertyName\", \"transitionstart\", \"transitionrun\", \"transitionend\", \"transitioncancel\", properties)\n}\n\nexport function isAnimating<T extends HTMLElement>(el: T) {\n    return combineLatest([inAnimation(el), inTransition(el)]).pipe(\n        map(values => !!(values[0] || values[1])),\n        distinctUntilChanged()\n    )\n}\n\nfunction _in<T extends HTMLElement>(\n    el: T,\n    keyName: string,\n    beginName: string,\n    doingName: string,\n    endName: string,\n    cancelName: string,\n    keys?: string[]\n) {\n    return new Observable((dest: Subscriber<string[] | null>) => {\n        const state: { [key: string]: number } = {}\n\n        const start = (event: any) => {\n            const key = event[keyName]\n            if (keys && keys.length > 0 && !keys.includes(key)) {\n                return\n            }\n\n            if (key in state) {\n                state[key]++\n            } else {\n                state[key] = 1\n            }\n            dest.next(Object.keys(state))\n        }\n\n        const doing = (event: any) => {\n            const key = event[keyName]\n            if (keys && keys.length > 0 && !keys.includes(key)) {\n                return\n            }\n\n            if (!(key in state)) {\n                state[key] = 1\n                dest.next(Object.keys(state))\n            }\n        }\n\n        const end = (event: any) => {\n            if (event[keyName] in state) {\n                const key = event[keyName]\n                state[key]--\n                if (state[key] <= 0) {\n                    delete state[key]\n                }\n            }\n\n            if (Object.keys(state).length === 0) {\n                dest.next(null)\n            }\n        }\n\n        el[addEventListener](beginName, start)\n        el[addEventListener](doingName, doing)\n        el[addEventListener](endName, end)\n        el[addEventListener](cancelName, end)\n\n        const raf = rawRequestAnimationFrame(() => {\n            if (Object.keys(state).length === 0) {\n                dest.next(null)\n            }\n        })\n\n        return () => {\n            rawCancelAnimationFrame(raf)\n            el[removeEventListener](beginName, start)\n            el[removeEventListener](doingName, doing)\n            el[removeEventListener](endName, end)\n            el[removeEventListener](cancelName, end)\n        }\n    }).pipe(distinctUntilChanged())\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0eWxlL3NyYy91dGlsL3JlY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRGltZW5zaW9uIHtcbiAgICB3aWR0aDogbnVtYmVyXG4gICAgaGVpZ2h0OiBudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZWN0IGV4dGVuZHMgRGltZW5zaW9uIHtcbiAgICB4OiBudW1iZXJcbiAgICB5OiBudW1iZXJcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0eWxlL3NyYy91dGlsL3JlY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRGltZW5zaW9uIHtcbiAgICB3aWR0aDogbnVtYmVyXG4gICAgaGVpZ2h0OiBudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQb3NpdGlvbiB7XG4gICAgeDogbnVtYmVyXG4gICAgeTogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVjdCBleHRlbmRzIERpbWVuc2lvbiwgUG9zaXRpb24ge31cbiJdfQ==
@@ -0,0 +1,21 @@
1
+ import { isPlainObject, NumberWithUnit } from "@ngutil/common";
2
+ export function sidesNormalize(value) {
3
+ if (isPlainObject(value)) {
4
+ return value;
5
+ }
6
+ else if (typeof value === "number") {
7
+ return sidesNormalize(`${value}px`);
8
+ }
9
+ else if (typeof value !== "string") {
10
+ throw new Error(`Invalid sides: ${value}`);
11
+ }
12
+ const entries = value.split(/\s+/g).map(v => NumberWithUnit.coerce(v, "px"));
13
+ if (entries.length < 0 || entries.length > 4) {
14
+ throw new Error(`Cannot parse: ${value}`);
15
+ }
16
+ return compose(...entries);
17
+ }
18
+ function compose(top, right = top, bottom = top, left = right) {
19
+ return { top, right, bottom, left };
20
+ }
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdHlsZS9zcmMvdXRpbC9zaWRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBa0I5RCxNQUFNLFVBQVUsY0FBYyxDQUFDLEtBQWlCO0lBQzVDLElBQUksYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDdkIsT0FBTyxLQUFLLENBQUE7SUFDaEIsQ0FBQztTQUFNLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDbkMsT0FBTyxjQUFjLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFBO0lBQ3ZDLENBQUM7U0FBTSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsa0JBQWtCLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDOUMsQ0FBQztJQUVELE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQXFCLENBQUE7SUFFaEcsSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDN0MsQ0FBQztJQUVELE9BQU8sT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUE7QUFDOUIsQ0FBQztBQUVELFNBQVMsT0FBTyxDQUNaLEdBQW1CLEVBQ25CLFFBQXdCLEdBQUcsRUFDM0IsU0FBeUIsR0FBRyxFQUM1QixPQUF1QixLQUFLO0lBRTVCLE9BQU8sRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQTtBQUN2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGFpbk9iamVjdCwgTnVtYmVyV2l0aFVuaXQgfSBmcm9tIFwiQG5ndXRpbC9jb21tb25cIlxuXG5leHBvcnQgaW50ZXJmYWNlIFNpZGVzIHtcbiAgICB0b3A6IE51bWJlcldpdGhVbml0XG4gICAgcmlnaHQ6IE51bWJlcldpdGhVbml0XG4gICAgYm90dG9tOiBOdW1iZXJXaXRoVW5pdFxuICAgIGxlZnQ6IE51bWJlcldpdGhVbml0XG59XG5cbmV4cG9ydCB0eXBlIFNpZGVzVW5pdCA9IFwicHhcIiB8IFwiJVwiXG5leHBvcnQgdHlwZSBTaWRlc051bWJlciA9IGAke251bWJlcn0ke1NpZGVzVW5pdH1gIHwgbnVtYmVyXG5leHBvcnQgdHlwZSBTaWRlc0lucHV0ID1cbiAgICB8IFNpZGVzXG4gICAgfCBTaWRlc051bWJlclxuICAgIHwgYCR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9YFxuICAgIHwgYCR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9YFxuICAgIHwgYCR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9YFxuXG5leHBvcnQgZnVuY3Rpb24gc2lkZXNOb3JtYWxpemUodmFsdWU6IFNpZGVzSW5wdXQpOiBTaWRlcyB7XG4gICAgaWYgKGlzUGxhaW5PYmplY3QodmFsdWUpKSB7XG4gICAgICAgIHJldHVybiB2YWx1ZVxuICAgIH0gZWxzZSBpZiAodHlwZW9mIHZhbHVlID09PSBcIm51bWJlclwiKSB7XG4gICAgICAgIHJldHVybiBzaWRlc05vcm1hbGl6ZShgJHt2YWx1ZX1weGApXG4gICAgfSBlbHNlIGlmICh0eXBlb2YgdmFsdWUgIT09IFwic3RyaW5nXCIpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHNpZGVzOiAke3ZhbHVlfWApXG4gICAgfVxuXG4gICAgY29uc3QgZW50cmllcyA9IHZhbHVlLnNwbGl0KC9cXHMrL2cpLm1hcCh2ID0+IE51bWJlcldpdGhVbml0LmNvZXJjZSh2LCBcInB4XCIpKSBhcyBbTnVtYmVyV2l0aFVuaXRdXG5cbiAgICBpZiAoZW50cmllcy5sZW5ndGggPCAwIHx8IGVudHJpZXMubGVuZ3RoID4gNCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBwYXJzZTogJHt2YWx1ZX1gKVxuICAgIH1cblxuICAgIHJldHVybiBjb21wb3NlKC4uLmVudHJpZXMpXG59XG5cbmZ1bmN0aW9uIGNvbXBvc2UoXG4gICAgdG9wOiBOdW1iZXJXaXRoVW5pdCxcbiAgICByaWdodDogTnVtYmVyV2l0aFVuaXQgPSB0b3AsXG4gICAgYm90dG9tOiBOdW1iZXJXaXRoVW5pdCA9IHRvcCxcbiAgICBsZWZ0OiBOdW1iZXJXaXRoVW5pdCA9IHJpZ2h0XG4pOiBTaWRlcyB7XG4gICAgcmV0dXJuIHsgdG9wLCByaWdodCwgYm90dG9tLCBsZWZ0IH1cbn1cbiJdfQ==
@@ -1,6 +1,8 @@
1
1
  import * as i0 from '@angular/core';
2
- import { inject, NgZone, Injectable, ElementRef } from '@angular/core';
3
- import { Observable, distinctUntilChanged, shareReplay, map } from 'rxjs';
2
+ import { inject, NgZone, Injectable } from '@angular/core';
3
+ import { Observable, distinctUntilChanged, shareReplay, map, of, combineLatest } from 'rxjs';
4
+ import { coerceElement, __zone_symbol__, rawRequestAnimationFrame, rawCancelAnimationFrame, isPlainObject, NumberWithUnit } from '@ngutil/common';
5
+ import { isEqual } from 'lodash';
4
6
 
5
7
  class MediaWatcher {
6
8
  #zone = inject(NgZone);
@@ -81,21 +83,26 @@ class DimensionWatcher {
81
83
  #zone = inject(NgZone);
82
84
  #watches = {};
83
85
  watch(element, box) {
86
+ element = coerceElement(element);
84
87
  let watches = this.#watches[box];
85
88
  if (watches == null) {
86
89
  watches = new Map();
87
90
  this.#watches[box] = watches;
88
91
  }
89
- const el = element instanceof ElementRef ? element.nativeElement : element;
90
- let watcher = watches.get(el);
92
+ let watcher = watches.get(element);
91
93
  if (watcher == null) {
92
- if (box === "scroll-box") {
93
- watcher = this.#createScollWatcher(watches, el);
94
+ if (element instanceof Window) {
95
+ watcher = this.#createWindowResizeWatcher();
94
96
  }
95
97
  else {
96
- watcher = this.#createResizeWatcher(watches, el, box);
98
+ if (box === "scroll-box") {
99
+ watcher = this.#createScollWatcher(watches, element);
100
+ }
101
+ else {
102
+ watcher = this.#createResizeWatcher(watches, element, box);
103
+ }
97
104
  }
98
- watches.set(el, watcher);
105
+ watches.set(element, watcher);
99
106
  }
100
107
  return watcher;
101
108
  }
@@ -157,6 +164,21 @@ class DimensionWatcher {
157
164
  };
158
165
  }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
159
166
  }
167
+ #createWindowResizeWatcher() {
168
+ return this.#zone.runOutsideAngular(() => new Observable((sub) => {
169
+ const onResize = () => {
170
+ sub.next({
171
+ width: window.innerWidth,
172
+ height: window.innerHeight
173
+ });
174
+ };
175
+ onResize();
176
+ window.addEventListener("resize", onResize);
177
+ return () => {
178
+ window.removeEventListener("resize", onResize);
179
+ };
180
+ }).pipe(distinctUntilChanged(dimensionIsEq), shareReplay(1)));
181
+ }
160
182
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DimensionWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
161
183
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DimensionWatcher, providedIn: "root" }); }
162
184
  }
@@ -168,9 +190,182 @@ function dimensionIsEq(a, b) {
168
190
  return a && b && a.width === b.width && a.height === b.height;
169
191
  }
170
192
 
193
+ class PositionWatcher {
194
+ #zone = inject(NgZone);
195
+ #watches = new Map();
196
+ watch(element) {
197
+ if (element instanceof Window) {
198
+ return of({ x: 0, y: 0 });
199
+ }
200
+ element = coerceElement(element);
201
+ let watcher = this.#watches.get(element);
202
+ if (watcher == null) {
203
+ watcher = this.#createWatcher(element);
204
+ this.#watches.set(element, watcher);
205
+ }
206
+ return watcher;
207
+ }
208
+ #createWatcher(element) {
209
+ return this.#zone.runOutsideAngular(() => new Observable((dest) => {
210
+ let rafId = undefined;
211
+ const emit = () => {
212
+ const rect = element.getBoundingClientRect();
213
+ dest.next({
214
+ x: rect.x,
215
+ y: rect.y
216
+ });
217
+ if (!dest.closed) {
218
+ rafId = requestAnimationFrame(emit);
219
+ }
220
+ };
221
+ emit();
222
+ return () => {
223
+ rafId && cancelAnimationFrame(rafId);
224
+ };
225
+ }).pipe(distinctUntilChanged(isEqual), shareReplay(1)));
226
+ }
227
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: PositionWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
228
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: PositionWatcher, providedIn: "root" }); }
229
+ }
230
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: PositionWatcher, decorators: [{
231
+ type: Injectable,
232
+ args: [{ providedIn: "root" }]
233
+ }] });
234
+
235
+ class RectWatcher {
236
+ #dimWatcher = inject(DimensionWatcher);
237
+ #posWatcher = inject(PositionWatcher);
238
+ watch(element, watchBox) {
239
+ return new Observable((dest) => combineLatest({
240
+ dim: this.#dimWatcher.watch(element, watchBox),
241
+ pos: this.#posWatcher.watch(element)
242
+ }).subscribe(({ dim, pos }) => {
243
+ dest.next({
244
+ x: pos.x,
245
+ y: pos.y,
246
+ width: dim.width,
247
+ height: dim.height
248
+ });
249
+ })).pipe(shareReplay(1));
250
+ }
251
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: RectWatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
252
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: RectWatcher, providedIn: "root" }); }
253
+ }
254
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: RectWatcher, decorators: [{
255
+ type: Injectable,
256
+ args: [{ providedIn: "root" }]
257
+ }] });
258
+
259
+ const HORIZONTAL = ["start", "center", "end", "max-width"];
260
+ const VERTICAL = ["top", "middle", "bottom", "max-height"];
261
+ const DEFAULT = { horizontal: "center", vertical: "middle" };
262
+ function alignmentNormalize(value) {
263
+ if (value == null) {
264
+ return DEFAULT;
265
+ }
266
+ if (typeof value !== "string") {
267
+ throw new Error(`Invalid alignment: ${value}`);
268
+ }
269
+ const entries = Array.from(new Set(value.split(/\s+/g)));
270
+ if (entries.length > 2) {
271
+ throw new Error(`Cannot parse: ${value}`);
272
+ }
273
+ const horizontal = HORIZONTAL.find(v => entries[0] === v || entries[1] === v) || "center";
274
+ const vertical = VERTICAL.find(v => entries[0] === v || entries[1] === v) || "middle";
275
+ return { horizontal, vertical };
276
+ }
277
+
278
+ const addEventListener = __zone_symbol__("addEventListener");
279
+ const removeEventListener = __zone_symbol__("removeEventListener");
280
+ function inAnimation(el, animations) {
281
+ return _in(el, "animationName", "animationstart", "animationiteration", "animationend", "animationcancel", animations);
282
+ }
283
+ function inTransition(el, properties) {
284
+ return _in(el, "propertyName", "transitionstart", "transitionrun", "transitionend", "transitioncancel", properties);
285
+ }
286
+ function isAnimating(el) {
287
+ return combineLatest([inAnimation(el), inTransition(el)]).pipe(map(values => !!(values[0] || values[1])), distinctUntilChanged());
288
+ }
289
+ function _in(el, keyName, beginName, doingName, endName, cancelName, keys) {
290
+ return new Observable((dest) => {
291
+ const state = {};
292
+ const start = (event) => {
293
+ const key = event[keyName];
294
+ if (keys && keys.length > 0 && !keys.includes(key)) {
295
+ return;
296
+ }
297
+ if (key in state) {
298
+ state[key]++;
299
+ }
300
+ else {
301
+ state[key] = 1;
302
+ }
303
+ dest.next(Object.keys(state));
304
+ };
305
+ const doing = (event) => {
306
+ const key = event[keyName];
307
+ if (keys && keys.length > 0 && !keys.includes(key)) {
308
+ return;
309
+ }
310
+ if (!(key in state)) {
311
+ state[key] = 1;
312
+ dest.next(Object.keys(state));
313
+ }
314
+ };
315
+ const end = (event) => {
316
+ if (event[keyName] in state) {
317
+ const key = event[keyName];
318
+ state[key]--;
319
+ if (state[key] <= 0) {
320
+ delete state[key];
321
+ }
322
+ }
323
+ if (Object.keys(state).length === 0) {
324
+ dest.next(null);
325
+ }
326
+ };
327
+ el[addEventListener](beginName, start);
328
+ el[addEventListener](doingName, doing);
329
+ el[addEventListener](endName, end);
330
+ el[addEventListener](cancelName, end);
331
+ const raf = rawRequestAnimationFrame(() => {
332
+ if (Object.keys(state).length === 0) {
333
+ dest.next(null);
334
+ }
335
+ });
336
+ return () => {
337
+ rawCancelAnimationFrame(raf);
338
+ el[removeEventListener](beginName, start);
339
+ el[removeEventListener](doingName, doing);
340
+ el[removeEventListener](endName, end);
341
+ el[removeEventListener](cancelName, end);
342
+ };
343
+ }).pipe(distinctUntilChanged());
344
+ }
345
+
346
+ function sidesNormalize(value) {
347
+ if (isPlainObject(value)) {
348
+ return value;
349
+ }
350
+ else if (typeof value === "number") {
351
+ return sidesNormalize(`${value}px`);
352
+ }
353
+ else if (typeof value !== "string") {
354
+ throw new Error(`Invalid sides: ${value}`);
355
+ }
356
+ const entries = value.split(/\s+/g).map(v => NumberWithUnit.coerce(v, "px"));
357
+ if (entries.length < 0 || entries.length > 4) {
358
+ throw new Error(`Cannot parse: ${value}`);
359
+ }
360
+ return compose(...entries);
361
+ }
362
+ function compose(top, right = top, bottom = top, left = right) {
363
+ return { top, right, bottom, left };
364
+ }
365
+
171
366
  /**
172
367
  * Generated bundle index. Do not edit.
173
368
  */
174
369
 
175
- export { ColorSchemeService, DimensionWatcher, Duration, Ease, MediaWatcher };
370
+ export { ColorSchemeService, DimensionWatcher, Duration, Ease, MediaWatcher, PositionWatcher, RectWatcher, alignmentNormalize, inAnimation, inTransition, isAnimating, sidesNormalize };
176
371
  //# sourceMappingURL=ngutil-style.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"ngutil-style.mjs","sources":["../../../../packages/style/src/services/media-watcher.service.ts","../../../../packages/style/src/services/color-scheme.service.ts","../../../../packages/style/src/sass/animation/vars/index.ts","../../../../packages/style/src/services/dimension-watcher.service.ts","../../../../packages/style/src/ngutil-style.ts"],"sourcesContent":["import { inject, Injectable, NgZone } from \"@angular/core\"\n\nimport { distinctUntilChanged, Observable, shareReplay, Subscriber } from \"rxjs\"\n\n@Injectable({ providedIn: \"root\" })\nexport class MediaWatcher {\n readonly #zone = inject(NgZone)\n #watches: { [key: string]: Observable<boolean> } = {}\n\n /**\n * svc.watch(\"(display-mode: standalone)\").subscribe(match => {})\n */\n watch(query: string): Observable<boolean> {\n let watcher = this.#watches[query]\n if (!watcher) {\n watcher = this.#newWatcher(query)\n this.#watches[query] = watcher\n }\n return watcher\n }\n\n #newWatcher(query: string): Observable<boolean> {\n return this.#zone.runOutsideAngular(() =>\n new Observable((sub: Subscriber<boolean>) => {\n const queryWatcher = window.matchMedia(query)\n const listener = (event: MediaQueryListEvent) => {\n sub.next(event.matches)\n }\n queryWatcher.addEventListener(\"change\", listener)\n sub.next(queryWatcher.matches)\n return () => {\n queryWatcher.removeEventListener(\"change\", listener)\n delete this.#watches[query]\n }\n }).pipe(distinctUntilChanged(), shareReplay(1))\n )\n }\n}\n","import { inject, Injectable } from \"@angular/core\"\n\nimport { map, Observable, shareReplay } from \"rxjs\"\n\nimport { MediaWatcher } from \"./media-watcher.service\"\n\n@Injectable({ providedIn: \"root\" })\nexport class ColorSchemeService {\n readonly #mq = inject(MediaWatcher)\n readonly isDark: Observable<boolean> = this.#mq.watch(\"(prefers-color-scheme: dark)\")\n readonly isLight = this.isDark.pipe(\n map(v => !v),\n shareReplay(1)\n )\n\n // TODO: set preferred color scheme (dark/light)\n}\n","/* eslint-disable */\n/* eslint-disable prettier/prettier */\n/* ! AUTO GENERATED DO NOT EDIT ! */\n\nexport class Ease {\n static readonly Deceleration = \"cubic-bezier(0, 0, 0.2, 1)\" as const\n static readonly Standard = \"cubic-bezier(0.4, 0, 0.2, 1)\" as const\n static readonly Acceleration = \"cubic-bezier(0.4, 0, 1, 1)\" as const\n static readonly Sharp = \"cubic-bezier(0.4, 0, 0.6, 1)\" as const\n /**\n * Reach nearly end position fast, and slowly move to final position\n */\n static readonly Emphasized = \"cubic-bezier(0.12, 0.9, 0.12, 0.9)\" as const\n}\n\nexport class Duration {\n static readonly Fast = \"200ms\" as const\n static readonly FastMs = 200 as const\n static readonly Medium = \"300ms\" as const\n static readonly MediumMs = 300 as const\n static readonly Slow = \"400ms\" as const\n static readonly SlowMs = 400 as const\n static readonly Snail = \"600ms\" as const\n static readonly SnailMs = 600 as const\n}\n","import { ElementRef, inject, Injectable, NgZone } from \"@angular/core\"\n\nimport { distinctUntilChanged, Observable, shareReplay, Subscriber } from \"rxjs\"\n\nimport { Dimension } from \"../util/rect\"\n\nexport type WatchBox = ResizeObserverBoxOptions | \"scroll-box\"\nexport type Watches = Map<HTMLElement, Observable<Dimension>>\n\n@Injectable({ providedIn: \"root\" })\nexport class DimensionWatcher {\n readonly #zone = inject(NgZone)\n readonly #watches: { [key in WatchBox]?: Watches } = {}\n\n watch(element: HTMLElement | ElementRef<HTMLElement>, box: WatchBox): Observable<Dimension> {\n let watches = this.#watches[box]\n if (watches == null) {\n watches = new Map()\n this.#watches[box] = watches\n }\n\n const el = element instanceof ElementRef ? element.nativeElement : element\n\n let watcher = watches.get(el)\n if (watcher == null) {\n if (box === \"scroll-box\") {\n watcher = this.#createScollWatcher(watches, el)\n } else {\n watcher = this.#createResizeWatcher(watches, el, box)\n }\n watches.set(el, 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 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\nfunction dimensionIsEq(a: Dimension, b: Dimension) {\n return a && b && a.width === b.width && a.height === b.height\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-style.mjs","sources":["../../../../packages/style/src/services/media-watcher.service.ts","../../../../packages/style/src/services/color-scheme.service.ts","../../../../packages/style/src/sass/animation/vars/index.ts","../../../../packages/style/src/services/dimension-watcher.service.ts","../../../../packages/style/src/services/position-watcher.service.ts","../../../../packages/style/src/services/rect-watcher.service.ts","../../../../packages/style/src/util/alignment.ts","../../../../packages/style/src/util/in-animation.ts","../../../../packages/style/src/util/sides.ts","../../../../packages/style/src/ngutil-style.ts"],"sourcesContent":["import { inject, Injectable, NgZone } from \"@angular/core\"\n\nimport { distinctUntilChanged, Observable, shareReplay, Subscriber } from \"rxjs\"\n\n@Injectable({ providedIn: \"root\" })\nexport class MediaWatcher {\n readonly #zone = inject(NgZone)\n #watches: { [key: string]: Observable<boolean> } = {}\n\n /**\n * svc.watch(\"(display-mode: standalone)\").subscribe(match => {})\n */\n watch(query: string): Observable<boolean> {\n let watcher = this.#watches[query]\n if (!watcher) {\n watcher = this.#newWatcher(query)\n this.#watches[query] = watcher\n }\n return watcher\n }\n\n #newWatcher(query: string): Observable<boolean> {\n return this.#zone.runOutsideAngular(() =>\n new Observable((sub: Subscriber<boolean>) => {\n const queryWatcher = window.matchMedia(query)\n const listener = (event: MediaQueryListEvent) => {\n sub.next(event.matches)\n }\n queryWatcher.addEventListener(\"change\", listener)\n sub.next(queryWatcher.matches)\n return () => {\n queryWatcher.removeEventListener(\"change\", listener)\n delete this.#watches[query]\n }\n }).pipe(distinctUntilChanged(), shareReplay(1))\n )\n }\n}\n","import { inject, Injectable } from \"@angular/core\"\n\nimport { map, Observable, shareReplay } from \"rxjs\"\n\nimport { MediaWatcher } from \"./media-watcher.service\"\n\n@Injectable({ providedIn: \"root\" })\nexport class ColorSchemeService {\n readonly #mq = inject(MediaWatcher)\n readonly isDark: Observable<boolean> = this.#mq.watch(\"(prefers-color-scheme: dark)\")\n readonly isLight = this.isDark.pipe(\n map(v => !v),\n shareReplay(1)\n )\n\n // TODO: set preferred color scheme (dark/light)\n}\n","/* eslint-disable */\n/* eslint-disable prettier/prettier */\n/* ! AUTO GENERATED DO NOT EDIT ! */\n\nexport class Ease {\n static readonly Deceleration = \"cubic-bezier(0, 0, 0.2, 1)\" as const\n static readonly Standard = \"cubic-bezier(0.4, 0, 0.2, 1)\" as const\n static readonly Acceleration = \"cubic-bezier(0.4, 0, 1, 1)\" as const\n static readonly Sharp = \"cubic-bezier(0.4, 0, 0.6, 1)\" as const\n /**\n * Reach nearly end position fast, and slowly move to final position\n */\n static readonly Emphasized = \"cubic-bezier(0.12, 0.9, 0.12, 0.9)\" as const\n}\n\nexport class Duration {\n static readonly Fast = \"200ms\" as const\n static readonly FastMs = 200 as const\n static readonly Medium = \"300ms\" as const\n static readonly MediumMs = 300 as const\n static readonly Slow = \"400ms\" as const\n static readonly SlowMs = 400 as const\n static readonly Snail = \"600ms\" as const\n static readonly SnailMs = 600 as const\n}\n","import { 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 #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 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","import { inject, Injectable, NgZone } from \"@angular/core\"\n\nimport { distinctUntilChanged, Observable, of, shareReplay, Subscriber } from \"rxjs\"\n\nimport { isEqual } from \"lodash\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\n\nimport { Position } from \"../util/rect\"\n\n@Injectable({ providedIn: \"root\" })\nexport class PositionWatcher {\n readonly #zone = inject(NgZone)\n readonly #watches: Map<HTMLElement, Observable<Position>> = new Map()\n\n watch(element: ElementInput | Window): Observable<Position> {\n if (element instanceof Window) {\n return of({ x: 0, y: 0 })\n }\n\n element = coerceElement(element)\n\n let watcher = this.#watches.get(element)\n if (watcher == null) {\n watcher = this.#createWatcher(element)\n this.#watches.set(element, watcher)\n }\n\n return watcher\n }\n\n #createWatcher(element: HTMLElement): Observable<Position> {\n return this.#zone.runOutsideAngular(() =>\n new Observable((dest: Subscriber<Position>) => {\n let rafId: number | undefined = undefined\n const emit = () => {\n const rect = element.getBoundingClientRect()\n dest.next({\n x: rect.x,\n y: rect.y\n })\n if (!dest.closed) {\n rafId = requestAnimationFrame(emit)\n }\n }\n emit()\n return () => {\n rafId && cancelAnimationFrame(rafId)\n }\n }).pipe(distinctUntilChanged(isEqual), shareReplay(1))\n )\n }\n}\n","import { inject, Injectable } from \"@angular/core\"\n\nimport { combineLatest, Observable, shareReplay, Subscriber } from \"rxjs\"\n\nimport { ElementInput } from \"@ngutil/common\"\n\nimport { Rect } from \"../util/rect\"\nimport { DimensionWatcher, WatchBox } from \"./dimension-watcher.service\"\nimport { PositionWatcher } from \"./position-watcher.service\"\n\n@Injectable({ providedIn: \"root\" })\nexport class RectWatcher {\n readonly #dimWatcher = inject(DimensionWatcher)\n readonly #posWatcher = inject(PositionWatcher)\n\n watch(element: ElementInput | Window, watchBox: WatchBox): Observable<Rect> {\n return new Observable((dest: Subscriber<Rect>) =>\n combineLatest({\n dim: this.#dimWatcher.watch(element, watchBox),\n pos: this.#posWatcher.watch(element)\n }).subscribe(({ dim, pos }) => {\n dest.next({\n x: pos.x,\n y: pos.y,\n width: dim.width,\n height: dim.height\n })\n })\n ).pipe(shareReplay(1))\n }\n}\n","const HORIZONTAL = [\"start\", \"center\", \"end\", \"max-width\"] as const\nexport type AlignHorizontal = (typeof HORIZONTAL)[number]\n\nconst VERTICAL = [\"top\", \"middle\", \"bottom\", \"max-height\"] as const\nexport type AlignVertical = (typeof VERTICAL)[number]\n\nexport type AlignmentInput =\n | `${AlignHorizontal} ${AlignVertical}`\n | `${AlignVertical} ${AlignHorizontal}`\n | AlignVertical\n | AlignHorizontal\n\nexport interface Alignment {\n horizontal: AlignHorizontal\n vertical: AlignVertical\n}\n\nconst DEFAULT: Alignment = { horizontal: \"center\", vertical: \"middle\" }\n\nexport function alignmentNormalize(value?: AlignmentInput): Alignment {\n if (value == null) {\n return DEFAULT\n }\n\n if (typeof value !== \"string\") {\n throw new Error(`Invalid alignment: ${value}`)\n }\n\n const entries = Array.from(new Set(value.split(/\\s+/g))) as [string, string]\n if (entries.length > 2) {\n throw new Error(`Cannot parse: ${value}`)\n }\n\n const horizontal = HORIZONTAL.find(v => entries[0] === v || entries[1] === v) || \"center\"\n const vertical = VERTICAL.find(v => entries[0] === v || entries[1] === v) || \"middle\"\n\n return { horizontal, vertical }\n}\n","import { combineLatest, distinctUntilChanged, map, Observable, Subscriber } from \"rxjs\"\n\nimport { __zone_symbol__, rawCancelAnimationFrame, rawRequestAnimationFrame } from \"@ngutil/common\"\n\nconst addEventListener = __zone_symbol__(\"addEventListener\")\nconst removeEventListener = __zone_symbol__(\"removeEventListener\")\n\nexport function inAnimation<T extends HTMLElement>(el: T, animations?: string[]) {\n return _in(\n el,\n \"animationName\",\n \"animationstart\",\n \"animationiteration\",\n \"animationend\",\n \"animationcancel\",\n animations\n )\n}\n\nexport function inTransition<T extends HTMLElement>(el: T, properties?: string[]) {\n return _in(el, \"propertyName\", \"transitionstart\", \"transitionrun\", \"transitionend\", \"transitioncancel\", properties)\n}\n\nexport function isAnimating<T extends HTMLElement>(el: T) {\n return combineLatest([inAnimation(el), inTransition(el)]).pipe(\n map(values => !!(values[0] || values[1])),\n distinctUntilChanged()\n )\n}\n\nfunction _in<T extends HTMLElement>(\n el: T,\n keyName: string,\n beginName: string,\n doingName: string,\n endName: string,\n cancelName: string,\n keys?: string[]\n) {\n return new Observable((dest: Subscriber<string[] | null>) => {\n const state: { [key: string]: number } = {}\n\n const start = (event: any) => {\n const key = event[keyName]\n if (keys && keys.length > 0 && !keys.includes(key)) {\n return\n }\n\n if (key in state) {\n state[key]++\n } else {\n state[key] = 1\n }\n dest.next(Object.keys(state))\n }\n\n const doing = (event: any) => {\n const key = event[keyName]\n if (keys && keys.length > 0 && !keys.includes(key)) {\n return\n }\n\n if (!(key in state)) {\n state[key] = 1\n dest.next(Object.keys(state))\n }\n }\n\n const end = (event: any) => {\n if (event[keyName] in state) {\n const key = event[keyName]\n state[key]--\n if (state[key] <= 0) {\n delete state[key]\n }\n }\n\n if (Object.keys(state).length === 0) {\n dest.next(null)\n }\n }\n\n el[addEventListener](beginName, start)\n el[addEventListener](doingName, doing)\n el[addEventListener](endName, end)\n el[addEventListener](cancelName, end)\n\n const raf = rawRequestAnimationFrame(() => {\n if (Object.keys(state).length === 0) {\n dest.next(null)\n }\n })\n\n return () => {\n rawCancelAnimationFrame(raf)\n el[removeEventListener](beginName, start)\n el[removeEventListener](doingName, doing)\n el[removeEventListener](endName, end)\n el[removeEventListener](cancelName, end)\n }\n }).pipe(distinctUntilChanged())\n}\n","import { isPlainObject, NumberWithUnit } from \"@ngutil/common\"\n\nexport interface Sides {\n top: NumberWithUnit\n right: NumberWithUnit\n bottom: NumberWithUnit\n left: NumberWithUnit\n}\n\nexport type SidesUnit = \"px\" | \"%\"\nexport type SidesNumber = `${number}${SidesUnit}` | number\nexport type SidesInput =\n | Sides\n | SidesNumber\n | `${SidesNumber} ${SidesNumber}`\n | `${SidesNumber} ${SidesNumber} ${SidesNumber}`\n | `${SidesNumber} ${SidesNumber} ${SidesNumber} ${SidesNumber}`\n\nexport function sidesNormalize(value: SidesInput): Sides {\n if (isPlainObject(value)) {\n return value\n } else if (typeof value === \"number\") {\n return sidesNormalize(`${value}px`)\n } else if (typeof value !== \"string\") {\n throw new Error(`Invalid sides: ${value}`)\n }\n\n const entries = value.split(/\\s+/g).map(v => NumberWithUnit.coerce(v, \"px\")) as [NumberWithUnit]\n\n if (entries.length < 0 || entries.length > 4) {\n throw new Error(`Cannot parse: ${value}`)\n }\n\n return compose(...entries)\n}\n\nfunction compose(\n top: NumberWithUnit,\n right: NumberWithUnit = top,\n bottom: NumberWithUnit = top,\n left: NumberWithUnit = right\n): Sides {\n return { top, right, bottom, left }\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,5 +1,10 @@
1
1
  export { MediaWatcher } from "./services/media-watcher.service";
2
2
  export { ColorSchemeService } from "./services/color-scheme.service";
3
3
  export { Ease, Duration } from "./sass";
4
- export { Dimension, Rect } from "./util/rect";
5
4
  export { DimensionWatcher, WatchBox } from "./services/dimension-watcher.service";
5
+ export { PositionWatcher } from "./services/position-watcher.service";
6
+ export { RectWatcher } from "./services/rect-watcher.service";
7
+ export { AlignmentInput, alignmentNormalize, Alignment, AlignHorizontal, AlignVertical } from "./util/alignment";
8
+ export { inAnimation, inTransition, isAnimating } from "./util/in-animation";
9
+ export { Dimension, Rect, Position } from "./util/rect";
10
+ export { SidesInput, sidesNormalize, Sides } from "./util/sides";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ngutil/style",
3
- "version": "0.0.24",
3
+ "version": "0.0.27",
4
4
  "exports": {
5
5
  ".": {
6
6
  "sass": "./index.scss",
@@ -17,7 +17,8 @@
17
17
  "peerDependencies": {
18
18
  "@angular/common": "^17.3.6",
19
19
  "@angular/core": "^17.3.6",
20
- "rxjs": "^7.8.1"
20
+ "rxjs": "^7.8.1",
21
+ "@ngutil/common": "0.0.27"
21
22
  },
22
23
  "publishConfig": {
23
24
  "access": "public",
@@ -1,12 +1,12 @@
1
- import { ElementRef } from "@angular/core";
2
1
  import { Observable } from "rxjs";
2
+ import { ElementInput } from "@ngutil/common";
3
3
  import { Dimension } from "../util/rect";
4
4
  import * as i0 from "@angular/core";
5
5
  export type WatchBox = ResizeObserverBoxOptions | "scroll-box";
6
- export type Watches = Map<HTMLElement, Observable<Dimension>>;
6
+ export type Watches = Map<HTMLElement | Window, Observable<Dimension>>;
7
7
  export declare class DimensionWatcher {
8
8
  #private;
9
- watch(element: HTMLElement | ElementRef<HTMLElement>, box: WatchBox): Observable<Dimension>;
9
+ watch(element: ElementInput | Window, box: WatchBox): Observable<Dimension>;
10
10
  static ɵfac: i0.ɵɵFactoryDeclaration<DimensionWatcher, never>;
11
11
  static ɵprov: i0.ɵɵInjectableDeclaration<DimensionWatcher>;
12
12
  }
@@ -0,0 +1,10 @@
1
+ import { Observable } from "rxjs";
2
+ import { ElementInput } from "@ngutil/common";
3
+ import { Position } from "../util/rect";
4
+ import * as i0 from "@angular/core";
5
+ export declare class PositionWatcher {
6
+ #private;
7
+ watch(element: ElementInput | Window): Observable<Position>;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<PositionWatcher, never>;
9
+ static ɵprov: i0.ɵɵInjectableDeclaration<PositionWatcher>;
10
+ }
@@ -0,0 +1,11 @@
1
+ import { Observable } from "rxjs";
2
+ import { ElementInput } from "@ngutil/common";
3
+ import { Rect } from "../util/rect";
4
+ import { WatchBox } from "./dimension-watcher.service";
5
+ import * as i0 from "@angular/core";
6
+ export declare class RectWatcher {
7
+ #private;
8
+ watch(element: ElementInput | Window, watchBox: WatchBox): Observable<Rect>;
9
+ static ɵfac: i0.ɵɵFactoryDeclaration<RectWatcher, never>;
10
+ static ɵprov: i0.ɵɵInjectableDeclaration<RectWatcher>;
11
+ }
@@ -0,0 +1,11 @@
1
+ declare const HORIZONTAL: readonly ["start", "center", "end", "max-width"];
2
+ export type AlignHorizontal = (typeof HORIZONTAL)[number];
3
+ declare const VERTICAL: readonly ["top", "middle", "bottom", "max-height"];
4
+ export type AlignVertical = (typeof VERTICAL)[number];
5
+ export type AlignmentInput = `${AlignHorizontal} ${AlignVertical}` | `${AlignVertical} ${AlignHorizontal}` | AlignVertical | AlignHorizontal;
6
+ export interface Alignment {
7
+ horizontal: AlignHorizontal;
8
+ vertical: AlignVertical;
9
+ }
10
+ export declare function alignmentNormalize(value?: AlignmentInput): Alignment;
11
+ export {};
@@ -0,0 +1,4 @@
1
+ import { Observable } from "rxjs";
2
+ export declare function inAnimation<T extends HTMLElement>(el: T, animations?: string[]): Observable<string[] | null>;
3
+ export declare function inTransition<T extends HTMLElement>(el: T, properties?: string[]): Observable<string[] | null>;
4
+ export declare function isAnimating<T extends HTMLElement>(el: T): Observable<boolean>;
package/util/rect.d.ts CHANGED
@@ -2,7 +2,9 @@ export interface Dimension {
2
2
  width: number;
3
3
  height: number;
4
4
  }
5
- export interface Rect extends Dimension {
5
+ export interface Position {
6
6
  x: number;
7
7
  y: number;
8
8
  }
9
+ export interface Rect extends Dimension, Position {
10
+ }
@@ -0,0 +1,11 @@
1
+ import { NumberWithUnit } from "@ngutil/common";
2
+ export interface Sides {
3
+ top: NumberWithUnit;
4
+ right: NumberWithUnit;
5
+ bottom: NumberWithUnit;
6
+ left: NumberWithUnit;
7
+ }
8
+ export type SidesUnit = "px" | "%";
9
+ export type SidesNumber = `${number}${SidesUnit}` | number;
10
+ export type SidesInput = Sides | SidesNumber | `${SidesNumber} ${SidesNumber}` | `${SidesNumber} ${SidesNumber} ${SidesNumber}` | `${SidesNumber} ${SidesNumber} ${SidesNumber} ${SidesNumber}`;
11
+ export declare function sidesNormalize(value: SidesInput): Sides;