3 http://code.google.com/p/openid-selector/
5 This code is licenced under the New BSD License.
8 var providers_large = {
11 icon: 'http://google.com/favicon.ico',
12 url: 'https://www.google.com/accounts/o8/id'
16 icon: 'http://yahoo.com/favicon.ico',
17 url: 'http://me.yahoo.com/'
21 icon: 'wikiicons/openidlogin-bg.gif',
22 label: 'Enter your OpenID:',
26 var providers_small = {
29 icon: 'http://livejournal.com/favicon.ico',
30 label: 'Enter your Livejournal username:',
31 url: 'http://{username}.livejournal.com/'
35 icon: 'http://flickr.com/favicon.ico',
36 label: 'Enter your Flickr username:',
37 url: 'http://flickr.com/{username}/'
41 icon: 'https://ddgw.s3.amazonaws.com/wordpress.org.ico',
42 label: 'Enter your Wordpress.com username:',
43 url: 'http://{username}.wordpress.com/'
47 icon: 'http://blogger.com/favicon.ico',
48 label: 'Enter your Blogger account:',
49 url: 'http://{username}.blogspot.com/'
53 icon: 'http://technorati.com/favicon.ico',
54 label: 'Enter your Technorati username:',
55 url: 'http://technorati.com/people/technorati/{username}/'
59 icon: 'http://myopenid.com/favicon.ico',
60 label: 'Enter your MyOpenID username:',
61 url: 'http://{username}.myopenid.com/'
65 icon: 'http://claimid.com/favicon.ico',
66 label: 'Enter your ClaimID username:',
67 url: 'http://claimid.com/{username}'
71 icon: 'http://aol.com/favicon.ico',
72 label: 'Enter your AOL screenname:',
73 url: 'http://openid.aol.com/{username}'
77 icon: 'http://verisign.com/favicon.ico',
78 label: 'Enter your Verisign username:',
79 url: 'http://{username}.pip.verisignlabs.com/'
82 var providers = $.extend({}, providers_large, providers_small);
88 cookie_expires: 6*30, // 6 months.
89 cookie_name: 'openid_provider',
98 init: function(input_id, localloginurl) {
100 var openid_btns = $('#openid_btns');
102 this.input_id = input_id;
104 $('#openid_choice').show();
105 $('#openid_input_area').empty();
107 // add box for each provider
108 for (id in providers_large) {
109 openid_btns.append(this.getBoxHTML(providers_large[id], 'large'));
112 if (localloginurl != "") {
114 '<a href="' + localloginurl + '"' +
115 ' style="background: #FFF" ' +
116 'class="openid_large_btn">' +
117 '<img alt="" width="24" height="24" src="favicon.ico" />' +
122 if (providers_small) {
123 openid_btns.append('<br/>');
125 for (id in providers_small) {
127 openid_btns.append(this.getBoxHTML(providers_small[id], 'small'));
131 $('#openid_form').submit(this.submit);
133 var box_id = this.readCookie();
135 this.signin(box_id, true);
138 getBoxHTML: function(provider, box_size) {
141 if (box_size == 'large') {
142 label=' ' + provider["name"];
145 title=' title="'+provider["name"]+'"';
147 var box_id = provider["name"].toLowerCase();
148 return '<a' + title +' href="javascript: openid.signin(\''+ box_id +'\');"' +
149 ' style="background: #FFF" ' +
150 'class="' + box_id + ' openid_' + box_size + '_btn">' +
151 '<img alt="" width="24" height="24" src="' + provider["icon"] + '" />' +
156 /* Provider image click */
157 signin: function(box_id, onload) {
159 var provider = providers[box_id];
164 this.highlight(box_id);
165 this.setCookie(box_id);
167 this.provider_id = box_id;
168 this.provider_url = provider['url'];
170 // prompt user for input?
171 if (provider['label']) {
172 this.useInputBox(provider);
174 $('#openid_input_area').empty();
176 $('#openid_form').submit();
180 /* Sign-in button click */
183 var url = openid.provider_url;
185 url = url.replace('{username}', $('#openid_username').val());
186 openid.setOpenIdUrl(url);
188 if(openid.ajaxHandler) {
189 openid.ajaxHandler(openid.provider_id, document.getElementById(openid.input_id).value);
193 alert("In client demo mode. Normally would have submitted OpenID:\r\n" + document.getElementById(openid.input_id).value);
198 setOpenIdUrl: function (url) {
200 var hidden = $('#'+this.input_id);
201 if (hidden.length > 0) {
204 $('#openid_form').append('<input style="display:none" id="' + this.input_id + '" name="' + this.input_id + '" value="'+url+'"/>');
207 highlight: function (box_id) {
209 // remove previous highlight.
210 var highlight = $('#openid_highlight');
212 highlight.replaceWith($('#openid_highlight a')[0]);
214 // add new highlight.
215 $('.'+box_id).wrap('<div id="openid_highlight"></div>');
217 setCookie: function (value) {
219 var date = new Date();
220 date.setTime(date.getTime()+(this.cookie_expires*24*60*60*1000));
221 var expires = "; expires="+date.toGMTString();
223 document.cookie = this.cookie_name+"="+value+expires+"; path=" + this.cookie_path;
225 readCookie: function () {
226 var nameEQ = this.cookie_name + "=";
227 var ca = document.cookie.split(';');
228 for(var i=0;i < ca.length;i++) {
230 while (c.charAt(0)==' ') c = c.substring(1,c.length);
231 if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
235 useInputBox: function (provider) {
237 var input_area = $('#openid_input_area');
240 var id = 'openid_username';
242 var label = provider['label'];
246 html = '<p>' + label + '</p>';
248 if (provider['name'] == 'OpenID') {
251 style = 'background:#FFF url(wikiicons/openidlogin-bg.gif) no-repeat scroll 0 50%; padding-left:18px;';
253 html += '<input id="'+id+'" type="text" style="'+style+'" name="'+id+'" value="'+value+'" />' +
254 '<input id="openid_submit" type="submit" value="Login"/>';
257 input_area.append(html);
261 setDemoMode: function (demoMode) {
262 this.demo = demoMode;
264 setAjaxHandler: function (ajaxFunction) {
265 this.ajaxHandler = ajaxFunction;