MediaWiki:Common.js — различия между версиями
Arhssaarh (обсуждение | вклад) |
|||
| Строка 139: | Строка 139: | ||
+encodeURIComponent(votingTrigger.innerHTML.replace(/\D+/g, '.'))) | +encodeURIComponent(votingTrigger.innerHTML.replace(/\D+/g, '.'))) | ||
} | } | ||
| + | |||
| + | function uploadPage(){ | ||
| + | if (window.wgUploadAutoFill){ | ||
| + | upForm = document.getElementById('mw-upload-form') | ||
| + | upForm.onsubmit = checkUpForm | ||
| + | } | ||
| + | var desc = document.getElementById('wpUploadDescription') | ||
| + | var tmpl = document.getElementById('imageinfo') | ||
| + | if (wgUploadAutoFill && tmpl && desc && !desc.value) desc.value = tmpl.innerHTML | ||
| + | appendCSS('a.insertlink { text-decoration: none; }') | ||
| + | var span = document.getElementById('insertlink-free') | ||
| + | if (!!span) { | ||
| + | var a = document.createElement('a') | ||
| + | a.href = 'javascript:addInfoTemplate("rationale", "imageinfo", 8)' | ||
| + | a.class = 'insertlink' | ||
| + | span.parentNode.insertBefore(a, span) | ||
| + | a.appendChild(span) | ||
| + | } | ||
| + | var span = document.getElementById('insertlink-unfree') | ||
| + | if (!!span) { | ||
| + | var a = document.createElement('a') | ||
| + | a.href = 'javascript:addInfoTemplate("imageinfo", "rationale", 16)' | ||
| + | a.class = 'insertlink' | ||
| + | span.parentNode.insertBefore(a, span) | ||
| + | a.appendChild(span) | ||
| + | } | ||
| + | var c = document.getElementById('commons-link') | ||
| + | var c_a = c.lastChild | ||
| + | c.innerHTML = '<input class="commons-btn" type="button" onclick="window.location.href=\''+c_a.href+'\'" value="'+c_a.text+'"/>' | ||
| + | } | ||
| + | function addInfoTemplate(oldId, newId, rows){ | ||
| + | var desc = document.getElementById('wpUploadDescription') | ||
| + | var oldTmpl = document.getElementById(oldId) | ||
| + | var tmpl = document.getElementById(newId) | ||
| + | if (desc && oldTmpl && desc.value == oldTmpl.innerHTML){ | ||
| + | desc.value = tmpl.innerHTML | ||
| + | desc.rows = rows | ||
| + | } | ||
| + | else if (desc && tmpl && desc.value.indexOf(tmpl.innerHTML.substring(0,8)) == -1){ | ||
| + | desc.value += '\n' + tmpl.innerHTML | ||
| + | desc.rows = 20 | ||
| + | } | ||
| + | licList = document.getElementsByTagName('option', document.getElementById('wpLicense')) | ||
| + | if (newId == 'rationale'){ | ||
| + | licList[licList.length-1].selected='selected' | ||
| + | } | ||
| + | else { | ||
| + | licList[0].selected='selected' | ||
| + | } | ||
| + | } | ||
| + | function checkUpForm(){ | ||
| + | upForm = document.getElementById('mw-upload-form') | ||
| + | var desc = document.getElementById('wpUploadDescription') | ||
| + | var lcns = document.getElementById('wpLicense') | ||
| + | var wrn = document.createElement('div') | ||
| + | wrn.innerHTML = '' | ||
| + | if (lcns.value != '' && /\{\{(fair ?use ?in|ОДИ|Обоснование добросовестного использования)/i.exec(desc.value)) | ||
| + | wrn.innerHTML += '<li>Вы используете устаревшую схему описания несвободных файлов. Пожалуйста, прочтите инструкцию выше.</li>' | ||
| + | if (lcns.value == '' && /^[^\{\}]*(\{\{(Изображение|Несвободный файл)[^\{\}]+\}\}[^\{\}]*)*$/i.exec(desc.value)) | ||
| + | wrn.innerHTML += '<li>Не указана лицензия. Выберите лицензию в выпадающем списке выше.</li>' | ||
| + | if (lcns.value != '' && lcns.value != 'subst:ET' && /\{\{Несвободный файл/i.exec(desc.value)) | ||
| + | wrn.innerHTML += '<li>Для несвободного файла выбрана лицензия в выпадающем списке. Возможно, вы где-то ошиблись.</li>' | ||
| + | if (lcns.value == '' && /\{\{Изображение\s*((\|\s*)+[\s\wа-яё]+=\s*)*(\|\s*)*\}\}/i.exec(desc.value)) | ||
| + | wrn.innerHTML += '<li>Не заполнен шаблон {'+'{Изображение}}.</li>' | ||
| + | if (lcns.value == '' && /\{\{Несвободный файл\s*((\|\s*)+([\wа-яё]+\s*)+=\s*)*(\|\s*)*\}\}/i.exec(desc.value)) | ||
| + | wrn.innerHTML += '<li>Не заполнен шаблон {'+'{Несвободный файл}}.</li>' | ||
| + | if (lcns.value == '' && /\{\{Несвободный файл\/ОДИ\s*((\|\s*)+([\wа-яё]+\s*)+=\s*)*(\|\s*)*\}\}/i.exec(desc.value)) | ||
| + | wrn.innerHTML += '<li>Не заполнен шаблон {'+'{Несвободный файл/ОДИ}}.</li>' | ||
| + | if (/\{\{(Несвободный файл|Изображение)[^\{\}]*Источник\s*=\s*(из|с|http:\/\/(www\.)?)?\s*(интернет|internet|гугл|google|яндекс|yandex|яху|yahoo|рамблер|rambler)[^\{\}]*\}\}/i.test(desc.value)) | ||
| + | wrn.innerHTML += '<li>«Интернет» или поисковая система не являются источником, подтверждающим лицензионный статус изображения. Укажите более конкретный источник.</li>' | ||
| + | if (wrn.innerHTML != ''){ | ||
| + | wrn.innerHTML = '<p style="text-align:center; font-weight:bold;">Автоматическая проверка выявила следующие ошибки:</p><ul style="font-weight:bold">' + wrn.innerHTML | ||
| + | wrn.innerHTML += '</ul><p style="padding:0.2em 0.8em">При повторном нажатии на кнопку «Загрузить файл» данное предупреждение будет проигнорировано. Помните, что файлы без лицензии или с некорректной лицензией будут удалены. Если у вас возникли проблемы или вопросы, обращайтесь на <a href="http://ru.wikipedia.org/wiki/%D0%92%D0%B8%D0%BA%D0%B8%D0%BF%D0%B5%D0%B4%D0%B8%D1%8F:%D0%A4%D0%BE%D1%80%D1%83%D0%BC/%D0%90%D0%B2%D1%82%D0%BE%D1%80%D1%81%D0%BA%D0%BE%D0%B5_%D0%BF%D1%80%D0%B0%D0%B2%D0%BE">форум по авторскому праву</a>.</p>' | ||
| + | var oldWrn = document.getElementById('jsUploadWarnings') | ||
| + | if (oldWrn) { | ||
| + | return true | ||
| + | } | ||
| + | else { | ||
| + | wrn.style.border = '1px solid red' | ||
| + | wrn.style.background = '#ffe4e1' | ||
| + | wrn.id = 'jsUploadWarnings' | ||
| + | upNode = document.getElementById('mw-htmlform-options').parentNode | ||
| + | upNode.parentNode.insertBefore(wrn, upNode) | ||
| + | } | ||
| + | return false | ||
| + | } | ||
| + | else { | ||
| + | return true | ||
| + | } | ||
| + | } | ||
| + | |||
| + | |||
| + | /* Hide quick insert */ | ||
| + | function uploadHideInsert(){ | ||
| + | qIns = document.getElementById('editpage-specialchars') | ||
| + | qInsCover = document.createElement('div') | ||
| + | qInsCover.setAttribute('style', qIns.style.cssText) | ||
| + | if (typeof(qInsCover.style.setAttribute) == 'function') qInsCover.style.setAttribute('style', qIns.style.cssText) // IE | ||
| + | qInsCover.innerHTML = '<small><span style="border-bottom:1px dotted gray; cursor:help" title="Позволяет быстро вставлять символы разметки в поле описания">Быстрая вставка</span> (<a href="javascript:uploadExpandInsert()">раскрыть блок</a>)</small>' | ||
| + | qIns.style.display = 'none' | ||
| + | qIns.parentNode.appendChild(qInsCover) | ||
| + | } | ||
| + | |||
| + | function uploadExpandInsert(){ | ||
| + | qInsCover.style.display = 'none' | ||
| + | qIns.style.display = 'block' | ||
| + | } | ||
| + | |||
| + | |||
| + | /* Ajax Preview */ | ||
| + | function uploadPreviewRun(){ | ||
| + | wpUploadPreview.innerHTML = '' | ||
| + | injectSpinner(wpUploadPreview,'preview') | ||
| + | var aj = sajax_init_object() | ||
| + | aj.onreadystatechange = function(){ | ||
| + | if (aj.readyState!=4 || aj.status!=200) return | ||
| + | removeSpinner('preview') | ||
| + | wpUploadPreview.innerHTML = eval('('+aj.responseText+')')['parse']['text']['*'] | ||
| + | wpUploadPreview.scrollIntoView() | ||
| + | } | ||
| + | aj.open('GET', '/w/api.php?action=parse&prop=text&pst&format=json&text=' | ||
| + | + encodeURIComponent(wpUploadText.value), true) | ||
| + | aj.send('') | ||
| + | } | ||
| + | |||
| + | function uploadPreviewInit(){ | ||
| + | wpUploadText = document.getElementById('wpUploadDescription') | ||
| + | if (!wpUploadText) return | ||
| + | var bt = create('input','wpDestFile'); bt.type='button' | ||
| + | bt.style.cssFloat = bt.style.styleFloat = 'right' | ||
| + | bt.value = 'Предпросмотр'; bt.onclick = uploadPreviewRun | ||
| + | wpUploadPreview = create('div','wpLicense') | ||
| + | function create(type, attachTo){ | ||
| + | var el = document.createElement(type) | ||
| + | attachTo = document.getElementById(attachTo) || wpUploadText | ||
| + | attachTo.parentNode.appendChild(el) | ||
| + | return el | ||
| + | } | ||
| + | } | ||
| + | |||
| + | |||
| + | addOnloadHook(uploadPage) | ||
| + | addOnloadHook(uploadHideInsert) | ||
| + | addOnloadHook(uploadPreviewInit) | ||
Версия 10:49, 4 июня 2011
//import scripts
//importScript('MediaWiki:Editpage.js');
importScriptURI('http://novopedia.net/w/index.php?title=MediaWiki:Editpage.js&action=raw&ctype=text/javascript');
addLoadEvent = addOnloadHook
importScript_ = importScript
// for backwards compatibility
var addLoadEvent = addOnloadHook;
var import_script = importScript;
var import_style = importStylesheet;
var importScript_ = importScript;
//
function addLoadEvent(func)
{
if (window.addEventListener)
window.addEventListener("load", func, false);
else if (window.attachEvent)
window.attachEvent("onload", func);
}
//Edit zero section
if (wgAction == 'view' && wgNamespaceNumber >=0)
addOnloadHook(function(){
var h2s = document.getElementsByTagName('H2');
var h2 = h2s[0];
if (!h2) return;
if (h2.parentNode.id == 'toctitle') h2 = h2s[1];
if (!h2) return;
var span = h2.firstChild;
if (!span || span.className != 'editsection') return;
var zero = span.cloneNode(true);
if (document.getElementById('featured-star')) zero.style.marginRight = '25px'
var parent = document.getElementsByTagName('H1')[0];
parent.insertBefore(zero, parent.firstChild);
var a = zero.getElementsByTagName('A')[0];
a.title = a.title.replace(/:.*$/,' после заголовка');
a.setAttribute('href', a.href.replace(/§ion=1/,'§ion=0'));
})
// hasClass()
var hasClass = (function () {
var reCache = {};
return function (element, className) {
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);
};
})();
//Collapsiblе: [[ВП:СБ]]
var NavigationBarShowDefault = 2
var NavigationBarHide = '[скрыть]'
var NavigationBarShow = '[показать]'
var hasClass = (function (){
var reCache = {}
return function (element, className){
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className)
}
})()
function collapsibleTables(){
var Table, HRow, HCell, btn, a, tblIdx = 0, colTables = []
var allTables = document.getElementsByTagName('table')
for (var i=0; Table = allTables[i]; i++){
if (!hasClass(Table, 'collapsible')) continue
if (!(HRow=Table.rows[0])) continue
if (!(HCell=HRow.getElementsByTagName('th')[0])) continue
Table.id = 'collapsibleTable' + tblIdx
btn = document.createElement('span')
btn.style.cssText = 'float:right; font-weight:normal; font-size:smaller'
a = document.createElement('a')
a.id = 'collapseButton' + tblIdx
a.href = 'javascript:collapseTable(' + tblIdx + ');'
a.style.color = HCell.style.color
a.appendChild(document.createTextNode(NavigationBarHide))
btn.appendChild(a)
HCell.insertBefore(btn, HCell.childNodes[0])
colTables[tblIdx++] = Table
}
for (var i=0; i < tblIdx; i++)
if ((tblIdx > NavigationBarShowDefault && hasClass(colTables[i], 'autocollapse')) || hasClass(colTables[i], 'collapsed'))
collapseTable(i)
}
function collapseTable (idx){
var Table = document.getElementById('collapsibleTable' + idx)
var btn = document.getElementById('collapseButton' + idx)
if (!Table || !btn) return false
var Rows = Table.rows
var isShown = (btn.firstChild.data == NavigationBarHide)
btn.firstChild.data = isShown ? NavigationBarShow : NavigationBarHide
var disp = isShown ? 'none' : Rows[0].style.display
for (var i=1; i < Rows.length; i++)
Rows[i].style.display = disp
}
function collapsibleDivs(){
var navIdx = 0, colNavs = [], i, NavFrame
var divs = document.getElementById('content').getElementsByTagName('div')
for (i=0; NavFrame = divs[i]; i++) {
if (!hasClass(NavFrame, 'NavFrame')) continue
NavFrame.id = 'NavFrame' + navIdx
var a = document.createElement('a')
a.className = 'NavToggle'
a.id = 'NavToggle' + navIdx
a.href = 'javascript:collapseDiv(' + navIdx + ');'
a.appendChild(document.createTextNode(NavigationBarHide))
for (var j=0; j < NavFrame.childNodes.length; j++)
if (hasClass(NavFrame.childNodes[j], 'NavHead'))
NavFrame.childNodes[j].appendChild(a)
colNavs[navIdx++] = NavFrame
}
for (i=0; i < navIdx; i++)
if ((navIdx > NavigationBarShowDefault && !hasClass(colNavs[i], 'expanded')) || hasClass(colNavs[i], 'collapsed'))
collapseDiv(i)
}
function collapseDiv(idx) {
var div = document.getElementById('NavFrame' + idx)
var btn = document.getElementById('NavToggle' + idx)
if (!div || !btn) return false
var isShown = (btn.firstChild.data == NavigationBarHide)
btn.firstChild.data = isShown ? NavigationBarShow : NavigationBarHide
var disp = isShown ? 'none' : 'block'
for (var child = div.firstChild; child != null; child = child.nextSibling)
if (hasClass(child, 'NavPic') || hasClass(child, 'NavContent'))
child.style.display = disp
}
function voting12(){
if (votingTrigger = document.getElementById('voting-trigger'))
importScriptURI(wgServer+wgScript
+'?title=MediaWiki:Voting12.js&action=raw&ctype=text/javascript&cversion='
+encodeURIComponent(votingTrigger.innerHTML.replace(/\D+/g, '.')))
}
function uploadPage(){
if (window.wgUploadAutoFill){
upForm = document.getElementById('mw-upload-form')
upForm.onsubmit = checkUpForm
}
var desc = document.getElementById('wpUploadDescription')
var tmpl = document.getElementById('imageinfo')
if (wgUploadAutoFill && tmpl && desc && !desc.value) desc.value = tmpl.innerHTML
appendCSS('a.insertlink { text-decoration: none; }')
var span = document.getElementById('insertlink-free')
if (!!span) {
var a = document.createElement('a')
a.href = 'javascript:addInfoTemplate("rationale", "imageinfo", 8)'
a.class = 'insertlink'
span.parentNode.insertBefore(a, span)
a.appendChild(span)
}
var span = document.getElementById('insertlink-unfree')
if (!!span) {
var a = document.createElement('a')
a.href = 'javascript:addInfoTemplate("imageinfo", "rationale", 16)'
a.class = 'insertlink'
span.parentNode.insertBefore(a, span)
a.appendChild(span)
}
var c = document.getElementById('commons-link')
var c_a = c.lastChild
c.innerHTML = '<input class="commons-btn" type="button" onclick="window.location.href=\''+c_a.href+'\'" value="'+c_a.text+'"/>'
}
function addInfoTemplate(oldId, newId, rows){
var desc = document.getElementById('wpUploadDescription')
var oldTmpl = document.getElementById(oldId)
var tmpl = document.getElementById(newId)
if (desc && oldTmpl && desc.value == oldTmpl.innerHTML){
desc.value = tmpl.innerHTML
desc.rows = rows
}
else if (desc && tmpl && desc.value.indexOf(tmpl.innerHTML.substring(0,8)) == -1){
desc.value += '\n' + tmpl.innerHTML
desc.rows = 20
}
licList = document.getElementsByTagName('option', document.getElementById('wpLicense'))
if (newId == 'rationale'){
licList[licList.length-1].selected='selected'
}
else {
licList[0].selected='selected'
}
}
function checkUpForm(){
upForm = document.getElementById('mw-upload-form')
var desc = document.getElementById('wpUploadDescription')
var lcns = document.getElementById('wpLicense')
var wrn = document.createElement('div')
wrn.innerHTML = ''
if (lcns.value != '' && /\{\{(fair ?use ?in|ОДИ|Обоснование добросовестного использования)/i.exec(desc.value))
wrn.innerHTML += '<li>Вы используете устаревшую схему описания несвободных файлов. Пожалуйста, прочтите инструкцию выше.</li>'
if (lcns.value == '' && /^[^\{\}]*(\{\{(Изображение|Несвободный файл)[^\{\}]+\}\}[^\{\}]*)*$/i.exec(desc.value))
wrn.innerHTML += '<li>Не указана лицензия. Выберите лицензию в выпадающем списке выше.</li>'
if (lcns.value != '' && lcns.value != 'subst:ET' && /\{\{Несвободный файл/i.exec(desc.value))
wrn.innerHTML += '<li>Для несвободного файла выбрана лицензия в выпадающем списке. Возможно, вы где-то ошиблись.</li>'
if (lcns.value == '' && /\{\{Изображение\s*((\|\s*)+[\s\wа-яё]+=\s*)*(\|\s*)*\}\}/i.exec(desc.value))
wrn.innerHTML += '<li>Не заполнен шаблон {'+'{Изображение}}.</li>'
if (lcns.value == '' && /\{\{Несвободный файл\s*((\|\s*)+([\wа-яё]+\s*)+=\s*)*(\|\s*)*\}\}/i.exec(desc.value))
wrn.innerHTML += '<li>Не заполнен шаблон {'+'{Несвободный файл}}.</li>'
if (lcns.value == '' && /\{\{Несвободный файл\/ОДИ\s*((\|\s*)+([\wа-яё]+\s*)+=\s*)*(\|\s*)*\}\}/i.exec(desc.value))
wrn.innerHTML += '<li>Не заполнен шаблон {'+'{Несвободный файл/ОДИ}}.</li>'
if (/\{\{(Несвободный файл|Изображение)[^\{\}]*Источник\s*=\s*(из|с|http:\/\/(www\.)?)?\s*(интернет|internet|гугл|google|яндекс|yandex|яху|yahoo|рамблер|rambler)[^\{\}]*\}\}/i.test(desc.value))
wrn.innerHTML += '<li>«Интернет» или поисковая система не являются источником, подтверждающим лицензионный статус изображения. Укажите более конкретный источник.</li>'
if (wrn.innerHTML != ''){
wrn.innerHTML = '<p style="text-align:center; font-weight:bold;">Автоматическая проверка выявила следующие ошибки:</p><ul style="font-weight:bold">' + wrn.innerHTML
wrn.innerHTML += '</ul><p style="padding:0.2em 0.8em">При повторном нажатии на кнопку «Загрузить файл» данное предупреждение будет проигнорировано. Помните, что файлы без лицензии или с некорректной лицензией будут удалены. Если у вас возникли проблемы или вопросы, обращайтесь на <a href="http://ru.wikipedia.org/wiki/%D0%92%D0%B8%D0%BA%D0%B8%D0%BF%D0%B5%D0%B4%D0%B8%D1%8F:%D0%A4%D0%BE%D1%80%D1%83%D0%BC/%D0%90%D0%B2%D1%82%D0%BE%D1%80%D1%81%D0%BA%D0%BE%D0%B5_%D0%BF%D1%80%D0%B0%D0%B2%D0%BE">форум по авторскому праву</a>.</p>'
var oldWrn = document.getElementById('jsUploadWarnings')
if (oldWrn) {
return true
}
else {
wrn.style.border = '1px solid red'
wrn.style.background = '#ffe4e1'
wrn.id = 'jsUploadWarnings'
upNode = document.getElementById('mw-htmlform-options').parentNode
upNode.parentNode.insertBefore(wrn, upNode)
}
return false
}
else {
return true
}
}
/* Hide quick insert */
function uploadHideInsert(){
qIns = document.getElementById('editpage-specialchars')
qInsCover = document.createElement('div')
qInsCover.setAttribute('style', qIns.style.cssText)
if (typeof(qInsCover.style.setAttribute) == 'function') qInsCover.style.setAttribute('style', qIns.style.cssText) // IE
qInsCover.innerHTML = '<small><span style="border-bottom:1px dotted gray; cursor:help" title="Позволяет быстро вставлять символы разметки в поле описания">Быстрая вставка</span> (<a href="javascript:uploadExpandInsert()">раскрыть блок</a>)</small>'
qIns.style.display = 'none'
qIns.parentNode.appendChild(qInsCover)
}
function uploadExpandInsert(){
qInsCover.style.display = 'none'
qIns.style.display = 'block'
}
/* Ajax Preview */
function uploadPreviewRun(){
wpUploadPreview.innerHTML = ''
injectSpinner(wpUploadPreview,'preview')
var aj = sajax_init_object()
aj.onreadystatechange = function(){
if (aj.readyState!=4 || aj.status!=200) return
removeSpinner('preview')
wpUploadPreview.innerHTML = eval('('+aj.responseText+')')['parse']['text']['*']
wpUploadPreview.scrollIntoView()
}
aj.open('GET', '/w/api.php?action=parse&prop=text&pst&format=json&text='
+ encodeURIComponent(wpUploadText.value), true)
aj.send('')
}
function uploadPreviewInit(){
wpUploadText = document.getElementById('wpUploadDescription')
if (!wpUploadText) return
var bt = create('input','wpDestFile'); bt.type='button'
bt.style.cssFloat = bt.style.styleFloat = 'right'
bt.value = 'Предпросмотр'; bt.onclick = uploadPreviewRun
wpUploadPreview = create('div','wpLicense')
function create(type, attachTo){
var el = document.createElement(type)
attachTo = document.getElementById(attachTo) || wpUploadText
attachTo.parentNode.appendChild(el)
return el
}
}
addOnloadHook(uploadPage)
addOnloadHook(uploadHideInsert)
addOnloadHook(uploadPreviewInit)