multiupload.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*!
  2. * MultiUpload for xheditor
  3. * @requires xhEditor
  4. *
  5. * @author Yanis.Wang<yanis.wang@gmail.com>
  6. * @site http://xheditor.com/
  7. * @licence LGPL(http://www.opensource.org/licenses/lgpl-license.php)
  8. *
  9. * @Version: 0.9.2 (build 100505)
  10. */
  11. var swfu,selQueue=[],selectID,arrMsg=[],allSize=0,uploadSize=0;
  12. function removeFile()
  13. {
  14. var file;
  15. if(!selectID)return;
  16. for(var i in selQueue)
  17. {
  18. file=selQueue[i];
  19. if(file.id==selectID)
  20. {
  21. selQueue.splice(i,1);
  22. allSize-=file.size;
  23. swfu.cancelUpload(file.id);
  24. $('#'+file.id).remove();
  25. selectID=null;
  26. break;
  27. }
  28. }
  29. $('#btnClear').hide();
  30. if(selQueue.length==0)$('#controlBtns').hide();
  31. }
  32. function startUploadFiles()
  33. {
  34. if(swfu.getStats().files_queued>0)
  35. {
  36. $('#controlBtns').hide();
  37. swfu.startUpload();
  38. }
  39. else alert('上传前请先添加文件');
  40. }
  41. function setFileState(fileid,txt)
  42. {
  43. $('#'+fileid+'_state').text(txt);
  44. }
  45. function fileQueued(file)//队列添加成功
  46. {
  47. for(var i in selQueue)if(selQueue[i].name==file.name){swfu.cancelUpload(file.id);return false;}//防止同名文件重复添加
  48. if(selQueue.length==0)$('#controlBtns').show();
  49. selQueue.push(file);
  50. allSize+=file.size;
  51. $('#listBody').append('<tr id="'+file.id+'"><td>'+file.name+'</td><td>'+formatBytes(file.size)+'</td><td id="'+file.id+'_state">就绪</td></tr>');
  52. $('#'+file.id).hover(function(){$(this).addClass('hover');},function(){$(this).removeClass('hover');})
  53. .click(function(){selectID=file.id;$('#listBody tr').removeClass('select');$(this).removeClass('hover').addClass('select');$('#btnClear').show();})
  54. }
  55. function fileQueueError(file, errorCode, message)//队列添加失败
  56. {
  57. var errorName='';
  58. switch (errorCode)
  59. {
  60. case SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED:
  61. errorName = "只能同时上传 "+this.settings.file_upload_limit+" 个文件";
  62. break;
  63. case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
  64. errorName = "选择的文件超过了当前大小限制:"+this.settings.file_size_limit;
  65. break;
  66. case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
  67. errorName = "零大小文件";
  68. break;
  69. case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
  70. errorName = "文件扩展名必需为:"+this.settings.file_types_description+" ("+this.settings.file_types+")";
  71. break;
  72. default:
  73. errorName = "未知错误";
  74. break;
  75. }
  76. alert(errorName);
  77. }
  78. function uploadStart(file)//单文件上传开始
  79. {
  80. setFileState(file.id,'上传中…');
  81. }
  82. function uploadProgress(file, bytesLoaded, bytesTotal)//单文件上传进度
  83. {
  84. var percent=Math.ceil((uploadSize+bytesLoaded)/allSize*100);
  85. $('#progressBar span').text(percent+'% ('+formatBytes(uploadSize+bytesLoaded)+' / '+formatBytes(allSize)+')');
  86. $('#progressBar div').css('width',percent+'%');
  87. }
  88. function uploadSuccess(file, serverData)//单文件上传成功
  89. {
  90. var data=Object;
  91. try{eval("data=" + serverData);}catch(ex){};
  92. if(data.err!=undefined&&data.msg!=undefined)
  93. {
  94. if(!data.err)
  95. {
  96. uploadSize+=file.size;
  97. arrMsg.push(data.msg);
  98. setFileState(file.id,'上传成功');
  99. }
  100. else
  101. {
  102. setFileState(file.id,'上传失败');
  103. alert(data.err);
  104. }
  105. }
  106. else setFileState(file.id,'上传失败!');
  107. }
  108. function uploadError(file, errorCode, message)//单文件上传错误
  109. {
  110. setFileState(file.id,'上传失败!');
  111. }
  112. function uploadComplete(file)//文件上传周期结束
  113. {
  114. if(swfu.getStats().files_queued>0)swfu.startUpload();
  115. else uploadAllComplete();
  116. }
  117. function uploadAllComplete()//全部文件上传成功
  118. {
  119. callback(arrMsg);
  120. }
  121. function formatBytes(bytes) {
  122. var s = ['Byte', 'KB', 'MB', 'GB', 'TB', 'PB'];
  123. var e = Math.floor(Math.log(bytes)/Math.log(1024));
  124. return (bytes/Math.pow(1024, Math.floor(e))).toFixed(2)+" "+s[e];
  125. }