]>
Commit | Line | Data |
---|---|---|
2cad083e | 1 | qwebirc.ui.GenericLoginBox = function(parentElement, callback, initialNickname, initialChannels, autoConnect, autoNick, networkName) { |
66de775f | 2 | if(autoConnect) { |
2cad083e | 3 | qwebirc.ui.ConfirmBox(parentElement, callback, initialNickname, initialChannels, autoNick, networkName); |
66de775f | 4 | } else { |
2cad083e | 5 | qwebirc.ui.LoginBox(parentElement, callback, initialNickname, initialChannels, networkName); |
66de775f CP |
6 | } |
7 | } | |
8 | ||
fb661c98 CP |
9 | qwebirc.ui.AuthLogin = function(e) { |
10 | var cookie = Cookie.write("redirect", document.location); | |
11 | document.location = "./auth/"; | |
12 | new Event(e).stop(); | |
13 | } | |
14 | ||
2cad083e | 15 | qwebirc.ui.ConfirmBox = function(parentElement, callback, initialNickname, initialChannels, autoNick, networkName) { |
d3ab254a CP |
16 | var outerbox = new Element("table"); |
17 | outerbox.addClass("qwebirc-centrebox"); | |
18 | parentElement.appendChild(outerbox); | |
19 | var tbody = new Element("tbody"); | |
20 | outerbox.appendChild(tbody); | |
21 | var tr = new Element("tr"); | |
22 | tbody.appendChild(tr); | |
23 | var td = new Element("td"); | |
24 | tr.appendChild(td); | |
25 | ||
90b89aee | 26 | var box = new Element("table"); |
e1a91a8a | 27 | box.addClass("qwebirc-confirmbox"); |
d3ab254a | 28 | td.appendChild(box); |
66de775f | 29 | |
95ce57b3 CP |
30 | var tbody = new Element("tbody"); |
31 | box.appendChild(tbody); | |
32 | ||
90b89aee | 33 | var tr = new Element("tr"); |
95ce57b3 | 34 | tbody.appendChild(tr); |
90b89aee CP |
35 | tr.addClass("tr1"); |
36 | ||
37 | var text = new Element("td"); | |
38 | tr.appendChild(text); | |
39 | ||
66de775f CP |
40 | var nick = new Element("b"); |
41 | nick.set("text", initialNickname); | |
42 | ||
290c60db | 43 | var c = initialChannels.split(" ")[0].split(","); |
66de775f | 44 | |
2cad083e | 45 | text.appendChild(document.createTextNode("To connect to " + networkName + " IRC and join channel" + ((c.length>1)?"s":"") + " ")); |
290c60db CP |
46 | |
47 | for(var i=0;i<c.length;i++) { | |
48 | if((c.length > 1) && (i == c.length - 1)) { | |
49 | text.appendChild(document.createTextNode(" and ")); | |
50 | } else if(i > 0) { | |
51 | text.appendChild(document.createTextNode(", ")); | |
52 | } | |
53 | text.appendChild(new Element("b").set("text", c[i])); | |
54 | ||
66de775f CP |
55 | } |
56 | ||
66de775f CP |
57 | if(!autoNick) { |
58 | text.appendChild(document.createTextNode(" as ")); | |
59 | text.appendChild(nick); | |
2cad083e CP |
60 | } |
61 | ||
66de775f | 62 | text.appendChild(document.createTextNode(" click 'Connect'.")); |
74caeb3e | 63 | text.appendChild(new Element("br")); |
6ce70043 | 64 | if(qwebirc.auth.enabled() && qwebirc.auth.quakeNetAuth() && !qwebirc.auth.loggedin()) |
74caeb3e CP |
65 | text.appendChild(document.createTextNode("If you'd like to connect using your Q auth click 'Log in'.")); |
66 | ||
90b89aee | 67 | var tr = new Element("tr"); |
95ce57b3 | 68 | tbody.appendChild(tr); |
90b89aee | 69 | tr.addClass("tr2"); |
66de775f | 70 | |
90b89aee CP |
71 | var td = new Element("td"); |
72 | tr.appendChild(td); | |
73 | ||
66de775f | 74 | var yes = new Element("input", {"type": "submit", "value": "Connect"}); |
f065bc69 | 75 | td.appendChild(yes); |
70638ce4 | 76 | yes.focus(); |
f065bc69 | 77 | yes.addEvent("click", function(e) { |
5fc104ff | 78 | parentElement.removeChild(outerbox); |
66de775f CP |
79 | callback({"nickname": initialNickname, "autojoin": initialChannels}); |
80 | }); | |
f065bc69 | 81 | |
6ce70043 | 82 | if(qwebirc.auth.enabled() && qwebirc.auth.quakeNetAuth() && !qwebirc.auth.loggedin()) { |
f065bc69 CP |
83 | var auth = new Element("input", {"type": "submit", "value": "Log in"}); |
84 | td.appendChild(auth); | |
fb661c98 | 85 | auth.addEvent("click", qwebirc.ui.AuthLogin); |
f065bc69 | 86 | } |
66de775f CP |
87 | } |
88 | ||
2cad083e | 89 | qwebirc.ui.LoginBox = function(parentElement, callback, initialNickname, initialChannels, networkName) { |
d3ab254a CP |
90 | var outerbox = new Element("table"); |
91 | outerbox.addClass("qwebirc-centrebox"); | |
92 | parentElement.appendChild(outerbox); | |
93 | var tbody = new Element("tbody"); | |
94 | outerbox.appendChild(tbody); | |
95 | var tr = new Element("tr"); | |
96 | tbody.appendChild(tr); | |
97 | var td = new Element("td"); | |
98 | tr.appendChild(td); | |
99 | ||
90b89aee | 100 | var box = new Element("table"); |
e1a91a8a | 101 | box.addClass("qwebirc-loginbox"); |
d3ab254a | 102 | td.appendChild(box); |
90b89aee | 103 | |
95ce57b3 CP |
104 | var tbody = new Element("tbody"); |
105 | box.appendChild(tbody); | |
106 | ||
90b89aee | 107 | var tr = new Element("tr"); |
95ce57b3 | 108 | tbody.appendChild(tr); |
90b89aee | 109 | tr.addClass("tr1"); |
66de775f | 110 | |
90b89aee CP |
111 | var td = new Element("td"); |
112 | tr.appendChild(td); | |
2cad083e | 113 | td.set("html", "<h1>Connect to " + networkName + " IRC</h1>"); |
95ce57b3 | 114 | |
90b89aee | 115 | var tr = new Element("tr"); |
95ce57b3 | 116 | tbody.appendChild(tr); |
90b89aee CP |
117 | tr.addClass("tr2"); |
118 | ||
90b89aee CP |
119 | var td = new Element("td"); |
120 | tr.appendChild(td); | |
95ce57b3 | 121 | |
66de775f | 122 | var form = new Element("form"); |
90b89aee | 123 | td.appendChild(form); |
66de775f CP |
124 | |
125 | var boxtable = new Element("table"); | |
126 | form.appendChild(boxtable); | |
127 | ||
128 | var tbody = new Element("tbody"); | |
129 | boxtable.appendChild(tbody); /* stupid IE */ | |
130 | ||
2f74dea9 | 131 | function createRow(label, e2, style) { |
66de775f CP |
132 | var r = new Element("tr"); |
133 | tbody.appendChild(r); | |
134 | ||
135 | var d1 = new Element("td"); | |
136 | if(label) | |
137 | d1.set("text", label); | |
138 | r.appendChild(d1); | |
139 | ||
140 | var d2 = new Element("td"); | |
141 | r.appendChild(d2); | |
2f74dea9 CP |
142 | |
143 | if($defined(e2)) | |
144 | d2.appendChild(e2); | |
145 | if($defined(style)) { | |
146 | r.setStyles(style); | |
147 | return [r, d2]; | |
148 | } | |
149 | ||
fb661c98 | 150 | return d2; |
66de775f CP |
151 | } |
152 | ||
153 | var nick = new Element("input"); | |
154 | createRow("Nickname:", nick); | |
6ce70043 CP |
155 | |
156 | var chanStyle = null; | |
157 | if(qwebirc.auth.enabled() && qwebirc.auth.bouncerAuth()) | |
158 | chanStyle = {display: "none"}; | |
159 | ||
66de775f | 160 | var chan = new Element("input"); |
6ce70043 | 161 | createRow("Channels:", chan, chanStyle); |
66de775f | 162 | |
6ce70043 CP |
163 | if(qwebirc.auth.enabled()) { |
164 | if(qwebirc.auth.passAuth()) { | |
165 | var authRow = createRow("Auth to services:"); | |
166 | var authCheckBox = qwebirc.util.createInput("checkbox", authRow, "connect_auth_to_services", false); | |
2f74dea9 | 167 | |
6ce70043 CP |
168 | var usernameBox = new Element("input"); |
169 | var usernameRow = createRow("Username:", usernameBox, {display: "none"})[0]; | |
2f74dea9 | 170 | |
6ce70043 CP |
171 | var passwordRow = createRow("Password:", null, {display: "none"}); |
172 | var passwordBox = qwebirc.util.createInput("password", passwordRow[1], "connect_auth_password"); | |
2f74dea9 | 173 | |
6ce70043 CP |
174 | authCheckBox.addEvent("click", function(e) { qwebirc.ui.authShowHide(authCheckBox, authRow, usernameBox, usernameRow, passwordRow[0]) }); |
175 | } else if(qwebirc.auth.bouncerAuth()) { | |
176 | var passwordRow = createRow("Password:"); | |
177 | var passwordBox = qwebirc.util.createInput("password", passwordRow, "connect_auth_password"); | |
178 | } | |
2f74dea9 CP |
179 | } |
180 | ||
66de775f CP |
181 | var connbutton = new Element("input", {"type": "submit"}); |
182 | connbutton.set("value", "Connect"); | |
2f74dea9 CP |
183 | var r = createRow(undefined, connbutton); |
184 | ||
185 | if(qwebirc.auth.enabled() && qwebirc.auth.quakeNetAuth() && !qwebirc.auth.loggedin()) { | |
fb661c98 CP |
186 | var auth = new Element("input", {"type": "submit", "value": "Log in"}); |
187 | r.appendChild(auth); | |
188 | auth.addEvent("click", qwebirc.ui.AuthLogin); | |
189 | } | |
66de775f CP |
190 | |
191 | form.addEvent("submit", function(e) { | |
192 | new Event(e).stop(); | |
193 | var nickname = nick.value; | |
194 | var chans = chan.value; | |
195 | if(chans == "#") /* sorry channel "#" :P */ | |
196 | chans = ""; | |
197 | ||
198 | if(!nickname) { | |
199 | alert("You must supply a nickname."); | |
200 | nick.focus(); | |
201 | return; | |
202 | } | |
203 | ||
2f74dea9 | 204 | var data = {"nickname": nickname, "autojoin": chans}; |
6ce70043 CP |
205 | if(qwebirc.auth.passAuth() && authCheckBox.checked) { |
206 | if(!usernameBox.value || !passwordBox.value) { | |
207 | alert("You must supply your username and password in auth mode."); | |
208 | if(!usernameBox.value) { | |
209 | usernameBox.focus(); | |
210 | } else { | |
211 | passwordBox.focus(); | |
212 | } | |
213 | return; | |
214 | } | |
215 | ||
216 | data["serverPassword"] = usernameBox.value + " " + passwordBox.value; | |
217 | } else if(qwebirc.auth.bouncerAuth()) { | |
218 | if(!passwordBox.value) { | |
219 | alert("You must supply a password."); | |
220 | passwordBox.focus(); | |
221 | return; | |
222 | } | |
2f74dea9 | 223 | |
6ce70043 CP |
224 | data["serverPassword"] = passwordBox.value; |
225 | } | |
226 | ||
227 | parentElement.removeChild(outerbox); | |
228 | ||
2f74dea9 | 229 | callback(data); |
66de775f | 230 | }.bind(this)); |
6ce70043 | 231 | |
66de775f CP |
232 | nick.set("value", initialNickname); |
233 | chan.set("value", initialChannels); | |
234 | ||
235 | nick.focus(); | |
cad18909 | 236 | } |
2f74dea9 CP |
237 | |
238 | qwebirc.ui.authShowHide = function(checkbox, authRow, usernameBox, usernameRow, passwordRow) { | |
239 | var visible = checkbox.checked; | |
240 | var display = visible?null:"none"; | |
241 | usernameRow.setStyle("display", display); | |
242 | passwordRow.setStyle("display", display); | |
243 | ||
244 | if(visible) { | |
245 | // authRow.parentNode.setStyle("display", "none"); | |
246 | usernameBox.focus(); | |
247 | } | |
248 | } |