“MediaWiki:Gadget-InPageEdit.js”的版本间的差异
来自小鱼君和他的朋友们
([InPageEdit]) |
|||
第1行: | 第1行: | ||
− | function InPageEdit( | + | function InPageEdit(inPageEditTarget) { |
// Variables | // Variables | ||
− | if ( | + | if (inPageEditTarget == undefined) { |
− | + | inPageEditTarget = mw.config.get('wginPageEditTarget'); | |
} | } | ||
var origintext; | var origintext; | ||
第9行: | 第9行: | ||
new mw.Api().get({ | new mw.Api().get({ | ||
action: "parse", | action: "parse", | ||
− | page: | + | page: inPageEditTarget, |
prop: "wikitext", | prop: "wikitext", | ||
format: "json" | format: "json" | ||
第22行: | 第22行: | ||
// Create area & hide article | // Create area & hide article | ||
$('#mw-content-text').hide(); | $('#mw-content-text').hide(); | ||
− | $('#mw-content-text').before('<div id="InPageEdit">' + '<textarea id="newcontent" style="width:100%;min-height:300px"></textarea>' + '<button id="preview-btn">预览</button><button id="cancle-btn">取消</button><br/><input id="reason" placeholder="原因"> <button id="submit-btn">提交</button>' + '<div id="preview-area"></div></div>'); | + | $('#mw-content-text').before('<div id="InPageEdit">' + '<h2 id="edit-title"></h2><textarea id="newcontent" style="width:100%;min-height:300px"></textarea>' + '<button id="preview-btn">预览</button><button id="cancle-btn">取消</button><br/><input id="reason" placeholder="原因"> <button id="submit-btn">提交</button>' + '<div id="preview-area"></div></div>'); |
$('#InPageEdit #newcontent').val(origintext); | $('#InPageEdit #newcontent').val(origintext); | ||
+ | $('#InPageEdit #edit-title').html('正在编辑: '+inPageEditTarget); | ||
// Cancle | // Cancle | ||
第56行: | 第57行: | ||
action: 'edit', | action: 'edit', | ||
text: $('#InPageEdit #newcontent').val(), | text: $('#InPageEdit #newcontent').val(), | ||
− | title: | + | title: inPageEditTarget, |
summary: '[InPageEdit] ' + $('#InPageEdit #reason').val(), | summary: '[InPageEdit] ' + $('#InPageEdit #reason').val(), | ||
token: mw.user.tokens.get('editToken') | token: mw.user.tokens.get('editToken') | ||
第86行: | 第87行: | ||
'href': 'javascript:void(0)', | 'href': 'javascript:void(0)', | ||
'class': 'in-page-edit-link-edit' | 'class': 'in-page-edit-link-edit' | ||
− | }).text('快速编辑').data({ | + | }).text('<sup title=" 快速编辑">[编]<sup>').data({ |
'target': decodeURIComponent(params.title), | 'target': decodeURIComponent(params.title), | ||
'number': params.section || -1 | 'number': params.section || -1 |
2019年9月23日 (一) 22:13的版本
function InPageEdit(inPageEditTarget) { // Variables if (inPageEditTarget == undefined) { inPageEditTarget = mw.config.get('wginPageEditTarget'); } var origintext; new mw.Api().get({ action: "parse", page: inPageEditTarget, prop: "wikitext", format: "json" }).then(function(data) { origintext = data.parse.wikitext['*']; ajaxArea() }).fail(function() { origintext = '<!-- 注意: 无法获取页面内容。新建页面请删除此行 -->\n'; ajaxArea() }); function ajaxArea() { // Create area & hide article $('#mw-content-text').hide(); $('#mw-content-text').before('<div id="InPageEdit">' + '<h2 id="edit-title"></h2><textarea id="newcontent" style="width:100%;min-height:300px"></textarea>' + '<button id="preview-btn">预览</button><button id="cancle-btn">取消</button><br/><input id="reason" placeholder="原因"> <button id="submit-btn">提交</button>' + '<div id="preview-area"></div></div>'); $('#InPageEdit #newcontent').val(origintext); $('#InPageEdit #edit-title').html('正在编辑: '+inPageEditTarget); // Cancle $('#InPageEdit #cancle-btn').click(function() { var cancleconfirm = confirm('取消吗?'); if (cancleconfirm) { $('#InPageEdit').remove(); $('#mw-content-text').show(); } }); // Preview $('#InPageEdit #preview-btn').click(function() { new mw.Api().post({ action: "parse", text: $('#InPageEdit #newcontent').val(), prop: "text", preview: true, format: "json" }).then(function(data) { var previewcontent = data.parse.text['*']; $('#InPageEdit #preview-area').html(previewcontent); }); }); // Submit $('#InPageEdit #submit-btn').click(function() { var submitconfirm = confirm('提交吗?'); if (submitconfirm) { new mw.Api().post({ action: 'edit', text: $('#InPageEdit #newcontent').val(), title: inPageEditTarget, summary: '[InPageEdit] ' + $('#InPageEdit #reason').val(), token: mw.user.tokens.get('editToken') }).done(function() { $('#InPageEdit').html('<center style="font-weight:bold;color:green;min-height: 300px;line-height: 300px;font-size: 48px;">已提交</center>'); window.location.reload(); }); } }); }; } // Add button $(function() { $('.action-view #p-userpagetools ul').append($('<li>').append($('<a>').attr('href', '#_InPageEdit').text('快速编辑').click(function(){InPageEdit()}))); }); // Get links in ariticle $(function() { var self = this; $('#mw-content-text a.external').each(function(i) { var url = $(this).attr('href'); var reg = /(([^?&=]+)(?:=([^?&=]*))*)/g; var params = {}, match; while (match = reg.exec(url)) { params[match[2]] = decodeURIComponent(match[3]); } if (params.action === 'edit' && params.title !== undefined && params.section !== 'new') { $(this).after($('<a>').attr({ 'href': 'javascript:void(0)', 'class': 'in-page-edit-link-edit' }).text('<sup title="快速编辑">[编]<sup>').data({ 'target': decodeURIComponent(params.title), 'number': params.section || -1 })); $('.in-page-edit-link-edit').click(function() { InPageEdit(params.title) }); } }); });