Skip to main content

Best ToDo-Application using javascript

To Do Application 

What is To Do List?

ToDoList is a type of software which is used for managing your productive workflow.It is also called "Getting things done" (GTD), scheduling and collaboration.

ToDoList is general-purpose, Windows-based software, which can be used for simple “honey do” home lists or to manage complex multi-user projects for business. In addition to tracking the status of tasks, ToDoList includes a powerful system for logging and reporting time spent on tasks. Combined with powerful reporting mechanisms, this makes ToDoList an effective tool for client billing.

About My To Do Application

So as you can read the above intro of ToDO-Application, I build this with very easy way and you can also try this for enhance or revise your JavaScript concepts. The code is simple and easy to understand, if you are new to JavaScript and web development then this tutorial is for you.I tried my best to design it for user friendly and keep it simple.Here is some screen shots of my To Do Application.



To Do List Design

  • Input Field
  • Buttons
Input Field:

Input Field is  a place where you can enter your To Do items.

Buttons:

I added two buttons mainly 'Add' & 'Delete' . Add button add the items in a list where as Delete button delete items from the list.

Here is some added items screen shot of  ToDo list








Live Demo of To Do List


To Do List Coding

Index.html

<!DOCTYPE html>
<html>
<head>
    <meta charset='utf-8'>
    <meta http-equiv='X-UA-Compatible' content='IE=edge'>
    <title>TODO List</title>
    <meta name='viewport' content='width=device-width, initial-scale=1'>
    <link rel='stylesheet' type='text/css' media='screen' href='style.css'>
    <link href="https://fonts.googleapis.com/css?family=Hind&display=swap" rel="stylesheet">
    <link rel="stylesheet" href="path/to/font-awesome/css/font-awesome.min.css">
    <script src="https://kit.fontawesome.com/a81368914c.js"></script>
</head>
<body>
    <h1><span class="title">Todo</span>List</h1>
    <div class="inputDiv">
           <input type="text" class="input" placeholder="What Do You Want to Do...">
           <button class="add"><i class="fas fa-plus"></i></button> <button onclick="deletAll()" class="add"><i class="fas fa-trash"></i></button>
    </div>
    <div class="container">
    </div>
    <script src='app.js'></script>
</body>
</html>

Style.css

* {
    margin0;
    padding0;
    box-sizingborder-box;
}

body{
    height100%;
    background-color: rgb(255255255);
    box-sizingborder-box;
}

h1 {
    color:  rgba(23561610.945);
    font-size3rem;
    font-weight50;
    text-aligncenter;
    margin1rem 0 3rem
    font-family'Hind'sans-serif;
}

.title{
    color: rgb(323232);
    text-transformuppercase;
    font-weight800;
}

.inputDiv{
    displayflex;
    justify-contentcenter;
    align-itemscenter;
}

.input{
    padding0.5rem 1rem;
    outlinenone;
    border2px solid black;
    height50px;
    border-radius25px;
    width360px;
    
    margin0.25rem;
    transition.5s;
    font-size1.15rem;
}

.add{
    outlinenone;
    bordernone;
    height50px;
    border-radius25px;
    width50px;
    background-color: rgb(151515);
    colorwhite;
    cursorpointer;
    transition.5s;
    margin0.25rem;
}

.add:hover{
    background-color: rgb(2263333);
    opacity0.7;
}

.container{
    displayflex;
    flex-directioncolumn;
    justify-contentcenter;
    align-itemscenter;
    text-aligncenter;
    margin-top2rem;
}

.item{
    padding0.5rem;
    border-bottom4px solid rgb(262525);
    margin-bottom1.5rem;
}

.item_input{
    backgroundnone;
    outlinenone;
    bordernone;
    color: rgb(202020);
    font-size1.4rem;
    width245px;
}

.edit{
    backgroundnone;
    outlinenone;
    bordernone;
    color: rgb(202020);
    font-size1.4rem;
    font-family'Hind'sans-serif;
    margin0 0.5rem;
    cursorpointer;
}

.remove{
    backgroundnone;
    outlinenone;
    bordernone;
    color: rgba(238000.644);
    font-size1.4rem;
    font-family'Hind'sans-serif;
    cursorpointer;
}
.trash{
    outlinenone;
  list-stylenone;
    height35px;
    border-radius24px;
    width60px;
    color: rgba(238000.644);
    background-color: rgb(343434);
    colorwhite;
    cursorpointer;
    transition.5s;
    margin0.25rem;
}

App.js

const container = document.querySelector('.container');
var inputValue = document.querySelector('.input');
const add = document.querySelector('.add');

if(window.localStorage.getItem("todos") == undefined){
     var todos = [];
     window.localStorage.setItem("todos", JSON.stringify(todos));
}

var todosEX = window.localStorage.getItem("todos");
var todos = JSON.parse(todosEX);


class item{
    constructor(name){
        this.createItem(name);
    }
    createItem(name){
        var itemBox = document.createElement('div');
        itemBox.classList.add('item');

        var input = document.createElement('input');
        input.type = "text";
        input.disabled = true;
        input.value = name;
        input.classList.add('item_input');

        var edit = document.createElement('button');
        edit.classList.add('edit');
        edit.innerHTML = "EDIT";
        edit.addEventListener('click', () => this.edit(input, name));

        var remove = document.createElement('button');
        remove.classList.add('remove');
        remove.innerHTML = "REMOVE";
        remove.addEventListener('click', () => this.remove(itemBox, name));

        container.appendChild(itemBox);

        itemBox.appendChild(input);
        itemBox.appendChild(edit);
        itemBox.appendChild(remove);

    }

    edit(input, name){
        if(input.disabled == true){
           input.disabled = !input.disabled;
        }
        else{
            input.disabled = !input.disabled;
            let indexof = todos.indexOf(name);
            todos[indexof] = input.value;
            window.localStorage.setItem("todos", JSON.stringify(todos));
        }
    }

    remove(itemBox, name){
        itemBox.parentNode.removeChild(itemBox);
        let index = todos.indexOf(name);
        todos.splice(index, 1);
        window.localStorage.setItem("todos", JSON.stringify(todos));
    }
}

add.addEventListener('click', check);
window.addEventListener('keydown', (e) => {
    if(e.which == 13){
        check();
    }
})

function check(){
    if(inputValue.value != ""){
        new item(inputValue.value);
        todos.push(inputValue.value);
        window.localStorage.setItem("todos", JSON.stringify(todos));
        inputValue.value = "";
    }
}



function deletAll(){
    container.innerHTML="";
}


Comments

Popular posts from this blog

Login & Signup forms using Html & CSS

  Login /Signup Form  Using Html & CSS Hello hope you all are fine :-), today I'm going to make Login and signup form by using html & css it is very easy to create just like a piece of cake! Login Form Index.Html <!DOCTYPE   html > <html   lang = "en" >      <head>      <meta   charset = "UTF-8" >      <meta   name = "viewport"   content = "width=device-width, initial-scale=1.0" >      <title> Join-Us </title>          <link   rel = "stylesheet"   href = "join-us.css" >     </head> <body>    <div   class = "form" >      <h1> Login  <span><hr   style = "  border: 0;       height: 1px;          ...

Best Ui Dark Calculator using Html,Css and Javascript

   How to Create a  Calculator  Introduction Calculator is one of the basic projects of JavaScript or any other languages a newbie programmer should probably know how to create it.The best thing of this is that the coding is short and easy to understand . It is a basic project that perform arithmetical operations. All you have to do is to create a button for each number, arithmetic operations. symbols and then add a text-box or input-field. Here is the Output of Dark Calculator : Output: Source Code : Index.html: Here is the html coding :) <!DOCTYPE html> <html  lang =" en "> <head> <meta  charset =" UTF-8 "> <meta  name =" viewport "  content =" width=device-width, initial-scale=1.0 "> <title> Dark Calculator </title> <link  rel =" stylesheet "  href =" styel.css "> </head> <body> <div  class =" main "> <div> <input  id =" result ...