Este aplicativo tem o objetivo de otimizar buscas de séries com uma interface pensada na experiência do usuário seguindo a Human interface guidelines (HIG), me organizei para realiza-lo em 2 semanas.
- Lista todas as séries fornecidas pela API
- Buscar todas as series por nome
- Informações da série: episódios, resumo, programação da série, gênero.
- Informações dos episódios: nome, número, temporada e resumo do episodio.
- Permite favoritar séries que ficam disponiveis para serem consultadas a qualquer momento.
- Sistema para configuração de PIN (6-digitos) e bloqueio por, se compatível com o modelo, FaceID ou TouchID.
Foi utilizado o padrão arquitetural MVVM para este projeto pensando na complexidade e facilidade na realização de testes e reuso de código, como padrão de navegação foi utilizado o coordinator, seus beneficios como reuso e manutenabilidade estão descritos em: Navegando com coordinators
Também utilizei o padrão Repository, pensando que, caso queira salvar dados em algum outro banco ou simplesmente decidir trocar a forma como estão sendo salvo os dados, poderia ser facilmente alterado através do repository facilitando ainda mais uma possivel manuntenção de código.
Cada tela é descrita dentro da pasta Scene e possui uma view(components em viewCode que iram ser apresentados na tela), uma viewModel(onde irá conter a logica de negócio e handler de eventos) e por fim uma controller(responsável por inicializar a view e os eventos da viewmodel)
- Na prototipagem decidi colocar as coisas basicas que vinha a minha mente com relação aos requisitos.
- Foi pensado na utilização de ViewCode com criação de componentes reutilizaveis como as células de tableView e Componentes de texto. e utilizei como base todas as dimensões aqui previamente testadas.
- Nesta etapa, estudei um pouco sobre como seria a transição da tela de shows para a tela de detalhes, segundo a HIG, isso não deve ser feito em uma modal caso você ainda vá realizar outras tarefas como por exemplo visualizar um episódio, mesmo algumas streamings de video fazendo esse percurso, decidi depois, voltar ao padrão mais comum ao usuário iOS que é uma pushViewController.
- Suporta darkmode ou white mode, componentes reutilizaveis, e utilização de auto-layout.
- Loading durante as chamadas de API.
- Fade-in de posters ao carregar.
- Feedback ao favoritar um item.
- Feedback de error ao colocar um PIN incorreto.
Foi utilizado a a api http://www.tvmaze.com/api para realizar as requisições, criei uma camada de network para realizar requisições gets, e criei um router para gerar as urls, com isso, fica super fácil criar uma nova requisição que ficam na classe TVMazeAPI.
Para realizar a persistência dos dados foi utilizado CoreData pelas facilidades de ser um framework nativo e trazer diversos beneficos de performace, eu criei modelos DAO no CoreData para gerenciar os objetos e uma classe reponsavel por gerenciar o container que serão salvos as series que forem favoritadas.
Implementei o desbloqueio de faceID ou TouchID Dependendo do dispositivo e adicionei o bloquei por PIN Code de 6 digitos, Foi utilizado o próprio framework de Seguraça e o KeyChain para guardar o codigo a ser salvo.
Após clonar o projeto, nenhuma configuração é necessária, basta abrir o arquivo TVShowAPP.xcworkspace, e executar o comando no diretorio raiz.
$ pod install
- Utilizei frameworks para otimizar o meu tempo com animações de imagem e caching com o Nuke.
- Utilizei o SnapKit para facilitar a escrita do autolayot.
Foi utilizado o swift lint como Style Guide de código do projeto com as configurações padrões.
Realizei testes para cada lógica feita nos arquivos de ViewModel e em algumas classes auxiliares como a de Keychain para verificar se os dados estão sendo salvos corretamente.