2019年10月12日
已更新支持 Laravel6.0 版本和 Laravel-admin1.7,同时简化了依赖
admin-config
基于laravel-admin的数据库配置管理工具,仅通过配置文件就可生成整个表单,支持使用tab页对配置项进行分组。
安装:
步骤一:使用composer:
composer require fourn/admin-config
步骤二:执行数据库迁移:
php artisan migrate
使用方法:
第一步:发布配置文件:
artisan vendor:publish --tag=admin-config
第二步:在配置文件中加入配置组及配置项,详细参考下面的"配置文件语法"
第三步:使用laravel中的config函数
// 获取一组
config('sample')
// 获取一项
config('sample.value')
其他:
你可以生成后台菜单:
php artisan admin:import admin-config
或者直接访问:
http://your-host/admin/admin-config
扩展配置:
'extensions' => [
'admin-config' => [
'title'=>'AdminConfig',
'description'=>'Manage your profiles as profiles',
'action'=>' ',
],
],
配置文件语法:
配置文件发布后路径为:config/admin-config.php
定义配置组:
'admin_config_groups' => [
// 配置组值 => tab选项卡显示文字
'sample' => 'sample-name',
// 省略写法,等同于 'sample2' => 'sample2'
'sample2'
],
定义配置项:
// 配置组名作为键,可以使用config('sample')访问一组值
'sample' => [
// 默认情况写法,以下等同于 'value' => ['label'=>'value', 'type'=>'test']
// 可以使用config('sample.value')访问其值
'value',
// 支持配置链式调用,以下将执行$form->text('value1')->help('help content')->default('default value')
'value1'=>['help'=>'help content', 'default'=>'default value'],
// 支持几乎所有Encore\Admin\Form\Field对象的链式调用方法,非链式调用的值将在Field实例化时作为参数传入
// 以下将执行$form->test('value2', 'label text')->placeholder('typing...')->rules('required')
'value2'=>['label text', 'placeholder'=>'typing...', 'rules'=>'required'],
// 需要定义字段类型,type键值不可省略
'value3'=>['type'=>'select', 'select label text', 'options'=>['option1'=>'option1', 'option2'=>'option2']],
'value5'=>['type'=>'checkbox', 'options'=>['foo'=>'foo', 'bar'=>'bar']],
'value6'=>['type'=>'ip'],
'value7'=>['type'=>'mobile'],
'value8'=>['type'=>'color'],
'value9'=>['type'=>'time', 'format'=>'HH:mm'],
// 范围类型的字段会分别存储为两个配置项,'sample.value10.start' 及 'sample.value10.end'
'value10'=>['type'=>'dateRange', 'dateRange label text'],
'value11'=>['type'=>'number', 'min'=>100, 'default'=>100],
'value12'=>['type'=>'rate'],
// 支持没有参数的链式调用,以下将执行$form->image('value13')->uniqueName()
'value13'=>['type'=>'image', 'uniqueName'],
'value14'=>['type'=>'file', 'uniqueName'],
'value17'=>['type'=>'editor'],
'value18'=>['type'=>'switch'],
'value19'=>['type'=>'tags'],
// 以下一对多关系将被自动转化为逗号隔开的数据存入数据库
'value4'=>['type'=>'listbox', 'options'=>['foo'=>'foo', 'bar'=>'bar']],
'value15'=>['type'=>'multipleImage', 'removable', 'uniqueName'],
'value16'=>['type'=>'multipleFile', 'removable', 'uniqueName'],
],
// 对应配置组值
'sample2' => [
'value'
]
效果示例:
配置文件自动转化为表单:
数据库: