You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
336 lines
9.0 KiB
336 lines
9.0 KiB
<?php
|
|
|
|
// +----------------------------------------------------------------------
|
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
|
// +----------------------------------------------------------------------
|
|
// | Author: CRMEB Team <admin@crmeb.com>
|
|
// +----------------------------------------------------------------------
|
|
|
|
|
|
namespace app\common\model\user;
|
|
|
|
|
|
use app\common\model\BaseModel;
|
|
use app\common\model\store\service\StoreService;
|
|
use app\common\model\wechat\WechatUser;
|
|
use app\common\repositories\store\coupon\StoreCouponUserRepository;
|
|
use app\common\repositories\store\order\StoreGroupOrderRepository;
|
|
use app\common\repositories\store\service\StoreServiceLogRepository;
|
|
use app\common\repositories\user\UserBillRepository;
|
|
use app\common\repositories\user\UserExtractRepository;
|
|
use app\common\repositories\user\UserHistoryRepository;
|
|
use app\common\repositories\user\UserRelationRepository;
|
|
use app\common\repositories\user\UserRepository;
|
|
|
|
/**
|
|
* Class User
|
|
* @package app\common\model\user
|
|
* @author xaboy
|
|
* @day 2020-04-28
|
|
*/
|
|
class User extends BaseModel
|
|
{
|
|
|
|
/**
|
|
* @return string
|
|
* @author xaboy
|
|
* @day 2020-03-30
|
|
*/
|
|
public static function tablePk(): string
|
|
{
|
|
return 'uid';
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
* @author xaboy
|
|
* @day 2020-03-30
|
|
*/
|
|
public static function tableName(): string
|
|
{
|
|
return 'user';
|
|
}
|
|
|
|
/**
|
|
* @param $value
|
|
* @return string
|
|
* @author xaboy
|
|
* @day 2020-05-09
|
|
*/
|
|
public function getBirthdayAttr($value)
|
|
{
|
|
return $value == '0000-00-00' ? '' : $value;
|
|
}
|
|
|
|
public function getIsSvipAttr($value)
|
|
{
|
|
|
|
if (systemConfig('svip_switch_status') == 1) {
|
|
return $value;
|
|
} else {
|
|
return $value > 0 ? 0 : $value;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param $value
|
|
* @return array
|
|
* @author xaboy
|
|
* @day 2020-05-09
|
|
*/
|
|
public function getLabelIdAttr($value)
|
|
{
|
|
return $value ? explode(',', $value) : [];
|
|
}
|
|
|
|
/**
|
|
* @param $value
|
|
* @return string
|
|
* @author xaboy
|
|
* @day 2020-05-09
|
|
*/
|
|
public function setLabelIdAttr($value)
|
|
{
|
|
return is_array($value) ? implode(',', $value) : $value;
|
|
}
|
|
|
|
public function getValidSpreadUidAttr()
|
|
{
|
|
if (!$this->spread_uid) return 0;
|
|
else {
|
|
$data = self::getDB()->where('uid', $this->spread_uid)->field('is_promoter,spread_uid')->find();
|
|
if ($data && $data['is_promoter'])
|
|
return $this->spread_uid;
|
|
else
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
public function getValidSpreadAttr()
|
|
{
|
|
if (!$this->spread_uid) return null;
|
|
else {
|
|
$data = self::getDB()->where('uid', $this->spread_uid)->field('is_promoter,spread_uid,brokerage_level,uid')->find();
|
|
if ($data && $data['is_promoter'])
|
|
return $data;
|
|
else
|
|
return null;
|
|
}
|
|
}
|
|
|
|
public function getValidTopUidAttr()
|
|
{
|
|
if (!$this->top_uid) return 0;
|
|
else {
|
|
$data = self::getDB()->where('uid', $this->top_uid)->field('is_promoter,spread_uid')->find();
|
|
if ($data && $data['is_promoter'])
|
|
return $this->top_uid;
|
|
else
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
public function getValidTopAttr()
|
|
{
|
|
if (!$this->top_uid) return null;
|
|
else {
|
|
$data = self::getDB()->where('uid', $this->top_uid)->field('is_promoter,spread_uid,brokerage_level,uid')->find();
|
|
if ($data && $data['is_promoter'])
|
|
return $data;
|
|
else
|
|
return null;
|
|
}
|
|
}
|
|
|
|
public function getTopUidAttr()
|
|
{
|
|
return self::getDB()->where('uid', $this->spread_uid)->value('spread_uid') ?: 0;
|
|
}
|
|
|
|
/**
|
|
* @return \think\model\relation\HasOne
|
|
* @author xaboy
|
|
* @day 2020-05-09
|
|
*/
|
|
public function group()
|
|
{
|
|
return $this->hasOne(UserGroup::class, 'group_id', 'group_id');
|
|
}
|
|
|
|
public function spread()
|
|
{
|
|
return $this->hasOne(User::class, 'uid', 'spread_uid');
|
|
}
|
|
|
|
public function spread2()
|
|
{
|
|
return $this->hasOne(User::class, 'uid', 'spread_uid2');
|
|
}
|
|
|
|
public function brokerage()
|
|
{
|
|
return $this->hasOne(UserBrokerage::class, 'brokerage_level', 'brokerage_level')->where('type',0);
|
|
}
|
|
|
|
public function member()
|
|
{
|
|
return $this->hasOne(UserBrokerage::class, 'brokerage_level', 'member_level')->where('type',1);
|
|
}
|
|
|
|
/**
|
|
* @param $spreadUid
|
|
* @author xaboy
|
|
* @day 2020-04-28
|
|
*/
|
|
public function setSpread($spreadUid)
|
|
{
|
|
if (self::getDB()->where('uid', $spreadUid)->value('is_promoter'))
|
|
$this->save([
|
|
'spread_uid' => $spreadUid,
|
|
'spread_time' => date('Y-m-d H:i:s')
|
|
]);
|
|
}
|
|
|
|
public function service()
|
|
{
|
|
return $this->hasOne(StoreService::class, 'uid', 'uid')
|
|
->where('mer_id', '<>', 0)
|
|
->where('is_del', 0)
|
|
->where('is_open', 1)
|
|
->field('service_id,uid,nickname,avatar,customer,mer_id,is_verify,is_goods,is_open')
|
|
->order('is_verify DESC,customer DESC');
|
|
}
|
|
|
|
public function topService()
|
|
{
|
|
return $this->hasOne(StoreService::class, 'uid', 'uid')
|
|
->where('mer_id', 0)->field('service_id,uid,nickname,avatar,customer,mer_id,is_verify,is_goods')->where('is_del', 0)
|
|
->order('is_verify DESC,customer DESC');
|
|
}
|
|
|
|
public function getLockBrokerageAttr()
|
|
{
|
|
return app()->make(UserBillRepository::class)->lockBrokerage($this->uid) ?: 0;
|
|
}
|
|
|
|
public function getLockIntegralAttr()
|
|
{
|
|
return app()->make(UserBillRepository::class)->lockIntegral($this->uid) ?: 0;
|
|
}
|
|
|
|
public function getYesterdayBrokerageAttr()
|
|
{
|
|
return app()->make(UserBillRepository::class)->yesterdayBrokerage($this->uid) ?: 0;
|
|
}
|
|
|
|
public function getTotalExtractAttr()
|
|
{
|
|
return app()->make(UserExtractRepository::class)->userTotalExtract($this->uid) ?: 0;
|
|
}
|
|
|
|
public function getTotalBrokerageAttr()
|
|
{
|
|
return app()->make(UserBillRepository::class)->totalBrokerage($this->uid) ?: 0;
|
|
}
|
|
|
|
public function getTotalBrokeragePriceAttr()
|
|
{
|
|
return bcadd($this->lock_brokerage, $this->brokerage_price, 2);
|
|
}
|
|
|
|
public function getTotalIntegralAttr()
|
|
{
|
|
return bcadd($this->lock_integral, $this->integral, 0);
|
|
}
|
|
|
|
public function getTotalRechargeAttr()
|
|
{
|
|
return app()->make(UserBillRepository::class)->userNowMoneyIncTotal($this->uid);
|
|
}
|
|
|
|
public function getTotalConsumeAttr()
|
|
{
|
|
return app()->make(StoreGroupOrderRepository::class)->totalNowMoney($this->uid);
|
|
}
|
|
|
|
public function getTotalCollectProductAttr()
|
|
{
|
|
return app()->make(UserRelationRepository::class)->getWhereCount(['uid' => $this->uid, 'type' => 1]);
|
|
}
|
|
|
|
public function getTotalCollectStoreAttr()
|
|
{
|
|
return app()->make(UserRelationRepository::class)->getWhereCount(['uid' => $this->uid, 'type' => 10]);
|
|
}
|
|
|
|
public function getTotalVisitProductAttr()
|
|
{
|
|
return app()->make(UserHistoryRepository::class)->userTotalHistory($this->uid);
|
|
}
|
|
|
|
public function getTotalCouponAttr()
|
|
{
|
|
return app()->make(StoreCouponUserRepository::class)->userTotal($this->uid, 0);
|
|
}
|
|
|
|
public function getTotalUnreadAttr()
|
|
{
|
|
return app()->make(StoreServiceLogRepository::class)->totalUnReadNum($this->uid);
|
|
}
|
|
|
|
public function getOneLevelCountAttr()
|
|
{
|
|
return app()->make(UserRepository::class)->getOneLevelCount($this->uid);
|
|
}
|
|
|
|
public function getTwoLevelCountAttr()
|
|
{
|
|
return app()->make(UserRepository::class)->getTwoLevelCount($this->uid);
|
|
}
|
|
|
|
public function getSpreadTotalAttr()
|
|
{
|
|
return $this->one_level_count + $this->two_level_count;
|
|
}
|
|
|
|
public function wechat()
|
|
{
|
|
return $this->hasOne(WechatUser::class, 'wechat_user_id', 'wechat_user_id');
|
|
}
|
|
|
|
public function getIntegralAttr($val)
|
|
{
|
|
return is_null($val) ? 0 : $val;
|
|
}
|
|
|
|
|
|
// public function getUserTypeAttr()
|
|
// {
|
|
// if($this->wechat['openid']){
|
|
// return 'wechat';
|
|
// }elseif($this->wechat['routine_openid']){
|
|
// return 'routine';
|
|
// }else{
|
|
// return 'H5';
|
|
// }
|
|
// }
|
|
|
|
public function getSubscribeAttr()
|
|
{
|
|
if ($this->wechat['openid'] && $this->wechat['subscribe']) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
public static function SumBrokeragePrice(int $status = 1): float
|
|
{
|
|
return self::getDB()->where("status", $status)->sum("brokerage_price") ?? 0.00;
|
|
}
|
|
|
|
}
|
|
|