upload.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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. headers: {
  28. 'auth': localStorage.token
  29. }
  30. });
  31. // Update the total progress bar
  32. dropzone.on("uploadprogress", function(file, progress) {
  33. file.previewElement.querySelector(".progress").style.width = progress + "%";
  34. });
  35. dropzone.on("success", function(file, response) {
  36. // Handle the responseText here. For example, add the text to the preview element:
  37. a = document.createElement('a');
  38. a.href = response.url;
  39. a.target = '_blank';
  40. a.innerHTML = response.filename;
  41. file.previewTemplate.querySelector(".progress").style.display = 'none';
  42. file.previewTemplate.querySelector(".link").appendChild(a);
  43. });
  44. }
  45. function getInfo(token) {
  46. var xhr = new XMLHttpRequest();
  47. xhr.onreadystatechange = function() {
  48. if (xhr.readyState == XMLHttpRequest.DONE) {
  49. if(xhr.responseText !== 'not-authorized'){
  50. div = document.createElement('div');
  51. div.id = 'dropzone';
  52. div.innerHTML = 'Click here or drag and drop files';
  53. div.style.display = 'flex';
  54. document.getElementById('btnGithub').style.display = 'none';
  55. document.getElementById('tokenContainer').style.display = 'none';
  56. document.getElementById('uploadContainer').appendChild(div);
  57. if(xhr.responseText.maxFileSize) maxSize = xhr.responseText.maxFileSize;
  58. if(token) localStorage.token = token;
  59. prepareDropzone();
  60. }
  61. }
  62. }
  63. xhr.open('GET', '/api/info', true);
  64. xhr.setRequestHeader('auth', token);
  65. xhr.send(null);
  66. }
  67. };