Skip to content

Latest commit

 

History

History
193 lines (124 loc) · 5.35 KB

README.md

File metadata and controls

193 lines (124 loc) · 5.35 KB

Terra Scratch

Terra Scratch is not only a travel diary application. It is a social community of travel enthusiast journaling about their feelings, experiences and adventures while exploring our beautiful planet.

Join the community today. Scratch countries you have visited off the map by creating journeys and diaries. Upload your best images and keep your memories forever. Share those valuable moments with your friends or follow them on their journeys.

In combination with its stunning 3D map of the earth, Terra Scratch offers a truly unique journaling experience.

Bon voyage.

Technologies

  • Next.js
  • Node.js
  • PostgreSQL
  • TypeScript/JavaScript
  • HTML/CSS
  • Tailwind CSS
  • Zustand state management
  • Google Gemini
  • RESTful APIs
  • Cloudinary API
  • Server Sent Events (SSE)
    • PostgreSQL's LISTEN/NOTIFY design pattern
    • EventSource
  • Jest
  • Playwright
  • drawSQL

3D Technologies

Impressions

Check out the deployed version here: https://terra-scratch.vercel.app/

Database design: https://drawsql.app/teams/myteam-1160/diagrams/finalproject

Landing page

final-project-screenshot-07

Interactive 3D globe

final-project-screenshot-01

Journey form

final-project-screenshot-04

Created journey

final-project-screenshot-02

Created diary

final-project-screenshot-03

Follower overview

final-project-screenshot-06

User profile

final-project-screenshot-05

Getting started (locally)

Clone the main branch of this repository to your local machine and navigate into the cloned project folder.

Install dependencies using pnpm

Open a CLI in the project folder and run:

pnpm install

Start database

Setup the database as mentioned below. To start the database run:

postgres

Populate database

The database is populated with migrations (using the ley library, which is a dependency of this project). Run the following command to populate the database:

pnpm migrate up

Run local development server

You can start a local development version of the project on 'localhost:3000' by running the following command. Open http://localhost:3000 with your browser to see the result.

pnpm dev

Database Setup

If you don't have PostgreSQL installed yet, follow the instructions from the PostgreSQL step in UpLeveled's System Setup Instructions.

Copy the .env.example file to a new file called .env (ignored from Git) and fill in the necessary information.

Then, connect to the built-in postgres database as administrator in order to create the database:

Windows

If it asks for a password, use postgres.

psql -U postgres

macOS

psql postgres

Linux

sudo -u postgres psql

Once you have connected, run the following to create the database:

CREATE DATABASE <database name>;
CREATE USER <user name> WITH ENCRYPTED PASSWORD '<user password>';
GRANT ALL PRIVILEGES ON DATABASE <database name> TO <user name>;
\connect <database name>
CREATE SCHEMA <schema name> AUTHORIZATION <user name>;

Quit psql using the following command:

\q

On Linux, it is best practice to create an operating system user for each database, to ensure that the operating system user can only access the single database and no other system resources. A different password is needed on Linux because passwords of operating system users cannot contain the user name. First, generate a random password and copy it:

openssl rand -hex 16

Then create the user, using the database user name from the previous section above. When you are prompted to create a password for the user, paste in the generated password.

sudo adduser <user name>

Once you're ready to use the new user, reconnect using the following command.

Windows and macOS:

psql -U <user name> <database name>

Linux:

sudo -u <user name> psql -U <user name> <database name>

Testing

To execute tests install jest for unit testing and playwright for integration testing and run the following commands in your CLI.

Jest

pnpm jest

Playwright

pnpm exec playwright test
pnpm exec playwright test --ui