currentIll.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. // 现病史
  2. import {SET_CURRENT,CURRENT_CONFIRM,INSERT_PROCESS,SET_CURRENT_DATA,SET_LABEL_MODULE,SETMAINCHECKBOX,
  3. CURRENT_RADIO,CURRENT_NUMBER,CURRENT_TEXT_LABEL,CLEAR_CURRENT_ILL,SETTEXTMODEVALUE,CURRENT_GET_BIGDATAPUSH,CURRENT_CLEAR,
  4. SET_CURRENT_SEARCH,SETCURRENTTEXT,CURRENT_FOCUS_INDEX,SELECT_SEARCHDATA,CLEAR_CURRENT_EDIT,CURRENTADDLABELITEM,
  5. SETCURRENTINPUT,DEL_CURRENT,CURRENT_TEXT_LABEL_NUMBER,REMOVE_CURR_ID,CURRENT_MUL,DEL_CURRENT_LABLE,SET_RADIO_INPUT_VALUE,CURRENT_CHRONIC} from '../types/currentIll';
  6. import {confirm,insertProcess,setData,setCheckBox,setRadioValue,setNumberValue,changeLabelVal,clearCurrentIll,
  7. setTextModeValue,setModule,bigDataSymptom,setCheckText,insertLabelData,clearCurrentEdit,addLabelItem,setInputLabel,
  8. backspaceText,changeNumLabelVal,removeId,multipleComfirn,delSingleLable,setRadioInputValue,fillChronicModule} from '../actions/currentIll';
  9. const initState = {
  10. moduleData:[],
  11. data:[],
  12. saveText:[],
  13. selecteds:[],
  14. searchDatas:[],//搜索结果
  15. editClear:true,
  16. addModule:[],
  17. emptyData:[],
  18. symptomIds:[] //搜索去重
  19. };
  20. export default function(state=initState,action){
  21. const res = Object.assign({},state);
  22. switch (action.type){
  23. case SET_CURRENT://需要处理截取的模板
  24. return setModule(state,action);
  25. case SET_CURRENT_DATA://设置使用的模板数据
  26. return setData(state,action);
  27. case CURRENT_CONFIRM://展开多选确定
  28. return confirm(state,action);
  29. case SET_LABEL_MODULE://设置主诉选中的标签模板
  30. res.mainLabelModule = action.data;
  31. return res;
  32. case INSERT_PROCESS://病程变化
  33. return insertProcess(state,action);
  34. case CLEAR_CURRENT_ILL://清除现病史数据
  35. return clearCurrentIll(state,action);
  36. case SETTEXTMODEVALUE:
  37. return setTextModeValue(state,action);
  38. case SETMAINCHECKBOX://普通多选确定
  39. return setCheckBox(state,action);
  40. case CURRENT_RADIO://单选确定
  41. return setRadioValue(state,action);
  42. case CURRENT_NUMBER://数字确定
  43. return setNumberValue(state,action);
  44. case CURRENT_TEXT_LABEL://标签双击编辑
  45. return changeLabelVal(state,action);
  46. case CURRENT_TEXT_LABEL_NUMBER://数字键盘
  47. return changeNumLabelVal(state,action);
  48. case CURRENT_GET_BIGDATAPUSH://标签双击编辑
  49. return bigDataSymptom(state,action);
  50. case SET_CURRENT_SEARCH://搜索结果
  51. res.searchDatas = action.data;
  52. res.searchStr = action.inpStr;
  53. return res;
  54. case CURRENT_CLEAR:
  55. res.searchDatas = [];//清空搜索结果
  56. return res;
  57. case SETCURRENTTEXT:
  58. return setCheckText(state,action);
  59. case CURRENT_FOCUS_INDEX://手动输入位置
  60. res.focusIndex = action.index;
  61. res.span = action.$span;
  62. return res;
  63. case SELECT_SEARCHDATA:
  64. return insertLabelData(state,action);
  65. case CLEAR_CURRENT_EDIT://清除数据
  66. return clearCurrentEdit(state,action);
  67. case CURRENTADDLABELITEM:
  68. return addLabelItem(state,action);
  69. case SETCURRENTINPUT:
  70. return setInputLabel(state,action);
  71. case DEL_CURRENT:
  72. return backspaceText(state,action);
  73. case REMOVE_CURR_ID:
  74. return removeId(state,action);
  75. case CURRENT_MUL://单列多选
  76. return multipleComfirn(state,action);
  77. case DEL_CURRENT_LABLE:
  78. return delSingleLable(state,action);
  79. case SET_RADIO_INPUT_VALUE:
  80. return setRadioInputValue(state,action);
  81. case CURRENT_CHRONIC:
  82. return fillChronicModule(state,action);
  83. default:
  84. return state;
  85. }
  86. }