repairDetail.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537
  1. <template>
  2. <view class="content">
  3. <view class="top">
  4. <u-navbar :title="title" @leftClick="leftClick" bgColor="rgba(0,0,0,0)" :placeholder="true"></u-navbar>
  5. <view class="state">{{state}}</view>
  6. <view class="top_box" v-if="state_id == '2'">
  7. <view class="hflex acenter ">
  8. <image :src="worker.headimg" class="headimg"></image>
  9. <view class="img_right">
  10. <view class="hflex acenter ">
  11. <view class="name">{{worker.name}}</view>
  12. <view class="blue_bg">维修工</view>
  13. </view>
  14. <view class="hflex acenter ">
  15. <view class="text_style1">{{worker.is_renz?'已认证':'未认证'}}</view>
  16. <view class="text_style1">| {{worker.wxc}}</view>
  17. </view>
  18. </view>
  19. </view>
  20. <view class="hflex acenter jbetween" style="padding-top: 32rpx;">
  21. <view class="hflex acenter">
  22. <view class="text_style1">联系电话:</view>
  23. <view class="text_style1">{{worker.phone}}</view>
  24. <view class="phone hflex acenter jcenter">
  25. <u-icon name="phone-fill" color="#506DFF" size="9"></u-icon>
  26. </view>
  27. </view>
  28. <view class="btn hflex acenter jcenter">查看详情</view>
  29. </view>
  30. </view>
  31. </view>
  32. <view class="box">
  33. <view class="hflex acenter" style="padding-top: 28rpx;">
  34. <image :src="boss.headimg" class="headimg"></image>
  35. <view class="img_right">
  36. <view class="hflex acenter ">
  37. <view class="name">{{boss.name}}</view>
  38. </view>
  39. <view class="hflex acenter ">
  40. <view class="text_style1">{{boss.addr}}</view>
  41. <view class="text_style1">| {{boss.date}}发布</view>
  42. </view>
  43. </view>
  44. </view>
  45. <view class="box_contetn">{{boss.content}}</view>
  46. <view class="imgs hflex acenter fwrap">
  47. <block v-for="(item,index) in boss.imgs" :key="index">
  48. <image :src="item" class="img" mode="aspectFill"></image>
  49. </block>
  50. </view>
  51. <view class="hflex acenter jbetween cell">
  52. <view class="left_text">联系方式</view>
  53. <view class="right_text">{{boss.phone}}</view>
  54. </view>
  55. <view class="hflex acenter jbetween cell">
  56. <view class="left_text">维修时间</view>
  57. <view class="right_text">{{boss.time}}</view>
  58. </view>
  59. <view class="hflex acenter jbetween cell" style="padding-bottom: 28rpx;">
  60. <view class="left_text">维修地点</view>
  61. <view class="right_text">{{boss.address}}</view>
  62. </view>
  63. <view class="hflex acenter jbetween type">
  64. <view class="right_text">订单类型</view>
  65. <view class="text_blue">{{boss.type}}</view>
  66. </view>
  67. <view class="offer hflex acenter jbetween">
  68. <view class="hflex acenter">
  69. <view class="offer_label">订单报价:</view>
  70. <view class="offer_text">¥{{boss.offest}}</view>
  71. </view>
  72. <view class="btn hflex acenter jcenter">查看详情</view>
  73. </view>
  74. </view>
  75. <view class="box" style="margin-bottom: 186rpx;" v-if="state_id == '2'">
  76. <view class="hflex acenter jbetween cell">
  77. <view class="left_text">订单编号</view>
  78. <view class="right_text">{{order_no}}</view>
  79. </view>
  80. <view class="hflex acenter jbetween cell">
  81. <view class="left_text">创建时间</view>
  82. <view class="right_text">{{create_date}}</view>
  83. </view>
  84. </view>
  85. <view class="box" style="margin-bottom: 186rpx;" v-if="state_id == '1'">
  86. <block v-for="(item,index) in works" :key="index">
  87. <view class="item_bg" :class="active == index ? 'active' : ''" @click="selectItem(index)">
  88. <view class="hflex jbetween">
  89. <view class="hflex acenter">
  90. <image :src="item.headimg" class="headimg"></image>
  91. <view class="img_right">
  92. <view class="hflex acenter ">
  93. <view class="name">{{item.name}}</view>
  94. <view class="blue_bg">维修工</view>
  95. </view>
  96. <view class="hflex acenter text_hide" style="width: 270rpx;">
  97. <view class="text_style1">{{item.is_renz?'已认证':'未认证'}} | {{item.wxc}}</view>
  98. </view>
  99. </view>
  100. </view>
  101. <view class="text_red">报价:<span style="font-size: 36rpx;">¥{{item.offest}}</span></view>
  102. </view>
  103. <view class="hflex acenter jbetween">
  104. <view class="hflex acenter">
  105. <view class="text_style1">联系电话:</view>
  106. <view class="text_style1">{{item.phone}}</view>
  107. <view class="phone hflex acenter jcenter">
  108. <u-icon name="phone-fill" color="#506DFF" size="9"></u-icon>
  109. </view>
  110. </view>
  111. <view class="btn hflex acenter jcenter">查看详情</view>
  112. </view>
  113. </view>
  114. </block>
  115. </view>
  116. <view class="bottom">
  117. <view class="btn hflex acenter jcenter" v-if="is_boss == '1' && state_id == '2'">
  118. <image src="/static/images/comment/down-fff.png" style="width: 33rpx; height: 33rpx;"></image>
  119. <view>下载文件</view>
  120. </view>
  121. <view class="btn hflex acenter jcenter" :class="active == -1 ? 'btn1' : ''" v-if="is_boss == '1' && state_id == '1'" @click="match">匹配维修工</view>
  122. <view class="hflex acenter jcenter" v-if="is_boss == '0'">
  123. <view class="left_btn hflex acenter jcenter">
  124. <image src="/static/images/comment/down-blue.png" style="width: 33rpx; height: 33rpx;"></image>
  125. <view>下载文件</view>
  126. </view>
  127. <view class="right_btn hflex acenter jcenter">查看回复</view>
  128. </view>
  129. </view>
  130. <u-modal :show="show">
  131. <view class="modeal_content" slot="default">
  132. <view>{{content}}</view>
  133. </view>
  134. <view slot="confirmButton" class="button_group hflex acenter jcenter">
  135. <view class="left hflex acenter jcenter" @click="close">我再想想</view>
  136. <view class="right hflex acenter jcenter" @click="sure">确认匹配</view>
  137. </view>
  138. </u-modal>
  139. </view>
  140. </template>
  141. <script>
  142. import $api from '@/static/js/api.js'
  143. var that = ''
  144. export default {
  145. data() {
  146. return {
  147. title: '',
  148. state_id: '1', //未报价,已报价,已确认
  149. state: '订单已匹配成功',
  150. worker: {
  151. headimg: '/static/images/mine/avatar2.jpg',
  152. name: '张琪',
  153. is_renz: true,
  154. wxc: '博锐船舶器械维修厂',
  155. phone: '18978652376',
  156. },
  157. boss: {
  158. headimg: '/static/images/mine/avatar1.jpg',
  159. name: 'NANA的微笑',
  160. addr: '江苏南京市',
  161. date: '2022-08-08 12:34',
  162. phone: '18978652376',
  163. time: '2022-08-03至08-04',
  164. type: '快修',
  165. address: '上海市浦东区滨河路18号江东造船厂',
  166. offest: '19999.89',
  167. content: '请详细描述故障情况及原因,方便师傅带齐工具,并为您提供准确合理的维修请详细描述故障情况及原因,方便师傅带齐工具,并为提供准确合理的维修请详细描述故障情况及',
  168. imgs: ['/static/images/index/class_img3.png','/static/images/index/class_img4.png','/static/images/index/class_img5.png'],
  169. },
  170. works: [
  171. {
  172. headimg: '/static/images/mine/avatar2.jpg',
  173. name: '张琪',
  174. is_renz: true,
  175. wxc: '博锐船舶器械维修厂',
  176. phone: '18978652376',
  177. offest: '199',
  178. },
  179. {
  180. headimg: '/static/images/mine/avatar2.jpg',
  181. name: '张琪',
  182. is_renz: true,
  183. wxc: '博锐船舶器械维修厂',
  184. phone: '18978652376',
  185. offest: '299',
  186. },
  187. {
  188. headimg: '/static/images/mine/avatar2.jpg',
  189. name: '张琪',
  190. is_renz: true,
  191. wxc: '博锐船舶器械维修厂',
  192. phone: '18978652376',
  193. offest: '799',
  194. },
  195. ],
  196. order_no: 'Cbz20221238993932',
  197. create_date: '2022-08-11 20:34:34',
  198. active: -1,
  199. is_boss: '0',
  200. show: false,
  201. content: '确定要匹配当前维修工吗?',
  202. }
  203. },
  204. onLoad() {
  205. that = this
  206. },
  207. onReady() {
  208. if(true) {
  209. uni.setNavigationBarTitle({
  210. title: '订单详情'
  211. })
  212. }
  213. },
  214. methods: {
  215. leftClick() {
  216. $api.jump(-1)
  217. },
  218. selectItem(index) {
  219. that.active = index
  220. },
  221. match() {
  222. if(that.active == -1) {
  223. $api.info('请选择维修工')
  224. return
  225. } else {
  226. that.show = true
  227. }
  228. },
  229. close() {
  230. that.show = false
  231. },
  232. sure() {
  233. that.state_id = '2'
  234. that.state = '订单已匹配成功'
  235. that.close()
  236. }
  237. },
  238. }
  239. </script>
  240. <style lang="scss" scoped>
  241. .content {
  242. background: #F4F4F4;
  243. .top {
  244. box-sizing: border-box;
  245. width: 100%;
  246. padding: 0 30rpx;
  247. background: linear-gradient(180deg, #506DFF 0%, #F3F3F3 100%);
  248. .state {
  249. font-size: 44rpx;
  250. font-weight: 500;
  251. color: #FFFFFF;
  252. line-height: 60rpx;
  253. padding: 28rpx 0;
  254. }
  255. .top_box {
  256. width: 100%;
  257. box-sizing: border-box;
  258. padding: 28rpx 20rpx 20rpx;
  259. background: #FFFFFF;
  260. border-radius: 10px;
  261. .headimg {
  262. width: 72rpx;
  263. height: 72rpx;
  264. border-radius: 50%;
  265. }
  266. .img_right {
  267. margin-left: 12rpx;
  268. .name {
  269. font-size: 30rpx;
  270. font-weight: 400;
  271. color: #222222;
  272. line-height: 42rpx;
  273. }
  274. .blue_bg {
  275. margin-left: 8rpx;
  276. width: 72rpx;
  277. height: 28rpx;
  278. background: #506DFF;
  279. border-radius: 4rpx;
  280. font-size: 20rpx;
  281. font-weight: 400;
  282. color: #FFFFFF;
  283. line-height: 28rpx;
  284. text-align: center;
  285. }
  286. }
  287. .text_style1 {
  288. font-size: 24rpx;
  289. font-weight: 400;
  290. color: #666666;
  291. line-height: 34rpx;
  292. padding-right: 12rpx;
  293. }
  294. .phone {
  295. width: 32rpx;
  296. height: 32rpx;
  297. background: #E1E6FF;
  298. border-radius: 8rpx;
  299. }
  300. .btn {
  301. width: 132rpx;
  302. height: 48rpx;
  303. border-radius: 24rpx;
  304. border: 2rpx solid #506DFF;
  305. font-size: 24rpx;
  306. font-weight: 400;
  307. color: #506DFF;
  308. line-height: 48rpx;
  309. }
  310. }
  311. }
  312. .box {
  313. width: 690rpx;
  314. margin: 20rpx auto 0;
  315. box-sizing: border-box;
  316. padding: 0 20rpx 20rpx;
  317. background: #FFFFFF;
  318. border-radius: 10px;
  319. .box_contetn {
  320. font-size: 28rpx;
  321. font-weight: 400;
  322. color: #444444;
  323. line-height: 44rpx;
  324. padding: 24rpx 0 0;
  325. }
  326. .imgs{
  327. width: 100%;
  328. .img {
  329. width: 208rpx;
  330. height: 208rpx;
  331. border-radius: 6px;
  332. margin: 20rpx 14rpx 0 0;
  333. }
  334. .img:nth-child(3n+3) {
  335. margin: 20rpx 0 0;
  336. }
  337. }
  338. .cell {
  339. padding: 24rpx 0 0;
  340. .left_text {
  341. font-size: 26rpx;
  342. font-weight: 400;
  343. color: #777777;
  344. line-height: 36rpx;
  345. }
  346. .right_text {
  347. font-size: 26rpx;
  348. font-weight: 500;
  349. color: #222222;
  350. line-height: 32rpx;
  351. }
  352. }
  353. .type {
  354. padding: 24rpx 0;
  355. border-top: 1rpx solid #F4F4F4;
  356. .text_blue {
  357. font-size: 28rpx;
  358. font-weight: 500;
  359. color: #506DFF;
  360. line-height: 40rpx;
  361. }
  362. }
  363. .offer {
  364. width: 100%;
  365. height: 76rpx;
  366. background: #EAF4FF;
  367. border-radius: 12rpx;
  368. box-sizing: border-box;
  369. padding: 16rpx 20rpx;
  370. .offer_label {
  371. font-size: 24rpx;
  372. font-weight: 400;
  373. color: #506DFF;
  374. line-height: 34rpx;
  375. }
  376. .offer_text {
  377. font-size: 32rpx;
  378. font-weight: 400;
  379. color: #222222;
  380. line-height: 40rpx;
  381. }
  382. .btn {
  383. width: 132rpx;
  384. height: 48rpx;
  385. border-radius: 24rpx;
  386. border: 2rpx solid #506DFF;
  387. font-size: 24rpx;
  388. font-weight: 400;
  389. color: #506DFF;
  390. line-height: 48rpx;
  391. }
  392. }
  393. .headimg {
  394. width: 72rpx;
  395. height: 72rpx;
  396. border-radius: 50%;
  397. }
  398. .img_right {
  399. margin-left: 12rpx;
  400. .name {
  401. font-size: 30rpx;
  402. font-weight: 400;
  403. color: #222222;
  404. line-height: 42rpx;
  405. }
  406. .blue_bg {
  407. margin-left: 8rpx;
  408. width: 72rpx;
  409. height: 28rpx;
  410. background: #506DFF;
  411. border-radius: 4rpx;
  412. font-size: 20rpx;
  413. font-weight: 400;
  414. color: #FFFFFF;
  415. line-height: 28rpx;
  416. text-align: center;
  417. }
  418. }
  419. .text_style1 {
  420. font-size: 24rpx;
  421. font-weight: 400;
  422. color: #666666;
  423. line-height: 34rpx;
  424. padding-right: 12rpx;
  425. }
  426. .phone {
  427. width: 32rpx;
  428. height: 32rpx;
  429. background: #E1E6FF;
  430. border-radius: 8rpx;
  431. }
  432. .active {
  433. background: #F0F3FF !important;
  434. border-radius: 8px;
  435. border: 1px solid #506DFF;
  436. }
  437. .item_bg {
  438. background: #F4F4F4;
  439. border-radius: 8px;
  440. margin-top: 20rpx;
  441. box-sizing: border-box;
  442. padding: 20rpx;
  443. .text_red {
  444. font-size: 24rpx;
  445. font-weight: 400;
  446. color: #FF4646;
  447. line-height: 34rpx;
  448. }
  449. .btn {
  450. width: 132rpx;
  451. height: 48rpx;
  452. border-radius: 24rpx;
  453. border: 2rpx solid #506DFF;
  454. font-size: 24rpx;
  455. font-weight: 400;
  456. color: #506DFF;
  457. line-height: 48rpx;
  458. }
  459. }
  460. }
  461. .bottom {
  462. width: 100%;
  463. height: 166rpx;
  464. background: #FFFFFF;
  465. position: fixed;
  466. bottom: 0;
  467. z-index: 99;
  468. box-sizing: border-box;
  469. padding: 10rpx 30rpx 0;
  470. .btn {
  471. width: 100%;
  472. height: 88rpx;
  473. background: #506DFF;
  474. border-radius: 44rpx;
  475. font-size: 36rpx;
  476. font-weight: 500;
  477. color: #FFFFFF;
  478. line-height: 50rpx;
  479. }
  480. .btn1 {
  481. background: rgba(80,109,255,0.3) !important;
  482. }
  483. .left_btn {
  484. width: 300rpx;
  485. height: 88rpx;
  486. background: #ECEFFE;
  487. border-radius: 44rpx;
  488. font-size: 36rpx;
  489. font-weight: 500;
  490. color: #506DFF;
  491. margin-right: 20rpx;
  492. }
  493. .right_btn {
  494. width: 370rpx;
  495. height: 88rpx;
  496. background: #506DFF;
  497. border-radius: 44rpx;
  498. font-size: 36rpx;
  499. font-weight: 500;
  500. color: #fff;
  501. }
  502. }
  503. .modeal_content {
  504. font-size: 36rpx;
  505. font-weight: 500;
  506. color: #222222;
  507. line-height: 50rpx;
  508. }
  509. .left {
  510. width: 230rpx;
  511. height: 84rpx;
  512. background: #ECEFFF;
  513. border-radius: 42rpx;
  514. font-size: 32rpx;
  515. font-weight: 400;
  516. color: #506DFF;
  517. margin-right: 50rpx;
  518. }
  519. .right {
  520. width: 230rpx;
  521. height: 84rpx;
  522. background: #506DFF;
  523. border-radius: 42rpx;
  524. font-size: 32rpx;
  525. font-weight: 400;
  526. color: #FFFFFF;
  527. }
  528. }
  529. </style>