TaoLer/app/admin/controller/content/Comment.php

182 lines
5.3 KiB
PHP
Raw Normal View History

2023-03-16 22:40:15 +08:00
<?php
2023-03-16 22:42:05 +08:00
/**
* @Program: TaoLer 2023/3/14
* @FilePath: app\admin\controller\content\Comment.php
* @Description: Comment
* @LastEditTime: 2023-03-14 15:38:55
* @Author: Taoker <317927823@qq.com>
* @Copyright (c) 2020~2023 https://www.aieok.com All rights reserved.
*/
2023-03-16 22:40:15 +08:00
namespace app\admin\controller\content;
use app\common\controller\AdminController;
2023-05-05 12:04:46 +08:00
use think\App;
2023-03-16 22:40:15 +08:00
use think\facade\View;
use think\facade\Request;
use think\facade\Db;
2023-03-16 22:42:05 +08:00
use app\common\model\Comment as CommentModel;
2023-03-16 22:40:15 +08:00
2023-03-16 22:42:05 +08:00
class Comment extends AdminController
{
2023-05-05 12:04:46 +08:00
protected $model;
public function __construct(App $app)
{
parent::__construct($app);
$this->model = new \app\common\model\Comment();
}
2023-03-16 22:42:05 +08:00
/**
* 浏览
* @return string
*/
2023-03-16 22:40:15 +08:00
public function index()
{
return View::fetch();
}
2023-05-05 12:04:46 +08:00
public function list1()
{
$data = Request::only(['name','content','status']);
$map = $this->getParamFilter($data);
$where = [];
if(!empty($map['content'])){
$where[] = ['content', 'like', $map['content'].'%'];
}
if(isset($data['status'])){
$where[] = ['status', '=', (int) $data['status']];
}
if(isset($data['name'])){
$userId = Db::name('user')->where('name',$data['name'])->value('id');
$where[] = ['user_id', '=', $userId];
}
unset($map);
$list = $this->model->getCommentList($where, input('page'), input('limit'));
$res = [];
if($list['total']) {
$res = ['code' =>0, 'msg' => 'ok', 'count' => $list['total']];
foreach($list['data'] as $k => $v){
$res['data'][] = [
'id' => $v['id'],
'replyer' => $v['user']['name'],
'title' => $v['article']['title'],
'avatar' => $v['user']['user_img'],
'content' => strip_tags($v['content']),
'replytime' => $v['create_time'],
'check' => $v['status'],
//'url' => $this->getArticleUrl($v['article_id'], 'index', $v->article->cate->ename),
];
}
return json($res);
}
return json(['code' => 0, 'msg' => 'no data']);
}
2023-03-16 22:40:15 +08:00
//帖子评论
public function list()
{
2023-05-05 12:04:46 +08:00
$data = Request::only(['name','content','status']);
$map = array_filter($data);
$where = array();
if(!empty($map['content'])){
$where[] = ['a.content','like', $map['content'].'%'];
unset($map['content']);
}
if(isset($data['status']) && $data['status'] !== '' ){
$where[] = ['a.status','=',(int)$data['status']];
unset($map['status']);
}
$replys = Db::name('comment')
->alias('a')
->join('user u','a.user_id = u.id')
->join('article c','a.article_id = c.id')
->join('cate ca','c.cate_id = ca.id')
->field('a.id as aid,name,ename,appname,title,user_img,a.content as content,a.create_time as create_time,a.status as astatus,c.id as cid')
->where('a.delete_time',0)
->where($map)
->where($where)
->order('a.create_time', 'desc')
->paginate([
'list_rows' => input('limit'),
'page' => input('page')
]);
$count = $replys->total();
if ($count) {
$res = ['code'=>0,'msg'=>'','count'=>$count];
foreach($replys as $k => $v){
$res['data'][] = [
'id' => $v['aid'],
'replyer' => $v['name'],
'title' => htmlspecialchars($v['title']),
'avatar' => $v['user_img'],
'content' => strip_tags($v['content']),
'replytime' => date("Y-m-d",$v['create_time']),
'check' => $v['astatus'],
'url' => $this->getArticleUrl($v['cid'],'index',$v['ename'])
];
}
} else {
$res = ['code'=>-1,'msg'=>'没有查询结果!'];
}
return json($res);
2023-03-16 22:40:15 +08:00
}
//评论编辑
public function edit()
{
return View::fetch();
}
//评论删除
public function delete($id)
{
if(Request::isAjax()){
2023-07-03 12:50:57 +08:00
try {
$arr = explode(",",$id);
foreach($arr as $v){
$comm = CommentModel::find($v);
$comm->delete();
}
2023-03-16 22:40:15 +08:00
return json(['code'=>0,'msg'=>'删除成功']);
2023-07-03 12:50:57 +08:00
} catch (\Exception $e) {
2023-03-16 22:40:15 +08:00
return json(['code'=>-1,'msg'=>'删除失败']);
}
}
}
2023-03-16 22:54:11 +08:00
2023-03-16 22:40:15 +08:00
//评论审核
public function check()
{
$data = Request::param();
//获取状态
$res = Db::name('comment')->where('id',$data['id'])->save(['status' => $data['status']]);
if($res){
2023-03-16 22:54:11 +08:00
if($data['status'] == 1) return json(['code'=>0,'msg'=>'评论审核通过','icon'=>6]);
return json(['code'=>0,'msg'=>'评论被禁止','icon'=>5]);
2023-03-16 22:40:15 +08:00
}
2023-03-16 22:54:11 +08:00
return json(['code'=>-1,'msg'=>'审核出错']);
2023-03-16 22:40:15 +08:00
}
//array_filter过滤函数
2023-03-16 22:54:11 +08:00
public function filtr($arr)
{
if($arr === '' || $arr === null) return false;
2023-03-16 22:40:15 +08:00
return true;
}
}