CRMEB_PRO_M/app/model/activity/coupon/StoreCouponUser.php

208 lines
4.9 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\model\activity\coupon;
use app\model\user\User;
use crmeb\basic\BaseModel;
use crmeb\traits\ModelTrait;
use think\Model;
/**
* 优惠券发放Model
* Class StoreCouponUser
* @package app\model\activity\coupon
*/
class StoreCouponUser extends BaseModel
{
use ModelTrait;
/**
* 数据表主键
* @var string
*/
protected $pk = 'id';
/**
* 模型名称
* @var string
*/
protected $name = 'store_coupon_user';
/**
* 获取类型
* @var string[]
*/
protected $gainType = [
'send' => '后台发放',
'get' => '手动领取',
'newcomer' => '新人礼赠送',
'activate_level' => '会员卡激活赠送',
'user_first' => '用户注册赠送',
'order' => '下单赠送',
'luck_lottery' => '抽奖赠送'
];
/**
* 类型获取器
* @param $value
* @return string
*/
public function getTypeAttr($value)
{
return $this->gainType[$value] ?? '';
}
/**
* 使用状态
* @var string[]
*/
protected $statusType = [0 => '未使用', 1 => '已使用', 2 => '已过期'];
/**
* 状态获取器
* @param $value
* @return string
*/
public function getStatusAttr($value)
{
return $this->statusType[$value];
}
/**
* @return \think\model\relation\HasOne
*/
public function issue()
{
return $this->hasOne(StoreCouponIssue::class, 'id', 'cid')->field(['id', 'end_use_time', 'start_use_time', 'coupon_type', 'type', 'coupon_time', 'product_id', 'category_id', 'brand_id', 'receive_type', 'applicable_type', 'applicable_store_id'])->bind([
'coupon_applicable_type' => 'type',
'coupon_time' => 'coupon_time',
'product_id',
'category_id',
'brand_id',
'receive_type',
'coupon_type',
'start_use_time',
'end_use_time',
'applicable_type',
'applicable_store_id'
]);
}
/**
* 获取领取人名称头像
* @return \think\model\relation\HasOne
*/
public function userInfo()
{
return $this->hasOne(User::class, 'uid', 'uid')->field('uid,nickname,avatar')->bind(['nickname', 'avatar']);
}
/**
* id
* @param Model $query
* @param $value
*/
public function searchIdAttr($query, $value)
{
if (is_array($value))
$query->whereIn('id', $value);
else
$query->where('id', $value);
}
/**
* 优惠券ID搜索器
* @param Model $query
* @param $value
*/
public function searchCidAttr($query, $value)
{
if (is_array($value))
$query->whereIn('cid', $value);
else
$query->where('cid', $value);
}
/**
* 用户ID搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchUidAttr($query, $value, $data)
{
$query->where('uid', $value);
}
/**
* 优惠券名称搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchCouponTitleAttr($query, $value, $data)
{
$query->where('coupon_title', 'like', '%' . $value . '%');
}
/**
* 获取方式搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchTypeAttr($query, $value, $data)
{
$query->where('type', $value);
}
/**
* 用户ID搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchStatusAttr($query, $value, $data)
{
if ($value !== '' && $value != -1) {
if (is_array($value)) {
$query->whereIn('status', $value);
} else {
$query->where('status', $value);
}
}
}
/**
* 是否失效
* @param Model $query
* @param $value
* @param $data
*/
public function searchIsFailAttr($query, $value, $data)
{
$query->where('is_fail', $value);
}
/**
* 是否在使用期限内搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchTimeAttr($query, $value, $data)
{
$query->whereTime('add_time', '>=', $value)->whereTime('end_time', '<=', $value);
}
}