200 lines
4.6 KiB
PHP
200 lines
4.6 KiB
PHP
<?php
|
|
|
|
|
|
namespace app\common\model\user;
|
|
|
|
|
|
use app\common\enum\user\UserEnum;
|
|
use app\common\model\BaseModel;
|
|
use app\common\model\user_label\UserLabel;
|
|
use app\common\service\FileService;
|
|
use think\model\concern\SoftDelete;
|
|
|
|
/**
|
|
* 用户模型
|
|
* Class User
|
|
* @package app\common\model\user
|
|
*/
|
|
class User extends BaseModel
|
|
{
|
|
use SoftDelete;
|
|
|
|
protected $deleteTime = 'delete_time';
|
|
|
|
//会员类型
|
|
public function userShip()
|
|
{
|
|
return $this->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();
|
|
}
|
|
}
|