You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
<?php
namespace App\Admin\Metrics\Examples;
use Dcat\Admin\Widgets\Metrics\Card;use Illuminate\Contracts\Support\Renderable;use Illuminate\Http\Request;
class TotalUsers extends Card{ /** * 卡片底部内容. * * @var string|Renderable|\Closure */ protected $footer;
/** * 初始化卡片. */ protected function init() { parent::init();
$this->title('Total Users'); $this->dropdown([ '7' => 'Last 7 Days', '28' => 'Last 28 Days', '30' => 'Last Month', '365' => 'Last Year', ]); }
/** * 处理请求. * * @param Request $request * * @return void */ public function handle(Request $request) { switch ($request->get('option')) { case '365': $this->content(mt_rand(600, 1500)); $this->down(mt_rand(1, 30)); break; case '30': $this->content(mt_rand(170, 250)); $this->up(mt_rand(12, 50)); break; case '28': $this->content(mt_rand(155, 200)); $this->up(mt_rand(5, 50)); break; case '7': default: $this->content(143); $this->up(15); } }
/** * @param int $percent * * @return $this */ public function up($percent) { return $this->footer( "<i class=\"feather icon-trending-up text-success\"></i> {$percent}% Increase" ); }
/** * @param int $percent * * @return $this */ public function down($percent) { return $this->footer( "<i class=\"feather icon-trending-down text-danger\"></i> {$percent}% Decrease" ); }
/** * 设置卡片底部内容. * * @param string|Renderable|\Closure $footer * * @return $this */ public function footer($footer) { $this->footer = $footer;
return $this; }
/** * 渲染卡片内容. * * @return string */ public function renderContent() { $content = parent::renderContent();
return <<<HTML<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></div><div class="ml-1 mt-1 font-weight-bold text-80"> {$this->renderFooter()}</div>HTML; }
/** * 渲染卡片底部内容. * * @return string */ public function renderFooter() { return $this->toString($this->footer); }}
|