-var QUIWindow = new Class({
- Extends: UIWindow,
-
- initialize: function(parentObject, client, type, name) {
- this.parent(parentObject, client, type, name);
-
- this.tab = new Element("a", {"href": "#"});
- this.tab.addClass("tab");
-
- this.tab.appendText(name);
- this.tab.addEvent("click", function(e) {
- new Event(e).stop();
- parentObject.selectWindow(this);
+qwebirc.ui.QUI = new Class({
+ Extends: qwebirc.ui.NewLoginUI,
+ initialize: function(parentElement, theme, options) {
+ this.parent(parentElement, qwebirc.ui.QUI.Window, "qui", options);
+ this.theme = theme;
+ this.parentElement = parentElement;
+ },
+ postInitialize: function() {
+ this.qjsui = new qwebirc.ui.QUI.JSUI("qwebirc-qui", this.parentElement);
+ this.qjsui.addEvent("reflow", function() {
+ var w = this.getActiveWindow();
+ if($defined(w))
+ w.onResize();
}.bind(this));
-
- parentObject.tabs.appendChild(this.tab);
+ this.qjsui.top.addClass("tabbar");
- if(type != WINDOW_STATUS) {
- tabclose = new Element("span");
- tabclose.addClass("tabclose");
- tabclose.addEvent("click", function(e) {
- new Event(e).stop();
-
- if(type == WINDOW_CHANNEL)
- this.client.exec("/PART " + name);
-
- this.close();
- }.bind(this));
- tabclose.set("text", "X");
- this.tab.appendChild(tabclose);
- }
-
- this.parentObject.reflow();
+ this.qjsui.bottom.addClass("input");
+ this.qjsui.right.addClass("nicklist");
+ this.qjsui.topic.addClass("topic");
+ this.qjsui.middle.addClass("lines");
- this.window = new Element("div");
- this.window.addClass("window");
- parentObject.container.appendChild(this.window);
+ this.tabs = this.qjsui.top;
+ this.origtopic = this.topic = this.qjsui.topic;
+ this.origlines = this.lines = this.qjsui.middle;
+ this.orignicklist = this.nicklist = this.qjsui.right;
- this.lines = new Element("div");
- this.lines.addClass("lines");
- this.window.appendChild(this.lines);
+ this.input = this.qjsui.bottom;
+ this.reflow = this.qjsui.reflow.bind(this.qjsui);
- var formdiv = new Element("div");
- this.window.appendChild(formdiv);
- this.formdiv = formdiv;
+ this.tabs.addEvent("mousewheel", function(x) {
+ var event = new Event(x);
+
+ /* up */
+ if(event.wheel > 0) {
+ this.nextWindow();
+ } else if(event.wheel < 0) {
+ /* down */
+ this.prevWindow();
+ }
+ event.stop();
+ }.bind(this));
+ this.createInput();
+ this.reflow();
+ },
+ createInput: function() {
var form = new Element("form");
+ this.input.appendChild(form);
+ form.addClass("input");
+
var inputbox = new Element("input");
+ form.appendChild(inputbox);
+ this.inputbox = inputbox;
- formdiv.addClass("input");
-
form.addEvent("submit", function(e) {
new Event(e).stop();
- this.historyExec(inputbox.value);
+ if(inputbox.value == "")
+ return;
+
+ this.resetTabComplete();
+ this.getActiveWindow().historyExec(inputbox.value);
inputbox.value = "";
}.bind(this));
- formdiv.appendChild(form);
- form.appendChild(inputbox);
- inputbox.addEvent("keypress", function(e) {
- var result;
+ inputbox.addEvent("focus", this.resetTabComplete.bind(this));
+ inputbox.addEvent("mousedown", this.resetTabComplete.bind(this));
+
+ inputbox.addEvent("keydown", function(e) {
+ var resultfn;
+ var cvalue = inputbox.value;
+
if(e.key == "up") {
- result = this.commandhistory.nextLine();
+ resultfn = this.commandhistory.upLine;
} else if(e.key == "down") {
- result = this.commandhistory.prevLine();
+ resultfn = this.commandhistory.downLine;
+ } else if(e.key == "tab") {
+ new Event(e).stop();
+ this.tabComplete(inputbox);
+ return;
} else {
+ /* ideally alt and other keys wouldn't break this */
+ this.resetTabComplete();
return;
}
+ this.resetTabComplete();
+ if((cvalue != "") && (this.lastcvalue != cvalue))
+ this.commandhistory.addLine(cvalue, true);
+
+ var result = resultfn.bind(this.commandhistory)();
+
new Event(e).stop();
if(!result)
- result = ""
+ result = "";
+ this.lastcvalue = result;
+
inputbox.value = result;
- setAtEnd(inputbox);
+ qwebirc.util.setAtEnd(inputbox);
}.bind(this));
- this.inputbox = inputbox;
+ },
+ setLines: function(lines) {
+ this.lines.parentNode.replaceChild(lines, this.lines);
+ this.qjsui.middle = this.lines = lines;
+ },
+ setChannelItems: function(nicklist, topic) {
+ if(!$defined(nicklist)) {
+ nicklist = this.orignicklist;
+ topic = this.origtopic;
+ }
+ this.nicklist.parentNode.replaceChild(nicklist, this.nicklist);
+ this.qjsui.right = this.nicklist = nicklist;
+
+ this.topic.parentNode.replaceChild(topic, this.topic);
+ this.qjsui.topic = this.topic = topic;
+ }
+});
+
+qwebirc.ui.QUI.JSUI = new Class({
+ Implements: [Events],
+ initialize: function(class_, parent, sizer) {
+ this.parent = parent;
+ this.sizer = $defined(sizer)?sizer:parent;
- var toppos = 0;
- var rightpos = 0;
- var bottompos = formdiv.getSize().y;
+ this.class_ = class_;
+ this.create();
- if(type == WINDOW_CHANNEL) {
- this.topic = new Element("div");
- this.topic.addClass("topic");
- this.topic.set("html", " ");
+ this.reflowevent = null;
+
+ window.addEvent("resize", function() {
+ this.reflow(100);
+ }.bind(this));
+ },
+ applyClasses: function(pos, l) {
+ l.addClass("dynamicpanel");
+ l.addClass(this.class_);
+
+ if(pos == "middle") {
+ l.addClass("leftboundpanel");
+ } else if(pos == "top") {
+ l.addClass("topboundpanel");
+ l.addClass("widepanel");
+ } else if(pos == "topic") {
+ l.addClass("widepanel");
+ } else if(pos == "right") {
+ l.addClass("rightboundpanel");
+ } else if(pos == "bottom") {
+ l.addClass("bottomboundpanel");
+ l.addClass("widepanel");
+ }
+ },
+ create: function() {
+ var XE = function(pos) {
+ var element = new Element("div");
+ this.applyClasses(pos, element);
- this.window.appendChild(this.topic);
+ this.parent.appendChild(element);
+ return element;
+ }.bind(this);
+
+ this.top = XE("top");
+ this.topic = XE("topic");
+ this.middle = XE("middle");
+ this.right = XE("right");
+ this.bottom = XE("bottom");
+ },
+ reflow: function(delay) {
+ if(!delay)
+ delay = 1;
- this.nicklist = new Element("div");
- this.nicklist.addClass("nicklist");
+ if(this.reflowevent)
+ $clear(this.reflowevent);
+ this.__reflow();
+ this.reflowevent = this.__reflow.delay(delay, this);
+ },
+ __reflow: function() {
+ var bottom = this.bottom;
+ var middle = this.middle;
+ var right = this.right;
+ var topic = this.topic;
+ var top = this.top;
+
+ var topicsize = topic.getSize();
+ var topsize = top.getSize();
+ var rightsize = right.getSize();
+ var bottomsize = bottom.getSize();
+ var docsize = this.sizer.getSize();
+
+ var mheight = (docsize.y - topsize.y - bottomsize.y - topicsize.y);
+ var mwidth = (docsize.x - rightsize.x);
+
+ topic.setStyle("top", topsize.y + "px");
+
+ middle.setStyle("top", (topsize.y + topicsize.y) + "px");
+ if(mheight > 0) {
+ middle.setStyle("height", mheight + "px");
+ right.setStyle("height", mheight + "px");
+ }
+
+ if(mwidth > 0)
+ middle.setStyle("width", mwidth + "px");
+ right.setStyle("top", (topsize.y + topicsize.y) + "px");
+ right.setStyle("left", mwidth + "px");
+
+ bottom.setStyle("top", (docsize.y - bottomsize.y) + "px");
+ this.fireEvent("reflow");
+ },
+ showChannel: function(state) {
+ var display = "none";
+ if(state)
+ display = "block";
+
+ this.right.setStyle("display", display);
+ this.topic.setStyle("display", display);
+ },
+ showInput: function(state) {
+ this.bottom.setStyle("display", state?"block":"none");
+ }
+});
+
+qwebirc.ui.QUI.Window = new Class({
+ Extends: qwebirc.ui.Window,
+
+ initialize: function(parentObject, client, type, name, identifier) {
+ this.parent(parentObject, client, type, name, identifier);
+
+ this.tab = new Element("a", {"href": "#"});
+ this.tab.addClass("tab");
+ this.tab.addEvent("focus", function() { this.blur() }.bind(this.tab));;
+
+ parentObject.tabs.appendChild(this.tab);
+
+ this.tab.appendText(name);
+ this.tab.addEvent("click", function(e) {
+ new Event(e).stop();
- this.window.appendChild(this.nicklist);
+ if(this.closed)
+ return;
+
+ parentObject.selectWindow(this);
+ }.bind(this));
+
+ if(type != qwebirc.ui.WINDOW_STATUS && type != qwebirc.ui.WINDOW_CONNECT) {
+ var tabclose = new Element("span");
+ tabclose.set("text", "X");
+ tabclose.addClass("tabclose");
+ var close = function(e) {
+ new Event(e).stop();
+
+ if(this.closed)
+ return;
+
+ if(type == qwebirc.ui.WINDOW_CHANNEL)
+ this.client.exec("/PART " + name);
+
+ this.close();
+
+ parentObject.inputbox.focus();
+ }.bind(this);
+
+ tabclose.addEvent("click", close);
+ this.tab.addEvent("mouseup", function(e) {
+ var button = 1;
+
+ if(Browser.Engine.trident)
+ button = 4;
+
+ if(e.event.button == button)
+ close(e);
+ }.bind(this));
+
+ this.tab.appendChild(tabclose);
}
+ this.lines = new Element("div");
+ this.parentObject.qjsui.applyClasses("middle", this.lines);
this.lines.addClass("lines");
- if(type == WINDOW_CHANNEL) {
- /* calls reflow */
- this.updateTopic("");
- } else {
- this.reflow();
- }
+ if(type != qwebirc.ui.WINDOW_CUSTOM && type != qwebirc.ui.WINDOW_CONNECT)
+ this.lines.addClass("ircwindow");
this.lines.addEvent("scroll", function() {
this.scrolleddown = this.scrolledDown();
+ this.scrollpos = this.getScrollParent().getScroll();
}.bind(this));
- window.addEvent("resize", function() {
- if(this.scrolleddown)
- this.scrollToBottom();
+ if(type == qwebirc.ui.WINDOW_CHANNEL) {
+ this.topic = new Element("div");
+ this.topic.addClass("topic");
+ this.topic.addClass("tab-invisible");
+ this.topic.set("html", " ");
+ this.parentObject.qjsui.applyClasses("topic", this.topic);
+
+ this.prevNick = null;
+ this.nicklist = new Element("div");
+ this.nicklist.addClass("nicklist");
+ this.nicklist.addClass("tab-invisible");
+ this.nicklist.addEvent("click", this.removePrevMenu.bind(this));
+ this.parentObject.qjsui.applyClasses("nicklist", this.nicklist);
+ }
+
+ if(type == qwebirc.ui.WINDOW_CHANNEL) {
+ this.updateTopic("");
+ } else {
this.reflow();
- }.bind(this));
+ }
},
reflow: function() {
- var toppos = 0;
- var rightpos = 0;
- var bottompos = this.formdiv.getSize().y;
-
- if(this.type == WINDOW_CHANNEL) {
- toppos = this.topic.getSize().y;
-
- this.nicklist.setStyle("top", toppos + "px");
- this.nicklist.setStyle("bottom", (bottompos - 1) + "px");
- rightpos = this.nicklist.getSize().x;
+ this.parentObject.reflow();
+ },
+ onResize: function() {
+ if(this.scrolleddown) {
+ if(Browser.Engine.trident) {
+ this.scrollToBottom.delay(5, this);
+ } else {
+ this.scrollToBottom();
+ }
+ } else if($defined(this.scrollpos)) {
+ if(Browser.Engine.trident) {
+ this.getScrollParent().scrollTo(this.scrollpos.x, this.scrollpos.y);
+ } else {
+ this.getScrollParent().scrollTo.delay(5, this, [this.scrollpos.x, this.scrollpos.y]);
+ }
}
+ },
+ createMenu: function(nick, parent) {
+ var e = new Element("div");
+ parent.appendChild(e);
+ e.addClass("menu");
- this.lines.setStyle("top", toppos + "px");
- this.lines.setStyle("bottom", bottompos + "px");
- this.lines.setStyle("right", rightpos + "px");
+ qwebirc.ui.MENU_ITEMS.forEach(function(x) {
+ var e2 = new Element("a");
+ e.appendChild(e2);
+
+ e2.href = "#";
+ e2.set("text", "- " + x[0]);
+
+ e2.addEvent("focus", function() { this.blur() }.bind(e2));
+ e2.addEvent("click", function(ev) { new Event(ev.stop()); this.menuClick(x[1]); }.bind(this));
+ }.bind(this));
+ return e;
+ },
+ menuClick: function(fn) {
+ /*
+ this.prevNick.removeChild(this.prevNick.menu);
+ this.prevNick.menu = null;
+ */
+ fn.bind(this)(this.prevNick.realNick);
+ this.removePrevMenu();
+ },
+ moveMenuClass: function() {
+ if(!this.prevNick)
+ return;
+ if(this.nicklist.firstChild == this.prevNick) {
+ this.prevNick.removeClass("selected-middle");
+ } else {
+ this.prevNick.addClass("selected-middle");
+ }
+ },
+ removePrevMenu: function() {
+ if(!this.prevNick)
+ return;
+
+ this.prevNick.removeClass("selected");
+ this.prevNick.removeClass("selected-middle");
+ if(this.prevNick.menu)
+ this.prevNick.removeChild(this.prevNick.menu);
+ this.prevNick = null;
},
- updateNickList: function(nicks) {
- this.parent(nicks);
+ nickListAdd: function(nick, position) {
+ var e = new Element("a");
+ qwebirc.ui.insertAt(position, this.nicklist, e);
- var n = this.nicklist;
- while(n.firstChild)
- n.removeChild(n.firstChild);
-
- nicks.each(function(nick) {
- var e = new Element("div");
- n.appendChild(e);
- e.appendChild(document.createTextNode(nick));
- });
+ e.href = "#";
+ e.appendChild(document.createTextNode(nick));
+
+ e.realNick = this.client.stripPrefix(nick);
+
+ e.addEvent("click", function(x) {
+ if(this.prevNick == e) {
+ this.removePrevMenu();
+ return;
+ }
+
+ this.removePrevMenu();
+ this.prevNick = e;
+ e.addClass("selected");
+ this.moveMenuClass();
+ e.menu = this.createMenu(x.realNick, e);
+ new Event(x).stop();
+ }.bind(this));
+ e.addEvent("dblclick", function(x) {
+ new Event(x).stop();
+ this.client.exec("/QUERY " + e.realNick);
+ }.bind(this));
+
+ e.addEvent("focus", function() { this.blur() }.bind(e));
+ this.moveMenuClass();
+ return e;
+ },
+ nickListRemove: function(nick, stored) {
+ this.nicklist.removeChild(stored);
+ this.moveMenuClass();
},
updateTopic: function(topic) {
- this.parent(topic);
-
var t = this.topic;
while(t.firstChild)
t.removeChild(t.firstChild);
if(topic) {
- Colourise("[" + topic + "]", t);
+ this.parent(topic, t);
} else {
var e = new Element("div");
e.set("text", "(no topic set)");
this.reflow();
},
select: function() {
- this.window.removeClass("tab-invisible");
+ var inputVisible = this.type != qwebirc.ui.WINDOW_CONNECT && this.type != qwebirc.ui.WINDOW_CUSTOM;
+
this.tab.removeClass("tab-unselected");
this.tab.addClass("tab-selected");
- this.reflow();
+ this.parentObject.setLines(this.lines);
+ this.parentObject.setChannelItems(this.nicklist, this.topic);
+ this.parentObject.qjsui.showInput(inputVisible);
+ this.parentObject.qjsui.showChannel($defined(this.nicklist));
+
+ this.reflow();
+
this.parent();
- this.inputbox.focus();
+ if(inputVisible)
+ this.parentObject.inputbox.focus();
},
deselect: function() {
this.parent();
- this.window.addClass("tab-invisible");
this.tab.removeClass("tab-selected");
this.tab.addClass("tab-unselected");
},
close: function() {
this.parent();
- this.parentObject.container.removeChild(this.window);
this.parentObject.tabs.removeChild(this.tab);
},
addLine: function(type, line, colour) {
e.addClass("linestyle2");
}
this.lastcolour = !this.lastcolour;
-
+
this.parent(type, line, colour, e);
},
setHilighted: function(state) {
- this.parent(state);
+ laststate = this.hilighted;
- if(state) {
- this.tab.addClass("tab-hilighted");
- } else {
- this.tab.removeClass("tab-hilighted");
- }
- }
-});
+ this.parent(state);
-var QUI = new Class({
- Extends: UI,
- initialize: function(parentElement, theme) {
- this.parent(parentElement, QUIWindow, "qui");
- this.theme = theme;
- this.parentElement = parentElement;
- },
- reflow: function() {
- var tabheight = this.tabs.getSize().y;
- this.container.setStyle("top", tabheight + "px");
- },
- postInitialize: function() {
- this.outerContainer = new Element("div");
- this.outerContainer.addClass("outercontainer");
- this.parentElement.appendChild(this.outerContainer);
-
- this.tabs = new Element("div");
- this.tabs.addClass("tabbar");
- this.outerContainer.appendChild(this.tabs);
-
- var tester = new Element("span");
- this.tabs.appendChild(tester);
+ if(state == laststate)
+ return;
+
+ this.tab.removeClass("tab-hilight-activity");
+ this.tab.removeClass("tab-hilight-us");
+ this.tab.removeClass("tab-hilight-speech");
- this.tabheight = this.tabs.getSize().y;
- this.tabs.removeChild(tester);
-
- this.container = new Element("div");
- this.container.addClass("container");
- this.outerContainer.appendChild(this.container);
- },
- loginBox: function(callbackfn, intialNickname, initialChannels, autoConnect, autoNick) {
- this.parent(function(options) {
- this.postInitialize();
- callbackfn(options);
- }.bind(this), intialNickname, initialChannels, autoConnect, autoNick);
+ switch(this.hilighted) {
+ case qwebirc.ui.HILIGHT_US:
+ this.tab.addClass("tab-hilight-us");
+ break;
+ case qwebirc.ui.HILIGHT_SPEECH:
+ this.tab.addClass("tab-hilight-speech");
+ break;
+ case qwebirc.ui.HILIGHT_ACTIVITY:
+ this.tab.addClass("tab-hilight-activity");
+ break;
+ }
}
});