OrderLogic.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeshop100%开源免费商用商城系统
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | 商业版本务必购买商业授权,以免引起法律纠纷
  8. // | 禁止对系统程序代码以任何目的,任何形式的再发布
  9. // | gitee下载:https://gitee.com/likeshop_gitee
  10. // | github下载:https://github.com/likeshop-github
  11. // | 访问官网:https://www.likeshop.cn
  12. // | 访问社区:https://home.likeshop.cn
  13. // | 访问手册:http://doc.likeshop.cn
  14. // | 微信公众号:likeshop技术社区
  15. // | likeshop团队 版权所有 拥有最终解释权
  16. // +----------------------------------------------------------------------
  17. // | author: likeshopTeam
  18. // +----------------------------------------------------------------------
  19. namespace app\openapi\logic\order;
  20. use app\adminapi\logic\distribution\DistributionLogic;
  21. use app\common\{enum\OrderLogEnum,
  22. logic\BaseLogic,
  23. model\AfterSale,
  24. model\OrderGoods,
  25. model\OrderLog,
  26. model\User,
  27. model\Order,
  28. enum\PayEnum,
  29. model\UserLevel,
  30. model\UserLabel,
  31. enum\CouponEnum,
  32. model\CouponList,
  33. enum\AccountLogEnum,
  34. model\UserLabelIndex,
  35. logic\AccountLogLogic,
  36. enum\UserTerminalEnum,
  37. service\ConfigService};
  38. use think\facade\Config;
  39. use think\facade\Db;
  40. use think\Model;
  41. /**
  42. * 订单逻辑层
  43. * Class UserLogic
  44. * @package app\adminapi\logic\user
  45. */
  46. class OrderLogic extends BaseLogic
  47. {
  48. /**
  49. * @notes 用户详情
  50. * @param $params array
  51. * @return list array
  52. * @throws \think\db\exception\DataNotFoundException
  53. * @throws \think\db\exception\DbException
  54. * @throws \think\db\exception\ModelNotFoundException
  55. * @author cjhao
  56. * @date 2021/8/18 15:52
  57. */
  58. public function getUserOrderList($params)
  59. {
  60. $where=[];
  61. $order_source = 0;
  62. if(isset($params['type'])) {
  63. if (($params['type']) == 1) {
  64. $order_source =1;
  65. $where['order_source'] = 1; //平台
  66. } else if (($params['type']) == 2) {
  67. $order_source=2;
  68. $where['order_source'] = 2; //线下
  69. }
  70. }
  71. $user_info = User::where(['mobile'=>$params['mobile']])->findOrEmpty();
  72. if($user_info->isEmpty()){
  73. return [];
  74. }
  75. $user_id = $user_info['id'];
  76. $where['user_id'] = $user_id;
  77. $pageNo = 1;
  78. if(isset($params['pageNo']) && !empty($params['pageNo'])){
  79. $pageNo = $params['pageNo']??1; //页码
  80. }
  81. if(isset($params['orderSn']) && !empty($params['orderSn'])){
  82. if($order_source == 1){
  83. $where['sn']=$params['orderSn'];
  84. }else if($order_source == 2){
  85. $where['transaction_id'] = $params['orderSn'];
  86. }else{
  87. $where['sn|transaction_id'] = $params['orderSn'];
  88. }
  89. }
  90. $pageSize = 10; //每页数量
  91. $index = (int)($pageNo-1)*$pageSize;
  92. $order_list = Order::field('id,sn,user_id,order_type,order_status,pay_status,pay_way,pay_time,address,delivery_type,
  93. goods_price,order_amount,discount_amount,member_amount,integral_amount,total_amount,total_num,express_status,confirm_take_time,
  94. create_time,order_source,order_goods')
  95. ->with('user')
  96. ->where($where)->order('id desc')->limit($index,$pageSize)->select()->toArray();
  97. foreach($order_list as &$v){
  98. if($v['order_source'] == 1){
  99. $gwhere['order_id'] = $v['id'];
  100. $order_goods = OrderGoods::field('id,goods_name,goods_snap,goods_num,goods_price,total_price,total_pay_price')->where($gwhere)->select()->toArray();
  101. $order_goods_list =$order_goods;
  102. $v['order_goods'] = $order_goods_list;
  103. }
  104. }
  105. $data['order_count'] = Order::where($where)->count();
  106. $data['order_list'] = $order_list;
  107. $data['page_index'] = $pageNo;
  108. $data['page_num'] = $pageSize;
  109. return $data;
  110. }
  111. /*
  112. *
  113. * 线下订单推送
  114. * */
  115. public function orderPush($params){
  116. outFileLog($params,'orderPush','$params');
  117. $userInfo = User::where(['mobile'=>$params['mobile']])->findOrEmpty();
  118. if($userInfo->isEmpty()){
  119. outFileLog($params,'orderPush','$params');
  120. self::setError('会员数据查询为空');
  121. return false;
  122. }
  123. $order_info = Order::where(['sn'=> $params['orderSn']])->findOrEmpty();
  124. if(!$order_info->isEmpty()){
  125. outFileLog($params,'orderPush','$params');
  126. self::setError('该订单号已存在');
  127. return false;
  128. }
  129. // if($params['pay_way'] == 1) {
  130. // if ($params['order_amount'] > $userInfo['user_money']) {
  131. // outFileLog($params, 'orderPush', '金额不足');
  132. // self::setError('线上会员金额不足以抵扣');
  133. // return false;
  134. // }
  135. // }
  136. $goods_price = 0;
  137. if(isset($params['goods_price']) && !empty($params['goods_price'])){
  138. $goods_price = $params['goods_price'];
  139. }
  140. $order_amount = 0;
  141. if(isset($params['order_amount']) && !empty($params['order_amount'])){
  142. $order_amount = $params['order_amount'];
  143. }
  144. $discount_amount = 0;
  145. // if(isset($params['discount_amount']) && !empty($params['discount_amount'])){
  146. // $discount_amount = $params['discount_amount'];
  147. // }
  148. $member_amount = 0;
  149. if(isset($params['member_amount']) && !empty($params['member_amount'])){
  150. $member_amount = $params['member_amount'];
  151. }
  152. $integral_amount = 0;
  153. // if(isset($params['integral_amount']) && !empty($params['integral_amount'])){
  154. // $integral_amount = $params['integral_amount'];
  155. // }
  156. $total_amount = 0;
  157. if(isset($params['total_amount']) && !empty($params['total_amount'])){
  158. $total_amount = $params['total_amount'];
  159. }
  160. $total_num = 0;
  161. if(isset($params['total_num']) && !empty($params['total_num'])){
  162. $total_num = $params['total_num'];
  163. }
  164. $create_time = time();
  165. if(isset($params['create_time']) && !empty($params['create_time'])){
  166. $create_time = $params['create_time'];
  167. }
  168. $user_id = $userInfo['id'];
  169. $saveData['sn'] = $params['orderSn'];
  170. $saveData['transaction_id'] = $params['orderSn'];
  171. $saveData['user_id'] = $user_id;
  172. $saveData['order_type'] = 1;
  173. // $saveData['pay_way'] =$params['pay_way'];
  174. $saveData['order_terminal'] = 7;
  175. $saveData['order_status'] = 0;
  176. $saveData['pay_status'] = 0;
  177. // $saveData['pay_time'] = $params['create_time'];
  178. $saveData['delivery_type'] = 2;
  179. $saveData['goods_price'] = $goods_price;
  180. $saveData['order_amount'] = $order_amount;
  181. $saveData['discount_amount'] = $discount_amount;
  182. $saveData['member_amount'] = $member_amount;
  183. $saveData['integral_amount'] = $integral_amount;
  184. $saveData['total_amount'] = $total_amount;
  185. $saveData['total_num'] = $total_num;
  186. $saveData['express_status'] = 1;
  187. // $saveData['express_time'] =$params['create_time'];
  188. // $saveData['confirm_take_time'] = $params['create_time'];
  189. $saveData['create_time'] = $create_time;
  190. $saveData['order_source'] = 2;
  191. $saveData['order_goods'] = $params['order_goods'];
  192. $ret = Order::create($saveData);
  193. if($ret) {
  194. // if ($params['pay_way'] == 1) {
  195. // //减少金额
  196. // $userInfo->user_money = $userInfo->user_money - $order_amount;
  197. // $userInfo->save();
  198. //
  199. // //记录用户金额变动记录
  200. // //记录日志
  201. // AccountLogLogic::add($userInfo->id, AccountLogEnum::BNW_DEC_ORDER, AccountLogEnum::DEC, $order_amount, $params['orderSn'], '线下收银台销售扣减用户金额');
  202. // }
  203. (new OrderLog())->record([
  204. 'type' => OrderLogEnum::TYPE_SYSTEM,
  205. 'channel' => OrderLogEnum::USER_ADD_ORDER,
  206. 'order_id' => $ret['id'],
  207. 'content'=>'收银台推送订单',
  208. ]);
  209. }
  210. return true;
  211. }
  212. /*
  213. *
  214. * 订单结算
  215. * */
  216. public function orderPay($params)
  217. {
  218. outFileLog($params, 'orderPay', '$params');
  219. $userInfo = User::where(['mobile' => $params['mobile']])->findOrEmpty();
  220. if ($userInfo->isEmpty()) {
  221. outFileLog($params, 'orderPay', '$params');
  222. self::setError('会员数据查询为空');
  223. return false;
  224. }
  225. $order_info = Order::where(['sn' => $params['orderSn']])->findOrEmpty();
  226. if ($order_info->isEmpty()) {
  227. outFileLog($params, 'orderPay', '订单号查询失败:');
  228. self::setError('订单号查询订单信息失败');
  229. return false;
  230. }
  231. if($order_info['order_status'] == 3){
  232. outFileLog($params, 'orderPay', '订单已支付完成');
  233. self::setError('订单已支付完成');
  234. return false;
  235. }
  236. $pay_money = round($order_info['offline_pay_money'] + $order_info['offline_pay_user_money'] + $params['pay_money'],2) ;
  237. if($pay_money>$order_info['order_amount']){
  238. outFileLog($params, 'orderPay', '金额超了应付金额');
  239. outFileLog($pay_money, 'orderPay', '金额超了应付金额-$pay_money');
  240. outFileLog($order_info['order_amount'], 'orderPay', '金额超了应付金额-order_amount');
  241. self::setError('订单支付金额错误,总支付金额大于应付金额');
  242. return false;
  243. }
  244. if ($params['pay_way'] == 1) {
  245. if ($params['pay_money'] > $userInfo['user_money']) {
  246. outFileLog($params, 'orderPay', '会员卡金额不足');
  247. self::setError('线上会员金额不足以支付');
  248. return false;
  249. }
  250. }
  251. $create_time = time();
  252. if(isset($params['create_time']) && !empty($params['create_time'])){
  253. $create_time = $params['create_time'];
  254. }
  255. if ($params['pay_way'] == 1) {
  256. $order_info->offline_pay_user_money = $params['pay_money'];
  257. $order_info->pay_way = 1;
  258. $order_info->pay_time = $create_time;
  259. $order_info->save();
  260. //减少金额
  261. $userInfo->user_money = $userInfo->user_money - $params['pay_money'];
  262. $userInfo->save();
  263. //记录用户金额变动记录
  264. //记录日志
  265. AccountLogLogic::add($userInfo->id, AccountLogEnum::BNW_DEC_ORDER, AccountLogEnum::DEC, $params['pay_money'], $params['orderSn'], '线下收银台销售扣减用户金额');
  266. $content = '收银台会员卡支付金额'.$params['pay_money'];
  267. }else{
  268. if(empty($order_info['pay_way'])){
  269. $order_info->pay_way = 5;
  270. $order_info->pay_time = $create_time;
  271. }
  272. $order_info->offline_pay_money = $order_info->offline_pay_money + $params['pay_money'];
  273. $order_info->save();
  274. $content = '收银台现金或移动支付金额'.$params['pay_money'];
  275. }
  276. (new OrderLog())->record([
  277. 'type' => OrderLogEnum::TYPE_SYSTEM,
  278. 'channel' => OrderLogEnum::USER_PAID_ORDER,
  279. 'order_id' => $order_info['id'],
  280. 'content'=>$content,
  281. ]);
  282. if($params['is_pay_end'] == 1){
  283. $order_info->order_status = 3;
  284. $order_info->save();
  285. }
  286. return true;
  287. }
  288. /*
  289. * 新增会员信息
  290. * */
  291. public function orderRefundMoney(array $params):bool{
  292. try {
  293. $mobile = $params['mobile'];
  294. $where['mobile'] = $mobile;
  295. $user_info = User::where($where)->findOrEmpty();
  296. if($user_info->isEmpty()){
  297. outFileLog($params,'orderRefundMoney','会员信息有无');
  298. self::setError('传入的会员信息有误,不存在,请同步');
  299. return false;
  300. }
  301. $refund_money = $params['refund_money'];
  302. if(isset($params['orderSn']) && !empty($params['orderSn'])) {
  303. $order_info = Order::where(['sn' => $params['orderSn']])->findOrEmpty();
  304. if ($order_info->isEmpty()) {
  305. outFileLog($params, 'orderRefundMoney', '传入订单信息有误');
  306. self::setError('传入订单信息有误');
  307. return false;
  308. }
  309. if($order_info['order_amount']<$refund_money || $order_info['order_amount']< round($refund_money+$order_info['offline_refund_money'],2)){
  310. outFileLog($params, 'orderRefundMoney', '传入退款金额有误');
  311. self::setError('传入退款金额有误或总退款金额超出支付金额');
  312. return false;
  313. }
  314. $afersaleInfo = AfterSale::where(['order_id'=>$order_info['id']])->findOrEmpty();
  315. if(!$afersaleInfo->isEmpty()){
  316. outFileLog($params, 'orderRefundMoney', '已申请售后');
  317. self::setError('该订单号已经售后');
  318. return false;
  319. }
  320. //插入售后表
  321. $afterSale = AfterSale::create([
  322. 'sn' => generate_sn((new AfterSale()), 'sn'),
  323. 'user_id' => $order_info['user_id'],
  324. 'order_id' => $order_info['id'],
  325. 'order_goods_id' => 0,
  326. 'refund_reason' => '线下收银退款-'.$params['remark'],
  327. 'refund_remark' => '收银台系统发起退款',
  328. 'refund_type' => 2,
  329. 'refund_method' => 1,
  330. 'refund_total_amount' =>$refund_money,
  331. 'refund_way' => 1,
  332. 'refund_status' => 3,
  333. 'status' => 2,
  334. 'sub_status' => 21,
  335. ]);
  336. if ($params['is_return_user_money'] == 0) {
  337. $order_info->offline_refund_money = $order_info->offline_refund_money + $refund_money;
  338. $order_info->save();
  339. return true;
  340. } else {
  341. $order_info->offline_refund_money = $order_info->offline_refund_money +$refund_money;
  342. $order_info->save();
  343. $user_info->user_money = $user_info->user_money + $refund_money;
  344. $user_info->save();
  345. //记录用户金额变动记录
  346. //记录日志
  347. AccountLogLogic::add($user_info->id, AccountLogEnum::BNW_INC_CANCEL_ORDER, AccountLogEnum::INC, $refund_money, $params['orderSn'], '线下收银台退款增加用户金额');
  348. return true;
  349. }
  350. }
  351. outFileLog($params,'orderRefundMoney','传入的订单编号有误');
  352. self::setError('传入的订单编号有误');
  353. return false;
  354. }catch(\Exception $e) {
  355. Db::rollback();
  356. self::setError($e->getMessage());
  357. return false;
  358. }
  359. }
  360. }