|
|
|
@ -40,6 +40,18 @@ class FullPaymentRateColumnCharts extends Chart
@@ -40,6 +40,18 @@ class FullPaymentRateColumnCharts extends Chart
|
|
|
|
|
[ |
|
|
|
|
"name" => "缴费率", |
|
|
|
|
"data" => [], |
|
|
|
|
"tooltip" => [ |
|
|
|
|
[ |
|
|
|
|
"name" => "全额缴费人数", |
|
|
|
|
"data" => [], |
|
|
|
|
"color" => '#ff6b6b' |
|
|
|
|
], |
|
|
|
|
[ |
|
|
|
|
"name" => "缴费人数", |
|
|
|
|
"data" => [], |
|
|
|
|
"color"=>"#a21919" |
|
|
|
|
] |
|
|
|
|
], |
|
|
|
|
] |
|
|
|
|
]; |
|
|
|
|
$label = []; |
|
|
|
@ -81,11 +93,6 @@ class FullPaymentRateColumnCharts extends Chart
@@ -81,11 +93,6 @@ class FullPaymentRateColumnCharts extends Chart
|
|
|
|
|
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, |
|
|
|
@ -113,17 +120,22 @@ class FullPaymentRateColumnCharts extends Chart
@@ -113,17 +120,22 @@ class FullPaymentRateColumnCharts extends Chart
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$list[$key]["registering"] = $registering; |
|
|
|
|
$list[$key]["studentsNum"] = $studentsNum; //全额缴费人数 |
|
|
|
|
$list[$key]["completedOfflineStep"] = $completedOfflineStep; //已缴费人数 |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach($list as $item){ |
|
|
|
|
array_push($label, $item["name"]); |
|
|
|
|
if(!empty($item["registering"])){ |
|
|
|
|
array_push($data[0]["data"], $item["registering"]); |
|
|
|
|
array_push($data[0]['tooltip'][0]['data'], $item["studentsNum"]); //全额缴费人数 |
|
|
|
|
array_push($data[0]['tooltip'][1]['data'], $item["completedOfflineStep"]);//已缴费人数 |
|
|
|
|
}else{ |
|
|
|
|
array_push($data[0]["data"], 0); |
|
|
|
|
array_push($data[0]['tooltip'][0]['data'], 0); //全额缴费人数 |
|
|
|
|
array_push($data[0]['tooltip'][1]['data'], 0);//已缴费人数 |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -133,31 +145,40 @@ class FullPaymentRateColumnCharts extends Chart
@@ -133,31 +145,40 @@ class FullPaymentRateColumnCharts extends Chart
|
|
|
|
|
$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代码执行 |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
$tooltipCustomFunction = <<<JS |
|
|
|
|
function({ series, seriesIndex, dataPointIndex, w }) { |
|
|
|
|
|
|
|
|
|
let newStr = ""; |
|
|
|
|
w.config.series[0].tooltip.forEach(item=>{ |
|
|
|
|
newStr += `<div style="display: flex;padding: 0 10px;align-items: center;margin-top: 8px;"> |
|
|
|
|
<div style="width:12px;height:12px;border-radius:50%;background-color: \${item.color};margin-right: 10px;"> |
|
|
|
|
|
|
|
|
|
</div> |
|
|
|
|
<div style="font-size: 12px;"> |
|
|
|
|
\${item.name}: \${item.data[dataPointIndex]} |
|
|
|
|
</div> |
|
|
|
|
</div>` |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
return ` |
|
|
|
|
<div style=' border: 1px solid #e3e3e3; background: rgba(255, 255, 255, 0.96); border-radius: 5px; box-shadow: 2px 2px 6px -4px #999; font-size: 14px;'> |
|
|
|
|
<div style='padding:6px;background: #ECEFF1;border-bottom: 1px solid #ddd;font-size:12px;'>\${w.config.labels[dataPointIndex]}</div> |
|
|
|
|
<div style="display: flex;padding: 0 10px;align-items: center; margin-top: 8px;"> |
|
|
|
|
<div style="width:12px;height:12px;border-radius:50%;background-color: rgb(0, 143, 251);margin-right: 10px;"> |
|
|
|
|
|
|
|
|
|
</div> |
|
|
|
|
<div style="font-size: 12px;"> |
|
|
|
|
\${w.config.series[0].name}: \${w.config.series[0].data[dataPointIndex]} |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
\${newStr} |
|
|
|
|
</div> |
|
|
|
|
`; |
|
|
|
|
} |
|
|
|
|
JS; |
|
|
|
|
|
|
|
|
|
$this->option('tooltip.custom', JavaScript::make($tooltipCustomFunction)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|