2019-02-13 17:40:33 -08:00
|
|
|
// Hide the noscript div, because our javascript is executing
|
|
|
|
document.getElementById('noscript').style.display = 'none';
|
|
|
|
|
2019-02-13 12:49:42 +11:00
|
|
|
var form = document.getElementById('send');
|
|
|
|
var fileSelect = document.getElementById('file-select');
|
|
|
|
var uploadButton = document.getElementById('send-button');
|
2019-02-15 14:52:00 -08:00
|
|
|
var flashes = document.getElementById('flashes');
|
|
|
|
|
|
|
|
// Add a flash message
|
|
|
|
function flash(category, message) {
|
|
|
|
var el = document.createElement('li');
|
|
|
|
el.innerText = message;
|
|
|
|
el.className = category;
|
|
|
|
flashes.appendChild(el);
|
|
|
|
}
|
2019-02-13 12:49:42 +11:00
|
|
|
|
|
|
|
form.onsubmit = function(event) {
|
|
|
|
event.preventDefault();
|
|
|
|
|
2019-02-13 09:56:36 -08:00
|
|
|
// Disable button, and update text
|
|
|
|
uploadButton.innerHTML = 'Uploading ...';
|
2019-02-14 09:45:41 -08:00
|
|
|
uploadButton.disabled = true;
|
|
|
|
fileSelect.disabled = true;
|
2019-02-13 12:49:42 +11:00
|
|
|
|
2019-02-13 09:56:36 -08:00
|
|
|
// Create form data
|
2019-02-13 12:49:42 +11:00
|
|
|
var files = fileSelect.files;
|
|
|
|
var formData = new FormData();
|
|
|
|
for (var i = 0; i < files.length; i++) {
|
|
|
|
var file = files[i];
|
|
|
|
formData.append('file[]', file, file.name);
|
|
|
|
}
|
|
|
|
|
2019-02-13 09:56:36 -08:00
|
|
|
// Set up the request
|
|
|
|
var ajax = new XMLHttpRequest();
|
|
|
|
|
|
|
|
ajax.upload.addEventListener('progress', function(event){
|
|
|
|
console.log('upload progress', 'uploaded '+event.loaded+' bytes / '+event.total+' bytes');
|
2019-02-14 09:45:41 -08:00
|
|
|
var percent = parseInt((event.loaded / event.total) * 100, 10);
|
2019-02-13 09:56:36 -08:00
|
|
|
uploadButton.innerHTML = 'Uploading '+percent+'%';
|
|
|
|
}, false);
|
|
|
|
|
2019-02-15 14:52:00 -08:00
|
|
|
ajax.addEventListener('load', function(event){
|
|
|
|
console.log('upload finished', ajax.response);
|
2019-02-13 09:56:36 -08:00
|
|
|
if(ajax.status == 200) {
|
2019-02-15 14:52:00 -08:00
|
|
|
// Parse response
|
|
|
|
try {
|
|
|
|
var response = JSON.parse(ajax.response);
|
|
|
|
|
|
|
|
// The 'new_body' response replaces the whole HTML document and ends
|
|
|
|
if('new_body' in response) {
|
|
|
|
document.body.innerHTML = response['new_body'];
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Show error flashes
|
|
|
|
if('error_flashes' in response) {
|
|
|
|
for(var i=0; i<response['error_flashes'].length; i++) {
|
|
|
|
flash('error', response['error_flashes'][i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Show info flashes
|
|
|
|
if('info_flashes' in response) {
|
|
|
|
for(var i=0; i<response['info_flashes'].length; i++) {
|
|
|
|
flash('info', response['info_flashes'][i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch(e) {
|
|
|
|
console.log('invalid response', ajax.response);
|
|
|
|
flash('error', 'Invalid response from server: '+ajax.response);
|
|
|
|
}
|
|
|
|
|
2019-02-13 09:56:36 -08:00
|
|
|
// Re-enable button, and update text
|
|
|
|
uploadButton.innerHTML = 'Send Files';
|
|
|
|
uploadButton.disabled = false;
|
2019-02-14 09:45:41 -08:00
|
|
|
fileSelect.disabled = false;
|
2019-02-13 09:56:36 -08:00
|
|
|
}
|
|
|
|
}, false);
|
|
|
|
|
2019-02-15 14:52:00 -08:00
|
|
|
ajax.addEventListener('error', function(event){
|
2019-02-13 09:56:36 -08:00
|
|
|
console.log('error', event);
|
2019-02-15 14:52:00 -08:00
|
|
|
flash('error', 'Error uploading');
|
2019-02-13 09:56:36 -08:00
|
|
|
}, false);
|
|
|
|
|
2019-02-15 14:52:00 -08:00
|
|
|
ajax.addEventListener('abort', function(event){
|
2019-02-13 09:56:36 -08:00
|
|
|
console.log('abort', event);
|
2019-02-15 14:52:00 -08:00
|
|
|
flash('error', 'Upload aborted');
|
2019-02-13 09:56:36 -08:00
|
|
|
}, false);
|
|
|
|
|
|
|
|
// Send the request
|
2019-02-15 14:52:00 -08:00
|
|
|
ajax.open('POST', window.location.pathname + '/upload-ajax', true);
|
2019-02-13 09:56:36 -08:00
|
|
|
ajax.send(formData);
|
2019-02-15 14:52:00 -08:00
|
|
|
console.log('upload started');
|
2019-02-13 12:49:42 +11:00
|
|
|
}
|