Order.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace addon\cashier\shop\controller;
  11. use app\model\order\Config as ConfigModel;
  12. use addon\cashier\model\order\CashierOrder as OrderModel;
  13. use app\model\order\OrderCommon;
  14. use app\model\order\OrderCommon as OrderCommonModel;
  15. use app\model\order\OrderExport;
  16. use app\model\store\Store;
  17. use app\model\store\Store as StoreModel;
  18. use app\model\system\Promotion as PromotionModel;
  19. use app\model\system\UserGroup;
  20. use app\model\web\Config as WebConfig;
  21. use app\shop\controller\BaseShop;
  22. /**
  23. * 订单
  24. * Class Order
  25. * @package app\shop\controller
  26. */
  27. class Order extends BaseShop
  28. {
  29. protected $replace = [
  30. 'CASHIER_CSS' => __ROOT__ . '/addon/cashier/shop/view/public/css',
  31. 'CASHIER_JS' => __ROOT__ . '/addon/cashier/shop/view/public/js',
  32. 'CASHIER_IMG' => __ROOT__ . '/addon/cashier/shop/view/public/img',
  33. ];
  34. /**
  35. * 快递订单列表
  36. */
  37. public function lists()
  38. {
  39. $order_label_list = array (
  40. 'order_no' => '订单号',
  41. 'out_trade_no' => '交易流水号',
  42. 'remark' => '订单备注',
  43. 'name' => '收货人姓名',
  44. 'order_name' => '商品名称',
  45. 'mobile' => '收货人电话',
  46. 'nick_name' => '会员昵称',
  47. 'sku_no' => '商品编码',
  48. );
  49. $order_model = new OrderModel();
  50. $order_status = input('order_status', '');//订单状态
  51. $order_name = input('order_name', '');
  52. $pay_type = input('pay_type', '');
  53. $order_from = input('order_from', '');
  54. $start_time = input('start_time', '');
  55. $end_time = input('end_time', '');
  56. $delivery_start_time = input('delivery_start_time', '');
  57. $delivery_end_time = input('delivery_end_time', '');
  58. $order_label = !empty($order_label_list[ input('order_label') ]) ? input('order_label') : '';
  59. $search_text = input('search', '');
  60. $promotion_type = input('promotion_type', '');//订单类型
  61. $order_type = input('order_type', 'all');//营销类型
  62. $is_verify = input('is_verify', 'all');
  63. $cashier_order_type = input('cashier_order_type', 'all');
  64. $store_id = input('store_id', '');
  65. $field = 'a.*,s.store_name';
  66. $cashier_order_type_list = $order_model->cashier_order_type;
  67. $order_common_model = new OrderCommonModel();
  68. if (request()->isAjax()) {
  69. $page_index = input('page', 1);
  70. $page_size = input('page_size', PAGE_LIST_ROWS);
  71. $alias = 'a';
  72. $join = null;
  73. $condition = [
  74. [ 'a.site_id', '=', $this->site_id ],
  75. [ 'a.is_delete', '=', 0 ],
  76. [ 'a.order_scene', '=', 'cashier' ],
  77. // [ 'a.pay_status', '=', 1 ]
  78. ];
  79. //订单状态
  80. if ($order_status != '') {
  81. if ($order_status == 'refunding') {
  82. $order_goods_list = $order_common_model->getOrderGoodsList([ [ 'refund_status', 'not in', [ 0, 3 ] ] ], 'order_id')[ 'data' ];
  83. $order_id_arr = array_unique(array_column($order_goods_list, 'order_id'));
  84. $condition[] = [ 'a.order_id', 'in', $order_id_arr ];
  85. } else {
  86. $condition[] = [ 'a.order_status', '=', $order_status ];
  87. }
  88. }
  89. $order = 'a.create_time desc';
  90. $join[] = [
  91. 'store s',
  92. 's.store_id = a.store_id',
  93. 'left'
  94. ];
  95. if ($is_verify != 'all') {
  96. $join[] = [
  97. 'verify v',
  98. 'v.verify_code = a.virtual_code',
  99. 'left'
  100. ];
  101. $condition[] = [ 'v.is_verify', '=', $is_verify ];
  102. }
  103. if ($store_id != '') {
  104. $condition[] = [ 'a.store_id', '=', $store_id ];
  105. }
  106. //订单内容 模糊查询
  107. if ($order_name != '') {
  108. $condition[] = [ 'a.order_name', 'like', '%' . $order_name . '%' ];
  109. }
  110. //订单来源
  111. if ($order_from != '') {
  112. $condition[] = [ 'a.order_from', '=', $order_from ];
  113. }
  114. //订单支付
  115. if ($pay_type != '') {
  116. $condition[] = [ 'a.pay_type', '=', $pay_type ];
  117. }
  118. //订单类型
  119. if ($order_type != 'all') {
  120. $condition[] = [ 'a.order_type', '=', $order_type ];
  121. }
  122. if ($cashier_order_type != 'all') {
  123. $condition[] = [ 'a.cashier_order_type', '=', $cashier_order_type ];
  124. }
  125. //营销类型
  126. if ($promotion_type != '') {
  127. if ($promotion_type == 'empty') {
  128. $condition[] = [ 'a.promotion_type', '=', '' ];
  129. } else {
  130. $condition[] = [ 'a.promotion_type', '=', $promotion_type ];
  131. }
  132. }
  133. if (!empty($start_time) && empty($end_time)) {
  134. $condition[] = [ 'a.create_time', '>=', date_to_time($start_time) ];
  135. } elseif (empty($start_time) && !empty($end_time)) {
  136. $condition[] = [ 'a.create_time', '<=', date_to_time($end_time) ];
  137. } elseif (!empty($start_time) && !empty($end_time)) {
  138. $condition[] = [ 'a.create_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  139. }
  140. if (!empty($delivery_start_time) && empty($delivery_end_time)) {
  141. $condition[] = [ 'a.buyer_ask_delivery_time', '>=', date_to_time($delivery_start_time) ];
  142. } elseif (empty($delivery_start_time) && !empty($delivery_end_time)) {
  143. $condition[] = [ 'a.buyer_ask_delivery_time', '<=', date_to_time($delivery_end_time) ];
  144. } elseif (!empty($delivery_start_time) && !empty($delivery_end_time)) {
  145. $condition[] = [ 'a.buyer_ask_delivery_time', 'between', [ date_to_time($delivery_start_time), date_to_time($delivery_end_time) ] ];
  146. }
  147. if ($search_text != '') {
  148. switch ( $order_label ) {
  149. case 'nick_name':
  150. $join[] = [
  151. 'member m',
  152. 'm.member_id = a.member_id',
  153. 'left'
  154. ];
  155. $condition[] = [ 'm.nickname', 'like', '%' . $search_text . '%' ];
  156. break;
  157. case 'sku_no':
  158. $order_goods_list = $order_common_model->getOrderGoodsList([ [ 'sku_no', 'like', '%' . $search_text . '%' ] ], 'order_id')[ 'data' ];
  159. $order_id_arr = array_unique(array_column($order_goods_list, 'order_id'));
  160. $condition[] = [ 'a.order_id', 'in', $order_id_arr ];
  161. break;
  162. default:
  163. $condition[] = [ 'a.' . $order_label, 'like', '%' . $search_text . '%' ];
  164. }
  165. }
  166. $store_id_arr = [];
  167. $userGroupModel = new UserGroup();
  168. $userInfo = $this->user_info;
  169. $userGroupWhere['uid'] = $userInfo['uid'];
  170. $userGroupList = $userGroupModel->getUserList($userGroupWhere,'uid,store_id');
  171. $store_id_arr = array_column($userGroupList['data'],'store_id');
  172. if(!empty($store_id_arr) && !$userInfo['is_admin']){
  173. $condition[] = [ "a.store_id", "in", $store_id_arr];
  174. }
  175. $list = $order_common_model->getOrderPageList($condition, $page_index, $page_size, $order, $field, $alias, $join);
  176. if (!empty($list[ 'data' ][ 'list' ])) {
  177. foreach ($list[ 'data' ][ 'list' ] as $k => $v) {
  178. $list[ 'data' ][ 'list' ][ $k ][ 'cashier_order_type_name' ] = $cashier_order_type_list[ $v[ 'cashier_order_type' ] ];
  179. }
  180. }
  181. $list[ 'data' ][ 'order_status' ] = $order_status;
  182. return $list;
  183. } else {
  184. $order_type_list = $order_common_model->getOrderTypeStatusList();
  185. $this->assign('order_type_list', $order_type_list);
  186. $this->assign('order_label_list', $order_label_list);
  187. $this->assign('order_status_list', $order_type_list[ 1 ][ 'status' ]);//订单状态
  188. //订单来源 (支持端口)
  189. $this->assign('order_from_list', $order_common_model->getOrderFromList());
  190. $pay_type = $order_common_model->getPayType([ 'order_type' => 5 ]);
  191. $this->assign('pay_type_list', $pay_type);
  192. $this->assign('order_status', $order_status);
  193. $this->assign('cashier_order_type_list', $cashier_order_type_list);
  194. $this->assign('http_type', get_http_type());
  195. $config_model = new ConfigModel();
  196. $order_config = $config_model->getOrderEventTimeConfig($this->site_id, $this->app_module)[ 'data' ][ 'value' ] ?? [];
  197. $this->assign('order_config', $order_config);
  198. $config_model = new WebConfig();
  199. $mp_config = $config_model->getMapConfig($this->site_id);
  200. $this->assign('tencent_map_key', $mp_config[ 'data' ][ 'value' ][ 'tencent_map_key' ]);
  201. $store_list = ( new Store() )->getStoreList([ [ 'site_id', '=', $this->site_id ] ], 'store_name,store_id')[ 'data' ];
  202. $this->assign('store_list', $store_list);
  203. return $this->fetch('order/lists', [], $this->replace);
  204. }
  205. }
  206. /**
  207. * 快递订单详情
  208. */
  209. public function detail()
  210. {
  211. $order_id = input('order_id', 0);
  212. $order_common_model = new OrderCommonModel();
  213. $order_detail_result = $order_common_model->getOrderDetail($order_id);
  214. $order_detail = $order_detail_result[ 'data' ];
  215. if (empty($order_detail)) $this->error('未获取到订单数据', addon_url('shop/order/lists'));
  216. $this->assign('order_detail', $order_detail);
  217. $this->assign('http_type', get_http_type());
  218. $config_model = new WebConfig();
  219. $mp_config = $config_model->getMapConfig($this->site_id);
  220. $this->assign('tencent_map_key', $mp_config[ 'data' ][ 'value' ][ 'tencent_map_key' ]);
  221. return $this->fetch('order/detail');
  222. }
  223. public function exportMoneyOrder2()
  224. {
  225. $order_label_list = array (
  226. 'order_no' => '订单号',
  227. 'out_trade_no' => '外部单号',
  228. 'name' => '收货人姓名',
  229. 'mobile' => '收货人手机号',
  230. 'order_name' => '商品名称',
  231. 'nick_name' => '会员昵称'
  232. );
  233. $order_status = input('order_status', '');//订单状态
  234. $order_name = input('order_name', '');
  235. $pay_type = input('pay_type', '');
  236. $order_from = input('order_from', '');
  237. $start_time = input('start_time', '');
  238. $end_time = input('end_time', '');
  239. $order_label = !empty($order_label_list[ input('order_label') ]) ? input('order_label') : '';
  240. $search_text = input('search', '');
  241. $promotion_type = input('promotion_type', '');
  242. $order_type = input('order_type', 'all');
  243. $is_verify = input('is_verify', 'all');
  244. $order_ids = input('order_ids', '');
  245. $store_id = input('store_id', 0);
  246. $condition_desc = [];
  247. $order_common_model = new OrderCommon();
  248. $condition = [
  249. [ 'o.site_id', '=', $this->site_id ],
  250. [ 'o.is_delete', '=', 0 ],
  251. [ 'o.order_scene', '=', 'cashier' ]
  252. ];
  253. if (!empty($order_ids)) {
  254. $condition[] = [ 'o.order_id', 'in', $order_ids ];
  255. $condition_desc[] = [ 'name' => 'order_id', 'value' => $order_ids ];
  256. }
  257. //订单类型
  258. $order_type_name = '全部';
  259. if ($order_type != 'all') {
  260. $condition[] = [ 'o.order_type', '=', $order_type ];
  261. $order_type_list = $order_common_model->getOrderTypeStatusList();
  262. $order_type_list = array_column($order_type_list, 'name', 'type');
  263. $order_type_name = $order_type_list[ $order_type ];
  264. }
  265. $condition_desc[] = [ 'name' => '订单类型', 'value' => $order_type_name ];
  266. //订单状态
  267. $order_status_name = '全部';
  268. if ($order_status != '') {
  269. if ($order_status != 'refunding') {
  270. $condition[] = [ 'o.order_status', '=', $order_status ];
  271. $order_status_list = $order_common_model->order_status;
  272. $order_status_name = $order_status_list[ $order_status ][ 'name' ] ?? '';
  273. } else {
  274. $join = [
  275. [
  276. 'order_goods og',
  277. 'og.order_id = o.order_id',
  278. 'left'
  279. ]
  280. ];
  281. $condition[] = [ 'og.refund_status', 'not in', [ 0, 3 ] ];
  282. $order_status_name = '维权中';
  283. }
  284. }
  285. $condition_desc[] = [ 'name' => '订单状态', 'value' => $order_status_name ];
  286. //订单内容 模糊查询
  287. if ($order_name != '') {
  288. $condition[] = [ 'o.order_name', 'like', '%' . $order_name . '%' ];
  289. }
  290. if ($is_verify != 'all') {
  291. $condition[] = [ 'v.is_verify', '=', $is_verify ];
  292. }
  293. //订单来源
  294. $order_from_name = '全部';
  295. if ($order_from != '') {
  296. $condition[] = [ 'o.order_from', '=', $order_from ];
  297. //订单来源 (支持端口)
  298. $order_from_list = $order_common_model->getOrderFromList();
  299. $order_from_name = $order_from_list[ $order_from ][ 'name' ] ?? '';
  300. }
  301. $condition_desc[] = [ 'name' => '订单来源', 'value' => $order_from_name ];
  302. //订单支付
  303. $pay_type_name = '全部';
  304. if ($pay_type != '') {
  305. $condition[] = [ 'o.pay_type', '=', $pay_type ];
  306. $pay_type_list = $order_common_model->getPayType();
  307. $pay_type_name = $pay_type_list[ $pay_type ] ?? '';
  308. }
  309. $condition_desc[] = [ 'name' => '支付方式', 'value' => $pay_type_name ];
  310. //营销类型
  311. $promotion_type_name = '全部';
  312. if ($promotion_type != '') {
  313. if ($promotion_type == 'empty') {
  314. $condition[] = [ 'o.promotion_type', '=', '' ];
  315. } else {
  316. $condition[] = [ 'o.promotion_type', '=', $promotion_type ];
  317. }
  318. //营销活动类型
  319. $promotion_model = new PromotionModel();
  320. $promotion_type_list = $promotion_model->getPromotionType();
  321. $promotion_type_list = array_column($promotion_type_list, 'name', 'type');
  322. $promotion_type_name = $promotion_type_list[ $promotion_type ] ?? '';
  323. }
  324. $condition_desc[] = [ 'name' => '营销活动', 'value' => $promotion_type_name ];
  325. $time_name = '';
  326. if (!empty($start_time) && empty($end_time)) {
  327. $condition[] = [ 'o.create_time', '>=', date_to_time($start_time) ];
  328. $time_name = $start_time . '起';
  329. } elseif (empty($start_time) && !empty($end_time)) {
  330. $condition[] = [ 'o.create_time', '<=', date_to_time($end_time) ];
  331. $time_name = '至' . $end_time;
  332. } elseif (!empty($start_time) && !empty($end_time)) {
  333. $condition[] = [ 'o.create_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  334. $time_name = $start_time . ' 至 ' . $end_time;
  335. }
  336. $condition_desc[] = [ 'name' => '下单时间', 'value' => $time_name ];
  337. if ($order_label != 'nick_name') {
  338. if ($search_text != '') {
  339. $condition[] = [ 'o.' . $order_label, 'like', '%' . $search_text . '%' ];
  340. }
  341. foreach ($order_label_list as $k => $v) {
  342. $order_label_name = $v;
  343. if ($k == $order_label) {
  344. $condition_desc[] = [ 'name' => $order_label_name, 'value' => $search_text ];
  345. } else {
  346. $condition_desc[] = [ 'name' => $order_label_name, 'value' => '' ];
  347. }
  348. }
  349. } else {
  350. $condition[] = [ 'm.nickname', 'like', '%' . $search_text . '%' ];
  351. }
  352. if (addon_is_exit('store') == 1 && !empty($store_id)) {
  353. $store_model = new StoreModel();
  354. $store_info = $store_model->getStoreInfo([ [ 'store_id', '=', $store_id ] ], 'store_name')[ 'data' ];
  355. $condition[] = [ 'o.store_id', '=', $store_id ];
  356. $condition_desc[] = [ 'name' => '来源门店', 'value' => $store_info[ 'store_name' ] ];
  357. }
  358. $order_export_model = new OrderExport();
  359. outFileLog($order_label,'order','$order_label');
  360. $result = $order_export_model->orderExport($condition, $condition_desc, $this->site_id, $join ?? null, $is_verify, $order_label);
  361. return $result;
  362. }
  363. }