Skip to content

Commit

Permalink
Add accessibility tests for toolbar roving tabindex functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
colfin-96 authored and Colin Finger committed Jan 14, 2025
1 parent cfb866c commit 347f52e
Showing 1 changed file with 54 additions and 4 deletions.
58 changes: 54 additions & 4 deletions packages/quill/test/unit/core/quill.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ describe('Quill', () => {
});

test('register(path, target)', () => {
class Counter {}
class Counter { }
Quill.register('modules/counter', Counter);

expect(Quill.imports).toHaveProperty('modules/counter', Counter);
Expand All @@ -59,7 +59,7 @@ describe('Quill', () => {
static blotName = 'a-blot';
static className = 'ql-a-blot';
}
class AModule {}
class AModule { }
Quill.register({
'formats/a-blot': ABlot,
'modules/a-module': AModule,
Expand Down Expand Up @@ -833,7 +833,7 @@ describe('Quill', () => {
});

test('toolbar custom handler, default container', () => {
const handler = () => {}; // eslint-disable-line func-style
const handler = () => { }; // eslint-disable-line func-style
const config = expandConfig(`#${testContainerId}`, {
modules: {
toolbar: {
Expand Down Expand Up @@ -1201,7 +1201,7 @@ describe('Quill', () => {
observer.observe(element);
// Firefox doesn't call IntersectionObserver callback unless
// there are rafs.
requestAnimationFrame(() => {});
requestAnimationFrame(() => { });
});
};

Expand Down Expand Up @@ -1377,4 +1377,54 @@ describe('Quill', () => {
).toEqual(0);
});
});

describe('accessibility', () => {
describe('toolbar', () => {
test('tabbing - no roving tabindex', () => {
const container = createContainer('<div></div>');
new Quill(container, {
modules: {
toolbar: [['bold', 'italic'], ['link', 'image']],
},
});
const toolbar = container?.parentElement?.querySelector('.ql-toolbar');
const buttons = toolbar?.querySelectorAll('button');
if (!buttons) {
throw new Error('No buttons found');
}
expect(buttons.length).toBe(4);

buttons.forEach((button) => {
expect(button.getAttribute('tabindex')).toBe(null);
});
});

test('tabbing - roving tabindex', () => {
const container = createContainer('<div></div>');
if (!container.parentElement) {
throw new Error('No parent element found');
}
container.parentElement.classList.add('roving-tabindex');
new Quill(container, {
modules: {
toolbar: [['bold', 'italic'], ['link', 'image']],
},
});
const toolbar = container?.parentElement?.querySelector('.ql-toolbar');
const buttons = toolbar?.querySelectorAll('button');
if (!buttons) {
throw new Error('No buttons found');
}
expect(buttons.length).toBe(4);

buttons.forEach((button, key) => {
if (key === 0) {
expect(button.getAttribute('tabindex')).toBe('0');
} else {
expect(button.getAttribute('tabindex')).toBe('-1');
}
});
});
});
});
});

0 comments on commit 347f52e

Please sign in to comment.