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="→" />';
var collapser = '<img src="/images/d/d4/Etool_collapser.png" width="5" height="16" alt="↓" />';
// Для отложенного разбора:
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="→" />',
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: ' ', 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"> a </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="Ξ">', title: 'Содержание здесь'}, br
, {wrapper: '+\n{{TOCRight}}\n', button: '<img src="/images/f/fd/Etool_toc_right.png" height="16" width="16" alt="Ξ→">', title: 'Содержание справа'}, br
, {wrapper: '+\n__NOTOC__\n', button: '<img src="/images/0/00/Etool_no_toc.png" height="16" width="16" alt="Ξ→">', title: 'Подавить содержание'}
], [
{title: 'Абзац', nl: true}
, {wrapper: '\n\n+', button: '<img src="/images/e/e9/Etool_red_line.png" width="16" height="16" alt="↵" />', 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="→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="<>" />', title: '<code>Исходный код</code>'}
, {wrapper: '<pre>+</pre>\n', button: '<img src="/images/2/2e/Etool_pre.png" width="16" height="16" alt="$>_" />', title: '<code>Преформатированный текст</code>'}, br
, {wrapper: '<nowiki>+</nowiki>', button: '<img src="/images/c/cb/Etool_nowiki.png" width="16" height="16" alt="</>" />', 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="↵" />', 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="→www">', title: 'Внешняя ссылка', filler: '(url)'}
, {wrapper: '<span class="plainlinks">[+ (описание ссылки)]</span>', button: '<img src="/images/e/e6/Etool_www_page.png" height="16" width="16" alt="→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="→[P]">', title: 'Статья', filler: '(url)'}
, {wrapper: '{{книга|автор=|часть=|заглавие=|оригинал=|язык_оригинала=|язык_оригинала_сокращённо=|переводчик=|ссылка=+|издание=|место={{М.}}|издательство=|год=[[]]|страницы=|isbn=}}', button: '<img src="/images/c/cd/Etool_book_link.png" height="16" width="16" alt="→[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="→[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="→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→">', 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="←S">', title: 'osm'}
/*, {wrapper: '{{wl|тайлы|local}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'сервер «Традиции»'}*/
, {wrapper: '{{wl|тайлы|osmarender}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'osmarender'}
, {wrapper: '{{wl|тайлы|cycle}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'cycle'}
, {wrapper: '{{wl|тайлы|mapquest}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'mapquest'}
, {wrapper: '{{wl|тайлы|openaerial}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'openaerial'}
, {wrapper: '{{wl|тайлы|osmosnimki}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'osmosnimki'}
, {wrapper: '{{wl|тайлы|kosmosnimki}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←S">', title: 'kosmosnimki'}
, {wrapper: '{{wl|тайлы|openmapsurfer}}', button: '<img src="/images/b/b8/Etool_server_database.png" height="16" width="16" alt="←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="↵">', 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="→">', title: 'Основная статья'},
, {wrapper: '{{обзор|+}}', button: '<img src="/images/a/a9/Icons-mini-icon_2brief.png" height="16" width="16" alt="↑">', 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="<>">', title: 'Отображаемое название'}
, {wrapper: '\n{{DEFAULTSORT:+}}', button: '<img src="/images/a/a2/Etool_page_key.png" height="16" width="16" alt="↑↓">', 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="<!>">', title: 'Заготовка'}
, {wrapper: '{{черновик}}', button: '<img src="/images/7/73/Etool_construction.png" height="16" width="16" alt="<!>">', 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="<!>">', 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: '<includeonly>'}
, {wrapper: '<noinclude>+</noinclude>', button: '<noinclude>'}, 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="Σ" />', title: 'Знаки', nl: true, leader: true}
, '<<Математические:>> − × ÷ ⋅ ° +² +³ ∗ ∘ ± ∓ ≤ ≥ ≠ ≡ ≅ ≜ ≝ ≐ ≃ ≈ ⊕ ⊗ ∞ ≪ ≫ ∝ √ ∤ ≀ ◅ ▻ ⋉ ⋊ ⋈ ∴ ∵ ∙ ∷ ⋮ ⋯ ⋰ ⋱ br '
+ '¬ ∧ ∨ ⊻ ∀ ∃ ∄ ∅ ∈ ∉ ∋ ⊆ ⊈ ⊊ ⊂ ⊄ ⊇ ⊉ ⊋ ⊃ ⊅ ∪ ∩ ∑ ∏ ∐ ′ ∫ ∬ ∭ ∮ ∇ ∂ ∆ ∅ ℂ ℍ ℕ ℙ ℚ ℝ ℤ ℵ br '
+ '⌊ ⌋ ⌈ ⌉ ⊤ ⊥ ⊢ ⊣ ⊧ □ ∠ ⟨ ⟩ − 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, '<').replace (/>/g, '>').replace (/"/g, '"').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>|²)/gi, '²'] // -- символы квадрата
, [/(<sup>3<\/sup>|³)/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, '-'] // -- – → -
, [/&(#151|[nm]dash);/g, '—'] // -- мнемоника тире → —
, [/( |\s)-{1,3} /g, '$1— '] // -- отбитые - → —
, [/(\d)-{1,2}(\d)/g, '$1‒$2'] // -- -/-- между цифрами → ‒ (ߜ)
, [/([IVXLCDM]+)-{1,2}([IVXLCDM]+)/g, '$1‒$2'] // -- -/-- между римскими цифрами → ‒ (ߜ)
, [/(\s)-(\d)/g, '$1−$2'] // -- отбитый - перед цифрой → −
// Мнемоники HTML -> символы:
, [/&#x([0-9a-f]{1,4});/gi, function(n,a){return String.fromCharCode(eval('0x'+a.substr(-4)))}] //́
, [/©/gi,'©']
, [/®/gi,'®']
, [/§/gi,'§']
, [/€/gi,'€']
, [/¥/gi,'¥']
, [/£/gi,'£']
, [/°/g,'°']
, [/\(tm\)|\(тм\)|™/gi,'™']
, [/\.\.\.|…/g,'…']
, [/\+-|±/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;
}