Skip to content

Commit

Permalink
fix(ui-simple-select): fix selection getting lost after options have …
Browse files Browse the repository at this point in the history
…changed

Closes: INSTUI-4402

This issue came up when the Option's value and children differed.
TEST PLAN:
make a SimpleSelect where the Option's value and children are not the same. Select a child and
remove a different element from the child list. Selection should stay
  • Loading branch information
matyasf committed Dec 11, 2024
1 parent 2b2a997 commit ded1321
Showing 1 changed file with 6 additions and 3 deletions.
9 changes: 6 additions & 3 deletions packages/ui-simple-select/src/SimpleSelect/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ import { allowedProps, propTypes, SimpleSelectState } from './props'
type OptionChild = React.ComponentElement<SimpleSelectOptionProps, Option>
type GroupChild = React.ComponentElement<SimpleSelectGroupProps, Group>

type GetOption = <F extends 'id' | 'value'>(
type GetOption = <F extends keyof SimpleSelectOptionProps>(
field: F,
value?: SimpleSelectOptionProps[F]
) => OptionChild | undefined
Expand Down Expand Up @@ -150,14 +150,17 @@ class SimpleSelect extends Component<SimpleSelectProps, SimpleSelectState> {

componentDidUpdate(prevProps: SimpleSelectProps) {
if (this.hasOptionsChanged(prevProps.children, this.props.children)) {
const option = this.getOption('value', this.state.inputValue)
// Compare current input value to children's child prop, this is put into
// state.inputValue
const option = this.getOption('children', this.state.inputValue)
this.setState({
inputValue: option ? option.props.children : undefined,
selectedOptionId: option ? option.props.id : ''
})
}

if (this.props.value !== prevProps.value) {
// if value has changed externally try to find an option with the same value
// and select it
let option = this.getOption('value', this.props.value)
if (typeof this.props.value === 'undefined') {
// preserve current value when changing from controlled to uncontrolled
Expand Down

0 comments on commit ded1321

Please sign in to comment.