OrderLogic.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  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\{logic\BaseLogic,
  22. model\AfterSale,
  23. model\OrderGoods,
  24. model\User,
  25. model\Order,
  26. enum\PayEnum,
  27. model\UserLevel,
  28. model\UserLabel,
  29. enum\CouponEnum,
  30. model\CouponList,
  31. enum\AccountLogEnum,
  32. model\UserLabelIndex,
  33. logic\AccountLogLogic,
  34. enum\UserTerminalEnum,
  35. service\ConfigService};
  36. use think\facade\Config;
  37. use think\facade\Db;
  38. use think\Model;
  39. /**
  40. * 订单逻辑层
  41. * Class UserLogic
  42. * @package app\adminapi\logic\user
  43. */
  44. class OrderLogic extends BaseLogic
  45. {
  46. /**
  47. * @notes 用户详情
  48. * @param $params array
  49. * @return list array
  50. * @throws \think\db\exception\DataNotFoundException
  51. * @throws \think\db\exception\DbException
  52. * @throws \think\db\exception\ModelNotFoundException
  53. * @author cjhao
  54. * @date 2021/8/18 15:52
  55. */
  56. public function getUserOrderList($params)
  57. {
  58. $where=[];
  59. $order_source = 0;
  60. if(isset($params['type'])) {
  61. if (($params['type']) == 1) {
  62. $order_source =1;
  63. $where['order_source'] = 1; //平台
  64. } else if (($params['type']) == 2) {
  65. $order_source=2;
  66. $where['order_source'] = 2; //线下
  67. }
  68. }
  69. $user_info = User::where(['mobile'=>$params['mobile']])->findOrEmpty();
  70. if($user_info->isEmpty()){
  71. return [];
  72. }
  73. $user_id = $user_info['id'];
  74. $where['user_id'] = $user_id;
  75. $pageNo = 1;
  76. if(isset($params['pageNo']) && !empty($params['pageNo'])){
  77. $pageNo = $params['pageNo']??1; //页码
  78. }
  79. if(isset($params['orderSn']) && !empty($params['orderSn'])){
  80. if($order_source == 1){
  81. $where['sn']=$params['orderSn'];
  82. }else if($order_source == 2){
  83. $where['transaction_id'] = $params['orderSn'];
  84. }else{
  85. $where['sn|transaction_id'] = $params['orderSn'];
  86. }
  87. }
  88. $pageSize = 10; //每页数量
  89. $index = (int)($pageNo-1)*$pageSize;
  90. $order_list = Order::field('id,sn,user_id,order_type,order_status,pay_status,pay_way,pay_time,address,delivery_type,
  91. goods_price,order_amount,discount_amount,member_amount,integral_amount,total_amount,total_num,express_status,confirm_take_time,
  92. create_time,order_source,order_goods')
  93. ->with('user')
  94. ->where($where)->order('id desc')->limit($index,$pageSize)->select()->toArray();
  95. foreach($order_list as &$v){
  96. if($v['order_source'] == 1){
  97. $gwhere['order_id'] = $v['id'];
  98. $order_goods = OrderGoods::field('id,goods_name,goods_snap,goods_num,goods_price,total_price,total_pay_price')->where($gwhere)->select()->toArray();
  99. $order_goods_list =$order_goods;
  100. $v['order_goods'] = $order_goods_list;
  101. }
  102. }
  103. $data['order_count'] = Order::where($where)->count();
  104. $data['order_list'] = $order_list;
  105. $data['page_index'] = $pageNo;
  106. $data['page_num'] = $pageSize;
  107. return $data;
  108. }
  109. /*
  110. *
  111. * 线下订单推送
  112. * */
  113. public function orderPush($params){
  114. $userInfo = User::where(['mobile'=>$params['mobile']])->findOrEmpty();
  115. if($userInfo->isEmpty()){
  116. outFileLog($params,'orderPush','$params');
  117. self::setError('会员数据查询为空');
  118. return false;
  119. }
  120. $order_info = Order::where(['sn'=> $params['orderSn']])->findOrEmpty();
  121. if(!$order_info->isEmpty()){
  122. outFileLog($params,'orderPush','$params');
  123. self::setError('该订单号已存在');
  124. return false;
  125. }
  126. if($params['pay_way'] == 1) {
  127. if ($params['order_amount'] > $userInfo['user_money']) {
  128. outFileLog($params, 'orderPush', '金额不足');
  129. self::setError('线上会员金额不足以抵扣');
  130. return false;
  131. }
  132. }
  133. $goods_price = 0;
  134. if(isset($params['goods_price']) && !empty($params['goods_price'])){
  135. $goods_price = $params['goods_price'];
  136. }
  137. $order_amount = 0;
  138. if(isset($params['order_amount']) && !empty($params['order_amount'])){
  139. $order_amount = $params['order_amount'];
  140. }
  141. $discount_amount = 0;
  142. if(isset($params['discount_amount']) && !empty($params['discount_amount'])){
  143. $discount_amount = $params['discount_amount'];
  144. }
  145. $member_amount = 0;
  146. if(isset($params['member_amount']) && !empty($params['member_amount'])){
  147. $member_amount = $params['member_amount'];
  148. }
  149. $integral_amount = 0;
  150. if(isset($params['integral_amount']) && !empty($params['integral_amount'])){
  151. $integral_amount = $params['integral_amount'];
  152. }
  153. $total_amount = 0;
  154. if(isset($params['total_amount']) && !empty($params['total_amount'])){
  155. $total_amount = $params['total_amount'];
  156. }
  157. $total_num = 0;
  158. if(isset($params['total_num']) && !empty($params['total_num'])){
  159. $total_num = $params['total_num'];
  160. }
  161. $user_id = $userInfo['id'];
  162. $saveData['sn'] = $params['orderSn'];
  163. $saveData['transaction_id'] = $params['orderSn'];
  164. $saveData['user_id'] = $user_id;
  165. $saveData['order_type'] = 1;
  166. $saveData['pay_way'] =$params['pay_way'];
  167. $saveData['order_terminal'] = 7;
  168. $saveData['order_status'] = 3;
  169. $saveData['pay_status'] = 1;
  170. $saveData['pay_time'] = $params['create_time'];
  171. $saveData['delivery_type'] = 2;
  172. $saveData['goods_price'] = $goods_price;
  173. $saveData['order_amount'] = $order_amount;
  174. $saveData['discount_amount'] = $discount_amount;
  175. $saveData['member_amount'] = $member_amount;
  176. $saveData['integral_amount'] = $integral_amount;
  177. $saveData['total_amount'] = $total_amount;
  178. $saveData['total_num'] = $total_num;
  179. $saveData['express_status'] = 1;
  180. $saveData['express_time'] =$params['create_time'];
  181. $saveData['confirm_take_time'] = $params['create_time'];
  182. $saveData['create_time'] = $params['create_time'];
  183. $saveData['order_source'] = 2;
  184. $saveData['order_goods'] = $params['order_goods'];
  185. $ret = Order::create($saveData);
  186. if($ret) {
  187. if ($params['pay_way'] == 1) {
  188. //减少金额
  189. $userInfo->user_money = $userInfo->user_money - $order_amount;
  190. $userInfo->save();
  191. //记录用户金额变动记录
  192. //记录日志
  193. AccountLogLogic::add($userInfo->id, AccountLogEnum::BNW_DEC_ORDER, AccountLogEnum::DEC, $order_amount, $params['orderSn'], '线下收银台销售扣减用户金额');
  194. }
  195. }
  196. return true;
  197. }
  198. /*
  199. * 新增会员信息
  200. * */
  201. public function orderRefundMoney(array $params):bool{
  202. try {
  203. $mobile = $params['mobile'];
  204. $where['mobile'] = $mobile;
  205. $user_info = User::where($where)->findOrEmpty();
  206. if($user_info->isEmpty()){
  207. outFileLog($params,'orderRefundMoney','会员信息有无');
  208. self::setError('传入的会员信息有误,不存在,请同步');
  209. return false;
  210. }
  211. $refund_money = $params['refund_money'];
  212. if(isset($params['orderSn']) && !empty($params['orderSn'])) {
  213. $order_info = Order::where(['sn' => $params['orderSn']])->findOrEmpty();
  214. if ($order_info->isEmpty()) {
  215. outFileLog($params, 'orderRefundMoney', '传入订单信息有误');
  216. self::setError('传入订单信息有误');
  217. return false;
  218. }
  219. if($order_info['order_amount']<$refund_money){
  220. outFileLog($params, 'orderRefundMoney', '传入退款金额有误');
  221. self::setError('传入退款金额有误');
  222. return false;
  223. }
  224. $afersaleInfo = AfterSale::where(['order_id'=>$order_info['id']])->findOrEmpty();
  225. if(!$afersaleInfo->isEmpty()){
  226. outFileLog($params, 'orderRefundMoney', '已申请售后');
  227. self::setError('该订单号已经售后');
  228. return false;
  229. }
  230. //插入售后表
  231. $afterSale = AfterSale::create([
  232. 'sn' => generate_sn((new AfterSale()), 'sn'),
  233. 'user_id' => $order_info['user_id'],
  234. 'order_id' => $order_info['id'],
  235. 'order_goods_id' => 0,
  236. 'refund_reason' => '线下收银退款-'.$params['remark'],
  237. 'refund_remark' => '收银台系统发起退款',
  238. 'refund_type' => 2,
  239. 'refund_method' => 1,
  240. 'refund_total_amount' =>$refund_money,
  241. 'refund_way' => 1,
  242. 'refund_status' => 3,
  243. 'status' => 2,
  244. 'sub_status' => 21,
  245. ]);
  246. if ($order_info['pay_way'] == 5) {
  247. return true;
  248. } else {
  249. $user_info->user_money = $user_info->user_money + $refund_money;
  250. $user_info->save();
  251. //记录用户金额变动记录
  252. //记录日志
  253. AccountLogLogic::add($user_info->id, AccountLogEnum::BNW_INC_CANCEL_ORDER, AccountLogEnum::INC, $refund_money, $params['orderSn'], '线下收银台退款增加用户金额');
  254. return true;
  255. }
  256. }
  257. outFileLog($params,'orderRefundMoney','传入的订单编号有误');
  258. self::setError('传入的订单编号有误');
  259. return false;
  260. }catch(\Exception $e) {
  261. Db::rollback();
  262. self::setError($e->getMessage());
  263. return false;
  264. }
  265. }
  266. }