Teste Técnico Frontend

Stone

React, Typescript

São Paulo - Brasil

Finanças

500 - 1k

A stone é uma empresa de meios de pagamento e tem um propósito claro, porém nada simples: evoluir um mercado bancário e facilitar o empreendedorismo no Brasil. Sempre com inovação e tecnologia.

Sobre o Teste

O desafio técnico consiste em criar uma aplicação web de conversão de valores de dólar para real. As tecnologias que devem ser utilizadas são React, TypeScript, axios para fazer as requisições HTTP, styled-components para estilização, e uma biblioteca de cache como swr ou react-query. Além disso, é necessário realizar testes unitários dos componentes e publicar a aplicação em uma plataforma de deploy rápido como Vercel, Heroku ou Netlify. O layout do desafio está disponível no Figma.

Instruções do Teste

Desafio web

O desafio é criar uma aplicação de conversão de valores de dólar para real.

A aplicação terá duas etapas, uma para inserir o valor que se deseja converter e outra para mostrar os valores convertidos.

Para isso, você deve buscar a cotação na API de moedas.

A aplicação deve mostrar os seguintes dados:

  1. Cotação do dólar
  2. IOF
  3. Total em dólar sem imposto
  4. Total em dólar com imposto
  5. Total em real sem imposto
  6. Total em real com imposto

Cálculo dos valores

Comprando com dinheiro

[(Valor em dólar) + (imposto do Estado)] x (valor do dólar + IOF da compra de dólar)

Comprando com cartão

[(Valor em dólar) + (imposto do Estado) + (IOF de transações internacionais)] x (valor do dólar)



Possíveis dúvidas:

  • IOF é um imposto federal e tem como intuito ser um regulador da economia nacional. Em dinheiro, seu valor é 1,1%, e em cartão 6,4%
  • Nos EUA, cada Estado tem sua própria cobrança de impostos. Por exemplo, o imposto de Nevada é de 8,19%, já o de Nova Iorque é de 8,87%

Layout

O layout está disponível no figma

figma-layout

Requisitos

  • Utilize a fonte do layout
  • Utilize React
  • Utilize TypeScript
  • Crie um cliente HTTP com axios
  • Faça testes unitários dos seus componentes
  • Utilize uma bilbioteca de cache como swr ou react-query
  • Utlize styled-components
  • Publique sua aplicação em uma plataforma de deploy rápido (vercel/heroku/netlify/outros)
  • Publique seu código no seu perfil no GitHub em um repositório privado

Critérios de avaliação

Entrega

  • O resultado final está completo para ser executado?
  • O resultado final atende ao que se propõe fazer?
  • O resultado final atende totalmente aos requisitos propostos?
  • O resultado final é visualmente elegante?

Boas práticas

  • O código está de acordo com o guia de estilo da linguagem?
  • O código está bem estruturado?
  • O código faz o bom uso de Design Patterns?
  • O código possui testes?

Documentação

  • O código foi entregue com um arquivo de README claro de como instalar e codificar no projeto?
  • O código possui comentários pertinentes?
  • O código está em algum controle de versão?
  • Os commits são pequenos e consistentes?
  • As mensagens de commit são claras?

Material de estudo