517 lines
22 KiB
PHP
517 lines
22 KiB
PHP
<?php
|
||
|
||
namespace app\api\controller;
|
||
|
||
use app\api\BaseController;
|
||
use app\api\middleware\Auth;
|
||
use think\facade\Db;
|
||
|
||
|
||
/**
|
||
* 文娱 旅游
|
||
*/
|
||
class Cultural extends BaseController
|
||
{
|
||
/**
|
||
* 控制器中间件 [不需要鉴权]
|
||
* @var array
|
||
*/
|
||
protected $middleware = [
|
||
Auth::class => ['except' => ['WebStrategy','HotParty','PunchCard','Article'] ]
|
||
];
|
||
|
||
protected function getData($cid){
|
||
$where = ['category_id'=>$cid];
|
||
$list = Db::table('fa_article')->where($where)
|
||
->page(1)
|
||
->limit(10)
|
||
->order('id desc')
|
||
->select();
|
||
|
||
return $list;
|
||
}
|
||
|
||
public function WebStrategy(){
|
||
$data = $this->getData(364);
|
||
$this->apiSuccess('ok', ['list' => $data]);
|
||
}
|
||
|
||
public function HotParty() {
|
||
$data = $this->getData(360);
|
||
$this->apiSuccess('ok', ['list' => $data]);
|
||
}
|
||
|
||
public function PunchCard(){
|
||
$data = $this->getData(361);
|
||
$this->apiSuccess('ok', ['list' => $data]);
|
||
}
|
||
|
||
public function Article(){
|
||
$data = $this->getData(362);
|
||
$this->apiSuccess('ok', ['list' => $data]);
|
||
}
|
||
|
||
|
||
|
||
public function index1($search = '', $category_id = 1, $page = 1, $is_time = 0, $category_type = 0)
|
||
{
|
||
$param = get_params();
|
||
|
||
$screen = $param['screen']??1;
|
||
$solve = $param['solve']??1;
|
||
$order = $param['order']??1;
|
||
// $model = Db::table('fa_article');
|
||
$where = [
|
||
['status', '=', 1],
|
||
['category_id', '=', $category_id]
|
||
];
|
||
//查询升降序
|
||
if($order==1){
|
||
$orders='desc';
|
||
}else{
|
||
$orders='asc';
|
||
}
|
||
if (!$category_id) {
|
||
unset($where[1]);
|
||
}
|
||
//根据个人村id进行查询
|
||
if (JWT_UID) {
|
||
$find = Db::table('fa_szxc_information_useraddress')->where('user_id', JWT_UID)->find();
|
||
if ($find) {
|
||
if ($find['auth_range']==1){
|
||
$where[] = ['village', '=', $find['village_id']];
|
||
}elseif ($find['auth_range']==2){
|
||
$where[] = ['township', '=', $find['street_id']];
|
||
}elseif ($find['auth_range']==3){
|
||
$where[] = ['county', '=', $find['area_id']];
|
||
}
|
||
}
|
||
// 登录返回村名和村地址
|
||
$cun_arr['cun_name'] = Db::table('fa_geo_village')->where('village_id', $find['village_id'])->value('village_name');
|
||
$cun_arr['cun_address'] = Db::table('fa_szxc_information_usermsg')->where('user_id', JWT_UID)->value('address_name');
|
||
}else{
|
||
$cun_arr = [];
|
||
}
|
||
|
||
if(isset($param['street_id']) && !empty($param['street_id'])){
|
||
$where[] = ['township', '=', $param['street_id']];
|
||
}
|
||
if(isset($param['village_id']) && !empty($param['village_id'])){
|
||
$where[] = ['village', '=', $param['village_id']];
|
||
}
|
||
|
||
//总条数
|
||
$count = Db::table('fa_article')->where($where)->count();
|
||
//当月条数
|
||
$month_count = Db::table('fa_article')->where($where)->whereMonth('view_time')->count();
|
||
if ($search != '') {
|
||
$where[] = ['title', 'like', '%' . $search . '%'];
|
||
}
|
||
if ($category_type != 0) {
|
||
$where[] = ['category_type', '=', $category_type];
|
||
}
|
||
//判断筛选查询
|
||
if ($screen==2){
|
||
foreach ($where as $key =>$value){
|
||
$where[$key][0] = 'a.'.$value[0];
|
||
}
|
||
//查询
|
||
$select = Db::table('fa_article')->where($where)->page($page)->limit(20)
|
||
->alias('a')
|
||
->join(['fa_article_vote_side_tables' => 'avst'],"a.id = avst.article_id and avst.end_time >=".date('Y-m-d'))
|
||
->field('a.id,a.title,a.describe,a.user_id,a.view,a.view_time,a.image,a.end_time,a.is_solve,a.is_vote,a.is_nickname,a.video,a.category_type,avst.end_time as die_time')
|
||
->order('a.id DESC')
|
||
->select()->toArray();
|
||
}else if ($screen==3){
|
||
foreach ($where as $key =>$value){
|
||
$where[$key][0] = 'a.'.$value[0];
|
||
}
|
||
//查询
|
||
$select = Db::table('fa_article')->where($where)->page($page)->limit(20)
|
||
->alias('a')
|
||
->join(['fa_article_vote_side_tables' => 'avst'],"a.id = avst.article_id and avst.end_time <=".date('Y-m-d'))
|
||
->field('a.id,a.title,a.describe,a.user_id,a.view,a.view_time,a.image,a.end_time,a.is_solve,a.is_vote,a.is_nickname,a.video,a.category_type,avst.end_time as die_time')
|
||
->order('a.id DESC')->select()->toArray();
|
||
}else{
|
||
//查询是否解决
|
||
if($solve==2){
|
||
$where[] = ['is_solve', '=', 0];
|
||
}else if($solve==3){
|
||
$where[] = ['is_solve', '=', 1];
|
||
}
|
||
$select = Db::table('fa_article')->with('user')->where($where)->page($page)->limit(20)
|
||
->field('id,title,user_id,view,view_time,image,end_time,is_solve,is_vote,is_nickname,video,category_type,describe')
|
||
->order('id',$orders)->select()->toArray();
|
||
}
|
||
|
||
foreach ($select as $key => $value) {
|
||
if ($value['is_nickname'] == 1) {
|
||
$select[$key]['nickname'] = "匿名人员";
|
||
$select[$key]['avatar'] = "";
|
||
$select[$key]['user_id'] = 0;
|
||
} else {
|
||
$select[$key]['nickname'] = Db::table('fa_szxc_information_usermsg')->where('user_id', $value['user_id'])->value('name');
|
||
}
|
||
//投票处理
|
||
if ($value['is_vote'] == 1) {
|
||
$article_vote = Db::table('fa_article_vote_side_tables')->where('article_id', $value['id'])->find();
|
||
if ($article_vote) {
|
||
$data = $article_vote;
|
||
$data['agree_percentage'] = 0;
|
||
$data['opposition_percentage'] = 0;
|
||
$count_vote = $data['agree'] + $data['opposition'] + $data['other'];
|
||
if ($count_vote != 0) {
|
||
if ($data['agree'] != 0) {
|
||
$data['agree_percentage'] = round(($data['agree'] / $count_vote) * 100);
|
||
}
|
||
if ($data['opposition'] != 0) {
|
||
$data['opposition_percentage'] = round(($data['opposition'] / $count_vote) * 100);
|
||
}
|
||
}
|
||
$select[$key]['extend']['vote'] = $data;
|
||
}
|
||
} else {
|
||
$select[$key]['extend'] = [];
|
||
}
|
||
if ($is_time == 1) {
|
||
if ($value['end_time'] < date('Y-m-d H:i:s')) {
|
||
if ($value['end_time'] == '0000-00-00 00:00:00') {
|
||
$select[$key]['overdue_time'] = '显示错误';
|
||
} else {
|
||
if($value['is_solve']==1){
|
||
$select[$key]['overdue_time'] = 0;
|
||
}else{
|
||
$cle = time() - strtotime($value['end_time']);
|
||
$select[$key]['overdue_time'] = ceil($cle / 3600 / 24);
|
||
}
|
||
}
|
||
} else {
|
||
$select[$key]['overdue_time'] = 0;
|
||
}
|
||
|
||
}
|
||
if ($category_id == 165) {
|
||
if ($value['category_type'] != 0) {
|
||
$find = Db::table('fa_category')->where('id', $value['category_type'])->find();
|
||
$select[$key]['extend']['category_type_name'] = $find ? $find['name'] . ':' : '';
|
||
} else {
|
||
$select[$key]['extend']['category_type_name'] = '';
|
||
}
|
||
}
|
||
|
||
|
||
}
|
||
$this->apiSuccess('ok', ['list' => $select, 'cun'=>$cun_arr, 'count' => ['count' => $count, 'month_count' => $month_count]]);
|
||
}
|
||
|
||
/**首页推荐
|
||
* @param $category_id
|
||
* @param $page
|
||
*/
|
||
public function hot_list($category_id = 0, $page = 1, $county = 0, $township = 0, $village = 0)
|
||
{
|
||
$where = [
|
||
['status', '=', 1],
|
||
];
|
||
if (!$category_id) {
|
||
unset($where[1]);
|
||
}
|
||
// 如果登录
|
||
if (JWT_UID) {
|
||
$find = Db::table('fa_szxc_information_useraddress')->where('user_id', JWT_UID)->find();
|
||
if ($find) {
|
||
if ($find['auth_range']==1){
|
||
$where[] = ['village', '=', $find['village_id']];
|
||
}elseif ($find['auth_range']==2){
|
||
$where[] = ['township', '=', $find['street_id']];
|
||
}elseif ($find['auth_range']==3){
|
||
$where[] = ['county', '=', $find['area_id']];
|
||
}
|
||
}
|
||
}
|
||
// if ($county != 0) {
|
||
// $where[] = ['county', '=', $county];
|
||
// }
|
||
// if ($township != 0) {
|
||
// $where[] = ['township', '=', $township];
|
||
// }
|
||
// if ($village != 0) {
|
||
// $where[] = ['village', '=', $village];
|
||
// }
|
||
if ($category_id == 0) {
|
||
$where[] = ['category_id', 'in', [176, 162, 161, 160, 152]];
|
||
$sos = Db::table('fa_article')->where('category_id', 150)->where('status', 1)
|
||
->whereTime('view_time','between', [date("H:i:s",strtotime("-5 minute")), date("H:i:s",strtotime("+5 minute"))])
|
||
->page($page)->limit(3)
|
||
->withAttr('user_info', function ($value, $data) {
|
||
$user = Db::table('fa_user')->where('id', $data['user_id'])->field('nickname,avatar')->find();
|
||
$user['name'] = Db::table('fa_szxc_information_usermsg')->where('user_id', $data['user_id'])->value('name');
|
||
return $user;
|
||
})
|
||
->withAttr('article_comment', function ($value, $data) {
|
||
return Db::table('fa_article_comment')->where([['vote_id','=',$data['id']],['status','=',1]])->count();
|
||
})
|
||
->withAttr('article_type', function ($value, $data) {
|
||
return '一键求救';
|
||
})
|
||
->field('id,title,user_id,view,view_time,image,end_time,is_solve,is_vote,is_nickname,video,category_id,source')->order('id DESC')
|
||
->withAttr('image', function ($value, $data) {
|
||
if ($data['image'] != '') {
|
||
return explode(',', $data['image']);
|
||
}
|
||
})
|
||
->select()->toArray();
|
||
} else {
|
||
$where[] = ['category_id', '=', $category_id];
|
||
$sos = [];
|
||
}
|
||
//查询
|
||
$mapo[] = [['category_id','=','1'],['status','=','1']];
|
||
$select = Db::table('fa_article')->where($where)->whereOr($mapo)->page($page)->limit(20)
|
||
->withAttr('user_info', function ($value, $data) {
|
||
$user = Db::table('fa_user')->where('id', $data['user_id'])->field('nickname,avatar')->find();
|
||
$user['name'] = Db::table('fa_szxc_information_usermsg')->where('user_id', $data['user_id'])->value('name');
|
||
return $user;
|
||
})
|
||
->field('id,title,describe,user_id,view,view_time,image,end_time,is_solve,is_vote,is_nickname,video,category_id')->order('id DESC')
|
||
->withAttr('image', function ($value, $data) {
|
||
if ($data['image'] != '') {
|
||
return explode(',', $data['image']);
|
||
}
|
||
})
|
||
->withAttr('article_comment', function ($value, $data) {
|
||
return Db::table('fa_article_comment')->where([['vote_id','=',$data['id']],['status','=',1]])->count();
|
||
})
|
||
->withAttr('article_type', function ($value, $data) {
|
||
if($data['category_id'] == 1){
|
||
return '实时信息';
|
||
}elseif($data['category_id'] == 176){
|
||
return '党务公开';
|
||
}elseif($data['category_id'] == 162){
|
||
return '议事大厅';
|
||
}elseif($data['category_id'] == 161){
|
||
return '财务公开';
|
||
}elseif($data['category_id'] == 160){
|
||
return '村务公开';
|
||
}elseif($data['category_id'] == 152){
|
||
return '好人好事';
|
||
}else{
|
||
return '';
|
||
}
|
||
})
|
||
->select()->toArray();
|
||
$personal=Db::table('fa_szxc_personal_news')
|
||
->withAttr('user_info', function ($value, $data) {
|
||
$user = Db::table('fa_user')->where('id', $data['user_id'])->field('nickname,avatar')->find();
|
||
$user['name'] = Db::table('fa_szxc_information_usermsg')->where('user_id', $data['user_id'])->value('name');
|
||
return $user;
|
||
})
|
||
->withAttr('image', function ($value, $data) {
|
||
if ($data['image'] != '') {
|
||
return json_decode($data['image'],true);
|
||
}
|
||
})
|
||
->withAttr('article_comment', function ($value, $data) {
|
||
return Db::table('fa_szxc_personal_news_comment')->where([['personal_news_id','=',$data['id']],['status','=',1]])->count();
|
||
})
|
||
->withAttr('article_type', function ($value, $data) {
|
||
return Db::table('fa_category')->where('id', $data['category_id'])->value('name');
|
||
})
|
||
->withAttr('view_time', function ($value, $data) {
|
||
return date('Y-m-d H:i:s', $value);
|
||
})
|
||
->field('id,id as personal_news_id,content as title,user_id,view,createtime as view_time,images as image,video,category_id')
|
||
->limit(5)->order('id desc')->page($page)->select()->toArray();
|
||
$i=0;
|
||
$personal_count=count($personal);
|
||
if ($select && $personal){
|
||
foreach($select as $key=>$value){
|
||
if ($key!=0 &&$key%2==0 &&$i<$personal_count){
|
||
array_splice($select,$key+$i,0,[$personal[$i]]);
|
||
++$i;
|
||
}
|
||
}
|
||
}
|
||
$this->apiSuccess('ok', ['list' => array_merge($sos, $select)]);
|
||
}
|
||
|
||
/**首页分类列表
|
||
* @param $category_id
|
||
* @param $page
|
||
*/
|
||
public function getArticleList($category_id = 0, $page = 1, $type = 1)
|
||
{
|
||
// $model = Db::table('fa_article');
|
||
$where = [
|
||
['status', '=', 1],
|
||
];
|
||
//根据个人村id进行查询
|
||
if (JWT_UID) {
|
||
$find = Db::table('fa_szxc_information_useraddress')->where('user_id', JWT_UID)->find();
|
||
if ($find) {
|
||
if ($find['auth_range']==1){
|
||
$where[] = ['village', '=', $find['village_id']];
|
||
}elseif ($find['auth_range']==2){
|
||
$where[] = ['township', '=', $find['street_id']];
|
||
}elseif ($find['auth_range']==3){
|
||
$where[] = ['county', '=', $find['area_id']];
|
||
}
|
||
}
|
||
}
|
||
if ($type == 1) {
|
||
$where[] = ['category_id', 'in', [162, 161, 160, 152]];
|
||
|
||
} else {
|
||
$where[] = ['category_id', '=', $category_id];
|
||
}
|
||
//查询
|
||
$select = Db::table('fa_article')->where($where)->page($page)->limit(20)
|
||
->field('id,title,user_id,view,view_time,image,end_time,is_solve,is_vote,is_nickname,video,category_id')->order('id DESC')
|
||
->withAttr('image', function ($value, $data) {
|
||
if ($data['image'] != '') {
|
||
return explode(',', $data['image']);
|
||
}
|
||
})
|
||
->withAttr('user_info', function ($value, $data) {
|
||
$user = Db::table('fa_user')->where('id', $data['user_id'])->field('nickname,avatar')->find();
|
||
$user['name'] = Db::table('fa_szxc_information_usermsg')->where('user_id', $data['user_id'])->value('name');
|
||
return $user;
|
||
})
|
||
->withAttr('article_comment', function ($value, $data) {
|
||
return Db::table('fa_article_comment')->where([['vote_id','=',$data['id']],['status','=',1]])->count();
|
||
})
|
||
->withAttr('article_type', function ($value, $data) {
|
||
if($data['category_id'] == 176){
|
||
return '党务公开';
|
||
}elseif($data['category_id'] == 162){
|
||
return '议事大厅';
|
||
}elseif($data['category_id'] == 161){
|
||
return '财务公开';
|
||
}elseif($data['category_id'] == 160){
|
||
return '村务公开';
|
||
}elseif($data['category_id'] == 152){
|
||
return '好人好事';
|
||
}else{
|
||
return '';
|
||
}
|
||
})
|
||
->select()->toArray();
|
||
return $this->apiSuccess('ok', ['list' => $select]);
|
||
}
|
||
|
||
/**详情
|
||
* @param $id
|
||
* @return null
|
||
* @throws \think\db\exception\DataNotFoundException
|
||
* @throws \think\db\exception\DbException
|
||
* @throws \think\db\exception\ModelNotFoundException
|
||
*/
|
||
public function details($id)
|
||
{
|
||
// 增加阅读数
|
||
// $ip = 'article-details-'.$this->request->ip().'-'.$id;
|
||
// $ip_cache = Cache::get($ip);
|
||
// if(empty($ip_cache)){
|
||
// Cache::set($ip,$id,3600*24);
|
||
$map[] =['id','=', $id];
|
||
Db::table('fa_article')->where($map)->inc('view','1')->update();
|
||
// }
|
||
|
||
$where = [
|
||
['status', '=', 1],
|
||
['id', '=', $id]
|
||
];
|
||
$find = Db::table('fa_article')->where($where)
|
||
->withAttr('user_info', function ($data, $value) {
|
||
$find['nickname'] = "匿名人员";
|
||
$find['mobile'] = "匿名状态无法显示";
|
||
$find['gender'] = "匿名状态无法显示";
|
||
$find['avatar'] = "";
|
||
$find['user_id'] = 0;
|
||
$find['count'] = 0;
|
||
$find['end_count'] = 0;
|
||
$find['overdue_count'] = 0;
|
||
if ($value['is_nickname'] == 0) {
|
||
$user = Db::table('fa_user')->where('id', $value['user_id'])->field('nickname,avatar,mobile')->find();
|
||
if ($user) {
|
||
$find = $user;
|
||
}
|
||
$find['nickname'] = Db::table('fa_szxc_information_usermsg')->where('user_id', $value['user_id'])->value('name');
|
||
}
|
||
$config_find = Db::table('fa_config')->where('id', 20)->find();
|
||
//是否查询提案数
|
||
if (in_array($value['category_id'], explode(',', $config_find['value']))) {
|
||
//提案总数
|
||
$where = [
|
||
['category_id', '=', $value['category_id']],
|
||
['user_id', '=', $value['user_id']]
|
||
];
|
||
//处理总数
|
||
$whereTwo = [
|
||
['category_id', '=', $value['category_id']],
|
||
['user_id', '=', $value['user_id']],
|
||
['is_solve', '=', 1]
|
||
];
|
||
$find['count'] = Db::table('fa_article')->where($where)->count();
|
||
$find['end_count'] = Db::table('fa_article')->where($whereTwo)->count();
|
||
//逾期总数
|
||
$where[] = ['is_solve', '=', 0];
|
||
$find['overdue_count'] = Db::table('fa_article')->where($where)->whereTime('end_time', '<=', date('Y-m-d H:i:s'))
|
||
->count();
|
||
$usermsg = Db::table('fa_szxc_information_usermsg')->where('user_id', $value['user_id'])->field('age,address_name,gender,name')->find();
|
||
if ($value['is_nickname']==1){
|
||
$find['age'] ='匿名状态无法显示';
|
||
$find['address'] = '匿名状态无法显示';
|
||
$find['gender'] = '匿名状态无法显示';
|
||
}else{
|
||
$find['age'] = $usermsg?$usermsg['age']:'';
|
||
$find['address'] = $usermsg?$usermsg['address_name']:'';
|
||
if ($usermsg){
|
||
$find['gender'] =$usermsg['gender']==1?'男':'女';
|
||
}
|
||
$find['nickname'] = $usermsg['name'];
|
||
}
|
||
$insurance = Db::table('fa_szxc_information_insurance')->where('user_id', $value['user_id'])->field('insurance_type')->find();
|
||
if ($insurance) {
|
||
$find['insurance_type'] = $insurance['insurance_type'];
|
||
} else {
|
||
$find['insurance_type'] = "";
|
||
}
|
||
}
|
||
return $find;
|
||
})->withAttr('category_type_title', function ($data, $value) {
|
||
if ($value['category_type'] != 0) {
|
||
$find = Db::table('fa_category')->where('id', $value['category_type'])->find();
|
||
return $find['name'];
|
||
}
|
||
})
|
||
->find();
|
||
//投票处理
|
||
if ($find['is_vote'] == 1) {
|
||
$article_vote = Db::table('fa_article_vote_side_tables')->where('article_id', $find['id'])->find();
|
||
if ($article_vote) {
|
||
$data = $article_vote;
|
||
$data['agree_percentage'] = 0;
|
||
$data['opposition_percentage'] = 0;
|
||
$count_vote = $data['agree'] + $data['opposition'] + $data['other'];
|
||
if ($count_vote != 0) {
|
||
if ($data['agree'] != 0) {
|
||
$data['agree_percentage'] = round(($data['agree'] / $count_vote) * 100);
|
||
}
|
||
if ($data['opposition'] != 0) {
|
||
$data['opposition_percentage'] = round(($data['opposition'] / $count_vote) * 100);
|
||
}
|
||
}
|
||
$find['extend']['vote'] = $data;
|
||
}
|
||
|
||
} else {
|
||
$find['extend'] = [];
|
||
|
||
}
|
||
return $this->apiSuccess('ok', $find);
|
||
}
|
||
|
||
|
||
}
|