Upload 2.14
This commit is contained in:
@@ -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 handleChange = (event) => {
|
||||||
const { name, value } = event.target;
|
const { name, value } = event.target;
|
||||||
setNewPerson({ ...newPerson, [name]: value });
|
setNewPerson({ ...newPerson, [name]: value });
|
||||||
@@ -47,13 +57,14 @@ const App = () => {
|
|||||||
<div>
|
<div>
|
||||||
<h2>Phonebook</h2>
|
<h2>Phonebook</h2>
|
||||||
<Filter filter={filter} filterByName={filterByName} />
|
<Filter filter={filter} filterByName={filterByName} />
|
||||||
|
<h2>Add a new number</h2>
|
||||||
<PersonForm
|
<PersonForm
|
||||||
addPerson={addPerson}
|
addPerson={addPerson}
|
||||||
newPerson={newPerson}
|
newPerson={newPerson}
|
||||||
handleChange={handleChange}
|
handleChange={handleChange}
|
||||||
/>
|
/>
|
||||||
<h2>Numbers</h2>
|
<h2>Numbers</h2>
|
||||||
<ShowPersons showedPersons={showedPersons} />
|
<ShowPersons showedPersons={showedPersons} deletePerson={deletePerson} />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,7 +1,10 @@
|
|||||||
const Person = ({ person }) => {
|
const Person = ({ person, deletePerson }) => {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div key={person.id}>
|
||||||
{person.name} {person.number}
|
{person.name} {person.number}{" "}
|
||||||
|
<button onClick={() => deletePerson(person.id, person.name)}>
|
||||||
|
Delete
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
import Person from "./Person";
|
import Person from "./Person";
|
||||||
|
|
||||||
const ShowPersons = ({ showedPersons }) => {
|
const ShowPersons = ({ showedPersons, deletePerson }) => {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
{showedPersons.map((person) => (
|
{showedPersons.map((person) => (
|
||||||
<Person key={person.name} person={person} />
|
<Person key={person.name} person={person} deletePerson={deletePerson} />
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,11 +1,9 @@
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
const baseUrl = "http://localhost:3001/persons";
|
const baseUrl = "http://localhost:3001/persons";
|
||||||
|
|
||||||
const getAll = () => {
|
const getAll = () => {
|
||||||
const request = axios.get(baseUrl);
|
const request = axios.get(baseUrl);
|
||||||
return request.then((response) => response.data);
|
return request.then((response) => response.data);
|
||||||
};
|
};
|
||||||
|
|
||||||
const create = (newObject) => {
|
const create = (newObject) => {
|
||||||
const request = axios.post(baseUrl, newObject);
|
const request = axios.post(baseUrl, newObject);
|
||||||
return request.then((response) => response.data);
|
return request.then((response) => response.data);
|
||||||
@@ -16,4 +14,9 @@ const update = (id, newObject) => {
|
|||||||
return request.then((response) => response.data);
|
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 };
|
||||||
|
|||||||
Reference in New Issue
Block a user