IndexController.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  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\asset\AssetLeaseInfo;
  21. use app\common\model\Order;
  22. use app\common\model\OrderGoods;
  23. use app\common\model\GoodsCategory as GoodsCategoryModel;
  24. use app\common\model\Goods;
  25. use app\common\model\Distribution;
  26. use app\common\model\AfterSale;
  27. use think\facade\Config;
  28. /**
  29. * 配置控制器
  30. * Class ConfigController
  31. * @package app\adminapi\controller
  32. */
  33. class IndexController extends BaseAdminController
  34. {
  35. public array $notNeedLogin = ['index'];
  36. public function index()
  37. {
  38. /** 商品统计 start **/
  39. // 获取上个月的第一天
  40. $firstDayOfLastMonth = strtotime(date('Y-m-01', strtotime('last month')));
  41. // 获取上个月最后一天
  42. $lastDayOfLastMonth = strtotime(date('Y-m-t', strtotime('last month')) . ' 23:59:59');
  43. // 获取上个月的第一天
  44. $firstDayOfNowMonth = strtotime(date('Y-m-01'));
  45. // 获取上个月最后一天
  46. $lastDayOfNowMonth = strtotime(date('Y-m-t') . ' 23:59:59');
  47. $where = [];
  48. $whereTime = [];
  49. $whereLastTime[] = ['o.create_time', 'between', [$firstDayOfLastMonth, $lastDayOfLastMonth]];
  50. $whereNowTime[] = ['o.create_time', 'between', [$firstDayOfNowMonth, $lastDayOfNowMonth]];
  51. $where[] = ['o.pay_status', '=', 1];
  52. //上月销量
  53. $lastOrderGoodsInfo = OrderGoods::alias('og')->leftJoin('order o', 'o.id = og.order_id')
  54. ->field('og.goods_id,og.goods_name name,sum(og.goods_num) last_total_num')
  55. ->where($where)->where($whereLastTime)
  56. ->group('og.goods_id,og.goods_name')
  57. ->order('last_total_num desc')
  58. ->select()->toArray();
  59. //本月销量
  60. $nowOrderGoodsInfo = OrderGoods::alias('og')->leftJoin('order o', 'o.id = og.order_id')
  61. ->field('og.goods_id,og.goods_name name,sum(og.goods_num) now_total_num')
  62. ->where($where)->where($whereNowTime)
  63. ->group('og.goods_id,og.goods_name')
  64. ->order('now_total_num desc')
  65. ->select()->toArray();
  66. $newGoodsData = [];
  67. if (count($lastOrderGoodsInfo) > 5) {
  68. foreach ($lastOrderGoodsInfo as $lk => $lv) {
  69. if ($lk > 4) break;
  70. foreach ($nowOrderGoodsInfo as $nk => $nv) {
  71. $lastOrderGoodsInfo[$lk]['now_total_num'] = 0;
  72. if ($lv['goods_id'] == $nv['goods_id']) {
  73. $lv['now_total_num'] = $nv['now_total_num'];
  74. break;
  75. }
  76. }
  77. $newGoodsData[] = $lv;
  78. }
  79. } else {
  80. if (empty($lastOrderGoodsInfo)) {
  81. foreach ($nowOrderGoodsInfo as $nk => $nv) {
  82. if ($nk > 4) break;
  83. $nv['last_total_num'] = 0;
  84. $newGoodsData[] = $nv;
  85. }
  86. } else {
  87. $count = 0;
  88. $lastGoodsIdArr = [];
  89. foreach ($lastOrderGoodsInfo as $lk => $lv) {
  90. $count++;
  91. array_push($lastGoodsIdArr, $lv['goods_id']);
  92. if ($lk > 4) break;
  93. foreach ($nowOrderGoodsInfo as $nk => $nv) {
  94. $lv['now_total_num'] = 0;
  95. if ($lv['goods_id'] == $nv['goods_id']) {
  96. $lv['now_total_num'] = $nv['now_total_num'];
  97. break;
  98. }
  99. }
  100. $newGoodsData[] = $lv;
  101. }
  102. if ($count < 5) {
  103. foreach ($nowOrderGoodsInfo as &$nv) {
  104. if ($count >= 5) break;
  105. if (in_array($nv['goods_id'], $lastGoodsIdArr)) continue;
  106. $nv['last_total_num'] = 0;
  107. $nv['growth'] = '100%';
  108. $nv['type'] = 1;
  109. $count++;
  110. $newGoodsData[] = $nv;
  111. }
  112. }
  113. }
  114. }
  115. foreach ($newGoodsData as &$ngv) {
  116. if ($ngv['last_total_num'] == 0) {
  117. $ngv['growth'] = '100%';
  118. $ngv['type'] = 1;
  119. } else {
  120. if(isset($ngv['now_total_num'])){
  121. }else{
  122. $ngv['now_total_num'] = 0;
  123. }
  124. if ($ngv['last_total_num'] < $ngv['now_total_num']) {
  125. $ngv['growth'] = round(($ngv['now_total_num'] - $ngv['last_total_num']) / $ngv['last_total_num'] * 100, 0) . '%';
  126. $ngv['type'] = 1;
  127. } else if ($ngv['last_total_num'] > $ngv['now_total_num']) {
  128. $ngv['growth'] = round(($ngv['last_total_num'] - $ngv['now_total_num']) / $ngv['last_total_num'] * 100, 0) . '%';
  129. $ngv['type'] = 0;
  130. } else {
  131. $ngv['growth'] = 0;
  132. $ngv['type'] = 1;
  133. }
  134. }
  135. $ngv['name'] = mb_substr($ngv['name'], 0, 6, "UTF-8") . '....';
  136. }
  137. $data['newGoodsData'] = $newGoodsData;
  138. /** 商品统计 end **/
  139. /** 分类销量排名 start**/
  140. $ogcwhere = [];
  141. // $ogcwhere[] = ['gc.level', '=', '1'];
  142. $OrderGoodsCategoryInfos = OrderGoods::alias('og')
  143. ->leftJoin('order o', 'o.id = og.order_id')
  144. ->leftJoin('goods g', 'g.id = og.goods_id')
  145. ->leftJoin('goods_category_index gci', 'gci.goods_id=g.id')
  146. ->leftJoin('goods_category gc', 'gc.id = gci.category_id')
  147. ->field('gc.id,gc.`name` ,gc.pid,sum( og.goods_num) total_num')
  148. ->where($where)->where($ogcwhere)
  149. ->group('gc.name')
  150. ->select()->toArray();
  151. $OrderGoodsCategoryInfo = [];
  152. foreach($OrderGoodsCategoryInfos as &$ogcv){
  153. $pid = $ogcv['pid'];
  154. $id = $ogcv['id'];
  155. $new_data=[];
  156. $name = $ogcv['name'];
  157. $total_num = $ogcv['total_num'];
  158. while($pid){
  159. if($pid == 0){
  160. break;
  161. }else{
  162. $categoryInfo = GoodsCategoryModel::find($pid);
  163. $pid = $categoryInfo['pid'];
  164. $id = $categoryInfo['id'];
  165. $name = $categoryInfo['name'];
  166. }
  167. }
  168. if(isset($OrderGoodsCategoryInfo[$id])){
  169. $new_total_num = $OrderGoodsCategoryInfo[$id]['total_num']+$total_num;
  170. $OrderGoodsCategoryInfo[$id]['total_num'] = $new_total_num;
  171. }else{
  172. $new_data['total_num'] = $total_num;
  173. $new_data['name'] = $name;
  174. $OrderGoodsCategoryInfo[$id] = $new_data;
  175. }
  176. }
  177. $goods_category_data = array_column($OrderGoodsCategoryInfo, 'total_num');
  178. $data['order_goods_category'] = $OrderGoodsCategoryInfo;
  179. $count = count($goods_category_data);
  180. while ($count) {
  181. if ($count < 3) {
  182. array_push($goods_category_data, 0);
  183. } else {
  184. break;
  185. }
  186. $count = count($goods_category_data);
  187. }
  188. $data['goods_category_data'] = json_encode($goods_category_data);
  189. $ogcK = 0;
  190. $chars_category = [];
  191. foreach ($OrderGoodsCategoryInfo as $ogcv) {
  192. $ogcK++;
  193. $random_data = [30, 20, 50, 40, 100, 200, 300];
  194. shuffle($random_data);
  195. $randomValue = $random_data[2];
  196. $max = substr($ogcv['total_num'] + $randomValue, 0, -1) . '0';
  197. $ogcv['max'] = $max;
  198. unset($ogcv['total_num']);
  199. $chars_category[] = $ogcv;
  200. }
  201. while ($ogcK) {
  202. $categorys['name'] = '填充';
  203. $categorys['max'] = '0';
  204. if ($ogcK < 3) {
  205. $chars_category[] = $categorys;
  206. } else {
  207. break;
  208. }
  209. $ogcK++;
  210. }
  211. $data['chars_category'] = json_encode($chars_category);
  212. /** 分类销量排名 end**/
  213. /** middle start **/
  214. //商品数量
  215. $goodswhere = [];
  216. $goodswhere[] = ['status', '=', 1];
  217. $goodswhere[] = ['delete_time', '=', NULL];
  218. $goods_count = Goods::where($goodswhere)->count();
  219. $middle['goods_number'] = $goods_count;
  220. //合作商
  221. $diswhere = [];
  222. $diswhere[] = ['is_distribution', '=', 1];
  223. $diswhere[] = ['delete_time', '=', NULL];
  224. $distribution_count = Distribution::where($diswhere)->count();
  225. $middle['distribution_number'] = $distribution_count;
  226. //订单数
  227. $order_where = [];
  228. $order_where[] = ['pay_status', '=', 1];
  229. $order_count = Order::where($order_where)->count();
  230. $middle['order_number'] = $order_count;
  231. //派送订单
  232. $orderwhere = [];
  233. $orderwhere[] = ['order_status', '=', 2];
  234. $order_delivery_count = Order::where($orderwhere)->count();
  235. $middle['delivery_number'] = $order_delivery_count;
  236. //农资供应
  237. $middle['agricultural_supply_number'] = 0;
  238. $nowYear = date('Y');
  239. $nowMonth = date('n');
  240. $monthData = [];
  241. $monthArr = [];
  242. for ($i = 1; $i <= $nowMonth; $i++) {
  243. array_push($monthArr, $i);
  244. $monthFat = $i . '月';
  245. array_push($monthData, $monthFat);
  246. }
  247. $middle['YearData'] = $nowYear;
  248. $middle['MonthFormatData'] = json_encode($monthData);
  249. $month_data = [];
  250. foreach ($monthArr as $mv) {
  251. $date = getMonthFirstAndLastDay($nowYear, $mv);
  252. $startTime = strtotime($date['firstDay']);
  253. $endTime = strtotime($date['lastDay'] . ' 23:59:59');
  254. $create_time_date = [$startTime, $endTime];
  255. $salewhere = [];
  256. $salewhere[] = ['create_time', 'between', $create_time_date];
  257. $month_order_number = Order::alias('o')->where($where)->where($salewhere)->count();
  258. array_push($month_data, $month_order_number);
  259. }
  260. $middle['MonthOrderData'] = json_encode($month_data);
  261. $nowTime = time();
  262. $todayStartDate = date('Y-m-d');
  263. $todaywhere = [];
  264. $todaywhere[] = ['create_time', 'between', [strtotime($todayStartDate), $nowTime]];
  265. $todayOrderInfo = Order::alias('o')->where($where)->where($todaywhere)->field('count(id) number,sum(total_amount) total_money')->find();
  266. $middle['today_order_number'] = $todayOrderInfo['number'];
  267. $middle['today_total_amount'] = $todayOrderInfo['total_money'] ?? 0;
  268. $thisMonth = date('n');
  269. $this_month_date = getMonthFirstAndLastDay($nowYear, $thisMonth);
  270. $startTime = strtotime($this_month_date['firstDay']);
  271. $endTime = strtotime($this_month_date['lastDay'] . ' 23:59:59');
  272. $create_time_date = [$startTime, $endTime];
  273. $thisMonthWhere = [];
  274. $thisMonthWhere[] = ['create_time', 'between', $create_time_date];
  275. $thisMonthOrderInfo = Order::alias('o')->where($where)->where($thisMonthWhere)->field('count(id) number,sum(total_amount) total_money')->find();
  276. $middle['this_month_order_number'] = $thisMonthOrderInfo['number'];
  277. $middle['this_month_total_amount'] = $thisMonthOrderInfo['total_money'] ?? 0;
  278. $data['middle'] = $middle;
  279. /** middle end **/
  280. /**下单退款 start**/
  281. $order_refund['MonthData'] = json_encode($monthArr);
  282. $order_month_info = [];
  283. $refund_month_info = [];
  284. foreach ($monthArr as $mv) {
  285. $date = getMonthFirstAndLastDay($nowYear, $mv);
  286. $startTime = strtotime($date['firstDay']);
  287. $endTime = strtotime($date['lastDay'] . ' 23:59:59');
  288. $create_time_date = [$startTime, $endTime];
  289. $salewhere = [];
  290. $salewhere[] = ['create_time', 'between', $create_time_date];
  291. $month_order_number = Order::alias('o')->where($where)->where($salewhere)->count();
  292. array_push($order_month_info, $month_order_number);
  293. $salewhere[]=['status','in',[1,2]];
  294. $month_refund_number = AfterSale::where($salewhere)->count();
  295. array_push($refund_month_info,$month_refund_number);
  296. }
  297. $order_refund['order_month_info'] = json_encode($order_month_info);
  298. $order_refund['refund_month_info'] = json_encode($refund_month_info);
  299. $data['order_refund_info'] = $order_refund;
  300. /**下单退款 end **/
  301. /**资产数据 start**/
  302. $leave_unused_num = 0;
  303. $unused_rate = 0;
  304. $unlease = 0;
  305. $leaseing = 0;
  306. $leaseend = 0;
  307. $demain = 'https://admin.gxsmlt.com/';
  308. // $demain = 'http://zhgx.asset.deom.com/';
  309. $asset_url = $demain.'/adminapi/asset.asset/getAssetData';
  310. $asset_info = httpRequest($asset_url);
  311. $asset_info = json_decode($asset_info,true);
  312. if($asset_info['code']==1){
  313. $a_data = $asset_info['data'];
  314. $leave_unused_num = $a_data['leave_unused_num'];
  315. $unused_rate = $a_data['unused_rate'];
  316. foreach($a_data['asset_list'] as $asv){
  317. switch ($asv['lease_status']){
  318. case 1:
  319. $unlease = $asv['total_number'];
  320. break;
  321. case 2:
  322. $leaseing = $asv['total_number'];
  323. break;
  324. case 3:
  325. $leaseend = $asv['total_number'];
  326. break;
  327. }
  328. }
  329. }
  330. $total_asset_num = $unlease + $leaseing + $leaseend;
  331. $asset_infos['leave_unused_num']=$leave_unused_num;
  332. $asset_infos['unused_rate']=round($unused_rate,0);
  333. $asset_infos['unlease']=$unlease;
  334. $asset_infos['leaseing']=$leaseing;
  335. $asset_infos['leaseend']=$leaseend;
  336. $asset_infos['total_asset_num']=$total_asset_num;
  337. $data['asset_info'] = $asset_infos;
  338. $data['asset_lease_info'] = json_encode($a_data['pay_info']);
  339. /**资产数据 end**/
  340. /* 社会化服务 start*/
  341. $user_service_demain = 'https://info.gxsmlt.com/';
  342. // $user_service_demain = 'http://www.zhgx.info.com/';
  343. $user_service_url = $user_service_demain.'/adminapi/agricultural_machinery.UserService/getUserServiceData';
  344. $user_service_info = httpRequest($user_service_url);
  345. // dump($user_service_info);die;
  346. $service_info = json_decode($user_service_info,true);
  347. $service_data['cate_name'] = json_encode($service_info['data']['cate_name']);
  348. $service_data['cate_value'] = json_encode($service_info['data']['cate_value']);
  349. $service_data['user_service_value'] = json_encode($service_info['data']['user_service_value']);
  350. $service_data['SupplyDemandInfo'] = json_encode($service_info['data']['SupplyDemandInfo']);
  351. $service_data['supply_cate_name'] = json_encode($service_info['data']['supply_cate_name']);
  352. $service_data['supply_cate_value'] = json_encode($service_info['data']['supply_cate_value']);
  353. $supply_first_cate_list = $service_info['data']['supply_first_cate_name'];
  354. $list = $service_info['data']['SupplyDemandInfo'];
  355. $con = ['co01','co03','co02','co05','co04'];
  356. foreach($list as &$lv){
  357. $randomKey = array_rand($con);
  358. $lv['co'] = $con[$randomKey];
  359. }
  360. $service_data['SupplyDemandList'] = $list ;
  361. $cons = ['co01','co03','co02','co05','co04'];
  362. foreach($supply_first_cate_list as &$sfcl){
  363. $randomKeys = array_rand($cons);
  364. $sfcl['co'] = $cons[$randomKeys];
  365. }
  366. $service_data['supply_first_cate_list'] = $supply_first_cate_list ;
  367. $service_data['monthData'] = json_encode($service_info['data']['monthData']);
  368. $service_data['agricultural_data'] = json_encode($service_info['data']['agricultural_data']);
  369. $service_data['bake_data'] = json_encode($service_info['data']['bake_data']);
  370. $service_data['air_data'] = json_encode($service_info['data']['air_data']);
  371. $data['service_info'] = $service_data;
  372. /* 社会化服务 end*/
  373. return view('/count/index', $data);
  374. }
  375. }