blob: 2eb644becf2a41d38365d72ea3bb20a1dec10b51 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
(function() {
//
// LOCAL FUNCTIONS
//
var poll_users, prevent_default, form_failed, form_passed, clear_errors;
prevent_default = function(event) {
return event.preventDefault();
};
poll_users = function(query, process) {
return $.get("/1/users.json", {
query: query
}).done(process);
};
clear_errors = function() {
return $('#messages').empty();
};
//
// PUBLIC FUNCTIONS
//
srp.session = new srp.Session();
srp.signedUp = function() {
return srp.login();
};
srp.loggedIn = function() {
return window.location = '/';
};
srp.updated = function() {
return window.location = '/users/' + srp.session.id();
};
//
// if a json request returns an error, this function gets called and
// decorates the appropriate fields with the error messages.
//
srp.error = function(message) {
clear_errors();
var element, error, field;
if ($.isPlainObject(message) && message.errors) {
for (field in message.errors) {
if (field == 'base') {
alert_message(message.errors[field]);
next;
}
error = message.errors[field];
element = $('form input[name$="[' + field + ']"]');
if (!element) {
next;
}
element.trigger('element:validate:fail.ClientSideValidations', error).data('valid', false);
}
} else if (message.error) {
alert_message(message.error);
} else {
alert_message(JSON.stringify(message));
}
};
//
// INIT
//
$(document).ready(function() {
$('#new_user').submit(prevent_default);
$('#new_user').submit(srp.signup);
$('#new_session').submit(prevent_default);
$('#new_session').submit(srp.login);
$('#update_login_and_password').submit(prevent_default);
$('#update_login_and_password').submit(srp.update);
return $('#user-typeahead').typeahead({
source: poll_users
});
});
}).call(this);
|