Make list selection explicit
Stop auto-downloading on list click and highlight the selected item; download only when the button is pressed.
This commit is contained in:
@@ -12,6 +12,8 @@ let items = [];
|
||||
let editMode = false;
|
||||
const selectedIds = new Set();
|
||||
let progressTimer = null;
|
||||
let selectedItemId = null;
|
||||
let selectedDownloadUrl = null;
|
||||
|
||||
function startProgress() {
|
||||
let value = 0;
|
||||
@@ -50,10 +52,13 @@ function finishProgress(success = true) {
|
||||
function setEditMode(isEdit) {
|
||||
editMode = isEdit;
|
||||
selectedIds.clear();
|
||||
selectedItemId = null;
|
||||
selectedDownloadUrl = null;
|
||||
editBtn.classList.toggle("hidden", editMode);
|
||||
deleteBtn.classList.toggle("hidden", !editMode);
|
||||
cancelBtn.classList.toggle("hidden", !editMode);
|
||||
downloadLink.classList.add("hidden");
|
||||
downloadLink.href = "#";
|
||||
renderList();
|
||||
}
|
||||
|
||||
@@ -62,6 +67,9 @@ function renderList() {
|
||||
items.forEach((item) => {
|
||||
const li = document.createElement("li");
|
||||
li.className = "tts-item";
|
||||
if (!editMode && selectedItemId === item.id) {
|
||||
li.classList.add("selected");
|
||||
}
|
||||
|
||||
if (editMode) {
|
||||
const checkbox = document.createElement("input");
|
||||
@@ -139,6 +147,15 @@ async function handleItemClick(item) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (selectedItemId === item.id) {
|
||||
selectedItemId = null;
|
||||
selectedDownloadUrl = null;
|
||||
downloadLink.href = "#";
|
||||
downloadLink.classList.add("hidden");
|
||||
renderList();
|
||||
return;
|
||||
}
|
||||
|
||||
const res = await fetch(`/api/tts/${item.id}`);
|
||||
if (!res.ok) {
|
||||
alert("항목을 불러오지 못했습니다.");
|
||||
@@ -147,9 +164,11 @@ async function handleItemClick(item) {
|
||||
|
||||
const data = await res.json();
|
||||
textInput.value = data.text || "";
|
||||
downloadLink.href = data.download_url;
|
||||
selectedItemId = item.id;
|
||||
selectedDownloadUrl = data.download_url;
|
||||
downloadLink.href = selectedDownloadUrl;
|
||||
downloadLink.classList.remove("hidden");
|
||||
downloadLink.click();
|
||||
renderList();
|
||||
}
|
||||
|
||||
async function handleDelete() {
|
||||
@@ -174,6 +193,8 @@ async function handleDelete() {
|
||||
const deletedSet = new Set(data.deleted || []);
|
||||
items = items.filter((item) => !deletedSet.has(item.id));
|
||||
textInput.value = "";
|
||||
selectedItemId = null;
|
||||
selectedDownloadUrl = null;
|
||||
downloadLink.href = "#";
|
||||
downloadLink.classList.add("hidden");
|
||||
setEditMode(false);
|
||||
@@ -183,5 +204,11 @@ saveBtn.addEventListener("click", handleSave);
|
||||
editBtn.addEventListener("click", () => setEditMode(true));
|
||||
cancelBtn.addEventListener("click", () => setEditMode(false));
|
||||
deleteBtn.addEventListener("click", handleDelete);
|
||||
downloadLink.addEventListener("click", (event) => {
|
||||
if (!selectedDownloadUrl) {
|
||||
event.preventDefault();
|
||||
alert("다운로드할 항목을 선택하세요.");
|
||||
}
|
||||
});
|
||||
|
||||
loadList();
|
||||
|
||||
Reference in New Issue
Block a user