]> jfr.im git - irc/quakenet/qwebirc.git/blame - js/ui/genericlogin.js
Prettify the embedded wizard and fix it for IE.
[irc/quakenet/qwebirc.git] / js / ui / genericlogin.js
CommitLineData
e20e5a6b 1qwebirc.ui.GenericLoginBox = function(parentElement, callback, initialNickname, initialChannels, autoConnect, autoNick) {
66de775f 2 if(autoConnect) {
e20e5a6b 3 qwebirc.ui.ConfirmBox(parentElement, callback, initialNickname, initialChannels, autoNick);
66de775f 4 } else {
e20e5a6b 5 qwebirc.ui.LoginBox(parentElement, callback, initialNickname, initialChannels);
66de775f
CP
6 }
7}
8
e20e5a6b 9qwebirc.ui.ConfirmBox = function(parentElement, callback, initialNickname, initialChannels, autoNick) {
90b89aee
CP
10 var box = new Element("table");
11 box.addClass("confirmbox");
66de775f
CP
12 parentElement.appendChild(box);
13
95ce57b3
CP
14 var tbody = new Element("tbody");
15 box.appendChild(tbody);
16
90b89aee 17 var tr = new Element("tr");
95ce57b3 18 tbody.appendChild(tr);
90b89aee
CP
19 tr.addClass("tr1");
20
21 var text = new Element("td");
22 tr.appendChild(text);
23
66de775f
CP
24 var nick = new Element("b");
25 nick.set("text", initialNickname);
26
290c60db 27 var c = initialChannels.split(" ")[0].split(",");
66de775f 28
290c60db
CP
29 text.appendChild(document.createTextNode("To connect to IRC and join channel" + ((c.length>1)?"s":"") + " "));
30
31 for(var i=0;i<c.length;i++) {
32 if((c.length > 1) && (i == c.length - 1)) {
33 text.appendChild(document.createTextNode(" and "));
34 } else if(i > 0) {
35 text.appendChild(document.createTextNode(", "));
36 }
37 text.appendChild(new Element("b").set("text", c[i]));
38
66de775f
CP
39 }
40
66de775f
CP
41 if(!autoNick) {
42 text.appendChild(document.createTextNode(" as "));
43 text.appendChild(nick);
44 }
45 text.appendChild(document.createTextNode(" click 'Connect'."));
46
90b89aee 47 var tr = new Element("tr");
95ce57b3 48 tbody.appendChild(tr);
90b89aee 49 tr.addClass("tr2");
66de775f 50
90b89aee
CP
51 var td = new Element("td");
52 tr.appendChild(td);
53
66de775f 54 var form = new Element("form");
90b89aee 55 td.appendChild(form);
66de775f
CP
56
57 var yes = new Element("input", {"type": "submit", "value": "Connect"});
58 form.appendChild(yes);
70638ce4 59 yes.focus();
66de775f
CP
60
61 form.addEvent("submit", function(e) {
62 new Event(e).stop();
63 parentElement.removeChild(box);
64 callback({"nickname": initialNickname, "autojoin": initialChannels});
65 });
66}
67
e20e5a6b 68qwebirc.ui.LoginBox = function(parentElement, callback, initialNickname, initialChannels) {
90b89aee 69 var box = new Element("table");
66de775f 70 parentElement.appendChild(box);
90b89aee
CP
71 box.addClass("loginbox");
72
95ce57b3
CP
73 var tbody = new Element("tbody");
74 box.appendChild(tbody);
75
90b89aee 76 var tr = new Element("tr");
95ce57b3 77 tbody.appendChild(tr);
90b89aee 78 tr.addClass("tr1");
66de775f 79
90b89aee
CP
80 var td = new Element("td");
81 tr.appendChild(td);
82 td.set("html", "<h1>Connect to IRC</h1>");
95ce57b3 83
90b89aee 84 var tr = new Element("tr");
95ce57b3 85 tbody.appendChild(tr);
90b89aee
CP
86 tr.addClass("tr2");
87
90b89aee
CP
88 var td = new Element("td");
89 tr.appendChild(td);
95ce57b3 90
66de775f 91 var form = new Element("form");
90b89aee 92 td.appendChild(form);
66de775f
CP
93
94 var boxtable = new Element("table");
95 form.appendChild(boxtable);
96
97 var tbody = new Element("tbody");
98 boxtable.appendChild(tbody); /* stupid IE */
99
100 function createRow(label, e2) {
101 var r = new Element("tr");
102 tbody.appendChild(r);
103
104 var d1 = new Element("td");
105 if(label)
106 d1.set("text", label);
107 r.appendChild(d1);
108
109 var d2 = new Element("td");
110 r.appendChild(d2);
111 d2.appendChild(e2);
112 return d1;
113 }
114
115 var nick = new Element("input");
116 createRow("Nickname:", nick);
117 var chan = new Element("input");
90b89aee 118 createRow("Channels:", chan);
66de775f
CP
119
120 var connbutton = new Element("input", {"type": "submit"});
121 connbutton.set("value", "Connect");
122 createRow(undefined, connbutton)
123
124 form.addEvent("submit", function(e) {
125 new Event(e).stop();
126 var nickname = nick.value;
127 var chans = chan.value;
128 if(chans == "#") /* sorry channel "#" :P */
129 chans = "";
130
131 if(!nickname) {
132 alert("You must supply a nickname.");
133 nick.focus();
134 return;
135 }
136
137 parentElement.removeChild(box);
138
139 callback({"nickname": nickname, "autojoin": chans});
140 }.bind(this));
141
142 nick.set("value", initialNickname);
143 chan.set("value", initialChannels);
144
145 nick.focus();
cad18909 146}