/NLW-Setup-11

Rocketseat's Next Level Week 11

Primary LanguageTypeScript

NLW Setup

Layout do projeto NLW Setup no Figma

Aula 1 - parte web

Começaremos com a estrutura do projeto backend

Setup do Back-end

console:

cd server

npm init -y

npm install fastify

mkdir src

instalar typescript como dependencia de desenvolvimento

npm install typescript -D

npx tsc --init

📄 tsconfig.json

→ mudaremos o target para es2020

npm i tsx -D

permite a gente executar um arquivo do node com typescript sem precisar fazer qualquer tipo de conversão desse arquivo

para executar o arquivo:

npx tsx server.ts

para nao ter q rodar essa linha toda vez que quisermos visualizar o código rodando, podemos criar um script em 📄 package.json:

"scripts": {
    "dev": "tsx src/server.ts"
  },

ai podemos executar com npm run dev

toda vez que alterar o arquivo, eu vou precisar fazer um run dev novamente, para que eu n precise fazer isso, com o tsx instalado posso adicionar um watch no script e ele vai atualizar sozinho toda vez que tiver uma alteracao no codigo

Fastify: usaremos para criar as rotas da aplicacao

com o servidor ainda rodando, abriremos um novo console, e instalaremos o prisma e o prisma/client

npm i -D prisma

npm i @prisma/client

npx prisma init --datasource-provider SQLite

quero utilizar o banco de dados sqlite porque ele cria um arquivo local de banco de dados e assim n precisamos usar docker

dentro de 📄 schema.prima é onde informaremos as tabelas do nosso banco de dados

como usaremos a sintaxe do prisma, é necessário ter a extensão do prisma instalada no VSCode

no console

npx prisma migrate dev

para exportar o nosso banco de datos

npx prisma studio

para acessarmos nossa tabela no navegador

cors

npm i @fastify/cors

usaremos para o front-end acessar os dados do nosso back-end

Setup do Front-End

com o projeto de back-end rodando, daermos inicio ao projeto front-end

vite

template que traz alguma coisas ja prontas, como o build

suporte ao typescript

em uma nova pasta

no terminal:

npm create vite@latest

web

react

typescript

cd web

npm install

npm run dev

✨ no react, tudo são componentes

componente é tudo o que queremos reaproveitar/isolar no nosso codigo

propriedades são informações enviadas para modificar um componente visual ou comportamental

tailwind

para economizar tempo no css usaremos o tailwind para estilizar nossa aplicacao

npm install -D tailwindcss postcss autoprefixer

npx tailwindcss init -p

em 📄 tailwind.config.cjs:

/** @type {import('tailwindcss').Config} */
module.exports = {
  content: [
    './src/**/*.tsx',
    './index.html'
  ],
  theme: {
    extend: {},
  },
  plugins: [],
}

criar em 📁 src um 📁styles 📄 global.css

@tailwind base;
@tailwind utilities;
@tailwind components;

em 📄 App.tsx

import './styles/global.css'

Aula 1 - parte mobile

configuração de desenvolvimento:

Rocketseat Docs | Ambiente React Native

criaremos a aplicaçao com o REACT NATIVE

EXPO

para iniciar o projeto, abrimos no terminal a pasta onde estao salvos os nossos back-end e front-end web e rodamos npx create-expo-app mobile --template

para iniciar o projeto npx expo start

criamos a tela de loading,

importamos as fontes google com npx expo install expo-font @expo-google-fonts/inter

alteramos a pasta assets com os arquivos criados para o projeto

Aula 2 - parte web

Nossa aplicação por enquanto nao irá trabalhar com autenticação

Começaremos criando as tabelas do banco de dados.

dando uma olhada no layout, precisamos analisar quais tabelas serão necessárias.

→ tabela cadastro de habitos

→ tabela que armazena cada um dos habitos que foram completados por dia

cada dia do nosso calendario pode ter varios habitos e esses habitos podem estar completos ou não (relacionamento n:n)

levando isso pro código, temos a tabela habito, a tabela dia e uma tabela pivo que relaciona essas duas informacoes.

na tabela pivo (DayHabit), alem de ter seu proprio id, ela tambem armazena os ids das tabelas que ela esta relacionando

nem todos os dias necessariamente, eu vou lembrar de preencher os habitos, portanto precisamos ter um campo data em Day. o registro na tabela Day, so sera feito caso seja completado pelo menos algum habito.

ainda em Day, podemos criar o campo unique com o campo date, para indicar que nao poderemos ter dois dias iguais

um mesmo habito, nao pode ser completado duas vezes num mesmo dia

um mesmo habito nao pode ter dois dias iguais

ainda precisamos de uma ultima tabela (HabitWeekDays), que vai armazenar a recorrencia do habito.

nem todos os habitos precisam ser praticados todos os dias da semana, necessariamente, e por isso essa tabela vai ter um relacionamento de 1 pra muitos. cada habito pode estar disponivel em varios dias da semana

um habito so pode estar disponivel uma vez por cada dia da semana

feito tudo isso, npx prisma migrate dev para armazenar as mudanças do nosso banco de dados

dessa forma o prisma nao criou as foreignKeys

precisamos criar entao essas referencias botando a coluna com a tabela que queremos referenciar.

shift+alt+f para formatar e o prisma criar as relations automaticamente.

depois de todas as relations feitas: npx prisma migrate dev para salvar

se quisermos ter uma noção mais visual de como ficou o diagrama, existe uma ferramenta que podemos instalar para poder gerar o ERD e visualiza-lo no navegador

npm i -D prisma-erd-generator @mermaid-js/mermaid-cli

em schema.prisma colar essa linha:

generator erd {
	provider = "prisma-erd-generator"
}

npx prisma generate vai criar um ERD.svg que abrindo no navegador, deve ficar assim:

Untitled

SEED

é um populador de banco de dados

cria dados ficticios para nao precisarmos trabalhar com o banco de dados vazio enquanto estivermos desenvolvendo nossa aplicação

em 📁 prisma → new 📄 seed.ts

para acharmos a estrutura do seed, podemos pesquisar na documentaçao do prisma

e em package.json adicionar a segunte linha:

"prisma":{
    "seed": "tsx prisma/seed.ts"
  }

para rodar o seed: npx prisma db seed para criar

npx prisma studio para vermos no navegador a tabela

alem de criarmos um dado no banco de dados, é interessante também excluirmos todos os dados com o seed. pois da maneira que criamos, toda vez que rodarmos o seed, ele vai criar o mesmo habito varias vezes, entao podemos adicionar uma linha que deleta todos os habitos e vai funcionar como um reset para cada vez que rodarmos o seed.

nos materiais da aula ja tem um modelo de seed que é só copiarmos

esse seed esta sendo criado 3 habitos.

agora podemos separar um pouco melhor os arquivos da nossa aplicacao, começando pela conexao com o banco, se eu vou usa-la varias vezes, posso separa-la em um arquivo proprio e importar ela desse arquivo.

📁src → new 📁 lib → new 📄 prisma.ts

alem disso, vamos separar também as rotas da nossa aplicacao

📁 src → new 📄 routes.ts

criacao de rotas back-end

rota de criacao de habito

recebe o titulo do habito e os dias da semana que esse habito vai estar disponivel

vamos instalar a biblioteca zod npm i zod e a dayjs npm i dayjs

rota que retorna o detalhe do dia, os habitos daquele dia

→ vamos dar uma pausa no backend e fazer algo de front, layout da aplicacao web

biblioteca de icones: npm i phosphor-react

criamos a header da nossa aplicacao como um componente

e criamos também os quadradinhos que vamos usar para marcar os nossos habitos.

Aula 2 - parte mobile

nativewind

serve para usarmos o tailwind no react native

para instalar: npm i nativewind feita a intalacao no nativeWind, podemos instalar o tailwind como dependencia de desenvolvimento npm i tailwindcss --save-dev

npx tailwindcss init para criar o config

alteraremos o conteudo do 📄 tailwind.config.js

alteramos também o conteudo do 📄 babel.config.js

em src criamos a 📁 screens que irá armazenar todas as nossas telas

o typescript aqui no react-native nao idendifica as className q nem na parte web, entao temos que fazer uma configuraçao pra ele poder entender.

criar uma 📁@types → new 📄app.d.ts com o seguinte conteudo:

/// <reference types="nativewind/types" />

demos inicio a criaçao da pagina home e seus respectivos componentes como header…

uma obs.: o react native nao suporta o uso de svg, para isso precisamos da biblioteca npx expo install react-native-svg e ainda a npm i react-native-svg-transformer --save-dev

https://github.com/kristerkari/react-native-svg-transformer

npm install dayjs

fizemos a mesma logica dos quadrinhos que fizemos no mobile

e o resto fica pra proxima aula

Aula 3 - Parte web

em server:

iremos finalizar as rotas do back-end a de resumo de dias e a de completar o habito

vamos começar com a rota de ‘completar’ o habito e para isso usaremos o patch, ja que a rota vai funcionar como um toggle (onde podemos marcar e desmarcar a opcao)

depois faremos a rota summary que vai nos retornar os dias que temos habitos, quantos habitos tem naquele dia, e quanto habitos foram completados.

em web:

vamos criar um modal de criacao de habito

fazer um popover do detalhe do dia

personalizar o progresso no quadrado do habito

no react nós usamos a forma declarativa

✨ estados sao variaveis monitoradas pelo react

radixUi sao varios componentes sem estilizacao e completamente acessiveis

usaremos o de modal: npm install @radix-ui/react-dialog

npm install @radix-ui/react-popover

usaremos uma biblioteca chamada clsx para fazer a estilizacao dos quadradinhos conforme forem sendo completos

Aula 3 - Parte Mobile

faremos a tela para cadastrar novos habitos e também a tela para visualizar os habitos

Implementar a navegaçao - fazer com que o usuario possa navegar de uma tela para outra

para criar as rotas, usaremos o react navigation

https://reactnavigation.org/

npm install @react-navigation/native

npx expo install react-native-screens react-native-safe-area-context

npm install @react-navigation/native-stack

Conteúdo

  • Criar a estrutura básica das telas

    • Cadastro de Hábito
    • Detalhes do Hábito
  • Implementando Navegação

    • Criar as rotas da aplicação
    • Navegar para a tela de cadastro
    • Definir a tipagem das rotas de navegação
    • Navegar para a tela de hábito
  • Criar a interface de cadastro de hábitos

    • Componente BackButton
    • Implementar botão de voltar na tela de cadastro
    • Input de novo hábito
    • Componente de Checkbox
    • Listar um Checkbox para cada dia da semana
    • Criar a função de marcar/desmarcar Checkbox
    • Botão de confirmar
    • Utilizar ScrollView para habilitar rolagem
  • Criar a interface de hábitos do dia

    • Utilizar ScrollView para habilitar rolagem
    • Reaproveitar o componente BackButton
    • Implementar botão de voltar na tela de cadastro
    • Input de novo hábito
    • Componente de Checkbox
    • Listar um Checkbox para cada dia da semana
    • Criar a função de marcar/desmarcar Checkbox
    • Botão de confirmar
  • Criar a interface de hábitos do dia

    • Navegar para a tela de hábito
    • Utilizar Scrollview para habilitar rolagem
    • reaproveitar o componente BackButton
    • Passando e recuperando data como parâmetro da rota
    • Formatar e exibir dia/mês
    • Criar o componente ProgressBar
    • Utilizar componente de Checkbox

    Aula 4 - Conectando a Api

  • Front-end

    • Criando
    • Obtendo dados do fomulário
  • Conexão com back-end

    • Configurando cliente HTTP
    • Buscando resumo da API
    • Criação de um novo hábito

npm install @radix-ui/react-checkbox

npm i axios

Aula 4 - parte mobile

  • iniciando o servidor

    • instalando o axios
    • configurando acesso ao server
  • Home

    • listando o sumário
    • utilizando componente de loading
    • passando utilizado propriedades no componente HabitDay
      • criando uma funcao para calcular a porcentagem do progresso
      • utilizando o clsx para utilizar classes condicionais
  • new

    • obtendo dados do formulario
    • cadastrando e enviando novos dados para api

    Aula 5 - o Próximo nível

  • Front-end

    • listando hábitos possíveis do dia
    • desabilitando em datas passadas
    • sincronizando hábitos completos
    • adicionando transitions e focus
  • Desafios:

    • adicionar autenticacao de usuário - firebase, authzero
    • notificações push / service workers
    • perfil publico com grafico de resumos
    • botao de editar ou excluir habito

    Aula 5 - parte mobile

  • Habit

    • Buscar os hábitos do dia selecionado na API
    • Exibir a lista de hábitos do dia
    • Criar o componente de lista de hábitos vazia
    • Verificar se data selecionada é passada e mostrar mensagem que não pode editar
    • Exibir o progresso
  • Enviar para API o status do hábito (realizado ou não)

    • Utilizando o useFocusEffect para atualizar a home ao voltar
    • Animação
    • Conhecendo o React Native Reanimated npx expo install react-native-reanimated
    • Instalando e configurando o Reanimated na aplicação
    • Animar a ProgressBar
    • Animar a Checkbox