This project is a frontend implementation using Vite and React for a web application.
It utilizes Zustand to manage UI state, React Query to handle remote server state, React Hook Form combined with Zod validation, and React Select for form dropdowns.
Cypress tests have been added to ensure the quality and reliability of the application's features.
It interacts with a backend standalone Natours API written in TypeScript with Node.js and Express. To ensure seamless functionality, verify that this backend API is up and running.
- Prerequisites
- Installation
- Environment Variables
- Running the Tests
- Running the Development Server
- Build
- Running the Production Server
- Live Demo 🚀
Before running this project, ensure you have the following accounts set up:
- Stripe Account: This is required for payment processing functionalities.
The Stripe account configured in this project must match the one used to create the Natours API backend. - Mapbox Account: This is used for mapping services.
To get started with this project, follow these steps:
-
Clone the repository:
git clone https://github.com/your-repo-name/api_ts_zod_fe_react_v2.git [email protected]:SiegfriedBz/vite_react_ts-natours.git cd vite_react_ts-natours
-
Install dependencies:
npm install
Create a .env file in the root directory of the project and add the following environment variables:
# Admin Email Link
VITE_ADMIN_LINK_TO=
# Natours API
VITE_API_PUBLIC_URL=http://localhost:1337 # Public URL for the Natours API
VITE_API_URL=http://localhost:1337/api/v1 # API URL for the Natours API
VITE_API_TOURS_PER_PAGE=4 # Number of tours per page for pagination
# Stripe Public Key
VITE_STRIPE_PUBLIC_KEY=
# Mapbox API Key
VITE_MAPBOX_API_KEY=
# Cloudinary Images
VITE_CLOUDINARY_CLOUD_NAME=
VITE_HERO_BG_IMG_URL=
VITE_LOGIN_BG_IMG_01_URL=
VITE_LOGIN_BG_IMG_02_URL=
VITE_LOGIN_BG_IMG_03_URL=
Run tests with Cypress:
npm run test
Start the development server:
bash npm run test
Build the project for production:
npm run build
After building the project, you can start the production server using:
npm run start
Visit the live demo of Spa-Natours deployed on Vercel.