melawy-site/public/assets/js/mastodon.js

144 lines
4.9 KiB
JavaScript
Raw Normal View History

2023-12-15 22:49:42 +05:00
async function fetchData(log, tpl) {
2023-12-15 22:40:07 +05:00
var log = document.getElementById('log');
var server_address = `techhub.social`;
// const response = await fetch('json/posts.json');
const response = await fetch(`https://${server_address}/api/v1/accounts/111518136987654656/statuses`);
const data = await response.json();
data.forEach(obj => {
let post_tpl = tpl;
var media_link = "";
Object.entries(obj).forEach(([key, value]) => {
if(key == "id") {
post_tpl = post_tpl.replace(/{post_id}/g, `${value}`);
}
if(key == "account") {
post_tpl = post_tpl.replace(/{id}/g, `${value.id}`);
post_tpl = post_tpl.replace(/{name}/g, `${value.display_name}`);
post_tpl = post_tpl.replace(/{server_address}/g, `${server_address}`);
post_tpl = post_tpl.replace(/{account_name}/g, `<a href="https://${server_address}/@${value.username}" target="_blank">@${value.username}@${server_address}</a>`);
// post_tpl = post_tpl.replace('{avatar}', `<img src="${value.avatar}" alt="${value.username}'s Avatar" style="width:48px;height:48px;">`);
post_tpl = post_tpl.replace(/{avatar}/g, `${value.avatar}`);
post_tpl = post_tpl.replace(/{profile_link}/g, `${value.url}`);
}
if(key == "content") {
2024-01-04 23:42:45 +05:00
let text = value;
let youtube_frame_arr = [];
let spl_arr = text.split('"');
let youtube_link_start = 'https://www.youtube.com/watch?v=';
2024-01-04 23:46:19 +05:00
for (let i = 0; i < spl_arr.length; i++) {
2024-01-04 23:42:45 +05:00
if (spl_arr[i].indexOf(youtube_link_start) === 0) {
let id = spl_arr[i].replace(youtube_link_start, '');
2024-01-04 23:54:06 +05:00
let text_frame = `<iframe class="youtube-video" src="https://www.youtube.com/embed/${id}" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe>`;
2024-01-04 23:42:45 +05:00
youtube_frame_arr.push(text_frame);
}
}
youtube_frame_arr.forEach(function(elem) {
text += elem;
});
2024-01-05 00:58:38 +05:00
// let regular = /<a (.*?)https:\/\/www.youtube.com\/watch\?v\=(.*?)>(.*?)<\/a>/g;
// text = text.replace(regular, '');
2024-01-04 23:42:45 +05:00
value = text;
2023-12-15 22:40:07 +05:00
post_tpl = post_tpl.replace('{content}', `${value}`);
}
if(key == "media_attachments") {
value.forEach(obj1 => {
Object.entries(obj1).forEach(([k, v]) => {
if(k == "preview_url") {
media_link += `<img src="${v}" full_src="${obj1.url}" class="fullscreen" onclick="showFullscreenImage(this);">`;
}
2023-12-15 20:34:37 +05:00
2023-12-15 22:40:07 +05:00
});
});
post_tpl = post_tpl.replace('{media_attachments}', `${media_link}`);
}
if(key == "created_at") {
post_tpl = post_tpl.replace(/{created_at}/g, `${value}`);
}
if(key == "edited_at") {
post_tpl = post_tpl.replace(/{edited_at}/g, `${value}`);
}
if(key == "favorites_count") {
post_tpl = post_tpl.replace(/{favorites_count}/g, `${value}`);
}
if(key == "replies_count") {
post_tpl = post_tpl.replace(/{replies_count}/g, `${value}`);
}
if(key == "reblogs_count") {
post_tpl = post_tpl.replace(/{reblogs_count}/g, `${value}`);
}
// log.innerHTML = log.innerHTML + `${key} ${value}` + '<br>';
});
log.innerHTML += `${post_tpl}<br>`;
});
}
async function openInNewTab(url) {
window.open(url, '_blank').focus();
}
2023-12-15 22:48:05 +05:00
async function getLog() {
2023-12-15 20:34:37 +05:00
let log = document.getElementById('log');
2023-12-15 22:48:05 +05:00
if(log == null) {
setTimeout(getLog, 1000);
} else {
getMastodonPage();
2023-12-15 22:40:07 +05:00
}
2023-12-15 22:48:05 +05:00
}
async function getMastodonPage() {
let log = document.getElementById('log');
2023-12-15 22:40:07 +05:00
2024-01-05 20:28:29 +05:00
let tplUrl = '/json/mastodon-tpl.html';
2023-12-15 22:41:55 +05:00
let response = await fetch(tplUrl);
var tpl = "";
2023-12-15 20:34:37 +05:00
log.innerHTML = "";
const controller = new AbortController();
const signal = controller.signal;
// Cancel the fetch request in 500ms
setTimeout(() => controller.abort(), 500);
try {
const response = await fetch(tplUrl, {signal});
tpl = await response.text();
} catch(error) {
// DOMException: The user aborted a request.
console.log('Error: ', error);
log.innerHTML = "<p>1) Ой всё сломалось :(</p>";
}
if(!tpl) {
log.innerHTML = "<p>2) Ой всё сломалось :(</p>";
}
2023-12-12 13:21:53 +05:00
2023-12-15 22:49:42 +05:00
fetchData(log, tpl);
2023-12-15 22:40:07 +05:00
}
2023-12-12 13:21:53 +05:00
2023-12-15 22:40:07 +05:00
let query = window.location.pathname;
2023-12-12 13:21:53 +05:00
2024-01-05 20:28:29 +05:00
if (query == "/" || query == "/news") {
2023-12-15 22:48:05 +05:00
getLog();
2023-12-15 20:34:37 +05:00
}