Order_bak.php 9.9 KB

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