refactor: 修改附件分类支持上下级

This commit is contained in:
2025-04-14 18:11:41 +08:00
parent e6e5f260fb
commit 941e103258
3 changed files with 80 additions and 32 deletions

View File

@@ -11,20 +11,48 @@ use app\admin\validate\v1\AttachmentCategoryValidate;
*/ */
class AttachmentCategory class AttachmentCategory
{ {
/**
* 列表树形结构
*/
public function tree()
{
$params = request()->param([
'name',
'is_show'
]);
$categorys = AttachmentCategoryModel::field([
'id',
'pid',
'name'
])
->withSearch(['name'], [
'name' => $params['name']??null
])
->where(function($query) use($params) {
if (isset($params['is_show'])) {
$query->where('is_show', '=', $params['is_show']);
}
})
->language(request()->lang_id)
->order(['sort' => 'asc', 'id' => 'desc'])
->select();
return success('获取成功', array_to_tree($categorys->toArray(), 0, 'pid', 1, false));
}
/** /**
* 分页数据 * 分页数据
*/ */
public function index() public function index()
{ {
$params = request()->param([ $params = request()->param([
'name', 'name'
'is_show',
'page/d' => 1,
'size/d' => 10
]); ]);
$categorys = AttachmentCategoryModel::field([ $categorys = AttachmentCategoryModel::field([
'id', 'id',
'pid',
'name', 'name',
'sort', 'sort',
'is_show' 'is_show'
@@ -33,23 +61,10 @@ class AttachmentCategory
'name' => $params['name']??null 'name' => $params['name']??null
]) ])
->language(request()->lang_id) ->language(request()->lang_id)
->order(['sort' => 'asc', 'id' => 'desc']); ->order(['sort' => 'asc', 'id' => 'desc'])
if (!request()->has('scene')) { ->select();
$categorys = $categorys->paginate([
'list_rows' => $params['size'],
'page' => $params['page']
]);
} else if ('all' == request()->param('scene')) {
$categorys = $categorys->where(function($query) use($params) {
if (isset($params['is_show'])) {
$query->where('is_show', '=', $params['is_show']);
}
})
->select()
->hidden(['sort', 'is_show']);
}
return success('获取成功', $categorys); return success('获取成功', array_to_tree($categorys->toArray(), 0, 'pid', 1, false));
} }
/** /**
@@ -80,6 +95,7 @@ class AttachmentCategory
public function save() public function save()
{ {
$post = request()->post([ $post = request()->post([
'pid' => 0,
'name', 'name',
'sort', 'sort',
'is_show' 'is_show'
@@ -105,6 +121,7 @@ class AttachmentCategory
{ {
$id = request()->param('id'); $id = request()->param('id');
$put = request()->put([ $put = request()->put([
'pid' => 0,
'name', 'name',
'sort', 'sort',
'is_show' 'is_show'

View File

@@ -373,12 +373,12 @@ Route::group('v1', function () {
// 附件(下载管理)删除 // 附件(下载管理)删除
Route::delete('delete/:id', 'Attachment/delete'); Route::delete('delete/:id', 'Attachment/delete');
// 附件(下载管理)分类列表 // 附件(下载管理)分类列表
Route::get('categorys', 'AttachmentCategory/index')->append(['scene' => 'all']); Route::get('tree', 'AttachmentCategory/tree');
// 附件(下载管理)分类 // 附件(下载管理)分类
Route::group('category', function () { Route::group('category', function () {
// 附件(下载管理)分类分页 // 附件(下载管理)分类
Route::get('index', 'AttachmentCategory/index'); Route::get('index', 'AttachmentCategory/index');
// 附件(下载管理)分类详情 // 附件(下载管理)分类详情

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\AttachmentCategoryModel;
use think\facade\Db;
use think\Validate; use think\Validate;
class AttachmentCategoryValidate extends Validate class AttachmentCategoryValidate extends Validate
@@ -15,6 +17,7 @@ class AttachmentCategoryValidate extends Validate
*/ */
protected $rule = [ protected $rule = [
'id' => 'require|integer', 'id' => 'require|integer',
'pid' => 'integer|checkPidNotBeChildren',
'language_id' => 'require|integer', 'language_id' => 'require|integer',
'name' => 'require|max:64', 'name' => 'require|max:64',
'sort' => 'integer', 'sort' => 'integer',
@@ -28,22 +31,50 @@ class AttachmentCategoryValidate extends Validate
* @var array * @var array
*/ */
protected $message = [ protected $message = [
'id.require' => 'ID不能为空', 'id.require' => 'ID不能为空',
'id.integer' => 'ID必须是整数', 'id.integer' => 'ID必须是整数',
'language_id.require' => '语言ID不能为空', 'pid.integer' => '父级ID必须是整数',
'language_id.integer' => '语言ID必须是整数', 'pid.checkPidNotBeChildren' => '父级分类不能为自身或自身的子分类',
'name.require' => '名称不能为空', 'language_id.require' => '语言ID不能为空',
'name.max' => '名称不能超过64个字符', 'language_id.integer' => '语言ID必须是整数',
'sort.integer' => '排序必须是整数', 'name.require' => '名称不能为空',
'is_show.in' => '是否显示必须是0或1', 'name.max' => '名称不能超过64个字符',
'sort.integer' => '排序必须是整数',
'is_show.in' => '是否显示必须是0或1',
]; ];
// 验证pid
protected function checkPidNotBeChildren($value, $rule, $data = [])
{
if ($value == 0) {
return true;
}
$table_name = (new AttachmentCategoryModel)->getTable();
$children = Db::query(
preg_replace(
'/\s+/u',
' ',
"WITH RECURSIVE attachment_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 attachement_tree_by t ON t.id = k.pid
)
SELECT id FROM attachment_tree_by WHERE id <> {$data['id']};"
)
);
if (!empty($children) && in_array($data['pid'], array_column($children, 'id'))) {
return false;
}
return true;
}
/** /**
* 新增场景 * 新增场景
*/ */
public function sceneCreate() public function sceneCreate()
{ {
return $this->remove('id', 'require|integer'); return $this->remove('id', 'require|integer')->remove('pid', 'checkPidNotBeChildren');
} }
/** /**