diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2020-09-30 22:18:32 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-30 22:18:32 -0700 |
commit | 542f96da0ef323f286aa9caa8cfffaa98094467e (patch) | |
tree | 055596a88e19157aa42b4ac65794e85fe49cee8b /modern/src/form/SelectField.js | |
parent | 739ca4cb813a7deb910f3dcb1655ae9d484e6487 (diff) | |
parent | 230d7d277d0386101dfcf88d8fabed58e4adde3d (diff) | |
download | trackermap-web-542f96da0ef323f286aa9caa8cfffaa98094467e.tar.gz trackermap-web-542f96da0ef323f286aa9caa8cfffaa98094467e.tar.bz2 trackermap-web-542f96da0ef323f286aa9caa8cfffaa98094467e.zip |
Merge pull request #785 from traccar/select-field
Implement common select field component
Diffstat (limited to 'modern/src/form/SelectField.js')
-rw-r--r-- | modern/src/form/SelectField.js | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/modern/src/form/SelectField.js b/modern/src/form/SelectField.js new file mode 100644 index 00000000..78a16887 --- /dev/null +++ b/modern/src/form/SelectField.js @@ -0,0 +1,35 @@ +import { FormControl, InputLabel, Select } from '@material-ui/core'; +import React, { useState } from 'react'; +import { useEffectAsync } from '../reactHelper'; + +const SelectField = ({ margin, variant, label, defaultValue, onChange, endpoint }) => { + const [items, setItems] = useState(); + + useEffectAsync(async () => { + const response = await fetch(endpoint); + if (response.ok) { + setItems(await response.json()); + } + }, []); + + if (items) { + return ( + <FormControl margin={margin} variant={variant}> + <InputLabel>{label}</InputLabel> + <Select + native + defaultValue={defaultValue} + onChange={onChange}> + <option value={0}></option> + {items.map(item => ( + <option key={item.id} value={item.id}>{item.name}</option> + ))} + </Select> + </FormControl> + ); + } else { + return null; + } +} + +export default SelectField; |