MediaWiki:Edit.js

Материал из свободной русской энциклопедии «Традиция»
Перейти к навигации Перейти к поиску

Замечание: Чтобы после сохранения вступили в силу изменения стилей, перезагрузите файл //traditio.wiki/w/load.php?debug=false&lang=ru&modules=site&only=styles&skin=vector&*, если используете скин Vector, или //traditio.wiki/w/load.php?debug=false&lang=ru&modules=site&only=styles&skin=common&*, если используете скин Common.

Чтобы вступили в силу изменения скриптов, перезагрузите файл //traditio.wiki/w/load.php?debug=false&lang=ru&modules=site&only=scripts&skin=vector&*, если используете скин Vector, или //traditio.wiki/w/load.php?debug=false&lang=ru&modules=site&only=scripts&skin=common&*, если используете скин Common.

Гаджеты и импортируемые скрипты загружаются отдельными файлами.

/*
 * Внимание! Этот скрипт более не загружается, заменённый MediaWiki:Gadget-edit.js.
 */

/*
 *   Инструменты редактирования. Версия 0.91
 *   Александр Машин.
 *   Отдельные изменения — Mithgol the Webmaster.
 *   Для обновления перезагрузить http://traditio-ru.org/w/index.php?title=MediaWiki:Edit.js&action=raw&ctype=text/javascript.
 * 
 */

// Значки развёртывания и свёртывания субменю:
var extender = '<img src="/images/c/cf/Etool_extender.png" width="5" height="16" alt="&rarr;" />';
var collapser = '<img src="/images/d/d4/Etool_collapser.png" width="5" height="16" alt="&darr;" />';
// Для отложенного разбора:
var lastPostponed = 0;
var immediate_limit = $.browser.msie    ? 16
                    : $.browser.mozilla ? 32
                    :                     64;
// Счётчик инструментов:
var tool_no = 0;
// Признак того, что кнопка мыши нажата:
var mouse_is_down = false;
// id счётчика времени, включившегося при наведении мыши на инструмент:
var delay_id;
// Задержка показа подменю при наведении указателя мыши, мс:
var popup_delay = 500;
// Кэш для хранения обёрток, заполнителей и подменю, загрузка которых отложена:
var cache = {};

/*  Заготовки для меню.
 *  Объявления — глобальные.
 *  Создаются функцией createStubs().
*/
var $li_stub, $button_stub, $a_stub, $full_stub, $ul0_stub, $ul1_stub, $li0_stub,
    $li1_stub, $postponed_stub;

function createStubs(){
    /*  употребляются в eButton():  */
    // Пункт меню:
    $li_stub = $('<li></li>');

    // Кнопка:
    $button_stub = $('<button type="button"></button>').mouseup(function(){
        // Срабатывание функции кнопки:
        insertTag ($(this).attr ('forbox')
            , cache [makeCacheKey (this.title) + '_wrapper']
            , cache [makeCacheKey (this.title) + '_filler']
            , $(this).attr ('process_all')
        );
        $(this).makeLeader();
    }).mouseover(function(){
        // Вывод вставляемого кнопкой вики-кода в строку состояния:
        var wrapper = cache [makeCacheKey (this.title) + '_wrapper'];
        if (wrapper && !$.isFunction (wrapper)) {
            window.status = this.title;
            if ( this.title != $.trim( stripHTML(wrapper) ).replace (/_/g, ' ') ){
                window.status += ': ' + wrapper;
            }
        }
        return false;
    }).mouseleave(function(){
        // Очистка строки состояния:
        window.status = '';
    });
    // + для IE, который не понимает :hover в CSS:
    if ($.browser.msie) {
        $button_stub.hover (
            function () {$(this).addClass    ('hover');}
          , function () {$(this).removeClass ('hover');}
        );
    }

    // Ссылка:
    $a_stub = $('<a target="_blank"></a>');
    // + для IE, который не понимает :hover в CSS:
    if ($.browser.msie) {
        $a_stub.hover (
            function(){ $(this).addClass   ('hover'); }
          , function(){ $(this).removeClass('hover'); }
        );
    }

    // Текст к кнопке:
    $full_stub = $('<span></span>').addClass('full');

    /*  употребляются в eMenu():  */
    // Заготовка меню верхнего уровня:
    $ul0_stub = $('<ul></ul>').addClass('eMenu');
    // Подменю:
    $ul1_stub = $ul0_stub.clone().mouseleave(function(){
        // Свёртывание при съезде мыши:
        $('.eMenu .eMenu').not('.fixed').slideUp('fast');
        // Сброс счётчика времени для показа подменю по наведению и задержке мыши:
        clearInterval(delay_id);
    });
    // + для IE, который не может нормально установить ширину абсолютно позиционированных блоков:
    if ($.browser.msie) {
        // Установить ширину подменю:
        $ul1_stub.width('35em');
    }

    // Заготовка кнопки верхнего меню:
    $li0_stub = $('<li></li>').append( // Последний инструмент:
        $('<button></button>').text ('?').addClass ('last')
    ).append( // Кнопка развёртывания:
        $('<button type="button"></button>').html(extender).addClass('extender').mousedown(
            function(){
                fixedToggle($(this).parent()); // -- развёртывание.
                return false;
            }
        )
    ).mousedown(function(){
        // Показ подменю при нажатии кнопки мыши:
        var $this = $(this);
        var $toolbar = $this.parents ('.eMenu');
        if ($toolbar.find('.eMenu.fixed').length == 0){
            $this.find ('.eMenu').loadAndShow ('instant');
            mouse_is_down = true;
        }
        // Сброс счётчика времени для показа подменю по наведению и задержке мыши:
        clearInterval (delay_id);
    }).mouseover(function(){
        // Сброс счётчика времени для показа подменю по наведению и задержке мыши:
        clearInterval (delay_id);

        var $this = $(this);
        var $toolbar = $this.parents ('.eMenu');
        if ($toolbar.find('.eMenu.fixed').length == 0) {
            // Показ подменю при наезде, при условии, что:
            if (mouse_is_down) { // кнопка мыши нажата:                   
                $this.find('.eMenu').loadAndShow('instant');
            } else {
                // или мышь задерживается на popupdelay мс (по умолчанию, 0,5 с):
                delay_id = setTimeout(function(){
                    $this.find('.eMenu').loadAndShow('fast');
                }, popup_delay);
            }
        }
    }).mouseup(function(){
        // Снятие признака нажатия кнопки мыши:
        mouse_is_down = false;
        // Сброс счётчика времени для показа подменю по наведению и задержке мыши:
        clearInterval (delay_id);
    }).mouseleave(function(){
        // Сброс счётчика времени для показа подменю по наведению и задержке мыши:
        clearInterval (delay_id);
        // Свёртывание при съезде мыши:
        $('.eMenu .eMenu').not ('.fixed').slideUp ('fast');
    });
    // + для IE: разрыв над подменю, чтобы оно показывалось ниже, а не справа:
    if ($.browser.msie) {
        $li0_stub.append( '<br />' );
    }

    // Заготовка кнопки подменю:
    $li1_stub = $('<li></li>');

    // Заготовка отметки отложенной загрузки:
    /*
    $postponed_stub = eButton({
       button: '<img src="/images/Etool_AJAX-loader-T16.gif" width="16" height="16" alt="loading…" />',
       title: 'Загрузка…'
    });
    */
}
    
// Вертикальный разделитель и перевод строки для субменю:
var separator = {html: '<li><img src="/images/7/77/Etool_vrule.png" width="3" style="height: 2.5ex" alt="|" /></li>'};
var inline_separator = ' <<_•_>> ';
var br = {html: '<br clear="all" />'};

// Строка шаблонов лицензий для страницы загрузки изображений:
var licenses = '';
if (wgTitle == 'Upload' || wgTitle == 'Загрузка') {
    $('#wpLicense option').each (function () {
        if (this.disabled) {
            // Группа лицензий:
            licenses += 'br <<' + $(this).text ().replace (/\s/g, '_').replace (/[[\]]/g, '') + '>> ';
        } else {
            // Лицензия:
            licenses += $(this).val () ? '{{' + $.trim ($(this).val ().split ('|', 2) [0]) + '}} ' : '';
        }
    });
}

// Настройка панелей инструментов над и под текстовыми окнами.
//     Вложенные массивы обозначают подменю.
//     Объекты описывают кнопки, метки, ссылки или произвольный HTML.
//     Строки -- ряды простых инструментов, разделённых пробелом.
// Верхняя панель:
var tools_above = [
[
    {title: 'Обработка выделенного текста', nl: true}
  , {wrapper: wikifyText, button: '<img src="/images/1/1f/Etool_wikify.png" width="20" height="16" alt="W"/>', title: 'Викификация', all: true}
  , {wrapper: function (s) {return s.toLowerCase ();}, title: 'Нижний регистр', button: 'аб', all: true}, br
    // Инструмент поиска и замены:
  , {html: '<hr />'}
  , {wrapper: function (s) {
                  return s.replace ($('#tregex').val () == 'on'
                          ? new RegExp ($('#tsearch').val ()
                                      , ($('#tglobal').val () == 'on' ? 'g' : '')
                                      + ($('#tmulti').val ()  == 'on' ? 'm' : '')
                                      + ($('#ticase').val ()  == 'on' ? 'i' : ''))
                          : $('#tsearch').val ()
                      , $('#treplace').val ());
              },
     button: '<img src="/images/b/b8/Etool_replace.png" alt="&rarr;" />',
     title: 'Поиск и замена',
     all: true, nl: true}
  , {html: '<span>(</span><input type="checkbox" id="tregex" /><label for="tregex">как <a href="http://traditio-ru.org/wiki/Регулярные_выражения" target="_blank" title="страница о регулярных выражениях (в новой вкладке)">regex</a></label>): '
         + '/<input id="tsearch" size="30" title="Что заменить">/<input id="treplace" size="30" title="Чем заменить">/'
         + '<input type="checkbox" id="tglobal" checked title="Заменить всё" /><label for="tglobal" title="Заменить всё">g</label>'              
         + '<input type="checkbox" id="tmulti" title="Много строк" /><label for="multi" title="Много строк">m</label>'
         + '<input type="checkbox" id="ticase" checked title="Игнорировать регистр" /><label for="ticase" title="Игнорировать регистр">i</label>/',
     nl: true}
] , separator, [
    {title: 'Пунктуация', nl: true}
  , {wrapper: '+—', button: '—', title: 'Тире'}  
  , {wrapper: '+–', button: '–', title: 'Минус'}
  , {wrapper: '+…', button: '…', title: 'Многоточие'}  
  , {wrapper: '&nbsp;', button: '∙', title: 'Неразрывный пробел'}, br
  , {title: 'Кавычки:'}
  , {wrapper: '<q>+</q>', button: '«<span class="plus_sign">a</span>»', title: 'Универсальные', filler: 'Текст в кавычках'}  
  , {wrapper: '«+»', button: '«<span class="plus_sign">a</span>»', title: 'Обычные', filler: 'Текст в кавычках'}  
  , {wrapper: '„+“', button: '„<span class="plus_sign">a</span>“', title: 'Вложенные', filler: 'Текст в кавычках второго уровня'}, br
  , {wrapper: '“+”', button: '“<span class="plus_sign">a</span>”', title: 'Английские', filler: 'Текст в кавычках внутри английского текста'}
  , {wrapper: '»+«', button: '»<span class="plus_sign">a</span>«', title: 'Немецкие', filler: 'Текст в кавычках внутри немецкого текста'}, br
  , '§+ №+ ~ ¡+ ¿+ +† +‡ {{•}}_ ¶ #+ &+'
  , {wrapper: function (s) {return s + '|';}, button: '|', title: 'Вертикальная черта'}  
  , ' {{!}} ` \''
  , {title: 'Диакритика', nl: true}
  , {wrapper: '+́', button: '<b><span style="color:black">a</span>́</b>', title: 'Знак ударения', filler: 'Подударная гласная'}, br
  , {wrapper: '+́', button: '<b><span class="plus_sign">a</span>́</b>', title: 'Акут', filler: 'Буква под акутом'}
  , {wrapper: '+̀', button: '<b><span class="plus_sign">a</span>̀</b>', title: 'Гравис', filler: 'Буква под грависом'}
  , {wrapper: '+̂', button: '<b><span class="plus_sign">a</span>̂</b>', title: 'Циркумфлекс', filler: 'Буква под циркумфлексом'}  
  , {wrapper: '+̈', button: '<b><span class="plus_sign">a</span>̈</b>', title: 'Диарезис', filler: 'Буква под диарезисом'}  
  , {wrapper: '+̃', button: '<b><span class="plus_sign">a</span>̃</b>', title: 'Тильда', filler: 'Буква под тильдой'}
  , {wrapper: '+̌', button: '<b><span class="plus_sign">e</span>̌</b>', title: 'Гачек', filler: 'Буква под гачеком'}, br
  , {wrapper: '+̆', button: '<b><span class="plus_sign">a</span>̆</b>', title: 'Кратка', filler: 'Краткая буква'}
  , {wrapper: '+̄', button: '<b><span class="plus_sign">a</span>̄</b>', title: 'Макрон', filler: 'Долгая буква'}
  , {url: mw.util.wikiGetlink ('Традиция:Типографика'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Типографика', nl: true}
], [
    {title: 'Шрифт', nl: true}
  , {wrapper: "''+''", button: '<img src="/images/e/e8/Etool_italic.png" width="14" height="16" alt="К" />', title: '<em>Курсив</em>'}
  , {wrapper: "'''+'''", button: '<img src="/images/1/15/Etool_bold.png" width="20" height="16" alt="Ж" />', title: '<strong>Полужирный шрифт</strong>'}, br
  , {wrapper: '<sup>+</sup>', button: '<img src="/images/9/9b/Etool_font_superscript.png" height="16" width="16" alt="sup">', title: 'Верхний индекс'}
  , {wrapper: '<sub>+</sub>', button: '<img src="/images/6/68/Etool_font_subscript.png" height="16" width="16" alt="sub">', title: 'Нижний индекс'}  
  , {wrapper: '<s>+</s>', button: '<strike style="color:blue"><span style="color:black">&nbsp;a&nbsp;</span></strike>', title: 'Зачеркнуть', filler: 'Зачёркнутый текст'}  , br
  , {wrapper: '<code>+</code>', button: 'К', title: '<code>Код</code>'}
  , {wrapper: '<kbd>+</kbd>', button: '<img src="/images/c/ce/Etool_keyboard.png" height="16" width="16" alt="kbd">', title: '<kbd>Ввод пользователя</kbd>'}
  , {wrapper: '<abbr title="(полностью)‎">+</abbr>', button: 'А', title: 'Сокращение'}  
  , {wrapper: '<acronym title="(полностью)‎">+</acronym>', button: 'Y', title: 'Акроним'}
], [
    {title: 'Заголовки', nl: true}
  , {wrapper: '\n== + ==\n', button: '<h2 style="font-size: 130%; margin: 0">З2</h2>', title: '<h2>Заголовок 2</h2>', nl: true}
  , {wrapper: '\n=== + ===\n', button: '<h3 style="font-size: 120%; margin: 0">З3</h3>', title: '<h3 style="margin-left: 16px;">Заголовок 3</h3>', nl: true}
  , {wrapper: '\n==== + ====\n', button: '<h4 style="font-size: 100%; margin: 0">З4</h4>', title: '<h4 style="margin-left: 32px;">Заголовок 4</h4>', nl: true}
  , {wrapper: '\n===== + =====\n', button: '<h5 style="font-size: 90%; margin: 0">З5</h5>', title: '<h5 style="margin-left: 48px;">Заголовок 5</h5>', nl: true}
  , {wrapper: '\n====== + ======\n', button: '<h6 style="font-size: 80%; margin: 0">З6</h6>', title: '<h6 style="margin-left: 64px;">Заголовок 6</h6>', nl: true}  
  , {title: 'Содержание', nl: true}
  , {wrapper: '+\n{{TOC}}\n', button: '<img src="/images/8/85/Etool_toc.png" height="16" width="16" alt="&Xi;">', title: 'Содержание здесь'}, br
  , {wrapper: '+\n{{TOCRight}}\n', button: '<img src="/images/f/fd/Etool_toc_right.png" height="16" width="16" alt="&Xi;&rarr;">', title: 'Содержание справа'}, br
  , {wrapper: '+\n__NOTOC__\n', button: '<img src="/images/0/00/Etool_no_toc.png" height="16" width="16" alt="&Xi;&rarr;">', title: 'Подавить содержание'}
], [
    {title: 'Абзац', nl: true}
  , {wrapper: '\n\n+', button: '<img src="/images/e/e9/Etool_red_line.png" width="16" height="16" alt="&crarr;" />', title: 'Новый абзац'}, br
  , {wrapper: makeUL, button: '<img src="/images/0/0d/Etool_text_list_bullets.png" width="16" height="16" alt="*" />', title: 'Маркированный список', filler: '\nодин пункт,\nдругой пункт,\n…,\nпоследний пункт'}
  , {wrapper: makeOL, button: '<img src="/images/3/36/Etool_text_list_numbers.png" width="16" height="16" alt="#" />', title: 'Нумерованный список', filler: '\nпервый пункт,\nвторой пункт,\n…,\nпоследний пункт'}
  , {wrapper: makeGlossary, button: '<img src="/images/4/42/Etool_glossary.png" width="16" height="16" alt="= ==" />', title: 'Глоссарий', filler: '\nпервый термин:определение,\nвторой термин:определение,\n…,\nпоследний термин:определение'}, br
  , {wrapper: '\n{{цитата|+|источник}}', button: '<img src="/images/4/43/Etool_text_indent.png" width="16" height="16" alt="&rarr;text" />', title: 'Цитата', filler: 'Цитируемый текст'}
  , {wrapper: makeTable
   , button: '<img src="/images/b/ba/Etool_table.png" width="16" height="16" alt="table" />'
   , title: 'Таблица'
   , filler: '\nзаголовок\n(1, nl:1)\n(2,1)'}
  , {url: mw.util.wikiGetlink ('Традиция:Как делать таблицы'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Таблицы'}, br
  , {wrapper: '<poem>+</poem>\n', button:  '<img src="/images/3/3b/Etool_poem.png" width="16" height="16" alt="Стихи" />', title: 'Стихи'}
  , {wrapper: '<source lang=(язык)">+</source>\n', button: '<img src="/images/a/ad/Etool_source_code.png" width="16" height="16" alt="&lt;&gt;" />', title: '<code>Исходный код</code>'}
  , {wrapper: '<pre>+</pre>\n', button: '<img src="/images/2/2e/Etool_pre.png" width="16" height="16" alt="$&gt;_" />', title: '<code>Преформатированный текст</code>'}, br
  , {wrapper: '<nowiki>+</nowiki>', button: '<img src="/images/c/cb/Etool_nowiki.png" width="16" height="16" alt="&lt;/&gt;" />', title: 'Невикифицированный текст', filler: 'Сырой викитест'}
  , {wrapper: '\n<!--\n+\n--' + '>\n', button: '<img src="/images/5/5f/Etool_comment.png" height="16" width="16" alt="books">', title: 'Комментарий HTML', filler: 'Комментарий HTML (не обрабатывается парсером)'}, br
  , {wrapper: '<br />', button: '<img src="/images/e/e3/Etool_br.png" width="11" height="16" alt="&crarr;" />', title: 'Перевод строки'}  
  , {url: mw.util.wikiGetlink ('Традиция:Вики-разметка'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Вики-разметка', nl: true}    
], [
    {title: 'Ссылки', nl: true}
  , {wrapper: '[[+]]', button: '<img src="/images/4/41/Etool_link.png" height="16" width="16" alt="[[]]">', title: 'Вставить викиссылку', filler: 'Статья «Традиции»'}, br
  , {wrapper: '[+ (описание ссылки)]', button: '<img src="/images/3/3b/Etool_world_link.png" height="16" width="16" alt="&rarr;www">', title: 'Внешняя ссылка', filler: '(url)'}
  , {wrapper: '<span class="plainlinks">[+ (описание ссылки)]</span>', button: '<img src="/images/e/e6/Etool_www_page.png" height="16" width="16" alt="&rarr;www">', title: 'Внешняя ссылка без значка', filler: '(url)'}
  , {title: 'Сноски', nl: true}
  , {wrapper: '<ref>+</ref>', button: '<img src="/images/0/02/Etool_bookmark.png" width="16" height="16" alt="Сноска" />', title: 'Сноска', filler: 'Текст сноски'}
  , {wrapper: '{{тчк}}<ref>+</ref>', button: '<span style="margin-right: -0.21em">.</span><sup class="reference">[1]</sup>', title: 'Точка и сноска', filler: 'Текст сноски'}
  , {wrapper: '{{,}}<ref>+</ref>', button: '<span style="margin-right: -0.21em">,</span><sup class="reference">[1]</sup>', title: 'Запятая и сноска', filler: 'Текст сноски'}
  , {title: 'Источники', nl: true}
  , {wrapper: '{{статья|автор=|заглавие=|оригинал=|ссылка=+|издание=|тип=|место={{М.}}|год=[[]]|том=|номер=|страницы=}}', button: '<img src="/images/d/d6/Etool_newspaper_link.png" height="16" width="16" alt="&rarr;[P]">', title: 'Статья', filler: '(url)'}
  , {wrapper: '{{книга|автор=|часть=|заглавие=|оригинал=|язык_оригинала=|язык_оригинала_сокращённо=|переводчик=|ссылка=+|издание=|место={{М.}}|издательство=|год=[[]]|страницы=|isbn=}}', button: '<img src="/images/c/cd/Etool_book_link.png" height="16" width="16" alt="&rarr;[B]">', title: 'Книга', filler: '(url)'}
  , {wrapper: '{{cite_news|first=|last=|authorlink=|author=|coauthors=|title=|url=+|format=|work=|publisher=|location=|id=|pages=|page=|date=|accessdate=|language=|quote=|archiveurl=|archivedate=}}', button: '<img src="/images/d/d6/Etool_newspaper_link.png" height="16" width="16" alt="&rarr;[P]">', title: 'Новость', filler: '(url)'}
  , {wrapper: '{{cite_web|first=|last=|authorlink=|author=|coauthors=|title=|url=+|format=|work=|publisher=|location=|id=|pages=|page=|date=|accessdate=|language=|quote=|archiveurl=|archivedate=}}', button: '<img src="/images/5/58/Etool_page_link.png" width="16" height="16" alt="&rarr;text" />', title: 'WWW', filler: '(url)'}
  , {title: 'Блоги и форумы', nl: true}
  , {wrapper: '{{Lj user|+}}', button: '<img src="/images/c/cd/Etool_user.png" width="16" height="16" alt="ЖЖuser" />', title: 'Пользователь ЖЖ', filler: '(ник)'}
  , {wrapper: '{{Lj comm|+}}', button: '<img src="/images/4/4b/Etool_group_link.png" height="16" width="16" alt="ЖЖС">', title: 'Сообщество ЖЖ', filler: '(ник)'}
  , {wrapper: '{{Lj post|ник=+|№=|название=|автор=|дата=}}', button: '<img src="/images/d/d6/Etool_livejournal.png" height="16" width="16" alt="ЖЖ">', title: 'Запись ЖЖ', filler: '(ник автора)'}, br
  , {wrapper: '{{Ljr user|+}}', button: '<img src="/images/d/d4/Etool_user_red.png" width="16" height="16" alt="ЖЖР user" />', title: 'Пользователь ЖЖР', filler: '(ник)'}
  , {wrapper: '{{Ljr comm|+}}', button: '<img src="/images/4/4b/Etool_group_link.png" height="16" width="16" alt="ЖЖРС">', title: 'Сообщество ЖЖР', filler: '(ник)'}, br
  , {wrapper: '{{ФИГШ:пост|№_поста|+}}', button: 'Пост ФИГШ', title: null, filler: '(название)'}
  , {wrapper: '{{ФИГШ:тема|№_темы|+}}', button: 'Тема ФИГШ', title: null, filler: '(название)'}
  , {title: 'См. также в', nl: true}  
  , {wrapper: '{{См. также в|tsdne=+}}\n', button: 'ТСДНЭ', title: null, filler: '(название)'}
  , {wrapper: '{{См. также в|nmp=+}}\n', button: 'НМП', title: null, filler: '(название)'}
  , {title: 'Запросы источников', nl: true}
  , '{{Источник}} {{Кто?}} {{Когда?}}'
  , {title: 'Разделы сносок и источников', nl: true}
  , {wrapper: '\n== Ссылки ==\n* ', button: '<img src="/images/9/91/Etool_books.png" height="16" width="16" alt="books">', title: 'Ссылки'}
  , {title: 'Автосписки: ', nl: true}
  , {wrapper: '{{автобиблиография}}\n', button: 'библиография'}
  , {wrapper: '{{список текстов по теме}}\n', button: 'тексты'}
  , {wrapper: '\n== Примечания ==\n{{примечания}}\n', button: '<img src="/images/3/38/Etool_column_one.png" height="16" width="16" alt="books">', title: 'Примечания'}
  , {wrapper: '\n== Примечания ==\n{{примечания|2}}\n', button: '<img src="/images/7/7d/Etool_column_two.png" height="16" width="16" alt="books">', title: 'Примечания в 2 столбца'}  
  , {title: 'Цитирование', nl: true}
  , {wrapper: '\n{{цитата|+|источник}}', button: '<img src="/images/0/05/Etool_document_quote.png" height="16" width="16" alt="books">', title: 'Цитата', filler: 'Цитируемый текст'}, br
  , {title: 'Кавычки:'}
  , {wrapper: '<q>+</q>', button: '«<span class="plus_sign">a</span>»', title: 'Универсальные', filler: 'Текст в кавычках'}
  , {wrapper: '«+»', button: '«<span class="plus_sign">a</span>»', title: 'Обычные', filler: 'Текст в кавычках'}  
  , {wrapper: '„+“', button: '„<span class="plus_sign">a</span>“', title: 'Вложенные', filler: 'Текст в кавычках второго уровня'}, br
  , {wrapper: '“+”', button: '“<span class="plus_sign">a</span>”', title: 'Английские', filler: 'Текст в кавычках внутри английского текста'}
  , {wrapper: '»+«', button: '»<span class="plus_sign">a</span>«', title: 'Немецкие', filler: 'Текст в кавычках внутри немецкого текста'}, br
  , {wrapper: '{{current}}', button: '<img src="/images/0/02/Current_event_marker.png" alt="!" height="16" width="21" />', title: 'Текущие события'}
  , {url: mw.util.wikiGetlink ('Справка:Примечания и сноски'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Примечания и сноски', nl: true}
], separator, [
    {button: '<img src="/images/c/c7/Etool_image.png" width="16" height="16" alt="Файл" />', title: 'Изображения', nl: true}
  , {wrapper: '{{Файл|+|ширина|right}}', button: '<img src="/images/c/c7/Etool_image.png" width="16" height="16" alt="-[]-" />', title: 'Универсальное изображение', filler: 'Имя файла'}
  , {wrapper: '[[Файл:+|thumb|(размер)px|(описание)]]', button: '<img src="/images/d/d7/Etool_image_right.png" width="16" height="16" alt="-[]-" />', title: 'Изображение справа', filler: 'Имя файла'}
  , {wrapper: '[[Файл:+|thumb|center|(размер)px|(описание)]]', button: '<img src="/images/8/88/Etool_image_center.png" width="16" height="16" alt="-[]-" />', title: 'Изображение в центре', filler: 'Имя файла'}
  , {wrapper: '[[Файл:+|(размер)px]]', button: '<img src="/images/a/aa/Etool_inline_image.png" height="16" width="17" alt="=[]=">', title: 'Внутристрочное изображение', filler: 'Имя файла'}, br
  , {wrapper: '{{Строчный блок|[[Файл:+|thumb|center|(размер)px|(описание)]]}}', button: '<img src="/images/8/83/Etool_inline_block_image.png" height="16" width="17" alt="[][][]">', title: 'Изображение в строчном блоке', filler: 'Имя файла'}, br
  , {wrapper: '\n<gallery>+</gallery>\n', button: '<img src="/images/d/d6/Etool_images.png" height="16" width="16" alt="[][][]">', title: 'Галерея', filler: 'Список файлов'}
  , {wrapper: '{{изображения}}', button: '<img src="/images/d/d6/Etool_images.png" height="16" width="16" alt="↓[][][]">', title: 'Автоматическая галерея'}
  , {url: mw.util.wikiGetlink ('Справка:Изображения'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Изображения', nl: true}
], [
    {button: '<img src="/images/0/0f/Etool_youtube.png" height="16" width="16" alt="YouTube">', title: 'Видео YouTube', nl: true}
  , {wrapper: '{{YouTube|+|ширина=(ширина)|(описание)}}', button: '<img src="/images/5/51/Etool_youtube_right.png" height="16" width="19" alt="film&rarr;">', title: 'YouTube справа', filler: 'Номер ролика'}
  , {wrapper: '{{YouTube|+|ширина=(ширина)|(описание)|центр=да}}', button: '<img src="/images/5/5c/Etool_youtube_centered.png" height="15" width="16" alt="film">', title: 'YouTube в центре', filler: 'Номер ролика'}
  , {wrapper: '{{Строчный блок|{{YouTube|+|ширина=(ширина)|(описание)|центр=да}}}}', button: '<img src="/images/b/bf/Etool_youtube_inline.png" height="16" width="32" alt="film">', title: 'YouTube в строчном блоке', filler: 'Номер ролика'}
  , {url: mw.util.wikiGetlink ('Справка:Видео'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Видео', nl: true}
], [
    {button: '<img src="/images/f/fe/Etool_globe_model.png" height="16" width="16" alt="[M]">', title: 'Карта WikiLeaflet', nl: true}
  , {wrapper: '{{wl|\n+\n}}', button: '<img src="/images/1/15/Etool_map.png" height="16" width="16" alt="[M]">', title: 'Вставить карту', filler: 'Содержимое карты — дополнительные вызовы {{wl}}.'}, br
  , {wrapper: '{{wl|точка|+|долгота|текст|тип|надпись=надпись}}', button: '<img src="/images/3/32/Etool_location_pin.png" height="16" width="16" alt="P">', title: 'Поставить значок', filler: 'широта'}
  , {wrapper: '{{wl|значок|+|файл|ширина|высота|тень|ширина тени|высота тени|сдвиг значка x|сдвиг значка y|сдвиг тени от пузыря x|сдвиг тени от пузыря y|надпись=надпись}}L', button: '<img src="/images/b/b4/Etool_legend.png" height="16" width="16" alt="...">', title: 'Определить значок', filler: 'идентификатор значка'}, br
  , {wrapper: '{{wl|центр|+|долгота|увеличение}}', button: '<img src="/images/b/be/Etool_compass.png" height="16" width="16" alt="compass">', title: 'Центр и масштаб', filler: 'широта'}
  , {wrapper: '{{wl|высота|+}}', button: '<img src="/images/7/77/Etool_vrule.png" width="16" height="16" alt="Файл" />', title: 'Высота', filler: 'целая высота карты в пикселах'}
  , {wrapper: '{{wl|редактор}}', button: '<img src="/images/e/e1/Etool_map_edit.png" height="16" width="16" alt="[M]/">', title: 'Возможность редактировать', filler: '-'}, br  
  , {title: 'Тайлы от:'}
  , {wrapper: '{{wl|тайлы|osm}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'osm'}
  /*, {wrapper: '{{wl|тайлы|local}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'сервер «Традиции»'}*/
  , {wrapper: '{{wl|тайлы|osmarender}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'osmarender'}
  , {wrapper: '{{wl|тайлы|cycle}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'cycle'}
  , {wrapper: '{{wl|тайлы|mapquest}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'mapquest'}
  , {wrapper: '{{wl|тайлы|openaerial}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'openaerial'}
  , {wrapper: '{{wl|тайлы|osmosnimki}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'osmosnimki'}
  , {wrapper: '{{wl|тайлы|kosmosnimki}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'kosmosnimki'}
  , {wrapper: '{{wl|тайлы|openmapsurfer}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="&larr;S">', title: 'openmapsurfer'}
  , br
  , '{{wl|меню|+}} {{wl|фильтры|+}} {{wl|пункт|+}} {{wl|GeoJSON|<nowiki>+</nowiki>}}'
  , {url: mw.util.wikiGetlink ('Справка:Карты'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Карты', nl: true}
], separator, [
    {button: '', title: 'Вики', nl: true}
  , {wrapper: '#перенаправление [[+]]', button: '<img src="/images/4/40/Etool_document_redirect.png" height="16" width="16" alt="&crarr;">', title: 'Перенаправление', filler: 'На какую статью перенаправить'}, br
  , {wrapper: '{{другие значения|+}}', button: 'Др. зн.', title: 'Есть другие значения'}
  , {wrapper: '{{неоднозначность}}', button: '<img src="/images/thumb/5/5f/Disambig_gray.svg/16px-Disambig_gray.svg.png" height="16" width="16" alt="‎E">', title: 'Неоднозначность'}, br,
  , {wrapper: '{{main|+}}', button: '<img src="/images/3/32/Icons-mini-icon_2main.png" height="16" width="16" alt="‎&rarr;">', title: 'Основная статья'},
  , {wrapper: '{{обзор|+}}', button: '<img src="/images/a/a9/Icons-mini-icon_2brief.png" height="16" width="16" alt="‎&uarr;">', title: 'Обзор'}, br
  , {wrapper: '{{+}}', button: '<img src="/images/2/21/Etool_template.png" height="16" width="41" alt="{{*}}">', title: 'Вызвать шаблон', filler: 'Шаблон'}
  , {wrapper: '{{!}}', title: '| для передачи в шаблон', filler: '-'}, br    
  , {wrapper: '\n[[Категория:+]]', button: '<img src="/images/3/32/Etool_bookshelf.png" width="16" height="16" alt="Добавить категорию" />', title: 'Добавить категорию', filler: 'Категория'}, br
  , {wrapper: '\n{{DISPLAYTITLE:+}}', button: '<img src="/images/7/78/Etool_displaytitle.png" height="16" width="16" alt="&lt;&gt;">', title: 'Отображаемое название'}
  , {wrapper: '\n{{DEFAULTSORT:+}}', button: '<img src="/images/a/a2/Etool_page_key.png" height="16" width="16" alt="&uarr;&darr;">', title: 'Ключ сортировки'}, br
  , {button: '', title: 'Заготовки и черновики', nl: true}
  , {wrapper: '{{заготовка}}', button: '<img src="/images/thumb/9/9d/Blank_template.gif/16px-Blank_template.gif" height="16" width="16" alt="&lt;!&gt;">', title: 'Заготовка'}
  , {wrapper: '{{черновик}}', button: '<img src="/images/7/73/Etool_construction.png" height="16" width="16" alt="&lt;!&gt;">', title: 'Черновик'}  
  , {wrapper: '{{сборник ссылок}}', button: '<img src="/images/thumb/Asymmetrical_symbol_of_Chaos.ant.svg/16px-Asymmetrical_symbol_of_Chaos.ant.svg.png" height="16" width="16" alt="&lt;!&gt;">', title: 'Сборник ссылок'}  
  , {wrapper: '{{Написал|+}}', button: '<img src="/images/3/3d/Etool_document_signature.png" height="16" width="16" alt="~">', title: 'Написал', filler: '(автор)'}
],
wgTitle.indexOf (':') > -1 ? [
    {button: '<img src="/images/6/66/Etool_infobox.png" alt="К" width="14" height="16" />', title: 'Карточка текста', wrapper: '{{Текст\n'
+ '    | название          = (название всего текста, по умолчанию часть названия страницы после двоеточия)\n'
+ '    | оригинал названия = (название на языке, с которого переведён текст)\n'
+ '    | подзаголовок      = (подзаголовок)\n'
+ '    | жанр              = (жанр текста)\n'
+ '    | категория         = (категория, по умолчанию, Традиция:Авторские статьи; -, если категория не должна добавляться)\n'
+ '    | автор             = (автор, по умолчанию часть названия страницы перед двоеточием)\n'
+ '    | оригинал автора   = (имя автора на языке, с которого переведён текст)\n'
+ '    | переводчик        = (имя переводчика иностранного текста) \n'
+ '    | язык оригинала    = (язык, на котором первоначально написан переведённый текст)\n'
+ '    | язык перевода     = (язык, на который переведён текст, по умолчанию — русский)\n'
+ '    | переведено        = (дата перевода)\n'
+ '    | раздел            = (название раздела текста на странице)\n'
+ '    | № раздела         = (номер раздела текста, который содержит эта страница)\n'
+ '    | без содержания    = (задать любое непустое значение, чтобы подавить вывод содержания)\n'
+ '    | написано          = (дата написания)\n'
+ '    | публикация        = (ссылка на первую публикацию)\n'
+ '    | предыдущая        = (предыдущая книга или текст в серии или сборнике)\n'
+ '    | следующая         = (следующая книга или текст в серии или сборнике)\n'
+ '    | источник          = (откуда текст попал на «Традицию»)\n'
+ '    | дата              = (дата первой публикации)\n'
+ '    | раздел0           = (ссылка на введение к большому тексту)\n'
+ '    | раздел1           = (ссылка на первый раздел большого текста)\n'
+ '    | раздел2           = (ссылка на второй раздел большого текста)\n'
+ '    …\n'
+ '    | раздел20          = (ссылка на двадцатый раздел большого текста)\n'
+ '    | текст эпиграфа    = (текст эпиграфа)\n'
+ '    | автор эпиграфа    = (автор эпиграфа)\n'
+ '    | источник эпиграфа = (источник эпиграфа)\n'
+ '    | обложка           = (название файла, содержащего изображение обложки)\n'
+ '    | ширина обложки    = (ширина изображения обложки, по умолчанию — 200 px)\n'
+ '    | предмет           = Предмет текста\n'
+ '    | примечание        = (примечание об истории текста и т.п.)\n'
+ '    | описание          = (ссылка на статью «Традиции» с описанием текста)\n'
+ '    | ББК               = (ББК)\n'
+ '    | УДК               = (УДК)\n'
+ '    | аудио             = (ссылка на звуковой файл с чтением текста)\n'
+ '}}\n'}
  , {url: mw.util.wikiGetlink ('Справка:Тексты'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Тексты', nl: true}
] : null
, wgNamespaceNumber == 10 || wgNamespaceNumber == 156 ? [
    {title: 'Шаблоны', nl: true}
  , '{{{+}}} {{!}}', br
  , {wrapper: '<includeonly>+</includeonly>', button: '&lt;includeonly&gt;'}
  , {wrapper: '<noinclude>+</noinclude>', button: '&lt;noinclude&gt;'}, br
  , '\n[[Категория:Традиция:Шаблоны|+]] {{doc}}', br
  , {wrapper: (wgNamespaceNumber == 10 ? makeTemplate : makeForm), button: '<img src="/images/d/d5/Etool_make_template.png" width="16" height="16" alt="M"/>', title: 'Создать ' + (wgNamespaceNumber == 10 ? 'шаблон' : 'форму'), all: true}
  , br,
  , '{{PAGENAME}} {{FULLPAGENAME}} {{#if:|+|}} {{#ifeq:||+|}} {{#switch:|1=+|2=|default=}}', br
  , '{{#vardefine:a=+}} {{#var:+}} {{#forargs:префикс|параметр|значение|+}}'
  , {url: mw.util.wikiGetlink ('Традиция:Шаблоны'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Шаблоны', nl: true}
] : null
, wgNamespaceNumber == 14 ? [
    {title: 'Категория', nl: true}
  , '{{Категория|+|форма}}  {{catmain|+}}'
] : null
, wgNamespaceNumber == 152 ? [
    {title: 'SMW', nl: true}
  , '{{Свойство|+|тип|опис|общ}}  [[Имеет_тип:+]]  {{Отношение|+|опис|общ}}'
] : null
, wgNamespaceNumber == 6 || wgTitle == 'Upload' || wgTitle == 'Загрузка' ? [
    {button: '<img src="/images/a/a3/Etool_image_desc.png" height="16" width="16" alt="Ξ">'
   , title: 'Описание', wrapper: '{{Изображение'
      + '\n| Название       = {{PAGENAME}}'
      + '\n| Объект         ='
      + '\n| Тип            ='
      + '\n| Описание       ='
      + '\n| Автор          ='
      + '\n| Время создания ='
      + '\n| Источник       ='
      + '\n| Лицензия       ='
      + '\n}}'
    }
  , {title: 'Лицензии', nl: true}
  , licenses
] : null, [
    {url: mw.util.wikiGetlink ('Справка:Справка'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Содержание', nl: true}
  , {url: mw.util.wikiGetlink ('Традиция:Правила и указания'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Правила и указания'}, br
  , {url: mw.util.wikiGetlink ('Традиция:Вики-разметка'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Вики-разметка'}, br
  , {url: mw.util.wikiGetlink ('Традиция:Типографика'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Типографика'}, br
  , {url: mw.util.wikiGetlink ('Традиция:Шаблоны'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Шаблоны'}, br
  , {url: mw.util.wikiGetlink ('Традиция:Как делать таблицы'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Таблицы'}, br
  , {url: mw.util.wikiGetlink ('Справка:Примечания и сноски'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Примечания и сноски'}, br
  , {url: mw.util.wikiGetlink ('Справка:Изображения'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Изображения'}, br
  , {url: mw.util.wikiGetlink ('Справка:Видео'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Видео'}, br
  , {url: mw.util.wikiGetlink ('Справка:Карты'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Карты'}, br
  , {url: mw.util.wikiGetlink ('Справка:Графы'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Графы'}, br
  , {url: mw.util.wikiGetlink ('Справка:Формулы'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Формулы'}, br
  , {url: mw.util.wikiGetlink ('Справка:Тексты'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Тексты'}
]
];
// Нижняя панель:
var tools_below = [
[
    {button: 'Яя', title: 'Кириллица', nl: true, leader: true}
  , '<<Основные:>> А а Б б В в Г г Д д Е е Ё ё Ж ж З з И и Й й К к Л л М м Н н О о П п Р р С с Т т У у Ф ф Х х Ц ц Ч ч Ш ш Щ щ Ъ ъ Ы ы Ь ь Э э Ю ю Я я br '
  + '<<Старорусские:>> Ѳ ѳ  І і  Ѣ ѣ  Ѵ ѵ <<Древнерусские:>> Ѕ ѕ  Ѥ ѥ  Ѯ ѯ  Ѹ ѹ  Ѱ ѱ  Ѡ ѡ  Ѻ ѻ  Ѽ ѽ  Ѿ ѿ  Ѧ ѧ  Ѩ ѩ  Ѫ ѫ  Ѭ ѭ  Ѷ ѷ  ҂  а҃  б҄  а҅  а҆  ́а  {{подст:у́}} br '
  + '<<Другие_славянские:>> Ґ ґ Ѓ ѓ Ђ ђ Є є І і Ї ї Й й Ј ј Ќ ќ Љ љ Њ њ Ћ ћ Ў ў Џ џ br '
  + '<<Неславянские:>> Ә ә Ө ө Ғ ғ Җ җ Қ қ Ҝ ҝ Ң ң Ү ү Ұ ұ Ҳ ҳ Ҹ ҹ Һ һ  Ҕ ҕ Ӣ ӣ Ӯ ӯ Ҙ ҙ  Ҡ ҡ Ҥ ҥ Ҫ ҫ Ӑ ӑ  Ӓ ӓ Ӕ ӕ Ӗ ӗ Ӱ ӱ  Ӳ ӳ Ӹ ӹ Ӏ br '
  + 'Ҟ ҟ Ҧ ҧ Ҩ ҩ Ҭ ҭ  Ҵ ҵ Ҷ ҷ Ҽ ҽ Ҿ ҿ  Ӂ ӂ Ӄ ӄ Ӈ ӈ Ӌ ӌ  Ӛ ӛ Ӝ ӝ Ӟ ӟ Ӡ ӡ  Ӥ ӥ Ӧ ӧ Ӫ ӫ Ӵ ӵ '
], [
    {button: 'Ωω', title: 'Греческие', nl: true, leader: true}
  , '<<Основные:>> Α α Β β Γ γ Δ δ Ε ε Ζ ζ Η η Θ θ Ι ι Κ κ Λ λ Μ μ Ν ν Ξ ξ Ο ο Π π Ρ ρ Σ σ ς Τ τ Υ υ Φ φ Χ χ Ψ ψ Ω ω br '
  + '<<Шаблоны:>> {{lang-el|+}}  {{lang-el2|+}} {{Polytonic|+}} br '
  + '<<С_тонами:>> Ά ά Έ έ Ή ή Ί ί Ό ό Ύ ύ Ώ ώ  ᾼ ᾳ ᾴ Ὰ ὰ ᾲ ᾶ ᾷ Ἀ ἀ ᾈ ᾀ Ἁ ἁ ᾉ ᾁ Ἄ ἄ ᾌ ᾄ Ἂ ἂ ᾊ ᾂ Ἆ ἆ ᾎ ᾆ Ἅ ἅ ᾍ ᾅ Ἃ ἃ ᾋ ᾃ Ἇ ἇ ᾏ ᾇ br '
  + 'Ὲ ὲ Ἐ ἐ Ἑ ἑ Ἔ ἔ Ἒ ἒ Ἕ ἕ Ἓ ἓ ῌ ῃ ῄ Ὴ ὴ ῂ ῆ ῇ Ἠ ἠ ᾘ ᾐ Ἡ ἡ ᾙ ᾑ Ἤ ἤ ᾜ ᾔ Ἢ ἢ ᾚ ᾒ Ἦ ἦ ᾞ ᾖ Ἥ ἥ ᾝ ᾕ Ἣ ἣ ᾛ ᾓ Ἧ ἧ ᾟ ᾗ br '
  + 'Ὶ ὶ ῖ Ἰ ἰ Ἱ ἱ Ἴ ἴ Ἲ ἲ Ἶ ἶ Ἵ ἵ Ἳ ἳ Ἷ ἷ Ὸ ὸ Ὀ ὀ Ὁ ὁ Ὄ ὄ Ὂ ὂ Ὅ ὅ Ὃ ὃ ῤ Ῥ ῥ Ὺ ὺ ῦ ὐ Ὑ ὑ ὔ ὒ ὖ Ὕ ὕ Ὓ ὓ Ὗ ὗ br '
  + 'ῼ ῳ ῴ Ὼ ὼ ῲ ῶ ῷ Ὠ ὠ ᾨ ᾠ Ὡ ὡ ᾩ ᾡ Ὤ ὤ ᾬ ᾤ Ὢ ὢ ᾪ ᾢ Ὦ ὦ ᾮ ᾦ Ὥ ὥ ᾭ ᾥ Ὣ ὣ ᾫ ᾣ Ὧ ὧ ᾯ ᾧ br '
  + '<<Архаичные:>> Ϝ ϝ  Ϙ ϙ  Ϛ ϛ  Ϻ ϻ  Ϡ ϡ <<Варианты:>>  ϐ ϑ ϳ ϰ ϱ ϲ ϕ ϖ <<Коптские:>> Ϣ ϣ Ϥ  Ϧ ϧ  Ϩ ϩ  Ϫ ϫ  Ϭ ϭ  Ϯ ϯ br '
  + '<<Пунктуация:>> ʹ ͵ ͺ ;'  
], [
    {button: 'Zz', title: 'Латинские', nl: true, leader: true}
  , '<<Основные:>> A a B b C c D d E e F f G g H h I i J j K k L l M m N n O o P p R r S s T t U u V v W w X x Y y Z z br '
  + '<<Шаблоны:>> {{Unicode|+}} br '
  + '<<Дополнительные:>> A a Á á À à Â â Ä ä Ǎ ǎ Ă ă Ā ā Ã ã Å å Ą ą Æ æ Ǣ ǣ  B b  C c Ć ć Ċ ċ Ĉ ĉ Č č Ç ç  D d Ď ď Đ đ Ḍ ḍ Ð ð br '
  + 'E e É é È è Ė ė Ê ê Ë ë Ě ě Ĕ ĕ Ē ē Ẽ ẽ Ę ę Ə ə  F f  G g Ġ ġ Ĝ ĝ Ğ ğ Ģ ģ  H h Ĥ ĥ Ħ ħ Ḥ ḥ  I i İ ı Í í Ì ì Î î Ï ï Ǐ ǐ Ĭ ĭ Ī ī Ĩ ĩ Į į  J j Ĵ ĵ br '
  + 'K k Ķ ķ  L l Ĺ ĺ Ŀ ŀ Ľ ľ Ļ ļ Ł ł Ḷ ḷ Ḹ ḹ  M m Ṃ ṃ  N n Ń ń Ň ň Ñ ñ Ņ ņ Ṇ ṇ  O o Ó ó Ò ò Ô ô Ö ö Ǒ ǒ Ŏ ŏ Ō ō Õ õ Ǫ ǫ Ő ő Ø ø Œ œ br '
  + 'P p  Q q  R r Ŕ ŕ Ř ř Ŗ ŗ Ṛ ṛ Ṝ ṝ  S s Ś ś Ŝ ŝ Š š Ş ş Ṣ ṣ ß  T t Ť ť Ţ ţ Ṭ ṭ Þ þ  U u Ú ú Ù ù Û û Ü ü Ǔ ǔ Ŭ ŭ Ū ū Ũ ũ Ů ů Ų ų Ű ű Ǘ ǘ Ǜ ǜ Ǚ ǚ Ǖ ǖ br '
  + 'V v  W w Ŵ ŵ  X x  Y y Ý ý Ŷ ŷ Ÿ ÿ Ỹ ỹ Ȳ ȳ  Z z Ź ź Ż ż Ž ž  ß Ð ð Þ þ Ə ə'
], [
    {button: 'א', title: 'Еврейские', nl: true, leader: true}
  , '<<Шаблоны:>> {{lang-he|+}} {{lang-he2|+}} br '
  + '<<Основные:>> א ב ג ד ה ו ז ח ט י ך כ ל ם מ ן נ ס ע ף פ ץ צ ק ר ש ת br '
  + '<<Дополнительные:>>  ׳ ״  װ ױ ײ '
], [
    {button: 'ار', title: 'Арабские', nl: true, leader: true}
  , '<<Шаблоны:>> {{lang-ar|+}}  {{lang-ar2|+}} br '
  + '<<Основные:>> ا ب ت ث ج ح خ د ذ ر ز س ش ص ض ط ظ ع غ ف ق ك ل م ن ه و ي br '
  + '<<Дополнительные:>> ﺁ  ﺓ ﻻ ﷲ ء '
  , {wrapper: 'ى', button: 'ى', title: 'алиф максура'}
  , {wrapper: 'ي', button: 'ي', title: 'йе'} , br
  , '<<Пунктуация:>> ، ؛ ؟ br '
  + '<<Цифры:>> ٠ ١ ٢ ٣ ٤ ٥ ٦ ٧ ٨ ٩ ٪ ٫ ٬'  
], [
    {button: '[ɑ]', title: 'IPA для английского языка', nl: true, leader: true}
  , '<<Шаблоны:>> {{IPA-en|+}} {{IPA|/+/}} ‹+› br '
  + 'ˈ ˌ ŋ ɡ tʃ dʒ ʃ ʒ θ ð ʔ  iː ɪ uː ʊ ʌ ɜr eɪ ɛ æ oʊ ɒ ɔː ɔɪ ɔr ɑː ɑr aɪ aʊ  ə ər ɨ ɵ ʉ'
  , {button: '[ʔ]', title: 'IPA для других языков', nl: true}
  , '<<Шаблон:>> {{IPA|+}} br '
  + 'ʈ ɖ ɟ ɡ ɢ ʡ ʔ  ɸ β θ ð ʃ ʒ ɕ ʑ ʂ ʐ ç ʝ ɣ χ ʁ ħ ʕ ʜ ʢ ɦ  ɱ ɳ ɲ ŋ ɴ  ʋ ɹ ɻ ɰ  ʙ ⱱ ʀ ɾ ɽ  ɬ ɮ ɺ ɭ ʎ ʟ  ʍ ɥ ɧ  ʼ ɓ ɗ ʄ ɠ ʛ br '
  + 'ʘ ǀ ǃ ǂ ǁ  ɨ ʉ ɯ ɪ ʏ ʊ ø ɘ ɵ ɤ ə ɛ œ ɜ ɞ ʌ ɔ æ ɐ ɶ ɑ ɒ br '
  + 'ʰ ʱ ʷ ʲ ˠ ˤ ˀ ᵊ k̚ ⁿˡ  ˈ ˌ ː ˑ t̪ d̪ s̺ s̻ θ̼ s̬ n̥ ŋ̊ a̤ a̰  β̞ ˕ r̝ ˔ o˞ ɚ ɝ e̘ e̙ u̟ i̠ ɪ̈ e̽ ɔ̹ ɔ̜ n̩ ə̆ ə̯ ə̃ ȷ̃ ɫ z̴ ə̋ ə́ ə̄ ə̀ ə̏ ə̌ ə̂ ə᷄ ə᷅ ə᷇ ə᷆ ə᷈ ə᷉ t͡ʃ d͡ʒ t͜ɬ ‿ br '
  + '˥ ˦ ˧ ˨ ˩ ꜛ ꜜ | ‖ ↗ ↘  k͈ s͎'
], separator, [
 {title: 'Формулы TEX', nl: true},
 {wrapper: '<math>+</math>', button: '<img src="/images/9/96/Etool_pi_math.png" height="16" width="16" alt="π">', title: 'Вставить внутристрочную формулу', filler: 'Формула'}, br,
 {wrapper: '\n: <math>+</math>\n', button: '<img src="/images/c/ce/Etool_pi_math_centered.png" height="16" width="16" alt="π">', title: 'Вставить выносную формулу', filler: 'Формула'}, br,
 {url: mw.util.wikiGetlink ('Справка:Формулы'), button: '<img src="/images/d/d5/Etool_help.png" height="16" width="16" alt="?">', title: 'Справка: Формулы'}
], [
 {button: 'Ω', title: 'Главные символы:', nl: true, leader: true},
 {wrapper: '{,}+', button: '<b>,</b>', title: 'Десятичная запятая', filler: '(дробная часть)'},
 {wrapper: '~+', button: '<b>·</b>', title: 'Неразрывный пробел TEX', filler: '(после пробела)'},
 {wrapper: '\\dots +', button: '<b>…</b>', title: 'Многоточие', filler: '(после многоточия)'}, br,
 {title: 'Греческие:'},
 {wrapper: '\\Alpha', button: 'Α'},
 {wrapper: '\\Beta', button: 'Β'},
 {wrapper: '\\Gamma', button: 'Γ'},
 {wrapper: '\\Delta', button: 'Δ'},
 {wrapper: '\\Epsilon', button: 'Ε'},
 {wrapper: '\\Zeta', button: 'Ζ'},
 {wrapper: '\\Eta', button: 'Η'},
 {wrapper: '\\Theta', button: 'Θ'},
 {wrapper: '\\Iota', button: 'Ι'},
 {wrapper: '\\Kappa', button: 'Κ'},
 {wrapper: '\\Lambda', button: 'Λ'},
 {wrapper: '\\Mu', button: 'Μ'},
 {wrapper: '\\Nu', button: 'Ν'},
 {wrapper: '\\Xi', button: 'Ξ'},
 {wrapper: '\\O', button: 'Ο'},
 {wrapper: '\\Pi', button: 'Π'},
 {wrapper: '\\Rho', button: 'Ρ'},
 {wrapper: '\\Sigma', button: 'Σ'},
 {wrapper: '\\Tau', button: 'Τ'},
 {wrapper: '\\Upsilon', button: 'Υ'},
 {wrapper: '\\Phi', button: 'Φ'},
 {wrapper: '\\Chi', button: 'Χ'},
 {wrapper: '\\Psi', button: 'Ψ'},
 {wrapper: '\\Omega', button: 'Ω'}, br,
 {wrapper: '\\alpha', button: 'α'},
 {wrapper: '\\beta', button: 'β'},
 {wrapper: '\\gamma', button: 'γ'},
 {wrapper: '\\delta', button: 'δ'},
 {wrapper: '\\epsilon', button: 'ε'},
 {wrapper: '\\varepsilon', button: 'ɛ'},
 {wrapper: '\\zeta', button: 'ζ'},
 {wrapper: '\\eta', button: 'η'},
 {wrapper: '\\theta', button: 'θ'},
 {wrapper: '\\iota', button: 'ι'},
 {wrapper: '\\kappa', button: 'κ'},
 {wrapper: '\\varkappa', button: 'ϰ'},
 {wrapper: '\\lambda', button: 'λ'},
 {wrapper: '\\mu', button: 'μ'},
 {wrapper: '\\nu', button: 'ν'},
 {wrapper: '\\xi', button: 'ξ'},
 {wrapper: '\\o', button: 'ο'},
 {wrapper: '\\pi', button: 'π'},
 {wrapper: '\\varpi', button: 'ϖ'},
 {wrapper: '\\rho', button: 'ρ'},
 {wrapper: '\\varrho', button: 'ϱ'},
 {wrapper: '\\sigma', button: 'σ'},
 {wrapper: '\\varsigma', button: 'ς'},
 {wrapper: '\\tau', button: 'τ'},
 {wrapper: '\\upsilon', button: 'υ'},
 {wrapper: '\\phi', button: 'ϕ'},
 {wrapper: '\\varphi', button: 'φ'},
 {wrapper: '\\chi', button: 'χ'},
 {wrapper: '\\psi', button: 'ψ'},
 {wrapper: '\\omega', button: 'ω'}, br,
 {title: 'Архаические греческие:'},
 {wrapper: '\\Stigma', button: 'Ϛ'},
 {wrapper: '\\Digamma', button: 'Ϝ'},
 {wrapper: '\\Koppa', button: 'Ϟ'},
 {wrapper: '\\Sampi', button: 'Ϡ'},
 {wrapper: '\\digamma', button: 'ϝ'},
 {wrapper: '\\backepsilon', button: '϶'},
 {title: 'Еврейские:'},
 {wrapper: '\\aleph', button: 'ℵ'},
 {wrapper: '\\beth', button: 'ℶ'},
 {wrapper: '\\gimel', button: 'ℷ'},
 {wrapper: '\\daleth', button: 'ℸ'}, br,
 {title: 'Диакритики:'},
 {wrapper: '\\acute{+}', button: '<b><span style="color:black">a</span>́</b>', title: 'Акут', filler: 'Буква под акутом'},
 {wrapper: '\\grave{+}', button: '<b><span style="color:black">a</span>̀</b>', title: 'Гравис', filler: 'Буква под грависом'},
 {wrapper: '\\breve{+}', button: '<b><span style="color:black">a</span>̆</b>', title: 'Кратка', filler: 'Буква под краткой'},
 {wrapper: '\\check{+}', button: '<b><span style="color:black">a</span>̇</b>', title: 'Чек', filler: 'Буква под чеком'},
 {wrapper: '\\tilde{+}', button: '<b><span style="color:black">a</span>̃</b>', title: 'Тильда', filler: 'Буква под тильдой'},
 {wrapper: '\\hat{+}', button: '<b><span style="color:black">a</span>̂</b>', title: 'Шляпка', filler: 'Буква под шляпкой'},
 {wrapper: '\\bar{+}', button: '<b><span style="color:black">a</span>̅</b>', title: 'Черта', filler: 'Буква под чертой'}, br,
 {title: 'Шрифты:'},
 {wrapper: '\\boldsymbol{+}', button: '<b>β</b>', title: 'жирный', filler: 'Жирный шрифт'},
 {wrapper: '\\mathbf{+}', button: '<b>v</b>', title: 'вектор', filler: 'Вектор'},
 {wrapper: '\\mathbb{+}', button: 'ℙ', title: 'ажурный', filler: 'Ажурный шрифт'},
 {wrapper: '\\mathsf{+}', button: 's', title: 'рубленый', filler: 'Рубленый шрифт'},
 {wrapper: '\\mathfrak{+}', button: 'ℑ', title: 'готический', filler: 'Готический шрифт'},
 {wrapper: '\\mathcal{+}', button: 'ℛ', title: 'каллиграфический', filler: 'Каллиграфический шрифт'},
 {wrapper: '\\mathit{+}', button: '<i>i</i>', title: 'наклонный', filler: 'Наклонный шрифт'}
], [
 {button: '√ ̅', title: 'Унарные операции', nl: true, leader: true},
 {wrapper: '\\sqrt{+}', button: '√ ̅', title: 'Квадратный корень', filler: 'под корнем'},
 {wrapper: '\\sqrt[3]{+}', button: '∛ ̅', title: 'Кубический корень', filler: 'под корнем'},
 {title: 'Тригонометрические функции:', nl: true},
 {wrapper: '\\sin +', button: 'sin', title: 'Синус', filler: 'аргумент'},
 {wrapper: '\\cos +', button: 'cos', title: 'Косинус', filler: 'аргумент'},
 {wrapper: '\\tg +', button: 'tg', title: 'Тангенс', filler: 'аргумент'},
 {wrapper: '\\sec +', button: 'sec', title: 'Секанс', filler: 'аргумент'},
 {wrapper: '\\cosec +', button: 'cosec', title: 'Косеканс', filler: 'аргумент'},
 {wrapper: '\\ctg +', button: 'ctg', title: 'Котангенс', filler: 'аргумент'}, br,
 {wrapper: '\\arcsin +', button: 'arcsin', title: 'Арксинус', filler: 'аргумент'},
 {wrapper: '\\arccos +', button: 'arccos', title: 'Арккосинус', filler: 'аргумент'},
 {wrapper: '\\arctg +', button: 'arctg', title: 'Арктангенс', filler: 'аргумент'},
 {wrapper: '\\arcsec +', button: 'arcsec', title: 'Арксеканс', filler: 'аргумент'},
 {wrapper: '\\arccosec +', button: 'arccosec', title: 'Арккосеканс', filler: 'аргумент'},
 {wrapper: '\\arcctg +', button: 'arcctg', title: 'Арккотангенс', filler: 'аргумент'},
 {title: 'Гиперболические и логарифмические функции:', nl: true},
 {wrapper: '\\sh +', button: 'sh', title: 'Гиперболический синус', filler: 'аргумент'},
 {wrapper: '\\ch +', button: 'ch', title: 'Гиперболический косинус', filler: 'аргумент'},
 {wrapper: '\\th +', button: 'th', title: 'Гиперболический тангенс', filler: 'аргумент'},
 {wrapper: '\\cth +', button: 'cth', title: 'Гиперболический котангенс', filler: 'аргумент'}, br,
 {wrapper: '\\exp +', button: 'exp', title: 'Экспонента', filler: 'аргумент'},
 {wrapper: '\\log _{основание} +', button: 'log<sub><i>n</i></sub><i>x</i>', title: 'Логарифм', filler: 'аргумент'},
 {wrapper: '\\ln +', button: 'ln', title: 'Натуральный логарифм', filler: 'аргумент'},
 {wrapper: '\\lg +', button: 'lg', title: 'Десятичный логарифм', filler: 'аргумент'},
 {title: 'Прочие функции:', nl: true},
 {wrapper: '\\min +', button: 'min', title: 'Минимум', filler: 'аргумент'},
 {wrapper: '\\max +', button: 'max', title: 'Максимум', filler: 'аргумент'}
], [
 {button: '+', title: 'Бинарные операции', nl: true, leader: true},
 {wrapper: '^+', button: '<span style="color:black; font-style: italic;">x<sup style="color: blue">n</sup></span>', title: 'Верхний индекс TEX', filler: 'индекс'},
 {wrapper: '_+', button: '<span style="color:black; font-style: italic">x<sub style="color: blue">i</sub></span>', title: 'Нижний индекс TEX', filler: 'индекс'},
 {title: 'Операции:', nl: true},
 {wrapper: ' ++ ', button: '+', title: 'Плюс', filler: 'слагаемое'},
 {wrapper: ' -+ ', button: '-', title: 'Минус', filler: 'вычитаемое'},
 {wrapper: '\\mp', button: '∓'},
 {wrapper: '\\pm', button: '±'},
 {wrapper: '\\frac{+}{знаменатель}', button: '<i><sup style="margin-right: -0.7em; border-bottom: solid 1px"><i>x</i></sup><sub>y</sub></i>', title: 'Дробь', filler: 'числитель'},
 {wrapper: ' \\cdot ', button: '·'},
 {wrapper: ' \\times ', button: '×'},
 {wrapper: ' \\div ', button: '÷'},
 {wrapper: '\\sqrt[n]{+}', button: '<i><sup style="margin-right: -0.5em">y</sup>√x̅</i>', title: 'Корень n-ной степени', filler: 'под корнем'},
 {wrapper: '\\dotplus', button: '∔'}, br,
 {wrapper: '\\setminus', button: '∖'},
 {wrapper: '\\{ast}', button: '∗'},
 {wrapper: '\\circ', button: '∘'},
 {wrapper: '\\wedge', button: '∧'},
 {wrapper: '\\vee', button: '∨'},
 {wrapper: '\\cap', button: '∩'},
 {wrapper: '\\cup', button: '∪'},
 {wrapper: '\\wr', button: '≀'},
 {wrapper: '\\uplus', button: '⊎'},
 {wrapper: '\\sqcap', button: '⊓'},
 {wrapper: '\\sqcup', button: '⊔'},
 {wrapper: '\\oplus', button: '⊕'},
 {wrapper: '\\ominus', button: '⊖'},
 {wrapper: '\\otimes', button: '⊗'},
 {wrapper: '\\oslash', button: '⊘'},
 {wrapper: '\\odot', button: '⊙'},
 {wrapper: '\\circledcirc', button: '⊚'},
 {wrapper: '\\circledast', button: '⊛'},
 {wrapper: '\\circleddash', button: '⊝'},
 {wrapper: '\\boxplus', button: '⊞'},
 {wrapper: '\\boxminus', button: '⊟'},
 {wrapper: '\\boxtimes', button: '⊠'},
 {wrapper: '\\boxdot', button: '⊡'},
 {wrapper: '\\intercal', button: '⊺'},
 {wrapper: '\\veebar', button: '⊻'},
 {wrapper: '\\diamond', button: '⋄'},
 {wrapper: '\\cdot', button: '⋅'},
 {wrapper: '\\star', button: '⋆'},
 {wrapper: '\\divideontimes', button: '⋇'},
 {wrapper: '\\ltimes', button: '⋉'},
 {wrapper: '\\rtimes', button: '⋊'},
 {wrapper: '\\leftthreetimes', button: '⋋'},
 {wrapper: '\\rightthreetimes', button: '⋌'},
 {wrapper: '\\curlyvee', button: '⋎'},
 {wrapper: '\\curlywedge', button: '⋏'},
 {wrapper: '\\Cap', button: '⋒'},
 {wrapper: '\\Cup', button: '⋓'},
 {wrapper: '\\perspcorrespond', button: '⌆'},
 {wrapper: '\\bigcirc', button: '○'},
 {wrapper: '\\amalg', button: '⨿'},
 {wrapper: '\\perspcorrespond', button: '⩞'},
 {wrapper: '\\homothetic', button: '∻'},
 {wrapper: '\\lazysinv', button: '∾'},
 {wrapper: '\\allequal', button: '≌'},
 {wrapper: '\\bigcap', button: '⋂'},
 {wrapper: '\\bigcup', button: '⋃'},
 {title: 'Отношения:', nl: true},
 {wrapper: '\\UpEquilibrium', button: '⥮'},
 {wrapper: '\\ReverseUpEquilibrium', button: '⥯'},
 {wrapper: '\\RoundImplies', button: '⥰'},
 {wrapper: '\\Equal', button: '⩵'},
 {wrapper: '\\leqslant', button: '⩽'},
 {wrapper: '\\geqslant', button: '⩾'},
 {wrapper: '\\lessapprox', button: '⪅'},
 {wrapper: '\\gtrapprox', button: '⪆'},
 {wrapper: '\\lneq', button: '⪇'},
 {wrapper: '\\gneq', button: '⪈'},
 {wrapper: '\\lnapprox', button: '⪉'},
 {wrapper: '\\gnapprox', button: '⪊'},
 {wrapper: '\\lesseqqgtr', button: '⪋'},
 {wrapper: '\\gtreqqless', button: '⪌'},
 {wrapper: '\\eqslantless', button: '⪕'},
 {wrapper: '\\eqslantgtr', button: '⪖'},
 {wrapper: '\\NestedLessLess', button: '⪡'},
 {wrapper: '\\NestedGreaterGreater', button: '⪢'},
 {wrapper: '\\preceq', button: '⪯'},
 {wrapper: '\\succeq', button: '⪰'},
 {wrapper: '\\precneqq', button: '⪵'},
 {wrapper: '\\succneqq', button: '⪶'},
 {wrapper: '\\precapprox', button: '⪷'},
 {wrapper: '\\succapprox', button: '⪸'},
 {wrapper: '\\precnapprox', button: '⪹'},
 {wrapper: '\\succnapprox', button: '⪺'},
 {wrapper: '\\subseteqq', button: '⫅'},
 {wrapper: '\\supseteqq', button: '⫆'},
 {wrapper: '\\subsetneqq', button: '⫋'},
 {wrapper: '\\supsetneqq', button: '⫌'}, br,
 {wrapper: '\\parallel', button: '∥'},
 {wrapper: '\\nparallel', button: '∦'},
 {wrapper: '\\sim', button: '∼'},
 {wrapper: '\\backsim', button: '∽'},
 {wrapper: '\\not\\sim', button: '≁'},
 {wrapper: '\\simeq', button: '≃'},
 {wrapper: '\\not\\simeq', button: '≄'},
 {wrapper: '\\cong', button: '≅'},
 {wrapper: '\\approxnotequal', button: '≆'},
 {wrapper: '\\not\\cong', button: '≇'},
 {wrapper: '\\approx', button: '≈'},
 {wrapper: '\\not\\approx', button: '≉'},
 {wrapper: '\\approxeq', button: '≊'},
 {wrapper: '\\tildetrpl', button: '≋'},
 {wrapper: '\\asymp', button: '≍'},
 {wrapper: '\\Bumpeq', button: '≎'},
 {wrapper: '\\bumpeq', button: '≏'},
 {wrapper: '\\doteq', button: '≐'},
 {wrapper: '\\doteqdot', button: '≑'},
 {wrapper: '\\fallingdotseq', button: '≒'},
 {wrapper: '\\risingdotseq', button: '≓'},
 {wrapper: '\\eqcirc', button: '≖'},
 {wrapper: '\\circeq', button: '≗'},
 {wrapper: '\\estimates', button: '≙'},
 {wrapper: '\\starequal', button: '≛'},
 {wrapper: '\\triangleq', button: '≜'},
 {wrapper: '\\not =', button: '≠'},
 {wrapper: '\\equiv', button: '≡'},
 {wrapper: '\\not\\equiv', button: '≢'},
 {wrapper: '\\leq', button: '≤'},
 {wrapper: '\\geq', button: '≥'},
 {wrapper: '\\leqq', button: '≦'},
 {wrapper: '\\geqq', button: '≧'},
 {wrapper: '\\lneqq', button: '≨'},
 {wrapper: '\\gneqq', button: '≩'},
 {wrapper: '\\ll', button: '≪'},
 {wrapper: '\\gg', button: '≫'},
 {wrapper: '\\between', button: '≬'},
 {wrapper: '\\not<', button: '≮'},
 {wrapper: '\\not>', button: '≯'},
 {wrapper: '\\not\\leq', button: '≰'},
 {wrapper: '\\not\\geq', button: '≱'},
 {wrapper: '\\lessequivlnt', button: '≲'},
 {wrapper: '\\greaterequivlnt', button: '≳'},
 {wrapper: '\\lessgtr', button: '≶'},
 {wrapper: '\\gtrless', button: '≷'},
 {wrapper: '\\notlessgreater', button: '≸'},
 {wrapper: '\\notgreaterless', button: '≹'},
 {wrapper: '\\prec', button: '≺'},
 {wrapper: '\\succ', button: '≻'},
 {wrapper: '\\preccurlyeq', button: '≼'},
 {wrapper: '\\succcurlyeq', button: '≽'},
 {wrapper: '\\precapprox', button: '≾'},
 {wrapper: '\\succapprox', button: '≿'},
 {wrapper: '\\not\\prec', button: '⊀'},
 {wrapper: '\\not\\succ', button: '⊁'}, br,
 {wrapper: '\\subset', button: '⊂'},
 {wrapper: '\\supset', button: '⊃'},
 {wrapper: '\\not\\subset', button: '⊄'},
 {wrapper: '\\not\\supset', button: '⊅'},
 {wrapper: '\\subseteq', button: '⊆'},
 {wrapper: '\\supseteq', button: '⊇'},
 {wrapper: '\\not\\subseteq', button: '⊈'},
 {wrapper: '\\not\\supseteq', button: '⊉'},
 {wrapper: '\\subsetneq', button: '⊊'},
 {wrapper: '\\supsetneq', button: '⊋'},
 {wrapper: '\\sqsubset', button: '⊏'},
 {wrapper: '\\sqsupset', button: '⊐'},
 {wrapper: '\\sqsubseteq', button: '⊑'},
 {wrapper: '\\sqsupseteq', button: '⊒'},
 {wrapper: '\\backsimeq', button: '⋍'},
 {wrapper: '\\Subset', button: '⋐'},
 {wrapper: '\\Supset', button: '⋑'},
 {wrapper: '\\lessdot', button: '⋖'},
 {wrapper: '\\gtrdot', button: '⋗'},
 {wrapper: '\\verymuchless', button: '⋘'},
 {wrapper: '\\verymuchgreater', button: '⋙'},
 {wrapper: '\\lesseqgtr', button: '⋚'},
 {wrapper: '\\gtreqless', button: '⋛'},
 {wrapper: '\\curlyeqprec', button: '⋞'},
 {wrapper: '\\curlyeqsucc', button: '⋟'},
 {wrapper: '\\not\sqsubseteq', button: '⋢'},
 {wrapper: '\\not\sqsupseteq', button: '⋣'},
 {wrapper: '\\lnsim', button: '⋦'},
 {wrapper: '\\gnsim', button: '⋧'},
 {wrapper: '\\precedesnotsimilar', button: '⋨'},
 {wrapper: '\\succnsim', button: '⋩'},
 {wrapper: '\\ntriangleleft', button: '⋪'},
 {wrapper: '\\ntriangleright', button: '⋫'},
 {wrapper: '\\ntrianglelefteq', button: '⋬'},
 {wrapper: '\\ntrianglerighteq', button: '⋭'},
 {wrapper: '\\in', button: '∈'},
 {wrapper: '\\not\\in', button: '∉'},
 {wrapper: '\\ni', button: '∋'},
 {wrapper: '\\not\ni', button: '∌'},
 {wrapper: '\\propto', button: '∝'}, br,
 {wrapper: '\\mid', button: '∣'},
 {wrapper: '\\nmid', button: '∤'},
 {wrapper: '\\vdash', button: '⊢'},
 {wrapper: '\\dashv', button: '⊣'},
 {wrapper: '\\perp', button: '⊥'},
 {wrapper: '\\truestate', button: '⊧'},
 {wrapper: '\\forcesextra', button: '⊨'},
 {wrapper: '\\Vdash', button: '⊩'},
 {wrapper: '\\Vvdash', button: '⊪'},
 {wrapper: '\\VDash', button: '⊫'},
 {wrapper: '\\nvdash', button: '⊬'},
 {wrapper: '\\nvDash', button: '⊭'},
 {wrapper: '\\nVdash', button: '⊮'},
 {wrapper: '\\nVDash', button: '⊯'},
 {wrapper: '\\vartriangleleft', button: '⊲'},
 {wrapper: '\\vartriangleright', button: '⊳'},
 {wrapper: '\\trianglelefteq', button: '⊴'},
 {wrapper: '\\trianglerighteq', button: '⊵'},
 {wrapper: '\\LeftTriangleBar', button: '⧏'},
 {wrapper: '\\RightTriangleBar', button: '⧐'}
], [
 {button: '∯', title: 'Групповые операции', nl: true, leader: true},
 {title: 'Суммы и интегралы:', nl: true},
 {wrapper: '\\sum\\limits_{i=1}^{n}+_i', button: '∑<span style="font-size: 65%"><sub><i>i=1</i></sub><sup style="margin-left: -0.7em"><i>n</i></sup></span>', title: 'Сумма', filler: '(суммируемое)'},
 {wrapper: '\\prod\\limits_{i=1}^{n}+_i', button: '∏<span style="font-size: 65%"><sub><i>i=1</i></sub><sup style="margin-left: -0.7em"><i>n</i></sup></span>', title: 'Произведение', filler: '(перемножаемое)'},
 {wrapper: '\\coprod\\limits_{i=1}^{n}+_i', button: '∐<span style="font-size: 65%"><sub><i>i=1</i></sub><sup style="margin-left: -0.7em"><i>n</i></sup></span>', title: 'Сопроизведение', filler: '(перемножаемое)'}, 
 {wrapper: '\\bigcap_1^{n} +', button: '∩<span style="font-size: 65%"><sub><i>i=1</i></sub><sup style="margin-left: -0.7em"><i>n</i></sup></span>', title: 'Пересечение', filler: '(множества)'},
 {wrapper: '\\bigcup_1^{n} +', button: '∪<span style="font-size: 65%"><sub><i>i=1</i></sub><sup style="margin-left: -0.7em"><i>n</i></sup></span>', title: 'Объединение', filler: '(множества)'},
 {wrapper: '\\int\\limits_{-N}^{N} +dx', button: '∫<span style="font-size: 65%"><sub>-N</sub><sup style="margin-left: -0.7em">N</sup></span>', title: 'Интеграл', filler: '(функция)'}, br,
 {wrapper: '\\iint\\limits_{-N}^{N} +dxdy', button: '∬<span style="font-size: 65%"><sub>-N</sub><sup style="margin-left: -0.7em">N</sup></span>', title: 'Двойной интеграл', filler: '(функция)'},
 {wrapper: '\\iiint\\limits_{-N}^{N} +dxdydz', button: '∭<span style="font-size: 65%"><sub>-N</sub><sup style="margin-left: -0.7em">N</sup></span>', title: 'Тройной интеграл', filler: '(функция)'},
 {wrapper: '\\oint\\limits_{C} +dx', button: '∮<span style="font-size: 65%"><sub>C</sub></span>', title: 'Интеграл по контуру', filler: '(функция)'},
 {wrapper: '\\surfintegral\\limits_{S} +dx', button: '∯<span style="font-size: 65%"><sub>S</sub></span>', title: 'Интеграл по поверхности', filler: '(функция)'},
 {wrapper: '\\volintegral\\limits_{V} +dx', button: '∰<span style="font-size: 65%"><sub>V</sub></span>', title: 'Интеграл по объёму', filler: '(функция)'},
 {wrapper: '\\clwintegral\\limits_{V} +dx', button: '∱<span style="font-size: 65%"><sub>V</sub></span>', title: 'Ещё какой-то интеграл', filler: '(функция)'}, br,
 {wrapper: '{n \\choose k}', button: '(<sub>k</sub><span style="font-size: 65%"><sup style="margin-left: -0.7em">n</sup></span>)', title: 'Биномиальный коэффициент'},
 {wrapper: '\\lim_{n \to \infty}+_n', button: 'lim', title: 'Предел', filler: '(последовательность)'},
 {title: 'Объединения:', nl: true},
 {wrapper: '\\overline {+}', button: '<span style="text-decoration: overline">abc</span>' /*'a̅b̅c̅'*/, title: 'Черта над', filler: 'под чертой'},
 {wrapper: '\\underline {+}', button: '<u>abc</u>', title: 'Черта под', filler: 'подчёркнутое'},
 {wrapper: '\\vec {+}', button: 'a⃗', title: 'Вектор', filler: 'под вектором'},
 {wrapper: '\\overrightarrow {+}', button: 'A̅B̅C⃗', title: 'Стрелка вправо сверху', filler: 'под стрелкой'},
 {wrapper: '\\overlefthtarrow {+}', button: 'A⃖B̅C̅', title: 'Стрелка влево сверху', filler: 'под стрелкой'},
 {wrapper: '\\widehat {+}', button: 'Â', title: 'Широкая шляпка', filler: 'под шляпкой'},
 {wrapper: '\\overbrace {+}^{надпись)', button: '{сверху', title: 'Фигурная скобка сверху', filler: 'под скобкой'},
 {wrapper: '\\underbrace {+}_{подпись)', button: '{внизу', title: 'Фигурная скобка внизу', filler: 'над скобкой'},
 {title: 'Системы и матрицы:', nl: true},
 {wrapper: '\\begin{cases} + \\\\ уравнение2 \\\\ уравнение3 \\end{cases}', button: '{<span style="font-size: 65%"><sub><i>a=b</i></sub><sup style="margin-left: -1.5em"><i>c=d</i></sup></span>', title: 'Система уравнений'},
 {wrapper: '\\begin{pmatrix} + & y \\\\ z & v \\end{pmatrix}', button: '(Матрица)'},
 {wrapper: '\\begin{bmatrix} 0 & \\cdots & 0 \\\\ \\vdots & \\ddots & \\vdots \\\\ 0 & \\cdots & 0\\end{bmatrix}', button: '[Матрица]'},
 {wrapper: '\\begin{Bmatrix} + & y \\\\ z & v \\end{Bmatrix}', button: '{Матрица}'},
 {wrapper: '\\begin{vmatrix} + & y \\\\ z & v \\end{vmatrix}', button: '|Матрица|'},
 {wrapper: '\\begin{Vmatrix} + & y \\\\ z & v \\end{Vmatrix}', button: '||Матрица||'},
 {wrapper: '\\begin{matrix} + & y \\\\ z & v \\end{matrix}', button: 'Матрица'},
 {title: 'Скобки:', nl: true},
 {wrapper: '\\left( + \\right)', button: '()', title: 'Круглые скобки', filler: 'в скобках'},
 {wrapper: '\\left[ + \\right]', button: '[]', title: 'Квадратные скобки', filler: 'в скобках'},
 {wrapper: '\\lbrace + \\rbrace', button: '{}', title: 'Фигурные скобки', filler: 'в скобках'},
 {wrapper: '\\langle + \\rangle', button: '<>', title: 'Угловые скобки', filler: 'в скобках'},
 {wrapper: '\\left| + \\right|', button: '||', title: 'Прямые скобки', filler: 'в скобках'}, br,
 {wrapper: '\\lceil + \\rceil', button: '⌈⌉', title: null, filler: 'в скобках'},
 {wrapper: '\\lfloor + \\rfloor', button: '⌊⌋', title: null, filler: 'в скобках'},
 {wrapper: '\\ulcorner + \\urcorner', button: '⌜⌝', title: null, filler: 'в скобках'},
 {wrapper: '\\llcorner + \\lrcorner', button: '⌞⌟', title: null, filler: 'в скобках'},
 {wrapper: '\\openbracketleft + \\openbracketright', button: '〚〛', title: null, filler: 'в скобках'}
], [
 {button: '∃', title: 'Знаки', nl: true, leader: true},
 {title: 'Стрелки:'},
 {wrapper: '\\circlearrowleft', button: '↺'},
 {wrapper: '\\circlearrowright', button: '↻'},
 {wrapper: '\\uparrow', button: '↑'},
 {wrapper: '\\rightarrow', button: '→'},
 {wrapper: '\\leftarrow', button: '←'},
 {wrapper: '\\downarrow', button: '↓'},
 {wrapper: '\\leftrightarrow', button: '↔'},
 {wrapper: '\\updownarrow', button: '↕'},
 {wrapper: '\\nwarrow', button: '↖'},
 {wrapper: '\\nearrow', button: '↗'},
 {wrapper: '\\searrow', button: '↘'},
 {wrapper: '\\swarrow', button: '↙'},
 {wrapper: '\\nleftarrow', button: '↚'},
 {wrapper: '\\nrightarrow', button: '↛'},
 {wrapper: '\\arrowwaveright', button: '↜'},
 {wrapper: '\\arrowwaveright', button: '↝'},
 {wrapper: '\\twoheadleftarrow', button: '↞'},
 {wrapper: '\\twoheadrightarrow', button: '↠'},
 {wrapper: '\\leftarrowtail', button: '↢'},
 {wrapper: '\\rightarrowtail', button: '↣'},
 {wrapper: '\\mapsto', button: '↦'},
 {wrapper: '\\hookleftarrow', button: '↩'},
 {wrapper: '\\hookrightarrow', button: '↪'},
 {wrapper: '\\looparrowleft', button: '↫'},
 {wrapper: '\\looparrowright', button: '↬'},
 {wrapper: '\\leftrightsquigarrow', button: '↭'},
 {wrapper: '\\nleftrightarrow', button: '↮'},
 {wrapper: '\\nLeftarrow', button: '⇍'},
 {wrapper: '\\nLeftrightarrow', button: '⇎'},
 {wrapper: '\\nRightarrow', button: '⇏'},
 {wrapper: '\\Leftarrow', button: '⇐'},
 {wrapper: '\\Uparrow', button: '⇑'},
 {wrapper: '\\Rightarrow', button: '⇒'},
 {wrapper: '\\Downarrow', button: '⇓'},
 {wrapper: '\\Leftrightarrow', button: '⇔'},
 {wrapper: '\\Updownarrow', button: '⇕'},
 {wrapper: '\\Lleftarrow', button: '⇚'},
 {wrapper: '\\Rrightarrow', button: '⇛'},
 {wrapper: '\\rightsquigarrow', button: '⇝'}, br,
 {wrapper: '\\DownArrowUpArrow', button: '⇵'},
 {wrapper: '\\longleftarrow', button: '⟵'},
 {wrapper: '\\longrightarrow', button: '⟶'},
 {wrapper: '\\longleftrightarrow', button: '⟷'},
 {wrapper: '\\Longleftarrow', button: '⟸'},
 {wrapper: '\\Longrightarrow', button: '⟹'},
 {wrapper: '\\Longleftrightarrow', button: '⟺'},
 {wrapper: '\\longmapsto', button: '⟼'},
 {wrapper: '\\UpArrowBar', button: '⤒'},
 {wrapper: '\\DownArrowBar', button: '⤓'},
 {wrapper: '\\LeftRightVector', button: '⥎'},
 {wrapper: '\\RightUpDownVector', button: '⥏'},
 {wrapper: '\\DownLeftRightVector', button: '⥐'},
 {wrapper: '\\LeftUpDownVector', button: '⥑'},
 {wrapper: '\\LeftVectorBar', button: '⥒'},
 {wrapper: '\\RightVectorBar', button: '⥓'},
 {wrapper: '\\RightUpVectorBar', button: '⥔'},
 {wrapper: '\\RightDownVectorBar', button: '⥕'},
 {wrapper: '\\DownLeftVectorBar', button: '⥖'},
 {wrapper: '\\DownRightVectorBar', button: '⥗'},
 {wrapper: '\\LeftUpVectorBar', button: '⥘'},
 {wrapper: '\\LeftDownVectorBar', button: '⥙'},
 {wrapper: '\\LeftTeeVector', button: '⥚'},
 {wrapper: '\\RightTeeVector', button: '⥛'},
 {wrapper: '\\RightUpTeeVector', button: '⥜'},
 {wrapper: '\\RightDownTeeVector', button: '⥝'},
 {wrapper: '\\DownLeftTeeVector', button: '⥞'},
 {wrapper: '\\DownRightTeeVector', button: '⥟'},
 {wrapper: '\\LeftUpTeeVector', button: '⥠'},
 {wrapper: '\\LeftDownTeeVector', button: '⥡'},
 {wrapper: '\\Lsh', button: '↰'},
 {wrapper: '\\Rsh', button: '↱'},
 {wrapper: '\\curvearrowleft', button: '↶'},
 {wrapper: '\\curvearrowright', button: '↷'},
 {wrapper: '\\leftharpoonup', button: '↼'},
 {wrapper: '\\leftharpoondown', button: '↽'},
 {wrapper: '\\upharpoonright', button: '↾'},
 {wrapper: '\\upharpoonleft', button: '↿'},
 {wrapper: '\\rightharpoonup', button: '⇀'},
 {wrapper: '\\rightharpoondown', button: '⇁'},
 {wrapper: '\\downharpoonright', button: '⇂'},
 {wrapper: '\\downharpoonleft', button: '⇃'},
 {wrapper: '\\rightleftarrows', button: '⇄'},
 {wrapper: '\\dblarrowupdown', button: '⇅'},
 {wrapper: '\\leftrightarrows', button: '⇆'},
 {wrapper: '\\leftleftarrows', button: '⇇'},
 {wrapper: '\\upuparrows', button: '⇈'},
 {wrapper: '\\rightrightarrows', button: '⇉'},
 {wrapper: '\\downdownarrows', button: '⇊'},
 {wrapper: '\\leftrightharpoons', button: '⇋'},
 {wrapper: '\\rightleftharpoons', button: '⇌'}, br,
 {wrapper: '\\bigtriangleup', button: '△'},
 {wrapper: '\\blacktriangle', button: '▴'},
 {wrapper: '\\vartriangle', button: '▵'},
 {wrapper: '\\blacktriangleright', button: '▸'},
 {wrapper: '\\triangleright', button: '▹'},
 {wrapper: '\\bigtriangledown', button: '▽'},
 {wrapper: '\\blacktriangledown', button: '▾'},
 {wrapper: '\\triangledown', button: '▿'},
 {wrapper: '\\blacktriangleleft', button: '◂'},
 {wrapper: '\\triangleleft', button: '◃'}, br,
 {title: 'Прочие:'},
 {wrapper: '\\forall', button: '∀'},
 {wrapper: '\\exists', button: '∃'},
 {wrapper: '\\nexists', button: '∄'},
 {wrapper: '\\therefore', button: '∴'},
 {wrapper: '\\because', button: '∵'},
 {wrapper: '\\varnothing', button: '∅'},
 {wrapper: '\\dddot', button: '⃛'},
 {wrapper: '\\ddddot', button: '⃜'},
 {wrapper: '\\complement', button: '∁'},
 {wrapper: '\\backprime', button: '‵'},
 {wrapper: '\\partial', button: '∂'},
 {wrapper: '\\nabla', button: '∇'},
 {wrapper: '\\infty', button: '∞'},
 {wrapper: '\\rightangle', button: '∟'},
 {wrapper: '\\angle', button: '∠'},
 {wrapper: '\\measuredangle', button: '∡'},
 {wrapper: '\\sphericalangle', button: '∢'},
 {wrapper: '\\rightanglearc', button: '⊾'},
 {wrapper: '\\Angle', button: '⦜'},
 {wrapper: '\\top', button: '⊤'},
 {wrapper: '\\ast', button: '*'},
 {wrapper: '{^1}', button: '¹'},
 {wrapper: '{^2}', button: '²'},
 {wrapper: '{^3}', button: '³'},
 {wrapper: '\\-', button: ''},
 {wrapper: '\\_', button: '_'},
 {wrapper: '\\vert', button: '|'},
 {wrapper: '\\Vert', button: '‖'},
 {wrapper: '\\mkern1mu', button: ' '},
 {wrapper: '\\surd', button: '√'},
 {wrapper: '\\bullet', button: '∙'},
 {wrapper: '\\Colon', button: '∷'},
 {wrapper: '\\vdots', button: '⋮'},
 {wrapper: '\\cdots', button: '⋯'},
 {wrapper: '\\upslopeellipsis', button: '⋰'},
 {wrapper: '\\downslopeellipsis', button: '⋱'},
 {wrapper: '\\hermitconjmatrix', button: '⊹'},
 {wrapper: '\\pitchfork', button: '⋔'},
 {wrapper: '\\recorder', button: '⌕'},
 {wrapper: '\\lmoustache', button: '⎰'},
 {wrapper: '\\rmoustache', button: '⎱'},
 {wrapper: '\\circledS', button: 'Ⓢ'},
 {wrapper: '\\diagup', button: '╱'},
 {wrapper: '\\fbox{~~}', button: '▭'},
 {wrapper: '\\RuleDelayed', button: '⧴'},
 {wrapper: '\\stackrel{*}{=}', button: '⩮'},
 {wrapper: '\\original', button: '⊶'},
 {wrapper: '\\image', button: '⊷'},
 {wrapper: '\\multimap', button: '⊸'},
 {wrapper: '\\bowtie', button: '⋈'},
 {wrapper: '\\frown', button: '⌢'},
 {wrapper: '\\smile', button: '⌣'},
 {wrapper: '\\square', button: '□'},
 {wrapper: '\\blacksquare', button: '▪'},
 {wrapper: '\\diamond', button: '♢'},
 {wrapper: '\\lozenge', button: '◊'},
 {wrapper: '\\blacklozenge', button: '⧫'},
 {wrapper: '\\flat', button: '♭'},
 {wrapper: '\\natural', button: '♮'},
 {wrapper: '\\sharp', button: '♯'},
 {wrapper: '\\mbox{+}', button: 'Текст', title: null, filler: '(текст)'} 
], [
 {wrapper: '\\label{+}', button: '№', title: 'Автонумеровать формулу', filler: 'метка'},
 {wrapper: '\\eqno{+}', button: '№', title: 'Ручной № формулы', filler: '№'},
 {wrapper: '\\eqref{+}', button: '№', title: 'Ссылка на формулу', filler: 'метка'}
], separator
, [ // Символы:
    {button: '<img src="/images/3/37/Etool_sum.png" width="16" height="16" alt="&Sigma;" />', title: 'Знаки', nl: true, leader: true}
  , '<<Математические:>> − × ÷ ⋅ ° +² +³ ∗ ∘ ± ∓ ≤ ≥ ≠ ≡ ≅ ≜ ≝ ≐ ≃ ≈ ⊕ ⊗ ∞ ≪ ≫ ∝ √ ∤ ≀ ◅ ▻ ⋉ ⋊ ⋈ ∴ ∵ ∙ ∷ ⋮ ⋯ ⋰ ⋱ br '
  + '¬ ∧ ∨ ⊻ ∀ ∃ ∄ ∅ ∈ ∉ ∋ ⊆ ⊈ ⊊ ⊂ ⊄ ⊇ ⊉ ⊋ ⊃ ⊅ ∪ ∩ ∑ ∏ ∐ ′ ∫ ∬ ∭ ∮ ∇ ∂ ∆ ∅ ℂ ℍ ℕ ℙ ℚ ℝ ℤ ℵ br '
  + '⌊ ⌋ ⌈ ⌉ ⊤ ⊥ ⊢ ⊣ ⊧ □ ∠ ⟨ ⟩ &nbsp; &minus; br '
  + ' ⃛  ⃜ ∁ ‵ ∂ ∞ ∟ ∠ ∡ ∢ ⊾ ⦜ ⊤ * ¹ ² ³ _ | ‖   √ ⊹ ⋔ ⌕ ⎰ ⎱ Ⓢ ╱ ▭ ⧴ ⩮ ⊶ ⊷ ⊸ ⋈ ⌢ ⌣ □ ▪ ♢ ◊ ⧫ br '
  + '<<Дроби:>> ½ ⅓ ⅔ ¼ ¾ ⅛ ⅜ ⅝ ⅞ <<Шахматы:>> ♔ ♕ ♖ ♗ ♘ ♙ ♚ ♛ ♜ ♝ ♞ ♟ br '
  + '<<Масти:>> ♠ ♣ ♥ ♦ ♡ ♢ ♤ ♧ <<Триграммы:>> ☰ ☱ ☲ ☳ ☴ ☵ ☶ ☷ br '
  + '<<Астрономия:>> ☼ ☽ ☾ ☿ ♀ ♁ ♂ ♃ ♄ ♅ ♆ ♇' + inline_separator + '♈ ♉ ♊ ♋ ♌ ♍ ♎ ♏ ♐ ♑ ♒ ♓' + inline_separator + '☉ ☊ ☋ ☌ ☍ br '
  + '<<Символы:>> ® © ™ ♀ ♂ ℅ ℓ ℗ µ Ω ℮ ☠ ☡ ☢ ☣ ☤ ☥ ☦ ☧ ☨ ☩ ☪ ☫ ☬ ✡ ☭ ☮ ☯ br '
  + '<<Ноты:>> ♩ ♪ ♫ ♬ ♬ ♭ ♮ ♯ br '
  + '<<Валюты:>> ¤ ₳ ฿ ₵ ¢ ₡ ₢ $ ₫ ₯ € ₠ ₣ ƒ ₴ ₭ ₤ ℳ ₥ ₦ ₧ ₰ £ ៛ ₨ ₪ ৳ ₮ ₩ ¥ br '
  + '<<Стрелки:>> ↺ ↻ ↑ → ← ↓ ↔ ↕ ↖ ↗ ↘ ↙ ↚ ↛ ↜ ↝ ↞↠ ↢ ↣ ↦ ↩  ↪ ↫ ↬ ↭ ↮ ⇍ ⇎ ⇏ ⇐ ⇑ ⇒ ⇓ ⇔ ⇕ ⇚ ⇛ ⇝ ☚ ☛ ☜ ☝ ☞ ☟ ➔ ➘ ➙ ➚ ➛ ➜ ➝ ➟ ➠ ➡ ➢ ➣ ➤ ➥ ➦ ➧ ➨ ➨ ➪ ➫ ➬ ➭ ➮ ➯ ➱ ➲ ➳ ➴ ➵ ➶ ➷ ➸ ➹ ➺ ➻ ➼ ➽ ➾ br '
  + '⇵ ⟵ ⟶ ⟷ ⟸ ⟹ ⟺ ⟼ ⤒ ⤓ ⥎ ⥏ ⥐ ⥑ ⥒ ⥓ ⥔ ⥕ ⥖ ⥗ ⥘ ⥙ ⥚ ⥛ ⥜ ⥝ ⥞ ⥟ ⥠ ⥡ br '
  + '↰ ↱ ↶ ↷ ↼ ↽ ↾ ↿ ⇀ ⇁ ⇂ ⇃ ⇄ ⇅ ⇆ ⇇ ⇈ ⇉ ⇊ ⇋ ⇌ △ ▴ ▵ ▸ ▹ ▽ ▾ ▿ ◂ ◃ br '
  + '⇄ ⇅ ⇆ ⇇ ⇈ ⇉ ⇊ ⇋ ⇌ △ ▴ ▵ ▸ ▹ ▽ ▾ ▿ ◂ ◃'
], // Подписи и обсуждения:
wgNamespaceNumber % 2 == 1 || wgNamespaceNumber == 4 ? [
    {title: 'Подписи', nl: true}
  , {wrapper: '<br />~~~~', button: '<img src="/images/c/c1/Etool_text_signature.png" width="16" height="16" alt="~~" />', title: 'С новой строки'}, br
  , '<<В_той_же_строке:>> --~~~~  ~~~~   —_~~~~  ~~~', br
  , {wrapper: '{{unsigned|+}}'}
  , {title: 'Голосования и обсуждения', nl: true}
  , {wrapper: '{{За}}', button: '<img src="/images/thumb/9/94/Symbol_support_vote.svg/15px-Symbol_support_vote.svg.png" alt="+" height="15" width="15" />', title: 'За'}
  , {wrapper: '{{Против}}', button: '<img src="/images/thumb/7/7f/Symbol_oppose_vote.svg/15px-Symbol_oppose_vote.svg.png" alt="-" height="15" width="15" />', title: 'Против'}
  , {wrapper: '{{Воздерживаюсь}}', button: '<img src="/images/thumb/5/5f/Symbol_neutral_vote.png/15px-Symbol_neutral_vote.png" alt="~" height="15" width="15" />', title: 'Воздерживаюсь'}, br
  , {wrapper: '{{Оставить}}', button: '<img src="/images/thumb/5/5a/BallotCheckMark.png/15px-BallotCheckMark.png" alt="Оставить" height="15" width="15" />', title: 'Оставить'}
  , {wrapper: '{{Удалить}}', button: '<img src="/images/thumb/8/83/BallotX.png/15px-BallotX.png" alt="Удалить" height="15" width="15" />', title: 'Удалить'}, br
  , {wrapper: '{{Перенесено в|+}}', filler: 'Страница, куда перенесён текст'}
  , {wrapper: '{{Перенесено из|+}}', filler: 'Страница, откуда перенесён текст'}
  , {title: 'Новые страницы', nl: true}
  , {title: 'Страница побывала в шаблоне «Новые статьи»', button: '<img src="/images/thumb/b/b9/Internet-news-reader.svg/16px-Internet-news-reader.svg.png" alt="!" height="16" width="16" />', wrapper: '{{Было_в_новых|URL=+}}'}
] : null
];
/*
 *  Обработчики событий:
 */
// Для упрощения синтаксиса вызова, оформляются в виде метода jQuery:
$.fn.extend ({ 
    // Выбрать ведущую кнопку для подменю:
    setLeader: function ($button) { 
        // Find first active (not submenu) button:
        $button = $button ? $button : this.find ('.leader *, button:not(.label), a:not(.label)').first ();
        this.parent ().children ('.last').replaceWith ($button.clone (true).addClass ('last'));
        return this;
    }
    // Сделать кнопку ведущей в подменю:
  , makeLeader: function () {
        this.parents ('.eMenu ul').setLeader (this);
        return this;
    }
    // Клонировать меню/подменю для указанного текстового поля:
  , cloneForTextbox: function (id) {
        return this.clone (true).find ('button, ul').attr ('forbox', id).end ().attr ('forbox', id);
    }
    // Активировать панели инструментов для текстового поля:
  , activateToolbars: function () {
        // Все панели серым:
        $('.eMenu').removeClass ('active');
        // Относящиеся к окну с фокусом -- не серым:
        $('.eMenu[forbox="' + this.attr ('id') + '"]').addClass ('active');
    }
    // Показать подменю с отложенной загрузкой:
  , loadAndShow: function (speed) {
       clearInterval (delay_id);
       var $ret = this.hasClass ('postponed')
                       // Подменю с отложенной загрузкой. Перезагрузить:
                     ? eMenu (
                           cache [this.attr('id')]
                         , 1, true
                       ).cloneForTextbox (this.attr('forbox')).replaceAll (this)
                       // Подменю полностью загружено:
                     : this;
        return speed == 'instant' ? $ret.show () : $ret.slideDown (speed);
    }
});
// Развёртывание и свёртывание субменю не наездом, а щелчком по треугольнику.
//     Так развёрнутое подменю свёртывается только другим щелчком:
function fixedToggle ($tool) {
    var $toolbar = $tool.parents ('.eMenu');
    // Снять класс fixed со всех развёрнутых подменю данной панели,
    //     всё равно, наездом или щелчком, кроме щёлкнутого:
    $toolbar.find ('li').not ($tool [0]).find ('.eMenu').removeClass ('fixed');
    // Переключить класс fixed щёлкнутого меню:
    $tool.find ('.eMenu').toggleClass ('fixed');
    // Скрыть все подменю данной панели:
    $toolbar.find ('li .eMenu').hide ();    
    // Показать подменю, развёрнутые щелчком (с классом fixed):
    $('.fixed').loadAndShow ();
    // Установить значки на основании класса fixed:
    $('.extender').each (function () {
        $(this).html ($(this).parent ('li').find ('.eMenu.fixed').length ? collapser : extender);
    });
}
/*
 *  Функции-обработчики настроек:
 */
// Экранирование HTML для title, onclick и т.п.:
function escape4htmlEvents (s) {
   return s.replace (/</g, '&lt;').replace (/>/g, '&gt;').replace (/"/g, '&quot;').replace (/\\/g, '\\\\').replace (/'/g, '\\\'');
}
// Удаляет из аргумента теги HTML:
function stripHTML (s) {
    return s ? s.replace (/(<.+?>|\n)/g, '') : null;
}
// Удаление из строки символов, недопустимых в имени переменной Javascript
//     для использования в кэше HTML:
function makeCacheKey (s) {
    return s.replace (/[:'"&+*\-\/|[\]{}(),\s\.#;]/g, 'S').replace (/\?/g, 'qu');
}
// Возвращает имя функции. Нужна только из-за IE:
function functionName (func) {
    var name = func && (typeof (func) == 'function' || typeof (func) == 'object')
             ? func.name
             : null;
    if (!name) {
        var matches = ('' + func).match (/function\s*([\w\$\d_]*)\s*\(/);
        name = matches ? matches [1] : '';
    }
    return name;
}
// Отладочная функция:
function showObj (obj, depth) {
    var out = '';
    if (!depth) {
        depth = 2;
    }
    if (typeof (obj) == 'object' && obj != null && depth > 1) {
        out += 'object (' + obj.constructor.name + ') : [\n';
        $.each (obj, function (key, val) {
            // window.alert (key + ' = ' + val + ' (' + typeof (val) + ')\n');
            out += key + ' = ' + showObj (val, depth - 1) + '\n';
        });
        out += ']';
    } else if (typeof (obj) == 'object' && obj != null && depth <= 1) {
        out = '[object]\n';
    } else if (obj != null) {
        out = typeof (obj) + ': ' + obj.toString ();
    } else {
        out = 'null';
    }
    return out;
}

/*
 *    Точка входа:
 */
// Добавление панелей инструментов над и под каждым текстовым полем после загрузки документа:
$(function () {
    // Компиляция панелей инструментов. Проводится только после загрузки формы редактирования,
    //     чтобы не задерживать её показ:
    if (!mw.config.exists ('wgCodeEditorCurrentLanguage') && !(mw.config.exists ('wgWikiEditorEnabledModules') && mw.config.get ('wgWikiEditorEnabledModules').toc)) {
        // Только если не включено содержание:
        // Создание заготовок:
        createStubs ();
        // Обход текстовых полей:
        $('textarea').each (function () {
            // Запись id текстового поля:
            var id = this.id;
            // Добавление панелей:
            $(this).before (       // -- верхняя панель:
                eMenu (tools_above).addClass ('above').cloneForTextbox (id)
            ).after (               // -- нижняя панель:            
                eMenu (tools_below).addClass ('below').cloneForTextbox (id)
            ).focus (function () { // -- событие фокуса: активация своих и деактивация чужих панелей:
                $(this).activateToolbars ();
            });
        });
        // Удаление стандартных инструментов:
        $('#toolbar').remove ();
        // Удаление инструментов WikiEditor:
        $('#wikiEditor-ui-toolbar').remove ();
        mwEditButtons = null;
        // Активация первого текстового поля:
        $('textarea').first ().focus ();
        // window.alert ('Число инструментов -- ' + tool_no);
    }
});
/*
 * Функции, создающие меню из массива:
 */
// Получает в качестве аргумента объект со свойствами
//     wrapper, filler, url, html, button, title:
function eButton (arg) {

    if (!arg) return null;

    // Установить неопределённые свойства в null для упрощения дальнейшего кода:
    var wrapper = typeof arg.wrapper == 'undefined' ? null : arg.wrapper;
    var button  = typeof arg.button  == 'undefined' ? null : arg.button;
    var title   = typeof arg.title   == 'undefined' ? null : arg.title;
    var filler  = typeof arg.filler  == 'undefined' ? null : arg.filler;
    var all     = typeof arg.all     == 'undefined' ? false : arg.all;
    var nl      = typeof arg.nl      == 'undefined' ? null : arg.nl;
    var leader  = typeof arg.leader  == 'undefined' ? null : arg.leader;
    var url     = typeof arg.url     == 'undefined' ? null : arg.url;
    var html    = typeof arg.html    == 'undefined' ? null : arg.html;

    if (!wrapper && !button && !title && !url && !html) return null;

    // Только если явно задано название инструмента, разворачивать его в подменю:
    var expand = arg.title ? true : false;

    tool_no++; // -- счётчик инструментов.
    var $ret = $li_stub.clone ();

    // Вывести инструмент в новой строке?
    if (nl) $ret.addClass ('nl');

    // Сделать его ведущим по умолчанию вне очереди?
    if (leader) $ret.addClass ('leader');

    // Допустить обработку всего поля?
    var wrapper_name = $.isFunction (wrapper)
                     ? functionName (wrapper)
                     : wrapper;
    // TODO: stripHTML () -> mw.html.escape ();
    // Создание отсутствующего заполнителя из заданного названия:
    filler = filler == '-' ? ''
           : filler        ? filler
/*           : title && wrapper && wrapper_name.indexOf ('+') > -1
                           ? stripHTML (title)*/
           :                 '';
    // Всплывающая подсказка для инструмента:
    title = title  ? title // Если надо, создать название из кнопки:
          : button ? escape4htmlEvents (stripHTML (button)) // или даже из обёртки:
          :              $.trim (stripHTML (wrapper_name)).replace (/_/g, ' ');
    // Если надо, создать кнопку из обёртки:
    if (!button && wrapper) {
        var split = wrapper_name.split ('+', 2);
        button = split [0]
               + (split [0] && split [1] ? '<span class="plus_sign">+</span>' : '')
               + (split [1] ? split [1] : '');
    }
    // Кэширование обёртки и заполнителя:
    if (title) {
        var cache_key = makeCacheKey (stripHTML (title));
        cache [cache_key + '_wrapper'] = wrapper;
        cache [cache_key + '_filler']  = filler;
    }
    if (!wrapper && !url && !html && title) {
        // Если обёртки, URL и HTML нет, то создаётся метка: 
        if (nl) $ret.addClass ('header');
        $ret.attr ('title', stripHTML (title)).append (
            // Кнопка без событий, чтобы при протаскивании мыши не началось выделение текста:
            $('<button type="button" class="label"></button>').append (button).append (
                expand ? $('<span></span>').addClass ('full').html (title) : ''
            )
        );
    } else if (url) {
        // Есть URL. Создаётся ссылка: 
        $ret.attr ('title', title ? stripHTML (title) : '').append (
            $a_stub.clone ().attr ('href', url).append (button).append (
                expand ? $full_stub.clone ().html (title) : null
            )
        );
        if (nl) $ret.addClass ('header');
    } else if (html) {
        // Произвольный HTML: 
        if (nl) $ret.addClass ('header');
        $ret = $(html);
    } else {
        // Создаётся настоящая кнопка:
        $ret.append (
            $button_stub.clone (true).attr ('title', stripHTML (title)).attr ('process_all', all).html (button).append (
                // Название инструмента для подменю:
                expand ? $full_stub.clone ().html (title) : null
            )
        );
    }
    return $ret;
}
 
// Создаёт подменю или подменю из массива объектов, описывающих кнопки
//     массивов, описывающих подменю и строк, описывающих ряды кнопок.
//     Если level = 0, нужно меню, иначе -- подменю.
//     Если now = true, отложенная загрузка запрещена.
//     Возвращает объект jQuery:
function eMenu (arg, level, now) {

    if (!level) level = 0;
               
    // Нужно из-за изменения значения this в зависимости от контекста:
    var $li_stub = level == 0 ? $li0_stub : $li1_stub;
    var $ret = level == 0 ? $ul0_stub.clone () : $ul1_stub.clone ();
    
    // Если подменю слишком длинное для немедленного показа, показать отложенно:
    var left = now || level == 0 ? 10000000 : immediate_limit;
    var postponed = false;
    
    // Развёртывание рядов кнопок, заданных с помощью разделённых пробелами строк:
    var parsed = [];

    // Обход всего переданного массива:
    $.each (arg, function () {
        if (this) {
            if (this.split && this.length) {
                // Разделённая пробелами строка. Заменить на массив объектов:
                var estimated_length = this.match (/\S+/ig).length;
                // Массив, полученный разбивкой строки, добавляется к накопленному массиву объектов:
                parsed = $.merge (parsed, $.map (this.split (' ', left), function (s) {
                    // Обёртка подстрок в объекты:
                    return !s         ? null
                          : s == 'br' ? {html   : '<br clear="all" />'} // -- перевод строки.
                          : s.match (/^<<.+>>$/)                        // Метка:
                                      ? {title  : s.replace (/(^<<|>>$)/g, '').replace (/_/g, ' ')}
                          :             {wrapper: s.replace (/_/g, ' ').replace (/-uline-/ig, '_')};
                }));
                // Отдельная оценка необходима, т.к. ограничение в .split () работает неправильно:
                left -= estimated_length;
            } else {
                // Кнопка или подменю. Возвратить как есть:
                parsed.push (this);
                left--;
            }
        }
        // При превышении лимита завершить цикл:
        if (left <= 0) {
            postponed = true;
            return false;
        }
    });
    
    // Обход массива:
    $.each (parsed, function () {
        if (this) {
            if ($.isArray (this)) {
                // Подменю:
                eMenu (this, level + 1, now).appendTo (   // -- создание подменю рекурсивным вызовом.
                    $li_stub.clone (true).appendTo ($ret) // -- создание пункта меню.
                ).setLeader ();                           // -- задание ведущей кнопки.
            } else {
                // Предположительно, объект, описывающий кнопку:
                // Создание пункта меню с кнопкой и добавление к возврату:
                var button = eButton (this);
                if (button) {
                    button.appendTo ($ret);
                }
            }
        }
    });
    // Добавление признаков отложенной загрузки и запись её параметров в кэш:
    if (postponed) {
        // Запись в кэш:
        cache ['postponed_' + lastPostponed] = arg;
        // Класс отложенной записи, id записи в кэше, заглушка:
        $ret.addClass ('postponed').attr ('id', 'postponed_' + lastPostponed++)/*.append (
            $postponed_stub
        )*/;
    }
    
    // Установка класса, заменяющего first-child и last-child, для IE:
    if ($.browser.msie) {
        $ret.children ().first ().addClass ('firstChild');
        $ret.children ().last  ().addClass ('lastChild');
    }
    
    // Возврат:
    return $ret;
}

/*
 *  Функции, обработки текста, вызываемые кнопками: 
 */
// Вставка тега вокруг выделенного текста или вызов функции-обработчика
//     в результате нажатия кнопки
//    (ID окна, обёртка или обработчик, текст-образец (если нет выделения)):
function insertTag (textbox_id, wrapper, filler, all) {
    var callback;
    if ($.isFunction (wrapper)) {
        // Передана функция-обработчик:
        callback = wrapper;
        callback.filler = filler;
    } else {
        // Передана строка-обёртка:
        // Превращение обёртки в открывающий и закрывающий тэги:
        var tag_open, tag_close;
        if (wrapper && wrapper.indexOf ('+') > -1) {
            // Если в обёрке есть плюс, по нему её и разрезать на открывающий и закрывающий теги:
            var tags = wrapper.split (/\+(?!\+)/, 2);
            tag_open  = tags [0];
            tag_close = tags [1];
            callback = function (s) {
                // Окружить старое выделение символами '\x01' и '\x02':
                return tag_open + '\x01' + (s ? s : filler ? filler : '') + '\x02' + tag_close;
            }
        } else {
            // Если в обёртке нет плюса, вставлять её после выделения.
            // Выделить после этого вставленный символ:
            callback = function (s) {
                // Подумать, имеет ли смысл в этом контексте filler:
                return (s ? s : filler ? filler : '') + '\x01' + wrapper + '\x02';
            }
        }
    }
    // ID -> объект DOM:
    var textbox = document.getElementById (textbox_id);
    processSelection (textbox, callback, eval (all));
} // -- конец insertTag ();
// Превратить многострочный текст в маркированный список:
function makeUL (s) {
    return '\n' + (s ? s : makeUL.filler).replace (/^\s*(?:\d*[.)]|-)?\s*(.)/gm, '* $1');
}
// Превратить многострочный текст в нумерованный список:
function makeOL (s) {
    return '\n' + (s ? s : makeOL.filler).replace (/^\s*(?:\d*[.)]|-)?\s*(.)/gm, '# $1');
}
// Превратить многострочный текст в глоссарий:
function makeGlossary (s) {
    return '\n' + (s ? s : makeGlossary.filler).replace (/^\s*(?:\d*[.)]|-)?\s*(.)/gm, '; $1').replace (/[\-—:]/gm, ' : ');
}
// Превратить многострочный текст в строки таблицы (в один столбец):
function makeTable (s) {
    return '\n{| class="wikitable"\n'
         + (s ? s : makeTable.filler).replace (/^./gm, '|-\n| $&').replace (/\t/g, ' || ')
         + '\n|}\n';
}
// Функция, викифицирующая выделение:
function wikifySelection (txtarea_id) {
    processSelection (document.getElementById (txtarea_id)
                    , wikifyText
                    , true);
     // Скорее всего, так просто не заработает:
     if (window.insertSummary) {
         insertSummary ('викификация');
     }
}
// Функция, выполняющая поиск и замену в выделении:
function regexSelection (txtarea_id, search, replace) {
    processSelection (document.getElementById (txtarea_id)
                    , function (s) {return s.replace (search, replace);}
                    , true);
}
// Обработать выделение в textbox с помощью funct.
//     Если ничего не выбрано и установлен all, обработать всё:
function processSelection (textbox, funct, all) {
    var inserted;
    var full_text = 'Будет обработан ВЕСЬ редактируемый текст. Продолжить?';
    var win_scroll = document.documentElement.scrollTop;
    textbox.focus ();
    if (typeof (textbox.selectionStart) != 'undefined'
    && (navigator ['productSub'] > 20031000
     || $.browser.safari
     || $.browser.webkit
     || $.browser.opera
     || $.browser.mozilla)) {
        // Mozilla/Opera/Safari3:
        var textScroll = textbox.scrollTop; // -- сохранить положение промотки.
        // Определить выделение в виде позиций начала и конца:
        var start_pos   = textbox.selectionStart;
        var end_pos     = textbox.selectionEnd;
        if (start_pos == end_pos && all && confirm (full_text)) {
            // Ничего не выделено, но в таком случае позволено обработать весь текст:
            start_pos = 0;
            end_pos = textbox.value.length;
        }
        // Получение и обработка выделения:
        inserted = funct (textbox.value.substring (start_pos, end_pos));
        // Получение старого выделения:
        var sel_offset = inserted.indexOf ('\x01') > -1 ? inserted.indexOf ('\x01') : 0;
        var sel_length = (inserted.indexOf ('\x02') > -1 ? inserted.indexOf ('\x02') : 0) - sel_offset - 1;
        sel_length = sel_length >= 0 ? sel_length : 0;
        // Удаление символов выделения:
        inserted = inserted.replace ('\x01', '').replace ('\x02', '');
        // Перезапись значения поля:
        textbox.value = textbox.value.substring (0, start_pos)
                      + inserted
                      + textbox.value.substring (end_pos);
        // Выделить обработанное. Использовать для выделения нестандартные свойства
        //     selOffset и selLength, если возвращены funct:
        var correction = Math.floor (($.browser.opera && inserted.substr (0, start_pos + sel_offset).match (/\n/g)
                ? inserted.substr (0, start_pos + sel_offset).match (/\n/g).length
                : 0) / 2);
        textbox.selectionStart
          = start_pos
          + sel_offset
          + correction;
        textbox.selectionEnd
          = start_pos + sel_offset
          + sel_length
          - correction;
        // -- всё ещё неверно в Опере.
        textbox.scrollTop = textScroll; // -- восстановить положение промотки.
    } else if (document.selection && document.selection.createRange) {
        // IE:
        // Определить выделение в виде объекта range:
        var range = document.selection.createRange();
        if (range.text.length == 0 && all && confirm (full_text)) {
            // Ничего не выделено, но в таком случае позволено обработать весь текст:
            textbox.value = funct (textbox.value);
        } else {
            // Есть выделение, или обработка всего текста не предусмотрена:
            // Обработать выделение:
            inserted = funct (range.text);
            // Получение старого выделения:
            var sel_offset = inserted.indexOf ('\x01') > -1 ? inserted.indexOf ('\x01') : 0;
            var sel_length = (inserted.indexOf ('\x02') > -1 ? inserted.indexOf ('\x02') : 0) - sel_offset - 1;
            sel_length = sel_length >= 0 ? sel_length : 0;
            // Удаление символов выделения:
            inserted = inserted.replace ('\x01', '').replace ('\x02', '');
            
            // Заменить выделение на обработанное:
            range.text = inserted;
            // Перевыделить вставленное:
            if (range.moveStart) {
                range.moveStart ('character', - inserted.length + sel_offset);
                range.moveEnd   ('character', - inserted.length + sel_offset + sel_length);
            }
            range.select();
        }
    } else { 
        // Другие браузеры. Выделения не получить; обрабатывать всё или ничего:    
        if (all && confirm (full_text)) {
            textbox.value = funct (textbox.value).replace ('\x01', '').replace ('\x02', '');
        }
    }
    document.documentElement.scrollTop = win_scroll; // -- восстановить позицию промотки в IE/Opera.
} // -- конец processSelection ().

/*  Описание изменений
 *  Fixed by Dream, переписано под jQuery А. Машиным:
*/
function insertSummary ($for, text) {
    if ($for.val ().indexOf (text) != -1) return;                       // -- не нужно повторов.
    if ($for.val ().match (/[^,;: \/]$/)) $for.val ($for.val () + ','); // -- добавление запятой в конце.
    if ($for.val ().match (/[^ ]$/))      $for.val ($for.val () + ' '); // -- добавление пробела в конце.
    $for.val ($for.val () + text);                                      // -- добавление текста.
}

$.fn.extend ({
    addSumButton: function ($for, name, text, title) {
        return this.append (
            $('<a></a>').text (name).attr ('title', title).click (function () {
                insertSummary ($for, text);
            })
        );
    }
});

$(function () {
    $('input.mw-summary, input#wpSummary').each (function () {
        var $this = $(this);
        $('<span></span>').attr ('id', 'userSummaryButtonsA').addSumButton (
            $this, 'викиф.', 'викификация', 'Произведена викификация').addSumButton (
            $this, 'оформл.', 'оформление', 'Улучшено оформление').addSumButton (
            $this, 'стиль', 'стилистические правки', 'Переменён стиль изложения').addSumButton (
            $this, 'орфогр.', 'орфография', 'Поправлена орфография').addSumButton (
            $this, 'опеч.', 'зачистка опечаток', 'Исправлена опечатка').addSumButton (
            $this, 'типогр.', 'типографика', 'Поправлена типографика').addSumButton (
            $this, 'пункт.', 'пунктуация', 'Изменена пунктуация').addSumButton (
            $this, 'сноски', '[[Справка:Сноски|сноски]]', 'Оформлены сноски').addSumButton (
            $this, 'кат.', 'категория', 'Исправлена категоризация').addSumButton (
            $this, 'шаб.', 'шаблон', 'Добавлен / изменён шаблон').addSumButton (
            $this, 'к удал.', 'к удалению', 'Страница предложена к удалению').addSumButton (
            $this, 'доп.', 'дополнение', 'Добавлены новые сведения').addSumButton (
            $this, 'иллюстрация', 'иллюстрация', 'Размещена иллюстрация').addSumButton (
            $this, 'обнов.', 'обновление данных', 'Обновлены устаревшие данные').addSumButton (
            $this, 'семант.', 'семантика', 'Добавлены аннотации'
        ).insertAfter ($this).before('<br />');
    });
});

/*
 * Викификатор
 */

// '''ВНИМАНИЕ! Внося изменения в код, не забывайте обновлять справку на странице [[Традиция:Викификатор]]''' 

var wmVersion = '2012-09-16'
var wmCantWork = 'Викификатор не может работать в Вашем браузере\n\nWikificator cannot work in your browser'
var wmTalkPage = 'Викификатор не обрабатывает страницы обсуждения целиком.\n\nВыделите Ваше сообщение — обработано будет только оно'

// Функция викифицирует переданный текст и возвращает викифицированный:
function wikifyText (s) {
    var txt='', hidden = [];

    var u = '\u00A0'; // -- unbreakable space.
    if (wgNamespaceNumber % 2 == 1 || wgNamespaceNumber == 4) { // -- это обсуждение.
        u = ' ';
        // Несколько дат, вероятно, чужие подписи::
        var sigs = s.match (/\d\d:\d\d, \d\d? \S{3,8} 20\d\d \(UTC\)/g);
            if (sigs && sigs.length > 1) {
                alert(wmTalkPage);
                return s;
             }
    }

    // Скрытие преформатированных тегов:
    s = hideTag (s, 'nowiki');
    s = hideTag (s, 'pre');
    s = hideTag (s, 'source');
    s = hideTag (s, 'code');
    s = hideTag (s, 'tt');

    s = hideTag (s, 'math'); // — внутристрочные формулы.
    s = hideTag (s, 'gallery'); // — галереи.
    s = hide (s, /{\{[\s\S]+?}}/g); // — шаблоны.
    s = hide (s, /^ .*/mg); // — преформатированный текст.
    s = hide (s, /(https?|ftp|news|nntp|telnet|irc|gopher):\/\/[^\s\[\]<>"]+ ?/gi); // — гиперссылки.
    s = hide (s, /^#(redirect|перенапр(авление)?)/i); // — перенаправления.

    s = s.replace (/ +(\n|\r)/g, '$1'); // -- пробелы в конце строки.
    s = '\n' + s + '\n';

    var replacements1 = [
        // Русификация пространств имён:
        [/(\[\[:?)(category|категория):( *)/ig, '$1Категория:']
      , [/(\[\[:?)(image|изображение|file):( *)/ig, '$1Файл:']
        // Оформление дат:
      , [/(\(|\s)(\[\[[12]?\d{3}\]\])[\u00A0 ]?(-{1,3}|–|—) ?(\[\[[12]?\d{3}\]\])(\W)/g, '$1$2—$4$5']
      , [/(\[\[[12]?\d{3}\]\]) ?(гг?\.)/g, '$1' + u + '$2']
      , [/(\(|\s)(\[\[[IVX]{1,5}\]\])[\u00A0 ]?(-{1,3}|–|—) ?(\[\[[IVX]{1,5}\]\])(\W)/g, '$1$2—$4$5']
      , [/(\[\[[IVX]{1,5}\]\]) ?(вв?\.)/g, '$1' + u + '$2']
      , [/\[\[(\d+)\]\][\u00A0 ]год/g, '[[$1' + u + 'год]]']
      , [/\[\[((\d+)(?: (?:год )?в [\wa-яёА-ЯЁ ]+\|\2)?)\]\][\u00A0 ](год[а-яё]*)/g, '[[$1' + u + '$3]]']
      , [/\[\[([XVI]+)\]\][\u00A0 ]век/g, '[[$1' + u + 'век]]']
      , [/\[\[(([XVI]+) век\|\2)\]\][\u00A0 ]век/g, '[[$2' + u + 'век]]']
      // Удаление недопустимых символов из викиссылок:
      , [/(\[\[[^|\[\]]*)[\u00AD\u200E\u200F]+([^\[\]]*\]\])/g, '$1$2'] // -- Soft Hyphen & DirMark.
      , [/\[\[ *([a-zA-Zа-яёА-ЯЁ\u00A0-\u00FF %!\"$&'()*,\-.\/0-9:;=?\\@\^_`’~]+) *\| *(\1)([a-zа-яё]*) *\]\]/g, '[[$2]]$3'] // -- ".
      , [/\[\[ *([a-zA-Zа-яёА-ЯЁ\u00A0-\u00FF %!\"$&'()*,\-.\/0-9:;=?\\@\^_`’~]+) *\| *([^|[\]]+) *\]\]([a-zа-яё]+)/g, '[[$1|$2$3]]'] // -- ".
     ];
     s = runReplacements (s, replacements1);
     s = hide (s, /\[\[[^\]|]+/g); // -- скрытие викиссылок.

    // Все теги в <> надо обработать здесь:
    var replacements2 = [
        // HTML -> викитекст:
        [/<<(\S.+\S)>>/g, '"$1"'] // -- угловые кавычки в обычные. Или лучше в «»?
      , [/(sup>|sub>|\s)-(\d)/g, '$1−$2'] // -- minus в индексах.
      , [/(<sup>2<\/sup>|&sup2;)/gi, '²'] // -- символы квадрата
      , [/(<sup>3<\/sup>|&sup3;)/gi, '³'] //    и куба.
      , [/<(b|strong)>(.*)<\/(b|strong)>/gi,"'''$2'''"] // -- вики-полужирный.
      , [/<(i|em)>(.*)<\/(i|em)>/gi,"''$2''"] // -- вики-курсив.
      , [/^<hr ?\/?>/gim, '----'] // -- вики-гор. разделитель.
      , [/<\/?(hr|br)( [^\/>]+?)? ?\/?>/gi, '<$1$2 />'] // оформление hr/br по стандарту XML.
      , [/(\n==\s*Примечания\s*==\n)<references *\/>/,'$1{{примечания}}']

        // .,… до сносок -- сдвиг сносок:
      , [/\s*,\s*((<ref[^<\/>]*?(>[^<]+?<\/ref|\/)>)+)/gi , '{{,}}$1']   // -- запятая до;
      , [/\s*(…)\s*((<ref[^<\/>]*?(>[^<]+?<\/ref|\/)>)+)/gi , '{{,|$1}}$2']   // -- др. знак до;
      , [/\s*\.\s*((<ref[^<\/>]*?(>[^<]+?<\/ref|\/)>)+)/gi, '{{тчк}}$1'] // -- точка до;

        // .,… после сносок -- перенос до и сдвиг сносок:
      , [/\s*((<ref[^<\/>]*?(>[^<]+?<\/ref|\/)>)+)\s*(?:,|\{\{(?:,|зпт)\}\})/gi , '{{,}}$1']   // -- запятая после;
      , [/\s*((?:<ref[^<\/>]*?(?:>[^<]+?<\/ref|\/)>)+)\s*([…])/gi , '{{,|$2}}$1']   // -- др. знак после;
      , [/\s*((<ref[^<\/>]*?(>[^<]+?<\/ref|\/)>)+)\s*(?:\.|\{\{(?:,\|\.|тчк)\}\})/gi, '{{тчк}}$1'] // -- точка после;

        // !? после сносок -- перенос до:
      , [/\s*((?:\<ref[^<\/>]*?(?:\>[^<]+?<\/ref|\/)>)+)([!?;:“])/gi , '$2$1']   // -- !? после;

        // !?;:“» до сносок -- удаление лишних пробелов:
      , [/\s*([!?;:“»])\s+((<ref[^<\/>]*?(>[^<]+?<\/ref|\/)>)+)/gi , '$1$2']   // -- др. знак до;

    ];
    s = runReplacements (s, replacements2);
    s = hide(s, /<[a-z][^>]*?>/gi);

    s = hide(s, /^({\||\|-).*/mg); // // -- таблицы и ряды.
    s = hide(s, /(^\||^!|!!|\|\|) *[a-z]+=[^|]+\|(?!\|)/mgi); // -- стили ячеек.
    s = hide(s, /\| +/g) // -- форматированные ячейки.
    s = hide(s, /IS[BS]N[\s\d\-]{9,18}/g) // -- ISBN/ISSN.

    s = s.replace (/[ \t]+/g, ' '); // -- двойные пробелы.

    var replacements3 = [
        // Заголовки:
        [/^(=+)[ \t\f\v]*(.*?)[ \t\f\v]*=+$/gm, '$1 $2 $1'] // -- окружить пробелами.
      , [/([^\r\n])(\r?\n==.*==\r?\n)/g, '$1\n$2'] // -- пустую строку впереди.
      , [/^== см(\.?|отрите) ?так\s*же ==$/gmi, '== См. также =='] // -- «См. также».
      , [/^== сноски ==$/gmi, '== Примечания ==']
      , [/^== (.*[^.])[.:] ==$/gm, '== $1 =='] // -- точка или двоеточие в конце.

      , [/«|»|“|”|„/g, '"'] // -- временное скрытие нормальных кавычек. Нужно ли?

        // Тире и дефисы:
      , [/–/g, '-']                    // -- &ndash; → -
      , [/&(#151|[nm]dash);/g, '—']     // -- мнемоника тире → —
      , [/(&nbsp;|\s)-{1,3} /g, '$1— '] // -- отбитые - → —
      , [/(\d)-{1,2}(\d)/g, '$1‒$2']    // -- -/-- между цифрами → ‒ (&#2012;)
      , [/([IVXLCDM]+)-{1,2}([IVXLCDM]+)/g, '$1‒$2']    // -- -/-- между римскими цифрами → ‒ (&#2012;)
      , [/(\s)-(\d)/g, '$1−$2']         // -- отбитый - перед цифрой → −

        // Мнемоники HTML -> символы:
      , [/&#x([0-9a-f]{1,4});/gi, function(n,a){return String.fromCharCode(eval('0x'+a.substr(-4)))}]  //&#x301;
      , [/&copy;/gi,'©']
      , [/&reg;/gi,'®']
      , [/&sect;/gi,'§']
      , [/&euro;/gi,'€']
      , [/&yen;/gi,'¥']
      , [/&pound;/gi,'£']
      , [/&deg;/g,'°']
      , [/\(tm\)|\(тм\)|&trade;/gi,'™']
      , [/\.\.\.|&hellip;/g,'…']
      , [/\+-|&plusmn;/g,'±']
      , [/~=/g,'≈']
      , [/\^2(\D)/g,'²$1']
      , [/\^3(\D)/g,'³$1']
      , [/&((la|ra|bd|ld)quo|quot);/g,'"']
      , [/([\wа-яА-ЯёЁ])'([\wа-яА-ЯёЁ])/g,'$1’$2'] //'
      , [/№№/g,'№']

        // Годы и века
      , [/(\(|\s)([12]?\d{3})[\u00A0 ]?(-{1,3}|—) ?([12]?\d{3})(?![\w-°])/g, '$1$2—$4']
      , [/([12]?\d{3}) ?(гг?\.)/g, '$1' + u + '$2']
      , [/(\(|\s)([IVX]{1,5})[\u00A0 ]?(-{1,3}|—) ?([IVX]{1,5})(?![\w-°])/g, '$1$2—$4']
      , [/([IVX]{1,5}) ?(вв?\.)/g, '$1' + u + '$2']

        // Сокращения:
      , [/(Т|т)\.\s?е\./g, '$1о есть']
      , [/(Т|т)\.\s?к\./g, '$1ак как']
      , [/(В|в)\sт\. ?ч\./g, '$1 том числе']
      , [/и\sт\.\s?д\./g, 'и' + u + 'т\.' + u + 'д\.']
      , [/и\sт\.\s?п\./g, 'и' + u + 'т\.' + u + 'п\.']
      , [/(Т|т)\.\s?н\./g, '$1\.' + u + 'н\.']
      , [/н\.\s?э\./g, 'н\.' + u + 'э\.']
      , [/(Д|д)(о|\.)\sн\.\s?э\./g, '$1о' + u + 'н\.' + u + 'э\.']
      , [/(\d)[\u00A0 ]?(тыс\.|млн|млрд|трлн|(?:м|с|д|к)?м|[км]г)\.?(?=[,;.]| "?[а-яё-])/g, '$1' + u + '$2']
      , [/(\d)[\u00A0 ](тыс)([^\.А-Яа-яЁё])/g, '$1' + u + '$2.$3']
      , [/ISBN:\s?(?=[\d\-]{8,17})/, 'ISBN ']

        // Пробелы:
      , [/^([#*:]+)[ \t\f\v]*([^ \t\f\v*#:;])/gm, '$1 $2'] // -- в списках.
      , [/(\S) (-{1,3}|—) (\S)/g, '$1' + u + '— $3']
      , [/([А-Я]\.) ?([А-Я]\.) ?([А-Я][а-я])/g, '$1' + u + '$2' + u + '$3']
      , [/([А-Я]\.)([А-Я]\.)/g, '$1 $2']
      , [/([а-я]\.)([А-ЯA-Z])/g, '$1 $2'] // -- после точки.
      , [/([)"а-яa-z\]])\s*,([\[("а-яa-z])/g, '$1, $2'] // -- после точки.
      , [/([)"а-яa-z\]])\s([,;])\s([\[("а-яa-z])/g, '$1$2 $3']
      , [/([^%\/\w]\d+?(?:[.,]\d+?)?) ?([%‰])(?!-[А-Яа-яЁё])/g, '$1' + u + '$2'] // -- проценты.
      , [/(\d) ([%‰])(?=-[А-Яа-яЁё])/g, '$1$2'] // -- 5%-й
      , [/([№§])(\s*)(\d)/g, '$1'+u+'$3']
      , [/\( +/g, '(']
      , [/ +\)/g, ')'] // -- убрать пробелы у внутренних сторон скобок.

        // Температура:
      , [/([\s\d=≈≠≤≥<>("'|])([+±−-]?\d+?(?:[.,]\d+?)?)(([ °^*]| [°^*])[CС])(?=[\s"').,;!?|])/gm, '$1$2' + u + '°C']
      , [/([\s\d=≈≠≤≥<>("'|])([+±−-]?\d+?(?:[.,]\d+?)?)(([ °^*]| [°^*])F)(?=[\s"').,;|!?])/gm, '$1$2' + u + '°F']

        // Десятичная точка → запятая:
      , [/(\s\d+)\.(\d+[\u00A0 ]*[%‰°])/gi, '$1,$2']

        // Союзы, предлоги, частицы, единицы измерения:
      , [/\b(а|в|во|да|до|за|и|к|ко|на|о|об|обо|с|со|у)\s/gi, '$1 '] // -- проклитики
      , [/\s(б|бы|же|ли|ль)\b/gi, ' $1'] // -- проклитики
    ];
    s = runReplacements (s, replacements3);
    
    // Интерфейс для дополнений к викификатору:
    s = runReplacements (s, window.wfPlugins);

    // Восстановление кавычек: "" → «»:
    for (var i=1; i<=2; i++) {
        s = s.replace (/([\s\u00A0·\x02!|#'"\/(;+-])"([^"]*)([^\s"(|])"([^a-zа-яё])/ig, '$1«$2$3»$4'); //"
    }
    while (/«[^»]*«/.test(s)) {
        s = s.replace (/«([^»]*)«([^»]*)»/g, '«$1„$2“');
    }

    s = s.substr (1, s.length - 2); // -- удаление начального и конечного пробелов.
    if ('0'.replace('0', '$$') == '$') { // -- $ в регэксах, как всегда, IE особенный.
        for (var i = 0; i < hidden.length; i++) {
            hidden [i] = hidden [i].replace (/\$/g, '$$$$');
        }
    }
    // Раскрытие скрытого в hide ():
    while (hidden.length > 0) {
        s = s.replace ('\x01' + hidden.length + '\x02', hidden.pop ());
    }
    return s;
    // Вспомогательные функции:
    // Выполнение массива замен:
    function runReplacements (s, pairs) {
        if (pairs && pairs.length) {
            jQuery.each (pairs, function () { s = s.replace (this [0], this [1]);});
        }
        return s;
    }
    // Скрытие фрагментов путём окружения \x01 и \x02:
    function hide (txt, re) {
        return txt.replace (re, function (s) {return '\x01' + hidden.push (s) + '\x02'});
    }
    function hideTag (txt, tag) {
        return hide (txt, RegExp ('<' + tag + '( [^>]+)?>[\\s\\S]+?<\\/' + tag + '>', 'gi'));
    }
}

// Создать шаблон, основанный на [[Шаблон:Карточка]] по синтаксису вызова:
function makeTemplate (/* String */ s) {
    return makeTemplateOrCard (true, s);
}

// Создать форму, основанную на [[Шаблон:Карточка]] по синтаксису вызова:
function makeForm (/* String */ s) {
    return makeTemplateOrCard (false, s);
}

/* Функция, генерирующая:
 *     код шаблона, основанного на шаблоне Карточка или
 *     код формы Semantic Forms с тем же оформлением
 * на основании синтаксиса вызова шаблона в виде
 * {{<Имя шаблона>
 *     | <параметр1> = пояснение1
 *     | <параметр2> = пояснение2
 * ...
 *     | <параметрn> = пояснениеn
 * }}
 * Спецификация синтаксиса берётся из выделения в окне редактирования викитекста;
 * если ничего не выделено, используется всё содержимое окна.
 *
 * Для генерации кода шаблона или формы нужно нажать кнопку со всплывающей подсказкой «Создать карточку».
 *
 * Автор: Александр Машин, 2 августа 2009 (создание шаблона) и 11 октября 2009 (создание формы) -- в виде приспособления.
 * 7 сентября 2012 -- интеграция в инструменты редактирования
 * 
 */
 
// Создание кода шаблона-карточки или формы-карточки на основе переданной спецификации:
function makeTemplateOrCard (/* Bool */is_template, /* String */specs) {
    // Ничего не выбрано:
	if (undefined == typeof specs || !specs || '' == specs) return specs;
    // Это не вызов шаблона с параметрами:
	var params = specs.split ('|');
    if (params == null) return specs;
	
    var t_body = '';
    // Проход по параметрам.
    // Номера параметров не подряд, чтобы облегчить вставку:
    var incr = 99 / params.length; // -- заменить на var incr = 10; после перехода [[Шаблон:Карточка]] на циклы.
    incr = incr < 1 ? 1 : incr;
    for (var i = 0; i < params.length; i++) {
        // Обрезка пробелов и того, что после =:
        var param = $.trim (params [i].split ('=') [0]);
        param = param.replace (/}}.*/, ''); // -- удаление закрывающих }}.
        param = param.substr (0, 1).toLocaleLowerCase () + param.substr (1); // -- регистр параметра.
        if (param.indexOf ('{{') > -1) {
            // Это название шаблона:
            var template_title = param.replace (/^.*\{\{/, '');
            continue;
        }
        if (is_template && (param == 'название'    || param == 'name'
                         || param == 'тип'         || param == 'type'
                         || param == 'изображение' || param == 'image'
                         || param == 'ширина'      || param == 'width'
                         || param == 'подпись'     || param == 'signature')) {
            // Эти параметры идут в заголовке шаблона:
            continue;
        }
        if (!is_template && (param == 'название' || param == 'name'
                          || param == 'ширина'   || param == 'width'
                          || param == 'подпись'  || param == 'signature')) {
            // Эти параметры идут в заголовке формы:
            continue;
        }
        var param_no = Math.floor ((i + 1) * incr).toString ();
        var label = param.substr (0, 1).toLocaleUpperCase () + param.substr (1).toLocaleLowerCase ();
        if (is_template) {
            // Это шаблон:
            var type = param.toLocaleLowerCase ().indexOf ('дата') > -1
                    || param.toLocaleLowerCase ().indexOf ('год')  > -1
                    || param.toLocaleLowerCase ().indexOf ('день') > -1
                     ? 'дата'
                     : 'страница';
            var prop = type == 'дата' ? label.replace (/(дата|год|день)\s*/i, '') : label;
            param    = '{{{' + param + '|{{{' + label + '|}}}}}}';
        } else {
            // Это форма:
            param    = '{{{field|' + param + '|width=23}}}';
        }
        t_body = t_body + '\n'
               + '\n | заголовок' + param_no + ' = ' + ''
               + '\n | метка' + param_no + ' = ' + label 
               + '   | текст' + param_no + ' = ' + param;
        if (is_template) {
            // Это нужно только для шаблонов:
            t_body = t_body
                   + '\n | свойство' + param_no + ' = ' + prop
                   + ' | обратно' + param_no + ' = ' + ''
                   + ' | тип' + param_no + ' = ' + type
                   + ( type != 'дата' ?('\n | категория' + param_no + ' = ' + ''
                   + ' | постфикс' + param_no + ' = ' + '')
                   :('\n | категория_дня' + param_no + ' = ' + ''
                   + ' | постфикс_дня' + param_no + ' = ' + ''
                   + ' | категория_года' + param_no + ' = ' + ''
                   + ' | постфикс_года' + param_no + ' = ' + ''));
        }
    }
    t_foot     = '\n\n | внизу ='
               + ' | стиль_внизу = '
               + ' | форма = ' + template_title
               + '}}\n';
 
    if (is_template) {
        // Это шаблон:
        var preface    = '';
        var title      = '{{{название|{{{Название|{{{name|{{{Name|{{PAGENAME}}}}}}}}}}}}}}';
        var subtitle   = '{{{тип|{{{Тип|{{{type|{{{Type|' + template_title + '}}}}}}}}}}}}';
        var image      = '{{{изображение|{{{Изображение|{{{image|{{{Image|}}}}}}}}}}}}';
        var width      = '{{{ширина|{{{Ширина|{{{width|{{{Width|}}}}}}}}}}}}';
        var signature  = '{{{подпись|{{{Подпись|{{{signature|{{{Signature|}}}}}}}}}}}}';
        var head_props = '';
        var body_class = '';
    } else {
        // это форма:
        var preface    = '<noinclude>{{#forminput:' + template_title + '|120|(' + template_title + ' — новая)|Создать}}\n'
                       + '</noinclude><includeonly>\n'
                       + '{{{info|page name=<' + template_title + '[название]>|add title=Создание статьи о ' + template_title + '|edit title=Правка статьи о·' + template_title + '}}}\n'
                       + '<!-- <div id="wikiPreview" style="display none; padding-bottom 25px; margin-bottom 25px; border-bottom 1px solid #AAAAAA;"></div> -->\n'
                       + '{{{for template|' + template_title + '}}}';
        var title      = '{{{field|название|width=52}}}';
        var subtitle   = '';
        var image      = '';
        var width      = '';
        var signature  = '';
        var head_props = '-';
        var body_class = 'formtable';
    }
    var t_head = preface
               + '\n{{Карточка'
               + '\n |имя = ' + template_title
               + '\n |стиль_тела = border-color: black'
               + '\n |класс_тела = ' + body_class
               + '\n |шапка = '
               + '   |стиль_шапки = '
               + '   |свойство_шапки = ' + head_props
               + '   |класс_шапки = '
               + '\n |название = ' + title
               + '   |стиль_названия = black'
               + '\n |вверху = '
               + '   |стиль_вверху = '
               + '   |свойство_вверху = ' + head_props
               + '\n |вверху2 = ' + subtitle
               + '   |стиль_вверху2 = '
               + '   |свойство_вверху2 = ' + head_props
               + '\n |вверху3 = '
               + '   |стиль_вверху3 = ' 
               + '   |свойство_вверху3 = ' + head_props
               + '\n |значок = '
               + '\n |изображение = ' + image
               + '\n |стиль_заголовков = '
               + '   |стиль_меток = '
               + '   |стиль_текста = ';
    if (is_template) {
        // шаблон:
        t_foot = t_foot
               + '<noinclude>\n<pre>\n' + specs + '\n</pre>\n[[Категория:Традиция:Шаблоны Summary]]</noinclude>';
    } else {
        // форма:
        t_foot = t_foot
               + '{{{end template}}}\n'
               + '{{{standard input|free text|rows=25|cols=55}}}\n\n'
               + '{{{standard input|summary}}}\n\n'
               + '{{{standard input|minor edit}}} {{{standard input|watch}}}\n\n'
               + '{{{standard input|save}}} {{{standard input|preview}}} {{{standard input|changes}}} {{{standard input|cancel}}}\n\n'
               + '</includeonly><noinclude>[[Категория:Традиция:Формы]]</noinclude>';
    }
    return t_head + t_body + t_foot;
}