ProgressUI.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286
  1. <?php
  2. include '../auth.php';
  3. ?>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="UTF-8">
  8. <script src="../script/jquery.min.js"></script>
  9. <link rel="stylesheet" href="../script/tocas/tocas.css">
  10. <script type='text/javascript' src="../script/tocas/tocas.js"></script>
  11. <script type='text/javascript' src="../script/ao_module.js"></script>
  12. <title>7z File Manager</title>
  13. <style>
  14. body{
  15. background-color:white
  16. }
  17. .ts.form .inline.field label {
  18. min-width: 50%;
  19. }
  20. .ts.basic.dropdown, .ts.form select {
  21. max-width: 50%;
  22. }
  23. </style>
  24. </head>
  25. <body>
  26. <br>
  27. <div class="ts container">
  28. <div class="ts grid">
  29. <div class="eight wide column">
  30. <span style="text-align:left">Elasped time:</span>
  31. <span style="text-align:right" id="time">00:00:00</span>
  32. </div>
  33. <div class="eight wide column">
  34. <span style="text-align:left">Total size:</span>
  35. <span style="text-align:right" id="totalsize">0 b</span>
  36. </div>
  37. <div class="eight wide column">
  38. <span style="text-align:left">Remaining time:</span>
  39. <span style="text-align:right" id="remaining">00:00:00</span>
  40. </div>
  41. <div class="eight wide column">
  42. <span style="text-align:left">Speed:</span>
  43. <span style="text-align:right" id="speed">0 b/s</span>
  44. </div>
  45. <div class="sixteen wide column">
  46. <span style="text-align:left">Loading...</span>
  47. <div class="ts progress">
  48. <div class="bar" id="bar" style="width: 0%"></div>
  49. </div>
  50. </div>
  51. <div class="eight wide column"></div>
  52. <div class="eight wide column">
  53. <button class="ts basic button" style="width:100%" onclick="f_close();f_cancel = true;">Cancel</button>
  54. </div>
  55. </div>
  56. </div>
  57. <div class="ts bottom right snackbar">
  58. <div class="content"></div>
  59. </div>
  60. </body>
  61. <script>
  62. var f_method = "<?php echo $_GET["method"] ?>";
  63. var f_rand = "<?php echo $_GET["rand"] ?>";
  64. var f_file = "<?php echo $_GET["file"] ?>";
  65. var f_dir = "<?php echo $_GET["dir"] ?>";
  66. var f_size = "<?php echo filesize($_GET["file"]); ?>";
  67. var f_destdir = "<?php echo isset($_GET["destdir"]) ? $_GET["destdir"] : ""; ?>";
  68. var f_time = 1;
  69. var f_totaltime = 1;
  70. var f_cancel = false;
  71. //Initiate floatWindow events
  72. ao_module_setWindowTitle("Inflating from compressed file...");
  73. ao_module_setWindowIcon("loading spinner");
  74. var f_load = setInterval(function(){
  75. $.ajax({
  76. url: "getMessage.php?id=" + f_rand + "messages",
  77. contentType: "text/plain"
  78. }).done(function(data) {
  79. var progress = data.match(/ ([0-9]{0,2}%)/gim);
  80. console.log(progress[progress.length - 1]);
  81. f_totaltime = Math.floor(f_time / (parseInt(progress[progress.length - 1])/100));
  82. $("#bar").attr("style","width: " + progress[progress.length - 1]);
  83. $("#time").text(f_convert(f_time));
  84. $("#remaining").text(f_convert(f_totaltime - f_time));
  85. $("#speed").text(f_filesize(Math.floor(f_size / f_totaltime)) + "/s");
  86. $("#totalsize").text(f_filesize(f_size));
  87. f_time += 1;
  88. });
  89. /*
  90. $.get("./tmp/" + f_rand + "messages", function( data ) {
  91. var progress = data.match(/ ([0-9]{0,2}%)/gim);
  92. console.log(progress[progress.length - 1]);
  93. f_totaltime = Math.floor(f_time / (parseInt(progress[progress.length - 1])/100));
  94. $("#bar").attr("style","width: " + progress[progress.length - 1]);
  95. $("#time").text(f_convert(f_time));
  96. $("#remaining").text(f_convert(f_totaltime - f_time));
  97. $("#speed").text(f_filesize(Math.floor(f_size / f_totaltime)) + "/s");
  98. $("#totalsize").text(f_filesize(f_size));
  99. f_time += 1;
  100. });
  101. */
  102. }, 1000);
  103. f_load;
  104. $.get("opr.php?method=" + f_method + "&rand=" + f_rand + "&file=" + f_file + "&dir=" + f_dir , function( raw ) {
  105. clearInterval(f_load);
  106. if(!f_cancel){
  107. if(f_destdir.length >0){
  108. //console.log('../SystemAOB/functions/file_system/move.php?from=../../../7-Zip%20File%20Manager/tmp/' + f_rand +'&to=../../' + f_destdir + f_filenameToFoldername(f_file));
  109. $.get( '../SystemAOB/functions/file_system/move.php?from=../../../7-Zip%20File%20Manager/tmp/' + f_rand +'&to=../../' + f_destdir + f_filenameToFoldername(f_file), function(data) {
  110. if(data !== "DONE"){
  111. if(ao_module_virtualDesktop){
  112. parent.msgbox(data,'<i class="caution sign icon"></i> 7-Zip File Manager',"");
  113. ao_module_close();
  114. }else{
  115. msgbox(data,"","");
  116. setTimeout(function(){ts('#modal').modal('hide')},1500);
  117. }
  118. }else{
  119. f_openFile(true);
  120. }
  121. });
  122. /*
  123. console.log('../SystemAOB/functions/file_system/copy_folder.php?from=../../../7-Zip%20File%20Manager/tmp/' + f_rand +'/&target=../../' + f_destdir + f_rand + "/");
  124. console.log('../SystemAOB/functions/file_system/rename.php?file=../../' + f_destdir + f_rand + '&newFileName=../../' + f_destdir + f_file.replace(/^.*[\\\/]/, '').replace(/\./,"") + '/&hex=false');
  125. $.get( '../SystemAOB/functions/file_system/copy_folder.php?from=../../../7-Zip%20File%20Manager/tmp/' + f_rand +'/&target=../../' + f_destdir + f_rand + "/", function(data) {
  126. if(data !== "DONE"){
  127. msgbox(data,"","");
  128. if(ao_module_virtualDesktop){
  129. parent.msgbox(data,"","");
  130. ao_module_close();
  131. }else{
  132. msgbox(data,"","");
  133. setTimeout(function(){ts('#modal').modal('hide')},1500);
  134. }
  135. }
  136. $.get( '../SystemAOB/functions/file_system/rename.php?file=../../' + f_destdir + f_rand + '&newFileName=../../' + f_destdir + f_file.replace(/^.*[\\\/]/, '').replace(/\./,"") + '/&hex=false', function(data) {
  137. if(data !== "DONE"){
  138. $.get( '../SystemAOB/functions/file_system/delete.php?filename=../../' + f_destdir + f_rand, function(data) {
  139. });
  140. if(ao_module_virtualDesktop){
  141. parent.msgbox(data,"","");
  142. ao_module_close();
  143. }else{
  144. msgbox(data,"","");
  145. setTimeout(function(){ts('#modal').modal('hide')},1500);
  146. }
  147. }else{
  148. f_openFile(true);
  149. }
  150. });
  151. });
  152. */
  153. }else{
  154. f_openFile(false);
  155. }
  156. }
  157. });
  158. function f_filenameToFoldername(path){
  159. var filename = path.split("\\").join("/").split("/").pop();
  160. var filename = filename.split(".");
  161. if (filename.length > 1){
  162. filename.pop();
  163. }
  164. filename = filename.join(".");
  165. if (filename.substring(0,5) == "inith"){
  166. filename = filename.replace("inith","");
  167. }
  168. return filename;
  169. }
  170. function f_openFile(bool){
  171. var Folder = "";
  172. // bool = true then it have destdir
  173. // bool = false then it dont have destdir
  174. if(bool == true){
  175. //f_method = e then it is only single file
  176. //f_method = x then it is a folder
  177. if(f_method == "e"){
  178. Folder = f_destdir.replace("../","") + f_filenameToFoldername(f_file) + "/" + f_dir.replace(/^.*[\\\/]/, '');
  179. }else if(f_method == "x"){
  180. Folder = f_destdir.replace("../","") + f_filenameToFoldername(f_file);
  181. }
  182. }else{
  183. //f_method = e then it is only single file
  184. //f_method = x then it is a folder
  185. if(f_method == "e"){
  186. Folder = "7-Zip File Manager/tmp/" + f_rand + "/" + f_dir.replace(/^.*[\\\/]/, '');
  187. }else if(f_method == "x"){
  188. Folder = "7-Zip File Manager/tmp/" + f_rand + "/";
  189. }
  190. }
  191. //console.log(f_rand + Folder);
  192. if(ao_module_virtualDesktop){
  193. if(f_method == "e"){
  194. ao_module_openFile(Folder,"7-Zip Preview");
  195. }else if(f_method == "x"){
  196. ao_module_openPath(Folder);
  197. }
  198. ao_module_close();
  199. }else{
  200. if(f_method == "e"){
  201. window.open("../" + Folder);
  202. }else if(f_method == "x"){
  203. window.open("../SystemAOB/functions/file_system/index.php?controlLv=2#../../../" + Folder);
  204. }
  205. setTimeout(function(){ts('#modal').modal('hide')},1500);
  206. }
  207. }
  208. function f_convert(time){
  209. var hours = Math.floor(time / 3600);
  210. var minutes = Math.floor((time - (hours * 3600)) / 60);
  211. var seconds = time - (hours * 3600) - (minutes * 60);
  212. if(hours < 10){
  213. var dhour = "0" + hours;
  214. }else{
  215. var dhour = hours;
  216. }
  217. if(minutes < 10){
  218. var dminutes = "0" + minutes;
  219. }else{
  220. var dminutes = minutes;
  221. }
  222. if(seconds < 10){
  223. var dseconds = "0" + seconds;
  224. }else{
  225. var dseconds = seconds;
  226. }
  227. if(!isNaN(hours) && !isNaN(minutes) && !isNaN(seconds)){
  228. var formatted = dhour + ":" + dminutes + ":" + dseconds;
  229. }else{
  230. var formatted = "00:00:00";
  231. }
  232. return formatted;
  233. }
  234. function f_filesize(size){
  235. if(size >= 1073741824){
  236. return Math.floor(size/1073741824*100)/100 + "GB";
  237. }else if(size >= 1048576){
  238. return Math.floor(size/1048576*100)/100 + "MB";
  239. }else if(size >= 1024){
  240. return Math.floor(size/1024*100)/100 + "KB";
  241. }else{
  242. return size + "Bytes";
  243. }
  244. }
  245. function msgbox(content,bgcolor,fontcolor){
  246. $(".snackbar").attr("style",'background-color: ' + bgcolor + ';color:' + fontcolor);
  247. ts('.snackbar').snackbar({
  248. content: content,
  249. onAction: () => {
  250. $(".snackbar").removeAttr("style");
  251. }
  252. });
  253. }
  254. function f_close(){
  255. if(ao_module_virtualDesktop){
  256. ao_module_close();
  257. }else{
  258. setTimeout(function(){ts('#modal').modal('hide')},1500);
  259. }
  260. }
  261. </script>
  262. </html>