From 338f7f3d430195e80897e9c87db8b7240c35f1a9 Mon Sep 17 00:00:00 2001 From: nizongfeng Date: Tue, 30 Nov 2021 19:51:27 +0800 Subject: [PATCH] 1 --- application/admin/controller/CfRoomPlan.php | 158 ++------- application/admin/dao/CfRoomPlanDao.php | 107 ++++++ application/admin/view/cf_room_plan/index.html | 437 +++++++++++++++++++++++-- 3 files changed, 540 insertions(+), 162 deletions(-) create mode 100644 application/admin/dao/CfRoomPlanDao.php diff --git a/application/admin/controller/CfRoomPlan.php b/application/admin/controller/CfRoomPlan.php index 1ff12e1..c89825c 100755 --- a/application/admin/controller/CfRoomPlan.php +++ b/application/admin/controller/CfRoomPlan.php @@ -2,6 +2,7 @@ namespace app\admin\controller; +use app\admin\dao\CfRoomPlanDao; use app\admin\dao\GroupDao; use app\admin\model\Area; use app\common\controller\Backend; @@ -16,7 +17,7 @@ use think\exception\ValidateException; */ class CfRoomPlan extends Backend { - protected $noNeedRight = ['getList']; + protected $noNeedRight = ['getList',"list","save","delAll"]; /** * CfRoomPlan模型对象 * @var \app\admin\model\CfRoomPlan @@ -73,143 +74,40 @@ class CfRoomPlan extends Backend } /** - * 查看 + * 获取列表 + * @return \think\response\Json */ - public function index() - { - //设置过滤方法 - $this->request->filter(['strip_tags', 'trim']); - if ($this->request->isAjax()) { - //如果发送的来源是Selectpage,则转发到Selectpage - if ($this->request->request('keyField')) { - return $this->selectpage(); - } - list($where, $sort, $order, $offset, $limit) = $this->buildparams(); - $groupDao = new GroupDao(); - $group_id = $groupDao->getTopGroup($this->auth->getGroupId()); - $list = $this->model - ->alias("a") - ->join('hbp_admin','a.purchase_user_id = hbp_admin.id','left') - ->join('hbp_cf_room_info e','a.room_id = e.id','left') - ->join('hbp_cf_hotel_info f','a.hotel_id = f.id','left') - ->field("a.*,hbp_admin.nickname,e.room_name,f.hotel_name") - ->where($where); - $list = $list - ->where("a.group_id","=",$group_id) - ->order($sort, $order) - ->paginate($limit); - $result = $list->items(); - foreach ($result as $k=>$item){ - $result[$k]["continuity_type"]=$this->continuity_type[$item["continuity_type"]]; - $result[$k]["hbp_admin.nickname"] = $item["nickname"]; - } - $result = array("total" => $list->total(), "rows" => $result); - return json($result); - } - return $this->view->fetch(); + public function list(){ + $params=$this->request->post(); + $params['create_id']=$this->auth->id; + $groupDao = new GroupDao(); + $params['group_id'] = $groupDao->getTopGroup($this->auth->getGroupId()); + $service = new CfRoomPlanDao(); + return json($service->getList($params)); } /** - * 添加 + * 保存记录 + * @return \think\response\Json */ - public function add() - { - if ($this->request->isPost()) { - - $params = $this->request->post("row/a"); - if ($params) { - $params = $this->preExcludeFields($params); - - if ($this->dataLimit && $this->dataLimitFieldAutoFill) { - $params[$this->dataLimitField] = $this->auth->id; - } - $result = false; - Db::startTrans(); - try { - //是否采用模型验证 - if ($this->modelValidate) { - $name = str_replace("\\model\\", "\\validate\\", get_class($this->model)); - $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate; - $this->model->validateFailException(true)->validate($validate); - } - $groupDao = new GroupDao(); - $params['create_id']=$this->auth->id; - $params['group_id']=$groupDao->getTopGroup($this->auth->getGroupId()); - $result = $this->model->allowField(true)->save($params); - Db::commit(); - } catch (ValidateException $e) { - Db::rollback(); - $this->error($e->getMessage()); - } catch (PDOException $e) { - Db::rollback(); - $this->error($e->getMessage()); - } catch (Exception $e) { - Db::rollback(); - $this->error($e->getMessage()); - } - if ($result !== false) { - $this->success(); - } else { - $this->error(__('No rows were inserted')); - } - } - $this->error(__('Parameter %s can not be empty', '')); - } - $this->view->assign("continuity_type", $this->continuity_type); - return $this->view->fetch(); + public function save(){ + $params=$this->request->post(); + $params['create_id']=$this->auth->id; + $groupDao = new GroupDao(); + $params['group_id'] = $groupDao->getTopGroup($this->auth->getGroupId()); + $service = new CfRoomPlanDao(); + return json($service->save($params)); } - /** - * 编辑 + * 删除 + * @return \think\response\Json */ - public function edit($ids = null) - { - $row = $this->model->get($ids); - if (!$row) { - $this->error(__('No Results were found')); - } - $adminIds = $this->getDataLimitAdminIds(); - if (is_array($adminIds)) { - if (!in_array($row[$this->dataLimitField], $adminIds)) { - $this->error(__('You have no permission')); - } - } - if ($this->request->isPost()) { - $params = $this->request->post("row/a"); - if ($params) { - $params = $this->preExcludeFields($params); - $result = false; - Db::startTrans(); - try { - //是否采用模型验证 - if ($this->modelValidate) { - $name = str_replace("\\model\\", "\\validate\\", get_class($this->model)); - $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.edit' : $name) : $this->modelValidate; - $row->validateFailException(true)->validate($validate); - } - $result = $row->allowField(true)->save($params); - Db::commit(); - } catch (ValidateException $e) { - Db::rollback(); - $this->error($e->getMessage()); - } catch (PDOException $e) { - Db::rollback(); - $this->error($e->getMessage()); - } catch (Exception $e) { - Db::rollback(); - $this->error($e->getMessage()); - } - if ($result !== false) { - $this->success(); - } else { - $this->error(__('No rows were updated')); - } - } - $this->error(__('Parameter %s can not be empty', '')); - } - $this->view->assign("continuity_type", $this->continuity_type); - $this->view->assign("row", $row); - return $this->view->fetch(); + public function delAll(){ + $params=$this->request->post(); + $service = new CfRoomPlanDao(); + return json($service->del($params)); } + + } diff --git a/application/admin/dao/CfRoomPlanDao.php b/application/admin/dao/CfRoomPlanDao.php new file mode 100644 index 0000000..9507991 --- /dev/null +++ b/application/admin/dao/CfRoomPlanDao.php @@ -0,0 +1,107 @@ + $param['hotel_id'], + 'room_id' => $param['room_id'], + 'plan_name' => $param['plan_name'], + 'breakfast_num' => $param['breakfast_num'], + 'book_end_day' => $param['book_end_day'], + 'book_end_hour' => $param['book_end_hour'], + 'continuity_type' => $param['continuity_type'], + "coutinuity_day"=>$param['coutinuity_day'], + 'plan_memo' => $param['plan_memo'], + 'purchase_user_id' => $param['purchase_user_id'] + ]; + $model = new CfRoomPlan(); + if (empty($param['id'])) { + $data['create_id'] = $param['create_id']; + $data['group_id'] = $param['group_id']; + $id = $model->insertGetId($data); + return Util::returnArrSu("", $id); + } else { + $model->save($data, ['id' => $param['id']]); + return Util::returnArrSu("", $param['id']); + } + } catch (\Exception $e) { + return Util::returnArrEr("更新记录失败:" . $e->getMessage()); + } + } + + /** + * 获取列表 + * @param $param + * @return array + */ + public function getList($param) + { + try { + $where = ["del_flag"=>0]; + if (!empty($param['hotel_id'])) { + $where["hotel_id"] = $param['hotel_id']; + } + if (!empty($param['room_id'])) { + $where["room_id"] = $param['room_id']; + } + if (!empty($param['plan_name'])) { + $where["plan_name"] = ["like","%".$param['plan_name']."%"]; + } + if (!empty($param['purchase_user_id'])) { + $where["purchase_user_id"] = $param['purchase_user_id']; + } + if (!empty($param['id'])) { + $where['id'] = $param['id']; + } + if (!empty($param['group_id'])) { + $where['group_id'] = $param['group_id']; + } + $offset = ($param['pageNum'] - 1) * $param['pageSize']; + $model = new CfRoomPlan(); + $total = $model->where($where)->count(); + $list = $model->where($where) + ->limit($offset, $param['pageSize']) + ->order("id","DESC")->select(); + $data = ["total" => $total, "list" => $list->toArray()]; + return Util::returnArrSu("", $data); + } catch (\Exception $e) { + return Util::returnArrSu("", ["total" => 0, "list" => []]); + } + } + + /** + * 删除 + * @param $id + * @return array + */ + public function del($param){ + try { + //设置收购单状态 + $model = new CfRoomPlan(); + $model->save(['del_flag' =>1], ['id' => $param['id']]); + return Util::returnArrSu(); + } catch (\Exception $e) { + return Util::returnArrEr("修改状态失败" . $e->getMessage()); + } + } +} \ No newline at end of file diff --git a/application/admin/view/cf_room_plan/index.html b/application/admin/view/cf_room_plan/index.html index 760e636..99cc504 100755 --- a/application/admin/view/cf_room_plan/index.html +++ b/application/admin/view/cf_room_plan/index.html @@ -1,35 +1,408 @@ -
- {:build_heading()} - -
-
- - + + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + + + + + +
+ + + + + +
+ +
+
+
+
+ + + +
+
+ + + + + + + + + + +
+
+ + + +
+
+ 保存 +
+
+
+
+ + + + + + + + +