Upload 2.14

This commit is contained in:
AndrewTrieu
2023-03-23 15:38:43 +02:00
parent 0aa93a7824
commit d4506db50a
4 changed files with 26 additions and 9 deletions

View File

@@ -30,6 +30,16 @@ const App = () => {
});
};
const deletePerson = (id, name) => {
if (window.confirm(`Delete ${name}?`)) {
personService.deletePerson(id).then((response) => {
const newPersons = persons.filter((person) => person.id !== id);
setPersons(newPersons);
setShowedPersons(newPersons);
});
}
};
const handleChange = (event) => {
const { name, value } = event.target;
setNewPerson({ ...newPerson, [name]: value });
@@ -47,13 +57,14 @@ const App = () => {
<div>
<h2>Phonebook</h2>
<Filter filter={filter} filterByName={filterByName} />
<h2>Add a new number</h2>
<PersonForm
addPerson={addPerson}
newPerson={newPerson}
handleChange={handleChange}
/>
<h2>Numbers</h2>
<ShowPersons showedPersons={showedPersons} />
<ShowPersons showedPersons={showedPersons} deletePerson={deletePerson} />
</div>
);
};

View File

@@ -1,7 +1,10 @@
const Person = ({ person }) => {
const Person = ({ person, deletePerson }) => {
return (
<div>
{person.name} {person.number}
<div key={person.id}>
{person.name} {person.number}{" "}
<button onClick={() => deletePerson(person.id, person.name)}>
Delete
</button>
</div>
);
};

View File

@@ -1,10 +1,10 @@
import Person from "./Person";
const ShowPersons = ({ showedPersons }) => {
const ShowPersons = ({ showedPersons, deletePerson }) => {
return (
<div>
{showedPersons.map((person) => (
<Person key={person.name} person={person} />
<Person key={person.name} person={person} deletePerson={deletePerson} />
))}
</div>
);

View File

@@ -1,11 +1,9 @@
import axios from "axios";
const baseUrl = "http://localhost:3001/persons";
const getAll = () => {
const request = axios.get(baseUrl);
return request.then((response) => response.data);
};
const create = (newObject) => {
const request = axios.post(baseUrl, newObject);
return request.then((response) => response.data);
@@ -16,4 +14,9 @@ const update = (id, newObject) => {
return request.then((response) => response.data);
};
export default { getAll, create, update };
const deletePerson = (id) => {
const request = axios.delete(`${baseUrl}/${id}`);
return request.then((response) => response);
};
export default { getAll, create, update, deletePerson };