Shopping.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2017 https://www.sapixx.com All rights reserved.
  4. * @license Licensed (http://www.apache.org/licenses/LICENSE-2.0).
  5. * @author pillar<ltmn@qq.com>
  6. * 订单管理
  7. */
  8. namespace app\fastshop\controller;
  9. use app\common\controller\Manage;
  10. class Shopping extends Manage{
  11. public function initialize() {
  12. parent::initialize();
  13. if(!model('auth')->getAuth($this->user->id,2)){
  14. $this->error('无权限,你非【订单管理员】');
  15. }
  16. $this->assign('pathMaps',[['name'=>'订单管理','url'=>url("fastshop/shopping/index")]]);
  17. }
  18. /**
  19. * 订单列表
  20. */
  21. public function index(){
  22. $starttime = empty(input('get.starttime')) ? 0 : strtotime(input('get.starttime/s'));
  23. $endtime = empty(input('get.endtime')) ? 0 : strtotime(input('get.endtime/s'));
  24. if(!empty($starttime) && !empty($endtime)){
  25. if($starttime > $endtime){
  26. $this->error('开始日期不能大于结束日期');
  27. }
  28. if($endtime-$starttime >= 518401){
  29. $this->error('只支持连续6天的查找');
  30. }
  31. $starttime = strtotime(date('Y-m-d 00:00:00',$starttime));
  32. $endtime = strtotime(date('Y-m-d 23:59:59',$endtime));
  33. }
  34. $view['keyword'] = input('get.keyword');
  35. $view['status'] = input('status/d');
  36. $path[] = ['name'=>'订单管理','url'=>url("fastshop/shopping/index")];
  37. switch ($view['status']) {
  38. case 1:
  39. $condition = [['paid_at','=',0],['is_del','=',0]];
  40. $path[] = ['name'=>'未付款','url'=>'javascript:;'];
  41. break;
  42. case 2:
  43. $condition = [['paid_at','=',1],['is_del','=',0]];
  44. $path[] = ['name'=>'已付款','url'=>'javascript:;'];
  45. break;
  46. case 3:
  47. $condition = [['express_status','=',1],['is_del','=',0]];
  48. $path[] = ['name'=>'已发货','url'=>'javascript:;'];
  49. break;
  50. case 4:
  51. $condition = [['is_del','=',1]];
  52. $path[] = ['name'=>'回收站','url'=>'javascript:;'];
  53. break;
  54. case 5:
  55. $condition = [['status','=',1],['is_del','=',0]];
  56. $path[] = ['name'=>'已结单','url'=>'javascript:;'];
  57. break;
  58. default:
  59. $condition = [['is_del','=',0]];
  60. break;
  61. }
  62. if(!empty($starttime) && !empty($endtime)){
  63. $condition[] = ['order_starttime','>=',$starttime];
  64. $condition[] = ['order_starttime','<=',$endtime];
  65. }
  66. if(!empty($view['keyword'])){
  67. $condition = [['fastshop_shopping.order_no','=',trim($view['keyword'])]];
  68. }
  69. $condition[] = ['fastshop_shopping.member_miniapp_id','=',$this->member_miniapp_id];
  70. $view['lists'] = model('Shopping')->getOrderList($condition,$view['status']);
  71. $view['order'] = model('Shopping')->order_data($view['lists']->toArray()['data']);
  72. $view['starttime'] = empty($starttime) ? time() : $starttime;
  73. $view['endtime'] = empty($endtime) ? time() : $endtime;;
  74. $view['pathMaps'] = $path;
  75. return view()->assign($view);
  76. }
  77. /**
  78. * 导出Excel
  79. * @return void
  80. */
  81. public function excel(){
  82. header("Content-type: text/plain");
  83. header("Accept-Ranges: bytes");
  84. header("Content-type:application/vnd.ms-excel");
  85. header("Content-Disposition:attachment;filename=shopping_".date('Y-m-d').".xls");
  86. header("Pragma: no-cache");
  87. header("Expires: 0");
  88. $status = input('status/d');
  89. switch ($status) {
  90. case 1:
  91. $condition = [['paid_at','=',0],['is_del','=',0]];
  92. $path[] = ['name'=>'未付款','url'=>'javascript:;'];
  93. break;
  94. case 2:
  95. $condition = [['paid_at','=',1],['is_del','=',0]];
  96. $path[] = ['name'=>'已付款','url'=>'javascript:;'];
  97. break;
  98. case 3:
  99. $condition = [['express_status','=',1],['is_del','=',0]];
  100. $path[] = ['name'=>'已发货','url'=>'javascript:;'];
  101. break;
  102. case 4:
  103. $condition = [['is_del','=',1]];
  104. $path[] = ['name'=>'回收站','url'=>'javascript:;'];
  105. break;
  106. case 5:
  107. $condition = [['status','=',1],['is_del','=',0]];
  108. $path[] = ['name'=>'已结单','url'=>'javascript:;'];
  109. break;
  110. default:
  111. $condition = [['is_del','=',0]];
  112. break;
  113. }
  114. $starttime = strtotime(input('get.starttime/s'));
  115. $endtime = strtotime(input('get.endtime/s'));
  116. if(!empty($starttime) && !empty($endtime)){
  117. $starttime = strtotime(date('Y-m-d 00:00:00',$starttime));
  118. $endtime = strtotime(date('Y-m-d 23:59:59',$endtime));
  119. $condition[] = ['order_starttime','>=',$starttime];
  120. $condition[] = ['order_starttime','<=',$endtime];
  121. }
  122. if(input('?get.keyword')){
  123. $condition = [['fastshop_shopping.order_no','=',trim(input('get.keyword','','htmlspecialchars'))]];
  124. }
  125. $condition[] = ['fastshop_shopping.member_miniapp_id','=',$this->member_miniapp_id];
  126. $view['lists'] = model('Shopping')->getOrderListNopage($condition,$status);
  127. $view['order'] = model('Shopping')->order_data($view['lists']->toArray());
  128. return view()->assign($view);
  129. }
  130. /**
  131. * 订单预览
  132. */
  133. public function view(string $order_no){
  134. $view['order'] = model('Shopping')->getOrder($order_no,0,0);
  135. return view()->assign($view);
  136. }
  137. /**
  138. * 发货
  139. */
  140. public function sendgoods(){
  141. if(request()->isAjax()){
  142. $data = [
  143. 'order_no' => input('post.order_no/s'),
  144. 'express_company' => input('post.express_company/s'),
  145. 'express_no' => trim(input('post.express_no/s')),
  146. ];
  147. $validate = $this->validate($data,'Order.sendgoods');
  148. if(true !== $validate){
  149. return json(['code'=>0,'msg'=>$validate]);
  150. }
  151. //判断当前商品是否完成
  152. $result = model('Shopping')->where(['paid_at' => 1,'order_no' => $data['order_no']])->find();
  153. if(empty($result)){
  154. return json(['code'=>0,'msg'=>'商品没有满足发货条件']);
  155. }
  156. $data['express_company'] = trim($data['express_company']);
  157. $data['express_no'] = trim($data['express_no']);
  158. $data['express_status'] = 1;
  159. $data['express_starttime'] = time();
  160. $rel = model('Shopping')->save($data,['paid_at' => 1,'order_no' => $data['order_no']]);
  161. if($rel){
  162. return json(['code'=>200,'data' => ['url' => url('fastshop/shopping/view',['order_no'=>$data['order_no']])],'msg'=>'操作成功']);
  163. }else{
  164. return json(['code'=>0,'msg'=>'操作失败']);
  165. }
  166. }else{
  167. $order_no = input('get.order_no/s');
  168. $view['order'] = model('Shopping')->getOrder($order_no);
  169. if(empty($view['order'])){
  170. $this->error("404 NOT FOUND");
  171. }
  172. $view['order_no'] = $order_no;
  173. return view()->assign($view);
  174. }
  175. }
  176. /**
  177. * 后台人工修改订单为已发货
  178. */
  179. public function paid($order_no){
  180. $data['paid_at'] = 1;
  181. $data['payment_id'] = 0;
  182. $data['order_starttime'] = time();
  183. $data['paid_no'] = 'GM'.order_no();
  184. $result = model('Shopping')->update($data,['paid_at' => 0,'order_no' => $order_no]);
  185. if($result){
  186. return json(['code'=>200,'data' => ['url' => url('fastshop/shopping/view',['order_no' => $order_no])],'msg'=>'操作成功']);
  187. }else{
  188. return json(['code'=>0,'msg'=>'操作失败']);
  189. }
  190. }
  191. /**
  192. * 删除
  193. */
  194. public function delete($order_no){
  195. $status = input('status/d');
  196. $rel = model('Shopping')->where(['order_no' => $order_no])->find();
  197. if($rel){
  198. if($rel['is_del'] == 0){
  199. $result = model('Shopping')->update(['is_del'=>1],['order_no' => $order_no]);
  200. }else{
  201. $result = model('Shopping')->where(['order_no' => $order_no])->delete();
  202. if($result){
  203. model('ShoppingCache')->where(['order_no' => $order_no])->delete();
  204. }
  205. }
  206. if($result){
  207. return json(['code'=>200,'data' => ['url' => url('fastshop/shopping/index',['status' => $status])],'msg'=>'操作成功']);
  208. }
  209. }
  210. return json(['code'=>0,'msg'=>'操作失败']);
  211. }
  212. /**
  213. * 清空回收站
  214. */
  215. public function alldelete(){
  216. $status = input('status/d');
  217. $rel = model('Shopping')->where(['is_del'=>1])->select();
  218. if($rel){
  219. foreach ($rel as $key => $value) {
  220. model('Shopping')->where(['order_no' => $value['order_no']])->delete();
  221. model('ShoppingCache')->where(['order_no' => $value['order_no']])->delete();
  222. }
  223. return json(['code'=>200,'data' => ['url' => url('fastshop/shopping/index',['status' => $status])],'msg'=>'操作成功']);
  224. }
  225. return json(['code'=>0,'msg'=>'操作失败']);
  226. }
  227. /**
  228. * 确认收货
  229. */
  230. public function completion($order_no){
  231. $result = model('Shopping')->update(['status'=>1],['express_status'=>1,'order_no' => $order_no]);
  232. if($result){
  233. return json(['code'=>200,'data' => ['url' => url('fastshop/shopping/view',['order_no' => $order_no])],'msg'=>'操作成功']);
  234. }else{
  235. return json(['code'=>0,'msg'=>'操作失败']);
  236. }
  237. }
  238. /**
  239. * 订单完成
  240. */
  241. public function force_completion($order_no){
  242. $status = input('status/d');
  243. $result = model('Shopping')->update(['status'=>1],['order_no' => $order_no]);
  244. if($result){
  245. return json(['code'=>200,'data' => ['url' => url('fastshop/shopping/index',['status' => $status])],'msg'=>'操作成功']);
  246. }else{
  247. return json(['code'=>0,'msg'=>'操作失败']);
  248. }
  249. }
  250. }