[MERGE]: survey: fixed a bug in warning message when users exceed maximal number...
[odoo/odoo.git] / addons / auth_openid / static / src / js / auth_openid.js
1
2 openerp.auth_openid = function(instance) {
3
4 var QWeb = instance.web.qweb;
5
6 instance.web.Login = instance.web.Login.extend({
7     start: function() {
8         this._super.apply(this, arguments);
9         var self = this;
10
11         this._default_error_message = this.$element.find('.login_error_message').text();
12
13         this.$openid_selected_button = $();
14         this.$openid_selected_input = $();
15         this.$openid_selected_provider = null;
16
17
18         var openIdProvider = null;
19         if (this.has_local_storage && this.remember_credentials) {
20             openIdProvider = localStorage.getItem('openid-provider');
21         }
22
23         if (openIdProvider) {
24             $openid_selected_provider = openIdProvider;
25             this.do_openid_select('a[href="#' + openIdProvider + '"]', openIdProvider, true);
26
27             if (this.has_local_storage && this.remember_credentials) {
28                 this.$openid_selected_input.find('input').val(localStorage.getItem('openid-login'));
29             }
30         }
31         else {
32             this.do_openid_select('a[data-url=""]', 'login,password', true);
33         }
34
35         this.$element.find('a[data-url]').click(function (event) {
36             event.preventDefault();
37             var selected_oidh = $(this).attr('href').substr(1);
38             if (selected_oidh != self.$openid_selected_provider) {
39                 self.do_openid_select(this, selected_oidh);
40             }
41         });
42
43         this._check_fragment();
44
45     },
46
47
48     do_openid_select: function (button, provider, noautosubmit) {
49         var self = this;
50
51             self.$openid_selected_button.add(self.$openid_selected_input).removeClass('selected');
52             self.$openid_selected_button = self.$element.find(button).addClass('selected');
53
54             var input = _(provider.split(',')).map(function(p) { return 'li[data-provider="'+p+'"]'; }).join(',');
55             self.$openid_selected_input = self.$element.find(input).addClass('selected');
56
57             self.$openid_selected_input.find('input:first').focus();
58             self.$openid_selected_provider = (self.$openid_selected_button.attr('href') || '').substr(1);
59
60             if (self.has_local_storage && self.remember_credentials) {
61                 localStorage.setItem('openid-provider', self.$openid_selected_provider);
62             }
63
64             if (!noautosubmit && self.$openid_selected_input.length == 0) {
65                 self.$element.find('form').submit();
66             }
67
68     },
69
70     _check_fragment: function() {
71         var self = this;
72         var fragment = jQuery.deparam.fragment();
73         console.log(fragment);
74         if (fragment.loginerror !== undefined) {
75             this.rpc('/auth_openid/login/status', {}, function(result) {
76                 if (_.contains(['success', 'failure'], result.status) && result.message) {
77                     self.do_warn('Invalid OpenID Login', result.message);
78                 }
79                 if (result.status === 'setup_needed' && result.message) {
80                     window.location.replace(result.message);
81                 }
82             });
83         }
84     },
85
86     on_submit: function(ev) {
87
88         var dataurl = this.$openid_selected_button.attr('data-url');
89
90         if(!dataurl) {
91             // login-password submitted
92             this.reset_error_message();
93             this._super(ev);
94         } else {
95             ev.preventDefault();
96
97             var id = this.$openid_selected_input.find('input').val();
98             if (this.has_local_storage && this.remember_credentials) {
99                 localStorage.setItem('openid-login', id);
100             }
101
102             var db = this.$element.find("form [name=db]").val();
103             var openid_url = dataurl.replace('{id}', id);
104
105             this.do_openid_login(db, openid_url);
106
107         }
108     },
109
110     do_openid_login: function(db, openid_url) {
111         var self = this;
112         this.rpc('/auth_openid/login/verify', {'db': db, 'url': openid_url}, function(result) {
113             if (result.error) {
114                 self.do_warn(result.title, result.error);
115                 return;
116             }
117             if (result.session_id) {
118                 self.session.set_cookie('session_id', result.session_id);
119             }
120             if (result.action === 'post') {
121                 document.open();
122                 document.write(result.value);
123                 document.close();
124             } else if (result.action === 'redirect') {
125                 window.location.replace(result.value);
126             } else {
127                 // XXX display error ?
128             }
129
130         });
131     },
132
133     do_warn: function(title, msg) {
134         //console.warn(title, msg);
135         this.$element.find('.login_error_message').text(msg).show();
136     },
137
138     reset_error_message: function() {
139         this.$element.find('.login_error_message').text(this._default_error_message);
140     }
141
142 });
143
144
145 };