dggzichahu/application/admin/logic/UserLogic.php

542 lines
22 KiB
PHP
Executable File

<?php
// +----------------------------------------------------------------------
// | 宏驰云科技开发团队 版权所有 拥有最终解释权
// +----------------------------------------------------------------------
// | Author: HcyShop-kiki
// +----------------------------------------------------------------------
namespace app\admin\logic;
use app\admin\model\User;
use app\common\logic\AccountLogLogic;
use app\common\logic\UserLevelLogic;
use app\common\model\AccountLog;
use app\common\model\Order;
use app\common\model\Pay;
use app\common\server\UrlServer;
use think\Db;
use think\Exception;
class UserLogic{
/**
* 列表
* @param $get
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\ModelNotFoundException
* @throws \think\exception\DbException
*/
public static function lists($get){
$user = new User();
$where = [];
$where[] = ['del','=', '0'];
//查询
if(isset($get['keyword']) && $get['keyword']){
$where[] = [$get['keyword_type'],'like','%'.$get['keyword'].'%'];
}
//等级查询
if(isset($get['level']) && $get['level'] != ''){
$where[] = ['level','=',$get['level']];
}
//分组查询
if(isset($get['group_id']) && $get['group_id']){
$where[] = ['group_id','=',$get['group_id']];
}
//消费金额
if(isset($get['total_amount_start']) && $get['total_amount_start']){
$where[] = ['total_order_amount','>=',$get['total_amount_start']];
}
if(isset($get['total_amount_end']) && $get['total_amount_end']){
$where[] = ['total_order_amount','<=',$get['total_amount_end']];
}
//注册时间
if(isset($get['start_time']) && $get['start_time']!=''){
$where[] = ['create_time','>=',strtotime($get['start_time'])];
}
if(isset($get['end_time']) && $get['end_time']!=''){
$where[] = ['create_time','<=',strtotime($get['end_time'])];
}
$user_count = $user
->where($where)
->count();
$user_list = $user
->where($where)
->field('password,pay_password,salt',true)
->page($get['page'],$get['limit'])
->order('id desc')
->select()->toArray();
//会员分组
$user_group = Db::name('user_group')->where(['del'=>0])->column('name','id');
//会员等级
$user_level = Db::name('user_level')->where(['del'=>0])->column('name','id');
$all_user_list = $user->where(['del'=>0])->column('sn,nickname,avatar,mobile,level','id');
$group_list = db::name('user_group')->where(['del'=>0])->column('name','id');
foreach ($user_list as &$item){
$item['group_name'] = '-';
$item['level_name'] = '无等级';
//会员所属分组
if(isset($user_group[$item['group_id']])){
$item['group_name'] = $user_group[$item['group_id']];
}
if(isset($user_level[$item['level']])){
$item['level_name'] = $user_level[$item['level']];
}
if ($item['avatar'] != '/static/common/image/default/user.png') {
$item['abs_avatar'] = $item['avatar'] ? UrlServer::getFileUrl($item['avatar']) : '';
} else {
$item['abs_avatar'] = '/static/common/image/default/user.png';
}
$item['referrer_nickname'] = '';
$item['referrer_sn'] = '';
$item['referrer_mobile'] = '';
$item['referrer_avatar'] = '';
$item['referrer_level_name'] = '-';
if(isset($all_user_list[$item['first_leader']])){
$referrer_user = $all_user_list[$item['first_leader']];
$item['referrer_nickname'] = $referrer_user['nickname'];
$item['referrer_sn'] = $referrer_user['sn'];
$item['referrer_mobile'] = $referrer_user['mobile'];
$item['referrer_avatar'] = UrlServer::getFileUrl($referrer_user['avatar']);
if(isset($user_level[$referrer_user['level']])){
$item['referrer_level_name'] =$user_level[$referrer_user['level']];
}
}
if(isset($group_list[$item['group_id']])){
$item['group_name'] = $group_list[$item['group_id']];
}
}
return ['count'=>$user_count , 'lists'=>$user_list];
}
public static function exportFile($get)
{
$where[] = ['del','=', '0'];
//查询
if(isset($get['keyword']) && $get['keyword']){
$where[] = [$get['keyword_type'],'like','%'.$get['keyword'].'%'];
}
//等级查询
if(isset($get['level']) && $get['level'] != ''){
$where[] = ['level','=',$get['level']];
}
//分组查询
if(isset($get['group_id']) && $get['group_id']){
$where[] = ['group_id','=',$get['group_id']];
}
//消费金额
if(isset($get['total_amount_start']) && $get['total_amount_start']){
$where[] = ['total_order_amount','>=',$get['total_amount_start']];
}
if(isset($get['total_amount_end']) && $get['total_amount_end']){
$where[] = ['total_order_amount','<=',$get['total_amount_end']];
}
//注册时间
if(isset($get['start_time']) && $get['start_time']!=''){
$where[] = ['create_time','>=',strtotime($get['start_time'])];
}
if(isset($get['end_time']) && $get['end_time']!=''){
$where[] = ['create_time','<=',strtotime($get['end_time'])];
}
$user_list = Db::name('user')->where($where)
->order('id desc')
->select();
//会员分组
$user_group = Db::name('user_group')->where(['del'=>0])->column('name','id');
//会员等级
$user_level = Db::name('user_level')->where(['del'=>0])->column('name','id');
// 所有会员信息
$all_user_list = User::where(['del'=>0])->column('sn,nickname,mobile,level','id');
$exportData = [];
foreach ($user_list as $item){
$groupName = '-';
$levelName = '无等级';
//会员所属分组
if(isset($user_group[$item['group_id']])){
$groupName = $user_group[$item['group_id']];
}
if(isset($user_level[$item['level']])){
$levelName = $user_level[$item['level']];
}
$referrer_user_info = '';
$referrer_nickname = '';
$referrer_sn = '';
$referrer_mobile = '';
$referrer_level_name = '-';
if(isset($all_user_list[$item['first_leader']])){
$referrer_user = $all_user_list[$item['first_leader']];
$referrer_nickname = $referrer_user['nickname'];
$referrer_sn = $referrer_user['sn'];
$referrer_mobile = $referrer_user['mobile'];
if(isset($user_level[$referrer_user['level']])){
$referrer_level_name =$user_level[$referrer_user['level']];
}
$referrer_user_info.= '【昵称:'.$referrer_nickname.' 编号:'.$referrer_sn. ' 手机:'. $referrer_mobile . ' 等级:'. $referrer_level_name.'】';
}
$loginTime = date('Y-m-d H:i:s', $item['login_time']);
$exportData[] = [$item['sn'], $item['nickname'], $levelName, $groupName, $referrer_user_info, $item['total_order_amount'], $item['user_money'], $item['user_integral'], $loginTime];
}
$exportTitle = ['会员编号', '会员昵称', '会员等级', '会员分组', '推荐人信息', '消费金额', '账户余额', '积分', '最后登录时间'];
$exportExt = 'xls';
return ['exportTitle'=> $exportTitle, 'exportData' => $exportData, 'exportExt'=>$exportExt, 'exportName'=>'会员列表'.date('Y-m-d H:i:s')];
}
/**
* Notes: 获取会员信息
* @param $id
* @param bool $getdata 是否获取原始数据
* @param bool $expenditure 是否显示会员消费
* @return User|mixed
*/
public static function getUser($id,$getdata = false,$expenditure = false){
$user = User::get($id);
$user->append(['level_name','group_name']);
if($getdata){
$user = $user->getData();
if($user['birthday']) $user['birthday'] = date('Y-m-d',$user['birthday']);
}
$user['abs_avatar'] = UrlServer::getFileUrl($user['avatar']);
if($expenditure){
//本月的消费金额
$month_amount = Db::name('order')
->where('order_status','not in',[Order::STATUS_CLOSE,Order::STATUS_WAIT_PAY])
->where(['user_id'=>$id,'pay_status'=>Pay::ISPAID])
->whereTime('create_time', 'month')
->sum('order_amount');
//本月的订单笔数
$month_num = Db::name('order')
->where('order_status','not in',[Order::STATUS_CLOSE,Order::STATUS_WAIT_PAY])
->where(['user_id'=>$id,'pay_status'=>Pay::ISPAID])
->whereTime('create_time', 'month')
->count();
//累计消费笔数
$total_num =Db::name('order')
->where('order_status','not in',[Order::STATUS_CLOSE,Order::STATUS_WAIT_PAY])
->where(['user_id'=>$id,'pay_status'=>Pay::ISPAID])
->sum('order_amount');
$avg_amount = Db::name('order')
->where('order_status','not in',[Order::STATUS_CLOSE,Order::STATUS_WAIT_PAY])
->where(['user_id'=>$id,'pay_status'=>Pay::ISPAID])
->avg('order_amount');
$user['month_amount'] = '¥'.round($month_amount,2);
$user['month_num'] = round($month_num,2);
$user['total_num'] = round($total_num,2);
$user['avg_amount'] = '¥'.round($avg_amount,2);
//分销会员
$user['distribution_tips'] = '否';
$user['superior_referrer'] = '-';
$user['superior_referrer_sn'] = '-';
if($user['is_distribution']){
$user['distribution_tips'] = '是';
$superior_referrer = Db::name('user')->where(['id'=>$user['first_leader']])->field('nickname,sn')->findOrEmpty();
$user['superior_referrer'] = '-';
$user['superior_referrer_sn'] = '-';
if($superior_referrer) {
$user['superior_referrer'] = $superior_referrer['nickname'];
$user['superior_referrer_sn'] = $superior_referrer['sn'];
}
}
// 头像
$user['avatar'] = UrlServer::getFileUrl($user['avatar']);
}
return $user;
}
/*
* 批量设置会员分组
*/
public static function setGroup($post){
return Db::name('user')->where(['id'=>$post['user_ids']])->update(['group_id'=>$post['group_id']]);
}
/*
* 用户账户调整
*/
public static function adjustAccount($post_data){
Db::startTrans();
try {
$update_data = [];
$account_log = [];
//余额调整
if (isset($post_data['money_handle'])) {
$number = $post_data['money'];
$change_type = 1;
$source_type = AccountLog::admin_add_money;
$money_sql = Db::raw('user_money + ' . $post_data['money']);
if ($post_data['money_handle'] == 0) {
$change_type = 2;
$source_type = AccountLog::admin_reduce_money;
$money_sql = Db::raw('user_money - ' . $post_data['money']);
}
$update_data['user_money'] = $money_sql;
$account_log[] = [
'number' => $number,
'change_type' => $change_type,
'source_type' => $source_type,
'remark' => $post_data['money_remark'],
];
}
//积分调整
if (isset($post_data['integral_handle'])) {
$number = $post_data['integral'];
$change_type = 1;
$source_type = AccountLog::admin_add_integral;
$integral_sql = Db::raw('user_integral + ' . $post_data['integral']);
if ($post_data['integral_handle'] == 0) {
$change_type = 2;
$source_type = AccountLog::admin_reduce_integral;
$integral_sql = Db::raw('user_integral - ' . $post_data['integral']);
}
$update_data['user_integral'] = $integral_sql;
$account_log[] = [
'number' => $number,
'change_type' => $change_type,
'source_type' => $source_type,
'remark' => $post_data['integral_remark'],
];
}
//成长值调整
if (isset($post_data['growth_handle'])) {
$number = $post_data['growth'];
$change_type = 1;
$source_type = AccountLog::admin_add_growth;
$growth_sql = Db::raw('user_growth + ' . $post_data['growth']);
if ($post_data['growth_handle'] == 0) {
$change_type = 2;
$source_type = AccountLog::admin_reduce_growth;
$growth_sql = Db::raw('user_growth - ' . $post_data['growth']);
}
$update_data['user_growth'] = $growth_sql;
$account_log[] = [
'number' => $number,
'change_type' => $change_type,
'source_type' => $source_type,
'remark' => $post_data['growth_remark'],
];
}
Db::name('user')->where('id', $post_data['id'])->update($update_data);
foreach ($account_log as $item => $value){
AccountLogLogic::AccountRecord($post_data['id'],$value['number'],$value['change_type'],$value['source_type'],$value['remark']);
}
if (isset($post_data['growth_handle'])) {
UserLevelLogic::updateUserLevel($post_data['id']);
}
Db::commit();
return true;
} catch (Exception $e) {
Db::rollback();
return false;
}
}
//todo 会员等级调整记录待完成
public static function adjustLevel($post_data){
return Db::name('user')->where('id',$post_data['id'])->update(['level'=>$post_data['level']]);
}
/*
* 获取分组
*/
public static function getGroupList(){
return Db::name('user_group')->where(['del'=>0])->field('id,name')->select();
}
/*
* 获取等级
*/
public static function getLevelList(){
return Db::name('user_level')->where(['del'=>0])->field('id,name')->select();
}
/*
* 编辑会员
*/
public static function edit($post){
$user = User::get($post['id']);
if (!empty($post['password'])) {
//生成密码
$post['password'] = create_password($post['password'], $user->salt);
} else {
unset($post['password']);
}
$post['update_time'] = time();
$post['birthday'] = strtotime($post['birthday']);
return $user->allowField(true)->save($post);
}
public static function getList($get){
switch ($get['type']){
case 0://下单明细
$order = new Order();
$count = $order->alias('o')
->where(['user_id'=>$get['user_id']])
->where('order_status','not in',[Order::STATUS_CLOSE,Order::STATUS_WAIT_PAY])
->count();
$list = $order->alias('o')
->where(['user_id'=>$get['user_id']])
->where('order_status','not in',[Order::STATUS_CLOSE,Order::STATUS_WAIT_PAY])
->page($get['page'],$get['limit'])
->order('id desc')
->field('o.id,order_sn,total_num,pay_time,total_amount,order_amount,discount_amount,
o.create_time,consignee,province,city,district,o.address,mobile')
->select();
break;
case 1://积分明细
$account_log =new AccountLog();
$count = $account_log
->where(['user_id'=>$get['user_id'],'source_type'=>AccountLog::integral_change])
->count();
$list = $account_log
->where(['user_id'=>$get['user_id'],'source_type'=>AccountLog::integral_change])
->page($get['page'],$get['limit'])
->order('id desc')
->select();
break;
case 2://签到明细
$account_log =new AccountLog();
$count = $account_log
->where(['user_id'=>$get['user_id'],'source_type'=>AccountLog::sign_in_integral])
->count();
$list = $account_log
->where(['user_id'=>$get['user_id'],'source_type'=>AccountLog::sign_in_integral])
->page($get['page'],$get['limit'])
->order('id desc')
->select();
break;
case 3://余额明细
$account_log = new AccountLog();
$count = $account_log
->where(['user_id'=>$get['user_id'],'source_type'=>AccountLog::money_change])
->count();
$list = $account_log
->where(['user_id'=>$get['user_id'],'source_type'=>AccountLog::money_change])
->page($get['page'],$get['limit'])
->order('id desc')
->select();
break;
case 4://推广明细
$count = 1;
$first_leader = Db::name('user')->where(['id'=>$get['user_id']])->value('first_leader');
$list = [];
if($first_leader){
$user = new User();
$list = $user
->where(['id'=>$first_leader])
->field('id,sn,nickname,mobile,avatar,level,sex,create_time,total_order_amount,user_money,user_integral')
->order('id desc')
->select();
$level_list = Db::name('user_level')->where(['del'=>0])->column('name','id');
foreach ($list as &$item) {
$item['avatar'] = UrlServer::getFileUrl($item['avatar']);
$item['level_name'] = '-';
if(isset($level_list[$item['level']])){
$item['level_name'] = $level_list[$item['level']];
}
}
}
break;
case 5://收货地址
$count = Db::name('user_address')
->where(['user_id'=>$get['user_id'],'del'=>0])
->count();
$list = Db::name('user_address')
->where(['user_id'=>$get['user_id'],'del'=>0])
->order('id desc')
->select();
foreach ($list as &$item){
$item['default'] = '否';
$region = Db::name('dev_region')
->where('id', 'IN', [$item['province_id'], $item['city_id'], $item['district_id']])->order('level asc')->column('name');
$region_desc = implode('', $region);
$item['address'] = $region_desc.$item['address'];
if($item['is_default']){
$item['default'] = '是';
}
}
break;
}
return ['count'=>$count , 'lists'=>$list];
}
/**
* 转账记录
*/
public static function transferRecord($get)
{
$where = [];
// 开始时间
if(!empty($get['start_time'])) {
$where[] = ['create_time', '>=', strtotime($get['start_time'])];
}
// 结束时间
if(!empty($get['end_time'])) {
$where[] = ['create_time', '<=', strtotime($get['end_time'])];
}
$list = Db::name('user_transfer')
->where($where)
->page($get['page'], $get['limit'])
->order('create_time', 'desc')
->select();
$count = Db::name('user_transfer')->count();
// 获取转账人及收款人信息
foreach($list as &$item) {
$transferFromInfo = Db::name('user')->alias('u')
->field('u.sn, u.nickname, u.avatar, ul.name as user_level_name')
->leftJoin('user_level ul', 'u.level=ul.id')
->where('u.id', $item['transfer_from_id'])->find();
$transferToInfo = Db::name('user')->alias('u')
->field('u.sn, u.nickname, u.avatar, ul.name as user_level_name')
->leftJoin('user_level ul', 'u.level=ul.id')
->where('u.id', $item['transfer_to_id'])->find();
$item['from_nickname'] = $transferFromInfo['nickname'];
$item['from_avatar'] = UrlServer::getFileUrl($transferFromInfo['avatar']);
$item['from_sn'] = $transferFromInfo['sn'];
$item['from_level_name'] = $transferFromInfo['user_level_name'] ?? '无等级';
$item['to_nickname'] = $transferToInfo['nickname'];
$item['to_avatar'] = UrlServer::getFileUrl($transferToInfo['avatar']);
$item['to_sn'] = $transferToInfo['sn'];
$item['to_level_name'] = $transferToInfo['user_level_name'] ?? '无等级';
$item['create_time'] = date('Y-m-d H:i:s', $item['create_time']);
}
$data = [
'count' => $count,
'list' => $list
];
return $data;
}
}