QuestionController.php
3.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2019/3/4
* Time: 10:13
*/
namespace app\admin\controller;
use cmf\controller\AdminBaseController;
use think\Db;
use think\Validate;
class QuestionController extends AdminBaseController
{
public function index(){
$where=[];
$param = $this->request->param();
$startTime = empty($param['start_time']) ? 0 : strtotime($param['start_time']);
$endTime = empty($param['end_time']) ? 0 : strtotime($param['end_time']);
if (!empty($startTime) && !empty($endTime)) {
$where['q.create_time'] = [['>= time', $startTime], ['<= time', $endTime]];
} else {
if (!empty($startTime)) {
$where['q.create_time'] = ['>= time', $startTime];
}
if (!empty($endTime)) {
$where['q.create_time'] = ['<= time', $endTime];
}
}
$keyword = empty($param['keyword']) ? '' : $param['keyword'];
if (!empty($keyword)) {
$where['u.nickname'] = ['like', "%$keyword%"];
}
$status = empty($param['status']) ? '' : $param['status'];
if (!empty($status)) {
$where['q.status'] = ['eq', "$status"];
}
$data=Db::name('question')
->alias('q')
->field('q.*,u.user_nickname')
->join('cmf_user u','u.id = q.user_id')
->where('q.delete_time',0)
->where($where)
->order('q.create_time desc')
->paginate(10);
$data->appends($param);
$list=$data->items();
$this->assign([
'data'=>$list,
'page'=>$data->render(),
'start_time'=>isset($param['start_time']) ? $param['start_time'] : '',
'end_time'=>isset($param['end_time']) ? $param['end_time'] : '',
'keyword'=>isset($param['keyword']) ? $param['keyword'] : '',
]);
return $this->fetch();
}
public function edit(){
$id=$this->request->param('id', 0, 'intval');
if($this->request->isPost()){
$param=$this->request->param();
$validate = new Validate([
'name' => 'require',
]);
$validate->message([
'name' => '姓名不能为空!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
Db::name('question')
->where('id',$id)
->update($param);
$this->success('更新成功!');
}else{
$data=Db::name('question')
->alias('q')
->field('q.*,u.user_nickname')
->join('cmf_user u','u.id = q.user_id')
->where('q.id',$id)
->find();
$this->assign([
'data'=>$data,
]);
return $this->fetch();
}
}
//删除
public function delete(){
$param = $this->request->param();
if (isset($param['id'])) {
$id = $this->request->param('id', 0, 'intval');
$resultPortal = Db::name('question')
->where(['id' => $id])
->update(['delete_time' => time()]);
if($resultPortal){
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
if (isset($param['ids'])) {
$ids = $this->request->param('ids/a');
$result = Db::name('question')
->where(['id' => ['in', $ids]])
->update(['delete_time' => time()]);
if ($result) {
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
}
}