twister-html/js/interface_profile-edit.js

120 lines
4.1 KiB
JavaScript
Raw Normal View History

2013-12-30 12:42:36 -02:00
// interface_profile-edit.js
// 2013 Miguel Freitas
//
// Profile editing interface (profile-edit.html)
var newUserWarnDisplayed = false;
function initProfileEdit() {
// Check for the various File API support.
if (window.File && window.FileReader && window.FileList && window.Blob) {
// Great success! All the File APIs are supported.
2013-12-30 12:42:36 -02:00
} else {
alert('The File APIs are not fully supported in this browser.');
2013-12-30 12:42:36 -02:00
}
2013-12-30 12:42:36 -02:00
initInterfaceCommon();
$('.profile-card-photo.forEdition').on('click', function () {$('#avatar-file').trigger('click');});
$('#avatar-file').on('change', handleAvatarFileSelect);
$('.submit-changes').on('click', saveProfile);
$('.cancel-changes').on('click', $.MAL.goHome);
2013-12-30 12:42:36 -02:00
initUser(function() {
if (!defaultScreenName) {
alert(polyglot.t('username_undefined'));
2013-12-30 12:42:36 -02:00
$.MAL.goLogin();
return;
}
checkNetworkStatusAndAskRedirect();
2013-12-30 12:42:36 -02:00
loadFollowing(function() {
twisterFollowingO = TwisterFollowing(defaultScreenName);
verifyUserAlreadyInBlockchain();
initMentionsCount();
initDMsCount();
});
2013-12-30 12:42:36 -02:00
$('.profile-card-main h2').text('@' + defaultScreenName);
2013-12-30 12:42:36 -02:00
loadAvatarForEdit();
loadProfileForEdit();
$('.secret-key-container').hide();
$('.toggle-priv-key').on('click', function () {
if ($('.secret-key-container').is(':visible')) {
$('.secret-key-container').fadeOut(function () {
$('.secret-key').text('');
});
} else {
dumpPrivkey(defaultScreenName, function(args, key) {
$('.secret-key').text(key);
$('.secret-key-container').fadeIn();
}, {});
}
});
2013-12-30 12:42:36 -02:00
});
}
function handleAvatarFileSelect(event) {
var files = event.target.files; // FileList object
var file = files[0];
2013-12-30 12:42:36 -02:00
// Only process image files.
if (file.type.match('image.*')) {
2013-12-30 12:42:36 -02:00
var reader = new FileReader();
reader.onload = function(event) {
var img = new Image();
img.onload = function() {
var MAXWidthHeight = 64;
var ratio = MAXWidthHeight / Math.max(this.width, this.height);
var canvas = document.createElement('canvas');
canvas.width = Math.round(this.width * ratio);
canvas.height = Math.round(this.height * ratio);
canvas.getContext('2d').drawImage(this, 0, 0, canvas.width, canvas.height);
var imgURL = undefined;
for (var quality = 1.0; (!imgURL || imgURL.length > 4096) && quality > 0.1; quality -= 0.01) {
imgURL = canvas.toDataURL('image/jpeg', quality);
}
$('.profile-card-photo.forEdition').attr('src', imgURL);
}
img.src = event.target.result;
2013-12-30 12:42:36 -02:00
}
// Read in the image file as a data URL.
reader.readAsDataURL(file);
2013-12-30 12:42:36 -02:00
}
}
function verifyUserAlreadyInBlockchain() {
$.MAL.disableButton($('.submit-changes'));
2013-12-30 12:42:36 -02:00
dumpPubkey(defaultScreenName, function(args, pubkey) {
if (pubkey.length > 0) {
follow('twister', true, function() {
$.MAL.enableButton($('.submit-changes'));
});
} else {
if (!newUserWarnDisplayed) {
alert(polyglot.t('user_not_yet_accepted'));
newUserWarnDisplayed = true;
}
setTimeout(verifyUserAlreadyInBlockchain, 5000);
}
}, {});
2013-12-30 12:42:36 -02:00
}
2014-09-21 14:06:48 +02:00
function localizePlaceholders() {
$('.input-name').attr('placeholder', polyglot.t('Full name here'));
$('.input-description').attr('placeholder', polyglot.t('Describe yourself'));
$('.input-city').attr('placeholder', polyglot.t('Location'));
$('.input-website').attr('placeholder', polyglot.t('website'));
$('.input-tox').attr('placeholder', polyglot.t('Tox address'));
$('.input-bitmessage').attr('placeholder', polyglot.t('Bitmessage address'));
2014-09-21 14:06:48 +02:00
}
$(localizePlaceholders);