diff --git a/app/api/controller/InformationController.php b/app/api/controller/InformationController.php index 8a9b5574a..8dec60efe 100644 --- a/app/api/controller/InformationController.php +++ b/app/api/controller/InformationController.php @@ -2,6 +2,7 @@ namespace app\api\controller; +use app\common\model\Company; use app\common\model\informationg\UserInformationg; use app\common\logic\BaseLogic; use app\common\model\informationg\UserInformationgDemand; @@ -12,7 +13,7 @@ use think\response\Json; class InformationController extends BaseApiController { - public array $notNeedLogin = ['captainInfo','farmerInfo','farmerLandInfo','farmerPondInfo']; + public array $notNeedLogin = ['groupServiceInfo','captainInfo','farmerInfo','farmerLandInfo','farmerPondInfo']; public function list() { @@ -133,6 +134,95 @@ class InformationController extends BaseApiController return $this->success('成功'); } + //获取吓阻服务公司用户信息 + public function groupServiceInfo(): Json + { + //获取参数 + $params = $this->request->post(['user_id']); + if(empty($params['user_id'])){ + return $this->fail('参数错误_worker'); + } + $userData = User::field('id,company_id,nickname as name,avatar')->where('id',$params['user_id'])->findOrEmpty(); + if($userData->isEmpty()){ + return $this->fail('用户数据不存在'); + } + $companyData = Company::field('id,company_name,company_type')->where('id',$userData['company_id'])->findOrEmpty(); + if($companyData->isEmpty() || $companyData['company_type'] != 18){ + return $this->fail('当前用户不是小组服务公司用户'); + } + $userData['company_name'] = $companyData['company_name']; + //获取小组服务公司下面的队长 + $captainList = User::field('id,nickname as name,avatar,province,province province_name,city,city city_name,area,area area_name,street,street street_name,village,village village_name,brigade,brigade brigade_name')->where('company_id',$userData['company_id'])->where('is_captain',1)->select()->each(function($item){ + $item['address'] = $item['province_name'].$item['city_name'].$item['area_name'].$item['street_name'].$item['village_name'].$item['brigade_name']; + unset($item['province'],$item['province_name'],$item['city'],$item['city_name'],$item['area'],$item['area_name'],$item['street'],$item['street_name'],$item['village'],$item['village_name'],$item['brigade'],$item['brigade_name']); + $farmerList = UserInformationg::where('create_user_id', $item['id'])->field('id')->select()->each(function($val){ + //获取农户档案详情 + $information = UserInformationgDemand::field('id,category_child,data')->where('information_id', $val['id'])->where('category_id',6)->where('category_child','in','7,32')->order('id', 'desc')->select()->toArray(); + //总面积 + $val['land_total_area'] = 0; + $val['pond_total_area'] = 0; + $val['animal_total_area'] = 0; + $val['poultry_total_area'] = 0; + //种养类型 + $val['is_zz_user'] = false; + $val['is_sc_user'] = false; + $val['is_jc_user'] = false; + $val['is_jq_user'] = false; + foreach($information as $v){ + if($v['category_child'] == 7){ + $val['is_zz_user'] = true; + $val['land_total_area'] += floatval($v['data']['area']); + } + if($v['category_child'] == 32){ + if($v['data']['breeding_type'] == 1){//水产 + $val['is_sc_user'] = true; + $val['pond_total_area'] += floatval($v['data']['area']); + }elseif ($v['data']['breeding_type'] == 2) {//脯乳动物 + $val['is_jc_user'] = true; + $val['animal_total_area'] += floatval($v['data']['area']); + }elseif ($v['data']['breeding_type'] == 3){//家禽 + $val['is_jq_user'] = true; + $val['poultry_total_area'] += floatval($v['data']['area']); + } + } + } + $val['total_area'] = $val['land_total_area'] + $val['pond_total_area'] + $val['animal_total_area'] + $val['poultry_total_area']; + return $val; + })->toArray(); + $item['farmer_total'] = count($farmerList); + $item['farmer_area'] = array_sum(array_column($farmerList,'total_area')); + $item['farmer_zz_total'] = 0; + $item['farmer_sc_total'] = 0; + $item['farmer_jc_total'] = 0; + $item['farmer_jq_total'] = 0; + $item['farmer_zz_area'] = 0; + $item['farmer_sc_area'] = 0; + $item['farmer_jc_area'] = 0; + $item['farmer_jq_area'] = 0; + foreach($farmerList as $v){ + if($v['is_zz_user']){ + $item['farmer_zz_total'] += 1; + } + if($v['is_sc_user']){ + $item['farmer_sc_total'] += 1; + } + if($v['is_jc_user']){ + $item['farmer_jc_total'] += 1; + } + if($v['is_jq_user']){ + $item['farmer_jq_total'] += 1; + } + $item['farmer_zz_area'] += $v['land_total_area']; + $item['farmer_sc_area'] += $v['pond_total_area']; + $item['farmer_jc_area'] += $v['animal_total_area']; + $item['farmer_jq_area'] += $v['poultry_total_area']; + } + return $item; + })->toArray(); + $userData['captain_list'] = $captainList; + return $this->success('请求成功',$userData->toArray()); + } + //获取生产队长信息 public function captainInfo(): Json { @@ -141,7 +231,7 @@ class InformationController extends BaseApiController if(empty($params['user_id'])){ return $this->fail('参数错误_worker'); } - $userData = User::field('nickname as name,avatar,province,province province_name,city,city city_name,area,area area_name,street,street street_name,village,village village_name,brigade,brigade brigade_name')->where('id',$params['user_id'])->where('is_captain',1)->findOrEmpty(); + $userData = User::field('id,nickname as name,avatar,province,province province_name,city,city city_name,area,area area_name,street,street street_name,village,village village_name,brigade,brigade brigade_name')->where('id',$params['user_id'])->where('is_captain',1)->findOrEmpty(); if($userData->isEmpty()){ return $this->fail('用户数据不存在'); }