Proyectos de Subversion LeadersLinked - SPA

Rev

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

Rev Autor Línea Nro. Línea
3452 stevensc 1
import { useEffect, useState } from 'react';
2
 
3665 stevensc 3
import { useAlert, useApi } from '@shared/hooks';
4
import { addComment, deleteComment, getComments, getKnowledge } from '../services';
3452 stevensc 5
 
6
export function useKnowledge(uuid) {
7
  const [comments, setComments] = useState([]);
8
  const [knowledge, setKnowledge] = useState({
9
    category: '',
10
    title: '',
11
    description: '',
12
    link: null,
13
    image: '',
14
    attachment: '',
15
    reaction: '',
16
    routeComments: '',
17
    routeCommentAdd: '',
18
    routeSaveReaction: '',
19
    routeDeleteReaction: ''
20
  });
21
 
3665 stevensc 22
  const { showError, showSuccess } = useAlert();
3452 stevensc 23
 
3665 stevensc 24
  const { loading } = useApi(getKnowledge, {
25
    autoFetch: true,
26
    autoFetchArgs: [uuid],
27
    onSuccess: (data) => {
28
      setKnowledge(data);
29
    },
30
    onError: (error) => {
31
      showError(error.message);
3452 stevensc 32
    }
3665 stevensc 33
  });
3452 stevensc 34
 
3665 stevensc 35
  const { loading: commentsLoading, execute: executeGetComments } = useApi(getComments, {
36
    onSuccess: (data) => {
37
      setComments(data);
38
    },
39
    onError: (error) => {
40
      showError(error.message);
41
    }
42
  });
3452 stevensc 43
 
3665 stevensc 44
  const { execute: executeDeleteComment } = useApi(deleteComment, {
45
    onSuccess: (message) => {
46
      showSuccess(message);
47
    },
48
    onError: (error) => {
49
      showError(error.message);
3452 stevensc 50
    }
3665 stevensc 51
  });
3452 stevensc 52
 
3665 stevensc 53
  const { execute: executeAddComment } = useApi(addComment, {
54
    onSuccess: (data) => {
55
      setComments((prevMessages) => [...prevMessages, data]);
56
    },
57
    onError: (error) => {
58
      showError(error.message);
59
    }
60
  });
3452 stevensc 61
 
62
  useEffect(() => {
3665 stevensc 63
    if (knowledge.routeComments) executeGetComments(knowledge.routeComments);
64
  }, [knowledge.routeComments]);
3452 stevensc 65
 
66
  return {
67
    knowledge,
3665 stevensc 68
    loading,
3452 stevensc 69
    comments,
70
    commentsLoading,
3665 stevensc 71
    addComment: executeAddComment,
72
    deleteComment: executeDeleteComment
3452 stevensc 73
  };
74
}