ember-aria-voyager 0.0.5 → 0.1.0
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/README.md +58 -13
- package/declarations/index.d.ts +10 -3
- package/declarations/index.d.ts.map +1 -1
- package/declarations/modifiers/-emitter.d.ts +28 -0
- package/declarations/modifiers/-emitter.d.ts.map +1 -0
- package/declarations/modifiers/aria-listbox.d.ts +25 -0
- package/declarations/modifiers/aria-listbox.d.ts.map +1 -0
- package/declarations/modifiers/{menu.d.ts → aria-menu.d.ts} +4 -2
- package/declarations/modifiers/aria-menu.d.ts.map +1 -0
- package/declarations/modifiers/aria-tablist.d.ts +28 -0
- package/declarations/modifiers/aria-tablist.d.ts.map +1 -0
- package/declarations/template-registry.d.ts +6 -4
- package/declarations/template-registry.d.ts.map +1 -1
- package/declarations/test-support/index.d.ts +1 -0
- package/declarations/test-support/index.d.ts.map +1 -1
- package/declarations/test-support/tablist.d.ts +11 -0
- package/declarations/test-support/tablist.d.ts.map +1 -0
- package/dist/-emitter-CQPiyyOK.js +47 -0
- package/dist/-emitter-CQPiyyOK.js.map +1 -0
- package/dist/_app_/modifiers/aria-listbox.js +1 -0
- package/dist/_app_/modifiers/aria-menu.js +1 -0
- package/dist/_app_/modifiers/aria-tablist.js +1 -0
- package/dist/index.js +3 -2
- package/dist/index.js.map +1 -1
- package/dist/modifiers/{listbox.js → aria-listbox.js} +10 -43
- package/dist/modifiers/aria-listbox.js.map +1 -0
- package/dist/modifiers/{menu.js → aria-menu.js} +9 -1
- package/dist/modifiers/aria-menu.js.map +1 -0
- package/dist/modifiers/aria-tablist.js +65 -0
- package/dist/modifiers/aria-tablist.js.map +1 -0
- package/dist/test-support/index.js +162 -13
- package/dist/test-support/index.js.map +1 -1
- package/package.json +17 -16
- package/declarations/modifiers/listbox.d.ts +0 -44
- package/declarations/modifiers/listbox.d.ts.map +0 -1
- package/declarations/modifiers/menu.d.ts.map +0 -1
- package/dist/_app_/modifiers/listbox.js +0 -1
- package/dist/_app_/modifiers/menu.js +0 -1
- package/dist/modifiers/listbox.js.map +0 -1
- package/dist/modifiers/menu.js.map +0 -1
package/README.md
CHANGED
|
@@ -26,16 +26,16 @@ pnpm add ember-aria-voyager
|
|
|
26
26
|
|
|
27
27
|
## Usage
|
|
28
28
|
|
|
29
|
-
### `{{
|
|
29
|
+
### `{{ariaListbox}}`
|
|
30
30
|
|
|
31
31
|
Basic example:
|
|
32
32
|
|
|
33
33
|
```glimmer-ts
|
|
34
|
-
import {
|
|
34
|
+
import { ariaListbox } from 'ember-aria-voyager';
|
|
35
35
|
const options = ['apple', 'banana', 'pineapple'];
|
|
36
36
|
|
|
37
37
|
<template>
|
|
38
|
-
<ul role="listbox" {{
|
|
38
|
+
<ul role="listbox" {{ariaListbox items=options}}>
|
|
39
39
|
{{#each options as |option|}}
|
|
40
40
|
<li role="option">{{option}}</li>
|
|
41
41
|
{{/each}}
|
|
@@ -43,7 +43,7 @@ const options = ['apple', 'banana', 'pineapple'];
|
|
|
43
43
|
</template>
|
|
44
44
|
```
|
|
45
45
|
|
|
46
|
-
Here are the options, you can pass to `{{
|
|
46
|
+
Here are the options, you can pass to `{{ariaListbox}}`
|
|
47
47
|
|
|
48
48
|
```ts
|
|
49
49
|
type ListboxSignature<T = HTMLElement> = {
|
|
@@ -67,7 +67,7 @@ When passing `items` the `select()` and `selection` can work off of your passed
|
|
|
67
67
|
Full example:
|
|
68
68
|
|
|
69
69
|
```glimmer-ts
|
|
70
|
-
import {
|
|
70
|
+
import { ariaListbox } from 'ember-aria-voyager';
|
|
71
71
|
const options = ['apple', 'banana', 'pineapple'];
|
|
72
72
|
const context = new class {
|
|
73
73
|
@tracked selection = [options[0]];
|
|
@@ -81,7 +81,7 @@ const context = new class {
|
|
|
81
81
|
const selection = ['banana'];
|
|
82
82
|
|
|
83
83
|
<template>
|
|
84
|
-
<ul role="listbox" {{
|
|
84
|
+
<ul role="listbox" {{ariaListbox
|
|
85
85
|
items=options
|
|
86
86
|
multi=true
|
|
87
87
|
disabled=context.disabled
|
|
@@ -95,19 +95,19 @@ const selection = ['banana'];
|
|
|
95
95
|
</template>
|
|
96
96
|
```
|
|
97
97
|
|
|
98
|
-
### `{{
|
|
98
|
+
### `{{ariaMenu}}`
|
|
99
99
|
|
|
100
100
|
Basic example:
|
|
101
101
|
|
|
102
102
|
```glimmer-ts
|
|
103
|
-
import {
|
|
103
|
+
import { ariaMenu } from 'ember-aria-voyager';
|
|
104
104
|
|
|
105
105
|
<template>
|
|
106
|
-
<div role="menu" {{
|
|
106
|
+
<div role="menu" {{ariaMenu}}>
|
|
107
107
|
<button role="menuitem">Version Info</button>
|
|
108
108
|
<a role="menuitem" href="https://github.com/hokulea/aria-voyager" target="_blank">Github</a>
|
|
109
109
|
<button role="menuitem" popovertarget="authormenu">Author</button>
|
|
110
|
-
<div role="menu" id="authormenu" popover {{
|
|
110
|
+
<div role="menu" id="authormenu" popover {{ariaMenu}}>
|
|
111
111
|
<a role="menuitem" href="https://gos.si" target="_blank">Homepage</a>
|
|
112
112
|
<a role="menuitem" href="https://github.com" target="_blank">Github</a>
|
|
113
113
|
</div>
|
|
@@ -115,7 +115,7 @@ import { menu } from 'ember-aria-voyager';
|
|
|
115
115
|
</template>
|
|
116
116
|
```
|
|
117
117
|
|
|
118
|
-
Here are the options, you can pass to `{{
|
|
118
|
+
Here are the options, you can pass to `{{ariaMenu}}`
|
|
119
119
|
|
|
120
120
|
```ts
|
|
121
121
|
interface MenuSignature<T> {
|
|
@@ -127,7 +127,7 @@ interface MenuSignature<T> {
|
|
|
127
127
|
Here is a full example:
|
|
128
128
|
|
|
129
129
|
```glimmer-ts
|
|
130
|
-
import {
|
|
130
|
+
import { ariaMenu } from 'ember-aria-voyager';
|
|
131
131
|
const items = [
|
|
132
132
|
{
|
|
133
133
|
label: 'Version Info',
|
|
@@ -140,7 +140,7 @@ const items = [
|
|
|
140
140
|
];
|
|
141
141
|
|
|
142
142
|
<template>
|
|
143
|
-
<div role="menu" {{
|
|
143
|
+
<div role="menu" {{ariaMenu items=items}}>
|
|
144
144
|
{{#each items as |item|}}
|
|
145
145
|
{{#if item.action}}
|
|
146
146
|
<button type="button" role="menuitem" {{on "click" item.action}}>{{item.label}}</button>
|
|
@@ -153,3 +153,48 @@ const items = [
|
|
|
153
153
|
</div>
|
|
154
154
|
</template>
|
|
155
155
|
```
|
|
156
|
+
|
|
157
|
+
### `{{ariaTablist}}`
|
|
158
|
+
|
|
159
|
+
Basic example:
|
|
160
|
+
|
|
161
|
+
```glimmer-ts
|
|
162
|
+
import { ariaTablist } from 'ember-aria-voyager';
|
|
163
|
+
const tabs = ['apple', 'banana', 'pineapple'];
|
|
164
|
+
|
|
165
|
+
<template>
|
|
166
|
+
<div>
|
|
167
|
+
<ul role="tablist" {{ariaTablist items=tabs}}>
|
|
168
|
+
{{#each tabs as |tab id|}}
|
|
169
|
+
<li role="tab" id="tab-{{id}}" aria-controls="panel-{{id}}">{{tab}}</li>
|
|
170
|
+
{{/each}}
|
|
171
|
+
</ul>
|
|
172
|
+
|
|
173
|
+
{{#each tabs as |tab id|}}
|
|
174
|
+
<div role="tabpanel" id="panel-{{id}}" aria-labelledby="tab-{{id}}">
|
|
175
|
+
Contents Panel {{tab}}
|
|
176
|
+
</div>
|
|
177
|
+
{{/each}}
|
|
178
|
+
<div>
|
|
179
|
+
</template>
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
Here are the options, you can pass to `{{ariaTablist}}`
|
|
183
|
+
|
|
184
|
+
```ts
|
|
185
|
+
import type { EmitStrategy, Orientation, TablistBehavior } from 'aria-voyager';
|
|
186
|
+
|
|
187
|
+
interface TablistSignature<T> {
|
|
188
|
+
Element: HTMLElement;
|
|
189
|
+
Args: {
|
|
190
|
+
Positional: [];
|
|
191
|
+
Named: {
|
|
192
|
+
disabled?: boolean;
|
|
193
|
+
orientation?: Orientation;
|
|
194
|
+
behavior?: TablistBehavior;
|
|
195
|
+
} & EmitterSignature<T>;
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
```
|
|
199
|
+
|
|
200
|
+
When passing `items` the `select()` and `selection` can work off of your passed items, anyway will fall back to the HTMLElement
|
package/declarations/index.d.ts
CHANGED
|
@@ -1,4 +1,11 @@
|
|
|
1
|
-
import { default as
|
|
2
|
-
import { default as
|
|
3
|
-
|
|
1
|
+
import { default as ariaListbox } from './modifiers/aria-listbox';
|
|
2
|
+
import { default as ariaMenu } from './modifiers/aria-menu';
|
|
3
|
+
import { default as ariaTablist } from './modifiers/aria-tablist';
|
|
4
|
+
export { ariaListbox, ariaMenu, ariaTablist,
|
|
5
|
+
/** @deprecated use `ariaListbox` */
|
|
6
|
+
ariaListbox as listbox,
|
|
7
|
+
/** @deprecated use `ariaMenu` */
|
|
8
|
+
ariaMenu as menu,
|
|
9
|
+
/** @deprecated use `ariaTablist` */
|
|
10
|
+
ariaTablist as tablist };
|
|
4
11
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAElE,OAAO,EACL,WAAW,EACX,QAAQ,EACR,WAAW;AACX,oCAAoC;AACpC,WAAW,IAAI,OAAO;AACtB,iCAAiC;AACjC,QAAQ,IAAI,IAAI;AAChB,oCAAoC;AACpC,WAAW,IAAI,OAAO,EACvB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type Control, IndexEmitStrategy, ItemEmitStrategy } from 'aria-voyager';
|
|
2
|
+
export declare function asArray(val?: unknown): any[];
|
|
3
|
+
export type WithItems<T> = {
|
|
4
|
+
items: T[];
|
|
5
|
+
selection?: T | T[];
|
|
6
|
+
activateItem?: (item: T) => void;
|
|
7
|
+
} & ({
|
|
8
|
+
multi: true;
|
|
9
|
+
select?: (selection: T[]) => void;
|
|
10
|
+
} | {
|
|
11
|
+
multi?: false;
|
|
12
|
+
select?: (selection: T) => void;
|
|
13
|
+
});
|
|
14
|
+
export type OptionalItems = {
|
|
15
|
+
items?: HTMLElement[];
|
|
16
|
+
selection?: HTMLElement | HTMLElement[];
|
|
17
|
+
activateItem?: (item: HTMLElement) => void;
|
|
18
|
+
} & ({
|
|
19
|
+
multi: true;
|
|
20
|
+
select?: (selection: HTMLElement[]) => void;
|
|
21
|
+
} | {
|
|
22
|
+
multi?: false;
|
|
23
|
+
select?: (selection: HTMLElement) => void;
|
|
24
|
+
});
|
|
25
|
+
export type EmitterSignature<T> = WithItems<T> | OptionalItems;
|
|
26
|
+
export declare function createItemEmitter<T>(control: Control, options: EmitterSignature<T>): ItemEmitStrategy;
|
|
27
|
+
export declare function createIndexEmitter<T>(control: Control, options: EmitterSignature<T>): IndexEmitStrategy;
|
|
28
|
+
//# sourceMappingURL=-emitter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"-emitter.d.ts","sourceRoot":"","sources":["../../src/modifiers/-emitter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEjF,wBAAgB,OAAO,CAAC,GAAG,CAAC,EAAE,OAAO,SAOpC;AAED,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI;IACzB,KAAK,EAAE,CAAC,EAAE,CAAC;IACX,SAAS,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;IACpB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC;CAClC,GAAG,CACA;IACE,KAAK,EAAE,IAAI,CAAC;IACZ,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC;CACnC,GACD;IACE,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,KAAK,IAAI,CAAC;CACjC,CACJ,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,KAAK,CAAC,EAAE,WAAW,EAAE,CAAC;IACtB,SAAS,CAAC,EAAE,WAAW,GAAG,WAAW,EAAE,CAAC;IACxC,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,WAAW,KAAK,IAAI,CAAC;CAC5C,GAAG,CACA;IACE,KAAK,EAAE,IAAI,CAAC;IACZ,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,WAAW,EAAE,KAAK,IAAI,CAAC;CAC7C,GACD;IACE,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,WAAW,KAAK,IAAI,CAAC;CAC3C,CACJ,CAAC;AAEF,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC;AAE/D,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,oBAYlF;AAED,wBAAgB,kBAAkB,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,qBA8BnF"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import Modifier from 'ember-modifier';
|
|
2
|
+
import { type EmitterSignature } from './-emitter';
|
|
3
|
+
import type Owner from '@ember/owner';
|
|
4
|
+
import type { ArgsFor, NamedArgs, PositionalArgs } from 'ember-modifier';
|
|
5
|
+
interface ListboxSignature<T> {
|
|
6
|
+
Args: {
|
|
7
|
+
Positional: [];
|
|
8
|
+
Named: {
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
} & EmitterSignature<T>;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export default class ListboxModifier<T> extends Modifier<ListboxSignature<T>> {
|
|
14
|
+
private listbox?;
|
|
15
|
+
private updater;
|
|
16
|
+
private emitter;
|
|
17
|
+
private prevItems?;
|
|
18
|
+
private prevSelection?;
|
|
19
|
+
private prevMulti?;
|
|
20
|
+
private prevDisabled?;
|
|
21
|
+
constructor(owner: Owner, args: ArgsFor<ListboxSignature<T>>);
|
|
22
|
+
modify(element: Element, _: PositionalArgs<ListboxSignature<T>>, options: NamedArgs<ListboxSignature<T>>): void;
|
|
23
|
+
}
|
|
24
|
+
export {};
|
|
25
|
+
//# sourceMappingURL=aria-listbox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria-listbox.d.ts","sourceRoot":"","sources":["../../src/modifiers/aria-listbox.ts"],"names":[],"mappings":"AAGA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AAGtC,OAAO,EAIL,KAAK,gBAAgB,EAEtB,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAEtC,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEzE,UAAU,gBAAgB,CAAC,CAAC;IAC1B,IAAI,EAAE;QACJ,UAAU,EAAE,EAAE,CAAC;QACf,KAAK,EAAE;YAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;SAAE,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC;KACrD,CAAC;CACH;AAED,MAAM,CAAC,OAAO,OAAO,eAAe,CAAC,CAAC,CAAE,SAAQ,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;IAC3E,OAAO,CAAC,OAAO,CAAC,CAAU;IAC1B,QAAgB,OAAO,CAAyB;IAChD,QAAgB,OAAO,CAAe;IAEtC,OAAO,CAAC,SAAS,CAAC,CAAM;IACxB,OAAO,CAAC,aAAa,CAAC,CAAU;IAChC,OAAO,CAAC,SAAS,CAAC,CAAU;IAC5B,OAAO,CAAC,YAAY,CAAC,CAAU;gBAEnB,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;IAS5D,MAAM,CACJ,OAAO,EAAE,OAAO,EAChB,CAAC,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EACtC,OAAO,EAAE,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;CAwD1C"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import Modifier from 'ember-modifier';
|
|
2
|
-
import type
|
|
2
|
+
import type Owner from '@ember/owner';
|
|
3
|
+
import type { ArgsFor, NamedArgs, PositionalArgs } from 'ember-modifier';
|
|
3
4
|
export interface MenuSignature<T> {
|
|
4
5
|
Element: HTMLElement;
|
|
5
6
|
Args: {
|
|
@@ -16,6 +17,7 @@ export default class MenuModifier<T> extends Modifier<MenuSignature<T>> {
|
|
|
16
17
|
private emitter;
|
|
17
18
|
private prevItems?;
|
|
18
19
|
private prevDisabled?;
|
|
20
|
+
constructor(owner: Owner, args: ArgsFor<MenuSignature<T>>);
|
|
19
21
|
modify(element: Element, _: PositionalArgs<MenuSignature<T>>, options: NamedArgs<MenuSignature<T>>): void;
|
|
20
22
|
}
|
|
21
|
-
//# sourceMappingURL=menu.d.ts.map
|
|
23
|
+
//# sourceMappingURL=aria-menu.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria-menu.d.ts","sourceRoot":"","sources":["../../src/modifiers/aria-menu.ts"],"names":[],"mappings":"AAGA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AAGtC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAEtC,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEzE,MAAM,WAAW,aAAa,CAAC,CAAC;IAC9B,OAAO,EAAE,WAAW,CAAC;IACrB,IAAI,EAAE;QACJ,UAAU,EAAE,EAAE,CAAC;QACf,KAAK,EAAE;YACL,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;YACZ,QAAQ,CAAC,EAAE,OAAO,CAAC;SACpB,CAAC;KACH,CAAC;CACH;AAED,MAAM,CAAC,OAAO,OAAO,YAAY,CAAC,CAAC,CAAE,SAAQ,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;IACrE,OAAO,CAAC,IAAI,CAAC,CAAO;IACpB,QAAgB,OAAO,CAAyB;IAChD,QAAgB,OAAO,CAAe;IAEtC,OAAO,CAAC,SAAS,CAAC,CAAM;IACxB,OAAO,CAAC,YAAY,CAAC,CAAU;gBAEnB,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;IASzD,MAAM,CACJ,OAAO,EAAE,OAAO,EAChB,CAAC,EAAE,cAAc,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EACnC,OAAO,EAAE,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;CAiCvC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import Modifier from 'ember-modifier';
|
|
2
|
+
import { type EmitterSignature } from './-emitter';
|
|
3
|
+
import type Owner from '@ember/owner';
|
|
4
|
+
import type { Orientation, TablistBehavior } from 'aria-voyager';
|
|
5
|
+
import type { ArgsFor, NamedArgs, PositionalArgs } from 'ember-modifier';
|
|
6
|
+
export interface TablistSignature<T> {
|
|
7
|
+
Element: HTMLElement;
|
|
8
|
+
Args: {
|
|
9
|
+
Positional: [];
|
|
10
|
+
Named: {
|
|
11
|
+
disabled?: boolean;
|
|
12
|
+
orientation?: Orientation;
|
|
13
|
+
behavior?: TablistBehavior;
|
|
14
|
+
} & EmitterSignature<T>;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export default class TablistModifier<T> extends Modifier<TablistSignature<T>> {
|
|
18
|
+
private tablist?;
|
|
19
|
+
private updater;
|
|
20
|
+
private emitter;
|
|
21
|
+
private prevItems?;
|
|
22
|
+
private prevSelection?;
|
|
23
|
+
private prevDisabled?;
|
|
24
|
+
private prevOrientation?;
|
|
25
|
+
constructor(owner: Owner, args: ArgsFor<TablistSignature<T>>);
|
|
26
|
+
modify(element: Element, _: PositionalArgs<TablistSignature<T>>, options: NamedArgs<TablistSignature<T>>): void;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=aria-tablist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria-tablist.d.ts","sourceRoot":"","sources":["../../src/modifiers/aria-tablist.ts"],"names":[],"mappings":"AAGA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AAGtC,OAAO,EAIL,KAAK,gBAAgB,EAEtB,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,EAAgB,WAAW,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/E,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEzE,MAAM,WAAW,gBAAgB,CAAC,CAAC;IACjC,OAAO,EAAE,WAAW,CAAC;IACrB,IAAI,EAAE;QACJ,UAAU,EAAE,EAAE,CAAC;QACf,KAAK,EAAE;YACL,QAAQ,CAAC,EAAE,OAAO,CAAC;YACnB,WAAW,CAAC,EAAE,WAAW,CAAC;YAC1B,QAAQ,CAAC,EAAE,eAAe,CAAC;SAC5B,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC;KACzB,CAAC;CACH;AAED,MAAM,CAAC,OAAO,OAAO,eAAe,CAAC,CAAC,CAAE,SAAQ,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;IAC3E,OAAO,CAAC,OAAO,CAAC,CAAU;IAC1B,QAAgB,OAAO,CAAyB;IAChD,QAAgB,OAAO,CAAe;IAEtC,OAAO,CAAC,SAAS,CAAC,CAAM;IACxB,OAAO,CAAC,aAAa,CAAC,CAAU;IAChC,OAAO,CAAC,YAAY,CAAC,CAAU;IAC/B,OAAO,CAAC,eAAe,CAAC,CAAc;gBAE1B,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;IAS5D,MAAM,CACJ,OAAO,EAAE,OAAO,EAChB,CAAC,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EACtC,OAAO,EAAE,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;CA2D1C"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import type listbox from './modifiers/listbox';
|
|
2
|
-
import type menu from './modifiers/menu';
|
|
1
|
+
import type listbox from './modifiers/aria-listbox';
|
|
2
|
+
import type menu from './modifiers/aria-menu';
|
|
3
|
+
import type tablist from './modifiers/aria-tablist';
|
|
3
4
|
export default interface AriaVoyagerRegistry {
|
|
4
|
-
listbox: typeof listbox;
|
|
5
|
-
menu: typeof menu;
|
|
5
|
+
'aria-listbox': typeof listbox;
|
|
6
|
+
'aria-menu': typeof menu;
|
|
7
|
+
'aria-tablist': typeof tablist;
|
|
6
8
|
}
|
|
7
9
|
//# sourceMappingURL=template-registry.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"template-registry.d.ts","sourceRoot":"","sources":["../src/template-registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,
|
|
1
|
+
{"version":3,"file":"template-registry.d.ts","sourceRoot":"","sources":["../src/template-registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,0BAA0B,CAAC;AACpD,OAAO,KAAK,IAAI,MAAM,uBAAuB,CAAC;AAC9C,OAAO,KAAK,OAAO,MAAM,0BAA0B,CAAC;AAEpD,MAAM,CAAC,OAAO,WAAW,mBAAmB;IAE1C,cAAc,EAAE,OAAO,OAAO,CAAC;IAE/B,WAAW,EAAE,OAAO,IAAI,CAAC;IAEzB,cAAc,EAAE,OAAO,OAAO,CAAC;CAChC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/test-support/index.ts"],"names":[],"mappings":"AAEA,cAAc,WAAW,CAAC;AAC1B,cAAc,QAAQ,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/test-support/index.ts"],"names":[],"mappings":"AAEA,cAAc,WAAW,CAAC;AAC1B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
type Selectors = {
|
|
2
|
+
tablist: string;
|
|
3
|
+
item: string;
|
|
4
|
+
};
|
|
5
|
+
export declare function testTablistKeyboardNavigation(assert: Assert, selectors?: Partial<Selectors>): Promise<void>;
|
|
6
|
+
export declare function testTablistKeyboardAutomaticSelection(assert: Assert, selectors?: Partial<Selectors>): Promise<void>;
|
|
7
|
+
export declare function testTablistKeyboardManualSelection(assert: Assert, selectors?: Partial<Selectors>): Promise<void>;
|
|
8
|
+
export declare function testTablistPointerNavigation(assert: Assert, selectors?: Partial<Selectors>): Promise<void>;
|
|
9
|
+
export declare function testTablistPointerSelection(assert: Assert, selectors?: Partial<Selectors>): Promise<void>;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=tablist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tablist.d.ts","sourceRoot":"","sources":["../../src/test-support/tablist.ts"],"names":[],"mappings":"AAIA,KAAK,SAAS,GAAG;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAgCF,wBAAsB,6BAA6B,CACjD,MAAM,EAAE,MAAM,EACd,SAAS,GAAE,OAAO,CAAC,SAAS,CAAqB,GAChD,OAAO,CAAC,IAAI,CAAC,CA6Bf;AAED,wBAAsB,qCAAqC,CACzD,MAAM,EAAE,MAAM,EACd,SAAS,GAAE,OAAO,CAAC,SAAS,CAAqB,GAChD,OAAO,CAAC,IAAI,CAAC,CAqBf;AAED,wBAAsB,kCAAkC,CACtD,MAAM,EAAE,MAAM,EACd,SAAS,GAAE,OAAO,CAAC,SAAS,CAAqB,GAChD,OAAO,CAAC,IAAI,CAAC,CAmCf;AAMD,wBAAsB,4BAA4B,CAChD,MAAM,EAAE,MAAM,EACd,SAAS,GAAE,OAAO,CAAC,SAAS,CAAqB,GAChD,OAAO,CAAC,IAAI,CAAC,CAef;AAED,wBAAsB,2BAA2B,CAC/C,MAAM,EAAE,MAAM,EACd,SAAS,GAAE,OAAO,CAAC,SAAS,CAAqB,GAChD,OAAO,CAAC,IAAI,CAAC,CAmBf"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ItemEmitStrategy, IndexEmitStrategy } from 'aria-voyager';
|
|
2
|
+
|
|
3
|
+
function asArray(val) {
|
|
4
|
+
if (val === undefined) {
|
|
5
|
+
return [];
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
9
|
+
return Array.isArray(val) ? val : [val];
|
|
10
|
+
}
|
|
11
|
+
function createItemEmitter(control, options) {
|
|
12
|
+
return new ItemEmitStrategy(control, {
|
|
13
|
+
select: selection => {
|
|
14
|
+
options.select?.(options.multi ? selection : selection[0]);
|
|
15
|
+
},
|
|
16
|
+
activateItem: item => {
|
|
17
|
+
options.activateItem?.(item);
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
function createIndexEmitter(control, options) {
|
|
22
|
+
const findByIndex = index => {
|
|
23
|
+
return options.items[index] ?? undefined;
|
|
24
|
+
};
|
|
25
|
+
return new IndexEmitStrategy(control, {
|
|
26
|
+
select: selection => {
|
|
27
|
+
if (options.multi) {
|
|
28
|
+
const items = selection.map(index => findByIndex(index)).filter(i => i !== undefined);
|
|
29
|
+
options.select?.(items);
|
|
30
|
+
} else {
|
|
31
|
+
const item = findByIndex(selection[0]);
|
|
32
|
+
if (item) {
|
|
33
|
+
options.select?.(item);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
activateItem: index => {
|
|
38
|
+
const item = findByIndex(index);
|
|
39
|
+
if (item) {
|
|
40
|
+
options.activateItem?.(item);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
export { createItemEmitter as a, asArray as b, createIndexEmitter as c };
|
|
47
|
+
//# sourceMappingURL=-emitter-CQPiyyOK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"-emitter-CQPiyyOK.js","sources":["../src/modifiers/-emitter.ts"],"sourcesContent":["import { type Control, IndexEmitStrategy, ItemEmitStrategy } from 'aria-voyager';\n\nexport function asArray(val?: unknown) {\n if (val === undefined) {\n return [];\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return Array.isArray(val) ? val : [val];\n}\n\nexport type WithItems<T> = {\n items: T[];\n selection?: T | T[];\n activateItem?: (item: T) => void;\n} & (\n | {\n multi: true;\n select?: (selection: T[]) => void;\n }\n | {\n multi?: false;\n select?: (selection: T) => void;\n }\n);\n\nexport type OptionalItems = {\n items?: HTMLElement[];\n selection?: HTMLElement | HTMLElement[];\n activateItem?: (item: HTMLElement) => void;\n} & (\n | {\n multi: true;\n select?: (selection: HTMLElement[]) => void;\n }\n | {\n multi?: false;\n select?: (selection: HTMLElement) => void;\n }\n);\n\nexport type EmitterSignature<T> = WithItems<T> | OptionalItems;\n\nexport function createItemEmitter<T>(control: Control, options: EmitterSignature<T>) {\n return new ItemEmitStrategy(control, {\n select: (selection: HTMLElement[]) => {\n (options.select as ((selection: HTMLElement | HTMLElement[]) => void) | undefined)?.(\n options.multi ? selection : (selection[0] as HTMLElement)\n );\n },\n\n activateItem: (item: HTMLElement) => {\n (options.activateItem as ((item: HTMLElement) => void) | undefined)?.(item);\n }\n });\n}\n\nexport function createIndexEmitter<T>(control: Control, options: EmitterSignature<T>) {\n const findByIndex = (index: number) => {\n return (options as WithItems<T>).items[index] ?? undefined;\n };\n\n return new IndexEmitStrategy(control, {\n select: (selection: number[]) => {\n if (options.multi) {\n const items = selection\n .map((index) => findByIndex(index))\n .filter((i) => i !== undefined) as T[];\n\n (options.select as ((selection: T[]) => void) | undefined)?.(items);\n } else {\n const item = findByIndex(selection[0] as number);\n\n if (item) {\n (options.select as ((selection: T) => void) | undefined)?.(item);\n }\n }\n },\n\n activateItem: (index: number) => {\n const item = findByIndex(index);\n\n if (item) {\n (options.activateItem as ((item: T) => void) | undefined)?.(item);\n }\n }\n });\n}\n"],"names":["asArray","val","undefined","Array","isArray","createItemEmitter","control","options","ItemEmitStrategy","select","selection","multi","activateItem","item","createIndexEmitter","findByIndex","index","items","IndexEmitStrategy","map","filter","i"],"mappings":";;AAEO,SAASA,OAAOA,CAACC,GAAa,EAAE;EACrC,IAAIA,GAAG,KAAKC,SAAS,EAAE;AACrB,IAAA,OAAO,EAAE;AACX;;AAEA;EACA,OAAOC,KAAK,CAACC,OAAO,CAACH,GAAG,CAAC,GAAGA,GAAG,GAAG,CAACA,GAAG,CAAC;AACzC;AAkCO,SAASI,iBAAiBA,CAAIC,OAAgB,EAAEC,OAA4B,EAAE;AACnF,EAAA,OAAO,IAAIC,gBAAgB,CAACF,OAAO,EAAE;IACnCG,MAAM,EAAGC,SAAwB,IAAK;AACnCH,MAAAA,OAAO,CAACE,MAAM,GACbF,OAAO,CAACI,KAAK,GAAGD,SAAS,GAAIA,SAAS,CAAC,CAAC,CAC1C,CAAC;KACF;IAEDE,YAAY,EAAGC,IAAiB,IAAK;AAClCN,MAAAA,OAAO,CAACK,YAAY,GAAiDC,IAAI,CAAC;AAC7E;AACF,GAAC,CAAC;AACJ;AAEO,SAASC,kBAAkBA,CAAIR,OAAgB,EAAEC,OAA4B,EAAE;EACpF,MAAMQ,WAAW,GAAIC,KAAa,IAAK;AACrC,IAAA,OAAQT,OAAO,CAAkBU,KAAK,CAACD,KAAK,CAAC,IAAId,SAAS;GAC3D;AAED,EAAA,OAAO,IAAIgB,iBAAiB,CAACZ,OAAO,EAAE;IACpCG,MAAM,EAAGC,SAAmB,IAAK;MAC/B,IAAIH,OAAO,CAACI,KAAK,EAAE;QACjB,MAAMM,KAAK,GAAGP,SAAS,CACpBS,GAAG,CAAEH,KAAK,IAAKD,WAAW,CAACC,KAAK,CAAC,CAAC,CAClCI,MAAM,CAAEC,CAAC,IAAKA,CAAC,KAAKnB,SAAS,CAAQ;AAEvCK,QAAAA,OAAO,CAACE,MAAM,GAA8CQ,KAAK,CAAC;AACrE,OAAC,MAAM;QACL,MAAMJ,IAAI,GAAGE,WAAW,CAACL,SAAS,CAAC,CAAC,CAAW,CAAC;AAEhD,QAAA,IAAIG,IAAI,EAAE;AACPN,UAAAA,OAAO,CAACE,MAAM,GAA4CI,IAAI,CAAC;AAClE;AACF;KACD;IAEDD,YAAY,EAAGI,KAAa,IAAK;AAC/B,MAAA,MAAMH,IAAI,GAAGE,WAAW,CAACC,KAAK,CAAC;AAE/B,MAAA,IAAIH,IAAI,EAAE;AACPN,QAAAA,OAAO,CAACK,YAAY,GAAuCC,IAAI,CAAC;AACnE;AACF;AACF,GAAC,CAAC;AACJ;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from "ember-aria-voyager/modifiers/aria-listbox";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from "ember-aria-voyager/modifiers/aria-menu";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from "ember-aria-voyager/modifiers/aria-tablist";
|
package/dist/index.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
export { default as listbox } from './modifiers/listbox.js';
|
|
2
|
-
export { default as menu } from './modifiers/menu.js';
|
|
1
|
+
export { default as ariaListbox, default as listbox } from './modifiers/aria-listbox.js';
|
|
2
|
+
export { default as ariaMenu, default as menu } from './modifiers/aria-menu.js';
|
|
3
|
+
export { default as ariaTablist, default as tablist } from './modifiers/aria-tablist.js';
|
|
3
4
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -1,50 +1,17 @@
|
|
|
1
|
+
import { registerDestructor } from '@ember/destroyable';
|
|
1
2
|
import { ReactiveUpdateStrategy, Listbox, IndexEmitStrategy, ItemEmitStrategy } from 'aria-voyager';
|
|
2
3
|
import Modifier from 'ember-modifier';
|
|
3
4
|
import isEqual from 'lodash.isequal';
|
|
5
|
+
import { c as createIndexEmitter, a as createItemEmitter, b as asArray } from '../-emitter-CQPiyyOK.js';
|
|
4
6
|
|
|
5
|
-
function asArray(val) {
|
|
6
|
-
if (val === undefined) {
|
|
7
|
-
return [];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
11
|
-
return Array.isArray(val) ? val : [val];
|
|
12
|
-
}
|
|
13
|
-
function createItemEmitter(listbox, options) {
|
|
14
|
-
return new ItemEmitStrategy(listbox, {
|
|
15
|
-
select: selection => {
|
|
16
|
-
options.select?.(options.multi ? selection : selection[0]);
|
|
17
|
-
},
|
|
18
|
-
activateItem: item => {
|
|
19
|
-
options.activateItem?.(item);
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
function createIndexEmitter(listbox, options) {
|
|
24
|
-
const findByIndex = index => {
|
|
25
|
-
return options.items[index] ?? undefined;
|
|
26
|
-
};
|
|
27
|
-
return new IndexEmitStrategy(listbox, {
|
|
28
|
-
select: selection => {
|
|
29
|
-
if (options.multi) {
|
|
30
|
-
const items = selection.map(index => findByIndex(index)).filter(i => i !== undefined);
|
|
31
|
-
options.select?.(items);
|
|
32
|
-
} else {
|
|
33
|
-
const item = findByIndex(selection[0]);
|
|
34
|
-
if (item) {
|
|
35
|
-
options.select?.(item);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
activateItem: index => {
|
|
40
|
-
const item = findByIndex(index);
|
|
41
|
-
if (item) {
|
|
42
|
-
options.activateItem?.(item);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
7
|
class ListboxModifier extends Modifier {
|
|
8
|
+
constructor(owner, args) {
|
|
9
|
+
super(owner, args);
|
|
10
|
+
registerDestructor(this, () => {
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
12
|
+
this.listbox?.dispose();
|
|
13
|
+
});
|
|
14
|
+
}
|
|
48
15
|
modify(element, _, options) {
|
|
49
16
|
if (!this.listbox) {
|
|
50
17
|
this.updater = new ReactiveUpdateStrategy();
|
|
@@ -91,4 +58,4 @@ class ListboxModifier extends Modifier {
|
|
|
91
58
|
}
|
|
92
59
|
|
|
93
60
|
export { ListboxModifier as default };
|
|
94
|
-
//# sourceMappingURL=listbox.js.map
|
|
61
|
+
//# sourceMappingURL=aria-listbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria-listbox.js","sources":["../../src/modifiers/aria-listbox.ts"],"sourcesContent":["import { registerDestructor } from '@ember/destroyable';\n\nimport { IndexEmitStrategy, ItemEmitStrategy, Listbox, ReactiveUpdateStrategy } from 'aria-voyager';\nimport Modifier from 'ember-modifier';\nimport isEqual from 'lodash.isequal';\n\nimport {\n asArray,\n createIndexEmitter,\n createItemEmitter,\n type EmitterSignature,\n type WithItems\n} from './-emitter';\n\nimport type Owner from '@ember/owner';\nimport type { EmitStrategy } from 'aria-voyager';\nimport type { ArgsFor, NamedArgs, PositionalArgs } from 'ember-modifier';\n\ninterface ListboxSignature<T> {\n Args: {\n Positional: [];\n Named: { disabled?: boolean } & EmitterSignature<T>;\n };\n}\n\nexport default class ListboxModifier<T> extends Modifier<ListboxSignature<T>> {\n private listbox?: Listbox;\n declare private updater: ReactiveUpdateStrategy;\n declare private emitter: EmitStrategy;\n\n private prevItems?: T[];\n private prevSelection?: T | T[];\n private prevMulti?: boolean;\n private prevDisabled?: boolean;\n\n constructor(owner: Owner, args: ArgsFor<ListboxSignature<T>>) {\n super(owner, args);\n\n registerDestructor(this, () => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n this.listbox?.dispose();\n });\n }\n\n modify(\n element: Element,\n _: PositionalArgs<ListboxSignature<T>>,\n options: NamedArgs<ListboxSignature<T>>\n ) {\n if (!this.listbox) {\n this.updater = new ReactiveUpdateStrategy();\n\n this.listbox = new Listbox(element as HTMLElement, {\n updater: this.updater\n });\n }\n\n if (options.items && !(this.emitter instanceof IndexEmitStrategy)) {\n this.emitter = createIndexEmitter<T>(this.listbox, options);\n } else if (!options.items && !(this.emitter instanceof ItemEmitStrategy)) {\n this.emitter = createItemEmitter<T>(this.listbox, options);\n }\n\n if (options.items && !isEqual(this.prevItems, (options as WithItems<T>).items)) {\n this.updater.updateItems();\n this.prevItems = [...(options as WithItems<T>).items];\n }\n\n if (options.selection && !isEqual(asArray(this.prevSelection), asArray(options.selection))) {\n this.updater.updateSelection();\n this.prevSelection = asArray(options.selection);\n }\n\n let optionsChanged = false;\n\n if (this.prevMulti !== options.multi) {\n if (options.multi) {\n element.setAttribute('aria-multiselectable', 'true');\n } else {\n element.removeAttribute('aria-multiselectable');\n }\n\n optionsChanged = true;\n\n this.prevMulti = options.multi;\n }\n\n if (this.prevDisabled !== options.disabled) {\n if (options.disabled) {\n element.setAttribute('aria-disabled', 'true');\n } else {\n element.removeAttribute('aria-disabled');\n }\n\n optionsChanged = true;\n\n this.prevDisabled = options.disabled;\n }\n\n if (optionsChanged) {\n this.updater.updateOptions();\n }\n }\n}\n"],"names":["ListboxModifier","Modifier","constructor","owner","args","registerDestructor","listbox","dispose","modify","element","_","options","updater","ReactiveUpdateStrategy","Listbox","items","emitter","IndexEmitStrategy","createIndexEmitter","ItemEmitStrategy","createItemEmitter","isEqual","prevItems","updateItems","selection","asArray","prevSelection","updateSelection","optionsChanged","prevMulti","multi","setAttribute","removeAttribute","prevDisabled","disabled","updateOptions"],"mappings":";;;;;;AAyBe,MAAMA,eAAe,SAAYC,QAAQ,CAAsB;AAU5EC,EAAAA,WAAWA,CAACC,KAAY,EAAEC,IAAkC,EAAE;AAC5D,IAAA,KAAK,CAACD,KAAK,EAAEC,IAAI,CAAC;IAElBC,kBAAkB,CAAC,IAAI,EAAE,MAAM;AAC7B;AACA,MAAA,IAAI,CAACC,OAAO,EAAEC,OAAO,EAAE;AACzB,KAAC,CAAC;AACJ;AAEAC,EAAAA,MAAMA,CACJC,OAAgB,EAChBC,CAAsC,EACtCC,OAAuC,EACvC;AACA,IAAA,IAAI,CAAC,IAAI,CAACL,OAAO,EAAE;AACjB,MAAA,IAAI,CAACM,OAAO,GAAG,IAAIC,sBAAsB,EAAE;AAE3C,MAAA,IAAI,CAACP,OAAO,GAAG,IAAIQ,OAAO,CAACL,OAAO,EAAiB;QACjDG,OAAO,EAAE,IAAI,CAACA;AAChB,OAAC,CAAC;AACJ;IAEA,IAAID,OAAO,CAACI,KAAK,IAAI,EAAE,IAAI,CAACC,OAAO,YAAYC,iBAAiB,CAAC,EAAE;MACjE,IAAI,CAACD,OAAO,GAAGE,kBAAkB,CAAI,IAAI,CAACZ,OAAO,EAAEK,OAAO,CAAC;AAC7D,KAAC,MAAM,IAAI,CAACA,OAAO,CAACI,KAAK,IAAI,EAAE,IAAI,CAACC,OAAO,YAAYG,gBAAgB,CAAC,EAAE;MACxE,IAAI,CAACH,OAAO,GAAGI,iBAAiB,CAAI,IAAI,CAACd,OAAO,EAAEK,OAAO,CAAC;AAC5D;AAEA,IAAA,IAAIA,OAAO,CAACI,KAAK,IAAI,CAACM,OAAO,CAAC,IAAI,CAACC,SAAS,EAAGX,OAAO,CAAkBI,KAAK,CAAC,EAAE;AAC9E,MAAA,IAAI,CAACH,OAAO,CAACW,WAAW,EAAE;MAC1B,IAAI,CAACD,SAAS,GAAG,CAAC,GAAIX,OAAO,CAAkBI,KAAK,CAAC;AACvD;IAEA,IAAIJ,OAAO,CAACa,SAAS,IAAI,CAACH,OAAO,CAACI,OAAO,CAAC,IAAI,CAACC,aAAa,CAAC,EAAED,OAAO,CAACd,OAAO,CAACa,SAAS,CAAC,CAAC,EAAE;AAC1F,MAAA,IAAI,CAACZ,OAAO,CAACe,eAAe,EAAE;MAC9B,IAAI,CAACD,aAAa,GAAGD,OAAO,CAACd,OAAO,CAACa,SAAS,CAAC;AACjD;IAEA,IAAII,cAAc,GAAG,KAAK;AAE1B,IAAA,IAAI,IAAI,CAACC,SAAS,KAAKlB,OAAO,CAACmB,KAAK,EAAE;MACpC,IAAInB,OAAO,CAACmB,KAAK,EAAE;AACjBrB,QAAAA,OAAO,CAACsB,YAAY,CAAC,sBAAsB,EAAE,MAAM,CAAC;AACtD,OAAC,MAAM;AACLtB,QAAAA,OAAO,CAACuB,eAAe,CAAC,sBAAsB,CAAC;AACjD;AAEAJ,MAAAA,cAAc,GAAG,IAAI;AAErB,MAAA,IAAI,CAACC,SAAS,GAAGlB,OAAO,CAACmB,KAAK;AAChC;AAEA,IAAA,IAAI,IAAI,CAACG,YAAY,KAAKtB,OAAO,CAACuB,QAAQ,EAAE;MAC1C,IAAIvB,OAAO,CAACuB,QAAQ,EAAE;AACpBzB,QAAAA,OAAO,CAACsB,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC;AAC/C,OAAC,MAAM;AACLtB,QAAAA,OAAO,CAACuB,eAAe,CAAC,eAAe,CAAC;AAC1C;AAEAJ,MAAAA,cAAc,GAAG,IAAI;AAErB,MAAA,IAAI,CAACK,YAAY,GAAGtB,OAAO,CAACuB,QAAQ;AACtC;AAEA,IAAA,IAAIN,cAAc,EAAE;AAClB,MAAA,IAAI,CAAChB,OAAO,CAACuB,aAAa,EAAE;AAC9B;AACF;AACF;;;;"}
|
|
@@ -1,8 +1,16 @@
|
|
|
1
|
+
import { registerDestructor } from '@ember/destroyable';
|
|
1
2
|
import { ReactiveUpdateStrategy, Menu } from 'aria-voyager';
|
|
2
3
|
import Modifier from 'ember-modifier';
|
|
3
4
|
import isEqual from 'lodash.isequal';
|
|
4
5
|
|
|
5
6
|
class MenuModifier extends Modifier {
|
|
7
|
+
constructor(owner, args) {
|
|
8
|
+
super(owner, args);
|
|
9
|
+
registerDestructor(this, () => {
|
|
10
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
11
|
+
this.menu?.dispose();
|
|
12
|
+
});
|
|
13
|
+
}
|
|
6
14
|
modify(element, _, options) {
|
|
7
15
|
if (!this.menu) {
|
|
8
16
|
this.updater = new ReactiveUpdateStrategy();
|
|
@@ -31,4 +39,4 @@ class MenuModifier extends Modifier {
|
|
|
31
39
|
}
|
|
32
40
|
|
|
33
41
|
export { MenuModifier as default };
|
|
34
|
-
//# sourceMappingURL=menu.js.map
|
|
42
|
+
//# sourceMappingURL=aria-menu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria-menu.js","sources":["../../src/modifiers/aria-menu.ts"],"sourcesContent":["import { registerDestructor } from '@ember/destroyable';\n\nimport { Menu, ReactiveUpdateStrategy } from 'aria-voyager';\nimport Modifier from 'ember-modifier';\nimport isEqual from 'lodash.isequal';\n\nimport type Owner from '@ember/owner';\nimport type { EmitStrategy } from 'aria-voyager';\nimport type { ArgsFor, NamedArgs, PositionalArgs } from 'ember-modifier';\n\nexport interface MenuSignature<T> {\n Element: HTMLElement;\n Args: {\n Positional: [];\n Named: {\n items?: T[];\n disabled?: boolean;\n };\n };\n}\n\nexport default class MenuModifier<T> extends Modifier<MenuSignature<T>> {\n private menu?: Menu;\n declare private updater: ReactiveUpdateStrategy;\n declare private emitter: EmitStrategy;\n\n private prevItems?: T[];\n private prevDisabled?: boolean;\n\n constructor(owner: Owner, args: ArgsFor<MenuSignature<T>>) {\n super(owner, args);\n\n registerDestructor(this, () => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n this.menu?.dispose();\n });\n }\n\n modify(\n element: Element,\n _: PositionalArgs<MenuSignature<T>>,\n options: NamedArgs<MenuSignature<T>>\n ) {\n if (!this.menu) {\n this.updater = new ReactiveUpdateStrategy();\n\n this.menu = new Menu(element as HTMLElement, {\n updater: this.updater\n });\n }\n\n if (options.items && !isEqual(this.prevItems, options.items)) {\n this.updater.updateItems();\n this.prevItems = [...options.items];\n }\n\n let optionsChanged = false;\n\n if (this.prevDisabled !== options.disabled) {\n if (options.disabled) {\n element.setAttribute('aria-disabled', 'true');\n } else {\n element.removeAttribute('aria-disabled');\n }\n\n optionsChanged = true;\n\n this.prevDisabled = options.disabled;\n }\n\n if (optionsChanged) {\n this.updater.updateOptions();\n }\n }\n}\n"],"names":["MenuModifier","Modifier","constructor","owner","args","registerDestructor","menu","dispose","modify","element","_","options","updater","ReactiveUpdateStrategy","Menu","items","isEqual","prevItems","updateItems","optionsChanged","prevDisabled","disabled","setAttribute","removeAttribute","updateOptions"],"mappings":";;;;;AAqBe,MAAMA,YAAY,SAAYC,QAAQ,CAAmB;AAQtEC,EAAAA,WAAWA,CAACC,KAAY,EAAEC,IAA+B,EAAE;AACzD,IAAA,KAAK,CAACD,KAAK,EAAEC,IAAI,CAAC;IAElBC,kBAAkB,CAAC,IAAI,EAAE,MAAM;AAC7B;AACA,MAAA,IAAI,CAACC,IAAI,EAAEC,OAAO,EAAE;AACtB,KAAC,CAAC;AACJ;AAEAC,EAAAA,MAAMA,CACJC,OAAgB,EAChBC,CAAmC,EACnCC,OAAoC,EACpC;AACA,IAAA,IAAI,CAAC,IAAI,CAACL,IAAI,EAAE;AACd,MAAA,IAAI,CAACM,OAAO,GAAG,IAAIC,sBAAsB,EAAE;AAE3C,MAAA,IAAI,CAACP,IAAI,GAAG,IAAIQ,IAAI,CAACL,OAAO,EAAiB;QAC3CG,OAAO,EAAE,IAAI,CAACA;AAChB,OAAC,CAAC;AACJ;AAEA,IAAA,IAAID,OAAO,CAACI,KAAK,IAAI,CAACC,OAAO,CAAC,IAAI,CAACC,SAAS,EAAEN,OAAO,CAACI,KAAK,CAAC,EAAE;AAC5D,MAAA,IAAI,CAACH,OAAO,CAACM,WAAW,EAAE;MAC1B,IAAI,CAACD,SAAS,GAAG,CAAC,GAAGN,OAAO,CAACI,KAAK,CAAC;AACrC;IAEA,IAAII,cAAc,GAAG,KAAK;AAE1B,IAAA,IAAI,IAAI,CAACC,YAAY,KAAKT,OAAO,CAACU,QAAQ,EAAE;MAC1C,IAAIV,OAAO,CAACU,QAAQ,EAAE;AACpBZ,QAAAA,OAAO,CAACa,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC;AAC/C,OAAC,MAAM;AACLb,QAAAA,OAAO,CAACc,eAAe,CAAC,eAAe,CAAC;AAC1C;AAEAJ,MAAAA,cAAc,GAAG,IAAI;AAErB,MAAA,IAAI,CAACC,YAAY,GAAGT,OAAO,CAACU,QAAQ;AACtC;AAEA,IAAA,IAAIF,cAAc,EAAE;AAClB,MAAA,IAAI,CAACP,OAAO,CAACY,aAAa,EAAE;AAC9B;AACF;AACF;;;;"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { registerDestructor } from '@ember/destroyable';
|
|
2
|
+
import { ReactiveUpdateStrategy, Tablist, IndexEmitStrategy, ItemEmitStrategy } from 'aria-voyager';
|
|
3
|
+
import Modifier from 'ember-modifier';
|
|
4
|
+
import isEqual from 'lodash.isequal';
|
|
5
|
+
import { c as createIndexEmitter, a as createItemEmitter, b as asArray } from '../-emitter-CQPiyyOK.js';
|
|
6
|
+
|
|
7
|
+
class TablistModifier extends Modifier {
|
|
8
|
+
constructor(owner, args) {
|
|
9
|
+
super(owner, args);
|
|
10
|
+
registerDestructor(this, () => {
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
12
|
+
this.tablist?.dispose();
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
modify(element, _, options) {
|
|
16
|
+
if (!this.tablist) {
|
|
17
|
+
this.updater = new ReactiveUpdateStrategy();
|
|
18
|
+
this.tablist = new Tablist(element, {
|
|
19
|
+
updater: this.updater,
|
|
20
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
21
|
+
behavior: options.behavior
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
if (options.items && !(this.emitter instanceof IndexEmitStrategy)) {
|
|
25
|
+
this.emitter = createIndexEmitter(this.tablist, options);
|
|
26
|
+
} else if (!options.items && !(this.emitter instanceof ItemEmitStrategy)) {
|
|
27
|
+
this.emitter = createItemEmitter(this.tablist, options);
|
|
28
|
+
}
|
|
29
|
+
if (options.items && !isEqual(this.prevItems, options.items)) {
|
|
30
|
+
this.updater.updateItems();
|
|
31
|
+
this.prevItems = [...options.items];
|
|
32
|
+
}
|
|
33
|
+
if (options.selection && !isEqual(asArray(this.prevSelection), asArray(options.selection))) {
|
|
34
|
+
this.updater.updateSelection();
|
|
35
|
+
this.prevSelection = asArray(options.selection);
|
|
36
|
+
}
|
|
37
|
+
let optionsChanged = false;
|
|
38
|
+
if (this.prevOrientation !== options.orientation) {
|
|
39
|
+
if (options.orientation) {
|
|
40
|
+
element.setAttribute('aria-orientation', options.orientation);
|
|
41
|
+
} else {
|
|
42
|
+
element.removeAttribute('aria-orientation');
|
|
43
|
+
}
|
|
44
|
+
optionsChanged = true;
|
|
45
|
+
|
|
46
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
47
|
+
this.prevOrientation = options.orientation;
|
|
48
|
+
}
|
|
49
|
+
if (this.prevDisabled !== options.disabled) {
|
|
50
|
+
if (options.disabled) {
|
|
51
|
+
element.setAttribute('aria-disabled', 'true');
|
|
52
|
+
} else {
|
|
53
|
+
element.removeAttribute('aria-disabled');
|
|
54
|
+
}
|
|
55
|
+
optionsChanged = true;
|
|
56
|
+
this.prevDisabled = options.disabled;
|
|
57
|
+
}
|
|
58
|
+
if (optionsChanged) {
|
|
59
|
+
this.updater.updateOptions();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export { TablistModifier as default };
|
|
65
|
+
//# sourceMappingURL=aria-tablist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria-tablist.js","sources":["../../src/modifiers/aria-tablist.ts"],"sourcesContent":["import { registerDestructor } from '@ember/destroyable';\n\nimport { IndexEmitStrategy, ItemEmitStrategy, ReactiveUpdateStrategy, Tablist } from 'aria-voyager';\nimport Modifier from 'ember-modifier';\nimport isEqual from 'lodash.isequal';\n\nimport {\n asArray,\n createIndexEmitter,\n createItemEmitter,\n type EmitterSignature,\n type WithItems\n} from './-emitter';\n\nimport type Owner from '@ember/owner';\nimport type { EmitStrategy, Orientation, TablistBehavior } from 'aria-voyager';\nimport type { ArgsFor, NamedArgs, PositionalArgs } from 'ember-modifier';\n\nexport interface TablistSignature<T> {\n Element: HTMLElement;\n Args: {\n Positional: [];\n Named: {\n disabled?: boolean;\n orientation?: Orientation;\n behavior?: TablistBehavior;\n } & EmitterSignature<T>;\n };\n}\n\nexport default class TablistModifier<T> extends Modifier<TablistSignature<T>> {\n private tablist?: Tablist;\n declare private updater: ReactiveUpdateStrategy;\n declare private emitter: EmitStrategy;\n\n private prevItems?: T[];\n private prevSelection?: T | T[];\n private prevDisabled?: boolean;\n private prevOrientation?: Orientation;\n\n constructor(owner: Owner, args: ArgsFor<TablistSignature<T>>) {\n super(owner, args);\n\n registerDestructor(this, () => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n this.tablist?.dispose();\n });\n }\n\n modify(\n element: Element,\n _: PositionalArgs<TablistSignature<T>>,\n options: NamedArgs<TablistSignature<T>>\n ) {\n if (!this.tablist) {\n this.updater = new ReactiveUpdateStrategy();\n\n this.tablist = new Tablist(element as HTMLElement, {\n updater: this.updater,\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n behavior: options.behavior\n });\n }\n\n if (options.items && !(this.emitter instanceof IndexEmitStrategy)) {\n this.emitter = createIndexEmitter<T>(this.tablist, options);\n } else if (!options.items && !(this.emitter instanceof ItemEmitStrategy)) {\n this.emitter = createItemEmitter<T>(this.tablist, options);\n }\n\n if (options.items && !isEqual(this.prevItems, (options as WithItems<T>).items)) {\n this.updater.updateItems();\n this.prevItems = [...(options as WithItems<T>).items];\n }\n\n if (options.selection && !isEqual(asArray(this.prevSelection), asArray(options.selection))) {\n this.updater.updateSelection();\n this.prevSelection = asArray(options.selection);\n }\n\n let optionsChanged = false;\n\n if (this.prevOrientation !== options.orientation) {\n if (options.orientation) {\n element.setAttribute('aria-orientation', options.orientation as string);\n } else {\n element.removeAttribute('aria-orientation');\n }\n\n optionsChanged = true;\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n this.prevOrientation = options.orientation;\n }\n\n if (this.prevDisabled !== options.disabled) {\n if (options.disabled) {\n element.setAttribute('aria-disabled', 'true');\n } else {\n element.removeAttribute('aria-disabled');\n }\n\n optionsChanged = true;\n\n this.prevDisabled = options.disabled;\n }\n\n if (optionsChanged) {\n this.updater.updateOptions();\n }\n }\n}\n"],"names":["TablistModifier","Modifier","constructor","owner","args","registerDestructor","tablist","dispose","modify","element","_","options","updater","ReactiveUpdateStrategy","Tablist","behavior","items","emitter","IndexEmitStrategy","createIndexEmitter","ItemEmitStrategy","createItemEmitter","isEqual","prevItems","updateItems","selection","asArray","prevSelection","updateSelection","optionsChanged","prevOrientation","orientation","setAttribute","removeAttribute","prevDisabled","disabled","updateOptions"],"mappings":"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"}
|