表单功能完善

This commit is contained in:
2017-10-12 11:31:46 +08:00
parent 805697d643
commit 3a1ad06991
4 changed files with 81 additions and 7 deletions

View File

@@ -102,8 +102,52 @@ class Form extends Admin {
* @DateTime 2017-06-30 * @DateTime 2017-06-30
* @return html 页面 * @return html 页面
*/ */
public function lists() { public function lists($form_id = '') {
return $this->fetch(); $form = $this->model->where('id', $form_id)->find();
$list = M($form['name'], 'form')->order('id desc')->paginate(25);
$data = array(
'form_id' => $form_id,
'list' => $list,
'page' => $list->render()
);
$this->assign($data);
$this->setMeta('数据列表');
return $this->fetch('list_'.$form['name']);
}
public function detail($form_id = '', $id = ''){
$form = $this->model->where('id', $form_id)->find();
$info = M($form['name'], 'form')->where('id', $id)->find();
$data = array(
'info' => $info
);
$this->assign($data);
$this->setMeta('数据详情');
return $this->fetch('detail_'.$form['name']);
}
//数据导出
public function outxls($form_id = '') {
$form = $this->model->where('id', $form_id)->find();
$attr = $this->Fattr->where('form_id', $form_id)->where('is_show', 1)->select();
foreach ($attr as $key => $value) {
$title[$value['name']] = $value['title'];
}
$data[] = $title;
$res = M($form['name'], 'form')->order('id desc')->select();
foreach ($res as $key => $value) {
$data[] = $value;
}
$out = new \com\Outxls($data, date('Y-m-d'));
$out->out();
} }
public function attr($form_id = '') { public function attr($form_id = '') {
@@ -187,7 +231,6 @@ class Form extends Admin {
} }
} }
protected function getField(){ protected function getField(){
return array( return array(
array('name' => 'id', 'title' => 'id', 'help' => '', 'type' => 'hidden'), array('name' => 'id', 'title' => 'id', 'help' => '', 'type' => 'hidden'),

View File

@@ -34,13 +34,21 @@ class BaseModel {
protected $attrDb = 'Attribute'; protected $attrDb = 'Attribute';
public function __construct($name) { public function __construct($name) {
if ($this->attrDb == 'FormAttr') {
$this->db = db('Form'.ucfirst($name));
}else{
$this->db = db($name); $this->db = db($name);
} }
}
public function save($data, $where = array()) { public function save($data, $where = array()) {
$this->data = $data; $this->data = $data;
$rule = $msg = array(); $rule = $msg = array();
if ($this->attrDb == 'FormAttr') {
$attr = db($this->attrDb)->where('form_id', $data['form_id'])->select();
}else{
$attr = db($this->attrDb)->where('model_id', $data['model_id'])->select(); $attr = db($this->attrDb)->where('model_id', $data['model_id'])->select();
}
foreach ($attr as $key => $value) { foreach ($attr as $key => $value) {
if ($value['is_must'] == 1) { if ($value['is_must'] == 1) {
$rule[$value['name']] = "require"; $rule[$value['name']] = "require";
@@ -249,6 +257,28 @@ class BaseModel {
} }
return $value; return $value;
} }
/**
* 获取对象原始数据 如果不存在指定字段返回false
* @access public
* @param string $name 字段名 留空获取全部
* @return mixed
* @throws InvalidArgumentException
*/
public function getData($name = null)
{
if (is_null($name)) {
return $this->data;
} elseif (array_key_exists($name, $this->data)) {
return $this->data[$name];
} elseif (array_key_exists($name, $this->relation)) {
return $this->relation[$name];
} else {
throw new InvalidArgumentException('property not exists:' . $this->class . '->' . $name);
}
}
public function __call($method, $args) { public function __call($method, $args) {
return call_user_func_array([$this->db, $method], $args); return call_user_func_array([$this->db, $method], $args);
} }

View File

@@ -14,4 +14,5 @@ namespace app\common\model;
*/ */
class DiyForm extends BaseModel{ class DiyForm extends BaseModel{
protected $attrDb = 'FormAttr';
} }

View File

@@ -37,7 +37,7 @@ class FormAttr extends Base{
return $db->columField('form_' . strtolower($name), $attr)->query(); return $db->columField('form_' . strtolower($name), $attr)->query();
} }
}); });
self::beforeUpdate(function($data){dump($data); self::beforeUpdate(function($data){
$attr = $data->toArray(); $attr = $data->toArray();
$attr['action'] = 'CHANGE'; $attr['action'] = 'CHANGE';
$attr['oldname'] = db('FormAttr')->where('id', $attr['id'])->value('name'); $attr['oldname'] = db('FormAttr')->where('id', $attr['id'])->value('name');