Difference between revisions of "MediaWiki:Common.js"
From Pandora Wiki
EvilDragon (talk | contribs) |
EvilDragon (talk | contribs) |
||
Line 1: | Line 1: | ||
− | + | function mouseOver(e, imgUrl) | |
+ | { | ||
+ | var body = document.getElementById('bodyContent'); | ||
+ | |||
+ | var image = new Image(); | ||
+ | image.src = imgUrl; | ||
+ | |||
+ | var previewImage = document.createElement('img'); | ||
+ | previewImage.setAttribute('src', imgUrl); | ||
+ | previewImage.setAttribute('id', 'previewImage'); | ||
+ | var scrolledHeight = 0; | ||
− | + | if (document.documentElement.scrollTop) | |
− | + | scrolledHeight = document.documentElement.scrollTop; | |
− | + | else if (document.body.scrollTop) | |
− | + | scrolledHeight = document.body.scrollTop; | |
− | + | else | |
− | + | scrolledHeight = window.pageYOffset; | |
− | |||
− | |||
− | |||
− | |||
+ | previewStyle = "position: absolute; left: " + (e.clientX - image.width - 200) + "px; top: " + (e.clientY + scrolledHeight - 30) + "px; border: 1px solid grey;"; | ||
+ | previewImage.setAttribute('style', previewStyle); | ||
+ | |||
+ | body.appendChild(previewImage); | ||
+ | } | ||
− | |||
− | |||
− | |||
− | function | + | function mouseOut() |
{ | { | ||
− | + | var body = document.getElementById('bodyContent'); | |
− | + | var previewImage = document.getElementById('previewImage'); | |
− | + | ||
− | + | body.removeChild(previewImage); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | function | + | function createScreenshotLinks() |
{ | { | ||
var spanIndex = 0; | var spanIndex = 0; | ||
Line 48: | Line 42: | ||
for ( var i = 0; i < Spans.length; i++ ) | for ( var i = 0; i < Spans.length; i++ ) | ||
{ | { | ||
− | if ( hasClass( Spans[i], " | + | if ( hasClass( Spans[i], "previewScreenshot" ) ) |
{ | { | ||
CurrentSpan = Spans[i]; | CurrentSpan = Spans[i]; | ||
− | CurrentSpan. | + | |
+ | var wikiLinks = new Object(); // This is needed because the wiki automatically turns urls into links. | ||
+ | wikiLinks = CurrentSpan.getElementsByTagName( "a" ); | ||
+ | var imgURL = wikiLinks[0].innerHTML; | ||
var Button = document.createElement( "span" ); | var Button = document.createElement( "span" ); | ||
var ButtonLink = document.createElement( "a" ); | var ButtonLink = document.createElement( "a" ); | ||
− | var ButtonText = document.createTextNode( "[ | + | var ButtonText = document.createTextNode( "[ss]" ); |
− | ButtonLink.setAttribute( " | + | ButtonLink.setAttribute("href", imgURL); |
− | ButtonLink.setAttribute( " | + | ButtonLink.setAttribute("target", "_" + imgURL); |
− | |||
ButtonLink.appendChild( ButtonText ); | ButtonLink.appendChild( ButtonText ); | ||
Button.appendChild(document.createTextNode( " " )); | Button.appendChild(document.createTextNode( " " )); | ||
Button.appendChild(ButtonLink); | Button.appendChild(ButtonLink); | ||
+ | Button.setAttribute( "onmouseover", "mouseOver(event, '" + imgURL + "');"); | ||
+ | Button.setAttribute( "onmouseout", "mouseOut();"); | ||
CurrentSpan.parentNode.insertBefore( Button, CurrentSpan.nextSibling ); | CurrentSpan.parentNode.insertBefore( Button, CurrentSpan.nextSibling ); | ||
Line 73: | Line 71: | ||
} | } | ||
− | addOnloadHook( | + | addOnloadHook( createScreenshotLinks ); |
Revision as of 12:08, 23 January 2011
function mouseOver(e, imgUrl)
{
var body = document.getElementById('bodyContent');
var image = new Image();
image.src = imgUrl;
var previewImage = document.createElement('img');
previewImage.setAttribute('src', imgUrl);
previewImage.setAttribute('id', 'previewImage');
var scrolledHeight = 0;
if (document.documentElement.scrollTop)
scrolledHeight = document.documentElement.scrollTop;
else if (document.body.scrollTop)
scrolledHeight = document.body.scrollTop;
else
scrolledHeight = window.pageYOffset;
previewStyle = "position: absolute; left: " + (e.clientX - image.width - 200) + "px; top: " + (e.clientY + scrolledHeight - 30) + "px; border: 1px solid grey;";
previewImage.setAttribute('style', previewStyle);
body.appendChild(previewImage);
}
function mouseOut()
{
var body = document.getElementById('bodyContent');
var previewImage = document.getElementById('previewImage');
body.removeChild(previewImage);
}
function createScreenshotLinks()
{
var spanIndex = 0;
var Spans = document.getElementsByTagName( "span" );
var CurrentSpan = new Object();
for ( var i = 0; i < Spans.length; i++ )
{
if ( hasClass( Spans[i], "previewScreenshot" ) )
{
CurrentSpan = Spans[i];
var wikiLinks = new Object(); // This is needed because the wiki automatically turns urls into links.
wikiLinks = CurrentSpan.getElementsByTagName( "a" );
var imgURL = wikiLinks[0].innerHTML;
var Button = document.createElement( "span" );
var ButtonLink = document.createElement( "a" );
var ButtonText = document.createTextNode( "[ss]" );
ButtonLink.setAttribute("href", imgURL);
ButtonLink.setAttribute("target", "_" + imgURL);
ButtonLink.appendChild( ButtonText );
Button.appendChild(document.createTextNode( " " ));
Button.appendChild(ButtonLink);
Button.setAttribute( "onmouseover", "mouseOver(event, '" + imgURL + "');");
Button.setAttribute( "onmouseout", "mouseOut();");
CurrentSpan.parentNode.insertBefore( Button, CurrentSpan.nextSibling );
CurrentSpan.style.display="none";
spanIndex++;
}
}
}
addOnloadHook( createScreenshotLinks );