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

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

来自小鱼君和他的朋友们
([InPageEdit])
第8行: 第8行:
  
 
   if ($('#InPageEdit').length > 0) { // 只能存在一个窗口
 
   if ($('#InPageEdit').length > 0) { // 只能存在一个窗口
    Modal(' 已经存在一个编辑任务!请先关闭现在的编辑窗口。', 'In page edit 错误');
+
    $('#InPageEdit').remove();
   } else { // 开始执行任务
+
   }
   // Variables
+
  // 开始执行任务
   if (inPageEditTarget == undefined) {
+
  // Variables
    inPageEditTarget = mw.config.get('wgPageName');
+
  if (inPageEditTarget == undefined) {
    }
+
   inPageEditTarget = mw.config.get('wgPageName');
    var origintext;
+
  }
 +
  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"></textarea>' + '<button id="cancle-btn">取消</button> <button id="preview-btn">预览</button><div style="float:right"><input id="reason" placeholder="编辑摘要"> <button id="submit-btn">提交</button></div>' + '<h1>预览</h1><div id="preview-area" style="padding:8px; border:2px dotted #aaa"></div>' + '</div>');
 +
    $('#InPageEdit #newcontent').val(origintext);
 +
   $('#InPageEdit #edit-title').html('正在编辑: ' + inPageEditTarget);
  
    new mw.Api().get({
+
    // Cancle
    action: "parse",
+
    $('#InPageEdit #cancle-btn').click(function() {
    page: inPageEditTarget,
+
     var cancleconfirm = confirm(' 取消吗?');
    prop: "wikitext",
+
     if (cancleconfirm) {
    format: "json"
+
     $('#InPageEdit').remove();
    }).then(function(data) {
+
     $('#mw-content-text').show();
     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"></textarea>' +
 
     '<button id="cancle-btn">取消</button> <button id="preview-btn">预览</button><div style="float:right"><input id="reason" placeholder="编辑摘要"> <button id="submit-btn">提交</button></div>' +
 
     '<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
+
   // Preview
    $('#InPageEdit #cancle-btn').click(function() {
+
   $('#InPageEdit #preview-btn').click(function() {
     var cancleconfirm = confirm('取消吗?');
+
    new mw.Api().post({
      if (cancleconfirm) {
+
      action: "parse",
      $('#InPageEdit').remove();
+
     text: $('#InPageEdit #newcontent').val(),
      $('#mw-content-text').show();
+
     prop: "text",
     }
+
     preview: true,
 +
     format: "json"
 +
    }).then(function(data) {
 +
     var previewcontent = data.parse.text['*'];
 +
 
 +
     $('#InPageEdit #preview-area').html(previewcontent);
 
     });
 
     });
 +
   });
  
    // Preview
+
   // Submit
    $('#InPageEdit #preview-btn').click(function() {
+
   $('#InPageEdit #submit-btn').click(function() {
 +
    var submitconfirm = confirm('提交吗?');
 +
    if (submitconfirm) {
 
      new mw.Api().post({
 
      new mw.Api().post({
       action: "parse",
+
       action: 'edit',
 
       text: $('#InPageEdit #newcontent').val(),
 
       text: $('#InPageEdit #newcontent').val(),
       prop: "text",
+
       title: inPageEditTarget,
       preview: true,
+
       summary: '[InPageEdit] ' + $('#InPageEdit #reason').val(),
       format: "json"
+
       token: mw.user.tokens.get('editToken')
      }).then(function(data) {
+
      }).done(function() {
      var previewcontent = data.parse.text['*'];
+
       $('#InPageEdit').html('<center style="font-weight:bold;color:green;min-height: 300px;line-height: 300px;font-size: 48px;">已提交</center>');
 
+
      window.location.reload();
       $('#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
+
 
 +
/** Add button **/
 
$(function() {
 
$(function() {
 
   $('.action-view #p-userpagetools ul').append($('<li>').append($('<a>').attr('href', '#_InPageEdit').text('快速编辑').click(function() {
 
   $('.action-view #p-userpagetools ul').append($('<li>').append($('<a>').attr('href', '#_InPageEdit').text('快速编辑').click(function() {
第91行: 第85行:
 
   })));
 
   })));
 
});
 
});
// Get links in ariticle
+
/** Get links in ariticle **/
 
$(function() {
 
$(function() {
 
   var self = this;
 
   var self = this;

2019年9月23日 (一) 22:53的版本

/**
 * MediaWiki JS Plugin: In Page Edit
 * Author: 机智的小鱼君
 * Url: https://github.com/Dragon-Fish/wjghj-wiki/Gadgets/in-page-edit
 * Description: Let you edit page without open new tab. And edit Navebox via navbar, edit section via section edit link etc.
 **/
function InPageEdit(inPageEditTarget) {

  if ($('#InPageEdit').length > 0) { // 只能存在一个窗口
    $('#InPageEdit').remove();
  }
  // 开始执行任务
  // Variables
  if (inPageEditTarget == undefined) {
    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"></textarea>' + '<button id="cancle-btn">取消</button> <button id="preview-btn">预览</button><div style="float:right"><input id="reason" placeholder="编辑摘要"> <button id="submit-btn">提交</button></div>' + '<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() {
      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'
      }).html('<sup title="快速编辑">[编]<sup>').data({
        'target': decodeURIComponent(params.title),
        'number': params.section || -1
      }));
      $('.in-page-edit-link-edit').click(function() {
        InPageEdit(params.title)
      });
    }
  });
});