like-shop/application/admin/logic/DistributionMemberLogic.php
2024-01-16 13:06:20 +08:00

488 lines
17 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
// +----------------------------------------------------------------------
// | likeshop开源商城系统
// +----------------------------------------------------------------------
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
// | gitee下载https://gitee.com/likeshop_gitee
// | github下载https://github.com/likeshop-github
// | 访问官网https://www.likeshop.cn
// | 访问社区https://home.likeshop.cn
// | 访问手册http://doc.likeshop.cn
// | 微信公众号likeshop技术社区
// | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用未经许可不能去除前后端官方版权标识
// | likeshop系列产品收费版本务必购买商业授权购买去版权授权后方可去除前后端官方版权标识
// | 禁止对系统程序代码以任何目的,任何形式的再发布
// | likeshop团队版权所有并拥有最终解释权
// +----------------------------------------------------------------------
// | author: likeshop.cn.team
// +----------------------------------------------------------------------
namespace app\admin\logic;
use app\admin\model\DistributionMemberApply;
use app\admin\model\User;
use app\common\model\DistributionMember;
use app\common\model\DistributionOrder;
use app\common\model\Withdraw;
use app\common\server\UrlServer;
use think\Db;
use think\Exception;
class DistributionMemberLogic
{
/**
* 分销会员列表
* @param $get
* @return array
*/
public static function memberLists($get)
{
$where = [];
$where[] = ['is_distribution', '=', 1];
if (!empty($get['search_key']) && !empty($get['keyword'])) {
$keyword = $get['keyword'];
if ($get['search_key'] == 'mobile') {
$where[] = ['mobile', 'like', '%' . $keyword . '%'];
} else {
$where[] = [$get['search_key'], 'like', '%' . $keyword . '%'];
}
}
//分销状态
if (isset($get['freeze_distribution']) && $get['freeze_distribution'] != '') {
$where[] = ['freeze_distribution', '=', $get['freeze_distribution']];
}
$user = new User();
$count = $user->where($where)->count();
$lists = $user
->where($where)
->page($get['page'], $get['limit'])
->append(['fans', 'distribution_order'])
->hidden(['password,pay_password,salt'])
->order('id desc')
->select()->toArray();
$user_level = Db::name('user_level')->where(['del' => 0])->column('name', 'id');
$leader_ids = array_column($lists, 'first_leader');
$leaders = Db::name('user')
->where('id', 'in', $leader_ids)
->column('sn,nickname,mobile,level', 'id');
foreach ($lists as &$item) {
$item['level'] = $user_level[$item['level']] ?? '无等级';
$item['avatar'] = UrlServer::getFileUrl($item['avatar']);
$item['leader'] = $leaders[$item['first_leader']] ?? [];
if (!empty($item['leader'])) {
$leader_level = $item['leader']['level'] ?? 0;
$item['leader']['level'] = $user_level[$leader_level] ?? '无等级';
}
$item['distribution_num'] = $item['distribution_order']['num'] ?? 0;//分销订单数
$item['distribution_amount'] = $item['distribution_order']['amount'] ?? 0;//分销订单金额
$item['distribution_money'] = $item['distribution_order']['money'] ?? 0;//分销佣金
}
return ['count' => $count, 'lists' => $lists];
}
/**
* 分销会员审核列表
* @param $get
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function auditLists($get)
{
$where = [];
if (!empty($get['search_key']) && !empty($get['keyword'])) {
$keyword = $get['keyword'];
if ($get['search_key'] == 'mobile') {
$where[] = ['u.mobile', 'like', '%' . $keyword . '%'];
} else {
$where[] = [$get['search_key'], 'like', '%' . $keyword . '%'];
}
}
//审核状态
if (isset($get['status']) && $get['status'] != '') {
$where[] = ['status', '=', $get['status']];
}
$field = [
'a.*', 'u.sn', 'u.nickname', 'u.mobile', 'u.level', 'u.sex', 'a.reason',
'u.create_time' => 'register_time', 'u.avatar', 'u.first_leader'
];
$count = Db::name('distribution_member_apply a')
->join('user u', 'u.id = a.user_id')
->where($where)
->count();
$lists = Db::name('distribution_member_apply a')
->field($field)
->join('user u', 'u.id = a.user_id')
->order('a.id desc')
->page($get['page'], $get['limit'])
->where($where)
->select();
$user_level = Db::name('user_level')->where(['del' => 0])->column('name', 'id');
$leader_ids = array_column($lists, 'first_leader');
$leaders = Db::name('user')
->where('id', 'in', $leader_ids)
->column('sn,nickname,mobile,level', 'id');
foreach ($lists as &$item) {
$item['level'] = $user_level[$item['level']] ?? '无等级';
$item['sex'] = self::getSexText($item['sex']);
$item['register_time'] = date('Y-m-d H:i:s', $item['register_time']);
$item['create_time'] = date('Y-m-d H:i:s', $item['create_time']);
$item['status_text'] = DistributionMember::getApplyStatus($item['status']);
$item['leader'] = $leaders[$item['first_leader']] ?? [];
$item['avatar'] = UrlServer::getFileUrl($item['avatar']);
if (!empty($item['leader'])) {
$leader_level = $item['leader']['level'] ?? 0;
$item['leader']['level'] = $user_level[$leader_level] ?? '无等级';
}
}
return ['count' => $count, 'lists' => $lists];
}
public static function getSexText($value)
{
switch ($value) {
case 1:
return '男';
case 2:
return '女';
default:
return '未知';
}
}
/**
* 审核通过
* @param $post
* @return bool|string
*/
public static function auditPass($post)
{
Db::startTrans();
try {
$apply = DistributionMemberApply::where('id', $post['id'])->find();
$apply->status = DistributionMember::STATUS_AUDIT_SUCCESS;
$apply->update_time = time();
$apply->save();
$user = \app\admin\model\User::where('id', $apply['user_id'])->find();
$user->is_distribution = 1;
$user->save();
Db::commit();
return true;
} catch (Exception $e) {
Db::rollback();
return $e->getMessage();
}
}
/**
* 审核拒绝
* @param $post
*/
public static function auditRefuse($post)
{
$apply = DistributionMemberApply::where('id', $post['id'])->find();
$apply->status = DistributionMember::STATUS_AUDIT_ERROR;
$apply->save();
return true;
}
/**
* 冻结/解冻分销会员资格
* @param $post
*/
public static function freeze($post)
{
$user = User::where('id', $post['id'])->find();
$user->freeze_distribution = 1;
if ($post['type'] == 'unfreeze'){
$user->freeze_distribution = 0;
}
$user->save();
}
/**
* 分销会员信息
* @param $get
* @return User
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getMemberInfo($get)
{
$user_id = $get['id'];
$user_model = new User();
$user = $user_model->alias('u')
->field('u.*,u.sn as user_sn')
->leftJoin('distribution_order_goods d', 'd.user_id = u.id')
->where('u.id', $user_id)
->append(['distribution_order'])
->hidden(['password', 'pay_password', 'salt'])
->find();
$user['distribution_text'] = '否';
if ($user['is_distribution'] == 1) {
$user['distribution_text'] = '是';
}
//上级编号
$user['first_leader_sn'] = Db::name('user')
->where('id', $user['first_leader'])
->value('sn');
//直推会员数
$user['first_fans'] = Db::name('user')
->where(['first_leader' => $user_id, 'del' => 0])
->count();
$have_withdraw = Db::name('withdraw_apply')
->where(['status' => Withdraw::STATUS_SUCCESS, 'user_id' => $user_id])
->sum('money');
$user['distribution_num'] = $user['distribution_order']['num'] ?? 0;//分销订单数
$user['distribution_amount'] = $user['distribution_order']['amount'] ?? 0;//分销订单金额
$user['distribution_money'] = $user['distribution_order']['money'] ?? 0;//分销佣金
$user['have_withdraw'] = $have_withdraw;//已提现金额
return $user;
}
/**
* 粉丝列表(推广会员)
* @param $get
* @return array
*/
public static function getFansLists($get)
{
$user_id = $get['id'];
$where = [];
if (!empty($get['search_key']) && !empty($get['keyword'])) {
$keyword = $get['keyword'];
$where[] = [$get['search_key'], 'like', '%' . $keyword . '%'];
}
$fans_type = $get['type'] ?? 'all';
if ($fans_type == 'all') {
$where[] = ['', 'exp', Db::raw("FIND_IN_SET($user_id, ancestor_relation)")];
} else {
$where[] = [$fans_type, '=', $user_id];
}
$user = new User();
$count = $user
->where($where)
->append(['fans', 'distribution_order'])
->hidden(['password,pay_password,salt'])
->count();
$lists = $user
->where($where)
->append(['fans', 'distribution_order'])
->hidden(['password,pay_password,salt'])
->page($get['page'], $get['limit'])
->select()->toArray();
$user_level = Db::name('user_level')->where(['del' => 0])->column('name', 'id');
$leader_ids = array_column($lists, 'first_leader');
$leaders = Db::name('user')
->where('id', 'in', $leader_ids)
->column('sn,nickname,mobile,level', 'id');
foreach ($lists as &$item) {
$item['avatar'] = UrlServer::getFileUrl($item['avatar']);
$item['leader'] = $leaders[$item['first_leader']] ?? [];
if (!empty($item['leader'])) {
$leader_level = $item['leader']['level'] ?? 0;
$item['leader']['level'] = $user_level[$leader_level] ?? '无等级';
}
$item['distribution_num'] = $item['distribution_order']['num'] ?? 0;//分销订单数
$item['distribution_amount'] = $item['distribution_order']['amount'] ?? 0;//分销订单金额
$item['distribution_money'] = $item['distribution_order']['money'] ?? 0;//分销佣金
}
return ['count' => $count, 'lists' => $lists];
}
/**
* 分销收入明细
* @param $get
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getEarningsDetail($get)
{
$user_id = $get['id'];
$where = [];
$where[] = ['d.user_id', '=', $user_id];
$where[] = ['d.status', '=', DistributionOrder::STATUS_SUCCESS];
//记录时间
if (isset($get['start_time']) && $get['start_time'] != '') {
$where[] = ['d.create_time', '>=', strtotime($get['start_time'])];
}
if (isset($get['end_time']) && $get['end_time'] != '') {
$where[] = ['d.create_time', '<=', strtotime($get['end_time'])];
}
$count = Db::name('distribution_order_goods')->alias('d')
->field('d.id as distribution_id, d.sn, o.order_sn, d.money, d.create_time')
->join('order_goods og', 'og.id = d.order_goods_id')
->join('order o', 'o.id = og.order_id')
->where($where)
->count();
$lists = Db::name('distribution_order_goods')->alias('d')
->field('d.id as distribution_id, d.sn, o.order_sn, d.money, d.create_time')
->join('order_goods og', 'og.id = d.order_goods_id')
->join('order o', 'o.id = og.order_id')
->where($where)
->page($get['page'], $get['limit'])
->select();
foreach ($lists as &$item) {
$item['create_time'] = date('Y-m-d H:i:s', $item['create_time']);
$item['type'] = '分销佣金';
}
return ['count' => $count, 'lists' => $lists];
}
/**
* 获取上级名称和编号
* @param $user_id
* @return string
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function getLeaderInfo($user_id)
{
$first_leader = Db::name('user u')
->field('u1.nickname,u1.sn')
->join('user u1', 'u1.id = u.first_leader')
->where('u.id', $user_id)
->find();
$leader_data = '无';
if ($first_leader) {
$leader_data = $first_leader['nickname'] . '(' . $first_leader['sn'] . ')';
}
return $leader_data;
}
//更新关系
public static function updateRelation($post)
{
Db::startTrans();
try{
$user_id = $post['user_id'];//需要调整上级的user_id
$referrer_sn = $post['referrer_sn'];//新上级推荐人编号
//清空上级
$data = [
'first_leader' => 0,
'second_leader' => 0,
'third_leader' => 0,
'ancestor_relation' => '',
];
$my_leader_id = 0;
$my_first_leader = 0;
$my_ancestor_relation = '';
if ($post['change_type'] == 'appoint'){
//指定上级
$my_leader = Db::name('user')->where(['sn' => $referrer_sn])->find();
//更新我的第一上级、第二上级、第三上级、关系链
$my_leader_id = $my_leader['id'];
$my_first_leader = $my_leader['first_leader'];
$my_third_leader = $my_leader['second_leader'];
$my_ancestor_relation = trim("{$my_leader_id},{$my_leader['ancestor_relation']}", ',');
$data = [
'first_leader' => $my_leader_id,
'second_leader' => $my_first_leader,
'third_leader' => $my_third_leader,
'ancestor_relation' => $my_ancestor_relation,
];
}
Db::name('user')->where(['id' => $user_id])->update($data);
//更新我向下一级的第二上级、第三上级
$data = [
'second_leader' => $my_leader_id,
'third_leader' => $my_first_leader,
];
Db::name('user')->where(['first_leader' => $user_id])->update($data);
//更新我向下二级的第三级
$data = [
'third_leader' => $my_leader_id,
];
Db::name('user')->where(['second_leader' => $user_id])->update($data);
//更新与我相关的所有关系链
Db::name('user')
->where("find_in_set({$user_id},ancestor_relation)")
->exp('ancestor_relation', "replace(ancestor_relation,'{$user_id}','" . trim("{$user_id},{$my_ancestor_relation}", ',') . "')")
->update();
Db::commit();
return true;
} catch (Exception $e){
Db::rollback();
return $e->getMessage();
}
}
/**
* Notes: 添加分销会员
* @author 张无忌(2021/1/11 16:49)
* @param $post
* @return bool|string
*/
public static function addMember($post)
{
$userModel = new User();
// 根据会员编号查询用户
$user = $userModel->field('id,sn,is_distribution,distribution_add_remarks,del')
->where(['sn'=>$post['sn']])->find();
// 校验用户
if (!$user) { return '该用户不存在!'; }
if ($user['del'] === 1) { return '该用户已被删除!'; }
if ($user['is_distribution']) { return '该用户已是分销会员,无需重复添加'; }
try {
// 更新用户为分销会员
$result = $userModel->where(['id' => (int)$user['id']])->update([
'is_distribution' => 1,
'distribution_add_remarks' => $post['remarks']
]);
return $result ? true : '添加失败';
} catch (\Exception $e) {
return $e->getMessage();
}
}
}