- Project Status
- Overview
- Design Prototype
- User Experience
- Features
- Technology
- Installation
- API Collections
- VITE PWA Documentation
...
This booking system is still under development, and several features are not fully implemented. The following features are planned but not yet available in the current version:
- Full management of admin schedules in the frontend
- Users' ability to view available slots based on selected services
- Email notifications for bookings and reminders
The system works in its basic form, and more features are planned for future updates.
Salong Lumi Locks is a school project focusing on a booking system for hair salons. It allows users to book appointments with hairdressers (admins), view their bookings, and reschedule or cancel appointments.
The project is designed with ease of use, responsive design for mobile users, and clear interfaces for both users and administrators in mind.
A lo-fi prototype for both desktop and mobile views has been created to outline the basic structure and flow of the booking system. While the design is not fully completed, and some elements have deviated from the original concept, the prototype serves as a foundation for further development and refinement in the future.
You can explore the current version of the prototype in the Figma file:
The design and functionality of the booking system are informed by user feedback collected through surveys and analysis. This section includes:
- Personas: Representing key user types based on survey insights.
- Survey: Collecting opinions and preferences to shape the booking system.
- User Stories: Defining user needs and desired features.
- Sitemap: Visualizing the structure and flow of the application.
You can explore the detailed feedback and design elements in the FigJam file:
- Create an account and log in
- Book appointments based on the hairdresser's schedule and available services
- View upcoming bookings
- Booking history (in development)
- Cancel an appointment
- Reschedule appointment (in development)
- Profile management
- Change Password
- Create and manage services (e.g., haircut, coloring) with duration and price
- Create and manage work schedules with fixed time slots (30-minute intervals)
- Edit and remove slots from the schedule (in development)
- View and manage users' bookings in a calendar interface (in development)
- Manage user accounts (create, update, delete)
- Update
- Change name
- Change email
- Change role (user/admin)
- Update
- Search for users
- Calendar-based interface for bookings
- Role-based access control (user and admin)
- Dynamic availability based on selected services
- React with Vite (for fast development)
- Zustand (for state management)
- Tailwind CSS (for styling and responsive design)
- Node.js with Express (for server management and API endpoints)
- MongoDB via MongoDB Atlas (for data storage)
- Authentication and authorization with JWT (Json Web Token)
- MongoDB Mongoose (for data modeling)
- API design following REST principles
To run this project locally, follow the steps below:
- Clone the repository:
git clone https://github.com/u09-hair-salon.git
cd u09-hair-salon
- Backend-installation:
Navigate to ``backend`` folder:
cd backend
Install dependencies:
npm install
Create a .env.development file (for development) with the following environment variables:
NODE_ENV=development
MONGO_URI=<your MongoDB Atlas URI>
PORT=3000
JWT_SECRET=<your secret JWT key>
Or/and a .env.production file (for production) with the following environment variables:
NODE_ENV=production
MONGO_URI=<your MongoDB Atlas URI>
PORT=3000
JWT_SECRET=<your secret JWT key>
Start the backend-server:
npm run dev
- Frontend-installation:
Navigate to the frontend folder:
cd frontend
Install dependencies:
npm install
Create a .env file with the following variables:
VITE_API_URL=https://your.chosen.backend/api
And/Or for development
VITE_API_URL=http://localhost:3000/api
Start the frontend application:
npm run dev
- Usage
Navigate to http://localhost:5173 in your browser to start using the system.
To test the APIs, you can import Postman/Bruno API collections located in the /resources/api-collections
folder.
APIs can be seen at /resources/api-documentation
folder.
- Download the relevant JSON file from
/resources/api-collections
. - Open Postman or Bruno.
- Go to
File -> Import
and select the downloaded JSON file. - You will now be able to test all APIs directly from the tool.
This project includes a simple implementation of Vite's Progressive Web App (PWA) integration. Currently, the PWA does not support automatic updates or service worker-based updates. Users need to uninstall and reinstall the app to get the latest version when a new deployment is made.
To install the PWA on your device:
- On Desktop: In supported browsers (such as Chrome or Edge), you will see an "Install" icon in the address bar. Click the icon and follow the prompts to install the app.
- On Mobile: Open the website in a browser like Chrome on Android, then click the three-dot menu in the top right and select "Add to Home screen."
Once installed, the PWA will behave like a native app, offering a more app-like experience.
- The PWA does not automatically update when a new version is deployed.
- Users must uninstall the app and reinstall it to access the latest version.
- Automatic updates: Implementing a service worker that will handle caching and notify users when a new version is available.
- Improved user experience: Adding features like "New Version Available" prompts or automatic updates upon relaunch.