Browse Source

总后台

develop
lemon 4 years ago
parent
commit
c25d489dff
  1. 18
      app/Admin/Controllers/HomeController.php
  2. 13
      app/Admin/Metrics/Examples/Dashboard.php
  3. 189
      app/Admin/Metrics/Examples/NewUsers.php
  4. 160
      app/Admin/Metrics/Examples/OrderExamples.php
  5. 203
      app/Admin/Metrics/Examples/ProductOrders.php
  6. 177
      app/Admin/Metrics/Examples/SalesExamples.php
  7. 43
      resources/views/admin/pages/admin-home.blade.php

18
app/Admin/Controllers/HomeController.php

@ -4,7 +4,7 @@ namespace App\Admin\Controllers;
use App\Admin\Metrics\Examples; use App\Admin\Metrics\Examples;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Dcat\Admin\Http\Controllers\Dashboard;
use Dcat\Admin\Admin;
use Dcat\Admin\Layout\Column; use Dcat\Admin\Layout\Column;
use Dcat\Admin\Layout\Content; use Dcat\Admin\Layout\Content;
use Dcat\Admin\Layout\Row; use Dcat\Admin\Layout\Row;
@ -13,13 +13,23 @@ class HomeController extends Controller
{ {
public function index(Content $content) public function index(Content $content)
{ {
Admin::style(
<<<CSS
.col-sm-10.d-flex{
display: inline-block !important;
}
.col-sm-9.d-flex{
display: inline-block !important;
}
CSS
);
return $content return $content
->header('仪表盘') ->header('仪表盘')
->description('数据详情') ->description('数据详情')
->body(function (Row $row) { ->body(function (Row $row) {
$row->column(6, function (Column $column) { $row->column(6, function (Column $column) {
$column->row(Dashboard::title());
$column->row(new Examples\Tickets());
$column->row(Examples\Dashboard::title());
$column->row(new Examples\OrderExamples());
}); });
$row->column(6, function (Column $column) { $row->column(6, function (Column $column) {
@ -28,7 +38,7 @@ class HomeController extends Controller
$row->column(6, new Examples\NewDevices()); $row->column(6, new Examples\NewDevices());
}); });
$column->row(new Examples\Sessions());
$column->row(new Examples\SalesExamples());
$column->row(new Examples\ProductOrders()); $column->row(new Examples\ProductOrders());
}); });
}); });

13
app/Admin/Metrics/Examples/Dashboard.php

@ -0,0 +1,13 @@
<?php
namespace App\Admin\Metrics\Examples;
use Dcat\Admin\Admin;
class Dashboard
{
public static function title()
{
return view('admin::pages.admin-home', ['admin' => Admin::user()]);
}
}

189
app/Admin/Metrics/Examples/NewUsers.php

@ -2,107 +2,118 @@
namespace App\Admin\Metrics\Examples; namespace App\Admin\Metrics\Examples;
use App\Common\DataTime;
use App\Models\User;
use Carbon\Carbon;
use Dcat\Admin\Admin;
use Dcat\Admin\Widgets\Metrics\Line; use Dcat\Admin\Widgets\Metrics\Line;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Arr;
use Illuminate\Support\Facades\DB;
class NewUsers extends Line class NewUsers extends Line
{ {
/**
* 初始化卡片内容
*
* @return void
*/
protected function init()
{
parent::init();
/**
* 初始化卡片内容
*
* @return void
*/
protected function init()
{
parent::init();
$this->title('New Users');
$this->dropdown([
'7' => 'Last 7 Days',
'28' => 'Last 28 Days',
'30' => 'Last Month',
'365' => 'Last Year',
]);
}
$this->title('新增用户');
$this->dropdown([
//'day' => '本日',
'week' => '本周',
'month' => '本月',
//'year' => '今年',
]);
}
/**
* 处理请求
*
* @param Request $request
*
* @return mixed|void
*/
public function handle(Request $request)
{
$generator = function ($len, $min = 10, $max = 300) {
for ($i = 0; $i <= $len; $i++) {
yield mt_rand($min, $max);
}
};
/**
* 处理请求
*
* @param Request $request
*
* @return mixed|void
*/
public function handle(Request $request)
{
$count = User::query();
$user = User::query()
->select('*')
->addSelect(DB::raw("COUNT(id) as count_id,CONCAT(YEAR(created_at),'-',MONTH(created_at),'-',DAY(created_at)) AS statistics_time"));
switch ($request->get('option')) {
case 'day':
$count->whereDate('created_at', Carbon::today());
$user->whereDate('created_at', Carbon::today());
break;
case 'week':
$time = DataTime::beginAndEnd('week');
$count->whereBetween('created_at', $time);
$user->whereBetween('created_at', $time);
break;
case 'month':
$count->whereMonth('created_at', Carbon::now()->month);
$user->whereMonth('created_at', Carbon::now()->month);
break;
case 'year':
$count->whereYear('created_at', Carbon::now()->year);
$user->whereYear('created_at', Carbon::now()->year);
break;
default:
$time = DataTime::beginAndEnd('week');
$count->whereBetween('created_at', $time);
$user->whereBetween('created_at', $time);
}
$user = $user->where('agent_id', Admin::user()->id)
->limit(30)
->groupBy('statistics_time')
->get()
->toArray();
$count = $count->count();
$this->withContent($count);
// 图表数据
$this->chartLabels(Arr::pluck($user, 'statistics_time'));
$this->withChart(Arr::pluck($user, 'count_id'));
}
switch ($request->get('option')) {
case '365':
// 卡片内容
$this->withContent(mt_rand(1000, 5000).'k');
// 图表数据
$this->withChart(collect($generator(30))->toArray());
break;
case '30':
// 卡片内容
$this->withContent(mt_rand(400, 1000).'k');
// 图表数据
$this->withChart(collect($generator(30))->toArray());
break;
case '28':
// 卡片内容
$this->withContent(mt_rand(400, 1000).'k');
// 图表数据
$this->withChart(collect($generator(28))->toArray());
break;
case '7':
default:
// 卡片内容
$this->withContent('89.2k');
// 图表数据
$this->withChart([28, 40, 36, 52, 38, 60, 55,]);
}
}
/**
* 设置图表数据.
*
* @param array $data
*
* @return \App\Admin\Metrics\Examples\NewUsers
*/
public function withChart(array $data)
{
return $this->chart([
'series' => [
[
'name' => $this->title,
'data' => $data,
],
],
]);
}
/**
* 设置图表数据.
*
* @param array $data
*
* @return $this
*/
public function withChart(array $data)
{
return $this->chart([
'series' => [
[
'name' => $this->title,
'data' => $data,
],
],
]);
}
/**
* 设置卡片内容.
*
* @param string $content
*
* @return $this
*/
public function withContent($content)
{
return $this->content(
<<<HTML
/**
* 设置卡片内容.
*
* @param string $content
*
* @return $this
*/
public function withContent($content)
{
return $this->content(
<<<HTML
<div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px"> <div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px">
<h2 class="ml-1 font-lg-1">{$content}</h2> <h2 class="ml-1 font-lg-1">{$content}</h2>
<span class="mb-0 mr-1 text-80">{$this->title}</span> <span class="mb-0 mr-1 text-80">{$this->title}</span>
</div> </div>
HTML HTML
);
}
);
}
} }

160
app/Admin/Metrics/Examples/OrderExamples.php

@ -0,0 +1,160 @@
<?php
namespace App\Admin\Metrics\Examples;
use App\Common\OrderStatus;
use App\Models\Order;
use Carbon\Carbon;
use Dcat\Admin\Admin;
use Dcat\Admin\Widgets\Metrics\RadialBar;
use Illuminate\Http\Request;
use Illuminate\Support\Arr;
use Illuminate\Support\Facades\DB;
class OrderExamples extends RadialBar
{
/**
* 初始化卡片内容
*/
protected function init()
{
parent::init();
$this->title('订单统计');
$this->height(400);
$this->chartHeight(300);
}
/**
* 处理请求
*
* @param Request $request
*
* @return mixed|void
*/
public function handle(Request $request)
{
//总订单数
$count = Order::query()->count();
// 卡片内容
$this->withContent($count);
// 卡片底部
//今日订单
$countToday = Order::query()->whereDate('created_at',Carbon::today())->count();
$countYesterday = Order::query()->whereDate('created_at',Carbon::yesterday())->count();
$price = Order::query()->where('status',OrderStatus::SUCCESS)->whereDate('created_at',Carbon::today())->sum('price');
$this->withFooter($countToday, $countYesterday, $price);
$order = Order::query()
->select('*')
->addSelect(DB::raw("COUNT(id) as count_id,CONCAT(YEAR(created_at),'-',MONTH(created_at),'-',DAY(created_at)) AS statistics_time"))
->limit(30)
->orderBy('created_at', 'asc')
->groupBy('statistics_time')
->get()
->toArray();
$categories = Arr::pluck($order,'statistics_time');
// 图表数据
$data = Arr::pluck($order,'count_id');
$this->withChart($data,$categories);
}
/**
* 设置图表数据.
*
* @param int $data
*
* @return $this
*/
public function withChart(array $data,array $categories)
{
return $this->chart([
'series' => [
[
'name' => '订单量',
'data' => $data
]
],
'chart' => [
'type' => 'line',
'zoom' => [
'enabled' => false
],
'toolbar' => [
'show' => false
],
],
'colors' => [
Admin::color()->green(),
],
'dataLabels' => [
'enabled' => false
],
'stroke' => [
'curve' => 'smooth'
],
'legend' => [
'position' =>'top',
//'horizontalAlign' => 'right'
],
'fill' => [
'opacity' => 1,
'type' => 'solid',
],
'xaxis' => [
'categories' => $categories,
]
]);
}
/**
* 卡片内容
*
* @param string $content
*
* @return $this
*/
public function withContent($content)
{
return $this->content(
<<<HTML
<div class="d-flex flex-column flex-wrap text-left p-1">
<h1 class="font-lg-2 mt-2 mb-0">{$content}</h1>
<small>总订单数</small>
</div>
HTML
);
}
/**
* 卡片底部内容.
*
* @param string $new
* @param string $open
* @param string $response
*
* @return $this
*/
public function withFooter($new, $open, $response)
{
return $this->footer(
<<<HTML
<div class="d-flex justify-content-between p-1" style="padding-top: 0!important;">
<div class="text-center">
<p>今日订单</p>
<span class="font-lg-1">{$new}</span>
</div>
<div class="text-center">
<p>昨日订单</p>
<span class="font-lg-1">{$open}</span>
</div>
<div class="text-center">
<p>今日成交()</p>
<span class="font-lg-1">{$response}</span>
</div>
</div>
HTML
);
}
}

203
app/Admin/Metrics/Examples/ProductOrders.php

@ -2,86 +2,139 @@
namespace App\Admin\Metrics\Examples; namespace App\Admin\Metrics\Examples;
use App\Common\DataTime;
use App\Common\OrderStatus;
use App\Models\Order;
use Carbon\Carbon;
use Dcat\Admin\Admin;
use Dcat\Admin\Widgets\Metrics\Round; use Dcat\Admin\Widgets\Metrics\Round;
use Illuminate\Http\Request; use Illuminate\Http\Request;
class ProductOrders extends Round class ProductOrders extends Round
{ {
/**
* 初始化卡片内容
*/
protected function init()
{
parent::init();
$this->title('Product Orders');
$this->chartLabels(['Finished', 'Pending', 'Rejected']);
$this->dropdown([
'7' => 'Last 7 Days',
'28' => 'Last 28 Days',
'30' => 'Last Month',
'365' => 'Last Year',
]);
}
/**
* 处理请求
*
* @param Request $request
*
* @return mixed|void
*/
public function handle(Request $request)
{
switch ($request->get('option')) {
case '365':
case '30':
case '28':
case '7':
default:
// 卡片内容
$this->withContent(23043, 14658, 4758);
// 图表数据
$this->withChart([70, 52, 26]);
// 总数
$this->chartTotal('Total', 344);
}
}
/**
* 设置图表数据.
*
* @param array $data
*
* @return $this
*/
public function withChart(array $data)
{
return $this->chart([
'series' => $data,
]);
}
/**
* 卡片内容.
*
* @param int $finished
* @param int $pending
* @param int $rejected
*
* @return $this
*/
public function withContent($finished, $pending, $rejected)
{
return $this->content(
<<<HTML
/**
* 初始化卡片内容
*/
protected function init()
{
parent::init();
$this->title('订单状态统计');
$this->chartLabels(['Finished', 'Pending', 'Rejected']);
$this->dropdown([
//'day' => '本日',
'week' => '本周',
'month' => '本月',
'year' => '今年',
]);
}
/**
* 处理请求
*
* @param Request $request
*
* @return mixed|void
*/
public function handle(Request $request)
{
$orders = Order::query()
->whereIn('status',[
OrderStatus::PAY_EARNEST,
OrderStatus::PAID,
OrderStatus::PAID_RETAINAGE,
OrderStatus::OFFLINE_PAID,
OrderStatus::SUCCESS
]);
switch ($request->get('option')) {
case 'day':
$orders->whereDate('created_at', Carbon::today());
break;
case 'week':
$time = DataTime::beginAndEnd('week');
$orders->whereBetween('created_at', $time);
break;
case 'month':
$orders->whereMonth('created_at', Carbon::now()->month);
break;
case 'year':
$orders->whereYear('created_at', Carbon::now()->year);
break;
default:
$time = DataTime::beginAndEnd('week');
$orders->whereBetween('created_at', $time);
}
$orders = $orders->pluck('status')->toArray();
$payEarnest = $pay = $success = 0;
$arr = [
OrderStatus::PAID,
OrderStatus::PAID_RETAINAGE,
OrderStatus::OFFLINE_PAID,
];
$count = count($orders);
if ($orders > 0) {
foreach ($orders as $status) {
if ($status == OrderStatus::PAY_EARNEST) {
$payEarnest++;
} elseif (in_array($status,$arr)) {
$pay++;
} elseif ($status == OrderStatus::SUCCESS) {
$success++;
}
}
}
// 卡片内容
$this->withContent($payEarnest, $pay, $success);
$payEarnestPer = $count > 0 ? bcdiv($payEarnest,$count,2) * 100 : 0;
$payPer = $count > 0 ? bcdiv($pay,$count,2) * 100 : 0;
$successPer = $count > 0 ? bcdiv($success,$count,2) * 100 : 0;
// 图表数据
$this->withChart([$payEarnestPer, $payPer, $successPer]);
// 总数
$this->chartTotal('总计', $count);
}
/**
* 设置图表数据.
*
* @param array $data
*
* @return \App\Admin\Metrics\Examples\ProductOrders
*/
public function withChart(array $data)
{
return $this->chart([
'series' => $data,
]);
}
/**
* 卡片内容.
*
* @param int $finished
* @param int $pending
* @param int $rejected
*
* @return $this
*/
public function withContent($finished, $pending, $rejected)
{
return $this->content(
<<<HTML
<div class="col-12 d-flex flex-column flex-wrap text-center" style="max-width: 220px"> <div class="col-12 d-flex flex-column flex-wrap text-center" style="max-width: 220px">
<div class="chart-info d-flex justify-content-between mb-1 mt-2" > <div class="chart-info d-flex justify-content-between mb-1 mt-2" >
<div class="series-info d-flex align-items-center"> <div class="series-info d-flex align-items-center">
<i class="fa fa-circle-o text-bold-700 text-primary"></i> <i class="fa fa-circle-o text-bold-700 text-primary"></i>
<span class="text-bold-600 ml-50">Finished</span>
<span class="text-bold-600 ml-50">已付定金</span>
</div> </div>
<div class="product-result"> <div class="product-result">
<span>{$finished}</span> <span>{$finished}</span>
@ -91,7 +144,7 @@ class ProductOrders extends Round
<div class="chart-info d-flex justify-content-between mb-1"> <div class="chart-info d-flex justify-content-between mb-1">
<div class="series-info d-flex align-items-center"> <div class="series-info d-flex align-items-center">
<i class="fa fa-circle-o text-bold-700 text-warning"></i> <i class="fa fa-circle-o text-bold-700 text-warning"></i>
<span class="text-bold-600 ml-50">Pending</span>
<span class="text-bold-600 ml-50">已付款</span>
</div> </div>
<div class="product-result"> <div class="product-result">
<span>{$pending}</span> <span>{$pending}</span>
@ -101,7 +154,7 @@ class ProductOrders extends Round
<div class="chart-info d-flex justify-content-between mb-1"> <div class="chart-info d-flex justify-content-between mb-1">
<div class="series-info d-flex align-items-center"> <div class="series-info d-flex align-items-center">
<i class="fa fa-circle-o text-bold-700 text-danger"></i> <i class="fa fa-circle-o text-bold-700 text-danger"></i>
<span class="text-bold-600 ml-50">Rejected</span>
<span class="text-bold-600 ml-50">已完成</span>
</div> </div>
<div class="product-result"> <div class="product-result">
<span>{$rejected}</span> <span>{$rejected}</span>
@ -109,6 +162,6 @@ class ProductOrders extends Round
</div> </div>
</div> </div>
HTML HTML
);
}
);
}
} }

177
app/Admin/Metrics/Examples/SalesExamples.php

@ -0,0 +1,177 @@
<?php
namespace App\Admin\Metrics\Examples;
use App\Common\OrderStatus;
use App\Models\Order;
use Dcat\Admin\Admin;
use Dcat\Admin\Widgets\Metrics\Bar;
use Illuminate\Support\Facades\DB;
class SalesExamples extends Bar
{
protected $labels = [];
protected $colors;
/**
* 初始化卡片内容
*/
protected function init()
{
parent::init();
$color = Admin::color();
$this->colors = [$color->green(), $color->red(), $color->yellow(), $color->orange1(), $color->dark90(), $color->dark70(), $color->custom()];
$this->contentWidth(3, 9);
$this->title('销售排行');
//$this->chartPullRight = false;
//$this->subTitle('Last 30 days');
$this->height = 280;
$this->chartHeight = 250;
// 设置图表颜色
$this->chartColors($this->colors);
}
/**
* 渲染模板
*
* @return string
*/
public function render()
{
$this->fill();
return parent::render();
}
/**
* 写入数据.
*
* @return void
*/
public function fill()
{
$warehouse = Order::query()
->with('agentProduct')
->select('*')
->addSelect(DB::raw('count(id) as count_id'))
->where([
'status' => OrderStatus::SUCCESS,
])
->orderByDesc('count_id')
->groupBy('agent_product_id')
->limit(5)
->get();
//$warehouse = [];
$data = $categories = [];
foreach ($warehouse as $v) {
array_push($this->labels, $v->title);
array_push($data, $v->count_id);
$categories[] = [$v->title];
}
$this->withChart($data, $categories);
//$this->chartLabels($this->labels);
$count = Order::query()
->where([
'status' => OrderStatus::SUCCESS,
])
->count();
//$count = 0;
if ($count > 0) {
array_unshift($data, $count);
array_unshift($this->labels, '总销售量');
$color = Admin::color();
array_unshift($this->colors, $color->primary());
}
$this->withContent($data);
}
/**
* 设置图表数据.
*
* @param array $data
*
* @return $this
*/
public function withChart($data, $categories)
{
return $this->chart([
'series' => [[
'name' => '销量',
'data' => $data
]],
'chart' => [
//'width' => '180%',
'type' => 'bar',
'events' => [
],
'toolbar' => ['show' => false],
],
'colors' => $this->colors,
'plotOptions' => [
'bar' => [
//'columnWidth' => '45%',
'distributed' => true,
]
],
'dataLabels' => [
'enabled' => false
],
'legend' => [
'show' => false
],
'xaxis' => [
'categories' =>
$categories
,
'labels' => [
'show' => false,
'style' => [
'colors' => $this->colors,
'fontSize' => '12px'
]
],
],
'yaxis' => [
'show' => false
],
'tooltip' => [
'x' => ['show' => true],
],
]);
}
/**
* 设置卡片头部内容.
*
* @param mixed $desktop
* @param mixed $mobile
*
* @return $this
*/
protected function withContent($data)
{
$content = '';
foreach ($data as $k => $v) {
$content .= '
<div class="d-flex pl-1 mt-2">
<div style="width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis;">
<i class="fa fa-circle" style="color:' . $this->colors[$k] . '"></i> ' . $this->labels[$k] . '
<div style="display:inline-block">' . $v . '</div>
</div>
</div>
';
}
return $this->content(
<<<HTML
$content
HTML
);
}
}

43
resources/views/admin/pages/admin-home.blade.php

@ -0,0 +1,43 @@
<style>
.dashboard-title .links {
text-align: center;
margin-bottom: 2.5rem;
}
.dashboard-title .links > a {
padding: 0 25px;
font-size: 12px;
font-weight: 600;
letter-spacing: .1rem;
text-decoration: none;
text-transform: uppercase;
color: #fff;
}
.dashboard-title h1 {
font-weight: 200;
font-size: 2.5rem;
}
.dashboard-title .avatar {
background: #fff;
border: 2px solid #fff;
width: 70px;
height: 70px;
}
</style>
<div class="dashboard-title card bg-primary">
<div class="card-body">
<div class="text-center ">
<img class="avatar img-circle shadow mt-1" src="{{config('filesystems.disks.oss.cdnDomain').'/'.$admin->avatar}}">
<div class="text-center mb-1">
<h1 class="mb-3 mt-2 text-white">{{$admin->name}}</h1>
<div class="links">
<a href="{{ admin_url('/supplier/list') }}">供应商管理</a>
<a href="{{ admin_url('/agent/list') }}" id="doc-link">代理商管理</a>
<a href="{{ admin_url('/guide/list') }}" id="demo-link">地接管理</a>
<a href="{{ admin_url('/product/audit') }}" id="demo-link">产品审核</a>
</div>
</div>
</div>
</div>
</div>
Loading…
Cancel
Save