IndexController.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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\count\controller;
  20. use app\common\model\Order;
  21. use app\common\model\OrderGoods;
  22. use think\facade\Config;
  23. /**
  24. * 配置控制器
  25. * Class ConfigController
  26. * @package app\adminapi\controller
  27. */
  28. class IndexController extends BaseAdminController
  29. {
  30. public array $notNeedLogin = ['index'];
  31. public function index()
  32. {
  33. // 获取上个月的第一天
  34. $firstDayOfLastMonth = strtotime(date('Y-m-01', strtotime('last month')));
  35. // 获取上个月最后一天
  36. $lastDayOfLastMonth = strtotime(date('Y-m-t', strtotime('last month')) . ' 23:59:59');
  37. // 获取上个月的第一天
  38. $firstDayOfNowMonth = strtotime(date('Y-m-01'));
  39. // 获取上个月最后一天
  40. $lastDayOfNowMonth = strtotime(date('Y-m-t') . ' 23:59:59');
  41. $where = [];
  42. $whereTime = [];
  43. $whereLastTime[] = ['o.create_time', 'between', [$firstDayOfLastMonth, $lastDayOfLastMonth]];
  44. $whereNowTime[] = ['o.create_time', 'between', [$firstDayOfNowMonth, $lastDayOfNowMonth]];
  45. $where[]=['o.pay_status','=',1];
  46. $lastOrderGoodsInfo = OrderGoods::alias('og')->leftJoin('order o','o.id = og.order_id')
  47. ->field('og.goods_id,og.goods_name name,sum(og.goods_num) last_total_num')
  48. ->where($where)->where($whereLastTime)
  49. ->group('og.goods_id,og.goods_name')
  50. ->order('last_total_num desc')
  51. ->select()->toArray();
  52. $nowOrderGoodsInfo = OrderGoods::alias('og')->leftJoin('order o','o.id = og.order_id')
  53. ->field('og.goods_id,og.goods_name name,sum(og.goods_num) now_total_num')
  54. ->where($where)->where($whereNowTime)
  55. ->group('og.goods_id,og.goods_name')
  56. ->order('now_total_num desc')
  57. ->select()->toArray();
  58. $newGoodsData = [];
  59. if(count($lastOrderGoodsInfo)>5){
  60. foreach($lastOrderGoodsInfo as $lk=>$lv){
  61. if($lk>4)break;
  62. foreach($nowOrderGoodsInfo as $nk=>$nv){
  63. $lastOrderGoodsInfo[$lk]['now_total_num'] = 0;
  64. if($lv['goods_id'] == $nv['goods_id'] ){
  65. $lv['now_total_num'] = $nv['now_total_num'];
  66. break;
  67. }
  68. }
  69. $newGoodsData[] =$lv;
  70. }
  71. }else{
  72. if(empty($lastOrderGoodsInfo)){
  73. foreach($nowOrderGoodsInfo as $nk=>$nv){
  74. if($nk>4)break;
  75. $nv['last_total_num'] = 0;
  76. $newGoodsData[] = $nv;
  77. }
  78. }else{
  79. $count = 0;
  80. $lastGoodsIdArr = [];
  81. foreach($lastOrderGoodsInfo as $lk=>$lv){
  82. $count++;
  83. array_push($lastGoodsIdArr,$lv['goods_id']);
  84. if($lk>4)break;
  85. foreach($nowOrderGoodsInfo as $nk=>$nv){
  86. $lv['now_total_num'] = 0;
  87. if($lv['goods_id'] == $nv['goods_id'] ){
  88. $lv['now_total_num'] = $nv['now_total_num'];
  89. break;
  90. }
  91. }
  92. $newGoodsData[] =$lv;
  93. }
  94. if($count<5){
  95. foreach($nowOrderGoodsInfo as &$nv){
  96. if($count>=5) break;
  97. if(in_array($nv['goods_id'],$lastGoodsIdArr)) continue;
  98. $nv['last_total_num'] = 0;
  99. $nv['growth'] = '100%';
  100. $nv['type'] = 1;
  101. $count ++;
  102. $newGoodsData[] = $nv;
  103. }
  104. }
  105. }
  106. }
  107. foreach ($newGoodsData as &$ngv){
  108. if($ngv['last_total_num']==0){
  109. $ngv['growth'] = '100%';
  110. $ngv['type'] = 1;
  111. }else{
  112. if($ngv['last_total_num'] < $ngv['now_total_num']){
  113. $ngv['growth'] = round(($ngv['now_total_num'] - $ngv['last_total_num'])/$ngv['last_total_num']*100 ,0). '%';
  114. $ngv['type'] = 1;
  115. }else if($ngv['last_total_num'] > $ngv['now_total_num']){
  116. $ngv['growth'] = round(($ngv['last_total_num'] - $ngv['now_total_num'])/$ngv['last_total_num']*100 ,0). '%';
  117. $ngv['type'] = 0;
  118. }else{
  119. $ngv['growth'] = 0;
  120. $ngv['type'] = 1;
  121. }
  122. }
  123. $ngv['name'] = mb_substr( $ngv['name'], 0, 6, "UTF-8") . '....' ;
  124. }
  125. return view('/count/index', ['newGoodsData' => $newGoodsData]);
  126. }
  127. }