From ae4f62643704e7fb6721a37b4af1dcc417bf882d Mon Sep 17 00:00:00 2001 From: Tyler Hogan Date: Thu, 12 Dec 2019 05:16:00 -0800 Subject: [PATCH] [Autocomplete] Add reason to onInputChange callback (#18796) --- docs/pages/api/autocomplete.md | 2 +- .../src/Autocomplete/Autocomplete.js | 3 +- .../src/Autocomplete/Autocomplete.test.js | 37 +++++++++++++++++++ .../src/useAutocomplete/useAutocomplete.d.ts | 5 ++- .../src/useAutocomplete/useAutocomplete.js | 12 +++++- 5 files changed, 53 insertions(+), 6 deletions(-) diff --git a/docs/pages/api/autocomplete.md b/docs/pages/api/autocomplete.md index d2077b0bd06121..340066ee750df6 100644 --- a/docs/pages/api/autocomplete.md +++ b/docs/pages/api/autocomplete.md @@ -57,7 +57,7 @@ You can learn more about the difference by [reading this guide](/guides/minimizi | noOptionsText | node | 'No options' | Text to display when there are no options.
For localization purposes, you can use the provided [translations](/guides/localization/). | | onChange | func | | Callback fired when the value changes.

**Signature:**
`function(event: object, value: any) => void`
*event:* The event source of the callback
*value:* null | | onClose | func | | Callback fired when the popup requests to be closed. Use in controlled mode (see open).

**Signature:**
`function(event: object) => void`
*event:* The event source of the callback. | -| onInputChange | func | | Callback fired when the input value changes.

**Signature:**
`function(event: object, value: string) => void`
*event:* The event source of the callback.
*value:* null | +| onInputChange | func | | Callback fired when the input value changes.

**Signature:**
`function(event: object, value: string, reason: string) => void`
*event:* The event source of the callback.
*value:* The new value of the text input
*reason:* One of "input" (user input) or "reset" (programmatic change) | | onOpen | func | | Callback fired when the popup requests to be opened. Use in controlled mode (see open).

**Signature:**
`function(event: object) => void`
*event:* The event source of the callback. | | open | bool | | Control the popup` open state. | | openText | string | 'Open' | Override the default text for the *open popup* icon button.
For localization purposes, you can use the provided [translations](/guides/localization/). | diff --git a/packages/material-ui-lab/src/Autocomplete/Autocomplete.js b/packages/material-ui-lab/src/Autocomplete/Autocomplete.js index 991500fc58a886..efee54ed27131e 100644 --- a/packages/material-ui-lab/src/Autocomplete/Autocomplete.js +++ b/packages/material-ui-lab/src/Autocomplete/Autocomplete.js @@ -622,7 +622,8 @@ Autocomplete.propTypes = { * Callback fired when the input value changes. * * @param {object} event The event source of the callback. - * @param {string} value + * @param {string} value The new value of the text input + * @param {string} reason One of "input" (user input) or "reset" (programmatic change) */ onInputChange: PropTypes.func, /** diff --git a/packages/material-ui-lab/src/Autocomplete/Autocomplete.test.js b/packages/material-ui-lab/src/Autocomplete/Autocomplete.test.js index 3411cdcbf0a4f3..1132b7ed002450 100644 --- a/packages/material-ui-lab/src/Autocomplete/Autocomplete.test.js +++ b/packages/material-ui-lab/src/Autocomplete/Autocomplete.test.js @@ -742,4 +742,41 @@ describe('', () => { expect(handleChange.callCount).to.equal(1); }); }); + + describe('prop: onInputChange', () => { + it('provides a reason on input change', () => { + const handleInputChange = spy(); + const options = [{ name: 'foo' }]; + render( + option.name} + renderInput={params => } + />, + ); + fireEvent.change(document.activeElement, { target: { value: 'a' } }); + expect(handleInputChange.callCount).to.equal(1); + expect(handleInputChange.args[0][1]).to.equal('a'); + expect(handleInputChange.args[0][2]).to.equal('input'); + }); + + it('provides a reason on select reset', () => { + const handleInputChange = spy(); + const options = [{ name: 'foo' }]; + render( + option.name} + renderInput={params => } + />, + ); + fireEvent.keyDown(document.activeElement, { key: 'ArrowDown' }); + fireEvent.keyDown(document.activeElement, { key: 'Enter' }); + expect(handleInputChange.callCount).to.equal(1); + expect(handleInputChange.args[0][1]).to.equal(options[0].name); + expect(handleInputChange.args[0][2]).to.equal('reset'); + }); + }); }); diff --git a/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.d.ts b/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.d.ts index 310167c6c7145a..0628df0b15c714 100644 --- a/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.d.ts +++ b/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.d.ts @@ -138,9 +138,10 @@ export interface UseAutocompleteProps { * Callback fired when the input value changes. * * @param {object} event The event source of the callback. - * @param {string} value + * @param {string} value The new value of the text input + * @param {string} reason One of "input" (user input) or "reset" (programmatic change) */ - onInputChange?: (event: React.ChangeEvent<{}>, value: any) => void; + onInputChange?: (event: React.ChangeEvent<{}>, value: any, reason: 'input' | 'reset') => void; /** * Callback fired when the popup requests to be opened. * Use in controlled mode (see open). diff --git a/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.js b/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.js index 38f9ee430afd72..5b4ef231c45e85 100644 --- a/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.js +++ b/packages/material-ui-lab/src/useAutocomplete/useAutocomplete.js @@ -218,7 +218,7 @@ export default function useAutocomplete(props) { setInputValue(newInputValue); if (onInputChange) { - onInputChange(event, newInputValue); + onInputChange(event, newInputValue, 'reset'); } }); @@ -657,7 +657,7 @@ export default function useAutocomplete(props) { setInputValue(newValue); if (onInputChange) { - onInputChange(event, newValue); + onInputChange(event, newValue, 'input'); } }; @@ -948,6 +948,14 @@ useAutocomplete.propTypes = { * @param {object} event The event source of the callback. */ onClose: PropTypes.func, + /** + * Callback fired when the text input value changes. + * + * @param {object} event The event source of the callback + * @param {string} value The new value of the text input + * @param {string} reason One of "input" (user input) or "reset" (programmatic change) + */ + onInputChange: PropTypes.func, /** * Callback fired when the popup requests to be opened. * Use in controlled mode (see open).