203 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			203 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
 | 
						|
namespace app\admin\logic\community;
 | 
						|
 | 
						|
 | 
						|
use app\common\basics\Logic;
 | 
						|
use app\common\enum\CommunityLikeEnum;
 | 
						|
use app\common\model\community\CommunityArticle;
 | 
						|
use app\common\model\community\CommunityComment;
 | 
						|
use app\common\model\community\CommunityLike;
 | 
						|
use app\common\model\community\CommunityTopic;
 | 
						|
use app\common\logic\CommunityArticleLogic as CommonArticleLogic;
 | 
						|
use app\common\server\UrlServer;
 | 
						|
use think\Exception;
 | 
						|
use think\facade\Db;
 | 
						|
 | 
						|
 | 
						|
/**
 | 
						|
 * 种草社区文章逻辑
 | 
						|
 * Class CommunityArticleLogic
 | 
						|
 * @package app\admin\logic\community
 | 
						|
 */
 | 
						|
class CommunityArticleLogic extends Logic
 | 
						|
{
 | 
						|
 | 
						|
    /**
 | 
						|
     * @notes 文章列表
 | 
						|
     * @param $get
 | 
						|
     * @return array
 | 
						|
     * @author 段誉
 | 
						|
     * @date 2022/5/10 11:07
 | 
						|
     */
 | 
						|
    public static function lists($get)
 | 
						|
    {
 | 
						|
        $where = [
 | 
						|
            ['a.del', '=', 0]
 | 
						|
        ];
 | 
						|
 | 
						|
        if (!empty($get['keyword'])) {
 | 
						|
            $where[] = ['u.sn|u.nickname|u.mobile', 'like', '%' . $get['keyword'] . '%'];
 | 
						|
        }
 | 
						|
 | 
						|
        if (!empty($get['content'])) {
 | 
						|
            $where[] = ['a.content', 'like', '%' . $get['content'] . '%'];
 | 
						|
        }
 | 
						|
 | 
						|
        if (isset($get['status']) && $get['status'] != '') {
 | 
						|
            $where[] = ['a.status', '=', $get['status']];
 | 
						|
        }
 | 
						|
 | 
						|
        if (isset($get['start_time']) && $get['start_time'] != '') {
 | 
						|
            $where[] = ['a.audit_time', '>=', strtotime($get['start_time'])];
 | 
						|
        }
 | 
						|
 | 
						|
        if (isset($get['end_time']) && $get['end_time'] != '') {
 | 
						|
            $where[] = ['a.audit_time', '<=', strtotime($get['end_time'])];
 | 
						|
        }
 | 
						|
 | 
						|
        $model = new CommunityArticle();
 | 
						|
        $lists = $model->with(['images'])->alias('a')
 | 
						|
            ->field('a.*,u.nickname,u.avatar,u.sn')
 | 
						|
            ->join('user u', 'u.id = a.user_id')
 | 
						|
            ->where($where)
 | 
						|
            ->order(['id' => 'desc'])
 | 
						|
            ->append(['status_desc'])
 | 
						|
            ->paginate([
 | 
						|
                'page' => $get['page'],
 | 
						|
                'list_rows' => $get['limit'],
 | 
						|
                'var_page' => 'page'
 | 
						|
            ])
 | 
						|
            ->toArray();
 | 
						|
 | 
						|
        foreach ($lists['data'] as &$item) {
 | 
						|
            $item['avatar'] = !empty($item['avatar']) ? UrlServer::getFileUrl($item['avatar']) : '';
 | 
						|
        }
 | 
						|
 | 
						|
        return ['count' => $lists['total'], 'lists' => $lists['data']];
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * @notes 文章详情
 | 
						|
     * @param $id
 | 
						|
     * @return array
 | 
						|
     * @author 段誉
 | 
						|
     * @date 2022/5/10 16:53
 | 
						|
     */
 | 
						|
    public static function detail($id)
 | 
						|
    {
 | 
						|
        $detail = CommunityArticle::with(['images', 'topic', 'user' => function ($query) {
 | 
						|
            $query->field(['id', 'nickname', 'sn']);
 | 
						|
        }])
 | 
						|
            ->append(['shop_data', 'goods_data', 'status_desc'])
 | 
						|
            ->findOrEmpty($id);
 | 
						|
 | 
						|
        $detail['cate_name'] = $detail['topic']['cate']['name'] ?? '';
 | 
						|
        $detail['audit_time'] = date('Y-m-d H:i:s', $detail['audit_time']);
 | 
						|
        return $detail->toArray();
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * @notes 删除文章
 | 
						|
     * @param $id
 | 
						|
     * @return bool
 | 
						|
     * @author 段誉
 | 
						|
     * @date 2022/5/10 16:34
 | 
						|
     */
 | 
						|
    public static function del($id)
 | 
						|
    {
 | 
						|
        Db::startTrans();
 | 
						|
        try {
 | 
						|
            $article = CommunityArticle::find($id);
 | 
						|
            $article->del = 1;
 | 
						|
            $article->update_time = time();
 | 
						|
            $article->save();
 | 
						|
 | 
						|
            if (!empty($article['topic_id'])) {
 | 
						|
                CommunityTopic::decArticleNum($article['topic_id']);
 | 
						|
            }
 | 
						|
 | 
						|
            Db::commit();
 | 
						|
            return true;
 | 
						|
 | 
						|
        } catch (Exception $e) {
 | 
						|
            Db::rollback();
 | 
						|
            self::$error = $e->getMessage();
 | 
						|
            return false;
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * @notes 审核文章
 | 
						|
     * @param $post
 | 
						|
     * @return bool
 | 
						|
     * @author 段誉
 | 
						|
     * @date 2022/5/12 16:57
 | 
						|
     */
 | 
						|
    public static function audit($post)
 | 
						|
    {
 | 
						|
        Db::startTrans();
 | 
						|
        try {
 | 
						|
            $article = CommunityArticle::findOrEmpty($post['id']);
 | 
						|
            $article->status = $post['status'];
 | 
						|
            $article->audit_remark = $post['audit_remark'] ?? '';
 | 
						|
            $article->audit_time = time();
 | 
						|
            $article->save();
 | 
						|
 | 
						|
            // 通知粉丝有新文章发布
 | 
						|
            CommonArticleLogic::noticeFans($article['user_id'], $post['status']);
 | 
						|
 | 
						|
            Db::commit();
 | 
						|
            return true;
 | 
						|
        } catch (\Exception $e) {
 | 
						|
            Db::rollback();
 | 
						|
            self::$error = $e->getMessage();
 | 
						|
            return false;
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * @notes 文章关联评论及点赞
 | 
						|
     * @param $get
 | 
						|
     * @return array
 | 
						|
     * @throws \think\db\exception\DbException
 | 
						|
     * @author 段誉
 | 
						|
     * @date 2022/5/11 10:14
 | 
						|
     */
 | 
						|
    public static function getRelationData($get)
 | 
						|
    {
 | 
						|
        $type = $get['type'] ?? 'comment';
 | 
						|
        if ($type == 'comment') {
 | 
						|
            $lists = CommunityComment::with(['user'])
 | 
						|
                ->where([
 | 
						|
                    'del' => 0,
 | 
						|
                    'article_id' => $get['id'],
 | 
						|
                ])->paginate([
 | 
						|
                    'page' => $get['page'],
 | 
						|
                    'list_rows' => $get['limit'],
 | 
						|
                    'var_page' => 'page'
 | 
						|
                ])
 | 
						|
                ->toArray();
 | 
						|
        } else {
 | 
						|
            $lists = CommunityLike::with(['user'])
 | 
						|
                ->where([
 | 
						|
                    'relation_id' => $get['id'],
 | 
						|
                    'type' => CommunityLikeEnum::TYPE_ARTICLE
 | 
						|
                ])
 | 
						|
                ->paginate([
 | 
						|
                    'page' => $get['page'],
 | 
						|
                    'list_rows' => $get['limit'],
 | 
						|
                    'var_page' => 'page'
 | 
						|
                ])
 | 
						|
                ->toArray();
 | 
						|
        }
 | 
						|
        return ['count' => $lists['total'], 'lists' => $lists['data']];
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
} |