MediaWiki:Common.js — различия между версиями

Материал из Мегапедии
Перейти к: навигация, поиск
Строка 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(/&section=1/,'&section=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)