upload.vue 34 KB

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