@ngutil/floating 0.0.80 → 0.0.82
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/ngutil-floating.mjs +20 -21
- package/fesm2022/ngutil-floating.mjs.map +1 -1
- package/layer/layer-container.d.ts +1 -1
- package/package.json +8 -9
- package/esm2022/floating/floating-ref.mjs +0 -103
- package/esm2022/floating/floating.service.mjs +0 -133
- package/esm2022/floating/index.mjs +0 -4
- package/esm2022/floating/traits/_base.mjs +0 -2
- package/esm2022/floating/traits/animation.mjs +0 -129
- package/esm2022/floating/traits/attribute.mjs +0 -26
- package/esm2022/floating/traits/backdrop.mjs +0 -37
- package/esm2022/floating/traits/close-trigger.mjs +0 -90
- package/esm2022/floating/traits/focus.mjs +0 -46
- package/esm2022/floating/traits/index.mjs +0 -10
- package/esm2022/floating/traits/modal.mjs +0 -24
- package/esm2022/floating/traits/position.mjs +0 -110
- package/esm2022/floating/traits/style.mjs +0 -15
- package/esm2022/index.mjs +0 -17
- package/esm2022/layer/backdrop-ref.mjs +0 -33
- package/esm2022/layer/child-ref.mjs +0 -65
- package/esm2022/layer/container-ref.mjs +0 -42
- package/esm2022/layer/external-ref.mjs +0 -4
- package/esm2022/layer/index.mjs +0 -7
- package/esm2022/layer/layer-container.mjs +0 -110
- package/esm2022/layer/layer.service.mjs +0 -65
- package/esm2022/layer/portal-ref.mjs +0 -52
- package/esm2022/ngutil-floating.mjs +0 -5
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
import { Inject, Injectable, InjectionToken } from "@angular/core";
|
|
2
|
-
import { combineLatest, debounceTime, EMPTY, filter, map, ReplaySubject, shareReplay, startWith, take, takeUntil, takeWhile } from "rxjs";
|
|
3
|
-
import { Lifecycle } from "@ngutil/common";
|
|
4
|
-
import { ContainerRef } from "../layer/container-ref";
|
|
5
|
-
import { LayerService } from "../layer/layer.service";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "../layer/layer.service";
|
|
8
|
-
import * as i2 from "../layer/container-ref";
|
|
9
|
-
export const TRAITS = new InjectionToken("TRAITS");
|
|
10
|
-
let UID_COUNTER = 0;
|
|
11
|
-
export class FloatingRef {
|
|
12
|
-
#traits;
|
|
13
|
-
#untilCleanup;
|
|
14
|
-
#untilDisposed;
|
|
15
|
-
constructor(layerSvc, container, traits) {
|
|
16
|
-
this.layerSvc = layerSvc;
|
|
17
|
-
this.container = container;
|
|
18
|
-
this.channel = new ReplaySubject(1);
|
|
19
|
-
this.state = new Lifecycle({
|
|
20
|
-
init: {},
|
|
21
|
-
showing: {},
|
|
22
|
-
shown: {},
|
|
23
|
-
closing: { cancellable: false, order: "sequential" },
|
|
24
|
-
disposing: { cancellable: false },
|
|
25
|
-
disposed: { cancellable: false, order: "sequential" },
|
|
26
|
-
cleanup: { cancellable: false, order: "sequential" }
|
|
27
|
-
});
|
|
28
|
-
this.#traits = {};
|
|
29
|
-
this.#untilCleanup = this.state.onExecute("cleanup");
|
|
30
|
-
this.#untilDisposed = this.state.onExecute("disposed");
|
|
31
|
-
this.uid = `${++UID_COUNTER}`;
|
|
32
|
-
Object.assign(container.nativeElement.style, {
|
|
33
|
-
overflow: "hidden",
|
|
34
|
-
visibility: "hidden",
|
|
35
|
-
pointerEvents: "none"
|
|
36
|
-
});
|
|
37
|
-
container.nativeElement.setAttribute("data-floating", this.uid);
|
|
38
|
-
this.#traits = traits;
|
|
39
|
-
this.traitState$ = this.#traitState().pipe(shareReplay(1));
|
|
40
|
-
this.state.current$.pipe(takeWhile(state => state !== "cleanup", true)).subscribe(state => {
|
|
41
|
-
this.emit({ type: state });
|
|
42
|
-
});
|
|
43
|
-
this.state.on("init", () => this.traitState$.pipe(takeUntil(this.#untilCleanup), debounceTime(5), take(1)));
|
|
44
|
-
this.state.on("showing", () => {
|
|
45
|
-
container.nativeElement.style.visibility = "visible";
|
|
46
|
-
});
|
|
47
|
-
this.state.on("shown", () => {
|
|
48
|
-
container.nativeElement.style.pointerEvents = null;
|
|
49
|
-
});
|
|
50
|
-
this.state.on("disposing", () => {
|
|
51
|
-
container.nativeElement.style.pointerEvents = "none";
|
|
52
|
-
});
|
|
53
|
-
this.state.control(container.state);
|
|
54
|
-
}
|
|
55
|
-
show() {
|
|
56
|
-
return this.state.run("init", "showing", "shown");
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* @deprecated
|
|
60
|
-
*/
|
|
61
|
-
hide() {
|
|
62
|
-
return this.close(true);
|
|
63
|
-
}
|
|
64
|
-
close(force = false) {
|
|
65
|
-
if (force) {
|
|
66
|
-
return this.state.run("disposing", "disposed", "cleanup");
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
return this.state.run("closing", "disposing", "disposed", "cleanup");
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
emit(event) {
|
|
73
|
-
this.channel.next({ ...event, floatingRef: this });
|
|
74
|
-
}
|
|
75
|
-
setResult(data) {
|
|
76
|
-
this.emit({ type: "result", data });
|
|
77
|
-
this.close(true).subscribe();
|
|
78
|
-
}
|
|
79
|
-
watchTrait(name) {
|
|
80
|
-
return this.traitState$.pipe(takeUntil(this.#untilDisposed), map(state => state[name]), filter(value => value != null));
|
|
81
|
-
}
|
|
82
|
-
#traitState() {
|
|
83
|
-
const src = {};
|
|
84
|
-
for (const [k, v] of Object.entries(this.#traits)) {
|
|
85
|
-
src[k] = v.connect(this).pipe(takeUntil(this.#untilDisposed), startWith(null));
|
|
86
|
-
}
|
|
87
|
-
if (Object.keys(src).length === 0) {
|
|
88
|
-
return EMPTY;
|
|
89
|
-
}
|
|
90
|
-
else {
|
|
91
|
-
return combineLatest(src).pipe(shareReplay(1));
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingRef, deps: [{ token: i1.LayerService }, { token: i2.ContainerRef }, { token: TRAITS }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
95
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingRef }); }
|
|
96
|
-
}
|
|
97
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingRef, decorators: [{
|
|
98
|
-
type: Injectable
|
|
99
|
-
}], ctorParameters: () => [{ type: i1.LayerService }, { type: i2.ContainerRef }, { type: undefined, decorators: [{
|
|
100
|
-
type: Inject,
|
|
101
|
-
args: [TRAITS]
|
|
102
|
-
}] }] });
|
|
103
|
-
//# 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 {\n    combineLatest,\n    debounceTime,\n    EMPTY,\n    filter,\n    map,\n    Observable,\n    ReplaySubject,\n    shareReplay,\n    startWith,\n    take,\n    takeUntil,\n    takeWhile\n} from \"rxjs\"\n\nimport { Lifecycle } 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\ntype TraitState = { [key: string]: FloatingTraitEvent | null }\n\nlet UID_COUNTER = 0\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 Lifecycle({\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<TraitState>\n\n    readonly #untilCleanup = this.state.onExecute(\"cleanup\")\n    readonly #untilDisposed = this.state.onExecute(\"disposed\")\n\n    readonly uid = `${++UID_COUNTER}`\n\n    constructor(\n        readonly layerSvc: LayerService,\n        readonly container: ContainerRef,\n        @Inject(TRAITS) traits: Traits\n    ) {\n        Object.assign(container.nativeElement.style, {\n            overflow: \"hidden\",\n            visibility: \"hidden\",\n            pointerEvents: \"none\"\n        })\n        container.nativeElement.setAttribute(\"data-floating\", this.uid)\n\n        this.#traits = traits\n        this.traitState$ = this.#traitState().pipe(shareReplay(1))\n\n        this.state.current$.pipe(takeWhile(state => state !== \"cleanup\", true)).subscribe(state => {\n            this.emit({ type: state } as C)\n        })\n        this.state.on(\"init\", () => this.traitState$.pipe(takeUntil(this.#untilCleanup), debounceTime(5), take(1)))\n        this.state.on(\"showing\", () => {\n            container.nativeElement.style.visibility = \"visible\"\n        })\n        this.state.on(\"shown\", () => {\n            container.nativeElement.style.pointerEvents = null as any\n        })\n        this.state.on(\"disposing\", () => {\n            container.nativeElement.style.pointerEvents = \"none\"\n        })\n\n        this.state.control(container.state)\n    }\n\n    show() {\n        return this.state.run(\"init\", \"showing\", \"shown\")\n    }\n\n    /**\n     * @deprecated\n     */\n    hide() {\n        return this.close(true)\n    }\n\n    close(force = false) {\n        if (force) {\n            return this.state.run(\"disposing\", \"disposed\", \"cleanup\")\n        } else {\n            return this.state.run(\"closing\", \"disposing\", \"disposed\", \"cleanup\")\n        }\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.close(true).subscribe()\n    }\n\n    watchTrait<T>(name: string): Observable<T> {\n        return this.traitState$.pipe(\n            takeUntil(this.#untilDisposed),\n            map(state => state[name]),\n            filter(value => value != null)\n        ) as Observable<T>\n    }\n\n    #traitState(): Observable<TraitState> {\n        const src: { [key: string]: Observable<FloatingTraitEvent | null> } = {}\n\n        for (const [k, v] of Object.entries(this.#traits)) {\n            src[k] = v.connect(this).pipe(takeUntil(this.#untilDisposed), startWith(null))\n        }\n\n        if (Object.keys(src).length === 0) {\n            return EMPTY\n        } else {\n            return combineLatest(src).pipe(shareReplay(1))\n        }\n    }\n}\n"]}
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { inject, Injectable, TemplateRef } from "@angular/core";
|
|
2
|
-
import { Observable } from "rxjs";
|
|
3
|
-
import { LayerService } from "../layer/layer.service";
|
|
4
|
-
import { FloatingRef, TRAITS } from "./floating-ref";
|
|
5
|
-
import { position } from "./traits/position";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class FloatingFactory {
|
|
8
|
-
#providers;
|
|
9
|
-
constructor(floatingSvc) {
|
|
10
|
-
this.floatingSvc = floatingSvc;
|
|
11
|
-
this.traits = {};
|
|
12
|
-
this.#providers = [];
|
|
13
|
-
this.subscribe = (...args) => this.show().subscribe(...args);
|
|
14
|
-
}
|
|
15
|
-
trait(...traits) {
|
|
16
|
-
for (const trait of traits) {
|
|
17
|
-
if (Array.isArray(trait)) {
|
|
18
|
-
this.trait(...trait);
|
|
19
|
-
}
|
|
20
|
-
else {
|
|
21
|
-
this.traits[trait.name] = trait;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
return this;
|
|
25
|
-
}
|
|
26
|
-
show() {
|
|
27
|
-
return new Observable((dest) => {
|
|
28
|
-
let disposing = false;
|
|
29
|
-
const ref = this.create();
|
|
30
|
-
const channelSub = ref.channel.subscribe(event => {
|
|
31
|
-
dest.next(event);
|
|
32
|
-
if (event.type === "disposing") {
|
|
33
|
-
disposing = true;
|
|
34
|
-
}
|
|
35
|
-
if (event.type === "cleanup") {
|
|
36
|
-
dest.complete();
|
|
37
|
-
}
|
|
38
|
-
});
|
|
39
|
-
const showSub = ref.show().subscribe();
|
|
40
|
-
return () => {
|
|
41
|
-
showSub.unsubscribe();
|
|
42
|
-
channelSub.unsubscribe();
|
|
43
|
-
if (!disposing) {
|
|
44
|
-
ref.hide().subscribe();
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
providers(providers) {
|
|
50
|
-
if (!providers) {
|
|
51
|
-
providers = [];
|
|
52
|
-
}
|
|
53
|
-
providers = [
|
|
54
|
-
...providers,
|
|
55
|
-
{ provide: TRAITS, useValue: this.traits },
|
|
56
|
-
{ provide: LayerService, useValue: this.floatingSvc.layer },
|
|
57
|
-
{ provide: FloatingService, useValue: this.floatingSvc },
|
|
58
|
-
FloatingRef,
|
|
59
|
-
...this.#providers
|
|
60
|
-
];
|
|
61
|
-
return providers;
|
|
62
|
-
}
|
|
63
|
-
position(options) {
|
|
64
|
-
return this.trait(position(options));
|
|
65
|
-
}
|
|
66
|
-
provides(providers) {
|
|
67
|
-
if (Array.isArray(providers)) {
|
|
68
|
-
this.#providers = [...this.#providers, ...providers];
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
this.#providers = [...this.#providers, providers];
|
|
72
|
-
}
|
|
73
|
-
return this;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
export class FloatingTemplateFactory extends FloatingFactory {
|
|
77
|
-
constructor(floatingSvc, tpl, options) {
|
|
78
|
-
super(floatingSvc);
|
|
79
|
-
this.tpl = tpl;
|
|
80
|
-
this.options = options;
|
|
81
|
-
}
|
|
82
|
-
create() {
|
|
83
|
-
const options = { ...this.options };
|
|
84
|
-
options.providers = this.providers(options.providers);
|
|
85
|
-
const container = this.floatingSvc.layer.newTemplatePortal(this.tpl, options);
|
|
86
|
-
return container.injector.get(FloatingRef);
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
export class FloatingComponentFactory extends FloatingFactory {
|
|
90
|
-
constructor(floatingSvc, component, options) {
|
|
91
|
-
super(floatingSvc);
|
|
92
|
-
this.component = component;
|
|
93
|
-
this.options = options;
|
|
94
|
-
}
|
|
95
|
-
create() {
|
|
96
|
-
const options = { ...this.options };
|
|
97
|
-
options.providers = this.providers(options.providers);
|
|
98
|
-
const container = this.floatingSvc.layer.newComponentPortal(this.component, options);
|
|
99
|
-
return container.injector.get(FloatingRef);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* @example
|
|
104
|
-
* ```typescript
|
|
105
|
-
* class SomeComponent {}
|
|
106
|
-
*
|
|
107
|
-
* class SomeList {
|
|
108
|
-
* readonly floating = inject(FloatingService)
|
|
109
|
-
*
|
|
110
|
-
* showComponent() {
|
|
111
|
-
* this.floating.from(SomeComponent).traits(position(), backdrop()).subscribe()
|
|
112
|
-
* }
|
|
113
|
-
* ```
|
|
114
|
-
*/
|
|
115
|
-
export class FloatingService {
|
|
116
|
-
constructor() {
|
|
117
|
-
this.layer = inject(LayerService);
|
|
118
|
-
}
|
|
119
|
-
from(value, opts) {
|
|
120
|
-
if (value instanceof TemplateRef) {
|
|
121
|
-
return new FloatingTemplateFactory(this, value, opts);
|
|
122
|
-
}
|
|
123
|
-
else {
|
|
124
|
-
return new FloatingComponentFactory(this, value, opts);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
128
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingService }); }
|
|
129
|
-
}
|
|
130
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FloatingService, decorators: [{
|
|
131
|
-
type: Injectable
|
|
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 { 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,4 +0,0 @@
|
|
|
1
|
-
export * from "./traits";
|
|
2
|
-
export * from "./floating-ref";
|
|
3
|
-
export * from "./floating.service";
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxVQUFVLENBQUE7QUFDeEIsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLG9CQUFvQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vdHJhaXRzXCJcbmV4cG9ydCAqIGZyb20gXCIuL2Zsb2F0aW5nLXJlZlwiXG5leHBvcnQgKiBmcm9tIFwiLi9mbG9hdGluZy5zZXJ2aWNlXCJcbiJdfQ==
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiX2Jhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL19iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgdHlwZSB7IEZsb2F0aW5nUmVmIH0gZnJvbSBcIi4uL2Zsb2F0aW5nLXJlZlwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvYXRpbmdUcmFpdDxUID0gYW55PiB7XG4gICAgcmVhZG9ubHkgbmFtZTogc3RyaW5nXG5cbiAgICBjb25uZWN0KGZsb2F0aW5nUmVmOiBGbG9hdGluZ1JlZjxhbnk+KTogT2JzZXJ2YWJsZTxUPlxufVxuIl19
|
|
@@ -1,129 +0,0 @@
|
|
|
1
|
-
import { animate, AnimationBuilder, style } from "@angular/animations";
|
|
2
|
-
import { map, Observable, of, switchMap, take, tap } from "rxjs";
|
|
3
|
-
import { animationObservable, maxPossibleRadius } from "@ngutil/graphics";
|
|
4
|
-
import { Duration, Ease, rectContainsPoint, rectOrigin } from "@ngutil/style";
|
|
5
|
-
// https://tympanus.net/Development/ModalWindowEffects/
|
|
6
|
-
const timing = `${Duration.FastMs}ms ${Ease.Deceleration}`;
|
|
7
|
-
export class AnimationTrait {
|
|
8
|
-
constructor(animation, params) {
|
|
9
|
-
this.animation = animation;
|
|
10
|
-
this.params = params;
|
|
11
|
-
this.name = "animation";
|
|
12
|
-
}
|
|
13
|
-
connect(floatingRef) {
|
|
14
|
-
return new Observable((dst) => {
|
|
15
|
-
const builder = floatingRef.container.injector.get(AnimationBuilder);
|
|
16
|
-
const element = floatingRef.container.nativeElement;
|
|
17
|
-
floatingRef.state.on("showing", () => animationParams(floatingRef, this.params).pipe(switchMap(params => animationObservable({
|
|
18
|
-
builder,
|
|
19
|
-
element,
|
|
20
|
-
animation: this.animation.show,
|
|
21
|
-
options: { params }
|
|
22
|
-
}))));
|
|
23
|
-
floatingRef.state.on("disposing", () => animationParams(floatingRef, this.params).pipe(switchMap(params => animationObservable({
|
|
24
|
-
builder,
|
|
25
|
-
element,
|
|
26
|
-
animation: this.animation.hide,
|
|
27
|
-
options: { params }
|
|
28
|
-
})), tap(() => (element.style.display = "none"))));
|
|
29
|
-
floatingRef.state.on("disposing", () => dst.complete());
|
|
30
|
-
dst.next();
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
function animationParams(floatingRef, params) {
|
|
35
|
-
if (params == null) {
|
|
36
|
-
return of({});
|
|
37
|
-
}
|
|
38
|
-
return floatingRef.watchTrait("position").pipe(take(1), map(params));
|
|
39
|
-
}
|
|
40
|
-
export const FallAnimation = {
|
|
41
|
-
show: [
|
|
42
|
-
style({
|
|
43
|
-
transform: "scale({{ scale }})",
|
|
44
|
-
visibility: "visible",
|
|
45
|
-
opacity: "0"
|
|
46
|
-
}),
|
|
47
|
-
animate(timing, style({
|
|
48
|
-
transform: "scale(1)",
|
|
49
|
-
opacity: "1"
|
|
50
|
-
}))
|
|
51
|
-
],
|
|
52
|
-
hide: [
|
|
53
|
-
animate(timing, style({
|
|
54
|
-
transform: "scale({{ scale }})",
|
|
55
|
-
visibility: "visible",
|
|
56
|
-
opacity: "0"
|
|
57
|
-
}))
|
|
58
|
-
]
|
|
59
|
-
};
|
|
60
|
-
export function fallAnimation(scale = 1.5) {
|
|
61
|
-
return new AnimationTrait(FallAnimation, () => {
|
|
62
|
-
return { scale };
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
export const FadeAnimation = {
|
|
66
|
-
show: [style({ opacity: 0 }), animate(timing, style({ opacity: 1 }))],
|
|
67
|
-
hide: [animate(timing, style({ opacity: 0 }))]
|
|
68
|
-
};
|
|
69
|
-
export function fadeAnimation() {
|
|
70
|
-
return new AnimationTrait(FadeAnimation);
|
|
71
|
-
}
|
|
72
|
-
const SlideAnimation = {
|
|
73
|
-
show: [
|
|
74
|
-
style({
|
|
75
|
-
transform: "translate({{ tx }}, {{ ty }})",
|
|
76
|
-
opacity: "0",
|
|
77
|
-
// transformOrigin: "{{ origin }}",
|
|
78
|
-
visibility: "visible"
|
|
79
|
-
}),
|
|
80
|
-
animate(timing, style({
|
|
81
|
-
opacity: "1",
|
|
82
|
-
transform: "translate(0px, 0px)"
|
|
83
|
-
}))
|
|
84
|
-
],
|
|
85
|
-
hide: [animate(timing, style({ opacity: 0, transform: "translate(calc({{ tx }} * -1), calc({{ ty }} * -1))" }))]
|
|
86
|
-
};
|
|
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 { tx, ty } = SlideAnimationParams[position.direction];
|
|
97
|
-
return { tx: `${tx * size}px`, ty: `${ty * size}px` };
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
export function slideNearAnimation(size = 40) {
|
|
101
|
-
return slideAnimation(size * -1);
|
|
102
|
-
}
|
|
103
|
-
export function slideAwayAnimation(size = 40) {
|
|
104
|
-
return slideAnimation(size);
|
|
105
|
-
}
|
|
106
|
-
const RippleRevealAnimation = {
|
|
107
|
-
show: [
|
|
108
|
-
style({ clipPath: "circle({{ radiusStart }} at {{ origin }})" }),
|
|
109
|
-
animate(`{{ duration }}ms ${Ease.Acceleration}`, style({ clipPath: "circle({{ radiusEnd }} at {{ origin }})" }))
|
|
110
|
-
],
|
|
111
|
-
hide: [animate(timing, style({ opacity: 0 }))]
|
|
112
|
-
};
|
|
113
|
-
export function rippleRevealAnimation(options) {
|
|
114
|
-
const { origin, initialRadius = 0, duration = Duration.SlowMs } = options;
|
|
115
|
-
return new AnimationTrait(RippleRevealAnimation, position => {
|
|
116
|
-
const animOrigin = rectContainsPoint(position.content.rect, origin)
|
|
117
|
-
? origin
|
|
118
|
-
: rectOrigin(position.content.rect, "center middle");
|
|
119
|
-
const { x, y, width, height } = position.content.rect;
|
|
120
|
-
const radius = maxPossibleRadius(animOrigin.x, animOrigin.y, width, height);
|
|
121
|
-
return {
|
|
122
|
-
radiusStart: `${initialRadius}px`,
|
|
123
|
-
radiusEnd: `${radius}px`,
|
|
124
|
-
origin: `${animOrigin.x - x}px ${animOrigin.y - y}px`,
|
|
125
|
-
duration: duration
|
|
126
|
-
};
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
//# 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, maxPossibleRadius } from \"@ngutil/graphics\"\nimport {\n    Duration,\n    Ease,\n    FloatingPosition,\n    FloatingPositionDirection,\n    Position,\n    rectContainsPoint,\n    rectOrigin\n} 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 { tx, ty } = SlideAnimationParams[position.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\nconst RippleRevealAnimation: AnimationSet = {\n    show: [\n        style({ clipPath: \"circle({{ radiusStart }} at {{ origin }})\" }),\n        animate(`{{ duration }}ms ${Ease.Acceleration}`, style({ clipPath: \"circle({{ radiusEnd }} at {{ origin }})\" }))\n    ],\n    hide: [animate(timing, style({ opacity: 0 }))]\n}\n\ntype RippleRevealAnimationOptions = {\n    origin: Position\n    initialRadius?: number\n    duration?: number\n}\n\nexport function rippleRevealAnimation(options: RippleRevealAnimationOptions) {\n    const { origin, initialRadius = 0, duration = Duration.SlowMs } = options\n    return new AnimationTrait(RippleRevealAnimation, position => {\n        const animOrigin = rectContainsPoint(position.content.rect, origin)\n            ? origin\n            : rectOrigin(position.content.rect, \"center middle\")\n        const { x, y, width, height } = position.content.rect\n        const radius = maxPossibleRadius(animOrigin.x, animOrigin.y, width, height)\n        return {\n            radiusStart: `${initialRadius}px`,\n            radiusEnd: `${radius}px`,\n            origin: `${animOrigin.x - x}px ${animOrigin.y - y}px`,\n            duration: duration\n        }\n    })\n}\n"]}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { of } from "rxjs";
|
|
2
|
-
export class AttributeTrait {
|
|
3
|
-
constructor(attrs) {
|
|
4
|
-
this.attrs = attrs;
|
|
5
|
-
this.name = "attribute";
|
|
6
|
-
}
|
|
7
|
-
connect(floatingRef) {
|
|
8
|
-
const el = floatingRef.container.nativeElement;
|
|
9
|
-
for (const [k, v] of Object.entries(this.attrs)) {
|
|
10
|
-
if (k === "dataset") {
|
|
11
|
-
v && Object.assign(el.dataset, v);
|
|
12
|
-
}
|
|
13
|
-
else if (v == null) {
|
|
14
|
-
el.removeAttribute(k);
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
el.setAttribute(k, v.toString());
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
return of(this.attrs);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
export function attribute(attrs) {
|
|
24
|
-
return new AttributeTrait(attrs);
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0cmlidXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZmxvYXRpbmcvc3JjL2Zsb2F0aW5nL3RyYWl0cy9hdHRyaWJ1dGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQTtBQVNyQyxNQUFNLE9BQU8sY0FBYztJQUd2QixZQUFxQixLQUFpQjtRQUFqQixVQUFLLEdBQUwsS0FBSyxDQUFZO1FBRjdCLFNBQUksR0FBRyxXQUFXLENBQUE7SUFFYyxDQUFDO0lBRTFDLE9BQU8sQ0FBQyxXQUF3QjtRQUM1QixNQUFNLEVBQUUsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQTtRQUU5QyxLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM5QyxJQUFJLENBQUMsS0FBSyxTQUFTLEVBQUUsQ0FBQztnQkFDbEIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQTtZQUNyQyxDQUFDO2lCQUFNLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDO2dCQUNuQixFQUFFLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxDQUFBO1lBQ3pCLENBQUM7aUJBQU0sQ0FBQztnQkFDSixFQUFFLENBQUMsWUFBWSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtZQUNwQyxDQUFDO1FBQ0wsQ0FBQztRQUVELE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUN6QixDQUFDO0NBQ0o7QUFFRCxNQUFNLFVBQVUsU0FBUyxDQUFDLEtBQWlCO0lBQ3ZDLE9BQU8sSUFBSSxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUE7QUFDcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgeyBQcmltaXRpdmUgfSBmcm9tIFwidXRpbGl0eS10eXBlc1wiXG5cbmltcG9ydCB7IEZsb2F0aW5nUmVmIH0gZnJvbSBcIi4uL2Zsb2F0aW5nLXJlZlwiXG5pbXBvcnQgeyBGbG9hdGluZ1RyYWl0IH0gZnJvbSBcIi4vX2Jhc2VcIlxuXG5leHBvcnQgdHlwZSBBdHRyaWJ1dGVzID0geyBba2V5OiBzdHJpbmddOiBQcmltaXRpdmUgfSB8IHsgZGF0YXNldDogeyBba2V5OiBzdHJpbmddOiBQcmltaXRpdmUgfSB9XG5cbmV4cG9ydCBjbGFzcyBBdHRyaWJ1dGVUcmFpdCBpbXBsZW1lbnRzIEZsb2F0aW5nVHJhaXQ8QXR0cmlidXRlcz4ge1xuICAgIHJlYWRvbmx5IG5hbWUgPSBcImF0dHJpYnV0ZVwiXG5cbiAgICBjb25zdHJ1Y3RvcihyZWFkb25seSBhdHRyczogQXR0cmlidXRlcykge31cblxuICAgIGNvbm5lY3QoZmxvYXRpbmdSZWY6IEZsb2F0aW5nUmVmKTogT2JzZXJ2YWJsZTxBdHRyaWJ1dGVzPiB7XG4gICAgICAgIGNvbnN0IGVsID0gZmxvYXRpbmdSZWYuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnRcblxuICAgICAgICBmb3IgKGNvbnN0IFtrLCB2XSBvZiBPYmplY3QuZW50cmllcyh0aGlzLmF0dHJzKSkge1xuICAgICAgICAgICAgaWYgKGsgPT09IFwiZGF0YXNldFwiKSB7XG4gICAgICAgICAgICAgICAgdiAmJiBPYmplY3QuYXNzaWduKGVsLmRhdGFzZXQsIHYpXG4gICAgICAgICAgICB9IGVsc2UgaWYgKHYgPT0gbnVsbCkge1xuICAgICAgICAgICAgICAgIGVsLnJlbW92ZUF0dHJpYnV0ZShrKVxuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICBlbC5zZXRBdHRyaWJ1dGUoaywgdi50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG9mKHRoaXMuYXR0cnMpXG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gYXR0cmlidXRlKGF0dHJzOiBBdHRyaWJ1dGVzKSB7XG4gICAgcmV0dXJuIG5ldyBBdHRyaWJ1dGVUcmFpdChhdHRycylcbn1cbiJdfQ==
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { AnimationBuilder } from "@angular/animations";
|
|
2
|
-
import { Observable } from "rxjs";
|
|
3
|
-
import { animationObservable } from "@ngutil/graphics";
|
|
4
|
-
import { FadeAnimation } from "./animation";
|
|
5
|
-
export class BackdropTrait {
|
|
6
|
-
constructor(options) {
|
|
7
|
-
this.options = options;
|
|
8
|
-
this.name = "backdrop";
|
|
9
|
-
}
|
|
10
|
-
connect(floatingRef) {
|
|
11
|
-
return new Observable((dest) => {
|
|
12
|
-
const animationBuilder = floatingRef.container.injector.get(AnimationBuilder);
|
|
13
|
-
const options = { ...this.options };
|
|
14
|
-
const backdrop = floatingRef.layerSvc.newBackdrop(floatingRef.container, options);
|
|
15
|
-
floatingRef.container.nativeElement.setAttribute("data-floating-has-backdrop", "true");
|
|
16
|
-
backdrop.nativeElement.setAttribute("data-floating-backdrop", floatingRef.uid);
|
|
17
|
-
backdrop.state.on("showing", () => animationObservable({
|
|
18
|
-
builder: animationBuilder,
|
|
19
|
-
element: backdrop.nativeElement,
|
|
20
|
-
animation: FadeAnimation.show
|
|
21
|
-
}));
|
|
22
|
-
backdrop.state.on("disposing", () => animationObservable({
|
|
23
|
-
builder: animationBuilder,
|
|
24
|
-
element: backdrop.nativeElement,
|
|
25
|
-
animation: FadeAnimation.hide
|
|
26
|
-
}));
|
|
27
|
-
backdrop.state.on("disposed", () => dest.complete());
|
|
28
|
-
floatingRef.state.on("disposing", () => backdrop.dispose());
|
|
29
|
-
dest.add(backdrop.show().subscribe());
|
|
30
|
-
dest.next(backdrop);
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
export function backdrop(options) {
|
|
35
|
-
return new BackdropTrait(options);
|
|
36
|
-
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFja2Ryb3AuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mbG9hdGluZy9zcmMvZmxvYXRpbmcvdHJhaXRzL2JhY2tkcm9wLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBRXRELE9BQU8sRUFBRSxVQUFVLEVBQWMsTUFBTSxNQUFNLENBQUE7QUFFN0MsT0FBTyxFQUFFLG1CQUFtQixFQUFnQixNQUFNLGtCQUFrQixDQUFBO0FBS3BFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFNM0MsTUFBTSxPQUFPLGFBQWE7SUFHdEIsWUFBcUIsT0FBNkI7UUFBN0IsWUFBTyxHQUFQLE9BQU8sQ0FBc0I7UUFGekMsU0FBSSxHQUFHLFVBQVUsQ0FBQTtJQUUyQixDQUFDO0lBRXRELE9BQU8sQ0FBQyxXQUE2QjtRQUNqQyxPQUFPLElBQUksVUFBVSxDQUFDLENBQUMsSUFBNkIsRUFBRSxFQUFFO1lBQ3BELE1BQU0sZ0JBQWdCLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUE7WUFDN0UsTUFBTSxPQUFPLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQTtZQUNuQyxNQUFNLFFBQVEsR0FBRyxXQUFXLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFBO1lBRWpGLFdBQVcsQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyw0QkFBNEIsRUFBRSxNQUFNLENBQUMsQ0FBQTtZQUN0RixRQUFRLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyx3QkFBd0IsRUFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUE7WUFFOUUsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsU0FBUyxFQUFFLEdBQUcsRUFBRSxDQUM5QixtQkFBbUIsQ0FBQztnQkFDaEIsT0FBTyxFQUFFLGdCQUFnQjtnQkFDekIsT0FBTyxFQUFFLFFBQVEsQ0FBQyxhQUFhO2dCQUMvQixTQUFTLEVBQUUsYUFBYSxDQUFDLElBQUk7YUFDaEMsQ0FBQyxDQUNMLENBQUE7WUFDRCxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQ2hDLG1CQUFtQixDQUFDO2dCQUNoQixPQUFPLEVBQUUsZ0JBQWdCO2dCQUN6QixPQUFPLEVBQUUsUUFBUSxDQUFDLGFBQWE7Z0JBQy9CLFNBQVMsRUFBRSxhQUFhLENBQUMsSUFBSTthQUNoQyxDQUFDLENBQ0wsQ0FBQTtZQUVELFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtZQUVwRCxXQUFXLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUE7WUFFM0QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtZQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQ3ZCLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQztDQUNKO0FBRUQsTUFBTSxVQUFVLFFBQVEsQ0FBQyxPQUE2QjtJQUNsRCxPQUFPLElBQUksYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0FBQ3JDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbmltYXRpb25CdWlsZGVyIH0gZnJvbSBcIkBhbmd1bGFyL2FuaW1hdGlvbnNcIlxuXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJzY3JpYmVyIH0gZnJvbSBcInJ4anNcIlxuXG5pbXBvcnQgeyBhbmltYXRpb25PYnNlcnZhYmxlLCBDb3Zlck9wdGlvbnMgfSBmcm9tIFwiQG5ndXRpbC9ncmFwaGljc1wiXG5cbmltcG9ydCB7IEJhY2tkcm9wUmVmIH0gZnJvbSBcIi4uLy4uL2xheWVyXCJcbmltcG9ydCB7IHR5cGUgRmxvYXRpbmdSZWYgfSBmcm9tIFwiLi4vZmxvYXRpbmctcmVmXCJcbmltcG9ydCB7IEZsb2F0aW5nVHJhaXQgfSBmcm9tIFwiLi9fYmFzZVwiXG5pbXBvcnQgeyBGYWRlQW5pbWF0aW9uIH0gZnJvbSBcIi4vYW5pbWF0aW9uXCJcblxuaW50ZXJmYWNlIENvbW1vbk9wdGlvbnMge31cblxuZXhwb3J0IHR5cGUgQmFja2Ryb3BUcmFpdE9wdGlvbnMgPSBDb3Zlck9wdGlvbnMgJiBDb21tb25PcHRpb25zXG5cbmV4cG9ydCBjbGFzcyBCYWNrZHJvcFRyYWl0IGltcGxlbWVudHMgRmxvYXRpbmdUcmFpdDxCYWNrZHJvcFJlZj4ge1xuICAgIHJlYWRvbmx5IG5hbWUgPSBcImJhY2tkcm9wXCJcblxuICAgIGNvbnN0cnVjdG9yKHJlYWRvbmx5IG9wdGlvbnM6IEJhY2tkcm9wVHJhaXRPcHRpb25zKSB7fVxuXG4gICAgY29ubmVjdChmbG9hdGluZ1JlZjogRmxvYXRpbmdSZWY8YW55Pik6IE9ic2VydmFibGU8QmFja2Ryb3BSZWY+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlKChkZXN0OiBTdWJzY3JpYmVyPEJhY2tkcm9wUmVmPikgPT4ge1xuICAgICAgICAgICAgY29uc3QgYW5pbWF0aW9uQnVpbGRlciA9IGZsb2F0aW5nUmVmLmNvbnRhaW5lci5pbmplY3Rvci5nZXQoQW5pbWF0aW9uQnVpbGRlcilcbiAgICAgICAgICAgIGNvbnN0IG9wdGlvbnMgPSB7IC4uLnRoaXMub3B0aW9ucyB9XG4gICAgICAgICAgICBjb25zdCBiYWNrZHJvcCA9IGZsb2F0aW5nUmVmLmxheWVyU3ZjLm5ld0JhY2tkcm9wKGZsb2F0aW5nUmVmLmNvbnRhaW5lciwgb3B0aW9ucylcblxuICAgICAgICAgICAgZmxvYXRpbmdSZWYuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnQuc2V0QXR0cmlidXRlKFwiZGF0YS1mbG9hdGluZy1oYXMtYmFja2Ryb3BcIiwgXCJ0cnVlXCIpXG4gICAgICAgICAgICBiYWNrZHJvcC5uYXRpdmVFbGVtZW50LnNldEF0dHJpYnV0ZShcImRhdGEtZmxvYXRpbmctYmFja2Ryb3BcIiwgZmxvYXRpbmdSZWYudWlkKVxuXG4gICAgICAgICAgICBiYWNrZHJvcC5zdGF0ZS5vbihcInNob3dpbmdcIiwgKCkgPT5cbiAgICAgICAgICAgICAgICBhbmltYXRpb25PYnNlcnZhYmxlKHtcbiAgICAgICAgICAgICAgICAgICAgYnVpbGRlcjogYW5pbWF0aW9uQnVpbGRlcixcbiAgICAgICAgICAgICAgICAgICAgZWxlbWVudDogYmFja2Ryb3AubmF0aXZlRWxlbWVudCxcbiAgICAgICAgICAgICAgICAgICAgYW5pbWF0aW9uOiBGYWRlQW5pbWF0aW9uLnNob3dcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgYmFja2Ryb3Auc3RhdGUub24oXCJkaXNwb3NpbmdcIiwgKCkgPT5cbiAgICAgICAgICAgICAgICBhbmltYXRpb25PYnNlcnZhYmxlKHtcbiAgICAgICAgICAgICAgICAgICAgYnVpbGRlcjogYW5pbWF0aW9uQnVpbGRlcixcbiAgICAgICAgICAgICAgICAgICAgZWxlbWVudDogYmFja2Ryb3AubmF0aXZlRWxlbWVudCxcbiAgICAgICAgICAgICAgICAgICAgYW5pbWF0aW9uOiBGYWRlQW5pbWF0aW9uLmhpZGVcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKVxuXG4gICAgICAgICAgICBiYWNrZHJvcC5zdGF0ZS5vbihcImRpc3Bvc2VkXCIsICgpID0+IGRlc3QuY29tcGxldGUoKSlcblxuICAgICAgICAgICAgZmxvYXRpbmdSZWYuc3RhdGUub24oXCJkaXNwb3NpbmdcIiwgKCkgPT4gYmFja2Ryb3AuZGlzcG9zZSgpKVxuXG4gICAgICAgICAgICBkZXN0LmFkZChiYWNrZHJvcC5zaG93KCkuc3Vic2NyaWJlKCkpXG4gICAgICAgICAgICBkZXN0Lm5leHQoYmFja2Ryb3ApXG4gICAgICAgIH0pXG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gYmFja2Ryb3Aob3B0aW9uczogQmFja2Ryb3BUcmFpdE9wdGlvbnMpIHtcbiAgICByZXR1cm4gbmV3IEJhY2tkcm9wVHJhaXQob3B0aW9ucylcbn1cbiJdfQ==
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { distinctUntilChanged, exhaustMap, filter, from, fromEvent, map, Observable, of, race } from "rxjs";
|
|
2
|
-
import { KeystrokeService } from "@ngutil/aria";
|
|
3
|
-
import { coerceElement } from "@ngutil/common";
|
|
4
|
-
class CloseTriggerTrait {
|
|
5
|
-
constructor(options = {}) {
|
|
6
|
-
this.options = options;
|
|
7
|
-
this.name = "close-trigger";
|
|
8
|
-
}
|
|
9
|
-
connect(floatingRef) {
|
|
10
|
-
const { keystroke, clickOutside, trigger } = this.options;
|
|
11
|
-
const container = floatingRef.container.nativeElement;
|
|
12
|
-
const triggers = [];
|
|
13
|
-
const selfUid = Number(floatingRef.uid);
|
|
14
|
-
if (keystroke) {
|
|
15
|
-
const ks = floatingRef.container.injector.get(KeystrokeService);
|
|
16
|
-
triggers.push(ks.watch(container, { key: "Escape", state: "up" }).pipe(map(() => {
|
|
17
|
-
return { source: "keystroke" };
|
|
18
|
-
})));
|
|
19
|
-
// TODO: angular auxiliary route
|
|
20
|
-
}
|
|
21
|
-
if (clickOutside) {
|
|
22
|
-
const allowedElements = typeof clickOutside === "boolean" ? [] : clickOutside.allowedElements?.map(coerceElement) || [];
|
|
23
|
-
triggers.push(fromEvent(document, "click", { capture: true, passive: true }).pipe(filter(event => {
|
|
24
|
-
if (!(event.target instanceof HTMLElement)) {
|
|
25
|
-
return false;
|
|
26
|
-
}
|
|
27
|
-
const target = event.target;
|
|
28
|
-
for (const allowed of allowedElements) {
|
|
29
|
-
if (target === allowed || allowed.contains(target)) {
|
|
30
|
-
return false;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
const floatingUid = getFloatingUid(target, "data-floating", "floating");
|
|
34
|
-
const backdropUid = getFloatingUid(target, "data-floating-backdrop", "floatingBackdrop");
|
|
35
|
-
const otherBackdropUid = floatingUid != null && floatingUid !== selfUid
|
|
36
|
-
? getFloatingUid(document.querySelector(`[data-floating-backdrop="${floatingUid}"]`), "data-floating-backdrop", "floatingBackdrop")
|
|
37
|
-
: undefined;
|
|
38
|
-
// console.log({ floatingUid, backdropUid, otherBackdropUid, self: selfUid })
|
|
39
|
-
if (floatingUid == null && backdropUid == null) {
|
|
40
|
-
return true;
|
|
41
|
-
}
|
|
42
|
-
else {
|
|
43
|
-
return (
|
|
44
|
-
// click on self or erlier backdrop
|
|
45
|
-
(backdropUid != null && backdropUid <= selfUid) ||
|
|
46
|
-
// click on other floating element, whitout backdrop
|
|
47
|
-
(floatingUid != null && otherBackdropUid == null && floatingUid < selfUid) ||
|
|
48
|
-
// click on other floating element that opened erlier
|
|
49
|
-
(floatingUid != null && floatingUid < selfUid));
|
|
50
|
-
}
|
|
51
|
-
}), map(() => {
|
|
52
|
-
return { source: "click" };
|
|
53
|
-
})));
|
|
54
|
-
}
|
|
55
|
-
if (trigger) {
|
|
56
|
-
triggers.push(from(trigger).pipe(map(() => {
|
|
57
|
-
return { source: "trigger" };
|
|
58
|
-
})));
|
|
59
|
-
}
|
|
60
|
-
if (triggers.length === 0) {
|
|
61
|
-
return of();
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
64
|
-
return new Observable(dst => floatingRef.state.on("shown", () => {
|
|
65
|
-
race(...triggers)
|
|
66
|
-
.pipe(exhaustMap(event => floatingRef.close().pipe(map(() => event), distinctUntilChanged())))
|
|
67
|
-
.subscribe(dst);
|
|
68
|
-
}));
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
export function closeTrigger(options = { clickOutside: true, keystroke: true }) {
|
|
73
|
-
return new CloseTriggerTrait(options);
|
|
74
|
-
}
|
|
75
|
-
function getFloatingUid(el, attr, dataset) {
|
|
76
|
-
if (el == null) {
|
|
77
|
-
return undefined;
|
|
78
|
-
}
|
|
79
|
-
if (el.matches(`[${attr}]`)) {
|
|
80
|
-
return Number(el.dataset[dataset]) || undefined;
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
const parent = el.closest(`[${attr}]`);
|
|
84
|
-
if (parent) {
|
|
85
|
-
return Number(parent.dataset[dataset]) || undefined;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
return undefined;
|
|
89
|
-
}
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"close-trigger.js","sourceRoot":"","sources":["../../../../../../packages/floating/src/floating/traits/close-trigger.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    distinctUntilChanged,\n    exhaustMap,\n    filter,\n    from,\n    fromEvent,\n    map,\n    Observable,\n    ObservableInput,\n    of,\n    race\n} from \"rxjs\"\n\nimport { KeystrokeService } from \"@ngutil/aria\"\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\n\nimport { FloatingRef } from \"../floating-ref\"\nimport { FloatingTrait } from \"./_base\"\n\nexport interface ClickOutsideOptions {\n    /**\n     * If clicks happened on this element, that not trigger the close event\n     */\n    allowedElements?: ElementInput[]\n}\n\nexport interface CloseTriggerOptions {\n    /**\n     * Close floating when click outside of floating element\n     */\n    clickOutside?: boolean | ClickOutsideOptions\n\n    /**\n     * Only works when the floating element is focused\n     */\n    keystroke?: boolean\n\n    /**\n     * Close when emitting any value\n     */\n    trigger?: ObservableInput<any>\n}\n\nexport interface CloseTriggerEvent {\n    source: \"click\" | \"keystroke\" | \"backbutton\" | \"trigger\"\n}\n\nclass CloseTriggerTrait implements FloatingTrait {\n    readonly name = \"close-trigger\"\n\n    constructor(readonly options: CloseTriggerOptions = {}) {}\n\n    connect(floatingRef: FloatingRef): Observable<CloseTriggerEvent | void> {\n        const { keystroke, clickOutside, trigger } = this.options\n\n        const container = floatingRef.container.nativeElement\n        const triggers: Array<Observable<any>> = []\n        const selfUid = Number(floatingRef.uid)\n\n        if (keystroke) {\n            const ks = floatingRef.container.injector.get(KeystrokeService)\n\n            triggers.push(\n                ks.watch(container, { key: \"Escape\", state: \"up\" }).pipe(\n                    map(() => {\n                        return { source: \"keystroke\" as const }\n                    })\n                )\n            )\n\n            // TODO: angular auxiliary route\n        }\n\n        if (clickOutside) {\n            const allowedElements =\n                typeof clickOutside === \"boolean\" ? [] : clickOutside.allowedElements?.map(coerceElement) || []\n\n            triggers.push(\n                fromEvent(document, \"click\", { capture: true, passive: true }).pipe(\n                    filter(event => {\n                        if (!(event.target instanceof HTMLElement)) {\n                            return false\n                        }\n                        const target = event.target\n\n                        for (const allowed of allowedElements) {\n                            if (target === allowed || allowed.contains(target)) {\n                                return false\n                            }\n                        }\n\n                        const floatingUid = getFloatingUid(target, \"data-floating\", \"floating\")\n                        const backdropUid = getFloatingUid(target, \"data-floating-backdrop\", \"floatingBackdrop\")\n                        const otherBackdropUid =\n                            floatingUid != null && floatingUid !== selfUid\n                                ? getFloatingUid(\n                                      document.querySelector(`[data-floating-backdrop=\"${floatingUid}\"]`),\n                                      \"data-floating-backdrop\",\n                                      \"floatingBackdrop\"\n                                  )\n                                : undefined\n\n                        // console.log({ floatingUid, backdropUid, otherBackdropUid, self: selfUid })\n\n                        if (floatingUid == null && backdropUid == null) {\n                            return true\n                        } else {\n                            return (\n                                // click on self or erlier backdrop\n                                (backdropUid != null && backdropUid <= selfUid) ||\n                                // click on other floating element, whitout backdrop\n                                (floatingUid != null && otherBackdropUid == null && floatingUid < selfUid) ||\n                                // click on other floating element that opened erlier\n                                (floatingUid != null && floatingUid < selfUid)\n                            )\n                        }\n                    }),\n                    map(() => {\n                        return { source: \"click\" as const }\n                    })\n                )\n            )\n        }\n\n        if (trigger) {\n            triggers.push(\n                from(trigger).pipe(\n                    map(() => {\n                        return { source: \"trigger\" as const }\n                    })\n                )\n            )\n        }\n\n        if (triggers.length === 0) {\n            return of()\n        } else {\n            return new Observable(dst =>\n                floatingRef.state.on(\"shown\", () => {\n                    race(...triggers)\n                        .pipe(\n                            exhaustMap(event =>\n                                floatingRef.close().pipe(\n                                    map(() => event),\n                                    distinctUntilChanged()\n                                )\n                            )\n                        )\n                        .subscribe(dst)\n                })\n            )\n        }\n    }\n}\n\nexport function closeTrigger(options: CloseTriggerOptions = { clickOutside: true, keystroke: true }) {\n    return new CloseTriggerTrait(options)\n}\n\nfunction getFloatingUid(el: HTMLElement | null, attr: string, dataset: string): number | undefined {\n    if (el == null) {\n        return undefined\n    }\n\n    if (el.matches(`[${attr}]`)) {\n        return Number(el.dataset[dataset]) || undefined\n    } else {\n        const parent = el.closest(`[${attr}]`) as HTMLElement\n        if (parent) {\n            return Number(parent.dataset[dataset]) || undefined\n        }\n    }\n    return undefined\n}\n"]}
|