มีเดียวิกิ:Gadget-massdelete.js

หมายเหตุ: หลังจากบันทึกแล้ว, คุณต้องล้างแคชของเบราเซอร์เสียก่อน จึงจะเห็นการเปลี่ยนแปลง: Mozilla: กด reload(หรือ ctrl-r), IE / Opera: ctrl-f5, Safari: cmd-r, Konqueror ctrl-r.

mw.loader.using(['mediawiki.api', 'mediawiki.Title'], function () {
    "use strict";

    var config = mw.config.get(['wgNamespaceNumber', 'wgTitle', 'wgUserGroups', 'skin']);

    function removeBlanks(arr) {
        var ret = [];
        var i, len;
        for (i = 0, len = arr.length; i < len; i++) {
            var s = arr[i];
            s = s.trim();
            if (s) {
                ret.push(s);
            }
        }
        return ret;
    }

    function doMassDelete() {
        document.getElementById("wpMassDeleteSubmit").disabled = true;
        var articles = document.getElementById("wpMassDeletePages").value.split("\n");
        articles = removeBlanks(articles);
        if (!articles.length) {
            return;
        }
        var
            api = new mw.Api(),
            wpMassDeleteReasons = document.getElementById("wpMassDeleteReasons").value,
            wpMassDeleteReason = document.getElementById("wpMassDeleteReason").value,
            deleted = 0,
            failed = [],
            error = [],
            deferreds = [],
            reason = wpMassDeleteReasons == "other" ?
                wpMassDeleteReason :
                wpMassDeleteReasons + (wpMassDeleteReason ? " (" + wpMassDeleteReason + ")" : ""),
            onSuccess = function () {
                deleted++;
                document.getElementById("wpMassDeleteSubmit").value = "(" + deleted + ")";
            };

        function makeDeleteFunc(article) {
            return function () {
                return $.Deferred(function (deferred) {
                    var promise = api.postWithToken('delete', {
                        format: 'json',
                        action: 'delete',
                        title: article,
                        reason: reason
                    });
                    promise.done(onSuccess);
                    promise.fail(function (code, obj) {
                        failed.push(article);
                        error.push(obj.error.info);
                    });
                    promise.always(function () {
                        deferred.resolve();
                    });
                });
            };
        }

        // Make a chain of deferred objects. We chain them rather than execute them in
        // parallel so that we don't make 1000 simultaneous delete requests and bring the
        // site down. We use deferred objects rather than the promise objects returned
        // from the API request so that the chain continues even if some articles gave
        // errors.
        var deferred = makeDeleteFunc(articles[0])();
        for (var i = 1, len = articles.length; i < len; i++) {
            deferred = deferred.then(makeDeleteFunc(articles[i]));
        }

        // Show the output and do cleanup once all the requests are done.
        $.when(deferred).then(function () {
            document.getElementById("wpMassDeleteSubmit").value = "สำเร็จ (" + deleted + ")";
            if (failed.length) {
                var $failedList = $('<ul>');
                for(var x = 0; x < failed.length; x++) {
                    // Link the titles in the "failed" array
                    var failedTitle = mw.Title.newFromText(failed[x]);
                    var $failedItem = $('<li>');
                    if (failedTitle) {
                        $failedItem.append( $('<a>')
                            .attr('href', failedTitle.getUrl())
                            .text(failed[x])
                        );
                    } else {
                        $failedItem.text(failed[x]);
                    }
                    $failedItem.append(document.createTextNode(': ' + error[x]));
                    $failedList.append($failedItem);
                }
                $('#wpMassDeleteFailedContainer')
                    .append($('<br />'))
                    .append($('<b>')
                        .text('การลบล้มเหลว:')
                    )
                    .append($failedList);
            }
        });
    }
     
    function massdeleteform() {
        var bodyContent = (config.skin == "cologneblue" ? "article" : "bodyContent");
        document.getElementsByTagName("h1")[0].textContent = "ลบหน้าจำนวนมาก";
        document.title = "ลบหน้าจำนวนมาก";
        document.getElementById(bodyContent).innerHTML = '<h3 id="siteSub">Lifted From Wikimedia Incubator - revision of 2015-10-28</h3><br />' +
        '<div>' +
            '<form id="wpMassDelete" name="wpMassDelete">' +
            '<p>ยินดีต้อนรับสู่แบบคำขอสำหรับการลบหน้าจำนวนมาก คุณสามารถใช้หน้าพิเศษนี้เพื่อลบหน้าจำนวนมากกว่าสองหน้าขึ้นไป ถ้าคุณกำลังลบหน้าจำนวนมากที่สร้างโดยผู้ใช้คนเดียว โปรดใช้ <a href="/wiki/Special:Nuke">พิเศษ:Nuke</a></p>' +
            '<p>ถ้าคุณกำลังจะลบ<b>หน้ามากกว่า 10 หน้าขึ้นไป</b> โปรดระวังการฟลัด (flood) ข้อมูลในหน้า <a href="/wiki/Special:RecentChanges">พิเศษ:ปรับปรุงล่าสุด</a></p>' +
            '<p>โปรดเพิ่มรายการหน้าที่คุณต้องการลบในกล่องข้อความด้านล่างอย่างละหนึ่งหน้าต่อหนึ่งบรรทัด (ไม่ต้องใส่ลิงก์มาร์กอัป) ขอบคุณสำหรับการใช้เครื่องมือนี้</p>' +
            '<div id="wpMassDeleteFailedContainer"></div>' +
            '<br />' +
                'หน้าที่จะลบ (หนึ่งหน้าต่อหนึ่งบรรทัด):<br />' +
                    '<textarea tabindex="1" accesskey="," name="wpMassDeletePages" id="wpMassDeletePages" rows="15" cols="80"></textarea>' +
                '<br /><table style="background-color:transparent">' +
                    '<tr><td>เหตุผลทั่วไป:</td>' +
                        '<td><select id="wpMassDeleteReasons">' +
                            '<optgroup label="เหตุผลอื่น">' +
                                '<option value="other">เหตุผลอื่น</option>' +
                                 '<optgroup label="เหตุผลสำหรับการลบทันที">' +
                                    '<option value="[[WB:SPEEDY|รับแจ้งจากผู้มีส่วนร่วมหลักของตำราหรือผู้เขียนทำหน้าว่าง]]">[[WB:SPEEDY|รับแจ้งจากผู้มีส่วนร่วมหลักของตำราหรือผู้เขียนทำหน้าว่าง]]</option>' +
                                    '<option value="[[WB:SPEEDY|รับแจ้งจากผู้ใช้ให้ลบสเปซผู้ใช้ของตนเอง]]">[[WB:SPEEDY|รับแจ้งจากผู้ใช้ให้ลบสเปซผู้ใช้ของตนเอง]]</option>' +
                                    '<option value="[[WB:NMC|ก่อกวน ข่าวขยะ หรือเรื่องไร้สาระ]]">[[WB:NMC|ก่อกวน ข่าวขยะ หรือเรื่องไร้สาระ]]</option>' +
                                    '<option value="[[WB:NMC|เนื้อหาที่ไม่อาจเข้าใจได้หรือเป็นการทดลองเขียน]] โปรดใช้[[WB:SB|หน้าทดลองเขียน]]เพื่อทำการทดสอบบนวิกิตำรา">[[WB:NMC|เนื้อหาที่ไม่อาจเข้าใจได้หรือเป็นการทดลองเขียน]] โปรดใช้[[WB:SB|หน้าทดลองเขียน]]เพื่อทำการทดสอบบนวิกิตำรา</option>' +
                                    '<option value="[[WB:NMC|เนื้อหาถูกทอดทิ้งโดยเจตนาและไม่มีการพัฒนาต่อ]]หลังจาก 7 วัน">[[WB:NMC|เนื้อหาถูกทอดทิ้งโดยเจตนาและไม่มีการพัฒนาต่อ]]หลังจาก 7 วัน</option>' +
                                    '<option value="[[WB:NMC|หน้าคุยของหน้าที่ถูกลบหรือไม่มีเนื้อหา]]">[[WB:NMC|หน้าคุยของหน้าที่ถูกลบหรือไม่มีเนื้อหา]]</option>' +
                                    '<option value="[[WB:SPEEDY|ความเห็นพ้องจากผู้มีส่วนร่วมของตำรา]]">[[WB:SPEEDY|ความเห็นพ้องจากผู้มีส่วนร่วมของตำรา]]</option>' +
                                    '<option value="[[WB:SPEEDY|การลบโดยเทคนิค]]">[[WB:SPEEDY|การลบโดยเทคนิค]]</option>' +
                                    '<option value="โปรด[[WB:RFU|ขอให้ทบทวนการลบ]]แทน[[WB:SPEEDY|การลงเนื้อหาที่เคยถูกลบซ้ำ]]">โปรด[[WB:RFU|ขอให้ทบทวนการลบ]]แทน[[WB:SPEEDY|การลงเนื้อหาที่เคยถูกลบซ้ำ]]</option>' +
                                '</optgroup>' +
                                 '<optgroup label="เหตุผลสำหรับการรวมหรือย้าย">' +
                                    '<option value="[[WB:HOST|วิกิตำราไม่ใช่พื้นที่รับฝากเว็บไซต์หรือผู้ให้บริการเว็บสเปซส่วนตัว]]">[[WB:HOST|วิกิตำราไม่ใช่พื้นที่รับฝากเว็บไซต์หรือผู้ให้บริการเว็บสเปซส่วนตัว]]</option>' +
                                    '<option value="โปรดใช้บล็อก ฟอรัมหรือเว็บไซต์ส่วนตัวเพื่อ[[WB:SOAP|โฆษณาหรือแบ่งปันความคิดเห็นส่วนตัว]]ของคุณ">โปรดใช้บล็อก ฟอรัมหรือเว็บไซต์ส่วนตัวเพื่อ[[WB:SOAP|โฆษณาหรือแบ่งปันความคิดเห็นส่วนตัว]]ของคุณ</option>' +
                                    '<option value="[[WB:NOR|งานเขียนสารคดีและวรรณกรรมต้นฉบับ]]ซึ่งอยู่นอกเหนือขอบเขตของโครงการ">[[WB:NOR|งานเขียนสารคดีและวรรณกรรมต้นฉบับ]]ซึ่งอยู่นอกเหนือขอบเขตของโครงการ</option>' +
                                    '<option value="[[WB:NOR|งานวิจัยต้นฉบับ]] โปรดใช้[[betawikiversity:หน้าหลัก|วิกิวิทยาลัย]]">[[WB:NOR|งานวิจัยต้นฉบับ]] โปรดใช้[[betawikiversity:หน้าหลัก|วิกิวิทยาลัย]]</option>' +
                                    '<option value="[[WB:SOURCE|เอกสารต้นฉบับ]] โปรดใช้[[s:WS:WIW|วิกิซอร์ซ]]">[[WB:SOURCE|เอกสารต้นฉบับ]] โปรดใช้[[s:WS:WIW|วิกิซอร์ซ]]</option>' +
                                    '<option value="[[WB:NOTWP|บทความสารานุกรม]] โปรดใช้[[w:WP:WIW|วิกิพีเดีย]]">[[WB:NOTWP|บทความสารานุกรม]] โปรดใช้[[w:WP:WIW|วิกิพีเดีย]]</option>' +
                                    '<option value="[[WB:NEWS|บทความข่าว]] โปรดใช้[[n:|วิกิข่าว]]">[[WB:NEWS|บทความข่าว]] โปรดใช้[[n:|วิกิข่าว]]</option>' +
                                    '<option value="[[WB:SPEEDY|การลบโดยเทคนิค]]">[[WB:SPEEDY|การลบโดยเทคนิค]]</option>' +
                                    '<option value="[[WB:DICT|พจนานุกรมและอรรถาธิบาย]] โปรดใช้[[wikt:วิกิพจนานุกรม:อะไรที่ไม่ใช่วิกิพจนานุกรม|วิกิพจนานุกรม]]">[[WB:DICT|พจนานุกรมและอรรถาธิบาย]] โปรดใช้[[wikt:วิกิพจนานุกรม:อะไรที่ไม่ใช่วิกิพจนานุกรม|วิกิพจนานุกรม]]</option>' +
                                    '<option value="[[WB:GUIDE|คู่มือวางกลยุทธ์หรือสรุปเนื้อหาของเกม]]ซึ่งอยู่นอกเหนือขอบเขตของโครงการ โปรดใช้[[strategywiki:|สแทรทิจีวิกิ]]">[[WB:GUIDE|คู่มือวางกลยุทธ์หรือสรุปเนื้อหาของเกม]]ซึ่งอยู่นอกเหนือขอบเขตของโครงการ โปรดใช้[[strategywiki:|สแทรทิจีวิกิ]]</option>' +
                                '</optgroup>' +
                                '<optgroup label="นโยบายที่เกี่ยวข้อง">' +
                                    '<option value="การแจ้งลบที่ไม่มีผู้คัดค้านหลังจาก 7 วัน">การแจ้งลบที่ไม่มีผู้คัดค้านหลังจาก 7 วัน</option>' +
                                    '<option value="ความเห็นพ้องจาก[[WB:CAFE|ชุมชน]]">ความเห็นพ้องจาก[[WB:CAFE|ชุมชน]]</option>' +
                                    '<option value="[[WB:COPYVIO|การใช้งานที่มีลิขสิทธิ์โดยไม่ได้รับอนุญาต]] โปรดอ่าน[[foundation:Terms of Use/th|ข้อกำหนดการใช้งาน]]">[[WB:COPYVIO|การใช้งานที่มีลิขสิทธิ์โดยไม่ได้รับอนุญาต]] โปรดอ่าน[[foundation:Terms of Use/th|ข้อกำหนดการใช้งาน]]</option>' +
                                    '<option value="การตีความอย่างมีอคติหรือลำเอียงจากข้อเท็จจริง ตำราจะต้องมี[[WB:NPOV|มุมมองที่เป็นกลาง]]">การตีความอย่างมีอคติหรือลำเอียงจากข้อเท็จจริง ตำราจะต้องมี[[WB:NPOV|มุมมองที่เป็นกลาง]]</option>' +
                                    '<option value="[[WB:ATTACK|หน้าโจมตี]]">[[WB:ATTACK|หน้าโจมตี]]</option>' +
                                '</optgroup>' +
                            '</optgroup>' +
                        '</select></td></tr>' +
                    '<tr><td>เหตุผลอื่น/เพิ่มเติม:</td>' +
                    '<td><input type="text" id="wpMassDeleteReason" name="wpMassDeleteReason" size="42" maxlength="255" /></td></tr>' +
                    '<tr><td><input type="button" id="wpMassDeleteSubmit" name="wpMassDeleteSubmit" value="ลบ" /></td>' +
            '</form>' +
        '</div>';
        document.getElementById("wpMassDeleteReasons").onchange = function() {
            var maxlength = (document.getElementById("wpMassDeleteReasons").value == "other" ? 255 : 252-document.getElementById("wpMassDeleteReasons").value.length); //It's 252 because of the three characters (" ()") in addition to the selected summary.
            document.getElementById("wpMassDeleteReason").setAttribute("maxlength", maxlength);
        };
        document.getElementById("wpMassDeleteSubmit").addEventListener("click", function (e) {
            doMassDelete();
        });
    }
     
    if (config.wgNamespaceNumber == -1 &&
        config.wgTitle.toLowerCase() == "massdelete" &&
        /sysop/.test(config.wgUserGroups)
    ) {
        massdeleteform();
    }

});