127 lines
3.2 KiB
PHP
127 lines
3.2 KiB
PHP
|
<?php
|
||
|
|
||
|
|
||
|
namespace app\admin\logic\community;
|
||
|
|
||
|
|
||
|
use app\common\basics\Logic;
|
||
|
use app\common\enum\CommunityCommentEnum;
|
||
|
use app\common\model\community\CommunityArticle;
|
||
|
use app\common\model\community\CommunityComment;
|
||
|
use app\common\server\UrlServer;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* 种草社区评论
|
||
|
* Class CommunityCommentLogic
|
||
|
* @package app\admin\logic\community
|
||
|
*/
|
||
|
class CommunityCommentLogic extends Logic
|
||
|
{
|
||
|
|
||
|
/**
|
||
|
* @notes 评论列表
|
||
|
* @param $get
|
||
|
* @return array
|
||
|
* @author 段誉
|
||
|
* @date 2022/5/10 12:06
|
||
|
*/
|
||
|
public static function lists($get)
|
||
|
{
|
||
|
$where = [
|
||
|
['c.del', '=', 0]
|
||
|
];
|
||
|
|
||
|
if (!empty($get['keyword'])) {
|
||
|
$where[] = ['u.sn|u.nickname|u.mobile', 'like', '%' . $get['keyword'] . '%'];
|
||
|
}
|
||
|
|
||
|
if (!empty($get['comment'])) {
|
||
|
$where[] = ['c.comment', 'like', '%' . $get['comment'] . '%'];
|
||
|
}
|
||
|
|
||
|
if (isset($get['status']) && $get['status'] != '') {
|
||
|
$where[] = ['c.status', '=', $get['status']];
|
||
|
}
|
||
|
|
||
|
$model = new CommunityComment();
|
||
|
$lists = $model->alias('c')
|
||
|
->with(['article' => function($query) {
|
||
|
$query->field('id,content,topic_id');
|
||
|
}])
|
||
|
->field('c.*,u.nickname,u.avatar,u.sn')
|
||
|
->join('user u', 'u.id = c.user_id')
|
||
|
->where($where)
|
||
|
->order(['id' => 'desc'])
|
||
|
->append(['status_desc'])
|
||
|
->paginate([
|
||
|
'page' => $get['page'],
|
||
|
'list_rows' => $get['limit'],
|
||
|
'var_page' => 'page'
|
||
|
]);
|
||
|
foreach ($lists as &$item) {
|
||
|
$item['avatar'] = !empty($item['avatar']) ? UrlServer::getFileUrl($item['avatar']) : '';
|
||
|
$item['status_desc'] = CommunityCommentEnum::getStatusDesc($item['status']);
|
||
|
$item['topic_name'] = $item['article']['topic']['name'] ?? '';
|
||
|
}
|
||
|
|
||
|
return ['count' => $lists->total(), 'lists' => $lists->getCollection()];
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @notes 详情
|
||
|
* @param $id
|
||
|
* @return array
|
||
|
* @author 段誉
|
||
|
* @date 2022/5/10 12:15
|
||
|
*/
|
||
|
public static function detail($id)
|
||
|
{
|
||
|
return CommunityComment::with(['article'])->findOrEmpty($id)->toArray();
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @notes 审核成功
|
||
|
* @param $post
|
||
|
* @return CommunityComment
|
||
|
* @author 段誉
|
||
|
* @date 2022/5/10 15:11
|
||
|
*/
|
||
|
public static function audit($post)
|
||
|
{
|
||
|
return CommunityComment::where(['id' => $post['id']])->update([
|
||
|
'status' => $post['status'],
|
||
|
'update_time' => time()
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @notes 删除评论
|
||
|
* @param $id
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\DbException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @author 段誉
|
||
|
* @date 2022/5/10 15:23
|
||
|
*/
|
||
|
public static function del($id)
|
||
|
{
|
||
|
// 删除评论
|
||
|
$comment = CommunityComment::find($id);
|
||
|
$comment->del = 1;
|
||
|
$comment->update_time = time();
|
||
|
$comment->save();
|
||
|
|
||
|
// 更新文章评论数
|
||
|
CommunityArticle::where([
|
||
|
['id', '=', $comment['article_id']],
|
||
|
['comment', '>=', 1]]
|
||
|
)->dec('comment')->update();
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|