upload.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. window.onload = function () {
  2. var maxSize = '512';
  3. if(!localStorage.token){
  4. document.getElementById('tokenContainer').style.display = 'flex'
  5. document.getElementById("tokenSubmit").addEventListener("click", function(){
  6. getInfo(document.getElementById("token").value)
  7. });
  8. }else{
  9. getInfo(localStorage.token);
  10. }
  11. function prepareDropzone(){
  12. var previewNode = document.querySelector("#template");
  13. previewNode.id = "";
  14. var previewTemplate = previewNode.parentNode.innerHTML;
  15. previewNode.parentNode.removeChild(previewNode);
  16. var dropzone = new Dropzone('div#dropzone', {
  17. url: '/api/upload',
  18. paramName: 'file',
  19. maxFilesize: maxSize,
  20. parallelUploads: 2,
  21. uploadMultiple: false,
  22. previewsContainer: 'div#uploads',
  23. previewTemplate: previewTemplate,
  24. createImageThumbnails: false,
  25. maxFiles: 1000,
  26. autoProcessQueue: true
  27. });
  28. // Update the total progress bar
  29. dropzone.on("uploadprogress", function(file, progress) {
  30. file.previewElement.querySelector(".progress").style.width = progress + "%";
  31. });
  32. dropzone.on("success", function(file, response) {
  33. // Handle the responseText here. For example, add the text to the preview element:
  34. a = document.createElement('a');
  35. a.href = response.url;
  36. a.target = '_blank';
  37. a.innerHTML = response.filename;
  38. file.previewTemplate.querySelector(".progress").style.display = 'none';
  39. file.previewTemplate.querySelector(".link").appendChild(a);
  40. });
  41. }
  42. function getInfo(token) {
  43. var xhr = new XMLHttpRequest();
  44. xhr.onreadystatechange = function() {
  45. if (xhr.readyState == XMLHttpRequest.DONE) {
  46. if(xhr.responseText !== 'not-authorized'){
  47. div = document.createElement('div');
  48. div.id = 'dropzone';
  49. div.innerHTML = 'Click here or drag and drop files';
  50. div.style.display = 'flex';
  51. document.getElementById('btnGithub').style.display = 'none';
  52. document.getElementById('tokenContainer').style.display = 'none';
  53. document.getElementById('uploadContainer').appendChild(div);
  54. if(xhr.responseText.maxFileSize) maxSize = xhr.responseText.maxFileSize;
  55. if(token) localStorage.token = token;
  56. prepareDropzone();
  57. }
  58. }
  59. }
  60. xhr.open('GET', '/api/info', true);
  61. xhr.setRequestHeader('auth', token);
  62. xhr.send(null);
  63. }
  64. };