diff --git a/digital_doctor_admin/application/admin/controller/Ttmedicalreport.php b/digital_doctor_admin/application/admin/controller/Ttmedicalreport.php index 5015bc3..2c73224 100644 --- a/digital_doctor_admin/application/admin/controller/Ttmedicalreport.php +++ b/digital_doctor_admin/application/admin/controller/Ttmedicalreport.php @@ -3,6 +3,7 @@ namespace app\admin\controller; use app\common\controller\Backend; +use think\Db; /** * 疼痛科病历报告(听译问诊) @@ -34,4 +35,55 @@ class Ttmedicalreport extends Backend */ + /** + * 编辑 + * + * @param $ids + * @return string + * @throws DbException + * @throws \think\Exception + */ + public function edit($ids = null) + { + $row = $this->model->get($ids); + if (!$row) { + $this->error(__('No Results were found')); + } + //查询随访记录 + $followup = Db::table('fa_tt_followup')->where('report_dataid', $row['id'])->select(); + $this->view->assign('follow_record', $followup); + + $adminIds = $this->getDataLimitAdminIds(); + if (is_array($adminIds) && !in_array($row[$this->dataLimitField], $adminIds)) { + $this->error(__('You have no permission')); + } + if (false === $this->request->isPost()) { + $this->view->assign('row', $row); + return $this->view->fetch(); + } + $params = $this->request->post('row/a'); + if (empty($params)) { + $this->error(__('Parameter %s can not be empty', '')); + } + $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()->validate($validate); + } + $result = $row->allowField(true)->save($params); + Db::commit(); + } catch (\Exception $e) { + Db::rollback(); + $this->error($e->getMessage()); + } + if (false === $result) { + $this->error(__('No rows were updated')); + } + $this->success(); + } } diff --git a/digital_doctor_admin/application/admin/controller/tt/Followup.php b/digital_doctor_admin/application/admin/controller/tt/Followup.php new file mode 100644 index 0000000..9688e5b --- /dev/null +++ b/digital_doctor_admin/application/admin/controller/tt/Followup.php @@ -0,0 +1,106 @@ +model = new \app\admin\model\tt\Followup; + + } + + + + /** + * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法 + * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑 + * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 + */ + + + /** + * 添加页面 + * + * @return string + * @throws \think\Exception + */ + public function addfollowup() + { + //报告数据id + $report_dataid = input('report_dataid'); + $report = Db::table('fa_tt_medical_report')->where('id',$report_dataid)->find(); + //$user = Db::table('fa_tt_users')->where('username',$report['username'])->find(); + + $userbaseinfo = Db::table('fa_tt_userbaseinfo')->where('id',$report['id'])->find(); + $this->assign('user',$userbaseinfo); + $html = view('add')->getContent(); + return json(Tools::set_ok('ok',$html)); + } + + function submitfollowup(){ + return Mmodel::catchJson(function (){ + $content = input('content'); + if(empty($content)){ + return Tools::set_fail( '请填写随访内容'); + } + $report_dataid = input('report_dataid'); + if(empty($report_dataid)){ + return Tools::set_fail( '请选择诊断报告'); + } + $data = [ + 'report_dataid'=>$report_dataid, + 'content'=>$content, + 'create_time'=>date('Y-m-d H:i:s') + ]; + Db::table('fa_tt_followup')->insert($data); + return Tools::set_ok('添加成功'); + }); + } + + //function getfollowup(){ + // + // //设置过滤方法 + // //$this->request->filter(['strip_tags', 'trim']); + // //if (false === $this->request->isAjax()) { + // // return $this->view->fetch(); + // //} + // ////如果发送的来源是 Selectpage,则转发到 Selectpage + // //if ($this->request->request('keyField')) { + // // return $this->selectpage(); + // //} + // //[$where, $sort, $order, $offset, $limit] = $this->buildparams(); + // //$list = $this->model + // // ->where($where) + // // ->order($sort, $order) + // // ->paginate($limit); + // //$result = ['total' => $list->total(), 'rows' => $list->items()]; + // //return json($result); + // + // //报告数据id + // $report_dataid = input('report_dataid'); + // $report = Db::table('fa_tt_followup')->where('id',$report_dataid)->select(); + // + // $this->assign('rows',$report); + // $html = view('index')->getContent(); + // return json(Tools::set_ok('ok',$html)); + //} +} diff --git a/digital_doctor_admin/application/admin/lang/zh-cn/tt/followup.php b/digital_doctor_admin/application/admin/lang/zh-cn/tt/followup.php new file mode 100644 index 0000000..dcd7367 --- /dev/null +++ b/digital_doctor_admin/application/admin/lang/zh-cn/tt/followup.php @@ -0,0 +1,9 @@ + 'ID', + 'Name' => '姓名', + 'Phone' => '电话', + 'Content' => '随访内容', + 'Create_time' => '随访时间' +]; diff --git a/digital_doctor_admin/application/admin/model/tt/Followup.php b/digital_doctor_admin/application/admin/model/tt/Followup.php new file mode 100644 index 0000000..5b614cb --- /dev/null +++ b/digital_doctor_admin/application/admin/model/tt/Followup.php @@ -0,0 +1,40 @@ + [], + 'edit' => [], + ]; + +} diff --git a/digital_doctor_admin/application/admin/view/tt/followup/add.html b/digital_doctor_admin/application/admin/view/tt/followup/add.html new file mode 100644 index 0000000..a1385b4 --- /dev/null +++ b/digital_doctor_admin/application/admin/view/tt/followup/add.html @@ -0,0 +1,33 @@ +
+ +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ +
diff --git a/digital_doctor_admin/application/admin/view/tt/followup/edit.html b/digital_doctor_admin/application/admin/view/tt/followup/edit.html new file mode 100644 index 0000000..883aaf7 --- /dev/null +++ b/digital_doctor_admin/application/admin/view/tt/followup/edit.html @@ -0,0 +1,33 @@ +
+ +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ +
diff --git a/digital_doctor_admin/application/admin/view/tt/followup/index.html b/digital_doctor_admin/application/admin/view/tt/followup/index.html new file mode 100644 index 0000000..0c28b52 --- /dev/null +++ b/digital_doctor_admin/application/admin/view/tt/followup/index.html @@ -0,0 +1,29 @@ +
+ {:build_heading()} + +
+
+
+ +
+ +
+
+
diff --git a/digital_doctor_admin/application/admin/view/ttmedicalreport/edit.html b/digital_doctor_admin/application/admin/view/ttmedicalreport/edit.html index 5b67f8d..809ee11 100644 --- a/digital_doctor_admin/application/admin/view/ttmedicalreport/edit.html +++ b/digital_doctor_admin/application/admin/view/ttmedicalreport/edit.html @@ -1,11 +1,11 @@
-
- -
- -
-
+ + + + + +
@@ -24,13 +24,23 @@
+ + {volist name='follow_record' key='k' id='vo' empty='没有随访记录'} +
+ +
+ +
+
+ {/volist}
diff --git a/digital_doctor_admin/public/assets/js/backend/tt/followup.js b/digital_doctor_admin/public/assets/js/backend/tt/followup.js new file mode 100644 index 0000000..361b9be --- /dev/null +++ b/digital_doctor_admin/public/assets/js/backend/tt/followup.js @@ -0,0 +1,53 @@ +define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) { + + var Controller = { + index: function () { + // 初始化表格参数配置 + Table.api.init({ + extend: { + index_url: 'tt/followup/index' + location.search, + add_url: 'tt/followup/add', + edit_url: 'tt/followup/edit', + del_url: 'tt/followup/del', + multi_url: 'tt/followup/multi', + import_url: 'tt/followup/import', + table: 'tt_followup', + } + }); + + var table = $("#table"); + + // 初始化表格 + table.bootstrapTable({ + url: $.fn.bootstrapTable.defaults.extend.index_url, + pk: 'id', + sortName: 'id', + columns: [ + [ + {checkbox: true}, + {field: 'id', title: __('Id')}, + {field: 'name', title: __('Name'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content}, + {field: 'phone', title: __('Phone'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content}, + {field: 'create_time', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime}, + {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate} + ] + ] + }); + + // 为表格绑定事件 + Table.api.bindevent(table); + }, + add: function () { + Controller.api.bindevent(); + }, + edit: function () { + Controller.api.bindevent(); + }, + api: { + bindevent: function () { + Form.api.bindevent($("form[role=form]")); + } + } + }; + return Controller; +}); diff --git a/digital_doctor_admin/public/assets/js/backend/tt/userbaseinfo.js b/digital_doctor_admin/public/assets/js/backend/tt/userbaseinfo.js index b13e91f..70317b2 100644 --- a/digital_doctor_admin/public/assets/js/backend/tt/userbaseinfo.js +++ b/digital_doctor_admin/public/assets/js/backend/tt/userbaseinfo.js @@ -28,7 +28,7 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin [ {checkbox: true}, {field: 'id', title: __('Id')}, - {field: 'doctor', title: __('Doctor'), operate: 'LIKE'}, + // {field: 'doctor', title: __('Doctor'), operate: 'LIKE'}, {field: 'name', title: __('Name'), operate: 'LIKE'}, {field: 'gender', title: __('Gender'), operate: 'LIKE'}, {field: 'age', title: __('Age')}, diff --git a/digital_doctor_admin/public/assets/js/backend/ttmedicalreport.js b/digital_doctor_admin/public/assets/js/backend/ttmedicalreport.js index 26bbc5f..c19538d 100644 --- a/digital_doctor_admin/public/assets/js/backend/ttmedicalreport.js +++ b/digital_doctor_admin/public/assets/js/backend/ttmedicalreport.js @@ -62,6 +62,10 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin $.post(url,{content:content,report_dataid:report_dataid},function (res) { layer.msg(res.msg); + if(res.code==200){ + layer.close(index); + location.href = ''; + } },'json'); }, btn2: function(index, layero){ @@ -78,6 +82,44 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin },'json'); }); + //查询随访报告 + $('#get_follow_report').on('click',function () { + let report_dataid = $('#add_follow_report').attr('data-id'); + //添加随访记录 + let url = 'tt/Followup/getfollowup'; + $.post(url,{report_dataid:report_dataid},function (res) { + + layer.open({ + type: 1, + title:'添加随访', + area: '80%', + content:res.data, + btn: ['确定', '取消'], + yes: function(index, layero){ + //按钮【按钮一】的回调 + + // let content = $('#c-content').val(); + // + // let url = 'tt/Followup/submitfollowup'; + // $.post(url,{content:content,report_dataid:report_dataid},function (res) { + // + // layer.msg(res.msg); + // },'json'); + }, + btn2: function(index, layero){ + //按钮【按钮二】的回调 + + //return false 开启该代码可禁止点击该按钮关闭 + }, + cancel: function(){ + //右上角关闭回调 + + //return false 开启该代码可禁止点击该按钮关闭 + } + }); + },'json'); + }); + Controller.api.bindevent(); }, api: {