-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.js
More file actions
125 lines (106 loc) · 3.65 KB
/
main.js
File metadata and controls
125 lines (106 loc) · 3.65 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
import TaskManager from "./TaskManager.js";
const taskManager = new TaskManager();
const addListButton = document.getElementById("addList");
const listsContainer = document.getElementById("listsContainer");
addListButton.addEventListener("click", () => {
const listName = prompt("Enter list name:");
if (listName) {
taskManager.addList(listName);
render();
}
});
function render() {
listsContainer.innerHTML = "";
taskManager.lists.forEach((list, listIndex) => {
const listDiv = document.createElement("div");
listDiv.className = "list";
listDiv.innerHTML = `<h1>${list.name}</h1>`;
listDiv.addEventListener("dragover", (event) => {
event.preventDefault();
});
listDiv.addEventListener("drop", (event) => {
event.preventDefault();
console.log(event.dataTransfer.getData("text/plain"))
const sourceData = event.dataTransfer.getData("text/plain").split("-");
const sourceListIndex = parseInt(sourceData[0]);
const sourceItemIndex = parseInt(sourceData[1]);
const targetListIndex = listIndex;
const dropPosition = getDropPosition(event.clientY, listDiv);
if (sourceListIndex === targetListIndex) {
const [item] = taskManager.lists[sourceListIndex].items.splice(sourceItemIndex, 1);
taskManager.lists[targetListIndex].items.splice(dropPosition, 0, item);
taskManager.saveToLocalStorage();
render();
} else {
const [item] = taskManager.lists[sourceListIndex].items.splice(sourceItemIndex, 1);
taskManager.lists[targetListIndex].items.splice(dropPosition, 0, item);
taskManager.saveToLocalStorage();
render();
}
});
list.items.forEach((item, itemIndex) => {
const itemDiv = document.createElement("div");
itemDiv.className = "item";
itemDiv.innerText = item.text;
const removeButton = document.createElement("button");
removeButton.className = "remove-button";
removeButton.innerText = "✕";
removeButton.addEventListener("click", (event) => {
event.stopPropagation();
const confirmDelete = confirm("Are you sure you want to remove this task?");
if (confirmDelete) {
taskManager.removeItem(listIndex, itemIndex);
render();
}
});
itemDiv.appendChild(removeButton);
itemDiv.addEventListener("click", () => {
const newText = prompt("Edit item:", item.text);
if (newText) {
item.text = newText;
render();
}
});
itemDiv.draggable = true;
itemDiv.addEventListener("dragstart", (event) => {
event.dataTransfer.setData("text/plain", `${listIndex}-${itemIndex}`);
});
listDiv.appendChild(itemDiv);
});
const addTaskButton = document.createElement("button");
addTaskButton.innerText = "+";
addTaskButton.className = "add-task-button"
addTaskButton.addEventListener("click", () => {
const taskText = prompt("Enter task:");
if (taskText) {
taskManager.addItem(listIndex, taskText);
render();
}
});
const removeListButton = document.createElement("button");
removeListButton.innerText = "✕";
removeListButton.className = "remove-list-button"
removeListButton.addEventListener("click", () => {
const confirmDelete = confirm("Are you sure you want to remove this list?");
if (confirmDelete) {
taskManager.removeList(listIndex);
render();
}
});
listDiv.appendChild(addTaskButton);
listDiv.appendChild(removeListButton);
listsContainer.appendChild(listDiv);
});
}
function getDropPosition(y, listDiv) {
const items = Array.from(listDiv.getElementsByClassName("item"));
for (let i = 0; i < items.length; i++) {
const rect = items[i].getBoundingClientRect();
if (y < rect.top + rect.height / 2) {
return i;
}
}
return items.length;
}
taskManager.initialize();
render();