JavaScript Upload
If you are developing a custom application that is handling files in the browser via JavaScript, you can use the JavaScript API of the widget to manually upload files.
The field supports file uploads form a Blob or a base64 encoded string.
Upload API
UploadField.uploadFile(file: Blob|Base64): Promise<File>
The API returns a Promise that resolves with a file domain object that contains information about the file storage location.
Note: for the upload field to link the uploaded files with an order, the upload field needs to be placed inside a <form action="/cart/add"></from> . (This is done automatically on product pages)
To get access to the upload field instance:
/* wait for the upload widget to be ready (only needed if the code is executed right after pageload) */ window.addEventListener('cloudlift.upload.ready', function(e) { /* get field reference (update index in case of multiple fields) */ var field = window.Cloudlift.upload.App.fields[0]; ... });
Blob Upload Example
/* helper function */ function urlToBlob(url) { return new Promise(function(resolve, reject) { try { var xhr = new XMLHttpRequest(); xhr.open("GET", url); xhr.responseType = "blob"; xhr.onerror = function() {reject("Network error.")}; xhr.onload = function() { if (xhr.status === 200) {resolve(xhr.response)} else {reject("Loading error:" + xhr.statusText)} }; xhr.send(); } catch(err) {reject(err.message)} }); } urlToBlob('https://img.icons8.com/color/48/000000/tesla-logo.png').then(function(blob) { field.uploadFile(blob).then(function(file) { console.debug('got file upload: ', file); }); })
Base64 Example
field.uploadFile('') .then(function(file) { console.debug('got file upload: ', file); });