Search code examples
reactjsreact-selectreact-final-form

Conditional dropdowns with react-select and react-final-form field arrays


I'm using react-select with react-final-form and I need to have two selects, where the selected option in the first select dynamically sets the options for the second select. For example, when option One is selected in the first select, the second select gets options One A and One B.

These selects are used in an array. Here is my codesandbox with initial setup https://codesandbox.io/s/react-final-form-field-arrays-e4mm6?fontsize=14.

I've found two similar examples, but I don't know how to adapt them to my use case.

First, I've found this example for react-final-form which sets field's value using createDecorator, but it's used for the value of the field and not the options prop.

Second, I've found this example for react-select which sets options dynamically using state, but I don't know how I can adapt it to my case, considering field arrays.

I would appreciate any help.


Solution

  • Interesting, problem. Here ya go. I created a <PickOptions/> component that watches the first field and provides the options to the second. It also clears the second field when the value of the first changes, which seemed like something you'd want. You could also set it to the first option in the array or something...

    Edit 🏁 React Final Form - Field Arrays SO