In this challenge, you will need to build the frontend for a simple login page.
Currently, the page just consists of a Header and a body containing some text. We need to spruce this page up a little ✨
Note: We do not expect anyone to complete this assessment. It is made to simulate a mini assignment and might be overwhelming for some. However, if you do end up submitting something, you can bet that we will take under HEAVY consideration. You might also learn something new and interesting from it.
Specifications • Extension • Getting Started • Submission
Once you have got the frontend up and running, you will notice that on the Header, there is a text that says "Vue is Fun". Your task here is to change it so that it says "Vue is Mega Fun" or "Vue > React".
No personal project is complete without a footer that says "Made with love..." am I right? Your task is to make a footer that is positioned at the bottom of the page regardless of where the user currently is on the page. It is up to you how you want this footer to look like.
- The page shall have a form which allows the user to input their username and password.
- The username field will be displayed as text while the password field will be displayed as password.
- There should be a button that says 'Login'
- When the login button is clicked, there should be a modal popup displaying the message that you will receive from the backend
- One of 2 scenarios can occur after clicking the login button:
- The user receives a status 401 response, this can happen if either the username or password field is empty or both are empty (i.e. length === 0)
- The user receives a status 200 response, this can happen if both the username and password are not empty (i.e. length > 0)
You are free to express your creativity here, the only limit is your imagination. Note that presentation will be taken into account when assessing your work.
There are a few challenges that you can attempt for those sweet extra bonus points:
The frontend has a linter set up. Make sure that your code conforms to the linter's style expectations when running the command pnpm run lint
.
Make a profile page for the user when logging in. It is up to you how you want this profile page to look like.
Hint: you may want to take a look into routing for Vue
Some of our flagship projects such as Jobs Board and Chaos uses Tailwindcss to style our components. Your task is to refactor the codebase so that it uses Tailwindcss.
You've been told that good code coverage and continuous testing is vital to the development process right? If not, it is right. In our flagship projects, you will hardly come across a piece of code that doesn't have some sort of test written for it. Well, for your task here, you will need to set up cypress to test the usability of your website. Write a simple test case that takes the user through the process of logging in. You are welcome to write more test cases if you want to 😉
If you do not have pnpm
installed, you can do so by running the command npm install -g pnpm
. Then verify it by running pnpm --version
.
Starting up the frontend
- Fork this repository into your own GitHub account.
- Navigate to the
/frontend
directory and runpnpm install
. - Run
pnpm run dev
. - Open a browser and go to the URL provided.
Starting up the backend
- In a seperate terminal, navigate to the
/backend
directory and runpnpm install
. - Run
pnpm run start
.
To make a submission, ensure that your forked repository is public and paste a link to it in your Projects Application in the relevant field. You will be assessed on the following aspects:
- Code quality
- Code style
- Use of semantic tags
- Use of meaningful class names and ids
- Presentation of website
- Functionality/Amount of tasks completed
- Linting (Extension)
- Usability tests (Extension)
- Tailwind refactor (Extension)
- User profile page (Extension)