Refer to the npm Docs on how to install Node.js
and npm
.
My personal setup on GNU/Linux
involves using mise with the LTS version of Node.js
and Yarn
:
mise use -g node@lts
mise use -g yarn
On Windows
I use nvm-for-windows with the LTS version of Node.js
:
nvm install lts && nvm use lts
The instructions for installing Yarn
on Windows
or without mise
on GNU/Linux
can be found here.
Note: You may run into permission issues if you are using the official Node.js
installer on Windows
and want to use Yarn
! You may also want to remove the package-lock.json
file from the root directory of the project if you tend to use Yarn
on any operating system.
This project is using the MySQL Community Server 8.4.1 LTS
.
Read the official instructions on how to install and configure MySQL
for your operating system here.
Alternatively you can run MySQL
in a Docker
container using the provided docker-compose.yml
in the root directory of this project.
I recommend using DBeaver as a free cross-platform GUI tool to work with many databases!
The form
database is created using the following SQL Query, which is not necessary when you are using the provided docker-compose.yml
:
CREATE DATABASE IF NOT EXISTS `form`;
Create the form
table in the form
database:
CREATE TABLE form.form (
id INT PRIMARY KEY,
fname VARCHAR(50),
lname VARCHAR(50),
email VARCHAR(100),
department VARCHAR(50),
subject VARCHAR(100)
);
Insert some sample data into the form
table:
INSERT INTO form.form (id, fname, lname, email, department, subject)
VALUES (1, 'Maria', 'Fisher', 'mariafisher@example.com', 'sales', 'Inquiry about your services');
The user
database is created using the following SQL Query, which is not necessary when you are using the provided docker-compose.yml
:
CREATE DATABASE IF NOT EXISTS `user`;
Create the user
table in the user
database:
CREATE TABLE user.user (
id INT PRIMARY KEY,
fname VARCHAR(50),
lname VARCHAR(50),
email VARCHAR(100),
department VARCHAR(50)
);
Insert some sample data into the user
table:
INSERT INTO user.user (id, fname, lname, email, department)
VALUES (1, 'James', 'Smith', 'jamessmith@example.com', 'hr');
You will also need to create an .env
file in the root directory of this project with the following key-value pairs:
DB_HOST=localhost
DB_USER=root
DB_PASSWORD=!1234567890-The-Password-You-Decided-To-Choose-While-Creating-The-Database-?0987654321
DB_1=form
DB_2=user
-
Clone the repository and change the current working directory in the terminal to it and install the dependencies with
npm i
oryarn install
. -
After successful installation run the startup script with
npm run start
oryarn run start
. -
To hack on the project you may want to install the development dependencies with
npm i --include=dev
oryarn install --include=dev
and then execute the script withnpm run start-dev
oryarn run start-dev
.
-
Clone the repository, change the current working directory in
Powershell
or theCommand Prompt
to it and install the dependencies withnpm i
oryarn install
. -
After successful installation run the startup script with
npm run start-win
oryarn run start-win
. -
To hack on the project you may want to install the development dependencies with
npm i --include=dev
oryarn install --include=dev
and then execute the script withnpm run start-dev-win
oryarn run start-dev-win
.