@amboss/design-system 2.4.1 → 2.4.2
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/build/cjs/components/EntityTree/BaseEntityTree.d.ts +4 -2
- package/build/cjs/components/EntityTree/BaseEntityTree.js +1 -1
- package/build/cjs/components/EntityTree/types.d.ts +1 -1
- package/build/cjs/components/Form/Input/Input.d.ts +3 -0
- package/build/cjs/components/Form/Input/Input.js +1 -1
- package/build/cjs/components/Form/MaskedInput/MaskedInput.d.ts +1 -0
- package/build/cjs/components/Form/PasswordInput/PasswordInput.d.ts +3 -0
- package/build/cjs/components/Form/PasswordInput/PasswordInput.js +1 -1
- package/build/cjs/components/Form/SearchInput/SearchInput.d.ts +1 -1
- package/build/cjs/components/Form/SearchInput/SearchInput.js +1 -1
- package/build/cjs/components/Form/Select/BaseSelect.d.ts +1 -1
- package/build/cjs/components/Form/Select/BaseSelect.js +1 -1
- package/build/cjs/components/Form/Select/Select.d.ts +2 -1
- package/build/cjs/components/Form/Select/Select.js +1 -1
- package/build/esm/components/EntityTree/BaseEntityTree.d.ts +4 -2
- package/build/esm/components/EntityTree/BaseEntityTree.js +1 -1
- package/build/esm/components/EntityTree/types.d.ts +1 -1
- package/build/esm/components/Form/Input/Input.d.ts +3 -0
- package/build/esm/components/Form/Input/Input.js +1 -1
- package/build/esm/components/Form/MaskedInput/MaskedInput.d.ts +1 -0
- package/build/esm/components/Form/PasswordInput/PasswordInput.d.ts +3 -0
- package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
- package/build/esm/components/Form/SearchInput/SearchInput.d.ts +1 -1
- package/build/esm/components/Form/SearchInput/SearchInput.js +1 -1
- package/build/esm/components/Form/Select/BaseSelect.d.ts +1 -1
- package/build/esm/components/Form/Select/BaseSelect.js +1 -1
- package/build/esm/components/Form/Select/Select.d.ts +2 -1
- package/build/esm/components/Form/Select/Select.js +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useRef}from"react";import styled from"@emotion/styled";import{Icon}from"../../Icon/Icon";import{Box}from"../../Box/Box";import{PictogramButton}from"../../PictogramButton/PictogramButton";import{InputRaw}from"../Input/Input";import{FormField}from"../FormField/FormField";import iconSizesMap from"../../../web-tokens/_icon_sizes_map.json";let iconSizes=iconSizesMap.icons,StyledSearchInputContainer=styled("div",{target:"etiw1u20",label:"StyledSearchInputContainer"})(({theme})=>({position:"relative",backgroundColor:theme.values.color.searchInput.background.default,borderRadius:theme.variables.size.borderRadius.xs,height:theme.variables.size.spacing.xl,width:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIG9uQ2xlYXIgPSAoKSA9PiBudWxsLFxuICAuLi5yZXN0XG59OiBTZWFyY2hJbnB1dFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IGhhc1ZhbHVlID0gQm9vbGVhbih2YWx1ZSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2tDbGVhciA9IChlOiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PikgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBvbkNsZWFyKGUpO1xuICAgIGlucHV0UmVmLmN1cnJlbnQuZm9jdXMoKTtcbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxGb3JtRmllbGQgZGF0YS1kcy1pZD1cIlNlYXJjaElucHV0XCIgey4uLihyZXN0IGFzIEZvcm1GaWVsZFByb3BzKX0+XG4gICAgICA8U3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgICAgIDxCb3ggbFNwYWNlPVwieHNcIiBzcGFjZT1cInh4c1wiPlxuICAgICAgICAgIDxTdHlsZWRJbnB1dFdyYXAgaGFzVmFsdWU9e2hhc1ZhbHVlfT5cbiAgICAgICAgICAgIDxJbnB1dFJhd1xuICAgICAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17cmVzdC5kaXNhYmxlZH1cbiAgICAgICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICAgICAgcHJpdmF0ZVByb3BzPXtwcml2YXRlUHJvcHN9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3R5bGVkSW5wdXRXcmFwPlxuICAgICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICAgIDxJY29uIG5hbWU9XCJzZWFyY2hcIiBzaXplPVwic1wiIGNvbG9yPVwidGVydGlhcnlcIiAvPlxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAgIGlzSGlkZGVuPXshaGFzVmFsdWV9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICAgIDwvQm94PlxuICAgICAgPC9TdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZW1DIn0= */"),IconsContainer=styled("div",{target:"etiw1u21",label:"IconsContainer"})(()=>({display:"flex",alignItems:"center",justifyContent:"space-between","& > div":{lineHeight:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIG9uQ2xlYXIgPSAoKSA9PiBudWxsLFxuICAuLi5yZXN0XG59OiBTZWFyY2hJbnB1dFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IGhhc1ZhbHVlID0gQm9vbGVhbih2YWx1ZSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2tDbGVhciA9IChlOiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PikgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBvbkNsZWFyKGUpO1xuICAgIGlucHV0UmVmLmN1cnJlbnQuZm9jdXMoKTtcbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxGb3JtRmllbGQgZGF0YS1kcy1pZD1cIlNlYXJjaElucHV0XCIgey4uLihyZXN0IGFzIEZvcm1GaWVsZFByb3BzKX0+XG4gICAgICA8U3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgICAgIDxCb3ggbFNwYWNlPVwieHNcIiBzcGFjZT1cInh4c1wiPlxuICAgICAgICAgIDxTdHlsZWRJbnB1dFdyYXAgaGFzVmFsdWU9e2hhc1ZhbHVlfT5cbiAgICAgICAgICAgIDxJbnB1dFJhd1xuICAgICAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17cmVzdC5kaXNhYmxlZH1cbiAgICAgICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICAgICAgcHJpdmF0ZVByb3BzPXtwcml2YXRlUHJvcHN9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3R5bGVkSW5wdXRXcmFwPlxuICAgICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICAgIDxJY29uIG5hbWU9XCJzZWFyY2hcIiBzaXplPVwic1wiIGNvbG9yPVwidGVydGlhcnlcIiAvPlxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAgIGlzSGlkZGVuPXshaGFzVmFsdWV9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICAgIDwvQm94PlxuICAgICAgPC9TdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJ1QiJ9 */"),StyledInputWrap=styled("div",{target:"etiw1u22",label:"StyledInputWrap"})(({theme,hasValue})=>({position:"absolute",top:0,left:0,right:0,bottom:0,"& input":{backgroundColor:theme.values.color.background.transparent.default,lineHeight:theme.variables.size.lineHeight.xl,paddingTop:theme.variables.size.spacing.xxs,paddingBottom:theme.variables.size.spacing.xxs,paddingLeft:`calc(${theme.variables.size.spacing.s} + ${iconSizes.s})`,paddingRight:hasValue?theme.variables.size.spacing.xl:theme.variables.size.spacing.s,borderWidth:0,textOverflow:"ellipsis","&::placeholder":{color:theme.values.color.text.tertiary.default,fontStyle:"italic"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIG9uQ2xlYXIgPSAoKSA9PiBudWxsLFxuICAuLi5yZXN0XG59OiBTZWFyY2hJbnB1dFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IGhhc1ZhbHVlID0gQm9vbGVhbih2YWx1ZSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2tDbGVhciA9IChlOiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PikgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBvbkNsZWFyKGUpO1xuICAgIGlucHV0UmVmLmN1cnJlbnQuZm9jdXMoKTtcbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxGb3JtRmllbGQgZGF0YS1kcy1pZD1cIlNlYXJjaElucHV0XCIgey4uLihyZXN0IGFzIEZvcm1GaWVsZFByb3BzKX0+XG4gICAgICA8U3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgICAgIDxCb3ggbFNwYWNlPVwieHNcIiBzcGFjZT1cInh4c1wiPlxuICAgICAgICAgIDxTdHlsZWRJbnB1dFdyYXAgaGFzVmFsdWU9e2hhc1ZhbHVlfT5cbiAgICAgICAgICAgIDxJbnB1dFJhd1xuICAgICAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17cmVzdC5kaXNhYmxlZH1cbiAgICAgICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICAgICAgcHJpdmF0ZVByb3BzPXtwcml2YXRlUHJvcHN9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3R5bGVkSW5wdXRXcmFwPlxuICAgICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICAgIDxJY29uIG5hbWU9XCJzZWFyY2hcIiBzaXplPVwic1wiIGNvbG9yPVwidGVydGlhcnlcIiAvPlxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAgIGlzSGlkZGVuPXshaGFzVmFsdWV9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICAgIDwvQm94PlxuICAgICAgPC9TdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUN3QiJ9 */"),StyledClearButton=styled(PictogramButton,{target:"etiw1u23",label:"StyledClearButton"})(({isHidden})=>({position:"relative",zIndex:1,visibility:isHidden?"hidden":"visible"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIG9uQ2xlYXIgPSAoKSA9PiBudWxsLFxuICAuLi5yZXN0XG59OiBTZWFyY2hJbnB1dFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IGhhc1ZhbHVlID0gQm9vbGVhbih2YWx1ZSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2tDbGVhciA9IChlOiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PikgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBvbkNsZWFyKGUpO1xuICAgIGlucHV0UmVmLmN1cnJlbnQuZm9jdXMoKTtcbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxGb3JtRmllbGQgZGF0YS1kcy1pZD1cIlNlYXJjaElucHV0XCIgey4uLihyZXN0IGFzIEZvcm1GaWVsZFByb3BzKX0+XG4gICAgICA8U3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXI+XG4gICAgICAgIDxCb3ggbFNwYWNlPVwieHNcIiBzcGFjZT1cInh4c1wiPlxuICAgICAgICAgIDxTdHlsZWRJbnB1dFdyYXAgaGFzVmFsdWU9e2hhc1ZhbHVlfT5cbiAgICAgICAgICAgIDxJbnB1dFJhd1xuICAgICAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgICAgbmFtZT17bmFtZX1cbiAgICAgICAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17cmVzdC5kaXNhYmxlZH1cbiAgICAgICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICAgICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgICAgICAgICB0YWJJbmRleD17dGFiSW5kZXh9XG4gICAgICAgICAgICAgIGFyZWFMYWJlbD17YXJlYUxhYmVsfVxuICAgICAgICAgICAgICBhdXRvQ29tcGxldGU9e2F1dG9Db21wbGV0ZX1cbiAgICAgICAgICAgICAgcHJpdmF0ZVByb3BzPXtwcml2YXRlUHJvcHN9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3R5bGVkSW5wdXRXcmFwPlxuICAgICAgICAgIDxJY29uc0NvbnRhaW5lcj5cbiAgICAgICAgICAgIDxJY29uIG5hbWU9XCJzZWFyY2hcIiBzaXplPVwic1wiIGNvbG9yPVwidGVydGlhcnlcIiAvPlxuICAgICAgICAgICAgPFN0eWxlZENsZWFyQnV0dG9uXG4gICAgICAgICAgICAgIGljb249XCJ4XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrQ2xlYXJ9XG4gICAgICAgICAgICAgIGlzSGlkZGVuPXshaGFzVmFsdWV9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvSWNvbnNDb250YWluZXI+XG4gICAgICAgIDwvQm94PlxuICAgICAgPC9TdHlsZWRTZWFyY2hJbnB1dENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUUwQiJ9 */");export const SearchInput=({name,value,placeholder,hasError=!1,autoComplete="on",privateProps={},tabIndex,areaLabel,onChange,onClick,onBlur,onFocus,onClear=()=>null,...rest})=>{let inputRef=useRef(null),hasValue=!!value;return React.createElement(FormField,{"data-ds-id":"SearchInput",...rest},React.createElement(StyledSearchInputContainer,null,React.createElement(Box,{lSpace:"xs",space:"xxs"},React.createElement(StyledInputWrap,{hasValue:hasValue},React.createElement(InputRaw,{ref:inputRef,type:"text",value:value,name:name,placeholder:placeholder,disabled:rest.disabled,hasError:hasError,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,privateProps:privateProps})),React.createElement(IconsContainer,null,React.createElement(Icon,{name:"search",size:"s",color:"tertiary"}),React.createElement(StyledClearButton,{icon:"x",size:"xs",color:"tertiary",onClick:e=>{e.preventDefault(),onClear(e),inputRef.current.focus()},isHidden:!hasValue})))))};
|
|
1
|
+
import React,{useRef}from"react";import styled from"@emotion/styled";import{Icon}from"../../Icon/Icon";import{Box}from"../../Box/Box";import{PictogramButton}from"../../PictogramButton/PictogramButton";import{InputRaw}from"../Input/Input";import{FormField}from"../FormField/FormField";import iconSizesMap from"../../../web-tokens/_icon_sizes_map.json";let iconSizes=iconSizesMap.icons,StyledSearchInputContainer=styled("div",{target:"e9bv3mx0",label:"StyledSearchInputContainer"})(({theme})=>({position:"relative",backgroundColor:theme.values.color.searchInput.background.default,borderRadius:theme.variables.size.borderRadius.xs,height:theme.variables.size.spacing.xl,width:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8Qm94IGxTcGFjZT1cInhzXCIgc3BhY2U9XCJ4eHNcIj5cbiAgICAgICAgICA8U3R5bGVkSW5wdXRXcmFwIGhhc1ZhbHVlPXtoYXNWYWx1ZX0+XG4gICAgICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgYXJlYUxhYmVsPXthcmVhTGFiZWx9XG4gICAgICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1N0eWxlZElucHV0V3JhcD5cbiAgICAgICAgICA8SWNvbnNDb250YWluZXI+XG4gICAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgICAgaXNIaWRkZW49eyFoYXNWYWx1ZSB8fCByZWFkT25seX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlbUMifQ== */"),IconsContainer=styled("div",{target:"e9bv3mx1",label:"IconsContainer"})(()=>({display:"flex",alignItems:"center",justifyContent:"space-between","& > div":{lineHeight:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8Qm94IGxTcGFjZT1cInhzXCIgc3BhY2U9XCJ4eHNcIj5cbiAgICAgICAgICA8U3R5bGVkSW5wdXRXcmFwIGhhc1ZhbHVlPXtoYXNWYWx1ZX0+XG4gICAgICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgYXJlYUxhYmVsPXthcmVhTGFiZWx9XG4gICAgICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1N0eWxlZElucHV0V3JhcD5cbiAgICAgICAgICA8SWNvbnNDb250YWluZXI+XG4gICAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgICAgaXNIaWRkZW49eyFoYXNWYWx1ZSB8fCByZWFkT25seX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQnVCIn0= */"),StyledInputWrap=styled("div",{target:"e9bv3mx2",label:"StyledInputWrap"})(({theme,hasValue})=>({position:"absolute",top:0,left:0,right:0,bottom:0,"& input":{backgroundColor:theme.values.color.background.transparent.default,lineHeight:theme.variables.size.lineHeight.xl,paddingTop:theme.variables.size.spacing.xxs,paddingBottom:theme.variables.size.spacing.xxs,paddingLeft:`calc(${theme.variables.size.spacing.s} + ${iconSizes.s})`,paddingRight:hasValue?theme.variables.size.spacing.xl:theme.variables.size.spacing.s,borderWidth:0,textOverflow:"ellipsis","&::placeholder":{color:theme.values.color.text.tertiary.default,fontStyle:"italic"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8Qm94IGxTcGFjZT1cInhzXCIgc3BhY2U9XCJ4eHNcIj5cbiAgICAgICAgICA8U3R5bGVkSW5wdXRXcmFwIGhhc1ZhbHVlPXtoYXNWYWx1ZX0+XG4gICAgICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgYXJlYUxhYmVsPXthcmVhTGFiZWx9XG4gICAgICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1N0eWxlZElucHV0V3JhcD5cbiAgICAgICAgICA8SWNvbnNDb250YWluZXI+XG4gICAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgICAgaXNIaWRkZW49eyFoYXNWYWx1ZSB8fCByZWFkT25seX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQ3dCIn0= */"),StyledClearButton=styled(PictogramButton,{target:"e9bv3mx3",label:"StyledClearButton"})(({isHidden})=>({position:"relative",zIndex:1,visibility:isHidden?"hidden":"visible"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWFyY2hJbnB1dC9TZWFyY2hJbnB1dC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0Zvcm0vU2VhcmNoSW5wdXQvU2VhcmNoSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0LCB7IHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uLy4uL0JveC9Cb3hcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi8uLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgdHlwZSB7IElucHV0UHJvcHMgfSBmcm9tIFwiLi4vSW5wdXQvSW5wdXRcIjtcbmltcG9ydCB7IElucHV0UmF3IH0gZnJvbSBcIi4uL0lucHV0L0lucHV0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1GaWVsZFByb3BzIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IEZvcm1GaWVsZCB9IGZyb20gXCIuLi9Gb3JtRmllbGQvRm9ybUZpZWxkXCI7XG5pbXBvcnQgaWNvblNpemVzTWFwIGZyb20gXCIuLi8uLi8uLi93ZWItdG9rZW5zL19pY29uX3NpemVzX21hcC5qc29uXCI7XG5cbmNvbnN0IGljb25TaXplcyA9IGljb25TaXplc01hcC5pY29ucztcblxuY29uc3QgU3R5bGVkU2VhcmNoSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnNlYXJjaElucHV0LmJhY2tncm91bmQuZGVmYXVsdCxcbiAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54bCxcbiAgd2lkdGg6IFwiMTAwJVwiLFxufSkpO1xuXG50eXBlIFN0eWxlZElucHV0V3JhcFByb3BzID0ge1xuICBoYXNWYWx1ZT86IGJvb2xlYW47XG59O1xuY29uc3QgSWNvbnNDb250YWluZXIgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG5cbiAgXCImID4gZGl2XCI6IHtcbiAgICBsaW5lSGVpZ2h0OiAwLFxuICB9LFxufSkpO1xuY29uc3QgU3R5bGVkSW5wdXRXcmFwID0gc3R5bGVkLmRpdjxTdHlsZWRJbnB1dFdyYXBQcm9wcz4oXG4gICh7IHRoZW1lLCBoYXNWYWx1ZSB9KSA9PiAoe1xuICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgdG9wOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIFwiJiBpbnB1dFwiOiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBsaW5lSGVpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5saW5lSGVpZ2h0LnhsLFxuICAgICAgcGFkZGluZ1RvcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cyxcbiAgICAgIHBhZGRpbmdMZWZ0OiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc30gKyAke2ljb25TaXplcy5zfSlgLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBoYXNWYWx1ZVxuICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueGxcbiAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnMsXG4gICAgICBib3JkZXJXaWR0aDogMCxcbiAgICAgIHRleHRPdmVyZmxvdzogXCJlbGxpcHNpc1wiLFxuICAgICAgXCImOjpwbGFjZWhvbGRlclwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC50ZXJ0aWFyeS5kZWZhdWx0LFxuICAgICAgICBmb250U3R5bGU6IFwiaXRhbGljXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENsZWFyQnV0dG9uUHJvcHMgPSB7XG4gIGlzSGlkZGVuPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZENsZWFyQnV0dG9uID0gc3R5bGVkKFBpY3RvZ3JhbUJ1dHRvbik8U3R5bGVkQ2xlYXJCdXR0b25Qcm9wcz4oXG4gICh7IGlzSGlkZGVuIH0pID0+ICh7XG4gICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB6SW5kZXg6IDEsXG4gICAgdmlzaWJpbGl0eTogaXNIaWRkZW4gPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCIsXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBTZWFyY2hJbnB1dFByb3BzID0gT21pdDxJbnB1dFByb3BzLCBcInR5cGVcIiB8IFwiaWNvblwiPiAmIHtcbiAgLyoqIENsZWFycyB0aGUgaW5wdXQuICovXG4gIG9uQ2xlYXI/OiAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgU2VhcmNoSW5wdXQgPSAoe1xuICBuYW1lLFxuICB2YWx1ZSxcbiAgcGxhY2Vob2xkZXIsXG4gIGhhc0Vycm9yID0gZmFsc2UsXG4gIGF1dG9Db21wbGV0ZSA9IFwib25cIixcbiAgcHJpdmF0ZVByb3BzID0ge30sXG4gIHRhYkluZGV4LFxuICBhcmVhTGFiZWwsXG4gIG9uQ2hhbmdlLFxuICBvbkNsaWNrLFxuICBvbkJsdXIsXG4gIG9uRm9jdXMsXG4gIHJlYWRPbmx5LFxuICBvbkNsZWFyID0gKCkgPT4gbnVsbCxcbiAgLi4ucmVzdFxufTogU2VhcmNoSW5wdXRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gIGNvbnN0IGlucHV0UmVmID0gdXNlUmVmPEhUTUxJbnB1dEVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNWYWx1ZSA9IEJvb2xlYW4odmFsdWUpO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrQ2xlYXIgPSAoZTogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgb25DbGVhcihlKTtcbiAgICBpbnB1dFJlZi5jdXJyZW50LmZvY3VzKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkIGRhdGEtZHMtaWQ9XCJTZWFyY2hJbnB1dFwiIHsuLi4ocmVzdCBhcyBGb3JtRmllbGRQcm9wcyl9PlxuICAgICAgPFN0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgICAgICA8Qm94IGxTcGFjZT1cInhzXCIgc3BhY2U9XCJ4eHNcIj5cbiAgICAgICAgICA8U3R5bGVkSW5wdXRXcmFwIGhhc1ZhbHVlPXtoYXNWYWx1ZX0+XG4gICAgICAgICAgICA8SW5wdXRSYXdcbiAgICAgICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgICAgIHBsYWNlaG9sZGVyPXshcmVhZE9ubHkgJiYgcGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXtyZXN0LmRpc2FibGVkfVxuICAgICAgICAgICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICAgICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgICAgICAgIHRhYkluZGV4PXt0YWJJbmRleH1cbiAgICAgICAgICAgICAgYXJlYUxhYmVsPXthcmVhTGFiZWx9XG4gICAgICAgICAgICAgIGF1dG9Db21wbGV0ZT17YXV0b0NvbXBsZXRlfVxuICAgICAgICAgICAgICBwcml2YXRlUHJvcHM9e3ByaXZhdGVQcm9wc31cbiAgICAgICAgICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1N0eWxlZElucHV0V3JhcD5cbiAgICAgICAgICA8SWNvbnNDb250YWluZXI+XG4gICAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgICBuYW1lPVwic2VhcmNoXCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj17cmVhZE9ubHkgPyBcInF1YXRlcm5hcnlcIiA6IFwidGVydGlhcnlcIn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8U3R5bGVkQ2xlYXJCdXR0b25cbiAgICAgICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2tDbGVhcn1cbiAgICAgICAgICAgICAgaXNIaWRkZW49eyFoYXNWYWx1ZSB8fCByZWFkT25seX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9JY29uc0NvbnRhaW5lcj5cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L1N0eWxlZFNlYXJjaElucHV0Q29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRTBCIn0= */");export const SearchInput=({name,value,placeholder,hasError=!1,autoComplete="on",privateProps={},tabIndex,areaLabel,onChange,onClick,onBlur,onFocus,readOnly,onClear=()=>null,...rest})=>{let inputRef=useRef(null),hasValue=!!value;return React.createElement(FormField,{"data-ds-id":"SearchInput",...rest},React.createElement(StyledSearchInputContainer,null,React.createElement(Box,{lSpace:"xs",space:"xxs"},React.createElement(StyledInputWrap,{hasValue:hasValue},React.createElement(InputRaw,{ref:inputRef,type:"text",value:value,name:name,placeholder:!readOnly&&placeholder,disabled:rest.disabled,hasError:hasError,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,privateProps:privateProps,readOnly:readOnly})),React.createElement(IconsContainer,null,React.createElement(Icon,{name:"search",size:"s",color:readOnly?"quaternary":"tertiary"}),React.createElement(StyledClearButton,{icon:"x",size:"xs",color:"tertiary",onClick:e=>{e.preventDefault(),onClear(e),inputRef.current.focus()},isHidden:!hasValue||readOnly})))))};
|
|
@@ -5,5 +5,5 @@ type BaseSelectProps = CommonSelectProps & Pick<FormFieldProps, "label"> & {
|
|
|
5
5
|
value: string;
|
|
6
6
|
onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void;
|
|
7
7
|
};
|
|
8
|
-
export declare const BaseSelect: ({ options, name, value, placeholder, emptyStateMessage, hasError, filterMethod, onChange, onBlur, onFocus, maxHeight, autoComplete, disabled, label, optionsListWidth, portalContainer, }: BaseSelectProps) => React.ReactElement;
|
|
8
|
+
export declare const BaseSelect: ({ options, name, value, placeholder, emptyStateMessage, hasError, filterMethod, onChange, onBlur, onFocus, maxHeight, autoComplete, disabled, label, optionsListWidth, portalContainer, readOnly, }: BaseSelectProps) => React.ReactElement;
|
|
9
9
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useState,useRef,useMemo,useEffect,useCallback}from"react";import styled from"@emotion/styled";import{useKeyboard}from"../../../shared/useKeyboard";import{Input,InputRaw}from"../Input/Input";import{StyledContainer}from"./StyledSelectComponents";import{OptionsList}from"./OptionsList";let StyledInputWrap=styled("div",{target:"e1fmoaui0",label:"StyledInputWrap"})(()=>({zIndex:0,position:"absolute",pointerEvents:"none",width:"100%",bottom:0,left:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/BaseSelect.tsx","sources":["src/components/Form/Select/BaseSelect.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CommonSelectProps, SelectOption } from \"./Select\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { StyledContainer } from \"./StyledSelectComponents\";\nimport { OptionsList } from \"./OptionsList\";\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype BaseSelectProps = CommonSelectProps &\n  Pick<FormFieldProps, \"label\"> & {\n    value: string;\n    onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void;\n  };\n\nexport const BaseSelect = ({\n  options,\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod,\n  onChange = () => {},\n  onBlur,\n  onFocus,\n  maxHeight,\n  autoComplete,\n  disabled,\n  label,\n  optionsListWidth,\n  portalContainer,\n}: BaseSelectProps): React.ReactElement => {\n  const [isOpen, setIsOpen] = useState(false);\n\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const handlePreselectedIndexChange = (index: number) => {\n    setPreselectedIndex(index);\n  };\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <StyledContainer\n      onBlur={() => {\n        closeDropdown(true);\n      }}\n    >\n      <div style={{ zIndex: 1 }}>\n        <InputRaw\n          areaLabel={label}\n          name={`${name}-innerInput`}\n          value={innerValue}\n          privateProps={{ isTransparent: !(isOpen && innerValue) }}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          disabled={disabled}\n          onFocus={() => {\n            setIsOpen(true);\n            onFocus();\n          }}\n          onClick={() => {\n            setIsOpen(true);\n          }}\n          onChange={(e) => {\n            if (e.currentTarget.value) {\n              setIsOpen(true);\n            }\n            setInnerValue(e.currentTarget.value);\n          }}\n          ref={innerInputRef}\n          autoComplete={autoComplete}\n        />\n      </div>\n\n      <StyledInputWrap>\n        <Input\n          name={name}\n          value={displayValue}\n          onChange={() => null}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          placeholder={placeholder}\n          tabIndex={-1}\n          hasError={hasError}\n          autoComplete=\"off\"\n        />\n      </StyledInputWrap>\n\n      <OptionsList\n        isOpen={isOpen}\n        filteredOptions={filteredOptions}\n        innerInputRef={innerInputRef}\n        onCloseDropdown={closeDropdown}\n        portalContainer={portalContainer}\n        selectedIndex={preselectedIndex}\n        onSelectedIndexChange={handlePreselectedIndexChange}\n        forceChangeFakeSelect={forceChangeFakeSelect}\n        value={value}\n        emptyStateMessage={emptyStateMessage}\n        disabled={disabled}\n        maxHeight={maxHeight}\n        optionsListWidth={optionsListWidth}\n      />\n\n      <HiddenSelectInput\n        onChange={onChange}\n        value={fakeSelectedOption.value}\n        ref={fakeSelectRef}\n        autoComplete=\"off\"\n      >\n        <option value={fakeSelectedOption.value}>\n          {fakeSelectedOption.label}\n        </option>\n      </HiddenSelectInput>\n    </StyledContainer>\n  );\n};\n"],"names":[],"mappings":"AAiBwB"} */"),HiddenSelectInput=styled("select",{target:"e1fmoaui1",label:"HiddenSelectInput"})(()=>({display:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/BaseSelect.tsx","sources":["src/components/Form/Select/BaseSelect.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CommonSelectProps, SelectOption } from \"./Select\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { StyledContainer } from \"./StyledSelectComponents\";\nimport { OptionsList } from \"./OptionsList\";\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype BaseSelectProps = CommonSelectProps &\n  Pick<FormFieldProps, \"label\"> & {\n    value: string;\n    onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void;\n  };\n\nexport const BaseSelect = ({\n  options,\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod,\n  onChange = () => {},\n  onBlur,\n  onFocus,\n  maxHeight,\n  autoComplete,\n  disabled,\n  label,\n  optionsListWidth,\n  portalContainer,\n}: BaseSelectProps): React.ReactElement => {\n  const [isOpen, setIsOpen] = useState(false);\n\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const handlePreselectedIndexChange = (index: number) => {\n    setPreselectedIndex(index);\n  };\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <StyledContainer\n      onBlur={() => {\n        closeDropdown(true);\n      }}\n    >\n      <div style={{ zIndex: 1 }}>\n        <InputRaw\n          areaLabel={label}\n          name={`${name}-innerInput`}\n          value={innerValue}\n          privateProps={{ isTransparent: !(isOpen && innerValue) }}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          disabled={disabled}\n          onFocus={() => {\n            setIsOpen(true);\n            onFocus();\n          }}\n          onClick={() => {\n            setIsOpen(true);\n          }}\n          onChange={(e) => {\n            if (e.currentTarget.value) {\n              setIsOpen(true);\n            }\n            setInnerValue(e.currentTarget.value);\n          }}\n          ref={innerInputRef}\n          autoComplete={autoComplete}\n        />\n      </div>\n\n      <StyledInputWrap>\n        <Input\n          name={name}\n          value={displayValue}\n          onChange={() => null}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          placeholder={placeholder}\n          tabIndex={-1}\n          hasError={hasError}\n          autoComplete=\"off\"\n        />\n      </StyledInputWrap>\n\n      <OptionsList\n        isOpen={isOpen}\n        filteredOptions={filteredOptions}\n        innerInputRef={innerInputRef}\n        onCloseDropdown={closeDropdown}\n        portalContainer={portalContainer}\n        selectedIndex={preselectedIndex}\n        onSelectedIndexChange={handlePreselectedIndexChange}\n        forceChangeFakeSelect={forceChangeFakeSelect}\n        value={value}\n        emptyStateMessage={emptyStateMessage}\n        disabled={disabled}\n        maxHeight={maxHeight}\n        optionsListWidth={optionsListWidth}\n      />\n\n      <HiddenSelectInput\n        onChange={onChange}\n        value={fakeSelectedOption.value}\n        ref={fakeSelectRef}\n        autoComplete=\"off\"\n      >\n        <option value={fakeSelectedOption.value}>\n          {fakeSelectedOption.label}\n        </option>\n      </HiddenSelectInput>\n    </StyledContainer>\n  );\n};\n"],"names":[],"mappings":"AA0B0B"} */");export const BaseSelect=({options,name,value,placeholder,emptyStateMessage,hasError,filterMethod,onChange=()=>{},onBlur,onFocus,maxHeight,autoComplete,disabled,label,optionsListWidth,portalContainer})=>{let[isOpen,setIsOpen]=useState(!1),[innerValue,setInnerValue]=useState(""),[preselectedIndex,setPreselectedIndex]=useState(-1),initialValueOption=useMemo(()=>options.find(option=>option.value===value)||{value:"",label:""},[options,value]),[fakeSelectedOption,setFakeSelectedOption]=useState(initialValueOption),fakeSelectRef=useRef(null),innerInputRef=useRef(null),currentValueRef=useRef(value);currentValueRef.current=value;let forceChangeFakeSelect=useCallback(selectedOption=>{fakeSelectedOption.value!==selectedOption.value&&setFakeSelectedOption(selectedOption)},[fakeSelectedOption]),closeDropdown=useCallback((noSelect=!1)=>{if(setIsOpen(!1),!noSelect){let selectedOption=options.find(option=>option.label.toLowerCase().trim()===innerValue.toLowerCase().trim());selectedOption&&forceChangeFakeSelect(selectedOption)}setInnerValue(""),setPreselectedIndex(-1),onBlur()},[onBlur,forceChangeFakeSelect,innerValue,options]);useEffect(()=>{fakeSelectRef.current&¤tValueRef.current!==fakeSelectedOption.value&&fakeSelectRef.current.dispatchEvent(new Event("change",{bubbles:!0}))},[fakeSelectedOption,fakeSelectRef,currentValueRef]),useEffect(()=>{forceChangeFakeSelect(initialValueOption)},[initialValueOption]);let filteredOptions=useMemo(()=>innerValue?options.filter(option=>filterMethod(option,innerValue)):options,[options,filterMethod,innerValue]),displayValue=useMemo(()=>options.some(option=>option.value===value)?options.find(option=>option.value===value).label:"",[value,options]);return useEffect(()=>{setPreselectedIndex(-1)},[filteredOptions]),useKeyboard({"ArrowUp ArrowDown":()=>{setIsOpen(!0)}},innerInputRef,!isOpen&&!disabled),React.createElement(StyledContainer,{onBlur:()=>{closeDropdown(!0)}},React.createElement("div",{style:{zIndex:1}},React.createElement(InputRaw,{areaLabel:label,name:`${name}-innerInput`,value:innerValue,privateProps:{isTransparent:!(isOpen&&innerValue)},icon:isOpen?"chevron-up":"chevron-down",disabled:disabled,onFocus:()=>{setIsOpen(!0),onFocus()},onClick:()=>{setIsOpen(!0)},onChange:e=>{e.currentTarget.value&&setIsOpen(!0),setInnerValue(e.currentTarget.value)},ref:innerInputRef,autoComplete:autoComplete})),React.createElement(StyledInputWrap,null,React.createElement(Input,{name:name,value:displayValue,onChange:()=>null,icon:isOpen?"chevron-up":"chevron-down",placeholder:placeholder,tabIndex:-1,hasError:hasError,autoComplete:"off"})),React.createElement(OptionsList,{isOpen:isOpen,filteredOptions:filteredOptions,innerInputRef:innerInputRef,onCloseDropdown:closeDropdown,portalContainer:portalContainer,selectedIndex:preselectedIndex,onSelectedIndexChange:index=>{setPreselectedIndex(index)},forceChangeFakeSelect:forceChangeFakeSelect,value:value,emptyStateMessage:emptyStateMessage,disabled:disabled,maxHeight:maxHeight,optionsListWidth:optionsListWidth}),React.createElement(HiddenSelectInput,{onChange:onChange,value:fakeSelectedOption.value,ref:fakeSelectRef,autoComplete:"off"},React.createElement("option",{value:fakeSelectedOption.value},fakeSelectedOption.label)))};
|
|
1
|
+
import React,{useState,useRef,useMemo,useEffect,useCallback}from"react";import styled from"@emotion/styled";import{useKeyboard}from"../../../shared/useKeyboard";import{Input,InputRaw}from"../Input/Input";import{StyledContainer}from"./StyledSelectComponents";import{OptionsList}from"./OptionsList";let StyledInputWrap=styled("div",{target:"e18ja3960",label:"StyledInputWrap"})(()=>({zIndex:0,position:"absolute",pointerEvents:"none",width:"100%",bottom:0,left:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/BaseSelect.tsx","sources":["src/components/Form/Select/BaseSelect.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CommonSelectProps, SelectOption } from \"./Select\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { StyledContainer } from \"./StyledSelectComponents\";\nimport { OptionsList } from \"./OptionsList\";\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype BaseSelectProps = CommonSelectProps &\n  Pick<FormFieldProps, \"label\"> & {\n    value: string;\n    onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void;\n  };\n\nexport const BaseSelect = ({\n  options,\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod,\n  onChange = () => {},\n  onBlur,\n  onFocus,\n  maxHeight,\n  autoComplete,\n  disabled,\n  label,\n  optionsListWidth,\n  portalContainer,\n  readOnly,\n}: BaseSelectProps): React.ReactElement => {\n  const [isOpen, setIsOpen] = useState(false);\n\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const handlePreselectedIndexChange = (index: number) => {\n    setPreselectedIndex(index);\n  };\n\n  const handleOpenDropdown = useCallback(() => {\n    if (!readOnly) setIsOpen(true);\n  }, [readOnly, setIsOpen]);\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        handleOpenDropdown();\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled && !readOnly\n  );\n\n  return (\n    <StyledContainer\n      onBlur={() => {\n        closeDropdown(true);\n      }}\n    >\n      <div style={{ zIndex: 1 }}>\n        <InputRaw\n          areaLabel={label}\n          name={`${name}-innerInput`}\n          value={innerValue}\n          privateProps={{ isTransparent: !(isOpen && innerValue) || readOnly }}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          disabled={disabled}\n          readOnly={readOnly}\n          onFocus={() => {\n            handleOpenDropdown();\n            onFocus();\n          }}\n          onClick={handleOpenDropdown}\n          onChange={(e) => {\n            if (e.currentTarget.value) {\n              handleOpenDropdown();\n            }\n            setInnerValue(e.currentTarget.value);\n          }}\n          ref={innerInputRef}\n          autoComplete={autoComplete}\n        />\n      </div>\n\n      <StyledInputWrap>\n        <Input\n          name={name}\n          value={displayValue}\n          onChange={() => null}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          placeholder={placeholder}\n          tabIndex={-1}\n          hasError={hasError}\n          autoComplete=\"off\"\n          readOnly={readOnly}\n        />\n      </StyledInputWrap>\n\n      <OptionsList\n        isOpen={isOpen}\n        filteredOptions={filteredOptions}\n        innerInputRef={innerInputRef}\n        onCloseDropdown={closeDropdown}\n        portalContainer={portalContainer}\n        selectedIndex={preselectedIndex}\n        onSelectedIndexChange={handlePreselectedIndexChange}\n        forceChangeFakeSelect={forceChangeFakeSelect}\n        value={value}\n        emptyStateMessage={emptyStateMessage}\n        disabled={disabled}\n        maxHeight={maxHeight}\n        optionsListWidth={optionsListWidth}\n      />\n\n      <HiddenSelectInput\n        onChange={onChange}\n        value={fakeSelectedOption.value}\n        ref={fakeSelectRef}\n        autoComplete=\"off\"\n      >\n        <option value={fakeSelectedOption.value}>\n          {fakeSelectedOption.label}\n        </option>\n      </HiddenSelectInput>\n    </StyledContainer>\n  );\n};\n"],"names":[],"mappings":"AAiBwB"} */"),HiddenSelectInput=styled("select",{target:"e18ja3961",label:"HiddenSelectInput"})(()=>({display:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Select/BaseSelect.tsx","sources":["src/components/Form/Select/BaseSelect.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CommonSelectProps, SelectOption } from \"./Select\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { StyledContainer } from \"./StyledSelectComponents\";\nimport { OptionsList } from \"./OptionsList\";\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype BaseSelectProps = CommonSelectProps &\n  Pick<FormFieldProps, \"label\"> & {\n    value: string;\n    onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void;\n  };\n\nexport const BaseSelect = ({\n  options,\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod,\n  onChange = () => {},\n  onBlur,\n  onFocus,\n  maxHeight,\n  autoComplete,\n  disabled,\n  label,\n  optionsListWidth,\n  portalContainer,\n  readOnly,\n}: BaseSelectProps): React.ReactElement => {\n  const [isOpen, setIsOpen] = useState(false);\n\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const handlePreselectedIndexChange = (index: number) => {\n    setPreselectedIndex(index);\n  };\n\n  const handleOpenDropdown = useCallback(() => {\n    if (!readOnly) setIsOpen(true);\n  }, [readOnly, setIsOpen]);\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        handleOpenDropdown();\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled && !readOnly\n  );\n\n  return (\n    <StyledContainer\n      onBlur={() => {\n        closeDropdown(true);\n      }}\n    >\n      <div style={{ zIndex: 1 }}>\n        <InputRaw\n          areaLabel={label}\n          name={`${name}-innerInput`}\n          value={innerValue}\n          privateProps={{ isTransparent: !(isOpen && innerValue) || readOnly }}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          disabled={disabled}\n          readOnly={readOnly}\n          onFocus={() => {\n            handleOpenDropdown();\n            onFocus();\n          }}\n          onClick={handleOpenDropdown}\n          onChange={(e) => {\n            if (e.currentTarget.value) {\n              handleOpenDropdown();\n            }\n            setInnerValue(e.currentTarget.value);\n          }}\n          ref={innerInputRef}\n          autoComplete={autoComplete}\n        />\n      </div>\n\n      <StyledInputWrap>\n        <Input\n          name={name}\n          value={displayValue}\n          onChange={() => null}\n          icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n          placeholder={placeholder}\n          tabIndex={-1}\n          hasError={hasError}\n          autoComplete=\"off\"\n          readOnly={readOnly}\n        />\n      </StyledInputWrap>\n\n      <OptionsList\n        isOpen={isOpen}\n        filteredOptions={filteredOptions}\n        innerInputRef={innerInputRef}\n        onCloseDropdown={closeDropdown}\n        portalContainer={portalContainer}\n        selectedIndex={preselectedIndex}\n        onSelectedIndexChange={handlePreselectedIndexChange}\n        forceChangeFakeSelect={forceChangeFakeSelect}\n        value={value}\n        emptyStateMessage={emptyStateMessage}\n        disabled={disabled}\n        maxHeight={maxHeight}\n        optionsListWidth={optionsListWidth}\n      />\n\n      <HiddenSelectInput\n        onChange={onChange}\n        value={fakeSelectedOption.value}\n        ref={fakeSelectRef}\n        autoComplete=\"off\"\n      >\n        <option value={fakeSelectedOption.value}>\n          {fakeSelectedOption.label}\n        </option>\n      </HiddenSelectInput>\n    </StyledContainer>\n  );\n};\n"],"names":[],"mappings":"AA0B0B"} */");export const BaseSelect=({options,name,value,placeholder,emptyStateMessage,hasError,filterMethod,onChange=()=>{},onBlur,onFocus,maxHeight,autoComplete,disabled,label,optionsListWidth,portalContainer,readOnly})=>{let[isOpen,setIsOpen]=useState(!1),[innerValue,setInnerValue]=useState(""),[preselectedIndex,setPreselectedIndex]=useState(-1),initialValueOption=useMemo(()=>options.find(option=>option.value===value)||{value:"",label:""},[options,value]),[fakeSelectedOption,setFakeSelectedOption]=useState(initialValueOption),fakeSelectRef=useRef(null),innerInputRef=useRef(null),currentValueRef=useRef(value);currentValueRef.current=value;let forceChangeFakeSelect=useCallback(selectedOption=>{fakeSelectedOption.value!==selectedOption.value&&setFakeSelectedOption(selectedOption)},[fakeSelectedOption]),handleOpenDropdown=useCallback(()=>{readOnly||setIsOpen(!0)},[readOnly,setIsOpen]),closeDropdown=useCallback((noSelect=!1)=>{if(setIsOpen(!1),!noSelect){let selectedOption=options.find(option=>option.label.toLowerCase().trim()===innerValue.toLowerCase().trim());selectedOption&&forceChangeFakeSelect(selectedOption)}setInnerValue(""),setPreselectedIndex(-1),onBlur()},[onBlur,forceChangeFakeSelect,innerValue,options]);useEffect(()=>{fakeSelectRef.current&¤tValueRef.current!==fakeSelectedOption.value&&fakeSelectRef.current.dispatchEvent(new Event("change",{bubbles:!0}))},[fakeSelectedOption,fakeSelectRef,currentValueRef]),useEffect(()=>{forceChangeFakeSelect(initialValueOption)},[initialValueOption]);let filteredOptions=useMemo(()=>innerValue?options.filter(option=>filterMethod(option,innerValue)):options,[options,filterMethod,innerValue]),displayValue=useMemo(()=>options.some(option=>option.value===value)?options.find(option=>option.value===value).label:"",[value,options]);return useEffect(()=>{setPreselectedIndex(-1)},[filteredOptions]),useKeyboard({"ArrowUp ArrowDown":()=>{handleOpenDropdown()}},innerInputRef,!isOpen&&!disabled&&!readOnly),React.createElement(StyledContainer,{onBlur:()=>{closeDropdown(!0)}},React.createElement("div",{style:{zIndex:1}},React.createElement(InputRaw,{areaLabel:label,name:`${name}-innerInput`,value:innerValue,privateProps:{isTransparent:!(isOpen&&innerValue)||readOnly},icon:isOpen?"chevron-up":"chevron-down",disabled:disabled,readOnly:readOnly,onFocus:()=>{handleOpenDropdown(),onFocus()},onClick:handleOpenDropdown,onChange:e=>{e.currentTarget.value&&handleOpenDropdown(),setInnerValue(e.currentTarget.value)},ref:innerInputRef,autoComplete:autoComplete})),React.createElement(StyledInputWrap,null,React.createElement(Input,{name:name,value:displayValue,onChange:()=>null,icon:isOpen?"chevron-up":"chevron-down",placeholder:placeholder,tabIndex:-1,hasError:hasError,autoComplete:"off",readOnly:readOnly})),React.createElement(OptionsList,{isOpen:isOpen,filteredOptions:filteredOptions,innerInputRef:innerInputRef,onCloseDropdown:closeDropdown,portalContainer:portalContainer,selectedIndex:preselectedIndex,onSelectedIndexChange:index=>{setPreselectedIndex(index)},forceChangeFakeSelect:forceChangeFakeSelect,value:value,emptyStateMessage:emptyStateMessage,disabled:disabled,maxHeight:maxHeight,optionsListWidth:optionsListWidth}),React.createElement(HiddenSelectInput,{onChange:onChange,value:fakeSelectedOption.value,ref:fakeSelectRef,autoComplete:"off"},React.createElement("option",{value:fakeSelectedOption.value},fakeSelectedOption.label)))};
|
|
@@ -36,6 +36,7 @@ export type CommonSelectProps = {
|
|
|
36
36
|
autoComplete?: string;
|
|
37
37
|
onChange?: (selectedValues: SelectOption["value"][] & React.ChangeEvent<HTMLSelectElement>, actionData?: ActionData, e?: React.ChangeEvent<HTMLSelectElement>) => void;
|
|
38
38
|
value: string | string[] | null;
|
|
39
|
+
readOnly?: boolean;
|
|
39
40
|
} & Pick<PortalProps, "portalContainer">;
|
|
40
41
|
export type SelectProps = CommonSelectProps & FormFieldProps;
|
|
41
|
-
export declare function Select({ options, name, value, placeholder, emptyStateMessage, hasError, filterMethod, formatSelectedOptionsLabel, onChange, onBlur, onFocus, maxHeight, autoComplete, multiple, privateProps, portalContainer, optionsListWidth, ...rest }: SelectProps): React.ReactElement;
|
|
42
|
+
export declare function Select({ options, name, value, placeholder, emptyStateMessage, hasError, filterMethod, formatSelectedOptionsLabel, onChange, onBlur, onFocus, maxHeight, autoComplete, multiple, privateProps, portalContainer, optionsListWidth, readOnly, ...rest }: SelectProps): React.ReactElement;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React from"react";import{FormField}from"../FormField/FormField";import{BaseSelect}from"./BaseSelect";import{MultiSelect}from"./MultiSelect";let defaultFilterMethod=(option,value)=>option.label.toLowerCase().indexOf(value.toLowerCase())>-1;export function Select({options=[],name,value,placeholder,emptyStateMessage,hasError,filterMethod=defaultFilterMethod,formatSelectedOptionsLabel,onChange=()=>{},onBlur=()=>null,onFocus=()=>null,maxHeight=230,autoComplete="on",multiple=!1,privateProps,portalContainer,optionsListWidth,...rest}){let{disabled,label}=rest;return React.createElement(FormField,{"data-ds-id":"Select",disabled:disabled,...rest},multiple?React.createElement(MultiSelect,{name:name,options:options,value:value,placeholder:placeholder,emptyStateMessage:emptyStateMessage,hasError:hasError,disabled:disabled,filterMethod:filterMethod,onChange:onChange,onFocus:onFocus,onBlur:onBlur,maxHeight:maxHeight,autoComplete:autoComplete,label:label,formatSelectedOptionsLabel:formatSelectedOptionsLabel,portalContainer:portalContainer,optionsListWidth:optionsListWidth}):React.createElement(BaseSelect,{name:name,options:options,value:value,placeholder:placeholder,emptyStateMessage:emptyStateMessage,hasError:hasError,disabled:disabled,filterMethod:filterMethod,onChange:onChange,onFocus:onFocus,onBlur:onBlur,maxHeight:maxHeight,autoComplete:autoComplete,label:label,privateProps:privateProps,portalContainer:portalContainer,optionsListWidth:optionsListWidth}))}
|
|
1
|
+
import React from"react";import{FormField}from"../FormField/FormField";import{BaseSelect}from"./BaseSelect";import{MultiSelect}from"./MultiSelect";let defaultFilterMethod=(option,value)=>option.label.toLowerCase().indexOf(value.toLowerCase())>-1;export function Select({options=[],name,value,placeholder,emptyStateMessage,hasError,filterMethod=defaultFilterMethod,formatSelectedOptionsLabel,onChange=()=>{},onBlur=()=>null,onFocus=()=>null,maxHeight=230,autoComplete="on",multiple=!1,privateProps,portalContainer,optionsListWidth,readOnly,...rest}){let{disabled,label}=rest;return React.createElement(FormField,{"data-ds-id":"Select",disabled:disabled,...rest},multiple?React.createElement(MultiSelect,{name:name,options:options,value:value,placeholder:placeholder,emptyStateMessage:emptyStateMessage,hasError:hasError,disabled:disabled,filterMethod:filterMethod,onChange:onChange,onFocus:onFocus,onBlur:onBlur,maxHeight:maxHeight,autoComplete:autoComplete,label:label,formatSelectedOptionsLabel:formatSelectedOptionsLabel,portalContainer:portalContainer,optionsListWidth:optionsListWidth}):React.createElement(BaseSelect,{name:name,options:options,value:value,placeholder:placeholder,emptyStateMessage:emptyStateMessage,hasError:hasError,disabled:disabled,filterMethod:filterMethod,onChange:onChange,onFocus:onFocus,onBlur:onBlur,readOnly:readOnly,maxHeight:maxHeight,autoComplete:autoComplete,label:label,privateProps:privateProps,portalContainer:portalContainer,optionsListWidth:optionsListWidth}))}
|