1、修复栏目管理中的bug

2、增加路由规则管理
This commit is contained in:
2016-07-23 11:26:09 +08:00
parent 27891c868a
commit 75125bb298
7 changed files with 88 additions and 70 deletions

View File

@@ -10,23 +10,23 @@
namespace app\admin\controller;
use app\common\controller\Admin;
class Category extends Admin{
class Category extends Admin {
public function _initialize(){
public function _initialize() {
parent::_initialize();
$this->getContentMenu();
}
public function index(){
public function index() {
$map = array('status' => array('gt', -1));
$list = db('Category')->where($map)->order('sort asc,id asc')->column('*','id');
if (!empty($list)) {
$tree = new \com\Tree();
$list = $tree->toFormatTree($list);
}
$list = db('Category')->where($map)->order('sort asc,id asc')->column('*', 'id');
$this->assign('tree',$list);
if (!empty($list)) {
$tree = new \com\Tree();
$list = $tree->toFormatTree($list);
}
$this->assign('tree', $list);
$this->setMeta('栏目列表');
return $this->fetch();
}
@@ -37,7 +37,7 @@ class Category extends Admin{
db('Category')->where(array('id' => $pk))->setField($name, $value);
}
}
/* 编辑分类 */
public function edit($id = null, $pid = 0) {
if (IS_POST) {
@@ -48,8 +48,7 @@ class Category extends Admin{
//记录行为
action_log('update_category', 'category', $id, session('user_auth.uid'));
return $this->success('编辑成功!', url('index'));
}
else {
} else {
$error = $category->getError();
return $this->error(empty($error) ? '未知错误!' : $error);
}
@@ -64,7 +63,7 @@ class Category extends Admin{
}
/* 获取分类信息 */
$info = $id ? db('Category')->find($id) : '';
$this->assign('info', $info);
$this->assign('category', $cate);
$this->setMeta('编辑分类');
@@ -74,15 +73,14 @@ class Category extends Admin{
/* 新增分类 */
public function add($pid = 0) {
$Category = model('Category');
if (IS_POST) {
//提交表单
$id = $Category->change();
if (false !== $id) {
action_log('update_category', 'category', $id, session('user_auth.uid'));
return $this->success('新增成功!', url('index'));
}
else {
} else {
$error = $Category->getError();
return $this->error(empty($error) ? '未知错误!' : $error);
}
@@ -121,49 +119,46 @@ class Category extends Admin{
return $this->error('请先删除该分类下的文章(包含回收站)');
}
//删除该分类信息
$res = db('Category')->where(array('id'=>$id))->delete();
$res = db('Category')->where(array('id' => $id))->delete();
if ($res !== false) {
//记录行为
action_log('update_category', 'category', $id, session('user_auth.uid'));
return $this->success('删除分类成功!');
}
else {
} else {
return $this->error('删除分类失败!');
}
}
/**
* 操作分类初始化
* @param string $type
* @author huajie <banhuajie@163.com>
*/
public function operate($type = 'move') {
public function operate($type = 'move', $from = '') {
//检查操作参数
if (strcmp($type, 'move') == 0) {
if ($type == 'move') {
$operate = '移动';
}
elseif (strcmp($type, 'merge') == 0) {
} elseif ($type == 'merge') {
$operate = '合并';
}
else {
} else {
return $this->error('参数错误!');
}
$from = intval(input('get.from'));
if (empty($from)) {
return $this->error('参数错误!');
}
return $this->error('参数错误!');
}
//获取分类
$map = array('status' => 1, 'id' => array('neq', $from));
$map = array('status' => 1, 'id' => array('neq', $from));
$list = db('Category')->where($map)->field('id,pid,title')->select();
//移动分类时增加移至根分类
if (strcmp($type, 'move') == 0) {
if ($type == 'move') {
//不允许移动至其子孙分类
$list = tree_to_list(list_to_tree($list));
$pid = db('Category')->getFieldById($from, 'pid');
$pid && array_unshift($list, array('id' => 0, 'title' => '根分类'));
}
$this->assign('type', $type);
$this->assign('operate', $operate);
$this->assign('from', $from);
@@ -176,13 +171,12 @@ class Category extends Admin{
* @author huajie <banhuajie@163.com>
*/
public function move() {
$to = input('post.to');
$to = input('post.to');
$from = input('post.from');
$res = db('Category')->where(array('id' => $from))->setField('pid', $to);
$res = db('Category')->where(array('id' => $from))->setField('pid', $to);
if ($res !== false) {
return $this->success('分类移动成功!', url('index'));
}
else {
} else {
return $this->error('分类移动失败!');
}
}
@@ -191,12 +185,12 @@ class Category extends Admin{
* @author huajie <banhuajie@163.com>
*/
public function merge() {
$to = input('post.to');
$from = input('post.from');
$to = input('post.to');
$from = input('post.from');
$Model = model('Category');
//检查分类绑定的模型
$from_models = explode(',', $Model->getFieldById($from, 'model'));
$to_models = explode(',', $Model->getFieldById($to, 'model'));
$to_models = explode(',', $Model->getFieldById($to, 'model'));
foreach ($from_models as $value) {
if (!in_array($value, $to_models)) {
return $this->error('请给目标分类绑定' . get_document_model($value, 'title') . '模型');
@@ -204,40 +198,38 @@ class Category extends Admin{
}
//检查分类选择的文档类型
$from_types = explode(',', $Model->getFieldById($from, 'type'));
$to_types = explode(',', $Model->getFieldById($to, 'type'));
$to_types = explode(',', $Model->getFieldById($to, 'type'));
foreach ($from_types as $value) {
if (!in_array($value, $to_types)) {
$types = config('DOCUMENT_MODEL_TYPE');
$types = config('document_model_type');
return $this->error('请给目标分类绑定文档类型:' . $types[$value]);
}
}
//合并文档
$res = db('Document')->where(array('category_id' => $from))->setField('category_id', $to);
if ($res !== false) {
//删除被合并的分类
$Model->delete($from);
return $this->success('合并分类成功!', url('index'));
}
else {
} else {
return $this->error('合并分类失败!');
}
}
public function status(){
$id = input('id','','trim,intval');
$ids = input('post.ids/a',array(),'');
$status = input('status','0','trim,intval');
array_push($ids, $id);
public function status() {
$id = $this->getArrayParam('id');
$status = input('status', '0', 'trim,intval');
if (!$id) {
return $this->error("非法操作!");
}
$map['id'] = array('IN',$ids);
$result = db('Category')->where($map)->setField('status', $status);
$map['id'] = array('IN', $id);
$result = db('Category')->where($map)->setField('status', $status);
if ($result) {
return $this->success("设置成功!");
}else{
} else {
return $this->error("设置失败!");
}
}

View File

@@ -104,7 +104,12 @@ class Seo extends Admin{
public function addrewrite(){
if (IS_POST) {
# code...
$result = model('Rewrite')->change();
if (false != $result) {
return $this->success("添加成功!", url('admin/seo/rewrite'));
}else{
return $this->error(model('Rewrite')->getError());
}
}else{
$data = array(
'keyList' => $this->rewrite->keyList
@@ -117,7 +122,12 @@ class Seo extends Admin{
public function editrewrite(){
if (IS_POST) {
# code...
$result = model('Rewrite')->change();
if (false != $result) {
return $this->success("更新成功!", url('admin/seo/rewrite'));
}else{
return $this->error(model('Rewrite')->getError());
}
}else{
$id = input('id','','trim,intval');
$info = db('Rewrite')->where(array('id'=>$id))->find();

View File

@@ -25,6 +25,10 @@ class Base extends \think\Model{
*/
public function change(){
$data = \think\Request::instance()->post();
return $this->save($data, array('id'=>$data['id']));
if (isset($data['id']) && $data['id']) {
return $this->save($data, array('id'=>$data['id']));
}else{
return $this->save($data);
}
}
}

View File

@@ -18,7 +18,7 @@ class Document extends \think\model\Merge{
protected $fk = 'doc_id';
// 定义需要自动写入时间戳格式的字段
protected $autoTimeField = array('create_time','update_time','deadline');
protected $autoWriteTimestamp = array('create_time','update_time','deadline');
protected $auto = array('doc_id', 'title', 'description', 'update_time','deadline');
protected $insert = array('uid', 'attach'=>0, 'view'=>0, 'comment'=>0, 'extend'=>0, 'create_time', 'status');

View File

@@ -14,8 +14,24 @@ namespace app\common\model;
*/
class Rewrite extends Base{
protected $autoWriteTimestamp = true;
public $keyList = array(
array('name'=>'id','title'=>'标识','type'=>'hidden'),
array('name'=>'title','title'=>'规则名称','type'=>'text','option'=>'','help'=>'规则名称,方便记忆'),
array('name'=>'rule','title'=>'规则名称','type'=>'text','option'=>'','help'=>'规则名称,方便记忆'),
array('name'=>'url','title'=>'规则地址','type'=>'text','option'=>'','help'=>'规则地址'),
);
/**
* 数据修改
* @return [bool] [是否成功]
*/
public function change(){
$data = \think\Request::instance()->post();
if (isset($data['id']) && $data['id']) {
return $this->validate(true)->save($data, array('id'=>$data['id']));
}else{
return $this->validate(true)->save($data);
}
}
}

View File

@@ -12,21 +12,16 @@ namespace app\common\validate;
/**
* 设置模型
*/
class Book extends \think\Validate{
class Rewrite extends Base{
protected $rule = array(
'book_name' => 'require',
'stand_class' => 'require',
'rule' => 'require|unique:Rewrite',
'url' => 'require'
);
protected $message = array(
'book_name' => '书名称必须!',
'stand_class' => '图书标准类型必须',
);
protected $scene = array(
'add' => array('book_name', 'stand_class'),
'edit' => array('book_name', 'stand_class')
'rule.require' => '规则必须!',
'rule.unique' => '规则已存在',
'url.require' => '路由地址标题必须!',
);
}

View File

@@ -1309,6 +1309,7 @@ INSERT INTO `sent_menu` VALUES ('22', '广告管理', 'admin', 'cc', '5', '0', '
INSERT INTO `sent_menu` VALUES ('23', '插件列表', 'admin', 'usb', '6', '0', 'admin/addons/index', '0', '', '插件管理', '0', '0');
INSERT INTO `sent_menu` VALUES ('24', '钩子列表', 'admin', 'code', '6', '0', 'admin/addons/hooks', '0', '', '插件管理', '0', '0');
INSERT INTO `sent_menu` VALUES ('25', '自定义表单', 'admin', '', '5', '0', 'admin/form/index', '0', '', '运营管理', '0', '0');
INSERT INTO `sent_menu` VALUES ('26', '伪静态规则', 'admin', '', '2', '0', 'admin/seo/rewrite', '0', '', '优化设置', '0', '0');
-- -----------------------------
-- Table structure for `sent_model`