Teste Técnico Frontend
Hotel Urbano
O Hotel Urbano, também conhecido como Hurb, é uma agência de viagens brasileira que oferece uma ampla seleção de hotéis e pacotes turísticos, proporcionando experiências inesquecíveis para seus clientes.
Sobre o Teste
O desafio Charlie consiste em construir um microsite responsivo para mostrar a previsão do tempo em localidades informadas pelo usuário. O microsite deve ser desenvolvido preferencialmente em React, e pode usar outras bibliotecas ou frameworks, como Angular ou Vue.js, ou JavaScript puro. Para a folha de estilo, pode ser utilizado qualquer opção, como CSS, SASS, LESS, CSS Modules, ou CSS-in-JS. É recomendado o uso do Webpack, mas também é possível usar o create-react-app ou similar. O site deve estar pronto para produção e pode ser Dockerizado. O desafio deve ser forkado e um pull request deve ser submetido para a avaliação. Os critérios de avaliação incluem a execução correta da aplicação, organização do código, clareza do README, assertividade da aplicação, legibilidade do código, segurança, cobertura de testes, histórico de commits, UX e escolhas técnicas. Em caso de dúvidas, é possível consultar as issues existentes no repositório do desafio.
Instruções do Teste
Desafio Charlie
Construa um microsite responsivo para mostrar a previsão do tempo nas localidades informadas na caixa de texto branca (na imagem de exemplo é o local aonde aparece "Rio de Janeiro, Rio de Janeiro"). Essa caixa de texto deve ser um input
, aonde o usuário pode trocar a localidade. Com a mudança da localidade, devem ser carregadas as informações de previsão do tempo referentes à nova localidade.
Logo que a página seja aberta deve ser coletada as coordenadas geográficas do usuário pela API do navegador para então se descobrir o nome da cidade via reverse geocode.
Como fundo de tela deve ser usado a imagem de destaque do Bing. Devem ser mostradas as previsões para: hoje, amanhã e depois de amanhã.
Note que existe um degradê sobreposto na imagem original, na verdade essa cor reflete a temperatura atual do lugar buscado para as três datas. Para temperaturas abaixo de 15ºC deve ser usado tons de azul, para temperaturas acima de 35ºC deve ser usado tons de vermelho e use tons de amarelo para as demais temperaturas. Quando não houver nenhuma localidade escolhida deve ser usado tons de cinza como base para o degradê. Se o usuário clicar em qualquer temperatura, as temperaturas devem ser alteradas de Celsius para Fahrenheit ou de Fahrenheit para Celsius.
A URL da imagem de fundo deve ser extraida da API do Bing.
Para consultar a previsão do tempo, utilize a do OpenWeather - http://api.openweathermap.org/data/2.5/weather?q={{location_name}}&APPID=772920597e4ec8f00de8d376dfb3f094
informando o nome da localidade no lugar de {{location_name}}
usando a app id 772920597e4ec8f00de8d376dfb3f094
. Caso necessário, crie uma nova conta.
Para converter latitude e longitude em uma localidade utilize o OpenCage - https://api.opencagedata.com/geocode/v1/json?q={{latitude}},{{longitude}}&key=c63386b4f77e46de817bdf94f552cddf&language=en
usando a API key c63386b4f77e46de817bdf94f552cddf
. Caso necessário, crie uma nova conta.
Os ícones podem ser encontrados em http://www.alessioatzeni.com/meteocons/.
O layout deve ser seguido, mas você pode sugerir melhorias. Descreva essas melhorias no README e diga o por que delas. Você ganha pontos extras se essas melhorias forem positivas, ou perde pontos do contrário.
Requisitos
- Preferencialmente faça em React, mas você pode usar outras bibliotecas ou frameworks (Angular, Vue.js, etc) ou JavaScript puro (Vanilla JS).
- Para a folha de estilo, você pode usar o que preferir (CSS, SASS, LESS, CSS Modules, CSS-in-JS, etc).
- Preferencialmente use Webpack. Se preferir, você pode usar create-react-app ou similares. Fazer o próprio setup do Webpack da pontos extras.
- É interessante que sua aplicação esteja pronta para produção. Criar no Docker um
stage
para produção e um para desenvolvimento da pontos extras. - Forkar esse desafio e criar o seu projeto (ou workspace) usando a sua versão desse repositório, tão logo acabe o desafio, submeta um pull request.
- Caso você tenha algum motivo para não submeter um pull request, crie um repositório privado no Github, faça todo desafio na branch master e não se esqueça de preencher o arquivo
pull-request.txt
. Tão logo termine seu desenvolvimento, adicione como colaborador o usuárioautomator-hurb
no seu repositório e o deixe disponível por pelo menos 30 dias. Não adicione oautomator-hurb
antes do término do desenvolvimento. - Caso você tenha algum problema para criar o repositório privado, ao término do desafio preencha o arquivo chamado
pull-request.txt
, comprima a pasta do projeto - incluindo a pasta.git
- e nos envie por email.
- Caso você tenha algum motivo para não submeter um pull request, crie um repositório privado no Github, faça todo desafio na branch master e não se esqueça de preencher o arquivo
- O código precisa rodar dentro de um container Docker.
- Para executar seu código, deve ser preciso apenas rodar os seguintes comandos:
- git clone $seu-fork
- cd $seu-fork
- comando para instalar dependências
- comando para executar a aplicação
Critério de avaliação
- É executado conforme esperado: O passo-a-passo pedido para rodar a aplicação funciona?
- Organização do código: Separação de módulos e organização do projeto (back-end e front-end).
- Clareza: O README explica de forma resumida qual é o problema e como pode rodar a aplicação?
- Assertividade: A aplicação está fazendo o que é esperado? Se tem algo faltando, o README explica o porquê?
- Legibilidade do código É fácil ler e entender o código? Existem muitas variáveis/funções com nome enigmático? Comentários no código ajudam a explicar o fluxo?
- Segurança: Existe alguma vulnerabilidade clara?
- Cobertura de testes Qualidade e cobertura dos testes (não esperamos cobertura completa).
- Histórico de commits Qualidade e estrutura dos commits.
- UX: A interface é de fácil uso e auto-explicativa? As rotas/métodos da API são intuitivos?
- Escolhas técnicas: A escolha das bibliotecas, arquitetura etc, é a melhor escolha para a aplicação?
Dúvidas
Quaisquer dúvidas que você venha a ter, consulte as issues para ver se alguém já não a fez e caso você não ache sua resposta, abra você mesmo uma nova issue!
Boa sorte e boa viagem! ;)