Proyectos de Subversion LeadersLinked - SPA

Rev

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

Rev Autor Línea Nro. Línea
3270 stevensc 1
import React from 'react'
2
import { useNavigate } from 'react-router-dom'
3
import { useDispatch } from 'react-redux'
4
 
3371 stevensc 5
import { useHabits } from '@hooks'
3270 stevensc 6
import { saveHabit } from '@services/habits/habits'
7
import { addNotification } from '@store/notification/notification.actions'
8
 
9
import PageHeader from '@components/common/page-header'
10
import HabitForm from '@components/habits/habits/habit-form'
11
 
12
export default function CreateHabitPage() {
13
  const navigate = useNavigate()
14
  const dispatch = useDispatch()
15
 
16
  const { addUrl, addHabit } = useHabits()
17
 
18
  const onSubmit = async (habit) => {
19
    try {
20
      const response = await saveHabit(addUrl, habit)
21
      dispatch(addNotification({ style: 'success', msg: response.message }))
22
      addHabit(response.data)
23
      navigate('/habits/habits')
24
    } catch (error) {
25
      dispatch(addNotification({ style: 'danger', msg: error.message }))
26
    }
27
  }
28
 
29
  return (
30
    <>
31
      <PageHeader title='Crear hábito o competencia' goBack />
32
      <HabitForm onSubmit={onSubmit} />
33
    </>
34
  )
35
}