• 正在查找将来过去时的官方设定集?不如看看万界大百科吧!
  • 《将来过去时》第一部分 现在 魔科纪元的少年少女 即将正式发布!
  • 让我偷偷看一眼小鱼君的博客……
  • 服务器已成功迁移到 阿里云(杭州)

“MediaWiki:Gadget-InPageEdit.js”的版本间的差异

来自小鱼君和他的朋友们
([InPageEdit])
 
(未显示同一用户的70个中间版本)
第1行: 第1行:
/**
+
mw.loader.load('https://cdn.jsdelivr.net/npm/mediawiki-inpageedit@latest/dist/InPageEdit.min.js');
* MediaWiki JS Plugin: In Page Edit
+
mw.hook('InPageEdit').add(function (ctx) {
* Author: 机智的小鱼君
+
  var InPageEdit = ctx.InPageEdit,
* Url: https://github.com/Dragon-Fish/wjghj-wiki/Gadgets/in-page-edit
+
    _msg = ctx._msg,
* Description: Let you edit page without open new tab. And edit Navebox via navbar, edit section via section edit link etc.
+
    wgPageName = mw.config.get('wgPageName'),
**/
+
    wgRevisionId = mw.config.get('wgRevisionId');
function InPageEdit(inPageEditTarget) {
+
   $('#ca-edit').after(
  if (wgIsArticle === false) { // 不可编辑的页面
+
    $('<li>', {
   console.info('[InPageEdit] Not article page, plugin shut down.');
+
     id: 'ca-quick-edit',
   return;
+
     'class': 'collapsible'
  }
+
    }).append(
  if ($('#InPageEdit').length > 0) { // 只能存在一个窗口
+
     $('<span>').append(
   Modal('<span class="error">编辑窗口已存在</span>','InPageEdit Error');
+
      $('<a>', {
    return;
+
       href: 'javascript:void(0)',
  }
+
       text: _msg('quick-edit')
  // 开始执行任务
+
      }).on('click', function () {
  $('body').addClass('action-in-page-edit');
+
       InPageEdit.quickEdit({
  // Variables
+
       page: wgPageName,
  if (inPageEditTarget == undefined) {
+
       revision: wgRevisionId
    inPageEditTarget = mw.config.get('wgPageName');
+
      });
  }
+
     })
  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">' +
 
 
 
    '<h1 id="edit-title">in-page-edit-title</h1>' +
 
    '<textarea id="newcontent" style="width:100%;min-height:300px;max-height:1200px"></textarea>' +
 
 
 
    '<div id="button-area">' +
 
    '<button id="cancle-btn">取消</button> <button id="preview-btn">预览</button> <label><input type="checkbox" id="is-minor"/> 小编辑</label> <div style="float:right"><input id="reason" placeholder="编辑摘要"> <button id="submit-btn">提交</button></div>' +
 
 
 
    '<center id="confirm" style="display:none;clear:both"><span id="code"></span><br/><button id="no">否</button> <button id="yes">是</button></center>' +
 
 
 
     '</div>' +
 
 
 
    '<center id="info-area" style="display:none;"></center>' +
 
 
 
    '<h1>预览</h1>' +
 
    '<div id="preview-area" style="padding:8px; border:2px dotted #aaa"></div>' +
 
 
 
    '</div>'
 
   );
 
   $('#InPageEdit #newcontent').val(origintext);
 
   $('#InPageEdit #edit-title').html('正在编辑: ' + inPageEditTarget);
 
 
 
   // Cancle
 
   $('#InPageEdit #cancle-btn').click(function() {
 
    $('#InPageEdit #confirm').show(); $('#InPageEdit #confirm button').unbind();
 
    $('#InPageEdit #confirm #code').text('确认要取消吗?');
 
    $('#InPageEdit #confirm #no').click(function(){$('#InPageEdit #confirm').hide();});
 
    $('#InPageEdit #confirm #yes').click(function(){
 
     $('body').removeClass('action-in-page-edit');
 
     $('#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() {
 
     $('#InPageEdit #confirm').show(); $('#InPageEdit #confirm button').unbind();
 
    $('#InPageEdit #confirm #code').text('确认要提交吗?');
 
    $('#InPageEdit #confirm #no').click(function(){$('#InPageEdit #confirm').hide();});
 
    $('#InPageEdit #confirm #yes').click(function(){
 
     // Hide elements
 
      $('#InPageEdit #newcontent').attr('readonly','readonly');
 
     $('#InPageEdit #button-area').hide();
 
     $('#InPageEdit #info-area').show().html('<div style="font-weight:bold;color:green;min-height: 50px;line-height: 50px;font-size: 36px;">提交中&nbsp;<img src="https://wjghj.cn/images/9/98/Windows-loading.gif" style="height:36px;width:auto" /></div>');
 
 
 
     // Do post request
 
     var isMinor = $('#InPageEdit #is-minor').prop('checked');
 
     new mw.Api().post({
 
       action: 'edit',
 
      text: $('#InPageEdit #newcontent').val(),
 
      title: inPageEditTarget,
 
      minor: isMinor,
 
      summary: '[InPageEdit] ' + $('#InPageEdit #reason').val(),
 
       token: mw.user.tokens.get('editToken')
 
      }).done(function() {
 
      $('#InPageEdit #info-area').html('<div style="font-weight:bold;color:green;min-height: 50px;line-height: 50px;font-size: 36px;">提交成功</div>');
 
      window.location.reload();
 
     }).fail(function(){
 
       // Show elements
 
      $('#InPageEdit #submit-btn').html('重试');
 
      $('#InPageEdit #newcontent').attr('readonly',false);
 
      $('#InPageEdit #button-area').show();
 
      $('#InPageEdit #confirm').hide();
 
      Modal('<span class="error">Error post your request.</span>','InPageEdit Error');
 
      $('#InPageEdit #info-area').hide().html('');
 
     });
 
    });
 
   });
 
  }
 
}
 
 
 
/** Add button **/
 
$(function() {
 
  if (wgIsArticle === false) {
 
   console.info('[InPageEdit] Not article page, plugin shut down.');
 
   return;
 
  }
 
  $('.action-view #p-userpagetools ul, #p-views .mw-portlet-body ul').append($('<li>').append($('<a>').addClass('in-page-edit-btn-link').attr('href', 'javascript:void(0)').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-article-link'
 
    }).html('[快速编辑]').data({
 
     'target': decodeURIComponent(params.title),
 
     'number': params.section || -1
 
    }).click(function (){
 
     InPageEdit(params.title)
 
    }));
 
   }
 
   });
 
 
});
 
});

2020年10月1日 (四) 05:18的最新版本

mw.loader.load('https://cdn.jsdelivr.net/npm/mediawiki-inpageedit@latest/dist/InPageEdit.min.js');
mw.hook('InPageEdit').add(function (ctx) {
  var InPageEdit = ctx.InPageEdit,
    _msg = ctx._msg,
    wgPageName = mw.config.get('wgPageName'),
    wgRevisionId = mw.config.get('wgRevisionId');
  $('#ca-edit').after(
    $('<li>', {
      id: 'ca-quick-edit',
      'class': 'collapsible'
    }).append(
      $('<span>').append(
        $('<a>', {
          href: 'javascript:void(0)',
          text: _msg('quick-edit')
        }).on('click', function () {
          InPageEdit.quickEdit({
            page: wgPageName,
            revision: wgRevisionId
          });
        })
      )
    )
  );
});