海工商新版后台
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.
 
 

164 lines
6.7 KiB

<?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\Order;
use App\Models\PaymentList;
use App\Models\SecondaryCollege;
use App\Models\Speciality;
use App\Models\UsersMember;
use Dcat\Admin\Support\JavaScript;
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();*/
//已缴费人数
$payNum = Order::query()->whereIn("unique_number", $userList)->where([
"status" => Order::STATUS_PAID,
"annual_session" => $config->data,
])->select("unique_number")->groupBy('unique_number')->get()->toArray();
if(!empty($payNum)){
$completedOfflineStep = count($payNum);
}
//全额缴费人数
$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($studentsNum == 0 || $completedOfflineStep == 0){
$registering = 0;
}else{
$registering = round((($studentsNum / $completedOfflineStep ) * 100), 2) ;
}
$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轴最大值
$this->option(
'tooltip.custom',
JavaScript::make("function({ series, seriesIndex, dataPointIndex, w }) {
<div class=\"apexcharts-tooltip apexcharts-theme-light\" style=\"left: 392.603px; top: 29.6094px;\">
<div class=\"apexcharts-tooltip-title\" style=\"font-family: Helvetica, Arial, sans-serif; font-size: 12px;\">
信息工程学院</div>
<div class=\"apexcharts-tooltip-series-group apexcharts-active\" style=\"display: flex;\">
<span class=\"apexcharts-tooltip-marker\" style=\"background-color: rgb(0, 143, 251);\">
</span>
<div class=\"apexcharts-tooltip-text\" style=\"font-family: Helvetica, Arial, sans-serif; font-size: 12px;\">
<div class=\"apexcharts-tooltip-y-group\">
<span class=\"apexcharts-tooltip-text-label\">缴费率: </span>
<span class=\"apexcharts-tooltip-text-value\">87.65</span>
</div>
<div class=\"apexcharts-tooltip-z-group\">
<span class=\"apexcharts-tooltip-text-z-label\">
</span>
<span class=\"apexcharts-tooltip-text-z-value\">
</span>
</div>
</div>
</div>
</div>
}") // 这个值最后段代码会作为JS代码执行
);
}
}