|
@@ -4,10 +4,12 @@ namespace app\admin\controller;
|
|
|
|
|
|
use app\admin\model\Admin;
|
|
|
use app\admin\model\User;
|
|
|
+use app\admin\model\pig\Order;
|
|
|
use app\common\controller\Backend;
|
|
|
use app\common\model\Attachment;
|
|
|
use fast\Date;
|
|
|
use think\Db;
|
|
|
+use think\Cache;
|
|
|
|
|
|
/**
|
|
|
* 控制台
|
|
@@ -18,6 +20,12 @@ use think\Db;
|
|
|
class Dashboard extends Backend
|
|
|
{
|
|
|
|
|
|
+ //定义协会 进出
|
|
|
+ protected $_assoc = [
|
|
|
+ 'out'=>[2],//安徽协会 产地
|
|
|
+ 'in'=>[5],//上海协会 销售地
|
|
|
+ ];
|
|
|
+
|
|
|
/**
|
|
|
* 查看
|
|
|
*/
|
|
@@ -26,36 +34,55 @@ class Dashboard extends Backend
|
|
|
try {
|
|
|
\think\Db::execute("SET @@sql_mode='';");
|
|
|
} catch (\Exception $e) {
|
|
|
+ }
|
|
|
+
|
|
|
+ $adminid = $this->auth->id;
|
|
|
|
|
|
+ $where = [];
|
|
|
+ if (in_array($adminid, $this->_assoc['in'])) {//销售地
|
|
|
+ $province = 'province_id';
|
|
|
+ } elseif (in_array($adminid, $this->_assoc['out'])) {//产地
|
|
|
+ $province = 'source_id';
|
|
|
+ } else {//屠宰场
|
|
|
+ $province = 'source_id';
|
|
|
}
|
|
|
- $column = [];
|
|
|
- $starttime = Date::unixtime('day', -6);
|
|
|
- $endtime = Date::unixtime('day', 0, 'end');
|
|
|
- $joinlist = Db("user")->where('jointime', 'between time', [$starttime, $endtime])
|
|
|
- ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
|
|
|
+
|
|
|
+ $where[$province] = ['in',$this->auth->province_id];
|
|
|
+
|
|
|
+ //缓存图表
|
|
|
+ $key = __FILE__.__FUNCTION__.'orders'.json_encode($adminid);
|
|
|
+ $orders = Cache::get($key);
|
|
|
+ if (!$orders) {
|
|
|
+ $column = [];
|
|
|
+ $starttime = Date::unixtime('day', -6);
|
|
|
+ $endtime = Date::unixtime('day', 0, 'end');
|
|
|
+ //$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')
|
|
|
+ $joinlist = Db("p_order")->where($where)->field('createtime, status, SUM(num) AS nums, DATE_FORMAT(FROM_UNIXTIME(createtime), "%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'];
|
|
|
- }
|
|
|
+ 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");
|
|
|
+ $datalist = [
|
|
|
+ 'totalcode' => Order::where($where)->sum('num'),//码总数
|
|
|
+ 'totalorder' => Order::where($where)->count(),//订单总数
|
|
|
+ //'totaladdon' => count(get_addon_list()),
|
|
|
+ //'totaladmin' => Admin::count();
|
|
|
+ 'todaycode' => Order::where($where)->whereTime('createtime', 'today')->sum('num'),//码总数
|
|
|
+ 'todayorder' => Order::where($where)->whereTime('createtime', 'today')->count(),//订单总数
|
|
|
+ 'sevencode' => Order::where($where)->whereTime('createtime', '-7 days')->sum('num'),
|
|
|
+ 'sevenorder' => Order::where($where)->whereTime('createtime', '-7 days')->count(),
|
|
|
+ 'thirtycode' => Order::where($where)->whereTime('createtime', '-30 days')->sum('num'),
|
|
|
+ 'thirtyorder' => Order::where($where)->whereTime('createtime', '-30 days')->count(),
|
|
|
|
|
|
- $dbTableList = Db::query("SHOW TABLE STATUS");
|
|
|
- $this->view->assign([
|
|
|
- 'totaluser' => User::count(),
|
|
|
- 'totaladdon' => count(get_addon_list()),
|
|
|
- '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'];
|
|
@@ -64,12 +91,20 @@ class Dashboard extends Backend
|
|
|
'attachmentsize' => Attachment::sum('filesize'),
|
|
|
'picturenums' => Attachment::where('mimetype', 'like', 'image/%')->count(),
|
|
|
'picturesize' => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'),
|
|
|
- ]);
|
|
|
+ ];
|
|
|
+
|
|
|
+ $orders = [];
|
|
|
+ $orders['userlist'] = $userlist;
|
|
|
+ $orders['datalist'] = $datalist;
|
|
|
+ Cache::set($key, $orders, 300);
|
|
|
+ }
|
|
|
+
|
|
|
+ $this->view->assign($orders['datalist']);
|
|
|
+ $this->assignconfig('column', array_keys($orders['userlist']));
|
|
|
+ $this->assignconfig('userdata', array_values($orders['userlist']));
|
|
|
|
|
|
- $this->assignconfig('column', array_keys($userlist));
|
|
|
- $this->assignconfig('userdata', array_values($userlist));
|
|
|
+ $this->assign('isadmin', $this->auth->id == 1);
|
|
|
|
|
|
return $this->view->fetch();
|
|
|
}
|
|
|
-
|
|
|
}
|