]> jfr.im git - irc/quakenet/qwebirc.git/blobdiff - js/qwebircinterface.js
Merge websockets into quakenet.
[irc/quakenet/qwebirc.git] / js / qwebircinterface.js
index 82b8be81306a8fc90168fb4beb011deb8f76f906..44ea44c42cf3d6267e4dbaa4aa6c0851553719b5 100644 (file)
@@ -1,3 +1,13 @@
+function qwebirc_ui_onbeforeunload(e) { /* IE sucks */
+  if(qwebirc.connected) {
+    var message = "This action will close all active IRC connections.";
+    var e = e || window.event;
+    if(e)
+      e.returnValue = message;
+    return message;
+  }
+}
+
 qwebirc.ui.Interface = new Class({
   Implements: [Options],
   options: {
@@ -8,18 +18,52 @@ qwebirc.ui.Interface = new Class({
     loginRegex: null,
     appTitle: "ExampleNetwork Web IRC",
     searchURL: true,
-    theme: undefined
+    theme: undefined,
+    baseURL: null,
+    hue: null,
+    saturation: null,
+    lightness: null,
+    thue: null,
+    tsaturation: null,
+    tlightness: null,
+    uiOptionsArg: null,
+    nickValidation: null,
+    dynamicBaseURL: "/",
+    staticBaseURL: "/"
   },
   initialize: function(element, ui, options) {
     this.setOptions(options);
+    var extractHost = function(uri) {
+      var start = uri.indexOf('?');
+      if(start != -1)
+        uri = uri.substring(0, start);
+      var start = uri.indexOf('#');
+      if(start != -1)
+        uri = uri.substring(0, start);
+
+      if(uri.substr(uri.length - 1) != "/")
+        uri = uri + "/";
+
+      return uri;
+    };
+
+    options.baseURL = extractHost(document.location.href);
+    
+    /* HACK */
+    qwebirc.global = {
+      dynamicBaseURL: options.dynamicBaseURL,
+      staticBaseURL: options.staticBaseURL,
+      baseURL: options.baseURL,
+      nicknameValidator: $defined(options.nickValidation) ? new qwebirc.irc.NicknameValidator(options.nickValidation) : new qwebirc.irc.DummyNicknameValidator()
+    };
+
 
     window.addEvent("domready", function() {
-      var ui_ = new ui($(element), new qwebirc.ui.Theme(this.options.theme), this.options);
-      
       var callback = function(options) {
         var IRC = new qwebirc.irc.IRCClient(options, ui_);
         IRC.connect();
-        window.addEvent("beforeunload", function() {
+        window.onbeforeunload = qwebirc_ui_onbeforeunload;
+        window.addEvent("unload", function() {
           IRC.quit("Page closed");
         });
       };
@@ -30,7 +74,17 @@ qwebirc.ui.Interface = new Class({
       
       if(this.options.searchURL) {
         var args = qwebirc.util.parseURI(String(document.location));
+        this.options.hue = this.getHueArg(args, "");
+        this.options.saturation = this.getSaturationArg(args, "");
+        this.options.lightness = this.getLightnessArg(args, "");
+
+        this.options.thue = this.getHueArg(args, "t");
+        this.options.tsaturation = this.getSaturationArg(args, "t");
+        this.options.tlightness = this.getLightnessArg(args, "t");
         
+        if($defined(args["uio"]))
+          this.options.uiOptionsArg = args["uio"];
+
         var url = args["url"];
         var chans, nick = args["nick"];
         
@@ -90,6 +144,8 @@ qwebirc.ui.Interface = new Class({
         }
       }
   
+      var ui_ = new ui($(element), new qwebirc.ui.Theme(this.options.theme), this.options);
+
       var usingAutoNick = !$defined(nick);
       if(usingAutoNick && autoConnect)
         inick = this.options.initialNickname;
@@ -97,6 +153,33 @@ qwebirc.ui.Interface = new Class({
       var details = ui_.loginBox(callback, inick, ichans, autoConnect, usingAutoNick);
     }.bind(this));
   },
+  getHueArg: function(args, t) {
+    var hue = args[t + "hue"];
+    if(!$defined(hue))
+      return null;
+    hue = parseInt(hue);
+    if(hue > 360 || hue < 0)
+      return null;
+    return hue;
+  },
+  getSaturationArg: function(args, t) {
+    var saturation = args[t + "saturation"];
+    if(!$defined(saturation))
+      return null;
+    saturation = parseInt(saturation);
+    if(saturation > 100 || saturation < -100)
+      return null;
+    return saturation;
+  },
+  getLightnessArg: function(args, t) {
+    var lightness = args[t + "lightness"];
+    if(!$defined(lightness))
+      return null;
+    lightness = parseInt(lightness);
+    if(lightness > 100 || lightness < -100)
+      return null;
+    return lightness;
+  },
   randSub: function(nick) {
     var getDigit = function() { return Math.floor(Math.random() * 10); }