/vue-finances

Agenda Financeira: prisma + graphql + vue.js

Primary LanguageShell

Agenda Financeira

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.

Vue JS - Guia Completo (Vue CLI, Vue Router, Vuex e GraphQL)

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

Conteúdo

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.

Teste localmente

Se quiser testar o projeto localmente basta seguir estes passos:

  1. Clone o repositório usando HTTPS
git clone https://github.com/plinionaves/vue-finances.git
  1. Acesse o diretório criado para o projeto
cd vue-finances
  1. 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
  1. Inicialize o submódulos do Git
git submodule init
  1. Rode o comando abaixo para "puxar" o código fonte dos submódulos:
git submodule update
  1. 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
  1. Execute
docker-compose up -d
  1. Faça o deploy do Prisma Service
npm i -g prisma@1.28

cd deps/back

prisma deploy -e ../../.env
  1. Acesse as aplicações:

Contato