upload.vue 31 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096
  1. <template>
  2. <view class="upload" @click="uploadMask()">
  3. <u-toast ref="uToast" />
  4. <view>
  5. <view class="title" v-if="htmlType==0">
  6. <u-input v-model="FormData.title" :disabled="ishtmlType" placeholder-style="color: rgba(0,0,0,0.8);font-size:48rpx;font-weight: 700;" :clearable="false" type="text" :border="border" placeholder="添加标题名称" />
  7. </view>
  8. <view class="title" v-else>
  9. <view style="font-size: 48rpx;color: rgba(0,0,0,0.8);">{{FormData.title}}</view>
  10. </view>
  11. <view class="flex" v-if="htmlType==0">
  12. <view v-if="FormData.uploadingName!=''" class="upData flex" @click.stop="Dropdown=true">
  13. {{FormData.uploadingName}}
  14. <u-icon name="arrow-right" size="28" color="#2979ff" style="margin-left: 10rpx;"></u-icon>
  15. </view>
  16. <view v-else class="upData flex" @click.stop="Dropdown=true">
  17. 选择上传分类
  18. <u-icon name="arrow-right" size="28" color="#2979ff" style="margin-left: 10rpx;"></u-icon>
  19. </view>
  20. <view class="Dropdown" v-if="Dropdown">
  21. <view class="li">选择上传分类<u-icon name="arrow-down"></u-icon></view>
  22. <view :class="item == DropdownIndex?'li active':'li'" v-for="(item,index) in getUploading" @click.stop="DropdownMeh(item.name)">{{item.name}}</view>
  23. </view>
  24. </view>
  25. <view class="flex" v-else>
  26. <view class="upData flex">
  27. {{FormData.uploadingName}}
  28. </view>
  29. </view>
  30. <!-- 补充资料 -->
  31. <view class="box" v-if="htmlType == 1">
  32. <view class="input">
  33. <view class="label flex numbers">补充资料<view class="msg" style="margin: 0; padding: 0 12rpx 0;">PPT、视频</view>
  34. </view>
  35. <view :class="format(item)?'list flex': 'list list1 flex'" v-for="(item,index) in mhFileTwo" :key="index">
  36. <image v-if="format(item)" src="../../static/img/P.png" mode=""></image>
  37. <image v-else src="../../static/img/V.png" mode=""></image>
  38. <text>{{ item }}</text>
  39. <u-icon name="close" @click="deFile(index,2)" color="rgba(0,0,0,0.15)"></u-icon>
  40. </view>
  41. <view class="upButton" @click.stop="chooseMessageFile(2)">
  42. <image src="../../static/img/upButton.png" mode=""></image>上传新文件
  43. </view>
  44. </view>
  45. <view class="template" @click="downloadFile(ppt)">下载PPT模板(<text class="herf">{{ppt}}</text>)</view>
  46. </view>
  47. <view class="box" v-if="uploadData.type == 2">
  48. <view class="tit_box">通过原因</view>
  49. <text class="msg">{{uploadData.zjspPass}}</text>
  50. </view>
  51. <view class="box" v-if="uploadData.type == 1">
  52. <view class="tit_box" style="color: #F02E2F;">不通过原因</view>
  53. <text class="msg">{{uploadData.zjspNotpass}}</text>
  54. </view>
  55. <view class="box">
  56. <view class="tit">患者信息</view>
  57. <view class="input flex">
  58. <view class="icon">姓名</view>
  59. <u-input v-model="FormData.name" :disabled="ishtmlType" :clearable="false" type="text" :border="border" placeholder="患者姓名" />
  60. </view>
  61. <view class="input flex">
  62. <view class="icon">省份</view>
  63. <view class="text" :style="FormData.province?'flex: 1;':'flex: 1;color:rgba(0, 0, 0, 0.35);'" @click="provinceMet()">
  64. {{FormData.province?FormData.province:'请选择省份'}}
  65. </view>
  66. <u-select v-model="provinceType" :list="provinceList" @confirm="provinceConfirm"></u-select>
  67. <!-- <u-input v-model="FormData.province" :disabled="ishtmlType" :clearable="false" type="text" :border="border" placeholder="请输入省份" /> -->
  68. </view>
  69. <view class="input flex">
  70. <view class="icon">城市</view>
  71. <view class="text" @click="cityMet()" :style="FormData.city?'flex: 1;':'flex: 1;color:rgba(0, 0, 0, 0.35);'">
  72. {{FormData.city?FormData.city:'请选择城市'}}
  73. </view>
  74. <u-select v-model="cityType" :list="cityList" @confirm="cityConfirm"></u-select>
  75. <!-- <u-input v-model="FormData.city" :disabled="ishtmlType" :clearable="false" type="text" :border="border" placeholder="请输入城市" /> -->
  76. </view>
  77. <view class="input flex inputBorNode">
  78. <view class="icon">医院</view>
  79. <u-input v-model="FormData.hospital" :disabled="ishtmlType" :clearable="false" type="text" :border="border" placeholder="目前所处医院名称" />
  80. </view>
  81. </view>
  82. <view class="box">
  83. <view class="tit">病例详情</view>
  84. <view class="input flex" v-if="wisBllx == '1'">
  85. <view class="icon">病例类型</view>
  86. <view class="classType" v-if="FormData.caseName!=''" style="color:#167FFF;" @click.stop="!ishtmlType?selectType=true:''">{{FormData.caseName}}</view>
  87. <view v-else style="font-size: 28rpx;color: rgba(0,0,0,0.35);flex: 1;" @click.stop="!ishtmlType?selectType=true:''">请选择病病例类型</view>
  88. <!-- <u-input :disabled="true" :clearable="false" type="number" :border="border" placeholder="请选择病病例类型" /> -->
  89. <image v-if="FormData.caseName ==''" src="../../static/img/r.png" mode=""></image>
  90. <view class="select Dropdown" v-if="selectType">
  91. <view v-for="(val,i) in itemList" @click.stop="selectMeh(val.name)" :class="selectIndex == val.name?'li active': 'li'" :key="i">{{val.name}}<u-icon style="float: right;" v-if="i==0" name="arrow-down"></u-icon></view>
  92. </view>
  93. </view>
  94. <view class="input">
  95. <view class="label">备注</view>
  96. <u-input v-model="FormData.remark" :disabled="ishtmlType" :clearable="false" type="text" :border="border" placeholder="详细信息" />
  97. </view>
  98. <view class="input">
  99. <view class="label flex numbers">相关照片<view class="msg" style="margin: 0; padding: 0 12rpx 0;">最多可上传十张图片</view>
  100. </view>
  101. <u-upload ref="uUpload1" width="160rpx" height="160rpx" :show-progress="true" :deletable="htmlType == 0 ? true : false" :action="action" @on-change="progress1" upload-text=" " :max-count="maxCount" :file-list="fileList"></u-upload>
  102. </view>
  103. <view class="input">
  104. <view class="label flex numbers">相关文件<view class="msg" style="margin: 0; padding: 0 12rpx 0;">PPT、视频</view>
  105. </view>
  106. <view :class="format(item)?'list flex': 'list list1 flex'" v-for="(item,index) in FormData.mhFile" :key="index">
  107. <image v-if="format(item)" src="../../static/img/P.png" mode=""></image>
  108. <image v-else src="../../static/img/V.png" mode=""></image>
  109. <text>{{ item }}</text>
  110. <u-icon name="close" color="rgba(0,0,0,0.15)" v-if="!ishtmlType" @click="deFile(index)"></u-icon>
  111. </view>
  112. <view v-if="htmlType == 0" class="upButton" @click.stop="chooseMessageFile()">
  113. <image src="../../static/img/upButton.png" mode=""></image>上传新文件
  114. </view>
  115. </view>
  116. <view class="template" v-if="htmlType == 0">下载PPT模板(<text class="herf" v-for="(a,b) in ppt.split(',')" :key="b" @click="downloadFile(a)">{{a}},</text>)</view>
  117. </view>
  118. </view>
  119. <u-popup v-model="show" mode="center">
  120. <view class="suc">
  121. <image src="../../static/img/suc.png" mode=""></image>
  122. <view class="con">
  123. <view class="tit">上传成功</view>
  124. <view class="p">患者资料上传成功,是否继续上传</view>
  125. <view class="btn">
  126. <view @click="indexHerf()">返回首页</view>
  127. <view class="next" @click.stop="nextMeh()">
  128. 继续上传
  129. </view>
  130. </view>
  131. </view>
  132. </view>
  133. </u-popup>
  134. <view class="uploadBtn" v-if="htmlType!=2">
  135. <view class="yes" v-if="yesType==1" @click="patientQuide()">提交案例</view>
  136. <view class="yes" v-else @click="patientQuide()">重新提交</view>
  137. </view>
  138. </view>
  139. </template>
  140. <script>
  141. const cityData = require('@/https/data.js')
  142. export default {
  143. data() {
  144. return {
  145. optionId: '',
  146. // 自定义界面状态 0:第一次提交 1:二次上传 2:信息查询
  147. htmlType: 0,
  148. ishtmlType: false, //是否可输入
  149. // 演示地址,请勿直接使用
  150. action: 'http://www.example.com/upload',
  151. fileList: [],
  152. Dropdown: false,
  153. DropdownIndex: 0,
  154. selectType: false,
  155. selectIndex: 0,
  156. itemList: [],
  157. show: false, //成功弹框
  158. getUploading: [], //上传分类
  159. // 第一次上传所需要值
  160. FormData: {
  161. title: '', //标题
  162. uploadingName: '', //分类名称
  163. name: '', //姓名
  164. city: '', //城市
  165. province: '', //省份
  166. hospital: '', //医院名称
  167. caseName: '', //病历类型
  168. remark: '', //备注
  169. pic: [], //上传图片
  170. mhFile: [], //上传文件
  171. mhFileName: [], //文件名称(小程序使用)
  172. },
  173. border: false,
  174. mhFileTwo: [], //二次上传
  175. mhFileTwoName: [], //二次上传名称
  176. uploadData: {
  177. type: 0
  178. },
  179. ppt: '',
  180. yesType: 1, //显示 提交按钮 还是重新提交
  181. maxCount: 10, //上传图片数量限制
  182. provinceType: false,
  183. provinceList: [],
  184. cityType: false,
  185. cityList: [],
  186. wisBllx: ''
  187. }
  188. },
  189. onLoad(option) {
  190. console.log(cityData.data)
  191. this.provinceList = cityData.data;
  192. uni.setNavigationBarTitle({
  193. title: '上传新病例'
  194. });
  195. this.action = this.$httpUrl + '/api/uploadLocality'
  196. if (option.id) {
  197. this.optionId = option.id
  198. if (uni.getStorageSync('token') && option.id == JSON.parse(uni.getStorageSync('uploadData')).id) {
  199. this.uploadData = JSON.parse(uni.getStorageSync('uploadData'))
  200. // 是否专家分配
  201. if (this.uploadData.allocation == 2) {
  202. // 二次上传完 展示详情
  203. this.htmlType = 2
  204. this.ishtmlType = true
  205. } else {
  206. if (this.uploadData.firstTrial == 2 && this.uploadData.isSecondaryUpload == 2 && this.uploadData.secondaryUpload == 1) {
  207. // 通过初审 并且 未二次上传
  208. this.htmlType = 1
  209. this.ishtmlType = true
  210. } else if ((this.uploadData.firstTrial == 2 && this.uploadData.isSecondaryUpload != 1) || (this.uploadData.firstTrial == 2 && this.uploadData.isSecondaryUpload == 1 && this.uploadData.secondaryUpload == 2)) {
  211. // 二次上传完 展示详情
  212. this.htmlType = 2
  213. this.ishtmlType = true
  214. } else if (this.uploadData.firstTrial == 1) {
  215. // 未通过重新上传
  216. this.htmlType = 0
  217. uni.setNavigationBarTitle({
  218. title: '重新编辑'
  219. });
  220. this.yesType = 2
  221. } else if (this.uploadData.firstTrial == 0) {
  222. // 未审核
  223. this.htmlType = 2
  224. this.ishtmlType = true
  225. }
  226. }
  227. console.log(this.htmlType)
  228. this.initDataTwo()
  229. }
  230. }
  231. this.getUploadingName()
  232. this.getCaseName()
  233. this.configInfo()
  234. // console.log(JSON.parse(uni.getStorageSync('uploadData')))
  235. },
  236. methods: {
  237. provinceConfirm(e) {
  238. console.log(e);
  239. this.FormData.province = e[0].label
  240. this.cityList = e[0].value
  241. },
  242. provinceMet() {
  243. if (this.ishtmlType) {
  244. return
  245. }
  246. this.provinceType = true
  247. },
  248. cityConfirm(e) {
  249. this.FormData.city = e[0].label
  250. },
  251. cityMet() {
  252. if (this.ishtmlType) {
  253. return
  254. }
  255. if (this.cityList.length != 0) {
  256. this.cityType = true
  257. } else {
  258. this.$refs.uToast.show({
  259. title: '请先选择省份',
  260. type: 'error ',
  261. })
  262. }
  263. },
  264. format(str) {
  265. if (str.indexOf('ppt') != -1) {
  266. return true
  267. } else {
  268. return false
  269. }
  270. },
  271. // 二次上传赋值
  272. initDataTwo() {
  273. console.log(this.FormData, this.uploadData);
  274. for (let key in this.FormData) {
  275. if (key == 'pic') {
  276. if (this.uploadData[key] == '') {
  277. return
  278. }
  279. // 相关图片处理
  280. let arr = this.uploadData.picTwo.split(',')
  281. this.FormData[key] = arr
  282. // this.maxCount = 10 - arr.length
  283. arr.forEach(item => {
  284. this.fileList.push({
  285. url: item
  286. })
  287. })
  288. } else if (key == 'mhFile') {
  289. if (this.uploadData[key] != '' && this.uploadData[key] != null) {
  290. if (this.uploadData.secondaryUploadFile != '' && this.uploadData.secondaryUploadFile != null) {
  291. this.FormData[key] = this.uploadData[key].split(',').concat(this.uploadData.secondaryUploadFile.split(','))
  292. } else {
  293. // 相关文件处理
  294. this.FormData[key] = this.uploadData[key].split(',')
  295. }
  296. }
  297. } else if (key == 'mhFileName') {
  298. if (this.uploadData[key] != '' && this.uploadData[key] != null) {
  299. if (this.uploadData.secondaryUploadFileName != '' && this.uploadData.secondaryUploadFileName != null) {
  300. this.FormData[key] = this.uploadData[key].split(',').concat(this.uploadData.secondaryUploadFileName.split(','))
  301. } else {
  302. // 相关文件处理
  303. this.FormData[key] = this.uploadData[key].split(',')
  304. }
  305. }
  306. } else {
  307. this.FormData[key] = this.uploadData[key]
  308. }
  309. }
  310. console.log(this.FormData)
  311. },
  312. chooseMessageFile(type) {
  313. let this_ = this;
  314. wx.chooseMessageFile({
  315. count: 10,
  316. type: 'all',
  317. success(res) {
  318. console.log(res)
  319. const tempFilePaths = res.tempFiles
  320. for (let i = 0; i < tempFilePaths.length; i++) {
  321. if (tempFilePaths[i].path.indexOf('ppt') == -1 && tempFilePaths[i].path.indexOf('mp4') == -1) {
  322. this_.$refs.uToast.show({
  323. title: '请上传ppt或mp4格式.',
  324. type: 'error ',
  325. })
  326. } else {
  327. this_.uploadFile(tempFilePaths[i], type)
  328. }
  329. }
  330. }
  331. })
  332. },
  333. // 微信上传
  334. uploadFile(val, type) {
  335. wx.uploadFile({
  336. url: this.$httpUrl + '/api/uploadLocality2/' + val.name, //仅为示例,非真实的接口地址
  337. filePath: val.path,
  338. name: 'file',
  339. formData: {
  340. 'file': val,
  341. 'name': val.name,
  342. },
  343. success: (uploadFileRes) => {
  344. let data = JSON.parse(uploadFileRes.data)
  345. if (data.code == 200) {
  346. this.$refs.uToast.show({
  347. title: '上传成功',
  348. type: 'success',
  349. })
  350. if (type == 2) {
  351. // 补充资料上传
  352. this.mhFileTwo.push(data.result)
  353. this.mhFileTwoName.push(val.name)
  354. } else {
  355. // 第一次上传
  356. this.FormData.mhFile.push(data.result)
  357. this.FormData.mhFileName.push(val.name)
  358. }
  359. }
  360. },
  361. fail(err) {
  362. console.log(err)
  363. },
  364. });
  365. },
  366. // 上传接口
  367. patientQuide() {
  368. console.log(this.$refs.uUpload1.lists);
  369. if (this.optionId == '') {
  370. // 第一次上传
  371. if (this.FormData.title == '') {
  372. this.$refs.uToast.show({
  373. title: '请输入标题',
  374. type: 'error ',
  375. })
  376. return;
  377. }
  378. if (this.FormData.uploadingName == '') {
  379. this.$refs.uToast.show({
  380. title: '请输入上传分类',
  381. type: 'error ',
  382. })
  383. return;
  384. }
  385. if (this.FormData.name == '') {
  386. this.$refs.uToast.show({
  387. title: '请输入姓名',
  388. type: 'error ',
  389. })
  390. return;
  391. }
  392. if (this.FormData.province == '') {
  393. this.$refs.uToast.show({
  394. title: '请输入省份',
  395. type: 'error ',
  396. })
  397. return;
  398. }
  399. if (this.FormData.city == '') {
  400. this.$refs.uToast.show({
  401. title: '请输入城市',
  402. type: 'error ',
  403. })
  404. return;
  405. }
  406. if (this.FormData.hospital == '') {
  407. this.$refs.uToast.show({
  408. title: '请输入医院',
  409. type: 'error ',
  410. })
  411. return;
  412. }
  413. if (this.wisBllx == 1) {
  414. if (this.FormData.caseName == '') {
  415. this.$refs.uToast.show({
  416. title: '请输入病例类型',
  417. type: 'error ',
  418. })
  419. return;
  420. }
  421. }
  422. let files1 = [];
  423. // 通过filter,筛选出上传进度为100的文件(因为某些上传失败的文件,进度值不为100,这个是可选的操作)
  424. files1 = this.$refs.uUpload1.lists.filter(val => {
  425. return val.progress == 100;
  426. })
  427. console.log(files1)
  428. if (files1.length == 0) {
  429. this.$refs.uToast.show({
  430. title: '请上传相关照片',
  431. type: 'error ',
  432. })
  433. return;
  434. }
  435. let values = []
  436. files1.forEach(item => {
  437. if (item.response) {
  438. values.push(item.response.result)
  439. } else {
  440. values.push(item.url)
  441. }
  442. })
  443. // let values = files1.map(item => item.response.result)
  444. this.FormData.pic = values.join(',')
  445. if (this.FormData.mhFile instanceof Array) {
  446. this.FormData.mhFile = this.FormData.mhFile.join(',')
  447. }
  448. if (this.FormData.mhFileName instanceof Array) {
  449. this.FormData.mhFileName = this.FormData.mhFileName.join(',')
  450. }
  451. uni.showLoading({
  452. mask: true,
  453. title:'请稍后'
  454. })
  455. this.$http.patientQuide(this.FormData).then(res => {
  456. uni.hideLoading()
  457. if (res.data.code == 200) {
  458. console.log(res.data)
  459. if (this.htmlType == 0) {
  460. this.show = true;
  461. } else {
  462. this.$refs.uToast.show({
  463. title: '上传成功',
  464. type: 'success',
  465. })
  466. uni.navigateTo({
  467. url: '/pages/index/calendar',
  468. })
  469. }
  470. } else {
  471. this.$refs.uToast.show({
  472. title: res.data.message,
  473. type: 'error ',
  474. })
  475. }
  476. })
  477. } else {
  478. // 审核失败
  479. if (this.uploadData.firstTrial == 1) {
  480. let data = JSON.parse(JSON.stringify(this.FormData))
  481. data['firstTrial'] = '0';
  482. data['id'] = this.uploadData.id;
  483. if (data.title == '') {
  484. this.$refs.uToast.show({
  485. title: '请输入标题',
  486. type: 'error ',
  487. })
  488. return;
  489. }
  490. if (data.uploadingName == '') {
  491. this.$refs.uToast.show({
  492. title: '请输入上传分类',
  493. type: 'error ',
  494. })
  495. return;
  496. }
  497. if (data.name == '') {
  498. this.$refs.uToast.show({
  499. title: '请输入姓名',
  500. type: 'error ',
  501. })
  502. return;
  503. }
  504. if (data.city == '') {
  505. this.$refs.uToast.show({
  506. title: '请输入城市',
  507. type: 'error ',
  508. })
  509. return;
  510. }
  511. if (data.province == '') {
  512. this.$refs.uToast.show({
  513. title: '请输入省份',
  514. type: 'error ',
  515. })
  516. return;
  517. }
  518. if (data.hospital == '') {
  519. this.$refs.uToast.show({
  520. title: '请输入医院',
  521. type: 'error ',
  522. })
  523. return;
  524. }
  525. if (this.wisBllx == 1) {
  526. if (data.caseName == '') {
  527. this.$refs.uToast.show({
  528. title: '请输入病例类型',
  529. type: 'error ',
  530. })
  531. return;
  532. }
  533. }
  534. let files1 = [];
  535. // 通过filter,筛选出上传进度为100的文件(因为某些上传失败的文件,进度值不为100,这个是可选的操作)
  536. files1 = this.$refs.uUpload1.lists.filter(val => {
  537. return val.progress == 100;
  538. })
  539. console.log(files1)
  540. if (files1.length == 0) {
  541. this.$refs.uToast.show({
  542. title: '请上传相关照片',
  543. type: 'error ',
  544. })
  545. return;
  546. }
  547. let values = []
  548. files1.forEach(item => {
  549. if (item.response) {
  550. values.push(item.response.result)
  551. } else {
  552. values.push(item.url)
  553. }
  554. })
  555. // let values = files1.map(item => item.response.result)
  556. data.pic = values.join(',')
  557. data.picTwo = values.join(',')
  558. if (data.mhFile instanceof Array) {
  559. data.mhFile = data.mhFile.join(',')
  560. }
  561. if (data.mhFileName instanceof Array) {
  562. data.mhFileName = data.mhFileName.join(',')
  563. }
  564. uni.showLoading({
  565. mask: true,
  566. title:'请稍后'
  567. })
  568. this.$http.patientQuideEdit(data).then(res => {
  569. console.log(res)
  570. uni.hideLoading()
  571. if (res.data.code == 200) {
  572. this.$refs.uToast.show({
  573. title: '提交成功',
  574. })
  575. uni.navigateTo({
  576. url: '/pages/index/calendar',
  577. })
  578. } else {
  579. this.$refs.uToast.show({
  580. title: res.data.message,
  581. type: 'error ',
  582. })
  583. }
  584. })
  585. } else {
  586. // 二次上传
  587. if (this.mhFileTwo == '') {
  588. this.$refs.uToast.show({
  589. title: '请上传补充资料',
  590. type: 'error ',
  591. })
  592. return;
  593. }
  594. let files1 = [];
  595. // 通过filter,筛选出上传进度为100的文件(因为某些上传失败的文件,进度值不为100,这个是可选的操作)
  596. files1 = this.$refs.uUpload1.lists.filter(val => {
  597. return val.progress == 100;
  598. })
  599. console.log(files1)
  600. if (files1.length == 0) {
  601. this.$refs.uToast.show({
  602. title: '请上传相关照片',
  603. type: 'error ',
  604. })
  605. return;
  606. }
  607. let values = []
  608. files1.forEach(item => {
  609. if (item.response) {
  610. values.push(item.response.result)
  611. } else {
  612. values.push(item.url)
  613. }
  614. })
  615. // let values = files1.map(item => item.response.result)
  616. this.FormData.pic = values.join(',')
  617. this.FormData.picTwo = values.join(',')
  618. if (this.FormData.mhFile instanceof Array) {
  619. this.FormData.mhFile = this.FormData.mhFile.join(',')
  620. }
  621. if (this.FormData.mhFileName instanceof Array) {
  622. this.FormData.mhFileName = this.FormData.mhFileName.join(',')
  623. }
  624. // 二次上传
  625. if (this.htmlType == 1) {
  626. let datas = {
  627. id: this.optionId,
  628. secondaryUpload: 2,
  629. secondaryUploadFileName: this.mhFileTwoName.join(','),
  630. secondaryUploadFile: this.mhFileTwo.join(',')
  631. }
  632. console.log(datas)
  633. uni.showLoading({
  634. mask: true,
  635. title:'请稍后'
  636. })
  637. this.$http.patientQuideEdit(datas).then(res => {
  638. uni.hideLoading()
  639. console.log(res)
  640. if (res.data.code == 200) {
  641. this.$refs.uToast.show({
  642. title: '提交成功',
  643. })
  644. uni.navigateTo({
  645. url: '/pages/index/calendar',
  646. })
  647. } else {
  648. this.$refs.uToast.show({
  649. title: res.data.message,
  650. type: 'error ',
  651. })
  652. }
  653. })
  654. }
  655. }
  656. }
  657. // if(this.htmlType!=0){
  658. // // 二次上传 补充资料
  659. // if(this.FormData.mhFile instanceof Array){
  660. // this.FormData.mhFile = this.FormData.mhFile.concat(this.mhFileTwo).join(',')
  661. // }
  662. // }else{
  663. // if(this.FormData.mhFile instanceof Array){
  664. // this.FormData.mhFile = this.FormData.mhFile.join(',')
  665. // }
  666. // }
  667. console.log(this.FormData)
  668. },
  669. // 继续提交
  670. nextMeh() {
  671. console.log('继续提交')
  672. this.show = false
  673. this.fileList = []
  674. this.$refs.uUpload1.clear()
  675. this.FormData = {
  676. title: '', //标题
  677. uploadingName: '', //分类名称
  678. name: '', //姓名
  679. city: '', //城市
  680. province: '', //省份
  681. hospital: '', //医院名称
  682. caseName: '', //病历类型
  683. remark: '', //备注
  684. pic: [], //上传图片
  685. mhFile: [], //上传文件
  686. mhFileName: [], //文件名称(小程序使用)
  687. }
  688. },
  689. uploadMask() {
  690. console.log('false')
  691. this.Dropdown = false;
  692. this.selectType = false;
  693. },
  694. // 上传分类
  695. getUploadingName() {
  696. this.$http.getUploadingName()
  697. .then(res => {
  698. if (res.data.code == 200) {
  699. this.getUploading = res.data.result
  700. // this.DropdownIndex=res.data.result[0].id
  701. }
  702. })
  703. },
  704. // 病历分类
  705. getCaseName() {
  706. this.$http.getCaseName()
  707. .then(res => {
  708. if (res.data.code == 200) {
  709. this.itemList = res.data.result
  710. }
  711. })
  712. },
  713. // 系统设置
  714. configInfo() {
  715. this.$http.configInfo()
  716. .then(res => {
  717. if (res.data.code == 200) {
  718. console.log(res)
  719. // console.log(this.data)
  720. this.ppt = res.data.result.ppt
  721. this.wisBllx = res.data.result.wisBllx
  722. }
  723. })
  724. },
  725. // 下载文件
  726. downloadFile(url) {
  727. uni.showLoading({
  728. title: '正在下载……'
  729. });
  730. uni.downloadFile({
  731. url: url,
  732. success: (data) => {
  733. console.log('打印data', data)
  734. if (data.statusCode === 200) {
  735. console.log('下载成功');
  736. //隐藏加载框
  737. uni.hideLoading();
  738. //文件保存到本地
  739. uni.saveFile({
  740. tempFilePath: data.tempFilePath, //临时路径
  741. success: function(res) {
  742. // console.log('打印res',res)
  743. uni.showToast({
  744. icon: 'success',
  745. mask: true,
  746. // title: '文件已保存:' + res.savedFilePath, //保存路径
  747. title: '下载成功',
  748. duration: 2000,
  749. });
  750. //自动打开文档查看
  751. setTimeout(() => {
  752. var filePath = res.savedFilePath;
  753. uni.openDocument({ //新开页面打开文档,支持格式:doc, xls, ppt, pdf, docx, xlsx, pptx。
  754. filePath: filePath,
  755. showMenu: true,
  756. success: function(res) {
  757. console.log('打开文档成功');
  758. }
  759. });
  760. }, 1000)
  761. },
  762. });
  763. }
  764. }
  765. });
  766. },
  767. // 上传分类选择
  768. DropdownMeh(item) {
  769. this.FormData.uploadingName = item;
  770. this.DropdownIndex = item;
  771. this.Dropdown = false;
  772. },
  773. selectMeh(item) {
  774. this.FormData.caseName = item;
  775. this.selectIndex = item;
  776. this.selectType = false;
  777. },
  778. // 图片上传失败 清空
  779. progress1(res, index, lists, name) {
  780. // console.log(JSON.parse(res.data))
  781. if (JSON.parse(res.data).code == 0) {
  782. this.$refs.uToast.show({
  783. title: JSON.parse(res.data).msg,
  784. type: 'error ',
  785. })
  786. // this.$refs.uUpload1.clear()
  787. }
  788. },
  789. // 删除相关文件
  790. deFile(index, type) {
  791. if (type == 2) {
  792. this.mhFileTwo.splice(index, 1)
  793. this.mhFileTwoName.splice(index, 1)
  794. } else {
  795. this.FormData.mhFile.splice(index, 1)
  796. this.FormData.mhFileName.splice(index, 1)
  797. }
  798. },
  799. // 返回首页
  800. indexHerf() {
  801. uni.navigateTo({
  802. url: '/pages/index/index',
  803. })
  804. },
  805. }
  806. }
  807. </script>
  808. <style lang="scss">
  809. .upload {
  810. padding: 32rpx 32rpx 120rpx;
  811. .title {
  812. input {
  813. font-size: 48rpx;
  814. color: #000;
  815. padding-bottom: 24rpx;
  816. }
  817. }
  818. .flex {
  819. position: relative;
  820. .Dropdown {
  821. position: absolute;
  822. top: 0;
  823. z-index: 10;
  824. width: 100%;
  825. padding: 24rpx 36rpx 0;
  826. background-color: #fff;
  827. box-shadow: 0px 2rpx 20rpx 0px rgba(0, 0, 0, 0.1);
  828. border-radius: 16rpx;
  829. font-size: 28rpx;
  830. color: rgba(0, 0, 0, 0.8);
  831. .li {
  832. margin-bottom: 28rpx;
  833. }
  834. .active {
  835. color: $color;
  836. }
  837. }
  838. }
  839. .upData {
  840. display: inline-block;
  841. padding: 4rpx 24rpx;
  842. background: rgba(22, 127, 255, 0.1);
  843. border-radius: 24rpx;
  844. font-size: 28rpx;
  845. color: $color;
  846. image {
  847. width: 32rpx;
  848. height: 32rpx;
  849. margin-left: 12rpx;
  850. }
  851. }
  852. .box {
  853. box-sizing: border-box;
  854. padding: 32rpx 20rpx 0;
  855. background-color: #fff;
  856. border-radius: 24rpx;
  857. margin-top: 24rpx;
  858. .tit_box {
  859. font-size: 32rpx;
  860. color: $color;
  861. }
  862. .msg {
  863. display: block;
  864. margin-top: 24rpx;
  865. font-size: 28rpx;
  866. color: #000000;
  867. padding-bottom: 32rpx;
  868. }
  869. .tit {
  870. font-weight: 700;
  871. font-size: 32rpx;
  872. color: rgba(0, 0, 0, 0.8);
  873. }
  874. .input {
  875. position: relative;
  876. .u-upload {
  877. .u-list-item {
  878. width: 180rpx !important;
  879. height: 180rpx !important;
  880. }
  881. }
  882. .label {}
  883. .icon {
  884. width: 140rpx;
  885. color: rgba(0, 0, 0, 0.8);
  886. }
  887. .msg {
  888. color: rgba(0, 0, 0, 0.35);
  889. margin-left: 10rpx;
  890. }
  891. .list {
  892. padding: 20rpx;
  893. background: rgba(227, 66, 33, 0.1);
  894. border-radius: 24rpx;
  895. font-size: 28rpx;
  896. color: #000000;
  897. margin-top: 20rpx;
  898. image {
  899. width: 40rpx;
  900. height: 40rpx;
  901. margin-right: 20rpx;
  902. }
  903. text {
  904. flex: 1;
  905. white-space: nowrap;
  906. text-overflow: ellipsis;
  907. overflow: hidden;
  908. word-break: break-all;
  909. }
  910. }
  911. .list1 {
  912. background: rgba(22, 127, 255, 0.1);
  913. }
  914. u-input {
  915. flex: 1;
  916. }
  917. image {
  918. width: 32rpx;
  919. height: 32rpx;
  920. }
  921. .upButton {
  922. padding: 24rpx 0;
  923. text-align: center;
  924. background: #F3F3F3;
  925. border-radius: 24rpx;
  926. color: rgba(0, 0, 0, 0.35);
  927. font-size: 32rpx;
  928. margin-top: 20rpx;
  929. image {
  930. vertical-align: middle;
  931. }
  932. }
  933. .select {
  934. position: absolute;
  935. top: 10rpx;
  936. z-index: 10;
  937. right: 0;
  938. width: 550rpx;
  939. padding: 24rpx 36rpx 0;
  940. background-color: #fff;
  941. box-shadow: 0px 2rpx 20rpx 0px rgba(0, 0, 0, 0.1);
  942. border-radius: 16rpx;
  943. font-size: 28rpx;
  944. color: rgba(0, 0, 0, 0.8);
  945. }
  946. }
  947. .input:last-child {
  948. border-bottom: 1px solid transparent;
  949. }
  950. }
  951. .template {
  952. padding: 24rpx 0;
  953. font-size: 28rpx;
  954. color: #000;
  955. .herf {
  956. color: $color;
  957. }
  958. }
  959. .suc {
  960. position: relative;
  961. text-align: center;
  962. width: 520rpx;
  963. height: 510rpx;
  964. margin: 0 auto;
  965. image {
  966. position: absolute;
  967. left: 0;
  968. top: 0;
  969. width: 100%;
  970. height: 510rpx;
  971. }
  972. .con {
  973. position: relative;
  974. z-index: 11;
  975. text-align: center;
  976. box-sizing: border-box;
  977. padding: 0 40rpx;
  978. overflow: hidden;
  979. .tit {
  980. font-size: 36rpx;
  981. color: $color;
  982. padding-top: 190rpx;
  983. }
  984. .p {
  985. width: 230rpx;
  986. margin: 32rpx auto 50rpx;
  987. font-size: 28rpx;
  988. color: rgba(0, 0, 0, 0.6);
  989. }
  990. .btn {
  991. display: flex;
  992. flex-direction: row;
  993. align-items: center;
  994. justify-content: space-between;
  995. view {
  996. width: 208rpx;
  997. height: 56rpx;
  998. line-height: 56rpx;
  999. text-align: center;
  1000. border: 2rpx solid rgba(0, 0, 0, 0.35);
  1001. font-size: 28rpx;
  1002. color: rgba(0, 0, 0, 0.35);
  1003. border-radius: 40rpx;
  1004. }
  1005. .next {
  1006. background-color: $color;
  1007. color: #fff;
  1008. border: 2rpx solid $color;
  1009. }
  1010. }
  1011. }
  1012. }
  1013. .u-mode-center-box {
  1014. background-color: transparent !important;
  1015. }
  1016. .uploadBtn {
  1017. position: fixed;
  1018. bottom: 0;
  1019. left: 0;
  1020. width: 100%;
  1021. box-sizing: border-box;
  1022. padding: 12rpx 32rpx;
  1023. display: flex;
  1024. flex-direction: row;
  1025. align-items: center;
  1026. justify-content: space-between;
  1027. font-size: 32rpx;
  1028. color: #fff;
  1029. background-color: #fff;
  1030. z-index: 11;
  1031. .yes {
  1032. width: 100%;
  1033. box-sizing: border-box;
  1034. border-radius: 48rpx;
  1035. padding: 20rpx 0;
  1036. text-align: center;
  1037. background-color: $color;
  1038. }
  1039. }
  1040. }
  1041. </style>