2014-08-22 09:11:39 -06:00
|
|
|
/*
|
2014-09-03 10:29:13 -06:00
|
|
|
Copyright 2014 OpenMarket Ltd
|
2014-08-22 09:11:39 -06:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
2014-08-27 10:00:08 -06:00
|
|
|
angular.module('SettingsController', ['matrixService', 'mFileUpload', 'mFileInput'])
|
2014-08-22 09:11:39 -06:00
|
|
|
.controller('SettingsController', ['$scope', 'matrixService', 'mFileUpload',
|
|
|
|
function($scope, matrixService, mFileUpload) {
|
2014-09-04 04:38:26 -06:00
|
|
|
// XXX: duplicated from register
|
|
|
|
var generateClientSecret = function() {
|
|
|
|
var ret = "";
|
|
|
|
var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
|
|
|
|
|
|
|
for (var i = 0; i < 32; i++) {
|
|
|
|
ret += chars.charAt(Math.floor(Math.random() * chars.length));
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
};
|
2014-08-22 09:11:39 -06:00
|
|
|
$scope.config = matrixService.config();
|
|
|
|
|
|
|
|
$scope.profile = {
|
2014-08-29 10:22:05 -06:00
|
|
|
displayName: "",
|
|
|
|
avatarUrl: ""
|
2014-08-22 09:11:39 -06:00
|
|
|
};
|
2014-08-29 10:22:05 -06:00
|
|
|
|
|
|
|
// The profile as stored on the server
|
|
|
|
$scope.profileOnServer = {
|
|
|
|
displayName: "",
|
|
|
|
avatarUrl: ""
|
|
|
|
};
|
|
|
|
|
|
|
|
$scope.onInit = function() {
|
|
|
|
// Load profile data
|
|
|
|
// Display name
|
|
|
|
matrixService.getDisplayName($scope.config.user_id).then(
|
|
|
|
function(response) {
|
|
|
|
$scope.profile.displayName = response.data.displayname;
|
|
|
|
$scope.profileOnServer.displayName = response.data.displayname;
|
|
|
|
},
|
|
|
|
function(error) {
|
|
|
|
$scope.feedback = "Can't load display name";
|
|
|
|
}
|
|
|
|
);
|
|
|
|
// Avatar
|
|
|
|
matrixService.getProfilePictureUrl($scope.config.user_id).then(
|
|
|
|
function(response) {
|
|
|
|
$scope.profile.avatarUrl = response.data.avatar_url;
|
|
|
|
$scope.profileOnServer.avatarUrl = response.data.avatar_url;
|
|
|
|
},
|
|
|
|
function(error) {
|
|
|
|
$scope.feedback = "Can't load avatar URL";
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2014-08-22 09:11:39 -06:00
|
|
|
$scope.$watch("profile.avatarFile", function(newValue, oldValue) {
|
|
|
|
if ($scope.profile.avatarFile) {
|
|
|
|
console.log("Uploading new avatar file...");
|
|
|
|
mFileUpload.uploadFile($scope.profile.avatarFile).then(
|
|
|
|
function(url) {
|
|
|
|
$scope.profile.avatarUrl = url;
|
|
|
|
},
|
|
|
|
function(error) {
|
|
|
|
$scope.feedback = "Can't upload image";
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$scope.saveProfile = function() {
|
2014-08-29 10:22:05 -06:00
|
|
|
if ($scope.profile.displayName !== $scope.profileOnServer.displayName) {
|
2014-08-22 09:11:39 -06:00
|
|
|
setDisplayName($scope.profile.displayName);
|
|
|
|
}
|
2014-08-29 10:22:05 -06:00
|
|
|
if ($scope.profile.avatarUrl !== $scope.profileOnServer.avatarUrl) {
|
2014-08-22 09:11:39 -06:00
|
|
|
setAvatar($scope.profile.avatarUrl);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
var setDisplayName = function(displayName) {
|
|
|
|
matrixService.setDisplayName(displayName).then(
|
|
|
|
function(response) {
|
|
|
|
$scope.feedback = "Updated display name.";
|
|
|
|
},
|
|
|
|
function(error) {
|
|
|
|
$scope.feedback = "Can't update display name: " + error.data;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
var setAvatar = function(avatarURL) {
|
|
|
|
console.log("Updating avatar to " + avatarURL);
|
|
|
|
matrixService.setProfilePictureUrl(avatarURL).then(
|
|
|
|
function(response) {
|
|
|
|
console.log("Updated avatar");
|
|
|
|
$scope.feedback = "Updated avatar.";
|
|
|
|
},
|
|
|
|
function(error) {
|
|
|
|
$scope.feedback = "Can't update avatar: " + error.data;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
$scope.linkedEmails = {
|
|
|
|
linkNewEmail: "", // the email entry box
|
|
|
|
emailBeingAuthed: undefined, // to populate verification text
|
2014-09-04 04:38:26 -06:00
|
|
|
authSid: undefined, // the token id from the IS
|
2014-08-22 09:11:39 -06:00
|
|
|
emailCode: "", // the code entry box
|
|
|
|
linkedEmailList: matrixService.config().emailList // linked email list
|
|
|
|
};
|
|
|
|
|
|
|
|
$scope.linkEmail = function(email) {
|
2014-09-04 04:38:26 -06:00
|
|
|
if (email != $scope.linkedEmails.emailBeingAuthed) {
|
|
|
|
$scope.linkedEmails.emailBeingAuthed = email;
|
|
|
|
$scope.clientSecret = generateClientSecret();
|
|
|
|
$scope.sendAttempt = 0;
|
|
|
|
}
|
|
|
|
$scope.sendAttempt++;
|
|
|
|
matrixService.linkEmail(email, $scope.clientSecret, $scope.sendAttempt).then(
|
2014-08-22 09:11:39 -06:00
|
|
|
function(response) {
|
|
|
|
if (response.data.success === true) {
|
2014-09-04 04:38:26 -06:00
|
|
|
$scope.linkedEmails.authSid = response.data.sid;
|
2014-08-22 09:11:39 -06:00
|
|
|
$scope.emailFeedback = "You have been sent an email.";
|
|
|
|
$scope.linkedEmails.emailBeingAuthed = email;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$scope.emailFeedback = "Failed to send email.";
|
|
|
|
}
|
|
|
|
},
|
|
|
|
function(error) {
|
|
|
|
$scope.emailFeedback = "Can't send email: " + error.data;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2014-09-04 04:38:26 -06:00
|
|
|
$scope.submitEmailCode = function() {
|
|
|
|
var tokenId = $scope.linkedEmails.authSid;
|
2014-08-22 09:11:39 -06:00
|
|
|
if (tokenId === undefined) {
|
|
|
|
$scope.emailFeedback = "You have not requested a code with this email.";
|
|
|
|
return;
|
|
|
|
}
|
2014-09-04 04:38:26 -06:00
|
|
|
matrixService.authEmail($scope.clientSecret, $scope.linkedEmails.authSid, $scope.linkedEmails.emailCode).then(
|
2014-08-22 09:11:39 -06:00
|
|
|
function(response) {
|
2014-09-04 04:38:26 -06:00
|
|
|
if ("errcode" in response.data) {
|
2014-08-22 09:11:39 -06:00
|
|
|
$scope.emailFeedback = "Failed to authenticate email.";
|
|
|
|
return;
|
|
|
|
}
|
2014-09-04 04:38:26 -06:00
|
|
|
matrixService.bindEmail(matrixService.config().user_id, tokenId, $scope.clientSecret).then(
|
|
|
|
function(response) {
|
|
|
|
if ('errcode' in response.data) {
|
|
|
|
$scope.emailFeedback = "Failed to link email.";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
var config = matrixService.config();
|
|
|
|
var emailList = {};
|
|
|
|
if ("emailList" in config) {
|
|
|
|
emailList = config.emailList;
|
|
|
|
}
|
|
|
|
emailList[$scope.linkedEmails.emailBeingAuthed] = response;
|
|
|
|
// save the new email list
|
|
|
|
config.emailList = emailList;
|
|
|
|
matrixService.setConfig(config);
|
|
|
|
matrixService.saveConfig();
|
|
|
|
// invalidate the email being authed and update UI.
|
|
|
|
$scope.linkedEmails.emailBeingAuthed = undefined;
|
|
|
|
$scope.emailFeedback = "";
|
|
|
|
$scope.linkedEmails.linkedEmailList = emailList;
|
|
|
|
$scope.linkedEmails.linkNewEmail = "";
|
|
|
|
$scope.linkedEmails.emailCode = "";
|
|
|
|
}, function(reason) {
|
|
|
|
$scope.emailFeedback = "Failed to link email: " + reason;
|
|
|
|
}
|
|
|
|
);
|
2014-08-22 09:11:39 -06:00
|
|
|
},
|
|
|
|
function(reason) {
|
|
|
|
$scope.emailFeedback = "Failed to auth email: " + reason;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
2014-08-29 09:11:03 -06:00
|
|
|
|
|
|
|
|
|
|
|
/*** Desktop notifications section ***/
|
|
|
|
$scope.settings = {
|
2014-09-16 07:20:26 -06:00
|
|
|
notifications: undefined,
|
|
|
|
bingWords: matrixService.config().bingWords
|
|
|
|
};
|
|
|
|
|
|
|
|
$scope.saveBingWords = function() {
|
|
|
|
console.log("Saving words: "+JSON.stringify($scope.settings.bingWords));
|
|
|
|
var config = matrixService.config();
|
|
|
|
config.bingWords = $scope.settings.bingWords;
|
|
|
|
matrixService.setConfig(config);
|
|
|
|
matrixService.saveConfig();
|
2014-08-29 09:11:03 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
// If the browser supports it, check the desktop notification state
|
|
|
|
if ("Notification" in window) {
|
|
|
|
$scope.settings.notifications = window.Notification.permission;
|
|
|
|
}
|
|
|
|
|
|
|
|
$scope.requestNotifications = function() {
|
|
|
|
console.log("requestNotifications");
|
|
|
|
window.Notification.requestPermission(function (permission) {
|
|
|
|
console.log(" -> User decision: " + permission);
|
|
|
|
$scope.settings.notifications = permission;
|
|
|
|
});
|
|
|
|
};
|
2014-09-04 04:38:26 -06:00
|
|
|
}]);
|