Skip to content

autay27/card-app-typescript-test

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Integrum ESG interview - Card App 🎴🃏

Simple card app created with Typescript Stack Converted to a test from the original

Prerequisites

NodeJS - if you don't already have it installed, check out nvm.

Development set-up

If you don't have a favorite editor we highly recommend VSCode.

Recommended VSCode extensions:

Instruction to candidates

Your assignment is to improve this application. At the moment the application is simple and can only create and remove todos.

Fork this project into your own on github

Clone it onto a machine with node and a development environment (we use VScode) Follow the instructions below to run the back end and the front end.

Then make changes to:

  • Add a dark mode. Create a settings dialog to set it - and change the styling to render a dark mode. Consider how the current setting is passed to the components (and describe it in your covering email)
  • Add a scheduled date to the cards. This involves adding a column in the database, changing the backend service and changing the frontend card entry and display components
  • Add tests to the backend. There are some clues here and here.

If you feel constrained by time (which is totally fine!), prioritize quality over quantity.

Email us the link to your repo when you're done. Please also include a short write up describing the rationale of the changes you have made.

Features

  • Mutiple Routes for each action.
  • Local Backend Database
  • You can View, Create, Update, Delete simple cards.

Stack

Front End

  • React ⚛
  • React Router DOM 🔀
  • Tailwind CSS 🐦

Back End

  • Fastify 🚀
  • Prisma ORM 🅿
  • SQLite ▪

Deploy

Git hooks are used to automatically format committed files. To setup the hooks run:

npm i

The front end works in port 3000 and the backend works in the port 3001.

Back End

npm install

npm run prisma-setup

npm start

To have the backend restart when changes have been made to .ts, .prisma and .sql files:

Replace npm start with npm run dev

To run the tests:

npm run test

Front End

npm install

npm start

To deploy a final build with static files:

npm run build

cd ./dist

npx serve -p 3000 -s

About

Full stack coding exercise

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 95.6%
  • HTML 2.5%
  • JavaScript 1.2%
  • Other 0.7%