2022-11-11 05:19:42 +00:00
|
|
|
const getSiteUrl = async () => await fetch("/api/site")
|
|
|
|
.then(res => res.text())
|
|
|
|
.then(text => {
|
|
|
|
if (text == "unset") {
|
|
|
|
return window.location.host;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
});
|
2022-11-11 02:17:39 +00:00
|
|
|
|
2020-02-14 18:52:14 +00:00
|
|
|
const refreshData = async () => {
|
2020-02-16 14:46:29 +00:00
|
|
|
let data = await fetch("/api/all").then(res => res.text());
|
2020-02-14 18:52:14 +00:00
|
|
|
data = data
|
|
|
|
.split("\n")
|
|
|
|
.filter(line => line !== "")
|
|
|
|
.map(line => line.split(","))
|
|
|
|
.map(arr => ({
|
2022-11-03 21:53:04 +00:00
|
|
|
short: arr[0],
|
2020-02-14 18:52:14 +00:00
|
|
|
long: arr[1],
|
2022-11-03 21:53:04 +00:00
|
|
|
hits: arr[2]
|
2020-02-14 18:52:14 +00:00
|
|
|
}));
|
|
|
|
|
|
|
|
displayData(data);
|
|
|
|
};
|
|
|
|
|
2022-11-11 02:17:39 +00:00
|
|
|
const displayData = async (data) => {
|
2022-11-11 05:19:42 +00:00
|
|
|
let site = await getSiteUrl();
|
2022-11-11 02:31:25 +00:00
|
|
|
site = site.replace(/(^\w+:|^)\/\//, '');
|
2022-11-10 00:55:50 +00:00
|
|
|
table_box = document.querySelector(".pure-table");
|
|
|
|
if (data.length == 0) {
|
|
|
|
table_box.style.visibility = "hidden";
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
const table = document.querySelector("#url-table");
|
|
|
|
table_box.style.visibility = "visible";
|
|
|
|
table.innerHTML = ''; // Clear
|
2022-11-11 02:17:39 +00:00
|
|
|
data.forEach(tr => table.appendChild(TR(tr, site)));
|
2022-11-10 00:55:50 +00:00
|
|
|
}
|
2020-02-14 18:52:14 +00:00
|
|
|
};
|
|
|
|
|
2022-11-11 05:19:42 +00:00
|
|
|
const addAlertBox = async (text, col) => {
|
2022-11-11 01:01:21 +00:00
|
|
|
document.getElementById("alertBox")?.remove();
|
2022-11-09 01:18:14 +00:00
|
|
|
const controls = document.querySelector(".pure-controls");
|
2022-11-11 00:11:57 +00:00
|
|
|
const alertBox = document.createElement("p");
|
|
|
|
alertBox.setAttribute("id", "alertBox");
|
2022-11-11 05:19:42 +00:00
|
|
|
alertBox.setAttribute("style", `color:${col}`);
|
|
|
|
alertBox.innerHTML = text;
|
2022-11-11 00:11:57 +00:00
|
|
|
controls.appendChild(alertBox);
|
2022-11-11 01:01:21 +00:00
|
|
|
};
|
2022-11-09 01:18:14 +00:00
|
|
|
|
2022-11-11 02:17:39 +00:00
|
|
|
const TR = (row, site) => {
|
2020-02-14 18:52:14 +00:00
|
|
|
const tr = document.createElement("tr");
|
|
|
|
const longTD = TD(A(row.long));
|
2022-11-11 02:17:39 +00:00
|
|
|
const shortTD = TD(A_INT(row.short, site));
|
2022-11-03 21:53:04 +00:00
|
|
|
const hitsTD = TD(row.hits);
|
2020-02-16 15:52:54 +00:00
|
|
|
const btn = deleteButton(row.short);
|
2020-02-14 18:52:14 +00:00
|
|
|
|
|
|
|
tr.appendChild(shortTD);
|
2022-11-03 19:47:38 +00:00
|
|
|
tr.appendChild(longTD);
|
2022-11-03 21:53:04 +00:00
|
|
|
tr.appendChild(hitsTD);
|
2020-02-16 15:52:54 +00:00
|
|
|
tr.appendChild(btn);
|
2020-02-14 18:52:14 +00:00
|
|
|
|
|
|
|
return tr;
|
|
|
|
};
|
|
|
|
|
2022-11-11 05:19:42 +00:00
|
|
|
const copyShortUrl = async (link) => {
|
|
|
|
const site = await getSiteUrl();
|
2022-11-12 00:52:22 +00:00
|
|
|
try {
|
|
|
|
navigator.clipboard.writeText(`${site}/${link}`);
|
|
|
|
addAlertBox(`Short URL ${link} was copied to clipboard!`, "green");
|
|
|
|
} catch (e) {
|
|
|
|
console.log(e);
|
|
|
|
addAlertBox("Could not copy short URL to clipboard, please do it manually.", "red");
|
|
|
|
}
|
|
|
|
|
2022-11-11 01:01:21 +00:00
|
|
|
};
|
|
|
|
|
2022-11-12 00:52:22 +00:00
|
|
|
const addProtocol = (input) => {
|
|
|
|
var url = input.value.trim();
|
|
|
|
if (url != "" && !~url.indexOf(":/")) {
|
|
|
|
url = "https://" + url;
|
|
|
|
}
|
|
|
|
input.value = url;
|
|
|
|
return input
|
|
|
|
}
|
|
|
|
|
2020-02-14 18:52:14 +00:00
|
|
|
const A = (s) => `<a href='${s}'>${s}</a>`;
|
2022-11-11 02:17:39 +00:00
|
|
|
const A_INT = (s, t) => `<a href="javascript:copyShortUrl('${s}');">${t}/${s}</a>`;
|
2020-02-14 18:52:14 +00:00
|
|
|
|
2020-02-16 15:52:54 +00:00
|
|
|
const deleteButton = (shortUrl) => {
|
2022-11-10 00:55:50 +00:00
|
|
|
const td = document.createElement("td");
|
2020-02-16 15:52:54 +00:00
|
|
|
const btn = document.createElement("button");
|
|
|
|
|
|
|
|
btn.innerHTML = "×";
|
|
|
|
|
|
|
|
btn.onclick = e => {
|
|
|
|
e.preventDefault();
|
2022-11-09 23:58:15 +00:00
|
|
|
if (confirm("Do you want to delete the entry " + shortUrl + "?")) {
|
2022-11-11 01:01:21 +00:00
|
|
|
document.getElementById("alertBox")?.remove();
|
2022-11-09 23:58:15 +00:00
|
|
|
fetch(`/api/${shortUrl}`, {
|
|
|
|
method: "DELETE"
|
|
|
|
}).then(_ => refreshData());
|
|
|
|
}
|
2020-02-16 15:52:54 +00:00
|
|
|
};
|
2022-11-10 00:55:50 +00:00
|
|
|
td.setAttribute("name", "deleteBtn");
|
|
|
|
td.appendChild(btn);
|
|
|
|
return td;
|
2020-02-16 15:52:54 +00:00
|
|
|
};
|
|
|
|
|
2020-02-14 18:52:14 +00:00
|
|
|
const TD = (s) => {
|
|
|
|
const td = document.createElement("td");
|
2022-11-03 20:19:22 +00:00
|
|
|
const div = document.createElement("div");
|
|
|
|
div.innerHTML = s;
|
|
|
|
td.appendChild(div);
|
2020-02-14 18:52:14 +00:00
|
|
|
return td;
|
|
|
|
};
|
|
|
|
|
|
|
|
const submitForm = () => {
|
|
|
|
const form = document.forms.namedItem("new-url-form");
|
|
|
|
const longUrl = form.elements["longUrl"];
|
|
|
|
const shortUrl = form.elements["shortUrl"];
|
|
|
|
|
2020-11-09 09:30:30 +00:00
|
|
|
const url = `/api/new`;
|
2020-02-14 18:52:14 +00:00
|
|
|
|
|
|
|
fetch(url, {
|
2020-11-09 09:30:30 +00:00
|
|
|
method: "POST",
|
|
|
|
body: `${longUrl.value};${shortUrl.value}`
|
2020-02-14 18:52:14 +00:00
|
|
|
})
|
2022-11-11 02:17:39 +00:00
|
|
|
.then(res => {
|
2022-11-09 00:23:41 +00:00
|
|
|
if (!res.ok) {
|
2022-11-12 00:52:22 +00:00
|
|
|
addAlertBox("Short URL is not valid or it's already in use!", "red");
|
2022-11-11 01:01:21 +00:00
|
|
|
return "error";
|
2022-11-09 00:23:41 +00:00
|
|
|
}
|
|
|
|
else {
|
2022-11-11 00:11:57 +00:00
|
|
|
return res.text();
|
2022-11-09 00:23:41 +00:00
|
|
|
}
|
2022-11-11 02:17:39 +00:00
|
|
|
}).then(text => {
|
2022-11-11 01:01:21 +00:00
|
|
|
if (text != "error") {
|
|
|
|
copyShortUrl(text);
|
|
|
|
longUrl.value = "";
|
|
|
|
shortUrl.value = "";
|
|
|
|
refreshData();
|
|
|
|
}
|
2022-11-03 19:47:38 +00:00
|
|
|
});
|
2020-02-14 18:52:14 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
(async () => {
|
|
|
|
await refreshData();
|
|
|
|
const form = document.forms.namedItem("new-url-form");
|
|
|
|
form.onsubmit = e => {
|
|
|
|
e.preventDefault();
|
|
|
|
submitForm();
|
|
|
|
}
|
|
|
|
})();
|