Code Monkey home page Code Monkey logo

proyecto3's Introduction

Proyecto3 - CrossFitAPP V1.0

Descripción

En este proyecto creamos una aplicación para un Box de Crossfit para que sus usuarios puedan reservar las clases diarias, llevar un registro de sus marcas personales, ver WODs famosos y pagar la cuota mensual.

Existirán dos tipos de usuarios. Administrador y usuario cliente. Cada uno de ellos podrá hacer lo siguiente:

  • Administrador:

    • Gestión de usuarios: El administrador es el encargado de crear los usuarios clientes. Cuando cree un usuario nuevo, se enviará vía email una invitación al usuario para que entre a la aplicación con las credenciales recibidas comunicándole que modifique la contraseña. También puede eliminar cuentas de usuario

    • Gestiona las clases: Es el encargado de crear el calendario de clases en el que incluirá la fecha, la hora y el número de personas que pueden apuntarse

    • Gestiona el entreno diario: Crea el entreno diario que se mostrará al usuario cuando vaya a reservar una plaza de la clase.

    • Gestiona el apartado Marcas Personales: Crea los nombres de ejercicios en los cuales el usuario introducirá sus resultados

  • Usuario cliente: El usuario recibirá vía email una invitación por parte del propietario para que acceda a la aplicación utilizando las credenciales que le llegan y teniendo que cambiar la contraseña una vez entre.

    • Perfil: En el que podrá modificar su nombre, apellido, foto y contraseña. También podrá eliminar su cuenta

    • Reserva de clases: Se verá el listado de clases del día para elegir la hora que más le convenga, la descripción del entreno del día y el listado (foto) de usuarios que ya estén apuntados (si los hubiera). Habrá un botón de “Reservar” en cada hora. En caso de que estés apuntado en una clase aparecerá el botón “Borrar” para quitarte de la clase.

    • Marcas Personales: En este apartado el usuario podrá llevar el registro de su progresión en cuando a “pesos”. Una vez dentro existe un listado de ejercicios introducidos por el usuario administrador en el que entrando en cada uno de ellos podemos añadir tantas veces como queramos: Fecha, repeticiones y peso. De esta forma cuando haya datos y entremos en un ejercicio en concreto se verá el listado de las notas que hayamos añadido.

    • Pagos: Para que el usuario cliente pague la mensualidad

    • Salir: Para “desloguearse” de la aplicación

Descripción técnica

Rutas de USUARIO (UserRouter.js)

  • Usuario Administrador

    • Registrar usuario: “/register” – El Administrador de la aplicación registrará los usuarios introduciendo un nombre, apellido, email y contraseña. Una vez creado, al usuario le llegará un correo electrónico con los datos de acceso.
  • Usuario

    • Loguear un usuario: “/login” – Los usuarios se loguearán para acceder a la aplicación introduciendo el email y contraseña que han recibido por email.
    • Ver perfil de usuario: “/profile” – Los usuarios pueden ver los datos de su perfil
    • Modificar perfil de usuario: “/updateProfile” – Se podrán actualizar los datos del perfil
    • Subir imagen de perfil: “/upload” – Se utilizará para subir la foto de perfil de usuario.
    • Eliminar un usuario: “/deleteUser” – Los usuarios podrán eliminar su cuenta de la base de datos

Rutas de WOD (WodsRouter.js)

  • Usuario Administrador

    • Crear un WOD: “/createWod” – Se crearán entrenos que van en un apartado para que los usuarios puedan consultarlos.
    • Actualizar WOD: “/updateWod/:id” – Se podrá actualizar el WOD que se haya pasado su ID por params.
    • Eliminar un WOD: “/deleteWod/:id” – Se eliminará el WOD que hayamos pasado su ID por params.
  • Usuario

    • Listar WOD: “/wodsList” – Los usuarios podrán ver todos los wods que estén creados

Rutas de CLASES (ClassesRouter.js)

  • Usuario Administrador

    • Crear una clase: “/createClass” – Se podrá crear una clase indicando la fecha y el entreno de día
    • Modificar una clase: “/updateClass/:id” – Se podrá modificar la clase que hayamos indicado por params su ID.
    • Eliminar una clase: “/deleteClass/:id” – Se eliminará la clase que hayamos introducido su ID por params
  • Usuario

    • Listar Clases con horario: "/classesList/:id" - Se podrá listar la clase que pasemos su ID por params y veremos los datos de la clase y sus horarios.

Rutas de Horarios (TimeTableRouter.js)

  • Usuario Administrador
    • Crear un horario: "/createTime/:dateID" - Se crea un horario para una fecha de clase específica que pasaremos por params y el número de personas que podrán apuntarse a la clase.
    • Modificar horario: "/updateTime/:id" - Se modifica el horario o el número de personas de la clase pasando su ID por params.
    • Eliminar horario: "/deleteTime/:id" - Se elimina el horario pasado por params.

Rutas de Ejercicios (ExercicesRoutes.js)

  • Usuario
    • Crear ejercicio: "/createExercice" - El usuario creará diferentes ejercicios por nombre para posteriormente añadir sus marcas personales a él.
    • Modificar un ejercicio: "/updateExercice/:id" - Introduciendo una ID de un ejercicio por params podremos modificarlo.
    • Eliminar un ejercicio: "/deleteExercice/:id" - Se eliminará el ejercicio con la ID que pasemos por params.
    • Listar ejercicios de un usuario. "/exercicesUser" - Se identifica la ID del usuario logueado, a continuación se busca en el modelo de usuario si existe esa ID y si existe busca en el modelo de ejercicios si hay ejercicios asociados a esa ID. Finalmente muestra el usuario y todos los ejercicios que tenga asociados.
    • Listar ejercicios: "/marksUserList/:id" - En esta ruta pasaremos por params la ID de un ejercicio para que nos muestre todas las marcas asociadas al ejercicio.

Rutas de Marcas (MarksRouter.js)

  • Usuario
    • Crear una marca: "/createMark" - Se creará una marca para el ejercicio que seleccionemos donde podremos introducir la fecha, las repeticiones del ejercicio, el peso y un comentario.
    • Eliminar una marca: "/deleteUserMark/:id" - A través de params pasaremos la ID de una marca para eliminarla.

Rutas de Reservas (BookingRouter.js)

  • Usuario
    • Nueva Reserva: "/newBooking" - En esta ruta a través del token de usuario se identifica su ID y realiza la reserva asociandola a una ID de Clase y a una ID de horario.
    • Eliminar Reserva: "/deleteBooking/:id" - A través de la ID de reserva pasada por params se eliminará la reserva quedando disponible para otro usuario.
    • Listar Clases con usuarios apuntados: "/bookingList/:id" - Introduciendo por params una ID de clase se mostrará la clase con todos sus horarios y con los usuarios con reserva. Esto se realiza ya que se busca la ID introducida en los modelos de Clases, horarios y reservas.

proyecto3's People

Contributors

manuelfdezf avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.