MediaWiki:Common.js: Διαφορά μεταξύ των αναθεωρήσεων
Περιεχόμενο που διαγράφηκε Περιεχόμενο που προστέθηκε
moved here because it may break users' privacy |
Geraki (συζήτηση | Συνεισφορά) αφαίρεση tabber |
||
Γραμμή 369: | Γραμμή 369: | ||
$( createNavigationBarToggleButton ); |
$( createNavigationBarToggleButton ); |
||
/* |
|||
==Tabber code== |
|||
*/ |
|||
/* |
|||
This was originally from http://www.barelyfitz.com/projects/tabber/ |
|||
This has been modified very slightly for wikinews by [[user:Bawolff]] (you can use any of my modifications under the same license as the original author specified) |
|||
Please note, only the tabber code is under the MIT license. (the rest is probably either cc-by, GPL, or some combination thereof. its not really clear) |
|||
Note i'm slowly modifying to use hasClass() as it is supposedly more efficient |
|||
================================================== |
|||
$Id: tabber.js,v 1.9 2006/04/27 20:51:51 pat Exp $ |
|||
tabber.js by Patrick Fitzgerald pat@barelyfitz.com |
|||
Documentation can be found at the following URL: |
|||
http://www.barelyfitz.com/projects/tabber/ |
|||
License (http://www.opensource.org/licenses/mit-license.php) |
|||
Copyright (c) 2006 Patrick Fitzgerald, modifed by Bawolff |
|||
Permission is hereby granted, free of charge, to any person |
|||
obtaining a copy of this software and associated documentation files |
|||
(the "Software"), to deal in the Software without restriction, |
|||
including without limitation the rights to use, copy, modify, merge, |
|||
publish, distribute, sublicense, and/or sell copies of the Software, |
|||
and to permit persons to whom the Software is furnished to do so, |
|||
subject to the following conditions: |
|||
The above copyright notice and this permission notice shall be |
|||
included in all copies or substantial portions of the Software. |
|||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
|||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
|||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
|||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS |
|||
BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
|||
ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN |
|||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
|||
SOFTWARE. |
|||
==================================================*/ |
|||
function tabberObj(argsObj) |
|||
{ |
|||
var arg; /* name of an argument to override */ |
|||
/* Element for the main tabber div. If you supply this in argsObj, |
|||
then the init() method will be called. |
|||
*/ |
|||
this.div = null; |
|||
/* Class of the main tabber div */ |
|||
this.classMain = "tabber"; |
|||
/* Rename classMain to classMainLive after tabifying |
|||
(so a different style can be applied) |
|||
*/ |
|||
this.classMainLive = "tabberlive"; |
|||
/* Class of each DIV that contains a tab */ |
|||
this.classTab = "tabbertab"; |
|||
/* Class to indicate which tab should be active on startup */ |
|||
this.classTabDefault = "tabbertabdefault"; |
|||
/* Class for the navigation UL */ |
|||
this.classNav = "tabbernav"; |
|||
/* add space between tabs to force line break. use class UseTabBreaks*/ |
|||
this.spaceTabs = false; |
|||
/* When a tab is to be hidden, instead of setting display='none', we |
|||
set the class of the div to classTabHide. In your screen |
|||
stylesheet you should set classTabHide to display:none. In your |
|||
print stylesheet you should set display:block to ensure that all |
|||
the information is printed. |
|||
*/ |
|||
this.classTabHide = "tabbertabhide"; |
|||
/* Class to set the navigation LI when the tab is active, so you can |
|||
use a different style on the active tab. |
|||
*/ |
|||
this.classNavActive = "tabberactive"; |
|||
/* Elements that might contain the title for the tab, only used if a |
|||
title is not specified in the TITLE attribute of DIV classTab. |
|||
*/ |
|||
this.titleElements = ['h2','h3','h4','h5','h6']; |
|||
/* Should we strip out the HTML from the innerHTML of the title elements? |
|||
This should usually be true. |
|||
*/ |
|||
this.titleElementsStripHTML = true; |
|||
/* If the user specified the tab names using a TITLE attribute on |
|||
the DIV, then the browser will display a tooltip whenever the |
|||
mouse is over the DIV. To prevent this tooltip, we can remove the |
|||
TITLE attribute after getting the tab name. |
|||
*/ |
|||
this.removeTitle = true; |
|||
/* If you want to add an id to each link set this to true */ |
|||
this.addLinkId = false; |
|||
/* If addIds==true, then you can set a format for the ids. |
|||
<tabberid> will be replaced with the id of the main tabber div. |
|||
<tabnumberzero> will be replaced with the tab number |
|||
(tab numbers starting at zero) |
|||
<tabnumberone> will be replaced with the tab number |
|||
(tab numbers starting at one) |
|||
<tabtitle> will be replaced by the tab title |
|||
(with all non-alphanumeric characters removed) |
|||
*/ |
|||
this.linkIdFormat = '<tabberid>nav<tabnumberone>'; |
|||
/* You can override the defaults listed above by passing in an object: |
|||
var mytab = new tabber({property:value,property:value}); |
|||
*/ |
|||
for (arg in argsObj) { this[arg] = argsObj[arg]; } |
|||
/* Create regular expressions for the class names; Note: if you |
|||
change the class names after a new object is created you must |
|||
also change these regular expressions. |
|||
*/ |
|||
this.REclassMain = new RegExp('\\b' + this.classMain + '\\b', 'gi'); |
|||
this.REclassMainLive = new RegExp('\\b' + this.classMainLive + '\\b', 'gi'); |
|||
this.REclassTab = new RegExp('\\b' + this.classTab + '\\b', 'gi'); |
|||
this.REclassTabDefault = new RegExp('\\b' + this.classTabDefault + '\\b', 'gi'); |
|||
this.REclassTabHide = new RegExp('\\b' + this.classTabHide + '\\b', 'gi'); |
|||
/* Array of objects holding info about each tab */ |
|||
this.tabs = new Array(); |
|||
/* If the main tabber div was specified, call init() now */ |
|||
if (this.div) { |
|||
this.init(this.div); |
|||
/* We don't need the main div anymore, and to prevent a memory leak |
|||
in IE, we must remove the circular reference between the div |
|||
and the tabber object. */ |
|||
this.div = null; |
|||
} |
|||
} |
|||
/*-------------------------------------------------- |
|||
Methods for tabberObj |
|||
--------------------------------------------------*/ |
|||
tabberObj.prototype.init = function(e) |
|||
{ |
|||
/* Set up the tabber interface. |
|||
e = element (the main containing div) |
|||
Example: |
|||
init(document.getElementById('mytabberdiv')) |
|||
*/ |
|||
var |
|||
childNodes, /* child nodes of the tabber div */ |
|||
i, i2, /* loop indices */ |
|||
t, /* object to store info about a single tab */ |
|||
defaultTab=0, /* which tab to select by default */ |
|||
DOM_ul, /* tabbernav list */ |
|||
DOM_li, /* tabbernav list item */ |
|||
DOM_a, /* tabbernav link */ |
|||
aId, /* A unique id for DOM_a */ |
|||
headingElement; /* searching for text to use in the tab */ |
|||
/* Verify that the browser supports DOM scripting */ |
|||
if (!document.getElementsByTagName) { return false; } |
|||
/* If the main DIV has an ID then save it. */ |
|||
if (e.id) { |
|||
this.id = e.id; |
|||
} |
|||
/* Clear the tabs array (but it should normally be empty) */ |
|||
this.tabs.length = 0; |
|||
/* Loop through an array of all the child nodes within our tabber element. */ |
|||
childNodes = e.childNodes; |
|||
for(i=0; i < childNodes.length; i++) { |
|||
/* Find the nodes where class="tabbertab" */ |
|||
if(childNodes[i].className && |
|||
$(childNodes[i]).hasClass( this.classTab)) { |
|||
/* Create a new object to save info about this tab */ |
|||
t = new Object(); |
|||
/* Save a pointer to the div for this tab */ |
|||
t.div = childNodes[i]; |
|||
/* Add the new object to the array of tabs */ |
|||
this.tabs.push(t); |
|||
/* If the class name contains classTabDefault, |
|||
then select this tab by default. |
|||
*/ |
|||
if (childNodes[i].className.match(this.REclassTabDefault)) { |
|||
defaultTab = this.tabs.length-1; |
|||
} |
|||
} |
|||
} |
|||
/* Create a new UL list to hold the tab headings */ |
|||
DOM_ul = document.createElement("ul"); |
|||
DOM_ul.className = this.classNav; |
|||
/* Loop through each tab we found */ |
|||
for (i=0; i < this.tabs.length; i++) { |
|||
t = this.tabs[i]; |
|||
/* Get the label to use for this tab: |
|||
From the title attribute on the DIV, |
|||
Or from one of the this.titleElements[] elements, |
|||
Or use an automatically generated number. |
|||
*/ |
|||
t.headingText = t.div.title; |
|||
/* Remove the title attribute to prevent a tooltip from appearing */ |
|||
if (this.removeTitle) { t.div.title = ''; } |
|||
if (!t.headingText) { |
|||
/* Title was not defined in the title of the DIV, |
|||
So try to get the title from an element within the DIV. |
|||
Go through the list of elements in this.titleElements |
|||
(typically heading elements ['h2','h3','h4']) |
|||
*/ |
|||
for (i2=0; i2<this.titleElements.length; i2++) { |
|||
headingElement = t.div.getElementsByTagName(this.titleElements[i2])[0]; |
|||
if (headingElement) { |
|||
t.headingText = headingElement.innerHTML; |
|||
if (this.titleElementsStripHTML) { |
|||
t.headingText.replace(/<br>/gi," "); |
|||
t.headingText = t.headingText.replace(/<[^>]+>/g,""); |
|||
} |
|||
break; |
|||
} |
|||
} |
|||
} |
|||
if (!t.headingText) { |
|||
/* Title was not found (or is blank) so automatically generate a |
|||
number for the tab. |
|||
*/ |
|||
t.headingText = i + 1; |
|||
} |
|||
/* Create a list element for the tab */ |
|||
DOM_li = document.createElement("li"); |
|||
/* Save a reference to this list item so we can later change it to |
|||
the "active" class */ |
|||
t.li = DOM_li; |
|||
/* Create a link to activate the tab */ |
|||
DOM_a = document.createElement("a"); |
|||
DOM_a.appendChild(document.createTextNode(t.headingText)); |
|||
DOM_a.href = "javascript:void(null);"; |
|||
DOM_a.title = t.headingText; |
|||
DOM_a.onclick = this.navClick; |
|||
/* Add some properties to the link so we can identify which tab |
|||
was clicked. Later the navClick method will need this. |
|||
*/ |
|||
DOM_a.tabber = this; |
|||
DOM_a.tabberIndex = i; |
|||
/* Do we need to add an id to DOM_a? */ |
|||
if (this.addLinkId && this.linkIdFormat) { |
|||
/* Determine the id name */ |
|||
aId = this.linkIdFormat; |
|||
aId = aId.replace(/<tabberid>/gi, this.id); |
|||
aId = aId.replace(/<tabnumberzero>/gi, i); |
|||
aId = aId.replace(/<tabnumberone>/gi, i+1); |
|||
aId = aId.replace(/<tabtitle>/gi, t.headingText.replace(/[^a-zA-Z0-9\-]/gi, '')); |
|||
DOM_a.id = aId; |
|||
} |
|||
/* Add the link to the list element */ |
|||
DOM_li.appendChild(DOM_a); |
|||
/* Add the list element to the list */ |
|||
DOM_ul.appendChild(DOM_li); |
|||
/* add a space to get line breaks */ |
|||
if (this.spaceTabs) { |
|||
DOM_ul.appendChild(document.createTextNode(" ")); |
|||
} |
|||
} |
|||
/* Add the UL list to the beginning of the tabber div */ |
|||
e.insertBefore(DOM_ul, e.firstChild); |
|||
/* Make the tabber div "live" so different CSS can be applied */ |
|||
e.className = e.className.replace(this.REclassMain, this.classMainLive); |
|||
/* Activate the default tab, and do not call the onclick handler */ |
|||
this.tabShow(defaultTab); |
|||
/* If the user specified an onLoad function, call it now. */ |
|||
if (typeof this.onLoad == 'function') { |
|||
this.onLoad({tabber:this}); |
|||
} |
|||
return this; |
|||
}; |
|||
tabberObj.prototype.navClick = function(event) |
|||
{ |
|||
/* This method should only be called by the onClick event of an <A> |
|||
element, in which case we will determine which tab was clicked by |
|||
examining a property that we previously attached to the <A> |
|||
element. |
|||
Since this was triggered from an onClick event, the variable |
|||
"this" refers to the <A> element that triggered the onClick |
|||
event (and not to the tabberObj). |
|||
When tabberObj was initialized, we added some extra properties |
|||
to the <A> element, for the purpose of retrieving them now. Get |
|||
the tabberObj object, plus the tab number that was clicked. |
|||
*/ |
|||
var |
|||
rVal, /* Return value from the user onclick function */ |
|||
a, /* element that triggered the onclick event */ |
|||
self, /* the tabber object */ |
|||
tabberIndex, /* index of the tab that triggered the event */ |
|||
onClickArgs; /* args to send the onclick function */ |
|||
a = this; |
|||
if (!a.tabber) { return false; } |
|||
self = a.tabber; |
|||
tabberIndex = a.tabberIndex; |
|||
/* Remove focus from the link because it looks ugly. |
|||
I don't know if this is a good idea... |
|||
*/ |
|||
a.blur(); |
|||
/* If the user specified an onClick function, call it now. |
|||
If the function returns false then do not continue. |
|||
*/ |
|||
if (typeof self.onClick == 'function') { |
|||
onClickArgs = {'tabber':self, 'index':tabberIndex, 'event':event}; |
|||
/* IE uses a different way to access the event object */ |
|||
if (!event) { onClickArgs.event = window.event; } |
|||
rVal = self.onClick(onClickArgs); |
|||
if (rVal === false) { return false; } |
|||
} |
|||
self.tabShow(tabberIndex); |
|||
return false; |
|||
}; |
|||
tabberObj.prototype.tabHideAll = function() |
|||
{ |
|||
var i; /* counter */ |
|||
/* Hide all tabs and make all navigation links inactive */ |
|||
for (i = 0; i < this.tabs.length; i++) { |
|||
this.tabHide(i); |
|||
} |
|||
}; |
|||
tabberObj.prototype.tabHide = function(tabberIndex) |
|||
{ |
|||
var div; |
|||
if (!this.tabs[tabberIndex]) { return false; } |
|||
/* Hide a single tab and make its navigation link inactive */ |
|||
div = this.tabs[tabberIndex].div; |
|||
/* Hide the tab contents by adding classTabHide to the div */ |
|||
if (!div.className.match(this.REclassTabHide)) { |
|||
div.className += ' ' + this.classTabHide; |
|||
} |
|||
this.navClearActive(tabberIndex); |
|||
return this; |
|||
}; |
|||
tabberObj.prototype.tabShow = function(tabberIndex) |
|||
{ |
|||
/* Show the tabberIndex tab and hide all the other tabs */ |
|||
var div; |
|||
if (!this.tabs[tabberIndex]) { return false; } |
|||
/* Hide all the tabs first */ |
|||
this.tabHideAll(); |
|||
/* Get the div that holds this tab */ |
|||
div = this.tabs[tabberIndex].div; |
|||
/* Remove classTabHide from the div */ |
|||
div.className = div.className.replace(this.REclassTabHide, ''); |
|||
/* Mark this tab navigation link as "active" */ |
|||
this.navSetActive(tabberIndex); |
|||
/* If the user specified an onTabDisplay function, call it now. */ |
|||
if (typeof this.onTabDisplay == 'function') { |
|||
this.onTabDisplay({'tabber':this, 'index':tabberIndex}); |
|||
} |
|||
return this; |
|||
}; |
|||
tabberObj.prototype.navSetActive = function(tabberIndex) |
|||
{ |
|||
/* Note: this method does *not* enforce the rule |
|||
that only one nav item can be active at a time. |
|||
*/ |
|||
/* Set classNavActive for the navigation list item */ |
|||
this.tabs[tabberIndex].li.className = this.classNavActive; |
|||
return this; |
|||
}; |
|||
tabberObj.prototype.navClearActive = function(tabberIndex) |
|||
{ |
|||
/* Note: this method does *not* enforce the rule |
|||
that one nav should always be active. |
|||
*/ |
|||
/* Remove classNavActive from the navigation list item */ |
|||
this.tabs[tabberIndex].li.className = ''; |
|||
return this; |
|||
}; |
|||
/*==================================================*/ |
|||
function tabberAutomatic(tabberArgs) |
|||
{ |
|||
/* This function finds all DIV elements in the document where |
|||
class=tabber.classMain, then converts them to use the tabber |
|||
interface. |
|||
tabberArgs = an object to send to "new tabber()" |
|||
*/ |
|||
var |
|||
tempObj, /* Temporary tabber object */ |
|||
divs, /* Array of all divs on the page */ |
|||
i; /* Loop index */ |
|||
if (!tabberArgs) { tabberArgs = {}; } |
|||
/* Create a tabber object so we can get the value of classMain */ |
|||
tempObj = new tabberObj(tabberArgs); |
|||
/* Find all DIV elements in the document that have class=tabber */ |
|||
/* First get an array of all DIV elements and loop through them */ |
|||
divs = document.getElementsByTagName("div"); |
|||
for (i=0; i < divs.length; i++) { |
|||
/* Is this DIV the correct class? */ |
|||
if (divs[i].className && |
|||
$(divs[i]).hasClass( tempObj.classMain)) { |
|||
if ($(divs[i]).hasClass( "UseTabBreaks")) { |
|||
tabberArgs.spaceTabs = true; |
|||
} |
|||
/* Now tabify the DIV */ |
|||
tabberArgs.div = divs[i]; |
|||
divs[i].tabber = new tabberObj(tabberArgs); |
|||
} |
|||
} |
|||
return this; |
|||
} |
|||
/*==================================================*/ |
|||
function tabberAutomaticOnLoad(tabberArgs) |
|||
{ |
|||
/* This function adds tabberAutomatic to the window.onload event, |
|||
so it will run after the document has finished loading. |
|||
*/ |
|||
// var oldOnLoad; |
|||
if (!tabberArgs) { tabberArgs = {}; } |
|||
//Use the wiki onload |
|||
$(function() { |
|||
tabberAutomatic(tabberArgs); |
|||
}) |
|||
} |
|||
/*==================================================*/ |
|||
/* Run tabberAutomaticOnload() unless the "manualStartup" option was specified */ |
|||
if (typeof tabberOptions == 'undefined') { |
|||
tabberAutomaticOnLoad(); |
|||
} else { |
|||
if (!tabberOptions['manualStartup']) { |
|||
tabberAutomaticOnLoad(tabberOptions); |
|||
} |
|||
} |
|||
/* |
|||
End Tabber. Note, code after this line probably is not under the MIT license. |
|||
*/ |
|||
/* |
/* |
Αναθεώρηση της 12:07, 7 Ιανουαρίου 2021
mw.loader.using(['mediawiki.util', 'jquery.cookie']).then(function () {
// Crudely widen the sitenotice message to 100% page width and hide the dismiss link.
// NB: This one is better left commented out when not specifically needed.
/*
$(function(){
var siteNoticeText = document.getElementById('mw-dismissable-notice').childNodes[0].childNodes[0].childNodes[0];
var siteNoticeDismiss = document.getElementById('mw-dismissable-notice').childNodes[0].childNodes[0].childNodes[2];
siteNoticeDismiss.setAttribute('style', 'display:none;');
siteNoticeText.setAttribute('width', '100%');
});
*/
/**********************
*** Allow descriptive labels next to sidebar language links using {{interwiki-info}}
*** by [[user:ThomasV]]
**********************/
function interwikiExtra() {
// iterate over all <span>-elements
for(var i=0; a=document.getElementsByTagName('span')[i]; i++) {
// if found a linkInfo span
if(a.className == 'interwiki-info') {
// iterate over all <li>-elements
var count=0;
for(var j=0; b=document.getElementsByTagName('li')[j]; j++) {
if(b.className == 'interwiki-' + a.id) {
b.innerHTML = b.innerHTML + ' ' + a.title;
if(a.title == '(vo)') {
b.title = 'Texte original';
}
}
else if(b.className == 'interwiki-' + a.id.substr(0, a.id.length-1)) {
count++;
if(a.id.charAt(a.id.length-1) == count) {
b.innerHTML = b.innerHTML + ' ' + a.title;
}
}
}
}
}
}
$(interwikiExtra);
/**********************
*** Quality indicators on "article" tab
*** by [[user:ThomasV]]
**********************/
// return src for icon given percentage
function icon_src(t){
var src='//upload.wikimedia.org/wikipedia/commons/';
switch(t){
case '0%': src+='8/8f/00'; break;
case '25%': src+='5/5b/25'; break;
case '50%': src+='3/3a/50'; break;
case '75%': src+='c/cd/75'; break;
case '100%': src+='6/64/100'; break;
}
return src + '%25.png';
}
// add indicator
function pageQuality() {
var a = document.getElementById('ca-nstab-main');
if(!a) return;
var pr_index = document.getElementById('pr_index');
if(pr_index) return;
var q = document.getElementById('textquality');
if(q) {
var new_img = document.createElement('img');
new_img.setAttribute('src', icon_src(q.className));
a.firstChild.appendChild(new_img);
}
for(var i=0; spanElem = document.getElementsByTagName('span')[i]; i++) {
if (spanElem.className == 'pagequality') {
var new_img = document.createElement('img');
new_img.setAttribute('src', icon_src(spanElem.title));
if(mw.config.get('wgCanonicalNamespace') == 'Page') {
a.firstChild.appendChild(new_img);
}
else {
s1 = spanElem.parentNode.previousSibling;
opttext = s1.firstChild.firstChild;
img = opttext.firstChild.nextSibling.nextSibling.nextSibling;
next = img.nextSibling;
opttext.removeChild(img);
opttext.insertBefore(new_img,next);
}
}
}
}
$(pageQuality);
//add link to the extension [[user:sanbeg]]
function pr_add_quality_buttons_link(){
if(typeof proofreadPageMessageStatus == 'undefined') return;
if( self.proofreadpage_no_quality_buttons ) return;
var ig = document.getElementById("wpWatchthis");
if( !ig ) return;
var f = document.createElement("span");
f.innerHTML = ' (<a href="/wiki/Help:Page Status">help</a>)';
ig.parentNode.insertBefore(f,ig.nextSibling.nextSibling.nextSibling.nextSibling);
}
$(pr_add_quality_buttons_link);
/****************
*** Allows extra script to run in Special:Watchlist — addition of announcements
*** script allows users to dismiss Mediawiki:watchlist-announcements, as per sitenotice
*** [[user:billinghurst]] 20100522, as hacked from WP script
*****************/
/*if (mw.config.get('wgPageName') == "Special:Watchlist") //watchlist scripts
{
importScript("MediaWiki:Common.js/watchlist.js")
}*/
/**********************
*** add menu on edit page /for selecting subsets of special characters
*** by [[user:Pathoschild]]
*** - note: must match MediaWiki:Edittools
**********************/
function addCharSubsetMenu() {
var specialchars = document.getElementById('specialchars');
if (specialchars) {
var menu = "<select style=\"display:inline\" onChange=\"chooseCharSubset(selectedIndex)\">";
menu += "<option>Select</option>";
menu += "<option>Ligatures and symbols</option>";
menu += "<option>Accents</option>";
menu += "<option>Tildes</option>";
menu += "<option>Cedillas</option>";
menu += "<option>Diereses</option>";
menu += "<option>Circumflexes</option>";
menu += "<option>Macrons</option>";
menu += "<option>Other diacritics</option>";
menu += "<option>Greek</option>";
menu += "<option>Hebrew</option>";
menu += "<option>Cyrillic</option>";
menu += "<option>IPA</option>";
menu += "</select>";
specialchars.innerHTML = menu + specialchars.innerHTML.replace(/_newline_/gm, "\n");
/* default subset - try to use a cookie some day */
chooseCharSubset(0);
}
}
/* select subsection of special characters */
function chooseCharSubset(s) {
var l = document.getElementById('specialchars').getElementsByTagName('p');
for (var i = 0; i < l.length ; i++) {
l[i].style.display = i == s ? 'inline' : 'none';
l[i].style.visibility = i == s ? 'visible' : 'hidden';
}
}
$(addCharSubsetMenu);
/**
* Imports JaveScript for the current page when the URL contains a &usejs parameter.
* @see https://meta.wikimedia.org/wiki/UseJS
* @update-token [[File:pathoschild/usejs.js]]
*/
mw.loader.load('//el.wikisource.org/w/index.php?title=MediaWiki:Usejs.js&action=raw&ctype=text/javascript');
/** Collapsible tables *********************************************************
*
* Description: Allows tables to be collapsed, showing only the header. See
* [[w:Wikipedia:NavFrame]].
* Maintainers: [[w:User:R. Koot]]
*/
var autoCollapse = 2;
var collapseCaption = "απόκρυψη";
var expandCaption = "εμφάνιση";
function collapseTable( tableIndex )
{
var Button = document.getElementById( "collapseButton" + tableIndex );
var Table = document.getElementById( "collapsibleTable" + tableIndex );
if ( !Table || !Button ) {
return false;
}
var Rows = Table.rows;
if ( Button.firstChild.data == collapseCaption ) {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = "none";
}
Button.firstChild.data = expandCaption;
} else {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = Rows[0].style.display;
}
Button.firstChild.data = collapseCaption;
}
}
function createCollapseButtons()
{
var tableIndex = 0;
var NavigationBoxes = new Object();
var Tables = document.getElementsByTagName( "table" );
for ( var i = 0; i < Tables.length; i++ ) {
if ($(Tables[i]).hasClass( "collapsible" ) ) {
/* only add button and increment count if there is a header row to work with */
var HeaderRow = Tables[i].getElementsByTagName( "tr" )[0];
if (!HeaderRow) continue;
var Header = HeaderRow.getElementsByTagName( "th" )[0];
if (!Header) continue;
NavigationBoxes[ tableIndex ] = Tables[i];
Tables[i].setAttribute( "id", "collapsibleTable" + tableIndex );
var Button = document.createElement( "span" );
var ButtonLink = document.createElement( "a" );
var ButtonText = document.createTextNode( collapseCaption );
Button.style.styleFloat = "right"; //
Button.style.cssFloat = "right"; // REMOVE THESE LINES
Button.style.fontWeight = "normal"; // ON 10 FEBRUARY 2009
Button.style.textAlign = "right"; //
Button.style.width = "6em"; //
Button.className = "collapseButton"; //Styles are declared in Common.css
ButtonLink.style.color = Header.style.color;
ButtonLink.setAttribute( "id", "collapseButton" + tableIndex );
ButtonLink.setAttribute( "href", "javascript:collapseTable(" + tableIndex + ");" );
ButtonLink.appendChild( ButtonText );
Button.appendChild( document.createTextNode( "[" ) );
Button.appendChild( ButtonLink );
Button.appendChild( document.createTextNode( "]" ) );
Header.insertBefore( Button, Header.childNodes[0] );
tableIndex++;
}
}
for ( var i = 0; i < tableIndex; i++ ) {
if ( $(NavigationBoxes[i]).hasClass( "collapsed" ) || ( tableIndex >= autoCollapse && $(NavigationBoxes[i]).hasClass( "autocollapse" ) ) ) {
collapseTable( i );
}
else if ( $(NavigationBoxes[i]).hasClass( "innercollapse" ) ) {
var element = NavigationBoxes[i];
while (element = element.parentNode) {
if ( $(element).hasClass( "outercollapse" ) ) {
collapseTable ( i );
break;
}
}
}
}
}
$( createCollapseButtons );
/** Dynamic Navigation Bars (experimental) *************************************
*
* Description: See [[w:Wikipedia:NavFrame]].
* Maintainers: UNMAINTAINED
*/
// set up the words in your language
var NavigationBarHide = '[' + collapseCaption + ']';
var NavigationBarShow = '[' + expandCaption + ']';
// shows and hides content and picture (if available) of navigation bars
// Parameters:
// indexNavigationBar: the index of navigation bar to be toggled
function toggleNavigationBar(indexNavigationBar)
{
var NavToggle = document.getElementById("NavToggle" + indexNavigationBar);
var NavFrame = document.getElementById("NavFrame" + indexNavigationBar);
if (!NavFrame || !NavToggle) {
return false;
}
// if shown now
if (NavToggle.firstChild.data == NavigationBarHide) {
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
if ( $(NavChild).hasClass( 'NavPic' ) ) {
NavChild.style.display = 'none';
}
if ( $(NavChild).hasClass( 'NavContent') ) {
NavChild.style.display = 'none';
}
}
NavToggle.firstChild.data = NavigationBarShow;
// if hidden now
} else if (NavToggle.firstChild.data == NavigationBarShow) {
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
if ($(NavChild).hasClass( 'NavPic')) {
NavChild.style.display = 'block';
}
if ($(NavChild).hasClass( 'NavContent')) {
NavChild.style.display = 'block';
}
}
NavToggle.firstChild.data = NavigationBarHide;
}
}
// adds show/hide-button to navigation bars
function createNavigationBarToggleButton()
{
var indexNavigationBar = 0;
// iterate over all < div >-elements
var divs = document.getElementsByTagName("div");
for (var i = 0; NavFrame = divs[i]; i++) {
// if found a navigation bar
if ($(NavFrame).hasClass( "NavFrame")) {
indexNavigationBar++;
var NavToggle = document.createElement("a");
NavToggle.className = 'NavToggle';
NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);
NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');
var isCollapsed = $(NavFrame).hasClass( "collapsed" );
/*
* Check if any children are already hidden. This loop is here for backwards compatibility:
* the old way of making NavFrames start out collapsed was to manually add style="display:none"
* to all the NavPic/NavContent elements. Since this was bad for accessibility (no way to make
* the content visible without JavaScript support), the new recommended way is to add the class
* "collapsed" to the NavFrame itself, just like with collapsible tables.
*/
for (var NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling) {
if ( $(NavChild).hasClass( 'NavPic' ) || $(NavChild).hasClass( 'NavContent' ) ) {
if ( NavChild.style.display == 'none' ) {
isCollapsed = true;
}
}
}
if (isCollapsed) {
for (var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling) {
if ( $(NavChild).hasClass( 'NavPic' ) || $(NavChild).hasClass( 'NavContent' ) ) {
NavChild.style.display = 'none';
}
}
}
var NavToggleText = document.createTextNode(isCollapsed ? NavigationBarShow : NavigationBarHide);
NavToggle.appendChild(NavToggleText);
// Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)
for(var j=0; j < NavFrame.childNodes.length; j++) {
if ($(NavFrame.childNodes[j]).hasClass( "NavHead")) {
NavFrame.childNodes[j].appendChild(NavToggle);
}
}
NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
}
}
}
$( createNavigationBarToggleButton );
/*
* port from [[:he:mediawiki:common.js]] for [[mediawiki:edittools]] -Steve
*/
/* פונקציה שמשמשת לאיפשור ניקוד ב[[מדיה ויקי:edittools]] */
function nikud(){
if (document.getElementById('edit-templates')!=null){
for(var i=0; a = document.getElementsByTagName("span")[i]; i++) {
if(a.className == "nikud") {
a.onclick=function(){mw.util.insertTags('', this.title, '');return false;};
}
}
}
}
$(nikud);
/*scripts imported from wikisource.org*/
/* messages are configurable here */
self.ws_messages = {
'optlist':'Επιλογές εμφάνισης',
'hide_page_numbers':'Απόκρυψη συνδ. σελίδας',
'show_page_numbers':'Εμφάνιση συνδ. σελίδας',
'layout':'Διάταξη',
'author':'Συγγραφέας',
'translator':'Μεταφραστής',
'editor':'Επιμελητής',
'publisher':'Εκδότης',
'place':'Τόπος',
'volume':'Τόμος',
'school':'Σχολή',
'book':'Βιβλίο',
'collection':'Συλλογή',
'journal':'Εφημερίδα ή περιοδικό',
'phdthesis':'Διατριβή',
'dictionary':'Λεξικό',
'progress':'Πρόοδος',
'progress_T':'Έγινε',
'progress_V':'Χρειάζεται επιβεβαίωση',
'progress_C':'Χρειάζεται διόρθωση',
'progress_MS':'Έτοιμα για σύγκριση και διαχωρισμό',
'progress_OCR':'Χρειάζεται στρώμα κειμένου OCR',
'progress_X':'Το αρχείο πηγής είναι απόσπασμα μεγαλίτερου τόμου ή μίγμα διαφόρων πηγών',
'progress_L':'Το αρχείο πηγής είναι λανθασμένο (λείπουν σελίδες, οι σελίδες είναι ανακατεμένες, κτλ.)',
'▲':'Επαναφορά στην αρχή της σελίδας.',
'matching':'γίνεται σύγκριση ',
'splitting':'γίνεται διαχωρισμός',
'corr_list':"Κατάλογος διορθώσεων αυτής της σελίδας" ,
'corr_link':"Διορθώσεις" ,
'corr_one':"Ένα λάθος </a> διορθώθηκε." ,
'corr_many':"Λάθη</a> διορθώθηκαν." ,
'corr_close':"Κλείσιμο." ,
'iwtrans':'Το κείμενό της προέρχεται από',
'iwtrans2':'Το κείμενό της προέρχεται από άλλες υποπεριοχές Wikisource.'
}
/* dynamic layouts */
self.ws_layouts = {
'Διάταξη 1':{'text-wrap':"",
'#text-container':"" ,
'#text':"",
'.sidenote-right':"float:right;margin:0.5em;padding:3px;border:solid 1px gray;max-width:9em;text-indent:0em;text-align:left;",
'.sidenote-left':"float:left;margin:0.5em;padding:3px;border:solid 1px gray;max-width:9em;text-indent:0em;text-align:left;",
'.editsection':"display:none",
'#headertemplate':"" },
'Διάταξη 2':{'text-wrap':"position:relative;margin-left:3em;margin-right:3em;",
'#text-container':"width:36em;margin:0px auto;" ,
'#text':"text-align:justify;",
'.sidenote-right':"position:absolute; left:37em;width:16em;text-indent:0em;text-align:left;",
'.sidenote-left':"position:absolute; right:37em;width:16em;text-indent:0em;text-align:right;",
'.editsection':"display:none",
'#headertemplate':"" },
'Διάταξη 3':{'text-wrap':"margin-left:3em",
'#text-container':"position:relative; min-width:60em; float:left; width:100%; margin-right:-23em;" ,
'#text':"text-align:justify;margin-right:23em; text-indent:0em; padding-left:0px; padding-right:0px;width:auto;",
'.sidenote-right':"position:absolute; right:-10em; width:9em; background-color:#eeeeee;text-indent:0em;text-align:left;",
'.sidenote-left': "position:absolute; right:-10em; width:9em; background-color:#eeeeee;text-indent:0em;text-align:left;",
'.editsection':"display:none",
'#headertemplate':"position:absolute; top:0em; right:-23em; width:21em;float:right; text-align:left;" }
}
self.proofreadpage_add_container = true;
mw.loader.load('//el.wikisource.org/w/index.php?title=MediaWiki:Base.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:OCR.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:DisplayFooter.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:PageNumbers.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:Corrections.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:IndexForm.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:Dictionary.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:InterWikiTransclusion.js&action=raw&ctype=text/javascript');
mw.loader.load('//wikisource.org/w/index.php?title=MediaWiki:DoubleWiki.js&action=raw&ctype=text/javascript');
/*
Disabling mouse wheel until the problem is fixed.
Users that have a configurations where zoom wheel works can override this,
by adding "self.proofreadpage_disable_wheelzoom=false;" to their javascript.
*/
self.proofreadpage_disable_wheelzoom=true;
/**********************
*** Download as EPUB
**********************/
//link "Download as EPUB"
if (mw.config.get('wgNamespaceNumber') == 0) {
$(document).ready( function () {
mw.util.addPortletLink(
'p-coll-print_export',
'https://tools.wmflabs.org/wsexport/tool/book.php?lang=el&format=epub-3&page=' + mw.config.get('wgPageName'),
'Κατέβασμα ως EPUB',
'n-epubExport',
'Ληψη μιας έκδοσης EPUB αυτής της σελίδας',
'',
'#t-print');
});
}
//Απόκρυψη του namespace Συγγραφέας από τις κατηγορίες Συγγραφέων, πρέπει να έχουν το πρότυπο Κατηγορία συγγραφέων για να δουλέψει
function catprefix() {
if(!document.getElementById('catnoprefix')) return
var anchors = document.getElementById('mw-pages').getElementsByTagName('a');
for(var i=0;i < anchors.length;i++) {
if(anchors[i].firstChild.nodeValue.indexOf(':') != -1) {
anchors[i].firstChild.nodeValue = anchors[i].firstChild.nodeValue.substring(anchors[i].firstChild.nodeValue.indexOf(':')+1);
}
}
}
$(catprefix)
});