2020-08-21 10:07:39 +03:00
|
|
|
export const upload = async ({ file, slate, context }) => {
|
2020-08-20 08:20:18 +03:00
|
|
|
let formData = new FormData();
|
|
|
|
const HEIC2ANY = require("heic2any");
|
|
|
|
|
2020-08-20 08:29:33 +03:00
|
|
|
// NOTE(jim): You must provide a file from an type="file" input field.
|
|
|
|
if (!file) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-08-20 08:20:18 +03:00
|
|
|
// TODO(jim): Put this somewhere else to handle conversion cases.
|
|
|
|
if (file.type.startsWith("image/heic")) {
|
|
|
|
const converted = await HEIC2ANY({
|
|
|
|
blob: file,
|
|
|
|
toType: "image/png",
|
|
|
|
quality: 1,
|
|
|
|
});
|
|
|
|
|
|
|
|
formData.append("data", converted);
|
|
|
|
} else {
|
|
|
|
formData.append("data", file);
|
|
|
|
}
|
|
|
|
|
2020-08-20 08:29:33 +03:00
|
|
|
const _privateUploadMethod = (path) =>
|
2020-08-20 08:20:18 +03:00
|
|
|
new Promise((resolve, reject) => {
|
|
|
|
const XHR = new XMLHttpRequest();
|
|
|
|
XHR.open("post", path, true);
|
|
|
|
XHR.onerror = (event) => {
|
|
|
|
console.log(event);
|
|
|
|
};
|
|
|
|
|
|
|
|
// NOTE(jim): UPLOADS ONLY.
|
|
|
|
XHR.upload.addEventListener(
|
|
|
|
"progress",
|
|
|
|
(event) => {
|
2020-08-21 10:07:39 +03:00
|
|
|
if (!context) {
|
2020-08-20 08:29:33 +03:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-08-20 08:20:18 +03:00
|
|
|
if (event.lengthComputable) {
|
|
|
|
console.log("FILE UPLOAD PROGRESS", event);
|
2020-08-21 10:07:39 +03:00
|
|
|
context.setState({
|
2020-08-20 08:20:18 +03:00
|
|
|
fileLoading: {
|
2020-08-21 10:07:39 +03:00
|
|
|
...context.state.fileLoading,
|
2020-08-20 08:20:18 +03:00
|
|
|
[`${file.lastModified}-${file.name}`]: {
|
|
|
|
name: file.name,
|
|
|
|
loaded: event.loaded,
|
|
|
|
total: event.total,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
false
|
|
|
|
);
|
|
|
|
|
|
|
|
XHR.onloadend = (event) => {
|
|
|
|
console.log("FILE UPLOAD END", event);
|
|
|
|
try {
|
|
|
|
return resolve(JSON.parse(event.target.response));
|
|
|
|
} catch (e) {
|
|
|
|
return resolve({
|
|
|
|
error: "SERVER_UPLOAD_ERROR",
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
XHR.send(formData);
|
|
|
|
});
|
|
|
|
|
2020-08-20 08:29:33 +03:00
|
|
|
const json = await _privateUploadMethod(`/api/data/${file.name}`);
|
2020-08-20 08:20:18 +03:00
|
|
|
if (!json || json.error || !json.data) {
|
2020-08-21 10:07:39 +03:00
|
|
|
if (context) {
|
|
|
|
context.setState({
|
2020-08-20 08:29:33 +03:00
|
|
|
fileLoading: {
|
2020-08-21 10:07:39 +03:00
|
|
|
...context.state.fileLoading,
|
2020-08-20 08:29:33 +03:00
|
|
|
[`${file.lastModified}-${file.name}`]: {
|
|
|
|
name: file.name,
|
|
|
|
failed: true,
|
|
|
|
},
|
2020-08-20 08:20:18 +03:00
|
|
|
},
|
2020-08-20 08:29:33 +03:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-08-20 08:20:18 +03:00
|
|
|
return !json ? { error: "NO_RESPONSE" } : json;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (slate) {
|
|
|
|
const addResponse = await fetch(`/api/slates/add-url`, {
|
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
Accept: "application/json",
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
body: JSON.stringify({ slate, data: { ...json.data } }),
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!addResponse || addResponse.error) {
|
|
|
|
console.log(addResponse.error);
|
|
|
|
alert("TODO: Adding an image to Slate went wrong.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return json;
|
|
|
|
};
|