增加复选框后台新增和编辑

This commit is contained in:
微笑涩涩的
2016-09-14 00:14:59 +08:00
parent 5d19b2e5ce
commit 6aea22ad27

View File

@@ -1,133 +1,143 @@
<?php <?php
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
// | SentCMS [ WE CAN DO IT JUST THINK IT ] // | SentCMS [ WE CAN DO IT JUST THINK IT ]
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.tensent.cn All rights reserved. // | Copyright (c) 2013 http://www.tensent.cn All rights reserved.
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn> // | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
namespace app\common\model; namespace app\common\model;
/** /**
* 设置模型 * 设置模型
*/ */
class Document extends \think\model\Merge{ class Document extends \think\model\Merge{
protected $fk = 'doc_id'; protected $fk = 'doc_id';
//protected static $relationModel = array('document_article'); //protected static $relationModel = array('document_article');
// 定义需要自动写入时间戳格式的字段 // 定义需要自动写入时间戳格式的字段
protected $autoWriteTimestamp = 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 $auto = array('doc_id', 'title', 'description', 'update_time','deadline');
protected $insert = array('uid', 'attach'=>0, 'view'=>0, 'comment'=>0, 'extend'=>0, 'create_time', 'status'); protected $insert = array('uid', 'attach'=>0, 'view'=>0, 'comment'=>0, 'extend'=>0, 'create_time', 'status');
protected $type = array( protected $type = array(
'cover_id' => 'integer', 'cover_id' => 'integer',
'link_id' => 'integer', 'link_id' => 'integer',
'level' => 'integer', 'level' => 'integer',
'comment' => 'integer', 'comment' => 'integer',
'view' => 'integer', 'view' => 'integer',
); );
protected function setUidAttr(){ protected function setUidAttr(){
return session('user_auth.uid'); return session('user_auth.uid');
} }
protected function setDocIdAttr(){ protected function setDocIdAttr(){
return input('id','','intval,trim'); return input('id','','intval,trim');
} }
protected function setDeadlineAttr($value){ protected function setDeadlineAttr($value){
return $value ? strtotime($value) : time(); return $value ? strtotime($value) : time();
} }
protected function setCreateTimeAttr($value){ protected function setCreateTimeAttr($value){
return $value ? strtotime($value) : time(); return $value ? strtotime($value) : time();
} }
/** /**
* 获取数据状态 * 获取数据状态
* @return integer 数据状态 * @return integer 数据状态
* @author huajie <banhuajie@163.com> * @author huajie <banhuajie@163.com>
*/ */
protected function setStatusAttr($value){ protected function setStatusAttr($value){
$cate = input('post.category_id'); $cate = input('post.category_id');
$check = db('Category')->getFieldById($cate, 'check'); $check = db('Category')->getFieldById($cate, 'check');
if($check){ if($check){
$status = 2; $status = 2;
}else{ }else{
$status = 1; $status = 1;
} }
return $status; return $status;
} }
protected function getTagsAttr($value){ protected function getTagsAttr($value){
if ($value) { if ($value) {
return explode(',', $value); return explode(',', $value);
} }
} }
public function extend($name){ public function extend($name){
if (is_numeric($name)) { if (is_numeric($name)) {
$name = db('model')->where(array('id'=>$name))->value('name'); $name = db('model')->where(array('id'=>$name))->value('name');
} }
self::$relationModel = array('document_' . $name); self::$relationModel = array('document_' . $name);
return $this; return $this;
} }
public function change(){ public function change(){
/* 获取数据对象 */ /* 获取数据对象 */
$data = \think\Request::instance()->post(); $data = \think\Request::instance()->post();
if ($data !== false) { if ($data !== false) {
/* 添加或新增基础内容 */ //增加增加复选框 shu'zu数组保存
if(empty($data['id'])){ //新增数据 foreach($data ad $key=>$val){
unset($data['id']); if(is_array($val)){
$id = $this->validate('document.edit')->save($data); //添加基础内容 $data[$key] = implode(',', $val);
}
if(!$id){ }
return false; /* 添加或新增基础内容 */
} if(empty($data['id'])){ //新增数据
$data['id'] = $id; unset($data['id']);
} else { //更新数据 $id = $this->validate('document.edit')->save($data); //添加基础内容
$status = $this->validate('document.edit')->save($data, array('id'=>$data['id'])); //更新基础内容
if(false === $status){ if(!$id){
return false; return false;
} }
} $data['id'] = $id;
return $data['id']; } else { //更新数据
}else{ $status = $this->validate('document.edit')->save($data, array('id'=>$data['id'])); //更新基础内容
return false; if(false === $status){
} return false;
} }
}
public function del($map){ return $data['id'];
return $this->where($map)->delete(); }else{
} return false;
}
public function detail($id){ }
$data = $this->get($id);
public function del($map){
return $data; return $this->where($map)->delete();
} }
public function recom($id, $field = '*', $limit = 10, $order = 'id desc'){ public function detail($id){
$tag = $this->where(array('id'=>$id))->value('tags'); $data = $this->get($id);
$map = ''; $model_type = db('attribute')->where('model_id'=>$data['model_id'], 'type'=>array('in', 'checkbox'))->column('name');
if ($tag) { foreach($model_type as $val){
$tags = explode(',', $tag); $data->setAttr($val, explode(',', $data[$val]));
foreach ($tags as $item) { }
$where[] = 'tags LIKE "%' . $item . '%"';
} return $data;
$map = implode(' OR ', $where); }
}
$list = $this->where($map)->field($field)->limit($limit)->order($order)->select(); public function recom($id, $field = '*', $limit = 10, $order = 'id desc'){
if (empty($list)) { $tag = $this->where(array('id'=>$id))->value('tags');
return $list; $map = '';
}else{ if ($tag) {
return $this->field($field)->limit($limit)->order($order)->select(); $tags = explode(',', $tag);
} foreach ($tags as $item) {
} $where[] = 'tags LIKE "%' . $item . '%"';
}
$map = implode(' OR ', $where);
}
$list = $this->where($map)->field($field)->limit($limit)->order($order)->select();
if (empty($list)) {
return $list;
}else{
return $this->field($field)->limit($limit)->order($order)->select();
}
}
} }