feat: 添加站点配置/配置项分页/配置项详情/配置项新增/配置项更新/配置项删除接口/站点配置项
接口/站点配置项更新接口/配置项类型接口/配置项分组接口
This commit is contained in:
163
app/admin/controller/v1/SiteConfig.php
Normal file
163
app/admin/controller/v1/SiteConfig.php
Normal file
@@ -0,0 +1,163 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\admin\controller\v1;
|
||||
|
||||
use app\admin\model\v1\SysConfigGroupModel;
|
||||
use app\admin\model\v1\SysConfigModel;
|
||||
|
||||
/**
|
||||
* 站酷配置控制器
|
||||
*/
|
||||
class SiteConfig
|
||||
{
|
||||
// 获取配置项
|
||||
public function index()
|
||||
{
|
||||
// 按语言获取分组
|
||||
$groups = SysConfigGroupModel::field([
|
||||
'id',
|
||||
'name'
|
||||
])
|
||||
->language(request()->lang_id)
|
||||
->enabled()
|
||||
->order(['sort' => 'asc', 'id' => 'desc'])
|
||||
->select()
|
||||
->toArray();
|
||||
if (empty($groups)) {
|
||||
return error('配置分组不存在');
|
||||
}
|
||||
|
||||
// 根据分组获取配置项
|
||||
$configs = SysConfigModel::field([
|
||||
'id',
|
||||
'group_id',
|
||||
'title',
|
||||
'name',
|
||||
'value',
|
||||
'extra',
|
||||
'type',
|
||||
'remark'
|
||||
])
|
||||
->groupId(array_column($groups, 'id'))
|
||||
->order(['sort' => 'asc', 'id' => 'desc'])
|
||||
->select()
|
||||
->each(function($item) {
|
||||
// 修改字段为null的输出为空字符串
|
||||
$keys = array_keys($item->toArray());
|
||||
foreach ($keys as $key) {
|
||||
if (is_null($item[$key])) {
|
||||
$item[$key] = '';
|
||||
}
|
||||
}
|
||||
return $item;
|
||||
})
|
||||
->toArray();
|
||||
if (empty($configs)) {
|
||||
return error('配置项不存在');
|
||||
}
|
||||
|
||||
// 处理附加配置项及联动项
|
||||
$config_name_map = [];
|
||||
foreach ($configs as $config) {
|
||||
unset($config['group_id']);
|
||||
$config_name_map[$config['name']] = $config;
|
||||
}
|
||||
$configs = $this->handleExtra($configs, $config_name_map);
|
||||
|
||||
// 组合数据
|
||||
$config_group_map = [];
|
||||
foreach ($configs as $config) {
|
||||
$group_id = $config['group_id'];
|
||||
unset($config['group_id']);
|
||||
$config_group_map[$group_id][] = $config;
|
||||
}
|
||||
|
||||
// 组合分组和配置项
|
||||
foreach ($groups as &$group) {
|
||||
$group['configs'] = $config_group_map[$group['id']] ?? [];
|
||||
}
|
||||
unset($group);
|
||||
|
||||
return success('获取成功', $groups);
|
||||
}
|
||||
// 处理配置联动项数据
|
||||
private function handleExtra($data, $map)
|
||||
{
|
||||
$ret = [];
|
||||
$need_delete_names = [];
|
||||
foreach ($data as $val) {
|
||||
if (!empty($val['extra'])) {
|
||||
$extra = explode(PHP_EOL, $val['extra']);
|
||||
foreach ($extra as $v) {
|
||||
if (preg_match('/^([^:]+):(.+)\[(.+)\]$/i', $v, $match)) {
|
||||
$item = [
|
||||
'name' => $match[2],
|
||||
'value' => $match[1]
|
||||
];
|
||||
if (isset($match[3])) {
|
||||
$children = [];
|
||||
$names = explode(',', $match[3]);
|
||||
foreach ($names as $name) {
|
||||
$name = trim(trim($name), "'");
|
||||
$need_delete_names[] = $name;
|
||||
if (!empty($map[$name])) {
|
||||
$children[] = $map[$name];
|
||||
}
|
||||
}
|
||||
// 处理子级
|
||||
if (!empty($children)) {
|
||||
$item['children'] = $this->handleExtra($children, $map);
|
||||
}
|
||||
}
|
||||
unset($val['extra']);
|
||||
if (!isset($val['extras'])) {
|
||||
$val['extras'] = [];
|
||||
}
|
||||
$val['extras'][] = $item;
|
||||
}
|
||||
}
|
||||
}
|
||||
$ret[] = $val;
|
||||
}
|
||||
// 删除多余的配置项
|
||||
foreach ($ret as $k => $it) {
|
||||
if (in_array($it['name'], $need_delete_names)) {
|
||||
unset($ret[$k]);
|
||||
}
|
||||
}
|
||||
return $ret;
|
||||
}
|
||||
|
||||
// 更新配置
|
||||
public function update()
|
||||
{
|
||||
$put = request()->put();
|
||||
|
||||
if (empty($put)) {
|
||||
return error('参数错误');
|
||||
}
|
||||
|
||||
$validate = validate([
|
||||
'id' => 'require|integer',
|
||||
'value' => 'max:255'
|
||||
])
|
||||
->message([
|
||||
'id.require' => '配置项ID不能为空',
|
||||
'id.integer' => '配置项ID必须是整数',
|
||||
'value.max' => '配置值不能超过255个字符'
|
||||
]);
|
||||
foreach ($put as $val) {
|
||||
if (!$validate->check($val)) {
|
||||
return error($validate->getError());
|
||||
}
|
||||
}
|
||||
|
||||
$configs = (new SysConfigModel)->saveAll($put);
|
||||
if ($configs->isEmpty()) {
|
||||
return error('操作失败');
|
||||
}
|
||||
|
||||
return success('操作成功');
|
||||
}
|
||||
}
|
||||
173
app/admin/controller/v1/SysConfig.php
Normal file
173
app/admin/controller/v1/SysConfig.php
Normal file
@@ -0,0 +1,173 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\admin\controller\v1;
|
||||
|
||||
use app\admin\model\v1\SysConfigGroupModel;
|
||||
use app\admin\model\v1\SysConfigModel;
|
||||
use app\admin\model\v1\SysConfigTypeModel;
|
||||
use app\admin\validate\v1\SysConfigValidate;
|
||||
|
||||
/**
|
||||
* 配置项控制器
|
||||
*/
|
||||
class SysConfig
|
||||
{
|
||||
// 获取分组列表
|
||||
public function groups()
|
||||
{
|
||||
$groups = SysConfigGroupModel::field([
|
||||
'id',
|
||||
'name'
|
||||
])
|
||||
->language(request()->lang_id)
|
||||
->enabled()
|
||||
->order(['sort' => 'asc', 'id' => 'desc'])
|
||||
->select();
|
||||
|
||||
return success('获取成功', $groups);
|
||||
}
|
||||
|
||||
// 获取配置类型
|
||||
public function types()
|
||||
{
|
||||
$types = SysConfigTypeModel::field([
|
||||
'name',
|
||||
'value'
|
||||
])
|
||||
->order(['sort' => 'asc'])
|
||||
->select();
|
||||
|
||||
return success('获取成功', $types);
|
||||
}
|
||||
|
||||
// 配置项分页
|
||||
public function index()
|
||||
{
|
||||
$param = request()->param([
|
||||
'title',
|
||||
'page/d' => 1,
|
||||
'size/d' => 10
|
||||
]);
|
||||
|
||||
$configs = SysConfigModel::field([
|
||||
'id',
|
||||
'group_id',
|
||||
'title',
|
||||
'name',
|
||||
'type',
|
||||
'sort'
|
||||
])
|
||||
->with([
|
||||
'group' => function($query) {
|
||||
$query->field(['id', 'name' => 'group_name']);
|
||||
},
|
||||
'type' => function($query) {
|
||||
$query->field(['name' => 'type_name', 'value']);
|
||||
}
|
||||
])
|
||||
->withSearch(['title'], ['title' => $param['title']??null])
|
||||
->order(['sort' => 'asc', 'id' => 'desc'])
|
||||
->paginate([
|
||||
'list_rows' => $param['size'],
|
||||
'page' => $param['page']
|
||||
])
|
||||
->bindAttr('group', ['group_name'])
|
||||
->bindAttr('type', ['type_name'])
|
||||
->hidden(['group_id', 'group', 'type']);
|
||||
|
||||
return success('获取成功', $configs);
|
||||
}
|
||||
|
||||
// 配置项详情
|
||||
public function read()
|
||||
{
|
||||
$id = request()->param('id');
|
||||
|
||||
$config = SysConfigModel::withoutField([
|
||||
'created_at',
|
||||
'updated_at',
|
||||
'deleted_at'
|
||||
])
|
||||
->bypy($id)
|
||||
->find();
|
||||
if (empty($config)) {
|
||||
return error('配置项不存在');
|
||||
}
|
||||
|
||||
return success('获取成功', $config);
|
||||
}
|
||||
|
||||
// 配置项新增
|
||||
public function save()
|
||||
{
|
||||
$post = request()->post([
|
||||
'group_id',
|
||||
'title',
|
||||
'name',
|
||||
'value',
|
||||
'extra',
|
||||
'type' => 'text',
|
||||
'sort',
|
||||
'remark'
|
||||
]);
|
||||
|
||||
$validate = new SysConfigValidate;
|
||||
if (!$validate->scene('add')->check($post)) {
|
||||
return error($validate->getError());
|
||||
}
|
||||
|
||||
$config = SysConfigModel::create($post);
|
||||
if ($config->isEmpty()) {
|
||||
return error('操作失败');
|
||||
}
|
||||
return success('操作成功');
|
||||
}
|
||||
|
||||
// 配置项更新
|
||||
public function update()
|
||||
{
|
||||
$id = request()->param('id');
|
||||
$put = request()->put([
|
||||
'group_id',
|
||||
'title',
|
||||
'name',
|
||||
'value',
|
||||
'extra',
|
||||
'type' => 'text',
|
||||
'sort',
|
||||
'remark'
|
||||
]);
|
||||
|
||||
$validate = new SysConfigValidate;
|
||||
if (!$validate->check(array_merge($put, ['id' => $id]))) {
|
||||
return error($validate->getError());
|
||||
}
|
||||
|
||||
$config = SysConfigModel::bypk($id)->find();
|
||||
if (empty($config)) {
|
||||
return error('请确认要操作对象是否存在');
|
||||
}
|
||||
|
||||
if (!$config->save($put)) {
|
||||
return error('操作失败');
|
||||
}
|
||||
return success('操作成功');
|
||||
}
|
||||
|
||||
// 配置项删除
|
||||
public function delete()
|
||||
{
|
||||
$id = request()->param('id');
|
||||
|
||||
$config = SysConfigModel::bypk($id)->find();
|
||||
if (empty($config)) {
|
||||
return error('请确认要操作对象是否存在');
|
||||
}
|
||||
|
||||
if (!$config->delete()) {
|
||||
return error('操作失败');
|
||||
}
|
||||
return success('操作成功');
|
||||
}
|
||||
}
|
||||
31
app/admin/model/v1/SysConfigGroupModel.php
Normal file
31
app/admin/model/v1/SysConfigGroupModel.php
Normal file
@@ -0,0 +1,31 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\admin\model\v1;
|
||||
|
||||
use app\common\model\SysConfigGroupBaseModel;
|
||||
use think\model\concern\SoftDelete;
|
||||
|
||||
/**
|
||||
* 系统配置分组模型
|
||||
* @mixin \think\Model
|
||||
*/
|
||||
class SysConfigGroupModel extends SysConfigGroupBaseModel
|
||||
{
|
||||
// 启用软件删除
|
||||
use SoftDelete;
|
||||
// 软件删除字段
|
||||
protected $deleteTime = 'deleted_at';
|
||||
|
||||
// 按语言搜索
|
||||
public function scopeLanguage($query, $value)
|
||||
{
|
||||
$query->where('language_id', '=', $value);
|
||||
}
|
||||
|
||||
// 获取启用的配置分组
|
||||
public function scopeEnabled($query)
|
||||
{
|
||||
$query->where('status', '=', 1);
|
||||
}
|
||||
}
|
||||
50
app/admin/model/v1/SysConfigModel.php
Normal file
50
app/admin/model/v1/SysConfigModel.php
Normal file
@@ -0,0 +1,50 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\admin\model\v1;
|
||||
|
||||
use app\common\model\SysConfigBaseModel;
|
||||
use think\model\concern\SoftDelete;
|
||||
|
||||
/**
|
||||
* 系统配置模型
|
||||
* @mixin \think\Model
|
||||
*/
|
||||
class SysConfigModel extends SysConfigBaseModel
|
||||
{
|
||||
// 启用软件删除
|
||||
use SoftDelete;
|
||||
// 软件删除字段
|
||||
protected $deleteTime = 'deleted_at';
|
||||
|
||||
// 关联分组
|
||||
public function group()
|
||||
{
|
||||
return $this->belongsTo('SysConfigGroupModel', 'group_id', 'id');
|
||||
}
|
||||
|
||||
// 关联类型
|
||||
public function type()
|
||||
{
|
||||
return $this->belongsTo('SysConfigTypeModel', 'type', 'value');
|
||||
}
|
||||
|
||||
// 按title搜索
|
||||
public function searchTitleAttr($query, $value, $data)
|
||||
{
|
||||
if (empty($value)) {
|
||||
return;
|
||||
}
|
||||
$query->where('title', 'like', "%{$value}%");
|
||||
}
|
||||
|
||||
// 按group_id查询
|
||||
public function scopeGroupId($query, $value)
|
||||
{
|
||||
if (is_array($value)) {
|
||||
$query->where('group_id', 'in', $value);
|
||||
return;
|
||||
}
|
||||
$query->where('group_id', '=', $value);
|
||||
}
|
||||
}
|
||||
15
app/admin/model/v1/SysConfigTypeModel.php
Normal file
15
app/admin/model/v1/SysConfigTypeModel.php
Normal file
@@ -0,0 +1,15 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\admin\model\v1;
|
||||
|
||||
use app\common\model\SysConfigTypeBaseModel;
|
||||
|
||||
/**
|
||||
* 配置类型模型
|
||||
* @mixin \think\Model
|
||||
*/
|
||||
class SysConfigTypeModel extends SysConfigTypeBaseModel
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -453,6 +453,41 @@ Route::group('v1', function () {
|
||||
Route::delete('delete/:id', 'NavigationItem/delete');
|
||||
});
|
||||
});
|
||||
|
||||
// 配置项列表
|
||||
Route::group('config', function() {
|
||||
// 配置分组
|
||||
Route::get('groups', 'SysConfig/groups');
|
||||
|
||||
// 配置类型
|
||||
Route::get('types', 'SysConfig/types');
|
||||
|
||||
// 配置项分页
|
||||
Route::get('index', 'SysConfig/index');
|
||||
|
||||
// 配置项详情
|
||||
Route::get('read/:id', 'SysConfig/read');
|
||||
|
||||
// 配置项新增
|
||||
Route::post('save', 'SysConfig/save');
|
||||
|
||||
// 配置项更新
|
||||
Route::put('update/:id', 'SysConfig/update');
|
||||
|
||||
// 配置项删除
|
||||
Route::delete('delete/:id', 'SysConfig/delete');
|
||||
});
|
||||
|
||||
// 站点配置
|
||||
Route::group('site', function() {
|
||||
Route::group('config', function() {
|
||||
// 站点配置项
|
||||
Route::get('index', 'SiteConfig/index');
|
||||
|
||||
// 站点配置更新
|
||||
Route::put('update', 'SiteConfig/update');
|
||||
});
|
||||
});
|
||||
})->prefix('v1.');
|
||||
|
||||
Route::miss(function() {
|
||||
|
||||
56
app/admin/validate/v1/SysConfigValidate.php
Normal file
56
app/admin/validate/v1/SysConfigValidate.php
Normal file
@@ -0,0 +1,56 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\admin\validate\v1;
|
||||
|
||||
use think\Validate;
|
||||
|
||||
class SysConfigValidate extends Validate
|
||||
{
|
||||
/**
|
||||
* 定义验证规则
|
||||
* 格式:'字段名' => ['规则1','规则2'...]
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $rule = [
|
||||
'id' => 'require|integer',
|
||||
'group_id' => 'require|integer',
|
||||
'title' => 'require|max:64',
|
||||
'name' => 'require|unique:sys_config|max:64',
|
||||
'value' => 'max:255',
|
||||
'extra' => 'max:255',
|
||||
'type' => 'max:64',
|
||||
'sort' => 'integer',
|
||||
'remark' => 'max:255'
|
||||
];
|
||||
|
||||
/**
|
||||
* 定义错误信息
|
||||
* 格式:'字段名.规则名' => '错误信息'
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $message = [
|
||||
'id.require' => 'ID不能为空',
|
||||
'id.integer' => 'ID必须是整数',
|
||||
'group_id.require' => '分组ID不能为空',
|
||||
'group_id.integer' => '分组ID必须是整数',
|
||||
'title.require' => '标题不能为空',
|
||||
'title.max' => '标题最多不能超过64个字符',
|
||||
'name.require' => '标识不能为空',
|
||||
'name.unique' => '标识已存在',
|
||||
'name.max' => '名称最多不能超过64个字符',
|
||||
'value.max' => '值最多不能超过255个字符',
|
||||
'extra.max' => '额外信息最多不能超过255个字符',
|
||||
'type.max' => '类型最多不能超过64个字符',
|
||||
'sort.integer' => '排序必须是整数',
|
||||
'remark.max' => '备注最多不能超过255个字符',
|
||||
];
|
||||
|
||||
// 新增场景
|
||||
public function sceneAdd()
|
||||
{
|
||||
return $this->remove('id', 'require|integer');
|
||||
}
|
||||
}
|
||||
33
app/common/model/SysConfigBaseModel.php
Normal file
33
app/common/model/SysConfigBaseModel.php
Normal file
@@ -0,0 +1,33 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\common\model;
|
||||
|
||||
/**
|
||||
* 系统配置模型
|
||||
* @mixin \think\Model
|
||||
*/
|
||||
class SysConfigBaseModel extends BaseModel
|
||||
{
|
||||
// 表名
|
||||
protected $name = 'sys_config';
|
||||
|
||||
// 主键
|
||||
protected $pk = 'id';
|
||||
|
||||
// 字段信息
|
||||
protected $schema = [
|
||||
'id' => 'int',
|
||||
'group_id' => 'int',
|
||||
'title' => 'string',
|
||||
'name' => 'string',
|
||||
'value' => 'string',
|
||||
'extra' => 'string',
|
||||
'type' => 'string',
|
||||
'sort' => 'int',
|
||||
'remark' => 'string',
|
||||
'created_at' => 'datetime',
|
||||
'updated_at' => 'datetime',
|
||||
'deleted_at' => 'datetime',
|
||||
];
|
||||
}
|
||||
29
app/common/model/SysConfigGroupBaseModel.php
Normal file
29
app/common/model/SysConfigGroupBaseModel.php
Normal file
@@ -0,0 +1,29 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\common\model;
|
||||
|
||||
/**
|
||||
* 系统配置分组模型
|
||||
* @mixin \think\Model
|
||||
*/
|
||||
class SysConfigGroupBaseModel extends BaseModel
|
||||
{
|
||||
// 表名
|
||||
protected $name = 'sys_config_group';
|
||||
|
||||
// 主键
|
||||
protected $pk = 'id';
|
||||
|
||||
// 字段信息
|
||||
protected $schema = [
|
||||
'id' => 'int',
|
||||
'language_id' => 'int',
|
||||
'name' => 'string',
|
||||
'sort' => 'int',
|
||||
'status' => 'int',
|
||||
'created_at' => 'datetime',
|
||||
'updated_at' => 'datetime',
|
||||
'deleted_at' => 'datetime',
|
||||
];
|
||||
}
|
||||
24
app/common/model/SysConfigTypeBaseModel.php
Normal file
24
app/common/model/SysConfigTypeBaseModel.php
Normal file
@@ -0,0 +1,24 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
|
||||
namespace app\common\model;
|
||||
|
||||
use think\Model;
|
||||
|
||||
/**
|
||||
* 配置类型模型
|
||||
* @mixin \think\Model
|
||||
*/
|
||||
class SysConfigTypeBaseModel extends Model
|
||||
{
|
||||
// 表名
|
||||
protected $name = 'sys_config_type';
|
||||
|
||||
// 字段信息
|
||||
protected $schema = [
|
||||
'name' => 'string',
|
||||
'value' => 'string',
|
||||
'sort' => 'int',
|
||||
'remark' => 'string'
|
||||
];
|
||||
}
|
||||
@@ -31,13 +31,14 @@ class CreateSysConfig extends Migrator
|
||||
$table->addColumn('group_id', 'integer', ['limit' => 11, 'null' => false, 'comment' => '分组ID'])
|
||||
->addColumn('title', 'string', ['limit' => 64, 'null' => false, 'comment' => '配置标题'])
|
||||
->addColumn('name', 'string', ['limit' => 64, 'null' => false, 'comment' => '配置名称'])
|
||||
->addColumn('value', 'string', ['limit' => 255, 'null' => false, 'comment' => '配置值'])
|
||||
->addColumn('value', 'string', ['limit' => 255, 'null' => true, 'default' => null, 'comment' => '配置值'])
|
||||
->addColumn('extra', 'string', ['limit' => 255, 'null' => true, 'default' => null, 'comment' => '配置额外信息'])
|
||||
->addColumn('type', 'string', ['limit' => 64, 'null' => false, 'comment' => '配置类型: text, textarea, number, select, checkbox, radio, date, time, datetime'])
|
||||
->addColumn('sort', 'integer', ['limit' => 11, 'null' => false, 'default' => 0, 'comment' => '排序'])
|
||||
->addColumn('remark', 'string', ['limit' => 255, 'null' => true, 'default' => null, 'comment' => '备注'])
|
||||
->addColumn('created_at', 'timestamp', ['null' => false, 'default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addColumn('updated_at', 'timestamp', ['null' => false, 'default' => 'CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP', 'comment' => '更新时间'])
|
||||
->addIndex(['name'], ['unique' => true, 'name' => 'unique_idx_name'])
|
||||
->create();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
class CreateSysConfigType 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_config_type', ['id' => false, 'engine' => 'InnoDB', 'comment' => '系统配置类型表']);
|
||||
$table->addColumn('name', 'string', ['limit' => 64, 'null' => false, 'comment' => '类型名'])
|
||||
->addColumn('value', 'string', ['limit' => 255, 'null' => true, 'default' => null, 'comment' => '类型值'])
|
||||
->addColumn('sort', 'integer', ['limit' => 11, 'null' => false, 'default' => 0, 'comment' => '排序'])
|
||||
->addColumn('remark', 'string', ['limit' => 255, 'null' => true, 'default' => null, 'comment' => '备注'])
|
||||
->create();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user