LLWiki正在建设中,欢迎加入我们

“User:Bhsd/tool.js”的版本间差异

跳转到导航 跳转到搜索
删除457字节 、​ 2023年3月17日 (五) 13:30
// 使用Wikiplus小工具快速编辑
(// 使用Wikiplus小工具快速编辑)
标签移动版网页编辑 移动版编辑
 
(未显示同一用户的3个中间版本)
* @Description: 自用的工具函数
* @Author: [[User:Bhsd]]
* @Dependencies: mediawiki.util
*/
"use strict";
// jshint varstmt: true
/**
* @Function: 批量添加文件授权协议,只能处理不超过500个文件的分类
*/
mw.myCopyright = (cmtitle = mw.config.get( 'wgTitle' )) => {
const cats = ['原作者保留权利的文件', '可自由使用的文件', 'LLWiki版权所有的文件', '使用CC Zero协议的文件'];,
const api = new mw.Api();
mw.loader.using( ['mediawiki.api', 'ext.gadget.site-lib'] ).then(() => {
mw.timedQuery(api, { prop: 'categories', generator: 'categorymembers', gcmtitle: `Category:${cmtitle}`,
const api = new mw.Api();
gcmtype: 'file', gcmlimit: 'max', clcategories: cats.map(ele => `Category:${ele}`).join( '|' ), cllimit: 'max'
mw.timedQuery(api, { prop: 'categories', generator: 'categorymembers', gcmtitle: `Category:${cmtitle}`,
}, '分类下无授权协议的文件').then(res => {
gcmtype: 'file', gcmlimit: 'max', clcategories: cats.map(ele => `Category:${ele}`).join( '|' )
res.query.pages.filter(ele => !ele.categories).forEach(ele => {
}, '分类下无授权协议的文件').then(res => {
api.postWithToken('csrf', {action: 'edit', pageid: ele.pageid, minor: 1, bot: 1,
res.query.pages.filter(ele => !ele.categories).forEach(ele => {
prependtext: '==授权协议==\n{{copyright}}\n', summary: '使用API批量添加授权协议',
api.postWithToken('csrf', {action: 'edit', pageid: ele.pageid, minor: 1, bot: 1,
}).catch(reason => { console.error( `页面${ele.pageid}无法添加授权协议,错误原因:${reason}` ); });
prependtext: '==授权协议==\n{{copyright}}\n', summary: '使用API批量添加授权协议',
});
}).catch(reason => { console.error( `页面${ele.pageid}无法添加授权协议,错误原因:${reason}` ); });
}, () => {});
}, () => {});
});
};
 
*/
mw.myJsSize = () => {
const $table = $('.jsTable'), // 总是获取当前页面中的表格
$items = $table.find( 'tr:nth-child(n+1)' ),
titles = $items.find( 'a' ).toArray().map(ele => ele.title);
mw.timedQuery(new mw.Api(), {prop: 'info', titles: titles.join( '|' )}, 'JS页面大小').then(data => {
mw.loader.using( ['mediawiki.api', 'ext.gadget.site-lib'] ).then(() => {
$table.toggleClass( 'jsTable jsTable2' );
mw.timedQuery(new mw.Api(), {prop: 'info', titles: titles.join( '|' )}, 'JS页面大小').then(data => {
// 注意返回的结果可能顺序不同
$table.toggleClass( 'jsTable jsTable2' );
const lengths = Object.fromEntries( data.query.pages.map(ele => [ele.title, ele.length]) );
// 注意返回的结果可能顺序不同
$items.children( 'td:last-child' ).text(i => (lengths[ titles[i] ] / 1024).toFixed(1));
const lengths = Object.fromEntries( data.query.pages.map(ele => [ele.title, ele.length]) );
}, () => { $('#myJsSize').off( 'click' ).one('click', mw.myJsSize); });
$items.children( 'td:last-child' ).text(i => (lengths[ titles[i] ] / 1024).toFixed(1));
}, () => { $('#myJsSize').off( 'click' ).one('click', mw.myJsSize); });
});
};
 
mw.hook( 'wikipage.content' ).add($content => {
const $btn = $content.find( '#myJsSize' ).one('click', mw.myJsSize);
if ($btn.length === 0) { return; }
console.log('Hook: wikipage.content, 开始添加JS大小查询按钮');
});
 
(() => {
/**
* @Function: 记录所有触发的Hook
*/
const start = mw.now();
['postEdit', 'wikipage.content', 'wikipage.collapsibleContent', 'wikipage.categories', 'wikipage.diff',
'wikipage.editform', 'structuredChangeFilters.ui.initialized', 'codeEditor.configure', // MW原生Hook
'code.prettify', 'wikiplus.dialog', 'transclusion.preview', 'local.comments', 'hotcat.ready',
'settings.dialog', 'to.bottom', 'mobile.menu' // 小工具Hook
].forEach(ele => {
mw.hook( ele ).add(x => {
console.log(`Hook: ${ele} after ${mw.now() - start} ms`);
if (x) { console.info(x); }
});
});
}) ();
16,874

个编辑

导航菜单