86 lines
3.3 KiB
PHP
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);
|
|
}
|
|
} |