]>
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 exec("[name=" + focus
+ "]", util
.focus
);
60 exec("[name=connect]", util
.attachClick(this.__connect
.bind(this)));
61 exec("[name=loginconnect]", util
.attachClick(this.__loginConnect
.bind(this)));
62 exec("[name=login]", util
.attachClick(this.__login
.bind(this)));
67 makeVisible: function(x
) { x
.setStyle("display", ""); },
68 setVisible: function(y
) { return function(x
) { x
.setStyle("display", y
? "" : "none"); }; },
69 focus: function(x
) { x
.focus(); },
70 attachClick: function(fn
) { return function(x
) { x
.addListener("click", fn
); } },
71 setText: function(x
) { return function(y
) {
72 if(typeof y
.value
=== "undefined") {
75 y
.value
= x
=== null ? "" : x
;
79 validate: function() {
80 return this.__validate();
82 __connect: function(e
) {
84 var data
= this.validate();
89 this.fireEvent("close");
90 this.options
.callback(data
);
92 __cancelLogin: function(noUIModifications
) {
93 if(this.__cancelLoginCallback
)
94 this.__cancelLoginCallback(noUIModifications
);
96 __loginConnect: function(e
) {
98 if(this.validate() === false)
101 this.__performLogin(function() {
102 var data
= this.validate();
104 /* we're logged in -- show the normal join button */
105 this.util
.exec("[name=connectbutton]", this.util
.setVisible(true));
109 this.fireEvent("close");
110 this.options
.callback(data
);
111 }.bind(this), "loginconnectbutton");
113 __login: function(e
) {
116 this.__cancelLogin(true);
118 this.__performLogin(function() {
119 var focus
= "connect";
120 if(!this.options
.autoConnect
) {
121 var nick
= this.rootElement
.getElement("input[name=nickname]").value
, chan
= this.rootElement
.getElement("input[name=channels]").value
;
128 this.util
.exec("[name=" + focus
+ "]", this.util
.focus
);
129 }.bind(this), "login");
131 __performLogin: function(callback
, calleename
) {
132 Cookie
.write("jslogin", "1");
134 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");
136 if(handle
=== null || handle
=== undefined) {
137 Cookie
.dispose("jslogin");
138 // Cookie.write("redirect", document.location);
139 // window.location = "auth?";
143 var closeDetector = function() {
145 this.__cancelLoginCallback();
147 var closeCallback
= closeDetector
.periodical(100);
149 this.__cancelLoginCallback = function(noUIModifications
) {
150 $clear(closeCallback
);
152 Cookie
.dispose("jslogin");
159 if(!noUIModifications
) {
160 this.util
.exec("[name=loggingin]", this.util
.setVisible(false));
161 this.util
.exec("[name=" + calleename
+ "]", this.util
.setVisible(true));
163 this.__cancelLoginCallback
= null;
166 this.util
.exec("[name=loggingin]", this.util
.setVisible(true));
167 this.util
.exec("[name=" + calleename
+ "]", this.util
.setVisible(false));
169 __qwebircAuthCallback = function(username
) {
170 this.__cancelLoginCallback(true);
172 this.util
.exec("[name=loggingin]", this.util
.setVisible(false));
173 this.util
.exec("[name=loginstatus]", this.util
.setVisible(true));
174 this.util
.exec("[name=authname]", this.util
.setText(username
));
179 __validateConfirmData: function() {
180 return {nickname: this.options
.initialNickname
, autojoin: this.options
.initialChannels
};
182 __validateLoginData: function() {
183 var nick
= this.rootElement
.getElement("input[name=nickname]"), chan
= this.rootElement
.getElement("input[name=channels]");
185 var nickname
= nick
.value
;
186 var chans
= chan
.value
;
187 if(chans
== "#") /* sorry channel "#" :P */
191 alert("You must supply a nickname.");
196 var data
= {nickname: nickname
, autojoin: chans
};
199 __buildPrettyChannels: function(node
, channels
) {
200 var c
= channels
.split(" ")[0].split(",");
201 node
.appendChild(document
.createTextNode("channel" + ((c
.length
>1)?"s":"") + " "));
202 for(var i
=0;i
<c
.length
;i
++) {
203 if((c
.length
> 1) && (i
== c
.length
- 1)) {
204 node
.appendChild(document
.createTextNode(" and "));
206 node
.appendChild(document
.createTextNode(", "));
208 node
.appendChild(new Element("b").set("text", c
[i
]));
213 qwebirc
.ui
.LoginBox2 = function(parentElement
, callback
, initialNickname
, initialChannels
, networkName
) {
215 if(qwebirc.auth.enabled()) {
216 if(qwebirc.auth.passAuth()) {
217 var authRow = createRow("Auth to services:");
218 var authCheckBox = qwebirc.util.createInput("checkbox", authRow, "connect_auth_to_services", false);
220 var usernameBox = new Element("input");
221 var usernameRow = createRow("Username:", usernameBox, {display: "none"})[0];
223 var passwordRow = createRow("Password:", null, {display: "none"});
224 var passwordBox = qwebirc.util.createInput("password", passwordRow[1], "connect_auth_password");
226 authCheckBox.addEvent("click", function(e) { qwebirc.ui.authShowHide(authCheckBox, authRow, usernameBox, usernameRow, passwordRow[0]) });
227 } else if(qwebirc.auth.bouncerAuth()) {
228 var passwordRow = createRow("Password:");
229 var passwordBox = qwebirc.util.createInput("password", passwordRow, "connect_auth_password");
234 var connbutton
= new Element("input", {"type": "submit"});
235 connbutton
.set("value", "Connect");
236 var r
= createRow(undefined, connbutton
);
238 form
.addEvent("submit", function(e
) {
241 var data
= {"nickname": nickname
, "autojoin": chans
};
242 if(qwebirc
.auth
.enabled()) {
243 if(qwebirc
.auth
.passAuth() && authCheckBox
.checked
) {
244 if(!usernameBox
.value
|| !passwordBox
.value
) {
245 alert("You must supply your username and password in auth mode.");
246 if(!usernameBox
.value
) {
254 data
["serverPassword"] = usernameBox
.value
+ " " + passwordBox
.value
;
255 } else if(qwebirc
.auth
.bouncerAuth()) {
256 if(!passwordBox
.value
) {
257 alert("You must supply a password.");
262 data
["serverPassword"] = passwordBox
.value
;
265 parentElement
.removeChild(outerbox
);
270 nick
.set("value", initialNickname
);
271 chan
.set("value", initialChannels
);
273 if(window
== window
.top
)
277 qwebirc
.ui
.authShowHide = function(checkbox
, authRow
, usernameBox
, usernameRow
, passwordRow
) {
278 var visible
= checkbox
.checked
;
279 var display
= visible
?null:"none";
280 usernameRow
.setStyle("display", display
);
281 passwordRow
.setStyle("display", display
);
284 // authRow.parentNode.setStyle("display", "none");
289 qwebirc
.ui
.isAuthRequired
= (function() {
290 var args
= qwebirc
.util
.parseURI(String(document
.location
));
291 var value
= $defined(args
) && args
["authrequired"];
293 return value
&& qwebirc
.auth
.enabled();