Skip to content

Commit

Permalink
[fields] Prevent keyboard editing when disabled (#13900)
Browse files Browse the repository at this point in the history
Co-authored-by: Arthur Balduini <[email protected]>
  • Loading branch information
arthurbalduini and Arthur Balduini authored Jul 22, 2024
1 parent 46c6d1b commit a26c904
Show file tree
Hide file tree
Showing 4 changed files with 100 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -744,6 +744,63 @@ describe('<DateField /> - Editing', () => {
});
});

describeAdapters('Disabled field', DateField, ({ renderWithProps }) => {
it('should not allow key editing on disabled field', () => {
// Test with v7 input
const onChangeV7 = spy();
const v7Response = renderWithProps({
enableAccessibleFieldDOMStructure: true,
onChange: onChangeV7,
disabled: true,
});

const keys = [
'ArrowUp',
'ArrowDown',
'PageUp',
'PageDown',
'Home',
'End',
'Delete',
'ArrowLeft',
'ArrowRight',
];

v7Response.selectSection('month');

keys.forEach((key) => {
v7Response.pressKey(0, key);
expectFieldValueV7(v7Response.getSectionsContainer(), 'MM/DD/YYYY');
expect(onChangeV7.callCount).to.equal(0);
});

// digit key press
userEvent.keyPress(v7Response.getActiveSection(0), { key: '2' });
expectFieldValueV7(v7Response.getSectionsContainer(), 'MM/DD/YYYY');

v7Response.unmount();

// Test with v6 input
const onChangeV6 = spy();
const v6Response = renderWithProps({
onChange: onChangeV6,
enableAccessibleFieldDOMStructure: false,
disabled: true,
});

const input = getTextbox();
v6Response.selectSection('month');

// v6 doesn't allow focusing on sections when disabled
keys.forEach((key) => {
fireEvent.change(input, { target: { value: key } });
expect(document.activeElement).not.to.equal(input);
expectFieldValueV6(input, '');
});
expect(onChangeV6.callCount).to.equal(0);
});
});

describeAdapters('Digit editing', DateField, ({ adapter, testFieldChange, renderWithProps }) => {
it('should set the day to the digit pressed when no digit no value is provided', () => {
testFieldChange({
Expand Down Expand Up @@ -1743,6 +1800,43 @@ describe('<DateField /> - Editing', () => {
fireEvent.change(input, { target: { value: '2/05/2018' } }); // check that the search query has been cleared after pasting
expectFieldValueV6(input, '02/05/2018'); // If internal state is not reset it would be 12 instead of 02
});

it('should not allow pasting on disabled field', () => {
// Test with v7 input
const onChangeV7 = spy();
const v7Response = renderWithProps({
enableAccessibleFieldDOMStructure: true,
onChange: onChangeV7,
disabled: true,
});

v7Response.selectSection('month');

// Select all sections
fireEvent.keyDown(v7Response.getActiveSection(0), { key: 'a', ctrlKey: true });

firePasteEventV7(v7Response.getSectionsContainer(), '09/16/2022');
expect(onChangeV7.callCount).to.equal(0);
expectFieldValueV7(v7Response.getSectionsContainer(), 'MM/DD/YYYY');

v7Response.unmount();

// Test with v6 input
const onChangeV6 = spy();
const v6Response = renderWithProps({
onChange: onChangeV6,
enableAccessibleFieldDOMStructure: false,
disabled: true,
});
const input = getTextbox();
v6Response.selectSection('month');
firePasteEventV6(input, '9');

// v6 doesn't allow focusing on sections when disabled
expect(document.activeElement).not.to.equal(input);
expect(onChangeV6.callCount).to.equal(0);
expectFieldValueV6(input, '');
});
});

describeAdapters(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,9 @@ export const useField = <
const handleContainerKeyDown = useEventCallback((event: React.KeyboardEvent<HTMLSpanElement>) => {
onKeyDown?.(event);

if (disabled) {
return;
}
// eslint-disable-next-line default-case
switch (true) {
// Select all
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ export const useFieldV6TextField: UseFieldTextField<false> = (params) => {
inputRef: inputRefProp,
placeholder: inPlaceholder,
},
internalProps: { readOnly = false },
internalProps: { readOnly = false, disabled = false },
parsedSelectedSections,
activeSectionIndex,
state,
Expand Down Expand Up @@ -273,7 +273,7 @@ export const useFieldV6TextField: UseFieldTextField<false> = (params) => {
// prevent default to avoid the input `onChange` handler being called
event.preventDefault();

if (readOnly) {
if (readOnly || disabled) {
return;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -311,7 +311,7 @@ export const useFieldV7TextField: UseFieldTextField<true> = (params) => {
// prevent default to avoid the input `onInput` handler being called
event.preventDefault();

if (readOnly || typeof parsedSelectedSections !== 'number') {
if (readOnly || disabled || typeof parsedSelectedSections !== 'number') {
return;
}

Expand Down

0 comments on commit a26c904

Please sign in to comment.