aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/public/js/controllers
diff options
context:
space:
mode:
Diffstat (limited to 'public/js/controllers')
-rw-r--r--public/js/controllers/homeController.js67
-rw-r--r--public/js/controllers/loginController.js14
-rw-r--r--public/js/controllers/signupController.js9
3 files changed, 90 insertions, 0 deletions
diff --git a/public/js/controllers/homeController.js b/public/js/controllers/homeController.js
new file mode 100644
index 0000000..9894d0e
--- /dev/null
+++ b/public/js/controllers/homeController.js
@@ -0,0 +1,67 @@
+
+function HomeController()
+{
+
+// bind event listeners to button clicks //
+ var that = this;
+
+// handle user logout //
+ $('#btn-logout').click(function(){ that.attemptLogout(); });
+
+// confirm account deletion //
+ $('#account-form-btn1').click(function(){$('.modal-confirm').modal('show')});
+
+// handle account deletion //
+ $('.modal-confirm .submit').click(function(){ that.deleteAccount(); });
+
+ this.deleteAccount = function()
+ {
+ $('.modal-confirm').modal('hide');
+ var that = this;
+ $.ajax({
+ url: '/delete',
+ type: 'POST',
+ data: { id: $('#userId').val()},
+ success: function(data){
+ that.showLockedAlert('Your account has been deleted.<br>Redirecting you back to the homepage.');
+ },
+ error: function(jqXHR){
+ console.log(jqXHR.responseText+' :: '+jqXHR.statusText);
+ }
+ });
+ }
+
+ this.attemptLogout = function()
+ {
+ var that = this;
+ $.ajax({
+ url: "/home",
+ type: "POST",
+ data: {logout : true},
+ success: function(data){
+ that.showLockedAlert('You are now logged out.<br>Redirecting you back to the homepage.');
+ },
+ error: function(jqXHR){
+ console.log(jqXHR.responseText+' :: '+jqXHR.statusText);
+ }
+ });
+ }
+
+ this.showLockedAlert = function(msg){
+ $('.modal-alert').modal({ show : false, keyboard : false, backdrop : 'static' });
+ $('.modal-alert .modal-header h3').text('Success!');
+ $('.modal-alert .modal-body p').html(msg);
+ $('.modal-alert').modal('show');
+ $('.modal-alert button').click(function(){window.location.href = '/';})
+ setTimeout(function(){window.location.href = '/';}, 3000);
+ }
+}
+
+HomeController.prototype.onUpdateSuccess = function()
+{
+ $('.modal-alert').modal({ show : false, keyboard : true, backdrop : true });
+ $('.modal-alert .modal-header h3').text('Success!');
+ $('.modal-alert .modal-body p').html('Your account has been updated.');
+ $('.modal-alert').modal('show');
+ $('.modal-alert button').off('click');
+}
diff --git a/public/js/controllers/loginController.js b/public/js/controllers/loginController.js
new file mode 100644
index 0000000..a894aed
--- /dev/null
+++ b/public/js/controllers/loginController.js
@@ -0,0 +1,14 @@
+
+function LoginController()
+{
+
+// bind event listeners to button clicks //
+
+ $('#login-form #forgot-password').click(function(){ $('#get-credentials').modal('show');});
+
+// automatically toggle focus between the email modal window and the login form //
+
+ $('#get-credentials').on('shown', function(){ $('#email-tf').focus(); });
+ $('#get-credentials').on('hidden', function(){ $('#user-tf').focus(); });
+
+} \ No newline at end of file
diff --git a/public/js/controllers/signupController.js b/public/js/controllers/signupController.js
new file mode 100644
index 0000000..97d20e6
--- /dev/null
+++ b/public/js/controllers/signupController.js
@@ -0,0 +1,9 @@
+
+function SignupController()
+{
+// redirect to homepage when cancel button is clicked //
+ $('#account-form-btn1').click(function(){ window.location.href = '/';});
+
+// redirect to homepage on new account creation, add short delay so user can read alert window //
+ $('.modal-alert #ok').click(function(){ setTimeout(function(){window.location.href = '/';}, 300)});
+} \ No newline at end of file