170 lines
6.4 KiB
PHP
170 lines
6.4 KiB
PHP
<?php
|
||
|
||
declare(strict_types=1);
|
||
|
||
namespace App\Model;
|
||
|
||
|
||
|
||
use Hyperf\Database\Model\Builder;
|
||
use Hyperf\Database\Model\Collection;
|
||
use Hyperf\Snowflake\Concern\Snowflake;
|
||
|
||
/**
|
||
* @property int $order_detection_id 主键id
|
||
* @property int $order_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 $order_inquiry_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 string $detection_pic 检测管图片(逗号分隔)
|
||
* @property string $detection_time 上传检测时间
|
||
* @property string $detection_result_pdf 检测结果
|
||
* @property string $detection_result_date 检测结果时间
|
||
* @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', 'order_id', 'user_id', 'patient_id', 'doctor_id', 'family_id', 'detection_project_id', 'purpose_id', 'detection_organ_id', 'order_inquiry_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', 'detection_pic', 'detection_time', 'detection_result_pdf', 'detection_result_date', '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 object|null
|
||
*/
|
||
public static function getLastOne(array $params, array $fields = ['*']): object|null
|
||
{
|
||
return self::where($params)->latest()->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);
|
||
}
|
||
|
||
/**
|
||
* 获取问诊订单分页
|
||
* 已结束
|
||
* @param array $params
|
||
* @param array $detection_status_params
|
||
* @param array $fields
|
||
* @param int|null $page
|
||
* @param int|null $per_page
|
||
* @return array
|
||
*/
|
||
public static function getPatientOrderDetectionPage(array $params, array $detection_status_params, array $fields = ["*"], int $page = null, ?int $per_page = 10): array
|
||
{
|
||
$raw = self::where($params)
|
||
->when($detection_status_params, function ($query, $detection_status_params) {
|
||
$query->whereIn('detection_status', $detection_status_params);
|
||
})
|
||
->orderBy('created_at', 'desc')
|
||
->paginate($per_page, $fields, "page", $page);
|
||
|
||
$data = array();
|
||
$data['current_page'] = $raw->currentPage();// 当前页码
|
||
$data['total'] = $raw->total();//数据总数
|
||
$data['data'] = $raw->items();//数据
|
||
$data['per_page'] = $raw->perPage();//每页个数
|
||
$data['last_page'] = $raw->lastPage();//最后一页
|
||
|
||
return $data;
|
||
}
|
||
|
||
/**
|
||
* 获取数量
|
||
* @param array $params
|
||
* @return int
|
||
*/
|
||
public static function getCount(array $params): int
|
||
{
|
||
return self::where($params)->count();
|
||
}
|
||
}
|