BaseComplaintService.java 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754
  1. package com.yihu.jw.complaint;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONArray;
  4. import com.alibaba.fastjson.JSONObject;
  5. import com.fasterxml.jackson.databind.ObjectMapper;
  6. import com.yihu.jw.dict.dao.DictHospitalDeptDao;
  7. import com.yihu.jw.doctor.dao.BaseDoctorDao;
  8. import com.yihu.jw.doctor.dao.BaseDoctorHospitalDao;
  9. import com.yihu.jw.doctor.dao.BaseDoctorRoleDao;
  10. import com.yihu.jw.entity.base.complaint.BaseComplaintDO;
  11. import com.yihu.jw.entity.base.complaint.BaseComplaintDictDO;
  12. import com.yihu.jw.entity.base.complaint.BaseComplaintDoctorDO;
  13. import com.yihu.jw.entity.base.complaint.BaseComplaintOperateLogDO;
  14. import com.yihu.jw.entity.base.dict.DictHospitalDeptDO;
  15. import com.yihu.jw.entity.base.doctor.BaseDoctorDO;
  16. import com.yihu.jw.entity.base.doctor.BaseDoctorHospitalDO;
  17. import com.yihu.jw.entity.base.doctor.BaseDoctorRoleDO;
  18. import com.yihu.jw.entity.base.patient.BasePatientDO;
  19. import com.yihu.jw.entity.hospital.consult.WlyyHospitalSysDictDO;
  20. import com.yihu.jw.hospital.dict.WlyyHospitalSysDictDao;
  21. import com.yihu.jw.hospital.prescription.service.entrance.EntranceService;
  22. import com.yihu.jw.patient.dao.BasePatientDao;
  23. import com.yihu.jw.restmodel.web.MixEnvelop;
  24. import com.yihu.jw.utils.StringUtil;
  25. import com.yihu.jw.utils.hibernate.HibenateUtils;
  26. import com.yihu.jw.wechat.enterprise.EnterpriseService;
  27. import org.apache.commons.lang3.StringUtils;
  28. import org.springframework.beans.factory.annotation.Autowired;
  29. import org.springframework.beans.factory.annotation.Value;
  30. import org.springframework.stereotype.Service;
  31. import org.springframework.transaction.annotation.Transactional;
  32. import java.text.SimpleDateFormat;
  33. import java.util.*;
  34. @Service
  35. public class BaseComplaintService {
  36. @Autowired
  37. private BaseComplaintDictDao baseComplaintDictDao;
  38. @Autowired
  39. private BaseComplaintDoctorDao baseComplaintDoctorDao;
  40. @Autowired
  41. private BaseDoctorDao baseDoctorDao;
  42. @Autowired
  43. private BaseDoctorHospitalDao baseDoctorHospitalDao;
  44. @Autowired
  45. private HibenateUtils hibenateUtils;
  46. @Autowired
  47. private BaseComplaintDao baseComplaintDao;
  48. @Autowired
  49. private ObjectMapper objectMapper;
  50. @Autowired
  51. private DictHospitalDeptDao dictHospitalDeptDao;
  52. @Autowired
  53. private BaseComplaintOperateDao baseComplaintOperateDao;
  54. @Autowired
  55. private BaseDoctorRoleDao baseDoctorRoleDao;
  56. @Autowired
  57. private BasePatientDao basePatientDao;
  58. @Autowired
  59. private EnterpriseService enterpriseService;
  60. @Autowired
  61. private WlyyHospitalSysDictDao wlyyHospitalSysDictDao;
  62. @Value("${wechat.id}")
  63. private String wxId;
  64. @Value("${wechat.flag}")
  65. private boolean flag;
  66. //修改新增
  67. public BaseComplaintDictDO createOrUpdateDict(String id, String name) {
  68. BaseComplaintDictDO baseComplaintDictDO = new BaseComplaintDictDO();
  69. if (StringUtils.isNoneBlank(id)) {
  70. baseComplaintDictDO = baseComplaintDictDao.findById(id);
  71. baseComplaintDictDO.setName(name);
  72. baseComplaintDictDO.setUpdateTime(new Date());
  73. } else {
  74. baseComplaintDictDO.setIsDel("1");
  75. baseComplaintDictDO.setName(name);
  76. baseComplaintDictDO.setCreateTime(new Date());
  77. }
  78. return baseComplaintDictDao.save(baseComplaintDictDO);
  79. }
  80. //删除
  81. public BaseComplaintDictDO deleteDict(String id) {
  82. BaseComplaintDictDO baseComplaintDictDO = baseComplaintDictDao.findById(id);
  83. if (null != baseComplaintDictDO) {
  84. baseComplaintDictDO.setIsDel("0");
  85. baseComplaintDictDO.setUpdateTime(new Date());
  86. baseComplaintDictDao.save(baseComplaintDictDO);
  87. }
  88. List<BaseComplaintDoctorDO> baseComplaintDoctorDOs = baseComplaintDoctorDao.findbyComplaintId(id);
  89. for (BaseComplaintDoctorDO baseComplaintDoctorDO:baseComplaintDoctorDOs){
  90. baseComplaintDoctorDO.setIsDel("0");
  91. }
  92. baseComplaintDoctorDao.save(baseComplaintDoctorDOs);
  93. return baseComplaintDictDO;
  94. }
  95. public BaseComplaintDictDO findOneDict(String id) {
  96. BaseComplaintDictDO baseComplaintDictDO = baseComplaintDictDao.findById(id);
  97. return baseComplaintDictDO;
  98. }
  99. //查询
  100. public List<BaseComplaintDictDO> findAll(String name) {
  101. List<BaseComplaintDictDO> list = new ArrayList<>();
  102. if (StringUtils.isNoneBlank(name)) {
  103. list = baseComplaintDictDao.findByName(name);
  104. } else {
  105. list = baseComplaintDictDao.findByAll();
  106. }
  107. return list;
  108. }
  109. //新增投诉管理医生
  110. @Transactional
  111. public void createOrUpdateComplainDoctor(String id, String complaintId, String doctorList) throws Exception {
  112. JSONArray jsonArray = JSON.parseArray(doctorList);
  113. for (int i=0;i<jsonArray.size();i++){
  114. JSONObject jsonObject = jsonArray.getJSONObject(i);
  115. String doctor = jsonObject.getString("doctor");
  116. String deptCode = jsonObject.getString("deptCode");
  117. String deptName = "";
  118. String doctorName = "";
  119. BaseComplaintDoctorDO preDoctor= baseComplaintDoctorDao.findbyDoctorAndDel(doctor);
  120. BaseDoctorDO baseDoctorDO = baseDoctorDao.findById(doctor);
  121. List<BaseDoctorRoleDO> baseDoctorRoleDOs = baseDoctorRoleDao.findByDoctorCode(doctor);
  122. if (baseDoctorRoleDOs==null||baseDoctorRoleDOs.size()==0){
  123. BaseDoctorRoleDO baseDoctorRoleDO = new BaseDoctorRoleDO();
  124. baseDoctorRoleDO.setDoctorCode(doctor);
  125. baseDoctorRoleDO.setRoleCode("specialist");
  126. baseDoctorRoleDao.save(baseDoctorRoleDO);
  127. }else if (baseDoctorRoleDOs!=null){
  128. Boolean addRoleFlag=true;//是否为对应医生添加专科医生角色表示 true即为添加
  129. for (BaseDoctorRoleDO baseDoctorRoleDO :baseDoctorRoleDOs){
  130. if (baseDoctorRoleDO.getRoleCode().equalsIgnoreCase("specialist")){
  131. addRoleFlag=false;
  132. }
  133. }
  134. if(addRoleFlag){
  135. BaseDoctorRoleDO baseDoctorRoleDO = new BaseDoctorRoleDO();
  136. baseDoctorRoleDO.setDoctorCode(doctor);
  137. baseDoctorRoleDO.setRoleCode("specialist");
  138. baseDoctorRoleDao.save(baseDoctorRoleDO);
  139. }
  140. }
  141. if (null != baseDoctorDO) {
  142. doctorName = baseDoctorDO.getName();
  143. }
  144. if (preDoctor!=null){
  145. throw new Exception("医生"+doctorName+"已有负责的投诉类型");
  146. }
  147. List<BaseDoctorHospitalDO> baseDoctorHospitalDO = baseDoctorHospitalDao.findByDeptCodeDoctorCode(deptCode, doctor);
  148. if (baseDoctorHospitalDO != null && baseDoctorHospitalDO.size() > 0) {
  149. deptName = baseDoctorHospitalDO.get(0).getDeptName();
  150. }
  151. if (StringUtils.isNoneBlank(id)) {
  152. BaseComplaintDoctorDO baseComplaintDoctorDO = new BaseComplaintDoctorDO();
  153. baseComplaintDoctorDO.setDept(deptCode);
  154. baseComplaintDoctorDO.setDeptName(deptName);
  155. baseComplaintDoctorDO.setComplaintId(id);
  156. baseComplaintDoctorDO.setDoctor(doctor);
  157. baseComplaintDoctorDO.setDoctorName(doctorName);
  158. baseComplaintDoctorDO.setIsDel("1");
  159. baseComplaintDoctorDO.setCreateTime(new Date());
  160. baseComplaintDoctorDao.save(baseComplaintDoctorDO);
  161. }
  162. }
  163. }
  164. //删除管理医生
  165. public BaseComplaintDoctorDO deleteDoctorComplain(String id) {
  166. BaseComplaintDoctorDO baseComplaintDoctorDO = baseComplaintDoctorDao.findByDelAndId(id);
  167. if (null != baseComplaintDoctorDO) {
  168. baseComplaintDoctorDO.setIsDel("0");
  169. baseComplaintDoctorDO.setUpdateTime(new Date());
  170. baseComplaintDoctorDao.save(baseComplaintDoctorDO);
  171. }
  172. return baseComplaintDoctorDO;
  173. }
  174. public MixEnvelop findComplaintDoctor(String doctor,String doctorName, String deptName, String complaintType, Integer page, Integer pageSize) {
  175. String sql = "select t.id as \"id\"," +
  176. " t.complaint_id as \"complaintId\"," +
  177. " t.doctor as \"doctor\"," +
  178. " t.doctor_name as \"doctorName\"," +
  179. " t.dept as \"dept\"," +
  180. " t.dept_name as \"deptName\"," +
  181. " t.is_del as \"isDel\"," +
  182. " t.create_time as \"createTime\"," +
  183. " t.update_time as \"updateTime\"," +
  184. " d.photo as \"photo\"," +
  185. " b.name as \"name\" " +
  186. " from base_complaint_doctor t left join base_complaint_dict b" +
  187. " on t.complaint_id=b.id " +
  188. " left join base_doctor d on t.doctor=d.id where t.is_del='1'";
  189. if (StringUtils.isNoneBlank(doctorName)) {
  190. sql += " and t.doctor_name like '%" + doctorName + "%'";
  191. }
  192. if (StringUtils.isNoneBlank(deptName)) {
  193. sql += " and t.dept_name like '%" + deptName + "%'";
  194. }
  195. if (StringUtils.isNoneBlank(complaintType)) {
  196. sql += " and t.complaint_id = '" + complaintType + "'";
  197. }
  198. if (StringUtils.isNoneBlank(doctor)) {
  199. sql += " and t.doctor = '" + doctor + "'";
  200. }
  201. sql += "order by t.create_time desc";
  202. List<Map<String, Object>> list = hibenateUtils.createSQLQuery(sql, page, pageSize);
  203. List<Map<String, Object>> listCount = hibenateUtils.createSQLQuery(sql);
  204. MixEnvelop mixEnvelop = new MixEnvelop();
  205. mixEnvelop.setTotalCount(listCount == null ? 0 : listCount.size());
  206. mixEnvelop.setPageSize(pageSize);
  207. mixEnvelop.setCurrPage(page);
  208. mixEnvelop.setDetailModelList(list);
  209. return mixEnvelop;
  210. }
  211. public BaseComplaintDoctorDO findOneDoctorComplain(String id) {
  212. BaseComplaintDoctorDO baseComplaintDoctorDO = baseComplaintDoctorDao.findByDelAndId(id);
  213. return baseComplaintDoctorDO;
  214. }
  215. /*
  216. * 患者举报接口
  217. * */
  218. public BaseComplaintDO patiemtComplaint(String json) throws Exception{
  219. WlyyHospitalSysDictDO wlyyHospitalSysDictDO= wlyyHospitalSysDictDao.findById("complaintOpenControl");
  220. if (wlyyHospitalSysDictDO!=null){
  221. if (!"1".equalsIgnoreCase(wlyyHospitalSysDictDO.getDictCode())){
  222. throw new Exception("投诉通道已关闭");
  223. }
  224. }else {
  225. throw new Exception("投诉通道已关闭");
  226. }
  227. BaseComplaintDO baseComplaintDO =objectMapper.readValue(json,BaseComplaintDO.class);
  228. BaseComplaintDictDO baseComplaintDictDO = baseComplaintDictDao.findById(baseComplaintDO.getComplaintId());
  229. if (baseComplaintDictDO!=null){
  230. baseComplaintDO.setComplaintName(baseComplaintDictDO.getName());
  231. }
  232. if (StringUtils.isNoneBlank(baseComplaintDO.getVisitDept())){
  233. DictHospitalDeptDO dictHospitalDeptDO=dictHospitalDeptDao.findByCode(baseComplaintDO.getVisitDept());
  234. if (dictHospitalDeptDO!=null){
  235. baseComplaintDO.setVisitDeptName(dictHospitalDeptDO.getName());
  236. }
  237. }
  238. /*if(StringUtils.isNoneBlank(baseComplaintDO.getPatient())){
  239. BasePatientDO basePatientDO= basePatientDao.findById(baseComplaintDO.getPatient());
  240. if (basePatientDO!=null){
  241. basePatientDO.setIdcardFront(baseComplaintDO.getIdcardFront());
  242. basePatientDO.setIdcardBack(baseComplaintDO.getIdcardBack());
  243. basePatientDao.save(basePatientDO);
  244. }
  245. }*/
  246. baseComplaintDO.setIsDel("1");
  247. baseComplaintDO.setStatus("0");
  248. baseComplaintDO.setCreateTime(new Date());
  249. baseComplaintDO= baseComplaintDao.save(baseComplaintDO);
  250. BaseComplaintOperateLogDO baseComplaintOperateLogDO = new BaseComplaintOperateLogDO();
  251. baseComplaintOperateLogDO.setOperateFrom(baseComplaintDO.getPatient());
  252. baseComplaintOperateLogDO.setStatus("0");
  253. baseComplaintOperateLogDO.setOperateType("投诉提交");
  254. baseComplaintOperateLogDO.setRelationCode(baseComplaintDO.getId());
  255. baseComplaintOperateLogDO.setCreateTime(new Date());
  256. baseComplaintOperateDao.save(baseComplaintOperateLogDO);
  257. try {
  258. List<BaseComplaintDoctorDO> doctorList=baseComplaintDoctorDao.findbyComplaintId(baseComplaintDO.getComplaintId());
  259. for (BaseComplaintDoctorDO baseComplaintDoctorDO:doctorList){
  260. String url="https://hlwyy.xmzsh.com/hlwyy/ims-app-web/#/complaint/detail?id="+baseComplaintDO.getId();
  261. enterpriseService.sendTWMesByDoctor("zsyy",baseComplaintDoctorDO.getDoctor(),"投诉反馈","您收到一条投诉反馈,点击查看。",url);
  262. }
  263. }catch (Exception e){
  264. }
  265. return baseComplaintDao.save(baseComplaintDO);
  266. }
  267. /*
  268. * 医生转交
  269. * */
  270. public BaseComplaintDO passTo(String id,String complaintId,String doctor,String operator){
  271. BaseComplaintDO baseComplaintDO = baseComplaintDao.findOne(id);
  272. BaseComplaintOperateLogDO baseComplaintOperateLogDO = new BaseComplaintOperateLogDO();
  273. String doctorName="";
  274. String complaitTypeName="";
  275. if (null!=baseComplaintDO){
  276. baseComplaintOperateLogDO.setOperateFrom(operator);
  277. baseComplaintOperateLogDO.setOperateTo(doctor);
  278. baseComplaintOperateLogDO.setComplaintTo(complaintId);
  279. baseComplaintOperateLogDO.setComplaintFrom(baseComplaintDO.getComplaintId());
  280. baseComplaintOperateLogDO.setStatus("3");
  281. baseComplaintOperateLogDO.setOperateType("转交");
  282. baseComplaintOperateLogDO.setRelationCode(id);
  283. baseComplaintOperateLogDO.setCreateTime(new Date());
  284. baseComplaintOperateDao.save(baseComplaintOperateLogDO);
  285. /*BaseDoctorDO baseDoctorDO = baseDoctorDao.findById(doctor);
  286. if (null != baseDoctorDO) {
  287. doctorName=baseDoctorDO.getName();
  288. baseComplaintDO.setAcceptorName(doctorName);
  289. }
  290. baseComplaintDO.setAcceptor(doctor);*/
  291. baseComplaintDO.setComplaintId(complaintId);
  292. BaseComplaintDictDO baseComplaintDictDO = baseComplaintDictDao.findById(complaintId);
  293. if (baseComplaintDictDO!=null){
  294. complaitTypeName=baseComplaintDictDO.getName();
  295. baseComplaintDO.setComplaintName(complaitTypeName);
  296. }
  297. baseComplaintDO= baseComplaintDao.save(baseComplaintDO);
  298. try {
  299. List<BaseComplaintDoctorDO> doctorList=baseComplaintDoctorDao.findbyComplaintId(baseComplaintDO.getComplaintId());
  300. for (BaseComplaintDoctorDO baseComplaintDoctorDO:doctorList){
  301. String url="https://hlwyy.xmzsh.com/hlwyy/ims-app-web/#/complaint/detail?id="+baseComplaintDO.getId();
  302. enterpriseService.sendTWMesByDoctor("zsyy",baseComplaintDoctorDO.getDoctor(),"投诉反馈","您收到一条投诉反馈,点击查看。",url);
  303. }
  304. }catch (Exception e){
  305. }
  306. return baseComplaintDO;
  307. }
  308. return null;
  309. }
  310. //接受投诉
  311. public BaseComplaintDO doctorAccept(String id,String doctor) throws Exception{
  312. BaseComplaintDO baseComplaintDO = baseComplaintDao.findOne(id);
  313. if (baseComplaintDO!=null){
  314. baseComplaintDO.setStatus("1");
  315. BaseDoctorDO baseDoctorDO = baseDoctorDao.findById(doctor);
  316. if (null != baseDoctorDO) {
  317. baseComplaintDO.setAcceptorName(baseDoctorDO.getName());
  318. }
  319. baseComplaintDO.setAcceptor(doctor);
  320. baseComplaintDO.setAcceptTime(new Date());
  321. baseComplaintDao.save(baseComplaintDO);
  322. BaseComplaintOperateLogDO baseComplaintOperateLogDO = new BaseComplaintOperateLogDO();
  323. baseComplaintOperateLogDO.setOperateFrom(doctor);
  324. baseComplaintOperateLogDO.setStatus("1");
  325. baseComplaintOperateLogDO.setOperateType("接受");
  326. baseComplaintOperateLogDO.setRelationCode(id);
  327. baseComplaintOperateLogDO.setCreateTime(new Date());
  328. baseComplaintOperateDao.save(baseComplaintOperateLogDO);
  329. }/*else if ("1".equalsIgnoreCase(baseComplaintDO.getStatus())){
  330. throw new Exception("该工单已被接受");
  331. }else {
  332. throw new Exception("该工单已被处理完成");
  333. }*/
  334. return baseComplaintDO;
  335. }
  336. //反馈投诉
  337. public BaseComplaintDO dealComplaint(String id,String operator,String content,String imgUrl ,String deptCode) throws Exception{
  338. BaseComplaintDO baseComplaintDO = baseComplaintDao.findOne(id);
  339. if (baseComplaintDO!=null){
  340. baseComplaintDO.setDealTime(new Date());
  341. baseComplaintDO.setFeedBack(content);
  342. baseComplaintDO.setFeedImg(imgUrl);
  343. baseComplaintDO.setOperator(operator);
  344. baseComplaintDO.setStatus("2");
  345. BaseDoctorDO baseDoctorDO = baseDoctorDao.findById(operator);
  346. if (null != baseDoctorDO) {
  347. baseComplaintDO.setOperatorName(baseDoctorDO.getName());
  348. }
  349. baseComplaintDO.setOperatorDept(deptCode);
  350. List<BaseDoctorHospitalDO> baseDoctorHospitalDO = baseDoctorHospitalDao.findByDeptCodeDoctorCode(deptCode, operator);
  351. if (baseDoctorHospitalDO != null && baseDoctorHospitalDO.size() > 0) {
  352. baseComplaintDO.setOperatorDeptName(baseDoctorHospitalDO.get(0).getDeptName());
  353. }
  354. baseComplaintDao.save(baseComplaintDO);
  355. BaseComplaintOperateLogDO baseComplaintOperateLogDO = new BaseComplaintOperateLogDO();
  356. baseComplaintOperateLogDO.setOperateFrom(operator);
  357. baseComplaintOperateLogDO.setStatus("2");
  358. baseComplaintOperateLogDO.setOperateType("反馈");
  359. baseComplaintOperateLogDO.setRelationCode(id);
  360. baseComplaintOperateLogDO.setCreateTime(new Date());
  361. baseComplaintOperateDao.save(baseComplaintOperateLogDO);
  362. }/*else if ("2".equalsIgnoreCase(baseComplaintDO.getStatus())){
  363. throw new Exception("该工单已被处理完成");
  364. }else if ("0".equalsIgnoreCase(baseComplaintDO.getStatus())){
  365. throw new Exception("该工单未被接收");
  366. }*/
  367. return baseComplaintDO;
  368. }
  369. //查询投诉列表
  370. public MixEnvelop findComplaintList(String role,String doctor,String status,String patientName,String patientId,String keyWord,String complaintId,
  371. String startTime,String endTime,Integer page ,Integer pageSize){
  372. MixEnvelop mixEnvelop = new MixEnvelop();
  373. Boolean queryAll=false;
  374. if ("admin".equalsIgnoreCase(role)){
  375. queryAll=true;
  376. }
  377. String sql="select t.id as \"id\"," +
  378. " t.complaint_id as \"complaintId\"," +
  379. " t.complaint_name as \"complaintName\"," +
  380. " t.complaint_content as \"complaintContent\"," +
  381. " t.visit_type as \"visitType\"," +
  382. " case t.visit_type when '1' then '门诊' else '住院' end as \"visitTypeName\"," +
  383. " t.visit_time as \"visitTime\"," +
  384. " t.visit_dept as \"visitDept\"," +
  385. " t.visit_dept_name as \"visitDeptName\"," +
  386. " t.adm_no as \"admNo\"," +
  387. " t.patient as \"patient\"," +
  388. " t.patient_name as \"patientName\"," +
  389. " t.patient_idcard as \"patientIdcard\"," +
  390. " t.idcard_front as \"idcardFront\"," +
  391. " t.idcard_back as \"idcardBack\"," +
  392. " t.img_url as \"imgUrl\"," +
  393. " t.is_del as \"isDel\"," +
  394. " t.status as \"status\"," +
  395. " t.create_time as \"createTime\"," +
  396. " t.accept_time as \"acceptTime\"," +
  397. " t.deal_time as \"dealTime\"," +
  398. " t.operator_dept as \"operatorDept\"," +
  399. " t.operator_dept_name as \"operatorDeptName\"," +
  400. " t.operator as \"operator\"," +
  401. " t.operator_name as \"operatorName\"," +
  402. " t.feed_back as \"feedBack\"," +
  403. " t.feed_img as \"feedImg\"," +
  404. " t.acceptor as \"acceptor\"," +
  405. " t.mobile as \"mobile\"," +
  406. " t.acceptor_name as \"acceptorName\"" +
  407. "from base_complaint t " +
  408. " left join base_patient b on t.patient=b.id" +
  409. " where t.is_del=1";
  410. if (!queryAll){
  411. BaseComplaintDoctorDO baseComplaintDoctorDO= baseComplaintDoctorDao.findbyDoctorAndDel(doctor);
  412. /*List<BaseComplaintOperateLogDO> logList =baseComplaintOperateDao.findbyOperateFrom(doctor);
  413. String types= "";
  414. if (logList!=null&&logList.size()>0){
  415. for (int i=0;i<logList.size();i++){
  416. if (i==logList.size()-1){
  417. types+=logList.get(i).getComplaintTo();
  418. }else {
  419. types+=logList.get(i).getComplaintTo()+",";
  420. }
  421. }
  422. }*/
  423. String complaint="";
  424. if (baseComplaintDoctorDO!=null){
  425. complaint=baseComplaintDoctorDO.getComplaintId();
  426. }
  427. //complaint=complaint+","+types;
  428. if (StringUtils.isNoneBlank(complaint)){
  429. //sql+=" and t.complaint_id in ('"+complaint.replace(",","','")+"')";
  430. sql+=" and t.complaint_id='"+complaint+"'";
  431. }else {
  432. return null;
  433. }
  434. if (!StringUtils.isNoneBlank(status)){
  435. sql+=" and t.status !='-1'";
  436. }
  437. }else {
  438. if (StringUtils.isNoneBlank(complaintId)){
  439. //sql+=" and t.complaint_id in ('"+complaint.replace(",","','")+"')";
  440. sql+=" and t.complaint_id='"+complaintId+"'";
  441. }
  442. }
  443. if (StringUtils.isNoneBlank(status)){
  444. sql+=" and t.status ='"+status+"'";
  445. }
  446. if (StringUtils.isNoneBlank(patientName)){
  447. sql+=" and t.patient_name like '%"+patientName+"%'";
  448. }
  449. if (StringUtils.isNoneBlank(patientId)){
  450. sql+=" and t.patient ='"+patientId+"'";
  451. }
  452. if (StringUtils.isNoneBlank(keyWord)){
  453. sql+=" and (t.patient_idcard like '%"+keyWord+"%' or t.patient_name like '%"+keyWord+"%')";
  454. }
  455. if (StringUtils.isNotBlank(startTime)){
  456. if("xm_ykyy_wx".equals(wxId)){
  457. if (flag){
  458. sql+=" and t.create_time > '"+startTime+"'";
  459. }else {
  460. sql+=" and t.create_time > to_date('" + startTime + "', 'yyyy-mm-dd hh24:mi:ss') ";
  461. }
  462. }else{
  463. sql+=" and t.create_time > '"+startTime+"'";
  464. }
  465. }
  466. if (StringUtils.isNotBlank(endTime)){
  467. if("xm_ykyy_wx".equals(wxId)){
  468. if (flag){
  469. sql+=" and t.create_time<='" + endTime + "'";
  470. }else {
  471. sql+=" and t.create_time<= to_date('" + endTime + "','yyyy-mm-dd hh24:mi:ss')";
  472. }
  473. }else{
  474. sql+=" and t.create_time<='" + endTime + "'";
  475. }
  476. }
  477. sql+=" order by t.create_time desc ";
  478. List<Map<String,Object>> list = hibenateUtils.createSQLQuery(sql,page,pageSize);
  479. String sqlcount = "SELECT COUNT(1) AS \"total\" FROM ("+sql+") q";
  480. Long count = 0L;
  481. List<Map<String,Object>> total = hibenateUtils.createSQLQuery(sqlcount);
  482. if(total!=null){
  483. //mysql 与 Oracle 聚合函数返回类型不一致,需要判断装换
  484. count = hibenateUtils.objTransformLong(total.get(0).get("total"));
  485. }
  486. mixEnvelop.setTotalCount(count.intValue());
  487. mixEnvelop.setDetailModelList(list);
  488. mixEnvelop.setPageSize(pageSize);
  489. mixEnvelop.setCurrPage(page);
  490. return mixEnvelop;
  491. }
  492. public BaseComplaintDO findOnePaitentComplaint(String id){
  493. BaseComplaintDO baseComplaintDO = baseComplaintDao.findOne(id);
  494. BasePatientDO basePatientDO=basePatientDao.findById(baseComplaintDO.getPatient());
  495. if (null!=basePatientDO){
  496. baseComplaintDO.setMobile(basePatientDO.getMobile());
  497. }
  498. WlyyHospitalSysDictDO wlyyHospitalSysDictDO =wlyyHospitalSysDictDao.findById("latestFeedBackTime");
  499. Integer timeOut=15;
  500. if (wlyyHospitalSysDictDO!=null){
  501. timeOut =Integer.parseInt(wlyyHospitalSysDictDO.getDictValue());
  502. }
  503. long latestDate=baseComplaintDO.getCreateTime().getTime()+timeOut*24*60*60*1000;
  504. baseComplaintDO.setLatestFeedTime( (new Date(latestDate)));
  505. baseComplaintDO.setVisitTypeName(baseComplaintDO.getVisitType().equalsIgnoreCase("1")?"门诊":"住院");
  506. return baseComplaintDO;
  507. }
  508. //查询投诉列表
  509. public MixEnvelop findPatientComplaintList(String status,String patientName,String patientId,
  510. String startTime,String endTime,String complaintType,Integer page ,Integer pageSize){
  511. MixEnvelop mixEnvelop = new MixEnvelop();
  512. String sql="select t.id as \"id\"," +
  513. " t.complaint_id as \"complaintId\"," +
  514. " t.complaint_name as \"complaintName\"," +
  515. " t.complaint_content as \"complaintContent\"," +
  516. " t.visit_type as \"visitType\"," +
  517. " case t.visit_type when '1' then '门诊' else '住院' end as \"visitTypeName\"," +
  518. " t.visit_time as \"visitTime\"," +
  519. " t.visit_dept as \"visitDept\"," +
  520. " t.visit_dept_name as \"visitDeptName\"," +
  521. " t.adm_no as \"admNo\"," +
  522. " t.patient as \"patient\"," +
  523. " t.patient_name as \"patientName\"," +
  524. " t.patient_idcard as \"patientIdcard\"," +
  525. " t.idcard_front as \"idcardFront\"," +
  526. " t.idcard_back as \"idcardBack\"," +
  527. " t.img_url as \"imgUrl\"," +
  528. " t.is_del as \"isDel\"," +
  529. " t.status as \"status\"," +
  530. " t.create_time as \"createTime\"," +
  531. " t.accept_time as \"acceptTime\"," +
  532. " t.deal_time as \"dealTime\"," +
  533. " t.operator_dept as \"operatorDept\"," +
  534. " t.operator_dept_name as \"operatorDeptName\"," +
  535. " t.operator as \"operator\"," +
  536. " t.operator_name as \"operatorName\"," +
  537. " t.feed_back as \"feedBack\"," +
  538. " t.feed_img as \"feedImg\"," +
  539. " t.acceptor as \"acceptor\"," +
  540. " t.mobile as \"mobile\"," +
  541. " t.acceptor_name as \"acceptorName\"" +
  542. " from base_complaint t " +
  543. " left join base_patient b on t.patient=b.id" +
  544. " where t.is_del=1";
  545. if (StringUtils.isNoneBlank(status)){
  546. sql+=" and t.status ='"+status+"'";
  547. }
  548. if (StringUtils.isNoneBlank(patientName)){
  549. sql+=" and t.patient_name like '%"+patientName+"%'";
  550. }
  551. if (StringUtils.isNoneBlank(patientId)){
  552. sql+=" and t.patient ='"+patientId+"'";
  553. }
  554. if (StringUtils.isNoneBlank(complaintType)){
  555. sql+=" and t.complaint_id ='"+complaintType+"'";
  556. }
  557. if (StringUtils.isNotBlank(startTime)){
  558. if("xm_ykyy_wx".equals(wxId)){
  559. if (flag){
  560. sql+=" and t.create_time > '"+startTime+"'";
  561. }else {
  562. sql+=" and t.create_time > to_date('" + startTime + "', 'yyyy-mm-dd hh24:mi:ss') ";
  563. }
  564. }else{
  565. sql+=" and t.create_time > '"+startTime+"'";
  566. }
  567. }
  568. if (StringUtils.isNotBlank(endTime)){
  569. if("xm_ykyy_wx".equals(wxId)){
  570. if (flag){
  571. sql+=" and t.create_time<='" + endTime + "'";
  572. }else {
  573. sql+=" and t.create_time<= to_date('" + endTime + "','yyyy-mm-dd hh24:mi:ss')";
  574. }
  575. }else{
  576. sql+=" and t.create_time<='" + endTime + "'";
  577. }
  578. }
  579. sql+=" order by t.create_time desc ";
  580. List<Map<String,Object>> list = hibenateUtils.createSQLQuery(sql,page,pageSize);
  581. String sqlcount = "SELECT COUNT(1) AS \"total\" FROM ("+sql+") q";
  582. Long count = 0L;
  583. List<Map<String,Object>> total = hibenateUtils.createSQLQuery(sqlcount);
  584. if(total!=null){
  585. //mysql 与 Oracle 聚合函数返回类型不一致,需要判断装换
  586. count = hibenateUtils.objTransformLong(total.get(0).get("total"));
  587. }
  588. mixEnvelop.setTotalCount(count.intValue());
  589. mixEnvelop.setDetailModelList(list);
  590. mixEnvelop.setPageSize(pageSize);
  591. mixEnvelop.setCurrPage(page);
  592. return mixEnvelop;
  593. }
  594. /*
  595. * 查询投诉数量*/
  596. public Map<String,Object> findComplaintCount(String doctor,String role){
  597. BaseComplaintDoctorDO baseComplaintDoctorDO=baseComplaintDoctorDao.findbyDoctorAndDel(doctor);
  598. Integer complaints=0;
  599. Integer recieve=0;
  600. Integer deal=0;
  601. Integer cacel=0;
  602. if (baseComplaintDoctorDO!=null){
  603. Boolean queryAll=false;
  604. if ("admin".equalsIgnoreCase(role)){
  605. queryAll=true;
  606. }
  607. if (!queryAll){
  608. complaints=baseComplaintDao.getCountByStatusAndComplaintId("0",baseComplaintDoctorDO.getComplaintId());
  609. recieve=baseComplaintDao.getCountByStatusAndComplaintId("1",baseComplaintDoctorDO.getComplaintId());
  610. deal=baseComplaintDao.getCountByStatusAndComplaintId("2",baseComplaintDoctorDO.getComplaintId());
  611. //cacel=baseComplaintDao.getCountByStatusAndComplaintId("-1",baseComplaintDoctorDO.getComplaintId());
  612. }else {
  613. complaints=baseComplaintDao.getCountByStatus("0");
  614. recieve=baseComplaintDao.getCountByStatus("1");
  615. deal=baseComplaintDao.getCountByStatus("2");
  616. cacel=baseComplaintDao.getCountByStatus("-1");
  617. }
  618. }
  619. Integer total = complaints+recieve+deal+cacel;
  620. Map map=new HashMap();
  621. map.put("complaints",complaints);
  622. map.put("recieve",recieve);
  623. map.put("deal",deal);
  624. map.put("cacel",cacel);
  625. map.put("total",total);
  626. return map;
  627. }
  628. /*
  629. * 查询投诉数量*/
  630. public Map<String,Object> findComplaintCountPatient(String patient){
  631. Integer complaints=0;
  632. Integer recieve=0;
  633. Integer deal=0;
  634. Integer cacel=0;
  635. complaints=baseComplaintDao.getCountByStatusByPatient("0",patient);
  636. recieve=baseComplaintDao.getCountByStatusByPatient("1",patient);
  637. deal=baseComplaintDao.getCountByStatusByPatient("2",patient);
  638. cacel=baseComplaintDao.getCountByStatusByPatient("-1",patient);
  639. Integer total = complaints+recieve+deal+cacel;
  640. Map map=new HashMap();
  641. map.put("complaints",complaints);
  642. map.put("recieve",recieve);
  643. map.put("deal",deal);
  644. map.put("cacel",cacel);
  645. map.put("total",total);
  646. return map;
  647. }
  648. public BaseComplaintDO cancelPaitentComplaint(String id,String patient) throws Exception{
  649. BaseComplaintDO baseComplaintDO = baseComplaintDao.findOne(id);
  650. if (baseComplaintDO!=null){
  651. if ("0".equalsIgnoreCase(baseComplaintDO.getStatus())){
  652. baseComplaintDO.setStatus("-1");
  653. baseComplaintDO=baseComplaintDao.save(baseComplaintDO);
  654. BaseComplaintOperateLogDO baseComplaintOperateLogDO = new BaseComplaintOperateLogDO();
  655. baseComplaintOperateLogDO.setOperateFrom(patient);
  656. baseComplaintOperateLogDO.setStatus("-1");
  657. baseComplaintOperateLogDO.setOperateType("居民撤销投诉");
  658. baseComplaintOperateLogDO.setRelationCode(baseComplaintDO.getId());
  659. baseComplaintOperateLogDO.setCreateTime(new Date());
  660. baseComplaintOperateDao.save(baseComplaintOperateLogDO);
  661. }else {
  662. throw new Exception("不允许撤销");
  663. }
  664. }
  665. return baseComplaintDO;
  666. }
  667. public List<Map<String,Object>> findComplaintOperateLog(String complaintId){
  668. String sql ="select t.id as \"id\"," +
  669. " p.name as \"complaintNameFrom\" ," +
  670. " n.name as \"complaintNameto\", " +
  671. " t.operate_from as \"operateFrom\" ," +
  672. " t.operate_to as \"operateTo\" ," +
  673. " t.cancel_by as \"cancelBy\", " +
  674. " t.operate_type as \"operateType\", " +
  675. " t.status as \"status\", " +
  676. " t.create_time as \"createTime\" ," +
  677. " t.relation_code as \"relationCode\" " +
  678. " from base_complaint_operate_log t left join base_complaint c" +
  679. " on t.relation_code=c.id" +
  680. " left join base_complaint_dict p on t.complaint_from= p.id" +
  681. " left join base_complaint_dict n on t.complaint_to=n.id where 1=1 " ;
  682. if (StringUtils.isNoneBlank(complaintId)){
  683. sql+=" and t.relation_code='"+complaintId+"'";
  684. }
  685. sql+=" order by t.create_time desc";
  686. List<Map<String,Object>> list = hibenateUtils.createSQLQuery(sql);
  687. List<WlyyHospitalSysDictDO> typeList=wlyyHospitalSysDictDao.findByDictName("complaintStatus");
  688. for (Map<String,Object> map:list){
  689. if (map.get("operateFrom")!=null){
  690. if (map.get("status")!=null){
  691. for (WlyyHospitalSysDictDO wlyyHospitalSysDictDO:typeList){
  692. if (map.get("status").toString().equalsIgnoreCase(wlyyHospitalSysDictDO.getDictCode())){
  693. map.put("operateType",wlyyHospitalSysDictDO.getDictValue());
  694. }
  695. }
  696. if ("0".equalsIgnoreCase(map.get("status").toString())||"-1".equalsIgnoreCase(map.get("status").toString())){
  697. BasePatientDO basePatientDO = basePatientDao.findById(map.get("operateFrom").toString());
  698. if (basePatientDO!=null){
  699. map.put("operateFromName",basePatientDO.getName());
  700. }
  701. }else {
  702. BaseDoctorDO baseDoctorDO= baseDoctorDao.findById(map.get("operateFrom").toString());
  703. if (baseDoctorDO!=null){
  704. map.put("operateFromName",baseDoctorDO.getName());
  705. }
  706. List<BaseDoctorHospitalDO> baseDoctorHospitalDO= baseDoctorHospitalDao.findByDoctorCode(map.get("operateFrom").toString());
  707. if (baseDoctorHospitalDO!=null&&baseDoctorHospitalDO.size()>0){
  708. map.put("operateFromDeptName",baseDoctorHospitalDO.get(0).getDeptName());
  709. }
  710. }
  711. }
  712. }
  713. if (map.get("operateTo")!=null){
  714. BaseDoctorDO baseDoctorDO= baseDoctorDao.findById(map.get("operateTo").toString());
  715. if (baseDoctorDO!=null){
  716. map.put("operateToName",baseDoctorDO.getName());
  717. }
  718. List<BaseDoctorHospitalDO> baseDoctorHospitalDO= baseDoctorHospitalDao.findByDoctorCode(map.get("operateTo").toString());
  719. if (baseDoctorHospitalDO!=null&&baseDoctorHospitalDO.size()>0){
  720. map.put("operateToDeptName",baseDoctorHospitalDO.get(0).getDeptName());
  721. }
  722. }
  723. }
  724. return list;
  725. }
  726. }