feat: 新增导航相关接口

This commit is contained in:
2025-03-01 18:05:35 +08:00
parent d21a69d99d
commit b5dae966e6
10 changed files with 252 additions and 3 deletions

View File

@@ -0,0 +1,57 @@
<?php
declare (strict_types = 1);
namespace app\admin\controller\v1;
use app\admin\model\v1\SysNavigationItemModel;
use app\admin\model\v1\SysNavigationLinkTypeModel;
/**
* 导航管理控制器
*/
class Navigation
{
// 导航链接类型
public function linkType()
{
$types = SysNavigationLinkTypeModel::withoutField(['sort'])
->order(['sort' => 'asc', 'id' => 'asc'])
->select();
return success('获取成功', $types);
}
// 导航分页
public function index()
{
$param = request()->get([
'name',
'nav_id',
'created_at',
'page/d' => 1,
'size/d' => 10,
]);
$navigations = SysNavigationItemModel::withoutField([
'created_at',
'updated_at'
])
->with(['navigation' => function ($query) {
$query->field(['id', 'name' => 'nav_name']);
}])
->withSearch(['name', 'created_at'], [
'name' => $param['name']??null,
'created_at' => $param['created_at']??null
])
->navId($param['nav_id']??null)
->order(['sort' => 'asc', 'id' => 'asc'])
->paginate([
'page' => $param['page'],
'list_rows' => $param['size'],
])
->bindAttr('navigation', ['nav_name'])
->hidden(['nav_id', 'navigation']);
return success('获取成功', $navigations);
}
}

View File

@@ -0,0 +1,46 @@
<?php
declare (strict_types = 1);
namespace app\admin\model\v1;
use think\Model;
/**
* 导航数据模型
* @mixin \think\Model
*/
class SysNavigationItemModel extends Model
{
// 关联导航
public function navigation()
{
return $this->belongsTo(SysNavigationModel::class, 'nav_id', 'id');
}
// 名称搜索
public function searchNameAttr($query, $value, $data)
{
if (empty($value)) return;
$query->where('name', 'like', "%{$value}%");
}
// 新增时间搜索
public function searchCreatedAtAttr($query, $value, $data)
{
if (empty($value)) return;
if (is_array($value)) {
if (count($value) > 1) {
$query->whereBetweenTime('created_at', $value[0], $value[1]);
} else {
$query->whereTime('created_at', '>=', $value[0]);
}
}
}
// 导航查询
public function scopeNavId($query, $value)
{
if (empty($value)) return;
$query->where('nav_id', '=', $value);
}
}

View File

@@ -0,0 +1,15 @@
<?php
declare (strict_types = 1);
namespace app\admin\model\v1;
use app\common\model\SysNavigationLinkTypeBaseModel;
/**
* 导航链接类型模型
* @mixin \think\Model
*/
class SysNavigationLinkTypeModel extends SysNavigationLinkTypeBaseModel
{
//
}

View File

@@ -0,0 +1,15 @@
<?php
declare (strict_types = 1);
namespace app\admin\model\v1;
use app\common\model\SysNavigationBaseModel;
/**
* 导航模型
* @mixin \think\Model
*/
class SysNavigationModel extends SysNavigationBaseModel
{
//
}

View File

@@ -406,6 +406,15 @@ Route::group('v1', function () {
// 菜单删除
Route::delete('delete/:id', 'Menu/delete');
});
// 导航管理
Route::group('navigation', function() {
// 导航数据类型
Route::get('link/type', 'Navigation/linkType');
// 导航分页
Route::get('index', 'Navigation/index');
});
})->prefix('v1.');
Route::miss(function() {

View File

@@ -0,0 +1,15 @@
<?php
declare (strict_types = 1);
namespace app\common\model;
/**
* 导航模型
* @mixin \think\Model
*/
class SysNavigationBaseModel extends BaseModel
{
// 表名
protected $name = 'sys_navigation';
}

View File

@@ -0,0 +1,35 @@
<?php
declare (strict_types = 1);
namespace app\common\model;
use think\Model;
/**
* 导航数据模型
* @mixin \think\Model
*/
class SysNavigationItemBaseModel extends Model
{
// 表名
protected $name = 'sys_navigation_item';
// 主键
protected $pk = 'id';
// 字段信息
protected $schema = [
'id' => 'int',
'nav_id' => 'int',
'pid' => 'int',
'name' => 'string',
'icon' => 'string',
'link_type' => 'int',
'link' => 'string',
'sort' => 'int',
'blank' => 'int',
'status' => 'int',
'created_at' => 'datetime',
'updated_at' => 'datetime',
];
}

View File

@@ -0,0 +1,24 @@
<?php
declare (strict_types = 1);
namespace app\common\model;
/**
* 导航链接类型模型
* @mixin \think\Model
*/
class SysNavigationLinkTypeBaseModel extends BaseModel
{
// 表名
protected $name = 'sys_navigation_link_type';
// 主键
protected $pk = 'id';
// 字段信息
protected $schema = [
'id' => 'int',
'type_name' => 'string',
'sort' => 'int'
];
}

View File

@@ -29,9 +29,7 @@ class CreateSysNavigation extends Migrator
{
$table = $this->table('sys_navigation', ['engine' => 'InnoDB', 'comment' => '系统导航表']);
$table->addColumn('language_id', 'integer', ['null' => false, 'comment' => '语言ID'])
->addColumn('at_platform', 'string', ['limit' => 8, 'null' => false, 'comment' => '所在平台: pc为电脑, mobile为手机'])
->addColumn('at_page', 'string', ['limit' => 64, 'null' => false, 'comment' => '导航所在页面标识'])
->addColumn('at_position', 'string', ['limit' => 64, 'null' => false, 'comment' => '导航所在页面位置: top为顶部导航, footer为底部导航'])
->addColumn('at_page', 'string', ['limit' => 64, 'null' => true, 'comment' => '导航所在页面路径'])
->addColumn('unique_label', 'string', ['limit' => 64, 'null' => false, 'comment' => '导航唯一标识'])
->addColumn('name', 'string', ['limit' => 64, 'null' => false, 'comment' => '导航名称'])
->addColumn('desc', 'string', ['limit' => 255, 'null' => true, 'default' => null, 'comment' => '导航描述'])

View File

@@ -0,0 +1,35 @@
<?php
use think\migration\Migrator;
class SysNavigationLinkType extends Migrator
{
/**
* Change Method.
*
* Write your reversible migrations using this method.
*
* More information on writing migrations is available here:
* http://docs.phinx.org/en/latest/migrations.html#the-abstractmigration-class
*
* The following commands can be used in this method and Phinx will
* automatically reverse them when rolling back:
*
* createTable
* renameTable
* addColumn
* renameColumn
* addIndex
* addForeignKey
*
* Remember to call "create()" or "update()" and NOT "save()" when working
* with the Table class.
*/
public function change()
{
$table = $this->table('sys_navigation_link_type', ['engine' => 'InnoDB', 'comment' => '系统导航链接类型']);
$table->addColumn('type_name', 'string', ['limit' => 64, 'null' => false, 'comment' => '类型名称'])
->addColumn('sort', 'integer', ['limit' => 11, 'null' => false, 'default' => 0, 'comment' => '排序'])
->create();
}
}