* 分类信息管理 */ namespace app\allwin\model; use app\common\facade\Inform; use app\allwin\model\Levels; use app\allwin\model\Vip; use think\Model; use util\Util; use filter\Filter; use think\db\Where; class AllwinInfo extends Model{ protected $pk = 'id'; //用户 public function user(){ return $this->hasOne('app\common\model\SystemUser','id','user_id'); } //一对多管理回复的评论 public function comments(){ return $this->hasMany('AllwinInfoReply','info_id','id'); } //所属栏目 public function cate(){ return $this->hasOne('AllwinInfoCate','id','cate_id'); } //是否关注 public function follow(){ return $this->hasOne('AllwinInfoFollow','like_uid','user_id'); } //是否认证号 public function mp(){ return $this->hasOne('AllwinInfoMp','uid','user_id'); } //搜索器 public function searchThemesAttr($query,$value){ $value = Filter::filter_escape($value); if(!empty($value)){ $query->where('themes','like', '%'. $value .'%'); } } /** * 锁定 * @param integer $id */ public static function lock(int $id,$member_miniapp_id){ $result = self::get($id); $data['is_lock'] = $result['is_lock'] ? 0 : 1; if($data['is_lock'] == 0) { //通知申请者到微信 Inform::sms($result->user_id,$member_miniapp_id,['title' =>'业务进展通知','type' => '同城信息申请','content' =>'您的同城信息申请已经通过审核','state' => '成功']); } return AllwinInfo::where('id',$id)->update($data); } /** * 指定 * @param integer $id */ public static function top(int $id){ $result = self::where(['id' => $id])->find(); $data['is_top'] = $result['is_top'] ? 0 : 1; return AllwinInfo::where('id',$id)->update($data); } /** * API的信息列表查询 * @param integer $id */ public static function apiLists($where,$order,$user,$keyword = ''){ $rel = AllwinInfo::with([ 'user' => function($query) { $query->field('id,nickname,face'); }, 'cate' => function($query) { $query->field('id,tpl_id,title'); }, 'mp' => function($query) { $query->field('id,uid,logo,title,is_vip'); } ])->withSearch(['themes'],['themes' => $keyword])->where($where)->order($order)->paginate(10); $data = []; foreach ($rel as $key => $value) { $data[$key] = $value; if(empty($value->cate->tpl)){ $data[$key]['button_name'] = '立即下单'; $data[$key]['tips'] = '任何有用户发布,下单后请电话再次确认'; $data[$key]['is_shop'] = 0; }else{ $data[$key]['button_name'] = $value->cate->tpl->button_name; $data[$key]['tips'] = $value->cate->tpl->tips; $data[$key]['is_shop'] = $value->cate->tpl->is_shop; } $images = empty($value->images) ? [] : json_decode($value->images,true); foreach ($images as $i => $img) { $images[$i] = $img.'?x-oss-process=style/300'; } $data[$key]['images'] = $images; $data[$key]['images_len'] = count($images); $data[$key]['fields'] = empty($value->fields) ? [] : json_decode($value->fields,true); $data[$key]['create_time'] = util::ftime($value->create_time); $data[$key]['is_mp'] = empty($value->mp)?0:1; //是否点赞 $data[$key]['is_like'] = 0; $data[$key]['like_face'] = empty($value->like_face) ? [] : json_decode($value->like_face,true); //判断是否被关注 $data[$key]['is_follow'] = !empty($value->follow) && ! empty($user) && $value->follow->uid = $user->id ? 1:0; } return $data; } //添加或编辑 public static function postThemes($param){ $data['themes'] = $param['content']; $data['telphone'] = $param['telphone']; $data['top_money'] = $param['top_money']; $data['topday'] = $param['topday']; $data['fields'] = $param['fields']; $data['images'] = $param['imgs']; $data['user_id'] = $param['user_id']; $data['cate_id'] = $param['cate_id']; $data['store_id'] = $param['store_id']; $data['order_no'] = $param['order_no']; $data['price'] = (int)$param['price']; $data['create_time'] = time(); $data['views'] = rand(1,500); $data['is_lock'] = 1; $data['member_miniapp_id'] = $param['member_miniapp_id']; return self::create($data); } /** * 读取信息列表 * @param integer 读取ID * @return json */ public function lists(array $where,int $num = 10){ $rel = self::where($where) ->field('id,is_top,cate_id,cate_name,user_id,member_miniapp_id,themes,images,sort,telphone,views,task_money,topday,is_pay,create_time') ->order('is_top desc,sort desc,id desc') ->paginate($num); $data = []; foreach ($rel as $key => $value) { $data[$key] = $value; $data[$key]['face'] = $value->user['face']; $data[$key]['nickname'] = $value['user']['nickname'];; $data[$key]['images'] = empty($value['images']) ? []: json_decode($value['images']); $data[$key]['create_time'] = util::ftime($value['create_time']); } return $data; } /** * 获取某个评论列表 * @param integer 读取ID * @return json */ public function reply(array $where,int $num = 10){ $rel = self::view('allwin_info_reply','id,info_id,user_id,reply,create_time') ->view('system_user','face,nickname','allwin_info_reply.user_id = system_user.id') ->where($where) ->where(['state' => 1]) ->order('id desc')->paginate($num,true)->toArray(); $data = $rel['data']; foreach ($data as $key => $value) { $data[$key]['create_time'] = util::ftime($value['create_time']); } return $data; } /** * 信息发布获利 * @param integer $miniapp_id 来源小程序 * @param integer $uid 用户ID * @param float $cash_fee (分) * @param [type] $config 系统配置 * @return void */ public static function sendinfo($order){ $level = Levels::where(['user_id' => $order->user_id,'level'=>[1,2]])->select(); $level1 = 0; $level2 = 0; foreach ($level as $value) { if ($value['level'] == 1) { $level1 = $value['parent_id']; } if ($value['level'] == 2) { $level2 = $value['parent_id']; } } $config = AllwinInfoConfig::config($order->member_miniapp_id); if ($level1) { $rel1 = Vip::where(['user_id' => $level1,'state'=>1,'is_lock' =>0])->field('user_id')->find(); if (!empty($rel1)) { $bring = intval($order->top_money*($config->bring/100)); $l1_money = (float)money($bring/100); if ($l1_money > 0) { Bank::dueMoney($order->member_miniapp_id,$level1,$l1_money); BankBill::add(['miniapp_id'=>$order->member_miniapp_id,'store_id' => 0,'money'=>$l1_money,'uid'=>$level1,'pay_uid' => $order->user_id],'同城推荐奖励'); } } } if ($level2) { $rel2 = Vip::where(['user_id' => $level2,'state'=>1,'is_lock' => 0])->field('user_id')->find(); if (!empty($rel2)) { $reward = intval($order->top_money*($config->reward/100)); $l2_money = (float)money($reward/100); if ($l2_money > 0) { Bank::dueMoney($order->member_miniapp_id,$level2,$l2_money); BankBill::add(['miniapp_id' => $order->member_miniapp_id,'store_id' => 0,'money'=> $l2_money,'uid'=>$level2,'pay_uid' =>$order->user_id],'同城推荐奖励'); } } } } }