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.
 
 
 
 
 
 
shipin/app/services/user/UserSearchServices.php

81 lines
2.6 KiB

<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
declare (strict_types=1);
namespace app\services\user;
use app\services\BaseServices;
use app\dao\user\UserSearchDao;
/**
*
* Class UserLabelServices
* @package app\services\user
* * @method getColumn(array $where, string $field, string $key = '') 获取某个字段数组
* * @method getKeywordResult(int $uid, string $keyword, int $preTime = 7200) 获取全局|用户某个关键词搜素结果
*/
class UserSearchServices extends BaseServices
{
/**
* UserSearchServices constructor.
* @param UserSearchDao $dao
*/
public function __construct(UserSearchDao $dao)
{
$this->dao = $dao;
}
/**
* 获取用户搜索关键词列表
* @param int $uid
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function getUserList(int $uid)
{
if (!$uid) {
return [];
}
[$page, $limit] = $this->getPageValue();
return $this->dao->getList(['uid' => $uid, 'is_del' => 0], 'add_time desc,num desc', $page, $limit);
}
/**
* 用户增加搜索记录
* @param int $uid
* @param string $key
* @param array $result
*/
public function saveUserSearch(int $uid, string $keyword, array $vicword, array $result)
{
$result = json_encode($result);
$vicword = json_encode($vicword, JSON_UNESCAPED_UNICODE);
$userkeyword = $this->dao->getKeywordResult($uid, $keyword, 0);
$data = [];
$data['result'] = $result;
$data['vicword'] = $vicword;
$data['add_time'] = time();
if ($userkeyword) {
$data['num'] = $userkeyword['num'] + 1;
$this->dao->update(['id' => $userkeyword['id']], $data);
} else {
$data['uid'] = $uid;
$data['keyword'] = $keyword;
$this->dao->save($data);
}
return true;
}
}