@ngutil/aria 0.0.52 → 0.0.55
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/activity/activity.service.mjs +3 -3
- package/esm2022/focus/focus-state.directive.mjs +3 -3
- package/esm2022/focus/focus.service.mjs +3 -3
- package/esm2022/focus/focusable.directive.mjs +6 -9
- package/esm2022/gestures/gestures.service.mjs +3 -3
- package/esm2022/index.mjs +2 -1
- package/esm2022/keystroke/keystroke.service.mjs +60 -61
- package/esm2022/ui-state/abstract.mjs +35 -0
- package/esm2022/ui-state/busy.directive.mjs +27 -0
- package/esm2022/ui-state/disabled.directive.mjs +28 -0
- package/esm2022/ui-state/index.mjs +25 -0
- package/esm2022/ui-state/progress-state.mjs +150 -0
- package/esm2022/ui-state/readonly.directive.mjs +28 -0
- package/esm2022/ui-state/ui-state.mjs +92 -0
- package/fesm2022/ngutil-aria.mjs +428 -83
- package/fesm2022/ngutil-aria.mjs.map +1 -1
- package/focus/focusable.directive.d.ts +0 -1
- package/index.d.ts +1 -0
- package/keystroke/keystroke.service.d.ts +3 -2
- package/package.json +6 -6
- package/ui-state/abstract.d.ts +16 -0
- package/ui-state/busy.directive.d.ts +9 -0
- package/ui-state/disabled.directive.d.ts +9 -0
- package/ui-state/index.d.ts +15 -0
- package/ui-state/progress-state.d.ts +50 -0
- package/ui-state/readonly.directive.d.ts +9 -0
- package/ui-state/ui-state.d.ts +33 -0
|
@@ -39,10 +39,10 @@ export class ActivityService {
|
|
|
39
39
|
watchInactvity(timeout) {
|
|
40
40
|
return this.events$.pipe(startWith(null), throttleTime(timeout / 2), switchMap(() => timer(0, timeout).pipe(take(2))), map(v => v !== 0), distinctUntilChanged(), shareReplay(1));
|
|
41
41
|
}
|
|
42
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
43
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ActivityService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
43
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ActivityService, providedIn: "root" }); }
|
|
44
44
|
}
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ActivityService, decorators: [{
|
|
46
46
|
type: Injectable,
|
|
47
47
|
args: [{ providedIn: "root" }]
|
|
48
48
|
}] });
|
|
@@ -46,11 +46,11 @@ export class FocusState {
|
|
|
46
46
|
};
|
|
47
47
|
});
|
|
48
48
|
}
|
|
49
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
50
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
49
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FocusState, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
50
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: FocusState, isStandalone: true, host: { properties: { "attr.focus": "origin()", "attr.focusWithin": "within()" } }, ngImport: i0 }); }
|
|
51
51
|
}
|
|
52
52
|
_a = FocusState;
|
|
53
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FocusState, decorators: [{
|
|
54
54
|
type: Directive,
|
|
55
55
|
args: [{
|
|
56
56
|
standalone: true,
|
|
@@ -82,10 +82,10 @@ export class FocusService {
|
|
|
82
82
|
focusTrap(inside, deferCaptureElements = false) {
|
|
83
83
|
return this.#focusTrap.create(inside, deferCaptureElements);
|
|
84
84
|
}
|
|
85
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
86
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
85
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FocusService, deps: [{ token: DOCUMENT }, { token: NgZone }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
86
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FocusService, providedIn: "root" }); }
|
|
87
87
|
}
|
|
88
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
88
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: FocusService, decorators: [{
|
|
89
89
|
type: Injectable,
|
|
90
90
|
args: [{ providedIn: "root" }]
|
|
91
91
|
}], ctorParameters: () => [{ type: Document, decorators: [{
|
|
@@ -1,21 +1,18 @@
|
|
|
1
1
|
import { computed, Directive, effect, inject, input } from "@angular/core";
|
|
2
|
-
import {
|
|
2
|
+
import { isElementInput } from "@ngutil/common";
|
|
3
3
|
import { FocusState } from "./focus-state.directive";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "./focus-state.directive";
|
|
6
6
|
// TODO: what happens when disabled is changed
|
|
7
7
|
export class Focusable {
|
|
8
|
-
#disabled;
|
|
9
8
|
constructor() {
|
|
10
|
-
this.#disabled = inject(DisabledState, { optional: true, self: true });
|
|
11
9
|
this.state = inject(FocusState);
|
|
12
10
|
this.focusable = input(true, { alias: "nuFocusable" });
|
|
13
11
|
this.tabindex = input(0, { transform: Number });
|
|
14
12
|
this._tabindex = computed(() => {
|
|
15
13
|
const focusable = this.focusable();
|
|
16
14
|
const tabindex = this.tabindex();
|
|
17
|
-
|
|
18
|
-
if (focusable === false || isDisabled) {
|
|
15
|
+
if (focusable === false) {
|
|
19
16
|
return -1;
|
|
20
17
|
}
|
|
21
18
|
if (typeof focusable === "number") {
|
|
@@ -37,10 +34,10 @@ export class Focusable {
|
|
|
37
34
|
return this.state.connect(value.state);
|
|
38
35
|
}
|
|
39
36
|
}
|
|
40
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
41
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "
|
|
37
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: Focusable, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
38
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.6", type: Focusable, isStandalone: true, selector: "[nuFocusable]", inputs: { focusable: { classPropertyName: "focusable", publicName: "nuFocusable", isSignal: true, isRequired: false, transformFunction: null }, tabindex: { classPropertyName: "tabindex", publicName: "tabindex", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.tabindex": "_tabindex()" } }, exportAs: ["nuFocusable"], hostDirectives: [{ directive: i1.FocusState }], ngImport: i0 }); }
|
|
42
39
|
}
|
|
43
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: Focusable, decorators: [{
|
|
44
41
|
type: Directive,
|
|
45
42
|
args: [{
|
|
46
43
|
standalone: true,
|
|
@@ -52,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
|
|
|
52
49
|
hostDirectives: [FocusState]
|
|
53
50
|
}]
|
|
54
51
|
}], ctorParameters: () => [] });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXNhYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FyaWEvc3JjL2ZvY3VzL2ZvY3VzYWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUUsT0FBTyxFQUFpQyxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUU5RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0seUJBQXlCLENBQUE7OztBQUVwRCw4Q0FBOEM7QUFXOUMsTUFBTSxPQUFPLFNBQVM7SUF5QmxCO1FBeEJTLFVBQUssR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUE7UUFFMUIsY0FBUyxHQUFHLEtBQUssQ0FBbUIsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxDQUFDLENBQUE7UUFDbkUsYUFBUSxHQUFHLEtBQUssQ0FBQyxDQUFDLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQTtRQUUxQyxjQUFTLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUMvQixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUE7WUFDbEMsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFBO1lBRWhDLElBQUksU0FBUyxLQUFLLEtBQUssRUFBRSxDQUFDO2dCQUN0QixPQUFPLENBQUMsQ0FBQyxDQUFBO1lBQ2IsQ0FBQztZQUVELElBQUksT0FBTyxTQUFTLEtBQUssUUFBUSxFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sU0FBUyxDQUFBO1lBQ3BCLENBQUM7WUFFRCxJQUFJLFNBQVMsS0FBSyxJQUFJLElBQUksUUFBUSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO2dCQUM3RCxPQUFPLFFBQVEsQ0FBQTtZQUNuQixDQUFDO1lBRUQsT0FBTyxDQUFDLENBQUE7UUFDWixDQUFDLENBQUMsQ0FBQTtRQUdFLHVEQUF1RDtRQUN2RCxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQTtJQUNoRSxDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQTRDO1FBQ2hELElBQUksS0FBSyxZQUFZLFVBQVUsSUFBSSxjQUFjLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN2RCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQ3BDLENBQUM7YUFBTSxDQUFDO1lBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDMUMsQ0FBQztJQUNMLENBQUM7OEdBcENRLFNBQVM7a0dBQVQsU0FBUzs7MkZBQVQsU0FBUztrQkFUckIsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFFBQVEsRUFBRSxhQUFhO29CQUN2QixJQUFJLEVBQUU7d0JBQ0YsaUJBQWlCLEVBQUUsYUFBYTtxQkFDbkM7b0JBQ0QsY0FBYyxFQUFFLENBQUMsVUFBVSxDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbXB1dGVkLCBEaXJlY3RpdmUsIGVmZmVjdCwgaW5qZWN0LCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgQ29ubmVjdFByb3RvY29sLCBFbGVtZW50SW5wdXQsIGlzRWxlbWVudElucHV0IH0gZnJvbSBcIkBuZ3V0aWwvY29tbW9uXCJcblxuaW1wb3J0IHsgRm9jdXNTdGF0ZSB9IGZyb20gXCIuL2ZvY3VzLXN0YXRlLmRpcmVjdGl2ZVwiXG5cbi8vIFRPRE86IHdoYXQgaGFwcGVucyB3aGVuIGRpc2FibGVkIGlzIGNoYW5nZWRcblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogXCJbbnVGb2N1c2FibGVdXCIsXG4gICAgZXhwb3J0QXM6IFwibnVGb2N1c2FibGVcIixcbiAgICBob3N0OiB7XG4gICAgICAgIFwiW2F0dHIudGFiaW5kZXhdXCI6IFwiX3RhYmluZGV4KClcIlxuICAgIH0sXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtGb2N1c1N0YXRlXVxufSlcbmV4cG9ydCBjbGFzcyBGb2N1c2FibGUgaW1wbGVtZW50cyBDb25uZWN0UHJvdG9jb2wge1xuICAgIHJlYWRvbmx5IHN0YXRlID0gaW5qZWN0KEZvY3VzU3RhdGUpXG5cbiAgICByZWFkb25seSBmb2N1c2FibGUgPSBpbnB1dDxib29sZWFuIHwgbnVtYmVyPih0cnVlLCB7IGFsaWFzOiBcIm51Rm9jdXNhYmxlXCIgfSlcbiAgICByZWFkb25seSB0YWJpbmRleCA9IGlucHV0KDAsIHsgdHJhbnNmb3JtOiBOdW1iZXIgfSlcblxuICAgIHJlYWRvbmx5IF90YWJpbmRleCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3QgZm9jdXNhYmxlID0gdGhpcy5mb2N1c2FibGUoKVxuICAgICAgICBjb25zdCB0YWJpbmRleCA9IHRoaXMudGFiaW5kZXgoKVxuXG4gICAgICAgIGlmIChmb2N1c2FibGUgPT09IGZhbHNlKSB7XG4gICAgICAgICAgICByZXR1cm4gLTFcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0eXBlb2YgZm9jdXNhYmxlID09PSBcIm51bWJlclwiKSB7XG4gICAgICAgICAgICByZXR1cm4gZm9jdXNhYmxlXG4gICAgICAgIH1cblxuICAgICAgICBpZiAoZm9jdXNhYmxlID09PSB0cnVlICYmIHRhYmluZGV4ICE9IG51bGwgJiYgIWlzTmFOKHRhYmluZGV4KSkge1xuICAgICAgICAgICAgcmV0dXJuIHRhYmluZGV4XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gMFxuICAgIH0pXG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgLy8gVE9ETzogbWnDqXJ0IGtlbGwgZXo/LCBoYSBuaW5jcyBpdHQgYWtrb3IgbmVtIGZyaXNzw7xsXG4gICAgICAgIGVmZmVjdCgoKSA9PiB0aGlzLl90YWJpbmRleCgpLCB7IGFsbG93U2lnbmFsV3JpdGVzOiBmYWxzZSB9KVxuICAgIH1cblxuICAgIGNvbm5lY3QodmFsdWU6IEZvY3VzYWJsZSB8IEZvY3VzU3RhdGUgfCBFbGVtZW50SW5wdXQpIHtcbiAgICAgICAgaWYgKHZhbHVlIGluc3RhbmNlb2YgRm9jdXNTdGF0ZSB8fCBpc0VsZW1lbnRJbnB1dCh2YWx1ZSkpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLnN0YXRlLmNvbm5lY3QodmFsdWUpXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5zdGF0ZS5jb25uZWN0KHZhbHVlLnN0YXRlKVxuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -92,10 +92,10 @@ export class GesturesService {
|
|
|
92
92
|
return listener;
|
|
93
93
|
});
|
|
94
94
|
}
|
|
95
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
96
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
95
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: GesturesService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
96
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: GesturesService, providedIn: "root" }); }
|
|
97
97
|
}
|
|
98
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: GesturesService, decorators: [{
|
|
99
99
|
type: Injectable,
|
|
100
100
|
args: [{ providedIn: "root" }]
|
|
101
101
|
}] });
|
package/esm2022/index.mjs
CHANGED
|
@@ -2,4 +2,5 @@ export { ActivityService } from "./activity";
|
|
|
2
2
|
export { FocusService, FocusTrap, Focusable, FocusState } from "./focus";
|
|
3
3
|
export { KeystrokeService } from "./keystroke";
|
|
4
4
|
export * from "./gestures";
|
|
5
|
-
|
|
5
|
+
export * from "./ui-state";
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlDLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUMzRSxPQUFPLEVBQWUsWUFBWSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFnQyxNQUFNLFNBQVMsQ0FBQTtBQUNuSCxPQUFPLEVBQTZCLGdCQUFnQixFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQ3pFLGNBQWMsWUFBWSxDQUFBO0FBQzFCLGNBQWMsWUFBWSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQWN0aXZpdHlFdmVudCwgQWN0aXZpdHlPcmlnaW4sIEFjdGl2aXR5U2VydmljZSB9IGZyb20gXCIuL2FjdGl2aXR5XCJcbmV4cG9ydCB7IEZvY3VzT3JpZ2luLCBGb2N1c1NlcnZpY2UsIEZvY3VzVHJhcCwgRm9jdXNhYmxlLCBGb2N1c1N0YXRlLCBGb2N1c2FibGVFdmVudCwgRm9jdXNDaGFuZ2VzIH0gZnJvbSBcIi4vZm9jdXNcIlxuZXhwb3J0IHsgS2V5c3Ryb2tlLCBLZXlzdHJva2VFdmVudCwgS2V5c3Ryb2tlU2VydmljZSB9IGZyb20gXCIuL2tleXN0cm9rZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9nZXN0dXJlc1wiXG5leHBvcnQgKiBmcm9tIFwiLi91aS1zdGF0ZVwiXG4iXX0=
|
|
@@ -1,72 +1,71 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { map, Observable, share,
|
|
4
|
-
import { coerceElement } from "@ngutil/common";
|
|
1
|
+
import { DOCUMENT } from "@angular/common";
|
|
2
|
+
import { inject, Injectable, NgZone } from "@angular/core";
|
|
3
|
+
import { distinctUntilChanged, EMPTY, filter, from, fromEvent, map, merge, Observable, of, share, shareReplay, startWith, switchMap } from "rxjs";
|
|
4
|
+
import { coerceElement, isElementInput } from "@ngutil/common";
|
|
5
|
+
import { FocusState } from "../focus";
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
export class KeystrokeService {
|
|
7
|
-
#
|
|
8
|
-
#
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
document.removeEventListener("keyup", handler, { capture: true });
|
|
17
|
-
};
|
|
18
|
-
}).pipe(share());
|
|
19
|
-
#activatedKs = this.#keyEvent.pipe(map(event => {
|
|
20
|
-
const keystroke = eventToKeystroke(event);
|
|
21
|
-
const id = keystrokeId(keystroke);
|
|
22
|
-
return { event, keystrokes: this.#keystrokes[id] || [], keystroke };
|
|
23
|
-
}));
|
|
24
|
-
constructor() {
|
|
25
|
-
this.#activatedKs.pipe(takeUntilDestroyed()).subscribe(({ event, keystrokes, keystroke }) => {
|
|
26
|
-
for (const ks of keystrokes) {
|
|
27
|
-
if (event.defaultPrevented) {
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
if (ks.target === event.target ||
|
|
31
|
-
ks.target.contains(event.target) ||
|
|
32
|
-
document.activeElement === ks.target ||
|
|
33
|
-
ks.target.contains(document.activeElement)) {
|
|
34
|
-
ks.subject.next({ original: event, keystroke });
|
|
35
|
-
}
|
|
8
|
+
#document = inject(DOCUMENT);
|
|
9
|
+
#zone = inject(NgZone);
|
|
10
|
+
#keyEvent = this.#zone.runOutsideAngular(() => merge(fromEvent(this.#document, "keydown", { capture: true, passive: false }), fromEvent(this.#document, "keyup", { capture: true, passive: false })).pipe(filter(event => event.defaultPrevented === false), share()));
|
|
11
|
+
#focusEvent = this.#zone.runOutsideAngular(() => fromEvent(this.#document, "focus", { capture: true, passive: true }).pipe(startWith(null), map(() => this.#document.activeElement), shareReplay(1)));
|
|
12
|
+
watch(activation, ...keystrokes) {
|
|
13
|
+
return new Observable((dst) => this.#trigger(activation)
|
|
14
|
+
.pipe(distinctUntilChanged(), switchMap(enabled => {
|
|
15
|
+
if (enabled) {
|
|
16
|
+
return this.#keyEvent;
|
|
36
17
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
this.#keystrokes[id] = [];
|
|
18
|
+
else {
|
|
19
|
+
return EMPTY;
|
|
20
|
+
}
|
|
21
|
+
}), map(event => {
|
|
22
|
+
if (event.defaultPrevented) {
|
|
23
|
+
return [];
|
|
44
24
|
}
|
|
45
|
-
const
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
25
|
+
const idFromEvent = keystrokeId(eventToKeystroke(event));
|
|
26
|
+
const matches = keystrokes
|
|
27
|
+
.filter(ks => keystrokeId(ks) === idFromEvent)
|
|
28
|
+
.map(ks => {
|
|
29
|
+
return {
|
|
30
|
+
original: event,
|
|
31
|
+
keystroke: ks
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
if (matches.length > 0) {
|
|
35
|
+
event.preventDefault();
|
|
36
|
+
}
|
|
37
|
+
return matches;
|
|
38
|
+
}), filter(matches => matches.length > 0), switchMap(matches => of(...matches)))
|
|
39
|
+
.subscribe(dst));
|
|
40
|
+
}
|
|
41
|
+
#trigger(activation) {
|
|
42
|
+
if (isElementInput(activation)) {
|
|
43
|
+
return this.#focusActivation(coerceElement(activation));
|
|
44
|
+
}
|
|
45
|
+
else if (activation instanceof FocusState) {
|
|
46
|
+
return activation.origin$.pipe(map(origin => origin != null));
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
return from(activation).pipe(switchMap(value => {
|
|
50
|
+
if (isElementInput(value) || value instanceof FocusState) {
|
|
51
|
+
return this.#trigger(value);
|
|
59
52
|
}
|
|
60
|
-
|
|
61
|
-
|
|
53
|
+
else {
|
|
54
|
+
return of(value);
|
|
55
|
+
}
|
|
56
|
+
}));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
#focusActivation(element) {
|
|
60
|
+
return this.#focusEvent.pipe(map(focused => focused === element || element.contains(focused)));
|
|
62
61
|
}
|
|
63
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
64
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
62
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: KeystrokeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
63
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: KeystrokeService, providedIn: "root" }); }
|
|
65
64
|
}
|
|
66
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: KeystrokeService, decorators: [{
|
|
67
66
|
type: Injectable,
|
|
68
67
|
args: [{ providedIn: "root" }]
|
|
69
|
-
}]
|
|
68
|
+
}] });
|
|
70
69
|
function keystrokeId(ks) {
|
|
71
70
|
let res = ks.key;
|
|
72
71
|
if (ks.shift) {
|
|
@@ -90,4 +89,4 @@ function eventToKeystroke(event) {
|
|
|
90
89
|
state: event.type === "keyup" ? "up" : "down"
|
|
91
90
|
};
|
|
92
91
|
}
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keystroke.service.js","sourceRoot":"","sources":["../../../../../packages/aria/src/keystroke/keystroke.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\"\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\"\n\nimport { map, Observable, share, Subject, Subscriber } from \"rxjs\"\n\nimport { coerceElement, ElementInput } from \"@ngutil/common\"\n\nexport interface Keystroke {\n    // https://developer.mozilla.org/en-US/docs/Web/API/UI_Events/Keyboard_event_key_values\n    key: KeyboardEvent[\"key\"]\n    shift?: boolean\n    ctrl?: boolean\n    alt?: boolean\n    state: \"down\" | \"up\"\n}\n\nexport interface KeystrokeEvent {\n    original: KeyboardEvent\n    keystroke: Keystroke\n}\n\ninterface KeystrokeEntry {\n    keystroke: Keystroke\n    target: HTMLElement\n    subject: Subject<KeystrokeEvent>\n}\n\n@Injectable({ providedIn: \"root\" })\nexport class KeystrokeService {\n    readonly #keystrokes: { [key: string]: KeystrokeEntry[] } = {}\n\n    readonly #keyEvent = new Observable((dst: Subscriber<KeyboardEvent>) => {\n        const handler = (event: KeyboardEvent) => {\n            dst.next(event)\n        }\n        document.addEventListener(\"keydown\", handler, { capture: true })\n        document.addEventListener(\"keyup\", handler, { capture: true })\n\n        return () => {\n            document.removeEventListener(\"keydown\", handler, { capture: true })\n            document.removeEventListener(\"keyup\", handler, { capture: true })\n        }\n    }).pipe(share())\n\n    readonly #activatedKs = this.#keyEvent.pipe(\n        map(event => {\n            const keystroke = eventToKeystroke(event)\n            const id = keystrokeId(keystroke)\n            return { event, keystrokes: this.#keystrokes[id] || [], keystroke }\n        })\n    )\n\n    constructor() {\n        this.#activatedKs.pipe(takeUntilDestroyed()).subscribe(({ event, keystrokes, keystroke }) => {\n            for (const ks of keystrokes) {\n                if (event.defaultPrevented) {\n                    return\n                }\n\n                if (\n                    ks.target === event.target ||\n                    ks.target.contains(event.target as Node) ||\n                    document.activeElement === ks.target ||\n                    ks.target.contains(document.activeElement as Node)\n                ) {\n                    ks.subject.next({ original: event, keystroke })\n                }\n            }\n        })\n    }\n\n    watch(target: ElementInput, keystroke: Keystroke): Observable<KeystrokeEvent> {\n        const id = keystrokeId(keystroke)\n        return new Observable((dst: Subscriber<KeystrokeEvent>) => {\n            if (!this.#keystrokes[id]) {\n                this.#keystrokes[id] = []\n            }\n\n            const subject = new Subject<KeystrokeEvent>()\n            const entry: KeystrokeEntry = { target: coerceElement(target), keystroke, subject }\n            const sub = subject.subscribe(dst)\n\n            this.#keystrokes[id].push(entry)\n\n            return () => {\n                sub.unsubscribe()\n                if (this.#keystrokes[id]) {\n                    const index = this.#keystrokes[id].indexOf(entry)\n                    if (index !== -1) {\n                        this.#keystrokes[id].splice(index, 1)\n                    }\n                    if (this.#keystrokes[id].length === 0) {\n                        delete this.#keystrokes[id]\n                    }\n                }\n            }\n        }).pipe(share())\n    }\n}\n\nfunction keystrokeId(ks: Keystroke): string {\n    let res = ks.key\n    if (ks.shift) {\n        res += \"+shift\"\n    }\n    if (ks.ctrl) {\n        res += \"+ctrl\"\n    }\n    if (ks.alt) {\n        res += \"+alt\"\n    }\n    res += `${ks.state}`\n    return res\n}\n\nfunction eventToKeystroke(event: KeyboardEvent): Keystroke {\n    return {\n        key: event.key,\n        shift: event.shiftKey,\n        ctrl: event.ctrlKey,\n        alt: event.altKey,\n        state: event.type === \"keyup\" ? \"up\" : \"down\"\n    }\n}\n"]}
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keystroke.service.js","sourceRoot":"","sources":["../../../../../packages/aria/src/keystroke/keystroke.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AAE1D,OAAO,EACH,oBAAoB,EACpB,KAAK,EACL,MAAM,EACN,IAAI,EACJ,SAAS,EACT,GAAG,EACH,KAAK,EACL,UAAU,EACV,EAAE,EACF,KAAK,EACL,WAAW,EACX,SAAS,EAET,SAAS,EACZ,MAAM,MAAM,CAAA;AAEb,OAAO,EAAE,aAAa,EAAgB,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAE5E,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;;AAmBrC,MAAM,OAAO,gBAAgB;IAChB,SAAS,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC5B,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,CAAA;IAEtB,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,CACnD,KAAK,CACD,SAAS,CAAgB,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EACtF,SAAS,CAAgB,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CACvF,CAAC,IAAI,CACF,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,gBAAgB,KAAK,KAAK,CAAC,EACjD,KAAK,EAAE,CACV,CACJ,CAAA;IAEQ,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,CACrD,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CACrE,SAAS,CAAC,IAAI,CAAC,EACf,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,EACvC,WAAW,CAAC,CAAC,CAAC,CACjB,CACJ,CAAA;IAED,KAAK,CAAC,UAA+B,EAAE,GAAG,UAAuB;QAC7D,OAAO,IAAI,UAAU,CAAC,CAAC,GAA+B,EAAE,EAAE,CACtD,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;aACpB,IAAI,CACD,oBAAoB,EAAE,EACtB,SAAS,CAAC,OAAO,CAAC,EAAE;YAChB,IAAI,OAAO,EAAE,CAAC;gBACV,OAAO,IAAI,CAAC,SAAS,CAAA;YACzB,CAAC;iBAAM,CAAC;gBACJ,OAAO,KAAK,CAAA;YAChB,CAAC;QACL,CAAC,CAAC,EACF,GAAG,CAAC,KAAK,CAAC,EAAE;YACR,IAAI,KAAK,CAAC,gBAAgB,EAAE,CAAC;gBACzB,OAAO,EAAE,CAAA;YACb,CAAC;YAED,MAAM,WAAW,GAAG,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAA;YACxD,MAAM,OAAO,GAAG,UAAU;iBACrB,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,WAAW,CAAC;iBAC7C,GAAG,CAAC,EAAE,CAAC,EAAE;gBACN,OAAO;oBACH,QAAQ,EAAE,KAAK;oBACf,SAAS,EAAE,EAAE;iBAChB,CAAA;YACL,CAAC,CAAC,CAAA;YAEN,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACrB,KAAK,CAAC,cAAc,EAAE,CAAA;YAC1B,CAAC;YAED,OAAO,OAAO,CAAA;QAClB,CAAC,CAAC,EACF,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,EACrC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CACvC;aACA,SAAS,CAAC,GAAG,CAAC,CACtB,CAAA;IACL,CAAC;IAED,QAAQ,CAAC,UAA+B;QACpC,IAAI,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAA;QAC3D,CAAC;aAAM,IAAI,UAAU,YAAY,UAAU,EAAE,CAAC;YAC1C,OAAO,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC,CAAA;QACjE,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CACxB,SAAS,CAAC,KAAK,CAAC,EAAE;gBACd,IAAI,cAAc,CAAC,KAAK,CAAC,IAAI,KAAK,YAAY,UAAU,EAAE,CAAC;oBACvD,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;gBAC/B,CAAC;qBAAM,CAAC;oBACJ,OAAO,EAAE,CAAC,KAAK,CAAC,CAAA;gBACpB,CAAC;YACL,CAAC,CAAC,CACL,CAAA;QACL,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,OAAoB;QACjC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,KAAK,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;IAClG,CAAC;8GAlFQ,gBAAgB;kHAAhB,gBAAgB,cADH,MAAM;;2FACnB,gBAAgB;kBAD5B,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;AAsFlC,SAAS,WAAW,CAAC,EAAa;IAC9B,IAAI,GAAG,GAAG,EAAE,CAAC,GAAG,CAAA;IAChB,IAAI,EAAE,CAAC,KAAK,EAAE,CAAC;QACX,GAAG,IAAI,QAAQ,CAAA;IACnB,CAAC;IACD,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC;QACV,GAAG,IAAI,OAAO,CAAA;IAClB,CAAC;IACD,IAAI,EAAE,CAAC,GAAG,EAAE,CAAC;QACT,GAAG,IAAI,MAAM,CAAA;IACjB,CAAC;IACD,GAAG,IAAI,GAAG,EAAE,CAAC,KAAK,EAAE,CAAA;IACpB,OAAO,GAAG,CAAA;AACd,CAAC;AAED,SAAS,gBAAgB,CAAC,KAAoB;IAC1C,OAAO;QACH,GAAG,EAAE,KAAK,CAAC,GAAG;QACd,KAAK,EAAE,KAAK,CAAC,QAAQ;QACrB,IAAI,EAAE,KAAK,CAAC,OAAO;QACnB,GAAG,EAAE,KAAK,CAAC,MAAM;QACjB,KAAK,EAAE,KAAK,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM;KAChD,CAAA;AACL,CAAC","sourcesContent":["import { DOCUMENT } from \"@angular/common\"\nimport { inject, Injectable, NgZone } from \"@angular/core\"\n\nimport {\n    distinctUntilChanged,\n    EMPTY,\n    filter,\n    from,\n    fromEvent,\n    map,\n    merge,\n    Observable,\n    of,\n    share,\n    shareReplay,\n    startWith,\n    Subscriber,\n    switchMap\n} from \"rxjs\"\n\nimport { coerceElement, ElementInput, isElementInput } from \"@ngutil/common\"\n\nimport { FocusState } from \"../focus\"\n\nexport interface Keystroke {\n    // https://developer.mozilla.org/en-US/docs/Web/API/UI_Events/Keyboard_event_key_values\n    key: KeyboardEvent[\"key\"]\n    shift?: boolean\n    ctrl?: boolean\n    alt?: boolean\n    state: \"down\" | \"up\"\n}\n\nexport interface KeystrokeEvent {\n    original: KeyboardEvent\n    keystroke: Keystroke\n}\n\nexport type KeystrokeActivation = ElementInput | FocusState | Observable<ElementInput | FocusState | boolean>\n\n@Injectable({ providedIn: \"root\" })\nexport class KeystrokeService {\n    readonly #document = inject(DOCUMENT)\n    readonly #zone = inject(NgZone)\n\n    readonly #keyEvent = this.#zone.runOutsideAngular(() =>\n        merge(\n            fromEvent<KeyboardEvent>(this.#document, \"keydown\", { capture: true, passive: false }),\n            fromEvent<KeyboardEvent>(this.#document, \"keyup\", { capture: true, passive: false })\n        ).pipe(\n            filter(event => event.defaultPrevented === false),\n            share()\n        )\n    )\n\n    readonly #focusEvent = this.#zone.runOutsideAngular(() =>\n        fromEvent(this.#document, \"focus\", { capture: true, passive: true }).pipe(\n            startWith(null),\n            map(() => this.#document.activeElement),\n            shareReplay(1)\n        )\n    )\n\n    watch(activation: KeystrokeActivation, ...keystrokes: Keystroke[]): Observable<KeystrokeEvent> {\n        return new Observable((dst: Subscriber<KeystrokeEvent>) =>\n            this.#trigger(activation)\n                .pipe(\n                    distinctUntilChanged(),\n                    switchMap(enabled => {\n                        if (enabled) {\n                            return this.#keyEvent\n                        } else {\n                            return EMPTY\n                        }\n                    }),\n                    map(event => {\n                        if (event.defaultPrevented) {\n                            return []\n                        }\n\n                        const idFromEvent = keystrokeId(eventToKeystroke(event))\n                        const matches = keystrokes\n                            .filter(ks => keystrokeId(ks) === idFromEvent)\n                            .map(ks => {\n                                return {\n                                    original: event,\n                                    keystroke: ks\n                                }\n                            })\n\n                        if (matches.length > 0) {\n                            event.preventDefault()\n                        }\n\n                        return matches\n                    }),\n                    filter(matches => matches.length > 0),\n                    switchMap(matches => of(...matches))\n                )\n                .subscribe(dst)\n        )\n    }\n\n    #trigger(activation: KeystrokeActivation): Observable<boolean | HTMLElement> {\n        if (isElementInput(activation)) {\n            return this.#focusActivation(coerceElement(activation))\n        } else if (activation instanceof FocusState) {\n            return activation.origin$.pipe(map(origin => origin != null))\n        } else {\n            return from(activation).pipe(\n                switchMap(value => {\n                    if (isElementInput(value) || value instanceof FocusState) {\n                        return this.#trigger(value)\n                    } else {\n                        return of(value)\n                    }\n                })\n            )\n        }\n    }\n\n    #focusActivation(element: HTMLElement): Observable<boolean> {\n        return this.#focusEvent.pipe(map(focused => focused === element || element.contains(focused)))\n    }\n}\n\nfunction keystrokeId(ks: Keystroke): string {\n    let res = ks.key\n    if (ks.shift) {\n        res += \"+shift\"\n    }\n    if (ks.ctrl) {\n        res += \"+ctrl\"\n    }\n    if (ks.alt) {\n        res += \"+alt\"\n    }\n    res += `${ks.state}`\n    return res\n}\n\nfunction eventToKeystroke(event: KeyboardEvent): Keystroke {\n    return {\n        key: event.key,\n        shift: event.shiftKey,\n        ctrl: event.ctrlKey,\n        alt: event.altKey,\n        state: event.type === \"keyup\" ? \"up\" : \"down\"\n    }\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { computed, Directive, effect, inject } from "@angular/core";
|
|
2
|
+
import { coerceBoolAttr } from "@ngutil/common";
|
|
3
|
+
import { UiState } from "./ui-state";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export const NOTSET = Symbol("NOTSET");
|
|
6
|
+
export class AbstractUiState {
|
|
7
|
+
constructor(name) {
|
|
8
|
+
this.name = name;
|
|
9
|
+
this.state = inject(UiState);
|
|
10
|
+
this.yes = computed(() => {
|
|
11
|
+
const when = this.when();
|
|
12
|
+
if (when !== NOTSET) {
|
|
13
|
+
return this.state.is(this.name, `${when},self`);
|
|
14
|
+
}
|
|
15
|
+
return this.state.is(this.name);
|
|
16
|
+
});
|
|
17
|
+
this.no = computed(() => !this.yes());
|
|
18
|
+
effect(() => {
|
|
19
|
+
const input = this.input();
|
|
20
|
+
if (input !== NOTSET) {
|
|
21
|
+
this.state.set(name, !!coerceBoolAttr(input));
|
|
22
|
+
}
|
|
23
|
+
this.yes();
|
|
24
|
+
}, { allowSignalWrites: true });
|
|
25
|
+
}
|
|
26
|
+
set(value, source) {
|
|
27
|
+
this.state.set(this.name, value, source);
|
|
28
|
+
}
|
|
29
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: AbstractUiState, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
|
30
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: AbstractUiState, ngImport: i0 }); }
|
|
31
|
+
}
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: AbstractUiState, decorators: [{
|
|
33
|
+
type: Directive
|
|
34
|
+
}], ctorParameters: () => [{ type: undefined }] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy91aS1zdGF0ZS9hYnN0cmFjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFBO0FBRTNFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUUvQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFBOztBQUVwQyxNQUFNLENBQUMsTUFBTSxNQUFNLEdBQVEsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFBO0FBRzNDLE1BQU0sT0FBZ0IsZUFBZTtJQWVqQyxZQUFxQixJQUFPO1FBQVAsU0FBSSxHQUFKLElBQUksQ0FBRztRQWRuQixVQUFLLEdBQWUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBS25DLFFBQUcsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ3pCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQTtZQUN4QixJQUFJLElBQUksS0FBSyxNQUFNLEVBQUUsQ0FBQztnQkFDbEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLEdBQUcsSUFBSSxPQUFPLENBQUMsQ0FBQTtZQUNuRCxDQUFDO1lBQ0QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDbkMsQ0FBQyxDQUFDLENBQUE7UUFDTyxPQUFFLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUE7UUFHckMsTUFBTSxDQUNGLEdBQUcsRUFBRTtZQUNELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQTtZQUMxQixJQUFJLEtBQUssS0FBSyxNQUFNLEVBQUUsQ0FBQztnQkFDbkIsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQTtZQUNqRCxDQUFDO1lBQ0QsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFBO1FBQ2QsQ0FBQyxFQUNELEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLENBQzlCLENBQUE7SUFDTCxDQUFDO0lBRUQsR0FBRyxDQUFDLEtBQWMsRUFBRSxNQUFjO1FBQzlCLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFBO0lBQzVDLENBQUM7OEdBOUJpQixlQUFlO2tHQUFmLGVBQWU7OzJGQUFmLGVBQWU7a0JBRHBDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb21wdXRlZCwgRGlyZWN0aXZlLCBlZmZlY3QsIGluamVjdCwgU2lnbmFsIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5pbXBvcnQgeyBjb2VyY2VCb29sQXR0ciB9IGZyb20gXCJAbmd1dGlsL2NvbW1vblwiXG5cbmltcG9ydCB7IFVpU3RhdGUgfSBmcm9tIFwiLi91aS1zdGF0ZVwiXG5cbmV4cG9ydCBjb25zdCBOT1RTRVQ6IGFueSA9IFN5bWJvbChcIk5PVFNFVFwiKVxuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFVpU3RhdGU8TiBleHRlbmRzIHN0cmluZz4ge1xuICAgIHJlYWRvbmx5IHN0YXRlOiBVaVN0YXRlPE4+ID0gaW5qZWN0KFVpU3RhdGUpXG5cbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgcmVhZG9ubHkgaW5wdXQ6IFNpZ25hbDxib29sZWFuPlxuICAgIHByb3RlY3RlZCBhYnN0cmFjdCByZWFkb25seSB3aGVuOiBTaWduYWw8c3RyaW5nPlxuXG4gICAgcmVhZG9ubHkgeWVzID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgICAgICBjb25zdCB3aGVuID0gdGhpcy53aGVuKClcbiAgICAgICAgaWYgKHdoZW4gIT09IE5PVFNFVCkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMuc3RhdGUuaXModGhpcy5uYW1lLCBgJHt3aGVufSxzZWxmYClcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5zdGF0ZS5pcyh0aGlzLm5hbWUpXG4gICAgfSlcbiAgICByZWFkb25seSBubyA9IGNvbXB1dGVkKCgpID0+ICF0aGlzLnllcygpKVxuXG4gICAgY29uc3RydWN0b3IocmVhZG9ubHkgbmFtZTogTikge1xuICAgICAgICBlZmZlY3QoXG4gICAgICAgICAgICAoKSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgaW5wdXQgPSB0aGlzLmlucHV0KClcbiAgICAgICAgICAgICAgICBpZiAoaW5wdXQgIT09IE5PVFNFVCkge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnN0YXRlLnNldChuYW1lLCAhIWNvZXJjZUJvb2xBdHRyKGlucHV0KSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdGhpcy55ZXMoKVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHsgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUgfVxuICAgICAgICApXG4gICAgfVxuXG4gICAgc2V0KHZhbHVlOiBib29sZWFuLCBzb3VyY2U6IHN0cmluZykge1xuICAgICAgICB0aGlzLnN0YXRlLnNldCh0aGlzLm5hbWUsIHZhbHVlLCBzb3VyY2UpXG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Directive, input } from "@angular/core";
|
|
2
|
+
import { AbstractUiState, NOTSET } from "./abstract";
|
|
3
|
+
import { UiState } from "./ui-state";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class BusyDirective extends AbstractUiState {
|
|
6
|
+
constructor() {
|
|
7
|
+
super("busy");
|
|
8
|
+
this.input = input(NOTSET, { alias: "nuBusy" });
|
|
9
|
+
this.when = input(NOTSET, { alias: "nuBusyWhen" });
|
|
10
|
+
}
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: BusyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
12
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.6", type: BusyDirective, isStandalone: true, selector: "[nuBusy], [nuBusyWhen]", inputs: { input: { classPropertyName: "input", publicName: "nuBusy", isSignal: true, isRequired: false, transformFunction: null }, when: { classPropertyName: "when", publicName: "nuBusyWhen", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.aria-busy": "yes() ? 'true' : 'false'", "attr.inert": "yes() ? '' : null" } }, providers: [UiState], exportAs: ["busy"], usesInheritance: true, ngImport: i0 }); }
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: BusyDirective, decorators: [{
|
|
15
|
+
type: Directive,
|
|
16
|
+
args: [{
|
|
17
|
+
selector: "[nuBusy], [nuBusyWhen]",
|
|
18
|
+
exportAs: "busy",
|
|
19
|
+
standalone: true,
|
|
20
|
+
host: {
|
|
21
|
+
"[attr.aria-busy]": "yes() ? 'true' : 'false'",
|
|
22
|
+
"[attr.inert]": "yes() ? '' : null"
|
|
23
|
+
},
|
|
24
|
+
providers: [UiState]
|
|
25
|
+
}]
|
|
26
|
+
}], ctorParameters: () => [] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVzeS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy91aS1zdGF0ZS9idXN5LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUVoRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUNwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFBOztBQVlwQyxNQUFNLE9BQU8sYUFBYyxTQUFRLGVBQXVCO0lBSXREO1FBQ0ksS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBSkUsVUFBSyxHQUFHLEtBQUssQ0FBQyxNQUFpQixFQUFFLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUE7UUFDckQsU0FBSSxHQUFHLEtBQUssQ0FBQyxNQUFnQixFQUFFLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxDQUFDLENBQUE7SUFJMUUsQ0FBQzs4R0FOUSxhQUFhO2tHQUFiLGFBQWEsZ2JBRlgsQ0FBQyxPQUFPLENBQUM7OzJGQUVYLGFBQWE7a0JBVnpCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsUUFBUSxFQUFFLE1BQU07b0JBQ2hCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0Ysa0JBQWtCLEVBQUUsMEJBQTBCO3dCQUM5QyxjQUFjLEVBQUUsbUJBQW1CO3FCQUN0QztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUM7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgQWJzdHJhY3RVaVN0YXRlLCBOT1RTRVQgfSBmcm9tIFwiLi9hYnN0cmFjdFwiXG5pbXBvcnQgeyBVaVN0YXRlIH0gZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJbbnVCdXN5XSwgW251QnVzeVdoZW5dXCIsXG4gICAgZXhwb3J0QXM6IFwiYnVzeVwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICBcIlthdHRyLmFyaWEtYnVzeV1cIjogXCJ5ZXMoKSA/ICd0cnVlJyA6ICdmYWxzZSdcIixcbiAgICAgICAgXCJbYXR0ci5pbmVydF1cIjogXCJ5ZXMoKSA/ICcnIDogbnVsbFwiXG4gICAgfSxcbiAgICBwcm92aWRlcnM6IFtVaVN0YXRlXVxufSlcbmV4cG9ydCBjbGFzcyBCdXN5RGlyZWN0aXZlIGV4dGVuZHMgQWJzdHJhY3RVaVN0YXRlPFwiYnVzeVwiPiB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGlucHV0ID0gaW5wdXQoTk9UU0VUIGFzIGJvb2xlYW4sIHsgYWxpYXM6IFwibnVCdXN5XCIgfSlcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgd2hlbiA9IGlucHV0KE5PVFNFVCBhcyBzdHJpbmcsIHsgYWxpYXM6IFwibnVCdXN5V2hlblwiIH0pXG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoXCJidXN5XCIpXG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Directive, input } from "@angular/core";
|
|
2
|
+
import { AbstractUiState, NOTSET } from "./abstract";
|
|
3
|
+
import { UiState } from "./ui-state";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class DisabledDirective extends AbstractUiState {
|
|
6
|
+
constructor() {
|
|
7
|
+
super("disabled");
|
|
8
|
+
this.input = input(NOTSET, { alias: "nuDisabled" });
|
|
9
|
+
this.when = input(NOTSET, { alias: "nuDisabledWhen" });
|
|
10
|
+
}
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DisabledDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
12
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.6", type: DisabledDirective, isStandalone: true, selector: "[nuDisabled], [nuDisabledWhen]", inputs: { input: { classPropertyName: "input", publicName: "nuDisabled", isSignal: true, isRequired: false, transformFunction: null }, when: { classPropertyName: "when", publicName: "nuDisabledWhen", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.aria-disabled": "yes() ? 'true' : 'false'", "attr.disabled": "yes() ? '' : null", "attr.inert": "yes() ? '' : null" } }, providers: [UiState], exportAs: ["disabled"], usesInheritance: true, ngImport: i0 }); }
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DisabledDirective, decorators: [{
|
|
15
|
+
type: Directive,
|
|
16
|
+
args: [{
|
|
17
|
+
selector: "[nuDisabled], [nuDisabledWhen]",
|
|
18
|
+
exportAs: "disabled",
|
|
19
|
+
standalone: true,
|
|
20
|
+
host: {
|
|
21
|
+
"[attr.aria-disabled]": "yes() ? 'true' : 'false'",
|
|
22
|
+
"[attr.disabled]": "yes() ? '' : null",
|
|
23
|
+
"[attr.inert]": "yes() ? '' : null"
|
|
24
|
+
},
|
|
25
|
+
providers: [UiState]
|
|
26
|
+
}]
|
|
27
|
+
}], ctorParameters: () => [] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzYWJsZWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYXJpYS9zcmMvdWktc3RhdGUvZGlzYWJsZWQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRWhELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBQ3BELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUE7O0FBYXBDLE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxlQUEyQjtJQUk5RDtRQUNJLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUpGLFVBQUssR0FBRyxLQUFLLENBQUMsTUFBaUIsRUFBRSxFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFBO1FBQ3pELFNBQUksR0FBRyxLQUFLLENBQUMsTUFBZ0IsRUFBRSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUE7SUFJOUUsQ0FBQzs4R0FOUSxpQkFBaUI7a0dBQWpCLGlCQUFpQiwwZUFGZixDQUFDLE9BQU8sQ0FBQzs7MkZBRVgsaUJBQWlCO2tCQVg3QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQ0FBZ0M7b0JBQzFDLFFBQVEsRUFBRSxVQUFVO29CQUNwQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNGLHNCQUFzQixFQUFFLDBCQUEwQjt3QkFDbEQsaUJBQWlCLEVBQUUsbUJBQW1CO3dCQUN0QyxjQUFjLEVBQUUsbUJBQW1CO3FCQUN0QztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUM7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgQWJzdHJhY3RVaVN0YXRlLCBOT1RTRVQgfSBmcm9tIFwiLi9hYnN0cmFjdFwiXG5pbXBvcnQgeyBVaVN0YXRlIH0gZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJbbnVEaXNhYmxlZF0sIFtudURpc2FibGVkV2hlbl1cIixcbiAgICBleHBvcnRBczogXCJkaXNhYmxlZFwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICBcIlthdHRyLmFyaWEtZGlzYWJsZWRdXCI6IFwieWVzKCkgPyAndHJ1ZScgOiAnZmFsc2UnXCIsXG4gICAgICAgIFwiW2F0dHIuZGlzYWJsZWRdXCI6IFwieWVzKCkgPyAnJyA6IG51bGxcIixcbiAgICAgICAgXCJbYXR0ci5pbmVydF1cIjogXCJ5ZXMoKSA/ICcnIDogbnVsbFwiXG4gICAgfSxcbiAgICBwcm92aWRlcnM6IFtVaVN0YXRlXVxufSlcbmV4cG9ydCBjbGFzcyBEaXNhYmxlZERpcmVjdGl2ZSBleHRlbmRzIEFic3RyYWN0VWlTdGF0ZTxcImRpc2FibGVkXCI+IHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaW5wdXQgPSBpbnB1dChOT1RTRVQgYXMgYm9vbGVhbiwgeyBhbGlhczogXCJudURpc2FibGVkXCIgfSlcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgd2hlbiA9IGlucHV0KE5PVFNFVCBhcyBzdHJpbmcsIHsgYWxpYXM6IFwibnVEaXNhYmxlZFdoZW5cIiB9KVxuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFwiZGlzYWJsZWRcIilcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { BusyDirective } from "./busy.directive";
|
|
3
|
+
import { DisabledDirective } from "./disabled.directive";
|
|
4
|
+
import { ReadonlyDirective } from "./readonly.directive";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export * from "./abstract";
|
|
7
|
+
export * from "./busy.directive";
|
|
8
|
+
export * from "./disabled.directive";
|
|
9
|
+
export * from "./progress-state";
|
|
10
|
+
export * from "./readonly.directive";
|
|
11
|
+
export * from "./ui-state";
|
|
12
|
+
const entries = [BusyDirective, DisabledDirective, ReadonlyDirective];
|
|
13
|
+
export class UiStateModule {
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: UiStateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
15
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: UiStateModule, imports: [BusyDirective, DisabledDirective, ReadonlyDirective], exports: [BusyDirective, DisabledDirective, ReadonlyDirective] }); }
|
|
16
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: UiStateModule }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: UiStateModule, decorators: [{
|
|
19
|
+
type: NgModule,
|
|
20
|
+
args: [{
|
|
21
|
+
imports: entries,
|
|
22
|
+
exports: entries
|
|
23
|
+
}]
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy91aS1zdGF0ZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRXhDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUNoRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUN4RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTs7QUFFeEQsY0FBYyxZQUFZLENBQUE7QUFDMUIsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLHNCQUFzQixDQUFBO0FBQ3BDLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLFlBQVksQ0FBQTtBQUUxQixNQUFNLE9BQU8sR0FBRyxDQUFDLGFBQWEsRUFBRSxpQkFBaUIsRUFBRSxpQkFBaUIsQ0FBQyxDQUFBO0FBTXJFLE1BQU0sT0FBTyxhQUFhOzhHQUFiLGFBQWE7K0dBQWIsYUFBYSxZQU5ULGFBQWEsRUFBRSxpQkFBaUIsRUFBRSxpQkFBaUIsYUFBbkQsYUFBYSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQjsrR0FNdkQsYUFBYTs7MkZBQWIsYUFBYTtrQkFKekIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsT0FBTztvQkFDaEIsT0FBTyxFQUFFLE9BQU87aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB7IEJ1c3lEaXJlY3RpdmUgfSBmcm9tIFwiLi9idXN5LmRpcmVjdGl2ZVwiXG5pbXBvcnQgeyBEaXNhYmxlZERpcmVjdGl2ZSB9IGZyb20gXCIuL2Rpc2FibGVkLmRpcmVjdGl2ZVwiXG5pbXBvcnQgeyBSZWFkb25seURpcmVjdGl2ZSB9IGZyb20gXCIuL3JlYWRvbmx5LmRpcmVjdGl2ZVwiXG5cbmV4cG9ydCAqIGZyb20gXCIuL2Fic3RyYWN0XCJcbmV4cG9ydCAqIGZyb20gXCIuL2J1c3kuZGlyZWN0aXZlXCJcbmV4cG9ydCAqIGZyb20gXCIuL2Rpc2FibGVkLmRpcmVjdGl2ZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9wcm9ncmVzcy1zdGF0ZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9yZWFkb25seS5kaXJlY3RpdmVcIlxuZXhwb3J0ICogZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5jb25zdCBlbnRyaWVzID0gW0J1c3lEaXJlY3RpdmUsIERpc2FibGVkRGlyZWN0aXZlLCBSZWFkb25seURpcmVjdGl2ZV1cblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBlbnRyaWVzLFxuICAgIGV4cG9ydHM6IGVudHJpZXNcbn0pXG5leHBvcnQgY2xhc3MgVWlTdGF0ZU1vZHVsZSB7fVxuIl19
|