Orderimportfile.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace app\shop\controller;
  11. use app\model\order\OrderImportFile as OrderImportFileModel;
  12. use app\model\order\OrderCommon as OrderCommonModel;
  13. use app\model\order\Order as OrderModel;
  14. use addon\electronicsheet\model\ExpressElectronicsheet as ExpressElectronicsheetModel;
  15. use app\model\express\ExpressCompany;
  16. use phpoffice\phpexcel\Classes\PHPExcel;
  17. use phpoffice\phpexcel\Classes\PHPExcel\Writer\Excel2007;
  18. /**
  19. * 配送
  20. * Class Express
  21. * @package app\shop\controller
  22. */
  23. class Orderimportfile extends BaseShop
  24. {
  25. /**
  26. * 批量发货(订单导入)
  27. * @return array|mixed
  28. */
  29. public function lists()
  30. {
  31. //电子面单插件
  32. $addon_is_exit = addon_is_exit('electronicsheet', $this->site_id);
  33. if (request()->isAjax()) {
  34. $page_index = input('page', 1);
  35. $page_size = input('page_size', PAGE_LIST_ROWS);
  36. $model = new OrderImportFileModel();
  37. $list = $model->getOrderImportFilePageList([ [ 'site_id', '=', $this->site_id ] ], $page_index, $page_size);
  38. return $list;
  39. }
  40. $this->assign('addon_is_exit', $addon_is_exit);
  41. return $this->fetch('orderimportfile/lists');
  42. }
  43. /**
  44. * 导出待发货订单
  45. */
  46. public function exportDeliveryOrder()
  47. {
  48. //电子面单插件
  49. $addon_is_exit = addon_is_exit('electronicsheet', $this->site_id);
  50. $order_model = new OrderModel();
  51. $order_status_list = $order_model->delivery_order_status;
  52. $condition = [
  53. [ 'order_status', 'in', array_keys($order_status_list) ],
  54. [ 'order_type', '=', 1 ],
  55. [ 'site_id', '=', $this->site_id ],
  56. [ 'is_delete', '=', 0 ]
  57. ];
  58. $order_common_model = new OrderCommonModel();
  59. $field = 'order_no,order_name,full_address,address,name,mobile';
  60. $list_result = $order_common_model->getOrderList($condition, $field, 'create_time desc');
  61. $list = $list_result[ 'data' ];
  62. // 实例化excel
  63. $phpExcel = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
  64. $phpExcel->getProperties()->setTitle("待发货订单");
  65. $phpExcel->getProperties()->setSubject("待发货订单");
  66. //单独添加列名称
  67. $phpExcel->setActiveSheetIndex(0);
  68. $phpExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20);
  69. $phpExcel->getActiveSheet()->getColumnDimension('B')->setWidth(50);
  70. $phpExcel->getActiveSheet()->getColumnDimension('C')->setWidth(20);
  71. $phpExcel->getActiveSheet()->getColumnDimension('D')->setWidth(32);
  72. $phpExcel->getActiveSheet()->getColumnDimension('E')->setWidth(70);
  73. $phpExcel->getActiveSheet()->getColumnDimension('F')->setWidth(32);
  74. $phpExcel->getActiveSheet()->getColumnDimension('G')->setWidth(50);
  75. $phpExcel->getActiveSheet()->getColumnDimension('H')->setWidth(48);
  76. $phpExcel->getActiveSheet()->setCellValue('A1', '订单编号');
  77. $phpExcel->getActiveSheet()->setCellValue('B1', '订单内容');
  78. $phpExcel->getActiveSheet()->setCellValue('C1', '收件人姓名');
  79. $phpExcel->getActiveSheet()->setCellValue('D1', '收件人电话');
  80. $phpExcel->getActiveSheet()->setCellValue('E1', '收件人地址');
  81. if ($addon_is_exit == 1) {
  82. $phpExcel->getActiveSheet()->setCellValue('F1', '发货方式(手动发货/电子面单)');
  83. $phpExcel->getActiveSheet()->setCellValue('G1', '物流公司名称(电子面单发货时为面单模板名称)');
  84. $phpExcel->getActiveSheet()->setCellValue('H1', '物流单号(手动发货无需物流和电子面单时为空)');
  85. } else {
  86. $phpExcel->getActiveSheet()->setCellValue('F1', '发货方式');
  87. $phpExcel->getActiveSheet()->setCellValue('G1', '物流公司名称');
  88. $phpExcel->getActiveSheet()->setCellValue('H1', '物流单号(无需物流时为空)');
  89. }
  90. foreach ($list as $k => $v) {
  91. $start = $k + 2;
  92. $phpExcel->getActiveSheet()->setCellValue('A' . $start, $v[ 'order_no' ] . ' ');
  93. $phpExcel->getActiveSheet()->setCellValue('B' . $start, $v[ 'order_name' ] . "\t");
  94. $phpExcel->getActiveSheet()->setCellValue('C' . $start, $v[ 'name' ] . ' ');
  95. $phpExcel->getActiveSheet()->setCellValue('D' . $start, $v[ 'mobile' ] . ' ');
  96. $phpExcel->getActiveSheet()->setCellValue('E' . $start, $v[ 'full_address' ] . $v[ 'address' ] . "\t");
  97. $phpExcel->getActiveSheet()->setCellValue('F' . $start, '');
  98. $phpExcel->getActiveSheet()->setCellValue('G' . $start, '');
  99. $phpExcel->getActiveSheet()->setCellValue('H' . $start, '');
  100. }
  101. // 重命名工作sheet
  102. $phpExcel->getActiveSheet()->setTitle('待发货订单');
  103. // 设置第一个sheet为工作的sheet
  104. $phpExcel->setActiveSheetIndex(0);
  105. // 保存Excel 2007格式文件,保存路径为当前路径,名字为export.xlsx
  106. $objWriter = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($phpExcel, 'Xlsx');
  107. $file = date('Y年m月d日-待发货订单', time()) . '.xlsx';
  108. $objWriter->save($file);
  109. header("Content-type:application/octet-stream");
  110. $filename = basename($file);
  111. header("Content-Disposition:attachment;filename = " . $filename);
  112. header("Accept-ranges:bytes");
  113. header("Accept-length:" . filesize($file));
  114. readfile($file);
  115. unlink($file);
  116. exit;
  117. }
  118. /**
  119. * 导出物流公司和电子面单模板
  120. */
  121. public function exportExpressTemplate()
  122. {
  123. //电子面单插件
  124. $addon_is_exit = addon_is_exit('electronicsheet', $this->site_id);
  125. $express_company_model = new ExpressCompany();
  126. //店铺物流公司
  127. $result = $express_company_model->getExpressCompanyList([ [ "site_id", "=", $this->site_id ] ]);
  128. $list = $result[ 'data' ];
  129. // 实例化excel
  130. $phpExcel = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
  131. //单独添加列名称
  132. $phpExcel->setActiveSheetIndex(0);
  133. $phpExcel->getActiveSheet()->getColumnDimension('A')->setWidth(30);
  134. $phpExcel->getActiveSheet()->getColumnDimension('B')->setWidth(15);
  135. $phpExcel->getActiveSheet()->setCellValue('A1', '物流公司');
  136. $phpExcel->getActiveSheet()->setCellValue('B1', '物流公司编码');
  137. foreach ($list as $k => $v) {
  138. $start = $k + 2;
  139. $phpExcel->getActiveSheet()->setCellValue('A' . $start, $v[ 'company_name' ] . "\t");
  140. $phpExcel->getActiveSheet()->setCellValue('B' . $start, $v[ 'express_no' ]);
  141. }
  142. // 重命名工作sheet
  143. $phpExcel->getActiveSheet()->setTitle('物流公司');
  144. if ($addon_is_exit == 1) {
  145. //获取电子面单模板
  146. $electronicsheet_model = new ExpressElectronicsheetModel();
  147. $condition[] = [ 'site_id', '=', $this->site_id ];
  148. $field = 'id,template_name,company_name';
  149. $electronicsheet_list_result = $electronicsheet_model->getExpressElectronicsheetList($condition, $field, 'is_default desc');
  150. $electronicsheet_list = $electronicsheet_list_result[ 'data' ];
  151. $phpExcel->createSheet();
  152. $phpExcel->setActivesheetindex(1);
  153. $phpExcel->getActiveSheet()->getColumnDimension('A')->setWidth(30);
  154. $phpExcel->getActiveSheet()->getColumnDimension('B')->setWidth(30);
  155. $phpExcel->getActiveSheet()->setCellValue('A1', '电子面单模板名称');
  156. $phpExcel->getActiveSheet()->setCellValue('B1', '物流公司');
  157. foreach ($electronicsheet_list as $k => $v) {
  158. $start = $k + 2;
  159. $phpExcel->getActiveSheet()->setCellValue('A' . $start, $v[ 'template_name' ] . "\t");
  160. $phpExcel->getActiveSheet()->setCellValue('B' . $start, $v[ 'company_name' ] . "\t");
  161. }
  162. $phpExcel->getActiveSheet()->setTitle('电子面单');
  163. }
  164. // 设置第一个sheet为工作的sheet
  165. $phpExcel->setActiveSheetIndex(0);
  166. // 保存Excel 2007格式文件,保存路径为当前路径,名字为export.xlsx
  167. $objWriter = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($phpExcel, 'Xlsx');
  168. if ($addon_is_exit == 1) {
  169. $file = date('Y年m月d日-物流公司和电子面单对照表', time()) . '.xlsx';
  170. } else {
  171. $file = date('Y年m月d日-物流公司对照表', time()) . '.xlsx';
  172. }
  173. $objWriter->save($file);
  174. header("Content-type:application/octet-stream");
  175. $filename = basename($file);
  176. header("Content-Disposition:attachment;filename = " . $filename);
  177. header("Accept-ranges:bytes");
  178. header("Accept-length:" . filesize($file));
  179. readfile($file);
  180. unlink($file);
  181. exit;
  182. }
  183. /**
  184. * 导入订单发货
  185. */
  186. public function importOrder()
  187. {
  188. if (request()->isAjax()) {
  189. $filename = input('filename', '');
  190. $path = input('path', '');
  191. $order_model = new OrderModel();
  192. $res = $order_model->orderFileDelivery([ 'filename' => $filename, 'path' => $path ], $this->site_id, $this->uid);
  193. return $res;
  194. }
  195. }
  196. /**
  197. * 删除导入的订单文件记录
  198. */
  199. public function delete()
  200. {
  201. if (request()->isAjax()) {
  202. $id = input('id', '');
  203. $model = new OrderimportfileModel();
  204. $res = $model->deleteOrderImportFile($id, $this->site_id);
  205. return $res;
  206. }
  207. }
  208. /**
  209. * 导入记录
  210. * @return array|mixed
  211. */
  212. public function detail()
  213. {
  214. $model = new OrderImportFileModel();
  215. $file_id = input('file_id', 0);
  216. if (request()->isAjax()) {
  217. $condition = [
  218. [ 'oif.site_id', '=', $this->site_id ],
  219. [ 'oif.file_id', '=', $file_id ]
  220. ];
  221. $page_index = input('page', 1);
  222. $page_size = input('page_size', PAGE_LIST_ROWS);
  223. $status = input('status', '');
  224. if ($status !== '') {
  225. $condition[] = [ 'oif.status', '=', $status ];
  226. }
  227. $field = 'oif.*, o.order_id';
  228. $alias = 'oif';
  229. $join = [
  230. [ 'order o', 'oif.order_no = o.order_no', 'left' ]
  231. ];
  232. $list = $model->getOrderImportFilePageLogList($condition, $page_index, $page_size, 'oif.id desc', $field, $alias, $join);
  233. return $list;
  234. }
  235. $this->assign('file_id', $file_id);
  236. $info = $model->getOrderImportFileInfo([ [ 'id', '=', $file_id ], [ 'site_id', '=', $this->site_id ] ]);
  237. if (empty($info[ 'data' ])) $this->error('未获取到导入数据', addon_url('shop/orderimportfile/lists'));
  238. $this->assign('info', $info[ 'data' ]);
  239. return $this->fetch('orderimportfile/detail');
  240. }
  241. }