新增 创建检测订单 接口

This commit is contained in:
wucongxing 2023-07-28 14:35:25 +08:00
parent b3d0576013
commit ff5d622110
9 changed files with 441 additions and 12 deletions

View File

@ -55,12 +55,13 @@ class DetectionController extends AbstractController
}
// 创建检测订单
public function addDetectionOrder(){
public function addDetectionOrder(): ResponseInterface
{
$request = $this->container->get(DetectionRequest::class);
$request->scene('addDetectionOrder')->validateResolved();
$detectionService = new DetectionService();
$data = $detectionService->getDetectionDoctorList();
$data = $detectionService->addDetectionOrder();
return $this->response->json($data);
}
}

View File

@ -7,6 +7,7 @@ namespace App\Model;
use Hyperf\Database\Model\Collection;
use Hyperf\Snowflake\Concern\Snowflake;
/**
* @property int $detection_project_id 主键id
@ -19,6 +20,8 @@ use Hyperf\Database\Model\Collection;
*/
class DetectionProject extends Model
{
use Snowflake;
/**
* The table associated with the model.
*/

View File

@ -7,6 +7,7 @@ namespace App\Model;
use Hyperf\Database\Model\Collection;
use Hyperf\Snowflake\Concern\Snowflake;
/**
* @property int $purpose_id 主键id
@ -17,6 +18,8 @@ use Hyperf\Database\Model\Collection;
*/
class DetectionProjectPurpose extends Model
{
use Snowflake;
/**
* The table associated with the model.
*/

View File

@ -7,6 +7,7 @@ namespace App\Model;
use Hyperf\Database\Model\Collection;
use Hyperf\Snowflake\Concern\Snowflake;
/**
* @property int $id 主键id
@ -20,6 +21,8 @@ use Hyperf\Database\Model\Collection;
*/
class DiseaseClassDetection extends Model
{
use Snowflake;
/**
* The table associated with the model.
*/

View File

@ -0,0 +1,112 @@
<?php
declare(strict_types=1);
namespace App\Model;
use Hyperf\Database\Model\Collection;
use Hyperf\Snowflake\Concern\Snowflake;
/**
* @property int $order_detection_id 主键id
* @property int $user_id 用户id-患者
* @property int $patient_id 患者id
* @property int $doctor_id 医生id
* @property int $family_id 家庭成员id就诊用户
* @property int $detection_project_id 检测项目id
* @property int $purpose_id 检测项目用途id
* @property int $detection_organ_id 检测机构id
* @property int $detection_status 检测订单状态(1:待支付 2:待绑定 3:检测中 4:检测完成 5:已取消)
* @property int $is_delete 删除状态0: 1:是)
* @property int $detection_refund_status 检测订单退款状态0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭 6:退款异常)
* @property int $detection_pay_channel 支付渠道1:小程序支付 2:微信扫码支付 3:模拟支付)
* @property int $detection_pay_status 支付状态1:未支付 2:已支付 3:支付中 4:支付失败 5:支付超时 6:支付关闭 7:已撤销 8:转入退款)
* @property string $detection_no 系统订单编号
* @property string $escrow_trade_no 第三方支付流水号
* @property string $amount_total 订单金额
* @property string $coupon_amount_total 优惠卷总金额
* @property string $payment_amount_total 实际付款金额
* @property string $pay_time 支付时间
* @property string $cancel_time 订单取消时间
* @property int $cancel_reason 取消订单原因1:主动取消 2:客服取消 3:支付超时)
* @property string $cancel_remarks 取消订单备注(自动添加)
* @property string $patient_name 患者姓名-就诊人
* @property string $patient_name_mask 患者姓名-就诊人(掩码)
* @property int $patient_sex 患者性别-就诊人0:未知 1: 2:女)
* @property int $patient_age 患者年龄-就诊人
* @property string $detection_bar_code 检测条码
* @property \Carbon\Carbon $created_at 创建时间
* @property \Carbon\Carbon $updated_at 修改时间
*/
class OrderDetection extends Model
{
use Snowflake;
/**
* The table associated with the model.
*/
protected ?string $table = 'order_detection';
/**
* The attributes that are mass assignable.
*/
protected array $fillable = ['order_detection_id', 'user_id', 'patient_id', 'doctor_id', 'family_id', 'detection_project_id', 'purpose_id', 'detection_organ_id', 'detection_status', 'is_delete', 'detection_refund_status', 'detection_pay_channel', 'detection_pay_status', 'detection_no', 'escrow_trade_no', 'amount_total', 'coupon_amount_total', 'payment_amount_total', 'pay_time', 'cancel_time', 'cancel_reason', 'cancel_remarks', 'patient_name', 'patient_name_mask', 'patient_sex', 'patient_age', 'detection_bar_code', 'created_at', 'updated_at'];
protected string $primaryKey = "order_detection_id";
/**
* 获取信息-单条
* @param array $params
* @param array $fields
* @return object|null
*/
public static function getOne(array $params, array $fields = ['*']): object|null
{
return self::where($params)->first($fields);
}
/**
* 获取数据-
* @param array $params
* @param array $fields
* @return Collection|array
*/
public static function getList(array $params = [], array $fields = ['*']): Collection|array
{
return self::where($params)->get($fields);
}
/**
* 新增-批量
* @param array $data 新增数据
* @return \Hyperf\Database\Model\Model|OrderDetection
*/
public static function addOrderDetection(array $data): \Hyperf\Database\Model\Model|OrderDetection
{
return self::create($data);
}
/**
* 修改-批量
* @param array $params
* @param array $data
* @return int
*/
public static function editOrderDetection(array $params = [], array $data = []): int
{
return self::where($params)->update($data);
}
/**
* 获取未完成订单
* @param array $params
* @param array $fields
* @return object|null
*/
public static function getNotFinishedOrderDetectionOne(array $params,array $fields = ['*']): object|null
{
return self::where($params)->whereIn('detection_status',[1,2,3])->first($fields);
}
}

View File

@ -0,0 +1,87 @@
<?php
declare(strict_types=1);
namespace App\Model;
use Hyperf\Database\Model\Collection;
use Hyperf\Snowflake\Concern\Snowflake;
/**
* @property int $detection_case_id 主键id
* @property int $order_detection_id 订单-检测id
* @property int $family_id 家庭成员id
* @property int $doctor_id 医生id检测医生
* @property int $relation 与患者关系1:本人 2:父母 3:爱人 4:子女 5:亲戚 6:其他
* @property string $name 患者名称
* @property int $sex 患者性别0:未知 1: 2:女)
* @property int $age 患者年龄
* @property int $nation_id 民族
* @property string $nation_name 民族名称
* @property string $detection_disease_class_ids 疾病id-检测-逗号分隔
* @property string $detection_disease_class_names 疾病名称-检测-逗号分隔
* @property \Carbon\Carbon $created_at 创建时间
* @property \Carbon\Carbon $updated_at 修改时间
*/
class OrderDetectionCase extends Model
{
use Snowflake;
/**
* The table associated with the model.
*/
protected ?string $table = 'order_detection_case';
/**
* The attributes that are mass assignable.
*/
protected array $fillable = ['detection_case_id', 'order_detection_id', 'family_id', 'doctor_id', 'relation', 'name', 'sex', 'age', 'nation_id', 'nation_name', 'detection_disease_class_ids', 'detection_disease_class_names', 'created_at', 'updated_at'];
protected string $primaryKey = "detection_case_id";
/**
* 获取信息-单条
* @param array $params
* @param array $fields
* @return object|null
*/
public static function getOne(array $params, array $fields = ['*']): object|null
{
return self::where($params)->first($fields);
}
/**
* 获取数据-
* @param array $params
* @param array $fields
* @return Collection|array
*/
public static function getList(array $params = [], array $fields = ['*']): Collection|array
{
return self::where($params)->get($fields);
}
/**
* 新增-批量
* @param array $data 新增数据
* @return \Hyperf\Database\Model\Model|OrderDetectionCase
*/
public static function addOrderDetectionCase(array $data): \Hyperf\Database\Model\Model|OrderDetectionCase
{
return self::create($data);
}
/**
* 修改-批量
* @param array $params
* @param array $data
* @return int
*/
public static function editOrderDetectionCase(array $params = [], array $data = []): int
{
return self::where($params)->update($data);
}
}

View File

@ -379,15 +379,6 @@ class UserDoctor extends Model
->whereHas('Hospital', function ($query) use ($hospital_params) {
$query->where($hospital_params);
})
// ->when($keyword, function ($query, $keyword) {
// $query->where(function ($query) use ($keyword) {
// $query->orwhere("user_name", 'like', '%' . $keyword . '%');
// $query->orwhere("department_custom_name", 'like', '%' . $keyword . '%');
// $query->orWhereHas('Hospital', function ($query) use ($keyword) {
// $query->where('hospital_name', 'like', '%' . $keyword . '%');
// });
// });
// })
->where($params)
->get($fields);
}

View File

@ -16,6 +16,10 @@ class DetectionRequest extends FormRequest
'family_id',
'nation_id',
'detection_disease_class_ids',
'detection_project_id', // 检测项目id
'purpose_id', // 检测项目用途id
'doctor_id', // 医生id
'client_type', // 客户端类型(1:手机 2电脑)
],
];
@ -33,7 +37,13 @@ class DetectionRequest extends FormRequest
public function rules(): array
{
return [
'patient_id' => 'required',
'family_id' => 'required',
'nation_id' => 'required',
'detection_disease_class_ids' => 'required',
'detection_project_id' => 'required',
'doctor_id' => 'required',
'client_type' => 'required|integer|min:1|max:2',
];
}
@ -43,7 +53,16 @@ class DetectionRequest extends FormRequest
public function messages(): array
{
return [
'company_id.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'patient_id.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'family_id.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'nation_id.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'detection_disease_class_ids.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'detection_project_id.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'doctor_id.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'client_type.required' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'client_type.integer' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'client_type.min' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
'client_type.max' => HttpEnumCode::getMessage(HttpEnumCode::CLIENT_HTTP_ERROR),
];
}
}

View File

@ -2,12 +2,25 @@
namespace App\Services;
use App\Amqp\Producer\CancelUnpayOrdersDelayDirectProducer;
use App\Constants\HttpEnumCode;
use App\Model\Area;
use App\Model\BasicCompany;
use App\Model\BasicNation;
use App\Model\DetectionProject;
use App\Model\DetectionProjectPurpose;
use App\Model\DiseaseClassDetection;
use App\Model\OrderDetection;
use App\Model\OrderDetectionCase;
use App\Model\PatientFamily;
use App\Model\UserDoctor;
use App\Model\UserLocation;
use App\Utils\Log;
use Hyperf\Amqp\Producer;
use Hyperf\DbConnection\Db;
use Hyperf\Snowflake\IdGeneratorInterface;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
class DetectionService extends BaseService
{
@ -257,4 +270,201 @@ class DetectionService extends BaseService
return success($detection_project_purpose->toArray());
}
/**
* 创建检测订单
* @return array
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
public function addDetectionOrder(): array
{
$result = array();
$result['status'] = 1;
$result['message'] = "成功";
$result['data'] = [
"inquiry_no" => "",
"order_detection_id" => "",
];
$user_info = $this->request->getAttribute("userInfo") ?? [];
$request_params = $this->request->all();
// 检测家庭成员是否存在
$params = array();
$params['family_id'] = $request_params['family_id'];
$params['patient_id'] = $user_info['client_user_id'];
$params['status'] = 1;
$patient_family = PatientFamily::getOne($params);
if (empty($patient_family)) {
return fail(HttpEnumCode::HTTP_ERROR, "患者信息错误");
}
// 检测是否存在同类型未完成的检测订单
$params = array();
$params['patient_id'] = $user_info['client_user_id'];
$params['family_id'] = $request_params['family_id'];
$params['detection_project_id'] = $request_params['detection_project_id'];
$order_detection = OrderDetection::getNotFinishedOrderDetectionOne($params);
if (!empty($order_detection)){
$result['status'] = 2;
$result['message'] = "当前患者存在未完成的检测订单";
$result['data']['order_detection_id'] = $order_detection['order_detection_id'];
return success($result);
}
// 检测民族
$params = array();
$params['nation_id'] = $request_params['nation_id'];
$nation = BasicNation::getOne($params);
if (empty($nation)){
return fail(HttpEnumCode::HTTP_ERROR,"民族选择错误");
}
// 检测疾病分类
$detection_disease_class_ids = explode(',',$request_params['detection_disease_class_ids']);
if (count($detection_disease_class_ids) > 3){
return fail(HttpEnumCode::HTTP_ERROR,"既往病史最多可选三项");
}
$detection_disease_class_names = "";
foreach ($detection_disease_class_ids as $value){
$params = array();
$params['id'] = $value;
$disease_class_detection = DiseaseClassDetection::getOne($params);
if (empty($disease_class_detection)){
return fail(HttpEnumCode::HTTP_ERROR,"既往病史错误");
}
if ($disease_class_detection['status'] != 1){
return fail(HttpEnumCode::HTTP_ERROR,"既往病史错误");
}
if ($disease_class_detection['enable'] != 1){
return fail(HttpEnumCode::HTTP_ERROR,"既往病史错误");
}
if (empty($detection_disease_class_names)){
$detection_disease_class_names = $disease_class_detection['name'];
}else{
$detection_disease_class_names = $detection_disease_class_names . ',' . $disease_class_detection['name'];
}
}
// 检测项目
$params = array();
$params['detection_project_id'] = $request_params['detection_project_id'];
$detection_project = DetectionProject::getOne($params);
if (empty($detection_project)){
return fail(HttpEnumCode::HTTP_ERROR,"检测项目错误");
}
if ($detection_project['detection_project_price'] <= 0){
return fail(HttpEnumCode::HTTP_ERROR,"订单金额错误");
}
// 检测用途
$params = array();
$params['purpose_id'] = $request_params['purpose_id'];
$params['detection_project_id'] = $request_params['detection_project_id'];
$detection_project_purpose = DetectionProjectPurpose::getOne($params);
if (empty($detection_project_purpose)){
return fail();
}
// 检测医生
$params = array();
$params['doctor_id'] = $request_params['doctor_id'];
$user_doctor = UserDoctor::getOne($params);
if (empty($user_doctor)){
return fail(HttpEnumCode::HTTP_ERROR,"医生错误");
}
if ($user_doctor['is_sys_diagno_cooperation'] != 1){
return fail(HttpEnumCode::HTTP_ERROR,"医生错误");
}
// 确定支付渠道
// 支付渠道1:小程序支付 2:微信扫码支付)
if ($request_params['client_type'] == 1) {
$detection_pay_channel = 1;
} elseif ($request_params['client_type'] == 2) {
$detection_pay_channel = 2;
}
// 处理订单金额
Db::beginTransaction();
$generator = $this->container->get(IdGeneratorInterface::class);
try {
// 新增检测订单
$data = array();
$data['user_id'] = $user_info['user_id'];
$data['patient_id'] = $user_info['client_user_id'];
$data['doctor_id'] = $user_doctor['doctor_id'];
$data['family_id'] = $patient_family['family_id'];
$data['detection_project_id'] = $detection_project['detection_project_id'];
$data['purpose_id'] = $detection_project_purpose['purpose_id'];
$data['detection_status'] = 1; // 检测订单状态(1:待支付 2:待绑定 3:检测中 4:检测完成 5:已取消)
$data['detection_pay_channel'] = $detection_pay_channel; // 支付渠道1:小程序支付 2:微信扫码支付 3:模拟支付)
$data['detection_no'] = "D" . $generator->generate(); // 系统订单编号
$data['amount_total'] = $detection_project['detection_project_price']; // 订单金额
$data['patient_name'] = $patient_family['card_name'];// 患者姓名-就诊人
$data['patient_name_mask'] = $patient_family['card_name_mask'];// 患者姓名-就诊人(掩码)
$data['patient_sex'] = $patient_family['sex'];// 患者性别-就诊人0:未知 1:男 2:女)
$data['patient_age'] = $patient_family['age'];// 患者年龄-就诊人
$order_detection = OrderDetection::addOrderDetection($data);
if (empty($order_detection)){
Db::rollBack();
return fail(HttpEnumCode::SERVER_ERROR, "订单创建失败");
}
// 新增检测订单病例
$data = array();
$data['order_detection_id'] = $order_detection['order_detection_id'];
$data['family_id'] = $patient_family['family_id'];
$data['doctor_id'] = $user_doctor['doctor_id'];
$data['relation'] = $patient_family['relation']; // 与患者关系1:本人 2:父母 3:爱人 4:子女 5:亲戚 6:其他
$data['name'] = $patient_family['card_name']; // 患者名称
$data['sex'] = $patient_family['sex'] ?? 0; // 患者性别0:未知 1:男 2:女)
$data['age'] = $patient_family['age'] ?? null; // 患者年龄
$data['nation_id'] = $nation['nation_id'] ?? null; // 民族
$data['nation_name'] = $nation['nation_name'] ?? null; // 民族名称
$data['detection_disease_class_ids'] = $request_params['detection_disease_class_ids']; // 疾病id-检测-逗号分隔
$data['detection_disease_class_names'] = $detection_disease_class_names; // 疾病名称-检测-逗号分隔
$order_detection_case = OrderDetectionCase::addOrderDetectionCase($data);
if (empty($order_detection_case)){
Db::rollBack();
return fail(HttpEnumCode::SERVER_ERROR, "订单创建失败");
}
// 增加至未支付取消订单延迟队列
// $data = array();
// $data['order_no'] = $order_detection['detection_no'];
// $data['order_type'] = 3;
//
// $message = new CancelUnpayOrdersDelayDirectProducer($data);
// $message->setDelayMs(1000 * 60 * 30);
// $producer = $this->container->get(Producer::class);
// $res = $producer->produce($message);
// if (!$res) {
// Db::rollBack();
// return fail(HttpEnumCode::SERVER_ERROR, "订单创建失败");
// }
Db::commit();
}catch (\Exception $e){
Db::rollBack();
return fail(HttpEnumCode::HTTP_ERROR, $e->getMessage());
}
$result['status'] = 1;
$result['data']['order_detection_id'] = (string)$order_detection['order_detection_id']; // 订单主键id
$result['data']['inquiry_no'] = (string)$order_detection['detection_no']; // 订单编号
return success($result);
}
}