Order0626.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  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 as OrderCommonModel;
  14. use app\model\store\Store;
  15. use app\model\system\UserGroup;
  16. use app\model\web\Config as WebConfig;
  17. use app\shop\controller\BaseShop;
  18. /**
  19. * 订单
  20. * Class Order
  21. * @package app\shop\controller
  22. */
  23. class Order extends BaseShop
  24. {
  25. protected $replace = [
  26. 'CASHIER_CSS' => __ROOT__ . '/addon/cashier/shop/view/public/css',
  27. 'CASHIER_JS' => __ROOT__ . '/addon/cashier/shop/view/public/js',
  28. 'CASHIER_IMG' => __ROOT__ . '/addon/cashier/shop/view/public/img',
  29. ];
  30. /**
  31. * 快递订单列表
  32. */
  33. public function lists()
  34. {
  35. $order_label_list = array (
  36. 'order_no' => '订单号',
  37. 'out_trade_no' => '交易流水号',
  38. 'remark' => '订单备注',
  39. 'name' => '收货人姓名',
  40. 'order_name' => '商品名称',
  41. 'mobile' => '收货人电话',
  42. 'nick_name' => '会员昵称',
  43. 'sku_no' => '商品编码',
  44. );
  45. $order_model = new OrderModel();
  46. $order_status = input('order_status', '');//订单状态
  47. $order_name = input('order_name', '');
  48. $pay_type = input('pay_type', '');
  49. $order_from = input('order_from', '');
  50. $start_time = input('start_time', '');
  51. $end_time = input('end_time', '');
  52. $delivery_start_time = input('delivery_start_time', '');
  53. $delivery_end_time = input('delivery_end_time', '');
  54. $order_label = !empty($order_label_list[ input('order_label') ]) ? input('order_label') : '';
  55. $search_text = input('search', '');
  56. $promotion_type = input('promotion_type', '');//订单类型
  57. $order_type = input('order_type', 'all');//营销类型
  58. $is_verify = input('is_verify', 'all');
  59. $cashier_order_type = input('cashier_order_type', 'all');
  60. $store_id = input('store_id', '');
  61. $field = 'a.*,s.store_name';
  62. $cashier_order_type_list = $order_model->cashier_order_type;
  63. $order_common_model = new OrderCommonModel();
  64. if (request()->isAjax()) {
  65. $page_index = input('page', 1);
  66. $page_size = input('page_size', PAGE_LIST_ROWS);
  67. $alias = 'a';
  68. $join = null;
  69. $condition = [
  70. [ 'a.site_id', '=', $this->site_id ],
  71. [ 'a.is_delete', '=', 0 ],
  72. [ 'a.order_scene', '=', 'cashier' ],
  73. // [ 'a.pay_status', '=', 1 ]
  74. ];
  75. //订单状态
  76. if ($order_status != '') {
  77. if ($order_status == 'refunding') {
  78. $order_goods_list = $order_common_model->getOrderGoodsList([ [ 'refund_status', 'not in', [ 0, 3 ] ] ], 'order_id')[ 'data' ];
  79. $order_id_arr = array_unique(array_column($order_goods_list, 'order_id'));
  80. $condition[] = [ 'a.order_id', 'in', $order_id_arr ];
  81. } else {
  82. $condition[] = [ 'a.order_status', '=', $order_status ];
  83. }
  84. }
  85. $order = 'a.create_time desc';
  86. $join[] = [
  87. 'store s',
  88. 's.store_id = a.store_id',
  89. 'left'
  90. ];
  91. if ($is_verify != 'all') {
  92. $join[] = [
  93. 'verify v',
  94. 'v.verify_code = a.virtual_code',
  95. 'left'
  96. ];
  97. $condition[] = [ 'v.is_verify', '=', $is_verify ];
  98. }
  99. if ($store_id != '') {
  100. $condition[] = [ 'a.store_id', '=', $store_id ];
  101. }
  102. //订单内容 模糊查询
  103. if ($order_name != '') {
  104. $condition[] = [ 'a.order_name', 'like', '%' . $order_name . '%' ];
  105. }
  106. //订单来源
  107. if ($order_from != '') {
  108. $condition[] = [ 'a.order_from', '=', $order_from ];
  109. }
  110. //订单支付
  111. if ($pay_type != '') {
  112. $condition[] = [ 'a.pay_type', '=', $pay_type ];
  113. }
  114. //订单类型
  115. if ($order_type != 'all') {
  116. $condition[] = [ 'a.order_type', '=', $order_type ];
  117. }
  118. if ($cashier_order_type != 'all') {
  119. $condition[] = [ 'a.cashier_order_type', '=', $cashier_order_type ];
  120. }
  121. //营销类型
  122. if ($promotion_type != '') {
  123. if ($promotion_type == 'empty') {
  124. $condition[] = [ 'a.promotion_type', '=', '' ];
  125. } else {
  126. $condition[] = [ 'a.promotion_type', '=', $promotion_type ];
  127. }
  128. }
  129. if (!empty($start_time) && empty($end_time)) {
  130. $condition[] = [ 'a.create_time', '>=', date_to_time($start_time) ];
  131. } elseif (empty($start_time) && !empty($end_time)) {
  132. $condition[] = [ 'a.create_time', '<=', date_to_time($end_time) ];
  133. } elseif (!empty($start_time) && !empty($end_time)) {
  134. $condition[] = [ 'a.create_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  135. }
  136. if (!empty($delivery_start_time) && empty($delivery_end_time)) {
  137. $condition[] = [ 'a.buyer_ask_delivery_time', '>=', date_to_time($delivery_start_time) ];
  138. } elseif (empty($delivery_start_time) && !empty($delivery_end_time)) {
  139. $condition[] = [ 'a.buyer_ask_delivery_time', '<=', date_to_time($delivery_end_time) ];
  140. } elseif (!empty($delivery_start_time) && !empty($delivery_end_time)) {
  141. $condition[] = [ 'a.buyer_ask_delivery_time', 'between', [ date_to_time($delivery_start_time), date_to_time($delivery_end_time) ] ];
  142. }
  143. if ($search_text != '') {
  144. switch ( $order_label ) {
  145. case 'nick_name':
  146. $join[] = [
  147. 'member m',
  148. 'm.member_id = a.member_id',
  149. 'left'
  150. ];
  151. $condition[] = [ 'm.nickname', 'like', '%' . $search_text . '%' ];
  152. break;
  153. case 'sku_no':
  154. $order_goods_list = $order_common_model->getOrderGoodsList([ [ 'sku_no', 'like', '%' . $search_text . '%' ] ], 'order_id')[ 'data' ];
  155. $order_id_arr = array_unique(array_column($order_goods_list, 'order_id'));
  156. $condition[] = [ 'a.order_id', 'in', $order_id_arr ];
  157. break;
  158. default:
  159. $condition[] = [ 'a.' . $order_label, 'like', '%' . $search_text . '%' ];
  160. }
  161. }
  162. $store_id_arr = [];
  163. $userGroupModel = new UserGroup();
  164. $userInfo = $this->user_info;
  165. $userGroupWhere['uid'] = $userInfo['uid'];
  166. $userGroupList = $userGroupModel->getUserList($userGroupWhere,'uid,store_id');
  167. $store_id_arr = array_column($userGroupList['data'],'store_id');
  168. if(!empty($store_id_arr) && !$userInfo['is_admin']){
  169. $condition[] = [ "a.store_id", "in", $store_id_arr];
  170. }
  171. $list = $order_common_model->getOrderPageList($condition, $page_index, $page_size, $order, $field, $alias, $join);
  172. if (!empty($list[ 'data' ][ 'list' ])) {
  173. foreach ($list[ 'data' ][ 'list' ] as $k => $v) {
  174. $list[ 'data' ][ 'list' ][ $k ][ 'cashier_order_type_name' ] = $cashier_order_type_list[ $v[ 'cashier_order_type' ] ];
  175. }
  176. }
  177. $list[ 'data' ][ 'order_status' ] = $order_status;
  178. return $list;
  179. } else {
  180. $order_type_list = $order_common_model->getOrderTypeStatusList();
  181. $this->assign('order_type_list', $order_type_list);
  182. $this->assign('order_label_list', $order_label_list);
  183. $this->assign('order_status_list', $order_type_list[ 1 ][ 'status' ]);//订单状态
  184. //订单来源 (支持端口)
  185. $this->assign('order_from_list', $order_common_model->getOrderFromList());
  186. $pay_type = $order_common_model->getPayType([ 'order_type' => 5 ]);
  187. $this->assign('pay_type_list', $pay_type);
  188. $this->assign('order_status', $order_status);
  189. $this->assign('cashier_order_type_list', $cashier_order_type_list);
  190. $this->assign('http_type', get_http_type());
  191. $config_model = new ConfigModel();
  192. $order_config = $config_model->getOrderEventTimeConfig($this->site_id, $this->app_module)[ 'data' ][ 'value' ] ?? [];
  193. $this->assign('order_config', $order_config);
  194. $config_model = new WebConfig();
  195. $mp_config = $config_model->getMapConfig($this->site_id);
  196. $this->assign('tencent_map_key', $mp_config[ 'data' ][ 'value' ][ 'tencent_map_key' ]);
  197. $store_list = ( new Store() )->getStoreList([ [ 'site_id', '=', $this->site_id ] ], 'store_name,store_id')[ 'data' ];
  198. $this->assign('store_list', $store_list);
  199. return $this->fetch('order/lists', [], $this->replace);
  200. }
  201. }
  202. /**
  203. * 快递订单详情
  204. */
  205. public function detail()
  206. {
  207. $order_id = input('order_id', 0);
  208. $order_common_model = new OrderCommonModel();
  209. $order_detail_result = $order_common_model->getOrderDetail($order_id);
  210. $order_detail = $order_detail_result[ 'data' ];
  211. if (empty($order_detail)) $this->error('未获取到订单数据', addon_url('shop/order/lists'));
  212. $this->assign('order_detail', $order_detail);
  213. $this->assign('http_type', get_http_type());
  214. $config_model = new WebConfig();
  215. $mp_config = $config_model->getMapConfig($this->site_id);
  216. $this->assign('tencent_map_key', $mp_config[ 'data' ][ 'value' ][ 'tencent_map_key' ]);
  217. return $this->fetch('order/detail');
  218. }
  219. }