fix: 客户检索分页查询

This commit is contained in:
2026-03-25 15:57:05 +08:00
parent 9dbcab4e89
commit 8df05405b4
5 changed files with 301 additions and 95 deletions

View File

@@ -129,4 +129,46 @@ class Customer extends Common
return $this->sendSuccess($ret);
}
// 客户检索 - 分页查询合作伙伴公司
public function SearchPartnerCompany()
{
$param = request()->post();
$currPage = isset($param['page']) ? $param['page'] : 1;
$pageSize = isset($param['limit']) ? $param['limit'] : 10;
$company_name = isset($param['company_name']) ? $param['company_name'] : '';
// 构建查询条件
$query = db('partner_company');
// 查询客户类型
$query->whereIn('company_type', [1, 5]);
if (!empty($company_name)) {
$query->where('company_name', 'like', '%' . $company_name . '%');
}
// 查询列表数据
$list = $query->page($currPage, $pageSize)
->order('company_id desc')
->select();
// 查询总记录数
$totalQuery = db('partner_company');
$totalQuery->whereIn('company_type', [1, 5]);
if (!empty($company_name)) {
$totalQuery->where('company_name', 'like', '%' . $company_name . '%');
}
$total = $totalQuery->count();
$result = [
'list' => $list,
'total' => $total
];
return $this->sendSuccess($result);
}
}

View File

@@ -831,9 +831,10 @@ class Work extends Common
$user_id = $param['user_id'];
$currPage = isset($param['currPage']) ? $param['currPage'] : 1;
$pageSize = isset($param['pageSize']) ? $param['pageSize'] : 10;
$project_name = isset($param['project_name']) ? $param['project_name'] : '';
$user = new User();
$project_work = $this->GetProjectListPaginated($user_id, $currPage, $pageSize);
$project_work = $this->GetProjectListPaginated($user_id, $currPage, $pageSize, $project_name);
for ($i = 0; $i < count($project_work['list']); $i++) {
$involve_manager = $project_work['list'][$i]['involve_manager'];
@@ -849,7 +850,7 @@ class Work extends Common
}
//获取参与的客户项目列表 - 分页版本
public function GetProjectListPaginated($user_id, $currPage, $pageSize)
public function GetProjectListPaginated($user_id, $currPage, $pageSize, $project_name = '')
{
//判断登录用户的角色,如果是管理员,就获取所有的项目信息
$user_info = db('system_user')->where('id', $user_id)->find();
@@ -859,6 +860,11 @@ class Work extends Common
->where('p.project_state', '<', 10) //未关闭的项目
->field('p.*, s.desp as project_state_name,1 as project_types');
// 添加项目名称模糊查询
if (!empty($project_name)) {
$query->where('p.project_name', 'like', '%' . $project_name . '%');
}
if (1 != $user_info['user_role']) {
$query->where(function ($query) use ($user_id) {
$query->where('p.involve_manager', $user_id)
@@ -877,6 +883,11 @@ class Work extends Common
->join('project_state s', 's.id =p.project_state', 'left')
->where('p.project_state', '<', 10);
// 添加项目名称模糊查询到总数查询
if (!empty($project_name)) {
$totalQuery->where('p.project_name', 'like', '%' . $project_name . '%');
}
if (1 != $user_info['user_role']) {
$totalQuery->where(function ($query) use ($user_id) {
$query->where('p.involve_manager', $user_id)