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();
 | |
|     }
 | |
| 
 | |
| 
 | |
| } |