- The following section contains a detailed text on what you need to do as part of this system test.
- Read each section carefully, do not skip any section. As part of details, we have given the acceptance criteria as well.
- If at any point, you feel like the requirement is not clear, call one of us and let us know your concern. Try not to speculate, each of us think differently.
- Please note, we scan all the PRs carefully. If we find your code to be same as any other PR, we will reject your application and you will be prohibited from participating in any future opprotunities. We take plagiarism very seriously.
- Fork this repository [see the fork icon on the top right corner of this page].
- Add regular commits and regular pushes to your forked repository.
- All the requirements i.e., among all the Must Haves and any extra features added must be mentioned in your README.md file. Other wise your pull request will not be reviewed / accepted. 4.Explain Your Code: Whenever you write a function, include comments explaining its purpose, logic, and any significant decisions made. If you use libraries or external dependencies, briefly explain why they were used and how they contribute to solving the problem. 5.Submission Video: After completing the application, record a short video (5–10 minutes) demonstrating the app's features and functionality. Highlight key features and walk us through your code structure briefly. Share the video link (e.g., Google Drive, Loom, or YouTube) along with your pull request. 6.Email Submission: Send your submission link (repository and video) personally to my emailId. Do not forward or share your submission with anyone else.
The goal of this test to see how you tackle the following:
-
Coding standard
-
Your approach on modularity of the application
-
Problem solving approach
-
Use and justification of use of standard libraries
-
Decision making
You have to build a simple todo-application with certain features listed in the following sections. While we do not require you to build a fancy user-interface, we expect you should come up with a decent and standard design. As a modern front-end developer we never liked the default HTML button or the input fields, isn’t it?
A todo-application helps you to keep track of your tasks that you want to complete on any given day/time. Please let us know if you need any further explanation on this.
Here is a sample and minimal structure of a task that we would like you to keep.
Field name | Description | UI Element | Validations (if any) | Allow Sort | Allow Search | Allow Group By |
---|---|---|---|---|---|---|
currentState | State of the task, open or done | None | By default all tasks will be set to open. Hint: Use boolean | Yes | No | No |
title | One line summary of a task | Text input | Max-length: 140 Chars Min-length: 10 Chars Accept: all | Yes | Yes | No |
description | Detail of the task | Textarea | Max-length: 500 chars Min-length: 10 chars Accept: all | No | Yes | No |
createdAt | Timestamp when the task is created | None | Should be auto-filled based on current timestamp | Yes | No | Yes |
dueDate | Target completion date and time | Datepicker | Time is optional | Yes | No | Yes |
priority | Priority of the tasks | Dropdown | None/Low/Medium/High | Yes | No | Yes |
Consider this to be a starting point. Feel free to make any enhancement in the given design. However, if we feel the choice you made is a downgrade in the existing design, you should justify it. We are suggesting this design and we consider it suits the time period you have been given.
-
Add a task button: A composer button, which we usually see at the bottom right corner of any application. The text of the button should be a plus symbol (+). For reference, see the gmail app.
-
Adding a task (add-task-form): Clicking on the + button should open a modal. A modal will have above mentioned fields. Use the following (rough) design for displaying the form inside the modal.
Summary: _____________________________________________________________
Description: ____________________________________________________________
______________________________________________________________________
______________________________________________________________________
Priority: None (default)/low/medium/high Due date: [datepicker]
[Cancel] [Save]
-
Action buttons of the form: Like all modals, this will have two buttons: i) Save Task, ii) Cancel
-
Actions:
- Save Task: When a user clicks on save button, the UI should indicate that the API call is in progress.
- Cancel: All the changes done by the user in the form should be discarded.
-
Tabs: The page should contain 3 tabs
- All tasks: this tab will contain all the tasks.
- Completed: this tab will contain only completed tasks.
- Pending: this tab will contain only pending tasks.
-
List view of the tasks: The content of each tab will be a list of tasks with following columns
Summary | Priority | Created On | Due Date | Actions
Note: The description is not displayed in this list view.
-
Actions: Icons for edit, delete, and close/open the task. See later sections for the description of these actions.
-
Global Search: Preferably on the top left-corner of the page, a text box to allow users to search within the page.
-
Group By dropdown: A dropdown to allow the current tab’s list to be grouped by selected item.
To add a task, click on the + button present at the bottom-right corner of the application. A modal will open with add-task-form.
By default the task should be treated as an open task. This task should be added at the top of the list in both “All tasks” and “Pending” tasks tabs.
Click on the task row. The modal should open read only view of add-task-form with all fields filled in it.
Note: The add form will not contain all fields, for example created on, currentState (i.e. pending or open) but the view mode will contain such details. Make sure to add those detail in view mode.
To edit a task, click on the edit icon available in the Actions column of a row. When a user clicks on the edit icon, a modal will open with add-task-form. The values of the current task will be prefilled in the form.
Note: Unlike add, on editing the position of the task in the list should not change.
To delete a task, click on the delete icon available in the Actions column of a row. When a user clicks on the delete icon, a modal will open with the task summary. The modal will also contain a question for the user: “Do you want to delete this task?”, with “Yes” and “No” action buttons.
The action buttons are self-explanatory. Check with us,if you need any help on this.
Click the done button available in the Actions column.
-
- In the all tasks lists, the style of the task should change. E.g. make the background green, or put a strikethrough in the row.
- The “done” button should change to “re-open” in the actions column.
- A copy of task should be moved to “Completed” tab.
Click the re-open button available in the Actions column.
-
This is the exact opposite of marking a task as done.
- In all tasks list, the style of tasks should become normal.
- The “re-open” button should change to “done” button.
- The task from “Completed” tab should be moved to “Pending”.
-
If a column is sortable (see the structure/configuration), clicking on the column header should sort the list based on that column.
-
If you are considering ASC as default, the first click should sort the list in ascending order.
-
If the user clicks on the column header again, the order should become descending.
-
Subsequent clicks on column header should alternate the sorting order.
-
If a user starts to type in the “Global Search” text input, perform a search on the page with the given keyword.
-
While performing search, consider the “Allow search” key specified in the configuration.
-
The search should be case-insensitive.
- When there is a match, display the matched section of the text highlighted.
-
The dropdown will contain list of attributes for which “Allow group by” has the value yes.
-
As per above mentioned structure, the group by drop down should contain
- None
- Created On
- Pending On
- Priority.
-
Sample: If the user selects Priority from the dropdown, the list should become like the following:
Summary | Priority | Created on | Due date | Actions |
---|---|---|---|---|
High | ||||
Task summary 1 | High | 12/07/2024 | 12/09/2024 | Edit |
Task summary 2 | High | 12/07/2024 | 12/09/2024 | Edit |
Medium | ||||
Task summary 3 | Medium | 12/07/2024 | 12/09/2024 | Edit |
Task summary 4 | Medium | 12/07/2024 | 12/09/2024 | Edit |
None | ||||
Task summary 5 | None | 12/07/2024 | 12/09/2024 | Edit |
Task summary 6 | None | 12/07/2024 | 12/09/2024 | Edit |
- Give us a shout, if you need any further clarification on this.
Note: Sorting, searching, highlight, and group by - all these filters should persist when user changes the tab. For example, if the user has sorted the list on priority in ASC order in Completed tab, changing to All tasks tab should maintain the order.
- If you are implementing your own modals, make sure we can close it by pressing escape key.
- Add a short-cut for focusing user on global search. For example, if user presses Shift + Ctrl + F, focus on global search input text field.
- Bulk action: Add checkbox in front of each row. Select multiple rows and perform bulk actions like delete and mark as done, mark as pending or any other applicable action.
-
We are looking for someone who can join our front-end team and get started in no time.
-
The more you showcase your knowledge on React JS and its ecosystem, the happier we will feel about you.
-
Have you used React hooks in your applications yet? If no, don’t worry about it, if yes, give it a try today. We will be glad to see it. But again, if you are not aware of it, we like the class-based components the same.
-
While we wouldn’t mind if you include bootstrap or any other library for creating UI elements like button, input, textarea etc, we would really want you to build your own components like tabs, list, modal, etc.
-
First impression is the last impression. It might not be true, but the first page we see when we run your application, will tell a lot of things about the application. So please give some time to it, and add all the required components on the page (see the list mentioned in previous sections).
-
First try to create the bare-minimum (concentrate on Must haves - I), then go on to pick and complete items listed in the next section (Must haves - II).
-
Think dynamic, low or no hardcode - we can and will go and update the values of the attributes listed in the structure in the page 1. You should save these configuration somewhere in your source code. So, if we mark “Priority => Group by => false”, the dropdown for the group by should not list Priority as an option.
Similar behaviour will be expected for other configuration items, like allow search, allow sort, etc.
Hint: Create a config file to store the configuration provided in the first section and refer to it while making a decision on searching/sorting etc.
-
We would want you to use Redux and possibly showcase the knowledge of middlewares you have.
-
Even though we are not asking you to integrate any API calls, consider the CRUD operations to be asynchronous actions. Use a redux middleware of your choice, redux-thunk, redux-saga, redux-observables, and so on.
Hint: Use setTimeout in your action creators to simulate the side-effect and asynchronous behaviour.
-
Use of a rich text editor [library of your preference] for adding description of the tasks.
-
Use the “Confirm before save” functionality. We understand that showing a modal after modal will become clumsy and this could lead to a lot of complications but if at all you are considering this feature, use native JavaScript “Confirm” pop-up.
-
Consider the case when a user is not sure about her changes. So she made changes, then reverted it. Changed priority then again moved it to the old one. Then if she clicks the save button, do we need to update this data?
Add a logic to identify this. If the data of a task has not changed on clicking the save button, do not make the API call. In short, make the API call only if the data of a task has changed.