shareupload.html 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <!--
  2. Copyright (C) 2019-2022 Nicola Murino
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU Affero General Public License as published
  5. by the Free Software Foundation, version 3.
  6. This program is distributed in the hope that it will be useful,
  7. but WITHOUT ANY WARRANTY; without even the implied warranty of
  8. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  9. GNU Affero General Public License for more details.
  10. You should have received a copy of the GNU Affero General Public License
  11. along with this program. If not, see <https://www.gnu.org/licenses/>.
  12. -->
  13. {{template "base" .}}
  14. {{define "title"}}{{.Title}}{{end}}
  15. {{define "page_body"}}
  16. <div class="row justify-content-center">
  17. <div class="col-xl-5 col-lg-6 col-md-8">
  18. <div class="card shadow-lg my-5">
  19. <div class="card-header py-3">
  20. <h6 id="default_title" class="m-0 font-weight-bold text-primary">Upload one or more files to share "{{.Share.Name}}", user "{{.Share.Username}}"</h6>
  21. <h6 id="success_title" class="m-0 font-weight-bold text-primary" style="display: none;">Upload completed to share "{{.Share.Name}}", user "{{.Share.Username}}"</h6>
  22. </div>
  23. <div class="card-body">
  24. <div id="errorMsg" class="card mb-4 border-left-warning" style="display: none;">
  25. <div id="errorTxt" class="card-body text-form-error"></div>
  26. </div>
  27. <div id="successMsg" class="card mb-4 border-left-success" style="display: none;">
  28. <div id="successTxt" class="card-body">
  29. <p>File/s uploaded successfully</p>
  30. <p>If you want to upload other files click <a href="javascript:refreshPage();">here</a></p>
  31. </div>
  32. </div>
  33. <form id="upload_files_form" action="#" method="POST" enctype="multipart/form-data">
  34. <div class="modal-body">
  35. <input type="file" class="form-control-file" id="files_name" name="filenames" required multiple>
  36. </div>
  37. <button type="submit" class="btn btn-primary float-right mt-3 px-5">Submit</button>
  38. </form>
  39. </div>
  40. </div>
  41. </div>
  42. </div>
  43. {{end}}
  44. {{define "dialog"}}
  45. <div class="modal fade" id="spinnerModal" tabindex="-1" role="dialog" data-keyboard="false" data-backdrop="static">
  46. <div class="modal-dialog modal-dialog-centered justify-content-center" role="document">
  47. <span style="color: #333333;" class="fa fa-spinner fa-spin fa-3x"></span>
  48. </div>
  49. </div>
  50. {{end}}
  51. {{define "extra_js"}}
  52. <script type="text/javascript">
  53. var spinnerDone = false;
  54. function refreshPage() {
  55. location.reload();
  56. }
  57. $(document).ready(function () {
  58. $('#spinnerModal').on('shown.bs.modal', function () {
  59. if (spinnerDone){
  60. $('#spinnerModal').modal('hide');
  61. }
  62. });
  63. $("#upload_files_form").submit(function (event){
  64. event.preventDefault();
  65. var files = $("#files_name")[0].files;
  66. var has_errors = false;
  67. var index = 0;
  68. var success = 0;
  69. spinnerDone = false;
  70. $('#spinnerModal').modal('show');
  71. function uploadFile() {
  72. if (index >= files.length || has_errors){
  73. $('#spinnerModal').modal('hide');
  74. spinnerDone = true;
  75. if (!has_errors){
  76. $('#errorMsg').hide();
  77. $('#upload_files_form').hide();
  78. $('#default_title').hide();
  79. $('#success_title').show();
  80. $('#successMsg').show();
  81. }
  82. return;
  83. }
  84. async function saveFile() {
  85. var errorMessage = "Error uploading files";
  86. let response;
  87. try {
  88. var f = files[index];
  89. var uploadPath = '{{.UploadBasePath}}/'+fixedEncodeURIComponent(escapeHTML(f.name));
  90. var lastModified;
  91. try {
  92. lastModified = f.lastModified;
  93. } catch (e) {
  94. console.log("unable to get last modified time from file: "+e.message);
  95. lastModified = "";
  96. }
  97. response = await fetch(uploadPath, {
  98. method: 'POST',
  99. headers: {
  100. 'X-SFTPGO-MTIME': lastModified
  101. },
  102. credentials: 'same-origin',
  103. redirect: 'error',
  104. body: f
  105. });
  106. } catch (e){
  107. throw Error(errorMessage+": " +e.message);
  108. }
  109. if (response.status == 201){
  110. index++;
  111. success++;
  112. uploadFile();
  113. } else {
  114. let jsonResponse;
  115. try {
  116. jsonResponse = await response.json();
  117. } catch(e){
  118. throw Error(errorMessage);
  119. }
  120. if (jsonResponse.message) {
  121. errorMessage = jsonResponse.message;
  122. }
  123. if (jsonResponse.error) {
  124. errorMessage += ": " + jsonResponse.error;
  125. }
  126. throw Error(errorMessage);
  127. }
  128. }
  129. saveFile().catch(function(error){
  130. index++;
  131. has_errors = true;
  132. $('#errorTxt').text(error.message);
  133. $('#errorMsg').show();
  134. setTimeout(function () {
  135. $('#errorMsg').hide();
  136. }, 10000);
  137. uploadFile();
  138. });
  139. }
  140. uploadFile();
  141. });
  142. });
  143. </script>
  144. {{end}}