86 lines
3.1 KiB
Cheetah
86 lines
3.1 KiB
Cheetah
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<title>{{ .title }}</title>
|
|
{{template "head" .}}
|
|
</head>
|
|
<body>
|
|
{{template "navbar" .}}
|
|
|
|
<div class="container">
|
|
<div class="fs-3 text-center mt-5">{{ .title }}</div>
|
|
<hr>
|
|
<div id="tasks"></div>
|
|
<hr>
|
|
<form class="row g-3 needs-validation" novalidate>
|
|
<div class="col-1"></div>
|
|
<div class="col-8">
|
|
<div class="input-group has-validation">
|
|
<input type="text" class="form-control" id="description" required>
|
|
<div class="invalid-feedback">
|
|
Please provide a description.
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-3">
|
|
<button class="btn btn-primary" id="button" type="submit"><i class="bi bi-plus-lg"></i></button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
|
|
{{template "scripts" .}}
|
|
{{template "formScripts" .}}
|
|
<script>
|
|
userLoggedIn().then((loggedIn) => !loggedIn ? redirect("/view/login") : getAllTasks());
|
|
const tasksEl = document.getElementById("tasks");
|
|
const descriptionInput = document.getElementById("description");
|
|
|
|
function submitForm(formData) {
|
|
axios.post("/tasks", formData, axiosConfig)
|
|
.then((response) => {
|
|
addTaskToTasks(response.data.task);
|
|
form.classList.remove('was-validated');
|
|
descriptionInput.value = "";
|
|
})
|
|
.catch((err) => {
|
|
showErrorToast(err.response.data.message);
|
|
});
|
|
}
|
|
|
|
function addTaskToTasks(task) {
|
|
const newTask = document.createElement('div');
|
|
newTask.classList.add('row', 'g-0', 'align-items-center', 'mb-1');
|
|
newTask.innerHTML = `
|
|
<div class="col-1 text-center">${task.ID}</div>
|
|
<div class="col-8">${task.Description}</div>
|
|
<div class="col-2 form-check form-switch d-flex justify-content-center">
|
|
<input class="text-center form-check-input" type="checkbox" ${task.Done && "checked"} role="switch" id="flexSwitchCheckDefault">
|
|
</div>
|
|
<button class="col-1 btn btn-danger"><i class="bi bi-trash"></i></button>
|
|
`;
|
|
tasksEl.appendChild(newTask);
|
|
}
|
|
|
|
function getAllTasks() {
|
|
axios.get("/tasks", axiosConfig).then((response) => {
|
|
const taskHeader = document.createElement("div");
|
|
taskHeader.classList.add('row', 'g-0', 'align-items-center', 'mb-1');
|
|
taskHeader.innerHTML = `
|
|
<div class="fw-bold col-1 text-center">ID</div>
|
|
<div class="fw-bold col-8">Description</div>
|
|
<div class="fw-bold col-2 text-center">Done</div>
|
|
<div class="fw-bold col-1 text-center">Delete</div>
|
|
<hr class="mt-3 mb-2">
|
|
`;
|
|
tasksEl.appendChild(taskHeader);
|
|
const tasks = response.data.tasks;
|
|
[...tasks]
|
|
.forEach((task) => {
|
|
addTaskToTasks(task);
|
|
});
|
|
});
|
|
}
|
|
</script>
|
|
</body>
|
|
</html>
|