eleType.js 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. import MixCheckBox from '@containers/MixCheckBox';
  2. import RadioDrop from "@containers/RadioDrop";
  3. import RadioInpDrop from "@containers/RadioInpDrop";
  4. import NumberDrop from "@containers/NumberDrop";
  5. import MultSpread from "@containers/MultSpread";
  6. import SpreadDrop from "@containers/SpreadDrop";
  7. import EditableSpan from '@containers/EditableSpan';
  8. import InlineTag from '@containers/InlineTag';
  9. import NumberUnitDrop from '@containers/NumberUnitDrop';
  10. import Multiple from '@containers/Multiple';
  11. /******
  12. * 下拉类型分发
  13. * 先根据tagType分为几个大类填写单
  14. * 再根据controlType判断子项(列)类型
  15. * tagType:1:单项单列,例如: 程度,咳出通畅度 2:单项多列,例如:杂音,添加症状 3:横铺单标签形式,例如:血压 4:横铺多标签形式,例如:咳嗽 5:竖铺组合项,例如:有无治疗 6:组合项多列 既往史
  16. * controlType控件类型:(0:无类型,默认值 1:下拉单选 2:下拉多选 3:纯文本 4:待定 5:待定 6:文本框 7:数字键盘文本框 99:联合推送)
  17. *
  18. * *******/
  19. //单选类型
  20. export function singleRadio(params){
  21. const data = params.item;
  22. const {i,hideTag,boxMark,showArr,selecteds,boxTop,boxLeft,importLabel} = params;
  23. let isHigh=importLabel&&importLabel.includes(data.id);
  24. const showInx = boxMark+i+'0'; //单括号多标签的情况下需要识别同一个标签内多个下拉组件的显示状态
  25. switch (+data.controlType){
  26. case 0:
  27. case 1:
  28. const custom= JSON.parse(localStorage.getItem('radio'+data.id));
  29. const list = data.questionDetailList&&data.questionDetailList.length>0?data.questionDetailList:data.questionMapping;
  30. return <RadioDrop data={custom&&custom.length?[...custom,...list]:list}
  31. prefix={data.labelPrefix}
  32. suffix={data.labelSuffix}
  33. placeholder={data.name}
  34. show={showArr&&showArr[showInx]}
  35. value = {data.value}
  36. boxMark={boxMark}
  37. id={data.id}
  38. isImports={isHigh}
  39. ikey={showInx}
  40. hideTag={hideTag}></RadioDrop>;
  41. case 2:
  42. const dataList = data.questionDetailList&&data.questionDetailList.length>0?data.questionDetailList:data.questionMapping;
  43. return <Multiple data={dataList}
  44. ikey={showInx}
  45. placeholder={data.name}
  46. value={data.value}
  47. copyType={data.copyType}
  48. selecteds={selecteds ?selecteds[i]:[]}
  49. show={showArr&&showArr[showInx]}
  50. order={data.textGenerate}
  51. type={boxMark}
  52. isImports={isHigh}
  53. textPrefix={data.labelPrefix}
  54. textSuffix={data.labelSuffix}
  55. id={data.id}></Multiple>
  56. case 3:
  57. return <EditableSpan {...params} value={data.value||data.value==''?data.value:data.name} update={Math.random()}/>;
  58. case 5://带单位数字键盘
  59. return <NumberUnitDrop prefix={data.labelPrefix}
  60. suffix={data.labelSuffix}
  61. placeholder={data.name}
  62. formulaCode={data.formulaCode}
  63. boxMark={boxMark}
  64. id={data.id}
  65. isImports={isHigh}
  66. show={showArr&&showArr[showInx]}
  67. ikey={showInx}
  68. value={data.value}
  69. hideTag={hideTag}></NumberUnitDrop>;
  70. case 6:
  71. return <InlineTag prefix={data.labelPrefix}
  72. suffix={data.labelSuffix}
  73. placeholder={data.name}
  74. value={data.value}
  75. isImports={isHigh}
  76. id={data.id}
  77. ikey={showInx}></InlineTag>;
  78. case 7:
  79. const min = data.minValue!=null&&data.minValue!=undefined?data.minValue-1:undefined;
  80. const max = data.maxValue!=null&&data.maxValue!=undefined?+data.maxValue+1:undefined;
  81. return <NumberDrop prefix={data.labelPrefix}
  82. suffix={data.labelSuffix}
  83. min={min}
  84. max={max}
  85. placeholder={data.name}
  86. boxMark={boxMark}
  87. id={data.id}
  88. allClick={true}
  89. show={showArr&&showArr[showInx]}
  90. ikey={showInx}
  91. value={data.value}
  92. hideTag={hideTag}></NumberDrop>;
  93. case 11:
  94. return <RadioInpDrop data={data.questionDetailList}
  95. vals={data.vals}
  96. placeholder={data.name}
  97. show={showArr&&showArr[showInx]}
  98. value = {data.value}
  99. boxMark={boxMark}
  100. isImports={isHigh}
  101. id={data.id}
  102. ikey={showInx}></RadioInpDrop>;
  103. default:
  104. return '';
  105. }
  106. }
  107. //多标签组合型
  108. function multLabels(params){
  109. const data = params.item;
  110. const {i,boxMark,showArr,saveText,selecteds,importLabel} = params;
  111. let isHigh=importLabel&&importLabel.includes(data.id);
  112. return <MultSpread data={data.questionMapping}
  113. showAdd = {+data.showAdd===1}
  114. copyId={data.id}
  115. fullData = {data}
  116. showArr={showArr||{}}
  117. update={Math.random()}
  118. boxMark={boxMark}
  119. isImports={isHigh}
  120. ikey={boxMark+i}
  121. selecteds={selecteds&&selecteds[i]}
  122. saveText={saveText}
  123. name={data.name||data.tagName}
  124. textPrefix={data.prefix}
  125. textSuffix={data.suffix}></MultSpread>
  126. }
  127. //多选标签展开型
  128. function multCheckLabels(params,tagType){
  129. const data = params.item;
  130. const {i,boxMark,showArr,selecteds,importLabel} = params;
  131. let isHigh=importLabel&&importLabel.includes(data.id);
  132. const showInx = boxMark+i+'0';
  133. return <SpreadDrop data={data.questionMapping}
  134. ikey={showInx}
  135. placeholder={data.name}
  136. value={data.value}
  137. copyType={data.copyType}
  138. selecteds={selecteds ?selecteds[i]:[]}
  139. show={showArr&&showArr[showInx]}
  140. order={data.textGenerate}
  141. isImports={isHigh}
  142. type={boxMark}
  143. tagType={tagType}
  144. textPrefix={data.prefix}
  145. textSuffix={data.suffix}
  146. id={data.id}
  147. flag={data.flag}></SpreadDrop>
  148. }
  149. export default function(params){
  150. const data = params.item;
  151. switch (+data.tagType) {
  152. case 1:
  153. case 5:
  154. return singleRadio(params);
  155. case 2:
  156. // return singleChecks(params);
  157. return multCheckLabels(params,data.tagType);
  158. case 3:
  159. return multLabels(params); //单标签组合展开
  160. case 4:
  161. return multLabels(params); //多标签展开--已废(不会用到)
  162. case 6:
  163. return multCheckLabels(params,data.tagType);
  164. case 8:
  165. let isLast = false;
  166. if(+params.boxMark===3||+params.boxMark === 4){
  167. //其他史查体删到只剩最后一个自由文本标签时,该标签宽度100%,解决落关标文本
  168. if(params.saveText.length==1&&+data.tagType===8){
  169. isLast = true;
  170. }
  171. }
  172. // 删除后value为空,应展示空而不是name
  173. return <EditableSpan {...params} value={data.value||data.value==''?data.value:data.name} full={data.full||isLast}/>;
  174. case 11://推送类型
  175. return multCheckLabels(params,data.tagType);
  176. default:
  177. return '';
  178. }
  179. }