Browse Source

首页推荐的条件又改了

lizhen_gitee 1 year ago
parent
commit
144fa3d293
2 changed files with 42 additions and 26 deletions
  1. 41 25
      application/api/controller/Index.php
  2. 1 1
      application/extra/site.php

+ 41 - 25
application/api/controller/Index.php

@@ -129,48 +129,30 @@ class Index extends Api
     //推荐
     //真人认证的,是推荐用户的,可能也要限制vip的
     public function tuijian(){
-        $cityname = input('cityname','');
+        /*$cityname = input('cityname','');
         if(empty($cityname)){
             $cityname = $this->auth->cityname;
-        }
+        }*/
 
+        //强制条件
         $where = [
             'user.id' => ['neq',$this->auth->id],
             'user.status' => 1,
-//            'user.photo_images' => ['neq',''],
-//            'user.cityname' => $cityname,
             'power.yinshen' => 0,
         ];
 
-        //推荐条件
-        $where_tuijian = [
-            'user.idcard_status' => 1,
-            'user.is_tuijian'    => 1,
-        ];
-        if(config('site.index_tuijian_vip_limit') == 1){
-            $where_tuijian['wallet.vip_endtime'] = ['gt',time()];
-        }
-        //推荐条件
-
-        $where = array_merge($where,$where_tuijian);
-
-        //性别
+        //搜索条件 性别
         $gender = input('gender','all');
         if($gender != 'all'){
             $where['user.gender'] = $gender;
         }
-        //属性
+        //搜索条件 属性
         $attribute = input('attribute','all');
         if($attribute != 'all' && $attribute != 'BOTH'){
             $where['user.attribute'] = $attribute;
         }
-        //排除黑名单的
-        $where_black = [];
-        $black_ids = Db::name('user_black')->where(['uid'=>$this->auth->id])->column('black_uid');
-        if(!empty($black_ids)){
-            $where_black['user.id'] = ['NOTIN',$black_ids];
-        }
-        //年龄
+
+        //搜索条件 年龄
         $agemin = input('agemin',18);
         if($agemin > 18){
             $where['user.birthday'] = ['lt',time()-$agemin*31536000];
@@ -182,6 +164,30 @@ class Index extends Api
         if($agemin > 18 && $agemax < 100){
             $where['user.birthday'] = ['between',[time()-$agemax*31536000,time()-$agemin*31536000]];
         }
+
+        //排除黑名单的
+        $where_black = [];
+        $black_ids = Db::name('user_black')->where(['uid'=>$this->auth->id])->column('black_uid');
+        if(!empty($black_ids)){
+            $where_black['user.id'] = ['NOTIN',$black_ids];
+        }
+
+        //其他条件  与 推荐条件是 或的关系
+        $where_other = [
+            'user.avatar' => ['neq',''],
+            'user.idcard_status' => 1,
+        ];
+
+        if(config('site.index_tuijian_vip_limit') == 1){
+            $where_other['wallet.vip_endtime'] = ['gt',time()];
+        }
+
+        //推荐条件
+        $where_tuijian = [
+            'user.is_tuijian'    => 1,
+        ];
+
+
         //距离
         $having_dis = '';
         $distancemin = input('distancemin',0);
@@ -220,10 +226,20 @@ class Index extends Api
             ->join('user_active active' ,'user.id = active.user_id','LEFT')
             ->where($where)
             ->where($where_black)
+            ->where(
+                function($query)use($where_other,$where_tuijian){
+                    $query->where(
+                        function($query)use($where_other){
+                        $query->where($where_other);
+                        }
+                    );
+                    $query->whereOr($where_tuijian);
+            })
             ->having($having_dis)
             ->order('user.is_active desc,distance asc')
             ->autopage()
             ->select();
+
         $list = list_domain_image($list,['avatar','photo_images']);
         foreach($list as $key => &$val){
             $val['age'] = birthtime_to_age($val['birthday']);

+ 1 - 1
application/extra/site.php

@@ -59,7 +59,7 @@ return array (
   'min_withdrawal_money' => '1',
   'max_withdrawal_money' => '10000',
   'withdrawal_plat_bili' => '6',
-  'index_tuijian_vip_limit' => '0',
+  'index_tuijian_vip_limit' => '1',
   'index_pipei_switch' => '1',
   'index_pipei_oneday_user_times' => '5',
   'money_to_gold_rule' => '1、每个档位不限制兑换次数