API GraphQL e Aplicação Vue desenvolvidos no curso Vue JS - Guia Completo (Vue CLI, Vue Router, Vuex e GraphQL) disponível na Udemy.com.
A aplicação é um Gerenciador de Finanças Pessoais que usa as seguintes tecnologias e recursos:
-
Client Side
- Vue (2.6+)
- Vue Router
- Vuex
- Vuetify
- Vuelidate
- Apollo Client
- Apollo Cache InMemory
- ChartJS
- Moment
- RxJS
-
Server Side
- NodeJS
- Prisma (Client e Binding)
- GraphQL Yoga
- Moment
- JSON Web Tokens
- Bcrypt
- API GraphQL (Queries e Mutations)
- PM2
-
Outras ferramentas
- Docker (Compose e Machine)
- Prisma Server
- PostgreSQL
- Traefik (Reverse Proxy)
- Digital Ocean
- Let's Encrypt (HTTP/TLS)
- Git Submodules
O projeto aborda praticamente tudo sobre o Vue,tópicos abordados:
- Dominando os princípios (Diretivas, Instância Vue, Computed Properties, etc)
- Listas e condicionais (v-for, v-if e v-show)
- Vue CLI
- Components (Introdução, Props e Events, Slots, etc)
- Formulários
- Animações
- Rotas com Vue Router (Básico, aninhamento, guardas, etc)
- Chamadas HTTP com Axios
- Gerenciamento de estado com Vuex
- Projeto final (Back + Front, Docker)
- Build de produção + deploy
Veja a grade completa na página do curso.
Se quiser testar o projeto localmente basta seguir estes passos:
- Clone o repositório usando HTTPS
git clone https://github.com/plinionaves/vue-finances.git
- Acesse o diretório criado para o projeto
cd vue-finances
- Altere o arquivo
.gitmodules
para usar HTTPS também. Esse passo é necessário para que o Git não solicite nenhuma senha
[submodule "deps/front"]
path = deps/front
url = https://github.com/Luispaim/vue-finances-front.git
[submodule "deps/back"]
path = deps/back
url = https://github.com/Luispaim/vue-finances-back.git
- Inicialize o submódulos do Git
git submodule init
- Rode o comando abaixo para "puxar" o código fonte dos submódulos:
git submodule update
- Crie um arquivo
.env
na raiz do projeto e configure as seguintes variáveis de ambiente:
NODE_ENV=development
# monorepo
DOMAIN=vuefinances.localhost # dev domain
POSTGRES_USER=prisma
POSTGRES_PASSWORD=prisma
# o dashboard do traefik será configurado com:
# user: admin
# password: 123456
TRAEFIK_AUTH=admin:$apr1$8E0f5wvJ$HZE3AEO5xPFniztO0bkE50
# back
CLIENT_HOSTS=vuefinances.localhost # cors
JWT_SECRET=your-secret
PRISMA_PORT=4466
PRISMA_ENDPOINT=http://prisma.vuefinances.localhost
PRISMA_SERVICE=vue-finances-back
PRISMA_STAGE=dev
PRISMA_SERVICE_SECRET=service-secret # Prisma CLI
PRISMA_MANAGEMENT_API_SECRET=management-secret
- Execute
docker-compose up -d
- Faça o deploy do Prisma Service
npm i -g prisma@1.28
cd deps/back
prisma deploy -e ../../.env
- Acesse as aplicações:
- Front (Vue): http://vuefinances.localhost
- Back (GraphQL API): http://api.vuefinances.localhost
- Prisma: http://prisma.vuefinances.localhost
- Email: luis.paimadv@gmail.com
- Github: github.com/Luispaim
- Linkedin: linkedin.com/Luispaim