diff --git a/ReadMe.md b/ReadMe.md index 7ecdc638898..a8d8016e5d5 100644 --- a/ReadMe.md +++ b/ReadMe.md @@ -1,13 +1 @@ -code-quality-task-screenshot - -# Функционал приложения : - - - Добавление нового элемента в список задач "TODO" - - Редактирование элемента в списке задач "TODO" - - Удаление элемента из списка задач "TODO" - - Установка элемента в статус завершенного и перенос в список "COMPLETED" через checkbox - - - Удаление элемента из списка "COMPLETED" - - Редактирование элемента из списка "COMPLETED" - - Установка элемента в статус незавершенного и перенос в список "TODO" через checkbox - - Анимация на кнопке удаления +code-quality-task-screenshot \ No newline at end of file diff --git a/app.js b/app.js index ab737a60027..9f1e08296ed 100644 --- a/app.js +++ b/app.js @@ -9,9 +9,9 @@ // Event handling, user interaction is what starts the code execution. var taskInput=document.getElementById("new-task");//Add a new task. -var addButton=document.getElementsByTagName("button")[0];//first button -var incompleteTaskHolder=document.getElementById("incompleteTasks");//ul of #incompleteTasks -var completedTasksHolder=document.getElementById("completed-tasks");//completed-tasks +var addButton=document.querySelectorAll(".task__btn")[0];//first button +var incompleteTaskHolder=document.querySelector(".task__list_incomplete");//ul of #incomplete tasks +var completedTasksHolder=document.querySelector(".task__list_complete");//completed-tasks //New task list item @@ -31,19 +31,21 @@ var createNewTaskElement=function(taskString){ //button.delete var deleteButton=document.createElement("button");//delete button var deleteButtonImg=document.createElement("img");//delete button image - + listItem.classList.add("task__item"); + checkBox.classList.add("task__checkbox"); + label.classList.add("task__label"); + deleteButton.classList.add("task__btn"); + deleteButtonImg.classList.add("task__icon") label.innerText=taskString; - label.className='task'; + label.className='task__label'; //Each elements, needs appending checkBox.type="checkbox"; editInput.type="text"; - editInput.className="task"; - + editInput.className="task__input"; editButton.innerText="Edit"; //innerText encodes special characters, HTML does not. - editButton.className="edit"; - - deleteButton.className="delete"; + editButton.className="task__btn task__btn_edit"; + deleteButton.className="task__btn task__btn_delete"; deleteButtonImg.src='./remove.svg'; deleteButton.appendChild(deleteButtonImg); @@ -82,10 +84,10 @@ var editTask=function(){ var listItem=this.parentNode; - var editInput=listItem.querySelector('input[type=text]'); - var label=listItem.querySelector("label"); - var editBtn=listItem.querySelector(".edit"); - var containsClass=listItem.classList.contains("editMode"); + var editInput=listItem.querySelector('.task__input'); + var label=listItem.querySelector(".task__label"); + var editBtn=listItem.querySelector(".task__btn_edit"); + var containsClass=listItem.classList.contains("task__item_edit"); //If class of the parent is .editmode if(containsClass){ @@ -99,7 +101,7 @@ var editTask=function(){ } //toggle .editmode on the parent. - listItem.classList.toggle("editMode"); + listItem.classList.toggle("task__item_edit"); }; @@ -155,9 +157,9 @@ addButton.addEventListener("click",ajaxRequest); var bindTaskEvents=function(taskListItem,checkBoxEventHandler){ console.log("bind list item events"); //select ListItems children - var checkBox=taskListItem.querySelector("input[type=checkbox]"); - var editButton=taskListItem.querySelector("button.edit"); - var deleteButton=taskListItem.querySelector("button.delete"); + var checkBox=taskListItem.querySelector(".task__checkbox"); + var editButton=taskListItem.querySelector(".task__btn_edit"); + var deleteButton=taskListItem.querySelector(".task__btn_delete"); //Bind editTask to edit button. diff --git a/index.html b/index.html index ef4aa1f60ca..bb2bbe48691 100644 --- a/index.html +++ b/index.html @@ -1,19 +1,61 @@ - -Todo App - - - - -
Want more details?
-

-

Todo

-

Completed

-
- - + + + + Todo App + + + + +
+ eisenhower-matrix + Want more details? +
+
+
+ +
+ + +
+
+
+

Todo

+ +
+
+

Completed

+ +
+
+ + \ No newline at end of file diff --git a/style.css b/style.css index ab36227705e..5e3630d1cf6 100644 --- a/style.css +++ b/style.css @@ -1,148 +1,186 @@ /* Basic Style */ + body { - background-color: #f8f8f8; - color: #333; - font-family: Lato, sans-serif; + background-color: #f8f8f8; + color: #333; + font-family: Lato, sans-serif; } -.aaa { - width: 500px; - margin: 0 auto; - display: block; - text-align: right; + +.header { + width: 500px; + margin: 0 auto; + display: block; + text-align: right; } -.aaa img { - width: 100%; + +.header__img { + width: 100%; } -.aaa .more_inf { - font-family: fantasy, cursive; + +.header +.header__link { + font-family: fantasy, cursive; } @media (max-width:768px) { -.aaa { text-align: center; -} + + .header { + text-align: center; + } + } -.centered-main-page-element { - display: block; - width: 500px; - margin: 0 auto 0; + +.main { + display: block; + width: 500px; + margin: 0 auto 0; } -.task { - width: 56%; - display: inline-block; - flex-grow: 1 + +.task__input, +.task__label { + width: 56%; + display: inline-block; + flex-grow: 1; } -.task-row-wrapper { - display: flex; + +.task__wrapper { + display: flex; } -ul { - margin:0; - padding: 0px; + +.task__list { + margin: 0; + padding: 0px; } -li, h3 { - list-style:none; + +.task__item, +.task__header { + list-style: none; } -input,button{ - outline:none; + +.task__input, +.task__btn { + outline: none; } -button { - background: none; - border: 0px; - color: #888; - font-size: 15px; - width: 60px; - font-family: Lato, sans-serif; - cursor: pointer; + +.task__btn { + background: none; + border: 0px; + color: #888; + font-size: 15px; + width: 60px; + font-family: Lato, sans-serif; + cursor: pointer; } -button:hover { - color: #3a3A3a; + +.task__btn:hover { + color: #3a3a3a; } + /* Heading */ -h3, -label[for='new-task'] { - color: #333; - font-weight: 700; - font-size: 15px; - border-bottom: 2px solid #333; - padding: 30px 0 10px; - margin: 0; - text-transform: uppercase; -} -input[type="text"] { - margin: 0; - font-size: 18px; - line-height: 18px; - height: 21px; - padding: 0 9px; - border: 1px solid #dDd; - background: #FFF; - border-radius: 6px; - font-family: Lato, sans-serif; - color: #888; -} -input[type="text"]:focus { - color: #333; + +.task__header { + color: #333; + font-weight: 700; + font-size: 15px; + border-bottom: 2px solid #333; + padding: 30px 0 10px; + margin: 0; + text-transform: uppercase; +} + +.task__input { + margin: 0; + font-size: 18px; + line-height: 18px; + height: 21px; + padding: 0 9px; + border: 1px solid #ddd; + background: #fff; + border-radius: 6px; + font-family: Lato, sans-serif; + color: #888; +} + +.task__input:focus { + color: #333; } /* New Task */ -label[for='new-task'] { - display: block; - margin: 0 0 20px; + +.task__header[for="new-task"] { + display: block; + margin: 0 0 20px; } -input#new-task { - width: 318px; + +#new-task { + width: 318px; } /* Task list */ -li { - overflow: hidden; - padding: 20px 0; - border-bottom: 1px solid #eee; - display: flex; - justify-content: space-between; - align-items: center; +.task__item { + overflow: hidden; + padding: 20px 0; + border-bottom: 1px solid #eee; + display: flex; + justify-content: space-between; + align-items: center; } -li > * { - vertical-align: middle; + +.task__item > +* { + vertical-align: middle; } -li > input[type="checkbox"] { - margin: 0 10px; +.task__checkbox { + margin: 0 10px; } -li > label { - padding-left: 10px; - box-sizing: border-box; - font-size: 18px; - width: 226px; + +.task__label { + padding-left: 10px; + box-sizing: border-box; + font-size: 18px; + width: 226px; } -li > input[type="text"] { - width: 226px + +.task__item > +.task__input { + width: 226px; } -button.delete img { - height: 2em; - transform: rotateZ(45deg); - transition: transform 200ms ease-in; + +.task__btn_delete +.task__icon { + height: 2em; + transform: rotateZ(45deg); + transition: transform 200ms ease-in; } -button.delete img:hover { - transform: rotateZ(0); + +.task__btn_delete +.task__icon:hover { + transform: rotateZ(0); } /* Completed */ -ul#completed-tasks label { - text-decoration: line-through - color: #888; + +.task__list_complete +.task__label { + text-decoration: line-through; + color: #888; } /* Edit Task */ -ul li input[type=text] { - display:none +.task__item > +.task__input { + display: none; } -ul li.editMode input[type=text] { - display:inline-block; - width:224px +.task__item_edit +.task__input { + display: inline-block; + width: 224px; } -ul li.editMode label { - display:none; +.task__item_edit +.task__label { + display: none; } \ No newline at end of file