Test Assignment for UpLab Boot Camp 3
Welcome to the UpLab Boot Camp. This is the test assignment for you to get your brains prepared before the course. The number of places is limited, so the purpose of this test assignment is to choose the best candidates that are able to understand and complete tasks of different complexity.
The test assignment is a simple todo list application that allows you to create your own list that is saved in your browser memory. The application is supposed to perform the following actions:
- add a new task
- set a due date for a task
- see a list of todos
- mark todo as completed
- remove todos
- see all the todos along with completed
- use categories to group todos
In the daily life, programmers should fix bugs before adding features. Who is willing to use an application full of bugs, but with tons of features? That's why it is mandatory to complete all the bugs from the list.
Tasks list is a list of new features that should be added to the working application. It should allow you to choose an order, pick only the features that you can implement. Even one implemented task counts, but we will pick students among the ones who get the most points. Please take a note that different tasks have different number of points.
Important: partial task solution doesn't count. Solutions with critical bugs don't count - test your code.
- Create a private mirror of this repo in your GitHub account to avoid exposing your code and invite
brmk
as a collaborator (Settings -> Collaborators). You can learn how to do it here: https://help.github.com/articles/duplicating-a-repository/ - Setup your environment (please see Environment section for versions in the end of this file)
- Install npm dependencies with command
npm i
oryarn
- Start the app
npm run start
oryarn start
- Please try to have 1 commit per task/bugfix. When you complete your task, do not forget to mark it as completed in the list below. Just put an
x
into the checkbox between braces (- [ ]
- unchecked,- [x]
- checked ). - Do not forget to constantly push your changes.
- When you finish your assignment, please send an email to [email protected] with the link to your GitHub repo and a list of finished tasks.
We only accept your assignments in the GitHub. Do not send us any zip archives with your projects!
We recommend you to use VSCode while working on your assignment and install an ESlint extension from market to quickly see the syntax errors and other recommendations.
Have a question? Please, do not hesitate to contact us at https://instagr.am/uplab.life or by email [email protected]
- B1. Bug: status filter button displays on top of the calendar view when selecting due date of a task
- B2. Bug: the app crashes after adding a new todo
- T1. Change a favicon and title of the app into something cool. 1 point
- T2. Highlight due dates in the todo list with different colors. 4 points Requirements:
- Green - the task's due date is 2+ days from today or the task is already completed.
- Yellow - the task's due date is <2 days from today or today
- Red - the task's due date has already passed
- T3. Highlight the currently selected category in the sidebar with bold text 2 points
- T4. Allow user to delete any category created by him (category.readonly is false). Note: delete all todos in this category as well. 6 points
- T5. Allow user to edit category name of categories created by him (category.readonly is false) 6 points
- T6. On the "All" category page for each category display a separate card with the todos that belong to this category (to make this task easier, you can hide the filter and show only Open todos for each category only on this page). 8 points
- T7. Adapt the app to be usable on mobile (add a sidebar toggle button) 4 points
- T8. Deploy your demo app on Netlify or another hosting 4 points Links:
- T9. Drag'n'drop to do list item into another list in desktop version 10 points
- https://github.com/atlassian/react-beautiful-dnd
- https://egghead.io/lessons/react-reorder-a-list-with-react-beautiful-dnd
Note: you can do some extra stuff even if you completed 0 tasks here. Please write about it somewhere and we will add extra points to your application and we may add you extra points!
- JS fundamentals - https://www.codecademy.com/learn/introduction-to-javascript
- Intro to React - https://reactjs.org/tutorial/tutorial.html
- React Crashcourse 2021 - https://www.youtube.com/watch?v=w7ejDZ8SWv8
- ES6 - https://medium.freecodecamp.org/want-to-learn-es6-take-this-free-23-part-course-and-become-a-javascript-ninja-55002db1ff74
- How to Learn React — A roadmap from beginner to advanced - https://medium.freecodecamp.org/learning-react-roadmap-from-scratch-to-advanced-bff7735531b6
- Node.js v12.16.3 (nvm)
- npm - v6.14.4 (you can use yarn instead of npm)
The app should work in Node 8, 10, 12, 14 as well
This project was bootstrapped with Create React App.
In the project directory, you can run:
Runs the app in the development mode.
Open http://localhost:3000 to view it in the browser.
The page will reload if you make edits.
You will also see any lint errors in the console.
Runs eslint and fixes auto-fixable problems
Only runs eslint without auto-fix
Runs tests