ChronicInfo.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. import {connect} from 'react-redux';
  2. import ChronicInfo from '../components/ChronicInfo';
  3. import {SHOW_TABLE_LIST,HIDE_TABLE_LIST, SET_CHRONIC_PUSHS,TOGGLE_CHRONIC_INFO} from '@store/types/pushMessage';
  4. import {getTableList,getScaleInfo,getConceptDetail} from '../store/async-actions/pushMessage';
  5. import {ADD_ASSESS_ITEMS,SET_SAVE_ASSESS_DATA,SET_CHRONIC_CALCU_RESULT,ADD_WHOLE_SCALE_ITEMS,SET_CALCU_VALUES} from "@types/assessResult";
  6. import {saveMessage} from "../store/async-actions/print";
  7. import {saveClickNum} from '@store/async-actions/homePage';
  8. import { getFormulaResult } from '@store/async-actions/fetchModules'
  9. import {deepClone} from '@utils/tools';
  10. import Notify from '@commonComp/Notify';
  11. import {dragBox} from '@utils/drag';
  12. function mapStateToProps(state){
  13. const {pushMessage,assessResult} = state;
  14. return{
  15. chronicMagItem: state.diagnosticList.chronicMagItem,//慢病疾病
  16. //data:pushMessage.chronicPushItems, //慢病右侧推送
  17. tableList: pushMessage.tableList,
  18. showList: pushMessage.showList,
  19. showHide: pushMessage.showHide,
  20. scaleInfo: pushMessage.scaleInfo,//量表内容
  21. chronicDesease:state.mainSuit.chronicDesease,//主诉存的慢病
  22. update:assessResult.update1,
  23. formulaResult:pushMessage.formulaResult, //量表信息
  24. indexs:assessResult.wholeIndexs,
  25. wholeResults:assessResult.wholeResults, //整体评估可能结果
  26. calcuResult:assessResult.calcuResult, //计算公式结果
  27. calcuValues:assessResult.calcuValues, //计算公式填的值
  28. wholeScaleItems:assessResult.wholeScaleItems, //全部量表中已加入病例的量表
  29. addedScaleIds:assessResult.addedScaleIds, //已加入的量表id
  30. slideUp:pushMessage.slideUp, //是否收起指标推送模块
  31. }
  32. }
  33. function mapDispatchToProps(dispatch){
  34. return {
  35. toggleSlide(flag){
  36. dispatch({
  37. type:TOGGLE_CHRONIC_INFO,
  38. flag
  39. });
  40. },
  41. getTableList(name){
  42. dispatch(getTableList(name))
  43. // dispatch({type:SHOW_TABLE_LIST})
  44. },
  45. hideList(param,item){
  46. dispatch({
  47. type:SHOW_TABLE_LIST,
  48. name:param.name,
  49. value:param.value,
  50. item:item?Object.assign({},item):undefined
  51. })
  52. if(!param.value){
  53. dragBox('dragModalWrap','dragModalTitle','del')
  54. }
  55. },
  56. getScaleInfo(item){
  57. dispatch(getScaleInfo(item))
  58. },
  59. addAssessItem(row,pIndex,i){ //加入评估记录
  60. let obj = Object.assign({},row);
  61. const it = obj.details[i];
  62. dispatch({
  63. type:ADD_ASSESS_ITEMS,
  64. data:obj,
  65. index:pIndex,
  66. subIndex:i,
  67. id:it.type==1?it.content.conceptId:undefined, //只有量表需要记录id,去重用
  68. })
  69. },
  70. addScaleItems(obj,id){
  71. dispatch({
  72. type:ADD_WHOLE_SCALE_ITEMS,
  73. data:obj,
  74. id
  75. })
  76. },
  77. //保存管理评估
  78. saveAssessInfos(obj,flg,noSave){ //noSave未true则不调页面保存接口
  79. dispatch(Object.assign({},obj,{type:SET_SAVE_ASSESS_DATA}));
  80. if(!noSave){
  81. dispatch(saveClickNum);
  82. if(flg != 1 && flg != 2){
  83. dispatch(() => saveMessage())
  84. }
  85. }
  86. },
  87. savePossibleResult(data){
  88. dispatch({
  89. type: 'SAVE_POSSIBLE_RESULT',
  90. wholeResults: data
  91. })
  92. },
  93. //设置量表推送内容
  94. setChronicPush(data,id,calcuItem) {
  95. dispatch({
  96. type: SET_CHRONIC_PUSHS,
  97. data: data
  98. });
  99. dispatch({
  100. type:SET_CALCU_VALUES,
  101. data:calcuItem,
  102. id
  103. });
  104. },
  105. // 计算公式计算
  106. calcuFormula(param) {
  107. getFormulaResult(param).then((res)=>{
  108. if(+res.data.code==0){
  109. const result = res.data.data.result;
  110. dispatch({
  111. type: SET_CHRONIC_CALCU_RESULT,
  112. result:deepClone(result),
  113. id:param.disId
  114. });
  115. dispatch({
  116. type:SET_CALCU_VALUES,
  117. data:param.data.content.details,
  118. id:param.disId
  119. })
  120. }else{
  121. Notify.error(res.data.msg||'计算没有结果返回');
  122. }
  123. })
  124. },
  125. // 获取量表静态知识
  126. getInfomation(item){
  127. dispatch(getConceptDetail(item));
  128. }
  129. }
  130. }
  131. const ChronicInfoContainer = connect(mapStateToProps,mapDispatchToProps)(ChronicInfo);
  132. export default ChronicInfoContainer;