超管后台 - 项目详情项目概述
This commit is contained in:
@@ -0,0 +1,112 @@
|
||||
<?php
|
||||
|
||||
namespace app\superadmin\controller\company;
|
||||
|
||||
use app\common\model\Company as CompanyModel;
|
||||
use app\common\model\Device as DeviceModel;
|
||||
use app\common\model\DeviceWechatLogin as DeviceWechatLoginModel;
|
||||
use app\common\model\User as UserModel;
|
||||
use app\common\model\WechatFriend as WechatFriendModel;
|
||||
use app\superadmin\controller\BaseController;
|
||||
use library\ResponseHelper;
|
||||
|
||||
/**
|
||||
* 公司控制器
|
||||
*/
|
||||
class GetCompanyDetailForProfileController extends BaseController
|
||||
{
|
||||
/**
|
||||
* 获取登录设备的所有微信
|
||||
*
|
||||
* @param int $companyId
|
||||
* @return array
|
||||
*/
|
||||
protected function getDeveiceWechats(int $companyId): array
|
||||
{
|
||||
$wechatId = DeviceWechatLoginModel::where('companyId', $companyId)->column('wechatId');
|
||||
|
||||
return array_unique($wechatId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 统计微信好友数量
|
||||
*
|
||||
* @param int $companyId
|
||||
* @return int
|
||||
*/
|
||||
protected function getFriendCountByCompanyId(int $companyId): int
|
||||
{
|
||||
$wechatIds = $this->getDeveiceWechats($companyId);
|
||||
|
||||
return WechatFriendModel::whereIn('ownerWechatId', $wechatIds)->count();
|
||||
}
|
||||
|
||||
/**
|
||||
* 根据 CompanyId 获取设备数量
|
||||
*
|
||||
* @param int $companyId
|
||||
* @return int
|
||||
*/
|
||||
protected function getDeviceCountByCompanyId(int $companyId): int
|
||||
{
|
||||
return DeviceModel::where('companyId', $companyId)->count();
|
||||
}
|
||||
|
||||
/**
|
||||
* 根据 CompanyId 获取子账号数量
|
||||
*
|
||||
* @param int $companyId
|
||||
* @return int
|
||||
*/
|
||||
protected function getUsersCountByCompanyId(int $companyId): int
|
||||
{
|
||||
return UserModel::where('companyId', $companyId)->count();
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取项目详情
|
||||
*
|
||||
* @param int $id
|
||||
* @return CompanyModel
|
||||
* @throws \Exception
|
||||
*/
|
||||
protected function getCompanyDetail(int $id): array
|
||||
{
|
||||
$detail = CompanyModel::alias('c')
|
||||
->field([
|
||||
'c.id', 'c.name', 'c.memo', 'c.companyId', 'c.createTime',
|
||||
'u.account', 'u.phone'
|
||||
])
|
||||
->leftJoin('users u', 'c.companyId = u.companyId and u.isAdmin = 1')
|
||||
->find($id);
|
||||
|
||||
if (!$detail) {
|
||||
throw new \Exception('项目不存在', 404);
|
||||
}
|
||||
|
||||
return $detail->toArray();
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取项目详情
|
||||
*
|
||||
* @param int $id
|
||||
* @return \think\response\Json
|
||||
*/
|
||||
public function index($id)
|
||||
{
|
||||
try {
|
||||
$data = $this->getCompanyDetail($id);
|
||||
|
||||
$userCount = $this->getUsersCountByCompanyId($id);
|
||||
$deviceCount = $this->getDeviceCountByCompanyId($id);
|
||||
$friendCount = $this->getFriendCountByCompanyId($id);
|
||||
|
||||
return ResponseHelper::success(
|
||||
array_merge($data, compact('deviceCount', 'friendCount', 'userCount'))
|
||||
);
|
||||
} catch (\Exception $e) {
|
||||
return ResponseHelper::error($e->getMessage(), $e->getCode());
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user