up2.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. var imgArray1=[];//图片src数组
  2. var $ = jQuery, // just in case. Make sure it's not an other libaray.
  3. $wrap1 = $('#uploader2'),
  4. // 图片容器
  5. $queue1 = $('<ul id="filelist2" class="filelist"></ul>').appendTo( $wrap1.find('#queueList2') ),
  6. // 状态栏,包括进度和控制按钮
  7. $statusBar1 = $wrap1.find('.statusBar'),
  8. // 文件总体选择信息。
  9. $info1 = $statusBar1.find('.info'),
  10. // 上传按钮
  11. $upload1 = $wrap1.find('#uploadBtn2'),
  12. // 没选择文件之前的内容。
  13. $placeHolder1 = $wrap1.find('.placeholder'),
  14. // 总体进度条
  15. $progress1 = $statusBar1.find('.progress').hide(),
  16. // 添加的文件数量
  17. fileCount1 = 0,
  18. // 添加的文件总大小
  19. fileSize1 = 0,
  20. // 优化retina, 在retina下这个值是2或3
  21. ratio = window.devicePixelRatio || 1,
  22. // 缩略图大小
  23. thumbnailWidth = 414 * ratio,
  24. thumbnailHeight = 736 * ratio,
  25. // 可能有pedding, ready, uploading, confirm, done.
  26. state1 = 'pedding',
  27. // 所有文件的进度信息,key为file id
  28. percentages1 = {},
  29. supportTransition1 = (function(){
  30. var s = document.createElement('p').style,
  31. r = 'transition' in s ||
  32. 'WebkitTransition' in s ||
  33. 'MozTransition' in s ||
  34. 'msTransition' in s ||
  35. 'OTransition' in s;
  36. s = null;
  37. return r;
  38. })(),
  39. // WebUploader实例
  40. uploader1;
  41. if ( !WebUploader.Uploader.support() ) {
  42. alert( 'Web Uploader 不支持您的浏览器!如果你使用的是IE浏览器,请尝试升级 flash 播放器');
  43. throw new Error( 'WebUploader does not support the browser you are using.' );
  44. }
  45. // 实例化
  46. uploader1 = WebUploader.create({
  47. pick: {
  48. id: '#filePicker3',
  49. label: '选择图片',
  50. multiple:true
  51. },
  52. dnd: '#uploader2 .queueList',
  53. paste: document.body,
  54. accept: {
  55. title: 'Images',
  56. extensions: 'jpg,jpeg,png',
  57. mimeTypes: 'image/*'
  58. },
  59. thumb :{
  60. width: 595,
  61. height: 842,
  62. // 图片质量,只有type为`image/jpeg`的时候才有效。
  63. quality: 100,
  64. // 是否允许放大,如果想要生成小图的时候不失真,此选项应该设置为false.
  65. allowMagnify: false,
  66. // 是否允许裁剪。
  67. crop: false,
  68. // 为空的话则保留原有图片格式。
  69. // 否则强制转换成指定的类型。
  70. type: ''
  71. },
  72. compress :{
  73. width: 595,
  74. height: 842,
  75. // 图片质量,只有type为`image/jpeg`的时候才有效。
  76. quality: 90,
  77. // 是否允许放大,如果想要生成小图的时候不失真,此选项应该设置为false.
  78. allowMagnify: false,
  79. // 是否允许裁剪。
  80. crop: false,
  81. // 是否保留头部meta信息。
  82. preserveHeaders: true,
  83. // 如果发现压缩后文件大小比原来还大,则使用原来图片
  84. // 此属性可能会影响图片自动纠正功能
  85. noCompressIfLarger: false,
  86. // 单位字节,如果图片大小小于此值,不会采用压缩。
  87. compressSize: 0
  88. },
  89. // swf文件路径
  90. swf: '../images/Uploader.swf',
  91. disableGlobalDnd: true,
  92. auto:false, //这里我们设置不自动上传,true则为自动上传
  93. chunked: true, //是否要分片
  94. // server: 'http://webuploader.duapp.com/server/fileupload.php',
  95. server: base_path + '/uploadImage',
  96. fileNumLimit: 5,
  97. fileSizeLimit: 15 * 1024 * 1024, // 15 M
  98. fileSingleSizeLimit: 3 * 1024 * 1024 // 3 M
  99. });
  100. // 添加“添加文件”的按钮,
  101. uploader1.addButton({
  102. id: '#filePicker4',
  103. label: '继续添加'
  104. });
  105. // 当有文件添加进来时执行,负责view的创建
  106. function addFile1( file ) {
  107. console.log(file)
  108. var $li1 = $( '<li id="' + file.id + '">' +
  109. '<p class="title">' + file.name + '</p>' +
  110. '<p class="imgWrap"></p>'+
  111. '<p class="progress"><span></span></p>' +
  112. '</li>' ),
  113. $btns = $('<div class="file-panel">' +
  114. '<span class="cancel">删除</span>' +'</div>').appendTo( $li1 ),
  115. $prgress = $li1.find('p.progress span'),
  116. $wrap1 = $li1.find( 'p.imgWrap' ),
  117. $info1 = $('<p class="error"></p>'),
  118. showError = function( code ) {
  119. switch( code ) {
  120. case 'exceed_size':
  121. text = '文件大小超出';
  122. break;
  123. case 'interrupt':
  124. text = '上传暂停';
  125. break;
  126. default:
  127. text = '上传失败,请重试';
  128. break;
  129. }
  130. $info1.text( text ).appendTo( $li1 );
  131. };
  132. if ( file.getStatus() === 'invalid' ) {
  133. showError( file.statusText );
  134. } else {
  135. // @todo lazyload
  136. $wrap1.text( '预览中' );
  137. uploader1.makeThumb( file, function( error, src ) {
  138. if ( error ) {
  139. $wrap1.text( '不能预览' );
  140. return;
  141. }
  142. var img = $('<img src="'+src+'">');
  143. $wrap1.empty().append( img );
  144. }, thumbnailWidth, thumbnailHeight );
  145. percentages1[ file.id ] = [ file.size, 0 ];
  146. file.rotation = 0;
  147. }
  148. file.on('statuschange', function( cur, prev ) {
  149. if ( prev === 'progress' ) {
  150. $prgress.hide().width(0);
  151. } else if ( prev === 'queued' ) {
  152. $li1.off( 'mouseenter mouseleave' );
  153. $btns.remove();
  154. }
  155. // 成功
  156. if ( cur === 'error' || cur === 'invalid' ) {
  157. console.log( file.statusText );
  158. showError( file.statusText );
  159. percentages1[ file.id ][ 1 ] = 1;
  160. } else if ( cur === 'interrupt' ) {
  161. showError( 'interrupt' );
  162. } else if ( cur === 'queued' ) {
  163. percentages1[ file.id ][ 1 ] = 0;
  164. } else if ( cur === 'progress' ) {
  165. $info1.remove();
  166. $prgress.css('display', 'block');
  167. } else if ( cur === 'complete' ) {
  168. $li1.append( '<span class="success"></span>' );
  169. }
  170. $li1.removeClass( 'state-' + prev ).addClass( 'state-' + cur );
  171. });
  172. $li1.on( 'mouseenter', function() {
  173. $btns.stop().animate({height: 30});
  174. });
  175. $li1.on( 'mouseleave', function() {
  176. $btns.stop().animate({height: 0});
  177. });
  178. $btns.on( 'click', 'span', function() {
  179. var index = $(this).index(),
  180. deg;
  181. switch ( index ) {
  182. case 0:
  183. uploader1.removeFile( file );
  184. reqFace='';
  185. return;
  186. case 1:
  187. file.rotation += 90;
  188. break;
  189. case 2:
  190. file.rotation -= 90;
  191. break;
  192. }
  193. if ( supportTransition1 ) {
  194. deg = 'rotate(' + file.rotation + 'deg)';
  195. $wrap1.css({
  196. '-webkit-transform': deg,
  197. '-mos-transform': deg,
  198. '-o-transform': deg,
  199. 'transform': deg
  200. });
  201. } else {
  202. $wrap1.css( 'filter', 'progid:DXImageTransform.Microsoft.BasicImage(rotation='+ (~~((file.rotation/90)%4 + 4)%4) +')');
  203. // use jquery animate to rotation
  204. // $({
  205. // rotation: rotation
  206. // }).animate({
  207. // rotation: file.rotation
  208. // }, {
  209. // easing: 'linear',
  210. // step: function( now ) {
  211. // now = now * Math.PI / 180;
  212. // var cos = Math.cos( now ),
  213. // sin = Math.sin( now );
  214. // $wrap.css( 'filter', "progid:DXImageTransform.Microsoft.Matrix(M11=" + cos + ",M12=" + (-sin) + ",M21=" + sin + ",M22=" + cos + ",SizingMethod='auto expand')");
  215. // }
  216. // });
  217. }
  218. });
  219. $li1.appendTo( $queue1 );
  220. }
  221. // 负责view的销毁
  222. function removeFile( file ) {
  223. var $li1 = $('#'+file.id);
  224. delete percentages1[ file.id ];
  225. updateTotalProgress1();
  226. $li1.off().find('.file-panel').off().end().remove();
  227. }
  228. function updateTotalProgress1() {
  229. var loaded = 0,
  230. total = 0,
  231. spans = $progress1.children(),
  232. percent;
  233. $.each( percentages1, function( k, v ) {
  234. total += v[ 0 ];
  235. loaded += v[ 0 ] * v[ 1 ];
  236. } );
  237. percent = total ? loaded / total : 0;
  238. spans.eq( 0 ).text( Math.round( percent * 100 ) + '%' );
  239. spans.eq( 1 ).css( 'width', Math.round( percent * 100 ) + '%' );
  240. updateStatus1();
  241. }
  242. function updateStatus1() {
  243. var text = '', stats1;
  244. if ( state1 === 'ready' ) {
  245. text = '选中' + fileCount1 + '张图片,共' +
  246. WebUploader.formatSize( fileSize1 ) + '。';
  247. $("#uploadBtn2").show();
  248. } else if ( state1 === 'confirm' ) {
  249. stats1 = uploader1.getStats();
  250. if ( stats1.uploadFailNum ) {
  251. text = '已成功上传' + stats1.successNum+ '张图片,'+
  252. stats1.uploadFailNum + '张失败'
  253. // stats.uploadFailNum + '张失败,<a class="retry" href="#">重新上传</a>失败图片或<a class="ignore" href="#">忽略</a>'
  254. }
  255. } else {
  256. stats1 = uploader1.getStats();
  257. text = '共' + fileCount1 + '张(' +
  258. WebUploader.formatSize( fileSize1 ) +
  259. '),已上传' + stats1.successNum + '张';
  260. if ( stats1.uploadFailNum ) {
  261. text += ',失败' + stats1.uploadFailNum + '张';
  262. }
  263. }
  264. $info1.html( text );
  265. }
  266. function setState1( val ) {
  267. var file, stats1;
  268. if ( val === state1 ) {
  269. return;
  270. }
  271. $upload1.removeClass( 'state-' + state1 );
  272. $upload1.addClass( 'state-' + val );
  273. state1 = val;
  274. switch ( state1 ) {
  275. case 'pedding':
  276. $placeHolder1.removeClass( 'element-invisible' );
  277. $queue1.parent().removeClass('filled');
  278. $queue1.hide();
  279. $statusBar1.addClass( 'element-invisible' );
  280. uploader1.refresh();
  281. break;
  282. case 'ready':
  283. $placeHolder1.addClass( 'element-invisible' );
  284. $( '#filePicker2' ).removeClass( 'element-invisible');
  285. $queue1.parent().addClass('filled');
  286. $queue1.show();
  287. $statusBar1.removeClass('element-invisible');
  288. uploader1.refresh();
  289. break;
  290. case 'uploading':
  291. $( '#filePicker2' ).addClass( 'element-invisible' );
  292. $progress1.show();
  293. $upload1.text( '暂停上传' );
  294. break;
  295. case 'paused':
  296. $progress1.show();
  297. $upload1.text( '继续上传' );
  298. break;
  299. case 'confirm':
  300. $progress1.hide();
  301. $upload1.text( '开始上传' ).addClass( 'disabled' );
  302. stats1 = uploader1.getStats();
  303. if ( stats1.successNum && !stats1.uploadFailNum ) {
  304. setState1( 'finish' );
  305. return;
  306. }
  307. break;
  308. case 'finish':
  309. stats1 = uploader1.getStats();
  310. if ( stats1.successNum ) {
  311. console.log( '上传成功' );
  312. } else {
  313. // 没有成功的图片,重设
  314. state1 = 'done';
  315. //location.reload();
  316. }
  317. break;
  318. }
  319. updateStatus1();
  320. }
  321. uploader1.onUploadProgress = function( file, percentage ) {
  322. var $li1 = $('#'+file.id),
  323. $percent = $li1.find('.progress span');
  324. $percent.css( 'width', percentage * 100 + '%' );
  325. percentages1[ file.id ][ 1 ] = percentage;
  326. updateTotalProgress1();
  327. };
  328. uploader1.onFileQueued = function( file ) {
  329. fileCount1++;
  330. fileSize1 += file.size;
  331. if ( fileCount1 === 1 ) {
  332. $placeHolder1.addClass( 'element-invisible' );
  333. $statusBar1.show();
  334. }
  335. addFile1( file );
  336. setState1( 'ready' );
  337. updateTotalProgress1();
  338. };
  339. uploader1.onFileDequeued = function( file ) {
  340. fileCount1--;
  341. fileSize1 -= file.size;
  342. if ( !fileCount1 ) {
  343. setState1( 'pedding' );
  344. }
  345. removeFile( file );
  346. updateTotalProgress1();
  347. };
  348. uploader1.on( 'all', function( type ) {
  349. var stats1;
  350. switch( type ) {
  351. case 'uploadFinished':
  352. setState1( 'confirm' );
  353. break;
  354. case 'startUpload':
  355. setState1( 'uploading' );
  356. break;
  357. case 'stopUpload':
  358. setState1( 'paused' );
  359. break;
  360. }
  361. });
  362. uploader1.onError = function( code ) {
  363. alert( 'Eroor: ' + code );
  364. };
  365. $upload1.on('click', function() {
  366. if ( $(this).hasClass( 'disabled' ) ) {
  367. return false;
  368. }
  369. if ( state1 === 'ready' ) {
  370. console.log("开始上传")
  371. // $(".loading>p").text("正在上传,请稍候...");
  372. var count=0,sum=$('#filelist2 .imgWrap img').length;
  373. $('#filelist2 .imgWrap img').each(function(){
  374. var fileSrc=$(this).attr("src");
  375. // var fileSrc=$(this).attr("src").replace(/^data:image\/(jpeg|png|gif);base64,/,'');
  376. $.ajax(base_path + '/approval/baseFileUpload?dates=' + new Date().getTime(), {
  377. data: {
  378. "file": fileSrc
  379. },
  380. dataType: 'json',
  381. xhrFields: {
  382. withCredentials: true
  383. },
  384. crossDomain: true,
  385. async : false,
  386. type: 'post',
  387. timeout: 25000,
  388. success: function(dt) {
  389. if(dt.isRedirect) {
  390. location.href = dt.redirectURL;
  391. } else {
  392. if(dt.returnCode == "200") {
  393. console.log(dt)
  394. //reqFace = dt.returnMsg.pic;
  395. var prm={};
  396. prm["contractUrl"]=dt.returnMsg.imgUrl;
  397. prm["contractType"]=2;
  398. imgArray1.push(prm);
  399. //$(".info").html($(".info").text()+'<span style="color:#008800;">上传成功!</span>');
  400. //$(".imgWrap").append('<span class="up-tips">上传成功</span>');
  401. $("#uploadBtn2").hide();
  402. count++;
  403. }
  404. }
  405. },
  406. error: function(xhr, type, errorThrown) {
  407. console.log(xhr);
  408. }
  409. });
  410. });
  411. var err='';
  412. if(sum-count>0){
  413. err=',失败<span style="color:#f00;">'+(sum-count)+'</span>张';
  414. }
  415. $("#uploader2 .info").html('共'+sum+'张,上传成功<span style="color:#5882f7;">'+count+'</span>张'+err);
  416. //uploader.upload();
  417. } else if ( state1 === 'paused' ) {
  418. console.log("开始上传")
  419. //uploader.upload();
  420. } else if ( state1 === 'uploading' ) {
  421. //uploader.stop();
  422. }
  423. });
  424. $info1.on( 'click', '.retry', function() {
  425. uploader1.retry();
  426. } );
  427. $info1.on( 'click', '.ignore', function() {
  428. alert( 'todo' );
  429. } );
  430. $upload1.addClass( 'state-' + state1 );
  431. updateTotalProgress1();