Files
hyperf_service/app/Service/Api/Coupon/CouponListService.php
2025-03-31 16:28:39 +08:00

86 lines
3.3 KiB
PHP

<?php
/**
* This service file is part of item.
*
* @author ctexthuang
* @contact ctexthuang@qq.com
*/
declare(strict_types=1);
namespace App\Service\Api\Coupon;
use App\Constants\Common\CouponCode;
use App\Model\CouponTemplate;
use App\Model\UserCoupon;
use App\Service\Api\BaseService;
use Hyperf\Di\Annotation\Inject;
class CouponListService extends BaseService
{
/**
* @var UserCoupon
*/
#[Inject]
protected UserCoupon $userCouponModel;
/**
* @var CouponTemplate
*/
#[Inject]
protected CouponTemplate $couponTemplateModel;
/**
* @return array
*/
public function handle(): array
{
$limit = (int)$this->request->input('limit',20);
$searchStatus = (int)$this->request->input('searchStatus',CouponCode::COUPON_STATUS_UNUSED);
$data = $this->couponTemplateModel
->join('user_coupon', function ($join) use ($searchStatus) {
$join->on('user_coupon.coupon_template_id', '=', 'coupon_template.id')
->where('user_coupon.user_id', '=', $this->userId)
->when($searchStatus, function ($query, $searchStatus) {
// $query->where('user_coupon.status','=',$searchStatus);
switch ($searchStatus) {
case CouponCode::COUPON_STATUS_UNUSED:
$query->where('user_coupon.status','=',$searchStatus)->where('user_coupon.validity_end_time', '>=', date('Y-m-d H:i:s'));
break;
case CouponCode::COUPON_STATUS_EXPIRE:
$query->where('user_coupon.status','=',$searchStatus)->where('user_coupon.validity_end_time', '<', date('Y-m-d H:i:s'));
break;
case CouponCode::COUPON_STATUS_CAN_USED:
$query->where('user_coupon.status','=',CouponCode::COUPON_STATUS_UNUSED)->where('user_coupon.validity_start_time', '<=', date('Y-m-d H:i:s'));
break;
case CouponCode::COUPON_STATUS_USED:
$query->where('user_coupon.status','=',$searchStatus);
default:
break;
}
})
// ->where('user_coupon.status', '=', CouponCode::COUPON_STATUS_UNUSED)
// ->where('validity_start_time', '<=', date('Y-m-d H:i:s'))
// ->where('validity_end_time', '>=', date('Y-m-d H:i:s'))
->select([
'coupon_template.coupon_type',
'coupon_template.amount',
'coupon_template.ratio',
'user_coupon.id',
'user_coupon.coupon_template_id',
'user_coupon.coupon_name',
'user_coupon.status',
'user_coupon.validity_start_time',
'user_coupon.validity_end_time',
]);
})
->paginate($limit)
->toArray();
if (empty($data['list'])) return $this->return->success('success',$data);
return $this->return->success('success',$data);
}
}