OrderListForm.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. <?php
  2. /**
  3. * 重庆赤晓店信息科技有限公司
  4. * https://www.chixiaodian.com
  5. * Copyright (c) 2023 赤店商城 All rights reserved.
  6. */
  7. namespace app\modules\client\models\v1\admin;
  8. use app\constants\OptionSetting;
  9. use app\models\common\admin\order\CommonOrderSearch;
  10. use app\models\Express;
  11. use app\models\Option;
  12. use app\models\Order;
  13. use app\models\OrderDetail;
  14. use app\models\OrderRefund;
  15. use app\models\Shop;
  16. use app\models\User;
  17. use yii\base\Model;
  18. use yii\db\Query;
  19. use yii\helpers\Json;
  20. class OrderListForm extends Model
  21. {
  22. public $store_id;
  23. public $user_id;
  24. public $keyword;
  25. public $status;
  26. public $limit;
  27. public $is_offline;
  28. public $clerk_id;
  29. public $parent_id;
  30. public $shop_id;
  31. public $dateStart;
  32. public $dateEnd;
  33. public $express_type;
  34. public $keywordType;
  35. public $fields;
  36. public $type;
  37. public $mch_id;
  38. public $flag; // 是否导出
  39. /**
  40. * @var 所属平台
  41. */
  42. public $platform;//所属平台
  43. /**
  44. * @var 获取默写城市的订单 例如:["\u5357\u5b81","\u4e0a\u6d77"]
  45. */
  46. public $shop_list;
  47. public $order_id;
  48. public function rules()
  49. {
  50. return [
  51. [['keyword', 'flag'], 'trim'],
  52. [['status', 'limit', 'user_id', 'is_offline', 'clerk_id', 'shop_id', 'keywordType', 'platform'], 'integer'],
  53. [['status',], 'default', 'value' => -1],
  54. [['dateStart', 'dateEnd', 'express_type'], 'trim'],
  55. [['fields', 'shop_list'], 'safe']
  56. ];
  57. }
  58. public function search()
  59. {
  60. if (!$this->validate()) {
  61. return [
  62. 'code' => 1,
  63. 'msg' => $this->getErrorSummary(false)[0],
  64. ];
  65. }
  66. $query = Order::find()->alias('o')->where([
  67. 'o.store_id' => $this->store_id
  68. ]);
  69. $query->andWhere(['o.mch_id' => 0]);
  70. $query->leftJoin(['u' => User::tableName()], 'u.id = o.user_id')
  71. ->leftJoin(['od' => OrderDetail::tableName()], 'od.order_id=o.id');
  72. switch ($this->status) {
  73. case 0:
  74. $query->andWhere(['o.is_delete' => Order::IS_DELETE_FALSE, 'is_pay' => Order::IS_PAY_FALSE]);
  75. break;
  76. case 1:
  77. $query->andWhere([
  78. 'o.trade_status' => Order::ORDER_FLOW_NO_SEND,
  79. 'o.is_delete' => Order::IS_DELETE_FALSE
  80. ])->andWhere(['or', ['o.is_pay' => Order::IS_PAY_TRUE], ['o.pay_type' => Order::PAY_TYPE_COD]]);
  81. break;
  82. case 2:
  83. $query->andWhere([
  84. 'o.trade_status' => Order::ORDER_FLOW_SEND,
  85. 'o.is_delete' => Order::IS_DELETE_FALSE
  86. ])->andWhere(['or', ['o.is_pay' => Order::IS_PAY_TRUE], ['o.pay_type' => Order::PAY_TYPE_COD]]);
  87. break;
  88. case 3:
  89. $query->andWhere([
  90. 'o.trade_status' => Order::ORDER_FLOW_CONFIRM,
  91. 'o.is_delete' => Order::IS_DELETE_FALSE
  92. ])->andWhere(['or', ['o.is_pay' => Order::IS_PAY_TRUE], ['o.pay_type' => Order::PAY_TYPE_COD]]);
  93. break;
  94. case 4:
  95. break;
  96. case 5:
  97. $query->andWhere(['or', ['o.trade_status' => Order::ORDER_FLOW_CANCEL],
  98. ['o.is_delete' => Order::IS_DELETE_TRUE]]);
  99. break;
  100. case 6:
  101. $query->andWhere(['and',['o.apply_delete' => Order::ORDER_APPLY_DELETE], ['!=', 'o.trade_status', Order::ORDER_FLOW_CANCEL]]);
  102. break;
  103. default:
  104. if (empty($this->order_id)) {
  105. $query->andWhere([
  106. 'o.is_delete' => Order::IS_DELETE_FALSE
  107. ]);
  108. }
  109. break;
  110. }
  111. if (get_params('is_recycle')) {
  112. $query->andWhere([
  113. 'o.is_recycle' => Order::IS_DELETE_TRUE
  114. ]);
  115. } else {
  116. $query->andWhere([
  117. 'o.is_recycle' => Order::IS_DELETE_FALSE
  118. ]);
  119. }
  120. if ($this->order_id && $this->order_id > 0) {
  121. $query->andWhere(['o.id' => $this->order_id]);
  122. }
  123. // TODO:
  124. $commonOrderSearch = new CommonOrderSearch();
  125. $query = $commonOrderSearch->search($query, $this);
  126. $query = $commonOrderSearch->keyword($query, $this->keywordType, $this->keyword);
  127. if(!empty($this->shop_list)){
  128. $orWhere = ['or'];
  129. foreach ($this->shop_list as $val){
  130. $orWhere[] = ['like', 'o.address_data', "\"city\":\"{$val}"];
  131. }
  132. $query->andWhere($orWhere);
  133. unset($orWhere);
  134. }
  135. if ($this->platform !== null && $this->platform !== '') {
  136. $query->andWhere([
  137. 'u.platform' => $this->platform
  138. ]);
  139. }
  140. $refundQuery1 = OrderRefund::find()->alias('or')
  141. ->select('or.status, or.order_id, or.created_at')
  142. ->where(['or.store_id' => $this->store_id, 'or.is_delete' => 0]);
  143. $refundQuery = (new Query())->from(['or' => $refundQuery1])->where('`or`.order_id=o.id')
  144. ->select('or.status')
  145. ->orderBy(['or.created_at' => SORT_DESC])
  146. ->limit(1);
  147. $query->orderBy('o.created_at DESC')
  148. ->select(['o.*', 'u.nickname','u.nickname as de_name', 'u.platform',
  149. 'refund' => $refundQuery]);
  150. $pagination = pagination_make($query);
  151. $listArray = $pagination['list'];
  152. foreach ($listArray as $i => &$item) {
  153. $item['created_at'] = date('m/d H:i', $item['created_at']);
  154. $item['goods_list'] = $this->getOrderGoodsList($item['id']);
  155. $item['goods_num'] = 0;
  156. foreach($item['goods_list'] as $goods_num) {
  157. $item['goods_num'] += $goods_num['num'];
  158. }
  159. $item['clerk_name'] = User::findOne(Shop::findOne($item['shop_id'])->user_id)->nickname;
  160. if ($item['shop_id'] && $item['shop_id'] != 0) {
  161. $shop = Shop::find()->where(['store_id' => $this->store_id, 'id' => $item['shop_id']])->asArray()->one();
  162. $item['shop'] = $shop;
  163. }
  164. $item['integral'] = json_decode($item['integral'], true);
  165. if (isset($item['address_data'])) {
  166. $item['address_data'] = json_decode($item['address_data']);
  167. }
  168. $item['flag'] = 0;
  169. }
  170. return [
  171. 'code' => 0,
  172. 'msg' => 'success',
  173. 'data' => [
  174. 'data' => $listArray,
  175. 'pageNo' => $pagination['pageNo'],
  176. 'totalCount' => $pagination['totalCount'],
  177. ],
  178. ];
  179. }
  180. public function getOrderGoodsList($order_id)
  181. {
  182. $orderDetailList = OrderDetail::find()->alias('od')
  183. ->where([
  184. 'od.is_delete' => 0,
  185. 'od.order_id' => $order_id,
  186. ])->select(['od.num', 'od.total_price', 'od.attr', 'od.is_level', 'od.batch_price_tips', 'name' => 'od.goods_name','od.pic', 'od.goods_info'])->asArray()->all();
  187. foreach ($orderDetailList as &$item) {
  188. $item['attr_list'] = json_decode($item['attr'], true);
  189. $item['unit'] = Json::decode($item['goods_info'])['unit'];
  190. }
  191. return $orderDetailList;
  192. }
  193. /**
  194. * @return array
  195. */
  196. private function getExpressList()
  197. {
  198. $storeExpressList = Order::find()
  199. ->select('express')
  200. ->where([
  201. 'AND',
  202. ['store_id' => $this->store_id],
  203. ['is_pay' => Order::IS_PAY_TRUE],
  204. ['in', 'trade_status', [Order::ORDER_FLOW_SEND, Order::ORDER_FLOW_CONFIRM]],
  205. ['!=', 'express', ''],
  206. ])->groupBy('express')->orderBy('send_time DESC')->limit(5)->asArray()->all();
  207. $expressLst = Express::getExpressList();
  208. $newStoreExpressList = [];
  209. foreach ($storeExpressList as $i => $item) {
  210. foreach ($expressLst as $value) {
  211. if ($value['name'] == $item['express']) {
  212. $newStoreExpressList[] = $item['express'];
  213. break;
  214. }
  215. }
  216. }
  217. $newPublicExpressList = [];
  218. foreach ($expressLst as $i => $item) {
  219. $newPublicExpressList[] = $item['name'];
  220. }
  221. return array_merge($newStoreExpressList, $newPublicExpressList);
  222. }
  223. public function getEdit($order_id)
  224. {
  225. $order = Order::findOne([
  226. 'store_id' => $this->store_id,
  227. 'id' => $order_id
  228. ]);
  229. if (!$order) {
  230. return [
  231. 'code' => 1,
  232. 'msg' => '订单不存在',
  233. ];
  234. }
  235. $status = "";
  236. if ($order->is_pay == 0) {
  237. $status = '订单未付款';
  238. } elseif ($order->is_pay == 1 && $order->trade_status == Order::ORDER_FLOW_NO_SEND) {
  239. $status = '订单待发货';
  240. } elseif ($order->trade_status == Order::ORDER_FLOW_SEND) {
  241. $status = '订单已发货';
  242. } elseif ($order->trade_status == Order::ORDER_FLOW_CONFIRM) {
  243. $status = '订单已完成';
  244. }
  245. $goods_list = OrderDetail::find()->alias('od')
  246. ->where(['od.order_id' => $order->id, 'od.is_delete' => 0])->all();
  247. $num = 0;
  248. foreach ($goods_list as $i => $item) {
  249. $goods = Json::decode($item['goods_info']);
  250. $newItem = [];
  251. $newItem['goods_id'] = $item['goods_id'];
  252. $newItem['order_detail_id'] = $item['id'];
  253. $newItem['name'] = $item['goods_name'] ?: $goods['name'];
  254. $newItem['total_price'] = $item['total_price'];
  255. $newItem['num'] = $item['num'];
  256. $newItem['attr'] = json_decode($item['attr']);
  257. $num += intval($item['num']);
  258. $newItem['goods_pic'] = $item['pic'] ?: $goods['cover_pic'];
  259. $order_refund = OrderRefund::findOne([
  260. 'order_detail_id' => $item['id'],
  261. 'is_delete' => 0,
  262. ]);
  263. if ($order_refund) {
  264. $newItem['is_order_refund'] = 1;
  265. } else {
  266. $newItem['is_order_refund'] = 0;
  267. }
  268. if ($order->is_pay == 1 && $order->trade_status == Order::ORDER_FLOW_SEND) {
  269. $newItem['order_refund_enable'] = 1;
  270. } else {
  271. $newItem['order_refund_enable'] = 0;
  272. }
  273. if($item['is_level'] == 1 && ($order->discount && $order->discount < 10)){
  274. $newItem['is_level'] = 1;
  275. }
  276. $newList[] = $newItem;
  277. }
  278. $shop = null;
  279. if ($order->shop_id) {
  280. $shop = Shop::find()->select(['name', 'mobile', 'address', 'longitude', 'latitude'])->where(['store_id' => $this->store_id, 'id' => $order->shop_id])->asArray()->one();
  281. }
  282. if ($order->before_update_price) {
  283. if ($order->before_update_price < $order->pay_price) {
  284. $before_update = "加价";
  285. $money = $order->pay_price - $order->before_update_price;
  286. } else {
  287. $before_update = "优惠";
  288. $money = $order->before_update_price - $order->pay_price;
  289. }
  290. } else {
  291. $before_update = "";
  292. $money = "";
  293. }
  294. if(!$order->integral){
  295. $order->integral = 0;
  296. }
  297. return [
  298. 'code' => 0,
  299. 'msg' => 'success',
  300. 'data' => [
  301. 'express_list' => $this-> getExpressList(),
  302. 'order' => [
  303. 'order_id' => $order->id,
  304. 'is_pay' => $order->is_pay,
  305. 'status' => $status,
  306. 'express' => $order->express,
  307. 'express_no' => $order->express_no,
  308. 'name' => $order->name,
  309. 'mobile' => $order->mobile,
  310. 'address' => $order->address,
  311. 'order_no' => $order->order_no,
  312. 'addtime' => date('Y-m-d H:i', $order->created_at),
  313. 'total_price' => doubleval(sprintf('%.2f', $order->total_price)),
  314. 'express_price' => doubleval(sprintf('%.2f', $order->express_price)),
  315. 'goods_total_price' => doubleval(sprintf('%.2f', doubleval($order->total_price) - doubleval($order->express_price))),
  316. 'coupon_sub_price' => isset($order->coupon_sub_price) ? $order->coupon_sub_price : 0,
  317. 'pay_price' => $order->pay_price,
  318. 'num' => $num,
  319. 'goods_list' => $newList,
  320. 'is_offline' => $order->is_offline,
  321. 'content' => $order->content ? $order->content : "",
  322. 'before_update' => $before_update,
  323. 'money' => $money,
  324. 'shop' => $shop,
  325. 'discount' => $order->discount,
  326. 'user_coupon_id' => $order->user_coupon_id,
  327. 'words' => $order->words,
  328. 'pay_type' => $order->pay_type,
  329. 'integral'=> json_decode($order->integral),
  330. 'type' => $order->type,
  331. 'nickname' => User::findOne($order->user_id)->nickname,
  332. 'trade_status' => $order->trade_status
  333. ]
  334. ],
  335. ];
  336. }
  337. }