index.jsx 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. import React,{Component} from 'react';
  2. import style from './index.less';
  3. import {ItemBox} from '@commonComp';
  4. import Textarea from './Textarea';
  5. import FollowUp from '@components/Treat/FollowUp'
  6. class Advice extends Component{
  7. constructor(props){
  8. super(props);
  9. this.treatInput = React.createRef();
  10. this.assayRef = React.createRef();
  11. this.checkRef = React.createRef();
  12. this.adviceInputRef = React.createRef();
  13. this.handleTreatInput = this.handleTreatInput.bind(this);
  14. this.handleAssayInput = this.handleAssayInput.bind(this);
  15. this.handleCheckInput = this.handleCheckInput.bind(this);
  16. this.handleComTreatInput = this.handleComTreatInput.bind(this);
  17. this.handleAdviceInput = this.handleAdviceInput.bind(this);
  18. }
  19. shouldComponentUpdate(next){
  20. if(JSON.stringify(next) == JSON.stringify(this.props)){
  21. return false;
  22. }
  23. return true;
  24. }
  25. componentWillReceiveProps(next){
  26. const isRead = this.props.isRead;
  27. // if(next.isRead != isRead||next.value!=this.props.value){ //value对比解决复诊不显示bug
  28. // this.adviceInputRef.current.innerText?(this.adviceInputRef.current.innerText = next.value||''):(this.adviceInputRef.current.innerHTML = next.value||'');
  29. // }
  30. }
  31. handleTreatInput(e, index, ii) {
  32. const {advice} = this.props.pushMessage;
  33. const changeInput = e.target.value //改变的同类药的值
  34. const { setChangeAdviceTreatment } = this.props;
  35. setChangeAdviceTreatment && setChangeAdviceTreatment(index, ii, changeInput)
  36. }
  37. handleAssayInput(e) {
  38. const changeInput = e.target.value
  39. const { setChangeAdviceAssay } = this.props;
  40. setChangeAdviceAssay && setChangeAdviceAssay(changeInput)
  41. }
  42. handleCheckInput(e) {
  43. const changeInput = e.target.value
  44. const { setChangeAdviceCheck } = this.props;
  45. setChangeAdviceCheck && setChangeAdviceCheck(changeInput)
  46. }
  47. handleComTreatInput(text) {
  48. const { comTreatChange } = this.props;
  49. comTreatChange && comTreatChange(text)
  50. }
  51. handleAdviceInput(text) {
  52. const { adviceInputChange } = this.props;
  53. adviceInputChange && adviceInputChange(text)
  54. }
  55. componentDidMount(){
  56. // this.$dom.current.nextSibling.innerText?(this.$dom.current.nextSibling.innerText = ''):(this.$dom.current.nextSibling.innerHTML = '')
  57. // const {advice} = this.props.pushMessage.advice
  58. }
  59. render(){
  60. const {advice} = this.props.pushMessage;
  61. const {isRead, isFirstMainDiag, followUp, hasFollowUp, setFollowUp} = this.props
  62. let scheme = advice.scheme && advice.scheme.map((item, index) => {
  63. return <p>{item.treatment.map((it,ii) =>{
  64. return(it.treatmentStr && it.treatmentStr.length > 0 ?
  65. <div>
  66. { it.treatmentStr }
  67. {/* <input className={style['treat-input']} ref={this.treatInput} onInput={(e)=>{this.handleTreatInput(e, index, ii)}} type='text' value={ it.treatmentStr }/> */}
  68. </div>: '')
  69. // return <div>{it.drugs.length > 0 ? it.name : ''}: {it.drugs.map((drug, drugIndex) =>{
  70. // return(<span>{drug.selected ? (drugIndex === 0 ? drug.name : ' ' + drug.name) : ''}</span>)
  71. // })}</div>
  72. })}</p>
  73. })
  74. return <div className={`${'mainsuit-box'} ${style['main-suit']}`}>
  75. <ItemBox title='医嘱' editable={false} border={true} marginTop="10px">
  76. {/* <div className={style['billing']}>
  77. {advice.assay && advice.assay.length > 0 || advice.check && advice.check.length > 0 ? <h1>开单项目</h1> : ''}
  78. {advice.assay && <span className={style['treat-input']}> {advice.assay}</span>}
  79. {advice.check && <span className={style['treat-input']}> {advice.check}</span>}
  80. </div> */}
  81. {advice.commontreatment && advice.commontreatment.length > 0 &&<div className={style['billing']} >
  82. {advice.commontreatment && advice.commontreatment.length > 0 && <h1>一般治疗</h1>}
  83. {/* {advice.commontreatment && <div className={style['treat-input']} onInput={this.handleComTreatInput} contentEditable={true} style = {{outline: 'none'}}></div>} */}
  84. {<Textarea value={advice.commontreatment} isRead={isRead} handleChangeAssistValue={this.handleComTreatInput} ></Textarea>}
  85. </div>}
  86. {!isFirstMainDiag && <FollowUp noTitle="true" setFollowUp={setFollowUp} followUp = {followUp} isRead={isRead}></FollowUp>}
  87. {advice.scheme && advice.scheme.length > 0 &&<div contentEditable='false' className={style['scheme']}>
  88. {advice.scheme && advice.scheme.length > 0 && <h1>治疗方案</h1>}
  89. {scheme}
  90. </div>}
  91. <div className={style['billing']} >
  92. {/* {!advice.adviceInput && <Textarea value='' isRead={isRead} handleChangeAssistValue={this.handleAdviceInput} ></Textarea>}
  93. {advice.adviceInput && <Textarea value={advice.adviceInput} isRead={isRead} handleChangeAssistValue={this.handleAdviceInput} ></Textarea>} */}
  94. <Textarea value={advice.adviceInput} isRead={isRead} handleChangeAssistValue={this.handleAdviceInput} ></Textarea>
  95. </div>
  96. </ItemBox>
  97. </div>
  98. }
  99. }
  100. export default Advice;