CurrentIll.js 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. import React from 'react';
  2. import { connect } from 'react-redux';
  3. import CurrentIll from '@components/CurrentIll';
  4. import {INSERT_PROCESS,SET_CURRENT_DATA,SETCURRENTTEXTMODEVALUE,SET_LABEL_MODULE,SELECT_SEARCHDATA,CLEAR_CURRENT_EDIT,SAVE_CURR_FREE} from '@store/types/currentIll';
  5. import {pushMessage} from '../store/async-actions/pushContainer';
  6. import {getModules} from '../store/async-actions/fetchModules.js';
  7. import {HIDE,RESET,CLICKCOUNT,ISREAD,SETDROPSHOW,HIDEDROP,SET_CURRENT_MODULE} from '@store/types/homePage';
  8. import {billing,getMRAnalyse} from '@store/async-actions/pushMessage';
  9. import {getModule} from '@store/async-actions/fetchModules';
  10. import {didPushParamChange,filterDataArr} from '@utils/tools';
  11. import {Notify} from '@commonComp';
  12. import store from '@store';
  13. function mapStateToProps(state) {
  14. const {homePage,currentIll,mainSuit,diagnosticList,typeConfig} = state;
  15. const hasMain = filterDataArr(mainSuit.saveText);
  16. return {
  17. data:currentIll.data,//主诉模板
  18. emptyData:currentIll.emptyData,//空模板
  19. searchData:currentIll.searchDatas,//搜索结果
  20. focusIndex:currentIll.focusIndex,
  21. processModule:currentIll.processModule,//病程变化模板
  22. showArr:homePage.showDrop,
  23. span:currentIll.span,
  24. update:currentIll.update,//用于更新
  25. mainText:mainSuit.saveText,//主诉选中的数据
  26. mainData:mainSuit.data,//主诉使用的模板
  27. symptomFeature:mainSuit.symptomFeature,//主诉分词数据
  28. moduleNum:mainSuit.moduleNum,//主诉使用的模板
  29. type: typeConfig.mode,
  30. mainIds:mainSuit.mainIds,//主诉症状选中的id(去重用)
  31. mainTailIds:mainSuit.mainTailIds,//主诉症状选中的id(去重用)
  32. totalHide: homePage.totalHide,
  33. saveText:currentIll.saveText,
  34. editClear:currentIll.editClear,
  35. symptomIds:currentIll.symptomIds,//症状id,去重用
  36. isRead:homePage.isRead,
  37. fuzhen:diagnosticList.mainSuitStr,//诊断第一个复诊值
  38. allModules:homePage.allModules,
  39. // isChronic:!!diagnosticList.chronicMagItem,
  40. isChronic:mainSuit.chronicDesease?mainSuit.chronicDesease:diagnosticList.chronicMagItem,
  41. readMode:typeConfig.readMode, //回读回来的模式(与当前模式并存)
  42. hasMain, //是否有主诉
  43. typeConfig: state.typeConfig
  44. }
  45. }
  46. function mapDispatchToProps(dispatch) {
  47. return {
  48. insertProcess(obj,allModules){//点击病程变化
  49. const storeState = store.getState()
  50. const {moduleName, moduleObj} = storeState.homePage
  51. // 埋点dispatch
  52. dispatch({
  53. type:CLICKCOUNT,
  54. data:{id:obj.id},
  55. clickType:'单击',
  56. num:1
  57. });
  58. dispatch({
  59. type:INSERT_PROCESS,
  60. });
  61. if(moduleName != '现病史') {
  62. dispatch({
  63. type: SET_CURRENT_MODULE,
  64. moduleName: '现病史'
  65. });
  66. dispatch(getMRAnalyse());
  67. }
  68. dispatch({
  69. type:ISREAD
  70. })
  71. },
  72. async setData(info){//设置现病史使用模板
  73. // let idsArr = info.mainIds;
  74. let idsArr = info.mainTailIds.filter((it,i)=>{return it});
  75. // let ids = idsArr.join(",");
  76. let labelModule = await getModules(idsArr);
  77. if(labelModule.data.code==0){//根据id获取标签模板
  78. dispatch({
  79. type:SET_LABEL_MODULE,
  80. data:labelModule.data.data
  81. })
  82. }
  83. dispatch({
  84. type:SET_CURRENT_DATA,
  85. info
  86. })
  87. //右侧推送
  88. setTimeout(function(){ //延迟待确定后的数据更新后推送,避免获取的参数还是旧的
  89. if(didPushParamChange()){ //操作后内容有变化才推送
  90. dispatch(billing('',2)); //参数意义:点到现病史时查体无数据则提前获取查体模板,避免点查体时模板返回慢
  91. }
  92. },500);
  93. },
  94. pushMessage: (data) => {
  95. dispatch(() => pushMessage(data))
  96. },
  97. //文本模式下推送
  98. fetchPushInfos(){
  99. //调右侧推送
  100. if(didPushParamChange()) {
  101. dispatch(billing());
  102. }
  103. },
  104. handleInput(obj){ //文本模式值保存
  105. dispatch({
  106. type:SETCURRENTTEXTMODEVALUE,
  107. text:obj.text
  108. })
  109. },
  110. fetchModules(param){
  111. const {id,name,index,span,conceptId} = param;
  112. getModule(id).then((res)=>{
  113. if(res.data.code=='0'){
  114. dispatch({
  115. type:SELECT_SEARCHDATA,
  116. index,
  117. name,
  118. data: res.data.data,
  119. span,
  120. isReplace:false,
  121. conceptId
  122. });
  123. dispatch({
  124. type:ISREAD
  125. });
  126. /*
  127. * 选中后推送的入参可能变了,如输入心率搜索出心率不齐,
  128. * 500ms内心率不齐标签未选中,系统会推送入参心率,
  129. * 此时推送结果可能影响查体高亮结果且并不准确,
  130. * 所以选中后要重新推送
  131. * */
  132. if(didPushParamChange()){ //操作后内容有变化才推送
  133. dispatch(billing());
  134. }
  135. }
  136. });
  137. },
  138. changeEditIll(bool){
  139. dispatch({
  140. type:CLEAR_CURRENT_EDIT,
  141. editClear:bool
  142. })
  143. },
  144. freeText(item){//自由输入
  145. dispatch({
  146. type: SAVE_CURR_FREE,
  147. data:item
  148. });
  149. //右侧推送
  150. setTimeout(function(){
  151. if(didPushParamChange()){
  152. dispatch(billing());
  153. }
  154. },500);
  155. },
  156. hideAllDrop(){
  157. dispatch({
  158. type:HIDEDROP
  159. });
  160. },
  161. }
  162. }
  163. const CurrentIllContainer = connect(
  164. mapStateToProps,
  165. mapDispatchToProps
  166. )(CurrentIll);
  167. export default CurrentIllContainer;