Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 3416 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
3432 stevensc 1
import React, { createContext, useCallback } from 'react'
2
import { useFetch } from '@hooks'
3158 stevensc 3
 
3432 stevensc 4
export const ValuesContext = createContext()
3158 stevensc 5
 
6
export default function ValuesProvider({ url, children }) {
3432 stevensc 7
  const { data, isLoading: loading, mutate } = useFetch(url, { items: [] })
8
  const { items: values, link_add, total } = data
3158 stevensc 9
 
10
  const addValue = useCallback(
11
    (newValue) => {
3432 stevensc 12
      const newValues = [...values, newValue]
13
      mutate({ ...data, items: newValues })
3158 stevensc 14
    },
15
    [values, mutate]
3432 stevensc 16
  )
3158 stevensc 17
 
18
  const removeValue = useCallback(
19
    (valueId) => {
3432 stevensc 20
      const newValues = values.filter((value) => value.id !== valueId)
21
      mutate({ ...data, items: newValues })
3158 stevensc 22
    },
23
    [values, mutate]
3432 stevensc 24
  )
3158 stevensc 25
 
26
  const updateValue = useCallback(
27
    (updatedValue) => {
28
      const newValues = values.map((value) =>
29
        value.id === updatedValue.id ? updatedValue : value
3432 stevensc 30
      )
31
      mutate({ ...data, items: newValues })
3158 stevensc 32
    },
33
    [values, mutate]
3432 stevensc 34
  )
3158 stevensc 35
 
36
  const getValueById = useCallback(
37
    (valueId) => values.find((value) => value.id === valueId),
38
    [values]
3432 stevensc 39
  )
3158 stevensc 40
 
41
  return (
42
    <ValuesContext.Provider
43
      value={{
44
        loading,
45
        values,
46
        addUrl: link_add,
47
        total,
48
        addValue,
49
        removeValue,
50
        updateValue,
3432 stevensc 51
        getValueById
3158 stevensc 52
      }}
53
    >
54
      {children}
55
    </ValuesContext.Provider>
3432 stevensc 56
  )
3158 stevensc 57
}