347 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			347 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
<?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\kefuapi\logic;
 | 
						||
 | 
						||
use app\common\basics\Logic;
 | 
						||
use app\common\enum\ChatRecordEnum;
 | 
						||
use app\common\model\kefu\ChatRecord;
 | 
						||
USE app\common\logic\ChatLogic as CommonChatLogic;
 | 
						||
use app\common\model\kefu\ChatRelation;
 | 
						||
use app\common\model\kefu\Kefu;
 | 
						||
use app\common\model\kefu\KefuLang;
 | 
						||
use app\common\model\order\Order;
 | 
						||
use app\common\model\user\User;
 | 
						||
use app\common\server\ConfigServer;
 | 
						||
use app\common\server\UrlServer;
 | 
						||
 | 
						||
 | 
						||
class ChatLogic extends Logic
 | 
						||
{
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 曾对话过的用户
 | 
						||
     * @param $kefu_id
 | 
						||
     * @param $shop_id
 | 
						||
     * @param $get
 | 
						||
     * @param $page
 | 
						||
     * @param $size
 | 
						||
     * @return array
 | 
						||
     * @throws \think\db\exception\DataNotFoundException
 | 
						||
     * @throws \think\db\exception\DbException
 | 
						||
     * @throws \think\db\exception\ModelNotFoundException
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/14 12:11
 | 
						||
     */
 | 
						||
    public static function getChatUserList($kefu_id, $shop_id, $get, $page, $size)
 | 
						||
    {
 | 
						||
        $where[] = ['kefu_id', '=', $kefu_id];
 | 
						||
        $where[] = ['shop_id', '=', $shop_id];
 | 
						||
 | 
						||
        if (isset($get['nickname']) && $get['nickname']) {
 | 
						||
            $where[] = ['nickname', 'like', '%' . $get['nickname'] . '%'];
 | 
						||
        }
 | 
						||
 | 
						||
        $online_user = CommonChatLogic::getOnlineUser();
 | 
						||
 | 
						||
        $exp = 'update_time desc';
 | 
						||
        if (!empty($online_user)) {
 | 
						||
            $user_id = implode(",", $online_user);
 | 
						||
            $exp = "field(user_id," . $user_id . ") desc, update_time desc";
 | 
						||
        }
 | 
						||
 | 
						||
        // 当前客服曾聊天的记录
 | 
						||
        $lists = ChatRelation::where($where)
 | 
						||
            ->page($page, $size)
 | 
						||
            ->orderRaw($exp)
 | 
						||
            ->select();
 | 
						||
 | 
						||
        $count = ChatRelation::where($where)->count();
 | 
						||
 | 
						||
        foreach ($lists as &$item) {
 | 
						||
            $item['online'] = 0;
 | 
						||
            if (in_array($item['user_id'], $online_user)) {
 | 
						||
                $item['online'] = 1;
 | 
						||
            }
 | 
						||
 | 
						||
            if (empty($item['msg'])) {
 | 
						||
                $item['update_time'] = '';
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
        return [
 | 
						||
            'list' => $lists->toArray(),
 | 
						||
            'page' => $page,
 | 
						||
            'size' => $size,
 | 
						||
            'count' => $count,
 | 
						||
            'more' => is_more($count, $page, $size)
 | 
						||
        ];
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 客服与用户的聊天记录
 | 
						||
     * @param $kefu_id
 | 
						||
     * @param $user_id
 | 
						||
     * @param $shop_id
 | 
						||
     * @param $page
 | 
						||
     * @param $size
 | 
						||
     * @return array
 | 
						||
     * @throws \think\db\exception\DataNotFoundException
 | 
						||
     * @throws \think\db\exception\DbException
 | 
						||
     * @throws \think\db\exception\ModelNotFoundException
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/14 14:41
 | 
						||
     */
 | 
						||
    public static function getChatRecord($kefu_id, $user_id, $shop_id, $page, $size)
 | 
						||
    {
 | 
						||
        $map1 = [
 | 
						||
            ['shop_id', '=', $shop_id],
 | 
						||
            ['from_id', '=', $kefu_id],
 | 
						||
            ['from_type', '=', 'kefu'],
 | 
						||
            ['to_id', '=', $user_id],
 | 
						||
            ['type', '=', ChatRecordEnum::TYPE_NORMAL]
 | 
						||
        ];
 | 
						||
        $map2 = [
 | 
						||
            ['shop_id', '=', $shop_id],
 | 
						||
            ['to_id', '=', $kefu_id],
 | 
						||
            ['to_type', '=', 'kefu'],
 | 
						||
            ['from_id', '=', $user_id],
 | 
						||
            ['type', '=', ChatRecordEnum::TYPE_NORMAL]
 | 
						||
        ];
 | 
						||
 | 
						||
        // 聊天记录
 | 
						||
        $records = ChatRecord::whereOr([$map1, $map2])
 | 
						||
            ->order('id desc')
 | 
						||
            ->page($page, $size)
 | 
						||
            ->select()->toArray();
 | 
						||
 | 
						||
        $count = ChatRecord::whereOr([$map1, $map2])->count();
 | 
						||
 | 
						||
        $records = CommonChatLogic::formatChatRecords($records, $count, $page, $size);
 | 
						||
 | 
						||
        return $records;
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 获取在线客服
 | 
						||
     * @param $shop_id
 | 
						||
     * @return array
 | 
						||
     * @throws \think\db\exception\DataNotFoundException
 | 
						||
     * @throws \think\db\exception\DbException
 | 
						||
     * @throws \think\db\exception\ModelNotFoundException
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/14 14:39
 | 
						||
     */
 | 
						||
    public static function getOnlineKefu($kefu_id, $shop_id)
 | 
						||
    {
 | 
						||
        $online = CommonChatLogic::getOnlineKefu($shop_id);
 | 
						||
 | 
						||
        if (empty($online)) {
 | 
						||
            return [];
 | 
						||
        }
 | 
						||
 | 
						||
        $map = [
 | 
						||
            ['id', 'in', $online],
 | 
						||
            ['id', '<>', $kefu_id],
 | 
						||
            ['shop_id', '=', $shop_id]
 | 
						||
        ];
 | 
						||
 | 
						||
        $lists = Kefu::where($map)
 | 
						||
            ->field('id,nickname,avatar')
 | 
						||
            ->select()
 | 
						||
            ->toArray();
 | 
						||
 | 
						||
        foreach ($lists as &$item) {
 | 
						||
            $item['avatar'] = UrlServer::getFileUrl($item['avatar']);
 | 
						||
        }
 | 
						||
        return $lists;
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 快捷回复列表
 | 
						||
     * @param $shop_id
 | 
						||
     * @param $keyword
 | 
						||
     * @param $page
 | 
						||
     * @param $size
 | 
						||
     * @return array
 | 
						||
     * @throws \think\db\exception\DataNotFoundException
 | 
						||
     * @throws \think\db\exception\DbException
 | 
						||
     * @throws \think\db\exception\ModelNotFoundException
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/15 11:07
 | 
						||
     */
 | 
						||
    public static function getReplyLists($shop_id, $keyword, $page, $size)
 | 
						||
    {
 | 
						||
        $condition[] = ['title', 'like', '%' . $keyword . '%'];
 | 
						||
 | 
						||
        $lists = KefuLang::where(['shop_id' => $shop_id])
 | 
						||
            ->where($condition)
 | 
						||
            ->page($page, $size)
 | 
						||
            ->order('sort')
 | 
						||
            ->select();
 | 
						||
 | 
						||
        $count = KefuLang::where(['shop_id' => $shop_id])->count();
 | 
						||
 | 
						||
        return [
 | 
						||
            'list' => $lists,
 | 
						||
            'page' => $page,
 | 
						||
            'size' => $size,
 | 
						||
            'count' => $count,
 | 
						||
            'more' => is_more($count, $page, $size)
 | 
						||
        ];
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 用户信息接口
 | 
						||
     * @param $user_id
 | 
						||
     * @return array|bool
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/15 15:05
 | 
						||
     */
 | 
						||
    public static function getUserInfo($user_id)
 | 
						||
    {
 | 
						||
        try {
 | 
						||
            $user = User::where(['id' => $user_id, 'del' => 0])->field([
 | 
						||
                'id', 'sn', 'nickname', 'avatar',
 | 
						||
                'level', 'mobile', 'total_order_amount',
 | 
						||
                'birthday', 'client', 'create_time'
 | 
						||
            ])->findOrEmpty()->append(['level_name', 'client_desc'])->toArray();
 | 
						||
 | 
						||
            if (empty($user)) {
 | 
						||
                throw new \Exception('用户不存在');
 | 
						||
            }
 | 
						||
 | 
						||
            $user['birthday'] = empty($user['birthday']) ? '-' : $user['birthday'];
 | 
						||
            $user['avatar'] = empty($user['avatar']) ? '' : UrlServer::getFileUrl($user['avatar']);
 | 
						||
            $user['mobile'] = empty($user['mobile']) ? '-' : substr_replace($user['mobile'],'****',3,4);
 | 
						||
 | 
						||
            return $user;
 | 
						||
 | 
						||
        } catch (\Exception $e) {
 | 
						||
            self::$error = $e->getMessage();
 | 
						||
            return false;
 | 
						||
        }
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 订单列表
 | 
						||
     * @param $get
 | 
						||
     * @param $shop_id
 | 
						||
     * @param $page
 | 
						||
     * @param $size
 | 
						||
     * @return array|bool
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/15 16:04
 | 
						||
     */
 | 
						||
    public static function getOrderLists($get, $shop_id, $page, $size)
 | 
						||
    {
 | 
						||
        try{
 | 
						||
            if (empty($get['user_id'])) {
 | 
						||
                throw new \Exception('参数缺失');
 | 
						||
            }
 | 
						||
 | 
						||
            $condition[] = ['user_id', '=', $get['user_id']];
 | 
						||
            $condition[] = ['del', '=', 0];
 | 
						||
 | 
						||
            if ($shop_id > 0) {
 | 
						||
                $condition[] = ['shop_id', '=', $shop_id];
 | 
						||
            }
 | 
						||
 | 
						||
            if (isset($get['order_sn']) && $get['order_sn'] != '') {
 | 
						||
                $condition[] = ['order_sn', 'like', '%' . $get['order_sn'] . '%'];
 | 
						||
            }
 | 
						||
 | 
						||
            $order = new Order();
 | 
						||
 | 
						||
            $count = $order->with('order_goods')->where($condition)->count();
 | 
						||
 | 
						||
            $lists = $order
 | 
						||
                ->where($condition)
 | 
						||
                ->with('order_goods')
 | 
						||
                ->field(['id', 'order_sn', 'order_type', 'order_status', 'order_amount', 'create_time'])
 | 
						||
                ->append(['order_status_text', 'order_type_text'])
 | 
						||
                ->page($page, $size)
 | 
						||
                ->order('id desc')
 | 
						||
                ->select()->toArray();
 | 
						||
 | 
						||
            return [
 | 
						||
                'list' => $lists,
 | 
						||
                'page' => $page,
 | 
						||
                'size' => $size,
 | 
						||
                'count' => $count,
 | 
						||
                'more' => is_more($count, $page, $size)
 | 
						||
            ];
 | 
						||
 | 
						||
        } catch (\Exception $e) {
 | 
						||
            self::$error = $e->getMessage();
 | 
						||
            return false;
 | 
						||
        }
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 客服详情
 | 
						||
     * @param $id
 | 
						||
     * @return array
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/15 17:34
 | 
						||
     */
 | 
						||
    public static function getKefuInfo($id)
 | 
						||
    {
 | 
						||
        $res = Kefu::where(['id' => $id])
 | 
						||
            ->field(['id', 'shop_id', 'nickname', 'avatar'])
 | 
						||
            ->findOrEmpty()
 | 
						||
            ->toArray();
 | 
						||
        $res['avatar'] = empty($res['avatar']) ? '' : UrlServer::getFileUrl($res['avatar']);
 | 
						||
 | 
						||
        $online = CommonChatLogic::getOnlineKefu($res['shop_id']);
 | 
						||
 | 
						||
        $res['online'] = 0;
 | 
						||
        if(in_array($res['id'], $online)) {
 | 
						||
            $res['online'] = 1;
 | 
						||
        }
 | 
						||
 | 
						||
        return $res;
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    /**
 | 
						||
     * @notes 上传文件域名
 | 
						||
     * @return array
 | 
						||
     * @author 段誉
 | 
						||
     * @date 2021/12/16 17:05
 | 
						||
     */
 | 
						||
    public static function getConfig()
 | 
						||
    {
 | 
						||
        $web_favicon = ConfigServer::get('website', 'web_favicon');
 | 
						||
        return [
 | 
						||
            'base_domain' => UrlServer::getFileUrl(),
 | 
						||
            'web_favicon' => !empty($web_favicon) ? UrlServer::getFileUrl($web_favicon) : $web_favicon,
 | 
						||
            'company_name' => ConfigServer::get('copyright', 'company_name'),
 | 
						||
            'ws_domain' => env('project.ws_domain', 'ws:127.0.0.1')
 | 
						||
        ];
 | 
						||
    }
 | 
						||
 | 
						||
}
 |