mirror of
https://github.com/pierre42100/ComunicWeb
synced 2024-11-22 20:19:21 +00:00
Can send a request to the server to upload an image
This commit is contained in:
parent
612949a86a
commit
e533d1e2f8
@ -95,5 +95,16 @@ ComunicWeb.components.settings.interface = {
|
||||
var apiURI = "settings/get_account_image";
|
||||
var params = {};
|
||||
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, callback);
|
||||
},
|
||||
|
||||
/**
|
||||
* Upload a new account image
|
||||
*
|
||||
* @param {FormData} data The data containing information about the new account image
|
||||
* @param {function} callback
|
||||
*/
|
||||
uploadAccountImage: function(data, callback){
|
||||
var apiURI = "settings/upload_account_image";
|
||||
ComunicWeb.common.api.makeFormDatarequest(apiURI, data, true, callback);
|
||||
}
|
||||
}
|
@ -57,7 +57,61 @@ ComunicWeb.pages.settings.sections.accountImage = {
|
||||
}
|
||||
|
||||
//Apply account image settings
|
||||
var accountImageForm = createElem2({
|
||||
type: "div",
|
||||
appendTo: boxBody
|
||||
});
|
||||
|
||||
//First, offer the user to upload a new account image
|
||||
var newAccountImageLabel = createElem2({
|
||||
appendTo: accountImageForm,
|
||||
type: "label"
|
||||
});
|
||||
var fileInput = createElem2({
|
||||
appendTo: newAccountImageLabel,
|
||||
type: "input",
|
||||
elemType: "file"
|
||||
});
|
||||
fileInput.style.display = "none";
|
||||
var chooseButton = createElem2({
|
||||
appendTo: newAccountImageLabel,
|
||||
type: "div",
|
||||
class: "btn btn-primary",
|
||||
innerHTML: "Upload a new picture"
|
||||
});
|
||||
|
||||
//Add event listener
|
||||
fileInput.addEventListener("change", function(e){
|
||||
|
||||
//Check if no file have been selected
|
||||
if(fileInput.files.length == 0)
|
||||
return;
|
||||
|
||||
//Upload the new file
|
||||
//Display a callout message
|
||||
var message = ComunicWeb.common.messages.createCalloutElem("", "Please wait while your picture is being uploaded...");
|
||||
boxBody.insertBefore(message, accountImageForm);
|
||||
|
||||
//Upload the image
|
||||
var fd = new FormData();
|
||||
fd.append("picture", fileInput.files[0], fileInput.files[0].name);
|
||||
ComunicWeb.components.settings.interface.uploadAccountImage(fd, function(result){
|
||||
|
||||
//Remove message
|
||||
message.remove();
|
||||
|
||||
//Check for errors
|
||||
if(result.error){
|
||||
notify("An error occured while trying to upload your image !", "danger");
|
||||
return;
|
||||
}
|
||||
|
||||
notify("Your picture has been successfully uploaded !", "success");
|
||||
|
||||
//Reload current page
|
||||
ComunicWeb.common.system.reset();
|
||||
});
|
||||
});
|
||||
});
|
||||
},
|
||||
}
|
Loading…
Reference in New Issue
Block a user