aboutsummaryrefslogtreecommitdiff
path: root/modern/src/form
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2020-09-30 22:17:42 -0700
committerAnton Tananaev <anton.tananaev@gmail.com>2020-09-30 22:17:42 -0700
commit230d7d277d0386101dfcf88d8fabed58e4adde3d (patch)
tree055596a88e19157aa42b4ac65794e85fe49cee8b /modern/src/form
parent739ca4cb813a7deb910f3dcb1655ae9d484e6487 (diff)
downloadetbsa-traccar-web-230d7d277d0386101dfcf88d8fabed58e4adde3d.tar.gz
etbsa-traccar-web-230d7d277d0386101dfcf88d8fabed58e4adde3d.tar.bz2
etbsa-traccar-web-230d7d277d0386101dfcf88d8fabed58e4adde3d.zip
Implement common select field component
Diffstat (limited to 'modern/src/form')
-rw-r--r--modern/src/form/SelectField.js35
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 0000000..78a1688
--- /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;