O TeamTrack é um aplicativo de gerenciamento de projetos para manter o rastreio de seus clientes e atividades.
Para a aplicação funcionar localmente, é preciso seguir alguns passos importantes. O detalhamento desses passos será dado adiante, mas a visão geral é a seguinte:
- Primeiramente, defina um banco de dados com nome "teamtrack" no PostgreSQL, com senha própria.
- Suba o servidor backend em
http://localhost:8080
. - Com isso, é possível fazer requisições para os endpoints da API:
/clientes
,/projetos
,/atividades
. - Recomenda-se realizar requisições por meio de aplicativos como Insomnia ou Postman.
- Suba também o servidor frontend em
http://localhost:5173
. - A tela da aplicação será mostrada conforme a imagem acima: a diferença é que serão mostrados os projetos, clientes e atividades conforme definidos pelo usuário nas requisições com a API. A imagem acima mostra um exemplo.
Barbara Calderon, desenvolvedora de software.
- Linguagem: Java 17
- Framework: Spring Boot 3.2.5
- Banco de Dados: PostgreSQL
- Dependências Principais:
- Spring Boot Starter Data JPA
- Spring Boot Starter Web
- Spring Boot DevTools
- Lombok
- Jakarta Validation API
- Spring Boot Starter Test
- JUnit
- Mockito
- Linguagem: JavaScript
- Framework: Vue.js 3
- Ferramenta de Build: Vite
- Estilização: Bootstrap 4.5.2, CSS3
- Gerenciamento de Estado: Pinia
- HTML5
Também foi utilizado o Insomnia para requisições ao servidor backend e povoamento do banco de dados TeamTrack.
-
Clone o repositório:
git clone git@github.com:barbaracalderon/teamtrack.git
-
Crie um banco de dados no PostgreSQL com nome "teamtrack"
-
Configure o arquivo application.properties
spring.application.name=teamtrack
server.port=8080
spring.datasource.url=jdbc:postgresql://localhost:5432/teamtrack
spring.datasource.username=postgres
spring.datasource.password=[sua senha aqui]
spring.datasource.driver-class-name=org.postgresql.Driver
spring.jpa.properties.hibernate.format_sql=true
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
- Execute a aplicação
./mvnw spring-boot:run
O servidor será iniciado em http://localhost:8080/
- Uso pelo Insomnia
Recomenda-se o uso do Insomnia para realizar as requisições aos endpoints da API e povoar o banco de dados com as informações desejadas. Neste projeto também encontra-se um arquivo do Insomnia com os dados utilizados na construção do projeto: Insomnia_teamtrackjson.
- Endpoints da API
Método | Endpoint | Descrição |
---|---|---|
POST | /clientes | Cria um novo cliente |
GET | /clientes | Lista todos os clientes |
POST | /projetos | Cria um novo projeto |
GET | /projetos | Lista todos os projetos |
GET | /projetos/em_aberto | Lista todos os projetos em aberto |
POST | /atividades | Cria uma nova atividade associada a um projeto |
GET | /atividades | Lista todas as atividades |
- Logs
A aplicação conta com aplicação de Logs (@slf4j
) para visualização de infos
e errors
no terminal.
- Testes
Rode os testes com o comando:
mvn test
São 24 testes totais. O resultado é verificado abaixo:
A parte frontend do projeto encontra-se no diretório "frontend".
-
Entre no diretório frontend, ainda com o servidor backend ativo.
-
Execute o comando para subir
npm run dev
A aplicação será inicializada em http://localhost:5173/
- Abra o navegador no endereço citado acima e utilize a aplicação.
Você verá a aplicação dinâmica e responsiva, sendo atualizada ao mesmo tempo que novos dados são inseridos no servidor backend. Foi utilizado o "accordion" para visualização dos dados, de modo que temos o nome do projeto, o nome do cliente relacionado ao projeto e também as atividades daquele projeto. Algumas imagens da aplicação ativa e funcionando estão abaixo.
O TeamTrack foi desenvolvido inteiramente por mim, Barbara Calderon, com o objetivo de facilitar o gerenciamento de projetos, clientes e tarefas, oferecendo uma interface intuitiva e funcionalidades requisitadas. A combinação do Spring Boot no backend e do Vue.js no frontend proporciona uma aplicação eficiente e de fácil manutenção. Esperamos que este sistema atenda às suas necessidades e facilite o acompanhamento de suas atividades diárias.