upload.js 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. var upload_pic = [];
  2. var upload_file = [];
  3. var upload = [];
  4. var showUploadE;
  5. var showUploadUrl;
  6. var showUploadType = 1;
  7. var showUploadCall = false;
  8. var showUploadThis = false;
  9. var showUploadIndex = false;
  10. //创建监听函数
  11. var xhrOnProgress=function(fun) {
  12. xhrOnProgress.onprogress = fun; //绑定监听
  13. //使用闭包实现监听绑
  14. return function() {
  15. //通过$.ajaxSettings.xhr();获得XMLHttpRequest对象
  16. var xhr = $.ajaxSettings.xhr();
  17. //判断监听函数是否为函数
  18. if (typeof xhrOnProgress.onprogress !== 'function')
  19. return xhr;
  20. //如果有监听函数并且xhr对象支持绑定时就把监听函数绑定上去
  21. if (xhrOnProgress.onprogress && xhr.upload) {
  22. xhr.upload.onprogress = xhrOnProgress.onprogress;
  23. }
  24. return xhr;
  25. }
  26. }
  27. function showUpload(i,e,key,url,assets,type)
  28. {
  29. layui.use(['upload','layer','element'], function() {
  30. var html = '';
  31. var layer = layui.layer;
  32. var config = {
  33. type: 0,
  34. title: e.attr('value'),
  35. shade: 0.1,
  36. shadeClose : true,
  37. content: html,
  38. area: '800px'
  39. };
  40. e.click(function()
  41. {
  42. url = url.replace('save', 'view');
  43. showUploadE = e;
  44. if (!type) {
  45. type = 1;
  46. }
  47. showUploadType = type;
  48. showUploadUrl = url;
  49. var cur = $('#' + showUploadE.attr('v')).val();
  50. $.getJSON(url, {json:1,key:key,cur:cur}, function(t)
  51. {
  52. config.content = t.data;
  53. showUploadIndex = layer.open(config);
  54. })
  55. })
  56. });
  57. }
  58. function editorShowUpload(cur, url, title, func, self)
  59. {
  60. showUploadType = 2;
  61. showUploadCall = func;
  62. showUploadThis = self;
  63. layui.use(['upload','layer','element'], function() {
  64. var html = '';
  65. var layer = layui.layer;
  66. var config = {
  67. type: 0,
  68. title: title,
  69. shade: 0.1,
  70. shadeClose : true,
  71. content: html,
  72. area: '800px'
  73. };
  74. url = url.replace('save', 'view');
  75. showUploadUrl = url;
  76. $.getJSON(url, {json:1,cur:cur}, function(t)
  77. {
  78. config.content = t.data;
  79. showUploadIndex = layer.open(config);
  80. })
  81. });
  82. }
  83. function showUploadFilesSet(e, name, url, id)
  84. {
  85. $('.layui-anim-yes').addClass('layui-anim-no');
  86. $('.layui-anim-yes').removeClass('layui-anim-yes');
  87. e.parent().removeClass('layui-anim-no');
  88. e.parent().addClass('layui-anim-yes');
  89. $('.file_cur').val(url);
  90. if (showUploadType == 1) {
  91. var value = showUploadE.attr('v');
  92. loadUploadSet(showUploadE, value, {name:name,url:url});
  93. } else if (showUploadType == 2) {
  94. showUploadCall.call(showUploadThis, url, name, id);
  95. if (showUploadIndex) {
  96. layer.close(showUploadIndex);
  97. showUploadIndex = false;
  98. } else {
  99. layer.closeAll();
  100. }
  101. } else if (showUploadType == 3) {
  102. var value = showUploadE.attr('editor_id');
  103. var key = showUploadE.attr('key');
  104. //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>');
  105. KindEditor.insertHtml('#' + value, '<div class="dever-video"><img src="'+url+'" style="width:450px;height:300px;" data-id="'+id+'" data-key="'+key+'"/></div><div class="dever-drop">'+name+'(请勿修改)</div>');
  106. if (showUploadIndex) {
  107. layer.close(showUploadIndex);
  108. showUploadIndex = false;
  109. } else {
  110. layer.closeAll();
  111. }
  112. }
  113. }
  114. function showUploadFilesSearch(e)
  115. {
  116. var p = e.parent();
  117. var pg = p.find('.file_pg').val();
  118. var key = p.find('.file_key').val();
  119. var name = p.find('.file_filename').val();
  120. var tag = p.find('.file_tag').val();
  121. var cate = p.find('.file_cate').val();
  122. var cur = p.find('.file_cur').val();
  123. var url = showUploadUrl;
  124. showUploadFiles(url, name, key, cate, tag, cur, pg);
  125. }
  126. function showUploadFiles(url, name, key, cate, tag, cur, pg)
  127. {
  128. if (!pg) {
  129. pg = 1;
  130. }
  131. $.getJSON(url, {json:1,key:key, name:name,cate:cate, tag:tag, pg:pg, cur:cur}, function(t)
  132. {
  133. var t = '<div>' + t.data + '</div>';
  134. html = $(t).find('#component-anim').html();
  135. $("#component-anim").html(html);
  136. })
  137. }
  138. function loadUploadQiniu(i,e,key,url,assets)
  139. {
  140. //https://developer.qiniu.com/kodo/sdk/1241/php
  141. var value = e.attr('v');
  142. if (typeof(upload[value]) != "undefined") {
  143. //return;
  144. }
  145. upload[value] = true;
  146. upload_pic[value] = [];
  147. upload_file[value] = [];
  148. var id = e.attr('id');
  149. var uploader = Qiniu.uploader({
  150. runtimes: 'html5,flash,html4', //上传模式,依次退化
  151. browse_button: id, //上传选择的点选按钮,**必需**
  152. uptoken_url: url, //Ajax请求upToken的Url,**强烈建议设置**(服务端提供)
  153. domain: 'http://rwxf.qiniudn.com/', //bucket 域名,下载资源时用到,**必需**
  154. //container: 'container', //上传区域DOM ID,默认是browser_button的父元素,
  155. max_file_size: '100mb', //最大文件体积限制
  156. flash_swf_url: 'plupload/Moxie.swf', //引入flash,相对路径
  157. max_retries: 3, //上传失败最大重试次数
  158. dragdrop: true, //开启可拖曳上传
  159. drop_element: 'container', //拖曳上传区域元素的ID,拖曳文件或文件夹后可触发上传
  160. chunk_size: '4mb', //分块上传时,每片的体积
  161. auto_start: true, //选择文件后自动上传,若关闭需要自己绑定事件触发上传
  162. init: {
  163. 'UploadProgress': function(up, file) {
  164. $('#pickfiles').prop('disabled', true).html('图片上传中...');
  165. },
  166. 'FileUploaded': function(up, file, info) {
  167. $('#pickfiles').prop('disabled', false).html('上传图片');
  168. var res = JSON.parse(info);
  169. imgUrl = up.getOption('domain') + res.key;
  170. refresh(imgUrl);
  171. },
  172. 'Error': function(up, err, errTip) {
  173. $('#pickfiles').prop('disabled', false).html('上传图片');
  174. }
  175. }
  176. });
  177. }
  178. function loadUpload(i,e,key,url,assets)
  179. {
  180. var value = e.attr('v');
  181. if (typeof(upload[value]) != "undefined") {
  182. //return;
  183. }
  184. upload[value] = true;
  185. upload_pic[value] = [];
  186. upload_file[value] = [];
  187. var id = e.attr('id');
  188. layui.use(['upload','layer','element'], function() {
  189. var layer = layui.layer;
  190. var layuiUpload = layui.upload;
  191. var element = layui.element;
  192. var uploadInst = layuiUpload.render({
  193. elem: '#' + id
  194. ,data: {'key' : key}
  195. ,field: 'file'
  196. ,url: url
  197. ,multiple: true
  198. ,accept:'file'
  199. ,xhr:xhrOnProgress
  200. ,progress:function(value){//上传进度回调 value进度值
  201. $('#' + id + '_progress').show();
  202. element.progress(id + '_progress', value+'%')//设置页面进度条
  203. }
  204. ,choose: function(obj){
  205. element.progress(id + '_progress', '0%')
  206. layer.load();
  207. }
  208. ,done: function(data) {
  209. element.progress(id + '_progress', '0%')
  210. $('#' + id + '_progress').hide();
  211. layer.closeAll('loading');
  212. if (data.status == 1) {
  213. loadUploadSet(e,value,data);
  214. } else {
  215. element.progress(id + '_progress', '0%')
  216. layer.alert(data.message);
  217. return false;
  218. }
  219. }
  220. ,error: function(){
  221. //请求异常回调
  222. }
  223. });
  224. });
  225. }
  226. function loadUploadSet(e,value,data)
  227. {
  228. var mul = e.attr('mul');
  229. if (mul == 'yes') {
  230. if (e.attr('t') == 'file') {
  231. if (upload_file[value].length <= 0 && $("#" + value).val()) {
  232. upload_file[value] = $("#" + value).val().split(',');
  233. }
  234. var m = $('.' +value+'_mul');
  235. var i = m.find('li').eq(upload_file[value].length);
  236. if (i.length) {
  237. i.find('a').eq(0).html(data.name);
  238. } else {
  239. 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>');
  240. }
  241. upload_file[value].push(data.url);
  242. $("#" + value).val(upload_file.join(','));
  243. } else {
  244. if (upload_pic[value].length <= 0 && $("#" + value).val()) {
  245. upload_pic[value] = $("#" + value).val().split(',');
  246. }
  247. var m = $('.' +value+'_mul');
  248. var i = m.find('img').eq(upload_pic[value].length);
  249. if (i.length) {
  250. i.attr('src', data.url);
  251. } else {
  252. m.append('<a href="javascript:;" title="点此删除" onclick="picDel($(this), \''+value+'\')"><img src="'+data.url+'" width="150" style="margin-left:5px;" alt="点此删除"/></a>');
  253. }
  254. upload_pic[value].push(data.url);
  255. $("#" + value).val(upload_pic[value].join(','));
  256. }
  257. } else {
  258. if (e.attr('t') == 'file') {
  259. } else {
  260. $('#show_'+value).attr('src',data.url).show();
  261. $('#show_'+value).unbind('click').bind('click', function()
  262. {
  263. picDel($(this), value, 1);
  264. })
  265. }
  266. $('#'+value).val(data.url);
  267. }
  268. }
  269. function picDel(e,v,s)
  270. {
  271. if (confirm('确定要删除图片吗?')) {
  272. if (s == 1) {
  273. e.hide();
  274. $("#" + v).val('');
  275. } else {
  276. if (upload_pic[v].length <= 0 && $("#" + v).val()) {
  277. upload_pic[v] = $("#" + v).val().split(',');
  278. }
  279. var p = e.find('img').attr('src');
  280. e.remove();
  281. upload_pic[v].remove(p);
  282. $("#" + v).val(upload_pic[v].join(','));
  283. }
  284. }
  285. }
  286. function fileDel(e,v)
  287. {
  288. if(confirm('确定要删除文件吗?'))
  289. {
  290. if(upload_file[v].length <= 0 && $("#" + v).val())
  291. {
  292. upload_file[v] = $("#" + v).val().split(',');
  293. }
  294. var parent = e.parent();
  295. var p = parent.find('a').eq(0).attr('href');
  296. parent.remove();
  297. upload_file[v].remove(p);
  298. //console.info(pic);
  299. $("#" + v).val(upload_file[v].join(','));
  300. }
  301. }