@ngutil/floating 0.0.34 → 0.0.36
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/floating/floating-ref.mjs +4 -1
- package/esm2022/floating/floating.service.mjs +1 -2
- package/esm2022/floating/traits/_base.mjs +2 -3
- package/esm2022/floating/traits/animation.mjs +2 -4
- package/esm2022/floating/traits/attribute.mjs +2 -4
- package/esm2022/floating/traits/backdrop.mjs +2 -4
- package/esm2022/floating/traits/dim-contraint.mjs +15 -6
- package/esm2022/floating/traits/focus.mjs +48 -0
- package/esm2022/floating/traits/index.mjs +2 -2
- package/esm2022/floating/traits/keystroke.mjs +2 -4
- package/esm2022/floating/traits/modal.mjs +3 -3
- package/esm2022/floating/traits/position.mjs +4 -5
- package/esm2022/floating/traits/style.mjs +2 -4
- package/fesm2022/ngutil-floating.mjs +57 -32
- package/fesm2022/ngutil-floating.mjs.map +1 -1
- package/floating/floating.service.d.ts +2 -1
- package/floating/traits/_base.d.ts +3 -3
- package/floating/traits/animation.d.ts +2 -2
- package/floating/traits/attribute.d.ts +2 -2
- package/floating/traits/backdrop.d.ts +2 -2
- package/floating/traits/dim-contraint.d.ts +1 -1
- package/floating/traits/focus.d.ts +19 -0
- package/floating/traits/index.d.ts +1 -1
- package/floating/traits/keystroke.d.ts +1 -1
- package/floating/traits/modal.d.ts +1 -1
- package/floating/traits/position.d.ts +3 -3
- package/floating/traits/style.d.ts +2 -2
- package/package.json +4 -4
- package/esm2022/floating/traits/focus-trap.mjs +0 -27
- package/floating/traits/focus-trap.d.ts +0 -8
|
@@ -43,6 +43,9 @@ export class FloatingRef {
|
|
|
43
43
|
this.state.on("showing", () => {
|
|
44
44
|
container.nativeElement.style.visibility = "visible";
|
|
45
45
|
});
|
|
46
|
+
this.state.on("disposing", () => {
|
|
47
|
+
container.nativeElement.style.pointerEvents = "none";
|
|
48
|
+
});
|
|
46
49
|
this.state.on("disposed", () => {
|
|
47
50
|
sub.unsubscribe();
|
|
48
51
|
});
|
|
@@ -93,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
|
|
|
93
96
|
type: Inject,
|
|
94
97
|
args: [TRAITS]
|
|
95
98
|
}] }] });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating-ref.js","sourceRoot":"","sources":["../../../../../packages/floating/src/floating/floating-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, InjectionToken } from \"@angular/core\"\n\nimport { debounceTime, EMPTY, filter, map, merge, Observable, ReplaySubject, shareReplay, takeUntil } from \"rxjs\"\n\nimport { StateChain } from \"@ngutil/common\"\n\nimport { ContainerRef } from \"../layer/container-ref\"\nimport { LayerService } from \"../layer/layer.service\"\nimport { FloatingTrait } from \"./traits/_base\"\n\nexport type Traits = { [key: string]: FloatingTrait }\n\nexport const TRAITS = new InjectionToken<Traits>(\"TRAITS\")\n\nexport interface FloatingChannel {\n    floatingRef: FloatingRef\n    type: string\n    data?: any\n}\n\nexport interface FloatingTraitEvent {\n    name: string\n    data: object\n}\n\n@Injectable()\nexport class FloatingRef<C extends FloatingChannel = FloatingChannel, T extends HTMLElement = HTMLElement> {\n    readonly channel = new ReplaySubject<FloatingChannel>(1)\n\n    readonly state = new StateChain({\n        init: {},\n        showing: {},\n        shown: {},\n        closing: { cancellable: false, order: \"sequential\" },\n        disposing: { cancellable: false },\n        disposed: { cancellable: false, order: \"sequential\" },\n        cleanup: { cancellable: false, order: \"sequential\" }\n    })\n\n    readonly #traits: Traits = {}\n    readonly traitState$: Observable<FloatingTraitEvent>\n\n    readonly #untilCleanup = this.state.current$.pipe(\n        filter(state => state === \"cleanup\"),\n        shareReplay(1)\n    )\n\n    readonly #untilDisposed = this.state.current$.pipe(\n        filter(state => state === \"cleanup\"),\n        shareReplay(1)\n    )\n\n    constructor(\n        readonly layerSvc: LayerService,\n        readonly container: ContainerRef,\n        @Inject(TRAITS) traits: Traits\n    ) {\n        container.nativeElement.style.overflow = \"hidden\"\n        container.nativeElement.style.visibility = \"hidden\"\n\n        this.#traits = traits\n        this.traitState$ = this.#traitState().pipe(shareReplay(1))\n\n        const sub = this.state.current$.subscribe(state => {\n            this.emit({ type: state } as C)\n        })\n        this.state.on(\n            \"init\",\n            () =>\n                new Observable(dst => {\n                    // TODO: angular render is stabilized\n                    this.traitState$.pipe(takeUntil(this.#untilCleanup), debounceTime(5)).subscribe(() => {\n                        dst.complete()\n                    })\n                })\n        )\n        this.state.on(\"showing\", () => {\n            container.nativeElement.style.visibility = \"visible\"\n        })\n        this.state.on(\"disposed\", () => {\n            sub.unsubscribe()\n        })\n        this.state.control(container.state)\n    }\n\n    show() {\n        return this.state.run([\"init\", \"showing\", \"shown\"])\n    }\n\n    hide() {\n        return this.state.run([\"disposing\", \"disposed\", \"cleanup\"])\n    }\n\n    close() {\n        return this.state.run([\"closing\", \"disposing\", \"disposed\", \"cleanup\"])\n    }\n\n    emit(event: Omit<C, \"floatingRef\">) {\n        this.channel.next({ ...event, floatingRef: this } as any)\n    }\n\n    setResult(data: any) {\n        this.emit({ type: \"result\", data } as C)\n        this.hide().subscribe()\n    }\n\n    watchTrait<T>(name: string): Observable<T> {\n        return this.traitState$.pipe(\n            takeUntil(this.#untilDisposed),\n            filter(event => event.name === name),\n            map(event => event.data as T),\n            shareReplay(1)\n        )\n    }\n\n    #traitState(): Observable<FloatingTraitEvent> {\n        const src = []\n\n        for (const [k, v] of Object.entries(this.#traits)) {\n            src.push(\n                v.connect(this).pipe(\n                    takeUntil(this.#untilCleanup),\n                    map(result => {\n                        return { name: k, data: result }\n                    })\n                )\n            )\n        }\n\n        if (src.length === 0) {\n            return EMPTY\n        } else if (src.length === 1) {\n            return src[0]\n        } else {\n            return merge(...src)\n        }\n    }\n}\n"]}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating-ref.js","sourceRoot":"","sources":["../../../../../packages/floating/src/floating/floating-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, InjectionToken } from \"@angular/core\"\n\nimport { debounceTime, EMPTY, filter, map, merge, Observable, ReplaySubject, shareReplay, takeUntil } from \"rxjs\"\n\nimport { StateChain } from \"@ngutil/common\"\n\nimport { ContainerRef } from \"../layer/container-ref\"\nimport { LayerService } from \"../layer/layer.service\"\nimport { FloatingTrait } from \"./traits/_base\"\n\nexport type Traits = { [key: string]: FloatingTrait }\n\nexport const TRAITS = new InjectionToken<Traits>(\"TRAITS\")\n\nexport interface FloatingChannel {\n    floatingRef: FloatingRef\n    type: string\n    data?: any\n}\n\nexport interface FloatingTraitEvent {\n    name: string\n    data: object\n}\n\n@Injectable()\nexport class FloatingRef<C extends FloatingChannel = FloatingChannel, T extends HTMLElement = HTMLElement> {\n    readonly channel = new ReplaySubject<FloatingChannel>(1)\n\n    readonly state = new StateChain({\n        init: {},\n        showing: {},\n        shown: {},\n        closing: { cancellable: false, order: \"sequential\" },\n        disposing: { cancellable: false },\n        disposed: { cancellable: false, order: \"sequential\" },\n        cleanup: { cancellable: false, order: \"sequential\" }\n    })\n\n    readonly #traits: Traits = {}\n    readonly traitState$: Observable<FloatingTraitEvent>\n\n    readonly #untilCleanup = this.state.current$.pipe(\n        filter(state => state === \"cleanup\"),\n        shareReplay(1)\n    )\n\n    readonly #untilDisposed = this.state.current$.pipe(\n        filter(state => state === \"cleanup\"),\n        shareReplay(1)\n    )\n\n    constructor(\n        readonly layerSvc: LayerService,\n        readonly container: ContainerRef,\n        @Inject(TRAITS) traits: Traits\n    ) {\n        container.nativeElement.style.overflow = \"hidden\"\n        container.nativeElement.style.visibility = \"hidden\"\n\n        this.#traits = traits\n        this.traitState$ = this.#traitState().pipe(shareReplay(1))\n\n        const sub = this.state.current$.subscribe(state => {\n            this.emit({ type: state } as C)\n        })\n        this.state.on(\n            \"init\",\n            () =>\n                new Observable(dst => {\n                    // TODO: angular render is stabilized\n                    this.traitState$.pipe(takeUntil(this.#untilCleanup), debounceTime(5)).subscribe(() => {\n                        dst.complete()\n                    })\n                })\n        )\n        this.state.on(\"showing\", () => {\n            container.nativeElement.style.visibility = \"visible\"\n        })\n        this.state.on(\"disposing\", () => {\n            container.nativeElement.style.pointerEvents = \"none\"\n        })\n        this.state.on(\"disposed\", () => {\n            sub.unsubscribe()\n        })\n        this.state.control(container.state)\n    }\n\n    show() {\n        return this.state.run([\"init\", \"showing\", \"shown\"])\n    }\n\n    hide() {\n        return this.state.run([\"disposing\", \"disposed\", \"cleanup\"])\n    }\n\n    close() {\n        return this.state.run([\"closing\", \"disposing\", \"disposed\", \"cleanup\"])\n    }\n\n    emit(event: Omit<C, \"floatingRef\">) {\n        this.channel.next({ ...event, floatingRef: this } as any)\n    }\n\n    setResult(data: any) {\n        this.emit({ type: \"result\", data } as C)\n        this.hide().subscribe()\n    }\n\n    watchTrait<T>(name: string): Observable<T> {\n        return this.traitState$.pipe(\n            takeUntil(this.#untilDisposed),\n            filter(event => event.name === name),\n            map(event => event.data as T),\n            shareReplay(1)\n        )\n    }\n\n    #traitState(): Observable<FloatingTraitEvent> {\n        const src = []\n\n        for (const [k, v] of Object.entries(this.#traits)) {\n            src.push(\n                v.connect(this).pipe(\n                    takeUntil(this.#untilCleanup),\n                    map(result => {\n                        return { name: k, data: result }\n                    })\n                )\n            )\n        }\n\n        if (src.length === 0) {\n            return EMPTY\n        } else if (src.length === 1) {\n            return src[0]\n        } else {\n            return merge(...src)\n        }\n    }\n}\n"]}
|
|
@@ -4,7 +4,6 @@ import { LayerService } from "../layer/layer.service";
|
|
|
4
4
|
import { FloatingRef, TRAITS } from "./floating-ref";
|
|
5
5
|
import { position } from "./traits/position";
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
// export type FloatingTrait = (...args: any[]) => (traits: object) => Observable<object>
|
|
8
7
|
export class FloatingFactory {
|
|
9
8
|
#providers;
|
|
10
9
|
constructor(layer) {
|
|
@@ -128,4 +127,4 @@ export class FloatingService {
|
|
|
128
127
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: FloatingService, decorators: [{
|
|
129
128
|
type: Injectable
|
|
130
129
|
}] });
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating.service.js","sourceRoot":"","sources":["../../../../../packages/floating/src/floating/floating.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentType } from \"@angular/cdk/portal\"\nimport { inject, Injectable, Provider, TemplateRef } from \"@angular/core\"\n\nimport { Observable, Subscriber } from \"rxjs\"\n\nimport { LayerService } from \"../layer/layer.service\"\nimport { ComponentPortalOptions, TemplatePortalOptions } from \"../layer/portal-ref\"\nimport { FloatingChannel, FloatingRef, TRAITS } from \"./floating-ref\"\nimport { type FloatingTrait } from \"./traits/_base\"\nimport { type FloatingPositionOptions, position } from \"./traits/position\"\n\n// export type FloatingTrait = (...args: any[]) => (traits: object) => Observable<object>\n\nexport abstract class FloatingFactory {\n    protected readonly traits: { [key: string]: FloatingTrait } = {}\n\n    #providers: Provider[] = []\n\n    constructor(protected readonly layer: LayerService) {}\n\n    trait(...traits: Array<FloatingTrait | FloatingTrait[]>) {\n        for (const trait of traits) {\n            if (Array.isArray(trait)) {\n                this.trait(...trait)\n            } else {\n                this.traits[trait.name] = trait\n            }\n        }\n\n        return this\n    }\n\n    show(): Observable<FloatingChannel> {\n        return new Observable((dest: Subscriber<FloatingChannel>) => {\n            let disposing = false\n\n            const ref = this.create()\n            const channelSub = ref.channel.subscribe(event => {\n                dest.next(event)\n                if (event.type === \"disposing\") {\n                    disposing = true\n                }\n                if (event.type === \"cleanup\") {\n                    dest.complete()\n                }\n            })\n\n            const showSub = ref.show().subscribe()\n\n            return () => {\n                showSub.unsubscribe()\n                channelSub.unsubscribe()\n                if (!disposing) {\n                    ref.hide().subscribe()\n                }\n            }\n        })\n    }\n\n    subscribe: Observable<FloatingChannel>[\"subscribe\"] = (...args: any[]) => this.show().subscribe(...args)\n\n    protected providers(providers?: Provider[]): Provider[] {\n        if (!providers) {\n            providers = []\n        }\n\n        providers = [\n            ...providers,\n            { provide: TRAITS, useValue: this.traits },\n            { provide: LayerService, useValue: this.layer },\n            FloatingRef,\n            ...this.#providers\n        ]\n\n        return providers\n    }\n\n    protected abstract create(): FloatingRef<FloatingChannel>\n\n    position(options: FloatingPositionOptions) {\n        return this.trait(position(options))\n    }\n\n    provides(providers: Provider | Provider[]) {\n        if (Array.isArray(providers)) {\n            this.#providers = [...this.#providers, ...providers]\n        } else {\n            this.#providers = [...this.#providers, providers]\n        }\n        return this\n    }\n}\n\nexport class FloatingTemplateFactory<T extends object> extends FloatingFactory {\n    constructor(\n        layer: LayerService,\n        public readonly tpl: TemplateRef<T>,\n        public readonly options: TemplatePortalOptions<T>\n    ) {\n        super(layer)\n    }\n\n    protected override create(): FloatingRef<FloatingChannel> {\n        const options: TemplatePortalOptions<T> = { ...this.options }\n        options.providers = this.providers(options.providers)\n        const container = this.layer.newTemplatePortal(this.tpl, options)\n        return container.injector.get(FloatingRef)\n    }\n}\n\nexport class FloatingComponentFactory<T extends ComponentType<any>> extends FloatingFactory {\n    constructor(\n        layer: LayerService,\n        public readonly component: T,\n        public readonly options: ComponentPortalOptions<T>\n    ) {\n        super(layer)\n    }\n\n    protected override create(): FloatingRef<FloatingChannel> {\n        const options: ComponentPortalOptions<T> = { ...this.options }\n        options.providers = this.providers(options.providers)\n        const container = this.layer.newComponentPortal(this.component, options)\n        return container.injector.get(FloatingRef)\n    }\n}\n\n/**\n * @example\n * ```typescript\n * class SomeComponent {}\n *\n * class SomeList {\n *      readonly floating = inject(FloatingService)\n *\n *      showComponent() {\n *          this.floating.from(SomeComponent).traits(position(), backdrop()).subscribe()\n *      }\n * ```\n */\n@Injectable()\nexport class FloatingService {\n    readonly #layer = inject(LayerService)\n    // readonly parent = inject(FloatingRef, { skipSelf: true, optional: true })\n\n    from<T extends ComponentType<any>>(component: T, opts?: ComponentPortalOptions<T>): FloatingComponentFactory<T>\n\n    from<T extends object>(tpl: TemplateRef<T>, opts?: TemplatePortalOptions<T>): FloatingTemplateFactory<T>\n\n    from<T>(value: ComponentType<T> | TemplateRef<T>, opts: any): FloatingFactory {\n        if (value instanceof TemplateRef) {\n            return new FloatingTemplateFactory(this.#layer, value as any, opts)\n        } else {\n            return new FloatingComponentFactory(this.#layer, value as any, opts)\n        }\n    }\n}\n"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating.service.js","sourceRoot":"","sources":["../../../../../packages/floating/src/floating/floating.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentType } from \"@angular/cdk/portal\"\nimport { inject, Injectable, Provider, TemplateRef } from \"@angular/core\"\n\nimport { Observable, Subscriber } from \"rxjs\"\n\nimport { LayerService } from \"../layer/layer.service\"\nimport { ComponentPortalOptions, TemplatePortalOptions } from \"../layer/portal-ref\"\nimport { FloatingChannel, FloatingRef, TRAITS } from \"./floating-ref\"\nimport { type FloatingTrait } from \"./traits/_base\"\nimport { type FloatingPositionOptions, position } from \"./traits/position\"\n\n// export type FloatingTrait = (...args: any[]) => (traits: object) => Observable<object>\n\nexport type FloatingTraitInput = FloatingTrait | Array<FloatingTraitInput>\n\nexport abstract class FloatingFactory {\n    protected readonly traits: { [key: string]: FloatingTrait } = {}\n\n    #providers: Provider[] = []\n\n    constructor(protected readonly layer: LayerService) {}\n\n    trait(...traits: Array<FloatingTraitInput>) {\n        for (const trait of traits) {\n            if (Array.isArray(trait)) {\n                this.trait(...trait)\n            } else {\n                this.traits[trait.name] = trait\n            }\n        }\n\n        return this\n    }\n\n    show(): Observable<FloatingChannel> {\n        return new Observable((dest: Subscriber<FloatingChannel>) => {\n            let disposing = false\n\n            const ref = this.create()\n            const channelSub = ref.channel.subscribe(event => {\n                dest.next(event)\n                if (event.type === \"disposing\") {\n                    disposing = true\n                }\n                if (event.type === \"cleanup\") {\n                    dest.complete()\n                }\n            })\n\n            const showSub = ref.show().subscribe()\n\n            return () => {\n                showSub.unsubscribe()\n                channelSub.unsubscribe()\n                if (!disposing) {\n                    ref.hide().subscribe()\n                }\n            }\n        })\n    }\n\n    subscribe: Observable<FloatingChannel>[\"subscribe\"] = (...args: any[]) => this.show().subscribe(...args)\n\n    protected providers(providers?: Provider[]): Provider[] {\n        if (!providers) {\n            providers = []\n        }\n\n        providers = [\n            ...providers,\n            { provide: TRAITS, useValue: this.traits },\n            { provide: LayerService, useValue: this.layer },\n            FloatingRef,\n            ...this.#providers\n        ]\n\n        return providers\n    }\n\n    protected abstract create(): FloatingRef<FloatingChannel>\n\n    position(options: FloatingPositionOptions) {\n        return this.trait(position(options))\n    }\n\n    provides(providers: Provider | Provider[]) {\n        if (Array.isArray(providers)) {\n            this.#providers = [...this.#providers, ...providers]\n        } else {\n            this.#providers = [...this.#providers, providers]\n        }\n        return this\n    }\n}\n\nexport class FloatingTemplateFactory<T extends object> extends FloatingFactory {\n    constructor(\n        layer: LayerService,\n        public readonly tpl: TemplateRef<T>,\n        public readonly options: TemplatePortalOptions<T>\n    ) {\n        super(layer)\n    }\n\n    protected override create(): FloatingRef<FloatingChannel> {\n        const options: TemplatePortalOptions<T> = { ...this.options }\n        options.providers = this.providers(options.providers)\n        const container = this.layer.newTemplatePortal(this.tpl, options)\n        return container.injector.get(FloatingRef)\n    }\n}\n\nexport class FloatingComponentFactory<T extends ComponentType<any>> extends FloatingFactory {\n    constructor(\n        layer: LayerService,\n        public readonly component: T,\n        public readonly options: ComponentPortalOptions<T>\n    ) {\n        super(layer)\n    }\n\n    protected override create(): FloatingRef<FloatingChannel> {\n        const options: ComponentPortalOptions<T> = { ...this.options }\n        options.providers = this.providers(options.providers)\n        const container = this.layer.newComponentPortal(this.component, options)\n        return container.injector.get(FloatingRef)\n    }\n}\n\n/**\n * @example\n * ```typescript\n * class SomeComponent {}\n *\n * class SomeList {\n *      readonly floating = inject(FloatingService)\n *\n *      showComponent() {\n *          this.floating.from(SomeComponent).traits(position(), backdrop()).subscribe()\n *      }\n * ```\n */\n@Injectable()\nexport class FloatingService {\n    readonly #layer = inject(LayerService)\n    // readonly parent = inject(FloatingRef, { skipSelf: true, optional: true })\n\n    from<T extends ComponentType<any>>(component: T, opts?: ComponentPortalOptions<T>): FloatingComponentFactory<T>\n\n    from<T extends object>(tpl: TemplateRef<T>, opts?: TemplatePortalOptions<T>): FloatingTemplateFactory<T>\n\n    from<T>(value: ComponentType<T> | TemplateRef<T>, opts: any): FloatingFactory {\n        if (value instanceof TemplateRef) {\n            return new FloatingTemplateFactory(this.#layer, value as any, opts)\n        } else {\n            return new FloatingComponentFactory(this.#layer, value as any, opts)\n        }\n    }\n}\n"]}
|
|
@@ -1,3 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiX2Jhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL19iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sT0FBZ0IsYUFBYTtDQUlsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB0eXBlIHsgRmxvYXRpbmdSZWYgfSBmcm9tIFwiLi4vZmxvYXRpbmctcmVmXCJcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEZsb2F0aW5nVHJhaXQ8VCA9IGFueT4ge1xuICAgIGFic3RyYWN0IHJlYWRvbmx5IG5hbWU6IHN0cmluZ1xuXG4gICAgYWJzdHJhY3QgY29ubmVjdChmbG9hdGluZ1JlZjogRmxvYXRpbmdSZWY8YW55Pik6IE9ic2VydmFibGU8VD5cbn1cbiJdfQ==
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiX2Jhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL19iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgdHlwZSB7IEZsb2F0aW5nUmVmIH0gZnJvbSBcIi4uL2Zsb2F0aW5nLXJlZlwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvYXRpbmdUcmFpdDxUID0gYW55PiB7XG4gICAgcmVhZG9ubHkgbmFtZTogc3RyaW5nXG5cbiAgICBjb25uZWN0KGZsb2F0aW5nUmVmOiBGbG9hdGluZ1JlZjxhbnk+KTogT2JzZXJ2YWJsZTxUPlxufVxuIl19
|
|
@@ -2,12 +2,10 @@ import { animate, AnimationBuilder, style } from "@angular/animations";
|
|
|
2
2
|
import { Observable } from "rxjs";
|
|
3
3
|
import { animationObservable } from "@ngutil/graphics";
|
|
4
4
|
import { Duration, Ease } from "@ngutil/style";
|
|
5
|
-
import { FloatingTrait } from "./_base";
|
|
6
5
|
// https://tympanus.net/Development/ModalWindowEffects/
|
|
7
6
|
const transitionDuration = Duration.FastMs;
|
|
8
|
-
export class AnimationTrait
|
|
7
|
+
export class AnimationTrait {
|
|
9
8
|
constructor(animation) {
|
|
10
|
-
super();
|
|
11
9
|
this.animation = animation;
|
|
12
10
|
this.name = "animation";
|
|
13
11
|
}
|
|
@@ -52,4 +50,4 @@ export const FadeAnimation = {
|
|
|
52
50
|
export function fadeAnimation() {
|
|
53
51
|
return new AnimationTrait(FadeAnimation);
|
|
54
52
|
}
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZmxvYXRpbmcvc3JjL2Zsb2F0aW5nL3RyYWl0cy9hbmltYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBcUIsS0FBSyxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFFekYsT0FBTyxFQUFFLFVBQVUsRUFBYyxNQUFNLE1BQU0sQ0FBQTtBQUU3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUN0RCxPQUFPLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQU85Qyx1REFBdUQ7QUFFdkQsTUFBTSxrQkFBa0IsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFBO0FBRTFDLE1BQU0sT0FBTyxjQUFjO0lBR3ZCLFlBQXFCLFNBQXVCO1FBQXZCLGNBQVMsR0FBVCxTQUFTLENBQWM7UUFGbkMsU0FBSSxHQUFHLFdBQVcsQ0FBQTtJQUVvQixDQUFDO0lBRWhELE9BQU8sQ0FBQyxXQUF3QjtRQUM1QixPQUFPLElBQUksVUFBVSxDQUFDLENBQUMsR0FBd0IsRUFBRSxFQUFFO1lBQy9DLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFBO1lBQ3BFLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFBO1lBQ25ELFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUUsQ0FDakMsbUJBQW1CLENBQUMsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDLENBQzVFLENBQUE7WUFDRCxXQUFXLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQ25DLG1CQUFtQixDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUM1RSxDQUFBO1lBQ0QsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFBO1FBQ2QsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDO0NBQ0o7QUFFRCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQWlCO0lBQ3ZDLElBQUksRUFBRTtRQUNGLEtBQUssQ0FBQztZQUNGLDRCQUE0QjtZQUM1QixTQUFTLEVBQUUsWUFBWTtZQUN2QixVQUFVLEVBQUUsU0FBUztZQUNyQixPQUFPLEVBQUUsR0FBRztTQUNmLENBQUM7UUFDRixPQUFPLENBQ0gsR0FBRyxrQkFBa0IsTUFBTSxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQzlDLEtBQUssQ0FBQztZQUNGLFNBQVMsRUFBRSxVQUFVO1lBQ3JCLE9BQU8sRUFBRSxHQUFHO1NBQ2YsQ0FBQyxDQUNMO0tBQ0o7SUFDRCxJQUFJLEVBQUU7UUFDRixPQUFPLENBQ0gsR0FBRyxrQkFBa0IsTUFBTSxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQzlDLEtBQUssQ0FBQztZQUNGLFNBQVMsRUFBRSxZQUFZO1lBQ3ZCLFVBQVUsRUFBRSxTQUFTO1lBQ3JCLE9BQU8sRUFBRSxHQUFHO1NBQ2YsQ0FBQyxDQUNMO0tBQ0o7Q0FDSixDQUFBO0FBRUQsTUFBTSxVQUFVLGFBQWE7SUFDekIsT0FBTyxJQUFJLGNBQWMsQ0FBQyxhQUFhLENBQUMsQ0FBQTtBQUM1QyxDQUFDO0FBRUQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFpQjtJQUN2QyxJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxPQUFPLENBQUMsR0FBRyxrQkFBa0IsTUFBTSxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM3RyxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUMsR0FBRyxrQkFBa0IsTUFBTSxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztDQUN6RixDQUFBO0FBRUQsTUFBTSxVQUFVLGFBQWE7SUFDekIsT0FBTyxJQUFJLGNBQWMsQ0FBQyxhQUFhLENBQUMsQ0FBQTtBQUM1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYW5pbWF0ZSwgQW5pbWF0aW9uQnVpbGRlciwgQW5pbWF0aW9uTWV0YWRhdGEsIHN0eWxlIH0gZnJvbSBcIkBhbmd1bGFyL2FuaW1hdGlvbnNcIlxuXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJzY3JpYmVyIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgeyBhbmltYXRpb25PYnNlcnZhYmxlIH0gZnJvbSBcIkBuZ3V0aWwvZ3JhcGhpY3NcIlxuaW1wb3J0IHsgRHVyYXRpb24sIEVhc2UgfSBmcm9tIFwiQG5ndXRpbC9zdHlsZVwiXG5cbmltcG9ydCB7IEZsb2F0aW5nUmVmIH0gZnJvbSBcIi4uL2Zsb2F0aW5nLXJlZlwiXG5pbXBvcnQgeyBGbG9hdGluZ1RyYWl0IH0gZnJvbSBcIi4vX2Jhc2VcIlxuXG5leHBvcnQgdHlwZSBBbmltYXRpb25TZXQgPSB7IHNob3c6IEFuaW1hdGlvbk1ldGFkYXRhW107IGhpZGU6IEFuaW1hdGlvbk1ldGFkYXRhW10gfVxuXG4vLyBodHRwczovL3R5bXBhbnVzLm5ldC9EZXZlbG9wbWVudC9Nb2RhbFdpbmRvd0VmZmVjdHMvXG5cbmNvbnN0IHRyYW5zaXRpb25EdXJhdGlvbiA9IER1cmF0aW9uLkZhc3RNc1xuXG5leHBvcnQgY2xhc3MgQW5pbWF0aW9uVHJhaXQgaW1wbGVtZW50cyBGbG9hdGluZ1RyYWl0PHVua25vd24+IHtcbiAgICByZWFkb25seSBuYW1lID0gXCJhbmltYXRpb25cIlxuXG4gICAgY29uc3RydWN0b3IocmVhZG9ubHkgYW5pbWF0aW9uOiBBbmltYXRpb25TZXQpIHt9XG5cbiAgICBjb25uZWN0KGZsb2F0aW5nUmVmOiBGbG9hdGluZ1JlZik6IE9ic2VydmFibGU8dW5rbm93bj4ge1xuICAgICAgICByZXR1cm4gbmV3IE9ic2VydmFibGUoKGRzdDogU3Vic2NyaWJlcjx1bmtub3duPikgPT4ge1xuICAgICAgICAgICAgY29uc3QgYnVpbGRlciA9IGZsb2F0aW5nUmVmLmNvbnRhaW5lci5pbmplY3Rvci5nZXQoQW5pbWF0aW9uQnVpbGRlcilcbiAgICAgICAgICAgIGNvbnN0IGVsZW1lbnQgPSBmbG9hdGluZ1JlZi5jb250YWluZXIubmF0aXZlRWxlbWVudFxuICAgICAgICAgICAgZmxvYXRpbmdSZWYuc3RhdGUub24oXCJzaG93aW5nXCIsICgpID0+XG4gICAgICAgICAgICAgICAgYW5pbWF0aW9uT2JzZXJ2YWJsZSh7IGJ1aWxkZXIsIGVsZW1lbnQsIGFuaW1hdGlvbjogdGhpcy5hbmltYXRpb24uc2hvdyB9KVxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgZmxvYXRpbmdSZWYuc3RhdGUub24oXCJkaXNwb3NpbmdcIiwgKCkgPT5cbiAgICAgICAgICAgICAgICBhbmltYXRpb25PYnNlcnZhYmxlKHsgYnVpbGRlciwgZWxlbWVudCwgYW5pbWF0aW9uOiB0aGlzLmFuaW1hdGlvbi5oaWRlIH0pXG4gICAgICAgICAgICApXG4gICAgICAgICAgICBkc3QubmV4dCgpXG4gICAgICAgIH0pXG4gICAgfVxufVxuXG5leHBvcnQgY29uc3QgRmFsbEFuaW1hdGlvbjogQW5pbWF0aW9uU2V0ID0ge1xuICAgIHNob3c6IFtcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgICAgLy8gXCJwZXJzcGVjdGl2ZTpcIjogXCIxMzAwcHhcIixcbiAgICAgICAgICAgIHRyYW5zZm9ybTogXCJzY2FsZSgxLjUpXCIsXG4gICAgICAgICAgICB2aXNpYmlsaXR5OiBcInZpc2libGVcIixcbiAgICAgICAgICAgIG9wYWNpdHk6IFwiMFwiXG4gICAgICAgIH0pLFxuICAgICAgICBhbmltYXRlKFxuICAgICAgICAgICAgYCR7dHJhbnNpdGlvbkR1cmF0aW9ufW1zICR7RWFzZS5EZWNlbGVyYXRpb259YCxcbiAgICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm06IFwic2NhbGUoMSlcIixcbiAgICAgICAgICAgICAgICBvcGFjaXR5OiBcIjFcIlxuICAgICAgICAgICAgfSlcbiAgICAgICAgKVxuICAgIF0sXG4gICAgaGlkZTogW1xuICAgICAgICBhbmltYXRlKFxuICAgICAgICAgICAgYCR7dHJhbnNpdGlvbkR1cmF0aW9ufW1zICR7RWFzZS5EZWNlbGVyYXRpb259YCxcbiAgICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm06IFwic2NhbGUoMS41KVwiLFxuICAgICAgICAgICAgICAgIHZpc2liaWxpdHk6IFwidmlzaWJsZVwiLFxuICAgICAgICAgICAgICAgIG9wYWNpdHk6IFwiMFwiXG4gICAgICAgICAgICB9KVxuICAgICAgICApXG4gICAgXVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZmFsbEFuaW1hdGlvbigpIHtcbiAgICByZXR1cm4gbmV3IEFuaW1hdGlvblRyYWl0KEZhbGxBbmltYXRpb24pXG59XG5cbmV4cG9ydCBjb25zdCBGYWRlQW5pbWF0aW9uOiBBbmltYXRpb25TZXQgPSB7XG4gICAgc2hvdzogW3N0eWxlKHsgb3BhY2l0eTogMCB9KSwgYW5pbWF0ZShgJHt0cmFuc2l0aW9uRHVyYXRpb259bXMgJHtFYXNlLkRlY2VsZXJhdGlvbn1gLCBzdHlsZSh7IG9wYWNpdHk6IDEgfSkpXSxcbiAgICBoaWRlOiBbYW5pbWF0ZShgJHt0cmFuc2l0aW9uRHVyYXRpb259bXMgJHtFYXNlLkRlY2VsZXJhdGlvbn1gLCBzdHlsZSh7IG9wYWNpdHk6IDAgfSkpXVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZmFkZUFuaW1hdGlvbigpIHtcbiAgICByZXR1cm4gbmV3IEFuaW1hdGlvblRyYWl0KEZhZGVBbmltYXRpb24pXG59XG4iXX0=
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import { of } from "rxjs";
|
|
2
|
-
|
|
3
|
-
export class AttributeTrait extends FloatingTrait {
|
|
2
|
+
export class AttributeTrait {
|
|
4
3
|
constructor(attrs) {
|
|
5
|
-
super();
|
|
6
4
|
this.attrs = attrs;
|
|
7
5
|
this.name = "attribute";
|
|
8
6
|
}
|
|
@@ -25,4 +23,4 @@ export class AttributeTrait extends FloatingTrait {
|
|
|
25
23
|
export function attribute(attrs) {
|
|
26
24
|
return new AttributeTrait(attrs);
|
|
27
25
|
}
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0cmlidXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZmxvYXRpbmcvc3JjL2Zsb2F0aW5nL3RyYWl0cy9hdHRyaWJ1dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQTtBQVNyQyxNQUFNLE9BQU8sY0FBYztJQUd2QixZQUFxQixLQUFpQjtRQUFqQixVQUFLLEdBQUwsS0FBSyxDQUFZO1FBRjdCLFNBQUksR0FBRyxXQUFXLENBQUE7SUFFYyxDQUFDO0lBRTFDLE9BQU8sQ0FBQyxXQUF3QjtRQUM1QixNQUFNLEVBQUUsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQTtRQUU5QyxLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM5QyxJQUFJLENBQUMsS0FBSyxTQUFTLEVBQUUsQ0FBQztnQkFDbEIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQTtZQUNyQyxDQUFDO2lCQUFNLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDO2dCQUNuQixFQUFFLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxDQUFBO1lBQ3pCLENBQUM7aUJBQU0sQ0FBQztnQkFDSixFQUFFLENBQUMsWUFBWSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtZQUNwQyxDQUFDO1FBQ0wsQ0FBQztRQUVELE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUN6QixDQUFDO0NBQ0o7QUFFRCxNQUFNLFVBQVUsU0FBUyxDQUFDLEtBQWlCO0lBQ3ZDLE9BQU8sSUFBSSxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUE7QUFDcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgeyBQcmltaXRpdmUgfSBmcm9tIFwidXRpbGl0eS10eXBlc1wiXG5cbmltcG9ydCB7IEZsb2F0aW5nUmVmIH0gZnJvbSBcIi4uL2Zsb2F0aW5nLXJlZlwiXG5pbXBvcnQgeyBGbG9hdGluZ1RyYWl0IH0gZnJvbSBcIi4vX2Jhc2VcIlxuXG5leHBvcnQgdHlwZSBBdHRyaWJ1dGVzID0geyBba2V5OiBzdHJpbmddOiBQcmltaXRpdmUgfSB8IHsgZGF0YXNldDogeyBba2V5OiBzdHJpbmddOiBQcmltaXRpdmUgfSB9XG5cbmV4cG9ydCBjbGFzcyBBdHRyaWJ1dGVUcmFpdCBpbXBsZW1lbnRzIEZsb2F0aW5nVHJhaXQ8QXR0cmlidXRlcz4ge1xuICAgIHJlYWRvbmx5IG5hbWUgPSBcImF0dHJpYnV0ZVwiXG5cbiAgICBjb25zdHJ1Y3RvcihyZWFkb25seSBhdHRyczogQXR0cmlidXRlcykge31cblxuICAgIGNvbm5lY3QoZmxvYXRpbmdSZWY6IEZsb2F0aW5nUmVmKTogT2JzZXJ2YWJsZTxBdHRyaWJ1dGVzPiB7XG4gICAgICAgIGNvbnN0IGVsID0gZmxvYXRpbmdSZWYuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnRcblxuICAgICAgICBmb3IgKGNvbnN0IFtrLCB2XSBvZiBPYmplY3QuZW50cmllcyh0aGlzLmF0dHJzKSkge1xuICAgICAgICAgICAgaWYgKGsgPT09IFwiZGF0YXNldFwiKSB7XG4gICAgICAgICAgICAgICAgdiAmJiBPYmplY3QuYXNzaWduKGVsLmRhdGFzZXQsIHYpXG4gICAgICAgICAgICB9IGVsc2UgaWYgKHYgPT0gbnVsbCkge1xuICAgICAgICAgICAgICAgIGVsLnJlbW92ZUF0dHJpYnV0ZShrKVxuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICBlbC5zZXRBdHRyaWJ1dGUoaywgdi50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG9mKHRoaXMuYXR0cnMpXG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gYXR0cmlidXRlKGF0dHJzOiBBdHRyaWJ1dGVzKSB7XG4gICAgcmV0dXJuIG5ldyBBdHRyaWJ1dGVUcmFpdChhdHRycylcbn1cbiJdfQ==
|
|
@@ -1,16 +1,14 @@
|
|
|
1
1
|
import { AnimationBuilder } from "@angular/animations";
|
|
2
2
|
import { exhaustMap, map, Observable, Subject } from "rxjs";
|
|
3
3
|
import { animationObservable } from "@ngutil/graphics";
|
|
4
|
-
import { FloatingTrait } from "./_base";
|
|
5
4
|
import { FadeAnimation } from "./animation";
|
|
6
5
|
export class BackdropState {
|
|
7
6
|
constructor() {
|
|
8
7
|
this.onClick = new Subject();
|
|
9
8
|
}
|
|
10
9
|
}
|
|
11
|
-
export class BackdropTrait
|
|
10
|
+
export class BackdropTrait {
|
|
12
11
|
constructor(options) {
|
|
13
|
-
super();
|
|
14
12
|
this.options = options;
|
|
15
13
|
this.name = "backdrop";
|
|
16
14
|
}
|
|
@@ -75,4 +73,4 @@ export class BackdropTrait extends FloatingTrait {
|
|
|
75
73
|
export function backdrop(options) {
|
|
76
74
|
return new BackdropTrait(options);
|
|
77
75
|
}
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"backdrop.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/backdrop.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationBuilder } from \"@angular/animations\"\n\nimport { exhaustMap, map, Observable, Subject, Subscriber } from \"rxjs\"\n\nimport { animationObservable } from \"@ngutil/graphics\"\n\nimport type { BackdropOptions, BackdropRef, CropBackdropOptions } from \"../../layer/backdrop-ref\"\nimport { type FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\nimport { FadeAnimation } from \"./animation\"\nimport { FloatingPosition } from \"./position\"\n\nexport interface BackdropTraitOptions {\n    type: BackdropOptions[\"type\"]\n    color: BackdropOptions[\"color\"]\n    closeOnClick?: boolean\n    // TODO: maybe cropMargin\n}\n\nexport class BackdropState {\n    onClick: Observable<void> = new Subject<void>()\n}\n\nexport class BackdropTrait implements FloatingTrait<BackdropState> {\n    readonly name = \"backdrop\"\n\n    constructor(readonly options: BackdropTraitOptions) {}\n\n    connect(floatingRef: FloatingRef<any>): Observable<BackdropState> {\n        return new Observable((dest: Subscriber<BackdropState>) => {\n            const animationBuilder = floatingRef.container.injector.get(AnimationBuilder)\n            const options: BackdropOptions = {\n                type: this.options.type,\n                under: floatingRef.container,\n                color: this.options.color\n            } as any\n\n            if (this.options.type === \"crop\") {\n                ;(options as CropBackdropOptions).crop = floatingRef\n                    .watchTrait<FloatingPosition>(\"position\")\n                    .pipe(map(position => position.anchor))\n            }\n\n            const state = new BackdropState()\n            const backdrop = floatingRef.layerSvc.newBackdrop(options)\n            const removeOnClick = this.options.closeOnClick\n                ? this.#installClickHandler(floatingRef, backdrop, state)\n                : null\n\n            const onClickSub = this.options.closeOnClick\n                ? state.onClick.pipe(exhaustMap(() => floatingRef.close())).subscribe()\n                : null\n\n            backdrop.state.on(\"showing\", () =>\n                animationObservable({\n                    builder: animationBuilder,\n                    element: backdrop.nativeElement,\n                    animation: FadeAnimation.show\n                })\n            )\n            backdrop.state.on(\"disposing\", () =>\n                animationObservable({\n                    builder: animationBuilder,\n                    element: backdrop.nativeElement,\n                    animation: FadeAnimation.hide\n                })\n            )\n\n            floatingRef.state.on(\"disposing\", () => backdrop.dispose())\n\n            const backdropShowSub = backdrop.show().subscribe()\n            dest.next(state)\n\n            return () => {\n                removeOnClick && removeOnClick()\n                onClickSub?.unsubscribe()\n                backdropShowSub.unsubscribe()\n            }\n        })\n    }\n\n    #installClickHandler(floatingRef: FloatingRef<any>, backdrop: BackdropRef, state: BackdropState) {\n        const handler = (event: MouseEvent) => {\n            if (event.defaultPrevented) {\n                return\n            }\n\n            if (event.target === backdrop.nativeElement || backdrop.nativeElement.contains(event.target as Node)) {\n                ;(state.onClick as Subject<void>).next()\n            }\n        }\n\n        document.addEventListener(\"click\", handler)\n\n        return () => {\n            document.removeEventListener(\"click\", handler)\n        }\n    }\n}\n\nexport function backdrop(options: BackdropTraitOptions) {\n    return new BackdropTrait(options)\n}\n"]}
|
|
@@ -2,17 +2,15 @@ import { combineLatest, distinctUntilChanged, map, Observable, tap } from "rxjs"
|
|
|
2
2
|
import { clamp } from "lodash";
|
|
3
3
|
import { isElementInput } from "@ngutil/common";
|
|
4
4
|
import { DimensionWatcher } from "@ngutil/style";
|
|
5
|
-
import { FloatingTrait } from "./_base";
|
|
6
5
|
const DIM_MAP = {
|
|
7
6
|
maxWidth: { computedRef: "max", dimension: "width" },
|
|
8
7
|
maxHeight: { computedRef: "max", dimension: "height" },
|
|
9
8
|
minWidth: { computedRef: "min", dimension: "width" },
|
|
10
9
|
minHeight: { computedRef: "min", dimension: "height" }
|
|
11
10
|
};
|
|
12
|
-
export class DimensionConstraintTrait
|
|
11
|
+
export class DimensionConstraintTrait {
|
|
13
12
|
#map;
|
|
14
13
|
constructor(name, value) {
|
|
15
|
-
super();
|
|
16
14
|
this.value = value;
|
|
17
15
|
this.name = name;
|
|
18
16
|
this.#map = DIM_MAP[name];
|
|
@@ -27,13 +25,24 @@ export class DimensionConstraintTrait extends FloatingTrait {
|
|
|
27
25
|
position: floatingRef.watchTrait("position")
|
|
28
26
|
}).subscribe(({ refDim, position }) => {
|
|
29
27
|
const floating = position.computed?.floating;
|
|
30
|
-
|
|
28
|
+
if (!floating) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
dst.next(clamp(refDim, floating.min[this.#map.dimension] || 0, floating.max[this.#map.dimension] || Infinity));
|
|
31
32
|
});
|
|
32
33
|
}
|
|
33
34
|
else {
|
|
34
35
|
return floatingRef.watchTrait("position").subscribe(position => {
|
|
35
36
|
const floating = position.computed?.floating;
|
|
36
|
-
|
|
37
|
+
if (!floating) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (isNaN(this.value)) {
|
|
41
|
+
dst.next(floating[this.#map.computedRef][this.#map.dimension]);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
dst.next(clamp(this.value, floating?.min[this.#map.dimension] || 0, floating?.max[this.#map.dimension] || Infinity));
|
|
45
|
+
}
|
|
37
46
|
});
|
|
38
47
|
}
|
|
39
48
|
}).pipe(distinctUntilChanged(), tap(value => {
|
|
@@ -54,4 +63,4 @@ export function minWidth(value) {
|
|
|
54
63
|
export function minHeight(value) {
|
|
55
64
|
return new DimensionConstraintTrait("minHeight", value);
|
|
56
65
|
}
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dim-contraint.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/dim-contraint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,GAAG,EAAE,UAAU,EAAc,GAAG,EAAE,MAAM,MAAM,CAAA;AAE5F,OAAO,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAA;AAE9B,OAAO,EAAgB,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC7D,OAAO,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAA;AAa3D,MAAM,OAAO,GAAmC;IAC5C,QAAQ,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE;IACpD,SAAS,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE;IACtD,QAAQ,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE;IACpD,SAAS,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE;CACzD,CAAA;AAED,MAAM,OAAO,wBAAwB;IAExB,IAAI,CAAa;IAC1B,YACI,IAA0B,EACjB,KAA+B;QAA/B,UAAK,GAAL,KAAK,CAA0B;QAExC,IAAI,CAAC,IAAI,GAAG,IAAc,CAAA;QAC1B,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC7B,CAAC;IAED,OAAO,CAAC,WAA6B;QACjC,OAAO,IAAI,UAAU,CAAC,CAAC,GAAuB,EAAE,EAAE;YAC9C,IAAI,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC7B,MAAM,OAAO,GAAG,WAAW,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;gBACpE,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAA;gBACrG,OAAO,aAAa,CAAC;oBACjB,MAAM,EAAE,MAAM;oBACd,QAAQ,EAAE,WAAW,CAAC,UAAU,CAAmB,UAAU,CAAC;iBACjE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE;oBAClC,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAA;oBAC5C,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACZ,OAAM;oBACV,CAAC;oBACD,GAAG,CAAC,IAAI,CACJ,KAAK,CACD,MAAM,EACN,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EACtC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,QAAQ,CAChD,CACJ,CAAA;gBACL,CAAC,CAAC,CAAA;YACN,CAAC;iBAAM,CAAC;gBACJ,OAAO,WAAW,CAAC,UAAU,CAAmB,UAAU,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;oBAC7E,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAA;oBAC5C,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACZ,OAAM;oBACV,CAAC;oBACD,IAAI,KAAK,CAAC,IAAI,CAAC,KAAe,CAAC,EAAE,CAAC;wBAC9B,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;oBAClE,CAAC;yBAAM,CAAC;wBACJ,GAAG,CAAC,IAAI,CACJ,KAAK,CACD,IAAI,CAAC,KAAe,EACpB,QAAQ,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EACvC,QAAQ,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,QAAQ,CACjD,CACJ,CAAA;oBACL,CAAC;gBACL,CAAC,CAAC,CAAA;YACN,CAAC;QACL,CAAC,CAAC,CAAC,IAAI,CACH,oBAAoB,EAAE,EACtB,GAAG,CAAC,KAAK,CAAC,EAAE;YACR,MAAM,UAAU,GAAG,WAAW,CAAC,SAAS,CAAC,aAAa,CAAA;YACtD,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,IAAW,CAAC,GAAG,GAAG,KAAK,IAAI,CAAA;QACrD,CAAC,CAAC,CACL,CAAA;IACL,CAAC;CACJ;AAED,MAAM,UAAU,QAAQ,CAAC,KAA+B;IACpD,OAAO,IAAI,wBAAwB,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;AAC1D,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,KAA+B;IACrD,OAAO,IAAI,wBAAwB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;AAC3D,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,KAA+B;IACpD,OAAO,IAAI,wBAAwB,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;AAC1D,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,KAA+B;IACrD,OAAO,IAAI,wBAAwB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;AAC3D,CAAC","sourcesContent":["import { combineLatest, distinctUntilChanged, map, Observable, Subscriber, tap } from \"rxjs\"\n\nimport { clamp } from \"lodash\"\n\nimport { ElementInput, isElementInput } from \"@ngutil/common\"\nimport { Dimension, DimensionWatcher } from \"@ngutil/style\"\n\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\nimport type { FloatingPosition } from \"./position\"\n\nexport type DimensionConstraintInput = ElementInput | number\n\ninterface DimMapEntry {\n    computedRef: \"min\" | \"max\"\n    dimension: keyof Dimension\n}\n\nconst DIM_MAP: { [key: string]: DimMapEntry } = {\n    maxWidth: { computedRef: \"max\", dimension: \"width\" },\n    maxHeight: { computedRef: \"max\", dimension: \"height\" },\n    minWidth: { computedRef: \"min\", dimension: \"width\" },\n    minHeight: { computedRef: \"min\", dimension: \"height\" }\n}\n\nexport class DimensionConstraintTrait implements FloatingTrait<number> {\n    readonly name: string\n    readonly #map: DimMapEntry\n    constructor(\n        name: keyof typeof DIM_MAP,\n        readonly value: DimensionConstraintInput\n    ) {\n        this.name = name as string\n        this.#map = DIM_MAP[name]\n    }\n\n    connect(floatingRef: FloatingRef<any>): Observable<number> {\n        return new Observable((dst: Subscriber<number>) => {\n            if (isElementInput(this.value)) {\n                const watcher = floatingRef.container.injector.get(DimensionWatcher)\n                const refDim = watcher.watch(this.value, \"border-box\").pipe(map(value => value[this.#map.dimension]))\n                return combineLatest({\n                    refDim: refDim,\n                    position: floatingRef.watchTrait<FloatingPosition>(\"position\")\n                }).subscribe(({ refDim, position }) => {\n                    const floating = position.computed?.floating\n                    if (!floating) {\n                        return\n                    }\n                    dst.next(\n                        clamp(\n                            refDim,\n                            floating.min[this.#map.dimension] || 0,\n                            floating.max[this.#map.dimension] || Infinity\n                        )\n                    )\n                })\n            } else {\n                return floatingRef.watchTrait<FloatingPosition>(\"position\").subscribe(position => {\n                    const floating = position.computed?.floating\n                    if (!floating) {\n                        return\n                    }\n                    if (isNaN(this.value as number)) {\n                        dst.next(floating[this.#map.computedRef][this.#map.dimension])\n                    } else {\n                        dst.next(\n                            clamp(\n                                this.value as number,\n                                floating?.min[this.#map.dimension] || 0,\n                                floating?.max[this.#map.dimension] || Infinity\n                            )\n                        )\n                    }\n                })\n            }\n        }).pipe(\n            distinctUntilChanged(),\n            tap(value => {\n                const floatingEl = floatingRef.container.nativeElement\n                floatingEl.style[this.name as any] = `${value}px`\n            })\n        )\n    }\n}\n\nexport function maxWidth(value: DimensionConstraintInput) {\n    return new DimensionConstraintTrait(\"maxWidth\", value)\n}\n\nexport function maxHeight(value: DimensionConstraintInput) {\n    return new DimensionConstraintTrait(\"maxHeight\", value)\n}\n\nexport function minWidth(value: DimensionConstraintInput) {\n    return new DimensionConstraintTrait(\"minWidth\", value)\n}\n\nexport function minHeight(value: DimensionConstraintInput) {\n    return new DimensionConstraintTrait(\"minHeight\", value)\n}\n"]}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Observable, Subscription } from "rxjs";
|
|
2
|
+
import { FocusService } from "@ngutil/aria";
|
|
3
|
+
export class FocusTrait {
|
|
4
|
+
constructor(options) {
|
|
5
|
+
this.options = options;
|
|
6
|
+
this.name = "focus";
|
|
7
|
+
}
|
|
8
|
+
connect(floatingRef) {
|
|
9
|
+
return new Observable(() => {
|
|
10
|
+
const subs = new Subscription();
|
|
11
|
+
const originallyFocused = document.activeElement;
|
|
12
|
+
const svc = floatingRef.container.injector.get(FocusService);
|
|
13
|
+
if (this.options.connect) {
|
|
14
|
+
const tabindex = this.options.tabindex == null ? 0 : this.options.tabindex;
|
|
15
|
+
floatingRef.container.nativeElement.setAttribute("tabindex", tabindex.toString());
|
|
16
|
+
subs.add(this.options.connect.connect(floatingRef.container).subscribe());
|
|
17
|
+
}
|
|
18
|
+
if (this.options.trap) {
|
|
19
|
+
subs.add(this.#trap(floatingRef, svc).subscribe());
|
|
20
|
+
}
|
|
21
|
+
floatingRef.state.on("disposing", () => {
|
|
22
|
+
const active = document.activeElement;
|
|
23
|
+
const floating = floatingRef.container.nativeElement;
|
|
24
|
+
if (active === floating || floating.contains(active)) {
|
|
25
|
+
originallyFocused && document.contains(originallyFocused) && svc.focus(originallyFocused, "program");
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
return () => {
|
|
29
|
+
subs.unsubscribe();
|
|
30
|
+
};
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
#trap(floatingRef, svc) {
|
|
34
|
+
return new Observable(() => {
|
|
35
|
+
const trap = svc.focusTrap(floatingRef.container.nativeElement);
|
|
36
|
+
floatingRef.state.on("shown", () => {
|
|
37
|
+
trap.focusInitialElement();
|
|
38
|
+
});
|
|
39
|
+
return () => {
|
|
40
|
+
trap.destroy();
|
|
41
|
+
};
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
export function focus(options) {
|
|
46
|
+
return new FocusTrait(options);
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL2ZvY3VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBRS9DLE9BQU8sRUFBYSxZQUFZLEVBQWMsTUFBTSxjQUFjLENBQUE7QUFhbEUsTUFBTSxPQUFPLFVBQVU7SUFHbkIsWUFBcUIsT0FBcUI7UUFBckIsWUFBTyxHQUFQLE9BQU8sQ0FBYztRQUZqQyxTQUFJLEdBQUcsT0FBTyxDQUFBO0lBRXNCLENBQUM7SUFFOUMsT0FBTyxDQUFDLFdBQXdCO1FBQzVCLE9BQU8sSUFBSSxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ3ZCLE1BQU0sSUFBSSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUE7WUFDL0IsTUFBTSxpQkFBaUIsR0FBRyxRQUFRLENBQUMsYUFBNEIsQ0FBQTtZQUMvRCxNQUFNLEdBQUcsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLENBQUE7WUFFNUQsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUN2QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUE7Z0JBQzFFLFdBQVcsQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyxVQUFVLEVBQUUsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUE7Z0JBQ2pGLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFBO1lBQzdFLENBQUM7WUFFRCxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQ3BCLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsR0FBRyxDQUFDLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtZQUN0RCxDQUFDO1lBRUQsV0FBVyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsV0FBVyxFQUFFLEdBQUcsRUFBRTtnQkFDbkMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQTtnQkFDckMsTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUE7Z0JBQ3BELElBQUksTUFBTSxLQUFLLFFBQVEsSUFBSSxRQUFRLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7b0JBQ25ELGlCQUFpQixJQUFJLFFBQVEsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLGlCQUFpQixFQUFFLFNBQVMsQ0FBQyxDQUFBO2dCQUN4RyxDQUFDO1lBQ0wsQ0FBQyxDQUFDLENBQUE7WUFFRixPQUFPLEdBQUcsRUFBRTtnQkFDUixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUE7WUFDdEIsQ0FBQyxDQUFBO1FBQ0wsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQXdCLEVBQUUsR0FBaUI7UUFDN0MsT0FBTyxJQUFJLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDdkIsTUFBTSxJQUFJLEdBQUcsR0FBRyxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxDQUFBO1lBRS9ELFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7Z0JBQy9CLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFBO1lBQzlCLENBQUMsQ0FBQyxDQUFBO1lBRUYsT0FBTyxHQUFHLEVBQUU7Z0JBQ1IsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFBO1lBQ2xCLENBQUMsQ0FBQTtRQUNMLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQztDQUNKO0FBRUQsTUFBTSxVQUFVLEtBQUssQ0FBQyxPQUFxQjtJQUN2QyxPQUFPLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0FBQ2xDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJzY3JpcHRpb24gfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB7IEZvY3VzYWJsZSwgRm9jdXNTZXJ2aWNlLCBGb2N1c1N0YXRlIH0gZnJvbSBcIkBuZ3V0aWwvYXJpYVwiXG5pbXBvcnQgeyBFbGVtZW50SW5wdXQgfSBmcm9tIFwiQG5ndXRpbC9jb21tb25cIlxuXG5pbXBvcnQgeyBGbG9hdGluZ1JlZiB9IGZyb20gXCIuLi9mbG9hdGluZy1yZWZcIlxuaW1wb3J0IHsgRmxvYXRpbmdUcmFpdCB9IGZyb20gXCIuL19iYXNlXCJcblxuZXhwb3J0IGludGVyZmFjZSBGb2N1c09wdGlvbnMge1xuICAgIHRyYXA/OiBib29sZWFuXG4gICAgY29ubmVjdD86IEZvY3VzYWJsZSB8IEZvY3VzU3RhdGVcbiAgICB0YWJpbmRleD86IG51bWJlclxuICAgIGZvY3VzT25DbG9zZT86IEVsZW1lbnRJbnB1dFxufVxuXG5leHBvcnQgY2xhc3MgRm9jdXNUcmFpdCBpbXBsZW1lbnRzIEZsb2F0aW5nVHJhaXQ8dW5rbm93bj4ge1xuICAgIHJlYWRvbmx5IG5hbWUgPSBcImZvY3VzXCJcblxuICAgIGNvbnN0cnVjdG9yKHJlYWRvbmx5IG9wdGlvbnM6IEZvY3VzT3B0aW9ucykge31cblxuICAgIGNvbm5lY3QoZmxvYXRpbmdSZWY6IEZsb2F0aW5nUmVmKTogT2JzZXJ2YWJsZTx1bmtub3duPiB7XG4gICAgICAgIHJldHVybiBuZXcgT2JzZXJ2YWJsZSgoKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBzdWJzID0gbmV3IFN1YnNjcmlwdGlvbigpXG4gICAgICAgICAgICBjb25zdCBvcmlnaW5hbGx5Rm9jdXNlZCA9IGRvY3VtZW50LmFjdGl2ZUVsZW1lbnQgYXMgSFRNTEVsZW1lbnRcbiAgICAgICAgICAgIGNvbnN0IHN2YyA9IGZsb2F0aW5nUmVmLmNvbnRhaW5lci5pbmplY3Rvci5nZXQoRm9jdXNTZXJ2aWNlKVxuXG4gICAgICAgICAgICBpZiAodGhpcy5vcHRpb25zLmNvbm5lY3QpIHtcbiAgICAgICAgICAgICAgICBjb25zdCB0YWJpbmRleCA9IHRoaXMub3B0aW9ucy50YWJpbmRleCA9PSBudWxsID8gMCA6IHRoaXMub3B0aW9ucy50YWJpbmRleFxuICAgICAgICAgICAgICAgIGZsb2F0aW5nUmVmLmNvbnRhaW5lci5uYXRpdmVFbGVtZW50LnNldEF0dHJpYnV0ZShcInRhYmluZGV4XCIsIHRhYmluZGV4LnRvU3RyaW5nKCkpXG4gICAgICAgICAgICAgICAgc3Vicy5hZGQodGhpcy5vcHRpb25zLmNvbm5lY3QuY29ubmVjdChmbG9hdGluZ1JlZi5jb250YWluZXIpLnN1YnNjcmliZSgpKVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAodGhpcy5vcHRpb25zLnRyYXApIHtcbiAgICAgICAgICAgICAgICBzdWJzLmFkZCh0aGlzLiN0cmFwKGZsb2F0aW5nUmVmLCBzdmMpLnN1YnNjcmliZSgpKVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBmbG9hdGluZ1JlZi5zdGF0ZS5vbihcImRpc3Bvc2luZ1wiLCAoKSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgYWN0aXZlID0gZG9jdW1lbnQuYWN0aXZlRWxlbWVudFxuICAgICAgICAgICAgICAgIGNvbnN0IGZsb2F0aW5nID0gZmxvYXRpbmdSZWYuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnRcbiAgICAgICAgICAgICAgICBpZiAoYWN0aXZlID09PSBmbG9hdGluZyB8fCBmbG9hdGluZy5jb250YWlucyhhY3RpdmUpKSB7XG4gICAgICAgICAgICAgICAgICAgIG9yaWdpbmFsbHlGb2N1c2VkICYmIGRvY3VtZW50LmNvbnRhaW5zKG9yaWdpbmFsbHlGb2N1c2VkKSAmJiBzdmMuZm9jdXMob3JpZ2luYWxseUZvY3VzZWQsIFwicHJvZ3JhbVwiKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pXG5cbiAgICAgICAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgc3Vicy51bnN1YnNjcmliZSgpXG4gICAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgfVxuXG4gICAgI3RyYXAoZmxvYXRpbmdSZWY6IEZsb2F0aW5nUmVmLCBzdmM6IEZvY3VzU2VydmljZSkge1xuICAgICAgICByZXR1cm4gbmV3IE9ic2VydmFibGUoKCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgdHJhcCA9IHN2Yy5mb2N1c1RyYXAoZmxvYXRpbmdSZWYuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnQpXG5cbiAgICAgICAgICAgIGZsb2F0aW5nUmVmLnN0YXRlLm9uKFwic2hvd25cIiwgKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRyYXAuZm9jdXNJbml0aWFsRWxlbWVudCgpXG4gICAgICAgICAgICB9KVxuXG4gICAgICAgICAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRyYXAuZGVzdHJveSgpXG4gICAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9jdXMob3B0aW9uczogRm9jdXNPcHRpb25zKSB7XG4gICAgcmV0dXJuIG5ldyBGb2N1c1RyYWl0KG9wdGlvbnMpXG59XG4iXX0=
|
|
@@ -2,11 +2,11 @@ export * from "./_base";
|
|
|
2
2
|
export * from "./animation";
|
|
3
3
|
export * from "./backdrop";
|
|
4
4
|
export * from "./dim-contraint";
|
|
5
|
-
export * from "./focus
|
|
5
|
+
export * from "./focus";
|
|
6
6
|
export * from "./keystroke";
|
|
7
7
|
export * from "./modal";
|
|
8
8
|
export * from "./position-calc";
|
|
9
9
|
export * from "./position";
|
|
10
10
|
export * from "./style";
|
|
11
11
|
export * from "./attribute";
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsU0FBUyxDQUFBO0FBQ3ZCLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsWUFBWSxDQUFBO0FBQzFCLGNBQWMsaUJBQWlCLENBQUE7QUFDL0IsY0FBYyxTQUFTLENBQUE7QUFDdkIsY0FBYyxhQUFhLENBQUE7QUFDM0IsY0FBYyxTQUFTLENBQUE7QUFDdkIsY0FBYyxpQkFBaUIsQ0FBQTtBQUMvQixjQUFjLFlBQVksQ0FBQTtBQUMxQixjQUFjLFNBQVMsQ0FBQTtBQUN2QixjQUFjLGFBQWEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL19iYXNlXCJcbmV4cG9ydCAqIGZyb20gXCIuL2FuaW1hdGlvblwiXG5leHBvcnQgKiBmcm9tIFwiLi9iYWNrZHJvcFwiXG5leHBvcnQgKiBmcm9tIFwiLi9kaW0tY29udHJhaW50XCJcbmV4cG9ydCAqIGZyb20gXCIuL2ZvY3VzXCJcbmV4cG9ydCAqIGZyb20gXCIuL2tleXN0cm9rZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9tb2RhbFwiXG5leHBvcnQgKiBmcm9tIFwiLi9wb3NpdGlvbi1jYWxjXCJcbmV4cG9ydCAqIGZyb20gXCIuL3Bvc2l0aW9uXCJcbmV4cG9ydCAqIGZyb20gXCIuL3N0eWxlXCJcbmV4cG9ydCAqIGZyb20gXCIuL2F0dHJpYnV0ZVwiXG4iXX0=
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
import { exhaustMap } from "rxjs";
|
|
2
2
|
import { KeystrokeService } from "@ngutil/aria";
|
|
3
|
-
|
|
4
|
-
export class KeystrokeTrait extends FloatingTrait {
|
|
3
|
+
export class KeystrokeTrait {
|
|
5
4
|
constructor() {
|
|
6
|
-
super(...arguments);
|
|
7
5
|
this.name = "keystroke";
|
|
8
6
|
}
|
|
9
7
|
connect(floatingRef) {
|
|
@@ -16,4 +14,4 @@ export class KeystrokeTrait extends FloatingTrait {
|
|
|
16
14
|
export function keystroke() {
|
|
17
15
|
return new KeystrokeTrait();
|
|
18
16
|
}
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5c3Ryb2tlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZmxvYXRpbmcvc3JjL2Zsb2F0aW5nL3RyYWl0cy9rZXlzdHJva2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBYyxNQUFNLE1BQU0sQ0FBQTtBQUU3QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxjQUFjLENBQUE7QUFLL0MsTUFBTSxPQUFPLGNBQWM7SUFBM0I7UUFDSSxTQUFJLEdBQUcsV0FBVyxDQUFBO0lBUXRCLENBQUM7SUFORyxPQUFPLENBQUMsV0FBd0I7UUFDNUIsTUFBTSxFQUFFLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUE7UUFDL0QsT0FBTyxFQUFFO2FBQ0osS0FBSyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7YUFDMUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFBO0lBQ3BELENBQUM7Q0FDSjtBQUVELE1BQU0sVUFBVSxTQUFTO0lBQ3JCLE9BQU8sSUFBSSxjQUFjLEVBQUUsQ0FBQTtBQUMvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZXhoYXVzdE1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCJcblxuaW1wb3J0IHsgS2V5c3Ryb2tlU2VydmljZSB9IGZyb20gXCJAbmd1dGlsL2FyaWFcIlxuXG5pbXBvcnQgeyBGbG9hdGluZ1JlZiB9IGZyb20gXCIuLi9mbG9hdGluZy1yZWZcIlxuaW1wb3J0IHsgRmxvYXRpbmdUcmFpdCB9IGZyb20gXCIuL19iYXNlXCJcblxuZXhwb3J0IGNsYXNzIEtleXN0cm9rZVRyYWl0IGltcGxlbWVudHMgRmxvYXRpbmdUcmFpdDx1bmtub3duPiB7XG4gICAgbmFtZSA9IFwia2V5c3Ryb2tlXCJcblxuICAgIGNvbm5lY3QoZmxvYXRpbmdSZWY6IEZsb2F0aW5nUmVmKTogT2JzZXJ2YWJsZTx1bmtub3duPiB7XG4gICAgICAgIGNvbnN0IGtzID0gZmxvYXRpbmdSZWYuY29udGFpbmVyLmluamVjdG9yLmdldChLZXlzdHJva2VTZXJ2aWNlKVxuICAgICAgICByZXR1cm4ga3NcbiAgICAgICAgICAgIC53YXRjaChmbG9hdGluZ1JlZi5jb250YWluZXIubmF0aXZlRWxlbWVudCwgeyBrZXk6IFwiRXNjYXBlXCIsIHN0YXRlOiBcInVwXCIgfSlcbiAgICAgICAgICAgIC5waXBlKGV4aGF1c3RNYXAoKCkgPT4gZmxvYXRpbmdSZWYuY2xvc2UoKSkpXG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24ga2V5c3Ryb2tlKCkge1xuICAgIHJldHVybiBuZXcgS2V5c3Ryb2tlVHJhaXQoKVxufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { fallAnimation } from "./animation";
|
|
2
2
|
import { backdrop } from "./backdrop";
|
|
3
|
-
import {
|
|
3
|
+
import { focus } from "./focus";
|
|
4
4
|
import { keystroke } from "./keystroke";
|
|
5
5
|
import { position } from "./position";
|
|
6
6
|
export function modal(options = {}) {
|
|
@@ -16,9 +16,9 @@ export function modal(options = {}) {
|
|
|
16
16
|
}
|
|
17
17
|
}),
|
|
18
18
|
backdrop({ type: "solid", color: "rgba(0, 0, 0, .3)", closeOnClick: options.closeOnBackdropClick }),
|
|
19
|
-
|
|
19
|
+
focus({ trap: true }),
|
|
20
20
|
keystroke(),
|
|
21
21
|
fallAnimation()
|
|
22
22
|
];
|
|
23
23
|
}
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL21vZGFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDM0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUNyQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sU0FBUyxDQUFBO0FBQy9CLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDdkMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQU1yQyxNQUFNLFVBQVUsS0FBSyxDQUFDLFVBQXdCLEVBQUU7SUFDNUMsT0FBTztRQUNILFFBQVEsQ0FBQztZQUNMLE1BQU0sRUFBRTtnQkFDSixHQUFHLEVBQUUsVUFBVTtnQkFDZixLQUFLLEVBQUUsZUFBZTthQUN6QjtZQUNELFNBQVMsRUFBRTtnQkFDUCxHQUFHLEVBQUUsVUFBVTtnQkFDZixPQUFPLEVBQUUsTUFBTTthQUNsQjtTQUNKLENBQUM7UUFDRixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxZQUFZLEVBQUUsT0FBTyxDQUFDLG9CQUFvQixFQUFFLENBQUM7UUFDbkcsS0FBSyxDQUFDLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ3JCLFNBQVMsRUFBRTtRQUNYLGFBQWEsRUFBRTtLQUNsQixDQUFBO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZhbGxBbmltYXRpb24gfSBmcm9tIFwiLi9hbmltYXRpb25cIlxuaW1wb3J0IHsgYmFja2Ryb3AgfSBmcm9tIFwiLi9iYWNrZHJvcFwiXG5pbXBvcnQgeyBmb2N1cyB9IGZyb20gXCIuL2ZvY3VzXCJcbmltcG9ydCB7IGtleXN0cm9rZSB9IGZyb20gXCIuL2tleXN0cm9rZVwiXG5pbXBvcnQgeyBwb3NpdGlvbiB9IGZyb20gXCIuL3Bvc2l0aW9uXCJcblxuZXhwb3J0IGludGVyZmFjZSBNb2RhbE9wdGlvbnMge1xuICAgIGNsb3NlT25CYWNrZHJvcENsaWNrPzogYm9vbGVhblxufVxuXG5leHBvcnQgZnVuY3Rpb24gbW9kYWwob3B0aW9uczogTW9kYWxPcHRpb25zID0ge30pIHtcbiAgICByZXR1cm4gW1xuICAgICAgICBwb3NpdGlvbih7XG4gICAgICAgICAgICBhbmNob3I6IHtcbiAgICAgICAgICAgICAgICByZWY6IFwidmlld3BvcnRcIixcbiAgICAgICAgICAgICAgICBhbGlnbjogXCJjZW50ZXIgbWlkZGxlXCJcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBwbGFjZW1lbnQ6IHtcbiAgICAgICAgICAgICAgICByZWY6IFwidmlld3BvcnRcIixcbiAgICAgICAgICAgICAgICBwYWRkaW5nOiBcIjE2cHhcIlxuICAgICAgICAgICAgfVxuICAgICAgICB9KSxcbiAgICAgICAgYmFja2Ryb3AoeyB0eXBlOiBcInNvbGlkXCIsIGNvbG9yOiBcInJnYmEoMCwgMCwgMCwgLjMpXCIsIGNsb3NlT25DbGljazogb3B0aW9ucy5jbG9zZU9uQmFja2Ryb3BDbGljayB9KSxcbiAgICAgICAgZm9jdXMoeyB0cmFwOiB0cnVlIH0pLFxuICAgICAgICBrZXlzdHJva2UoKSxcbiAgICAgICAgZmFsbEFuaW1hdGlvbigpXG4gICAgXVxufVxuIl19
|
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
import { ElementRef } from "@angular/core";
|
|
2
2
|
import { combineLatest, Observable } from "rxjs";
|
|
3
3
|
import { DimensionWatcher, RectWatcher } from "@ngutil/style";
|
|
4
|
-
import {
|
|
4
|
+
import { maxHeight, maxWidth } from "./dim-contraint";
|
|
5
5
|
import { computePosition } from "./position-calc";
|
|
6
6
|
export class FloatingAnchorRef extends ElementRef {
|
|
7
7
|
}
|
|
8
8
|
export class FloatingPlacementRef extends ElementRef {
|
|
9
9
|
}
|
|
10
|
-
export class PositionTrait
|
|
10
|
+
export class PositionTrait {
|
|
11
11
|
constructor(options) {
|
|
12
|
-
super();
|
|
13
12
|
this.name = "position";
|
|
14
13
|
const cloned = { ...options };
|
|
15
14
|
if (!cloned.placement) {
|
|
@@ -53,7 +52,7 @@ function refWatcher(rectWatcher, ref, floatingRef) {
|
|
|
53
52
|
}
|
|
54
53
|
}
|
|
55
54
|
export function position(options) {
|
|
56
|
-
return new PositionTrait(options);
|
|
55
|
+
return [new PositionTrait(options), maxWidth(NaN), maxHeight(NaN)];
|
|
57
56
|
}
|
|
58
57
|
export class FloatingPosition {
|
|
59
58
|
constructor(options, floating, anchor, placement) {
|
|
@@ -73,4 +72,4 @@ export class FloatingPosition {
|
|
|
73
72
|
floatingEl.style.top = `${this.computed.floating.current.y}px`;
|
|
74
73
|
}
|
|
75
74
|
}
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"position.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/position.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,OAAO,EAAE,aAAa,EAAE,UAAU,EAAc,MAAM,MAAM,CAAA;AAG5D,OAAO,EAA6B,gBAAgB,EAAQ,WAAW,EAAc,MAAM,eAAe,CAAA;AAI1G,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AACvC,OAAO,EAAmB,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAgBlE,MAAM,OAAO,iBAAkC,SAAQ,UAAa;CAAG;AAgBvE,MAAM,OAAO,oBAAsE,SAAQ,UAAa;CAAG;AAoB3G,MAAM,OAAO,aAAc,SAAQ,aAA+B;IAK9D,YAAY,OAAgC;QACxC,KAAK,EAAE,CAAA;QALX,SAAI,GAAG,UAAU,CAAA;QAMb,MAAM,MAAM,GAAG,EAAE,GAAG,OAAO,EAAE,CAAA;QAE7B,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YACpB,MAAM,CAAC,SAAS,GAAG,EAAE,GAAG,EAAE,UAAU,EAAE,CAAA;QAC1C,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YACjB,MAAM,CAAC,MAAM,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,EAAE,eAAe,EAAE,CAAA;QACzE,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,CAAC,OAAO,GAAG,EAAE,KAAK,EAAE,eAAe,EAAE,CAAA;QAC/C,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,MAAa,CAAA;IAChC,CAAC;IAED,OAAO,CAAC,WAA6B;QACjC,OAAO,IAAI,UAAU,CAAC,CAAC,IAAkC,EAAE,EAAE;YACzD,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,QAAQ,CAAA;YAC/C,MAAM,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;YACjD,MAAM,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;YAE7C,MAAM,OAAO,GAAY;gBACrB,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,EAAE,YAAY,CAAC;gBAC/D,MAAM,EAAE,UAAU,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,WAAW,CAAC;gBACrE,SAAS,EAAE,UAAU,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,WAAW,CAAC;aAC9E,CAAA;YAED,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,EAAE;gBACxE,MAAM,GAAG,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,CAAA;gBAC3E,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;gBACtB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YAClB,CAAC,CAAC,CAAA;QACN,CAAC,CAAC,CAAA;IACN,CAAC;CACJ;AAED,SAAS,UAAU,CAAC,WAAwB,EAAE,GAA6B,EAAE,WAA6B;IACtG,IAAI,GAAG,KAAK,OAAO,EAAE,CAAC;QAClB,OAAO,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;IACrE,CAAC;SAAM,IAAI,GAAG,KAAK,UAAU,IAAI,GAAG,YAAY,MAAM,EAAE,CAAC;QACrD,OAAO,WAAW,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAA;IAClD,CAAC;SAAM,CAAC;QACJ,OAAO,WAAW,CAAC,KAAK,CAAC,GAAG,EAAE,YAAY,CAAC,CAAA;IAC/C,CAAC;AACL,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,OAAgC;IACrD,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,CAAA;AACrC,CAAC;AAED,MAAM,OAAO,gBAAgB;IAEzB,YACa,OAA0C,EAC1C,QAAmB,EACnB,MAAY,EACZ,SAAe;QAHf,YAAO,GAAP,OAAO,CAAmC;QAC1C,aAAQ,GAAR,QAAQ,CAAW;QACnB,WAAM,GAAN,MAAM,CAAM;QACZ,cAAS,GAAT,SAAS,CAAM;QAExB,kDAAkD;QAClD,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CAAA;IAC7E,CAAC;IAED,KAAK,CAAC,WAAwB;QAC1B,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE,CAAC;YACxB,OAAM;QACV,CAAC;QAED,MAAM,UAAU,GAAG,WAAW,CAAC,SAAS,CAAC,aAAa,CAAA;QACtD,UAAU,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAA;QAC/D,UAAU,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAA;IAClE,CAAC;CACJ","sourcesContent":["import { ElementRef } from \"@angular/core\"\n\nimport { combineLatest, Observable, Subscriber } from \"rxjs\"\n\nimport { ElementInput } from \"@ngutil/common\"\nimport { AlignmentInput, Dimension, DimensionWatcher, Rect, RectWatcher, SidesInput } from \"@ngutil/style\"\n\nimport { LayerService } from \"../../layer/layer.service\"\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\nimport { ComputedPositon, computePosition } from \"./position-calc\"\n\nexport type FloatingTargetElementRef = ElementInput | Window | \"layer\" | \"viewport\"\n\nexport interface FloatingAlign {\n    align: AlignmentInput\n}\n\nexport interface FloatingAnchorPosition extends FloatingAlign {\n    margin?: SidesInput\n}\n\nexport interface FloatingAnchor extends FloatingAnchorPosition {\n    ref: FloatingTargetElementRef\n}\n\nexport class FloatingAnchorRef<T extends Node> extends ElementRef<T> {}\n\nexport interface FloatingContentPosition extends FloatingAlign {\n    margin?: SidesInput\n}\n\nexport interface FloatingContent extends FloatingContentPosition {}\n\nexport interface FloatingPlacementPosition {\n    padding?: SidesInput\n}\n\nexport interface FloatingPlacement extends FloatingPlacementPosition {\n    ref: FloatingTargetElementRef\n}\n\nexport class FloatingPlacementRef<T extends LayerService[\"root\"][\"nativeElement\"]> extends ElementRef<T> {}\n\nexport interface FloatingPositionOptions {\n    anchor?: FloatingAnchor\n    content?: FloatingContent\n    placement?: FloatingPlacement\n}\n\nexport type FloatingPositionOptionsNormalized = FloatingPositionOptions & {\n    anchor: FloatingAnchor\n    content: FloatingContent\n    placement: FloatingPlacement\n}\n\ntype Watches = {\n    floating: Observable<Dimension>\n    anchor: Observable<Rect>\n    placement: Observable<Rect>\n}\n\nexport class PositionTrait extends FloatingTrait<FloatingPosition> {\n    name = \"position\"\n\n    readonly options: FloatingPositionOptionsNormalized\n\n    constructor(options: FloatingPositionOptions) {\n        super()\n        const cloned = { ...options }\n\n        if (!cloned.placement) {\n            cloned.placement = { ref: \"viewport\" }\n        }\n\n        if (!cloned.anchor) {\n            cloned.anchor = { ref: cloned.placement.ref, align: \"center middle\" }\n        }\n\n        if (!cloned.content) {\n            cloned.content = { align: \"center middle\" }\n        }\n\n        this.options = cloned as any\n    }\n\n    connect(floatingRef: FloatingRef<any>): Observable<FloatingPosition> {\n        return new Observable((dest: Subscriber<FloatingPosition>) => {\n            const injector = floatingRef.container.injector\n            const dimWatcher = injector.get(DimensionWatcher)\n            const rectWatcher = injector.get(RectWatcher)\n\n            const watches: Watches = {\n                floating: dimWatcher.watch(floatingRef.container, \"border-box\"),\n                anchor: refWatcher(rectWatcher, this.options.anchor.ref, floatingRef),\n                placement: refWatcher(rectWatcher, this.options.placement.ref, floatingRef)\n            }\n\n            return combineLatest(watches).subscribe(({ floating, anchor, placement }) => {\n                const res = new FloatingPosition(this.options, floating, anchor, placement)\n                res.apply(floatingRef)\n                dest.next(res)\n            })\n        })\n    }\n}\n\nfunction refWatcher(rectWatcher: RectWatcher, ref: FloatingTargetElementRef, floatingRef: FloatingRef<any>) {\n    if (ref === \"layer\") {\n        return rectWatcher.watch(floatingRef.layerSvc.root, \"border-box\")\n    } else if (ref === \"viewport\" || ref instanceof Window) {\n        return rectWatcher.watch(window, \"border-box\")\n    } else {\n        return rectWatcher.watch(ref, \"border-box\")\n    }\n}\n\nexport function position(options: FloatingPositionOptions) {\n    return new PositionTrait(options)\n}\n\nexport class FloatingPosition {\n    readonly computed?: ComputedPositon\n    constructor(\n        readonly options: FloatingPositionOptionsNormalized,\n        readonly floating: Dimension,\n        readonly anchor: Rect,\n        readonly placement: Rect\n    ) {\n        // const frect: Rect = { x: 0, y: 0, ...floating }\n        this.computed = computePosition({ floating, anchor, placement, options })\n    }\n\n    apply(floatingRef: FloatingRef) {\n        if (this.computed == null) {\n            return\n        }\n\n        const floatingEl = floatingRef.container.nativeElement\n        floatingEl.style.left = `${this.computed.floating.current.x}px`\n        floatingEl.style.top = `${this.computed.floating.current.y}px`\n    }\n}\n"]}
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"position.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/position.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from \"@angular/core\"\n\nimport { combineLatest, Observable, Subscriber } from \"rxjs\"\n\nimport { ElementInput } from \"@ngutil/common\"\nimport { AlignmentInput, Dimension, DimensionWatcher, Rect, RectWatcher, SidesInput } from \"@ngutil/style\"\n\nimport { LayerService } from \"../../layer/layer.service\"\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\nimport { maxHeight, maxWidth } from \"./dim-contraint\"\nimport { ComputedPositon, computePosition } from \"./position-calc\"\n\nexport type FloatingTargetElementRef = ElementInput | Window | \"layer\" | \"viewport\"\n\nexport interface FloatingAlign {\n    align: AlignmentInput\n}\n\nexport interface FloatingAnchorPosition extends FloatingAlign {\n    margin?: SidesInput\n}\n\nexport interface FloatingAnchor extends FloatingAnchorPosition {\n    ref: FloatingTargetElementRef\n}\n\nexport class FloatingAnchorRef<T extends Node> extends ElementRef<T> {}\n\nexport interface FloatingContentPosition extends FloatingAlign {\n    margin?: SidesInput\n}\n\nexport interface FloatingContent extends FloatingContentPosition {}\n\nexport interface FloatingPlacementPosition {\n    padding?: SidesInput\n}\n\nexport interface FloatingPlacement extends FloatingPlacementPosition {\n    ref: FloatingTargetElementRef\n}\n\nexport class FloatingPlacementRef<T extends LayerService[\"root\"][\"nativeElement\"]> extends ElementRef<T> {}\n\nexport interface FloatingPositionOptions {\n    anchor?: FloatingAnchor\n    content?: FloatingContent\n    placement?: FloatingPlacement\n}\n\nexport type FloatingPositionOptionsNormalized = FloatingPositionOptions & {\n    anchor: FloatingAnchor\n    content: FloatingContent\n    placement: FloatingPlacement\n}\n\ntype Watches = {\n    floating: Observable<Dimension>\n    anchor: Observable<Rect>\n    placement: Observable<Rect>\n}\n\nexport class PositionTrait implements FloatingTrait<FloatingPosition> {\n    readonly name = \"position\"\n\n    readonly options: FloatingPositionOptionsNormalized\n\n    constructor(options: FloatingPositionOptions) {\n        const cloned = { ...options }\n\n        if (!cloned.placement) {\n            cloned.placement = { ref: \"viewport\" }\n        }\n\n        if (!cloned.anchor) {\n            cloned.anchor = { ref: cloned.placement.ref, align: \"center middle\" }\n        }\n\n        if (!cloned.content) {\n            cloned.content = { align: \"center middle\" }\n        }\n\n        this.options = cloned as any\n    }\n\n    connect(floatingRef: FloatingRef<any>): Observable<FloatingPosition> {\n        return new Observable((dest: Subscriber<FloatingPosition>) => {\n            const injector = floatingRef.container.injector\n            const dimWatcher = injector.get(DimensionWatcher)\n            const rectWatcher = injector.get(RectWatcher)\n\n            const watches: Watches = {\n                floating: dimWatcher.watch(floatingRef.container, \"border-box\"),\n                anchor: refWatcher(rectWatcher, this.options.anchor.ref, floatingRef),\n                placement: refWatcher(rectWatcher, this.options.placement.ref, floatingRef)\n            }\n\n            return combineLatest(watches).subscribe(({ floating, anchor, placement }) => {\n                const res = new FloatingPosition(this.options, floating, anchor, placement)\n                res.apply(floatingRef)\n                dest.next(res)\n            })\n        })\n    }\n}\n\nfunction refWatcher(rectWatcher: RectWatcher, ref: FloatingTargetElementRef, floatingRef: FloatingRef<any>) {\n    if (ref === \"layer\") {\n        return rectWatcher.watch(floatingRef.layerSvc.root, \"border-box\")\n    } else if (ref === \"viewport\" || ref instanceof Window) {\n        return rectWatcher.watch(window, \"border-box\")\n    } else {\n        return rectWatcher.watch(ref, \"border-box\")\n    }\n}\n\nexport function position(options: FloatingPositionOptions) {\n    return [new PositionTrait(options), maxWidth(NaN), maxHeight(NaN)]\n}\n\nexport class FloatingPosition {\n    readonly computed?: ComputedPositon\n    constructor(\n        readonly options: FloatingPositionOptionsNormalized,\n        readonly floating: Dimension,\n        readonly anchor: Rect,\n        readonly placement: Rect\n    ) {\n        // const frect: Rect = { x: 0, y: 0, ...floating }\n        this.computed = computePosition({ floating, anchor, placement, options })\n    }\n\n    apply(floatingRef: FloatingRef) {\n        if (this.computed == null) {\n            return\n        }\n\n        const floatingEl = floatingRef.container.nativeElement\n        floatingEl.style.left = `${this.computed.floating.current.x}px`\n        floatingEl.style.top = `${this.computed.floating.current.y}px`\n    }\n}\n"]}
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import { of } from "rxjs";
|
|
2
|
-
|
|
3
|
-
export class StyleTrait extends FloatingTrait {
|
|
2
|
+
export class StyleTrait {
|
|
4
3
|
constructor(styles) {
|
|
5
|
-
super();
|
|
6
4
|
this.styles = styles;
|
|
7
5
|
this.name = "style";
|
|
8
6
|
}
|
|
@@ -14,4 +12,4 @@ export class StyleTrait extends FloatingTrait {
|
|
|
14
12
|
export function style(styles) {
|
|
15
13
|
return new StyleTrait(styles);
|
|
16
14
|
}
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL3N0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUE7QUFLckMsTUFBTSxPQUFPLFVBQVU7SUFHbkIsWUFBcUIsTUFBb0M7UUFBcEMsV0FBTSxHQUFOLE1BQU0sQ0FBOEI7UUFGaEQsU0FBSSxHQUFHLE9BQU8sQ0FBQTtJQUVxQyxDQUFDO0lBRTdELE9BQU8sQ0FBQyxXQUF3QjtRQUM1QixNQUFNLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUE7UUFDckUsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQzFCLENBQUM7Q0FDSjtBQUVELE1BQU0sVUFBVSxLQUFLLENBQUMsTUFBb0M7SUFDdEQsT0FBTyxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQTtBQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tIFwicnhqc1wiXG5cbmltcG9ydCB7IEZsb2F0aW5nUmVmIH0gZnJvbSBcIi4uL2Zsb2F0aW5nLXJlZlwiXG5pbXBvcnQgeyBGbG9hdGluZ1RyYWl0IH0gZnJvbSBcIi4vX2Jhc2VcIlxuXG5leHBvcnQgY2xhc3MgU3R5bGVUcmFpdCBpbXBsZW1lbnRzIEZsb2F0aW5nVHJhaXQ8UGFydGlhbDxDU1NTdHlsZURlY2xhcmF0aW9uPj4ge1xuICAgIHJlYWRvbmx5IG5hbWUgPSBcInN0eWxlXCJcblxuICAgIGNvbnN0cnVjdG9yKHJlYWRvbmx5IHN0eWxlczogUGFydGlhbDxDU1NTdHlsZURlY2xhcmF0aW9uPikge31cblxuICAgIGNvbm5lY3QoZmxvYXRpbmdSZWY6IEZsb2F0aW5nUmVmKTogT2JzZXJ2YWJsZTxQYXJ0aWFsPENTU1N0eWxlRGVjbGFyYXRpb24+PiB7XG4gICAgICAgIE9iamVjdC5hc3NpZ24oZmxvYXRpbmdSZWYuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnQuc3R5bGUsIHRoaXMuc3R5bGVzKVxuICAgICAgICByZXR1cm4gb2YodGhpcy5zdHlsZXMpXG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gc3R5bGUoc3R5bGVzOiBQYXJ0aWFsPENTU1N0eWxlRGVjbGFyYXRpb24+KSB7XG4gICAgcmV0dXJuIG5ldyBTdHlsZVRyYWl0KHN0eWxlcylcbn1cbiJdfQ==
|