Skip to content

This is a To-Do List SPA (Single Page Application) that uses VanillaJS(for functionality like adding and deleting task elements ) , HTML5 and CSS3 (for basic structure and style)

Notifications You must be signed in to change notification settings

piyush26arora/TaskOrganiser

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Task-Organiser

✍️ This is a To-Do List Single Page Application built using :

  • VanillaJS (for functionality features like Creation and Removal of Task Elements in the list)
  • HTML5 (for basic structure)
  • CSS3 (for styling and making UI attractive)

🧑‍💻 While working on this project I also used VS Code's various Extensions for my advantage and also enhanced my knowledge of these tools as a developer .

Some of these Extensions were :

  • Live Server
  • JS (ES6) snippets
  • Bracket Pair Colorizer

🌱 Anyone interested in programming (especially Web Development) should definitely try out these extensions , for a nice developer experience .

    //declaring and initializing variables
var formList = document.querySelector('form')
var itemList = document.querySelector('.list-group-item')


    //calls event newElement function
formList.addEventListener('submit',newElement);


    //Removes task from list
itemList.addEventListener('click', function (e) {

        //event triggers only when delBtn(containing "delete" class) is pressed
    if(e.target.classList.contains('delete') ) {

            //asks for user confirmation before deletion
        if(confirm('Are You Sure to remove?')) {

                //deletes that item from itemList collection 
            var li = e.target.parentElement
            itemList.removeChild(li)
        }
    }
});

    //add new element in the list
function newElement(e) {

        //prevents default action from happening for event parameter e
    e.preventDefault()

    var newItem = document.querySelector('#input').value
        
        // to do avoid null entries to add to the list
    if (newItem === '') {
        alert("You must write something!");
      } else {  
          // create element , textNode for newItem entered by user ,that is 'li'
    var li = document.createElement('li')

    li.className = 'list-group-item'

    li.appendChild(document.createTextNode(newItem))
         
        //also adding delBtn for this element
    var delBtn = document.createElement('button')

    delBtn.className = 'delete'
    delBtn.appendChild(document.createTextNode('X'))

        //appending delBtn to element having NewItem ,that is 'li'
    li.appendChild(delBtn)

        //appending all this to the original itemList object/collection
    itemList.appendChild(li)
    }
}

⏳ 🌌 Lastly , I hope my application would be of some help to you all .

Thank you , happy coding :)

URL Link : [ https://piyush26arora.github.io/TaskOrganiser ]

About

This is a To-Do List SPA (Single Page Application) that uses VanillaJS(for functionality like adding and deleting task elements ) , HTML5 and CSS3 (for basic structure and style)

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published