160 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			160 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | ||
|  | 
 | ||
|  | 
 | ||
|  | namespace app\admin\logic\community; | ||
|  | 
 | ||
|  | 
 | ||
|  | use app\common\basics\Logic; | ||
|  | use app\common\model\community\CommunityArticle; | ||
|  | use app\common\model\community\CommunityTopic; | ||
|  | 
 | ||
|  | 
 | ||
|  | /** | ||
|  |  * 种草社区话题逻辑 | ||
|  |  * Class CommunityTopicLogic | ||
|  |  * @package app\admin\logic\content | ||
|  |  */ | ||
|  | class CommunityTopicLogic extends Logic | ||
|  | { | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @notes 获取话题 | ||
|  |      * @param $get | ||
|  |      * @return array | ||
|  |      * @throws \think\db\exception\DbException | ||
|  |      * @author 段誉 | ||
|  |      * @date 2022/4/28 10:09 | ||
|  |      */ | ||
|  |     public static function lists($get) | ||
|  |     { | ||
|  |         $where = [ | ||
|  |             ['del', '=', 0] | ||
|  |         ]; | ||
|  |          | ||
|  |         if (!empty($get['name'])) { | ||
|  |             $where[] = ['name', 'like', '%'.$get['name'].'%']; | ||
|  |         } | ||
|  | 
 | ||
|  |         if (!empty($get['cid'])) { | ||
|  |             $where[] = ['cid', '=', $get['cid']]; | ||
|  |         } | ||
|  | 
 | ||
|  |         $model = new CommunityTopic(); | ||
|  |         $lists = $model->with(['cate']) | ||
|  |             ->where($where) | ||
|  |             ->order(['sort' => 'asc', 'id' => 'desc']) | ||
|  |             ->paginate([ | ||
|  |                 'page' => $get['page'], | ||
|  |                 'list_rows' => $get['limit'], | ||
|  |                 'var_page' => 'page' | ||
|  |             ]) | ||
|  |             ->toArray(); | ||
|  | 
 | ||
|  |         foreach ($lists['data'] as &$item) { | ||
|  |             $item['cate_name'] = $item['cate']['name'] ?? ''; | ||
|  |         } | ||
|  | 
 | ||
|  | 
 | ||
|  |         return ['count' => $lists['total'], 'lists' => $lists['data']]; | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @notes 获取话题详情 | ||
|  |      * @param $id | ||
|  |      * @return array | ||
|  |      * @author 段誉 | ||
|  |      * @date 2022/4/28 10:11 | ||
|  |      */ | ||
|  |     public static function detail($id) | ||
|  |     { | ||
|  |         return CommunityTopic::findOrEmpty($id)->toArray(); | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @notes 添加话题 | ||
|  |      * @param $post | ||
|  |      * @return CommunityTopic|\think\Model | ||
|  |      * @author 段誉 | ||
|  |      * @date 2022/4/28 10:23 | ||
|  |      */ | ||
|  |     public static function add($post) | ||
|  |     { | ||
|  |         return CommunityTopic::create([ | ||
|  |             'name' => $post['name'], | ||
|  |             'image' => $post['image'], | ||
|  |             'cid' => $post['cid'], | ||
|  |             'is_show' => $post['is_show'], | ||
|  |             'is_recommend' => $post['is_recommend'], | ||
|  |             'sort' => $post['sort'] ?? 255, | ||
|  |             'create_time' => time() | ||
|  |         ]); | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @notes 编辑话题 | ||
|  |      * @param $post | ||
|  |      * @return CommunityTopic | ||
|  |      * @author 段誉 | ||
|  |      * @date 2022/4/28 10:24 | ||
|  |      */ | ||
|  |     public static function edit($post) | ||
|  |     { | ||
|  |         return CommunityTopic::update([ | ||
|  |             'name' => $post['name'], | ||
|  |             'image' => $post['image'], | ||
|  |             'cid' => $post['cid'], | ||
|  |             'is_show' => $post['is_show'], | ||
|  |             'is_recommend' => $post['is_recommend'], | ||
|  |             'sort' => $post['sort'] ?? 255, | ||
|  |             'update_time' => time() | ||
|  |         ], ['id' => $post['id']]); | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @notes 删除话题 | ||
|  |      * @param $id | ||
|  |      * @return bool | ||
|  |      * @author 段誉 | ||
|  |      * @date 2022/5/10 15:53 | ||
|  |      */ | ||
|  |     public static function del($id) | ||
|  |     { | ||
|  |         try { | ||
|  |             $check = CommunityArticle::where(['topic_id' => $id, 'del' => 0])->findOrEmpty(); | ||
|  |             if (!$check->isEmpty()) { | ||
|  |                 throw new \Exception('该话题下已关联文章,不可删除'); | ||
|  |             } | ||
|  | 
 | ||
|  |             CommunityTopic::where(['id' => $id])->update([ | ||
|  |                 'del' => 1, | ||
|  |                 'update_time' => time() | ||
|  |             ]); | ||
|  |             return true; | ||
|  |         } catch (\Exception $e) { | ||
|  |             self::$error = $e->getMessage(); | ||
|  |             return false; | ||
|  |         } | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @notes 设置显示状态 | ||
|  |      * @param $post | ||
|  |      * @author 段誉 | ||
|  |      * @date 2022/4/28 10:50 | ||
|  |      */ | ||
|  |     public static function setStatus($post) | ||
|  |     { | ||
|  |         CommunityTopic::update([ | ||
|  |             $post['field'] => $post['value'], | ||
|  |             'update_time' => time() | ||
|  |         ], ['id' => $post['id']]); | ||
|  |     } | ||
|  | } |