12 changed files with 863 additions and 26 deletions
@ -0,0 +1,112 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Admin\Metrics\Chart; |
||||||
|
use App\Models\AdmissionNewStudents; |
||||||
|
use App\Models\CompletedOfflineStep; |
||||||
|
use App\Models\Config; |
||||||
|
use App\Models\OfflineStep; |
||||||
|
use App\Models\PaymentList; |
||||||
|
use App\Models\SecondaryCollege; |
||||||
|
use App\Models\Speciality; |
||||||
|
use App\Models\UsersMember; |
||||||
|
use Dcat\Admin\Widgets\ApexCharts\Chart; |
||||||
|
use Illuminate\Support\Facades\DB; |
||||||
|
|
||||||
|
class FemaleColumnCharts extends Chart |
||||||
|
{ |
||||||
|
//各二级学院女生报道率 |
||||||
|
public function __construct($containerSelector = null, $options = []) |
||||||
|
{ |
||||||
|
parent::__construct($containerSelector, $options); |
||||||
|
|
||||||
|
$this->setUpOptions(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
//初始化方法,主要是调用$this->options()方法,执行整个option的初始化操作。 |
||||||
|
protected function setUpOptions() |
||||||
|
{ |
||||||
|
$this->options([ |
||||||
|
"chart"=>[ |
||||||
|
"height"=>350, //高度 |
||||||
|
"type"=>"bar", //chart 类型 |
||||||
|
], |
||||||
|
]); |
||||||
|
|
||||||
|
$data = [[ |
||||||
|
"name" => "报道率", |
||||||
|
"data" => [], |
||||||
|
]]; |
||||||
|
$label = []; |
||||||
|
|
||||||
|
// 执行你的数据查询逻辑 |
||||||
|
//取出当前年份 |
||||||
|
$config = Config::query()->where([ |
||||||
|
"unique_identification" => "annual_session" |
||||||
|
])->first(); |
||||||
|
|
||||||
|
//二级学院 |
||||||
|
$list = SecondaryCollege::query()->where([ |
||||||
|
"status" => SecondaryCollege::STATUS_YES |
||||||
|
])->get(["id", "name"])->toArray(); |
||||||
|
|
||||||
|
//不为空时 |
||||||
|
if(!empty($list)){ |
||||||
|
|
||||||
|
|
||||||
|
foreach($list as $key => $item){ |
||||||
|
//取出该学院下的专业 |
||||||
|
$speciality = Speciality::query()->where([ |
||||||
|
"status" => Speciality::STATUS_YES, |
||||||
|
"secondary_college_id" => $item["id"], |
||||||
|
])->get()->toArray(); |
||||||
|
//专业ID |
||||||
|
$specialityIds = array_column($speciality, "id"); |
||||||
|
|
||||||
|
//二级学院已录入的学生 |
||||||
|
$importStudents = AdmissionNewStudents::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
"status" => AdmissionNewStudents::STATUS_YES, |
||||||
|
"is_new_student" => AdmissionNewStudents::IS_NEW_STUDENT_YES, |
||||||
|
"sex" => AdmissionNewStudents::FEMALE, |
||||||
|
])->whereIn("speciality_id", $specialityIds)->get("idCard")->toArray(); |
||||||
|
if(!empty($importStudents)){ |
||||||
|
$idcardList = array_column($importStudents, "idCard"); |
||||||
|
//根据身份证集取出已注册的用户 |
||||||
|
$userList = UsersMember::query()->whereIn("idcard", $idcardList)->where("status", UsersMember::STATUS_YES)->get("unique_number")->toArray(); |
||||||
|
if(!empty($userList)){ |
||||||
|
$userList = array_column($userList, "unique_number"); |
||||||
|
|
||||||
|
//线下迎新有几步 |
||||||
|
$stepCount = OfflineStep::query()->where("status", OfflineStep::STATUS_YES)->count(); |
||||||
|
//检测是否存在线下报到步骤,存在则视为已到校(实际报到学生) |
||||||
|
$completedOfflineStep = CompletedOfflineStep::query()->whereIn("unique_number", $userList)->where("annual_session", $config->data)->where("step_id",">=",$stepCount)->count(); |
||||||
|
|
||||||
|
|
||||||
|
$studentsNum = count($importStudents); |
||||||
|
|
||||||
|
//报到率 |
||||||
|
$registering = (($completedOfflineStep / $studentsNum) * 100) ; |
||||||
|
$list[$key]["registering"] = $registering; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
foreach($list as $item){ |
||||||
|
array_push($label, $item["name"]); |
||||||
|
if(!empty($item["registering"])){ |
||||||
|
array_push($data[0]["data"], $item["registering"]); |
||||||
|
}else{ |
||||||
|
array_push($data[0]["data"], 0); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
$this->option("series",$data); |
||||||
|
$this->option("labels",$label); |
||||||
|
$this->option("yaxis",["max" => 100]); //Y轴最大值 |
||||||
|
|
||||||
|
} |
||||||
|
} |
@ -0,0 +1,118 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Admin\Metrics\Chart; |
||||||
|
use App\Models\AdmissionNewStudents; |
||||||
|
use App\Models\CompletedOfflineStep; |
||||||
|
use App\Models\Config; |
||||||
|
use App\Models\OfflineStep; |
||||||
|
use App\Models\PaymentList; |
||||||
|
use App\Models\SecondaryCollege; |
||||||
|
use App\Models\Speciality; |
||||||
|
use App\Models\UsersMember; |
||||||
|
use Dcat\Admin\Widgets\ApexCharts\Chart; |
||||||
|
use Illuminate\Support\Facades\DB; |
||||||
|
|
||||||
|
class FullPaymentRateColumnCharts extends Chart |
||||||
|
{ |
||||||
|
//各二级学院缴费率 |
||||||
|
public function __construct($containerSelector = null, $options = []) |
||||||
|
{ |
||||||
|
parent::__construct($containerSelector, $options); |
||||||
|
|
||||||
|
$this->setUpOptions(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
//初始化方法,主要是调用$this->options()方法,执行整个option的初始化操作。 |
||||||
|
protected function setUpOptions() |
||||||
|
{ |
||||||
|
$this->options([ |
||||||
|
"chart"=>[ |
||||||
|
"height"=>350, //高度 |
||||||
|
"type"=>"bar", //chart 类型 |
||||||
|
], |
||||||
|
]); |
||||||
|
|
||||||
|
$data = [[ |
||||||
|
"name" => "缴费率", |
||||||
|
"data" => [], |
||||||
|
]]; |
||||||
|
$label = []; |
||||||
|
|
||||||
|
// 执行你的数据查询逻辑 |
||||||
|
//取出当前年份 |
||||||
|
$config = Config::query()->where([ |
||||||
|
"unique_identification" => "annual_session" |
||||||
|
])->first(); |
||||||
|
|
||||||
|
//二级学院 |
||||||
|
$list = SecondaryCollege::query()->where([ |
||||||
|
"status" => SecondaryCollege::STATUS_YES |
||||||
|
])->get(["id", "name"])->toArray(); |
||||||
|
|
||||||
|
//不为空时 |
||||||
|
if(!empty($list)){ |
||||||
|
|
||||||
|
|
||||||
|
foreach($list as $key => $item){ |
||||||
|
//取出该学院下的专业 |
||||||
|
$speciality = Speciality::query()->where([ |
||||||
|
"status" => Speciality::STATUS_YES, |
||||||
|
"secondary_college_id" => $item["id"], |
||||||
|
])->get()->toArray(); |
||||||
|
//专业ID |
||||||
|
$specialityIds = array_column($speciality, "id"); |
||||||
|
|
||||||
|
//二级学院已录入的学生 |
||||||
|
$importStudents = AdmissionNewStudents::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
"status" => AdmissionNewStudents::STATUS_YES, |
||||||
|
"is_new_student" => AdmissionNewStudents::IS_NEW_STUDENT_YES, |
||||||
|
])->whereIn("speciality_id", $specialityIds)->get("idCard")->toArray(); |
||||||
|
if(!empty($importStudents)){ |
||||||
|
$idcardList = array_column($importStudents, "idCard"); |
||||||
|
//根据身份证集取出已注册的用户 |
||||||
|
$userList = UsersMember::query()->whereIn("idcard", $idcardList)->where("status", UsersMember::STATUS_YES)->get("unique_number")->toArray(); |
||||||
|
if(!empty($userList)){ |
||||||
|
$userList = array_column($userList, "unique_number"); |
||||||
|
|
||||||
|
//线下迎新有几步 |
||||||
|
$stepCount = OfflineStep::query()->where("status", OfflineStep::STATUS_YES)->count(); |
||||||
|
//检测是否存在线下报到步骤,存在则视为已到校(实际报到学生) |
||||||
|
$completedOfflineStep = CompletedOfflineStep::query()->whereIn("unique_number", $userList)->where("annual_session", $config->data)->where("step_id",">=",$stepCount)->count(); |
||||||
|
|
||||||
|
//全额缴费人数 |
||||||
|
$paymentList = PaymentList::query()->where("annual_session", $config->data) |
||||||
|
->whereIn("unique_number", $userList) |
||||||
|
->select('unique_number', DB::raw('SUM(amount) as total_amount')) |
||||||
|
->groupBy('unique_number') |
||||||
|
->havingRaw('total_amount = ?', [0]) |
||||||
|
->get()->toArray(); |
||||||
|
|
||||||
|
$studentsNum = count($paymentList); |
||||||
|
|
||||||
|
//报到率 |
||||||
|
$registering = (($studentsNum / $completedOfflineStep ) * 100) ; |
||||||
|
$list[$key]["registering"] = $registering; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
foreach($list as $item){ |
||||||
|
array_push($label, $item["name"]); |
||||||
|
if(!empty($item["registering"])){ |
||||||
|
array_push($data[0]["data"], $item["registering"]); |
||||||
|
}else{ |
||||||
|
array_push($data[0]["data"], 0); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
$this->option("series",$data); |
||||||
|
$this->option("labels",$label); |
||||||
|
$this->option("yaxis",["max" => 100]); //Y轴最大值 |
||||||
|
|
||||||
|
} |
||||||
|
} |
@ -0,0 +1,112 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Admin\Metrics\Chart; |
||||||
|
use App\Models\AdmissionNewStudents; |
||||||
|
use App\Models\CompletedOfflineStep; |
||||||
|
use App\Models\Config; |
||||||
|
use App\Models\OfflineStep; |
||||||
|
use App\Models\PaymentList; |
||||||
|
use App\Models\SecondaryCollege; |
||||||
|
use App\Models\Speciality; |
||||||
|
use App\Models\UsersMember; |
||||||
|
use Dcat\Admin\Widgets\ApexCharts\Chart; |
||||||
|
use Illuminate\Support\Facades\DB; |
||||||
|
|
||||||
|
class MaleColumnCharts extends Chart |
||||||
|
{ |
||||||
|
//各二级学院男生报道率 |
||||||
|
public function __construct($containerSelector = null, $options = []) |
||||||
|
{ |
||||||
|
parent::__construct($containerSelector, $options); |
||||||
|
|
||||||
|
$this->setUpOptions(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
//初始化方法,主要是调用$this->options()方法,执行整个option的初始化操作。 |
||||||
|
protected function setUpOptions() |
||||||
|
{ |
||||||
|
$this->options([ |
||||||
|
"chart"=>[ |
||||||
|
"height"=>350, //高度 |
||||||
|
"type"=>"bar", //chart 类型 |
||||||
|
], |
||||||
|
]); |
||||||
|
|
||||||
|
$data = [[ |
||||||
|
"name" => "报道率", |
||||||
|
"data" => [], |
||||||
|
]]; |
||||||
|
$label = []; |
||||||
|
|
||||||
|
// 执行你的数据查询逻辑 |
||||||
|
//取出当前年份 |
||||||
|
$config = Config::query()->where([ |
||||||
|
"unique_identification" => "annual_session" |
||||||
|
])->first(); |
||||||
|
|
||||||
|
//二级学院 |
||||||
|
$list = SecondaryCollege::query()->where([ |
||||||
|
"status" => SecondaryCollege::STATUS_YES |
||||||
|
])->get(["id", "name"])->toArray(); |
||||||
|
|
||||||
|
//不为空时 |
||||||
|
if(!empty($list)){ |
||||||
|
|
||||||
|
|
||||||
|
foreach($list as $key => $item){ |
||||||
|
//取出该学院下的专业 |
||||||
|
$speciality = Speciality::query()->where([ |
||||||
|
"status" => Speciality::STATUS_YES, |
||||||
|
"secondary_college_id" => $item["id"], |
||||||
|
])->get()->toArray(); |
||||||
|
//专业ID |
||||||
|
$specialityIds = array_column($speciality, "id"); |
||||||
|
|
||||||
|
//二级学院已录入的学生 |
||||||
|
$importStudents = AdmissionNewStudents::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
"status" => AdmissionNewStudents::STATUS_YES, |
||||||
|
"is_new_student" => AdmissionNewStudents::IS_NEW_STUDENT_YES, |
||||||
|
"sex" => AdmissionNewStudents::MALE, |
||||||
|
])->whereIn("speciality_id", $specialityIds)->get("idCard")->toArray(); |
||||||
|
if(!empty($importStudents)){ |
||||||
|
$idcardList = array_column($importStudents, "idCard"); |
||||||
|
//根据身份证集取出已注册的用户 |
||||||
|
$userList = UsersMember::query()->whereIn("idcard", $idcardList)->where("status", UsersMember::STATUS_YES)->get("unique_number")->toArray(); |
||||||
|
if(!empty($userList)){ |
||||||
|
$userList = array_column($userList, "unique_number"); |
||||||
|
|
||||||
|
//线下迎新有几步 |
||||||
|
$stepCount = OfflineStep::query()->where("status", OfflineStep::STATUS_YES)->count(); |
||||||
|
//检测是否存在线下报到步骤,存在则视为已到校(实际报到学生) |
||||||
|
$completedOfflineStep = CompletedOfflineStep::query()->whereIn("unique_number", $userList)->where("annual_session", $config->data)->where("step_id",">=",$stepCount)->count(); |
||||||
|
|
||||||
|
|
||||||
|
$studentsNum = count($importStudents); |
||||||
|
|
||||||
|
//报到率 |
||||||
|
$registering = (($completedOfflineStep / $studentsNum) * 100) ; |
||||||
|
$list[$key]["registering"] = $registering; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
foreach($list as $item){ |
||||||
|
array_push($label, $item["name"]); |
||||||
|
if(!empty($item["registering"])){ |
||||||
|
array_push($data[0]["data"], $item["registering"]); |
||||||
|
}else{ |
||||||
|
array_push($data[0]["data"], 0); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
$this->option("series",$data); |
||||||
|
$this->option("labels",$label); |
||||||
|
$this->option("yaxis",["max" => 100]); //Y轴最大值 |
||||||
|
|
||||||
|
} |
||||||
|
} |
@ -0,0 +1,154 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Admin\Metrics\Examples; |
||||||
|
use App\Models\AdmissionNewStudents; |
||||||
|
use App\Models\CompletedOfflineStep; |
||||||
|
use App\Models\Config; |
||||||
|
use App\Models\PaymentList; |
||||||
|
use App\Models\UsersMember; |
||||||
|
use Dcat\Admin\Widgets\Metrics\Card; |
||||||
|
use Illuminate\Contracts\Support\Renderable; |
||||||
|
use Illuminate\Http\Request; |
||||||
|
use Illuminate\Support\Facades\DB; |
||||||
|
|
||||||
|
/** |
||||||
|
* 女生报到率 |
||||||
|
*/ |
||||||
|
class FemaleRegistering extends Card |
||||||
|
{ |
||||||
|
/** |
||||||
|
* 卡片底部内容. |
||||||
|
* |
||||||
|
* @var string|Renderable|\Closure |
||||||
|
*/ |
||||||
|
protected $footer; |
||||||
|
|
||||||
|
/** |
||||||
|
* 初始化卡片. |
||||||
|
*/ |
||||||
|
protected function init() |
||||||
|
{ |
||||||
|
parent::init(); |
||||||
|
|
||||||
|
$this->title('女生报到率'); |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 处理请求. |
||||||
|
* |
||||||
|
* @param Request $request |
||||||
|
* |
||||||
|
* @return void |
||||||
|
*/ |
||||||
|
public function handle(Request $request) |
||||||
|
{ |
||||||
|
|
||||||
|
$number = 0; |
||||||
|
$studentsNum = 0; |
||||||
|
|
||||||
|
//取出当前年份 |
||||||
|
$config = Config::query()->where([ |
||||||
|
"unique_identification" => "annual_session" |
||||||
|
])->first(); |
||||||
|
|
||||||
|
|
||||||
|
//取出当前年份录入的女学生 |
||||||
|
$importStudents = AdmissionNewStudents::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
"status" => AdmissionNewStudents::STATUS_YES, |
||||||
|
"is_new_student" => AdmissionNewStudents::IS_NEW_STUDENT_YES, |
||||||
|
"sex" => AdmissionNewStudents:: FEMALE, |
||||||
|
])->get("idCard")->toArray(); |
||||||
|
if(!empty($importStudents)){ |
||||||
|
$idcardList = array_column($importStudents, "idCard"); |
||||||
|
//根据身份证集取出已注册的用户 |
||||||
|
$userList = UsersMember::query()->whereIn("idcard", $idcardList)->where("status", UsersMember::STATUS_YES)->get("unique_number")->toArray(); |
||||||
|
if(!empty($userList)){ |
||||||
|
$userList = array_column($userList, "unique_number"); |
||||||
|
|
||||||
|
//当前年份已完成二级学院扫码的学生(实际报道人数) |
||||||
|
$allCount = CompletedOfflineStep::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
])->whereIn("unique_number", $userList)->select("unique_number")->distinct()->get()->toArray(); |
||||||
|
|
||||||
|
$number = count($allCount); |
||||||
|
} |
||||||
|
$studentsNum = count($importStudents); |
||||||
|
} |
||||||
|
|
||||||
|
if($number == 0 || $studentsNum == 0){ |
||||||
|
$this->content("0%"); |
||||||
|
}else{ |
||||||
|
$this->content((($number / $studentsNum) * 100)."%"); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param int $percent |
||||||
|
* |
||||||
|
* @return $this |
||||||
|
*/ |
||||||
|
public function up($percent) |
||||||
|
{ |
||||||
|
return $this->footer( |
||||||
|
"<i class=\"feather icon-trending-up text-success\"></i> {$percent}人 为当前年份已分配床位数" |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param int $percent |
||||||
|
* |
||||||
|
* @return $this |
||||||
|
*/ |
||||||
|
public function down($percent) |
||||||
|
{ |
||||||
|
return $this->footer( |
||||||
|
"<i class=\"feather icon-trending-down text-danger\"></i> {$percent}人 为当前年份已分配床位数" |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 设置卡片底部内容. |
||||||
|
* |
||||||
|
* @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); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,164 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Admin\Metrics\Examples; |
||||||
|
use App\Models\AdmissionNewStudents; |
||||||
|
use App\Models\CompletedOfflineStep; |
||||||
|
use App\Models\Config; |
||||||
|
use App\Models\OfflineStep; |
||||||
|
use App\Models\PaymentList; |
||||||
|
use App\Models\UsersMember; |
||||||
|
use Dcat\Admin\Widgets\Metrics\Card; |
||||||
|
use Illuminate\Contracts\Support\Renderable; |
||||||
|
use Illuminate\Http\Request; |
||||||
|
use Illuminate\Support\Facades\DB; |
||||||
|
|
||||||
|
class FullPaymentRate extends Card |
||||||
|
{ |
||||||
|
/** |
||||||
|
* 卡片底部内容. |
||||||
|
* |
||||||
|
* @var string|Renderable|\Closure |
||||||
|
*/ |
||||||
|
protected $footer; |
||||||
|
|
||||||
|
/** |
||||||
|
* 初始化卡片. |
||||||
|
*/ |
||||||
|
protected function init() |
||||||
|
{ |
||||||
|
parent::init(); |
||||||
|
|
||||||
|
$this->title('全额缴费率'); |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 处理请求. |
||||||
|
* |
||||||
|
* @param Request $request |
||||||
|
* |
||||||
|
* @return void |
||||||
|
*/ |
||||||
|
public function handle(Request $request) |
||||||
|
{ |
||||||
|
|
||||||
|
$number = 0; |
||||||
|
$studentsNum = 0; |
||||||
|
|
||||||
|
//取出当前年份 |
||||||
|
$config = Config::query()->where([ |
||||||
|
"unique_identification" => "annual_session" |
||||||
|
])->first(); |
||||||
|
|
||||||
|
//当前年份已完成二级学院扫码的学生(实际报道人数) |
||||||
|
$allCount = CompletedOfflineStep::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
])->select("unique_number")->distinct()->get()->toArray(); |
||||||
|
if(!empty($allCount)){ |
||||||
|
$number = count($allCount); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//取出当前年份录入的学生 |
||||||
|
$importStudents = AdmissionNewStudents::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
"status" => AdmissionNewStudents::STATUS_YES, |
||||||
|
"is_new_student" => AdmissionNewStudents::IS_NEW_STUDENT_YES, |
||||||
|
])->get("idCard")->toArray(); |
||||||
|
if(!empty($importStudents)){ |
||||||
|
$idcardList = array_column($importStudents, "idCard"); |
||||||
|
//根据身份证集取出已注册的用户 |
||||||
|
$userList = UsersMember::query()->whereIn("idcard", $idcardList)->where("status", UsersMember::STATUS_YES)->get("unique_number")->toArray(); |
||||||
|
if(!empty($userList)){ |
||||||
|
$userList = array_column($userList, "unique_number"); |
||||||
|
|
||||||
|
//全额缴费人数 |
||||||
|
$paymentList = PaymentList::query()->where("annual_session", $config->data) |
||||||
|
->whereIn("unique_number", $userList) |
||||||
|
->select('unique_number', DB::raw('SUM(amount) as total_amount')) |
||||||
|
->groupBy('unique_number') |
||||||
|
->havingRaw('total_amount = ?', [0]) |
||||||
|
->get()->toArray(); |
||||||
|
|
||||||
|
$studentsNum = count($paymentList); |
||||||
|
|
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
if($number == 0 || $studentsNum == 0){ |
||||||
|
$this->content("0%"); |
||||||
|
}else{ |
||||||
|
$this->content((($studentsNum / $number) * 100)."%"); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param int $percent |
||||||
|
* |
||||||
|
* @return $this |
||||||
|
*/ |
||||||
|
public function up($percent) |
||||||
|
{ |
||||||
|
return $this->footer( |
||||||
|
"<i class=\"feather icon-trending-up text-success\"></i> {$percent}人 为当前年份已分配床位数" |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param int $percent |
||||||
|
* |
||||||
|
* @return $this |
||||||
|
*/ |
||||||
|
public function down($percent) |
||||||
|
{ |
||||||
|
return $this->footer( |
||||||
|
"<i class=\"feather icon-trending-down text-danger\"></i> {$percent}人 为当前年份已分配床位数" |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 设置卡片底部内容. |
||||||
|
* |
||||||
|
* @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); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,154 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Admin\Metrics\Examples; |
||||||
|
use App\Models\AdmissionNewStudents; |
||||||
|
use App\Models\CompletedOfflineStep; |
||||||
|
use App\Models\Config; |
||||||
|
use App\Models\PaymentList; |
||||||
|
use App\Models\UsersMember; |
||||||
|
use Dcat\Admin\Widgets\Metrics\Card; |
||||||
|
use Illuminate\Contracts\Support\Renderable; |
||||||
|
use Illuminate\Http\Request; |
||||||
|
use Illuminate\Support\Facades\DB; |
||||||
|
|
||||||
|
/** |
||||||
|
* 男生报到率 |
||||||
|
*/ |
||||||
|
class MaleRegistering extends Card |
||||||
|
{ |
||||||
|
/** |
||||||
|
* 卡片底部内容. |
||||||
|
* |
||||||
|
* @var string|Renderable|\Closure |
||||||
|
*/ |
||||||
|
protected $footer; |
||||||
|
|
||||||
|
/** |
||||||
|
* 初始化卡片. |
||||||
|
*/ |
||||||
|
protected function init() |
||||||
|
{ |
||||||
|
parent::init(); |
||||||
|
|
||||||
|
$this->title('男生报到率'); |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 处理请求. |
||||||
|
* |
||||||
|
* @param Request $request |
||||||
|
* |
||||||
|
* @return void |
||||||
|
*/ |
||||||
|
public function handle(Request $request) |
||||||
|
{ |
||||||
|
|
||||||
|
$number = 0; |
||||||
|
$studentsNum = 0; |
||||||
|
|
||||||
|
//取出当前年份 |
||||||
|
$config = Config::query()->where([ |
||||||
|
"unique_identification" => "annual_session" |
||||||
|
])->first(); |
||||||
|
|
||||||
|
|
||||||
|
//取出当前年份录入的男学生 |
||||||
|
$importStudents = AdmissionNewStudents::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
"status" => AdmissionNewStudents::STATUS_YES, |
||||||
|
"is_new_student" => AdmissionNewStudents::IS_NEW_STUDENT_YES, |
||||||
|
"sex" => AdmissionNewStudents:: MALE, |
||||||
|
])->get("idCard")->toArray(); |
||||||
|
if(!empty($importStudents)){ |
||||||
|
$idcardList = array_column($importStudents, "idCard"); |
||||||
|
//根据身份证集取出已注册的用户 |
||||||
|
$userList = UsersMember::query()->whereIn("idcard", $idcardList)->where("status", UsersMember::STATUS_YES)->get("unique_number")->toArray(); |
||||||
|
if(!empty($userList)){ |
||||||
|
$userList = array_column($userList, "unique_number"); |
||||||
|
|
||||||
|
//当前年份已完成二级学院扫码的学生(实际报道人数) |
||||||
|
$allCount = CompletedOfflineStep::query()->where([ |
||||||
|
"annual_session" => $config->data, |
||||||
|
])->whereIn("unique_number", $userList)->select("unique_number")->distinct()->get()->toArray(); |
||||||
|
|
||||||
|
$number = count($allCount); |
||||||
|
} |
||||||
|
$studentsNum = count($importStudents); |
||||||
|
} |
||||||
|
|
||||||
|
if($number == 0 || $studentsNum == 0){ |
||||||
|
$this->content("0%"); |
||||||
|
}else{ |
||||||
|
$this->content((($number / $studentsNum) * 100)."%"); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param int $percent |
||||||
|
* |
||||||
|
* @return $this |
||||||
|
*/ |
||||||
|
public function up($percent) |
||||||
|
{ |
||||||
|
return $this->footer( |
||||||
|
"<i class=\"feather icon-trending-up text-success\"></i> {$percent}人 为当前年份已分配床位数" |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param int $percent |
||||||
|
* |
||||||
|
* @return $this |
||||||
|
*/ |
||||||
|
public function down($percent) |
||||||
|
{ |
||||||
|
return $this->footer( |
||||||
|
"<i class=\"feather icon-trending-down text-danger\"></i> {$percent}人 为当前年份已分配床位数" |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 设置卡片底部内容. |
||||||
|
* |
||||||
|
* @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); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue