quanwei
2025-11-21 2d9362ae6f528f57e6133d5d80f0b633c24e8eb6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
<?php
 
namespace app\common\model\user;
 
use app\common\model\BaseModel;
use app\common\service\order\OrderService;
use app\common\model\user\WxCard as WxCardModel;
 
/**
 * 会员卡领取记录模型
 */
class CardRecord extends BaseModel
{
    protected $pk = 'order_id';
    protected $name = 'user_card_record';
 
    /**
     * 追加字段
     * @var string[]
     */
    protected $append = [
        'expire_time_text',
        'pay_time_text',
        'pay_type_text',
    ];
 
    /**
     * 会员卡有效期
     * @param $value
     * @param $data
     * @return string
     */
    public function getExpireTimeTextAttr($value, $data)
    {
        return $data['expire_time'] ? '有效期至' . date('Y-m-d', $data['expire_time']) : '永久有效';
    }
 
    /**
     * 会员卡有效期
     * @param $value
     * @param $data
     * @return string
     */
    public function getPayTimeTextAttr($value, $data)
    {
        return date('Y-m-d H:i:s', $data['pay_time']);
    }
 
    /**
     * 会员卡有效期
     * @param $value
     * @param $data
     * @return string
     */
    public function getPayTypeTextAttr($value, $data)
    {
        $pay_type = [10 => '余额支付', 20 => '微信支付', 30 => '后台发卡'];
        return $pay_type[$data['pay_type']];
    }
 
    /**
     * 优惠券数组转换
     * @param $value
     * @param $data
     * @return string
     */
    public function setOpenCouponsAttr($value)
    {
        return $value ? json_encode($value) : '';
    }
 
    /**
     * 优惠券数组转换
     * @param $value
     * @param $data
     * @return string
     */
    public function getOpenCouponsAttr($value)
    {
        return $value ? json_decode($value, 1) : [];
    }
 
    /**
     * 数组转换
     * @param $value
     * @param $data
     * @return string
     */
    public function setOpenProductsAttr($value)
    {
        return $value ? json_encode($value) : '';
    }
 
    /**
     * 数组转换
     * @param $value
     * @param $data
     * @return string
     */
    public function getOpenProductsAttr($value)
    {
        return $value ? json_decode($value, 1) : [];
    }
 
    /**
     * 关联会员卡表
     */
    public function card()
    {
        return $this->belongsTo('app\\common\\model\\user\\Card', 'card_id', 'card_id');
    }
 
    /**
     * 关联会员表
     */
    public function user()
    {
        return $this->belongsTo('app\\common\\model\\user\\User', 'user_id', 'user_id');
    }
 
    /**
     * 获取详情
     */
    public static function detail($order_id)
    {
        return (new static())->with(['card'])->find($order_id);
    }
 
    /**
     * 指定卡下是否存在用户
     */
    public static function checkExistByRecordId($card_id)
    {
        $model = new static;
        return !!$model->where('card_id', '=', (int)$card_id)->count();
    }
 
    /**
     * 指定用户是否存在卡
     */
    public static function checkExistByUserId($user_id, $order_id = 0)
    {
        $model = new static;
        if ($order_id) {
            $model = $model->where('order_id', '<>', $order_id);
        }
        return $model->where('is_delete', '=', 0)
            ->where('pay_status', '=', 20)
            ->where('user_id', '=', $user_id)
            ->where(function ($query) {
                $query->where('expire_time', '=', 0)->whereOr('expire_time', '>', time());
            })
            ->count();
    }
 
    /**
     * 生成订单号
     */
    public function orderNo()
    {
        return OrderService::createOrderNo();
    }
}