2024-04-30 17:39:37 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace app\app\controller;
|
|
|
|
|
|
|
|
|
|
use think\Controller;
|
|
|
|
|
use think\Db;
|
|
|
|
|
|
|
|
|
|
class Vitalcapacity extends Base{
|
|
|
|
|
|
2024-05-27 18:42:33 +08:00
|
|
|
protected $color = ['无效'=>'#FF5656','不及格'=>'#FF5656','及格'=>'#FFAB00','良好'=>'#5AD06D','优秀'=>'#6492F6','牛逼'=>'#3967D6'];
|
|
|
|
|
protected $standard0 = ['优秀','良好','及格','不及格','无效'];
|
|
|
|
|
protected $standard = [
|
|
|
|
|
['min_val'=>'90','max_val'=>'100','text'=>'优秀','color'=>'#6492F6'],
|
|
|
|
|
['min_val'=>'80','max_val'=>'89','text'=>'良好','color'=>'#5AD06D'],
|
|
|
|
|
['min_val'=>'66','max_val'=>'79','text'=>'及格','color'=>'#FFAB00'],
|
|
|
|
|
['min_val'=>'10','max_val'=>'65','text'=>'不及格','color'=>'#FF5656'],
|
|
|
|
|
['min_val'=>'0','max_val'=>'9','text'=>'无效','color'=>'#FF5656'],
|
|
|
|
|
];
|
2024-04-30 17:39:37 +08:00
|
|
|
|
|
|
|
|
protected $result_end_data_mould = [
|
|
|
|
|
'name'=>'',
|
|
|
|
|
'value'=>'',
|
|
|
|
|
'unit'=>'',
|
|
|
|
|
'standard'=>'',
|
|
|
|
|
'color'=>'',
|
|
|
|
|
'list'=>[]
|
|
|
|
|
];
|
|
|
|
|
|
2024-05-27 18:42:33 +08:00
|
|
|
// 加 bcadd(,,20)
|
|
|
|
|
// 减 bcsub(,,20)
|
|
|
|
|
// 乘 bcmul(,,20)
|
|
|
|
|
// 除 bcdiv(,,20)
|
2024-04-30 17:39:37 +08:00
|
|
|
################################################################接口################################################################
|
|
|
|
|
################################################################接口################################################################
|
|
|
|
|
################################################################接口################################################################
|
|
|
|
|
|
|
|
|
|
// 数据记录
|
2024-05-27 18:42:33 +08:00
|
|
|
public function vitalcapacity_save_record_data($data = ['aud_id'=>'25','one'=>'1500','two'=>'1200','three'=>'1456','time'=>'2024-05-25 10:10:15','token'=>'0dafb98a10995c98b5a33b7d59d986ca']){
|
|
|
|
|
if(count(input('post.')) > 0){
|
|
|
|
|
$data = input('post.');
|
2024-04-30 17:39:37 +08:00
|
|
|
}
|
2024-05-27 18:42:33 +08:00
|
|
|
if(!array_key_exists('aud_id', $data) || !array_key_exists('time', $data) || !array_key_exists('token', $data)){
|
|
|
|
|
return $this->msg(10001);
|
2024-04-30 17:39:37 +08:00
|
|
|
}
|
2024-05-27 18:42:33 +08:00
|
|
|
if($this->token_time_validate($data['token']) === false){
|
|
|
|
|
return $this->msg(20001);
|
2024-04-30 17:39:37 +08:00
|
|
|
}
|
2024-05-27 18:42:33 +08:00
|
|
|
unset($data['token']);
|
|
|
|
|
$data['one'] = $this->isPositiveNumber($data['one']) === false?0:$data['one'];
|
|
|
|
|
$data['two'] = $this->isPositiveNumber($data['one']) === false?0:$data['two'];
|
|
|
|
|
$data['three'] = $this->isPositiveNumber($data['one']) === false?0:$data['three'];
|
|
|
|
|
return $this->vitalcapacity_save_record_data_action($data);
|
2024-04-30 17:39:37 +08:00
|
|
|
}
|
2024-05-27 18:42:33 +08:00
|
|
|
// 数据报告
|
|
|
|
|
public function vitalcapacity_data_report($data = ['aud_id'=>'25','token'=>'0dafb98a10995c98b5a33b7d59d986ca']){
|
|
|
|
|
if(count(input('post.')) > 0){
|
|
|
|
|
$data = input('post.');
|
2024-05-21 18:43:56 +08:00
|
|
|
}
|
2024-05-27 18:42:33 +08:00
|
|
|
if(!array_key_exists('aud_id', $data) || !array_key_exists('token', $data)){
|
|
|
|
|
return $this->msg(10001);
|
2024-05-21 18:43:56 +08:00
|
|
|
}
|
|
|
|
|
if($this->token_time_validate($data['token']) === false){
|
2024-05-27 18:42:33 +08:00
|
|
|
return $this->msg(20001);
|
2024-05-21 18:43:56 +08:00
|
|
|
}
|
|
|
|
|
unset($data['token']);
|
2024-05-27 18:42:33 +08:00
|
|
|
return $this->vitalcapacity_data_report_action($data);
|
|
|
|
|
}
|
2024-05-21 18:43:56 +08:00
|
|
|
|
2024-05-27 18:42:33 +08:00
|
|
|
################################################################业务################################################################
|
|
|
|
|
|
|
|
|
|
################################################################vitalcapacity_save_record_data
|
|
|
|
|
public function vitalcapacity_save_record_data_action($data){
|
|
|
|
|
$temporary_arr['aud_id'] = $data['aud_id'];
|
|
|
|
|
$temporary_arr['record_time'] = $data['time'];
|
|
|
|
|
$temporary_arr['one'] = $data['one'];
|
|
|
|
|
$temporary_arr['two'] = $data['two'];
|
|
|
|
|
$temporary_arr['three'] = $data['three'];
|
|
|
|
|
$temporary_arr['average'] = bcdiv(bcadd(bcadd($data['one'],$data['two'],2),$data['three'],2),3,2);
|
|
|
|
|
$temporary_arr['create_time'] = date('Y-m-d H:i:s');
|
|
|
|
|
$temporary_arr['one_val'] = $data['one'];
|
|
|
|
|
$temporary_arr['two_val'] = $data['two'];
|
|
|
|
|
$temporary_arr['three_val'] = $data['three'];
|
|
|
|
|
$temporary_arr['average_val'] = $temporary_arr['average'];
|
2024-05-21 18:43:56 +08:00
|
|
|
$user_msg = Db::name('app_user_data')->where(['id'=>$data['aud_id']])->field('grade,gender')->find();
|
2024-05-27 18:42:33 +08:00
|
|
|
if($user_msg){
|
|
|
|
|
$achievement_judge_data = $this->vitalcapacity_achievement_judge(['average'=>$temporary_arr['average'],'grade'=>$user_msg['grade'],'gender'=>$user_msg['gender']]);
|
|
|
|
|
|
|
|
|
|
$temporary_arr['score'] = $achievement_judge_data['score'].','.$achievement_judge_data['level'].','.$this->color[$achievement_judge_data['level']];
|
|
|
|
|
$temporary_arr['score_val'] = $achievement_judge_data['score'];
|
|
|
|
|
}else{
|
|
|
|
|
return $this->msg(10004);
|
|
|
|
|
}
|
|
|
|
|
$result = Db::table('app_card_vitalcapacity_data')->insert($temporary_arr);
|
2024-05-16 10:33:57 +08:00
|
|
|
if($result){
|
2024-05-27 18:42:33 +08:00
|
|
|
$time = $result[0]['record_time'];
|
|
|
|
|
$time = strtotime($time);
|
|
|
|
|
$time = date('Y年m月d日 H:i:s', $time);
|
|
|
|
|
|
|
|
|
|
return $this->msg(['average'=>$temporary_arr['average'].'ml','level'=>$achievement_judge_data['level'],'time'=>$time,'list'=>$this->standard0,'offset'=>$temporary_arr['score_val']]);
|
2024-05-16 10:33:57 +08:00
|
|
|
}else{
|
2024-05-27 18:42:33 +08:00
|
|
|
return $this->msg(10002);
|
2024-05-16 10:33:57 +08:00
|
|
|
}
|
|
|
|
|
}
|
2024-05-27 18:42:33 +08:00
|
|
|
################################################################vitalcapacity_data_report
|
|
|
|
|
public function vitalcapacity_data_report_action($data){
|
|
|
|
|
$result = Db::table('app_card_vitalcapacity_data')->where(['aud_id'=>$data['aud_id']])->order('record_time desc')->field('record_time,score,average')->limit(1)->select();
|
|
|
|
|
if(count($result) <= 0){
|
|
|
|
|
return $this->msg(10004);
|
|
|
|
|
}else{
|
|
|
|
|
$time = $result[0]['record_time'];
|
|
|
|
|
$time = strtotime($time);
|
|
|
|
|
$time = date('Y年m月d日 H:i:s', $time);
|
|
|
|
|
$o_l = explode(',',$result[0]['score']);
|
|
|
|
|
return $this->msg(['average'=>$result[0]['average'].'ml','level'=>$o_l[1],'time'=>$time,'list'=>$this->standard0,'offset'=>$o_l[0]]);
|
|
|
|
|
}
|
2024-04-30 17:39:37 +08:00
|
|
|
|
2024-05-27 18:42:33 +08:00
|
|
|
}
|
|
|
|
|
|
2024-04-30 17:39:37 +08:00
|
|
|
|
2024-05-21 18:43:56 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
################################################################肺活量数据卡片接口################################################################
|
|
|
|
|
################################################################肺活量数据卡片接口################################################################
|
|
|
|
|
|
2024-05-27 18:42:33 +08:00
|
|
|
// 肺活量成绩判断
|
|
|
|
|
public function vitalcapacity_achievement_judge($data){
|
|
|
|
|
$str = "sex = ".$data['gender']." and ".$data['grade']." <= ".$data['average'];
|
|
|
|
|
$user_achievement = Db::name('pc_vitalcapacity_standard')->where($str)->order($data['grade'] .' desc')->field('level,score,'.$data['grade'])->limit(1)->select();
|
|
|
|
|
if(count($user_achievement)<=0){
|
|
|
|
|
$user_achievement = ['level'=>'无效','score'=>'0'];
|
|
|
|
|
}
|
|
|
|
|
return $user_achievement[0];
|
|
|
|
|
}
|
|
|
|
|
// 肺活量判断区间
|
|
|
|
|
public function vitalcapacity_standard_interval($data){
|
|
|
|
|
// 缓存一周
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
2024-05-21 18:43:56 +08:00
|
|
|
|
|
|
|
|
|
2024-04-30 17:39:37 +08:00
|
|
|
################################################################other################################################################
|
|
|
|
|
################################################################other################################################################
|
|
|
|
|
################################################################other################################################################
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|