where('jointime', 'between time', [$starttime, $endtime]) ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date') ->group('join_date') ->select(); for ($time = $starttime; $time <= $endtime;) { $column[] = date("Y-m-d", $time); $time += 86400; } $userlist = array_fill_keys($column, 0); foreach ($joinlist as $k => $v) { $userlist[$v['join_date']] = $v['nums']; } $dbTableList = Db::query("SHOW TABLE STATUS"); $addonList = get_addon_list(); $totalworkingaddon = 0; $totaladdon = count($addonList); foreach ($addonList as $index => $item) { if ($item['state']) { $totalworkingaddon += 1; } } $this->view->assign([ 'totaluser' => User::count(), 'totaladdon' => $totaladdon, 'totaladmin' => Admin::count(), 'totalcategory' => \app\common\model\Category::count(), 'todayusersignup' => User::whereTime('jointime', 'today')->count(), 'todayuserlogin' => User::whereTime('logintime', 'today')->count(), 'sevendau' => User::whereTime('jointime|logintime|prevtime', '-7 days')->count(), 'thirtydau' => User::whereTime('jointime|logintime|prevtime', '-30 days')->count(), 'threednu' => User::whereTime('jointime', '-3 days')->count(), 'sevendnu' => User::whereTime('jointime', '-7 days')->count(), 'dbtablenums' => count($dbTableList), 'dbsize' => array_sum(array_map(function ($item) { return $item['Data_length'] + $item['Index_length']; }, $dbTableList)), 'totalworkingaddon' => $totalworkingaddon, 'attachmentnums' => Attachment::count(), 'attachmentsize' => Attachment::sum('filesize'), 'picturenums' => Attachment::where('mimetype', 'like', 'image/%')->count(), 'picturesize' => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'), ]); $this->assignconfig('column', array_keys($userlist)); $this->assignconfig('userdata', array_values($userlist)); $date = date('Y-m-d'); $company_id = $_SESSION['think']['admin']['company_id'];//查询对应公司id //配方单 $formuladate = Db::name('formula')->where('company_id',$company_id)->where('date',"<",$date)->count(); $this->view->assign('formuladate',$formuladate); $formula = Db::name('formula')->where('company_id',$company_id)->count(); $this->view->assign('formula',$formula); //订单 $orderdate = Db::name('order')->where('company_id',$company_id)->where('date',"<",$date)->count(); $this->view->assign('orderdate',$orderdate); $order = Db::name('order')->where('company_id',$company_id)->count(); $this->view->assign('order',$order); //库存 $stockdate = Db::name('stock')->where('company_id',$company_id)->where('create',"<",$date)->count(); $this->view->assign('stockdate',$stockdate); $stock = Db::name('stock')->where('company_id',$company_id)->count(); $this->view->assign('stock',$stock); //管理员 $admin = Db::name('admin')->where('company_id',$company_id)->count(); $this->view->assign('admin',$admin); return $this->view->fetch(); } public function ecDashboard(){ // $date = date('Y-m-d 23:59:59',strtotime("last Monday")); $date = date('Y-m-d',strtotime("-6 days")); $end = date('Y-m-d'); $r = $this->getDateFromRange($date,$end); foreach ($r as $k=>$v){ $company_id = $_SESSION['think']['admin']['company_id'];//查询对应公司id $orderdate = Db::name('order')->where('company_id',$company_id)->where('date',">",$v)->select(); if ($orderdate) { return $orderdate; } else { return 0; } } } function getDateFromRange($startdate, $enddate) { $stimestamp = strtotime($startdate); $etimestamp = strtotime($enddate); // 计算日期段内有多少天 $days = ($etimestamp - $stimestamp) / 86400 + 1; // 保存每天日期 $date = array(); for ($i = 0; $i < $days; $i++) { $date[] = date('Y-m-d', $stimestamp + (86400 * $i)); } return $date; } }