mirror of
https://github.com/wah-su/mstickers.git
synced 2025-04-06 08:14:36 +00:00
131 lines
3.7 KiB
JavaScript
131 lines
3.7 KiB
JavaScript
const packPreview = document.getElementById("preview_sticker_pack");
|
|
const packName = document.getElementById("preview_sticker_pack_name");
|
|
const packAuthor_by = document.getElementById("preview_sticker_pack_author_by");
|
|
const packAuthor = document.getElementById("preview_sticker_pack_author");
|
|
const packImage = document.getElementById("preview_sticker_pack_image");
|
|
const packLinkTG = document.getElementById("preview_sticker_pack_add_tg");
|
|
const packLinkFC = document.getElementById("preview_sticker_pack_add_fc");
|
|
const packLinkCI = document.getElementById("preview_sticker_pack_add_ci");
|
|
const ElementInstructionOV = document.getElementById("preview_sticker_pack_add_to_element_overlay");
|
|
const ElementInstruction = document.getElementById("preview_sticker_pack_add_to_element");
|
|
|
|
let index = null;
|
|
const searchParams = new URLSearchParams(window.location.search);
|
|
const pack_id = searchParams.get("id");
|
|
|
|
async function loadIndex() {
|
|
index = await fetch(`${window.location.origin}/stickerpacks/index.json`)
|
|
.then((res) => {
|
|
if (!res.ok) {
|
|
throw new Error("not found");
|
|
}
|
|
return res.json();
|
|
})
|
|
.then((json) => {
|
|
return json;
|
|
})
|
|
.catch((e) => {
|
|
console.error(e);
|
|
return null;
|
|
});
|
|
|
|
if (!pack_id) {
|
|
packName.innerHTML = "no sticker pack provided";
|
|
} else if (!index) {
|
|
packName.innerHTML = "no index.json found";
|
|
} else {
|
|
loadPack(pack_id);
|
|
}
|
|
}
|
|
|
|
async function loadPack(pack) {
|
|
const data = await fetch(
|
|
`${window.location.origin}/stickerpacks/${pack}.json`
|
|
)
|
|
.then((res) => {
|
|
if (!res.ok) {
|
|
throw new Error("not found");
|
|
}
|
|
return res.json();
|
|
})
|
|
.then((json) => {
|
|
return json;
|
|
})
|
|
.catch((e) => {
|
|
console.error(e);
|
|
return null;
|
|
});
|
|
packPreview.classList.remove("hidden");
|
|
packPreview.classList.add("flex");
|
|
if (!data) {
|
|
packName.innerHTML = "sticker pack not found";
|
|
return;
|
|
}
|
|
updatePackInfo(data);
|
|
}
|
|
|
|
function updatePackInfo(data) {
|
|
packName.innerHTML = data.title;
|
|
|
|
if (data.hasOwnProperty("author") && data.author) {
|
|
packAuthor_by.classList.remove("hidden");
|
|
packAuthor.classList.remove("hidden");
|
|
packAuthor.innerHTML = data.author.name;
|
|
|
|
if (data.author.url) {
|
|
packAuthor.href = data.author.url;
|
|
}
|
|
}
|
|
|
|
const _image_id = data.stickers[0].id;
|
|
const _image_path = `${_image_id.slice(0, 2)}/${_image_id.slice(
|
|
2,
|
|
4
|
|
)}/${_image_id.slice(4)}`;
|
|
|
|
packImage.src = `${index.homeserver_url}/__thumbnail/${_image_path}`;
|
|
|
|
if (data.hasOwnProperty("rating") && data.rating) {
|
|
switch (data.rating.toLowerCase()) {
|
|
case "safe":
|
|
document
|
|
.getElementById("preview_sticker_pack_rating_safe")
|
|
.classList.remove("hidden");
|
|
break;
|
|
case "questionable":
|
|
document
|
|
.getElementById("preview_sticker_pack_rating_ques")
|
|
.classList.remove("hidden");
|
|
break;
|
|
case "explicit":
|
|
document
|
|
.getElementById("preview_sticker_pack_rating_expl")
|
|
.classList.remove("hidden");
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
packLinkTG.href = `https://t.me/addstickers/${data.id}`;
|
|
packLinkTG.classList.remove("hidden");
|
|
packLinkTG.classList.add("flex");
|
|
|
|
if (data.hasOwnProperty("room_id") && data.room_id) {
|
|
packLinkFC.href = `https://matrix.to/#/${data.room_id}`;
|
|
packLinkCI.href = `https://matrix.to/#/${data.room_id}`;
|
|
packLinkFC.classList.remove("hidden");
|
|
packLinkFC.classList.add("flex");
|
|
packLinkCI.classList.remove("hidden");
|
|
packLinkCI.classList.add("flex");
|
|
}
|
|
}
|
|
|
|
function toggleElementInstruction() {
|
|
ElementInstructionOV.classList.toggle("hidden");
|
|
ElementInstruction.classList.toggle("hidden");
|
|
|
|
ElementInstruction.classList.toggle("flex");
|
|
}
|
|
|
|
loadIndex();
|