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);
});
Did this answer your question? Thanks for the feedback There was a problem submitting your feedback. Please try again later.