@react-aria/searchfield 3.1.3 → 3.2.1

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/dist/main.js CHANGED
@@ -221,7 +221,9 @@ function useSearchField(props, state, inputRef) {
221
221
 
222
222
  let {
223
223
  labelProps,
224
- inputProps
224
+ inputProps,
225
+ descriptionProps,
226
+ errorMessageProps
225
227
  } = useTextField(_babelRuntimeHelpersExtends({}, props, {
226
228
  value: state.value,
227
229
  onChange: state.setValue,
@@ -237,9 +239,13 @@ function useSearchField(props, state, inputRef) {
237
239
  clearButtonProps: {
238
240
  'aria-label': formatMessage('Clear search'),
239
241
  excludeFromTabOrder: true,
242
+ // @ts-ignore
243
+ preventFocusOnPress: true,
240
244
  onPress: onClearButtonClick,
241
245
  onPressStart
242
- }
246
+ },
247
+ descriptionProps,
248
+ errorMessageProps
243
249
  };
244
250
  }
245
251
 
package/dist/main.js.map CHANGED
@@ -1 +1 @@
1
- {"mappings":";;;;;;;;;;;;AAAA,SAASA,sBAAT,CAAgCC,CAAhC,EAAmC;AACjC,SAAOA,CAAC,IAAIA,CAAC,CAACC,UAAP,GAAoBD,CAAC,CAACE,OAAtB,GAAgCF,CAAvC;AACD;;;;ACFD,4CAAiBG,IAAI,CAACC,KAAL,CAAW,kCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,8CAAX,CAAjB;;;ACAA,yCAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,0CAAiBD,IAAI,CAACC,KAAL,CAAW,oCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,2CAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,4CAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,qCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,sCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,6CAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,kCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,uCAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,0CAAiBD,IAAI,CAACC,KAAL,CAAW,yCAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,+BAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,+BAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,uCAAX,CAAjB;;;ACAA,0CAAiBD,IAAI,CAACC,KAAL,CAAW,0CAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,gCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,yCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,uDAAX,CAAjB;;;ACAA,oCAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,0CAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,uCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,6CAAX,CAAjB;;;ACAA,2CAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,yCAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,sCAAX,CAAjB;;;ACAA,uCAAiBD,IAAI,CAACC,KAAL,CAAW,wCAAX,CAAjB;;;ACAA,uCAAiBD,IAAI,CAACC,KAAL,CAAW,uCAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,6BAAX,CAAjB;;;ACAA,4CAAiBD,IAAI,CAACC,KAAL,CAAW,+BAAX,CAAjB;;ACAA;;;;;;;;;;;AAeA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeA;;;;;;AAMO,SAASC,cAAT,CACLC,KADK,EAELC,KAFK,EAGLC,QAHK,EAIY;AACjB,MAAIC,aAAa,GAAGC,mBAAmB,CAACC,+CAAD,CAAvC;AACA,MAAI;AACFC,IAAAA,UADE;AAEFC,IAAAA,QAAQ,GAAG,MAAM,CAAE,CAFjB;AAGFC,IAAAA,OAHE;AAIFC,IAAAA,IAAI,GAAG;AAJL,MAKAT,KALJ;;AAOA,MAAIU,SAAS,GAAIC,CAAD,IAAO;AACrB,UAAMC,GAAG,GAAGD,CAAC,CAACC,GAAd;;AAEA,QAAIA,GAAG,KAAK,OAAR,IAAmBA,GAAG,KAAK,QAA/B,EAAyC;AACvCD,MAAAA,CAAC,CAACE,cAAF;AACD;;AAED,QAAIP,UAAJ,EAAgB;AACd;AACD;;AAED,QAAIM,GAAG,KAAK,OAAZ,EAAqB;AACnBL,MAAAA,QAAQ,CAACN,KAAK,CAACa,KAAP,CAAR;AACD;;AAED,QAAIF,GAAG,KAAK,QAAZ,EAAsB;AACpBX,MAAAA,KAAK,CAACc,QAAN,CAAe,EAAf;;AACA,UAAIP,OAAJ,EAAa;AACXA,QAAAA,OAAO;AACR;AACF;AACF,GArBD;;AAuBA,MAAIQ,kBAAkB,GAAG,MAAM;AAC7Bf,IAAAA,KAAK,CAACc,QAAN,CAAe,EAAf;;AAEA,QAAIP,OAAJ,EAAa;AACXA,MAAAA,OAAO;AACR;AACF,GAND;;AAQA,MAAIS,YAAY,GAAG,MAAM;AACvB;AACA;AACAf,IAAAA,QAAQ,CAACgB,OAAT,CAAiBC,KAAjB;AACD,GAJD;;AAMA,MAAI;AAACC,IAAAA,UAAD;AAAaC,IAAAA;AAAb,MAA2BC,YAAY,iCACtCtB,KADsC;AAEzCc,IAAAA,KAAK,EAAEb,KAAK,CAACa,KAF4B;AAGzCS,IAAAA,QAAQ,EAAEtB,KAAK,CAACc,QAHyB;AAIzCL,IAAAA,SAJyC;AAKzCD,IAAAA;AALyC,MAMxCP,QANwC,CAA3C;AAQA,SAAO;AACLkB,IAAAA,UADK;AAELC,IAAAA,UAAU,kCACLA,UADK;AAER;AACAG,MAAAA,YAAY,EAAEC;AAHN,MAFL;AAOLC,IAAAA,gBAAgB,EAAE;AAChB,oBAAcvB,aAAa,CAAC,cAAD,CADX;AAEhBwB,MAAAA,mBAAmB,EAAE,IAFL;AAGhBC,MAAAA,OAAO,EAAEZ,kBAHO;AAIhBC,MAAAA;AAJgB;AAPb,GAAP;AAcD","sources":["./node_modules/@parcel/scope-hoisting/lib/helpers.js","./packages/@react-aria/searchfield/intl/ar-AE.json","./packages/@react-aria/searchfield/intl/bg-BG.json","./packages/@react-aria/searchfield/intl/cs-CZ.json","./packages/@react-aria/searchfield/intl/da-DK.json","./packages/@react-aria/searchfield/intl/de-DE.json","./packages/@react-aria/searchfield/intl/el-GR.json","./packages/@react-aria/searchfield/intl/en-US.json","./packages/@react-aria/searchfield/intl/es-ES.json","./packages/@react-aria/searchfield/intl/et-EE.json","./packages/@react-aria/searchfield/intl/fi-FI.json","./packages/@react-aria/searchfield/intl/fr-FR.json","./packages/@react-aria/searchfield/intl/he-IL.json","./packages/@react-aria/searchfield/intl/hr-HR.json","./packages/@react-aria/searchfield/intl/hu-HU.json","./packages/@react-aria/searchfield/intl/it-IT.json","./packages/@react-aria/searchfield/intl/ja-JP.json","./packages/@react-aria/searchfield/intl/ko-KR.json","./packages/@react-aria/searchfield/intl/lt-LT.json","./packages/@react-aria/searchfield/intl/lv-LV.json","./packages/@react-aria/searchfield/intl/nb-NO.json","./packages/@react-aria/searchfield/intl/nl-NL.json","./packages/@react-aria/searchfield/intl/pl-PL.json","./packages/@react-aria/searchfield/intl/pt-BR.json","./packages/@react-aria/searchfield/intl/pt-PT.json","./packages/@react-aria/searchfield/intl/ro-RO.json","./packages/@react-aria/searchfield/intl/ru-RU.json","./packages/@react-aria/searchfield/intl/sk-SK.json","./packages/@react-aria/searchfield/intl/sl-SI.json","./packages/@react-aria/searchfield/intl/sr-SP.json","./packages/@react-aria/searchfield/intl/sv-SE.json","./packages/@react-aria/searchfield/intl/tr-TR.json","./packages/@react-aria/searchfield/intl/uk-UA.json","./packages/@react-aria/searchfield/intl/zh-CN.json","./packages/@react-aria/searchfield/intl/zh-TW.json","./packages/@react-aria/searchfield/src/useSearchField.ts"],"sourcesContent":["function $parcel$interopDefault(a) {\n return a && a.__esModule ? a.default : a;\n}\n\nfunction $parcel$defineInteropFlag(a) {\n Object.defineProperty(a, '__esModule', {value: true});\n}\n\nfunction $parcel$exportWildcard(dest, source) {\n Object.keys(source).forEach(function(key) {\n if (key === 'default' || key === '__esModule') {\n return;\n }\n\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function get() {\n return source[key];\n },\n });\n });\n\n return dest;\n}\n\nfunction $parcel$missingModule(name) {\n var err = new Error(\"Cannot find module '\" + name + \"'\");\n err.code = 'MODULE_NOT_FOUND';\n throw err;\n}\n\nvar $parcel$global =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {};\n","{\n \"Clear search\": \"مسح البحث\"\n}\n","{\n \"Clear search\": \"Изчистване на търсене\"\n}\n","{\n \"Clear search\": \"Vymazat hledání\"\n}\n","{\n \"Clear search\": \"Ryd søgning\"\n}\n","{\n \"Clear search\": \"Suche zurücksetzen\"\n}\n","{\n \"Clear search\": \"Απαλοιφή αναζήτησης\"\n}\n","{\n \"Clear search\": \"Clear search\"\n}\n","{\n \"Clear search\": \"Borrar búsqueda\"\n}\n","{\n \"Clear search\": \"Tühjenda otsing\"\n}\n","{\n \"Clear search\": \"Tyhjennä haku\"\n}\n","{\n \"Clear search\": \"Effacer la recherche\"\n}\n","{\n \"Clear search\": \"נקה חיפוש\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Keresés törlése\"\n}\n","{\n \"Clear search\": \"Cancella ricerca\"\n}\n","{\n \"Clear search\": \"検索をクリア\"\n}\n","{\n \"Clear search\": \"검색 지우기\"\n}\n","{\n \"Clear search\": \"Išvalyti iešką\"\n}\n","{\n \"Clear search\": \"Notīrīt meklēšanu\"\n}\n","{\n \"Clear search\": \"Tøm søk\"\n}\n","{\n \"Clear search\": \"Zoekactie wissen\"\n}\n","{\n \"Clear search\": \"Wyczyść zawartość wyszukiwania\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Ştergeţi căutarea\"\n}\n","{\n \"Clear search\": \"Очистить поиск\"\n}\n","{\n \"Clear search\": \"Vymazať vyhľadávanie\"\n}\n","{\n \"Clear search\": \"Počisti iskanje\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Rensa sökning\"\n}\n","{\n \"Clear search\": \"Aramayı temizle\"\n}\n","{\n \"Clear search\": \"Очистити пошук\"\n}\n","{\n \"Clear search\": \"清除搜索\"\n}\n","{\n \"Clear search\": \"清除搜尋條件\"\n}\n","/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaButtonProps} from '@react-types/button';\nimport {AriaSearchFieldProps} from '@react-types/searchfield';\nimport {InputHTMLAttributes, LabelHTMLAttributes, RefObject} from 'react';\n// @ts-ignore\nimport intlMessages from '../intl/*.json';\nimport {SearchFieldState} from '@react-stately/searchfield';\nimport {useMessageFormatter} from '@react-aria/i18n';\nimport {useTextField} from '@react-aria/textfield';\n\ninterface SearchFieldAria {\n /** Props for the text field's visible label element (if any). */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>,\n /** Props for the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement | HTMLTextAreaElement>,\n /** Props for the clear button. */\n clearButtonProps: AriaButtonProps\n}\n\n/**\n * Provides the behavior and accessibility implementation for a search field.\n * @param props - Props for the search field.\n * @param state - State for the search field, as returned by `useSearchFieldState`.\n * @param inputRef - A ref to the input element.\n */\nexport function useSearchField(\n props: AriaSearchFieldProps,\n state: SearchFieldState,\n inputRef: RefObject<HTMLInputElement | HTMLTextAreaElement>\n): SearchFieldAria {\n let formatMessage = useMessageFormatter(intlMessages);\n let {\n isDisabled,\n onSubmit = () => {},\n onClear,\n type = 'search'\n } = props;\n\n let onKeyDown = (e) => {\n const key = e.key;\n\n if (key === 'Enter' || key === 'Escape') {\n e.preventDefault();\n }\n\n if (isDisabled) {\n return;\n }\n\n if (key === 'Enter') {\n onSubmit(state.value);\n }\n\n if (key === 'Escape') {\n state.setValue('');\n if (onClear) {\n onClear();\n }\n }\n };\n\n let onClearButtonClick = () => {\n state.setValue('');\n\n if (onClear) {\n onClear();\n }\n };\n\n let onPressStart = () => {\n // this is in PressStart for mobile so that touching the clear button doesn't remove focus from\n // the input and close the keyboard\n inputRef.current.focus();\n };\n\n let {labelProps, inputProps} = useTextField({\n ...props,\n value: state.value,\n onChange: state.setValue,\n onKeyDown,\n type\n }, inputRef);\n\n return {\n labelProps,\n inputProps: {\n ...inputProps,\n // already handled by useSearchFieldState\n defaultValue: undefined\n },\n clearButtonProps: {\n 'aria-label': formatMessage('Clear search'),\n excludeFromTabOrder: true,\n onPress: onClearButtonClick,\n onPressStart\n }\n };\n}\n"],"names":["$parcel$interopDefault","a","__esModule","default","JSON","parse","useSearchField","props","state","inputRef","formatMessage","useMessageFormatter","intlMessages","isDisabled","onSubmit","onClear","type","onKeyDown","e","key","preventDefault","value","setValue","onClearButtonClick","onPressStart","current","focus","labelProps","inputProps","useTextField","onChange","defaultValue","undefined","clearButtonProps","excludeFromTabOrder","onPress"],"version":3,"file":"main.js.map"}
1
+ {"mappings":"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","sources":["./node_modules/@parcel/scope-hoisting/lib/helpers.js","./packages/@react-aria/searchfield/intl/ar-AE.json","./packages/@react-aria/searchfield/intl/bg-BG.json","./packages/@react-aria/searchfield/intl/cs-CZ.json","./packages/@react-aria/searchfield/intl/da-DK.json","./packages/@react-aria/searchfield/intl/de-DE.json","./packages/@react-aria/searchfield/intl/el-GR.json","./packages/@react-aria/searchfield/intl/en-US.json","./packages/@react-aria/searchfield/intl/es-ES.json","./packages/@react-aria/searchfield/intl/et-EE.json","./packages/@react-aria/searchfield/intl/fi-FI.json","./packages/@react-aria/searchfield/intl/fr-FR.json","./packages/@react-aria/searchfield/intl/he-IL.json","./packages/@react-aria/searchfield/intl/hr-HR.json","./packages/@react-aria/searchfield/intl/hu-HU.json","./packages/@react-aria/searchfield/intl/it-IT.json","./packages/@react-aria/searchfield/intl/ja-JP.json","./packages/@react-aria/searchfield/intl/ko-KR.json","./packages/@react-aria/searchfield/intl/lt-LT.json","./packages/@react-aria/searchfield/intl/lv-LV.json","./packages/@react-aria/searchfield/intl/nb-NO.json","./packages/@react-aria/searchfield/intl/nl-NL.json","./packages/@react-aria/searchfield/intl/pl-PL.json","./packages/@react-aria/searchfield/intl/pt-BR.json","./packages/@react-aria/searchfield/intl/pt-PT.json","./packages/@react-aria/searchfield/intl/ro-RO.json","./packages/@react-aria/searchfield/intl/ru-RU.json","./packages/@react-aria/searchfield/intl/sk-SK.json","./packages/@react-aria/searchfield/intl/sl-SI.json","./packages/@react-aria/searchfield/intl/sr-SP.json","./packages/@react-aria/searchfield/intl/sv-SE.json","./packages/@react-aria/searchfield/intl/tr-TR.json","./packages/@react-aria/searchfield/intl/uk-UA.json","./packages/@react-aria/searchfield/intl/zh-CN.json","./packages/@react-aria/searchfield/intl/zh-TW.json","./packages/@react-aria/searchfield/src/useSearchField.ts"],"sourcesContent":["function $parcel$interopDefault(a) {\n return a && a.__esModule ? a.default : a;\n}\n\nfunction $parcel$defineInteropFlag(a) {\n Object.defineProperty(a, '__esModule', {value: true});\n}\n\nfunction $parcel$exportWildcard(dest, source) {\n Object.keys(source).forEach(function(key) {\n if (key === 'default' || key === '__esModule') {\n return;\n }\n\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function get() {\n return source[key];\n },\n });\n });\n\n return dest;\n}\n\nfunction $parcel$missingModule(name) {\n var err = new Error(\"Cannot find module '\" + name + \"'\");\n err.code = 'MODULE_NOT_FOUND';\n throw err;\n}\n\nvar $parcel$global =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {};\n","{\n \"Clear search\": \"مسح البحث\"\n}\n","{\n \"Clear search\": \"Изчистване на търсене\"\n}\n","{\n \"Clear search\": \"Vymazat hledání\"\n}\n","{\n \"Clear search\": \"Ryd søgning\"\n}\n","{\n \"Clear search\": \"Suche zurücksetzen\"\n}\n","{\n \"Clear search\": \"Απαλοιφή αναζήτησης\"\n}\n","{\n \"Clear search\": \"Clear search\"\n}\n","{\n \"Clear search\": \"Borrar búsqueda\"\n}\n","{\n \"Clear search\": \"Tühjenda otsing\"\n}\n","{\n \"Clear search\": \"Tyhjennä haku\"\n}\n","{\n \"Clear search\": \"Effacer la recherche\"\n}\n","{\n \"Clear search\": \"נקה חיפוש\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Keresés törlése\"\n}\n","{\n \"Clear search\": \"Cancella ricerca\"\n}\n","{\n \"Clear search\": \"検索をクリア\"\n}\n","{\n \"Clear search\": \"검색 지우기\"\n}\n","{\n \"Clear search\": \"Išvalyti iešką\"\n}\n","{\n \"Clear search\": \"Notīrīt meklēšanu\"\n}\n","{\n \"Clear search\": \"Tøm søk\"\n}\n","{\n \"Clear search\": \"Zoekactie wissen\"\n}\n","{\n \"Clear search\": \"Wyczyść zawartość wyszukiwania\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Ştergeţi căutarea\"\n}\n","{\n \"Clear search\": \"Очистить поиск\"\n}\n","{\n \"Clear search\": \"Vymazať vyhľadávanie\"\n}\n","{\n \"Clear search\": \"Počisti iskanje\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Rensa sökning\"\n}\n","{\n \"Clear search\": \"Aramayı temizle\"\n}\n","{\n \"Clear search\": \"Очистити пошук\"\n}\n","{\n \"Clear search\": \"清除搜索\"\n}\n","{\n \"Clear search\": \"清除搜尋條件\"\n}\n","/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaButtonProps} from '@react-types/button';\nimport {AriaSearchFieldProps} from '@react-types/searchfield';\nimport {HTMLAttributes, InputHTMLAttributes, LabelHTMLAttributes, RefObject} from 'react';\n// @ts-ignore\nimport intlMessages from '../intl/*.json';\nimport {SearchFieldState} from '@react-stately/searchfield';\nimport {useMessageFormatter} from '@react-aria/i18n';\nimport {useTextField} from '@react-aria/textfield';\n\ninterface SearchFieldAria {\n /** Props for the text field's visible label element (if any). */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>,\n /** Props for the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement>,\n /** Props for the clear button. */\n clearButtonProps: AriaButtonProps,\n /** Props for the searchfield's description element, if any. */\n descriptionProps: HTMLAttributes<HTMLElement>,\n /** Props for the searchfield's error message element, if any. */\n errorMessageProps: HTMLAttributes<HTMLElement>\n}\n\n/**\n * Provides the behavior and accessibility implementation for a search field.\n * @param props - Props for the search field.\n * @param state - State for the search field, as returned by `useSearchFieldState`.\n * @param inputRef - A ref to the input element.\n */\nexport function useSearchField(\n props: AriaSearchFieldProps,\n state: SearchFieldState,\n inputRef: RefObject<HTMLInputElement>\n): SearchFieldAria {\n let formatMessage = useMessageFormatter(intlMessages);\n let {\n isDisabled,\n onSubmit = () => {},\n onClear,\n type = 'search'\n } = props;\n\n let onKeyDown = (e) => {\n const key = e.key;\n\n if (key === 'Enter' || key === 'Escape') {\n e.preventDefault();\n }\n\n if (isDisabled) {\n return;\n }\n\n if (key === 'Enter') {\n onSubmit(state.value);\n }\n\n if (key === 'Escape') {\n state.setValue('');\n if (onClear) {\n onClear();\n }\n }\n };\n\n let onClearButtonClick = () => {\n state.setValue('');\n\n if (onClear) {\n onClear();\n }\n };\n\n let onPressStart = () => {\n // this is in PressStart for mobile so that touching the clear button doesn't remove focus from\n // the input and close the keyboard\n inputRef.current.focus();\n };\n\n let {labelProps, inputProps, descriptionProps, errorMessageProps} = useTextField({\n ...props,\n value: state.value,\n onChange: state.setValue,\n onKeyDown,\n type\n }, inputRef);\n\n return {\n labelProps,\n inputProps: {\n ...inputProps,\n // already handled by useSearchFieldState\n defaultValue: undefined\n },\n clearButtonProps: {\n 'aria-label': formatMessage('Clear search'),\n excludeFromTabOrder: true,\n // @ts-ignore\n preventFocusOnPress: true,\n onPress: onClearButtonClick,\n onPressStart\n },\n descriptionProps,\n errorMessageProps\n };\n}\n"],"names":["$parcel$interopDefault","a","__esModule","default","JSON","parse","useSearchField","props","state","inputRef","formatMessage","useMessageFormatter","intlMessages","isDisabled","onSubmit","onClear","type","onKeyDown","e","key","preventDefault","value","setValue","onClearButtonClick","onPressStart","current","focus","labelProps","inputProps","descriptionProps","errorMessageProps","useTextField","onChange","defaultValue","undefined","clearButtonProps","excludeFromTabOrder","preventFocusOnPress","onPress"],"version":3,"file":"main.js.map"}
package/dist/module.js CHANGED
@@ -209,7 +209,9 @@ export function useSearchField(props, state, inputRef) {
209
209
 
210
210
  let {
211
211
  labelProps,
212
- inputProps
212
+ inputProps,
213
+ descriptionProps,
214
+ errorMessageProps
213
215
  } = useTextField(_babelRuntimeHelpersEsmExtends({}, props, {
214
216
  value: state.value,
215
217
  onChange: state.setValue,
@@ -225,9 +227,13 @@ export function useSearchField(props, state, inputRef) {
225
227
  clearButtonProps: {
226
228
  'aria-label': formatMessage('Clear search'),
227
229
  excludeFromTabOrder: true,
230
+ // @ts-ignore
231
+ preventFocusOnPress: true,
228
232
  onPress: onClearButtonClick,
229
233
  onPressStart
230
- }
234
+ },
235
+ descriptionProps,
236
+ errorMessageProps
231
237
  };
232
238
  }
233
239
  //# sourceMappingURL=module.js.map
@@ -1 +1 @@
1
- {"mappings":"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","sources":["./packages/@react-aria/searchfield/intl/ar-AE.json","./packages/@react-aria/searchfield/intl/bg-BG.json","./packages/@react-aria/searchfield/intl/cs-CZ.json","./packages/@react-aria/searchfield/intl/da-DK.json","./packages/@react-aria/searchfield/intl/de-DE.json","./packages/@react-aria/searchfield/intl/el-GR.json","./packages/@react-aria/searchfield/intl/en-US.json","./packages/@react-aria/searchfield/intl/es-ES.json","./packages/@react-aria/searchfield/intl/et-EE.json","./packages/@react-aria/searchfield/intl/fi-FI.json","./packages/@react-aria/searchfield/intl/fr-FR.json","./packages/@react-aria/searchfield/intl/he-IL.json","./packages/@react-aria/searchfield/intl/hr-HR.json","./packages/@react-aria/searchfield/intl/hu-HU.json","./packages/@react-aria/searchfield/intl/it-IT.json","./packages/@react-aria/searchfield/intl/ja-JP.json","./packages/@react-aria/searchfield/intl/ko-KR.json","./packages/@react-aria/searchfield/intl/lt-LT.json","./packages/@react-aria/searchfield/intl/lv-LV.json","./packages/@react-aria/searchfield/intl/nb-NO.json","./packages/@react-aria/searchfield/intl/nl-NL.json","./packages/@react-aria/searchfield/intl/pl-PL.json","./packages/@react-aria/searchfield/intl/pt-BR.json","./packages/@react-aria/searchfield/intl/pt-PT.json","./packages/@react-aria/searchfield/intl/ro-RO.json","./packages/@react-aria/searchfield/intl/ru-RU.json","./packages/@react-aria/searchfield/intl/sk-SK.json","./packages/@react-aria/searchfield/intl/sl-SI.json","./packages/@react-aria/searchfield/intl/sr-SP.json","./packages/@react-aria/searchfield/intl/sv-SE.json","./packages/@react-aria/searchfield/intl/tr-TR.json","./packages/@react-aria/searchfield/intl/uk-UA.json","./packages/@react-aria/searchfield/intl/zh-CN.json","./packages/@react-aria/searchfield/intl/zh-TW.json","./packages/@react-aria/searchfield/src/useSearchField.ts"],"sourcesContent":["{\n \"Clear search\": \"مسح البحث\"\n}\n","{\n \"Clear search\": \"Изчистване на търсене\"\n}\n","{\n \"Clear search\": \"Vymazat hledání\"\n}\n","{\n \"Clear search\": \"Ryd søgning\"\n}\n","{\n \"Clear search\": \"Suche zurücksetzen\"\n}\n","{\n \"Clear search\": \"Απαλοιφή αναζήτησης\"\n}\n","{\n \"Clear search\": \"Clear search\"\n}\n","{\n \"Clear search\": \"Borrar búsqueda\"\n}\n","{\n \"Clear search\": \"Tühjenda otsing\"\n}\n","{\n \"Clear search\": \"Tyhjennä haku\"\n}\n","{\n \"Clear search\": \"Effacer la recherche\"\n}\n","{\n \"Clear search\": \"נקה חיפוש\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Keresés törlése\"\n}\n","{\n \"Clear search\": \"Cancella ricerca\"\n}\n","{\n \"Clear search\": \"検索をクリア\"\n}\n","{\n \"Clear search\": \"검색 지우기\"\n}\n","{\n \"Clear search\": \"Išvalyti iešką\"\n}\n","{\n \"Clear search\": \"Notīrīt meklēšanu\"\n}\n","{\n \"Clear search\": \"Tøm søk\"\n}\n","{\n \"Clear search\": \"Zoekactie wissen\"\n}\n","{\n \"Clear search\": \"Wyczyść zawartość wyszukiwania\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Ştergeţi căutarea\"\n}\n","{\n \"Clear search\": \"Очистить поиск\"\n}\n","{\n \"Clear search\": \"Vymazať vyhľadávanie\"\n}\n","{\n \"Clear search\": \"Počisti iskanje\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Rensa sökning\"\n}\n","{\n \"Clear search\": \"Aramayı temizle\"\n}\n","{\n \"Clear search\": \"Очистити пошук\"\n}\n","{\n \"Clear search\": \"清除搜索\"\n}\n","{\n \"Clear search\": \"清除搜尋條件\"\n}\n","/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaButtonProps} from '@react-types/button';\nimport {AriaSearchFieldProps} from '@react-types/searchfield';\nimport {InputHTMLAttributes, LabelHTMLAttributes, RefObject} from 'react';\n// @ts-ignore\nimport intlMessages from '../intl/*.json';\nimport {SearchFieldState} from '@react-stately/searchfield';\nimport {useMessageFormatter} from '@react-aria/i18n';\nimport {useTextField} from '@react-aria/textfield';\n\ninterface SearchFieldAria {\n /** Props for the text field's visible label element (if any). */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>,\n /** Props for the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement | HTMLTextAreaElement>,\n /** Props for the clear button. */\n clearButtonProps: AriaButtonProps\n}\n\n/**\n * Provides the behavior and accessibility implementation for a search field.\n * @param props - Props for the search field.\n * @param state - State for the search field, as returned by `useSearchFieldState`.\n * @param inputRef - A ref to the input element.\n */\nexport function useSearchField(\n props: AriaSearchFieldProps,\n state: SearchFieldState,\n inputRef: RefObject<HTMLInputElement | HTMLTextAreaElement>\n): SearchFieldAria {\n let formatMessage = useMessageFormatter(intlMessages);\n let {\n isDisabled,\n onSubmit = () => {},\n onClear,\n type = 'search'\n } = props;\n\n let onKeyDown = (e) => {\n const key = e.key;\n\n if (key === 'Enter' || key === 'Escape') {\n e.preventDefault();\n }\n\n if (isDisabled) {\n return;\n }\n\n if (key === 'Enter') {\n onSubmit(state.value);\n }\n\n if (key === 'Escape') {\n state.setValue('');\n if (onClear) {\n onClear();\n }\n }\n };\n\n let onClearButtonClick = () => {\n state.setValue('');\n\n if (onClear) {\n onClear();\n }\n };\n\n let onPressStart = () => {\n // this is in PressStart for mobile so that touching the clear button doesn't remove focus from\n // the input and close the keyboard\n inputRef.current.focus();\n };\n\n let {labelProps, inputProps} = useTextField({\n ...props,\n value: state.value,\n onChange: state.setValue,\n onKeyDown,\n type\n }, inputRef);\n\n return {\n labelProps,\n inputProps: {\n ...inputProps,\n // already handled by useSearchFieldState\n defaultValue: undefined\n },\n clearButtonProps: {\n 'aria-label': formatMessage('Clear search'),\n excludeFromTabOrder: true,\n onPress: onClearButtonClick,\n onPressStart\n }\n };\n}\n"],"names":["JSON","parse","useSearchField","props","state","inputRef","formatMessage","useMessageFormatter","intlMessages","isDisabled","onSubmit","onClear","type","onKeyDown","e","key","preventDefault","value","setValue","onClearButtonClick","onPressStart","current","focus","labelProps","inputProps","useTextField","onChange","defaultValue","undefined","clearButtonProps","excludeFromTabOrder","onPress"],"version":3,"file":"module.js.map"}
1
+ {"mappings":"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","sources":["./packages/@react-aria/searchfield/intl/ar-AE.json","./packages/@react-aria/searchfield/intl/bg-BG.json","./packages/@react-aria/searchfield/intl/cs-CZ.json","./packages/@react-aria/searchfield/intl/da-DK.json","./packages/@react-aria/searchfield/intl/de-DE.json","./packages/@react-aria/searchfield/intl/el-GR.json","./packages/@react-aria/searchfield/intl/en-US.json","./packages/@react-aria/searchfield/intl/es-ES.json","./packages/@react-aria/searchfield/intl/et-EE.json","./packages/@react-aria/searchfield/intl/fi-FI.json","./packages/@react-aria/searchfield/intl/fr-FR.json","./packages/@react-aria/searchfield/intl/he-IL.json","./packages/@react-aria/searchfield/intl/hr-HR.json","./packages/@react-aria/searchfield/intl/hu-HU.json","./packages/@react-aria/searchfield/intl/it-IT.json","./packages/@react-aria/searchfield/intl/ja-JP.json","./packages/@react-aria/searchfield/intl/ko-KR.json","./packages/@react-aria/searchfield/intl/lt-LT.json","./packages/@react-aria/searchfield/intl/lv-LV.json","./packages/@react-aria/searchfield/intl/nb-NO.json","./packages/@react-aria/searchfield/intl/nl-NL.json","./packages/@react-aria/searchfield/intl/pl-PL.json","./packages/@react-aria/searchfield/intl/pt-BR.json","./packages/@react-aria/searchfield/intl/pt-PT.json","./packages/@react-aria/searchfield/intl/ro-RO.json","./packages/@react-aria/searchfield/intl/ru-RU.json","./packages/@react-aria/searchfield/intl/sk-SK.json","./packages/@react-aria/searchfield/intl/sl-SI.json","./packages/@react-aria/searchfield/intl/sr-SP.json","./packages/@react-aria/searchfield/intl/sv-SE.json","./packages/@react-aria/searchfield/intl/tr-TR.json","./packages/@react-aria/searchfield/intl/uk-UA.json","./packages/@react-aria/searchfield/intl/zh-CN.json","./packages/@react-aria/searchfield/intl/zh-TW.json","./packages/@react-aria/searchfield/src/useSearchField.ts"],"sourcesContent":["{\n \"Clear search\": \"مسح البحث\"\n}\n","{\n \"Clear search\": \"Изчистване на търсене\"\n}\n","{\n \"Clear search\": \"Vymazat hledání\"\n}\n","{\n \"Clear search\": \"Ryd søgning\"\n}\n","{\n \"Clear search\": \"Suche zurücksetzen\"\n}\n","{\n \"Clear search\": \"Απαλοιφή αναζήτησης\"\n}\n","{\n \"Clear search\": \"Clear search\"\n}\n","{\n \"Clear search\": \"Borrar búsqueda\"\n}\n","{\n \"Clear search\": \"Tühjenda otsing\"\n}\n","{\n \"Clear search\": \"Tyhjennä haku\"\n}\n","{\n \"Clear search\": \"Effacer la recherche\"\n}\n","{\n \"Clear search\": \"נקה חיפוש\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Keresés törlése\"\n}\n","{\n \"Clear search\": \"Cancella ricerca\"\n}\n","{\n \"Clear search\": \"検索をクリア\"\n}\n","{\n \"Clear search\": \"검색 지우기\"\n}\n","{\n \"Clear search\": \"Išvalyti iešką\"\n}\n","{\n \"Clear search\": \"Notīrīt meklēšanu\"\n}\n","{\n \"Clear search\": \"Tøm søk\"\n}\n","{\n \"Clear search\": \"Zoekactie wissen\"\n}\n","{\n \"Clear search\": \"Wyczyść zawartość wyszukiwania\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Limpar pesquisa\"\n}\n","{\n \"Clear search\": \"Ştergeţi căutarea\"\n}\n","{\n \"Clear search\": \"Очистить поиск\"\n}\n","{\n \"Clear search\": \"Vymazať vyhľadávanie\"\n}\n","{\n \"Clear search\": \"Počisti iskanje\"\n}\n","{\n \"Clear search\": \"Obriši pretragu\"\n}\n","{\n \"Clear search\": \"Rensa sökning\"\n}\n","{\n \"Clear search\": \"Aramayı temizle\"\n}\n","{\n \"Clear search\": \"Очистити пошук\"\n}\n","{\n \"Clear search\": \"清除搜索\"\n}\n","{\n \"Clear search\": \"清除搜尋條件\"\n}\n","/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaButtonProps} from '@react-types/button';\nimport {AriaSearchFieldProps} from '@react-types/searchfield';\nimport {HTMLAttributes, InputHTMLAttributes, LabelHTMLAttributes, RefObject} from 'react';\n// @ts-ignore\nimport intlMessages from '../intl/*.json';\nimport {SearchFieldState} from '@react-stately/searchfield';\nimport {useMessageFormatter} from '@react-aria/i18n';\nimport {useTextField} from '@react-aria/textfield';\n\ninterface SearchFieldAria {\n /** Props for the text field's visible label element (if any). */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>,\n /** Props for the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement>,\n /** Props for the clear button. */\n clearButtonProps: AriaButtonProps,\n /** Props for the searchfield's description element, if any. */\n descriptionProps: HTMLAttributes<HTMLElement>,\n /** Props for the searchfield's error message element, if any. */\n errorMessageProps: HTMLAttributes<HTMLElement>\n}\n\n/**\n * Provides the behavior and accessibility implementation for a search field.\n * @param props - Props for the search field.\n * @param state - State for the search field, as returned by `useSearchFieldState`.\n * @param inputRef - A ref to the input element.\n */\nexport function useSearchField(\n props: AriaSearchFieldProps,\n state: SearchFieldState,\n inputRef: RefObject<HTMLInputElement>\n): SearchFieldAria {\n let formatMessage = useMessageFormatter(intlMessages);\n let {\n isDisabled,\n onSubmit = () => {},\n onClear,\n type = 'search'\n } = props;\n\n let onKeyDown = (e) => {\n const key = e.key;\n\n if (key === 'Enter' || key === 'Escape') {\n e.preventDefault();\n }\n\n if (isDisabled) {\n return;\n }\n\n if (key === 'Enter') {\n onSubmit(state.value);\n }\n\n if (key === 'Escape') {\n state.setValue('');\n if (onClear) {\n onClear();\n }\n }\n };\n\n let onClearButtonClick = () => {\n state.setValue('');\n\n if (onClear) {\n onClear();\n }\n };\n\n let onPressStart = () => {\n // this is in PressStart for mobile so that touching the clear button doesn't remove focus from\n // the input and close the keyboard\n inputRef.current.focus();\n };\n\n let {labelProps, inputProps, descriptionProps, errorMessageProps} = useTextField({\n ...props,\n value: state.value,\n onChange: state.setValue,\n onKeyDown,\n type\n }, inputRef);\n\n return {\n labelProps,\n inputProps: {\n ...inputProps,\n // already handled by useSearchFieldState\n defaultValue: undefined\n },\n clearButtonProps: {\n 'aria-label': formatMessage('Clear search'),\n excludeFromTabOrder: true,\n // @ts-ignore\n preventFocusOnPress: true,\n onPress: onClearButtonClick,\n onPressStart\n },\n descriptionProps,\n errorMessageProps\n };\n}\n"],"names":["JSON","parse","useSearchField","props","state","inputRef","formatMessage","useMessageFormatter","intlMessages","isDisabled","onSubmit","onClear","type","onKeyDown","e","key","preventDefault","value","setValue","onClearButtonClick","onPressStart","current","focus","labelProps","inputProps","descriptionProps","errorMessageProps","useTextField","onChange","defaultValue","undefined","clearButtonProps","excludeFromTabOrder","preventFocusOnPress","onPress"],"version":3,"file":"module.js.map"}
package/dist/types.d.ts CHANGED
@@ -1,14 +1,18 @@
1
1
  import { AriaButtonProps } from "@react-types/button";
2
2
  import { AriaSearchFieldProps } from "@react-types/searchfield";
3
- import { InputHTMLAttributes, LabelHTMLAttributes, RefObject } from "react";
3
+ import { HTMLAttributes, InputHTMLAttributes, LabelHTMLAttributes, RefObject } from "react";
4
4
  import { SearchFieldState } from "@react-stately/searchfield";
5
5
  interface SearchFieldAria {
6
6
  /** Props for the text field's visible label element (if any). */
7
7
  labelProps: LabelHTMLAttributes<HTMLLabelElement>;
8
8
  /** Props for the input element. */
9
- inputProps: InputHTMLAttributes<HTMLInputElement | HTMLTextAreaElement>;
9
+ inputProps: InputHTMLAttributes<HTMLInputElement>;
10
10
  /** Props for the clear button. */
11
11
  clearButtonProps: AriaButtonProps;
12
+ /** Props for the searchfield's description element, if any. */
13
+ descriptionProps: HTMLAttributes<HTMLElement>;
14
+ /** Props for the searchfield's error message element, if any. */
15
+ errorMessageProps: HTMLAttributes<HTMLElement>;
12
16
  }
13
17
  /**
14
18
  * Provides the behavior and accessibility implementation for a search field.
@@ -16,6 +20,6 @@ interface SearchFieldAria {
16
20
  * @param state - State for the search field, as returned by `useSearchFieldState`.
17
21
  * @param inputRef - A ref to the input element.
18
22
  */
19
- export function useSearchField(props: AriaSearchFieldProps, state: SearchFieldState, inputRef: RefObject<HTMLInputElement | HTMLTextAreaElement>): SearchFieldAria;
23
+ export function useSearchField(props: AriaSearchFieldProps, state: SearchFieldState, inputRef: RefObject<HTMLInputElement>): SearchFieldAria;
20
24
 
21
25
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"mappings":"A;A;A;A;AAqBA;IACE,iEAAiE;IACjE,UAAU,EAAE,oBAAoB,gBAAgB,CAAC,CAAC;IAClD,mCAAmC;IACnC,UAAU,EAAE,oBAAoB,gBAAgB,GAAG,mBAAmB,CAAC,CAAC;IACxE,kCAAkC;IAClC,gBAAgB,EAAE,eAAe,CAAA;CAClC;AAED;A;A;A;A;GAKG;AACH,+BACE,KAAK,EAAE,oBAAoB,EAC3B,KAAK,EAAE,gBAAgB,EACvB,QAAQ,EAAE,UAAU,gBAAgB,GAAG,mBAAmB,CAAC,GAC1D,eAAe,CAoEjB","sources":["./packages/@react-aria/searchfield/src/packages/@react-aria/searchfield/src/useSearchField.ts","./packages/@react-aria/searchfield/src/packages/@react-aria/searchfield/src/index.ts"],"sourcesContent":[null,null],"names":[],"version":3,"file":"types.d.ts.map"}
1
+ {"mappings":"A;A;A;A;AAqBA;IACE,iEAAiE;IACjE,UAAU,EAAE,oBAAoB,gBAAgB,CAAC,CAAC;IAClD,mCAAmC;IACnC,UAAU,EAAE,oBAAoB,gBAAgB,CAAC,CAAC;IAClD,kCAAkC;IAClC,gBAAgB,EAAE,eAAe,CAAC;IAClC,+DAA+D;IAC/D,gBAAgB,EAAE,eAAe,WAAW,CAAC,CAAC;IAC9C,iEAAiE;IACjE,iBAAiB,EAAE,eAAe,WAAW,CAAC,CAAA;CAC/C;AAED;A;A;A;A;GAKG;AACH,+BACE,KAAK,EAAE,oBAAoB,EAC3B,KAAK,EAAE,gBAAgB,EACvB,QAAQ,EAAE,UAAU,gBAAgB,CAAC,GACpC,eAAe,CAwEjB","sources":["./packages/@react-aria/searchfield/src/packages/@react-aria/searchfield/src/useSearchField.ts","./packages/@react-aria/searchfield/src/packages/@react-aria/searchfield/src/index.ts"],"sourcesContent":[null,null],"names":[],"version":3,"file":"types.d.ts.map"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@react-aria/searchfield",
3
- "version": "3.1.3",
3
+ "version": "3.2.1",
4
4
  "description": "Spectrum UI components in React",
5
5
  "license": "Apache-2.0",
6
6
  "main": "dist/main.js",
@@ -18,14 +18,14 @@
18
18
  },
19
19
  "dependencies": {
20
20
  "@babel/runtime": "^7.6.2",
21
- "@react-aria/i18n": "^3.3.1",
22
- "@react-aria/interactions": "^3.4.0",
23
- "@react-aria/textfield": "^3.3.0",
24
- "@react-aria/utils": "^3.8.0",
25
- "@react-stately/searchfield": "^3.1.2",
26
- "@react-types/button": "^3.2.1",
27
- "@react-types/searchfield": "^3.1.1",
28
- "@react-types/shared": "^3.6.0"
21
+ "@react-aria/i18n": "^3.3.3",
22
+ "@react-aria/interactions": "^3.7.0",
23
+ "@react-aria/textfield": "^3.5.0",
24
+ "@react-aria/utils": "^3.10.0",
25
+ "@react-stately/searchfield": "^3.1.3",
26
+ "@react-types/button": "^3.4.1",
27
+ "@react-types/searchfield": "^3.1.2",
28
+ "@react-types/shared": "^3.10.0"
29
29
  },
30
30
  "peerDependencies": {
31
31
  "react": "^16.8.0 || ^17.0.0-rc.1"
@@ -33,5 +33,5 @@
33
33
  "publishConfig": {
34
34
  "access": "public"
35
35
  },
36
- "gitHead": "3aae08e7d8a75382bedcddac7c86107e40db9296"
36
+ "gitHead": "896eabe5521a0349a675c4773ed7629addd4b8c4"
37
37
  }
@@ -12,7 +12,7 @@
12
12
 
13
13
  import {AriaButtonProps} from '@react-types/button';
14
14
  import {AriaSearchFieldProps} from '@react-types/searchfield';
15
- import {InputHTMLAttributes, LabelHTMLAttributes, RefObject} from 'react';
15
+ import {HTMLAttributes, InputHTMLAttributes, LabelHTMLAttributes, RefObject} from 'react';
16
16
  // @ts-ignore
17
17
  import intlMessages from '../intl/*.json';
18
18
  import {SearchFieldState} from '@react-stately/searchfield';
@@ -23,9 +23,13 @@ interface SearchFieldAria {
23
23
  /** Props for the text field's visible label element (if any). */
24
24
  labelProps: LabelHTMLAttributes<HTMLLabelElement>,
25
25
  /** Props for the input element. */
26
- inputProps: InputHTMLAttributes<HTMLInputElement | HTMLTextAreaElement>,
26
+ inputProps: InputHTMLAttributes<HTMLInputElement>,
27
27
  /** Props for the clear button. */
28
- clearButtonProps: AriaButtonProps
28
+ clearButtonProps: AriaButtonProps,
29
+ /** Props for the searchfield's description element, if any. */
30
+ descriptionProps: HTMLAttributes<HTMLElement>,
31
+ /** Props for the searchfield's error message element, if any. */
32
+ errorMessageProps: HTMLAttributes<HTMLElement>
29
33
  }
30
34
 
31
35
  /**
@@ -37,7 +41,7 @@ interface SearchFieldAria {
37
41
  export function useSearchField(
38
42
  props: AriaSearchFieldProps,
39
43
  state: SearchFieldState,
40
- inputRef: RefObject<HTMLInputElement | HTMLTextAreaElement>
44
+ inputRef: RefObject<HTMLInputElement>
41
45
  ): SearchFieldAria {
42
46
  let formatMessage = useMessageFormatter(intlMessages);
43
47
  let {
@@ -84,7 +88,7 @@ export function useSearchField(
84
88
  inputRef.current.focus();
85
89
  };
86
90
 
87
- let {labelProps, inputProps} = useTextField({
91
+ let {labelProps, inputProps, descriptionProps, errorMessageProps} = useTextField({
88
92
  ...props,
89
93
  value: state.value,
90
94
  onChange: state.setValue,
@@ -102,8 +106,12 @@ export function useSearchField(
102
106
  clearButtonProps: {
103
107
  'aria-label': formatMessage('Clear search'),
104
108
  excludeFromTabOrder: true,
109
+ // @ts-ignore
110
+ preventFocusOnPress: true,
105
111
  onPress: onClearButtonClick,
106
112
  onPressStart
107
- }
113
+ },
114
+ descriptionProps,
115
+ errorMessageProps
108
116
  };
109
117
  }