MediaWiki:Gadget-PreloadTemplates.js: Difference between revisions

From Tardis Wiki, the free Doctor Who reference
(Repositioning)
m (UCP visual editor compatibility)
Line 19: Line 19:
         'wgNamespaceNumber'
         'wgNamespaceNumber'
     ]),
     ]),
     $module = $('div#wpSummaryLabel'), // UCP Source Editor
     $module = $('div#wpSummaryLabel, .ve-ui-summaryPanel-summaryInputField'), // UCP source editors
     $moduleOld = $('div.module_content:first'); // Old Non-UCP Source Editor
     $moduleOld = $('div.module_content:first'); // Old Non-UCP Source Editor


     // Run conditions
     // Run conditions
     if (
     if (mwc.wgNamespaceNumber === 8) {
        mwc.wgAction !== 'edit' ||
         console.log('[PreloadTemplates]: page is not supported.');
        ( !$module.length && !$moduleOld.length ) ||
        mwc.wgNamespaceNumber === 8 // MediaWiki:
    ) {
         console.log('[PreloadTemplates]: container not found or page is not supported.');
         return;
         return;
     }
     }
Line 104: Line 100:
             var cke = document.getElementsByClassName('cke_source'),
             var cke = document.getElementsByClassName('cke_source'),
                 textbox = document.getElementById('wpTextbox1');
                 textbox = document.getElementById('wpTextbox1');
             if (cke.length) {
             if (window.ve && ve.init && ve.init.target && ve.init.target.active) {
                // UCP Visual Editor (Source mode)
                ve.init.target
                    .getSurface()
                    .getModel().
                    getFragment()
                    .insertContent(preloadDataParsed);
            } else if (cke.length) {
                 // Visual editor
                 // Visual editor
                 insertAtCursor(cke[0], preloadDataParsed);
                 insertAtCursor(cke[0], preloadDataParsed);
Line 120: Line 123:
     function preInit(i18nData) {
     function preInit(i18nData) {
         i18n = i18nData;
         i18n = i18nData;
        i18n.useUserLang();
         $main = $('<div>', { id: 'preload-templates' });
         $main = $('<div>', { id: 'preload-templates' });
         $main.append($('<span>', {
         $main.append($('<span>', {
Line 129: Line 131:
         }).append($('<a>', {
         }).append($('<a>', {
             target: '_blank',
             target: '_blank',
             href: '//dev.wikia.com/wiki/PreloadTemplates',
             href: 'https://dev.fandom.com/wiki/PreloadTemplates',
             title: msg('devWiki'),
             title: msg('devWiki'),
             text: '?'
             text: '?'
Line 135: Line 137:
         // Appending HTML to editor
         // Appending HTML to editor
         if ( $module.length ) {  
         if ( $module.length ) {  
             $module.after($main);          // UCP Source Editor
             $module.after($main);          // UCP source editors
         } else if ( $moduleOld.length ) {  
         } else if ( $moduleOld.length ) {  
             $moduleOld.append($main);      // Old Non-UCP Source Editor
             $moduleOld.append($main);      // Old Non-UCP Source Editor
Line 235: Line 237:


     mw.hook('dev.i18n').add(function(i18no) {
     mw.hook('dev.i18n').add(function(i18no) {
         i18no.loadMessages('PreloadTemplates').then(function(i18nData) {
         $.when(
            i18no.loadMessages('PreloadTemplates'),
            mw.loader.using('mediawiki.util')
        ).then(function(i18nData) {
             preInit(i18nData);
             preInit(i18nData);
            mw.hook('ve.activationComplete', $.proxy(preInit, null, i18nData));
             $.get(mw.util.wikiScript(), {
             $.get(mw.util.wikiScript(), {
                 title: config.list,
                 title: config.list,

Revision as of 11:24, 10 November 2020

//  ================================
//      Custom preload templates
//  ================================
/*  @author Grunny 
    From https://harrypotter.wikia.com/wiki/MediaWiki:Wikia.js
    edited by leviathan_89

    ** Info: **
    Template list loaded by default from "MediaWiki:Custom-PreloadTemplates",
    each syntax is loaded by default from the "/preload" subpage of the
    template.
*/

(function() {
    'use strict';
    var mwc = mw.config.get([
        'wgAction',
        'wgFormattedNamespaces',
        'wgNamespaceNumber'
    ]),
    $module = $('div#wpSummaryLabel, .ve-ui-summaryPanel-summaryInputField'), // UCP source editors
    $moduleOld = $('div.module_content:first'); // Old Non-UCP Source Editor

    // Run conditions
    if (mwc.wgNamespaceNumber === 8) {
        console.log('[PreloadTemplates]: page is not supported.');
        return;
    }
    console.log('[PreloadTemplates]: version 1.05 - 11/2020.');

    // =================
    //   Configuration
    // =================
    var config = {
        list: window.preloadTemplates_list || 'MediaWiki:Custom-PreloadTemplates',
        subpage: window.preloadTemplates_subpage || 'preload'
    }, i18n, $main, $help;

    // =============
    //   Functions  
    // =============

    // Get plain message from i18n
    function msg(message) {
        return i18n.msg(message).plain();
    }

    // Parse MediaWiki code to allow the use of includeonly and noninclude tags in the preload page
    function parseMW(source){
        return source.replace(/<includeonly>(\n)?|(\n)?<\/includeonly>|\s*<noinclude>[^]*?<\/noinclude>/g, '');
    }

    // Error alert
    function notFound(page){
        alert(i18n.msg('error', '"' + page + '"').plain());
    }

    // Inserts text at the cursor's current position - originally from Wookieepedia
    function insertAtCursor(myField, myValue) {
        if (document.selection) {
            // IE support
            myField.focus();
            window.sel = document.selection.createRange();
            window.sel.text = myValue;
        } else if ( myField.selectionStart || myField.selectionStart === 0 ) {
            // MOZILLA/NETSCAPE support
            var startPos = myField.selectionStart,
                endPos = myField.selectionEnd;
            myField.value = myField.value.substring(0, startPos) +
                myValue +
                myField.value.substring(endPos, myField.value.length);
        } else {
            myField.value += myValue;
        }
    }

    // Get preload text and add it to the text area
    function getPreloadPage(title) {
        // check if subpage is standard or is case by case
        var namespace = mwc.wgFormattedNamespaces['10'],
            page = config.subpage === 'case-by-case' ?
                namespace + ':' + title :
                namespace + ':' + title + '/' + config.subpage;

        $.get(mw.util.wikiScript(), {
                title: page,
                action: 'raw',
                ctype: 'text/plain'
        }).done(function(preloadData) {
            // Parse some MediaWiki tags
            var preloadDataParsed = parseMW(preloadData);

            // Display error if no useful data is present
            if (preloadDataParsed === '') {
                notFound(page);
                return;
            }

            // Insert syntax
            var cke = document.getElementsByClassName('cke_source'),
                textbox = document.getElementById('wpTextbox1');
            if (window.ve && ve.init && ve.init.target && ve.init.target.active) {
                // UCP Visual Editor (Source mode)
                ve.init.target
                    .getSurface()
                    .getModel().
                    getFragment()
                    .insertContent(preloadDataParsed);
            } else if (cke.length) {
                // Visual editor
                insertAtCursor(cke[0], preloadDataParsed);
            } else if (textbox) {
                insertAtCursor(textbox, preloadDataParsed);
            } else {
                console.warn('[PreloadTemplates] Could not find textbox to bind to');
            }
        }).fail(function() {
            notFound(page);
        });
    }

	// Add selector to editor
    function preInit(i18nData) {
        i18n = i18nData;
        $main = $('<div>', { id: 'preload-templates' });
        $main.append($('<span>', {
            text: msg('preload')
        }));
        $help = $('<div>', {
            id: 'pt-help'
        }).append($('<a>', {
            target: '_blank',
            href: 'https://dev.fandom.com/wiki/PreloadTemplates',
            title: msg('devWiki'),
            text: '?'
        }));
        // Appending HTML to editor
        if ( $module.length ) { 
            $module.after($main);          // UCP source editors
        } else if ( $moduleOld.length ) { 
            $moduleOld.append($main);       // Old Non-UCP Source Editor
        }
    }

    function listHTML(parsed) {
        return mw.html.element('option', {
            selected: true,
            disabled: true
        }, msg('choose')) + parsed.split('\n').map(function(line) {
            // Ignore empty lines
            if (line.trim() === '') {
                return '';
            }
            // Text in a list is the template name
            if (line.indexOf('*') === 0) {
                var title = line.substring(1).trim();

                // Text after pipe is display name
                if (title.indexOf('|') !== -1) {
                    var parts = title.split('|');
                    return mw.html.element('option', {
                        value: parts[0].trim()
                    }, parts[1].trim());
                } else {
                    return mw.html.element('option', {
                        value: title
                    }, title);
                }
            } else {
                // Rest are normal strings
                return mw.html.element('option', {
                    disabled: true
                }, line.trim());
            }
        }).join();
    }

    // =================
    //   Initialization  
    // =================

    // If the initialization failed
    function initFail() {
        $main.append(
            i18n.msg(
                'error',
                mw.html.element('a', {
                    href: mw.util.getUrl(config.list)
                }, config.list)
            ).plain(),
            $help
        );
    }

    function init(listData) {
        var parsed = parseMW(listData); // Parse data for MediaWiki tags

        // Display error if no valid data is present
        if (parsed === '') {
            initFail();
            return;
        }

        // Append template list and messages
        $main.append(
            $('<select>', {
                id: 'pt-list',
                title: msg('help'),
                html: listHTML(parsed)
            }).change(function() {
                var $this = $(this),
                    val = $this.val();

                // Restore default option
                $this.find('option:first-child').prop('selected', true);

                // Preload the template on click
                getPreloadPage(val);
            }),
            $help
        );
    }

    // ===========
    //   Imports  
    // ===========
    if (!window.dev || !window.dev.i18n) {
        importArticle({
            type: 'script',
            article: 'u:dev:MediaWiki:I18n-js/code.js'
        });
    }
    importArticle({
        type: 'style',
        article: 'u:dev:MediaWiki:PreloadTemplates.css'
    });

    mw.hook('dev.i18n').add(function(i18no) {
        $.when(
            i18no.loadMessages('PreloadTemplates'),
            mw.loader.using('mediawiki.util')
        ).then(function(i18nData) {
            preInit(i18nData);
            mw.hook('ve.activationComplete', $.proxy(preInit, null, i18nData));
            $.get(mw.util.wikiScript(), {
                title: config.list,
                action: 'raw',
                ctype: 'text/plain'
            }).done(init).fail(initFail);
        });
    });

})();