¡Gracias por participar en el desafío iOS de Concrete! Estamos muy contentos por tu primer paso para formar parte de un equipo excepcional.
Debes crear una aplicación sobre películas, usando la API de TheMovieDB.
Para tener un estándar y un layout minimamente definido adjuntamos algunos assets que te van a ayudar a desarrollar la aplicación:
Piensa en el desafío como una oportunidad de mostrar todo tu conocimiento. ¡Hazlo con calma! porque tienes una semana para entregar.
Dentro de los elementos que vamos a evaluar se encuentra:
- Consumo de APIs
- Persistencia de datos (Favoritos)
- Lógicas de filtros y búsquedas.
- Estructuración de layout y flujo de aplicación.
Los únicos requisitos previos para este desafío es que el código se haga en Swift (ojalá en su última versión) y utilizando UIKit (SwiftUI por ahora no es requerido). Eres libre de:
- Utilizar o no usar bibliotecas externas con el gestor de dependencias de tu preferencia (Cocoapods, Carthage, Swift Package Manager)
- Crear o estructurar tus vistas con Storyboards, Xibs o ViewCode.
- Adoptar la arquitectura que más te acomode y utilizar los patrones de diseño que desees.
Estamos especialmente preocupados por la calidad. Creemos que los patrones de diseño, pruebas automatizadas y la integración contínua son aspectos importantes. Sin embargo, sabemos que éstos no son tópicos dominados por todos y debido a eso hemos estructurado el desafío en varios niveles, los cuales van incrementando en dificultad. Esto implica que un postulante Senior debería ser capaz de completar más niveles.
- Haz un un fork de este repositorio. No lo clones directamente ni intentes hacer push a este repositorio.
- Desarrolla tu proyecto en tu fork. Eres libre de crear/modificar/borrar las ramas que desees.
- Al momento de hacer commit, sube los cambios a tu fork.
- Por la interfaz de GitHub, haz un pull request a este repositorio.
- En el pull request copia y pega la sección Requerimientos de este archivo y actualiza las cosas que hayas podido completar.
- Si pudiste completar algún aspecto específico de alguna de las partes, por ejemplo, de la parte 5, pero no terminaste todo lo que se pedía, no hay problema en marcarlo.
Si tienes alguna consulta, no dudes en preguntarnos :)
Orlando Velasco
(El desarrollo fue realizado durante el sabado y domingo, dias previos solo definiciones de proyecto. Para analisis de trazabilidad consultar https://github.com/orvenuevo1/ios-recruiting-hsa/tree/main)
El proyecto de aplicación iOS desarrollado en SwiftUI que se centra en la visualización y gestión de películas. A continuación, se presenta una descripción general de su estructura y componentes principales:
Modelos:
- Genre.swift: Define el modelo para los géneros de películas.
- GenreResponse.swift: Modelo para la respuesta de la API de géneros.
- Movie.swift: Define el modelo principal para las películas.
- MoviesResponse.swift: Modelo para la respuesta de la API de películas.
Vistas:
- ContentView.swift: Vista principal de la aplicación.
- MovieView.swift: Vista que muestra la lista de películas.
- MovieDetailView.swift: Vista detallada de una película específica.
- FavoriteMoviesView.swift: Vista que muestra las películas favoritas del usuario.
- SearchBarView.swift: Componente de barra de búsqueda.
- MovieCardView.swift: Componente de tarjeta para representar una película en la lista.
- FavoriteCardMovieView.swift: Componente de tarjeta para representar una película favorita.
Componentes:
- ImageView.swift: Componente para la carga y visualización de imágenes desde una URL.
Gestión de Datos:
- MovieViewModel.swift: ViewModel asociado con MovieView.
- FavoriteMovieManager.swift: Gestor para las operaciones relacionadas con las películas favoritas.
- CoreDataManager.swift: Gestor para las operaciones de la base de datos Core Data.
- GenreManager.swift: Gestor para las operaciones relacionadas con los géneros de películas.
- KeychainManager.swift: Gestor para las operaciones relacionadas con Keychain.
- UserDefaultsManager.swift: Gestor para las operaciones relacionadas con UserDefaults.
Servicios:
- APIManager.swift: Gestor de API para realizar solicitudes a la API de películas.
- Constants.swift: Contiene constantes utilizadas en toda la aplicación.
Workers:
- MoviesWorker.swift: Worker asociado con la funcionalidad de películas.
- GenreWorker.swift: Worker asociado con la funcionalidad de géneros.
- Pantalla de Splash
- Pantalla con una grilla de películas populares. Para ello debes usar esta API (Se usó el endpoint de Top Rated)
- Tratamiento de errores y presentación de flujos de excepción:
- Error genérico
- Cargando
- Al hacer clic en una película de la grilla debe dirigirse a la pantalla de detalle de la película. Esta pantalla debe contener:
- Nombre de la película
- Año de estreno
- Sinopsis
- El nombre del género de la película y no su ID (ej: Action, Horror, etc). Para ello, debes utilizar esta API.
- Selección de películas favoritas
- La acción para poner como favorita una película debe estar en la pantalla creada en el nivel 2.
- La información sobre las películas favoritas debe ser persistente, es decir, debe guardarse entre sesiones de la aplicación.
- Lista de películas favoritas:
- Borrado de películas favoritas desde la lista.
- Layout en pestañas:
- En la primera pestaña debes mostrarse la pantalla creada en el nivel 1.
- En la segunda pestaña debes mostrar la lista de películas favoritas.
- Mejoras a la grilla de películas populares:
- Scroll infinito.
- Mostrar si una película es favorita o no en cada celda de la grilla.
- Búsqueda local (filtrar por algún término).
- Pantalla de filtro con selección de fecha de lanzamiento y género:
- Sólo debe ser accesible desde la pantalla de favoritos.
- Al aplicar el filtro, debes volver a la pantalla de favoritos y hacer un filtro local usando la información seleccionada referente a la fecha de lanzamiento y el género.
- Soporte para rotación y iPad.
- Pruebas unitarias en el proyecto.
- Pruebas de snapshot.
- Pruebas de UI.
- Uso de SwiftLint.
- Uso de fastlane para generar binarios.
- Integración del repositorio con un servicio de integración continua como Bitrise o AppCenter. No existe problema en usar otra plataforma, pero esta debe estar disponible online (un jenkins local no cuenta).
- Integración de un servicio de análisis de código como SonarCloud.
A continuación puedes ver algunas pantallas de ejemplo de algunos flujos. Son sólo sugerencias, pero puedes modificarlas a tu gusto. Para facilitar el proceso, tienes assets, iconos de aplicación y paleta de colores en el repositorio. Pero si su lado diseñador habla más alto ¡puedes sorprendernos!