orderDetail.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909
  1. <template>
  2. <view class="box">
  3. <view class="status_bar" :style="{height: iStatusBarHeight + 'px'}"></view>
  4. <view class="top">
  5. <view class="nav" :style="{top: iStatusBarHeight + 'px'}">
  6. <view>
  7. <image src="../../static/img/baiback22.png" mode="" class="gobackImg" @click="goback"></image>
  8. <image src="../../static/img/baigoindex22.png" mode="" class="goIndexImg" @click="goIndex()"></image>
  9. </view>
  10. <view>订单详情</view>
  11. <view style="width: 200rpx;"></view>
  12. </view>
  13. <view style="height: 44px;"></view>
  14. <view :style="{height: iStatusBarHeight + 'px'}"></view>
  15. <view class="SheetState" v-if="orderData.SheetState==1">等待付款</view>
  16. <view class="SheetState" v-if="orderData.SheetState==2">请尽快到店享受服务</view>
  17. <view class="SheetState" v-if="orderData.SheetState==3||orderData.SheetState==5">订单已完成</view>
  18. <view class="SheetState" v-if="orderData.SheetState==0">订单已取消</view>
  19. <view class="SheetState" v-if="orderData.SheetState==4">订单已完成</view>
  20. </view>
  21. <view v-if="orderData">
  22. <view class="orderTop">
  23. <view class="timeBox">
  24. <view class="timeLeft">
  25. <span v-if="orderData.SheetState==1||orderData.SheetState==2||orderData.SheetState==0">预约到店:{{orderData.OrderTime}}</span>
  26. <span v-else>服务时间:{{orderData.ServiceTime}}</span>
  27. <image v-if="orderData.SheetState==1||orderData.SheetState==2" src="../../static/img/icon_edit.png" mode="" class="timeEditImg" @click="timeShowClick"></image>
  28. </view>
  29. <view class="timeRight" @click="qrcodeClick">订单码</view>
  30. </view>
  31. <view class="shopBox">
  32. <image src="../../static/img/dianp.png" mode="" class="shopBoximg"></image>
  33. <view class="shopCont">
  34. <view class="shopName">{{orderData.ShopName}}</view>
  35. <view class="Address">
  36. {{orderData.ProvinceName}}{{orderData.CityName}}{{orderData.AreaName}}{{orderData.Address}}
  37. </view>
  38. </view>
  39. <view class="shopRightBox" @click="map">
  40. <view> <image src="../../static/img/icon_ditu.png" mode="" class="shopRightImg"></image> </view>
  41. <view class="shopRihgtTxt">地图</view>
  42. </view>
  43. <view class="shopsx"></view>
  44. <view class="shopRightBox" @click="call">
  45. <view> <image src="../../static/img/icon_phone.png" mode="" class="shopRightImg"></image> </view>
  46. <view class="shopRihgtTxt">电话</view>
  47. </view>
  48. </view>
  49. <view class="people">
  50. <image src="../../static/img/icon_ren.png" mode="" class="shopBoximg"></image>
  51. <view class="peopleCont">{{orderData.ContactName}}</view>
  52. <view class="peopleCont" style="padding-left: 20rpx;">{{orderData.ContactPhone}}</view>
  53. </view>
  54. <view class="PlateNumberBox">
  55. <image src="../../static/img/icon_che.png" mode="" class="shopBoximg"></image>
  56. <view class="">
  57. <view class="PlateNumberBoxTop">
  58. <view class="PlateNumbercx"> <span v-if="orderData.Brand">{{orderData.Brand}}</span>
  59. <span style="padding-left: 20rpx;" v-if="orderData.Series">{{orderData.Series}}</span>
  60. </view>
  61. <view class="PlateNumber">{{orderData.PlateNumber}}</view>
  62. </view>
  63. <view class="CarModel">{{orderData.CarModel}}</view>
  64. </view>
  65. </view>
  66. </view>
  67. <view style="margin-top: -40rpx;"></view>
  68. <!-- 商品明细-->
  69. <view class="detailedBox itemBox" v-if="orderData.goods.length!=0">
  70. <view class="detailedTitle">商品明细</view>
  71. <view class="detailedLineBox">
  72. <view class="detailedLine" v-for="(item,index) in orderData.goods">
  73. <view>
  74. <image :src="item.Url" mode="" class="detailedImg" v-if="item.Url"></image>
  75. <image src="../../static/img/noimg.png" mode="" class="detailedImg" v-else></image>
  76. </view>
  77. <view class="detailedCont">
  78. <view class="detailedName">{{item.GoodsName}}</view>
  79. <view class="detailedContBottom">
  80. <span class="SalePrice">¥{{item.SalePrice}}</span>
  81. <span>x{{item.SaleQty}}</span>
  82. </view>
  83. </view>
  84. </view>
  85. </view>
  86. </view>
  87. <!-- 商品明细-->
  88. <!-- 项目明细 -->
  89. <view class="detailedBox itemBox" v-if=" orderData.items.length!=0">
  90. <view class="detailedTitle">项目明细</view>
  91. <view class="detailedLineBox">
  92. <view class="detailedLine" v-for="(item,index) in orderData.items">
  93. <view>
  94. <image :src="item.Url" mode="" class="detailedImg" v-if="item.Url"></image>
  95. <image src="../../static/img/noimg.png" mode="" class="detailedImg" v-else></image>
  96. </view>
  97. <view class="detailedCont">
  98. <view class="detailedName">{{item.ItemName}}</view>
  99. <view class="detailedContBottom">
  100. <span class="SalePrice">¥{{item.SalePrice}}</span>
  101. <span>x1</span>
  102. </view>
  103. </view>
  104. </view>
  105. </view>
  106. </view>
  107. <!-- 项目明细 -->
  108. <!-- 商品费 -->
  109. <view class="goodscost">
  110. <view class="goodscostLine">
  111. <view class="goodscostTxt">商品费</view>
  112. <view class="goodsCostNum">¥{{orderData.GoodsMoney}}</view>
  113. </view>
  114. <view class="goodscostLine">
  115. <view class="goodscostTxt">项目费</view>
  116. <view class="goodsCostNum">¥{{orderData.ItemMoney}}</view>
  117. </view>
  118. <view class="goodscostLine">
  119. <view class="goodscostTxt">优惠券优惠</view>
  120. <view class="goodsCostNum">-¥{{orderData.CouponMoney}}</view>
  121. </view>
  122. <view class="goodscostLine">
  123. <view class="goodscostTxt">实付款</view>
  124. <view class="goodsCostNum" style="color: #FF4F00;">¥{{orderData.PayMoney}}</view>
  125. </view>
  126. </view>
  127. <!-- 商品费 -->
  128. <!-- 订单信息 -->
  129. <view class="information">
  130. <view class="detailedTitle">订单信息</view>
  131. <view class="informationLine">
  132. <view class="informationTxt">订单编号:</view>
  133. <view class="informationNum">{{orderData.Code}}</view>
  134. <view class="copyBtn" @click="copy(orderData.Code)">复制</view>
  135. </view>
  136. <view class="informationLine">
  137. <view class="informationTxt">下单人:</view>
  138. <view class="informationNum">{{orderData.MemberName}}</view>
  139. </view>
  140. <view class="informationLine">
  141. <view class="informationTxt">下单时间:</view>
  142. <view class="informationNum">{{orderData.CreateTime}}</view>
  143. </view>
  144. <view class="informationLine">
  145. <view class="informationTxt">下单备注:</view>
  146. <view class="informationNum">{{orderData.Comment}}</view>
  147. </view>
  148. </view>
  149. <!-- 订单信息 -->
  150. <!-- 支付信息 -->
  151. <view class="information">
  152. <view class="detailedTitle">支付信息</view>
  153. <view class="informationLine">
  154. <view class="informationTxt">支付状态:</view>
  155. <view class="informationNum" v-if="orderData.SheetState==2||orderData.SheetState==3||orderData.SheetState==4">已支付</view>
  156. <view class="informationNum" v-if="orderData.SheetState==1">未支付</view>
  157. </view>
  158. <view class="informationLine">
  159. <view class="informationTxt">支付方式:</view>
  160. <view class="informationNum">{{orderData.PayMethod==1?'线上支付':'线下支付'}}</view>
  161. </view>
  162. <view class="informationLine">
  163. <view class="informationTxt">支付时间:</view>
  164. <view class="informationNum" v-if="orderData.PayTime">{{orderData.PayTime}}</view>
  165. </view>
  166. </view>
  167. <!-- 支付信息 -->
  168. <view style="height: 150rpx;"></view>
  169. <view class="orderBottom" v-if="orderData.SheetState==1">
  170. <view class="cancelBtn" @click="cancelOrder">取消订单</view>
  171. <view class="payBtn" @click="orderPay">立即支付</view>
  172. </view>
  173. <view class="orderBottom" v-if="orderData.EvaluateState==1">
  174. <view class="cancelBtn" style="margin-right: 16rpx;" @click="gopingjia">查看评价</view>
  175. </view>
  176. <view class="orderBottom" v-if="orderData.EvaluateState==0&&orderData.EState==1"><!-- 4 -->
  177. <view class="payBtn" @click="evaluate">立即评价</view>
  178. </view>
  179. <!-- 二维码 -->
  180. <view v-if="qrcodeShow" class="qrcodeBox" @click="qrcodeShow=false">
  181. <view @click.stop="qrc">
  182. <tki-qrcode cid="qrcode1" ref="qrcode" :val="qrcodeTopVal" :size="size" :unit="unit"
  183. :pdground="pdground" :icon="icon" :iconSize="iconsize"
  184. :lv="lv" :onval="onval" :loadMake="loadMake" :usingComponents="true" @result="qrR"/>
  185. </view>
  186. </view>
  187. <!-- 二维码 -->
  188. <!-- 地图 -->
  189. <!-- 地图 -->
  190. <!-- 预约时间 -->
  191. <view class="timeBox2" v-if="timeShow&&OrderTimes" @click="timeShow=false">
  192. <view class="timeMain">
  193. <view class="timeTop">
  194. <view class="timeTopTitle">选择预约时间</view>
  195. <view class="close" @click="timeShow=false">X</view>
  196. </view>
  197. <view class="timeCont">
  198. <view class="timeLeft2">
  199. <scroll-view scroll-y="true" class="timeSv">
  200. <view class="timeleftLine" v-for="(item,index) in OrderTimes"
  201. :class="{timeLeftActive:index==orderTimeIndex1}"
  202. @click.stop="orderTimeIndex1=index,orderTimeIndex2=-1"
  203. >{{item.date.substring(5,10)}}</view>
  204. </scroll-view>
  205. </view>
  206. <view class="timeRight2">
  207. <scroll-view scroll-y="true" class="timeSv">
  208. <view class="timerightBox">
  209. <view class="timesf" v-for="(item,index) in OrderTimes[orderTimeIndex1].timeList"
  210. :class="{timesfNo:item.type!=1,timesfActive:index==orderTimeIndex2}"
  211. @click.stop="timeSfCk(item,index)"
  212. >
  213. <view class="timeSfNum">{{item.time}}</view>
  214. <view class="timeyy" v-if="item.type==1">可预约</view>
  215. <view class="timeyy" v-if="item.type==2">已约满</view>
  216. <view class="timeyy" v-if="item.type==3">已过期</view>
  217. </view>
  218. </view>
  219. </scroll-view>
  220. </view>
  221. </view>
  222. <view class="timeBottom">
  223. <view class="timecomplete" @click="timeCk">完成</view>
  224. </view>
  225. </view>
  226. </view>
  227. </view>
  228. </view>
  229. </template>
  230. <script>
  231. import tkiQrcode from "@/components/tki-qrcode/tki-qrcode.vue"
  232. export default {
  233. components: {
  234. tkiQrcode
  235. },
  236. data() {
  237. return {
  238. location:'',
  239. isload:false,
  240. id:'',
  241. iStatusBarHeight:'',
  242. orderData:'',
  243. type:'',
  244. onval: true, // val值变化时自动重新生成二维码
  245. loadMake: true, // 组件加载完成后自动生成二维码
  246. size:500,
  247. qrcodeShow:false,
  248. qrcodeTop:'-100vh',
  249. qrcodeTopVal:'',
  250. ifShow: false,
  251. val: '二维码', // 要生成的二维码值
  252. unit: 'upx', // 单位
  253. background: '#b4e9e2', // 背景色
  254. foreground: '#309286', // 前景色
  255. pdground: '#32dbc6', // 角标色
  256. icon: '', // 二维码图标
  257. iconsize: 40, // 二维码图标大小
  258. lv: 3, // 二维码容错级别 , 一般不用设置,默认就行
  259. src: '' ,// 二维码生成后的图片地址或base64
  260. timeShow:false,
  261. orderTime:'',
  262. OrderTimes:'',
  263. orderTimeIndex1:0,
  264. orderTimeIndex2:-1,
  265. }
  266. },
  267. onLoad(opt) {
  268. this.iStatusBarHeight = uni.getSystemInfoSync().statusBarHeight;
  269. this.location=uni.getStorageSync("location");
  270. this.id=opt.id
  271. this.getData()
  272. this.type=opt.type;
  273. this.getOrderTimes();
  274. },
  275. onShow() {
  276. if(this.id){
  277. this.getData()
  278. }
  279. },
  280. methods: {
  281. gopingjia(){
  282. uni.navigateTo({
  283. url:'../me/myAppraiseDetail?id='+this.id
  284. })
  285. },
  286. timeShowClick(){
  287. if(this.OrderTimes){
  288. this.timeShow=true
  289. }else{
  290. uni.showToast({
  291. title: '当前店铺尚未设置可预约时间',
  292. icon:'none',
  293. duration: 3000
  294. });
  295. }
  296. },
  297. map(){
  298. console.log("打开地图")
  299. var that=this;
  300. if(!that.orderData.Lat||!that.orderData.Lng){
  301. uni.showToast({
  302. title: '该店铺未设置定位',
  303. icon:'none',
  304. duration: 3000
  305. });
  306. }else{
  307. uni.openLocation({
  308. latitude:Number(that.orderData.Lat) ,
  309. longitude:Number( that.orderData.Lng),
  310. name:that.orderData.ShopName,
  311. address:that.orderData.Address,
  312. success: function () {
  313. console.log('success');
  314. },
  315. fail(err) {
  316. console.log(err)
  317. }
  318. });
  319. }
  320. },
  321. qrR(){
  322. },
  323. qrc(){
  324. console.log(111)
  325. },
  326. call(){
  327. uni.makePhoneCall({
  328. phoneNumber: this.orderData.MobilePhone
  329. });
  330. },
  331. qrcodeClick(){
  332. this.ifShow=true;
  333. this.qrcodeShow=true;
  334. this.qrcodeTopVal=this.orderData.Code;
  335. //this.$refs.qrcode._makeCode()
  336. },
  337. copy(txt){
  338. uni.setClipboardData({
  339. data: txt,
  340. success: function () {
  341. uni.showToast({
  342. title: '复制成功',
  343. icon:'none',
  344. duration: 2000
  345. });
  346. }
  347. });
  348. },
  349. getData(){
  350. uni.showLoading({ });
  351. this.$http('miniAppMyBMemberCar/queryMiniAppSheetDetail', {
  352. lat:this.location.lat,
  353. lng:this.location.lng,
  354. id:this.id,
  355. },'GET').then(res => {
  356. uni.hideLoading();
  357. this.orderData=res.data;
  358. })
  359. },
  360. goback(){
  361. if(this.type==2){
  362. uni.switchTab({
  363. url:'../index/index'
  364. })
  365. }else{
  366. uni.navigateBack({})
  367. }
  368. },
  369. evaluate(){
  370. uni.navigateTo({
  371. url:'evaluate?sheetID='+this.id+'&shopID='+this.orderData.ShopID
  372. })
  373. },
  374. goIndex(){
  375. uni.switchTab({
  376. url:'../index/index'
  377. })
  378. },
  379. cancelOrder(){
  380. var that=this;
  381. uni.showModal({
  382. title: '提示',
  383. content: '确定要取消订单吗',
  384. success: function (res) {
  385. if (res.confirm) {
  386. uni.showLoading({ });
  387. that.$http('miniAppMyBMemberCar/updateBMSheetState', {
  388. id:that.orderData.ID
  389. },'POST').then(res => {
  390. uni.hideLoading();
  391. that.getData()
  392. })
  393. } else if (res.cancel) {
  394. }
  395. }
  396. });
  397. },
  398. orderPay(){
  399. uni.showLoading({ });
  400. var that=this;
  401. this.$http('miniApp/maintainOrder/orderPay', {
  402. sheetID:this.orderData.ID
  403. },'POST').then(res => {
  404. uni.hideLoading();
  405. var payInfo=JSON.parse(res.data.payInfo)
  406. uni.requestPayment({
  407. provider: 'wxpay',
  408. // timeStamp: String(Date.now()),
  409. timeStamp:payInfo.timeStamp,
  410. nonceStr: payInfo.nonceStr,
  411. package: payInfo.package,
  412. signType: payInfo.signType,
  413. paySign: payInfo.paySign,
  414. success: function (res) {
  415. console.log('success:' + JSON.stringify(res));
  416. uni.showToast({
  417. title: '支付成功',
  418. icon:'none',
  419. duration: 2000
  420. });
  421. that.getData()
  422. },
  423. fail: function (err) {
  424. console.log('fail:' + JSON.stringify(err));
  425. }
  426. });
  427. })
  428. },
  429. timeSfCk(item,index){
  430. if(item.type==1){
  431. this.orderTimeIndex2=index;
  432. var orderTime=this.OrderTimes[this.orderTimeIndex1].date +' '+ item.time
  433. this.orderTime=orderTime
  434. }
  435. },
  436. timeCk(){
  437. this.timeShow=false;
  438. this.$http('miniApp/maintainOrder/changeOrderTime', {
  439. id:this.id,
  440. orderTime:this.orderTime
  441. },'POST').then(res => {
  442. if(res.code==0){
  443. uni.showToast({
  444. title: '修改成功',
  445. icon:'none',
  446. duration: 2000
  447. });
  448. }
  449. this.getData()
  450. })
  451. },
  452. getOrderTimes(){
  453. this.$http('miniApp/maintainOrder/getOrderTimes', {
  454. },'GET').then(res => {
  455. this.OrderTimes=res.data;
  456. })
  457. }
  458. },
  459. onPullDownRefresh() {
  460. this.getOrderTimes()
  461. this.getData()
  462. setTimeout(function () {
  463. uni.stopPullDownRefresh();
  464. }, 1000);
  465. },
  466. }
  467. </script>
  468. <style scoped>
  469. .box{
  470. min-height: 100vh;
  471. background: #F4F5F7;
  472. }
  473. .status_bar{
  474. background: #FF4F00;
  475. width: 100vw;
  476. position: fixed;
  477. top: 0;
  478. left: 0;
  479. z-index: 1111;
  480. }
  481. .qrcodeBox{
  482. width: 100vw;
  483. height: 100vh;
  484. display: flex;
  485. justify-content: center;
  486. align-items: center;
  487. position: fixed;
  488. top: 0;
  489. left: 0;
  490. background: rgba(0,0,0,0.7);
  491. }
  492. .top{
  493. width: 750rpx;
  494. height: 342rpx;
  495. background: #FF4F00;
  496. /* background: linear-gradient(134deg, #FF8635 0%, #FF4828 100%); */
  497. }
  498. .nav{
  499. line-height: 44px;
  500. font-size: 34rpx;
  501. font-weight: 600;
  502. display: flex;
  503. justify-content: space-between;
  504. color: #FFFFFF;
  505. position: fixed;
  506. width: 100vw;
  507. left: 0;
  508. z-index: 1111;
  509. background: #FF4F00;
  510. }
  511. .gobackImg{
  512. width: 92rpx;
  513. height: 88rpx;
  514. /* padding: 12px; */
  515. }
  516. .SheetState{
  517. font-size: 44rpx;
  518. font-weight: 500;
  519. color: #FFFFFF;
  520. padding-left: 24rpx;
  521. padding-top: 50rpx;
  522. }
  523. .orderTop{
  524. width: 702rpx;
  525. background: #FFFFFF;
  526. border-radius: 10rpx;
  527. margin-left: 24rpx;
  528. }
  529. .timeEditImg{
  530. width: 25rpx;height: 25rpx;padding-left: 20rpx;
  531. }
  532. .timeLeft{
  533. font-size: 28rpx;
  534. color: #3C3C3C;font-weight: 500;
  535. }
  536. .timeRight{
  537. font-size: 26rpx;
  538. color: #3F90F7;
  539. }
  540. .timeBox{
  541. display: flex;
  542. justify-content: space-between;
  543. padding: 24rpx 20rpx;
  544. border-bottom: 1px solid #EEEEEE;
  545. }
  546. .orderTop{
  547. position: relative;
  548. top: -44rpx;
  549. }
  550. .shopBoximg{
  551. width: 40rpx;height: 40rpx;
  552. }
  553. .shopRightImg{
  554. width: 52rpx;height: 38rpx;
  555. }
  556. .shopsx{
  557. width: 1px;
  558. height: 50rpx;
  559. background: #EEEEEE;
  560. margin-top: 30rpx;
  561. margin-left: 28rpx;
  562. }
  563. .shopBox{
  564. display: flex;
  565. padding: 30rpx 20rpx 20rpx 20rpx;
  566. }
  567. .shopCont{
  568. width: 418rpx;padding-left: 20rpx;
  569. }
  570. .shopName{
  571. font-size: 28rpx;
  572. color: #3C3C3C;
  573. }
  574. .Address{
  575. color: #999999;font-size: 26rpx;padding-top: 10rpx;
  576. }
  577. .shopRihgtTxt{
  578. color: #999999;font-size: 22rpx;padding-top: 5rpx;
  579. }
  580. .shopRightBox{
  581. padding-top: 30rpx;
  582. padding-left: 28rpx;
  583. }
  584. .peopleCont{
  585. font-size: 28rpx;
  586. font-weight: 500;
  587. color: #3C3C3C;
  588. padding-left: 20rpx;
  589. }
  590. .people{
  591. display: flex;
  592. padding-left: 20rpx;
  593. padding-bottom: 36rpx;
  594. }
  595. .PlateNumberBox{
  596. display: flex;padding-left: 20rpx;padding-bottom: 30rpx;
  597. }
  598. .PlateNumbercx{
  599. font-size: 28rpx;
  600. font-weight: 500;
  601. color: #3C3C3C;
  602. padding-left: 20rpx;
  603. }
  604. .PlateNumber{
  605. width: 130rpx;
  606. height: 32rpx;
  607. border-radius: 4rpx;
  608. border: 1px solid #F19D01;
  609. line-height: 32rpx;
  610. text-align: center;
  611. font-size: 22rpx;
  612. color: #F19D01;
  613. margin-left: 26rpx;
  614. }
  615. .PlateNumberBoxTop{
  616. display: flex;
  617. }
  618. .CarModel{
  619. font-size: 26rpx;
  620. color: #999999;
  621. padding-left: 20rpx;
  622. padding-top: 6rpx;
  623. padding-right: 20rpx;
  624. padding-bottom: 15rpx;
  625. width: 600rpx;
  626. }
  627. .detailedBox{
  628. width: 702rpx;
  629. background: #FFFFFF;
  630. border-radius: 10px;
  631. margin-left: 24rpx;
  632. margin-top: -60rpx;
  633. padding-bottom: 20rpx;
  634. }
  635. .itemBox{
  636. margin-top: 20rpx;
  637. }
  638. .detailedTitle{
  639. font-size: 32rpx;
  640. color: #3C3C3C;
  641. padding-left: 20rpx;padding-top: 30rpx;
  642. font-weight: 600;
  643. padding-bottom: 10rpx;
  644. }
  645. .detailedLine{
  646. display: flex;
  647. padding-left: 20rpx;
  648. padding-top: 40rpx;
  649. }
  650. .detailedImg{
  651. width: 120rpx;
  652. height: 120rpx;
  653. border-radius: 10rpx;
  654. }
  655. .detailedCont{
  656. padding-left: 20rpx;
  657. display: flex;
  658. flex-direction: column;
  659. justify-content: space-between;
  660. }
  661. .detailedName{
  662. font-size: 26rpx;
  663. color: #3C3C3C;
  664. }
  665. .detailedContBottom{
  666. display: flex;
  667. justify-content: space-between;
  668. font-size: 26rpx;
  669. color: #999999;
  670. width: 500rpx;
  671. line-height: 40rpx;
  672. }
  673. .SalePrice{
  674. font-size: 32rpx;
  675. font-weight: 500;
  676. color: #3C3C3C;
  677. }
  678. .goodscost{
  679. width: 702rpx;
  680. background: #FFFFFF;
  681. border-radius: 10px;
  682. margin-left: 24rpx;
  683. margin-top: 20rpx;
  684. padding: 15rpx 0;
  685. }
  686. .goodscostLine{
  687. display: flex;
  688. justify-content: space-between;
  689. font-size: 28rpx;
  690. padding: 20rpx 20rpx;
  691. color: #666666;
  692. }
  693. .goodsCostNum{
  694. color: #3C3C3C;
  695. }
  696. .information{
  697. width: 702rpx;
  698. background: #FFFFFF;
  699. border-radius: 10px;
  700. margin-left: 24rpx;
  701. margin-top: 20rpx;
  702. padding: 0rpx 0 15rpx 0;
  703. }
  704. .informationLine{
  705. display: flex;font-size: 26rpx;
  706. padding: 15rpx 20rpx;
  707. }
  708. .informationTxt{
  709. width: 150rpx;
  710. color: #666666;
  711. }
  712. .informationNum{
  713. color: #333333;
  714. }
  715. .copyBtn{
  716. width: 86rpx;
  717. height: 40rpx;
  718. background: #F4F5F7;
  719. border-radius: 20rpx;
  720. font-size: 24rpx;
  721. color: #333333;
  722. text-align: center;
  723. line-height: 40rpx;
  724. margin-left: 20rpx;
  725. }
  726. .orderBottom{
  727. width: 750rpx;
  728. height: 98rpx;
  729. background: #FFFFFF;
  730. position: fixed;
  731. left: 0;
  732. bottom: 0;
  733. display: flex;
  734. justify-content: flex-end;
  735. }
  736. .cancelBtn{
  737. width: 150rpx;
  738. height: 56rpx;
  739. border-radius: 36rpx;
  740. border: 2rpx solid #DDDDDD;
  741. text-align: center;
  742. line-height: 56rpx;
  743. font-size: 28rpx;
  744. color: #3C3C3C;
  745. margin-top: 21rpx;
  746. }
  747. .payBtn{
  748. width: 150rpx;
  749. height: 56rpx;
  750. border-radius: 36rpx;
  751. border: 2rpx solid #FF4F00;
  752. text-align: center;
  753. line-height: 56rpx;
  754. font-size: 28rpx;
  755. color: #FF4F00;
  756. margin-top: 21rpx;
  757. margin-right: 16rpx;
  758. margin-left: 40rpx;
  759. }
  760. .timeBox2{
  761. width: 100vw;
  762. height: 100vh;
  763. background: rgba(0,0,0,0.5);
  764. position: fixed;
  765. top: 0;
  766. left: 0;
  767. }
  768. .timeLeftActive{
  769. background: #FFFFFF;
  770. }
  771. .timeMain{
  772. width: 100vw;
  773. height: 70vh;
  774. margin-top: 30vh;
  775. background: #FFFFFF;
  776. border-radius: 24rpx 24rpx 0px 0px;
  777. }
  778. .timesfNo{
  779. background: #F5F5F5;
  780. }
  781. .timesfActive{
  782. background: #FF4F00;
  783. }
  784. .timesfActive .timeSfNum{
  785. color: #FFFFFF;
  786. }
  787. .timesfActive .timeyy{
  788. color: #FFFFFF;
  789. }
  790. .topBox{
  791. padding: 20rpx 24rpx;
  792. }
  793. .timeTop{
  794. display: flex;
  795. line-height: 90rpx;
  796. padding-left: 24rpx;
  797. padding-right: 24rpx;
  798. justify-content: space-between;
  799. }
  800. .timeTopTitle{
  801. font-size: 30rpx;
  802. font-family: PingFangSC-Medium, PingFang SC;
  803. font-weight: 600;
  804. color: #3C3C3C;
  805. }
  806. .close{
  807. color: #999999;font-size: 30rpx;
  808. padding-left: 30rpx;
  809. }
  810. .timeCont{
  811. height: calc(70vh - 210rpx);
  812. }
  813. .timeSv{
  814. height: calc(70vh - 210rpx);
  815. }
  816. .timeLeft2{
  817. width: 162rpx;
  818. background: #F4F5F7;
  819. border-top: 1px soid #F4F5F7;
  820. border-right:1px soid #F4F5F7 ;
  821. }
  822. .timeRight2{
  823. width: 588rpx;
  824. }
  825. .timesf{
  826. width: 165rpx;
  827. height: 98rpx;
  828. border-radius: 7rpx;
  829. border: 2rpx solid #EEEEEE;
  830. text-align: center;
  831. margin-left: 20rpx;
  832. margin-bottom: 24rpx;
  833. }
  834. .timeBottom{
  835. width: 750rpx;
  836. height: 120rpx;
  837. background: #FFFFFF;
  838. box-shadow: 0px -2px 20rpx 0px rgba(153, 153, 153, 0.2);
  839. display: flex;
  840. align-items: center;
  841. }
  842. .timerightBox{
  843. display: flex;
  844. flex-wrap: wrap;
  845. }
  846. .timeCont{
  847. display: flex;
  848. }
  849. .timeSfNum{
  850. color: #666666;
  851. font-size: 28rpx;
  852. padding-top: 15rpx;
  853. }
  854. .timeyy{
  855. font-size: 24rpx;
  856. color: #999999;
  857. }
  858. .timecomplete{
  859. width: 690rpx;
  860. height: 74rpx;
  861. background: linear-gradient(124deg, #FF8700 0%, #FF4F00 100%);
  862. border-radius: 37rpx;
  863. line-height: 74rpx;
  864. text-align: center;
  865. font-size: 30rpx;
  866. color: #FFFFFF;
  867. margin-left: 30rpx;
  868. }
  869. .timeleftLine{
  870. font-size: 30rpx;
  871. color: #999999;
  872. text-align: center;
  873. padding: 28rpx 10rpx;
  874. border-bottom: 1px solid #EEEEEE;
  875. }
  876. .goIndexImg{
  877. width: 92rpx;
  878. height: 88rpx;
  879. }
  880. </style>