qwebirc.ui.WINDOW_MESSAGES = 0x20;
qwebirc.ui.CUSTOM_CLIENT = "custom";
+qwebirc.ui.DEFAULT_HUE = 210; /* nice blue */
qwebirc.ui.BaseUI = new Class({
Implements: [Events],
if(!this.firstClient) {
this.firstClient = true;
w.addLine("", "qwebirc v" + qwebirc.VERSION);
- w.addLine("", "Copyright (C) 2008-2014 Chris Porter and the qwebirc project.");
+ w.addLine("", "Copyright (C) 2008-2017 Chris Porter and the qwebirc project.");
w.addLine("", "http://www.qwebirc.org");
w.addLine("", "Licensed under the GNU General Public License, Version 2.");
}
if(!$defined(c))
return null;
- return c[this.getWindowIdentifier(client, type, name)];
+ return c.get(this.getWindowIdentifier(client, type, name));
},
getActiveWindow: function() {
return this.active;
},
+ getStatusWindow: function(client) {
+ return this.windows.get(this.getClientId(client)).get(this.getWindowIdentifier(client, qwebirc.ui.WINDOW_STATUS));
+ },
getActiveIRCWindow: function(client) {
if(!this.active || this.active.type == qwebirc.ui.WINDOW_CUSTOM) {
- return this.windows.get(this.getClientId(client)).get(this.getWindowIdentifier(client, qwebirc.ui.WINDOW_STATUS));
+ return this.getStatusWindow(client);
} else {
return this.active;
}
this.postInitialize();
this.addCustomWindow("Connect", qwebirc.ui.ConnectPane, "connectpane", {
- initialNickname: initialNickname, initialChannels: initialChannels, autoConnect: autoConnect, networkName: this.options.networkName, callback: callback, autoNick: autoNick
+ initialNickname: initialNickname, initialChannels: initialChannels, autoConnect: autoConnect, callback: callback, autoNick: autoNick,
+ uiOptions: this.options
}, qwebirc.ui.WINDOW_CONNECT);
},
focusChange: function(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.UICommands = this.__build_menu_items(options);
+
+ this.__styleValues = {hue: qwebirc.ui.DEFAULT_HUE, saturation: 0, lightness: 0, textHue: null, textSaturation: null, textLightness: null};
+ if($defined(this.options.hue)) this.__styleValues.hue = this.options.hue;
this.tabCompleter = new qwebirc.ui.TabCompleterFactory(this);
this.uiOptions = new qwebirc.ui.DefaultOptionsClass(this, options.uiOptionsArg);
this.customWindows = new QHash();
-
- this.__styleValues = {hue: this.uiOptions.STYLE_HUE, saturation: 0, lightness: 0};
- if($defined(this.options.hue)) this.__styleValues.hue = this.options.hue;
+
if($defined(this.options.saturation)) this.__styleValues.saturation = this.options.saturation;
if($defined(this.options.lightness)) this.__styleValues.lightness = this.options.lightness;
+ if($defined(this.options.tsaturation)) this.__styleValues.textSaturation = this.options.tsaturation;
+ if($defined(this.options.tlightness)) this.__styleValues.textLightness = this.options.tlightness;
+
+ if($defined(this.options.hue)) { /* overridden in url */
+ /* ugh... this will go away when we add proper options for hue/sat/light for text and background */
+ this.uiOptions.setValueByPrefix("STYLE_HUE", this.__styleValues.hue);
+ } else {
+ this.__styleValues.hue = this.uiOptions.STYLE_HUE; /* otherwise copy from serialised store */
+ }
+ this.__styleValues.textHue = $defined(this.options.thue) ? this.options.thue : this.__styleValues.hue;
- if(this.options.thue !== null) this.__styleValues.textHue = this.options.thue;
- if(this.options.tsaturation !== null) this.__styleValues.textSaturation = this.options.tsaturation;
- if(this.options.tlightness !== null) this.__styleValues.textLightness = this.options.tlightness;
-
document.addEvent("keydown", this.__handleHotkey.bind(this));
},
+ __build_menu_items: function(options) {
+ var r = [];
+ var seenAbout = null;
+
+ for(var i=0;i<qwebirc.ui.UI_COMMANDS_P1.length;i++)
+ r.push([true, qwebirc.ui.UI_COMMANDS_P1[i]]);
+ for(var i=0;i<options.customMenuItems.length;i++)
+ r.push([false, options.customMenuItems[i]]);
+ for(var i=0;i<qwebirc.ui.UI_COMMANDS_P2.length;i++)
+ r.push([true, qwebirc.ui.UI_COMMANDS_P2[i]]);
+
+ var r2 = []
+ for(var i=0;i<r.length;i++) {
+ var preset = r[i][0], c = r[i][1];
+
+ if(c[0] == "About qwebirc") { /* HACK */
+ if(!preset) {
+ seenAbout = c;
+ continue;
+ } else if(seenAbout) {
+ c = seenAbout;
+ preset = false;
+ }
+ }
+
+ if(preset) {
+ r2.push([c[0], this[c[1] + "Window"].bind(this)]);
+ } else {
+ r2.push([c[0], (function(c) { return function() {
+ this.addCustomWindow(c[0], qwebirc.ui.URLPane, "urlpane", {url: c[1]});
+ }.bind(this); }).call(this, c)]);
+ }
+ }
+
+ return r2;
+ },
__handleHotkey: function(x) {
var success = false;
- if(!x.alt || x.control) {
+ if(!x.alt && !x.control && !x.shift && !x.meta) {
if((x.key == "backspace" || x.key == "/") && !this.getInputFocused(x)) {
success = true;
}
+ } else if(!x.alt || x.control || x.meta) {
+ /* do nothing */
} else if(x.key == "a" || x.key == "A") {
var highestNum = 0;
var highestIndex = -1;
}
if(highestIndex > -1)
this.selectWindow(this.windowArray[highestIndex]);
- } else if(x.key >= '0' && x.key <= '9') {
+ } else if((x.key >= '0' && x.key <= '9') && !x.shift) {
success = true;
number = x.key - '0';
return;
this.selectWindow(this.windowArray[number]);
- } else if(x.key == "left") {
+ } else if((x.key == "left" || x.key == "up") && !x.shift) {
this.prevWindow();
success = true;
- } else if(x.key == "right") {
+ } else if((x.key == "right" || x.key == "down") && !x.shift) {
this.nextWindow();
success = true;
}
+
if(success) {
new Event(x).stop();
x.preventDefault();
this.addCustomWindow("Options", qwebirc.ui.OptionsPane, "optionspane", this.uiOptions);
},
aboutWindow: function() {
- this.addCustomWindow("About", qwebirc.ui.AboutPane, "aboutpane", this.uiOptions);
- },
- privacyWindow: function() {
- this.addCustomWindow("Privacy policy", qwebirc.ui.PrivacyPolicyPane, "privacypolicypane", this.uiOptions);
+ this.addCustomWindow("About qwebirc", qwebirc.ui.AboutPane, "aboutpane", this.uiOptions);
},
feedbackWindow: function() {
this.addCustomWindow("Feedback", qwebirc.ui.FeedbackPane, "feedbackpane", this.uiOptions);
},
- helpWindow: function() {
- this.addCustomWindow("Help!", qwebirc.ui.HelpPane, "helppane", this.uiOptions);
- },
urlDispatcher: function(name, window) {
if(name == "embedded")
return ["a", this.embeddedWindow.bind(this)];
return null;
},
- tabComplete: function(element) {
- this.tabCompleter.tabComplete(element);
+ tabComplete: function(element, backwards) {
+ this.tabCompleter.tabComplete(element, backwards);
},
resetTabComplete: function() {
this.tabCompleter.reset();
this.setModifiableStylesheetValues({});
},
setModifiableStylesheetValues: function(values) {
- for(var k in values)
+ for (var k in values)
this.__styleValues[k] = values[k];
-
- if(!$defined(this.__styleSheet))
+
+ if (!$defined(this.__styleSheet))
return;
-
- var back = {hue: this.__styleValues.hue, lightness: this.__styleValues.lightness, saturation: this.__styleValues.saturation};
- var front = {hue: this.__styleValues.textHue, lightness: this.__styleValues.textLightness, saturation: this.__styleValues.textSaturation};
- if(!this.__styleValues.textHue && !this.__styleValues.textLightness && !this.__styleValues.textSaturation)
+ var back = {hue: this.__styleValues.hue, lightness: this.__styleValues.lightness, saturation: this.__styleValues.saturation};
+ var front;
+ if (!$defined(this.__styleValues.textHue) && !$defined(this.__styleValues.textLightness) && !$defined(this.__styleValues.textSaturation)) {
front = back;
-
+ } else {
+ front = {hue: Number(this.__styleValues.textHue), lightness: Number(this.__styleValues.textLightness), saturation: Number(this.__styleValues.textSaturation)}
+ }
var colours = {
back: back,
front: front
urlDispatcher: function(name, window) {
if(name == "qwhois") {
return ["span", function(auth) {
- this.client.exec("/MSG Q whois #" + auth);
+ if($defined(this.parentObject.options.accountWhoisCommand))
+ this.client.exec(this.parentObject.options.accountWhoisCommand + auth);
}.bind(window)];
}
return this.parent(name, window);