refactor: 修改后台文章分类相关接口

This commit is contained in:
2025-04-10 17:42:46 +08:00
parent d27ddb4a99
commit 4f411d9e77
2 changed files with 61 additions and 22 deletions

View File

@@ -20,6 +20,7 @@ class ArticleCategory
]); ]);
$categorys = ArticleCategoryModel::field([ $categorys = ArticleCategoryModel::field([
'id', 'id',
'pid',
'name' 'name'
]) ])
->language(request()->lang_id) ->language(request()->lang_id)
@@ -31,16 +32,14 @@ class ArticleCategory
}) })
->order('sort', 'asc') ->order('sort', 'asc')
->select(); ->select();
return success('获取成功', $categorys); return success('获取成功', array_to_tree($categorys, 0, 'pid', 1, false));
} }
// 分类分页列表 // 分类分页列表
public function index() public function index()
{ {
$param = request()->param([ $param = request()->param([
'name', 'name'
'page/d' => 1,
'limit/d' => 10,
]); ]);
$category = ArticleCategoryModel::withoutField([ $category = ArticleCategoryModel::withoutField([
@@ -54,12 +53,9 @@ class ArticleCategory
} }
}) })
->order('sort', 'asc') ->order('sort', 'asc')
->paginate([ ->select();
'page' => $param['page'],
'list_rows' => $param['limit']
]);
return success('获取成功', $category); return success('获取成功', array_to_tree($category, 0, 'pid', 1, false));
} }
// 分类详情 // 分类详情
@@ -80,13 +76,14 @@ class ArticleCategory
{ {
$post = request()->post([ $post = request()->post([
'name', 'name',
'pid',
'sort' => 0, 'sort' => 0,
'is_show' => 1 'is_show' => 1
]); ]);
$data = array_merge($post, ['language_id' => request()->lang_id]); $data = array_merge($post, ['language_id' => request()->lang_id]);
$valiate = new ArticleCategoryValidate; $valiate = new ArticleCategoryValidate;
if (!$valiate->check($data)) { if (!$valiate->scene('add')->check($data)) {
return error($valiate->getError()); return error($valiate->getError());
} }
@@ -103,6 +100,7 @@ class ArticleCategory
$id = request()->param('id'); $id = request()->param('id');
$put = request()->put([ $put = request()->put([
'name', 'name',
'pid',
'sort', 'sort',
'is_show' 'is_show'
]); ]);

View File

@@ -3,6 +3,8 @@ declare (strict_types = 1);
namespace app\admin\validate\v1; namespace app\admin\validate\v1;
use app\admin\model\v1\ArticleModel;
use think\facade\Db;
use think\Validate; use think\Validate;
class ArticleCategoryValidate extends Validate class ArticleCategoryValidate extends Validate
@@ -14,8 +16,10 @@ class ArticleCategoryValidate extends Validate
* @var array * @var array
*/ */
protected $rule = [ protected $rule = [
'id' => 'require|integer',
'language_id' => 'require|integer', 'language_id' => 'require|integer',
'name' => 'require|unique:article_category,name^language_id|max:64', 'name' => 'require|unique:article_category,name^language_id|max:64',
'pid' => 'integer"different:id|checkPidNotBeChildren', // 验证pid
'sort' => 'require|integer', 'sort' => 'require|integer',
'is_show' => 'require|in:0,1', 'is_show' => 'require|in:0,1',
'seo_title' => 'max:255', 'seo_title' => 'max:255',
@@ -30,11 +34,16 @@ class ArticleCategoryValidate extends Validate
* @var array * @var array
*/ */
protected $message = [ protected $message = [
'id.require' => '分类ID不能为空',
'id.integer' => '分类ID必须为整数',
'language_id.require' => '语言ID不能为空', 'language_id.require' => '语言ID不能为空',
'language_id.integer' => '语言ID必须为整数', 'language_id.integer' => '语言ID必须为整数',
'name.require' => '分类名称不能为空', 'name.require' => '分类名称不能为空',
'name.unique' => '分类名称已存在', 'name.unique' => '分类名称已存在',
'name.max' => '分类名称最多64个字符', 'name.max' => '分类名称最多64个字符',
'pid.integer' => '父级分类ID必须为整数',
'pid.different' => '父级分类ID不能为自身',
'pid.checkPidNotBeChildren' => '父级分类不能为子分类',
'sort.require' => '排序不能为空', 'sort.require' => '排序不能为空',
'sort.integer' => '排序必须为整数', 'sort.integer' => '排序必须为整数',
'is_show.require' => '是否显示不能为空', 'is_show.require' => '是否显示不能为空',
@@ -43,4 +52,36 @@ class ArticleCategoryValidate extends Validate
'seo_keywords.max' => 'SEO关键词最多255个字符', 'seo_keywords.max' => 'SEO关键词最多255个字符',
'seo_desc.max' => 'SEO描述最多255个字符', 'seo_desc.max' => 'SEO描述最多255个字符',
]; ];
// 验证pid
protected function checkPidNotBeChildren($value, $rule, $data = [])
{
if ($value == 0) {
return true;
}
$table_name = (new ArticleModel)->getTable();
$children = Db::query(
preg_replace(
'/\s+/u',
' ',
"WITH RECURSIVE article_tree_by AS (
SELECT a.id, a.pid FROM $table_name a WHERE a.id = {$data['id']}
UNION ALL
SELECT k.id, k.pid FROM $table_name k INNER JOIN article_tree_by t ON t.id = k.pid
)
SELECT id FROM article_tree_by WHERE id <> {$data['id']};"
)
);
if (!empty($children) && in_array($data['pid'], array_column($children, 'id'))) {
return false;
}
return true;
}
// 新增分类验证场景
protected function sceneAdd()
{
$this->remove('id', 'require|integer')->remove('pid', 'different|checkPidNotBeChildren');
}
} }