更新目录结构

This commit is contained in:
molong
2022-04-29 20:26:03 +08:00
parent 4ef43e0258
commit ca1fbd6fd1
89 changed files with 529 additions and 381 deletions

View File

@@ -0,0 +1,17 @@
<?php
// +----------------------------------------------------------------------
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.tensent.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
// +----------------------------------------------------------------------
namespace app\model\form;
/**
* 自定义表单模型
*/
class DiyFormModel {
protected $attrDb = 'FormAttr';
}

111
app/model/form/Form.php Normal file
View File

@@ -0,0 +1,111 @@
<?php
// +----------------------------------------------------------------------
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.tensent.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
// +----------------------------------------------------------------------
namespace app\model\form;
use think\facade\Config;
/**
* 表单
*/
class Form extends \think\Model {
protected $auto = ['update_time'];
protected $insert = ['name', 'create_time', 'status' => 1, 'list_grid' => "id:ID\r\ntitle:标题\r\ncreate_time:添加时间|time_format\r\nupdate_time:更新时间|time_format"];
protected $type = [
'id' => 'integer'
];
public $addField = [
['name' => 'name', 'title' => '标识', 'type' => 'text', 'is_must'=> true, 'help' => ''],
['name' => 'title', 'title' => '标题', 'type' => 'text', 'is_must'=> true, 'help' => ''],
['name' => 'logo', 'title' => '显示Logo', 'type' => 'image', 'help' => ''],
['name' => 'cover', 'title' => 'banner图片', 'type' => 'image', 'help' => ''],
['name' => 'content', 'title' => '内容', 'type' => 'editor', 'help' => ''],
['name' => 'list_grid', 'title' => '列表定义', 'type' => 'textarea', 'is_must'=> true, 'help' => ''],
];
public $editField = [
['name' => 'id', 'title' => 'ID', 'type' => 'hidden', 'help' => ''],
// ['name' => 'name', 'title' => '标识', 'type' => 'text', 'help' => ''],
['name' => 'title', 'title' => '标题', 'type' => 'text', 'help' => ''],
['name' => 'logo', 'title' => '显示Logo', 'type' => 'image', 'help' => ''],
['name' => 'cover', 'title' => 'banner图片', 'type' => 'image', 'help' => ''],
['name' => 'content', 'title' => '内容', 'type' => 'editor', 'help' => ''],
['name' => 'list_grid', 'title' => '列表定义', 'type' => 'textarea', 'help' => ''],
];
protected static function onBeforeInsert($data){
if ($data['name'] && $data['title']) {
$db = new \com\Datatable();
//检查表是否存在并创建
if (!$db->CheckTable('form_' . $data['name'])) {
//创建新表
return $db->initTable('form_' . $data['name'], $data['title'], 'id')->query();
}else{
return false;
}
}else{
return false;
}
}
public static function onAfterInsert($data){
$data = $data->toArray();
$fields = [
'uid' => ['name' => 'uid', 'title' => '用户UID', 'type' => 'num', 'length' => 11, 'extra' => '', 'remark' => '用户UID', 'is_show' => 0, 'is_must' => 1, 'value'=>'0'],
'status' => ['name' => 'status', 'title' => '数据状态', 'type' => 'select', 'length' => 2, 'extra' => "0:禁用\r\n1:正常", 'remark' => '数据状态', 'is_show' => 1, 'is_must' => 1, 'value'=>'1'],
'update_time' => ['name' => 'update_time', 'title' => '更新时间', 'type' => 'datetime', 'length' => 11, 'extra' => '', 'remark' => '更新时间', 'is_show' => 0, 'is_must' => 1, 'value'=>'0'],
'create_time' => ['name' => 'create_time', 'title' => '添加时间', 'type' => 'datetime', 'length' => 11, 'extra' => '', 'remark' => '添加时间', 'is_show' => 0, 'is_must' => 1, 'value'=>'0'],
];
$result = false;
if (!empty($fields)) {
foreach ($fields as $key => $value) {
$fields[$key]['form_id'] = $data['id'];
}
$result = (new FormAttr())->saveAll($fields);
}
return $result;
}
protected static function onAfterDelete($data){
$data = $data->toArray();
(new FormAttr())->where('form_id', $data['id'])->delete();
$db = new \com\Datatable();
$result = false;
if ($db->CheckTable('form_' . $data['name'])) {
$result = $db->delTable('form_' . $data['name'])->query();
}
return $result;
}
public function getGridListAttr($value, $data){
$list = [];
if ($data['list_grid'] !== '') {
$row = explode(PHP_EOL, $data['list_grid']);
foreach ($row as $r) {
list($field, $title) = explode(":", $r);
$list[$field] = ['field' => $field, 'title' => $title];
if (strrpos($title, "|")) {
$title = explode("|", $title);
$list[$field] = ['field' => $field, 'title' => $title[0], 'format' => trim($title[1])];
}
}
}
return $list;
}
public function getStatusTextAttr($value, $data) {
$status = array(
0 => '禁用',
1 => '启用',
);
return $status[$data['status']];
}
}

134
app/model/form/FormAttr.php Normal file
View File

@@ -0,0 +1,134 @@
<?php
// +----------------------------------------------------------------------
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.tensent.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
// +----------------------------------------------------------------------
namespace app\model\form;
use think\facade\Cache;
use think\facade\Config;
/**
* 设置模型
*/
class FormAttr extends \think\Model{
protected $type = array(
'id' => 'integer',
);
/**
* @title 新增后事件
*/
protected static function onAfterInsert($data){
$data = $data->toArray();
if ($data['form_id']) {
$db = new \com\Datatable();
$name = Form::where('id', $data['form_id'])->value('name');
$data['after'] = self::where('name', '<>', $data['name'])->where('form_id', $data['form_id'])->order('sort asc, id desc')->value('name');
return $db->columField('form_' . strtolower($name), $data)->query();
}
}
/**
* @title 更新后事件
*/
protected static function onAfterUpdate($data){
$data = $data->toArray();
if (isset($data['form_id']) && isset($data['name'])) {
$tablename = Form::where('id', $data['form_id'])->value('name');
//删除模型表中字段
$db = new \com\Datatable();
if ($db->CheckField(strtolower('form_' . $tablename), $data['name'])) {
$data['action'] = 'CHANGE';
}
$data['after'] = self::where('name', '<>', $data['name'])->where('form_id', $data['form_id'])->order('sort asc, id asc')->value('name');
$result = $db->columField(strtolower('form_' . $tablename), $data)->query();
return $result;
}else{
return false;
}
}
/**
* @title 删除后事件
*/
protected static function onAfterDelete($data){
$data = $data->toArray();
if ($data['form_id']) {
$tablename = Form::where('id', $data['form_id'])->value('name');
//删除模型表中字段
$db = new \com\Datatable();
if (!$db->CheckField('form_' . $tablename, $data['name'])) {
$result = true;
}else{
$result = $db->delField('form_' . $tablename, $data['name'])->query();
}
return $result;
}else{
return false;
}
}
protected function getTypeTextAttr($value, $data) {
$config = Cache::get('system_config_data');
$type = $config['config_type_list'];
$type_text = "";
foreach ($type as $value) {
if ($value['key'] == $data['type']) {
$type_text = $value['label'];
}
}
return $type_text;
}
public function getFieldlist($map, $index = 'id') {
$list = array();
$row = $this->field('*,remark as help,type,extra as "option"')->where($map)->order('group_id asc, sort asc')->select();
foreach ($row as $key => $value) {
if (in_array($value['type'], array('checkbox', 'radio', 'select', 'bool'))) {
$value['option'] = parse_field_attr($value['extra']);
} elseif ($value['type'] == 'bind') {
$extra = parse_field_bind($value['extra']);
$option = array();
foreach ($extra as $k => $v) {
$option[$v['id']] = $v['title_show'];
}
$value['option'] = $option;
}
$list[$value['id']] = $value;
}
return $list;
}
public function del($id, $model_id) {
$map['id'] = $id;
$info = $this->find($id);
$tablename = db('Form')->where(array('id' => $model_id))->value('name');
//先删除字段表内的数据
$result = $this->where($map)->delete();
if ($result) {
$tablename = strtolower($tablename);
//删除模型表中字段
$db = new \com\Datatable();
if (!$db->CheckField($tablename, $info['name'])) {
return true;
}
$result = $db->delField($tablename, $info['name'])->query();
if ($result) {
return true;
} else {
$this->error = "删除失败!";
return false;
}
} else {
$this->error = "删除失败!";
return false;
}
}
}