X-Git-Url: https://jfr.im/git/irc/quakenet/qwebirc.git/blobdiff_plain/127631e04360ab01329781ca95c086dcc23651a7..cbef082a9c98b717f23c918364be0cbe8031d202:/js/ui/baseui.js diff --git a/js/ui/baseui.js b/js/ui/baseui.js index 627a55b..c44fe99 100644 --- a/js/ui/baseui.js +++ b/js/ui/baseui.js @@ -1,18 +1,16 @@ -qwebirc.ui.WINDOW_STATUS = 1; -qwebirc.ui.WINDOW_QUERY = 2; -qwebirc.ui.WINDOW_CHANNEL = 3; -qwebirc.ui.WINDOW_CUSTOM = 4; -qwebirc.ui.WINDOW_CONNECT = 5; +qwebirc.ui.WINDOW_STATUS = 0x01; +qwebirc.ui.WINDOW_QUERY = 0x02; +qwebirc.ui.WINDOW_CHANNEL = 0x04; +qwebirc.ui.WINDOW_CUSTOM = 0x08; +qwebirc.ui.WINDOW_CONNECT = 0x10; +qwebirc.ui.WINDOW_MESSAGES = 0x20; + qwebirc.ui.CUSTOM_CLIENT = "custom"; qwebirc.ui.BaseUI = new Class({ - Implements: [Events, Options], - options: { - appTitle: "QuakeNet Web IRC", - singleWindow: true - }, + Implements: [Events], initialize: function(parentElement, windowClass, uiName, options) { - this.setOptions(options); + this.options = options; this.windows = {}; this.clients = {}; @@ -25,6 +23,30 @@ qwebirc.ui.BaseUI = new Class({ this.firstClient = false; this.commandhistory = new qwebirc.irc.CommandHistory(); this.clientId = 0; + + this.windowFocused = true; + + if(Browser.Engine.trident) { + var checkFocus = function() { + var hasFocus = document.hasFocus(); + if(hasFocus != this.windowFocused) { + this.windowFocused = hasFocus; + this.focusChange(hasFocus); + } + } + + checkFocus.periodical(100, this); + } else { + var blur = function() { if(this.windowFocused) { this.windowFocused = false; this.focusChange(false); } }.bind(this); + var focus = function() { if(!this.windowFocused) { this.windowFocused = true; this.focusChange(true); } }.bind(this); + + /* firefox requires both */ + + document.addEvent("blur", blur); + window.addEvent("blur", blur); + document.addEvent("focus", focus); + window.addEvent("focus", focus); + } }, newClient: function(client) { client.id = this.clientId++; @@ -37,9 +59,9 @@ qwebirc.ui.BaseUI = new Class({ if(!this.firstClient) { this.firstClient = true; w.addLine("", "qwebirc v" + qwebirc.VERSION); - w.addLine("", "Copyright (C) 2008 Chris Porter. All rights reserved."); - w.addLine("", "http://webchat.quakenet.org/"); - w.addLine("", "This is BETA quality software, please report bugs to slug@quakenet.org"); + w.addLine("", "Copyright (C) 2008-2010 Chris Porter and the qwebirc project."); + w.addLine("", "http://www.qwebirc.org"); + w.addLine("", "Licensed under the GNU General Public License, Version 2."); } return w; }, @@ -50,22 +72,41 @@ qwebirc.ui.BaseUI = new Class({ return client.id; } }, - newWindow: function(client, type, name) { - var identifier = name; + getWindowIdentifier: function(client, type, name) { + if(type == qwebirc.ui.WINDOW_MESSAGES) + return "-M"; if(type == qwebirc.ui.WINDOW_STATUS) - identifier = ""; + return ""; + + if(client == qwebirc.ui.CUSTOM_CLIENT) /* HACK */ + return "_" + name; + + return "_" + client.toIRCLower(name); + }, + newWindow: function(client, type, name) { + var w = this.getWindow(client, type, name); + if($defined(w)) + return w; - var w = this.windows[this.getClientId(client)][identifier] = new this.windowClass(this, client, type, name, identifier); + var wId = this.getWindowIdentifier(client, type, name); + var w = this.windows[this.getClientId(client)][wId] = new this.windowClass(this, client, type, name, wId); this.windowArray.push(w); return w; }, + getWindow: function(client, type, name) { + var c = this.windows[this.getClientId(client)]; + if(!$defined(c)) + return null; + + return c[this.getWindowIdentifier(client, type, name)]; + }, getActiveWindow: function() { return this.active; }, getActiveIRCWindow: function(client) { if(!this.active || this.active.type == qwebirc.ui.WINDOW_CUSTOM) { - return this.windows[this.getClientId(client)][""]; + return this.windows[this.getClientId(client)][this.getWindowIdentifier(client, qwebirc.ui.WINDOW_STATUS)]; } else { return this.active; } @@ -77,7 +118,10 @@ qwebirc.ui.BaseUI = new Class({ if(this.active) this.active.deselect(); window.select(); /* calls setActiveWindow */ - document.title = window.name + " - " + this.options.appTitle; + this.updateTitle(window.name + " - " + this.options.appTitle); + }, + updateTitle: function(text) { + document.title = text; }, nextWindow: function(direction) { if(this.windowArray.length == 0 || !this.active) @@ -130,62 +174,83 @@ qwebirc.ui.BaseUI = new Class({ tricked into getting themselves glined */ loginBox: function(callback, initialNickname, initialChannels, autoConnect, autoNick) { - qwebirc.ui.GenericLoginBox(this.parentElement, callback, initialNickname, initialChannels, autoConnect, autoNick); + qwebirc.ui.GenericLoginBox(this.parentElement, callback, initialNickname, initialChannels, autoConnect, autoNick, this.options.networkName); + }, + focusChange: function(newValue) { + var window_ = this.getActiveWindow(); + if($defined(window_)) + window_.focusChange(newValue); } }); qwebirc.ui.StandardUI = new Class({ Extends: qwebirc.ui.BaseUI, + UICommands: qwebirc.ui.UI_COMMANDS, initialize: function(parentElement, windowClass, uiName, options) { this.parent(parentElement, windowClass, uiName, options); this.tabCompleter = new qwebirc.ui.TabCompleterFactory(this); - this.uiOptions = new qwebirc.ui.DefaultOptionsClass(this); + this.uiOptions = new qwebirc.ui.DefaultOptionsClass(this, options.uiOptionsArg); this.customWindows = {}; - window.addEvent("keydown", function(x) { - if(!x.alt || x.control) - return; - - var success = false; - if(x.key == "a" || x.key == "A") { - var highestNum = 0; - var highestIndex = -1; - success = true; - - new Event(x).stop(); - for(var i=0;i highestNum) { - highestIndex = i; - highestNum = h; - } + var ev; + if(Browser.Engine.trident) { + ev = "keydown"; + } else { + ev = "keypress"; + } + document.addEvent(ev, this.__handleHotkey.bind(this)); + }, + __handleHotkey: function(x) { + if(!x.alt || x.control) { + if(x.key == "backspace" || x.key == "/") + if(!this.getInputFocused(x)) + new Event(x).stop(); + return; + } + var success = false; + if(x.key == "a" || x.key == "A") { + var highestNum = 0; + var highestIndex = -1; + success = true; + + new Event(x).stop(); + for(var i=0;i highestNum) { + highestIndex = i; + highestNum = h; } - if(highestIndex > -1) - this.selectWindow(this.windowArray[highestIndex]); - } else if(x.key >= '0' && x.key <= '9') { - success = true; + } + if(highestIndex > -1) + this.selectWindow(this.windowArray[highestIndex]); + } else if(x.key >= '0' && x.key <= '9') { + success = true; + + number = x.key - '0'; + if(number == 0) + number = 10 - number = x.key - '0'; - if(number == 0) - number = 10 - - number = number - 1; + number = number - 1; + + if(number >= this.windowArray.length) + return; - if(number >= this.windowArray.length) - return; - - this.selectWindow(this.windowArray[number]); - } else if(x.key == "left") { - this.prevWindow(); - success = true; - } else if(x.key == "right") { - this.nextWindow(); - success = true; - } - if(success) - new Event(x).stop(); - }.bind(this)); + this.selectWindow(this.windowArray[number]); + } else if(x.key == "left") { + this.prevWindow(); + success = true; + } else if(x.key == "right") { + this.nextWindow(); + success = true; + } + if(success) + new Event(x).stop(); + }, + getInputFocused: function(x) { + if($$("input").indexOf(x.target) == -1 && $$("textarea").indexOf(x.target) == -1) + return false; + return true; }, newCustomWindow: function(name, select, type) { if(!type) @@ -193,7 +258,7 @@ qwebirc.ui.StandardUI = new Class({ var w = this.newWindow(qwebirc.ui.CUSTOM_CLIENT, type, name); w.addEvent("close", function(w) { - delete this.windows[qwebirc.ui.CUSTOM_CLIENT][name]; + delete this.windows[qwebirc.ui.CUSTOM_CLIENT][w.identifier]; }.bind(this)); if(select) @@ -218,26 +283,53 @@ qwebirc.ui.StandardUI = new Class({ }.bind(this)); if(cssClass) - d.lines.addClass(cssClass); + d.lines.addClass("qwebirc-" + cssClass); var ew = new class_(d.lines, options); ew.addEvent("close", function() { d.close(); }.bind(this)); + + d.setSubWindow(ew); }, embeddedWindow: function() { - this.addCustomWindow("Embedded Wizard", qwebirc.ui.EmbedWizard, "embeddedwizard"); + this.addCustomWindow("Add webchat to your site", qwebirc.ui.EmbedWizard, "embeddedwizard", {baseURL: this.options.baseURL, uiOptions: this.uiOptions, optionsCallback: function() { + this.optionsWindow(); + }.bind(this)}); }, optionsWindow: function() { this.addCustomWindow("Options", qwebirc.ui.OptionsPane, "optionspane", this.uiOptions); }, - urlDispatcher: function(name) { + aboutWindow: function() { + this.addCustomWindow("About", qwebirc.ui.AboutPane, "aboutpane", this.uiOptions); + }, + privacyWindow: function() { + this.addCustomWindow("Privacy policy", qwebirc.ui.PrivacyPolicyPane, "privacypolicypane", this.uiOptions); + }, + feedbackWindow: function() { + this.addCustomWindow("Feedback", qwebirc.ui.FeedbackPane, "feedbackpane", this.uiOptions); + }, + faqWindow: function() { + this.addCustomWindow("FAQ", qwebirc.ui.FAQPane, "faqpane", this.uiOptions); + }, + urlDispatcher: function(name, window) { if(name == "embedded") return ["a", this.embeddedWindow.bind(this)]; if(name == "options") return ["a", this.optionsWindow.bind(this)]; + /* doesn't really belong here */ + if(name == "whois") { + return ["span", function(nick) { + if(this.uiOptions.QUERY_ON_NICK_CLICK) { + window.client.exec("/QUERY " + nick); + } else { + window.client.exec("/WHOIS " + nick); + } + }.bind(this)]; + } + return null; }, tabComplete: function(element) { @@ -245,59 +337,77 @@ qwebirc.ui.StandardUI = new Class({ }, resetTabComplete: function() { this.tabCompleter.reset(); + }, + setModifiableStylesheet: function(name) { + this.__styleSheet = new qwebirc.ui.style.ModifiableStylesheet(qwebirc.global.staticBaseURL + "css/" + name + qwebirc.FILE_SUFFIX + ".mcss"); + + if($defined(this.options.hue)) { + this.setModifiableStylesheetValues(this.options.hue, 0, 0); + } else { + this.setModifiableStylesheetValues(this.uiOptions.STYLE_HUE, 0, 0); + } + }, + setModifiableStylesheetValues: function(hue, saturation, lightness) { + if(!$defined(this.__styleSheet)) + return; + this.__styleSheet.set(function(x) { + return x.setHue(hue).setSaturation(x.hsb[1] + saturation).setBrightness(x.hsb[2] + lightness); + }); } }); -qwebirc.ui.SoundUI = new Class({ +qwebirc.ui.NotificationUI = new Class({ Extends: qwebirc.ui.StandardUI, initialize: function(parentElement, windowClass, uiName, options) { this.parent(parentElement, windowClass, uiName, options); - this.soundInited = false; - this.soundReady = false; + this.__beeper = new qwebirc.ui.Beeper(this.uiOptions); + this.__flasher = new qwebirc.ui.Flasher(this.uiOptions); - this.setBeepOnMention(this.uiOptions.BEEP_ON_MENTION); - }, - soundInit: function() { - if(this.soundInited) - return; - if(!$defined(Browser.Plugins.Flash) || Browser.Plugins.Flash.version < 8) - return; - this.soundInited = true; + this.beep = this.__beeper.beep.bind(this.__beeper); - this.soundPlayer = new qwebirc.sound.SoundPlayer(); - this.soundPlayer.addEvent("ready", function() { - this.soundReady = true; - }.bind(this)); - this.soundPlayer.go(); + this.flash = this.__flasher.flash.bind(this.__flasher); + this.cancelFlash = this.__flasher.cancelFlash.bind(this.__flasher); }, setBeepOnMention: function(value) { if(value) - this.soundInit(); - this.beepOnMention = value; + this.__beeper.soundInit(); }, - beep: function() { - if(!this.soundReady || !this.beepOnMention) - return; - - this.soundPlayer.beep(); + updateTitle: function(text) { + if(this.__flasher.updateTitle(text)) + this.parent(text); + }, + focusChange: function(value) { + this.parent(value); + this.__flasher.focusChange(value); + } +}); + +qwebirc.ui.NewLoginUI = new Class({ + Extends: qwebirc.ui.NotificationUI, + loginBox: function(callbackfn, initialNickname, initialChannels, autoConnect, autoNick) { + this.postInitialize(); + + /* I'd prefer something shorter and snappier! */ + var w = this.newCustomWindow("Connection details", true, qwebirc.ui.WINDOW_CONNECT); + var callback = function(args) { + w.close(); + callbackfn(args); + }; + + qwebirc.ui.GenericLoginBox(w.lines, callback, initialNickname, initialChannels, autoConnect, autoNick, this.options.networkName); } }); qwebirc.ui.QuakeNetUI = new Class({ - Extends: qwebirc.ui.SoundUI, + Extends: qwebirc.ui.NewLoginUI, urlDispatcher: function(name, window) { if(name == "qwhois") { return ["span", function(auth) { this.client.exec("/MSG Q whois #" + auth); }.bind(window)]; } - if(name == "whois") { - return ["span", function(nick) { - this.client.exec("/WHOIS " + nick); - }.bind(window)]; - } - return this.parent(name); + return this.parent(name, window); }, logout: function() { if(!qwebirc.auth.loggedin()) @@ -306,22 +416,58 @@ qwebirc.ui.QuakeNetUI = new Class({ for(var client in this.clients) { this.clients[client].quit("Logged out"); }; - document.location = "/auth?logout=1"; + + /* HACK */ + var foo = function() { document.location = qwebirc.global.dynamicBaseURL + "auth?logout=1"; }; + foo.delay(500); } } }); -qwebirc.ui.NewLoginUI = new Class({ - Extends: qwebirc.ui.QuakeNetUI, - loginBox: function(callbackfn, initialNickname, initialChannels, autoConnect, autoNick) { - this.postInitialize(); +qwebirc.ui.RootUI = qwebirc.ui.QuakeNetUI; + +qwebirc.ui.RequestTransformHTML = function(options) { + var HREF_ELEMENTS = { + "IMG": 1 + }; + + var update = options.update; + var onSuccess = options.onSuccess; + + var fixUp = function(node) { + if(node.nodeType != 1) + return; + + var tagName = node.nodeName.toUpperCase(); + if(HREF_ELEMENTS[tagName]) { + var attr = node.getAttribute("transform_attr"); + var value = node.getAttribute("transform_value"); + if($defined(attr) && $defined(value)) { + node.removeAttribute("transform_attr"); + node.removeAttribute("transform_value"); + node.setAttribute(attr, qwebirc.global.staticBaseURL + value); + } + } + + for(var i=0;i 0) { + var x = container.firstChild; + container.removeChild(x); + update.appendChild(x); + } + onSuccess(); + }; + + return new Request.HTML(options); +}; - var w = this.newCustomWindow("Connect", true, qwebirc.ui.WINDOW_CONNECT); - var callback = function(args) { - w.close(); - callbackfn(args); - }; - - qwebirc.ui.GenericLoginBox(w.lines, callback, initialNickname, initialChannels, autoConnect, autoNick); - } -});