Skip to content

ARoSistemas/agendar_canchas

Repository files navigation

canchas_aro

Agendamiento de canchas - Demo

Getting Started

Me han solicitado realizar una demo para evaluar mis conocimientos en dart y flutter así que, esta fue mi propuesta.

Tiempo para entrega: 3 dias aprox.

Los requerimientos fueron:

El objetivo de esta prueba es hacer una aplicación Flutter que una persona pueda utilizar para manejar el agendamiento de tres canchas de tenis. Los requisitos son los siguientes:

  1. Cada cancha puede ser agendada máximo tres veces en un día específico.

  2. La aplicación debe almacenar la información del agendamiento localmente en la aplicación, si la aplicación es removida del celular entonces la información se pierde.

  3. Las tres canchas que se pueden agendar son la A, B y C.

  4. En la pantalla principal debe mostrar todos los agendamientos ordenados por fecha, donde el primero debe ser el próximo agendamiento. La lista debe mostrar el nombre de la cancha, la fecha y el nombre del usuario que realizó el agendamiento. También debe mostrar el porcentaje de probabilidad de lluvia para este día, más detalles luego. El elemento de la lista debe poseer un botón para borrar el agendamiento, al hacer clic debe mostrar un mensaje que confirme si desea borrar el agendamiento.

  5. Debe tener un botón que permita agregar un agendamiento. La pantalla para agregar el agendamiento debe permitir seleccionar la cancha, y fecha del agendamiento y el nombre de la persona realizando el agendamiento. Se debe validar que para esa fecha la cancha aun posee disponibilidad. Al seleccionar la fecha debe mostrarle el porcentaje de probabilidad de lluvia para ese día.

  6. La aplicación debe estar escrita en Dart. Para el manejo de los estados entre widgets puede usar bloc o providers, con el que se sienta más cómodo.

  7. Utilizar un patron o arquitectura de desarrollo para la organización y estructura del proyecto (+ si es basada en Clean Architecture)

  8. En cuanto al diseño puede ser creativo. Algo simple, pero amigable.

  9. Implementar unit tests. Para consultar el porcentaje de probabilidad de lluvia, puede consultar diferentes servicios REST que son gratuitos o con una quota. Puede asignarle a cada cancha la misma ubicación pues están una al lado de la otra. Un ejemplo de uno de estos API es https://darksky.net/dev/ docs, pero puede utilizar cualquier otro API que provea la información.




Notas:

  • Tuve que redactarlo de otra forma para que lo entendiera:

    Los requisitos son los siguientes:

  1. En la pantalla principal se debe mostrar: a. Una lista donde todos los agendamientos estén ordenados por fecha, en orden ascendente.

    b. La lista debe mostrar: i. Nombre de la cancha. ii. Fecha del agendamiento iii. Nombre del usuario que realizó el agendamiento. iV. Porcentaje de probabilidad de lluvia para este día.

c. Cada elemento de la lista debe poseer un botón para borrar el agendamiento, i. Al tocar dicho botón, debe mostrar un mensaje que confirme si desea borrar el agendamiento.

  1. Las tres canchas que se pueden agendar son la A, B y C.

  2. Cada cancha puede ser agendada máximo tres veces en un día específico.

a. Si el numero de elementos es igual a 3 en la fecha seleccionada, mostrar que no existe disponibilidad.

  1. Debe tener un botón que permita agregar un agendamiento.

    a. La pantalla para agregar el agendamiento debe permitir seleccionar la cancha, fecha y nombre del usuario. b. Se debe validar que para esa fecha la cancha aún posee disponibilidad. c. Al seleccionar la fecha debe mostrarle el porcentaje de probabilidad de lluvia para ese día. d. Validar que la fecha sea mayor o igual a la actual para proceder.

  2. La aplicación debe almacenar la información del agendamiento localmente en la aplicación, si la aplicación es removida del celular entonces la información se pierde.

La api recomendada no estae en funcion, tuve que utilizar otra, el detalle aquí es que la probabilidad de lluvia siempre la manda en 0, quizas por el tema de ser FREE, así que uso el campo humedad donde si devuelven valores diferentes.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published