combinationOrder.php 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590
  1. <?php
  2. namespace app\admin\controller\order;
  3. use crmeb\repositories\OrderRepository;
  4. use crmeb\services\ExpressService;
  5. use crmeb\services\MiniProgramService;
  6. use crmeb\services\WechatService;
  7. use crmeb\basic\BaseModel;
  8. use crmeb\services\CacheService;
  9. use crmeb\services\UtilService as Util;
  10. use crmeb\services\JsonService as Json;
  11. use think\facade\Db;
  12. use think\facade\Route as Url;
  13. use app\admin\controller\AuthController;
  14. use crmeb\services\FormBuilder as Form;
  15. use app\admin\model\order\StoreOrderStatus;
  16. use app\admin\model\ump\StorePink;
  17. use app\admin\model\user\User;
  18. use app\admin\model\user\UserBill;
  19. use app\admin\model\order\StoreOrder as StoreOrderModel;
  20. /**
  21. * 订单管理控制器
  22. * Class StoreOrder
  23. * @package app\admin\controller\store
  24. */
  25. class CombinationOrder extends AuthController
  26. {
  27. /**
  28. * @return mixed
  29. */
  30. public function index()
  31. {
  32. $where = Util::getMore([
  33. ['status',''],
  34. ['real_name',''],
  35. ['is_del',0],
  36. ['data',''],
  37. ['combination_id',''],
  38. ['export',0],
  39. ['order','id desc']
  40. ],$this->request);
  41. $limitTimeList = [
  42. 'yesterday'=>implode(' - ',[date('Y/m/d',strtotime('-1 day')),date('Y/m/d')]),
  43. 'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
  44. 'week'=>implode(' - ',[
  45. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  46. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  47. ]),
  48. 'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
  49. 'quarter'=>implode(' - ',[
  50. date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
  51. date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
  52. ]),
  53. 'year'=>implode(' - ',[
  54. date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
  55. ])
  56. ];
  57. $this->assign(StoreOrderModel::systemPage($where,$this->adminId));
  58. $this->assign('price',StoreOrderModel::getOrderPrice($where));
  59. $this->assign(compact('where','limitTimeList'));
  60. return $this->fetch();
  61. }
  62. public function orderchart(){
  63. $where = Util::getMore([
  64. ['status',''],
  65. ['real_name',''],
  66. ['is_del',0],
  67. ['data',''],
  68. ['combination_id',''],
  69. ['export',0],
  70. ['order','id desc']
  71. ],$this->request);
  72. $limitTimeList = [
  73. 'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
  74. 'week'=>implode(' - ',[
  75. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  76. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  77. ]),
  78. 'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
  79. 'quarter'=>implode(' - ',[
  80. date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
  81. date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
  82. ]),
  83. 'year'=>implode(' - ',[
  84. date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
  85. ])
  86. ];
  87. if($where['data'] == '') $where['data'] = $limitTimeList['today'];
  88. $orderCount = [
  89. urlencode('未支付')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(0))->count(),
  90. urlencode('未发货')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(1))->count(),
  91. urlencode('待收货')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(2))->count(),
  92. urlencode('待评价')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(3))->count(),
  93. urlencode('交易完成')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(4))->count(),
  94. urlencode('退款中')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(-1))->count(),
  95. urlencode('已退款')=>StoreOrderModel::getOrderWhere($where,StoreOrderModel::statusByWhere(-2))->count()
  96. ];
  97. $model = StoreOrderModel::getOrderWhere($where,new StoreOrderModel())->field('sum(total_num) total_num,count(*) count,sum(total_price) total_price,sum(refund_price) refund_price,from_unixtime(add_time,\'%Y-%m-%d\') add_time')
  98. ->group('from_unixtime(add_time,\'%Y-%m-%d\')');
  99. $orderPrice = $model->select()->toArray();
  100. $orderDays = [];
  101. $orderCategory = [
  102. ['name'=>'商品数','type'=>'line','data'=>[]],
  103. ['name'=>'订单数','type'=>'line','data'=>[]],
  104. ['name'=>'订单金额','type'=>'line','data'=>[]],
  105. ['name'=>'退款金额','type'=>'line','data'=>[]]
  106. ];
  107. foreach ($orderPrice as $price){
  108. $orderDays[] = $price['add_time'];
  109. $orderCategory[0]['data'][] = $price['total_num'];
  110. $orderCategory[1]['data'][] = $price['count'];
  111. $orderCategory[2]['data'][] = $price['total_price'];
  112. $orderCategory[3]['data'][] = $price['refund_price'];
  113. }
  114. $this->assign(StoreOrderModel::systemPage($where,$this->adminId));
  115. $this->assign('price',StoreOrderModel::getOrderPrice($where));
  116. $this->assign(compact('limitTimeList','where','orderCount','orderPrice','orderDays','orderCategory'));
  117. return $this->fetch();
  118. }
  119. /**
  120. * 修改支付金额等
  121. * @param $id
  122. * @return mixed|\think\response\Json|void
  123. */
  124. public function edit($id)
  125. {
  126. if(!$id) return $this->failed('数据不存在');
  127. $product = StoreOrderModel::get($id);
  128. if(!$product) return Json::fail('数据不存在!');
  129. $this->assign([
  130. 'title'=>'修改订单','rules'=>$this->read($id)->getContent(),
  131. 'action'=>Url::buildUrl('update',array('id'=>$id))
  132. ]);
  133. return $this->fetch('public/common_form');
  134. }
  135. public function read($id)
  136. {
  137. if(!$id) return $this->failed('数据不存在');
  138. $product = StoreOrderModel::get($id);
  139. if(!$product) return Json::fail('数据不存在!');
  140. Form::text('order_id','订单编号',$product->getData('order_id'))->readonly();
  141. Form::number('total_price','商品总价',$product->getData('total_price'))->min(0);
  142. Form::number('total_postage','原始邮费',$product->getData('total_postage'))->min(0);
  143. Form::number('pay_price','实际支付金额',$product->getData('pay_price'))->min(0);
  144. Form::number('pay_postage','实际支付邮费',$product->getData('pay_postage'))->min(0);
  145. Form::number('gain_integral','赠送积分',$product->getData('gain_integral'))->min(0);
  146. return Form::builder();
  147. }
  148. public function update($id)
  149. {
  150. $data = Util::postMore([
  151. 'order_id',
  152. 'total_price',
  153. 'total_postage',
  154. 'pay_price',
  155. 'pay_postage',
  156. 'gain_integral',
  157. ]);
  158. if($data['total_price'] <= 0) return Json::fail('请输入商品总价');
  159. if($data['pay_price'] <= 0) return Json::fail('请输入实际支付金额');
  160. $data['order_id'] = StoreOrderModel::changeOrderId($data['order_id']);
  161. StoreOrderModel::edit($data,$id);
  162. event('StoreProductOrderEditAfter',[$data,$id]);
  163. StoreOrderStatus::setStatus($id,'order_edit','修改商品总价为:'.$data['total_price'].' 实际支付金额'.$data['pay_price']);
  164. return Json::successful('修改成功!');
  165. }
  166. /**
  167. * 送货
  168. * @param $id
  169. * send
  170. */
  171. public function delivery($id){
  172. if(!$id) return $this->failed('数据不存在');
  173. $product = StoreOrderModel::get($id);
  174. if(!$product) return Json::fail('数据不存在!');
  175. if($product['paid'] == 1 && $product['status'] == 0) {
  176. $this->assign([
  177. 'title' => '送货信息', 'rules' => $this->readDelivery($id)->getContent(),
  178. 'action' => Url::buildUrl('updateDelivery', array('id' => $id))
  179. ]);
  180. return $this->fetch('public/common_form');
  181. }
  182. else return Json::fail('数据不存在!');
  183. }
  184. public function readDelivery($id){
  185. if(!$id) return $this->failed('数据不存在');
  186. $product = StoreOrderModel::get($id);
  187. if(!$product) return Json::fail('数据不存在!');
  188. Form::text('delivery_name','送货人姓名');
  189. Form::text('delivery_id','送货人电话')->number();
  190. return Form::builder();
  191. }
  192. public function updateDelivery($id){
  193. $data = Util::postMore([
  194. 'delivery_name',
  195. 'delivery_id',
  196. ]);
  197. $data['delivery_type'] = 'send';
  198. if(!$data['delivery_name']) return Json::fail('请输入送货人姓名');
  199. if(!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
  200. else if(!preg_match("/^1[3456789]{1}\d{9}$/",$data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
  201. $data['status'] = 1;
  202. StoreOrderModel::edit($data,$id);
  203. event('storeProductOrderDeliveryAfter',[$data,$id]);
  204. StoreOrderStatus::setStatus($id,'delivery','已配送 发货人:'.$data['delivery_name'].' 发货人电话:'.$data['delivery_id']);
  205. return Json::successful('修改成功!');
  206. }
  207. /**
  208. * 发货
  209. * @param $id
  210. * express
  211. */
  212. public function deliver_goods($id){
  213. if(!$id) return $this->failed('数据不存在');
  214. $product = StoreOrderModel::get($id);
  215. if(!$product) return Json::fail('数据不存在!');
  216. if($product['paid'] == 1 && $product['status'] == 0){
  217. $this->assign([
  218. 'title'=>'发货信息','rules'=>$this->readDeliveryGoods($id)->getContent(),
  219. 'action'=>Url::buildUrl('updateDeliveryGoods',array('id'=>$id))
  220. ]);
  221. return $this->fetch('public/common_form');
  222. }
  223. else return Json::fail('数据不存在!');
  224. }
  225. public function readDeliveryGoods($id){
  226. if(!$id) return $this->failed('数据不存在');
  227. $product = StoreOrderModel::get($id);
  228. if(!$product) return Json::fail('数据不存在!');
  229. Form::select('delivery_name','快递公司',function(){
  230. $list = Db::name('express')->where('is_show',1)->order('sort DESC')->column('name','id');
  231. $menus = [];
  232. foreach ($list as $k=>$v){
  233. $menus[] = ['value'=>$v,'label'=>$v];
  234. }
  235. return $menus;
  236. })->filterable();
  237. Form::text('delivery_id','快递单号');
  238. return Form::builder();
  239. }
  240. public function updateDeliveryGoods($id){
  241. $data = Util::postMore([
  242. 'delivery_name',
  243. 'delivery_id',
  244. ]);
  245. $data['delivery_type'] = 'express';
  246. if(!$data['delivery_name']) return Json::fail('请选择快递公司');
  247. if(!$data['delivery_id']) return Json::fail('请输入快递单号');
  248. $data['status'] = 1;
  249. StoreOrderModel::edit($data,$id);
  250. event('StoreProductOrderDeliveryGoodsAfter',[$data,$id]);
  251. StoreOrderStatus::setStatus($id,'delivery_goods','已发货 快递公司:'.$data['delivery_name'].' 快递单号:'.$data['delivery_id']);
  252. return Json::successful('修改成功!');
  253. }
  254. /**
  255. * 修改状态为已收货
  256. * @param $id
  257. * @return \think\response\Json|void
  258. */
  259. public function take_delivery($id){
  260. if(!$id) return $this->failed('数据不存在');
  261. $product = StoreOrderModel::get($id);
  262. if(!$product) return Json::fail('数据不存在!');
  263. if($product['status'] == 2) return Json::fail('不能重复收货!');
  264. if($product['paid'] == 1 && $product['status'] == 1) $data['status'] = 2;
  265. else if($product['pay_type'] == 'offline') $data['status'] = 2;
  266. else return Json::fail('请先发货或者送货!');
  267. if(!StoreOrderModel::edit($data,$id))
  268. return Json::fail(StoreOrderModel::getErrorInfo('收货失败,请稍候再试!'));
  269. else{
  270. try{
  271. OrderRepository::storeProductOrderTakeDeliveryAdmin($data, $id);
  272. }catch (\Exception $e){
  273. return Json::fail($e->getMessage());
  274. }
  275. StoreOrderStatus::setStatus($id,'take_delivery','已收货');
  276. return Json::successful('收货成功!');
  277. }
  278. }
  279. /**
  280. * 修改退款状态
  281. * @param $id
  282. * @return \think\response\Json|void
  283. */
  284. public function refund_y($id){
  285. if(!$id) return $this->failed('数据不存在');
  286. $product = StoreOrderModel::get($id);
  287. if(!$product) return Json::fail('数据不存在!');
  288. if($product['paid'] == 1){
  289. $this->assign([
  290. 'title'=>'退款','rules'=>$this->readRefundY($id)->getContent(),
  291. 'action'=>Url::buildUrl('updateRefundY',array('id'=>$id))
  292. ]);
  293. return $this->fetch('public/common_form');
  294. }
  295. else return Json::fail('数据不存在!');
  296. }
  297. public function readRefundY($id){
  298. if(!$id) return $this->failed('数据不存在');
  299. $product = StoreOrderModel::get($id);
  300. if(!$product) return Json::fail('数据不存在!');
  301. Form::text('order_id','退款单号',$product->getData('order_id'))->readonly();
  302. Form::number('refund_price','退款金额',$product->getData('pay_price'))->min(0);
  303. Form::radio('type','状态',[['label'=>'直接退款','value'=>1],['label'=>'退款后,返回原状态','value'=>2]],1);
  304. return Form::builder();
  305. }
  306. public function updateRefundY($id){
  307. $data = Util::postMore([
  308. 'refund_price',
  309. ['type',1],
  310. ]);
  311. if(!$id) return $this->failed('数据不存在');
  312. $product = StoreOrderModel::get($id);
  313. if(!$product) return Json::fail('数据不存在!');
  314. if($product['pay_price'] == $product['refund_price']) return Json::fail('已退完支付金额!不能再退款了');
  315. if(!$data['refund_price']) return Json::fail('请输入退款金额');
  316. $refund_price = $data['refund_price'];
  317. $data['refund_price'] = bcadd($data['refund_price'],$product['refund_price'],2);
  318. $bj = bccomp((float)$product['pay_price'],(float)$data['refund_price'],2);
  319. if($bj < 0) return Json::fail('退款金额大于支付金额,请修改退款金额');
  320. if($data['type'] == 1){
  321. $data['refund_status'] = 2;
  322. }else if($data['type'] == 2){
  323. $data['refund_status'] = 0;
  324. }
  325. $type = $data['type'];
  326. unset($data['type']);
  327. $refund_data['pay_price'] = $product['pay_price'];
  328. $refund_data['refund_price'] = $refund_price;
  329. if($product['pay_type'] == 'weixin'){
  330. if($product['is_channel'] == 1){//TODO 小程序
  331. try{
  332. MiniProgramService::payOrderRefund($product['order_id'],$refund_data);//2.5.36
  333. }catch(\Exception $e){
  334. return Json::fail($e->getMessage());
  335. }
  336. }else{ //TODO 公众号
  337. try{
  338. WechatService::payOrderRefund($product['order_id'],$refund_data);
  339. }catch(\Exception $e){
  340. return Json::fail($e->getMessage());
  341. }
  342. }
  343. }else if($product['pay_type'] == 'yue'){
  344. BaseModel::beginTrans();
  345. $usermoney = User::where('uid',$product['uid'])->value('now_money');
  346. $res1 = User::bcInc($product['uid'],'now_money',$refund_price,'uid');
  347. $res2 = $res2 = UserBill::income('商品退款',$product['uid'],'now_money','pay_product_refund',$refund_price,$product['id'],bcadd($usermoney,$refund_price,2),'订单退款到余额'.floatval($refund_price).'元');
  348. try{
  349. OrderRepository::storeOrderYueRefund($product, $refund_data);
  350. }catch (\Exception $e){
  351. BaseModel::rollbackTrans();
  352. return Json::fail($e->getMessage());
  353. }
  354. $res = $res1 && $res2;
  355. BaseModel::checkTrans($res);
  356. if(!$res) return Json::fail('余额退款失败!');
  357. }
  358. $resEdit = StoreOrderModel::edit($data,$id);
  359. if($resEdit){
  360. $data['type'] = $type;
  361. if($data['type'] == 1) StorePink::setRefundPink($id);
  362. try{
  363. OrderRepository::storeProductOrderRefundY($data, $id);
  364. }catch (\Exception $e){
  365. return Json::fail($e->getMessage());
  366. }
  367. StoreOrderStatus::setStatus($id,'refund_price','退款给用户'.$refund_price.'元');
  368. return Json::successful('修改成功!');
  369. }else{
  370. StoreOrderStatus::setStatus($id,'refund_price','退款给用户'.$refund_price.'元失败');
  371. return Json::fail('修改失败!');
  372. }
  373. }
  374. public function order_info($oid = '')
  375. {
  376. if(!$oid || !($orderInfo = StoreOrderModel::get($oid)))
  377. return $this->failed('订单不存在!');
  378. $userInfo = User::getUserInfo($orderInfo['uid']);
  379. if($userInfo['spread_uid']){
  380. $spread = User::where('uid',$userInfo['spread_uid'])->value('nickname');
  381. }else{
  382. $spread ='';
  383. }
  384. $this->assign(compact('orderInfo','userInfo','spread'));
  385. return $this->fetch();
  386. }
  387. public function express($oid = '')
  388. {
  389. if(!$oid || !($order = StoreOrderModel::get($oid)))
  390. return $this->failed('订单不存在!');
  391. if($order['delivery_type'] != 'express' || !$order['delivery_id']) return $this->failed('该订单不存在快递单号!');
  392. $cacheName = $order['order_id'].$order['delivery_id'];
  393. $result = CacheService::get($cacheName,null);
  394. if($result === null){
  395. $result = ExpressService::query($order['delivery_id']);
  396. if(is_array($result) &&
  397. isset($result['result']) &&
  398. isset($result['result']['deliverystatus']) &&
  399. $result['result']['deliverystatus'] >= 3)
  400. $cacheTime = 0;
  401. else
  402. $cacheTime = 1800;
  403. CacheService::set($cacheName,$result,$cacheTime);
  404. }
  405. $this->assign([
  406. 'order'=>$order,
  407. 'express'=>$result
  408. ]);
  409. return $this->fetch();
  410. }
  411. /**
  412. * 修改配送信息
  413. * @param $id
  414. * @return mixed|\think\response\Json|void
  415. */
  416. public function distribution($id){
  417. if(!$id) return $this->failed('数据不存在');
  418. $product = StoreOrderModel::get($id);
  419. if(!$product) return Json::fail('数据不存在!');
  420. $this->assign([
  421. 'title'=>'配送信息','rules'=>$this->readDistribution($id)->getContent(),
  422. 'action'=>Url::buildUrl('updateDistribution',array('id'=>$id))
  423. ]);
  424. return $this->fetch('public/common_form');
  425. }
  426. public function readDistribution($id){
  427. if(!$id) return $this->failed('数据不存在');
  428. $product = StoreOrderModel::get($id);
  429. if(!$product) return Json::fail('数据不存在!');
  430. if($product['delivery_type'] == 'send'){
  431. Form::text('delivery_name','送货人姓名',$product->getData('delivery_name'));
  432. Form::text('delivery_id','送货人电话',$product->getData('delivery_id'))->number();
  433. }else if($product['delivery_type'] == 'express'){
  434. Form::select('delivery_name','快递公司',function(){
  435. $list = Db::name('express')->where('is_show',1)->column('name','id');
  436. $menus = [];
  437. foreach ($list as $k=>$v){
  438. $menus[] = ['value'=>$v,'label'=>$v];
  439. }
  440. return $menus;
  441. },$product->getData('delivery_name'))->filterable();
  442. Form::text('delivery_id','快递单号',$product->getData('delivery_id'));
  443. }
  444. return Form::builder();
  445. }
  446. public function updateDistribution($id){
  447. $data = Util::postMore([
  448. 'delivery_name',
  449. 'delivery_id',
  450. ]);
  451. if(!$id) return $this->failed('数据不存在');
  452. $product = StoreOrderModel::get($id);
  453. if(!$product) return Json::fail('数据不存在!');
  454. if($product['delivery_type'] == 'send'){
  455. if(!$data['delivery_name']) return Json::fail('请输入送货人姓名');
  456. if(!(int)$data['delivery_id']) return Json::fail('请输入送货人电话号码');
  457. else if(!preg_match("/^1[3456789]{1}\d{9}$/",$data['delivery_id'])) return Json::fail('请输入正确的送货人电话号码');
  458. }else if($product['delivery_type'] == 'express'){
  459. if(!$data['delivery_name']) return Json::fail('请选择快递公司');
  460. if(!$data['delivery_id']) return Json::fail('请输入快递单号');
  461. }
  462. StoreOrderModel::edit($data,$id);
  463. event('StoreProductOrderDistributionAfter',[$data,$id]);
  464. StoreOrderStatus::setStatus($id,'distribution','修改发货信息为'.$data['delivery_name'].'号'.$data['delivery_id']);
  465. return Json::successful('修改成功!');
  466. }
  467. /**
  468. * 修改退款状态
  469. * @param $id
  470. * @return mixed|\think\response\Json|void
  471. */
  472. public function refund_n($id){
  473. if(!$id) return $this->failed('数据不存在');
  474. $product = StoreOrderModel::get($id);
  475. if(!$product) return Json::fail('数据不存在!');
  476. $this->assign([
  477. 'title'=>'退款','rules'=>$this->readRefundN($id)->getContent(),
  478. 'action'=>Url::buildUrl('updateRefundN',array('id'=>$id))
  479. ]);
  480. return $this->fetch('public/common_form');
  481. }
  482. public function readRefundN($id){
  483. if(!$id) return $this->failed('数据不存在');
  484. $product = StoreOrderModel::get($id);
  485. if(!$product) return Json::fail('数据不存在!');
  486. Form::text('order_id','退款单号',$product->getData('order_id'))->readonly();
  487. Form::textarea('refund_reason','退款原因');
  488. return Form::builder();
  489. }
  490. public function updateRefundN($id){
  491. $data = Util::postMore([
  492. 'refund_reason',
  493. ]);
  494. if(!$id) return $this->failed('数据不存在');
  495. $product = StoreOrderModel::get($id);
  496. if(!$product) return Json::fail('数据不存在!');
  497. if(!$data['refund_reason']) return Json::fail('请输入退款原因');
  498. $data['refund_status'] = 0;
  499. StoreOrderModel::edit($data,$id);
  500. event('StoreProductOrderRefundNAfter',[$data['refund_reason'],$id]);
  501. StoreOrderStatus::setStatus($id,'refund_n','不退款原因:'.$data['refund_reason']);
  502. return Json::successful('修改成功!');
  503. }
  504. /**
  505. * 立即支付
  506. * @param $id
  507. */
  508. public function offline($id){
  509. $res = StoreOrderModel::updateOffline($id);
  510. if($res){
  511. event('StoreProductOrderOffline',[$id]);
  512. StoreOrderStatus::setStatus($id,'offline','线下付款');
  513. return Json::successful('修改成功!');
  514. }else{
  515. return Json::fail(StoreOrderModel::getErrorInfo('修改失败!'));
  516. }
  517. }
  518. /**
  519. * 修改积分和金额
  520. * @param $id
  521. * @return mixed|\think\response\Json|void
  522. */
  523. public function integral_back($id){
  524. if(!$id) return $this->failed('数据不存在');
  525. $product = StoreOrderModel::get($id);
  526. if(!$product) return Json::fail('数据不存在!');
  527. if($product['paid'] == 1){
  528. $this->assign([
  529. 'title'=>'退积分','rules'=>$this->readIntegralBack($id)->getContent(),
  530. 'action'=>Url::buildUrl('updateIntegralBack',array('id'=>$id))
  531. ]);
  532. }else{
  533. return Json::fail('参数错误!');
  534. }
  535. return $this->fetch('public/common_form');
  536. }
  537. public function readIntegralBack($id){
  538. if(!$id) return $this->failed('数据不存在');
  539. $product = StoreOrderModel::get($id);
  540. if(!$product) return Json::fail('数据不存在!');
  541. Form::text('order_id','退积分单号',$product->getData('order_id'))->readonly();
  542. Form::number('back_integral','退积分')->min(0);
  543. return Form::builder();
  544. }
  545. public function updateIntegralBack($id){
  546. $data = Util::postMore([
  547. 'back_integral',
  548. ]);
  549. if(!$id) return $this->failed('数据不存在');
  550. $product = StoreOrderModel::get($id);
  551. if(!$product) return Json::fail('数据不存在!');
  552. if($data['back_integral'] <= 0) return Json::fail('请输入积分');
  553. if($product['use_integral'] == $product['back_integral']) return Json::fail('已退完积分!不能再积分了');
  554. $back_integral = $data['back_integral'];
  555. $data['back_integral'] = bcadd($data['back_integral'],$product['back_integral'],2);
  556. $bj = bccomp((float)$product['use_integral'],(float)$data['back_integral'],2);
  557. if($bj < 0) return Json::fail('退积分大于支付积分,请修改退积分');
  558. BaseModel::beginTrans();
  559. $integral = User::where('uid',product['uid'])->value('integral');
  560. $res1 = User::bcInc($product['uid'],'integral',$back_integral,'uid');
  561. $res2 = UserBill::income('商品退积分',$product['uid'],'integral','pay_product_integral_back',$back_integral,$product['id'],bcadd($integral,$back_integral,2),'订单退积分'.floatval($back_integral).'积分到用户积分');
  562. try{
  563. OrderRepository::storeOrderIntegralBack($product,$back_integral);
  564. }catch (\Exception $e){
  565. BaseModel::rollbackTrans();
  566. return Json::fail($e->getMessage());
  567. }
  568. $res = $res1 && $res2;
  569. BaseModel::checkTrans($res);
  570. if(!$res) return Json::fail('退积分失败!');
  571. StoreOrderModel::edit($data,$id);
  572. StoreOrderStatus::setStatus($id,'integral_back','商品退积分:'.$data['back_integral']);
  573. return Json::successful('退积分成功!');
  574. }
  575. public function remark(){
  576. $data = Util::postMore(['id','remark']);
  577. if(!$data['id']) return Json::fail('参数错误!');
  578. if($data['remark'] == '') return Json::fail('请输入要备注的内容!');
  579. $id = $data['id'];
  580. unset($data['id']);
  581. StoreOrderModel::edit($data,$id);
  582. return Json::successful('备注成功!');
  583. }
  584. public function order_status($oid){
  585. if(!$oid) return $this->failed('数据不存在');
  586. $this->assign(StoreOrderStatus::systemPage($oid));
  587. return $this->fetch();
  588. }
  589. }