Skip to content

Latest commit

 

History

History
110 lines (82 loc) · 3.64 KB

README.md

File metadata and controls

110 lines (82 loc) · 3.64 KB

Planner

Planner is a trip planning application designed to facilitate traveling with friends. From creating itineraries to inviting your friends, Planner helps ensure your travels are well-organized.

Demo gif

Features

Users can:

  • Create a new trip by selecting the destination, dates, and inviting friends.
  • Manage the trip itinerary by adding activities to each day.
  • Add useful links, such as hotel reservations.
  • Change the trip's dates and invite more friends.

When inviting friends, they will receive a confirmation email with a link to confirm their attendance.

Structure

The system is divided into two servers, which are explained in this section.

For both, you must have Node.js and npm installed.

% node --version
20.15.0
% npm --version
10.8.1

Backend

Running the server

After cloning this repository, navigate to the backend folder and install the essential packages with:

cd backend
npm i

In this directory, create a .env file and add the following environment variables:

DATABASE_URL # Used to connect Prisma to the database
API_BASE_URL
WEB_BASE_URL
PORT         # API port

Then run the following commands to generate tables in your database with prisma.

npx prisma generate
npx prisma migrate dev --name init

Finally run the server with:

npm run dev

Schema and Routes

Below is the full DB schema.

DB Schema

The API docs can be found in prisma/docs, and you can import the routes to your imsonia using insomnia-routes.

Dependencies

  • Prisma: Next-generation ORM for Node.js and TypeScript.
  • Typescript: TypeScript language support.
  • Dayjs: A lightweight JavaScript date library for parsing, validating, manipulating, and formatting dates.
  • Fastify: Fast and low overhead web framework for Node.js.
  • Nodemailer: Module to send emails from Node.js.
  • Zod: TypeScript-first schema declaration and validation library.

Frontend

Running the server

Navigate to the frontend folder and install the essential packages with:

cd frontend
npm i

In this directory, create a .env file and add the following environment variable:

VITE_GEOAPIFY_API_KEY

This key is necessary to use the geoapify autocomplete API, you can follow their tutorial to get a key api.

Finally run the application with:

npm run dev

Dependencies

  • Geoapify/react-geocoder-autocomplete: Provides a React component that wraps geocoder autocomplete for Geoapify Geocoding API.
  • Typescript: TypeScript language support.
  • Axios: Promise-based HTTP client for the browser and Node.js.
  • Date-fns: Toolset for manipulating JavaScript dates in a browser & Node.js.
  • Lucide-react: Open-source icon library
  • React: A JavaScript library for building user interfaces.
  • Tailwindcss: A utility-first CSS framework for rapid UI development.
  • Vite: A fast build tool and development server for modern web projects.