Skip to content

Commit

Permalink
fix(radio): dispatches input event on select
Browse files Browse the repository at this point in the history
PiperOrigin-RevId: 565522665
  • Loading branch information
asyncLiz authored and copybara-github committed Sep 15, 2023
1 parent 116b448 commit e444de3
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 0 deletions.
2 changes: 2 additions & 0 deletions radio/internal/radio.ts
Original file line number Diff line number Diff line change
Expand Up @@ -155,6 +155,8 @@ export class Radio extends LitElement {
// Per spec, clicking on a radio input always selects it.
this.checked = true;
this.dispatchEvent(new Event('change', {bubbles: true}));
this.dispatchEvent(
new InputEvent('input', {bubbles: true, composed: true}));
}

private async handleKeydown(event: KeyboardEvent) {
Expand Down
15 changes: 15 additions & 0 deletions radio/radio_test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -139,6 +139,21 @@ describe('<md-radio>', () => {
expect(changeHandler).toHaveBeenCalledTimes(1);
expect(changeHandler).toHaveBeenCalledWith(jasmine.any(Event));
});

it('Should trigger input event when a radio is selected', async () => {
const {harnesses, root} = await setupTest(radioGroupPreSelected);
const inputHandler = jasmine.createSpy('inputHandler');
root.addEventListener('input', inputHandler);

const a3 = harnesses[2];
await a3.clickWithMouse();

expect(a3.element.checked)
.withContext('clicked radio checked')
.toBeTrue();
expect(inputHandler).toHaveBeenCalledTimes(1);
expect(inputHandler).toHaveBeenCalledWith(jasmine.any(InputEvent));
});
});

describe('navigation', () => {
Expand Down

0 comments on commit e444de3

Please sign in to comment.