mirror of
https://github.com/pawelmalak/flame.git
synced 2025-07-21 20:39:36 +02:00
Weather settings form update functionality. API: update multiple values in one Config query
This commit is contained in:
parent
316bc49f5c
commit
88c8eee982
4 changed files with 95 additions and 70 deletions
|
@ -1,4 +1,4 @@
|
||||||
import { useState, ChangeEvent, Fragment, useEffect } from 'react';
|
import { useState, ChangeEvent, Fragment, useEffect, FormEvent } from 'react';
|
||||||
import axios from 'axios';
|
import axios from 'axios';
|
||||||
import { ApiResponse, Config } from '../../../interfaces';
|
import { ApiResponse, Config } from '../../../interfaces';
|
||||||
|
|
||||||
|
@ -55,9 +55,16 @@ const WeatherSettings = (): JSX.Element => {
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
const formSubmitHandler = (e: FormEvent) => {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
axios.put<ApiResponse<{}>>('/api/config', formData)
|
||||||
|
.then(data => console.log(data.data.success))
|
||||||
|
.catch(err => console.log(err));
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<form onSubmit={(e) => formSubmitHandler(e)}>
|
||||||
<Fragment>
|
|
||||||
<InputGroup>
|
<InputGroup>
|
||||||
<label htmlFor='WEATHER_API_KEY'>API Key</label>
|
<label htmlFor='WEATHER_API_KEY'>API Key</label>
|
||||||
<input
|
<input
|
||||||
|
@ -119,9 +126,8 @@ const WeatherSettings = (): JSX.Element => {
|
||||||
<option value={0}>Fahrenheit</option>
|
<option value={0}>Fahrenheit</option>
|
||||||
</select>
|
</select>
|
||||||
</InputGroup>
|
</InputGroup>
|
||||||
</Fragment>
|
|
||||||
<Button>Save changes</Button>
|
<Button>Save changes</Button>
|
||||||
</div>
|
</form>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -86,6 +86,22 @@ exports.updateValue = asyncWrapper(async (req, res, next) => {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// @desc Update multiple values
|
||||||
|
// @route PUT /api/config/
|
||||||
|
// @access Public
|
||||||
|
exports.updateValues = asyncWrapper(async (req, res, next) => {
|
||||||
|
Object.entries(req.body).forEach(async ([key, value]) => {
|
||||||
|
await Config.update({ value }, {
|
||||||
|
where: { key }
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
res.status(200).send({
|
||||||
|
success: true,
|
||||||
|
data: {}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
// @desc Delete key:value pair
|
// @desc Delete key:value pair
|
||||||
// @route DELETE /api/config/:key
|
// @route DELETE /api/config/:key
|
||||||
// @access Public
|
// @access Public
|
||||||
|
|
|
@ -7,7 +7,8 @@
|
||||||
"start": "node server.js",
|
"start": "node server.js",
|
||||||
"server": "nodemon server.js",
|
"server": "nodemon server.js",
|
||||||
"client": "npm start --prefix client",
|
"client": "npm start --prefix client",
|
||||||
"dev": "concurrently \"npm run server\" \"npm run client\""
|
"dev": "concurrently \"npm run server\" \"npm run client\"",
|
||||||
|
"dev-lines": "git ls-files | grep -v '.json' | xargs wc -l"
|
||||||
},
|
},
|
||||||
"author": "",
|
"author": "",
|
||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
|
|
|
@ -6,13 +6,15 @@ const {
|
||||||
getAllPairs,
|
getAllPairs,
|
||||||
getSinglePair,
|
getSinglePair,
|
||||||
updateValue,
|
updateValue,
|
||||||
deletePair
|
updateValues,
|
||||||
|
deletePair,
|
||||||
} = require('../controllers/config');
|
} = require('../controllers/config');
|
||||||
|
|
||||||
router
|
router
|
||||||
.route('')
|
.route('')
|
||||||
.post(createPair)
|
.post(createPair)
|
||||||
.get(getAllPairs);
|
.get(getAllPairs)
|
||||||
|
.put(updateValues);
|
||||||
|
|
||||||
router
|
router
|
||||||
.route('/:key')
|
.route('/:key')
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue