upload.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561
  1. var upload_pic = [];
  2. var upload_pic_info = [];
  3. var upload_file = [];
  4. var upload = [];
  5. var showUploadE;
  6. var showUploadUrl;
  7. var showUploadType = 1;
  8. var showUploadCall = false;
  9. var showUploadThis = false;
  10. var showUploadIndex = false;
  11. var picManageE = false;
  12. var picManageI = false;
  13. var picManageV = false;
  14. var picManageLayer = false;
  15. //创建监听函数
  16. var xhrOnProgress=function(fun) {
  17. xhrOnProgress.onprogress = fun; //绑定监听
  18. //使用闭包实现监听绑
  19. return function() {
  20. //通过$.ajaxSettings.xhr();获得XMLHttpRequest对象
  21. var xhr = $.ajaxSettings.xhr();
  22. //判断监听函数是否为函数
  23. if (typeof xhrOnProgress.onprogress !== 'function')
  24. return xhr;
  25. //如果有监听函数并且xhr对象支持绑定时就把监听函数绑定上去
  26. if (xhrOnProgress.onprogress && xhr.upload) {
  27. xhr.upload.onprogress = xhrOnProgress.onprogress;
  28. }
  29. return xhr;
  30. }
  31. }
  32. function showUpload(i,e,key,url,assets,type)
  33. {
  34. layui.use(['upload','layer','element'], function() {
  35. var html = '';
  36. var layer = layui.layer;
  37. var layerConfig = {
  38. type: 1,
  39. title: e.attr('value'),
  40. shade: 0.1,
  41. shadeClose : true,
  42. content: html,
  43. area: '800px'
  44. };
  45. e.unbind('click').bind('click', function()
  46. {
  47. url = url.replace('save', 'view');
  48. showUploadE = e;
  49. if (!type) {
  50. type = 1;
  51. }
  52. showUploadType = type;
  53. showUploadUrl = url;
  54. var cur = $('#' + showUploadE.attr('v')).val();
  55. var value = '';
  56. if (e.attr('data-value')) {
  57. value = e.attr('data-value');
  58. }
  59. $.getJSON(url, {json:1,key:key,cur:cur,value:value}, function(t)
  60. {
  61. if (showUploadIndex) {
  62. layer.close(showUploadIndex);
  63. }
  64. //layer.closeAll();
  65. layerConfig.content = t.data;
  66. showUploadIndex = layer.open(layerConfig);
  67. })
  68. })
  69. });
  70. }
  71. function editorShowUpload(cur, url, title, func, self)
  72. {
  73. showUploadType = 2;
  74. showUploadCall = func;
  75. showUploadThis = self;
  76. layui.use(['upload','layer','element'], function() {
  77. var html = '';
  78. var layer = layui.layer;
  79. var layerConfig = {
  80. type: 1,
  81. title: title,
  82. shade: 0.1,
  83. shadeClose : true,
  84. content: html,
  85. area: '800px'
  86. };
  87. url = url.replace('save', 'view');
  88. showUploadUrl = url;
  89. $.getJSON(url, {json:1,cur:cur}, function(t)
  90. {
  91. layerConfig.content = t.data;
  92. showUploadIndex = layer.open(layerConfig);
  93. })
  94. });
  95. }
  96. function showUploadFilesSet(e, name, url, id)
  97. {
  98. $('.layui-anim-yes').addClass('layui-anim-no');
  99. $('.layui-anim-yes').removeClass('layui-anim-yes');
  100. e.parent().removeClass('layui-anim-no');
  101. e.parent().addClass('layui-anim-yes');
  102. $('.file_cur').val(url);
  103. if (showUploadType == 1) {
  104. var value = showUploadE.attr('v');
  105. var key = showUploadE.attr('key');
  106. loadUploadSet(showUploadE, value, {name:name,url:url}, key);
  107. } else if (showUploadType == 2) {
  108. showUploadCall.call(showUploadThis, url, name, id);
  109. } else if (showUploadType == 3) {
  110. var value = showUploadE.attr('editor_id');
  111. var key = showUploadE.attr('key');
  112. //KindEditor.insertHtml('#' + value, '<div class="dever-video"><embed src="'+url+'" type="video/x-ms-asf-plugin" width="450" height="300" autostart="false" loop="true" data-id="'+id+'" data-key="'+key+'"/><div style="width:450px;height:20px;">'+name+':'+id+'(请勿修改)</div></div>');
  113. KindEditor.insertHtml('#' + value, '<img src="'+url+'" style="width:450px;height:300px;" data-id="'+id+'" data-key="'+key+'"/>');
  114. }
  115. if (showUploadIndex) {
  116. layer.close(showUploadIndex);
  117. showUploadIndex = false;
  118. } else {
  119. layer.closeAll();
  120. }
  121. }
  122. function showUploadFilesSearch(e)
  123. {
  124. var p = e.parent();
  125. var pg = p.find('.file_pg').val();
  126. var key = p.find('.file_key').val();
  127. var name = p.find('.file_filename').val();
  128. var tag = p.find('.file_tag').val();
  129. var cate = p.find('.file_cate').val();
  130. var cur = p.find('.file_cur').val();
  131. var url = showUploadUrl;
  132. showUploadFiles(url, name, key, cate, tag, cur, pg);
  133. }
  134. function showUploadFiles(url, name, key, cate, tag, cur, pg)
  135. {
  136. if (!pg) {
  137. pg = 1;
  138. }
  139. $.getJSON(url, {json:1,key:key, name:name,cate:cate, tag:tag, pg:pg, cur:cur}, function(t)
  140. {
  141. var t = '<div>' + t.data + '</div>';
  142. html = $(t).find('#component-anim').html();
  143. $("#component-anim").html(html);
  144. })
  145. }
  146. function loadUploadL(i,e,key,url,assets)
  147. {
  148. var value = e.attr('v');
  149. if (typeof(upload[value]) != "undefined") {
  150. //return;
  151. }
  152. upload[value] = true;
  153. upload_pic[value] = [];
  154. upload_pic_info[value] = [];
  155. upload_file[value] = [];
  156. var id = e.attr('id');
  157. var token = e.attr('token');
  158. var host = e.attr('host');
  159. var domain = e.attr('domain');
  160. var path = e.attr('path');
  161. var cover = e.attr('cover');
  162. if (!cover) {
  163. cover = 1;
  164. }
  165. var uploadUrl = url;
  166. url = domain;
  167. var layerConfig = {
  168. useCdnDomain: true,
  169. disableStatisticsReport: false,
  170. retryCount: 6
  171. };
  172. var putExtra = {
  173. fname: "",
  174. params: {},
  175. mimeType: null
  176. };
  177. layui.use(['layer','element'], function() {
  178. var layer = layui.layer;
  179. var element = layui.element;
  180. $("#" + id).unbind("change").bind("change",function() {
  181. var file = this.files[0];
  182. // eslint-disable-next-line
  183. var finishedAttr = [];
  184. // eslint-disable-next-line
  185. var compareChunks = [];
  186. var observable;
  187. if (file) {
  188. element.progress(id + '_progress', '0%')
  189. layer.load();
  190. var filename = file.name;
  191. var temp = filename.split('.');
  192. putExtra.params["x:name"] = temp[0];
  193. filename = path + hex_md5(file.name) + '.' + temp[temp.length-1];
  194. //不覆盖
  195. if (cover == 2) {
  196. var timestamp = Date.parse(new Date());
  197. filename = path + hex_md5(file.name + '_' + timestamp) + '.' + temp[temp.length-1];
  198. }
  199. // 设置next,error,complete对应的操作,分别处理相应的进度信息,错误信息,以及完成后的操作
  200. var error = function(err) {
  201. //请求异常回调
  202. console.log(err);
  203. layer.alert('文件上传错误1');
  204. element.progress(id + '_progress', '0%')
  205. $('#' + id + '_progress').hide();
  206. layer.closeAll('loading');
  207. };
  208. var complete = function(res) {
  209. //&& res.key.match(/\.(jpg|jpeg|png|gif)$/)
  210. if (res.key) {
  211. element.progress(id + '_progress', '0%')
  212. $('#' + id + '_progress').hide();
  213. layer.closeAll('loading');
  214. var data = {};
  215. if (res.hash) {
  216. $.getJSON(uploadUrl.replace('save.start', 'qiniu.addFile'), {source:file.name,file:res.key, key:key});
  217. data.status = 1;
  218. data.name = res.key;
  219. data.url = host + res.key;
  220. loadUploadSet(e,value,data,key);
  221. } else {
  222. layer.alert('文件上传错误2');
  223. return false;
  224. }
  225. }
  226. };
  227. var next = function(response) {
  228. var chunks = response.chunks||[];
  229. var total = response.total;
  230. // 这里对每个chunk更新进度,并记录已经更新好的避免重复更新,同时对未开始更新的跳过
  231. for (var i = 0; i < chunks.length; i++) {
  232. if (chunks[i].percent === 0 || finishedAttr[i]){
  233. continue;
  234. }
  235. if (compareChunks[i].percent === chunks[i].percent){
  236. continue;
  237. }
  238. if (chunks[i].percent === 100){
  239. finishedAttr[i] = true;
  240. }
  241. }
  242. $('#' + id + '_progress').show();
  243. element.progress(id + '_progress', parseInt(total.percent)+'%')
  244. compareChunks = chunks;
  245. };
  246. var subObject = {
  247. next: next,
  248. error: error,
  249. complete: complete
  250. };
  251. var subscription;
  252. // 调用sdk上传接口获得相应的observable,控制上传和暂停
  253. observable = qiniu.upload(file, filename, token, putExtra, layerConfig);
  254. subscription = observable.subscribe(subObject);
  255. }
  256. })
  257. });
  258. }
  259. function loadUpload(i,e,key,url,assets)
  260. {
  261. var value = e.attr('v');
  262. if (typeof(upload[value]) != "undefined") {
  263. //return;
  264. }
  265. upload[value] = true;
  266. upload_pic[value] = [];
  267. upload_pic_info[value] = [];
  268. upload_file[value] = [];
  269. var data = {};
  270. data.key = key;
  271. var token = e.attr('token');
  272. var host = e.attr('host');
  273. var domain = e.attr('domain');
  274. var path = e.attr('path');
  275. var cover = e.attr('cover');
  276. if (!cover) {
  277. cover = 1;
  278. }
  279. if (token) {
  280. data.token = token;
  281. }
  282. var uploadUrl = url;
  283. if (domain) {
  284. url = domain;
  285. delete data.key;
  286. //data.key = 2;
  287. }
  288. var id = e.attr('id');
  289. layui.use(['upload','layer','element'], function() {
  290. var layer = layui.layer;
  291. var layuiUpload = layui.upload;
  292. var element = layui.element;
  293. var uploadInst = layuiUpload.render({
  294. elem: '#' + id
  295. ,data: data
  296. ,field: 'file'
  297. ,url: url
  298. ,multiple: true
  299. ,accept:'file'
  300. //,auto:false
  301. ,xhr:xhrOnProgress
  302. ,progress:function(value){//上传进度回调 value进度值
  303. $('#' + id + '_progress').show();
  304. element.progress(id + '_progress', value+'%')//设置页面进度条
  305. }
  306. ,choose: function(obj, self){
  307. if (domain) {
  308. obj.editFile(path, cover);
  309. }
  310. element.progress(id + '_progress', '0%')
  311. //layer.load();
  312. }
  313. ,done: function(data, file) {
  314. if (data.hash) {
  315. data.status = 1;
  316. data.name = data.key;
  317. data.url = host + data.key;
  318. $.getJSON(uploadUrl.replace('save.start', 'qiniu.addFile'), {source:file.name,file:data.key, key:key});
  319. }
  320. element.progress(id + '_progress', '0%')
  321. $('#' + id + '_progress').hide();
  322. layer.closeAll('loading');
  323. if (data.status == 1) {
  324. loadUploadSet(e,value,data,key);
  325. } else {
  326. element.progress(id + '_progress', '0%')
  327. layer.alert(data.message);
  328. return false;
  329. }
  330. }
  331. ,error: function(){
  332. //请求异常回调
  333. layer.alert('文件上传错误');
  334. element.progress(id + '_progress', '0%')
  335. $('#' + id + '_progress').hide();
  336. layer.closeAll('loading');
  337. }
  338. });
  339. });
  340. }
  341. function loadUploadSet(e,value,data,key)
  342. {
  343. var mul = e.attr('mul');
  344. if (mul == 'yes') {
  345. if (e.attr('t') == 'file') {
  346. if (upload_file[value].length <= 0 && $("#" + value).val()) {
  347. upload_file[value] = $("#" + value).val().split(',');
  348. }
  349. var m = $('.' +value+'_mul');
  350. var i = m.find('li').eq(upload_file[value].length);
  351. if (i.length) {
  352. i.find('a').eq(0).html(data.name);
  353. } else {
  354. m.append('<li><a href="'+data.url+'" target="_blank" title="点此下载" >'+data.name+'</a>&nbsp;&nbsp;<a href="javascript:;" title="点此删除" style="color:red;" onclick="fileDel($(this), \''+value+'\')">[删除]</a></li>');
  355. }
  356. upload_file[value].push(data.url);
  357. $("#" + value).val(upload_file.join(','));
  358. } else {
  359. var i = e.attr('i');
  360. var info = '';
  361. if (data.width) {
  362. info = data.width + '_' + data.height + '_' +data.size + '_' + data.fid;
  363. }
  364. if (upload_pic[value].length <= 0 && $("#" + value).val()) {
  365. upload_pic[value] = $("#" + value).val().split(',');
  366. }
  367. if ($('#'+i).length) {
  368. upload_pic_info[value] = $("#" + i).val().split(',');
  369. }
  370. var m = $('.' +value+'_mul');
  371. var index = m.find('img').eq(upload_pic[value].length);
  372. if (index.length) {
  373. index.attr('src', data.url);
  374. index.attr('data-src', data.url);
  375. index.attr('info', info);
  376. } else {
  377. m.append('<a href="javascript:;" title="打开图片管理工具" onclick="picManage($(this), \''+value+'\', \''+key+'\', 2, \''+i+'\')"><img src="'+data.url+'" data-src="'+data.url+'" info="'+info+'" width="150" class="cropper_img" style="margin-left:5px;" alt="打开图片管理工具"/></a>');
  378. }
  379. upload_pic[value].push(data.url);
  380. $("#" + value).val(upload_pic[value].join(','));
  381. if ($('#'+i).length && info) {
  382. upload_pic_info[value].push(info);
  383. $('#'+i).val(upload_pic_info[value].join(','));
  384. }
  385. }
  386. } else {
  387. if (e.attr('t') == 'file') {
  388. } else {
  389. var i = e.attr('i');
  390. if ($('#show_'+value).length) {
  391. $('#show_'+value).parent().show();
  392. $('#show_'+value).attr('src',data.url).show();
  393. $('#show_'+value).attr('data-src',data.url);
  394. if (!checkClick($('#show_'+value))) {
  395. $('#show_'+value).unbind('click').bind('click', function()
  396. {
  397. picManage($(this), value, key, 1, i);
  398. })
  399. }
  400. }
  401. }
  402. $('#'+value).val(data.url);
  403. if ($('#'+i).length && data.width) {
  404. var info = data.width + '_' + data.height + '_' +data.size + '_' + data.fid;
  405. $('#'+i).val(info);
  406. }
  407. }
  408. }
  409. function picSet(pic, s, info)
  410. {
  411. if (picManageE) {
  412. //$('#'+value).val(data.url);
  413. var img = picManageE.find('img');
  414. var old = img.attr('src');
  415. img.attr('src', pic);
  416. var value = $("#" + picManageV);
  417. value.val(value.val().replace(old, pic));
  418. if (s != 1) {
  419. upload_pic[picManageV].replaceOne(old,pic);
  420. }
  421. var i = picManageI;
  422. if ($('#'+i).length) {
  423. if (s == 1) {
  424. $('#'+i).val(info);
  425. } else {
  426. var old = img.attr('info');
  427. if (old) {
  428. upload_pic_info[picManageV].replaceOne(old,info);
  429. $("#" + i).val(upload_pic_info[picManageV].join(','));
  430. }
  431. }
  432. }
  433. }
  434. layer.close(picManageLayer);
  435. }
  436. function picDel(s)
  437. {
  438. if (!picManageE) {
  439. return;
  440. }
  441. if (confirm('确定要删除图片吗?')) {
  442. var v = picManageV;
  443. var e = picManageE;
  444. var i = picManageI;
  445. if (s == 1) {
  446. e.hide();
  447. $("#" + v).val('');
  448. if ($('#'+i).length) {
  449. $('#'+i).val('');
  450. }
  451. } else {
  452. if (upload_pic[v].length <= 0 && $("#" + v).val()) {
  453. upload_pic[v] = $("#" + v).val().split(',');
  454. }
  455. if (upload_pic_info[v].length <= 0 && $('#'+i).length && $("#" + i).val()) {
  456. upload_pic_info[v] = $("#" + i).val().split(',');
  457. }
  458. var p = e.find('img').attr('src');
  459. e.remove();
  460. upload_pic[v].remove(p);
  461. $("#" + v).val(upload_pic[v].join(','));
  462. if ($('#'+i).length) {
  463. var info = e.find('img').attr('info');
  464. upload_pic_info[v].remove(info);
  465. $("#" + i).val(upload_pic_info[v].join(','));
  466. }
  467. }
  468. }
  469. layer.close(picManageLayer);
  470. }
  471. function picManage(e,v,k,s,i)
  472. {
  473. if (!s) {
  474. s = 2;
  475. }
  476. picManageE = e;
  477. picManageV = v;
  478. picManageI = i;
  479. var param = '';
  480. var img = e.find('img');
  481. if (img.attr('data-src')) {
  482. var pic = img.attr('data-src');
  483. param = img.attr('src');
  484. } else {
  485. var pic = img.attr('src');
  486. img.attr('data-src', pic);
  487. }
  488. var url = config.upload.replace('save', 'view') + '.manage&state='+s+'&key='+k+'&pic=' + pic + '&param=' + param;
  489. var layerConfig = {
  490. type: 2,
  491. title: '图片裁剪工具',
  492. content : [url, 'no'],
  493. shade: 0.1,
  494. shadeClose : true,
  495. area: ['1000px','500px']
  496. };
  497. picManageLayer = layer.open(layerConfig);
  498. }
  499. function fileDel(e,v)
  500. {
  501. if(confirm('确定要删除文件吗?'))
  502. {
  503. if(upload_file[v].length <= 0 && $("#" + v).val())
  504. {
  505. upload_file[v] = $("#" + v).val().split(',');
  506. }
  507. var parent = e.parent();
  508. var p = parent.find('a').eq(0).attr('href');
  509. parent.remove();
  510. upload_file[v].remove(p);
  511. //console.info(pic);
  512. $("#" + v).val(upload_file[v].join(','));
  513. }
  514. }