2011-08-23 03:40:13 +04:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2011, Robin Appelman <icewind1991@gmail.com>
|
2013-03-13 14:03:52 +04:00
|
|
|
* 2013, Morris Jobke <morris.jobke@gmail.com>
|
2011-08-23 03:40:13 +04:00
|
|
|
* This file is licensed under the Affero General Public License version 3 or later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
2014-04-07 16:04:16 +04:00
|
|
|
/* global OC, t */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The callback will be fired as soon as enter is pressed by the
|
|
|
|
* user or 1 second after the last data entry
|
|
|
|
*
|
|
|
|
* @param callback
|
|
|
|
*/
|
2014-08-15 19:18:46 +04:00
|
|
|
jQuery.fn.keyUpDelayedOrEnter = function (callback) {
|
2014-04-07 16:04:16 +04:00
|
|
|
var cb = callback;
|
|
|
|
var that = this;
|
|
|
|
this.keyup(_.debounce(function (event) {
|
|
|
|
// enter is already handled in keypress
|
2014-08-15 19:18:46 +04:00
|
|
|
if (event.keyCode === 13) {
|
2014-04-07 16:04:16 +04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (that.val() !== '') {
|
|
|
|
cb();
|
|
|
|
}
|
|
|
|
}, 1000));
|
|
|
|
|
2014-05-30 17:12:39 +04:00
|
|
|
this.keypress(function (event) {
|
2014-08-15 19:18:46 +04:00
|
|
|
if (event.keyCode === 13 && that.val() !== '') {
|
2014-04-07 16:04:16 +04:00
|
|
|
event.preventDefault();
|
|
|
|
cb();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-04-17 00:03:41 +04:00
|
|
|
/**
|
|
|
|
* Post the email address change to the server.
|
|
|
|
*/
|
2014-08-15 19:18:46 +04:00
|
|
|
function changeEmailAddress () {
|
|
|
|
var emailInfo = $('#email');
|
|
|
|
if (emailInfo.val() === emailInfo.defaultValue) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
emailInfo.defaultValue = emailInfo.val();
|
|
|
|
OC.msg.startSaving('#lostpassword .msg');
|
2014-12-15 14:43:42 +03:00
|
|
|
var post = $("#lostpassword").serializeArray();
|
|
|
|
$.ajax({
|
|
|
|
type: 'PUT',
|
|
|
|
url: OC.generateUrl('/settings/users/{id}/mailAddress', {id: OC.currentUser}),
|
|
|
|
data: {
|
|
|
|
mailAddress: post[0].value
|
|
|
|
}
|
|
|
|
}).done(function(result){
|
|
|
|
// I know the following 4 lines look weird, but that is how it works
|
|
|
|
// in jQuery - for success the first parameter is the result
|
|
|
|
// for failure the first parameter is the result object
|
|
|
|
OC.msg.finishedSaving('#lostpassword .msg', result);
|
|
|
|
}).fail(function(result){
|
|
|
|
OC.msg.finishedSaving('#lostpassword .msg', result.responseJSON);
|
2014-08-15 19:18:46 +04:00
|
|
|
});
|
2013-04-17 00:03:41 +04:00
|
|
|
}
|
|
|
|
|
2013-04-23 23:45:12 +04:00
|
|
|
/**
|
2013-04-24 01:31:35 +04:00
|
|
|
* Post the display name change to the server.
|
2013-04-23 23:45:12 +04:00
|
|
|
*/
|
2014-08-15 19:18:46 +04:00
|
|
|
function changeDisplayName () {
|
|
|
|
if ($('#displayName').val() !== '') {
|
|
|
|
OC.msg.startSaving('#displaynameform .msg');
|
|
|
|
// Serialize the data
|
|
|
|
var post = $("#displaynameform").serialize();
|
|
|
|
// Ajax foo
|
|
|
|
$.post('ajax/changedisplayname.php', post, function (data) {
|
|
|
|
if (data.status === "success") {
|
|
|
|
$('#oldDisplayName').val($('#displayName').val());
|
|
|
|
// update displayName on the top right expand button
|
|
|
|
$('#expandDisplayName').text($('#displayName').val());
|
|
|
|
updateAvatar();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$('#newdisplayname').val(data.data.displayName);
|
|
|
|
}
|
|
|
|
OC.msg.finishedSaving('#displaynameform .msg', data);
|
|
|
|
});
|
|
|
|
}
|
2013-04-23 23:45:12 +04:00
|
|
|
}
|
|
|
|
|
2013-10-04 04:27:53 +04:00
|
|
|
function updateAvatar (hidedefault) {
|
2014-04-07 16:04:16 +04:00
|
|
|
var $headerdiv = $('#header .avatardiv');
|
|
|
|
var $displaydiv = $('#displayavatar .avatardiv');
|
2013-09-04 15:16:21 +04:00
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
if (hidedefault) {
|
2013-10-04 04:27:53 +04:00
|
|
|
$headerdiv.hide();
|
2014-02-20 16:37:23 +04:00
|
|
|
$('#header .avatardiv').removeClass('avatardiv-shown');
|
2013-10-04 04:27:53 +04:00
|
|
|
} else {
|
|
|
|
$headerdiv.css({'background-color': ''});
|
|
|
|
$headerdiv.avatar(OC.currentUser, 32, true);
|
2014-02-20 16:37:23 +04:00
|
|
|
$('#header .avatardiv').addClass('avatardiv-shown');
|
2013-10-04 04:27:53 +04:00
|
|
|
}
|
2013-09-04 15:16:21 +04:00
|
|
|
$displaydiv.css({'background-color': ''});
|
|
|
|
$displaydiv.avatar(OC.currentUser, 128, true);
|
2014-02-21 00:53:59 +04:00
|
|
|
|
2014-03-12 18:42:29 +04:00
|
|
|
$('#removeavatar').show();
|
2013-08-24 02:35:32 +04:00
|
|
|
}
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
function showAvatarCropper () {
|
2014-04-07 16:04:16 +04:00
|
|
|
var $cropper = $('#cropper');
|
2013-09-05 21:26:02 +04:00
|
|
|
$cropper.prepend("<img>");
|
2014-04-07 16:04:16 +04:00
|
|
|
var $cropperImage = $('#cropper img');
|
2013-09-03 19:40:41 +04:00
|
|
|
|
2014-04-07 16:04:16 +04:00
|
|
|
$cropperImage.attr('src',
|
2015-02-17 17:25:38 +03:00
|
|
|
OC.generateUrl('/avatar/tmp') + '?requesttoken=' + encodeURIComponent(oc_requesttoken) + '#' + Math.floor(Math.random() * 1000));
|
2013-08-30 11:00:37 +04:00
|
|
|
|
2013-09-03 19:40:41 +04:00
|
|
|
// Looks weird, but on('load', ...) doesn't work in IE8
|
2014-08-15 19:18:46 +04:00
|
|
|
$cropperImage.ready(function () {
|
2013-09-03 19:40:41 +04:00
|
|
|
$('#displayavatar').hide();
|
|
|
|
$cropper.show();
|
2013-08-30 11:00:37 +04:00
|
|
|
|
2013-09-03 19:40:41 +04:00
|
|
|
$cropperImage.Jcrop({
|
2013-08-24 02:35:32 +04:00
|
|
|
onChange: saveCoords,
|
|
|
|
onSelect: saveCoords,
|
2013-08-29 18:56:32 +04:00
|
|
|
aspectRatio: 1,
|
|
|
|
boxHeight: 500,
|
2013-09-01 21:12:54 +04:00
|
|
|
boxWidth: 500,
|
|
|
|
setSelect: [0, 0, 300, 300]
|
2013-08-24 02:35:32 +04:00
|
|
|
});
|
2013-08-30 11:00:37 +04:00
|
|
|
});
|
2013-08-24 02:35:32 +04:00
|
|
|
}
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
function sendCropData () {
|
2013-09-05 21:26:02 +04:00
|
|
|
cleanCropper();
|
2013-09-03 19:40:41 +04:00
|
|
|
|
2014-04-07 16:04:16 +04:00
|
|
|
var cropperData = $('#cropper').data();
|
2013-08-24 02:35:32 +04:00
|
|
|
var data = {
|
2014-04-07 16:04:16 +04:00
|
|
|
x: cropperData.x,
|
|
|
|
y: cropperData.y,
|
|
|
|
w: cropperData.w,
|
|
|
|
h: cropperData.h
|
2013-08-24 02:35:32 +04:00
|
|
|
};
|
2014-03-03 01:30:24 +04:00
|
|
|
$.post(OC.generateUrl('/avatar/cropped'), {crop: data}, avatarResponseHandler);
|
2013-08-24 02:35:32 +04:00
|
|
|
}
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
function saveCoords (c) {
|
2013-08-24 02:35:32 +04:00
|
|
|
$('#cropper').data(c);
|
|
|
|
}
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
function cleanCropper () {
|
2014-04-07 16:04:16 +04:00
|
|
|
var $cropper = $('#cropper');
|
2013-09-05 21:26:02 +04:00
|
|
|
$('#displayavatar').show();
|
|
|
|
$cropper.hide();
|
|
|
|
$('.jcrop-holder').remove();
|
|
|
|
$('#cropper img').removeData('Jcrop').removeAttr('style').removeAttr('src');
|
|
|
|
$('#cropper img').remove();
|
|
|
|
}
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
function avatarResponseHandler (data) {
|
2014-04-07 16:04:16 +04:00
|
|
|
var $warning = $('#avatar .warning');
|
2013-08-24 02:35:32 +04:00
|
|
|
$warning.hide();
|
|
|
|
if (data.status === "success") {
|
|
|
|
updateAvatar();
|
2013-09-06 15:46:50 +04:00
|
|
|
} else if (data.data === "notsquare") {
|
2013-08-24 02:35:32 +04:00
|
|
|
showAvatarCropper();
|
|
|
|
} else {
|
|
|
|
$warning.show();
|
|
|
|
$warning.text(data.data.message);
|
|
|
|
}
|
2013-07-29 13:34:38 +04:00
|
|
|
}
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$(document).ready(function () {
|
2015-01-09 17:38:39 +03:00
|
|
|
if($('#pass2').length) {
|
|
|
|
$('#pass2').showPassword().keyup();
|
|
|
|
}
|
2014-08-15 19:18:46 +04:00
|
|
|
$("#passwordbutton").click(function () {
|
2015-03-31 14:41:10 +03:00
|
|
|
var isIE8or9 = $('html').hasClass('lte9');
|
2015-03-16 15:11:44 +03:00
|
|
|
// FIXME - TODO - once support for IE8 and IE9 is dropped
|
|
|
|
// for IE8 and IE9 this will check additionally if the typed in password
|
|
|
|
// is different from the placeholder, because in IE8/9 the placeholder
|
|
|
|
// is simply set as the value to look like a placeholder
|
|
|
|
if ($('#pass1').val() !== '' && $('#pass2').val() !== ''
|
|
|
|
&& !(isIE8or9 && $('#pass2').val() === $('#pass2').attr('placeholder'))) {
|
2011-08-28 01:40:41 +04:00
|
|
|
// Serialize the data
|
2014-08-15 19:18:46 +04:00
|
|
|
var post = $("#passwordform").serialize();
|
2011-08-28 01:40:41 +04:00
|
|
|
$('#passwordchanged').hide();
|
|
|
|
$('#passworderror').hide();
|
|
|
|
// Ajax foo
|
2014-08-15 19:18:46 +04:00
|
|
|
$.post(OC.generateUrl('/settings/personal/changepassword'), post, function (data) {
|
|
|
|
if (data.status === "success") {
|
2011-08-28 01:40:41 +04:00
|
|
|
$('#pass1').val('');
|
|
|
|
$('#pass2').val('');
|
2014-08-22 18:48:21 +04:00
|
|
|
// Hide a possible errormsg and show successmsg
|
|
|
|
$('#password-changed').removeClass('hidden').addClass('inlineblock');
|
|
|
|
$('#password-error').removeClass('inlineblock').addClass('hidden');
|
2014-08-15 19:18:46 +04:00
|
|
|
} else {
|
2013-09-06 10:05:07 +04:00
|
|
|
if (typeof(data.data) !== "undefined") {
|
|
|
|
$('#passworderror').html(data.data.message);
|
|
|
|
} else {
|
|
|
|
$('#passworderror').html(t('Unable to change password'));
|
|
|
|
}
|
2014-08-22 18:48:21 +04:00
|
|
|
// Hide a possible successmsg and show errormsg
|
|
|
|
$('#password-changed').removeClass('inlineblock').addClass('hidden');
|
|
|
|
$('#password-error').removeClass('hidden').addClass('inlineblock');
|
2011-08-28 01:40:41 +04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
} else {
|
2014-08-22 18:48:21 +04:00
|
|
|
// Hide a possible successmsg and show errormsg
|
|
|
|
$('#password-changed').removeClass('inlineblock').addClass('hidden');
|
|
|
|
$('#password-error').removeClass('hidden').addClass('inlineblock');
|
2011-08-28 01:40:41 +04:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2011-04-18 17:07:14 +04:00
|
|
|
});
|
2013-02-25 03:07:35 +04:00
|
|
|
|
2014-04-07 16:04:16 +04:00
|
|
|
$('#displayName').keyUpDelayedOrEnter(changeDisplayName);
|
|
|
|
$('#email').keyUpDelayedOrEnter(changeEmailAddress);
|
2013-12-07 20:33:27 +04:00
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$("#languageinput").change(function () {
|
2011-06-20 16:33:02 +04:00
|
|
|
// Serialize the data
|
2014-08-15 19:18:46 +04:00
|
|
|
var post = $("#languageinput").serialize();
|
2011-06-20 16:33:02 +04:00
|
|
|
// Ajax foo
|
2014-08-15 19:18:46 +04:00
|
|
|
$.post('ajax/setlanguage.php', post, function (data) {
|
|
|
|
if (data.status === "success") {
|
2011-08-28 01:06:15 +04:00
|
|
|
location.reload();
|
2011-06-20 16:33:02 +04:00
|
|
|
}
|
2014-08-15 19:18:46 +04:00
|
|
|
else {
|
|
|
|
$('#passworderror').html(data.data.message);
|
2011-06-20 16:33:02 +04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
});
|
2013-06-10 14:57:18 +04:00
|
|
|
|
2013-08-02 10:03:51 +04:00
|
|
|
var uploadparms = {
|
2014-08-15 19:18:46 +04:00
|
|
|
done: function (e, data) {
|
2013-08-24 02:35:32 +04:00
|
|
|
avatarResponseHandler(data.result);
|
2013-08-02 10:03:51 +04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$('#uploadavatarbutton').click(function () {
|
2013-08-15 12:34:12 +04:00
|
|
|
$('#uploadavatar').click();
|
|
|
|
});
|
|
|
|
|
2013-08-02 10:03:51 +04:00
|
|
|
$('#uploadavatar').fileupload(uploadparms);
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$('#selectavatar').click(function () {
|
2013-09-04 14:56:14 +04:00
|
|
|
OC.dialogs.filepicker(
|
|
|
|
t('settings', "Select a profile picture"),
|
2014-08-15 19:18:46 +04:00
|
|
|
function (path) {
|
2014-03-03 01:30:24 +04:00
|
|
|
$.post(OC.generateUrl('/avatar/'), {path: path}, avatarResponseHandler);
|
2013-09-04 14:56:14 +04:00
|
|
|
},
|
|
|
|
false,
|
2013-09-06 01:12:52 +04:00
|
|
|
["image/png", "image/jpeg"]
|
2013-09-04 14:56:14 +04:00
|
|
|
);
|
2013-07-29 13:34:38 +04:00
|
|
|
});
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$('#removeavatar').click(function () {
|
2013-08-19 00:10:23 +04:00
|
|
|
$.ajax({
|
2014-08-15 19:18:46 +04:00
|
|
|
type: 'DELETE',
|
|
|
|
url: OC.generateUrl('/avatar/'),
|
|
|
|
success: function () {
|
2013-10-04 04:27:53 +04:00
|
|
|
updateAvatar(true);
|
2014-03-12 18:42:29 +04:00
|
|
|
$('#removeavatar').hide();
|
2013-08-19 00:10:23 +04:00
|
|
|
}
|
|
|
|
});
|
2013-07-29 13:34:38 +04:00
|
|
|
});
|
2013-09-03 19:40:41 +04:00
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$('#abortcropperbutton').click(function () {
|
2013-09-05 21:26:02 +04:00
|
|
|
cleanCropper();
|
2013-09-03 19:40:41 +04:00
|
|
|
});
|
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
$('#sendcropperbutton').click(function () {
|
2013-09-03 19:40:41 +04:00
|
|
|
sendCropData();
|
|
|
|
});
|
2013-03-13 14:03:52 +04:00
|
|
|
|
|
|
|
$('#pass2').strengthify({
|
2014-11-06 12:15:22 +03:00
|
|
|
zxcvbn: OC.linkTo('core','vendor/zxcvbn/zxcvbn.js'),
|
2013-03-13 14:03:52 +04:00
|
|
|
titles: [
|
|
|
|
t('core', 'Very weak password'),
|
|
|
|
t('core', 'Weak password'),
|
|
|
|
t('core', 'So-so password'),
|
|
|
|
t('core', 'Good password'),
|
|
|
|
t('core', 'Strong password')
|
|
|
|
]
|
|
|
|
});
|
2014-02-21 00:53:59 +04:00
|
|
|
|
|
|
|
// does the user have a custom avatar? if he does hide #removeavatar
|
|
|
|
// needs to be this complicated because we can't check yet if an avatar has been loaded, because it's async
|
2014-03-12 18:31:48 +04:00
|
|
|
var url = OC.generateUrl(
|
|
|
|
'/avatar/{user}/{size}',
|
|
|
|
{user: OC.currentUser, size: 1}
|
2015-02-17 17:25:38 +03:00
|
|
|
) + '?requesttoken=' + encodeURIComponent(oc_requesttoken);
|
2014-08-15 19:18:46 +04:00
|
|
|
$.get(url, function (result) {
|
2014-03-12 18:31:48 +04:00
|
|
|
if (typeof(result) === 'object') {
|
2014-03-12 18:42:29 +04:00
|
|
|
$('#removeavatar').hide();
|
2014-03-12 18:31:48 +04:00
|
|
|
}
|
2014-02-21 00:53:59 +04:00
|
|
|
});
|
2014-08-15 19:18:46 +04:00
|
|
|
|
|
|
|
$('#sslCertificate').on('click', 'td.remove > img', function () {
|
|
|
|
var row = $(this).parent().parent();
|
2015-04-15 15:21:23 +03:00
|
|
|
$.ajax(OC.generateUrl('settings/personal/certificate/{certificate}', {certificate: row.data('name')}), {
|
|
|
|
type: 'DELETE'
|
2014-08-15 19:18:46 +04:00
|
|
|
});
|
|
|
|
row.remove();
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
2015-04-15 13:25:10 +03:00
|
|
|
$('#sslCertificate tr > td').tipsy({gravity: 'n', live: true});
|
2014-08-15 19:18:46 +04:00
|
|
|
|
|
|
|
$('#rootcert_import').fileupload({
|
2015-04-15 15:21:23 +03:00
|
|
|
success: function (data) {
|
|
|
|
var issueDate = new Date(data.validFrom * 1000);
|
|
|
|
var expireDate = new Date(data.validTill * 1000);
|
2014-08-15 19:18:46 +04:00
|
|
|
var now = new Date();
|
|
|
|
var isExpired = !(issueDate <= now && now <= expireDate);
|
|
|
|
|
|
|
|
var row = $('<tr/>');
|
2015-04-15 15:21:23 +03:00
|
|
|
row.data('name', data.name);
|
2014-08-15 19:18:46 +04:00
|
|
|
row.addClass(isExpired? 'expired': 'valid');
|
2015-04-15 15:21:23 +03:00
|
|
|
row.append($('<td/>').attr('title', data.organization).text(data.commonName));
|
2015-04-15 19:06:57 +03:00
|
|
|
row.append($('<td/>').attr('title', t('core,', 'Valid until {date}', {date: data.validTillString}))
|
2015-04-15 15:21:23 +03:00
|
|
|
.text(data.validTillString));
|
|
|
|
row.append($('<td/>').attr('title', data.issuerOrganization).text(data.issuer));
|
2014-08-15 19:18:46 +04:00
|
|
|
row.append($('<td/>').addClass('remove').append(
|
|
|
|
$('<img/>').attr({
|
|
|
|
alt: t('core', 'Delete'),
|
|
|
|
title: t('core', 'Delete'),
|
|
|
|
src: OC.imagePath('core', 'actions/delete.svg')
|
|
|
|
}).addClass('action')
|
|
|
|
));
|
|
|
|
|
|
|
|
$('#sslCertificate tbody').append(row);
|
2015-04-15 15:21:23 +03:00
|
|
|
},
|
2015-04-21 13:01:56 +03:00
|
|
|
fail: function () {
|
|
|
|
OC.Notification.showTemporary(
|
|
|
|
t('settings', 'An error occurred. Please upload an ASCII-encoded PEM certificate.'));
|
2014-08-15 19:18:46 +04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#rootcert_import_button').click(function () {
|
|
|
|
$('#rootcert_import').click();
|
|
|
|
});
|
|
|
|
});
|
2013-07-29 19:06:05 +04:00
|
|
|
|
2015-04-21 13:01:56 +03:00
|
|
|
if (!OC.Encryption) {
|
|
|
|
OC.Encryption = {};
|
|
|
|
}
|
2013-07-29 19:06:05 +04:00
|
|
|
|
2014-08-15 19:18:46 +04:00
|
|
|
OC.Encryption.msg = {
|
|
|
|
start: function (selector, msg) {
|
|
|
|
var spinner = '<img src="' + OC.imagePath('core', 'loading-small.gif') + '">';
|
2013-07-29 19:06:05 +04:00
|
|
|
$(selector)
|
2014-08-15 19:18:46 +04:00
|
|
|
.html(msg + ' ' + spinner)
|
2013-07-29 19:06:05 +04:00
|
|
|
.removeClass('success')
|
|
|
|
.removeClass('error')
|
|
|
|
.stop(true, true)
|
|
|
|
.show();
|
|
|
|
},
|
2014-08-15 19:18:46 +04:00
|
|
|
finished: function (selector, data) {
|
|
|
|
if (data.status === "success") {
|
|
|
|
$(selector).html(data.data.message)
|
2013-07-29 19:06:05 +04:00
|
|
|
.addClass('success')
|
|
|
|
.stop(true, true)
|
2013-11-20 15:23:10 +04:00
|
|
|
.delay(3000);
|
2014-08-15 19:18:46 +04:00
|
|
|
} else {
|
|
|
|
$(selector).html(data.data.message).addClass('error');
|
2013-07-29 19:06:05 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|