]>
jfr.im git - irc/quakenet/qwebirc.git/blob - js/ui/panes/connect.js
1 qwebirc
.ui
.ConnectPane
= new Class({
3 initialize: function(parent
, options
) {
4 var callback
= options
.callback
, initialNickname
= options
.initialNickname
, initialChannels
= options
.initialChannels
, networkName
= options
.networkName
, autoConnect
= options
.autoConnect
, autoNick
= options
.autoNick
;
5 this.options
= options
;
6 this.__windowName
= "authgate_" + Math
.floor(Math
.random() * 100000);
8 var delayfn = function() { parent
.set("html", "<div class=\"loading\">Loading. . .</div>"); };
9 var cb
= delayfn
.delay(500);
11 var r
= qwebirc
.ui
.RequestTransformHTML({url: qwebirc
.global
.staticBaseURL
+ "panes/connect.html", update: parent
, onSuccess: function() {
14 var box
= (autoConnect
? "confirm" : "login");
15 var rootElement
= parent
.getElement("[name=" + box
+ "box]");
16 this.rootElement
= rootElement
;
18 this.util
.exec = function(n
, x
) { rootElement
.getElements(n
).each(x
); };
21 util
.makeVisible(rootElement
);
23 exec("[name=nickname]", util
.setText(initialNickname
));
24 exec("[name=channels]", util
.setText(initialChannels
));
25 exec("[name=prettychannels]", function(node
) { this.__buildPrettyChannels(node
, initialChannels
); }.bind(this));
26 exec("[name=networkname]", util
.setText(networkName
));
28 var focus
= "connect";
31 exec("[name=nickselected]", util
.makeVisible
);
33 this.__validate
= this.__validateConfirmData
;
35 if(!initialNickname
) {
37 } else if(initialNickname
&& !initialChannels
) {
41 this.__validate
= this.__validateLoginData
;
44 if(qwebirc
.auth
.loggedin()) {
45 exec("[name=authname]", util
.setText(qwebirc
.auth
.loggedin()));
46 exec("[name=connectbutton]", util
.makeVisible
);
47 exec("[name=loginstatus]", util
.makeVisible
);
49 if(qwebirc
.ui
.isAuthRequired()) {
50 exec("[name=loginconnectbutton]", util
.makeVisible
);
51 if(focus
== "connect")
52 focus
= "loginconnect";
54 exec("[name=connectbutton]", util
.makeVisible
);
55 exec("[name=loginbutton]", util
.makeVisible
);
59 if(window
== window
.top
) /* don't focus when we're iframe'd */
60 exec("[name=" + focus
+ "]", util
.focus
);
61 exec("[name=connect]", util
.attachClick(this.__connect
.bind(this)));
62 exec("[name=loginconnect]", util
.attachClick(this.__loginConnect
.bind(this)));
63 exec("[name=login]", util
.attachClick(this.__login
.bind(this)));
68 makeVisible: function(x
) { x
.setStyle("display", ""); },
69 setVisible: function(y
) { return function(x
) { x
.setStyle("display", y
? "" : "none"); }; },
70 focus: function(x
) { x
.focus(); },
71 attachClick: function(fn
) { return function(x
) { x
.addListener("click", fn
); } },
72 setText: function(x
) { return function(y
) {
73 if(typeof y
.value
=== "undefined") {
76 y
.value
= x
=== null ? "" : x
;
80 validate: function() {
81 return this.__validate();
83 __connect: function(e
) {
85 var data
= this.validate();
90 this.fireEvent("close");
91 this.options
.callback(data
);
93 __cancelLogin: function(noUIModifications
) {
94 if(this.__cancelLoginCallback
)
95 this.__cancelLoginCallback(noUIModifications
);
97 __loginConnect: function(e
) {
99 if(this.validate() === false)
102 this.__performLogin(function() {
103 var data
= this.validate();
105 /* we're logged in -- show the normal join button */
106 this.util
.exec("[name=connectbutton]", this.util
.setVisible(true));
110 this.fireEvent("close");
111 this.options
.callback(data
);
112 }.bind(this), "loginconnectbutton");
114 __login: function(e
) {
117 this.__cancelLogin(true);
119 this.__performLogin(function() {
120 var focus
= "connect";
121 if(!this.options
.autoConnect
) {
122 var nick
= this.rootElement
.getElement("input[name=nickname]").value
, chan
= this.rootElement
.getElement("input[name=channels]").value
;
129 this.util
.exec("[name=" + focus
+ "]", this.util
.focus
);
130 }.bind(this), "login");
132 __performLogin: function(callback
, calleename
) {
133 Cookie
.write("jslogin", "1");
135 var handle
= window
.open("/auth", this.__windowName
, "status=0,toolbar=0,location=1,menubar=0,directories=0,resizable=0,scrollbars=1,height=280,width=550");
137 if(handle
=== null || handle
=== undefined) {
138 Cookie
.dispose("jslogin");
139 // Cookie.write("redirect", document.location);
140 // window.location = "auth?";
144 var closeDetector = function() {
146 this.__cancelLoginCallback();
148 var closeCallback
= closeDetector
.periodical(100);
150 this.__cancelLoginCallback = function(noUIModifications
) {
151 $clear(closeCallback
);
153 Cookie
.dispose("jslogin");
160 if(!noUIModifications
) {
161 this.util
.exec("[name=loggingin]", this.util
.setVisible(false));
162 this.util
.exec("[name=" + calleename
+ "]", this.util
.setVisible(true));
164 this.__cancelLoginCallback
= null;
167 this.util
.exec("[name=loggingin]", this.util
.setVisible(true));
168 this.util
.exec("[name=" + calleename
+ "]", this.util
.setVisible(false));
170 __qwebircAuthCallback = function(username
) {
171 this.__cancelLoginCallback(true);
173 this.util
.exec("[name=loggingin]", this.util
.setVisible(false));
174 this.util
.exec("[name=loginstatus]", this.util
.setVisible(true));
175 this.util
.exec("[name=authname]", this.util
.setText(username
));
180 __validateConfirmData: function() {
181 return {nickname: this.options
.initialNickname
, autojoin: this.options
.initialChannels
};
183 __validateLoginData: function() {
184 var nick
= this.rootElement
.getElement("input[name=nickname]"), chan
= this.rootElement
.getElement("input[name=channels]");
186 var nickname
= nick
.value
;
187 var chans
= chan
.value
;
188 if(chans
== "#") /* sorry channel "#" :P */
192 alert("You must supply a nickname.");
197 var stripped
= qwebirc
.global
.nicknameValidator
.validate(nickname
);
198 if(stripped
!= nickname
) {
199 nick
.value
= stripped
;
200 alert("Your nickname was invalid and has been corrected; please check your altered nickname and try again.");
205 var data
= {nickname: nickname
, autojoin: chans
};
208 __buildPrettyChannels: function(node
, channels
) {
209 var c
= channels
.split(" ")[0].split(",");
210 node
.appendChild(document
.createTextNode("channel" + ((c
.length
>1)?"s":"") + " "));
211 for(var i
=0;i
<c
.length
;i
++) {
212 if((c
.length
> 1) && (i
== c
.length
- 1)) {
213 node
.appendChild(document
.createTextNode(" and "));
215 node
.appendChild(document
.createTextNode(", "));
217 node
.appendChild(new Element("b").set("text", c
[i
]));
222 qwebirc
.ui
.LoginBox2 = function(parentElement
, callback
, initialNickname
, initialChannels
, networkName
) {
224 if(qwebirc.auth.enabled()) {
225 if(qwebirc.auth.passAuth()) {
226 var authRow = createRow("Auth to services:");
227 var authCheckBox = qwebirc.util.createInput("checkbox", authRow, "connect_auth_to_services", false);
229 var usernameBox = new Element("input");
230 var usernameRow = createRow("Username:", usernameBox, {display: "none"})[0];
232 var passwordRow = createRow("Password:", null, {display: "none"});
233 var passwordBox = qwebirc.util.createInput("password", passwordRow[1], "connect_auth_password");
235 authCheckBox.addEvent("click", function(e) { qwebirc.ui.authShowHide(authCheckBox, authRow, usernameBox, usernameRow, passwordRow[0]) });
236 } else if(qwebirc.auth.bouncerAuth()) {
237 var passwordRow = createRow("Password:");
238 var passwordBox = qwebirc.util.createInput("password", passwordRow, "connect_auth_password");
243 var connbutton
= new Element("input", {"type": "submit"});
244 connbutton
.set("value", "Connect");
245 var r
= createRow(undefined, connbutton
);
247 form
.addEvent("submit", function(e
) {
250 var nickname
= nick
.value
;
251 var chans
= chan
.value
;
252 if(chans
== "#") /* sorry channel "#" :P */
256 alert("You must supply a nickname.");
260 var stripped
= qwebirc
.global
.nicknameValidator
.validate(nickname
);
261 if(stripped
!= nickname
) {
262 nick
.value
= stripped
;
263 alert("Your nickname was invalid and has been corrected; please check your altered nickname and press Connect again.");
268 var data
= {"nickname": nickname
, "autojoin": chans
};
269 if(qwebirc
.auth
.enabled()) {
270 if(qwebirc
.auth
.passAuth() && authCheckBox
.checked
) {
271 if(!usernameBox
.value
|| !passwordBox
.value
) {
272 alert("You must supply your username and password in auth mode.");
273 if(!usernameBox
.value
) {
281 data
["serverPassword"] = usernameBox
.value
+ " " + passwordBox
.value
;
282 } else if(qwebirc
.auth
.bouncerAuth()) {
283 if(!passwordBox
.value
) {
284 alert("You must supply a password.");
289 data
["serverPassword"] = passwordBox
.value
;
292 parentElement
.removeChild(outerbox
);
297 nick
.set("value", initialNickname
);
298 chan
.set("value", initialChannels
);
300 if(window
== window
.top
)
304 qwebirc
.ui
.authShowHide = function(checkbox
, authRow
, usernameBox
, usernameRow
, passwordRow
) {
305 var visible
= checkbox
.checked
;
306 var display
= visible
?null:"none";
307 usernameRow
.setStyle("display", display
);
308 passwordRow
.setStyle("display", display
);
311 // authRow.parentNode.setStyle("display", "none");
316 qwebirc
.ui
.isAuthRequired
= (function() {
317 var args
= qwebirc
.util
.parseURI(String(document
.location
));
318 var value
= $defined(args
) && args
["authrequired"];
320 return value
&& qwebirc
.auth
.enabled();