Dashboard.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\model\Admin;
  4. use app\admin\model\User;
  5. use app\common\controller\Backend;
  6. use app\common\model\Attachment;
  7. use fast\Date;
  8. use think\Db;
  9. /**
  10. * 控制台
  11. *
  12. * @icon fa fa-dashboard
  13. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  14. */
  15. class Dashboard 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. $column = [];
  27. $starttime = Date::unixtime('day', -6);
  28. $endtime = Date::unixtime('day', 0, 'end');
  29. $joinlist = Db("user")->where('jointime', 'between time', [$starttime, $endtime])
  30. ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
  31. ->group('join_date')
  32. ->select();
  33. for ($time = $starttime; $time <= $endtime;) {
  34. $column[] = date("Y-m-d", $time);
  35. $time += 86400;
  36. }
  37. $userlist = array_fill_keys($column, 0);
  38. foreach ($joinlist as $k => $v) {
  39. $userlist[$v['join_date']] = $v['nums'];
  40. }
  41. $dbTableList = Db::query("SHOW TABLE STATUS");
  42. $addonList = get_addon_list();
  43. $totalworkingaddon = 0;
  44. $totaladdon = count($addonList);
  45. foreach ($addonList as $index => $item) {
  46. if ($item['state']) {
  47. $totalworkingaddon += 1;
  48. }
  49. }
  50. $this->view->assign([
  51. 'totaluser' => User::count(),
  52. 'totaladdon' => $totaladdon,
  53. 'totaladmin' => Admin::count(),
  54. 'totalcategory' => \app\common\model\Category::count(),
  55. 'todayusersignup' => User::whereTime('jointime', 'today')->count(),
  56. 'todayuserlogin' => User::whereTime('logintime', 'today')->count(),
  57. 'sevendau' => User::whereTime('jointime|logintime|prevtime', '-7 days')->count(),
  58. 'thirtydau' => User::whereTime('jointime|logintime|prevtime', '-30 days')->count(),
  59. 'threednu' => User::whereTime('jointime', '-3 days')->count(),
  60. 'sevendnu' => User::whereTime('jointime', '-7 days')->count(),
  61. 'dbtablenums' => count($dbTableList),
  62. 'dbsize' => array_sum(array_map(function ($item) {
  63. return $item['Data_length'] + $item['Index_length'];
  64. }, $dbTableList)),
  65. 'totalworkingaddon' => $totalworkingaddon,
  66. 'attachmentnums' => Attachment::count(),
  67. 'attachmentsize' => Attachment::sum('filesize'),
  68. 'picturenums' => Attachment::where('mimetype', 'like', 'image/%')->count(),
  69. 'picturesize' => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'),
  70. ]);
  71. $this->assignconfig('column', array_keys($userlist));
  72. $this->assignconfig('userdata', array_values($userlist));
  73. $date = date('Y-m-d');
  74. $company_id = $_SESSION['think']['admin']['company_id'];//查询对应公司id
  75. //配方单
  76. $formuladate = Db::name('formula')->where('company_id',$company_id)->where('create',">",$date)->count();
  77. $this->view->assign('formuladate',$formuladate);
  78. $formula = Db::name('formula')->where('company_id',$company_id)->count();
  79. $this->view->assign('formula',$formula);
  80. //订单
  81. $orderdate = Db::name('order')->where('company_id',$company_id)->where('create',">",$date)->count();
  82. $this->view->assign('orderdate',$orderdate);
  83. $order = Db::name('order')->where('company_id',$company_id)->count();
  84. $this->view->assign('order',$order);
  85. //库存
  86. $stockdate = Db::name('stock')->where('company_id',$company_id)->where('create',">",$date)->count();
  87. $this->view->assign('stockdate',$stockdate);
  88. $stock = Db::name('stock')->where('company_id',$company_id)->count();
  89. $this->view->assign('stock',$stock);
  90. //管理员
  91. $admin = Db::name('admin')->where('company_id',$company_id)->count();
  92. $this->view->assign('admin',$admin);
  93. return $this->view->fetch();
  94. }
  95. public function ecDashboard(){
  96. $company_id = $_SESSION['think']['admin']['company_id'];//查询对应公司id
  97. /**
  98. * 查出此公司一周内每一天的订单数量,返回到前台
  99. * 1、组合日期数组
  100. * 2、根据日期循环查询订单量,返回数据
  101. */
  102. $date = strtotime(date('Y-m-d'));
  103. $oneDay = 24*60*60;
  104. $data = array();
  105. for ($i=6;$i>=0;$i--){
  106. if ($i == 0){
  107. $data[$i] = date('Y-m-d',$date);
  108. }else{
  109. $data[$i] = date('Y-m-d',$date - $oneDay * $i);
  110. }
  111. }
  112. sort($data);//数组重新拍序
  113. $order = array();
  114. foreach ($data as $key=>$value){
  115. /**
  116. * 拼接下日期,查询当日0点到24点
  117. */
  118. $map = array();
  119. $start_value = $value.' 00:00:00';
  120. $end_value = $value.' 24:00:00';
  121. $map['create'] = array('between time',[$start_value,$end_value]);
  122. $order[$key] = Db::name('order')->where('company_id',$company_id)->where($map)->count();
  123. }
  124. return $order;
  125. }
  126. function getDateFromRange($startdate, $enddate)
  127. {
  128. $stimestamp = strtotime($startdate);
  129. $etimestamp = strtotime($enddate);
  130. // 计算日期段内有多少天
  131. $days = ($etimestamp - $stimestamp) / 86400 + 1;
  132. // 保存每天日期
  133. $date = array();
  134. for ($i = 0; $i < $days; $i++) {
  135. $date[] = date('Y-m-d', $stimestamp + (86400 * $i));
  136. }
  137. return $date;
  138. }
  139. }