diff --git a/README.md b/README.md index 9f744ef5f..9d2523adc 100644 --- a/README.md +++ b/README.md @@ -121,6 +121,7 @@ export default () => ( | showAction | actions trigger the dropdown to show | String[]? | - | | autoFocus | focus select after mount | boolean | - | | autoClearSearchValue | auto clear search input value when multiple select is selected/deselected | boolean | true | +| prefix | specify the select prefix icon or text | ReactNode | - | | | suffixIcon | specify the select arrow icon | ReactNode | - | | clearIcon | specify the clear icon | ReactNode | - | | removeIcon | specify the remove icon | ReactNode | - | diff --git a/assets/index.less b/assets/index.less index 4af07760c..a538f635d 100644 --- a/assets/index.less +++ b/assets/index.less @@ -72,6 +72,7 @@ .@{select-prefix}-selection-search { width: 100%; + position: relative; &-input { width: 100%; @@ -101,7 +102,6 @@ // -------------- Multiple --------------- &-multiple .@{select-prefix}-selector { display: flex; - flex-wrap: wrap; padding: 1px; border: 1px solid #000; @@ -121,7 +121,6 @@ .@{select-prefix}-selection-overflow { display: flex; flex-wrap: wrap; - width: 100%; &-item { flex: none; diff --git a/docs/examples/custom-icon.tsx b/docs/examples/custom-icon.tsx index ededd54b5..b82aff553 100644 --- a/docs/examples/custom-icon.tsx +++ b/docs/examples/custom-icon.tsx @@ -103,6 +103,7 @@ class CustomIconComponent extends React.Component { value={value} mode="combobox" backfill + prefix="Foobar" suffixIcon={({ searchValue }) => { if (searchValue) { return '😺'; @@ -193,6 +194,7 @@ class Test extends React.Component { onChange={this.onChange} onFocus={() => console.log('focus')} tokenSeparators={[' ', ',']} + prefix="Foobar" suffixIcon={getSvg(arrowPath)} clearIcon={getSvg(clearPath)} removeIcon={getSvg(clearPath)} diff --git a/src/BaseSelect/index.tsx b/src/BaseSelect/index.tsx index b1390f98b..3dba28fb7 100644 --- a/src/BaseSelect/index.tsx +++ b/src/BaseSelect/index.tsx @@ -173,6 +173,7 @@ export interface BaseSelectProps extends BaseSelectPrivateProps, React.AriaAttri // >>> Icons allowClear?: boolean | { clearIcon?: RenderNode }; + prefix?: RenderNode; suffixIcon?: RenderNode; /** * Clear all icon @@ -259,6 +260,7 @@ const BaseSelect = React.forwardRef((props, ref) // Icons allowClear, + prefix, suffixIcon, clearIcon, @@ -795,6 +797,7 @@ const BaseSelect = React.forwardRef((props, ref) inputElement={customizeInputElement} ref={selectorRef} id={id} + prefix={prefix} showSearch={mergedShowSearch} autoClearSearchValue={autoClearSearchValue} mode={mode} diff --git a/src/Selector/SingleSelector.tsx b/src/Selector/SingleSelector.tsx index 7fd7f69be..4fe56b86b 100644 --- a/src/Selector/SingleSelector.tsx +++ b/src/Selector/SingleSelector.tsx @@ -104,6 +104,8 @@ const SingleSelector: React.FC = (props) => { attrs={pickAttrs(props, true)} maxLength={combobox ? maxLength : undefined} /> + {/* Display placeholder */} + {placeholderNode} {/* Display value */} @@ -119,8 +121,6 @@ const SingleSelector: React.FC = (props) => { {item.label} ) : null} - {/* Display placeholder */} - {placeholderNode} ); }; diff --git a/src/Selector/index.tsx b/src/Selector/index.tsx index a24ca7c20..3766d23b0 100644 --- a/src/Selector/index.tsx +++ b/src/Selector/index.tsx @@ -72,6 +72,7 @@ export interface SelectorProps { disabled?: boolean; placeholder?: React.ReactNode; removeIcon?: RenderNode; + prefix?: RenderNode; // Tags maxTagCount?: number | 'responsive'; @@ -110,6 +111,7 @@ const Selector: React.ForwardRefRenderFunction showSearch, tokenWithEnter, disabled, + prefix, autoClearSearchValue, @@ -269,6 +271,7 @@ const Selector: React.ForwardRefRenderFunction onClick={onClick} onMouseDown={onMouseDown} > + {prefix &&
{typeof prefix === 'function' ? prefix(props): prefix}
} {selectNode} ); diff --git a/tests/__snapshots__/Combobox.test.tsx.snap b/tests/__snapshots__/Combobox.test.tsx.snap index 43deee073..806f9ea71 100644 --- a/tests/__snapshots__/Combobox.test.tsx.snap +++ b/tests/__snapshots__/Combobox.test.tsx.snap @@ -23,11 +23,11 @@ exports[`Select.Combobox renders controlled correctly 1`] = ` type="search" value="" /> - - - Search + + Search + @@ -56,11 +56,11 @@ exports[`Select.Combobox renders correctly 1`] = ` type="search" value="" /> - - - Search + + Search + diff --git a/tests/__snapshots__/ssr.test.tsx.snap b/tests/__snapshots__/ssr.test.tsx.snap index 60c144098..de916d8db 100644 --- a/tests/__snapshots__/ssr.test.tsx.snap +++ b/tests/__snapshots__/ssr.test.tsx.snap @@ -1,3 +1,3 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Select.SSR should work 1`] = `"
"`; +exports[`Select.SSR should work 1`] = `"
"`;