@ngutil/floating 0.0.64 → 0.0.66
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.service.mjs +1 -1
- package/esm2022/floating/traits/animation.mjs +46 -47
- package/esm2022/floating/traits/index.mjs +1 -3
- package/esm2022/floating/traits/modal.mjs +2 -2
- package/esm2022/floating/traits/position.mjs +47 -49
- package/esm2022/layer/container-ref.mjs +2 -1
- package/fesm2022/ngutil-floating.mjs +92 -193
- package/fesm2022/ngutil-floating.mjs.map +1 -1
- package/floating/floating.service.d.ts +2 -2
- package/floating/traits/animation.d.ts +9 -7
- package/floating/traits/index.d.ts +0 -2
- package/floating/traits/modal.d.ts +2 -2
- package/floating/traits/position.d.ts +34 -50
- package/package.json +4 -4
- package/esm2022/floating/traits/dim-contraint.mjs +0 -66
- package/esm2022/floating/traits/position-calc.mjs +0 -39
- package/floating/traits/dim-contraint.d.ts +0 -25
- package/floating/traits/position-calc.d.ts +0 -28
|
@@ -130,4 +130,4 @@ export class FloatingService {
|
|
|
130
130
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingService, decorators: [{
|
|
131
131
|
type: Injectable
|
|
132
132
|
}] });
|
|
133
|
-
//# 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 floatingSvc: FloatingService) {}\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.floatingSvc.layer },\n            { provide: FloatingService, useValue: this.floatingSvc },\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        floatingSvc: FloatingService,\n        public readonly tpl: TemplateRef<T>,\n        public readonly options: TemplatePortalOptions<T>\n    ) {\n        super(floatingSvc)\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.floatingSvc.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        floatingSvc: FloatingService,\n        public readonly component: T,\n        public readonly options: ComponentPortalOptions<T>\n    ) {\n        super(floatingSvc)\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.floatingSvc.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, value as any, opts)\n        } else {\n            return new FloatingComponentFactory(this, value as any, opts)\n        }\n    }\n}\n"]}
|
|
133
|
+
//# 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 { position, type PositionTraitOptions } from \"./traits/position\"\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 floatingSvc: FloatingService) {}\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.floatingSvc.layer },\n            { provide: FloatingService, useValue: this.floatingSvc },\n            FloatingRef,\n            ...this.#providers\n        ]\n\n        return providers\n    }\n\n    protected abstract create(): FloatingRef<FloatingChannel>\n\n    position(options: PositionTraitOptions) {\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        floatingSvc: FloatingService,\n        public readonly tpl: TemplateRef<T>,\n        public readonly options: TemplatePortalOptions<T>\n    ) {\n        super(floatingSvc)\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.floatingSvc.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        floatingSvc: FloatingService,\n        public readonly component: T,\n        public readonly options: ComponentPortalOptions<T>\n    ) {\n        super(floatingSvc)\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.floatingSvc.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, value as any, opts)\n        } else {\n            return new FloatingComponentFactory(this, value as any, opts)\n        }\n    }\n}\n"]}
|
|
@@ -1,53 +1,46 @@
|
|
|
1
1
|
import { animate, AnimationBuilder, style } from "@angular/animations";
|
|
2
|
-
import { map, Observable, switchMap, take, tap
|
|
2
|
+
import { map, Observable, of, switchMap, take, tap } from "rxjs";
|
|
3
3
|
import { animationObservable } from "@ngutil/graphics";
|
|
4
|
-
import {
|
|
4
|
+
import { Duration, Ease, floatingPositionDirection } from "@ngutil/style";
|
|
5
5
|
// https://tympanus.net/Development/ModalWindowEffects/
|
|
6
6
|
const timing = `${Duration.FastMs}ms ${Ease.Deceleration}`;
|
|
7
7
|
export class AnimationTrait {
|
|
8
|
-
constructor(animation,
|
|
8
|
+
constructor(animation, params) {
|
|
9
9
|
this.animation = animation;
|
|
10
|
-
this.
|
|
10
|
+
this.params = params;
|
|
11
11
|
this.name = "animation";
|
|
12
12
|
}
|
|
13
13
|
connect(floatingRef) {
|
|
14
14
|
return new Observable((dst) => {
|
|
15
15
|
const builder = floatingRef.container.injector.get(AnimationBuilder);
|
|
16
16
|
const element = floatingRef.container.nativeElement;
|
|
17
|
-
|
|
18
|
-
floatingRef.state.on("showing", () => animationParams(floatingRef, 0, options.params).pipe(switchMap(params => animationObservable({
|
|
17
|
+
floatingRef.state.on("showing", () => animationParams(floatingRef, this.params).pipe(switchMap(params => animationObservable({
|
|
19
18
|
builder,
|
|
20
19
|
element,
|
|
21
20
|
animation: this.animation.show,
|
|
22
|
-
options: {
|
|
21
|
+
options: { params }
|
|
23
22
|
}))));
|
|
24
|
-
floatingRef.state.on("disposing", () => animationParams(floatingRef,
|
|
23
|
+
floatingRef.state.on("disposing", () => animationParams(floatingRef, this.params).pipe(switchMap(params => animationObservable({
|
|
25
24
|
builder,
|
|
26
25
|
element,
|
|
27
26
|
animation: this.animation.hide,
|
|
28
|
-
options: {
|
|
27
|
+
options: { params }
|
|
29
28
|
})), tap(() => (element.style.display = "none"))));
|
|
30
29
|
floatingRef.state.on("disposing", () => dst.complete());
|
|
31
30
|
dst.next();
|
|
32
31
|
});
|
|
33
32
|
}
|
|
34
33
|
}
|
|
35
|
-
function animationParams(floatingRef,
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
return
|
|
40
|
-
const origin = position.computed ? alignmentToTransformOrigin(position.computed.content.align) : "center";
|
|
41
|
-
return {
|
|
42
|
-
origin,
|
|
43
|
-
...overrides
|
|
44
|
-
};
|
|
45
|
-
}));
|
|
34
|
+
function animationParams(floatingRef, params) {
|
|
35
|
+
if (params == null) {
|
|
36
|
+
return of({});
|
|
37
|
+
}
|
|
38
|
+
return floatingRef.watchTrait("position").pipe(take(1), map(params));
|
|
46
39
|
}
|
|
47
40
|
export const FallAnimation = {
|
|
48
41
|
show: [
|
|
49
42
|
style({
|
|
50
|
-
transform: "scale(
|
|
43
|
+
transform: "scale({{ scale }})",
|
|
51
44
|
visibility: "visible",
|
|
52
45
|
opacity: "0"
|
|
53
46
|
}),
|
|
@@ -58,51 +51,57 @@ export const FallAnimation = {
|
|
|
58
51
|
],
|
|
59
52
|
hide: [
|
|
60
53
|
animate(timing, style({
|
|
61
|
-
transform: "scale(
|
|
54
|
+
transform: "scale({{ scale }})",
|
|
62
55
|
visibility: "visible",
|
|
63
56
|
opacity: "0"
|
|
64
57
|
}))
|
|
65
58
|
]
|
|
66
59
|
};
|
|
67
|
-
export function fallAnimation(
|
|
68
|
-
return new AnimationTrait(FallAnimation,
|
|
60
|
+
export function fallAnimation(scale = 1.5) {
|
|
61
|
+
return new AnimationTrait(FallAnimation, () => {
|
|
62
|
+
return { scale };
|
|
63
|
+
});
|
|
69
64
|
}
|
|
70
65
|
export const FadeAnimation = {
|
|
71
66
|
show: [style({ opacity: 0 }), animate(timing, style({ opacity: 1 }))],
|
|
72
67
|
hide: [animate(timing, style({ opacity: 0 }))]
|
|
73
68
|
};
|
|
74
|
-
export function fadeAnimation(
|
|
75
|
-
return new AnimationTrait(FadeAnimation
|
|
69
|
+
export function fadeAnimation() {
|
|
70
|
+
return new AnimationTrait(FadeAnimation);
|
|
76
71
|
}
|
|
77
|
-
|
|
72
|
+
const SlideAnimation = {
|
|
78
73
|
show: [
|
|
79
74
|
style({
|
|
80
|
-
transform: "translate({{
|
|
75
|
+
transform: "translate({{ tx }}, {{ ty }})",
|
|
81
76
|
opacity: "0",
|
|
82
|
-
transformOrigin: "{{ origin }}",
|
|
77
|
+
// transformOrigin: "{{ origin }}",
|
|
83
78
|
visibility: "visible"
|
|
84
79
|
}),
|
|
85
80
|
animate(timing, style({
|
|
86
81
|
opacity: "1",
|
|
87
|
-
transform: "
|
|
82
|
+
transform: "translate(0px, 0px)"
|
|
88
83
|
}))
|
|
89
84
|
],
|
|
90
|
-
hide: [
|
|
91
|
-
animate(timing, style({ opacity: 0, transform: "translate(calc({{ translateX }} * -1), calc({{ translateY }} * -1))" }))
|
|
92
|
-
]
|
|
85
|
+
hide: [animate(timing, style({ opacity: 0, transform: "translate(calc({{ tx }} * -1), calc({{ ty }} * -1))" }))]
|
|
93
86
|
};
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
87
|
+
const SlideAnimationParams = {
|
|
88
|
+
center: { tx: 0, ty: 0 },
|
|
89
|
+
up: { tx: 0, ty: 1 },
|
|
90
|
+
down: { tx: 0, ty: -1 },
|
|
91
|
+
left: { tx: 1, ty: 0 },
|
|
92
|
+
right: { tx: -1, ty: 0 }
|
|
93
|
+
};
|
|
94
|
+
function slideAnimation(size) {
|
|
95
|
+
return new AnimationTrait(SlideAnimation, position => {
|
|
96
|
+
const direction = floatingPositionDirection(position);
|
|
97
|
+
const { tx, ty } = SlideAnimationParams[direction];
|
|
98
|
+
return { tx: `${tx * size}px`, ty: `${ty * size}px` };
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
export function slideNearAnimation(size = 40) {
|
|
102
|
+
return slideAnimation(size * -1);
|
|
103
|
+
}
|
|
104
|
+
export function slideAwayAnimation(size = 40) {
|
|
105
|
+
return slideAnimation(size);
|
|
107
106
|
}
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/animation.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationBuilder, AnimationMetadata, AnimationOptions, style } from \"@angular/animations\"\n\nimport { map, Observable, Subscriber, switchMap, take, tap, timer } from \"rxjs\"\n\nimport { animationObservable } from \"@ngutil/graphics\"\nimport { alignmentToTransformOrigin, Duration, Ease } from \"@ngutil/style\"\n\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\nimport { FloatingPosition } from \"./position\"\n\nexport type AnimationSet = { show: AnimationMetadata[]; hide: AnimationMetadata[] }\n\n// https://tympanus.net/Development/ModalWindowEffects/\n\nconst timing = `${Duration.FastMs}ms ${Ease.Deceleration}`\n\nexport class AnimationTrait implements FloatingTrait<unknown> {\n    readonly name = \"animation\"\n\n    constructor(\n        readonly animation: AnimationSet,\n        readonly options?: AnimationOptions\n    ) {}\n\n    connect(floatingRef: FloatingRef): Observable<unknown> {\n        return new Observable((dst: Subscriber<unknown>) => {\n            const builder = floatingRef.container.injector.get(AnimationBuilder)\n            const element = floatingRef.container.nativeElement\n            const options = this.options || {}\n\n            floatingRef.state.on(\"showing\", () =>\n                animationParams(floatingRef, 0, options.params).pipe(\n                    switchMap(params =>\n                        animationObservable({\n                            builder,\n                            element,\n                            animation: this.animation.show,\n                            options: { ...options, params }\n                        })\n                    )\n                )\n            )\n            floatingRef.state.on(\"disposing\", () =>\n                animationParams(floatingRef, 0, options.params).pipe(\n                    switchMap(params =>\n                        animationObservable({\n                            builder,\n                            element,\n                            animation: this.animation.hide,\n                            options: { ...options, params }\n                        })\n                    ),\n                    tap(() => (element.style.display = \"none\"))\n                )\n            )\n            floatingRef.state.on(\"disposing\", () => dst.complete())\n            dst.next()\n        })\n    }\n}\n\nfunction animationParams(\n    floatingRef: FloatingRef,\n    delay: number,\n    overrides: AnimationOptions[\"params\"]\n): Observable<AnimationOptions[\"params\"]> {\n    const src =\n        delay > 0\n            ? timer(delay).pipe(switchMap(() => floatingRef.watchTrait<FloatingPosition>(\"position\")))\n            : floatingRef.watchTrait<FloatingPosition>(\"position\")\n\n    return src.pipe(\n        take(1),\n        map(position => {\n            const origin = position.computed ? alignmentToTransformOrigin(position.computed!.content.align) : \"center\"\n            return {\n                origin,\n                ...overrides\n            }\n        })\n    )\n}\n\nexport const FallAnimation: AnimationSet = {\n    show: [\n        style({\n            transform: \"scale(1.5)\",\n            visibility: \"visible\",\n            opacity: \"0\"\n        }),\n        animate(\n            timing,\n            style({\n                transform: \"scale(1)\",\n                opacity: \"1\"\n            })\n        )\n    ],\n    hide: [\n        animate(\n            timing,\n            style({\n                transform: \"scale(1.5)\",\n                visibility: \"visible\",\n                opacity: \"0\"\n            })\n        )\n    ]\n}\n\nexport function fallAnimation(options?: AnimationOptions) {\n    return new AnimationTrait(FallAnimation, options)\n}\n\nexport const FadeAnimation: AnimationSet = {\n    show: [style({ opacity: 0 }), animate(timing, style({ opacity: 1 }))],\n    hide: [animate(timing, style({ opacity: 0 }))]\n}\n\nexport function fadeAnimation(options?: AnimationOptions) {\n    return new AnimationTrait(FadeAnimation, options)\n}\n\nexport const DropAnimation: AnimationSet = {\n    show: [\n        style({\n            transform: \"translate({{ translateX }}, {{ translateY }})\",\n            opacity: \"0\",\n            transformOrigin: \"{{ origin }}\",\n            visibility: \"visible\"\n        }),\n        animate(\n            timing,\n            style({\n                opacity: \"1\",\n                transform: \"scale(1, 1) translate(0px, 0px)\"\n            })\n        )\n    ],\n    hide: [\n        animate(\n            timing,\n            style({ opacity: 0, transform: \"translate(calc({{ translateX }} * -1), calc({{ translateY }} * -1))\" })\n        )\n    ]\n}\n\nexport function dropAnimation(options?: AnimationOptions) {\n    if (!options) {\n        options = {}\n    }\n\n    if (!options.params) {\n        options.params = {}\n    } else {\n        options.params = { ...options.params }\n    }\n\n    options.params[\"translateX\"] = \"0px\"\n    options.params[\"translateY\"] = \"-40px\"\n\n    return new AnimationTrait(DropAnimation, options)\n}\n"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/animation.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationBuilder, AnimationMetadata, style } from \"@angular/animations\"\n\nimport { map, Observable, of, Subscriber, switchMap, take, tap } from \"rxjs\"\n\nimport { animationObservable } from \"@ngutil/graphics\"\nimport { Duration, Ease, FloatingPosition, FloatingPositionDirection, floatingPositionDirection } from \"@ngutil/style\"\n\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\n\nexport type AnimationSet = { show: AnimationMetadata[]; hide: AnimationMetadata[] }\n\n// https://tympanus.net/Development/ModalWindowEffects/\n\nconst timing = `${Duration.FastMs}ms ${Ease.Deceleration}`\n\nexport type AnimationTraitParams = (position: FloatingPosition) => object\n\nexport class AnimationTrait implements FloatingTrait<unknown> {\n    readonly name = \"animation\"\n\n    constructor(\n        readonly animation: AnimationSet,\n        readonly params?: AnimationTraitParams\n    ) {}\n\n    connect(floatingRef: FloatingRef): Observable<unknown> {\n        return new Observable((dst: Subscriber<unknown>) => {\n            const builder = floatingRef.container.injector.get(AnimationBuilder)\n            const element = floatingRef.container.nativeElement\n\n            floatingRef.state.on(\"showing\", () =>\n                animationParams(floatingRef, this.params).pipe(\n                    switchMap(params =>\n                        animationObservable({\n                            builder,\n                            element,\n                            animation: this.animation.show,\n                            options: { params }\n                        })\n                    )\n                )\n            )\n            floatingRef.state.on(\"disposing\", () =>\n                animationParams(floatingRef, this.params).pipe(\n                    switchMap(params =>\n                        animationObservable({\n                            builder,\n                            element,\n                            animation: this.animation.hide,\n                            options: { params }\n                        })\n                    ),\n                    tap(() => (element.style.display = \"none\"))\n                )\n            )\n            floatingRef.state.on(\"disposing\", () => dst.complete())\n            dst.next()\n        })\n    }\n}\n\nfunction animationParams(floatingRef: FloatingRef, params?: AnimationTraitParams): Observable<object> {\n    if (params == null) {\n        return of({})\n    }\n\n    return floatingRef.watchTrait<FloatingPosition>(\"position\").pipe(take(1), map(params))\n}\n\nexport const FallAnimation: AnimationSet = {\n    show: [\n        style({\n            transform: \"scale({{ scale }})\",\n            visibility: \"visible\",\n            opacity: \"0\"\n        }),\n        animate(\n            timing,\n            style({\n                transform: \"scale(1)\",\n                opacity: \"1\"\n            })\n        )\n    ],\n    hide: [\n        animate(\n            timing,\n            style({\n                transform: \"scale({{ scale }})\",\n                visibility: \"visible\",\n                opacity: \"0\"\n            })\n        )\n    ]\n}\n\nexport function fallAnimation(scale: number = 1.5) {\n    return new AnimationTrait(FallAnimation, () => {\n        return { scale }\n    })\n}\n\nexport const FadeAnimation: AnimationSet = {\n    show: [style({ opacity: 0 }), animate(timing, style({ opacity: 1 }))],\n    hide: [animate(timing, style({ opacity: 0 }))]\n}\n\nexport function fadeAnimation() {\n    return new AnimationTrait(FadeAnimation)\n}\n\nconst SlideAnimation: AnimationSet = {\n    show: [\n        style({\n            transform: \"translate({{ tx }}, {{ ty }})\",\n            opacity: \"0\",\n            // transformOrigin: \"{{ origin }}\",\n            visibility: \"visible\"\n        }),\n        animate(\n            timing,\n            style({\n                opacity: \"1\",\n                transform: \"translate(0px, 0px)\"\n            })\n        )\n    ],\n    hide: [animate(timing, style({ opacity: 0, transform: \"translate(calc({{ tx }} * -1), calc({{ ty }} * -1))\" }))]\n}\n\nconst SlideAnimationParams: { [K in FloatingPositionDirection]: { tx: number; ty: number } } = {\n    center: { tx: 0, ty: 0 },\n    up: { tx: 0, ty: 1 },\n    down: { tx: 0, ty: -1 },\n    left: { tx: 1, ty: 0 },\n    right: { tx: -1, ty: 0 }\n}\n\nfunction slideAnimation(size: number) {\n    return new AnimationTrait(SlideAnimation, position => {\n        const direction = floatingPositionDirection(position)\n        const { tx, ty } = SlideAnimationParams[direction]\n        return { tx: `${tx * size}px`, ty: `${ty * size}px` }\n    })\n}\n\nexport function slideNearAnimation(size: number = 40) {\n    return slideAnimation(size * -1)\n}\n\nexport function slideAwayAnimation(size: number = 40) {\n    return slideAnimation(size)\n}\n"]}
|
|
@@ -2,11 +2,9 @@ export * from "./_base";
|
|
|
2
2
|
export * from "./animation";
|
|
3
3
|
export * from "./backdrop";
|
|
4
4
|
export * from "./close-trigger";
|
|
5
|
-
export * from "./dim-contraint";
|
|
6
5
|
export * from "./focus";
|
|
7
6
|
export * from "./modal";
|
|
8
|
-
export * from "./position-calc";
|
|
9
7
|
export * from "./position";
|
|
10
8
|
export * from "./style";
|
|
11
9
|
export * from "./attribute";
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsU0FBUyxDQUFBO0FBQ3ZCLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsWUFBWSxDQUFBO0FBQzFCLGNBQWMsaUJBQWlCLENBQUE7QUFDL0IsY0FBYyxTQUFTLENBQUE7QUFDdkIsY0FBYyxTQUFTLENBQUE7QUFDdkIsY0FBYyxZQUFZLENBQUE7QUFDMUIsY0FBYyxTQUFTLENBQUE7QUFDdkIsY0FBYyxhQUFhLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9fYmFzZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9hbmltYXRpb25cIlxuZXhwb3J0ICogZnJvbSBcIi4vYmFja2Ryb3BcIlxuZXhwb3J0ICogZnJvbSBcIi4vY2xvc2UtdHJpZ2dlclwiXG5leHBvcnQgKiBmcm9tIFwiLi9mb2N1c1wiXG5leHBvcnQgKiBmcm9tIFwiLi9tb2RhbFwiXG5leHBvcnQgKiBmcm9tIFwiLi9wb3NpdGlvblwiXG5leHBvcnQgKiBmcm9tIFwiLi9zdHlsZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9hdHRyaWJ1dGVcIlxuIl19
|
|
@@ -8,7 +8,7 @@ export function modal() {
|
|
|
8
8
|
position({
|
|
9
9
|
anchor: {
|
|
10
10
|
ref: "viewport",
|
|
11
|
-
|
|
11
|
+
link: "center middle"
|
|
12
12
|
},
|
|
13
13
|
placement: {
|
|
14
14
|
ref: "viewport",
|
|
@@ -21,4 +21,4 @@ export function modal() {
|
|
|
21
21
|
fallAnimation()
|
|
22
22
|
];
|
|
23
23
|
}
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL21vZGFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDM0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUNyQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLFNBQVMsQ0FBQTtBQUMvQixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBRXJDLE1BQU0sVUFBVSxLQUFLO0lBQ2pCLE9BQU87UUFDSCxRQUFRLENBQUM7WUFDTCxNQUFNLEVBQUU7Z0JBQ0osR0FBRyxFQUFFLFVBQVU7Z0JBQ2YsSUFBSSxFQUFFLGVBQWU7YUFDeEI7WUFDRCxTQUFTLEVBQUU7Z0JBQ1AsR0FBRyxFQUFFLFVBQVU7Z0JBQ2YsT0FBTyxFQUFFLE1BQU07YUFDbEI7U0FDSixDQUFDO1FBQ0YsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQztRQUN2RCxLQUFLLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDckIsWUFBWSxFQUFFO1FBQ2QsYUFBYSxFQUFFO0tBQ2xCLENBQUE7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZmFsbEFuaW1hdGlvbiB9IGZyb20gXCIuL2FuaW1hdGlvblwiXG5pbXBvcnQgeyBiYWNrZHJvcCB9IGZyb20gXCIuL2JhY2tkcm9wXCJcbmltcG9ydCB7IGNsb3NlVHJpZ2dlciB9IGZyb20gXCIuL2Nsb3NlLXRyaWdnZXJcIlxuaW1wb3J0IHsgZm9jdXMgfSBmcm9tIFwiLi9mb2N1c1wiXG5pbXBvcnQgeyBwb3NpdGlvbiB9IGZyb20gXCIuL3Bvc2l0aW9uXCJcblxuZXhwb3J0IGZ1bmN0aW9uIG1vZGFsKCkge1xuICAgIHJldHVybiBbXG4gICAgICAgIHBvc2l0aW9uKHtcbiAgICAgICAgICAgIGFuY2hvcjoge1xuICAgICAgICAgICAgICAgIHJlZjogXCJ2aWV3cG9ydFwiLFxuICAgICAgICAgICAgICAgIGxpbms6IFwiY2VudGVyIG1pZGRsZVwiXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgcGxhY2VtZW50OiB7XG4gICAgICAgICAgICAgICAgcmVmOiBcInZpZXdwb3J0XCIsXG4gICAgICAgICAgICAgICAgcGFkZGluZzogXCIxNnB4XCJcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSksXG4gICAgICAgIGJhY2tkcm9wKHsgdHlwZTogXCJzb2xpZFwiLCBjb2xvcjogXCJyZ2JhKDAsIDAsIDAsIC4zKVwiIH0pLFxuICAgICAgICBmb2N1cyh7IHRyYXA6IHRydWUgfSksXG4gICAgICAgIGNsb3NlVHJpZ2dlcigpLFxuICAgICAgICBmYWxsQW5pbWF0aW9uKClcbiAgICBdXG59XG4iXX0=
|
|
@@ -1,12 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import { computePosition } from "./position-calc";
|
|
6
|
-
export class FloatingAnchorRef extends ElementRef {
|
|
7
|
-
}
|
|
8
|
-
export class FloatingPlacementRef extends ElementRef {
|
|
9
|
-
}
|
|
1
|
+
import { combineLatest, distinctUntilChanged, isObservable, map, Observable, of, switchMap, takeUntil } from "rxjs";
|
|
2
|
+
import { isEqual } from "lodash";
|
|
3
|
+
import { isElementInput } from "@ngutil/common";
|
|
4
|
+
import { DimensionWatcher, floatingPosition, floatingPositionToStyle, RectWatcher } from "@ngutil/style";
|
|
10
5
|
export class PositionTrait {
|
|
11
6
|
constructor(options) {
|
|
12
7
|
this.name = "position";
|
|
@@ -15,10 +10,10 @@ export class PositionTrait {
|
|
|
15
10
|
cloned.placement = { ref: "viewport" };
|
|
16
11
|
}
|
|
17
12
|
if (!cloned.anchor) {
|
|
18
|
-
cloned.anchor = { ref: cloned.placement.ref,
|
|
13
|
+
cloned.anchor = { ref: cloned.placement.ref, link: "center middle" };
|
|
19
14
|
}
|
|
20
15
|
if (!cloned.content) {
|
|
21
|
-
cloned.content = {
|
|
16
|
+
cloned.content = { link: "center middle" };
|
|
22
17
|
}
|
|
23
18
|
this.options = cloned;
|
|
24
19
|
}
|
|
@@ -27,15 +22,27 @@ export class PositionTrait {
|
|
|
27
22
|
const injector = floatingRef.container.injector;
|
|
28
23
|
const dimWatcher = injector.get(DimensionWatcher);
|
|
29
24
|
const rectWatcher = injector.get(RectWatcher);
|
|
25
|
+
const constraints = this.options.content.constraints || {};
|
|
26
|
+
const constraintsWatches = {
|
|
27
|
+
minWidth: sizeWatcher(dimWatcher, "width", constraints.minWidth),
|
|
28
|
+
maxWidth: sizeWatcher(dimWatcher, "width", constraints.maxWidth),
|
|
29
|
+
minHeight: sizeWatcher(dimWatcher, "height", constraints.minHeight),
|
|
30
|
+
maxHeight: sizeWatcher(dimWatcher, "height", constraints.maxHeight)
|
|
31
|
+
};
|
|
30
32
|
const watches = {
|
|
31
|
-
|
|
33
|
+
content: dimWatcher.watch(floatingRef.container, "border-box"),
|
|
32
34
|
anchor: refWatcher(rectWatcher, this.options.anchor.ref, floatingRef),
|
|
33
|
-
placement: refWatcher(rectWatcher, this.options.placement.ref, floatingRef)
|
|
35
|
+
placement: refWatcher(rectWatcher, this.options.placement.ref, floatingRef),
|
|
36
|
+
constraints: combineLatest(constraintsWatches)
|
|
34
37
|
};
|
|
35
|
-
return combineLatest(watches)
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
38
|
+
return combineLatest(watches)
|
|
39
|
+
.pipe(distinctUntilChanged(isEqual))
|
|
40
|
+
.subscribe(dims => {
|
|
41
|
+
const pos = floatingPosition({ dims, options: this.options });
|
|
42
|
+
const floatingEl = floatingRef.container.nativeElement;
|
|
43
|
+
Object.assign(floatingEl.style, floatingPositionToStyle(pos));
|
|
44
|
+
Object.assign(floatingEl.style, constraintsToStyle(pos, dims.constraints));
|
|
45
|
+
dest.next(pos);
|
|
39
46
|
});
|
|
40
47
|
}).pipe(takeUntil(floatingRef.state.onExecute("disposing")));
|
|
41
48
|
}
|
|
@@ -51,38 +58,29 @@ function refWatcher(rectWatcher, ref, floatingRef) {
|
|
|
51
58
|
return rectWatcher.watch(ref, "border-box");
|
|
52
59
|
}
|
|
53
60
|
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
export class FloatingPosition {
|
|
58
|
-
constructor(options, floating, anchor, placement) {
|
|
59
|
-
this.options = options;
|
|
60
|
-
this.floating = floating;
|
|
61
|
-
this.anchor = anchor;
|
|
62
|
-
this.placement = placement;
|
|
63
|
-
// const frect: Rect = { x: 0, y: 0, ...floating }
|
|
64
|
-
this.computed = computePosition({ floating, anchor, placement, options });
|
|
61
|
+
function sizeWatcher(dimWatcher, prop, size) {
|
|
62
|
+
if (typeof size === "number") {
|
|
63
|
+
return of(size);
|
|
65
64
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
const computedContent = this.computed.content;
|
|
72
|
-
const style = { top: null, right: null, bottom: null, left: null };
|
|
73
|
-
if (computedContent.align.horizontal === "right") {
|
|
74
|
-
style["right"] = `${computedContent.right}px`;
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
style["left"] = `${computedContent.left}px`;
|
|
78
|
-
}
|
|
79
|
-
if (computedContent.align.vertical === "bottom") {
|
|
80
|
-
style["bottom"] = `${computedContent.bottom}px`;
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
style["top"] = `${computedContent.top}px`;
|
|
84
|
-
}
|
|
85
|
-
Object.assign(floatingEl.style, style);
|
|
65
|
+
else if (isElementInput(size)) {
|
|
66
|
+
return dimWatcher.watch(size, "border-box").pipe(map(value => value[prop]));
|
|
67
|
+
}
|
|
68
|
+
else if (isObservable(size)) {
|
|
69
|
+
return size.pipe(switchMap(value => sizeWatcher(dimWatcher, prop, value)));
|
|
86
70
|
}
|
|
71
|
+
return of(NaN);
|
|
72
|
+
}
|
|
73
|
+
function constraintsToStyle(pos, sizes) {
|
|
74
|
+
const { minWidth, maxWidth, minHeight, maxHeight } = sizes;
|
|
75
|
+
const { width, height } = pos.placement.area;
|
|
76
|
+
return {
|
|
77
|
+
minWidth: isNaN(minWidth) ? "auto" : `${Math.min(width, minWidth)}px`,
|
|
78
|
+
minHeight: isNaN(minHeight) ? "auto" : `${Math.min(height, minHeight)}px`,
|
|
79
|
+
maxWidth: isNaN(maxWidth) ? `${width}px` : `${Math.min(width, maxWidth)}px`,
|
|
80
|
+
maxHeight: isNaN(maxHeight) ? `${height}px` : `${Math.min(height, maxHeight)}px`
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
export function position(options) {
|
|
84
|
+
return new PositionTrait(options);
|
|
87
85
|
}
|
|
88
|
-
//# 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, takeUntil } 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\"]> 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        }).pipe(takeUntil(floatingRef.state.onExecute(\"disposing\")))\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        const computedContent = this.computed.content\n        const style: Record<string, string | null> = { top: null, right: null, bottom: null, left: null }\n\n        if (computedContent.align.horizontal === \"right\") {\n            style[\"right\"] = `${computedContent.right}px`\n        } else {\n            style[\"left\"] = `${computedContent.left}px`\n        }\n\n        if (computedContent.align.vertical === \"bottom\") {\n            style[\"bottom\"] = `${computedContent.bottom}px`\n        } else {\n            style[\"top\"] = `${computedContent.top}px`\n        }\n\n        Object.assign(floatingEl.style, style)\n    }\n}\n"]}
|
|
86
|
+
//# 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 {\n    combineLatest,\n    distinctUntilChanged,\n    isObservable,\n    map,\n    Observable,\n    of,\n    Subscriber,\n    switchMap,\n    takeUntil\n} from \"rxjs\"\n\nimport { isEqual } from \"lodash\"\n\nimport { ElementInput, isElementInput } from \"@ngutil/common\"\nimport {\n    Dimension,\n    DimensionWatcher,\n    floatingPosition,\n    FloatingPosition,\n    FloatingPositionAltInput,\n    FloatingPositionAnchorOptions,\n    FloatingPositionContentOptions,\n    FloatingPositionDims,\n    FloatingPositionPlacementOptions,\n    floatingPositionToStyle,\n    Rect,\n    RectWatcher\n} from \"@ngutil/style\"\n\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\n\nexport type PositionTraitElementRef = ElementInput | Window | \"layer\" | \"viewport\"\n\nexport type PositionTraitOptions = {\n    content?: Omit<FloatingPositionContentOptions, \"constraints\"> & { constraints?: SizeConstraintsInput }\n    anchor?: FloatingPositionAnchorOptions & { ref: PositionTraitElementRef }\n    placement?: FloatingPositionPlacementOptions & { ref: PositionTraitElementRef }\n    horizontalAlt?: FloatingPositionAltInput\n    verticalAlt?: FloatingPositionAltInput\n}\n\n/**\n * Width ot height input values\n *\n * - `number`: excact value\n * - `ElementInput`: element reference, and take the dimension from it\n * - `link`: take the dimension from the anchor element and only apply on connection dimension.\n *    eg.: `anchor.link = \"left bottom\"` and `content.link = \"left top\"`, in this case only width will be applied.\n */\ntype SizeInputConst = number | ElementInput\ntype SizeInput = SizeInputConst | Observable<SizeInputConst>\n\ninterface SizeConstraintsInput {\n    minWidth?: SizeInput\n    maxWidth?: SizeInput\n    minHeight?: SizeInput\n    maxHeight?: SizeInput\n}\n\ntype SizeConstraints = NonNullable<FloatingPositionDims[\"constraints\"]>\n\ntype Watches = {\n    content: Observable<Dimension>\n    anchor: Observable<Rect>\n    placement: Observable<Rect>\n    constraints: Observable<ConstraintsResult>\n}\n\ntype ConstraintWatches = { [K in keyof SizeConstraints]-?: Observable<NonNullable<SizeConstraints[K]>> }\ntype ConstraintsResult = Required<SizeConstraints>\n\nexport class PositionTrait implements FloatingTrait<FloatingPosition> {\n    readonly name = \"position\"\n\n    readonly options: Required<PositionTraitOptions>\n\n    constructor(options: PositionTraitOptions) {\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, link: \"center middle\" }\n        }\n\n        if (!cloned.content) {\n            cloned.content = { link: \"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 constraints = this.options.content.constraints || {}\n            const constraintsWatches: ConstraintWatches = {\n                minWidth: sizeWatcher(dimWatcher, \"width\", constraints.minWidth),\n                maxWidth: sizeWatcher(dimWatcher, \"width\", constraints.maxWidth),\n                minHeight: sizeWatcher(dimWatcher, \"height\", constraints.minHeight),\n                maxHeight: sizeWatcher(dimWatcher, \"height\", constraints.maxHeight)\n            }\n\n            const watches: Watches = {\n                content: 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                constraints: combineLatest(constraintsWatches)\n            }\n\n            return combineLatest(watches)\n                .pipe(distinctUntilChanged(isEqual))\n                .subscribe(dims => {\n                    const pos = floatingPosition({ dims, options: this.options })\n                    const floatingEl = floatingRef.container.nativeElement\n                    Object.assign(floatingEl.style, floatingPositionToStyle(pos))\n                    Object.assign(floatingEl.style, constraintsToStyle(pos, dims.constraints))\n                    dest.next(pos)\n                })\n        }).pipe(takeUntil(floatingRef.state.onExecute(\"disposing\")))\n    }\n}\n\nfunction refWatcher(rectWatcher: RectWatcher, ref: PositionTraitElementRef, 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\nfunction sizeWatcher(dimWatcher: DimensionWatcher, prop: \"width\" | \"height\", size?: SizeInput): Observable<number> {\n    if (typeof size === \"number\") {\n        return of(size)\n    } else if (isElementInput(size)) {\n        return dimWatcher.watch(size, \"border-box\").pipe(map(value => value[prop]))\n    } else if (isObservable(size)) {\n        return (size as Observable<number | ElementInput>).pipe(\n            switchMap(value => sizeWatcher(dimWatcher, prop, value))\n        )\n    }\n    return of(NaN)\n}\n\nfunction constraintsToStyle(pos: FloatingPosition, sizes: ConstraintsResult): Partial<CSSStyleDeclaration> {\n    const { minWidth, maxWidth, minHeight, maxHeight } = sizes\n    const { width, height } = pos.placement.area\n    return {\n        minWidth: isNaN(minWidth) ? \"auto\" : `${Math.min(width, minWidth)}px`,\n        minHeight: isNaN(minHeight) ? \"auto\" : `${Math.min(height, minHeight)}px`,\n        maxWidth: isNaN(maxWidth) ? `${width}px` : `${Math.min(width, maxWidth)}px`,\n        maxHeight: isNaN(maxHeight) ? `${height}px` : `${Math.min(height, maxHeight)}px`\n    }\n}\n\nexport function position(options: PositionTraitOptions) {\n    return new PositionTrait(options)\n}\n"]}
|
|
@@ -33,9 +33,10 @@ function createElement(options) {
|
|
|
33
33
|
div.style.flexDirection = "column";
|
|
34
34
|
div.style.alignItems = "stretch";
|
|
35
35
|
div.style.justifyContent = "stretch";
|
|
36
|
+
div.style.boxSizing = "border-box";
|
|
36
37
|
if (options.classes) {
|
|
37
38
|
div.classList.add(...options.classes);
|
|
38
39
|
}
|
|
39
40
|
return div;
|
|
40
41
|
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2Zsb2F0aW5nL3NyYy9sYXllci9jb250YWluZXItcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQVksTUFBTSxlQUFlLENBQUE7QUFFbEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFXbkQsTUFBTSxPQUFPLFlBQWEsU0FBUSxRQUFRO0lBS3RDLFlBQTRCLE9BQXlCO1FBQ2pELEtBQUssQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLEVBQUUsT0FBTyxDQUFDLFdBQVcsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUE7UUFEOUMsWUFBTyxHQUFQLE9BQU8sQ0FBa0I7UUFGM0MsaUJBQVksR0FBRyxjQUFjLENBQUE7UUFLbkMsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsSUFBSSxFQUFFLENBQUE7UUFDekMsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQzVCLFNBQVMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksRUFBRSxFQUFFLEdBQUcsU0FBUyxDQUFDO1lBQ2pELE1BQU0sRUFBRSxPQUFPLENBQUMsUUFBUTtZQUN4QixJQUFJLEVBQUUsSUFBSSxDQUFDLFlBQVk7U0FDMUIsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsVUFBVSxFQUFFLEdBQUcsRUFBRTtZQUMzQixPQUFRLElBQVksQ0FBQyxPQUFPLENBQUE7WUFDNUIsT0FBUSxJQUFZLENBQUMsUUFBUSxDQUFBO1FBQ2pDLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQztJQUVTLFlBQVk7UUFDbEIsT0FBTztZQUNILEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO1lBQ3JDLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO1NBQzVDLENBQUE7SUFDTCxDQUFDO0NBQ0o7QUFFRCxTQUFTLGFBQWEsQ0FBQyxPQUF5QjtJQUM1QyxNQUFNLEdBQUcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ3pDLEdBQUcsQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQTtJQUMvQixHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUE7SUFDbkIsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFBO0lBQ3BCLEdBQUcsQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLGFBQWEsQ0FBQTtJQUMvQixHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxhQUFhLENBQUE7SUFDakMsR0FBRyxDQUFDLEtBQUssQ0FBQyxhQUFhLEdBQUcsUUFBUSxDQUFBO0lBQ2xDLEdBQUcsQ0FBQyxLQUFLLENBQUMsVUFBVSxHQUFHLFNBQVMsQ0FBQTtJQUNoQyxHQUFHLENBQUMsS0FBSyxDQUFDLGNBQWMsR0FBRyxTQUFTLENBQUE7SUFDcEMsR0FBRyxDQUFDLEtBQUssQ0FBQyxTQUFTLEdBQUcsWUFBWSxDQUFBO0lBRWxDLElBQUksT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2xCLEdBQUcsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ3pDLENBQUM7SUFFRCxPQUFPLEdBQUcsQ0FBQTtBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RvciwgUHJvdmlkZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB7IEFsd2F5c09uVG9wLCBDaGlsZFJlZiB9IGZyb20gXCIuL2NoaWxkLXJlZlwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29udGFpbmVyT3B0aW9ucyB7XG4gICAgYWx3YXlzT25Ub3A/OiBBbHdheXNPblRvcFxuICAgIGVsZXZhdGlvbj86IG51bWJlclxuICAgIGNsYXNzZXM/OiBzdHJpbmdbXVxuICAgIGF0dHJpYnV0ZXM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+XG4gICAgaW5qZWN0b3I/OiBJbmplY3RvclxuICAgIHByb3ZpZGVycz86IFByb3ZpZGVyW11cbn1cblxuZXhwb3J0IGNsYXNzIENvbnRhaW5lclJlZiBleHRlbmRzIENoaWxkUmVmIHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgaW5qZWN0b3I6IEluamVjdG9yXG5cbiAgICBwcm90ZWN0ZWQgaW5qZWN0b3JOYW1lID0gXCJDb250YWluZXJSZWZcIlxuXG4gICAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IG9wdGlvbnM6IENvbnRhaW5lck9wdGlvbnMpIHtcbiAgICAgICAgc3VwZXIoY3JlYXRlRWxlbWVudChvcHRpb25zKSwgb3B0aW9ucy5hbHdheXNPblRvcCB8fCBBbHdheXNPblRvcC5Ob25lKVxuXG4gICAgICAgIGNvbnN0IHByb3ZpZGVycyA9IG9wdGlvbnMucHJvdmlkZXJzIHx8IFtdXG4gICAgICAgIHRoaXMuaW5qZWN0b3IgPSBJbmplY3Rvci5jcmVhdGUoe1xuICAgICAgICAgICAgcHJvdmlkZXJzOiBbLi4udGhpcy5nZXRQcm92aWRlcnMoKSwgLi4ucHJvdmlkZXJzXSxcbiAgICAgICAgICAgIHBhcmVudDogb3B0aW9ucy5pbmplY3RvcixcbiAgICAgICAgICAgIG5hbWU6IHRoaXMuaW5qZWN0b3JOYW1lXG4gICAgICAgIH0pXG5cbiAgICAgICAgdGhpcy5zdGF0ZS5vbihcImRpc3Bvc2VkXCIsICgpID0+IHtcbiAgICAgICAgICAgIGRlbGV0ZSAodGhpcyBhcyBhbnkpLm9wdGlvbnNcbiAgICAgICAgICAgIGRlbGV0ZSAodGhpcyBhcyBhbnkpLmluamVjdG9yXG4gICAgICAgIH0pXG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGdldFByb3ZpZGVycygpOiBQcm92aWRlcltdIHtcbiAgICAgICAgcmV0dXJuIFtcbiAgICAgICAgICAgIHsgcHJvdmlkZTogQ2hpbGRSZWYsIHVzZVZhbHVlOiB0aGlzIH0sXG4gICAgICAgICAgICB7IHByb3ZpZGU6IENvbnRhaW5lclJlZiwgdXNlVmFsdWU6IHRoaXMgfVxuICAgICAgICBdXG4gICAgfVxufVxuXG5mdW5jdGlvbiBjcmVhdGVFbGVtZW50KG9wdGlvbnM6IENvbnRhaW5lck9wdGlvbnMpOiBIVE1MRGl2RWxlbWVudCB7XG4gICAgY29uc3QgZGl2ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImRpdlwiKVxuICAgIGRpdi5zdHlsZS5wb3NpdGlvbiA9IFwiYWJzb2x1dGVcIlxuICAgIGRpdi5zdHlsZS50b3AgPSBcIjBcIlxuICAgIGRpdi5zdHlsZS5sZWZ0ID0gXCIwXCJcbiAgICBkaXYuc3R5bGUud2lkdGggPSBcIm1heC1jb250ZW50XCJcbiAgICBkaXYuc3R5bGUuZGlzcGxheSA9IFwiaW5saW5lLWZsZXhcIlxuICAgIGRpdi5zdHlsZS5mbGV4RGlyZWN0aW9uID0gXCJjb2x1bW5cIlxuICAgIGRpdi5zdHlsZS5hbGlnbkl0ZW1zID0gXCJzdHJldGNoXCJcbiAgICBkaXYuc3R5bGUuanVzdGlmeUNvbnRlbnQgPSBcInN0cmV0Y2hcIlxuICAgIGRpdi5zdHlsZS5ib3hTaXppbmcgPSBcImJvcmRlci1ib3hcIlxuXG4gICAgaWYgKG9wdGlvbnMuY2xhc3Nlcykge1xuICAgICAgICBkaXYuY2xhc3NMaXN0LmFkZCguLi5vcHRpb25zLmNsYXNzZXMpXG4gICAgfVxuXG4gICAgcmV0dXJuIGRpdlxufVxuIl19
|