您需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
您需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
您需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
您需要先安装一款用户样式管理器扩展后才能安装此样式。
您需要先安装一款用户样式管理器扩展后才能安装此样式。
您需要先安装一款用户样式管理器扩展后才能安装此样式。
(我已经安装了用户样式管理器,让我安装!)
// ==UserScript==
// @name あぷサムネ表示 [仮]
// @description あぷ/あぷ小の一覧表示にサムネイルを追加します。
// @version 1.5.1
// @match *://dec.2chan.net/up/
// @match *://dec.2chan.net/up/*.htm
// @match *://dec.2chan.net/up2/
// @match *://dec.2chan.net/up2/*.htm
// @icon https://www.2chan.net/favicon.ico
// @grant none
// @namespace https://gf.qytechs.cn/users/809755
// ==/UserScript==
/* jshint esversion: 6 */
(function () {
'use strict';
function copyId(str) {
const t = document.createElement("textarea");
t.textContent = str;
document.body.appendChild(t);
t.select();
const result = document.execCommand("copy");
document.body.removeChild(t)
return result;
}
function getSrc(a) {
if (/\.(bmp|gif|jpe?g|png|webp)$/i.test(a.href)) {
return `https://${a.host.replace(/\./g, '-')}.cdn.ampproject.org/ii/w128/s/${a.host}${a.pathname}`;
}
const filename = a.innerText;
const ext = filename.split('.').pop().toLowerCase();
const filebase = filename.replace(`.${ext}`, '');
if (/\.(mp4|webm|mov)$/i.test(a.href)) {
return `https://thumb.openis.ga/images/${filebase}.jpg`;
}
const iconUrls = {
"mov": "",
"mp3": "",
"mp4": "",
"webm": "",
"unknown": ""
};
return ext in iconUrls ? iconUrls[ext] : iconUrls.unknown;
}
if (!/all\.htm$/.test(location.pathname)) {
[...document.querySelectorAll('a[href*="src/"]')].splice(0, 50).forEach(a => {
if (!/\.(bmp|gif|jpe?g|png|webp|webm|mp4|mov)$/i.test(a.href)) return;
const parent = a.parentNode;
const filename = a.innerText;
const ext = filename.split('.').pop().toLowerCase();
const src = getSrc(a);
const img = document.createElement('img');
img.src = src;
img.height = 72;
img.style.maxWidth = "256px";
img.setAttribute("loading", "lazy");
const btn = document.createElement('a');
btn.href = "#";
btn.innerText = "📝 copy";
btn.onclick = () => {
copyId(a.href.split('/').pop());
}
a.insertBefore(document.createElement('br'), a.firstChild);
a.insertBefore(img, a.firstChild);
parent.insertBefore(document.createElement('br'), null)
parent.insertBefore(btn, null)
})
}
async function showThumbnails(e) {
document.querySelectorAll("div.thumb").forEach(div => div.remove());
const tr = await async function () {
const c = await fetch(`${location.origin}/${location.pathname.split("/")[1]}/all.htm`),
d = new DOMParser().parseFromString((await c.text()), "text/html");
try {
return d.querySelectorAll('tr')
} catch (a) { }
}();
const divMain = document.createElement('div');
const table = document.querySelector(".files");
const parent = table.parentNode;
divMain.className = "thumb";
parent.insertBefore(divMain, table);
[...tr].filter(tr => tr.hasAttribute("class") && tr.querySelector('a')).slice(0, 20000).forEach(tr => {
const a = tr.querySelector('a[href*="src/"]');
const size = tr.querySelector('.fsz').innerHTML;
const date = tr.querySelector('.fnw').innerHTML.replace(/^.*\/(\d+\/\d+)\(.*\)([\d:]+).*/, "$1 $2");
const filename = a.innerText;
const thumbUrl = getSrc(a);
const ext = filename.split('.').pop().toLowerCase();
if (this.onlyVideo && ext !== 'mp4' && ext !== 'webm' && ext !== 'mov') return;
const div = document.createElement('div');
const div2 = document.createElement('div');
const span = document.createElement('span');
span.innerText = filename;
const span2 = document.createElement('span');
span2.innerText = `${size} KB`;
const span3 = document.createElement('span');
span3.innerText = date;
const link = document.createElement('a');
link.href = a.href;
link.setAttribute('target', '_blank');
const center = document.createElement('center');
const img = document.createElement('img');
img.src = thumbUrl;
img.height = img.width = 128;
img.setAttribute("loading", "lazy");
img.setAttribute("style", "object-fit: contain");
const btn = document.createElement('a');
btn.href = "#";
btn.innerText = "📝 copy";
btn.onclick = () => {
copyId(a.href.split('/').pop());
}
div.insertBefore(center, null)
center.insertBefore(link, null);
link.insertBefore(div2, null);
div2.insertBefore(img, null);
link.insertBefore(span, null);
center.insertBefore(document.createElement('br'), null);
center.insertBefore(btn, null);
center.insertBefore(document.createElement('br'), null);
center.insertBefore(span2, null);
center.insertBefore(document.createElement('br'), null);
center.insertBefore(span3, null);
div.style.display = "block";
div.style.float = "left";
div.style.fontSize = "x-small";
div.style.margin = "10px";
divMain.insertBefore(div, null);
})
const divDummy = document.createElement('div');
divDummy.style.clear = "both";
parent.insertBefore(divDummy, table);
while (table.firstChild) {
table.removeChild(table.firstChild);
}
}
document.querySelectorAll(".pagelink").forEach(span => {
const btn = document.createElement('a');
btn.href = "#";
btn.innerText = "[📷]";
btn.addEventListener('click', { onlyVideo: false, handleEvent: showThumbnails });
span.insertBefore(btn, null)
})
document.querySelectorAll(".pagelink").forEach(span => {
const btn = document.createElement('a');
btn.href = "#";
btn.innerText = "[📼]";
btn.addEventListener('click', { onlyVideo: true, handleEvent: showThumbnails });
span.insertBefore(btn, null)
})
})();