Skip to content

15º projeto construído no curso de Desenvolvimento Web da Trybe: Criação de uma aplicação que calcula gastos, utilizando Redux

Notifications You must be signed in to change notification settings

AndersonSilva94/project-trybewallet

Repository files navigation

CAPA LINKEDIN_PERFIL PESSOAL03

Projeto TrybeWallet :money_with_wings:

Décimo quinto projeto do curso de Desenvolvimento Full Stack Web da Trybe.

Objetivos a serem alcançados no decorrer da construção do projeto:

Desenvolver uma carteira de controle de gastos com conversor de moedas. Ao utilizar essa aplicação um usuário deverá ser capaz de:

  • Adicionar, remover e editar um gasto;
  • Visualizar uma tabelas com seus gastos;
  • Visualizar o total de gastos convertidos para uma moeda de escolha;

Como foi construído

  • Criando um store Redux em aplicações React

  • Criando reducers no Redux em aplicações React

  • Criando actions no Redux em aplicações React

  • Criando dispatchers no Redux em aplicações React

  • Conectando Redux aos componentes React

  • Criando actions assíncronas na sua aplicação React que faz uso de Redux.

Instruções para clonar o projeto

  1. Clone o repositório
  • git clone git@github.com:AndersonSilva94/project-trybewallet.git.
  • Entre na pasta do repositório que você acabou de clonar:
    • project-trybewallet
  1. Instale as dependências, inicialize o projeto e rode os testes
  • Instale as dependências:
    • npm install
  • Inicialize o projeto:
    • npm start (uma nova página deve abrir no seu navegador com o projeto)
  • Você pode verificar que os testes estão executando:
    • npm test

Requisitos

Página de Login

Crie uma página para que a pessoa usuária se identifique, com email e senha. Esta página deve ser a página inicial de seu aplicativo.

image

1. Crie uma página inicial de login com os seguintes campos e características:

  • A rota para esta página deve ser ‘/’.

  • Você deve criar um local para que a pessoa usuária insira seu email e senha. Utilize o atributo data-testid="email-input" para o email e data-testid="password-input" para a senha.

  • Crie um botão com o texto ‘Entrar’.

O que será testado:

- A rota para esta página deve ser "/"
- Existe um local para que o usuário insira seu email e senha
- Existe um botão com o texto "Entrar"

2. Realize as seguintes verificações nos campos de email, senha e botão:

  • O email está no formato válido, como 'alguem@alguem.com'.

  • A senha possui 6 ou mais caracteres.

  • Salve o email no estado da aplicação, com a chave email, assim que a pessoa usuária logar.

  • A rota deve ser mudada para '/carteira' após o clique no botão 'Entrar'.

O que será testado:

- O botão de "Entrar" está desabilitado ao entrar na página
- O botão de "Entrar está desabilitado quando um email inválido é digitado
- O botão de "Entrar" está habilitado quando um email e uma senha válidos são passados

3. Utilize o Redux para salvar no estado global as informações da pessoa logada

  • Salve o email no estado da aplicação, com a chave email, assim que o usuário logar.

  • A rota deve ser mudada para /carteira quando o login for efetuado com sucesso.

O que será testado:

- O estado global possui a chave `email` no formato esperado
- A rota deve ser mudada para `/carteira` após o clique no botão

Página da Carteira

Crie uma página para gerenciar a carteira de gastos em diversas moedas, e que traga a despesa total em uma moeda só. Esta página deve ser renderizada por um componente chamado Wallet.

image

Configurando sua página

4. Crie uma página para sua carteira com as seguintes características:

  • A rota para esta página deve ser /carteira

  • O componente deve se chamar Wallet e estar localizado na pasta src/pages no arquivo Wallet.js

O que será testado:

- A rota para esta página deve ser "/carteira"
- O componente deve se chamar Wallet e estar localizado na pasta "src/pages"

Header (cabeçalho)

5. Crie um header para a página de carteira contendo as seguintes características:

  • Um elemento que exiba o email da pessoa usuária que fez login.

    • Adicione o atributo data-testid="email-field".
Dica: você deve pegar o email do estado global da aplicação (no Redux)
  • Um campo com a despesa total gerada pela lista de gastos.

    • Adicione o atributo data-testid="total-field".

    • Inicialmente esse campo deve exibir o valor 0

  • Um campo que mostre qual câmbio está sendo utilizado, que será neste caso será 'BRL'.

    • Adicione o atributo data-testid="header-currency-field".

O que será testado:

- Um elemento que exiba o email do usuário que fez login.
- Crie um campo com a despesa total gerada pela lista de gastos.
- Crie um campo que mostre que qual câmbio está sendo utilizado, que será neste caso "BRL"

Formulário de adição de Despesa

Dica: atente-se ao formato sugerido pelo React para criar formulários.

<form>
  <label>
    Nome:
    <input type="text" name="name" />
  </label>
</form>

6. Desenvolva um formulário para adicionar uma despesa contendo as seguintes características:

  • Um campo para adicionar valor da despesa.

    • O campo deverá ter a label Valor.
  • Um campo de texto para adicionar a descrição da despesa.

    • O campo deverá ter a label Descrição.
  • Um campo de select para adicionar em qual moeda será registrada a despesa.

    • O campo deverá ter a label Moeda.

    • O campo deverá ser um <select>.

    • As opções do select serão preenchidas através da consulta à API. Isso será feito em um requisito mais a frente. Nesse momento você pode deixar o <select> vazio.

  • Um campo para adicionar qual método de pagamento será utilizado.

    • O campo deverá ter a label Método de pagamento.

    • Este campo deve ser um <select>. A pessoa usuária deve poder escolher entre os campos: 'Dinheiro', 'Cartão de crédito' e 'Cartão de débito'.

  • Um campo para selecionar uma categoria (tag) para a despesa.

    • Este campo deve ser um <select>. A pessoa usuária deve poder escolher entre os campos: 'Alimentação', 'Lazer', 'Trabalho', 'Transporte' e 'Saúde'.

    • O campo deverá ter a label Tag.


7. Implemente a lógica para preencher as opções do campo "Moedas", buscando as siglas das moedas da API:

  • Ao entrar na página /carteira, você deverá fazer uma requisição para a API das moedas e preencher as opções do <select> de "Moedas" com os valores retornados. Utilizando as siglas das moedas.

  • As opções devem conter os valores: 'USD', 'CAD', 'EUR', 'GBP', 'ARS', 'BTC', 'LTC', 'JPY', 'CHF', 'AUD', 'CNY', 'ILS', 'ETH' e 'XRP'.


8. Desenvolva a opção de "Adicionar despesa" na sua tabela de gastos

  • Desenvolva a funcionalidade do botão "Adicionar despesa" de modo que ao clicar no botão, as seguintes ações sejam executadas:

    • Os valores dos campos devem ser salvos no estado da aplicação, na chave expenses, dentro de um array contendo todos gastos que serão adicionados:

      • O id da despesa deve ser um número sequencial, começando em 0. Ou seja: a primeira despesa terá id 0, a segunda terá id 1, a terceira id 2, e assim por diante.

      • Você deverá salvar a cotação do câmbio feita no momento da adição para ter esse dado quando for efetuar uma edição do gasto. Caso você não tenha essa informação salva, o valor da cotação trazida poderá ser diferente do obtido anteriormente.

        Atenção nesse ponto: você deverá fazer uma requisição para API e buscar a cotação no momento que o botão de Adicionar despesa for apertado. Para isso você deve utilizar um thunk. Atente-se ao formato do objeto da despesa descrito abaixo: o valor retornado pela API deverá ficar dentro da chave exchangeRates.

    • Após adicionar a despesa, atualize a soma total das despesas. Essa informação deve ficar no header dentro do elemento com data-testid="total-field"

    • As despesas salvas no Redux ficarão com um formato semelhante ao seguinte:

      Clique para expandir.

        expenses: [{
          "id": 0,
          "value": "3",
          "description": "Hot Dog",
          "currency": "USD",
          "method": "Dinheiro",
          "tag": "Alimentação",
          "exchangeRates": {
            "USD": {
              "code": "USD",
              "name": "Dólar Comercial",
              "ask": "5.6208",
              ...
            },
            "CAD": {
              "code": "CAD",
              "name": "Dólar Canadense",
              "ask": "4.2313",
              ...
            },
            "EUR": {
              "code": "EUR",
              "name": "Euro",
              "ask": "6.6112",
              ...
            },
            "GBP": {
              "code": "GBP",
              "name": "Libra Esterlina",
              "ask": "7.2498",
              ...
            },
            "ARS": {
              "code": "ARS",
              "name": "Peso Argentino",
              "ask": "0.0729",
              ...
            },
            "BTC": {
              "code": "BTC",
              "name": "Bitcoin",
              "ask": "60299",
              ...
            },
            "LTC": {
              "code": "LTC",
              "name": "Litecoin",
              "ask": "261.69",
              ...
            },
            "JPY": {
              "code": "JPY",
              "name": "Iene Japonês",
              "ask": "0.05301",
              ...
            },
            "CHF": {
              "code": "CHF",
              "name": "Franco Suíço",
              "ask": "6.1297",
              ...
            },
            "AUD": {
              "code": "AUD",
              "name": "Dólar Australiano",
              "ask": "4.0124",
              ...
            },
            "CNY": {
              "code": "CNY",
              "name": "Yuan Chinês",
              "ask": "0.8278",
              ...
            },
            "ILS": {
              "code": "ILS",
              "name": "Novo Shekel Israelense",
              "ask": "1.6514",
              ...
            },
            "ETH": {
              "code": "ETH",
              "name": "Ethereum",
              "ask": "5184",
              ...
            },
            "XRP": {
              "code": "XRP",
              "name": "Ripple",
              "ask": "1.4",
              ...
            }
          }
        }]


Tabela de Gastos

9. Desenvolva uma tabela com os gastos contendo as seguintes características:

  • A tabela deve possuir um cabeçalho exatamente com os campos Descrição, Tag, Método de pagamento, Valor, Moeda, Câmbio utilizado, Valor convertido, Moeda de conversão e Editar/Excluir

  • Atente-se ao formato semântico da tabela. Utilize os elementos corretos para o cabeçalho, para as linhas e para as células.

  • A tabela deve ser alimentada pelo estado da aplicação, que estará disponível na chave expenses que vem do reducer wallet.

    • O campo de Moeda e Moeda de Conversão deverão conter o nome da moeda. Portanto, ao invés de 'USD' ou 'EUR', deve conter "Dólar Comercial" e "Euro", respectivamente

    • Por padrão, o campo 'Moeda de conversão' exibirá 'Real'

    • Atenção também às casas decimais dos campos. Como são valores contábeis, eles devem apresentar duas casas após a vírgula. Arredonde sua resposta somente na hora de renderizar o resultado, e para os cálculos utilize sempre os valores vindos da API (utilize o campo ask que vem da API).

    • Utilize sempre o formato 0.00 (número - ponto - duas casas decimais)

O que será testado:

- A tabela deve possuir um cabeçalho com os campos Descrição, Tag, Método de pagamento, Valor, Moeda, Câmbio utilizado, Valor convertido e Moeda de conversão.
- A tabela deve ser alimentada pelo estado da aplicação, que estará disponível na chave expenses que vem do reducer wallet.

10. Crie um botão para deletar uma despesa da tabela contendo as seguintes características:

image

  • O botão deve estar na linha da tabela e deve possuir data-testid="delete-btn".

  • Ao ser clicado, o botão deleta a linha da tabela, alterando o estado global.

O que será testado:

- O botão deve estar dentro do último item da linha da tabela e deve possuir `data-testid="delete-btn"`
- Ao ser clicado, o botão deleta a linha da tabela, alterando o estado global

Bônus

11. Crie um botão para editar uma despesa da tabela contendo as seguintes características:

image

  • O botão deve estar dentro da linha da tabela e deve possuir data-testid="edit-btn"

  • Ao ser clicado, o botão habilita um formulário para editar a linha da tabela. Ao clicar em "Editar despesa" ela é atualizada, alterando o estado global.

    • O formulário deverá ter os mesmos data-testid do formulário de adicionar despesa. Você pode reaproveitá-lo.

    • O botão para submeter a despesa para edição deverá conter exatamente o texto "Editar despesa"

    Atenção: o câmbio utilizado na edição deve ser o mesmo do cálculo feito na adição do gasto.

O que será testado:

- O botão deve estar dentro do último item da linha da tabela e deve possuir `data-testid="edit-btn"
- Ao ser clicado, o botão habilita um formulário para editar a linha da tabela. Ao clicar em "Editar despesa" ela é atualizada, alterando o estado global

⌨️ com 💜 por Anderson Silva (Andy)

About

15º projeto construído no curso de Desenvolvimento Web da Trybe: Criação de uma aplicação que calcula gastos, utilizando Redux

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published