Este projeto é uma aplicação web desenvolvida para gerenciar funcionários e registrar pontos. Administradores têm acesso a funcionalidades de gerenciamento e geração de relatórios detalhados.
- Listagem de funcionários separados por administradores e colaboradores.
- Opção de adicionar, editar, e alterar o status de funcionários.
- Barra de pesquisa para encontrar funcionários por nome, e-mail, função ou setor.
- Navegação para relatórios de pontos de cada funcionário.
- Exibição de dados completos do funcionário.
- Filtros por data e mês para visualizar os pontos registrados.
- Edição de registros de horários de entrada e saída diretamente no relatório.
- Modal de Cadastro: Adiciona novos funcionários com campos como nome, CPF, e-mail, função, setor, etc.
- Modal de Edição: Permite atualizar informações de um funcionário existente.
- Modal de Edição de Pontos: Permite ajustar os horários de entrada e saída dos registros de ponto.
- React: Framework para construção da interface do usuário.
- TypeScript: Linguagem para aumentar a robustez do código.
- TailwindCSS: Estilização personalizada para componentes e tabelas.
- Node.js: Servidor backend para integração com o Firebase.
- Firebase Firestore: Banco de dados NoSQL para armazenar informações de funcionários e pontos.
- Firebase Authentication: Gerenciamento de autenticação de usuários.
- React Router: Para navegação entre páginas.
- Firebase SDK: Para integração com serviços Firebase.
- Icons (Material UI): Para botões e ações visuais.
-
backend
server.js
: Configuração do servidor backend usando Node.js.
-
src
- components: Contém modais e componentes principais como
AdminDashboard
eEmployeeReport
. - contexts: Implementação do contexto de autenticação.
- firebaseConfig.ts: Configuração do Firebase.
- styles: Arquivos CSS para estilização global e componentes específicos.
- components: Contém modais e componentes principais como
git clone https://github.com/eduardogazolla/hour-sync
- Crie um projeto no Firebase.
- Ative o Firestore Database e Authentication.
- Substitua as configurações no arquivo firebaseConfig.ts.\
- Certifique-se de estar na pasta
backend
:cd backend
- Instale as dependências:
npm install
- Inicie o servidor backend:
node server.js
- Retorne para a pasta raiz do projeto:
cd ..
- Instale as dependências:
npm install
- Inicie o frontend:
npm run dev
- Acesse no navegador: http://localhost:3000
- name: Nome do funcionário.
- cpf: CPF do funcionário.
- email: E-mail do funcionário.
- role: Função do funcionário.
- setor: Setor do funcionário.
- isAdmin: Booleano indicando se o funcionário é administrador.
- status: Status do funcionário (ativo/inativo).
- userId: ID do funcionário.
- userName: Nome do funcionário.
- date: Data do registro.
- entries:
- entradaManha, saidaManha, entradaTarde, saidaTarde: Horários - registrados.
- Adicionar gráficos nos relatórios para visualização de dados.
- Melhoria no documento exportado em PDF.
- Limitação de uso por IP.
Para dúvidas ou sugestões, entre em contato com o desenvolvedor. Eduardo Gazolla