Dashboard.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\model\Admin;
  4. use app\admin\model\User;
  5. use app\admin\model\pig\Order;
  6. use app\common\controller\Backend;
  7. use app\common\model\Attachment;
  8. use fast\Date;
  9. use think\Db;
  10. use think\Cache;
  11. /**
  12. * 控制台
  13. *
  14. * @icon fa fa-dashboard
  15. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  16. */
  17. class Dashboard extends Backend
  18. {
  19. //定义协会 进出
  20. protected $_assoc = [
  21. 'out'=>[2],//安徽协会 产地
  22. 'in'=>[5],//上海协会 销售地
  23. ];
  24. /**
  25. * 查看
  26. */
  27. public function index()
  28. {
  29. try {
  30. \think\Db::execute("SET @@sql_mode='';");
  31. } catch (\Exception $e) {
  32. }
  33. $adminid = $this->auth->id;
  34. $where = [];
  35. if (in_array($adminid, $this->_assoc['in'])) {//销售地
  36. $province = 'province_id';
  37. //SELECT * ,COUNT(*) AS s FROM `pi_p_order` WHERE province_id = 1 GROUP BY company_id
  38. //SELECT c.name,COUNT(*) AS num ,SUM(num) AS sums FROM `pi_p_order` AS o LEFT JOIN `pi_p_company` AS c ON o.`company_id` = c.id WHERE o.province_id = 1 AND o.createtime>1122 AND o.`createtime`<234 GROUP BY o.company_id
  39. } elseif (in_array($adminid, $this->_assoc['out'])) {//产地
  40. $province = 'source_id';
  41. //SELECT * ,COUNT(*) AS s FROM `pi_p_order` WHERE source_id = 1 GROUP BY customer_id
  42. } else {//屠宰场
  43. $province = 'source_id';
  44. ////SELECT * ,COUNT(*) AS s FROM `pi_p_order` WHERE source_id = 1 GROUP BY customer_id
  45. }
  46. $where[$province] = ['in',$this->auth->province_id];
  47. //缓存图表
  48. $key = __FILE__.__FUNCTION__.'orders'.json_encode($adminid);
  49. $orders = Cache::get($key);
  50. if (!$orders) {
  51. $column = [];
  52. $starttime = Date::unixtime('day', -6);
  53. $endtime = Date::unixtime('day', 0, 'end');
  54. //$joinlist = Db("p_order")->where('jointime', 'between time', [$starttime, $endtime])->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
  55. $joinlist = Db("p_order")->where($where)->field('createtime, status,COUNT(*) AS nums, SUM(num) AS sum, DATE_FORMAT(FROM_UNIXTIME(createtime), "%Y-%m-%d") AS join_date')
  56. ->group('join_date')
  57. ->select();
  58. for ($time = $starttime; $time <= $endtime;) {
  59. $column[] = date("Y-m-d", $time);
  60. $time += 86400;
  61. }
  62. $codelist = array_fill_keys($column, 0);//sum
  63. $orderlist = array_fill_keys($column, 0);//count
  64. foreach ($joinlist as $k => $v) {
  65. $codelist[$v['join_date']] = $v['sum'];
  66. $orderlist[$v['join_date']] = $v['nums'];
  67. }
  68. $dbTableList = Db::query("SHOW TABLE STATUS");
  69. $datalist = [
  70. 'totalcode' => Order::where($where)->sum('num'),//码总数
  71. 'totalorder' => Order::where($where)->count(),//订单总数
  72. //'totaladdon' => count(get_addon_list()),
  73. //'totaladmin' => Admin::count();
  74. 'todaycode' => Order::where($where)->whereTime('createtime', 'today')->sum('num'),//码总数
  75. 'todayorder' => Order::where($where)->whereTime('createtime', 'today')->count(),//订单总数
  76. 'sevencode' => Order::where($where)->whereTime('createtime', '-7 days')->sum('num'),
  77. 'sevenorder' => Order::where($where)->whereTime('createtime', '-7 days')->count(),
  78. 'thirtycode' => Order::where($where)->whereTime('createtime', '-30 days')->sum('num'),
  79. 'thirtyorder' => Order::where($where)->whereTime('createtime', '-30 days')->count(),
  80. 'totalcategory' => \app\common\model\Category::count(),
  81. 'dbtablenums' => count($dbTableList),
  82. 'dbsize' => array_sum(array_map(function ($item) {
  83. return $item['Data_length'] + $item['Index_length'];
  84. }, $dbTableList)),
  85. 'attachmentnums' => Attachment::count(),
  86. 'attachmentsize' => Attachment::sum('filesize'),
  87. 'picturenums' => Attachment::where('mimetype', 'like', 'image/%')->count(),
  88. 'picturesize' => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'),
  89. ];
  90. $orders = [];
  91. $orders['codelist'] = $codelist;
  92. $orders['orderlist'] = $orderlist;
  93. $orders['datalist'] = $datalist;
  94. Cache::set($key, $orders, 300);
  95. }
  96. $this->view->assign($orders['datalist']);
  97. $this->assignconfig('column', array_keys($orders['codelist']));
  98. $this->assignconfig('codelistdata', array_values($orders['codelist']));
  99. $this->assignconfig('orderlistdata', array_values($orders['orderlist']));
  100. $this->assign('isadmin', $this->auth->id == 1);
  101. return $this->view->fetch();
  102. }
  103. }