PubIndeptQa.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623
  1. <template>
  2. <div class="PubTagGroupWrapper"
  3. @click="closeNameLis(1)"
  4. >
  5. <el-form
  6. class="groups"
  7. :rules="rules"
  8. ref="groups"
  9. :model="form"
  10. label-width="150px"
  11. >
  12. <el-form-item
  13. label="选择归属:"
  14. prop="region1"
  15. >
  16. <span class="changeTips">改变归属后,填写单明细将会恢复到默认状态</span>
  17. <el-select
  18. v-model="form.region1"
  19. placeholder="请选择归属"
  20. :disabled="!!editData.id"
  21. @change="readyChangeSelect(1)"
  22. >
  23. <el-option
  24. v-for="item in Adscriptions"
  25. :label="item.name"
  26. :value="item.val"
  27. :key="item.val"
  28. ></el-option>
  29. </el-select>
  30. </el-form-item>
  31. <el-form-item
  32. label="选择类型:"
  33. prop="region2">
  34. <span class="changeTips">改变类型后,填写单明细将会恢复到默认状态</span>
  35. <el-select
  36. v-model="form.region2"
  37. placeholder="请选择类型"
  38. :disabled="(!!editData.id&&editData.controlType!='1'&&editData.controlType!='2') || !form.region1"
  39. @change="readyChangeSelect(2)"
  40. >
  41. <el-option
  42. v-for="item in labelTypes"
  43. :label="item.name"
  44. :value="item.val"
  45. :key="item.val"
  46. ></el-option>
  47. </el-select>
  48. </el-form-item>
  49. <el-form-item
  50. v-if="qaType==2"
  51. :label="'是否为主要内容'"
  52. prop="region12"
  53. >
  54. <el-select
  55. v-model="form.region12"
  56. :disabled="!form.region1||isEdit"
  57. @change="sendData"
  58. >
  59. <el-option
  60. label="是"
  61. value="0"
  62. ></el-option>
  63. <el-option
  64. label="不是"
  65. value="1"
  66. ></el-option>
  67. </el-select>
  68. </el-form-item>
  69. <el-form-item
  70. label="填写单系统名称:"
  71. prop="region3">
  72. <div @click.stop style="display:inline-block;">
  73. <el-input
  74. v-model="form.region3"
  75. :disabled="!form.region1"
  76. placeholder="请输入填写单系统名称"
  77. @change="sendData"
  78. @input="focusSystemName"></el-input>
  79. <ul class="systemNames"
  80. v-if="isNeedSearch&&systemNameShow">
  81. <li v-for="item in systemNameLis"
  82. class="ellipsis"
  83. :key="item.conceptId"
  84. @click="pushSystemName(item.name)">{{item.name}}</li>
  85. </ul>
  86. </div>
  87. <span class="changeTips changeTipsName" v-if="qaType !=='1'">
  88. 当为症状时,填写单系统名称需要与医学标准术语内容相对应,如果没有可以先在医学标准术语中建立相关信息!未建立相关信息可能会影响系统使用!
  89. </span>
  90. </el-form-item>
  91. <el-form-item
  92. :label="qaType==2?'填写单医生界面展示标准内容:':'填写单界面描述名称:'"
  93. prop="region4"
  94. >
  95. <el-input
  96. :disabled="!form.region1||(qaType==2&&form.region1==1)"
  97. v-model="form.region4"
  98. :placeholder="qaType==2?'请输入填写单医生界面展示标准内容':'请输入填写单界面描述名称'"
  99. @change="sendData"
  100. ></el-input>
  101. </el-form-item>
  102. <el-form-item class="flag-box" v-if="qaType =='1'&& form.region1 == '1' && form.region2 != '4'">
  103. <el-checkbox v-model="form.required" label="必填" true-label="1" false-label="0" @change="sendData"></el-checkbox>
  104. <!--<el-checkbox v-if="form.region2=='9'" v-model="form.specFlag" label="拼接到主诉" true-label="1" false-label="0" @change="sendData"></el-checkbox>-->
  105. <el-checkbox v-if="form.region2=='1'||form.region2=='9'" :disabled="form.flag==='2'" v-model="form.flag" label="时间类型" true-label="1" false-label="" @change="sendData"></el-checkbox>
  106. <el-checkbox v-if="form.region2=='1'||form.region2=='2'" :disabled="form.flag==='1'" v-model="form.flag" label="诱因类型" true-label="2" false-label="" @change="sendData"></el-checkbox>
  107. <el-checkbox v-if="form.region2=='8'" v-model="form.flag" label="伴随类型" true-label="3" false-label="" @change="sendData"></el-checkbox>
  108. </el-form-item>
  109. <el-form-item
  110. v-if="qaType==2"
  111. label="填写单患者界面展示通俗内容:"
  112. prop="region5"
  113. >
  114. <el-input
  115. :disabled="!form.region1"
  116. v-model="form.region5"
  117. placeholder="请输入填写单患者界面展示通俗内容"
  118. @change="sendData"
  119. ></el-input>
  120. </el-form-item>
  121. <el-form-item
  122. label="性别:"
  123. prop="region7"
  124. >
  125. <span class="changeTips">改变性别后,填写单明细将会恢复到默认状态</span>
  126. <el-select
  127. v-model="form.region7"
  128. :disabled="!!editData.id || !form.region1"
  129. @change="readyChangeSelect(3)"
  130. >
  131. <el-option
  132. label="通用"
  133. value="3"
  134. ></el-option>
  135. <el-option
  136. label="男"
  137. value="1"
  138. ></el-option>
  139. <el-option
  140. label="女"
  141. value="2"
  142. ></el-option>
  143. </el-select>
  144. </el-form-item>
  145. <el-form-item
  146. label="年龄:"
  147. prop="region8"
  148. class="ages"
  149. >
  150. <el-input
  151. v-model.number="form.region8"
  152. :disabled="!form.region1"
  153. type="number"
  154. ref="valage1"
  155. @input="sendData"
  156. ></el-input>
  157. </el-form-item> ~
  158. <el-form-item
  159. prop="region9"
  160. class="ages maxAges"
  161. >
  162. <el-input
  163. v-model.number="form.region9"
  164. :disabled="!form.region1"
  165. type="number"
  166. ref="valage2"
  167. @input="sendData"
  168. ></el-input>
  169. </el-form-item>
  170. <el-form-item label="填写单图片内容:"
  171. v-if="qaType==1&&form.region2&&form.region2!=4&&form.region2!=9"
  172. prop="region13">
  173. <el-upload
  174. :class="form.region13?'upload-hide':''"
  175. :limit="1"
  176. :action="uploadUrl"
  177. list-type="picture"
  178. :file-list="imgList"
  179. :show-file-list="showFileList"
  180. :on-remove="handleRemove"
  181. :on-success="handleSuccess"
  182. :on-error="handleError"
  183. accept="image/*"
  184. name="upfile">
  185. <el-button slot="trigger" size="small" type="primary">上传图片</el-button>
  186. </el-upload>
  187. </el-form-item>
  188. <el-form-item
  189. v-if="qaType==2&&form.region1=='1'&&form.region2=='4'"
  190. label="医学教育说明:"
  191. prop="explains"
  192. >
  193. <el-input type="textarea" @input="sendData" v-model="form.explains" maxLength ='100' style="width: 500px;"></el-input>
  194. </el-form-item>
  195. </el-form>
  196. </div>
  197. </template>
  198. <script>
  199. import api from '@api/preTreat.js';
  200. import utils from '@api/utils.js';
  201. import config from '@api/config.js';
  202. /**
  203. * titlePar 顶部显示左(有默认值可不填)
  204. * titleSub 顶部显示右(有默认值可不填)
  205. * form 当前页面传到父组件的数据(region10,region11暂时不用)
  206. * submitForm 基本信息验证必填项
  207. * validatePass 基本信息必填项验证成功回调
  208. * 父组件根据form.region2改变底部组件操作项
  209. */
  210. // 归属和填写单类型限制:
  211. // 症状情况(val:1):单选(val:1)、多选(val:2)、多列填写(val:3)、输入框(val:6)、数字输入框(val:7)、文本域(val:5)
  212. // 诊疗情况(val:51):单选(val:1)、多选(val:2)、多列填写(val:3)、输入框(val:6)、数字输入框(val:7)、文本域(val:5)、上传图片(val:4)
  213. // 其他史(val:3):单选(val:1)、多选(val:2)、多列填写(val:3)、输入框(val:6)、数字输入框(val:7)、文本域(val:5)
  214. // 补充内容(val:52):单选(val:1)、多选(val:2)、多列填写(val:3)、输入框(val:6)、数字输入框(val:7)、文本域(val:5)
  215. export default {
  216. props:['editData','qaType','isEdit','isCopy'], //qaType:独立1/组合2填写单
  217. data() {
  218. var validatePass1 = (rule, value, callback) => {
  219. this.validateSystomName(value,callback,1)
  220. };
  221. var validateNameLength = (value,callback,type)=>{
  222. const limit = (type===2||type===3)&&(this.qaType==2&&this.form.region1==1)?7:30;
  223. let name = '';
  224. switch (type){
  225. case 1:
  226. name='系统名称';
  227. break;
  228. case 2:
  229. name=this.qaType==1?'界面描述名称':'医生界面标准内容';
  230. break;
  231. case 3:
  232. name='患者界面通俗内容';
  233. break;
  234. }
  235. if(value.length>limit){
  236. callback(new Error(name+'不能超过'+limit+'个字'));
  237. }
  238. };
  239. var validatePass2 = (rule, value, callback) => {
  240. const editData = this.$props.editData;
  241. if(editData.id && value == editData.tagName){ //修改系统名称没变就不再校验
  242. callback();
  243. }else{
  244. validateNameLength(value,callback,1);
  245. this.validateSystomName(value,callback,2);
  246. }
  247. };
  248. var validatePass11 = (rule, value, callback) => {
  249. validateNameLength(value,callback,2);
  250. this.validateSystomName(value,callback,11)
  251. };
  252. var validatePass12 = (rule, value, callback) => {
  253. validateNameLength(value,callback,3);
  254. this.validateSystomName(value,callback,1)
  255. };
  256. var validateLength = (rule, value, callback) => {
  257. if(value.length>29){
  258. callback(new Error('不能超过30字'));
  259. }else{
  260. callback();
  261. }
  262. };
  263. var validateNum = (rule, value, callback)=>{
  264. if(value<0||(''+value).indexOf('.')>-1){
  265. callback(new Error('请输入正整数'));
  266. }else{
  267. callback();
  268. }
  269. };
  270. return {
  271. form: {
  272. region1: '', //归属
  273. region2: '', //填写单类型
  274. region3: '', //系统名称
  275. region4: '', //医生界面名称
  276. region5: '', //患者界面名称
  277. region6: '', //填写单界面描述问题名称
  278. region7: '3', //性别
  279. region8: '0', //最小年龄
  280. region9: '200', //最大年龄
  281. region12: '0', //是否为主要内容
  282. region13:'', //上传图片
  283. specFlag:'0', //拼接到主诉
  284. required: '0', //必填
  285. flag:'', //控件类型:时间类型1、诱因类型2、伴随类型3
  286. },
  287. //isNeedSearch: false, //是否需要查询(系统名称)
  288. imgList:[],
  289. showFileList:false,
  290. uploadUrl:config.urls.uploadImg, //图片上传地址
  291. labelTypesMaps: { // 归属和填写单类型限制
  292. '1':['1','2','3','5','6','7','8','9'], //症状情况
  293. '51':['1','2','3','4','5','6','7','9'], //诊疗情况
  294. '3':['1','2','3','5','6','7','9'], //其他史
  295. '52':['1','2','3','5','6','7','9'] //补充内容
  296. },
  297. combinLabelMaps:{
  298. '1':['4'], //症状情况
  299. '51':['4','6'], //诊疗情况
  300. '3':['4','6'], //其他史
  301. '52':['4','6'] //补充内容
  302. },
  303. rules: {
  304. region1: [
  305. { required: true, message: '请选择归属', trigger: 'change' }
  306. ],
  307. region2: [
  308. { required: true, message: '请选择类型', trigger: 'change' }
  309. ],
  310. region3: [
  311. { required: true, message: '请输入填写单系统名称', trigger: 'change' },
  312. { validator: validatePass2, trigger: 'blur' },
  313. ],
  314. region4: [
  315. { required: true, message: '请输入填写单医生界面名称', trigger: 'change' },
  316. { validator: validatePass11, trigger: 'blur' },
  317. ],
  318. region5: [
  319. { required: true, message: '请输入填写单患者界面名称', trigger: 'change' },
  320. { validator: validatePass12, trigger: 'blur' },
  321. ],
  322. region6: [
  323. { required: true, message: '请输入填写单界面描述名称', trigger: 'change' },
  324. { validator: validatePass1, trigger: 'blur' },
  325. ],
  326. region7: [
  327. { required: true, message: '请选择性别', trigger: 'change' }
  328. ],
  329. region8: [
  330. { required: true, message: '请输入最小年龄', trigger: 'change' },
  331. { validator: validateNum, trigger: 'blur' },
  332. ],
  333. region9: [
  334. { required: true, message: '请输入最大年龄', trigger: 'change' },
  335. { validator: validateNum, trigger: 'blur' },
  336. ],
  337. region12: [
  338. { required: true, message: '请选择是否为主要内容', trigger: 'change' }
  339. ],
  340. },
  341. Adscriptions: [],
  342. labelTypes: [],
  343. labelTypesList: [],
  344. systemNameShow: false,//系统名称列表显示
  345. systom:null, //填写单系统名称存在与否
  346. }
  347. },
  348. computed: {
  349. isNeedSearch() {
  350. return this.qaType==2&&this.form.region1==1;
  351. },
  352. },
  353. mounted() {
  354. this.getDropList();
  355. //编辑时赋值
  356. const editData = this.$props.editData;
  357. if(editData.id){
  358. const trans = utils.transPretreatKeys(editData,this.qaType==1);
  359. this.form = Object.assign({},this.form,trans);
  360. if(this.isCopy){ //复制时系统名称界面名称置空
  361. this.form.region3='';
  362. this.form.region4='';
  363. this.form.region5='';
  364. }
  365. const imgUrl = trans.region13;
  366. if(imgUrl){
  367. this.imgList = [{name:'',url:imgUrl.replace('{imageUrlPrefix}',config.imgHost)}];
  368. this.showFileList = true;
  369. }
  370. };
  371. this.$emit('changeVal', this.form, false);
  372. },
  373. /*watch: {
  374. newName(nextVal, prevVal) {
  375. if (this.isNeedSearch && nextVal != prevVal && (this.form.region12 == 0)) {
  376. this.focusSystemName()
  377. }
  378. },
  379. },*/
  380. methods: {
  381. handleRemove(){
  382. this.showFileList=false;
  383. this.form.region13 = '';
  384. this.imgList=[];
  385. },
  386. handleSuccess(response){
  387. if(response.code==='0'){
  388. this.showFileList = true;
  389. this.form.region13 = '{imageUrlPrefix}'+response.data.url;
  390. this.sendData();
  391. }else{
  392. this.imgList = [];
  393. this.showFileList=false;
  394. this.warning(response.msg);
  395. }
  396. },
  397. handleError(err, file, fileList){
  398. this.showFileList=false;
  399. },
  400. getDropList() {
  401. return api.getPreTypeList().then((res) => {
  402. if (res.data.code === '0') {
  403. this.Adscriptions = res.data.data[1];
  404. this.labelTypesList = this.qaType==1?res.data.data[2]:res.data.data[3];
  405. const editData = this.$props.editData;
  406. //编辑时,单选、多选可互相切换
  407. if(editData.controlType=='1'||editData.controlType=='2'){
  408. this.labelTypes = this.labelTypesList.filter((it)=>{
  409. return it.val==='1'||it.val==='2';
  410. })
  411. }else{
  412. this.labelTypes = this.labelTypesList;
  413. }
  414. }
  415. })
  416. },
  417. validateSystomName(name,callback,flg) {
  418. if(flg == 1){
  419. let tmpVal = this.form.region5;
  420. if(tmpVal.trim() == ''){
  421. callback(new Error('填写单界面描述名称不能为空'));
  422. }else{
  423. this.form.region5 = tmpVal.trim();
  424. callback();
  425. }
  426. }else if(flg == 2){
  427. let tmpVal = this.form.region3;
  428. if(tmpVal.trim() == ''){
  429. callback(new Error('填写单系统名称不能为空'));
  430. }else{
  431. this.form.region3 = tmpVal.trim();
  432. callback();
  433. }
  434. }else if(flg == 11){
  435. let tmpVal = this.form.region4;
  436. if(tmpVal.trim() == ''){
  437. callback(new Error('填写单医生界面名称不能为空'));
  438. }else{
  439. this.form.region4 = tmpVal.trim();
  440. callback();
  441. }
  442. }
  443. },
  444. sendData() {
  445. this.$emit('changeVal', Object.assign({},this.form), false)
  446. },
  447. readyChangeSelect(type) {
  448. if(type === 1) {
  449. this.initForm();
  450. const maps = this.qaType==1?this.labelTypesMaps:this.combinLabelMaps;
  451. this.labelTypes = this.labelTypesList.filter(item => maps[this.form.region1].includes(item.val));
  452. }
  453. //if(type === 2||type === 3) {
  454. this.form.flag = '';
  455. this.sendData();
  456. //}
  457. },
  458. submitForm(formName) {
  459. this.$refs[formName].validate((valid) => {
  460. if (valid) {
  461. this.$emit('validatePass', this.form, false);
  462. } else {
  463. console.log('error submit!!');
  464. return false;
  465. }
  466. });
  467. },
  468. focusSystemName() { //系统名称搜索标准词
  469. if(!this.isNeedSearch){
  470. return;
  471. }
  472. if (this.form.region3.trim() == '') {
  473. this.systemNameShow = false;
  474. this.systemNameLis = [];
  475. return;
  476. }
  477. let params = {
  478. "libType": [1],
  479. "name": this.form.region3
  480. };
  481. api.indexByLexicon(params).then((res) => {
  482. if (res.data.code === '0') {
  483. this.systemNameLis = res.data.data;
  484. if (res.data.data.length > 0) {
  485. this.systemNameShow = true;
  486. } else {
  487. this.systemNameShow = false;
  488. }
  489. }
  490. })
  491. },
  492. pushSystemName(val) {
  493. this.form.region3 = val;
  494. if(this.qaType==2&&this.form.region1==1){
  495. this.form.region4 = val;
  496. }
  497. this.systemNameShow = false;
  498. this.sendData();
  499. },
  500. closeNameLis(flg) {
  501. if (flg == 1) {
  502. this.systemNameShow = false;
  503. } else if (flg == 2) {
  504. if (this.systemNameLis.length > 0) {
  505. this.systemNameShow = true;
  506. } else {
  507. this.systemNameShow = false;
  508. }
  509. }
  510. },
  511. warning(msg, type) {
  512. this.$message({
  513. showClose: true,
  514. message: msg,
  515. type: type || 'warning'
  516. })
  517. },
  518. initForm() {
  519. this.form.region2 = '';
  520. this.form.region7 = '3';
  521. this.form.region12 = '0';
  522. this.form.region13 = '';
  523. //this.form.region5 = '';
  524. //this.form.region12 = '1';
  525. },
  526. }
  527. }
  528. </script>
  529. <style lang="less">
  530. .normalVal .el-input{
  531. width: auto;
  532. display: inline-block;
  533. .el-input__inner {
  534. width: 40px;
  535. padding: 0 5px;
  536. }
  537. }
  538. .el-upload-list--picture .el-upload-list__item-name{
  539. display: none;
  540. }
  541. .PubTagGroupWrapper .fix-inp .el-col .el-input__inner{
  542. width: 100%;
  543. display: inline-block;
  544. }
  545. .PubTagGroupWrapper .fix-inp .el-col-4{
  546. text-align: center;
  547. }
  548. .PubTagGroupWrapper .fix-inp .el-col-8{
  549. text-align: center;
  550. }
  551. .groups {
  552. background-color: #fff;
  553. padding: 20px;
  554. margin: 20px 20px -20px 20px;
  555. .el-form-item__content,
  556. .el-input__inner {
  557. height: 30px;
  558. line-height: 30px;
  559. width: 200px;
  560. }
  561. .el-form-item {
  562. margin-bottom: 20px;
  563. }
  564. .el-form-item__error {
  565. width: 200px;
  566. top: 28px;
  567. }
  568. .el-form-item__label {
  569. line-height: 30px;
  570. text-align: left;
  571. }
  572. .el-input__icon {
  573. line-height: 30px;
  574. }
  575. .ages .el-input {
  576. display: inline-block;
  577. width: auto;
  578. .el-input__inner {
  579. width: 40px;
  580. padding: 0 5px;
  581. }
  582. .el-input__inner::-webkit-outer-spin-button,
  583. .el-input__inner::-webkit-inner-spin-button {
  584. -webkit-appearance: none;
  585. }
  586. .el-input__inner[type="number"] {
  587. -moz-appearance: textfield;
  588. }
  589. }
  590. .el-message-box__btns .el-button--default {
  591. color: #606266 !important;
  592. }
  593. }
  594. .el-upload-list{
  595. float: left;
  596. }
  597. .upload-hide .el-upload--picture{
  598. display: none;
  599. }
  600. .PubTagGroupWrapper .groups .flag-box {
  601. .el-form-item__content{
  602. width:100%;
  603. }
  604. label:not(:first-child){
  605. margin-left: 20px;
  606. }
  607. }
  608. </style>