Final Project Report 20bcs1330
Final Project Report 20bcs1330
To-do List
A PROJECT REPORT
Submitted by
Avinash Yadav(20BCS1330)
Selendra Kumar(20BCS9960)
Yashveer
Choudhary(20BCS9934)
BACHELOR OF ENGINEERING
IN
Chandigarh University
MAY 2022
lOMoARcPSD|25191579
BONAFIDE CERTIFICATE
Certified that this project report To-do list is the bonafide work of Avinash Yadav,
Selendra Kumar and Yashveer Chaudhary who carried out the project work
under my/our supervision.
Acknowledgement
In successfully completing this project, many people have helped us. We would
like to thank all those who are related to this project.
Finally, we would like to thank our parents and friends who have helped me with
their valuable suggestions and guidance and have been very helpful in various stages
of project completion.
TABLE OF CONTENTS
1. Title Page 01
2. Bonafide Certificate 02
3. Acknowledgement 03
4. Table of Contents 04
5. List of Figures 05
6. List of Tables 06
7. Abstract 07
8. Graphical Abstract 08
9. Abbreviations 10
10.Symbols 11
11.Chapter 1: Introduction 12
12.Chapter 2: Literature survey 18
13.Chapter 3: Design Flow/Process 27
14.Chapter 4: Results analysis and validation 35
15.Chapter 5: Conclusion and future work 38
LIST OF FIGURES
List of Tables
ABSTRACT
A to-do list is a list of tasks that need to be completed, typically organized in order
of priority. It is one of the simplest solutions for task management and provides a
minimal and elegant way for managing tasks a person wishes to accomplish.
Our aim is to design a simple and elegant website for people to keep a track of the
status of their tasks. Making a to-do list is an easy and important task that everyone
should do. The immense satisfaction that one gets when completing the task and
marking it on the list are incomparable. Moreover, creating a list of tasks ensure you
don’t miss out on anything. It’s a scientific fact that when you write the tasks that you
need to complete, you are even more motivated to complete it. With this in mind, we
come to build a platform which will help people create their own task list.
With the help of modern tools and technologies, we strive to build a minimal
and efficient to-do list which minimizes distractions and helps people achieve
task management with ease and without hassle.
GRAPHICAL ABSTRACT
ABBREVIATIONS
Abbreviations Definitions
1. 3D Three Dimensional
2. API Application Programmable Interface
3. B.E. Bachelor of Engineering
4. CSS Cascading Style Sheets
5. DFM Design for Manufacturability
6. DOM Document Object Model
7. Dr. Doctor
8. ES6 ECMAScript6
9. ESA Entertainment Software Association
10. Etc. Etcetera
11. Fig. Figure
12. FoS Factor of Safety
13. JS JavaScript
14. JSX JavaScript XML
15. NAICS North American Industry Classification System
16. PC Personal Computer
17. PHP Hypertext Preprocessor
18. SASS Syntactically Awesome Style Sheets
19. SEMVER Semantic Versioning
20. SDG Sustainable Developments Goals
21. SF Safety Factor
22. SVS Scalable Vector Graphics
23. UI User Interface
24. U.S. United States
25. W3C World Wide Web Consortium
SYMBOLS
Symbols Definitions
1. % Percent
2. * Asterisk
3. → Right Arrow
4. × Multiplication Symbol
CHAPTER 1: INTRODUCTION
A to-do list is a simple prioritized list of the tasks a person must complete. People
make a list of everything they need to do, ranked according to priority from the most
critical task at the top to the least critical task at the bottom
To-dos are the tasks or the atomic entities that make up a to-do list. To-dos are made
quickly, the bulk of them do not specify the work; instead, they are typically just
comprehensive enough to serve as a valuable indicator. To be sure, to-do terminology
like "Groceries" or "Car Wash" is frequently grammatically correct. Because the
signal is so quick, it is only useful for a short period of time while the task is
remembered. In certain cases, a simple item like a stack is enough to recall the job
without the need for a note.
The To-do list project is a user-friendly website which helps them to keep a track of
their tasks. It is a simple site which requires no sign-in/log-in or any personal details
but still records your task, mark the completed tasks, and stores them even if you visit
memory aid. As technology has evolved, we have been able to create a to-do lists
with excel spreadsheets, word documents, to-do list apps, Microsoft to do and google
to do list to name a few. You can use to do list in your home and personal life, or in
the workplace.
1. Improves your memory: A to do list acts as an external memory aid. It’s only
possible to hold a few pieces of information at one time. Keep a to do list and
you’ll be able to keep track of everything, rather than just a few of the tasks
you need to do. Your to do list will also reinforce the information, which
2. Increases productivity: A to do list allows you to prioritize the tasks that are
more important. This means you don’t waste time on tasks that don’t require
your immediate attention. Your list will help you stay focused on the tasks that
3. Helps with motivation: To do lists are a great motivational tool because you
can use them to clarify your goals. You can divide your long-term goal into
smaller, more achievable short-term goals and as you tick each one off your
From an articulation standpoint, task management entails more than just organizing
virtual and physical collections and scheduling activities.
Recent research has begun to address the problem of generic task management in the
context of email. This development is hardly surprising, given that many digital
device users are overloaded by the number of chores done through email. According
to this research, any successful productivity tool must be tightly connected with
email functionalities. Recent researches looked at task management strategies more
generally because email and related technologies are unlikely to be the whole picture.
The concept of to-do list has existed for a very long time and it is one of the primary
methods for management of tasks, use of a to-dos as a reminder system, to-dos as a
system for note management, etc. In the simplest and most primitive form, a to-do
list can be implemented on a pen and paper as a checklist of items which can be
crossed of or ticked against when completed.
This can be further extended to calendars, by writing tasks against dates where the
dates can also act as deadlines for particular tasks. Other possible extensions of to-do
lists can be on whiteboards, journals, text editors,etc.
The functionalities of to-do lists naturally evolve to perfectly fit web applications and
applications on digital devices. Equipped with modern tools and technologies,
engineers can build an application to create a minimal and powerful application that
can help boost productivity without loss of focus and attention.
With the computing power and persistence of modern devices and databases, losing
track of tasks will not be a problem people will have to face anymore and they can
rest assured, only focused on the tasks they will have to accomplish as with modern
technology and the power of digital devices, integration will be seamless and tasks
can be synced across multiple devices all at once, without any hassle.
Essential Functionalities:
• Immediately turns on, allowing for quick input and clear view.
Conventional to-do lists are commonly abandoned due to slow, time-
consuming input and
weak output.
• A mechanism for dealing with stale, low-priority to-dos that are becoming
less likely to be performed but have not been explicitly deleted.
Table 1.1
Fig. 1.3
As discussed earlier, productivity and task management entails more than just
organizing virtual and physical collections and scheduling activities.
Recent research has begun to address the problem of generic task management in the
context of email. This development is hardly surprising, given that many digital
device users are overloaded by the number of chores done through email. According
to this research, any successful productivity tool must be tightly connected with
email functionalities. Recent researches looked at task management strategies more
generally because email and related technologies are unlikely to be the whole picture.
The idea of plan for the day has existed for quite a while and it is one of the essential
techniques for the board of assignments, utilization of a tasks as an update
framework, tasks as a framework for note the executives, and so on. In the least
difficult and most crude structure, a plan for the day can be executed on a pen and
paper as an agenda of things which can be crossed of or ticked against when finished.
The functionalities of plans for the day normally develop to fit web applications and
applications on advanced gadgets flawlessly. Furnished with current apparatuses and
advancements, specialists can fabricate an application to make a negligible and strong
application that can assist with supporting efficiency without loss of concentration
and consideration.
With the processing power and steadiness of current gadgets and data sets,
forgetting about assignments won't be an issue individuals should confront any
longer and they can have confidence, just centered around the errands they should
Downloaded by Kiran Kumar S P ([email protected])
lOMoARcPSD|25191579
achieve similarly
as with present day innovation and the force of advanced gadgets, combination
will be consistent and undertakings can be adjusted across different gadgets at the
same time, with next to no problem.
1. An assortment of strategies for analyzing and figuring out how tasks that go
past records and mirror the upsides of current assets.
2. The awkward property, for example, when it turns into the default spot
for ordinary errands where updates can be fulfilled.
3. Promptly turns on, taking into consideration fast information and clear
view. Regular plans for the day are ordinarily deserted because of slow,
tedious information and frail result.
5. An instrument for managing old, low-need tasks that are turning out to be
less inclined to be performed yet have not been expressly erased.
A To-do list is a simple and somewhat independent entity, which makes it easy to
integrate with related technologies to help create a better system of productivity
overall.
Various studies have pointed towards and shed light on how well e-mail as a
technology can be seamlessly integrated with to-do list technologies and the synergy
of these two technologies help boost productivity greatly as e-mail and social media
have now become an essential technology that people need to have access to in order
to be a productive member of any organization or institution as these have now
become an essential part of everyday life.
Collaborative task management is also one of the problems that can be solved
through a well designed and engineered to-do list application such as Trello, a web
based, Kanban-style list application which helps teams organize their tasks and stay
in sync when working collaboratively on a project.
Another example of a well integrated to-do list application is Google Tasks, a to-do
list application which is completely synchronized with other Google and third party
services such as Google Calendar, Mail, Clock, etc. Such well integrated applications
help build a highly effective productivity system for a user.
2.1.4 Gamification
2.2.1 INTRODUCTION
The current state of task management through currently available to-do list
applications is a hotch-potch, to say the least. The highly available and most
Downloaded by Kiran Kumar S P ([email protected])
lOMoARcPSD|25191579
used to-do list applications are heavily bloated and provide unnecessary levels
of integrations which are usually not required and clutter a user’s productivity
system.
A lot of good to-do list applications are not free to use and usually run ads to
generate revenue, which is a huge negative point when it comes to productivity
apps. Ones which are run by large companies are usually trying to pull users
towards their own app ecosystem through non-sensical integrations and
bloatware.
Some of the most glaring issues of to-do list productivity applications are
discussed in this chapter as we try to identify the problems and shortcomings of
currently available solutions and build our project to overcome those
shortcomings.
For most of the to-do list applications available to use, they are not independent
entities or applications. Most of these applications are usually meant to be used
with other applications to form a “productivity system” where a user’s
calendar, clock, mail, notifications, etc. are all linked to their to-do list. While
this may be desirable to most people and may work to improve productivity for
some, it is very often more distracting than useful and over-integration of
applications often leads to sensory overload and overwhelming frustration.
Integrations are very often counter-productive and there should exist solutions
that are absolutely independent entities, free of all clutter and meant to fulfill a
simple and minimal purpose. Unfortunately, not many solutions like this exist
currently.
Ironically, most good to-do list applications are not free-to-use and almost
always have some in-app purchase or subscription model to generate revenue.
This is one of the prominent problems with to-do list applications as very often
all people need is a simple app to take notes and record tasks without paying
for it and that is all a good to-do list application needs to offer, a simple and
minimal application to serve the mentioned functionalities to the user.
Making a to-do list is an easy and important task that everyone should do. The
immense satisfaction that one gets when completing the task and marking it on
the list is incomparable. Moreover, creating a list of tasks ensures you don’t
miss out on anything. It’s a scientific fact that when you write the tasks that
you need to complete, you are even more motivated to complete it.
With this in mind, we come to build a platform which will help people
create their own task list. The main goals we hope to accomplish with this
project include:
The to-do list application build for this project is completely free to use to
any and everyone. The only requirement of this application is to have a
device capable of running a web browser.
To-do list is open source and its code repository is publicly available on
GitHub. It is open to contributions and improvements by anyone who wishes to
contribute to it. It is also free for modification and personal use.
Open source software is software with source code that anyone can inspect,
modify, and enhance. "Source code" is the part of software that most computer
users don't ever see; it's the code computer programmers can manipulate to
change how a piece of software—a "program" or "application"—works.
Programmers who have access to a computer program's source code can
improve that program by adding features to it or fixing parts that don't always
work correctly.
2.3.4 AD-Free
2.3.5 Efficient
Very few resources are required to store and run the application.
2.3.5 CONCLUSION
The to-do list developed for this project is meant to be a minimal, free and
open source application that can help improve the productivity of a user
without taking anything. It aims to solve at least some of the problems
discussed earlier in this report.
In order to do manage tasks, the concept of to-do lists was formulated to provide a
simple, hassle-free solution to the problem of taking short notes and recording the
daily tasks that a person needs to complete. We extend this concept and implement it
using modern tools and technologies.
This project is divided into three main components : the frontend, backend and
database. The frontend is the medium through which the user can interact with the
application and utilize the necessary functionalities of the application. The backend is
a two-way bridge between the database and the frontend. It ensures security, transfer
and integrity of data that flows from the database to the frontend of the application.
The database is basically a store of all the information a user wishes to persistently
store. It is responsible for storage, persistence, integrity and retrieval of data. The
technologies used for the implementation of this project are : ReactJS for frontend,
Node.js for backend and MongoDB for database as the primary focus of this project
is simplicity.
3.3.1 ECONOMIC
To-do list is free to use. However, damage to a device’s software and/or hardware due to
improper modification of this application is always a possibility.
3.3.2 ENVIRONMENTAL
The use of To-do list does not generate any environmental concerns. The possible causes
of any problems may be from the hardware not being disposed properly which would lead
to
e-waste generation.
3.3.3 HEALTH
There are no health constraints. The only issues and problems that may arise might be due
to the devices and hardware that the user uses. In case of any such situation or in the event
of any problem or emergency in which the user feels biological discomfort, it is suggested
to immediately seek professional medical assistance.
3.3.4 MANUFACTURABILITY
As To-do list is digital software, there seem to be less issues with manufacturability.
3.3.5 SAFETY
To-do list it does not guarantee the physical safety of users. In case of intimidation
or underhanded malicious extortions, it is advised to seek police aid.
3.3.6 PROFESSIONAL
With the constant development in new technologies revolving around to-do list
applications, new professional services are required to be developed as well. However,
these will heavily depend on the regulations from the government.
The final design chosen for the implementation of this project was to divide it
into three main components: the frontend, backend and database. The frontend is the
Downloaded by Kiran Kumar S P ([email protected])
lOMoARcPSD|25191579
medium through which the user can interact with the application and utilize the
4.1 The technologies that are used to implement this project are:
4.1.1 ReactJS:
React (also known as React.js or ReactJS) is a free and open-
source front-end JavaScript library for building user interfaces based on
UI components. It is maintained by Meta (formerly Facebook) and a
community of individual developers and companies. React can be used
as a base in the development of single-page, mobile, or server-rendered
applications with frameworks like Next.js. However, React is only
concerned with state management and rendering that state to the DOM,
4.1.2 Node.js:
Node.js is an open-source, cross-platform, back-end JavaScript runtime
environment that runs on the V8 engine and executes JavaScript code
outside a web browser. Node.js lets developers use JavaScript to write
command line tools and for server-side scripting—running scripts
server- side to produce dynamic web page content before the page is sent
to the user's web browser. Consequently, Node.js represents a
"JavaScript everywhere" paradigm, unifying web-application
development around a single programming language, rather than
different languages for server- side and client-side scripts.
4.1.3 MongoDB
MongoDB a source-available cross-platform document-oriented
database program. Classified as a NoSQL database program, MongoDB
uses JSON-like documents with optional schemas. MongoDB is
developed by MongoDB Inc. and licensed under the Server Side Public
License (SSPL).
Fig 4.1
• The initial plan was to use an SQL database instead of MongoDB but
the Object Relational Mapping(ORM) library we planned to
use (Sequelize) with Node.js had issues performing queries on
local PostgreSQL database so we tried implementing the
project with MongoDB instead and decided to go on with it.
• The feature to rank and list tasks by their priority was implemented
towards the end of the project as we had initially planned to
classify tasks into two lists only based on whether the tasks were
completed or pending.
• Several implementation problems did not have any solutions that
could be solved by directly using third-party libraries so they had
to be solved by manually implementing the functionalities.
• Improvement in security and integrity
• Integration with other applications such as calendar, mail, etc.
• Implementation of authentication
• Hosting the web application online to make it accessible to
more users
5.2 REFERENCES
1. Staff, C. A. C. M. (2016). React: Facebook's functional turn on writing Javascript. Communications of the
ACM, 59(12), 56-62.
2. Kvalheim, C. (2015). The Little Mongo DB Schema Design Book. The Blue Print Series.
3. Khedkar, S., Thube, S., Estate, W. I., & Naka, C. (2017). Real time databases for
applications. International Research Journal of Engineering and Technology (IRJET), 4(06), 2078-
2082.
4. Tilkov, S., & Vinoski, S. (2010). Node. js: Using JavaScript to build high-performance network
programs. IEEE Internet Computing, 14(6), 80-83.
5. Syed, B. A., & Bean, M. (2014). Beginning Node. js (pp. 181-182). New York City: Apress.
6. Morales-Morell, A. (2001). Usability aspects of a location-aware TODO list application. University of
Puerto Rico, Mayaguez (Puerto Rico).
7. Gaspar, F., Taniça, L., Tomás, P., Ilic, A., & Sousa, L. (2015). A framework for application-guided task
management on heterogeneous embedded systems. ACM Transactions on Architecture and Code
Optimization (TACO), 12(4), 1-25.
8. Lin, C. Y., Hung, M. T., & Huang, W. H. (2012, September). A location-based personal task
management application for indoor and outdoor environments. In 2012 15th International
Conference on Network-Based Information Systems (pp. 582-587). IEEE.
9. Bellotti, V., Ducheneaut, N., Howard, M., & Smith, I. (2002). Taskmaster: recasting email as task
management. PARC, CSCW, 2.
10. Unger, T., & Bauer, T. (2008). Towards a Standardized Task Management. In Multikonferenz
Wirtschaftsinformatik (pp. 443-444).
5.3 APPENDIX
1. INTRODUCTION
1.3 Timeline
2.Literature Survey
2.1 Overview
2.1.4 Gamification
2.2.1 Introduction
2.3.4 AD-Free
2.3.5 Efficient
2.4.6 Conclusion
3.Design Flow/Process
Downloaded by Kiran Kumar S P ([email protected])
lOMoARcPSD|25191579
Validation
Work
5.2 References
5.3 Appendix
5.5 Achievements
Pre-requisites / Requirements:
Node (version 16 or higher)
5.5 ACHIEVEMENTS