hasOne(UserShip::class,'id','user_ship') ->bind(['vip_name'=>'title','discount','limit']); } public function userLabel() { return $this->hasOne(UserLabel::class,'label_id','label_id') ->bind(['label_name']); } /** * @notes 关联用户授权模型 * @return \think\model\relation\HasOne * @author 乔峰 * @date 2022/9/22 16:03 */ public function userAuth() { return $this->hasOne(UserAuth::class, 'user_id'); } /** * @notes 搜索器-用户信息 * @param $query * @param $value * @param $data * @author 乔峰 * @date 2022/9/22 16:12 */ public function searchKeywordAttr($query, $value, $data) { if ($value) { $query->where('nickname|mobile', 'like', '%' . $value . '%'); } } /** * @notes 搜索器-注册来源 * @param $query * @param $value * @param $data * @author 乔峰 * @date 2022/9/22 16:13 */ public function searchChannelAttr($query, $value, $data) { if ($value) { $query->where('channel', '=', $value); } } /** * @notes 搜索器-注册时间 * @param $query * @param $value * @param $data * @author 乔峰 * @date 2022/9/22 16:13 */ public function searchCreateTimeStartAttr($query, $value, $data) { if ($value) { $query->where('create_time', '>=', $value); } } /** * @notes 搜索器-注册时间 * @param $query * @param $value * @param $data * @author 乔峰 * @date 2022/9/22 16:13 */ public function searchCreateTimeEndAttr($query, $value, $data) { if ($value) { $query->where('create_time', '<=', $value); } } /** * @notes 头像获取器 - 用于头像地址拼接域名 * @param $value * @return string * @author Tab * @date 2021/7/17 14:28 */ public function getAvatarAttr($value) { if ($value) { return trim($value) ? FileService::getFileUrl($value) : ''; } } /** * @notes 获取器-性别描述 * @param $value * @param $data * @return string|string[] * @author 乔峰 * @date 2022/9/7 15:15 */ public function getSexTextAttr($value, $data) { return UserEnum::getSexDesc($data['sex']); } /** * @notes 登录时间 * @param $value * @return string * @author 乔峰 * @date 2022/9/23 18:15 */ public function getLoginTimeAttr($value) { return $value ? date('Y-m-d H:i:s', $value) : ''; } /** * @notes 生成用户编码 * @param string $prefix * @param int $length * @return string * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException * @author 乔峰 * @date 2022/9/16 10:33 */ public static function createUserSn($prefix = '', $length = 8) { // $rand_str = ''; // for ($i = 0; $i < $length; $i++) { // $rand_str .= mt_rand(0, 9); // } $sn = $prefix . time(); // if (User::where(['sn' => $sn])->find()) { // return self::createUserSn($prefix, $length); // } return $sn; } /** * 获取用户统计数据 * @param $time * @param $type * @param $timeType * @return mixed */ public function getTrendData($time, $type, $timeType) { return $this->when($type != '', function ($query) use ($type) { $query->where('user_type', $type); })->where(function ($query) use ($time) { if ($time[0] == $time[1]) { $query->whereDay('create_time', $time[0]); } else { $time[1] = $time[1] + 86400; $query->whereTime('create_time', 'between', $time); } })->field("FROM_UNIXTIME(create_time,'$timeType') as days,count(id) as num")->group('days')->select()->toArray(); } }