Advertisement
SanderCokart

TodoContext.js

Jan 23rd, 2020
210
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. import React, {createContext} from 'react';
  2. import axios from 'axios';
  3.  
  4. export const TodoContext = createContext();
  5.  
  6. class TodoContextProvider extends React.Component {
  7.     constructor(props) {
  8.         super(props);
  9.         this.state = {
  10.             todos: [],
  11.             message: {},
  12.         };
  13.         this.readTodo();
  14.     }
  15.  
  16.     //create
  17.     createTodo(event, todo) {
  18.         event.preventDefault();
  19.         axios.post('/api/todo/create', todo)
  20.             .then(response => {
  21.                 if (response.data.message.level === 'success') {
  22.                     let data = [...this.state.todos];
  23.                     data.push(response.data.todo);
  24.                     this.setState({
  25.                         todos: data,
  26.                         message: response.data.message,
  27.                     });
  28.                 } else {
  29.                     this.setState({
  30.                         message: response.data.message,
  31.                     });
  32.                 }
  33.             }).catch(error => {
  34.             console.error(error);
  35.         });
  36.  
  37.     }
  38.  
  39.     //read
  40.     readTodo() {
  41.         axios.get('/api/todo/read')
  42.             .then(response => {
  43.                 this.setState({
  44.                     todos: response.data,
  45.                 });
  46.             }).catch(error => {
  47.             console.error(error);
  48.         });
  49.     }
  50.  
  51.     //update
  52.     updateTodo(data) {
  53.         axios.put('/api/todo/update/' + data.id, data)
  54.             .then(response => {
  55.                 if (response.data.message.level === 'error') {
  56.                     this.setState({
  57.                         message: response.data.message,
  58.                     });
  59.                 } else {
  60.                     let todos = [...this.state.todos];
  61.                     let todo = todos.find(todo => {
  62.                         return todo.id === data.id;
  63.                     });
  64.  
  65.                     todo.name = data.name;
  66.  
  67.                     this.setState({
  68.                         todos: todos,
  69.                         message: response.data.message,
  70.                     });
  71.                 }
  72.             }).catch(error => {
  73.             console.error(error);
  74.         });
  75.     }
  76.  
  77.     //delete
  78.     deleteTodo(data) {
  79.         axios.delete('/api/todo/delete/' + data.id)
  80.             .then(response => {
  81.                 if (response.data.message.level === 'error') {
  82.                     this.setState({
  83.                         message: response.data.message,
  84.                     });
  85.                 } else {
  86.                     //message
  87.                     let todos = [...this.state.todos];
  88.                     let todo = todos.find(todo => {
  89.                         return todo.id === data.id;
  90.                     });
  91.  
  92.                     todos.splice(todos.indexOf(todo), 1);
  93.  
  94.                     this.setState({
  95.                         todos: todos,
  96.                         message: response.data.message
  97.                     });
  98.                 }
  99.             }).catch(error => {
  100.             console.error(error);
  101.         });
  102.     }
  103.  
  104.     render() {
  105.         return (
  106.             <TodoContext.Provider value={{
  107.                 ...this.state,
  108.                 createTodo: this.createTodo.bind(this),
  109.                 updateTodo: this.updateTodo.bind(this),
  110.                 deleteTodo: this.deleteTodo.bind(this),
  111.                 setMessage: (message) => this.setState({message: message}),
  112.             }}>
  113.                 {this.props.children}
  114.             </TodoContext.Provider>
  115.         );
  116.     }
  117. }
  118.  
  119. export default TodoContextProvider;
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement