testes/src_2/features/rh/hooks/useProventos.js

90 lines
2.7 KiB
JavaScript

import { useState, useCallback } from 'react';
import { rhService } from '../services/rhService';
import { toast } from 'sonner';
/**
* Hook customizado para gerenciar proventos de colaboradores
*/
export const useProventos = () => {
const [proventos, setProventos] = useState([]);
const [loading, setLoading] = useState(false);
const [error, setError] = useState(null);
/**
* Criar ou atualizar proventos
*/
const createOrUpdateProventos = useCallback(async (payload) => {
setLoading(true);
setError(null);
try {
const response = await rhService.createOrUpdateProventos(payload);
const data = response?.data || response;
toast.success(response?.message || 'Proventos salvos com sucesso!');
return data;
} catch (err) {
const errorMessage = err?.response?.data?.message || err?.message || 'Erro ao salvar proventos';
setError(errorMessage);
toast.error(errorMessage);
throw err;
} finally {
setLoading(false);
}
}, []);
/**
* Buscar proventos por colaborador
*/
const fetchProventosByColaborador = useCallback(async (idcolaborador, params = {}) => {
setLoading(true);
setError(null);
try {
const response = await rhService.getProventosByColaborador(idcolaborador, params);
console.log('📥 Response proventos da API:', response);
// A API retorna { data: [...], success: true } ou diretamente [...]
const proventosList = Array.isArray(response)
? response
: (Array.isArray(response?.data) ? response.data : (response?.proventos || []));
console.log('📊 Proventos processados:', proventosList);
setProventos(proventosList);
return response;
} catch (err) {
const errorMessage = err?.response?.data?.message || err?.message || 'Erro ao buscar proventos';
setError(errorMessage);
toast.error(errorMessage);
return null;
} finally {
setLoading(false);
}
}, []);
/**
* Listar todos os proventos
*/
const fetchAllProventos = useCallback(async (params = {}) => {
setLoading(true);
setError(null);
try {
const response = await rhService.getAllProventos(params);
const proventosList = response?.proventos || response?.data || [];
setProventos(proventosList);
return response;
} catch (err) {
const errorMessage = err?.response?.data?.message || err?.message || 'Erro ao listar proventos';
setError(errorMessage);
toast.error(errorMessage);
return null;
} finally {
setLoading(false);
}
}, []);
return {
proventos,
loading,
error,
createOrUpdateProventos,
fetchProventosByColaborador,
fetchAllProventos
};
};