- Implementar un módulo faltante mediante la reutilización del código generado por Hilt.
- Demostrar la imagen default en la lista de elementos.
Llegó el momento de agregar el módulo de Planetas a la app. Los requerimientos de este reto son los siguientes:
- Para hacerlo crea un nuevo Activity llamado PlanetsActivity. Este debe realizar la llamada al servicio de Planets y debe mostrar los resultados. Asimismo, mantén la estructura y utiliza la inyección de dependencias.
- Agrega el nuevo módulo Planets. El usuario debe tener a su disposición la opción de elegir People o Planets. Al hacer clic sobre alguna de ellas deben realizarse las llamadas e importaciones necesarias para consultar el API y mostrar la lista de resultados. Además, la lista debe tener habilitado el swipeRefresh.
- Una vez que hayas implementado el servicio, crea una dependencia que contenga una imagen de Star Wars; puedes agregar el base64 o la URL. Inyecta esta imagen y después debes asignarla a la lista para que todos los elementos muestren esa imagen.
Las propuestas de solución son:
Solución 1 - 2
Agregar ResponsePlanetModel con los datos del Json. Nueva función a ApiHelper.
suspend fun getPlanets(): Response<ResponsePlanetModel>
ApiService
@GET("planets")
suspend fun getPlanets(): Response<ResponsePlanetModel>
Override a ApiHelperImpl
override suspend fun getPlanets(): Response<ResponsePlanetModel> = apiService.getPlanets()
MainRepository
suspend fun getPlanets() = apiHelper.getPlanets()
Copiar paquete main.people a main.planets y modificar las referencias de People por Planets.
Solución 3
ApplicationModule
@Singleton
@Provides
@Named("provideImage")
fun provideImage() = ""
Modificar en PeopleAdapter y en PlanetsAdapter para que reciban el imagePath en el constructor y lo envíen como parámetro a cada elemento.
class PlanetsAdapter(
private val planet: ArrayList<Planet>,
private val imagePath: String
) : RecyclerView.Adapter<PlanetsAdapter.DataViewHolder>() {
…
fun bind(model: Planet, imagePath: String) {
itemView.textViewUserName.text = model.name
itemView.textViewUserEmail.text = model.population
Glide.with(itemView.imageViewAvatar.context)
.load(imagePath)
.into(itemView.imageViewAvatar)
}
…
holder.bind(planet[position], imagePath)
Inyectar dependencia en PlanetsActivity y en PeopleActivity.
@Inject
@Named("provideImage")
lateinit var provideImage: String
Enviar dependencia inyectada al inicializar el constructor.
adapter = PeopleAdapter(arrayListOf(), provideImage)
adapter = PlanetsAdapter(arrayListOf(), provideImage)
Siguiente (Postwork)