449 lines
14 KiB
PHP
Raw Normal View History

<?php
namespace app\common\model\school\activity\order;
use app\common\model\BaseModel;
use app\common\model\school\activity\Activity;
use think\Model;
use traits\model\SoftDelete;
class OrderCode extends BaseModel
{
use SoftDelete;
// 表名
protected $name = 'school_activity_order_code';
// 自动写入时间戳字段
protected $autoWriteTimestamp = 'integer';
// 定义时间戳字段名
protected $createTime = 'createtime';
protected $updateTime = 'updatetime';
protected $deleteTime = 'deletetime';
// 追加属性
protected $append = [
'status_text',
'verificationtime_text'
];
public function getCodeimageAttr($value, $data)
{
2025-05-13 18:47:25 +08:00
if (!empty($value)) return cdnurl($value, request()->domain());
}
public function getCodeoneimageAttr($value, $data)
{
2025-05-13 18:47:25 +08:00
if (!empty($value)) return cdnurl($value, request()->domain());
}
public function getMiniurlAttr($value, $data)
{
$code = (isset($data['code']) ? $data['code'] : '');
$activity_order_id = (isset($data['activity_order_id']) ? $data['activity_order_id'] : '');
if (!$activity_order_id || !$code){
return $value;
}else{
return $value . "?id={$activity_order_id}&code={$code}";
}
}
public function getStatusList()
{
return ['3' => __('Status 3'), '6' => __('Status 6')];
}
public function getStatusTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
$list = $this->getStatusList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getVerificationtimeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['verificationtime']) ? $data['verificationtime'] : '');
return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
}
protected function setVerificationtimeAttr($value)
{
return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
}
public function activityorder()
{
return $this->belongsTo(Order::class, 'activity_order_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function user()
{
return $this->belongsTo('app\common\model\User', 'verification_user_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
/**更新订单核销状态
* @param $order
* @return array|false|\PDOStatement|string|Model
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function updateVerification($code,$oper_id = 0,$oper_type='user',$check=true){
if(is_string($code))$code = self::getHaveVerificationOrderCode($code,$check);
2025-08-12 18:58:05 +08:00
// if($code["status"] == "6")return $code;
$code->status = "6";//refund_status
$code->verification_user_id = $oper_id;
$code->verification_type = $oper_type;
$code->verificationtime = time();
$code->save();
return $code;
}
/**得到可核销订单
* @param $order_no
* @return array|false|\PDOStatement|string|Model
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getHaveVerificationOrderCode($code,$check=true){
// $where = [self::STATUS_NOPAY,self::STATUS_PAYED];
2025-08-12 18:58:05 +08:00
// $ordercode = self::where('code',$code)->where("status","in",['3'])->find();
$ordercode = self::where('code',$code)->find();
if(!$ordercode)throw new \Exception("当前码已存在或核销过!");
$order = $ordercode->activityorder;
if(!$order)throw new \Exception("订单异常!");
if(!$check) return $ordercode;
if(!in_array($order["status"],['2','3']))throw new \Exception("当前订单不可核销!");
//过了可核销时间段
(new Activity)->update_classes($order["activity_id"]);
$activity = $order->activity;
if(!$activity)throw new \Exception("活动异常!");
if(!in_array($activity["status"],["2","3","4"]))throw new \Exception("当前活动还不能核销!可能未到时间!");
return $ordercode;
}
/** 强制核销订单
* @param $code
* @param $oper_type
* @param $oper_id
* @return array|false|\PDOStatement|string|Model
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public function forceVerification($code,$oper_type='user',$oper_id=0,$check=true)
{
2025-08-12 18:58:05 +08:00
if(is_string($code))$code = self::getHaveVerificationOrderCode($code,$check);
if($code["status"] == "6")return $code;
$ordercode = self::updateVerification($code,$oper_id,$oper_type,$check);
2025-08-12 18:58:05 +08:00
$order = $ordercode->activityorder;
if($check){
//插入订单取消日志
if($oper_type!='user' || $order["user_id"] !=$oper_id ){
OrderLog::log($order['id'],"[员工操作]活动订单成功核销一人",$oper_type ?: 'user', $oper_id ?: $order['user_id']);
}else{
OrderLog::log($order['id'],"活动订单成功核销一人",$oper_type ?: 'user', $oper_id ?: $order['user_id']);
}
}else{
OrderLog::log($order['id'],"活动结束订单强制完成核销(超时结算或特殊情况)",$oper_type ?: 'user', $oper_id ?: $order['user_id']);
}
//调用订单取消事件
$data = ['order' => Order::where("id",$order['id'])->find(),"user_id"=>$order["user_id"],"oper_type"=>$oper_type,"oper_id"=>$oper_id];
\think\Hook::listen('activity_order_verification_after', $data);
//过了可核销时间段
(new Activity)->update_classes($order["activity_id"]);
return $ordercode;
}
/**订单核销
* @param $code
* @param int $user_id
* @param bool $check
* @param bool $trans
* @return bool
* @throws \Exception
*/
public function verification($code,$user_id=0,$check=false,$oper_type='user',$oper_id=0,$trans=false){
//得到可取消订单
$ordercode = self::getHaveVerificationOrderCode($code,$check);
2025-08-12 18:58:05 +08:00
if($ordercode["status"] == "6")return $ordercode;
$order = $ordercode->activityorder;
if(!$order) throw new \Exception("订单异常!");
$detail = $order->detail;
if(!$detail) throw new \Exception("订单异常!");
if($check){
//用户操作权限检测
Order::checkOptionAuth($order['id'],$user_id ?: $oper_id,$oper_type,false,true);
// if($detail["user_id"] != $user_id){
// throw new \Exception("当前用户不是核销员!");
// }
}
//判断逻辑
if($trans){
self::beginTrans();
}
$res = true;
try{
//事务逻辑
//更新订单状态
$ordercode = $this->forceVerification($code,$oper_type,$oper_id,$check);
//检测订单完成状态
Order::statisticsAndUpdateOrderFinish($order['id']);
if($trans){
self::commitTrans();
}
}catch (\Exception $e){
if($trans){
self::rollbackTrans();
}
throw new \Exception($e->getMessage().$e->getFile().$e->getLine());
}
return $ordercode;
}
2025-08-12 18:58:05 +08:00
/**
* 获取所有报名人列表
*/
public static function getVaildList($params,$count=false) {
extract($params);
// $a = '';
$a = (new self)->getWithAlisaName().'.';
$with = ['user'];
// if (isset($has_shop) && $has_shop) {
$with[] = 'activityorder';
// }
// $cate_list = Cate::where("status",'1')->column("name","id");
// $label_list = Label::where("status",'1')->column("name","id");
// $type_list = Type::where("status",'1')->column("name","id");
$selfetch = self::with($with);
// $selfetch = self::where("{$a}show", '=', '1');
$order = $order?? 'normal';
$per_page = $limit ?? 10;
// $field = "{$a}id,{$a}title,{$a}image,{$a}status,{$a}video_file,{$a}recommend,{$a}show,{$a}weigh,{$a}views,{$a}collect,{$a}release_time,{$a}createtime,{$a}updatetime,{$a}deletetime";
//
// //得到距离
// if (isset($latitude) && isset($longitude) && $latitude && $longitude) {
// $field .= ', '.getDistanceBuilder($latitude, $longitude,$a);
// }else{
// $field .= ', 0 as distance';
// }
//得到每个
// $selfetch = $selfetch->field($field);
if (isset($keywords) && $keywords) {
// //查询分类名获得分类id
// $keywords_cate_ids = Cate::where("name",'like', '%' . $keywords . '%')->column("id");
//
// if($keywords_cate_ids){
// $keywords_cate_ids = implode("|",$keywords_cate_ids);
// $selfetch = $selfetch->where(function ($query)use($a,$keywords_cate_ids,$keywords){
// $query->whereRaw(" {$a}cate_ids REGEXP '({$keywords_cate_ids})'")
// ->whereOr("{$a}title|{$a}platform_title|{$a}content|{$a}address|{$a}address_detail|{$a}address_city", 'like', '%' . $keywords . '%');
// });
//
//// $selfetch = $selfetch->whereOr( function ($query)use($a,$keywords_cate_ids){
//// $query->whereRaw(" {$a}cate_ids REGEXP '({$keywords_cate_ids})'")
//// ->where("{$a}show", '=', '1');
//// });
// }else{
$selfetch = $selfetch->where("{$a}name|{$a}idnum|{$a}mobile", 'like', '%' . $keywords . '%');
// }
}
if (isset($user_id) && $user_id) {
$selfetch = $selfetch->where("{$a}user_id", 'in', ''.$user_id);
}
if (isset($my) && $my && isset($my_user_id) && $my_user_id) {
$selfetch = $selfetch->where("{$a}user_id", 'in', ''.$my_user_id);
}
if($my ==1 && empty($my_user_id)){
$selfetch = $selfetch->where("{$a}user_id", 'in', [-3]);
}
if (isset($activity_id) && $activity_id) {
$selfetch = $selfetch->where("{$a}activity_id", 'in', ''.$activity_id);
}
//设置订单信息
if(isset($status) && $status !=='' && $status !==null){
$selfetch = $selfetch->where("activityorder.status", 'in', ''.$status);
}
if(isset($code_status) && $code_status !=='' && $code_status !==null){
$selfetch = $selfetch->where("{$a}status", 'in', ''.$code_status);
}
// $collect_classes_lib_ids = [-1];
// //需登录查询条件:
// if(isset($my_user_id) && $my_user_id){
// //得到我收藏的课程ids
// $collect_classes_lib_ids = Collect::where("user_id",$my_user_id)->column("meal_classes_id");
// //专查我的收藏
// if(isset($collect) && $collect){
// $selfetch = $selfetch->where("{$a}id","in",$collect_classes_lib_ids);
// }
//
// }
//排序
switch ($order) {
case "normal": //综合排序(推薦優先)
$selfetch = $selfetch->order("{$a}id desc");
break;
// case "distance": //距离优先 权重
// $selfetch = $selfetch->order("distance asc,{$a}recommend desc,{$a}weigh desc,{$a}id desc");
// break;
// case "recommend": //推薦优先
// $selfetch = $selfetch->order("{$a}recommend desc,{$a}weigh desc,{$a}id desc");
// break;
case "earliest": //浏览量优先
$selfetch = $selfetch->order("{$a}id asc");
break;
case "new": //收藏量优先
$selfetch = $selfetch->order("{$a}id desc");
break;
case "recently": //收藏量优先
$selfetch = $selfetch->order("{$a}id desc");
break;
default:
throw new \Exception("不支持的排序类型");
}
// if(isset($nearby) && $nearby) {
//// throw new \Exception("现版本不支持");
// $selfetch = $selfetch->having("distance <= {$nearby}");
// }
if($count){
$total = $selfetch->count();
return $total;
}
$selfetch = $selfetch->page($page,$limit)->select();
// foreach ($selfetch as $row) {
//
//// $row->getRelation('manystore')->visible(['nickname']);
//// $row->getRelation('user')->visible(['nickname','avatar']);
// }
$rows = $selfetch;
// $total = $selfetch->total();
//额外附加数据
foreach ($rows as &$row) { //迭代器魔术方法遍历,填值自动引用传值
//设置是否已收藏
if (isset($my) && $my) {
if (isset($my_user_id) && $my_user_id) {
//正常全显示
}else{
$row["name"] = "***";
if($row["idnum"] && $row["open"] == '0'){
//替换除了前三位往后所有字符为*
$row["idnum"] = substr_replace($row["idnum"], "***", 3, -4);
}
}
}
// $classes_cate_ids = $row['cate_ids'];
// $classes_cate = [];
// foreach (explode(",", $classes_cate_ids) as $classes_cate_id){
// if(isset($cate_list[$classes_cate_id]))$classes_cate[] = $cate_list[$classes_cate_id];
// }
// $row['cate'] = $classes_cate;
}
// $result = array("data" => $rows);
return $rows;
}
}