@ngutil/aria 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-aria.mjs +88 -65
- package/fesm2022/ngutil-aria.mjs.map +1 -1
- package/focus/focus-state.directive.d.ts +1 -2
- package/focus/focus.service.d.ts +1 -1
- package/focus/focusable.directive.d.ts +0 -1
- package/package.json +7 -9
- package/ui-state/abstract.d.ts +1 -1
- package/ui-state/dirty.directive.d.ts +9 -0
- package/ui-state/index.d.ts +5 -3
- package/ui-state/progress-state.d.ts +1 -1
- package/esm2022/activity/activity.service.mjs +0 -49
- package/esm2022/activity/index.mjs +0 -2
- package/esm2022/focus/focus-state.directive.mjs +0 -63
- package/esm2022/focus/focus-trap.directive.mjs +0 -25
- package/esm2022/focus/focus.service.mjs +0 -145
- package/esm2022/focus/focusable.directive.mjs +0 -52
- package/esm2022/focus/index.mjs +0 -5
- package/esm2022/gestures/gesture-drag.mjs +0 -81
- package/esm2022/gestures/gesture-event.mjs +0 -44
- package/esm2022/gestures/gesture-longtap.mjs +0 -34
- package/esm2022/gestures/gesture-tap.mjs +0 -37
- package/esm2022/gestures/gesture.mjs +0 -66
- package/esm2022/gestures/gesture.service.mjs +0 -279
- package/esm2022/gestures/index.mjs +0 -7
- package/esm2022/index.mjs +0 -6
- package/esm2022/keystroke/index.mjs +0 -2
- package/esm2022/keystroke/keystroke.service.mjs +0 -92
- package/esm2022/ngutil-aria.mjs +0 -5
- package/esm2022/ui-state/abstract.mjs +0 -41
- package/esm2022/ui-state/busy.directive.mjs +0 -27
- package/esm2022/ui-state/disabled.directive.mjs +0 -28
- package/esm2022/ui-state/index.mjs +0 -25
- package/esm2022/ui-state/progress-state.mjs +0 -141
- package/esm2022/ui-state/readonly.directive.mjs +0 -27
- package/esm2022/ui-state/selector.mjs +0 -308
- package/esm2022/ui-state/ui-state.mjs +0 -91
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
import { computed, Directive, inject, signal, untracked } from "@angular/core";
|
|
3
|
-
import { Observable } from "rxjs";
|
|
4
|
-
import { deepClone } from "@ngutil/common";
|
|
5
|
-
import { compile as compileSelector } from "./selector";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class UiState {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.#parent = inject(_a, { skipSelf: true, optional: true });
|
|
10
|
-
this.#self = signal({});
|
|
11
|
-
this.merged = computed(() => {
|
|
12
|
-
const parent = this.#parent?.merged();
|
|
13
|
-
const self = this.#self();
|
|
14
|
-
if (parent) {
|
|
15
|
-
const result = deepClone(self);
|
|
16
|
-
for (const [k, v] of Object.entries(parent)) {
|
|
17
|
-
const parentIsTrue = Object.values(v).includes(true);
|
|
18
|
-
const { self: _, ...parentWihtoutSelf } = v;
|
|
19
|
-
if (result[k] != null) {
|
|
20
|
-
result[k] = {
|
|
21
|
-
...parentWihtoutSelf,
|
|
22
|
-
...result[k],
|
|
23
|
-
parent: parentIsTrue
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
result[k] = { ...parentWihtoutSelf, parent: parentIsTrue };
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
return result;
|
|
31
|
-
}
|
|
32
|
-
else {
|
|
33
|
-
return self;
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
this.value = computed(() => {
|
|
37
|
-
const merged = this.merged();
|
|
38
|
-
const result = {};
|
|
39
|
-
for (const [k, v] of Object.entries(merged)) {
|
|
40
|
-
result[k] = Object.values(v).includes(true);
|
|
41
|
-
}
|
|
42
|
-
return result;
|
|
43
|
-
});
|
|
44
|
-
this.inertSelector = signal("busy || disabled");
|
|
45
|
-
}
|
|
46
|
-
#parent;
|
|
47
|
-
get root() {
|
|
48
|
-
return this.#parent?.root || this;
|
|
49
|
-
}
|
|
50
|
-
#self;
|
|
51
|
-
set(name, value, source = "self") {
|
|
52
|
-
if (source === "parent") {
|
|
53
|
-
console.error("can't set parent state");
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
const current = untracked(this.#self);
|
|
57
|
-
const entry = current[name] || {};
|
|
58
|
-
if (entry[source] !== value) {
|
|
59
|
-
this.#self.set({ ...current, [name]: { ...entry, [source]: value } });
|
|
60
|
-
}
|
|
61
|
-
// TODO: maybe some option to propagate to root
|
|
62
|
-
// const root = this.root
|
|
63
|
-
// if (source !== "self" && root !== this) {
|
|
64
|
-
// root.set(name, value, source)
|
|
65
|
-
// }
|
|
66
|
-
}
|
|
67
|
-
is(selector = "*") {
|
|
68
|
-
return compileSelector(selector)(this.merged());
|
|
69
|
-
}
|
|
70
|
-
intercept(name, source) {
|
|
71
|
-
return (src) => this.wrap(src, name, source);
|
|
72
|
-
}
|
|
73
|
-
wrap(observable, name, source) {
|
|
74
|
-
return new Observable(subscriber => {
|
|
75
|
-
this.set(name, true, source);
|
|
76
|
-
subscriber.add(() => this.set(name, false, source));
|
|
77
|
-
return observable.subscribe(subscriber);
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
isInert() {
|
|
81
|
-
return this.is(this.inertSelector());
|
|
82
|
-
}
|
|
83
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: UiState, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
84
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: UiState, isStandalone: true, ngImport: i0 }); }
|
|
85
|
-
}
|
|
86
|
-
_a = UiState;
|
|
87
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: UiState, decorators: [{
|
|
88
|
-
type: Directive,
|
|
89
|
-
args: [{ standalone: true }]
|
|
90
|
-
}] });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-state.js","sourceRoot":"","sources":["../../../../../packages/aria/src/ui-state/ui-state.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, Directive, inject, signal, untracked } from \"@angular/core\"\n\nimport { Observable } from \"rxjs\"\n\nimport { Mutable } from \"utility-types\"\n\nimport { deepClone } from \"@ngutil/common\"\n\nimport { compile as compileSelector } from \"./selector\"\n\n/**\n * {\n *  busy: {\n *      self: true,\n *      parent: false,\n *      disabled: false\n *  }\n * }\n */\nexport type UiStateDetails = { readonly [key: string]: UiStateEntry }\n\nexport type UiStateEntry = { readonly [key: UiStateSource]: boolean }\n\nexport type UiStateValue = { readonly [key: string]: boolean }\n\nexport type UiStateSource = \"parent\" | \"self\" | string\n\nexport type UiStateSelector = string\n\n@Directive({ standalone: true })\nexport class UiState<N extends string = string, S extends UiStateSource = UiStateSource> {\n    readonly #parent = inject(UiState, { skipSelf: true, optional: true })\n\n    get root(): UiState {\n        return this.#parent?.root || this\n    }\n\n    readonly #self = signal<UiStateDetails>({})\n\n    readonly merged = computed<UiStateDetails>(() => {\n        const parent = this.#parent?.merged()\n        const self = this.#self()\n        if (parent) {\n            const result: Mutable<UiStateDetails> = deepClone(self)\n\n            for (const [k, v] of Object.entries(parent)) {\n                const parentIsTrue = Object.values(v).includes(true)\n                const { self: _, ...parentWihtoutSelf } = v\n                if (result[k] != null) {\n                    result[k] = {\n                        ...parentWihtoutSelf,\n                        ...result[k],\n                        parent: parentIsTrue\n                    }\n                } else {\n                    result[k] = { ...parentWihtoutSelf, parent: parentIsTrue }\n                }\n            }\n\n            return result\n        } else {\n            return self\n        }\n    })\n\n    readonly value = computed<UiStateValue>(() => {\n        const merged = this.merged()\n        const result: Mutable<UiStateValue> = {}\n\n        for (const [k, v] of Object.entries(merged)) {\n            result[k] = Object.values(v).includes(true)\n        }\n\n        return result\n    })\n\n    readonly inertSelector = signal(\"busy || disabled\")\n\n    set(name: N, value: boolean, source: S = \"self\" as S) {\n        if (source === \"parent\") {\n            console.error(\"can't set parent state\")\n            return\n        }\n\n        const current = untracked(this.#self)\n        const entry = current[name] || {}\n\n        if (entry[source] !== value) {\n            this.#self.set({ ...current, [name]: { ...entry, [source]: value } })\n        }\n\n        // TODO: maybe some option to propagate to root\n        // const root = this.root\n        // if (source !== \"self\" && root !== this) {\n        //     root.set(name, value, source)\n        // }\n    }\n\n    is(selector: UiStateSelector = \"*\"): boolean {\n        return compileSelector(selector)(this.merged())\n    }\n\n    intercept(name: N, source: S) {\n        return <S>(src: Observable<S>) => this.wrap(src, name, source)\n    }\n\n    wrap<T>(observable: Observable<T>, name: N, source: S): Observable<T> {\n        return new Observable<T>(subscriber => {\n            this.set(name, true, source)\n            subscriber.add(() => this.set(name, false, source))\n            return observable.subscribe(subscriber)\n        })\n    }\n\n    isInert() {\n        return this.is(this.inertSelector())\n    }\n}\n"]}
|