X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=htdocs%2Fjavascript%2Fxorg.js;h=0ce316941a1dd2f855cde78f1b74caf1ba7ee7f5;hb=e173ee9b7e29b11c13c3bc5124d200cba6675cce;hp=02ef26a8abd78a0a9404eb03973bdaa1d804243d;hpb=9f449375aa254a3af970d5eb0bd7f0478ed7363a;p=platal.git
diff --git a/htdocs/javascript/xorg.js b/htdocs/javascript/xorg.js
index 02ef26a..0ce3169 100644
--- a/htdocs/javascript/xorg.js
+++ b/htdocs/javascript/xorg.js
@@ -1,5 +1,5 @@
/***************************************************************************
- * Copyright (C) 2003-2004 Polytechnique.org *
+ * Copyright (C) 2003-2007 Polytechnique.org *
* http://opensource.polytechnique.org/ *
* *
* This program is free software; you can redistribute it and/or modify *
@@ -35,13 +35,43 @@ function getNow() {
time = (mi < 10) ? hr +':0'+mi : hr+':'+mi;
days = ['Dimanche', 'Lundi', 'Mardi', 'Mercredi', 'Jeudi', 'Vendredi', 'Samedi'];
- months = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet',
- 'août', 'septembre', 'octobre', 'novembre', 'décembre']
+ months = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet',
+ 'août', 'septembre', 'octobre', 'novembre', 'décembre']
return days[dy]+' '+wd+' '+months[mh]+' '+yr+'
'+time;
}
// }}}
+// {{{ Search Engine
+
+function canAddSearchEngine()
+{
+ if (((typeof window.sidebar == "object") && (typeof window.sidebar.addSearchEngine == "function"))
+ || ((typeof window.sidebar == "object") && (typeof window.sidebar.addSearchEngine == "function"))) {
+ return true;
+ }
+ return false;
+}
+
+function addSearchEngine()
+{
+ var searchURI = "http://www.polytechnique.org/xorg.opensearch.xml";
+ if ((typeof window.sidebar == "object") && (typeof window.sidebar.addSearchEngine == "function")) {
+ window.sidebar.addSearchEngine(
+ searchURI,
+ "http://www.polytechnique.org/images/xorg.png",
+ "Annuaire Polytechnique.org",
+ "Academic");
+ } else {
+ try {
+ window.external.AddSearchProvider(searchURI);
+ } catch(e) {
+ alert("Impossible d'installer la barre de recherche");
+ }
+ }
+}
+
+// }}}
// {{{ Events
function eventClosure(obj, methodName) {
@@ -59,7 +89,56 @@ function attachEvent(obj, evt, f, useCapture) {
return true;
} else if (obj.attachEvent) {
return obj.attachEvent("on"+evt, f);
+ }
+ return false;
+}
+
+// }}}
+// {{{ dynpost()
+
+function dynpost(action, values)
+{
+ var body = document.getElementsByTagName('body')[0];
+
+ var form = document.createElement('form');
+ form.action = action;
+ form.method = 'post';
+
+ body.appendChild(form);
+
+ for (var k in values) {
+ var input = document.createElement('input');
+ input.type = 'hidden';
+ input.name = k;
+ input.value = values[k];
+ form.appendChild(input);
}
+
+ form.submit();
+}
+
+function dynpostkv(action, k, v)
+{
+ var dict = {};
+ dict[k] = v;
+ dynpost(action, dict);
+}
+
+// }}}
+// {{{ function RegExp.escape()
+
+RegExp.escape = function(text) {
+ if (!arguments.callee.sRE) {
+ var specials = [
+ '/', '.', '*', '+', '?', '|',
+ '(', ')', '[', ']', '{', '}',
+ '\\', '^' , '$'
+ ];
+ arguments.callee.sRE = new RegExp(
+ '(\\' + specials.join('|\\') + ')', 'g'
+ );
+ }
+ return text.replace(arguments.callee.sRE, '\\$1');
}
// }}}
@@ -80,17 +159,25 @@ function popWin(theNode,w,h) {
function auto_links() {
nodes = document.getElementsByTagName('a');
- fqdn = document.URL;
- fqdn = fqdn.replace(/^https?:\/\/([^\/]*)\/.*$/,'$1');
+ url = document.URL;
+ fqdn = url.replace(/^https?:\/\/([^\/]*)\/.*$/,'$1');
+ light = (url.indexOf('display=light') > url.indexOf('?'));
for(var i=0; i -1 || node.href.indexOf('javascript:')>-1) continue;
- if(node.href.indexOf(fqdn)<0 || node.className == 'popup') {
+ if (node.href.indexOf(fqdn)<0 || node.className == 'popup') {
node.onclick = function () { window.open(this.href); return false; };
}
+ if (node.href.indexOf(fqdn) > -1 && light) {
+ node.href = node.href.replace(/([^\#\?]*)\??([^\#]*)(\#.*)?/,
+ "$1?display=light&$2$3");
+ }
if(node.className == 'popup2') {
- node.onclick = function () { popWin(this,840,600); return false; };
+ node.onclick = function () { popWin(this,840,600); return false; };
}
+ if(node.className == 'popup3') {
+ node.onclick = function () { popWin(this, 640, 800); return false; };
+ }
if(matches = (/^popup_([0-9]*)x([0-9]*)$/).exec(node.className)) {
var w = matches[1], h = matches[2];
node.onclick = function () { popWin(this,w,h); return false; };
@@ -106,7 +193,10 @@ function auto_links() {
// {{{ function pa_onload
-attachEvent(document, 'load', auto_links);
+if (!attachEvent(window, 'load', auto_links)) {
+ window.onload = auto_links;
+}
// }}}
+// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: