UserScript版アイコンボタン
script.js$('#editor').click(async e => {
const t = e.target;
if (!(t.tagName === 'IMG' && t.classList.contains('icon') && t.title.endsWith('-button')))return;
e.preventDefault();
e.stopImmediatePropagation();
const title = encodeURIComponent(t.title);
let res = await fetch(`/api/code/${scrapbox.Project.name}/${title}/button.js`);
if (!res.ok) return;
eval(await res.text());
});
data:image/s3,"s3://crabby-images/0fe66/0fe661dd6d81a7562604421fada787bd899ebd5e" alt="すごい すごい"
data:image/s3,"s3://crabby-images/3b69f/3b69f1655bea56c8c4da516907cd9dbe8312de5e" alt="suto3 suto3"
JavaScriptのトリガーとなるアイコンをどこでも置けるということなのかな?
eval
は非推奨なので動的importを使って書き換えました
button2.js
内で execute
という関数をexportして下さい
script2.jsconst buttonFileName = 'button2.js';
document.getElementById('editor').addEventListener('click', e => {
const t = e.target;
if (!(t.tagName === 'IMG' && t.classList.contains('icon') && t.title.endsWith('-button')))return;
e.preventDefault();
e.stopImmediatePropagation();
const title = encodeURIComponent(t.title);
//console.log(`Start loading the script from /api/code/${scrapbox.Project.name}/${title}/${buttonFileName}`);
import(`/api/code/${scrapbox.Project.name}/${title}/${buttonFileName}`)
.then(({execute}) => {
//console.log('Succeeded in loading the script.');
execute();
})
.catch(error => console.error(error));
});