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

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

来自LLWiki
跳转到导航 跳转到搜索
(// 使用Wikiplus小工具快速编辑)
标签移动版网页编辑 移动版编辑
 
(未显示同一用户的16个中间版本)
第1行: 第1行:
// 由[[Special:Mypage/common.js]]调用,可以使用ES6语法
// 由[[Special:Mypage/common.js]]调用,可以使用ES6语法
/**
// 生成JS文件大小
* @Description: 自用的工具函数
* @Author: [[User:Bhsd]]
*/
"use strict";
"use strict";
// jshint varstmt: true
/*global mw, $*/
/**
mw.myCopyright = function(cmtitle = mw.config.get('wgTitle')) {
* @Function: 批量添加文件授权协议,只能处理不超过500个文件的分类
mw.loader.using( 'mediawiki.api' ).then(() => {
* @Dependencies: mediawiki.api, ext.gadget.site-lib
const api = new mw.Api();
* @Param {String} cmtitle 分类名,默认为当前所在分类页
console.log('API request: 查询分类下无授权协议的文件');
*/
const timerStart = mw.now();
mw.myCopyright = (cmtitle = mw.config.get( 'wgTitle' )) => {
api.get({action: 'query', prop: 'categories', clcategories: 'Category:原作者保留权利的文件', formatversion: 2,
const cats = ['原作者保留权利的文件', '可自由使用的文件', 'LLWiki版权所有的文件', '使用CC Zero协议的文件'],
generator: 'categorymembers', gcmtitle: `Category:${cmtitle}`, gcmtype: 'file', gcmlimit: 'max'
api = new mw.Api();
}).then(res => {
mw.timedQuery(api, { prop: 'categories', generator: 'categorymembers', gcmtitle: `Category:${cmtitle}`,
console.log(`End API request: 已获得分类下无授权协议的文件,用时 ${mw.now() - timerStart} ms`);
gcmtype: 'file', gcmlimit: 'max', clcategories: cats.map(ele => `Category:${ele}`).join( '|' ), cllimit: 'max'
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批量添加授权协议',
});
}, reason => { mw.notify(`无法获得对应文件。错误原因:${reason}`, {type: 'error'}); });
}).catch(reason => { console.error( `页面${ele.pageid}无法添加授权协议,错误原因:${reason}` ); });
});
});
}, () => {});
};
};


/**
mw.myJsSize = function(table) {
* @Function: 查询JS页面大小
const items = table.find( 'td:first-child' ),
* @Dependencies: mediawiki.api, ext.gadget.site-lib
titles = items.children( 'a' ).toArray().map(ele => ele.title);
*/
mw.loader.using( 'mediawiki.api' ).then(() => {
mw.myJsSize = () => {
console.log('API request: 查询JS页面大小');
const $table = $('.jsTable'), // 总是获取当前页面中的表格
const timerStart = mw.now();
$items = $table.find( 'tr:nth-child(n+1)' ),
new mw.Api().get({ action:'query', prop:'info', titles:titles.join( '|' ), formatversion:2 }).then(data => {
titles = $items.find( 'a' ).toArray().map(ele => ele.title);
console.log(`End API request: 已获得JS页面大小,用时 ${mw.now() - timerStart} ms`);
mw.timedQuery(new mw.Api(), {prop: 'info', titles: titles.join( '|' )}, 'JS页面大小').then(data => {
table.find( 'th:last-child' ).show();
$table.toggleClass( 'jsTable jsTable2' );
const lengths = Object.fromEntries( data.query.pages.map(ele => [ele.title, ele.length]) );
// 注意返回的结果可能顺序不同
items.parent().append(i => $('<td>', {class: 'video-link',
const lengths = Object.fromEntries( data.query.pages.map(ele => [ele.title, ele.length]) );
text: (lengths[ titles[i] ] / 1024).toFixed(1)}).css('text-align', 'right'));
$items.children( 'td:last-child' ).text(i => (lengths[ titles[i] ] / 1024).toFixed(1));
}, reason => {
}, () => { $('#myJsSize').off( 'click' ).one('click', mw.myJsSize); });
mw.notify(`无法获得JS页面大小。错误原因:${reason}`, {type: 'error'});
$('#myJsSize').off( 'click' ).one('click', function() { mw.myJsSize( $(this).parent().next() ); });
});
});
};
};


mw.hook( 'wikipage.content' ).add($content => {
(function() {
$('#myJsSize').one('click', function() { mw.myJsSize( $(this).parent().next() ); });
const $btn = $content.find( '#myJsSize' ).one('click', mw.myJsSize);
if ($btn.length === 0) { return; }
const start = mw.now();
console.log('Hook: wikipage.content, 开始添加JS大小查询按钮');
['wikipage.content', 'wikipage.collapsibleContent', 'wikipage.categories', 'wikipage.diff',
});
'wikipage.editform', 'structuredChangeFilters.ui.initialized', 'codeEditor.configure', // MW原生Hook

'code.prettify', 'wikiplus.dialog', 'transclusion.preview' // 小工具Hook
(() => {
].forEach(ele => { mw.hook(ele).add(() => { console.log(`Hook: ${ele} after ${mw.now() - start} ms`); }); });
/**
* @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', 'local.comments', 'hotcat.ready',
'settings.dialog', 'to.bottom' // 小工具Hook
].forEach(ele => {
mw.hook( ele ).add(x => {
console.log(`Hook: ${ele} after ${mw.now() - start} ms`);
if (x) { console.info(x); }
});
});
}) ();
}) ();

2023年3月17日 (五) 13:30的最新版本

// 由[[Special:Mypage/common.js]]调用,可以使用ES6语法
/**
 * @Description: 自用的工具函数
 * @Author: [[User:Bhsd]]
 */
"use strict";
// jshint varstmt: true
/**
 * @Function: 批量添加文件授权协议,只能处理不超过500个文件的分类
 * @Dependencies: mediawiki.api, ext.gadget.site-lib
 * @Param {String} cmtitle 分类名,默认为当前所在分类页
 */
mw.myCopyright = (cmtitle = mw.config.get( 'wgTitle' )) => {
	const cats = ['原作者保留权利的文件', '可自由使用的文件', 'LLWiki版权所有的文件', '使用CC Zero协议的文件'],
		api = new mw.Api();
	mw.timedQuery(api, { prop: 'categories', generator: 'categorymembers', gcmtitle: `Category:${cmtitle}`,
		gcmtype: 'file', gcmlimit: 'max', clcategories: cats.map(ele => `Category:${ele}`).join( '|' ), cllimit: 'max'
	}, '分类下无授权协议的文件').then(res => {
		res.query.pages.filter(ele => !ele.categories).forEach(ele => {
			api.postWithToken('csrf', {action: 'edit', pageid: ele.pageid, minor: 1, bot: 1,
				prependtext: '==授权协议==\n{{copyright}}\n', summary: '使用API批量添加授权协议',
			}).catch(reason => { console.error( `页面${ele.pageid}无法添加授权协议,错误原因:${reason}` ); });
		});
	}, () => {});
};

/**
 * @Function: 查询JS页面大小
 * @Dependencies: mediawiki.api, ext.gadget.site-lib
 */
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 => {
		$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));
	}, () => { $('#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', 'local.comments', 'hotcat.ready',
		'settings.dialog', 'to.bottom' // 小工具Hook
	].forEach(ele => {
		mw.hook( ele ).add(x => {
			console.log(`Hook: ${ele} after ${mw.now() - start} ms`);
			if (x) { console.info(x); }
		});
	});
}) ();