returns.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. {Template header}
  2. <body>
  3. <div class="warp">
  4. <div class="fixed">
  5. <ul class="search">
  6. <li>
  7. 所属店铺:<select name="shop" class="select" >
  8. <option value="">请选择</option>
  9. <option value="0">不确定</option>
  10. {loop usershop() as $val}
  11. <option value="{$val['id']}">{$val['shopname']}</option>
  12. {/loop}</select>
  13. </li>
  14. <li>订单编号:<input value="" name="number" type="text" ></li>
  15. <li>订单号:<input value="" name="orderinfo" type="text" ></li>
  16. <li>退回单号:<input value="" name="torderinfo" type="text" ></li>
  17. <li>姓名:<input value="" name="name" type="text" ></li>
  18. <li>退货登记编码:<input value="" name="ret_regist_no" type="text" ></li>
  19. <br/>
  20. <li>收货地址:<select name="region" class="select class" style="width:85px !important;">
  21. <option value="-1">请选择</option>
  22. <option value="2">美国</option>
  23. <option value="1">国内</option>
  24. </select></li>
  25. <li>快递方式:<select name="express" class="select class" style="width:85px !important;">
  26. <option value="">请选择</option>
  27. <option value="USPS">USPS</option>
  28. <option value="UPS">UPS</option>
  29. <option value="Fedex">Fedex</option>
  30. <option value="DHL">DHL</option>
  31. <option value="Royal Mail">Royal Mail</option>
  32. <option value="Canada Post">Canada Post</option>
  33. <option value="France Post">France Post</option>
  34. <option value="Germany Post">Germany Post</option>
  35. <option value="Australia Post">Australia Post</option>
  36. <option value="TNT">TNT</option>
  37. <option value="邮政">邮政</option>
  38. <option value="其它">其它</option>
  39. </select></li>
  40. <li>
  41. 是否收到:<select name="fh" class="select" style="width:85px !important;">
  42. <option value="">请选择</option>
  43. <option value="1">已收到</option>
  44. <option value="2">未收到</option>
  45. </select>
  46. </li>
  47. <li>是否处理:<select name="qr" class="select class" style="width:85px !important;">
  48. <option value="">请选择</option>
  49. <option value="0">未处理</option>
  50. <option value="1">已处理</option>
  51. </select></li>
  52. <li>
  53. 完好程度:<select name="whcd_status" class="select" style="width:85px !important;">
  54. <option value="">请选择</option>
  55. <option value="1">(人发)可用</option>
  56. <option value="6">(化纤)可用</option>
  57. <option value="7">(化纤)待确认</option>
  58. <option value="2">(人发)精打理</option>
  59. <option value="3">(人发)不可用</option>
  60. <option value="5">(化纤)不可用</option>
  61. <option value="4">非假发/非我司头发</option>
  62. </select>
  63. </li>
  64. <li>选择时间条件:<select name="xztime" class="select" style="width:85px !important;">
  65. <option value="time">添加时间</option>
  66. <option value="edittime">更新时间</option>
  67. </select></li>
  68. <li><input id="timetk" value="{date('Y-m-d',time()-30*3*24*3600)} 0:00" name="timetk" type="text" onClick="laydate({istime: true,format:'YYYY-MM-DD hh:mm'})" style="width:110px !important;">
  69. 至&nbsp;&nbsp;&nbsp;&nbsp; <input id="timetj" value="{date('Y-m-d',time()+24*3600)} 0:00" name="timetj" type="text" onClick="laydate({istime: true,format:'YYYY-MM-DD hh:mm'})" style="width:110px !important;"></li>
  70. <li><span>确 定</span></li>
  71. </ul>
  72. <div class="control">
  73. <a href="javascript:void(0);" class="window" data-h="/returns/add/" data-t="退货 - 添加">添 加</a>
  74. {if $power == '1'}<a href="javascript:void(0);" class="check">删 除</a> {/if}
  75. <a href="javascript:void(0);" class="returnsexcel">下 载</a>
  76. <a href="javascript:void(0);" id="uploadLink">导入数据</a>
  77. <input type="file" id="fileInput" accept=".xlsx, .xls, .csv" style="display: none;">
  78. <a href="/data/lymob/thdjb.xlsx" >下载导入模板</a>
  79. </div>
  80. <table class="datatitle data" border="0" style="border-collapse:collapse;">
  81. <tr>
  82. <td><label onClick="swapCheck()"><input name="checkbox" type="checkbox" class="regular-checkbox"></label></td>
  83. <td>收货地址</td>
  84. <td>编号</td>
  85. <td>客户姓名</td>
  86. <td>快递方式</td>
  87. <td>退回单号</td>
  88. <td>所属店铺</td>
  89. <td>添加时间</td>
  90. <td>更新时间</td>
  91. <td>操作</td>
  92. </tr>
  93. </table>
  94. </div>
  95. <table class="datatext data" border="0" style="border-collapse:collapse;">
  96. </table>
  97. <div class="bomf"></div>
  98. </div>
  99. <script>
  100. var dataurl = "/returns";
  101. var excel = "/returns/";
  102. var editurl = "/returns/edit/";
  103. var editdj = 1;
  104. var editt = "退货 - 修改";
  105. $(function(){
  106. // 获取元素
  107. const uploadLink = document.getElementById('uploadLink');
  108. const fileInput = document.getElementById('fileInput');
  109. // 点击 a 标签触发隐藏的 file input
  110. uploadLink.addEventListener('click', (e) => {
  111. e.preventDefault(); // 阻止 a 标签跳转
  112. fileInput.click(); // 打开文件选择对话框
  113. });
  114. // 监听文件选择
  115. fileInput.addEventListener('change', (e) => {
  116. const file = e.target.files[0];
  117. if (!file) return;
  118. // 可选的:检查文件类型
  119. const validTypes = ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'text/csv'];
  120. if (!validTypes.includes(file.type)) {
  121. alert('请选择有效的 Excel 文件(.xlsx, .xls, .csv)');
  122. fileInput.value = ''; // 清空选择
  123. return;
  124. }
  125. // 使用 FileReader 读取文件内容
  126. const reader = new FileReader();
  127. reader.onload = (loadEvent) => {
  128. try {
  129. // 读取结果为 ArrayBuffer
  130. const arrayBuffer = loadEvent.target.result;
  131. // 使用 SheetJS 解析 Excel(type 指定为 'array')
  132. const workbook = XLSX.read(arrayBuffer, { type: 'array' });
  133. // 获取第一个工作表
  134. const firstSheetName = workbook.SheetNames[0];
  135. // 将工作表转换为 HTML 表格(简单展示)
  136. const worksheet = workbook.Sheets[firstSheetName];
  137. // const jsonData = XLSX.utils.sheet_to_json(worksheet, {header: 1,
  138. // defval: '' // 为空单元格设置默认值
  139. // });
  140. // console.log(jsonData)
  141. //resultDiv.innerHTML = `<h3>解析结果(第一个工作表)</h3>${htmlTable}`;
  142. // 同时你也可以获得 JSON 数据:
  143. const jsonData = XLSX.utils.sheet_to_json(worksheet);
  144. //console.log(jsonData); // 在控制台查看 JSON
  145. doSendExcel(jsonData);
  146. } catch (error) {
  147. console.error('解析失败', error);
  148. alert('文件解析失败,请确保文件格式正确');
  149. }
  150. };
  151. reader.readAsArrayBuffer(file); // 以 ArrayBuffer 形式读取
  152. });
  153. })
  154. // 重置文件输入框的函数
  155. function resetFileInput() {
  156. $("#fileInput").val(''); // 核心:清空选择
  157. }
  158. function doSendExcel(jsonData){
  159. if(jsonData.length == 0 ){
  160. return layx.confirm('提示',"解析excel数据不存在",null,{
  161. buttons:[
  162. {
  163. label:'确定',
  164. callback:function(id, button, event){
  165. layx.destroy(id);
  166. }
  167. }
  168. ],dialogIcon:'error',shadable:0.6
  169. });
  170. }
  171. layx.load('loadId','数据加载中');
  172. resetFileInput();
  173. $.ajax({
  174. url: dataurl+"/excellr",
  175. data: {data:JSON.stringify(jsonData)},
  176. type: "POST",
  177. dataType: "json",
  178. success: function(a) {
  179. layx.destroy('loadId');
  180. if (a && a.success) {
  181. if(a.data.length > 0){
  182. layx.confirm('提示',a.msg,null,{
  183. buttons:[
  184. {
  185. label:'确定',
  186. callback:function(id, button, event){
  187. layx.destroy(id);
  188. download_excel(a.data)
  189. }
  190. },
  191. {
  192. label:'取消',
  193. callback:function(id, button, event){
  194. layx.destroy(id);
  195. }
  196. }
  197. ]
  198. });
  199. }else{
  200. $(".ts p").html(a.msg);
  201. $(".ts").show();
  202. setTimeout('$(".ts").fadeOut()', 1000);
  203. }
  204. } else {
  205. $(".ts p").html(a.msg);
  206. $(".ts").show();
  207. setTimeout('$(".ts").fadeOut()', 1000);
  208. }
  209. }
  210. })
  211. }
  212. function download_excel(data){
  213. let sheet = XLSX.utils.json_to_sheet(data)
  214. sheet['!cols'] = [
  215. //订单号
  216. {
  217. wch:40,
  218. },
  219. //订单编码
  220. {
  221. wch:100,
  222. },
  223. ];
  224. let workbook = XLSX.utils.book_new();
  225. XLSX.utils.book_append_sheet(workbook, sheet, "Sheet1");
  226. XLSX.writeFile(workbook, "错误数据.xlsx");
  227. }
  228. $(".returnsexcel").click(function() {
  229. var f = "";
  230. var a = "";
  231. $(".datatext input[name='check']:checked").each(function() {
  232. a = a + $(this).val()+",";
  233. });
  234. f = f + "a=" + a + "&";
  235. $(".select").each(function() {
  236. f = f + $(this).attr("name") + "=" + $(this).children("option:selected").val() + "&";
  237. });
  238. $("input:text").each(function() {
  239. f = f + $(this).attr("name") + "=" + $(this).val() + "&";
  240. });
  241. var a = "";
  242. $(".datatext input[name='check']:checked").each(function() {
  243. a = a + $(this).val()+",";
  244. });
  245. f = f + "excel=1&a="+a;
  246. window.location.href = "/returns/excel?excel=1&"+f;
  247. });
  248. $(".datatext").on('click',".thqr",function() {
  249. var thid = $(this).data("id");
  250. $.ajax({
  251. url: dataurl+"/qr",
  252. data: 'id='+thid,
  253. type: "POST",
  254. dataType: "json",
  255. success: function(a) {
  256. if (a && a.success) {
  257. $(".datatext #"+a.id).find("td:eq(9)").html(a.t);
  258. $(".ts p").html(a.msg);
  259. $(".ts").show();
  260. setTimeout('$(".ts").fadeOut()', 1000);
  261. } else {
  262. $(".ts p").html(a.msg);
  263. $(".ts").show();
  264. setTimeout('$(".ts").fadeOut()', 1000);
  265. }
  266. }
  267. });
  268. });
  269. </script>
  270. <script type="text/javascript" src="{$theme}js/laydate.js"></script>
  271. <script type="text/javascript" src="{$theme}js/excel/xlxs.js" ></script>
  272. {Template footer}