88 lines
4.4 KiB
JavaScript
88 lines
4.4 KiB
JavaScript
const sitesjs = {
|
|
requestAPI: (url, callback, timeout) => {
|
|
let retryTimes = 5;
|
|
function request() {
|
|
return new Promise((resolve, reject) => {
|
|
let status = 0; // 0 等待 1 完成 2 超时
|
|
let timer = setTimeout(() => {
|
|
if (status === 0) {
|
|
status = 2;
|
|
timer = null;
|
|
reject('请求超时');
|
|
if (retryTimes == 0) {
|
|
timeout();
|
|
}
|
|
}
|
|
}, 5000);
|
|
fetch(url).then(function(response) {
|
|
if (status !== 2) {
|
|
clearTimeout(timer);
|
|
resolve(response);
|
|
timer = null;
|
|
status = 1;
|
|
}
|
|
if (response.ok) {
|
|
return response.json();
|
|
}
|
|
throw new Error('Network response was not ok.');
|
|
}).then(function(data) {
|
|
retryTimes = 0;
|
|
callback(data);
|
|
}).catch(function(error) {
|
|
if (retryTimes > 0) {
|
|
retryTimes -= 1;
|
|
setTimeout(() => {
|
|
request();
|
|
}, 5000);
|
|
} else {
|
|
timeout();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
request();
|
|
},
|
|
layout: (cfg) => {
|
|
const el = $(cfg.el)[0];
|
|
$(el).append('<div class="loading-wrap"><svg xmlns="http://www.w3.org/2000/svg" width="2em" height="2em" preserveAspectRatio="xMidYMid meet" viewBox="0 0 24 24"><g fill="none" stroke="currentColor" stroke-linecap="round" stroke-width="2"><path stroke-dasharray="60" stroke-dashoffset="60" stroke-opacity=".3" d="M12 3C16.9706 3 21 7.02944 21 12C21 16.9706 16.9706 21 12 21C7.02944 21 3 16.9706 3 12C3 7.02944 7.02944 3 12 3Z"><animate fill="freeze" attributeName="stroke-dashoffset" dur="1.3s" values="60;0"/></path><path stroke-dasharray="15" stroke-dashoffset="15" d="M12 3C16.9706 3 21 7.02944 21 12"><animate fill="freeze" attributeName="stroke-dashoffset" dur="0.3s" values="15;0"/><animateTransform attributeName="transform" dur="1.5s" repeatCount="indefinite" type="rotate" values="0 12 12;360 12 12"/></path></g></svg></div>');
|
|
sitesjs.requestAPI(cfg.api, function(data) {
|
|
$(el).find('.loading-wrap').remove();
|
|
for (let item of data.content) {
|
|
var cell = `<div class="grid-cell site-card">`;
|
|
cell += `<a class="card-link" target="_blank" rel="external nofollow noopener noreferrer" href="${item.url}">`;
|
|
cell += `<img src="${item.cover || item.screenshot}" onerror="javascript:this.removeAttribute(\'data-src\');this.src=\'${cfg.screenshot}\';"/>`;
|
|
cell += `<div class="info">`;
|
|
cell += `<img src="${item.icon || item.avatar || cfg.avatar}" onerror="javascript:this.removeAttribute(\'data-src\');this.src=\'${cfg.avatar}\';"/>`;
|
|
cell += `<span class="title">${item.title}</span>`;
|
|
cell += `<span class="desc">${item.description || item.url}</span>`;
|
|
cell += `</div>`;
|
|
cell += `</a>`;
|
|
cell += `</div>`;
|
|
$(el).find('.grid-box').append(cell);
|
|
}
|
|
}, function() {
|
|
$(el).find('.loading-wrap svg').remove();
|
|
$(el).find('.loading-wrap').append('<svg xmlns="http://www.w3.org/2000/svg" width="2em" height="2em" preserveAspectRatio="xMidYMid meet" viewBox="0 0 24 24"><g fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2"><path stroke-dasharray="60" stroke-dashoffset="60" d="M12 3L21 20H3L12 3Z"><animate fill="freeze" attributeName="stroke-dashoffset" dur="0.5s" values="60;0"/></path><path stroke-dasharray="6" stroke-dashoffset="6" d="M12 10V14"><animate fill="freeze" attributeName="stroke-dashoffset" begin="0.6s" dur="0.2s" values="6;0"/></path></g><circle cx="12" cy="17" r="1" fill="currentColor" fill-opacity="0"><animate fill="freeze" attributeName="fill-opacity" begin="0.8s" dur="0.4s" values="0;1"/></circle></svg>');
|
|
$(el).find('.loading-wrap').addClass('error');
|
|
});
|
|
},
|
|
}
|
|
|
|
$(function () {
|
|
const els = document.getElementsByClassName('stellar-sites-api');
|
|
for (var i = 0; i < els.length; i++) {
|
|
const el = els[i];
|
|
const api = el.getAttribute('api');
|
|
if (api == null) {
|
|
continue;
|
|
}
|
|
var cfg = new Object();
|
|
cfg.class = el.getAttribute('class');
|
|
cfg.el = el;
|
|
cfg.api = api;
|
|
cfg.avatar = 'https://gcore.jsdelivr.net/gh/cdn-x/placeholder@1.0.12/link/8f277b4ee0ecd.svg';
|
|
cfg.screenshot = 'https://gcore.jsdelivr.net/gh/cdn-x/placeholder@1.0.12/cover/76b86c0226ffd.svg';
|
|
sitesjs.layout(cfg);
|
|
}
|
|
});
|