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']]);
|
||
|
}
|
||
|
}
|