Team:EPF-Lausanne/Template/script.js
From 2012.igem.org
Line 1: | Line 1: | ||
//Generate private namespace | //Generate private namespace | ||
var EPFL = (function(){ | var EPFL = (function(){ | ||
+ | //Little hack to stop MediaWiki from replacing ampersands... | ||
var amp = unescape("%26"); | var amp = unescape("%26"); | ||
return { | return { | ||
Line 112: | Line 113: | ||
$("#pageTitle").text(result); | $("#pageTitle").text(result); | ||
+ | } | ||
+ | }; | ||
+ | }()); | ||
+ | |||
+ | var Doodles = (function(){ | ||
+ | var SPACE_MIN = 20; | ||
+ | var SPACE_MAX = 100; | ||
+ | var WIDTH = 120; | ||
+ | var MAX_DOODLES_PER_BAR = 20; | ||
+ | |||
+ | var all = [ | ||
+ | { height: 114, src: "https://static.igem.org/mediawiki/2012/6/61/Team-EPF-Lausanne_Template_Doodle_Placeholder.png" } | ||
+ | ]; | ||
+ | |||
+ | var contentHeight = 0; | ||
+ | var doodleBars = []; | ||
+ | var barUsage = [{max: 0, images: []}, {max: 0, images: []}]; | ||
+ | |||
+ | return { | ||
+ | onLoad: function(){ | ||
+ | contentHeight = $(".page-content").height() - 50; | ||
+ | doodleBars = $(".doodle-bar"); | ||
+ | doodleBars.height(contentHeight); | ||
+ | |||
+ | this.addDoodles(); | ||
+ | }, | ||
+ | addDoodles: function(){ | ||
+ | for(var i = 0; i < MAX_DOODLES_PER_BAR; i++){ | ||
+ | if(!this.addDoodle(0)) break; | ||
+ | } | ||
+ | for(var i = 0; i < MAX_DOODLES_PER_BAR; i++){ | ||
+ | if(!this.addDoodle(1)) break; | ||
+ | } | ||
+ | }, | ||
+ | addDoodle: function(barNumber){ | ||
+ | var bar = $(doodleBars[barNumber]); | ||
+ | var usage = $(barUsage[barNumber]); | ||
+ | |||
+ | if(usage.max > contentHeight) return false; | ||
+ | |||
+ | var nextDistance = SPACE_MIN + Math.floor(Math.random()*(SPACE_MAX-SPACE_MIN+1)); | ||
+ | var nextImage = all[Math.floor(Math.random()*all.length)]; | ||
+ | |||
+ | if(usage.max + nextDistance + nextImage.height > contentHeight) return false; | ||
+ | |||
+ | $("<img>") | ||
+ | .attr("src", nextImage.src) | ||
+ | .attr("width", WIDTH) | ||
+ | .attr("height", nextImage.height) | ||
+ | .css({ | ||
+ | "margin-top": nextDistance+"px" | ||
+ | }); | ||
+ | usage.max += nextDistance + nextImage.height; | ||
+ | |||
+ | return true; | ||
} | } | ||
}; | }; |
Revision as of 21:09, 5 September 2012
//Generate private namespace var EPFL = (function(){ //Little hack to stop MediaWiki from replacing ampersands... var amp = unescape("%26"); return { namingRegex: /^(\/|([A-Z][a-z]*))*[0-9]*$/, registerNewPageButton: function(titleID, buttonID, base, preload, check){ $(buttonID).click(function(){ if(check != undefined){ if(!check(base, $(titleID).val())){ if(!confirm("The title doesn't seem to follow the naming conventions.\nAre you sure you want to create this page?")){ return; } } } window.location.href = "/wiki/index.php?title="+base+"/"+$(titleID).val()+amp+"action=edit"+amp+"preload="+preload; }); }, checkNamingConventions: function(base, title){ return EPFL.namingRegex.test(title); }, setup: function(){ EPFL.setupProtocols(); EPFL.setupCalendar(); EPFL.setupPlanning(); EPFL.setupTitle(); EPFL.setupTOC(); $('p') .filter(function(){ return $.trim($(this).text()) === && $.trim($(this).html()).length < 10; }) .remove(); }, setupTOC: function(){ var toc = $("#toc"); toc.remove(); $(".paper").prepend(toc); }, setupPlanning: function(){ if(location.href.match(/Team:EPF-Lausanne\/Planning/ig)){ $(".toctext, .mw-headline").each(function(){ var text = $(this).text().trim();
if(text.substr(0, 1) == "\u2713"){ $(this).addClass("planning-finished"); }else{ var parts = text.split(" - "); if(parts.length == 1){ $(this).addClass("planning-todo"); }else{ $(this).addClass("planning-taken"); } } }); } }, setupProtocols: function(){ var hide = false; $(".protocol-title").each(function(){ if($.trim($(this).parent().parent().attr("class")) != "protocol-remove-style"){ hide = true; var link = $("<a>") .attr("href", "#") .click( function(){ $(this).parent().parent().children().last().toggle() return false; });
var children = $(this).children().children(); $(this).empty(); link.append(children); $(this).append(link); }else{ var txt = $(this).text(); $(this).empty(); $(this).text(txt); } }); if(hide) $(".protocol-inner-box").hide(); }, setupCalendar: function(){ var toAdd = amp+"preload=Team:EPF-Lausanne/Notebook/Template/NewEntry"; $(".month tr td a") .filter( function(){ return $(this).attr("href").length > 80; }) .each( function(){ $(this).attr("href", $(this).attr("href")+toAdd); } ); }, setupTitle: function(){ var title = $($(".firstHeading")[0]).text(); var prefix = "Team:EPF-Lausanne/"; title = title.substr(prefix.length); titleParts = title.split("/");
switch(titleParts[0]){ case "Template": titleParts.shift(); break; }
var result = titleParts.join(" ");
if(result == ""){ result = "Home"; }
$("#pageTitle").text(result); } }; }());
var Doodles = (function(){ var SPACE_MIN = 20; var SPACE_MAX = 100; var WIDTH = 120; var MAX_DOODLES_PER_BAR = 20;
var all = [ { height: 114, src: "" } ];
var contentHeight = 0; var doodleBars = []; var barUsage = [{max: 0, images: []}, {max: 0, images: []}];
return { onLoad: function(){ contentHeight = $(".page-content").height() - 50; doodleBars = $(".doodle-bar"); doodleBars.height(contentHeight);
this.addDoodles(); }, addDoodles: function(){ for(var i = 0; i < MAX_DOODLES_PER_BAR; i++){ if(!this.addDoodle(0)) break; } for(var i = 0; i < MAX_DOODLES_PER_BAR; i++){ if(!this.addDoodle(1)) break; } }, addDoodle: function(barNumber){ var bar = $(doodleBars[barNumber]); var usage = $(barUsage[barNumber]);
if(usage.max > contentHeight) return false;
var nextDistance = SPACE_MIN + Math.floor(Math.random()*(SPACE_MAX-SPACE_MIN+1)); var nextImage = all[Math.floor(Math.random()*all.length)];
if(usage.max + nextDistance + nextImage.height > contentHeight) return false;
$("<img>") .attr("src", nextImage.src) .attr("width", WIDTH) .attr("height", nextImage.height) .css({ "margin-top": nextDistance+"px" }); usage.max += nextDistance + nextImage.height;
return true; } }; }());
runOnloadHook = function(){ EPFL.setup(); };