2023年政策修订增补工作正在进行中,欢迎参与!
User:Iehcni/js/disambigHelper.js
< User:Iehcni | js
注意:在保存之后,您可能需要清除浏览器缓存才能看到所作出的变更的影响。
- Firefox/Safari:按住“Shift”的同时单击“刷新”,或按“Ctrl-F5”或“Ctrl-R”(Mac为“⌘-R”)
- Google Chrome:按“Ctrl-Shift-R”(Mac为“⌘-Shift-R”)
- Internet Explorer:按住“Ctrl”的同时单击“刷新”,或按“Ctrl-F5”
- Opera:在“工具→首选项”中清除缓存
- 如果您已登录但该页面出现未登录状态,请尝试在地址栏的地址最后添加代码
?_=1
来访问最新页面。 - 添加代码后的本页地址如下:
-{R|https://moegirl.icu/User:Iehcni/js/disambigHelper.js?_=1}-
/*
* 功能:鼠標懸浮在消歧義鏈接旁標識符(“?”)上顯示或刷新義項,移開懸浮框退出
義項邊有鏈接按鈕和編輯按鈕,按鈕為紅色表示可能出現錯誤編輯
* 已知問題:1. 沒有時間戳功能,有編衝危險;
2. 部分鏈接無法加載相應 class
目測是 mw 的鍋,因為<del>概率很低</del>懶不打算改,等 mw 修復;
3. Navbox;
4. 懸浮框顯示問題;
5. 錯誤處理沒寫,希望不會遇到錯誤
*/
$(function () {
if (!mw.config.get( 'wgIsArticle' ) || mw.config.get( 'wgPageContentModel' ) !== 'wikitext') { return }
const msg = {
loading: '加载中...',
loadingFailed: '( ゚∀。)加载失败',
editing: '修改中...',
edited: '修改成功!正在刷新页面...',
editFailed: '( ゚∀。)修改失败',
disambig: '消歧义',
}
switch (mw.config.get().wgUserLanguage) {
case 'zh-hant':
msg.loading = '加載中...';
msg.loadingFailed = '( ゚∀。)加載失敗';
msg.editing = '修改中...';
msg.edited = '修改成功!正在刷新頁面...';
msg.editFailed = '( ゚∀。)修改失敗';
msg.disambig = '消歧義';
break;
}
const edit = `<img class="icon" alt="edit" src="">`;
const edit_all = `<img class="icon" alt="edit_all" src="">`;
const link = `<img class="icon" alt="link" src="">`;
const style = `<style>
a.mw-disambig.mw-disambig { color: #ff8921; }
a.mw-disambig.mw-disambig:visited { color: #d2711b; }
a.mw-redirect.mw-disambig { color: #ff6421; }
a.mw-redirect.mw-disambig:visited { color: #d2521b; }
div.disambig-box {
width: 200px;
max-height: 220px;
overflow-y: scroll;
border-radius: 2px;
box-shadow: rgba(0, 0, 0, 0.156863) 0px 3px 10px, rgba(0, 0, 0, 0.227451) 0px 3px 10px;
-webkit-box-shadow: rgba(0, 0, 0, 0.156863) 0px 3px 10px, rgba(0, 0, 0, 0.227451) 0px 3px 10px;
margin: 0;
padding: 0;
color: #000;
background: #FFF;
position: absolute;
font-size: 14px;
font-style: normal;
font-weight: normal;
text-decoration: none;
text-align: left;
display: none;
transition: all 500ms cubic-bezier(.23, 1, .32, 1) 0ms;
z-index: 999;
}
.disambig-box ul.disambig-ul {
list-style: none;
padding: 0 !important;
margin: 0 !important;
}
.disambig-box li {
color: #000 !important;
padding: 2px 10px;
transition: all 500ms cubic-bezier(.23, 1, .32, 1) 0ms;
}
.disambig-box li:hover { background: #F0F0F0; }
.disambig-box li a { text-decoration: none; }
.icon {
margin-left: 5px;
width: 20px;
opacity: .7;
transition: all 500ms cubic-bezier(.23, 1, .32, 1) 0ms;
}
.icon:hover { opacity: 1; }
</style>`;
$('body').append(style);
const getLinkTitle = element => decodeURI($(element).attr('href').substring(1)).replace('%2F', '/')
const getWikitext = title => {
return new Promise(resolve => {
new mw.Api().get({
action: 'parse',
page: title,
redirects: true,
prop: 'wikitext',
format: 'json',
}).done((data) => {
resolve(data.parse.wikitext['*']);
}).fail((a, b, errorThrown) => {
resolve(errorThrown);
});
})
}
const repeat_num_list = function() {
let list = {}
$('.mw-disambig').each(function() {
const title = getLinkTitle(this);
list[title] = list[title] + 1 || 0;
});
return list
}();
$('.mw-disambig').each(async function() {
const title = getLinkTitle(this); // 鏈接頁面標題
const display_title = $(this).text(); // 管道符後顯示文字
let id_title = title.split('.').join(''); // 防止消歧義頁標題含 .
let repeat_now = $(`#${id_title}`).length;
if (repeat_now > 0) { id_title = id_title + repeat_now + 1; } // 同頁面出現相同的消歧義鏈接
const edit_icon = repeat_num_list[title] === 0 ? edit : edit_all;
const send = msg => { $(`#${id_title} ul`).empty().append(`<li>${msg}</li>`) }
$(this).after(
$('<div>', {
id: id_title,
class: 'disambig-box',
}).on('mouseleave', () => {
$(`#${id_title}`).hide(150, 'swing');
}).append('<ul class="disambig-ul">'),
$('<sup>').append($('<a>', {
href: 'javascript:void(0)',
text: '?',
class: id_title,
}))
)
$(`a.${id_title}`).on('mouseenter', async () => {
$(`#${id_title}`).css({ // 定位
'left': $(this).position()['left'] + 10,
'top': $(this).position()['top'] + 16,
});
send(msg.loading);
$(`#${id_title}`).show(150, 'swing');
let senses = await getWikitext(title); // 獲取義項
senses = senses.split('\n').map(
sense => sense.substring(0, sense.indexOf('——'))
).map(sense => {
if (sense.match(/\[\[/g) && !sense.match(/\[\[File:/gi)) {
return sense.split('[[')[1].split(']]')[0]
} else if (sense.match(/\{\{(dis|dl)\|/gi)) { // {{dis}}, {{dl}}
return sense.split(/\{\{(dis|dl)\|/gi)[1]
} else if (sense.match(/\{\{coloredlink\|/gi)) { // {{coloredlink}}
return sense.split(/\{\{coloredlink\|/gi)[1]
}
}).filter(sense => sense).map(sense => sense.split('|')[0]);
$(`#${id_title} ul`).empty();
if (!senses[0]) { return send(msg.loadingFailed) }
for (const sense of senses) { // 填充至顯示框
let safe_sense = sense.replace('"', '"');
$(`#${id_title} ul`).append(`<li id="${safe_sense}">${sense}<a href="/${safe_sense}">${link}</a><a>${edit_icon}</a></li>`);
document.getElementById(sense).lastChild.addEventListener('click', async () => {
send(msg.editing);
let page_title = mw.config.get().wgPageName;
let wikitext = await getWikitext(page_title);
let origin_link = `[[${title}]]`;
if (title !== display_title) {
origin_link = `[[${title}|${display_title}]]`;
}
new mw.Api().postWithToken('csrf', {
action: 'edit',
text: wikitext.replaceAll(origin_link, `[[${sense}|${display_title}]]`),
title: page_title,
minor: true,
nocreate: true,
summary: `${msg.disambig}:[[${title}]]→[[${sense}]]`,
errorformat: 'plaintext'
}).done((data) => {
send(msg.edited);
window.location.reload();
}).fail((a, b, errorThrown) => {
send(`${msg.editFailed}(${errorThrown})`);
});
});
}
})
})
});