-
Notifications
You must be signed in to change notification settings - Fork 349
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Should we support <select /> with multiple=true like ReactJS? #283
Comments
Here is an example application which showcases this, where we can comment/uncomment the lines to switch between the behavior of type state = {
selectedItems: list(string),
/* selectedItems: string, */
items: list(string),
};
type action =
| SelectItem(string);
let component = ReasonReact.reducerComponent("Multiselect");
let make = _children => {
...component,
initialState: () => {
items: ["a", "b", "c", "f", "g", "x"],
selectedItems: [],
/* selectedItems: "", */
},
reducer: (action, state) =>
switch (action) {
/* | SelectItem(item) => ReasonReact.Update({...state, selectedItems: item}) */
| SelectItem(item) =>
ReasonReact.Update({...state, selectedItems: [item]})
},
render: self =>
<div>
<h1>
{ReasonReact.string("Selected item: ")}
/* {ReasonReact.string(self.state.selectedItems)} */
{
self.state.selectedItems
|> List.map(item =>
<div key=item> {ReasonReact.string(item)} </div>
)
|> Array.of_list
|> ReasonReact.array
}
</h1>
<select
name="Tasks"
value={self.state.selectedItems}
multiple=true
onChange={
event =>
self.send(SelectItem(ReactEvent.Form.target(event)##value))
}>
{
self.state.items
|> List.map(item =>
<option value=item key=item>
{ReasonReact.string(item)}
</option>
)
|> Array.of_list
|> ReasonReact.array
}
</select>
</div>,
}; |
I'm encountering the same issue. Is there solution or workaround for this yet? |
I imagine an increasing number of people are going to run into this issue. There's an easy solution, but it'd be a breaking change to I'd be happy to submit a PR with that change, but is there any other non-breaking solution or workaround? Edit: I think GADTs might also work if you didn't want the variants to be polymorphic for whatever reason, but would require the value type to be polymorphic which could be a headache and which you may be avoiding intentionally. |
That's a little harder in Reason than it might sound, we can't change the type definition of a function based on a value. Possible solutions like GADTs or moving this logic to the ppx are valid approaches to this, but unsure if the hassle makes sense here. Smashing ideas here but, probably removing the multiple=true as a valid prop (add a warning when is used) and provide a It feels gross thought. |
In ReactJS we can easily make a multiselect component by setting our
value
to anarray
ofstrings
instead of a singlestring
like so:see: https://reactjs.org/docs/forms.html#the-select-tag
Intuitively, I thought this would be the case for ReasonReact as well, allowing us to use
list(string)
orarray(string)
to achieve the same behavior.As of now the
value
of a<select />
component expectsvalue
to be astring
, even whenmultiple=true
. addingmultiple=true
andvalue=string
satisfies the compiler, but we'll get an error in the browser like so:Now, if we try to obey the JS error we get the following error in Reason:
It would be helpful to be able to handle this with
list(string)
orarray(string)
, just like ReactJS does it.The text was updated successfully, but these errors were encountered: