2016-07-16 01:05:18 +02:00
|
|
|
import axios from 'axios';
|
2016-07-19 22:49:46 +02:00
|
|
|
import { createFile } from './files';
|
2016-07-16 01:05:18 +02:00
|
|
|
|
2017-02-22 20:29:35 +01:00
|
|
|
const textFileRegex = /(text\/|application\/json)/;
|
2016-09-09 04:02:42 +02:00
|
|
|
const s3BucketHttps = `https://s3-us-west-2.amazonaws.com/${process.env.S3_BUCKET}/`;
|
2017-03-16 05:34:14 +01:00
|
|
|
const ROOT_URL = process.env.API_URL;
|
2016-10-25 21:51:44 +02:00
|
|
|
const MAX_LOCAL_FILE_SIZE = 80000; // bytes, aka 80 KB
|
2016-07-16 01:05:18 +02:00
|
|
|
|
2016-08-25 06:18:28 +02:00
|
|
|
function localIntercept(file, options = {}) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
if (!options.readType) {
|
|
|
|
// const mime = file.type;
|
|
|
|
// const textType = a(_textTypes).any(type => {
|
|
|
|
// const re = new RegExp(type);
|
|
|
|
// return re.test(mime);
|
|
|
|
// });
|
|
|
|
// options.readType = textType ? 'readAsText' : 'readAsDataURL';
|
|
|
|
options.readType = 'readAsText'; // eslint-disable-line
|
|
|
|
}
|
|
|
|
const reader = new window.FileReader();
|
|
|
|
reader.onload = () => {
|
|
|
|
resolve(reader.result);
|
|
|
|
};
|
|
|
|
reader.onerror = () => {
|
|
|
|
reject(reader.result);
|
|
|
|
};
|
|
|
|
|
|
|
|
// run the reader
|
|
|
|
reader[options.readType](file);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-07-16 01:05:18 +02:00
|
|
|
export function dropzoneAcceptCallback(file, done) {
|
2016-12-14 02:08:10 +01:00
|
|
|
return () => {
|
2016-08-25 06:18:28 +02:00
|
|
|
// for text files and small files
|
|
|
|
// check mime type
|
|
|
|
// if text, local interceptor
|
2016-10-25 21:51:44 +02:00
|
|
|
if (file.type.match(textFileRegex) && file.size < MAX_LOCAL_FILE_SIZE) {
|
2017-02-22 20:29:35 +01:00
|
|
|
localIntercept(file).then((result) => {
|
2016-08-25 06:18:28 +02:00
|
|
|
file.content = result; // eslint-disable-line
|
2016-10-24 22:33:16 +02:00
|
|
|
done('Uploading plaintext file locally.');
|
2016-08-25 06:18:28 +02:00
|
|
|
})
|
2017-02-22 20:29:35 +01:00
|
|
|
.catch((result) => {
|
2016-08-25 06:18:28 +02:00
|
|
|
done(`Failed to download file ${file.name}: ${result}`);
|
|
|
|
console.warn(file);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
file.postData = []; // eslint-disable-line
|
|
|
|
axios.post(`${ROOT_URL}/S3/sign`, {
|
|
|
|
name: file.name,
|
|
|
|
type: file.type,
|
|
|
|
size: file.size,
|
|
|
|
// _csrf: document.getElementById('__createPostToken').value
|
|
|
|
},
|
|
|
|
{
|
|
|
|
withCredentials: true
|
|
|
|
})
|
2017-02-22 20:29:35 +01:00
|
|
|
.then((response) => {
|
2016-08-25 06:18:28 +02:00
|
|
|
file.custom_status = 'ready'; // eslint-disable-line
|
|
|
|
file.postData = response.data; // eslint-disable-line
|
|
|
|
file.s3 = response.data.key; // eslint-disable-line
|
|
|
|
file.previewTemplate.className += ' uploading'; // eslint-disable-line
|
|
|
|
done();
|
2016-07-19 22:49:46 +02:00
|
|
|
})
|
2017-02-22 20:29:35 +01:00
|
|
|
.catch((response) => {
|
2016-08-25 06:18:28 +02:00
|
|
|
file.custom_status = 'rejected'; // eslint-disable-line
|
|
|
|
if (response.data.responseText && response.data.responseText.message) {
|
|
|
|
done(response.data.responseText.message);
|
|
|
|
}
|
|
|
|
done('error preparing the upload');
|
|
|
|
});
|
|
|
|
}
|
2016-07-19 22:49:46 +02:00
|
|
|
};
|
2016-07-16 01:05:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export function dropzoneSendingCallback(file, xhr, formData) {
|
2016-07-19 22:49:46 +02:00
|
|
|
return () => {
|
2016-10-25 21:51:44 +02:00
|
|
|
if (!file.type.match(textFileRegex) || file.size >= MAX_LOCAL_FILE_SIZE) {
|
2017-02-22 20:29:35 +01:00
|
|
|
Object.keys(file.postData).forEach((key) => {
|
2016-08-25 06:18:28 +02:00
|
|
|
formData.append(key, file.postData[key]);
|
|
|
|
});
|
|
|
|
formData.append('Content-type', '');
|
|
|
|
formData.append('Content-length', '');
|
|
|
|
formData.append('acl', 'public-read');
|
|
|
|
}
|
2016-07-19 22:49:46 +02:00
|
|
|
};
|
2016-07-16 01:05:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export function dropzoneCompleteCallback(file) {
|
2016-07-19 22:49:46 +02:00
|
|
|
return (dispatch, getState) => { // eslint-disable-line
|
2016-10-25 21:51:44 +02:00
|
|
|
if ((!file.type.match(textFileRegex) || file.size >= MAX_LOCAL_FILE_SIZE) && file.status !== 'error') {
|
2016-08-25 06:18:28 +02:00
|
|
|
let inputHidden = '<input type="hidden" name="attachments[]" value="';
|
|
|
|
const json = {
|
2016-09-09 04:15:29 +02:00
|
|
|
url: `${s3BucketHttps}${file.postData.key}`,
|
2016-08-25 06:18:28 +02:00
|
|
|
originalFilename: file.name
|
|
|
|
};
|
2016-09-09 04:02:42 +02:00
|
|
|
// console.log(json, JSON.stringify(json), JSON.stringify(json).replace('"', '\\"'));
|
2016-08-25 06:18:28 +02:00
|
|
|
inputHidden += `${window.btoa(JSON.stringify(json))}" />`;
|
|
|
|
// document.getElementById('uploader').appendChild(inputHidden);
|
|
|
|
document.getElementById('uploader').innerHTML += inputHidden;
|
2016-07-19 22:49:46 +02:00
|
|
|
|
2016-08-25 06:18:28 +02:00
|
|
|
const formParams = {
|
|
|
|
name: file.name,
|
2016-09-09 04:02:42 +02:00
|
|
|
url: `${s3BucketHttps}${file.postData.key}`
|
2016-08-25 06:18:28 +02:00
|
|
|
};
|
|
|
|
createFile(formParams)(dispatch, getState);
|
2016-10-25 03:15:32 +02:00
|
|
|
} else if (file.content !== undefined) {
|
2016-08-25 06:18:28 +02:00
|
|
|
const formParams = {
|
|
|
|
name: file.name,
|
|
|
|
content: file.content
|
|
|
|
};
|
|
|
|
createFile(formParams)(dispatch, getState);
|
|
|
|
}
|
2016-07-16 01:05:18 +02:00
|
|
|
};
|
|
|
|
}
|