aboutsummaryrefslogtreecommitdiffstats
path: root/public/projects/react-small-apps/apps/todos/src/views/TodoForm
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-02-20 16:11:50 +0100
committerArmand Philippot <git@armandphilippot.com>2022-02-20 16:15:08 +0100
commit73a5c7fae9ffbe9ada721148c8c454a643aceebe (patch)
treec8fad013ed9b5dd589add87f8d45cf02bbfc6e91 /public/projects/react-small-apps/apps/todos/src/views/TodoForm
parentb01239fbdcc5bbc5921f73ec0e8fee7bedd5c8e8 (diff)
chore!: restructure repo
I separated public files from the config/dev files. It improves repo readability. I also moved dotenv helper to public/inc directory and extract the Matomo tracker in the same directory.
Diffstat (limited to 'public/projects/react-small-apps/apps/todos/src/views/TodoForm')
-rw-r--r--public/projects/react-small-apps/apps/todos/src/views/TodoForm/TodoForm.js42
1 files changed, 42 insertions, 0 deletions
diff --git a/public/projects/react-small-apps/apps/todos/src/views/TodoForm/TodoForm.js b/public/projects/react-small-apps/apps/todos/src/views/TodoForm/TodoForm.js
new file mode 100644
index 0000000..bc6ed97
--- /dev/null
+++ b/public/projects/react-small-apps/apps/todos/src/views/TodoForm/TodoForm.js
@@ -0,0 +1,42 @@
+import { useState } from "react";
+import { useDispatch } from "react-redux";
+import { Button, Fieldset, Input, TextArea } from "../../components/forms";
+import { addTodo } from "../../store/todos/todos.slice";
+
+function TodoForm({ userId, closeForm }) {
+ const [titleValue, setTitleValue] = useState("");
+ const [bodyValue, setBodyValue] = useState("");
+ const dispatch = useDispatch();
+
+ const handleSubmit = (e) => {
+ e.preventDefault();
+ closeForm((prev) => !prev);
+ };
+
+ const handleSave = () => {
+ const newTodo = { userId, title: titleValue, body: bodyValue };
+ dispatch(addTodo(newTodo));
+ };
+
+ return (
+ <form onSubmit={handleSubmit} className="form form--todo">
+ <Fieldset legend="Add a new todo">
+ <Input label="Title" value={titleValue} updateValue={setTitleValue} />
+ <TextArea
+ label="Details"
+ value={bodyValue}
+ updateValue={setBodyValue}
+ />
+ <Button
+ type="submit"
+ modifiers={["submit"]}
+ onClickHandler={handleSave}
+ >
+ Save
+ </Button>
+ </Fieldset>
+ </form>
+ );
+}
+
+export default TodoForm;