@ngutil/aria 0.0.53 → 0.0.56

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.
@@ -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: "17.3.6", ngImport: i0, type: ActivityService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
43
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: ActivityService, providedIn: "root" }); }
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: "17.3.6", ngImport: i0, type: ActivityService, decorators: [{
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: "17.3.6", ngImport: i0, type: FocusState, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
50
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.6", type: FocusState, isStandalone: true, host: { properties: { "attr.focus": "origin()", "attr.focusWithin": "within()" } }, ngImport: i0 }); }
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: "17.3.6", ngImport: i0, type: FocusState, decorators: [{
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: "17.3.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: "17.3.6", ngImport: i0, type: FocusService, providedIn: "root" }); }
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: "17.3.6", ngImport: i0, type: FocusService, decorators: [{
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 { DisabledState, isElementInput } from "@ngutil/common";
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
- const isDisabled = this.#disabled?.isDisabled();
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: "17.3.6", ngImport: i0, type: Focusable, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
41
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.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 }); }
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: "17.3.6", ngImport: i0, type: Focusable, decorators: [{
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXNhYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FyaWEvc3JjL2ZvY3VzL2ZvY3VzYWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUUsT0FBTyxFQUFtQixhQUFhLEVBQWdCLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBRTdGLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQTs7O0FBRXBELDhDQUE4QztBQVc5QyxNQUFNLE9BQU8sU0FBUztJQUNULFNBQVMsQ0FBd0Q7SUEwQjFFO1FBMUJTLGNBQVMsR0FBRyxNQUFNLENBQUMsYUFBYSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQTtRQUNqRSxVQUFLLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBRTFCLGNBQVMsR0FBRyxLQUFLLENBQW1CLElBQUksRUFBRSxFQUFFLEtBQUssRUFBRSxhQUFhLEVBQUUsQ0FBQyxDQUFBO1FBQ25FLGFBQVEsR0FBRyxLQUFLLENBQUMsQ0FBQyxFQUFFLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUE7UUFFMUMsY0FBUyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDL0IsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFBO1lBQ2xDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQTtZQUNoQyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxDQUFBO1lBRS9DLElBQUksU0FBUyxLQUFLLEtBQUssSUFBSSxVQUFVLEVBQUUsQ0FBQztnQkFDcEMsT0FBTyxDQUFDLENBQUMsQ0FBQTtZQUNiLENBQUM7WUFFRCxJQUFJLE9BQU8sU0FBUyxLQUFLLFFBQVEsRUFBRSxDQUFDO2dCQUNoQyxPQUFPLFNBQVMsQ0FBQTtZQUNwQixDQUFDO1lBRUQsSUFBSSxTQUFTLEtBQUssSUFBSSxJQUFJLFFBQVEsSUFBSSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztnQkFDN0QsT0FBTyxRQUFRLENBQUE7WUFDbkIsQ0FBQztZQUVELE9BQU8sQ0FBQyxDQUFBO1FBQ1osQ0FBQyxDQUFDLENBQUE7UUFHRSx1REFBdUQ7UUFDdkQsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsRUFBRSxFQUFFLGlCQUFpQixFQUFFLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDaEUsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUE0QztRQUNoRCxJQUFJLEtBQUssWUFBWSxVQUFVLElBQUksY0FBYyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUNwQyxDQUFDO2FBQU0sQ0FBQztZQUNKLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQzFDLENBQUM7SUFDTCxDQUFDOzhHQXRDUSxTQUFTO2tHQUFULFNBQVM7OzJGQUFULFNBQVM7a0JBVHJCLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxlQUFlO29CQUN6QixRQUFRLEVBQUUsYUFBYTtvQkFDdkIsSUFBSSxFQUFFO3dCQUNGLGlCQUFpQixFQUFFLGFBQWE7cUJBQ25DO29CQUNELGNBQWMsRUFBRSxDQUFDLFVBQVUsQ0FBQztpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb21wdXRlZCwgRGlyZWN0aXZlLCBlZmZlY3QsIGluamVjdCwgaW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbmltcG9ydCB7IENvbm5lY3RQcm90b2NvbCwgRGlzYWJsZWRTdGF0ZSwgRWxlbWVudElucHV0LCBpc0VsZW1lbnRJbnB1dCB9IGZyb20gXCJAbmd1dGlsL2NvbW1vblwiXG5cbmltcG9ydCB7IEZvY3VzU3RhdGUgfSBmcm9tIFwiLi9mb2N1cy1zdGF0ZS5kaXJlY3RpdmVcIlxuXG4vLyBUT0RPOiB3aGF0IGhhcHBlbnMgd2hlbiBkaXNhYmxlZCBpcyBjaGFuZ2VkXG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6IFwiW251Rm9jdXNhYmxlXVwiLFxuICAgIGV4cG9ydEFzOiBcIm51Rm9jdXNhYmxlXCIsXG4gICAgaG9zdDoge1xuICAgICAgICBcIlthdHRyLnRhYmluZGV4XVwiOiBcIl90YWJpbmRleCgpXCJcbiAgICB9LFxuICAgIGhvc3REaXJlY3RpdmVzOiBbRm9jdXNTdGF0ZV1cbn0pXG5leHBvcnQgY2xhc3MgRm9jdXNhYmxlIGltcGxlbWVudHMgQ29ubmVjdFByb3RvY29sIHtcbiAgICByZWFkb25seSAjZGlzYWJsZWQgPSBpbmplY3QoRGlzYWJsZWRTdGF0ZSwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KVxuICAgIHJlYWRvbmx5IHN0YXRlID0gaW5qZWN0KEZvY3VzU3RhdGUpXG5cbiAgICByZWFkb25seSBmb2N1c2FibGUgPSBpbnB1dDxib29sZWFuIHwgbnVtYmVyPih0cnVlLCB7IGFsaWFzOiBcIm51Rm9jdXNhYmxlXCIgfSlcbiAgICByZWFkb25seSB0YWJpbmRleCA9IGlucHV0KDAsIHsgdHJhbnNmb3JtOiBOdW1iZXIgfSlcblxuICAgIHJlYWRvbmx5IF90YWJpbmRleCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3QgZm9jdXNhYmxlID0gdGhpcy5mb2N1c2FibGUoKVxuICAgICAgICBjb25zdCB0YWJpbmRleCA9IHRoaXMudGFiaW5kZXgoKVxuICAgICAgICBjb25zdCBpc0Rpc2FibGVkID0gdGhpcy4jZGlzYWJsZWQ/LmlzRGlzYWJsZWQoKVxuXG4gICAgICAgIGlmIChmb2N1c2FibGUgPT09IGZhbHNlIHx8IGlzRGlzYWJsZWQpIHtcbiAgICAgICAgICAgIHJldHVybiAtMVxuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHR5cGVvZiBmb2N1c2FibGUgPT09IFwibnVtYmVyXCIpIHtcbiAgICAgICAgICAgIHJldHVybiBmb2N1c2FibGVcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChmb2N1c2FibGUgPT09IHRydWUgJiYgdGFiaW5kZXggIT0gbnVsbCAmJiAhaXNOYU4odGFiaW5kZXgpKSB7XG4gICAgICAgICAgICByZXR1cm4gdGFiaW5kZXhcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiAwXG4gICAgfSlcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICAvLyBUT0RPOiBtacOpcnQga2VsbCBlej8sIGhhIG5pbmNzIGl0dCBha2tvciBuZW0gZnJpc3PDvGxcbiAgICAgICAgZWZmZWN0KCgpID0+IHRoaXMuX3RhYmluZGV4KCksIHsgYWxsb3dTaWduYWxXcml0ZXM6IGZhbHNlIH0pXG4gICAgfVxuXG4gICAgY29ubmVjdCh2YWx1ZTogRm9jdXNhYmxlIHwgRm9jdXNTdGF0ZSB8IEVsZW1lbnRJbnB1dCkge1xuICAgICAgICBpZiAodmFsdWUgaW5zdGFuY2VvZiBGb2N1c1N0YXRlIHx8IGlzRWxlbWVudElucHV0KHZhbHVlKSkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMuc3RhdGUuY29ubmVjdCh2YWx1ZSlcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLnN0YXRlLmNvbm5lY3QodmFsdWUuc3RhdGUpXG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
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: "17.3.6", ngImport: i0, type: GesturesService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
96
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: GesturesService, providedIn: "root" }); }
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: "17.3.6", ngImport: i0, type: GesturesService, decorators: [{
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlDLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUMzRSxPQUFPLEVBQWUsWUFBWSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFnQyxNQUFNLFNBQVMsQ0FBQTtBQUNuSCxPQUFPLEVBQTZCLGdCQUFnQixFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQ3pFLGNBQWMsWUFBWSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQWN0aXZpdHlFdmVudCwgQWN0aXZpdHlPcmlnaW4sIEFjdGl2aXR5U2VydmljZSB9IGZyb20gXCIuL2FjdGl2aXR5XCJcbmV4cG9ydCB7IEZvY3VzT3JpZ2luLCBGb2N1c1NlcnZpY2UsIEZvY3VzVHJhcCwgRm9jdXNhYmxlLCBGb2N1c1N0YXRlLCBGb2N1c2FibGVFdmVudCwgRm9jdXNDaGFuZ2VzIH0gZnJvbSBcIi4vZm9jdXNcIlxuZXhwb3J0IHsgS2V5c3Ryb2tlLCBLZXlzdHJva2VFdmVudCwgS2V5c3Ryb2tlU2VydmljZSB9IGZyb20gXCIuL2tleXN0cm9rZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9nZXN0dXJlc1wiXG4iXX0=
5
+ export * from "./ui-state";
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlDLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUMzRSxPQUFPLEVBQWUsWUFBWSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFnQyxNQUFNLFNBQVMsQ0FBQTtBQUNuSCxPQUFPLEVBQTZCLGdCQUFnQixFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQ3pFLGNBQWMsWUFBWSxDQUFBO0FBQzFCLGNBQWMsWUFBWSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQWN0aXZpdHlFdmVudCwgQWN0aXZpdHlPcmlnaW4sIEFjdGl2aXR5U2VydmljZSB9IGZyb20gXCIuL2FjdGl2aXR5XCJcbmV4cG9ydCB7IEZvY3VzT3JpZ2luLCBGb2N1c1NlcnZpY2UsIEZvY3VzVHJhcCwgRm9jdXNhYmxlLCBGb2N1c1N0YXRlLCBGb2N1c2FibGVFdmVudCwgRm9jdXNDaGFuZ2VzIH0gZnJvbSBcIi4vZm9jdXNcIlxuZXhwb3J0IHsgS2V5c3Ryb2tlLCBLZXlzdHJva2VFdmVudCwgS2V5c3Ryb2tlU2VydmljZSB9IGZyb20gXCIuL2tleXN0cm9rZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9nZXN0dXJlc1wiXG5leHBvcnQgKiBmcm9tIFwiLi91aS1zdGF0ZVwiXG4iXX0=
@@ -12,7 +12,6 @@ export class KeystrokeService {
12
12
  watch(activation, ...keystrokes) {
13
13
  return new Observable((dst) => this.#trigger(activation)
14
14
  .pipe(distinctUntilChanged(), switchMap(enabled => {
15
- console.log({ enabled }, keystrokes);
16
15
  if (enabled) {
17
16
  return this.#keyEvent;
18
17
  }
@@ -60,10 +59,10 @@ export class KeystrokeService {
60
59
  #focusActivation(element) {
61
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: "17.3.6", ngImport: i0, type: KeystrokeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
64
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: KeystrokeService, providedIn: "root" }); }
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: "17.3.6", ngImport: i0, type: KeystrokeService, decorators: [{
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
  }] });
@@ -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 { 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                        console.log({ enabled }, keystrokes)\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"]}
92
+ //# 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 { 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,41 @@
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
+ intercept(source) {
30
+ return this.state.intercept(this.name, source);
31
+ }
32
+ wrap(observable, source) {
33
+ return this.state.wrap(observable, this.name, source);
34
+ }
35
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: AbstractUiState, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
36
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: AbstractUiState, ngImport: i0 }); }
37
+ }
38
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: AbstractUiState, decorators: [{
39
+ type: Directive
40
+ }], ctorParameters: () => [{ type: undefined }] });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy91aS1zdGF0ZS9hYnN0cmFjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFBO0FBSTNFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUUvQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFBOztBQUVwQyxNQUFNLENBQUMsTUFBTSxNQUFNLEdBQVEsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFBO0FBRzNDLE1BQU0sT0FBZ0IsZUFBZTtJQWVqQyxZQUFxQixJQUFPO1FBQVAsU0FBSSxHQUFKLElBQUksQ0FBRztRQWRuQixVQUFLLEdBQWUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBS25DLFFBQUcsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ3pCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQTtZQUN4QixJQUFJLElBQUksS0FBSyxNQUFNLEVBQUUsQ0FBQztnQkFDbEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLEdBQUcsSUFBSSxPQUFPLENBQUMsQ0FBQTtZQUNuRCxDQUFDO1lBQ0QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDbkMsQ0FBQyxDQUFDLENBQUE7UUFDTyxPQUFFLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUE7UUFHckMsTUFBTSxDQUNGLEdBQUcsRUFBRTtZQUNELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQTtZQUMxQixJQUFJLEtBQUssS0FBSyxNQUFNLEVBQUUsQ0FBQztnQkFDbkIsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQTtZQUNqRCxDQUFDO1lBQ0QsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFBO1FBQ2QsQ0FBQyxFQUNELEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLENBQzlCLENBQUE7SUFDTCxDQUFDO0lBRUQsR0FBRyxDQUFDLEtBQWMsRUFBRSxNQUFjO1FBQzlCLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFBO0lBQzVDLENBQUM7SUFFRCxTQUFTLENBQUMsTUFBYztRQUNwQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUE7SUFDbEQsQ0FBQztJQUVELElBQUksQ0FBSSxVQUF5QixFQUFFLE1BQWM7UUFDN0MsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQTtJQUN6RCxDQUFDOzhHQXRDaUIsZUFBZTtrR0FBZixlQUFlOzsyRkFBZixlQUFlO2tCQURwQyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29tcHV0ZWQsIERpcmVjdGl2ZSwgZWZmZWN0LCBpbmplY3QsIFNpZ25hbCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCJcblxuaW1wb3J0IHsgY29lcmNlQm9vbEF0dHIgfSBmcm9tIFwiQG5ndXRpbC9jb21tb25cIlxuXG5pbXBvcnQgeyBVaVN0YXRlIH0gZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5leHBvcnQgY29uc3QgTk9UU0VUOiBhbnkgPSBTeW1ib2woXCJOT1RTRVRcIilcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RVaVN0YXRlPE4gZXh0ZW5kcyBzdHJpbmc+IHtcbiAgICByZWFkb25seSBzdGF0ZTogVWlTdGF0ZTxOPiA9IGluamVjdChVaVN0YXRlKVxuXG4gICAgYWJzdHJhY3QgcmVhZG9ubHkgaW5wdXQ6IFNpZ25hbDxib29sZWFuPlxuICAgIGFic3RyYWN0IHJlYWRvbmx5IHdoZW46IFNpZ25hbDxzdHJpbmc+XG5cbiAgICByZWFkb25seSB5ZXMgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IHdoZW4gPSB0aGlzLndoZW4oKVxuICAgICAgICBpZiAod2hlbiAhPT0gTk9UU0VUKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5zdGF0ZS5pcyh0aGlzLm5hbWUsIGAke3doZW59LHNlbGZgKVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLnN0YXRlLmlzKHRoaXMubmFtZSlcbiAgICB9KVxuICAgIHJlYWRvbmx5IG5vID0gY29tcHV0ZWQoKCkgPT4gIXRoaXMueWVzKCkpXG5cbiAgICBjb25zdHJ1Y3RvcihyZWFkb25seSBuYW1lOiBOKSB7XG4gICAgICAgIGVmZmVjdChcbiAgICAgICAgICAgICgpID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCBpbnB1dCA9IHRoaXMuaW5wdXQoKVxuICAgICAgICAgICAgICAgIGlmIChpbnB1dCAhPT0gTk9UU0VUKSB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuc3RhdGUuc2V0KG5hbWUsICEhY29lcmNlQm9vbEF0dHIoaW5wdXQpKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB0aGlzLnllcygpXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgeyBhbGxvd1NpZ25hbFdyaXRlczogdHJ1ZSB9XG4gICAgICAgIClcbiAgICB9XG5cbiAgICBzZXQodmFsdWU6IGJvb2xlYW4sIHNvdXJjZTogc3RyaW5nKSB7XG4gICAgICAgIHRoaXMuc3RhdGUuc2V0KHRoaXMubmFtZSwgdmFsdWUsIHNvdXJjZSlcbiAgICB9XG5cbiAgICBpbnRlcmNlcHQoc291cmNlOiBzdHJpbmcpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RhdGUuaW50ZXJjZXB0KHRoaXMubmFtZSwgc291cmNlKVxuICAgIH1cblxuICAgIHdyYXA8VD4ob2JzZXJ2YWJsZTogT2JzZXJ2YWJsZTxUPiwgc291cmNlOiBzdHJpbmcpOiBPYnNlcnZhYmxlPFQ+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RhdGUud3JhcChvYnNlcnZhYmxlLCB0aGlzLm5hbWUsIHNvdXJjZSlcbiAgICB9XG59XG4iXX0=
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVzeS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hcmlhL3NyYy91aS1zdGF0ZS9idXN5LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUVoRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUNwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFBOztBQVlwQyxNQUFNLE9BQU8sYUFBYyxTQUFRLGVBQXVCO0lBSXREO1FBQ0ksS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBSlIsVUFBSyxHQUFHLEtBQUssQ0FBQyxNQUFpQixFQUFFLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUE7UUFDckQsU0FBSSxHQUFHLEtBQUssQ0FBQyxNQUFnQixFQUFFLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxDQUFDLENBQUE7SUFJaEUsQ0FBQzs4R0FOUSxhQUFhO2tHQUFiLGFBQWEsZ2JBRlgsQ0FBQyxPQUFPLENBQUM7OzJGQUVYLGFBQWE7a0JBVnpCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsUUFBUSxFQUFFLE1BQU07b0JBQ2hCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0Ysa0JBQWtCLEVBQUUsMEJBQTBCO3dCQUM5QyxjQUFjLEVBQUUsbUJBQW1CO3FCQUN0QztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUM7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgQWJzdHJhY3RVaVN0YXRlLCBOT1RTRVQgfSBmcm9tIFwiLi9hYnN0cmFjdFwiXG5pbXBvcnQgeyBVaVN0YXRlIH0gZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJbbnVCdXN5XSwgW251QnVzeVdoZW5dXCIsXG4gICAgZXhwb3J0QXM6IFwiYnVzeVwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICBcIlthdHRyLmFyaWEtYnVzeV1cIjogXCJ5ZXMoKSA/ICd0cnVlJyA6ICdmYWxzZSdcIixcbiAgICAgICAgXCJbYXR0ci5pbmVydF1cIjogXCJ5ZXMoKSA/ICcnIDogbnVsbFwiXG4gICAgfSxcbiAgICBwcm92aWRlcnM6IFtVaVN0YXRlXVxufSlcbmV4cG9ydCBjbGFzcyBCdXN5RGlyZWN0aXZlIGV4dGVuZHMgQWJzdHJhY3RVaVN0YXRlPFwiYnVzeVwiPiB7XG4gICAgcmVhZG9ubHkgaW5wdXQgPSBpbnB1dChOT1RTRVQgYXMgYm9vbGVhbiwgeyBhbGlhczogXCJudUJ1c3lcIiB9KVxuICAgIHJlYWRvbmx5IHdoZW4gPSBpbnB1dChOT1RTRVQgYXMgc3RyaW5nLCB7IGFsaWFzOiBcIm51QnVzeVdoZW5cIiB9KVxuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKFwiYnVzeVwiKVxuICAgIH1cbn1cbiJdfQ==
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzYWJsZWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYXJpYS9zcmMvdWktc3RhdGUvZGlzYWJsZWQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRWhELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBQ3BELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUE7O0FBYXBDLE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxlQUEyQjtJQUk5RDtRQUNJLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUpaLFVBQUssR0FBRyxLQUFLLENBQUMsTUFBaUIsRUFBRSxFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFBO1FBQ3pELFNBQUksR0FBRyxLQUFLLENBQUMsTUFBZ0IsRUFBRSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUE7SUFJcEUsQ0FBQzs4R0FOUSxpQkFBaUI7a0dBQWpCLGlCQUFpQiwwZUFGZixDQUFDLE9BQU8sQ0FBQzs7MkZBRVgsaUJBQWlCO2tCQVg3QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQ0FBZ0M7b0JBQzFDLFFBQVEsRUFBRSxVQUFVO29CQUNwQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNGLHNCQUFzQixFQUFFLDBCQUEwQjt3QkFDbEQsaUJBQWlCLEVBQUUsbUJBQW1CO3dCQUN0QyxjQUFjLEVBQUUsbUJBQW1CO3FCQUN0QztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUM7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgQWJzdHJhY3RVaVN0YXRlLCBOT1RTRVQgfSBmcm9tIFwiLi9hYnN0cmFjdFwiXG5pbXBvcnQgeyBVaVN0YXRlIH0gZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJbbnVEaXNhYmxlZF0sIFtudURpc2FibGVkV2hlbl1cIixcbiAgICBleHBvcnRBczogXCJkaXNhYmxlZFwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICBcIlthdHRyLmFyaWEtZGlzYWJsZWRdXCI6IFwieWVzKCkgPyAndHJ1ZScgOiAnZmFsc2UnXCIsXG4gICAgICAgIFwiW2F0dHIuZGlzYWJsZWRdXCI6IFwieWVzKCkgPyAnJyA6IG51bGxcIixcbiAgICAgICAgXCJbYXR0ci5pbmVydF1cIjogXCJ5ZXMoKSA/ICcnIDogbnVsbFwiXG4gICAgfSxcbiAgICBwcm92aWRlcnM6IFtVaVN0YXRlXVxufSlcbmV4cG9ydCBjbGFzcyBEaXNhYmxlZERpcmVjdGl2ZSBleHRlbmRzIEFic3RyYWN0VWlTdGF0ZTxcImRpc2FibGVkXCI+IHtcbiAgICByZWFkb25seSBpbnB1dCA9IGlucHV0KE5PVFNFVCBhcyBib29sZWFuLCB7IGFsaWFzOiBcIm51RGlzYWJsZWRcIiB9KVxuICAgIHJlYWRvbmx5IHdoZW4gPSBpbnB1dChOT1RTRVQgYXMgc3RyaW5nLCB7IGFsaWFzOiBcIm51RGlzYWJsZWRXaGVuXCIgfSlcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcihcImRpc2FibGVkXCIpXG4gICAgfVxufVxuIl19
@@ -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
@@ -0,0 +1,150 @@
1
+ import { Directive } from "@angular/core";
2
+ import { animationFrames, map, Observable, of, scan, shareReplay, startWith, Subject, switchMap, takeWhile, tap } from "rxjs";
3
+ import { clamp } from "lodash";
4
+ import * as i0 from "@angular/core";
5
+ const SEGMENT_REGISTER = { type: "fix", percent: 0 };
6
+ const SEGMENT_COMPLETE = { type: "fix", percent: 1 };
7
+ export class ProgressState {
8
+ constructor() {
9
+ this.#segments = {};
10
+ this.#input = new Subject();
11
+ this.#state = this.#input.pipe(startWith(null), scan((state, input) => {
12
+ if (Object.keys(state).length === 0) {
13
+ state = this.#initialState();
14
+ }
15
+ if (input == null) {
16
+ return state;
17
+ }
18
+ let current = state[input.name] ?? { ratio: 0, share: 0, done: false };
19
+ current = { ...current, ...input };
20
+ if (input.progress.type === "lax") {
21
+ delete current.laxBegin;
22
+ delete current.laxPercent;
23
+ }
24
+ return { ...state, [input.name]: { ...current, ...input } };
25
+ }, {}), switchMap(state => {
26
+ const laxCount = Object.values(state).filter(({ progress }) => progress.type === "lax").length;
27
+ if (laxCount > 0) {
28
+ return animationFrames().pipe(map(({ timestamp }) => {
29
+ for (const entry of Object.values(state)) {
30
+ if (entry.progress.type === "lax") {
31
+ if (entry.laxBegin == null) {
32
+ entry.laxBegin = timestamp;
33
+ }
34
+ let percent = (timestamp - entry.laxBegin) / entry.progress.predictedTime;
35
+ if (percent >= 0.8) {
36
+ const final = (timestamp - entry.laxBegin) / (entry.progress.predictedTime * 50);
37
+ percent = 0.8 + Math.log1p(final);
38
+ }
39
+ entry.laxPercent = clamp(percent, 0, 0.99);
40
+ }
41
+ else {
42
+ delete entry.laxPercent;
43
+ }
44
+ }
45
+ return state;
46
+ }), takeWhile(() => {
47
+ const doneCount = Object.values(state).filter(item => item.progress.type === "lax" && item.laxPercent >= 1).length;
48
+ return doneCount !== laxCount;
49
+ }, true));
50
+ }
51
+ else {
52
+ return of(state);
53
+ }
54
+ }), tap(state => {
55
+ const slist = Object.values(state);
56
+ const min = slist.reduce((min, current) => Math.min(min, current.distribution || 0), Infinity) || 1;
57
+ const totalDistribution = slist.reduce((total, current) => total + (current.distribution || min), 0);
58
+ for (const segment of slist) {
59
+ if (segment.distribution == null) {
60
+ segment.distribution = min;
61
+ }
62
+ segment.ratio = segment.distribution / totalDistribution + 0.0001;
63
+ if (segment.progress.type === "fix") {
64
+ const percent = clamp(segment.progress.percent, 0, 1);
65
+ segment.share = percent * segment.ratio;
66
+ segment.done = percent >= 1;
67
+ }
68
+ else if (segment.progress.type === "lax" && segment.laxPercent != null) {
69
+ const percent = segment.laxPercent;
70
+ segment.share = percent * segment.ratio;
71
+ segment.done = percent >= 1;
72
+ }
73
+ }
74
+ }), shareReplay({ bufferSize: 1, refCount: true }));
75
+ this.value$ = this.#state;
76
+ this.percent$ = this.value$.pipe(map(value => clamp(Object.values(value).reduce((a, b) => a + b.share, 0), 0, 1)), shareReplay({ bufferSize: 1, refCount: true }));
77
+ }
78
+ #segments;
79
+ #input;
80
+ #state;
81
+ segment(name, distribution) {
82
+ const segment = this.#segments[name] ?? (this.#segments[name] = new ProgressSegmentRef(this.#input, name, distribution));
83
+ segment.next(SEGMENT_REGISTER);
84
+ return segment;
85
+ }
86
+ connect(state, name, distribution) {
87
+ return new Observable(() => {
88
+ const segment = this.segment(name, distribution);
89
+ return state.percent$.subscribe(percent => {
90
+ segment.next({ type: "fix", percent });
91
+ });
92
+ });
93
+ }
94
+ #initialState() {
95
+ return Object.values(this.#segments).reduce((res, segment) => {
96
+ if (segment.value) {
97
+ res[segment.name] = {
98
+ name: segment.name,
99
+ distribution: segment.distribution,
100
+ progress: segment.value,
101
+ ratio: 0,
102
+ share: 0,
103
+ done: false
104
+ };
105
+ }
106
+ return res;
107
+ }, {});
108
+ }
109
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProgressState, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
110
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: ProgressState, ngImport: i0 }); }
111
+ }
112
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ProgressState, decorators: [{
113
+ type: Directive
114
+ }] });
115
+ export class ProgressSegmentRef {
116
+ #subject;
117
+ set distribution(value) {
118
+ if (this.#distribution !== value) {
119
+ this.#distribution = value;
120
+ if (this.#value != null) {
121
+ this.#next(this.#value);
122
+ }
123
+ }
124
+ }
125
+ get distribution() {
126
+ return this.#distribution;
127
+ }
128
+ #distribution;
129
+ get value() {
130
+ return this.#value;
131
+ }
132
+ #value;
133
+ constructor(subject, name, distribution) {
134
+ this.name = name;
135
+ this.#subject = subject;
136
+ this.#distribution = distribution;
137
+ }
138
+ next(progress) {
139
+ return this.#next(progress);
140
+ }
141
+ complete() {
142
+ return this.#next(SEGMENT_COMPLETE);
143
+ }
144
+ #next(progress) {
145
+ this.#value = progress;
146
+ this.#subject.next({ name: this.name, distribution: this.distribution, progress });
147
+ return this;
148
+ }
149
+ }
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-state.js","sourceRoot":"","sources":["../../../../../packages/aria/src/ui-state/progress-state.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive } from \"@angular/core\"\n\nimport {\n    animationFrames,\n    map,\n    Observable,\n    of,\n    scan,\n    shareReplay,\n    startWith,\n    Subject,\n    switchMap,\n    takeWhile,\n    tap\n} from \"rxjs\"\n\nimport { clamp } from \"lodash\"\nimport { Mutable } from \"utility-types\"\n\nimport { DeepReadonly } from \"@ngutil/common\"\n\nexport interface ProgressCommon {\n    readonly message?: string\n    readonly [other: string]: unknown\n}\n\nexport interface ProgressLax {\n    readonly type: \"lax\"\n    readonly predictedTime: number\n    // readonly updateInterval: number\n}\n\nexport interface ProgressFix {\n    readonly type: \"fix\"\n    readonly percent: number\n}\n\nexport type Progress = (ProgressLax | ProgressFix) & ProgressCommon\n\nexport interface ProgressSegmentInput {\n    readonly name: string\n    readonly distribution?: number\n    readonly progress: DeepReadonly<Progress>\n}\n\nexport interface ProgressSegement extends ProgressSegmentInput {\n    ratio: number\n    share: number\n    done: boolean\n    laxPercent?: number\n    laxBegin?: number\n}\n\nexport type ProgressSegements = { [key: string]: ProgressSegement }\n\nconst SEGMENT_REGISTER: Progress = { type: \"fix\", percent: 0 }\nconst SEGMENT_COMPLETE: Progress = { type: \"fix\", percent: 1 }\n\n@Directive()\nexport class ProgressState {\n    readonly #segments: { [key: string]: ProgressSegmentRef } = {}\n\n    readonly #input = new Subject<ProgressSegmentInput>()\n\n    readonly #state: Observable<ProgressSegements> = this.#input.pipe(\n        startWith(null),\n        scan((state, input) => {\n            if (Object.keys(state).length === 0) {\n                state = this.#initialState()\n            }\n\n            if (input == null) {\n                return state\n            }\n\n            let current = state[input.name] ?? { ratio: 0, share: 0, done: false }\n            current = { ...current, ...input }\n\n            if (input.progress.type === \"lax\") {\n                delete current.laxBegin\n                delete current.laxPercent\n            }\n\n            return { ...state, [input.name]: { ...current, ...input } }\n        }, {} as ProgressSegements),\n        switchMap(state => {\n            const laxCount = Object.values(state).filter(({ progress }) => progress.type === \"lax\").length\n\n            if (laxCount > 0) {\n                return animationFrames().pipe(\n                    map(({ timestamp }) => {\n                        for (const entry of Object.values(state)) {\n                            if (entry.progress.type === \"lax\") {\n                                if (entry.laxBegin == null) {\n                                    entry.laxBegin = timestamp\n                                }\n\n                                let percent = (timestamp - entry.laxBegin) / entry.progress.predictedTime\n                                if (percent >= 0.8) {\n                                    const final = (timestamp - entry.laxBegin) / (entry.progress.predictedTime * 50)\n                                    percent = 0.8 + Math.log1p(final)\n                                }\n                                entry.laxPercent = clamp(percent, 0, 0.99)\n                            } else {\n                                delete entry.laxPercent\n                            }\n                        }\n                        return state\n                    }),\n                    takeWhile(() => {\n                        const doneCount = Object.values(state).filter(\n                            item => item.progress.type === \"lax\" && item.laxPercent! >= 1\n                        ).length\n                        return doneCount !== laxCount\n                    }, true)\n                )\n            } else {\n                return of(state)\n            }\n        }),\n        tap(state => {\n            const slist = Object.values(state) as Array<Mutable<ProgressSegement>>\n            const min = slist.reduce((min, current) => Math.min(min, current.distribution || 0), Infinity) || 1\n            const totalDistribution = slist.reduce((total, current) => total + (current.distribution || min), 0)\n\n            for (const segment of slist) {\n                if (segment.distribution == null) {\n                    segment.distribution = min\n                }\n\n                segment.ratio = segment.distribution / totalDistribution + 0.0001\n\n                if (segment.progress.type === \"fix\") {\n                    const percent = clamp(segment.progress.percent, 0, 1)\n                    segment.share = percent * segment.ratio\n                    segment.done = percent >= 1\n                } else if (segment.progress.type === \"lax\" && segment.laxPercent != null) {\n                    const percent = segment.laxPercent\n                    segment.share = percent * segment.ratio\n                    segment.done = percent >= 1\n                }\n            }\n        }),\n        shareReplay({ bufferSize: 1, refCount: true })\n    )\n\n    readonly value$: Observable<DeepReadonly<ProgressSegements>> = this.#state\n\n    readonly percent$: Observable<number> = this.value$.pipe(\n        map(value =>\n            clamp(\n                Object.values(value).reduce((a, b) => a + b.share, 0),\n                0,\n                1\n            )\n        ),\n        shareReplay({ bufferSize: 1, refCount: true })\n    )\n\n    segment(name: string, distribution?: number): ProgressSegmentRef {\n        const segment =\n            this.#segments[name] ?? (this.#segments[name] = new ProgressSegmentRef(this.#input, name, distribution))\n        segment.next(SEGMENT_REGISTER)\n        return segment\n    }\n\n    connect(state: ProgressState, name: string, distribution?: number): Observable<void> {\n        return new Observable(() => {\n            const segment = this.segment(name, distribution)\n            return state.percent$.subscribe(percent => {\n                segment.next({ type: \"fix\", percent })\n            })\n        })\n    }\n\n    #initialState() {\n        return Object.values(this.#segments).reduce((res, segment) => {\n            if (segment.value) {\n                res[segment.name] = {\n                    name: segment.name,\n                    distribution: segment.distribution,\n                    progress: segment.value,\n                    ratio: 0,\n                    share: 0,\n                    done: false\n                }\n            }\n            return res\n        }, {} as ProgressSegements)\n    }\n}\n\nexport class ProgressSegmentRef {\n    readonly #subject: Subject<ProgressSegmentInput>\n\n    set distribution(value: number | undefined) {\n        if (this.#distribution !== value) {\n            this.#distribution = value\n            if (this.#value != null) {\n                this.#next(this.#value)\n            }\n        }\n    }\n\n    get distribution() {\n        return this.#distribution\n    }\n    #distribution?: number\n\n    get value() {\n        return this.#value\n    }\n    #value?: Progress\n\n    constructor(\n        subject: Subject<ProgressSegmentInput>,\n        public readonly name: string,\n        distribution?: number\n    ) {\n        this.#subject = subject\n        this.#distribution = distribution\n    }\n\n    next(progress: Progress) {\n        return this.#next(progress)\n    }\n\n    complete() {\n        return this.#next(SEGMENT_COMPLETE)\n    }\n\n    #next(progress: Progress) {\n        this.#value = progress\n        this.#subject.next({ name: this.name, distribution: this.distribution, progress })\n        return this\n    }\n}\n"]}
@@ -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 ReadonlyDirective extends AbstractUiState {
6
+ constructor() {
7
+ super("readonly");
8
+ this.input = input(NOTSET, { alias: "nuReadonly" });
9
+ this.when = input(NOTSET, { alias: "nuReadonlyWhen" });
10
+ }
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ReadonlyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
12
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.6", type: ReadonlyDirective, isStandalone: true, selector: "[nuReadonly], [nuReadonlyWhen]", inputs: { input: { classPropertyName: "input", publicName: "nuReadonly", isSignal: true, isRequired: false, transformFunction: null }, when: { classPropertyName: "when", publicName: "nuReadonlyWhen", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.aria-readonly": "yes() ? 'true' : 'false'", "attr.readonly": "yes() ? '' : null", "attr.inert": "yes() ? '' : null" } }, providers: [UiState], exportAs: ["readonly"], usesInheritance: true, ngImport: i0 }); }
13
+ }
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: ReadonlyDirective, decorators: [{
15
+ type: Directive,
16
+ args: [{
17
+ selector: "[nuReadonly], [nuReadonlyWhen]",
18
+ exportAs: "readonly",
19
+ standalone: true,
20
+ host: {
21
+ "[attr.aria-readonly]": "yes() ? 'true' : 'false'",
22
+ "[attr.readonly]": "yes() ? '' : null",
23
+ "[attr.inert]": "yes() ? '' : null"
24
+ },
25
+ providers: [UiState]
26
+ }]
27
+ }], ctorParameters: () => [] });
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZG9ubHkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYXJpYS9zcmMvdWktc3RhdGUvcmVhZG9ubHkuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRWhELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBQ3BELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUE7O0FBYXBDLE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxlQUEyQjtJQUk5RDtRQUNJLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUpaLFVBQUssR0FBRyxLQUFLLENBQUMsTUFBaUIsRUFBRSxFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFBO1FBQ3pELFNBQUksR0FBRyxLQUFLLENBQUMsTUFBZ0IsRUFBRSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUE7SUFJcEUsQ0FBQzs4R0FOUSxpQkFBaUI7a0dBQWpCLGlCQUFpQiwwZUFGZixDQUFDLE9BQU8sQ0FBQzs7MkZBRVgsaUJBQWlCO2tCQVg3QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQ0FBZ0M7b0JBQzFDLFFBQVEsRUFBRSxVQUFVO29CQUNwQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNGLHNCQUFzQixFQUFFLDBCQUEwQjt3QkFDbEQsaUJBQWlCLEVBQUUsbUJBQW1CO3dCQUN0QyxjQUFjLEVBQUUsbUJBQW1CO3FCQUN0QztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUM7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCJcblxuaW1wb3J0IHsgQWJzdHJhY3RVaVN0YXRlLCBOT1RTRVQgfSBmcm9tIFwiLi9hYnN0cmFjdFwiXG5pbXBvcnQgeyBVaVN0YXRlIH0gZnJvbSBcIi4vdWktc3RhdGVcIlxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJbbnVSZWFkb25seV0sIFtudVJlYWRvbmx5V2hlbl1cIixcbiAgICBleHBvcnRBczogXCJyZWFkb25seVwiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICBcIlthdHRyLmFyaWEtcmVhZG9ubHldXCI6IFwieWVzKCkgPyAndHJ1ZScgOiAnZmFsc2UnXCIsXG4gICAgICAgIFwiW2F0dHIucmVhZG9ubHldXCI6IFwieWVzKCkgPyAnJyA6IG51bGxcIixcbiAgICAgICAgXCJbYXR0ci5pbmVydF1cIjogXCJ5ZXMoKSA/ICcnIDogbnVsbFwiXG4gICAgfSxcbiAgICBwcm92aWRlcnM6IFtVaVN0YXRlXVxufSlcbmV4cG9ydCBjbGFzcyBSZWFkb25seURpcmVjdGl2ZSBleHRlbmRzIEFic3RyYWN0VWlTdGF0ZTxcInJlYWRvbmx5XCI+IHtcbiAgICByZWFkb25seSBpbnB1dCA9IGlucHV0KE5PVFNFVCBhcyBib29sZWFuLCB7IGFsaWFzOiBcIm51UmVhZG9ubHlcIiB9KVxuICAgIHJlYWRvbmx5IHdoZW4gPSBpbnB1dChOT1RTRVQgYXMgc3RyaW5nLCB7IGFsaWFzOiBcIm51UmVhZG9ubHlXaGVuXCIgfSlcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcihcInJlYWRvbmx5XCIpXG4gICAgfVxufVxuIl19