123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- <?php
- namespace app\api\controller;
- use app\common\controller\Api;
- use think\Db;
- /**
- * 关注
- */
- class Userfollow extends Api
- {
- protected $noNeedLogin = [];
- protected $noNeedRight = ['*'];
- //我的关注列表
- public function my_follow_list(){
- $list = Db::name('user_follow')
- ->alias('follow')
- ->join('user','follow.follow_uid = user.id','LEFT')
- ->field('user.id,user.u_id,user.username,user.nickname,user.avatar,user.desc,user.gender,follow.createtime')
- ->where('follow.uid',$this->auth->id)->order('follow.id desc')->autopage()->select();
- $list = list_domain_image($list,['avatar']);
- if(!empty($list)){
- foreach($list as $key => &$val){
- $val['createtime_text'] = get_last_time($val['createtime']);
- //是否关注
- $val['is_follow'] = 1;
- }
- }
- $this->success('success',$list);
- }
- //我的粉丝列表
- public function my_fans_list(){
- $list = Db::name('user_follow')
- ->alias('follow')
- ->join('user','follow.uid = user.id','LEFT')
- ->field('user.id,user.u_id,user.username,user.nickname,user.avatar,user.desc,user.gender,follow.createtime')
- ->where('follow.follow_uid',$this->auth->id)->order('follow.id desc')->autopage()->select();
- $list = list_domain_image($list,['avatar']);
- //我的关注uids
- $my_follow_uids = $this->my_follow_uids();
- if(!empty($list)){
- foreach($list as $key => &$val){
- $val['createtime_text'] = get_last_time($val['createtime']);
- //是否关注
- $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
- }
- }
- $this->success('success',$list);
- }
- //我的好友,拿粉丝列表改的
- public function my_friend_list(){
- $list = Db::name('user_follow')
- ->alias('follow')
- ->join('user','follow.uid = user.id','LEFT')
- ->field('user.id,user.u_id,user.username,user.nickname,user.avatar,user.desc,user.gender')
- ->where('follow.follow_uid',$this->auth->id)->order('follow.id desc')->autopage()->select();
- $list = list_domain_image($list,['avatar']);
- //我的关注uids
- $my_follow_uids = $this->my_follow_uids();
- $new_rs = []; //另起
- if(!empty($list)){
- foreach($list as $key => &$val){
- //是否关注
- $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
- //我的粉丝,且是我的关注的,另起
- if($val['is_follow'] == 1){
- $new_rs[] = $val;
- }
- }
- }
- $this->success('success',$new_rs);
- }
- //关注某人
- public function follow_one(){
- $follow_uid = input('follow_uid',0);
- if(!$follow_uid){
- $this->error(__('Invalid parameters'));
- }
- $checkuser = Db::name('user')->find($follow_uid);
- if(empty($checkuser)){
- $this->error('此用户不存在');
- }
- if($follow_uid == $this->auth->id){
- $this->error('不能关注自己');
- }
- $map = [
- 'uid' => $this->auth->id,
- 'follow_uid' => $follow_uid,
- ];
- $check = Db::name('user_follow')->where($map)->find();
- if($check){
- //取关
- $rs = Db::name('user_follow')->where($map)->delete();
- $this->success('操作成功');
- }
- Db::startTrans();
- $map['createtime'] = time();
- $id = Db::name('user_follow')->insertGetId($map);
- if(!$id){
- Db::rollback();
- $this->error('关注失败');
- }
- Db::commit();
- $this->success('操作成功',$id);
- }
- //取关某人
- public function un_follow_one(){
- $follow_uid = input('follow_uid',0);
- if(!$follow_uid){
- $this->error(__('Invalid parameters'));
- }
- $checkuser = Db::name('user')->find($follow_uid);
- if(empty($checkuser)){
- $this->error('此用户不存在');
- }
- $map = [
- 'uid' => $this->auth->id,
- 'follow_uid' => $follow_uid,
- ];
- //不检查,全删
- $rs = Db::name('user_follow')->where($map)->delete();
- $this->success('操作成功');
- }
- //我的关注uids
- private function my_follow_uids(){
- return Db::name('user_follow')->where('uid',$this->auth->id)->column('follow_uid');
- }
- //我的粉丝uids
- private function my_fans_uids(){
- return Db::name('user_follow')->where('follow_uid',$this->auth->id)->column('uid');
- }
- }
|