Skip to content

Latest commit

 

History

History
83 lines (59 loc) · 3.44 KB

README.md

File metadata and controls

83 lines (59 loc) · 3.44 KB

FunMath! logo
FunGeo! Website para brincar e aprender Geografia.

demonstração do projeto

Ver Projeto

Sobre

O usuário pode explorar, favoritar e ser desafiado com os países do mundo. Para uma melhor navegação possui filtros, barra de pesquisa e paginação.

Os favoritos são salvos e persistidos no armazenamento local do dispositivo, então quando sair vai manter esses dados salvos.

Também, possui uma sessão de desafio. O algoritmo vai escolher um país aleatório, sem repetir, e o usuário terá que descobrir o nome desse país, baseando-se em informações disponíveis como: Capital, bandeira e região. O usuário tem 5 tentativas antes do desafio falhar. Por fim, é mostrado o status daquele desafio e o país selecionado atualmente vai para uma lista de países que já foram escolhidos.

Estrutura

--- src/
	-- @types: Tipagens de terceiros.
	-- components: Componentes da aplicação. Podem possuir sub-diretórios.
	-- composables: Hooks para reaproveitação de lógica.
	-- dtos: Modelagem dos dados retornados da API.
	-- functions: Funções reaproveitáveis e para uso especifíco.
	-- interfaces: Modelagem/Tipagem de dados em geral.
	-- layouts: Layouts da aplicação.
	-- router: Configurações e definições de rotas.
	-- services: Utilitários para uso de serviços externos.
	-- store: Mantém a definição dos estados globais.
	-- styles: Definição de estilos globais e utilitários SASS.
	-- views: Páginas da aplicação.

Tecnologias:

Dificuldades:

  • Passei um sufoco para atualizar a tela de resultados de pesquisa quando a query da URL mudasse. Tive que usar o :key disponível pelo Vue para forçar uma nova renderização.
  • A API não possui paginação e estava renderizando muitos elementos diretamente no documento. Com certeza, iria travar em algum dispositivo mais fraco. Então, tive a idéia de usar uma Virtual Scroll List ou fazer uma paginação direto no front. Por fim, tive que optar pela paginação, pois a outra opção não funcionou.

Prototipagem:

demonstração do protótipo do projeto

Feito com Figma

Rodando o projeto:

Você precisa ter o Node, o Git e algum gerenciador de pacotes(NPM | Yarn) instalados em sua máquina.

1. Clone o repositório:
$ git clone https://github.com/gabriellima2/fun-geo.git

2. Acesse a pasta e instale as dependências via terminal:
$ yarn || npm i

3. Inicie a aplicação em modo de desenvolvimento:
$ yarn dev || npm run dev

4. O servidor será aberto em http://localhost:5173

Projeto feito com 💙 por Gabriel Lima