Overview.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\model\Admin;
  4. use app\admin\model\AdminMoneyLog;
  5. use app\admin\model\Refund;
  6. use app\admin\model\User;
  7. use app\common\controller\Backend;
  8. use app\admin\model\Orders;
  9. /**
  10. * 控制台
  11. *
  12. * @icon fa fa-dashboard
  13. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  14. */
  15. class Overview extends Backend
  16. {
  17. /**
  18. * 查看
  19. */
  20. public function index()
  21. {
  22. try {
  23. \think\Db::execute("SET @@sql_mode='';");
  24. } catch (\Exception $e) {
  25. }
  26. list($defDate)=$this->rangeTime('asdasdasd');
  27. $this->assign('defDate',$defDate);
  28. if($this->request->isAjax()){
  29. $filter=json_decode(input('filter'),true);
  30. $map=[];
  31. if(!empty($filter['date'])){
  32. list($time1,$time2)=explode(' - ',$filter['date']);
  33. $map['create_time']=['between',[strtotime($time1),strtotime($time2)]];
  34. }
  35. list($where, $sort, $order, $offset, $limit) = $this->buildparams();
  36. $offset=input('offset',0);
  37. $limit=input('limit',20);
  38. $page=$offset/$limit+1;
  39. $list= Orders::payed()
  40. ->where($map)
  41. ->order($sort,$order)
  42. ->paginate($limit,false,['page'=>$page]);
  43. $this->addRank($list);
  44. return json([
  45. 'rows'=>$list->items(),
  46. 'total'=>$list->total(),
  47. ]);
  48. }
  49. list($postTime,$postTimeArr) = $this->rangeTime('startTime');
  50. $where = [];
  51. $map = [];
  52. if($postTime){
  53. $time = explode(' - ',$postTime);
  54. $startTime = strtotime($time[0]);
  55. $endTime = strtotime($time[1]);
  56. $where['create_time'] = array('between',[$startTime,$endTime]);
  57. $map['createtime'] = array('between',[$startTime,$endTime]);
  58. }
  59. //总销售额
  60. $sale = Db('Orders')->where($where)->where('status','in','5,10,20')->sum('amount_pay');
  61. //$refund = Db('OrderInfoRefund')->where($where)->where('refund_status',20)->sum('amount');
  62. $sale = bcsub($sale,0);
  63. //总销售数量
  64. $saleNum = Db('Orders')->where($where)->where('status','in','5,10,20')->count();
  65. //$refundNum = Db('OrderInfoRefund')->where($where)->where('refund_status',20)->count();
  66. $saleNum = bcsub($saleNum,0);
  67. //新增用户数
  68. $register = User::where($map)->count();
  69. //下单用户数
  70. $buy = Orders::where($where)->where('status','in','5,10,20')->group('user_id')->count();
  71. #投诉量
  72. $tsNum=Refund::filterDate($postTimeArr)->filterTs()->count();
  73. $this->assign('tsNum',$tsNum);
  74. //毛利、毛利率
  75. $install = Db('Orders')->where($where)->where('status','in','5,10,20')->sum('amount_install');//总安装费
  76. $orderIds = Db('Orders')->where($where)->where('status','in','5,10,20')->column('id');
  77. $cost = Db('OrderInfo')->where('order_id','in',$orderIds)->sum('amount_cost_total');//总成本
  78. $gross_profit = bcsub($sale,$install);
  79. $gross_profit = bcsub($gross_profit,$cost);
  80. $gross_profit_margin = 0;
  81. if($sale > 0)$gross_profit_margin = round($gross_profit/$sale,2)*100;//毛利率
  82. //支付方式
  83. $orderList = Orders::where($where)
  84. ->whereNotNull('pay_type')
  85. ->field('pay_type, COUNT(*) AS nums')
  86. ->group('pay_type')
  87. ->select();
  88. $payTotalCount = Db("Orders")->where($where)->where('status','in','5,10,20,30')->count();
  89. $payTypeList = [];
  90. $payTypeList1 = [];
  91. foreach ($orderList as $k => $v) {
  92. if($v['pay_type'] == 1){
  93. $v['pay_type'] = '企业网银';
  94. }elseif ($v['pay_type'] == 2){
  95. $v['pay_type'] = '微信';
  96. }elseif ($v['pay_type'] == 3){
  97. $v['pay_type'] = '支付宝';
  98. }elseif ($v['pay_type'] == 4){
  99. $v['pay_type'] = '银联';
  100. }elseif ($v['pay_type'] == 5){
  101. $v['pay_type'] = '代付';
  102. }elseif ($v['pay_type'] == 6){
  103. $v['pay_type'] = '线下支付';
  104. }
  105. $rate = 0;
  106. if($payTotalCount > 0)$rate = round($v['nums']/$payTotalCount,2)*100;
  107. $rate = $rate.'%';
  108. $payTypeList[$v['pay_type']] = $v['nums'];
  109. $payTypeList1[$v['pay_type']] = $rate;
  110. }
  111. $this->view->assign([
  112. 'sale' => $sale,
  113. 'sale_num' => $saleNum,
  114. 'register' => $register,
  115. 'buy' => $buy,
  116. 'gross_profit'=>$gross_profit,
  117. 'gross_profit_margin'=>$gross_profit_margin,
  118. 'post_time'=>$postTime
  119. ]);
  120. $this->assignconfig('type_column', array_keys($payTypeList));
  121. $this->assignconfig('type_data', array_values($payTypeList));
  122. $this->assignconfig('type_column1', array_keys($payTypeList1));
  123. $this->assignconfig('type_data1', array_values($payTypeList1));
  124. return $this->view->fetch();
  125. }
  126. public function seller_statistics(){
  127. list($date)=$this->rangeTime('aaaaa');
  128. $this->assign('date',$date);
  129. if($this->request->isAjax()){
  130. $type=input('type',1);
  131. $filter=json_decode(input('filter'),true);
  132. $map=[];
  133. if(!empty($filter['date'])){
  134. list($time1,$time2)=explode(' - ',$filter['date']);
  135. $map['create_time']=['between',[strtotime($time1),strtotime($time2)]];
  136. }
  137. $offset=input('offset',0);
  138. $limit=input('limit',20);
  139. $page=$offset/$limit+1;
  140. if($type==1){
  141. $list= Orders::payed()
  142. ->where($map)
  143. ->field('SUM(amount_pay) as amount,admin_id')
  144. ->group('admin_id')
  145. ->order('amount','desc')
  146. ->paginate($limit,false,['page'=>$page]);
  147. }else{
  148. $list=AdminMoneyLog::filterTypeCommission()
  149. ->where($map)
  150. ->field('SUM(amount) as amount,admin_id')
  151. ->group('admin_id')
  152. ->order('amount','desc')
  153. ->paginate($limit,false,['page'=>$page]);
  154. }
  155. $index=$list->listRows()*$list->currentPage()-$list->listRows();
  156. foreach ($list as $idx=>&$item){
  157. $item['rank']=$index+$idx+1;
  158. $item['nickname']=Admin::where('id',$item['admin_id'])->value('nickname');
  159. }
  160. return json([
  161. 'rows'=>$list->items(),
  162. 'total'=>$list->total(),
  163. ]);
  164. }
  165. return $this->fetch();
  166. }
  167. }