detail.vue 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149
  1. <template>
  2. <view class="content">
  3. <block v-if="identity == 2 && type == 'life_supermarket'">
  4. <view class="box hflex acenter">
  5. <image src="@/static/images/address.png" mode="aspectFill" class="address_icon"></image>
  6. <view class="vflex">
  7. <view class="address_text">{{pageData.address}}</view>
  8. <view class="address_text2">{{pageData.address_name}} {{pageData.address_phone}}</view>
  9. </view>
  10. </view>
  11. <view class="box">
  12. <view class="cell hflex acenter jbetween">
  13. <view class="text">订单编号</view>
  14. <view class="text">{{pageData.order_sn}}</view>
  15. </view>
  16. <view class="cell hflex acenter jbetween">
  17. <view class="text">订单时间</view>
  18. <view class="text">{{pageData.createtime}}</view>
  19. </view>
  20. <view class="cell hflex acenter jbetween">
  21. <view class="text">配送社区</view>
  22. <view class="text">{{pageData.community_name}}</view>
  23. </view>
  24. <view class="cell hflex acenter jbetween">
  25. <view class="text">总优惠金额</view>
  26. <view class="text">¥{{pageData.type_coupon_amount}}</view>
  27. </view>
  28. <view class="cell hflex acenter jbetween">
  29. <view class="text">实际付款价格</view>
  30. <view class="text">¥{{pageData.type_pay_amount}}</view>
  31. </view>
  32. <view class="cell hflex acenter jbetween">
  33. <view class="text">订单备注</view>
  34. <view class="text">{{pageData.remark?pageData.remark:'-'}}</view>
  35. </view>
  36. </view>
  37. <view class="box">
  38. <view class="cell hflex acenter jbetween">
  39. <view class="text">支付金额</view>
  40. <view class="text" style="color: #333;font-weight: 600;">¥{{pageData.type_pay_amount}}</view>
  41. </view>
  42. <view class="cell hflex acenter jbetween">
  43. <view class="text">支付时间</view>
  44. <view class="text" style="color: #999;">{{pageData.paytime}}</view>
  45. </view>
  46. </view>
  47. <view class="box" v-if="pageData.status > 1">
  48. <view class="cell hflex acenter jbetween">
  49. <view class="text">配送人员</view>
  50. <view class="text">{{pageData.delivery_name}}</view>
  51. </view>
  52. <view class="cell hflex acenter jbetween">
  53. <view class="text">联系方式</view>
  54. <view class="text" style="color: #999;">{{pageData.delivery_mobile}}</view>
  55. </view>
  56. <view class="cell hflex acenter jbetween" v-if="pageData.status == 3 || pageData.status == 4">
  57. <view class="text">配送时间</view>
  58. <view class="text" style="color: #999;">{{pageData.delivery_time}}</view>
  59. </view>
  60. </view>
  61. <block v-for="(item,index) in pageData.ordercategory" :key="index">
  62. <div class="box">
  63. <view class="hflex acenter jbetween" >
  64. <view class="box_top hflex acenter">
  65. <image :src="item.category_image" mode="aspectFill" class="top_img"></image>
  66. <view class="top_text">{{item.category_name}}</view>
  67. </view>
  68. </view>
  69. <block v-for="(item2,index2) in item.ordergoods" :key="index2">
  70. <view class="good hflex acenter">
  71. <image :src="item2.goods_image" mode="aspectFill" class="item_img"></image>
  72. <view class="vflex img_right">
  73. <view class="status2 hflex jend" v-if="item2.refund_status == 1">退款审核中</view>
  74. <view class="status2 hflex jend" v-if="item2.refund_status == 2">已退款</view>
  75. <view class="status2 hflex jend" v-if="item2.refund_status == 3">退款驳回</view>
  76. <view class="hflex acenter jbetween">
  77. <view class="item_name text_hide" style="width: 400rpx;">{{item2.goods_name}}</view>
  78. <view class="item_name">¥{{item2.goods_sku_price}}</view>
  79. </view>
  80. <view class="hflex acenter jbetween">
  81. <view class="item_spec text_hide" style="width: 450rpx;">{{item2.goods_sku_text}}</view>
  82. <view class="item_spec text_hide">X{{item2.goods_num}}</view>
  83. </view>
  84. </view>
  85. </view>
  86. </block>
  87. <view class="cell hflex acenter jbetween" v-if="item.params">
  88. <view class="text">预约时间:</view>
  89. <view class="text">{{item.params.food_time}}</view>
  90. </view>
  91. <view class="cell hflex acenter jbetween">
  92. <view class="text">商品总价格:</view>
  93. <view class="text">¥{{item.category_goods_amount}}</view>
  94. </view>
  95. <view class="cell hflex acenter jbetween">
  96. <view class="text">是否扣除余额抵扣:</view>
  97. <view class="text">¥{{item.use_category_balance}}</view>
  98. </view>
  99. <view class="cell hflex acenter jbetween">
  100. <view class="text">应付款价格:</view>
  101. <view class="text">¥{{item.pay_category_amount}}</view>
  102. </view>
  103. </div>
  104. </block>
  105. <view class="box">
  106. <view class="cell hflex acenter jbetween">
  107. <view class="text">总价</view>
  108. <view class="text" style="color: #FF2828;">¥{{pageData.type_goods_amount}}</view>
  109. </view>
  110. <view class="cell hflex acenter jbetween">
  111. <view class="text">优惠券</view>
  112. <view class="text">{{pageData.coupons_name?pageData.coupons_name:'-'}}</view>
  113. </view>
  114. <view class="cell hflex acenter jbetween">
  115. <view class="text">生活超市应付总价</view>
  116. <view class="text" style="color: #FF2828;">¥{{pageData.type_pay_amount}}</view>
  117. </view>
  118. </view>
  119. <view class="" style="height: 186rpx;">
  120. </view>
  121. <view class="bottom hflex jend" v-if="pageData.status == 1">
  122. <view class="btn" v-if="pageData.status == 1 && pageData.delivery_id == 0" @click="open">指派配送人员</view>
  123. </view>
  124. </block>
  125. <block v-if="identity == 3 || type == 'daily_appliance'">
  126. <!-- <view class="box hflex acenter">
  127. <image src="@/static/images/address.png" mode="aspectFill" class="address_icon"></image>
  128. <view class="vflex">
  129. <view class="address_text">{{pageData.address}}</view>
  130. <view class="address_text2">{{pageData.address_name}} {{pageData.address_phone}}</view>
  131. </view>
  132. </view> -->
  133. <view class="box">
  134. <view class="title">用户信息</view>
  135. <view class="cell hflex acenter jbetween">
  136. <view class="text">用户姓名:</view>
  137. <view class="text">{{pageData.address_name}}</view>
  138. </view>
  139. <view class="cell hflex acenter jbetween">
  140. <view class="text">联系方式:</view>
  141. <view class="text">{{pageData.address_phone}}</view>
  142. </view>
  143. <view class="cell hflex acenter jbetween">
  144. <view class="text">用户社区:</view>
  145. <view class="text">{{pageData.community_name}}</view>
  146. </view>
  147. <view class="cell hflex acenter jbetween">
  148. <view class="text">用户地址:</view>
  149. <view class="text">{{pageData.address}}</view>
  150. </view>
  151. </view>
  152. <view class="box">
  153. <view class="cell hflex acenter jbetween">
  154. <view class="text">订单编号</view>
  155. <view class="text">{{pageData.order_sn}}</view>
  156. </view>
  157. <view class="cell hflex acenter jbetween">
  158. <view class="text">订单时间</view>
  159. <view class="text">{{pageData.createtime}}</view>
  160. </view>
  161. <view class="cell hflex acenter jbetween">
  162. <view class="text">配送社区</view>
  163. <view class="text">{{pageData.community_name}}</view>
  164. </view>
  165. <view class="cell hflex acenter jbetween">
  166. <view class="text">总优惠金额</view>
  167. <view class="text">¥{{pageData.type_coupon_amount}}</view>
  168. </view>
  169. <view class="cell hflex acenter jbetween">
  170. <view class="text">实际付款价格</view>
  171. <view class="text">¥{{pageData.type_pay_amount}}</view>
  172. </view>
  173. <view class="cell hflex acenter jbetween">
  174. <view class="text">订单备注</view>
  175. <view class="text">{{pageData.remark?pageData.remark:'无备注'}}</view>
  176. </view>
  177. </view>
  178. <view class="box">
  179. <view class="cell hflex acenter jbetween">
  180. <view class="text">支付金额</view>
  181. <view class="text" style="color: #333;font-weight: 600;">¥{{pageData.type_pay_amount}}</view>
  182. </view>
  183. <view class="cell hflex acenter jbetween">
  184. <view class="text">支付时间</view>
  185. <view class="text" style="color: #999;">{{pageData.paytime}}</view>
  186. </view>
  187. </view>
  188. <view class="box" v-if="pageData.status > 1">
  189. <view class="cell hflex acenter jbetween">
  190. <view class="text">配送人员</view>
  191. <view class="text">{{pageData.delivery_name}}</view>
  192. </view>
  193. <view class="cell hflex acenter jbetween">
  194. <view class="text">联系方式</view>
  195. <view class="text" style="color: #999;">{{pageData.delivery_mobile}}</view>
  196. </view>
  197. <view class="cell hflex acenter jbetween" v-if="pageData.status == 3 || pageData.status == 4">
  198. <view class="text">配送时间</view>
  199. <view class="text" style="color: #999;">{{pageData.delivery_time}}</view>
  200. </view>
  201. </view>
  202. <block v-for="(item,index) in pageData.ordercategory" :key="index">
  203. <div class="box">
  204. <view class="hflex acenter jbetween">
  205. <view class="box_top hflex acenter">
  206. <image :src="item.category_image" mode="aspectFill" class="top_img"></image>
  207. <view class="top_text">{{item.category_name}}</view>
  208. </view>
  209. </view>
  210. <block v-for="(item2,index2) in item.ordergoods" :key="index2">
  211. <view class="good hflex acenter">
  212. <image :src="item2.goods_image" mode="aspectFill" class="item_img"></image>
  213. <view class="vflex img_right">
  214. <view class="status2 hflex jend" v-if="item2.refund_status == 1">退款审核中</view>
  215. <view class="status2 hflex jend" v-if="item2.refund_status == 2">已退款</view>
  216. <view class="status2 hflex jend" v-if="item2.refund_status == 3">退款驳回</view>
  217. <view class="hflex acenter jbetween">
  218. <view class="item_name text_hide" style="width: 400rpx;">{{item2.goods_name}}</view>
  219. <view class="item_name">¥{{item2.goods_sku_price}}</view>
  220. </view>
  221. <view class="hflex acenter jbetween">
  222. <view class="item_spec text_hide" style="width: 450rpx;">{{item2.goods_sku_text}}</view>
  223. <view class="item_spec text_hide">X{{item2.goods_num}}</view>
  224. </view>
  225. </view>
  226. </view>
  227. </block>
  228. <view class="cell hflex acenter jbetween" v-if="item.params">
  229. <view class="text">预约时间:</view>
  230. <view class="text">{{item.params.food_time}}</view>
  231. </view>
  232. <view class="cell hflex acenter jbetween">
  233. <view class="text">商品总价格:</view>
  234. <view class="text">¥{{item.category_goods_amount}}</view>
  235. </view>
  236. <view class="cell hflex acenter jbetween">
  237. <view class="text">是否扣除余额抵扣:</view>
  238. <view class="text">¥{{item.use_category_balance}}</view>
  239. </view>
  240. <view class="cell hflex acenter jbetween">
  241. <view class="text">应付款价格:</view>
  242. <view class="text">¥{{item.pay_category_amount}}</view>
  243. </view>
  244. </div>
  245. </block>
  246. <view class="box">
  247. <view class="cell hflex acenter jbetween">
  248. <view class="text">总价</view>
  249. <view class="text" style="color: #FF2828;">¥{{pageData.type_goods_amount}}</view>
  250. </view>
  251. <view class="cell hflex acenter jbetween">
  252. <view class="text">优惠券</view>
  253. <view class="text">{{pageData.coupons_name?pageData.coupons_name:'-'}}</view>
  254. </view>
  255. <view class="cell hflex acenter jbetween">
  256. <view class="text" v-if="type=='life_supermarket'">生活超市应付总价</view>
  257. <view class="text" v-if="type=='daily_appliance' || identity == 3">日用家电应付总价</view>
  258. <view class="text" style="color: #FF2828;">¥{{pageData.type_pay_amount}}</view>
  259. </view>
  260. </view>
  261. <view class="" style="height: 186rpx;">
  262. </view>
  263. <view class="bottom hflex jend" v-if="pageData.status == 1 || pageData.status == 2">
  264. <view class="btn" v-if="pageData.status == 1 && pageData.delivery_id == 0" @click="send">发货</view>
  265. <view class="btn" v-if="pageData.status == 2" @click="sendAppliance(4)">已送达</view>
  266. <!-- <view class="btn" v-if="pageData.status == 4">已发货</view> -->
  267. </view>
  268. </block>
  269. <block v-if="identity == 4 || type == 'home_service'">
  270. <view class="box">
  271. <view class="title">用户信息</view>
  272. <view class="cell hflex acenter jbetween">
  273. <view class="text">用户姓名:</view>
  274. <view class="text">{{pageData.address_name}}</view>
  275. </view>
  276. <view class="cell hflex acenter jbetween">
  277. <view class="text">联系方式:</view>
  278. <view class="text">{{pageData.address_phone}}</view>
  279. </view>
  280. <view class="cell hflex acenter jbetween">
  281. <view class="text">用户社区:</view>
  282. <view class="text">{{pageData.community_name}}</view>
  283. </view>
  284. <view class="cell hflex acenter jbetween">
  285. <view class="text">用户地址:</view>
  286. <view class="text">{{pageData.address}}</view>
  287. </view>
  288. </view>
  289. <view class="box" >
  290. <view class="top hflex acenter jbetween">
  291. <view class="hflex acenter">
  292. <u-icon name="order" color="#999999" size="20"></u-icon>
  293. <view class="top_text">{{pageData.order_sn}}</view>
  294. </view>
  295. <view class="status" v-if="pageData.status == 0">已预约</view>
  296. <view class="status" v-if="pageData.status == 1">待服务</view>
  297. <view class="status" v-if="pageData.status == 2">已完成</view>
  298. </view>
  299. <view class="good hflex">
  300. <image :src="imgUrl + pageData.goods_image" mode="aspectFill" class="item_img"></image>
  301. <view class="vflex img_right">
  302. <view class="hflex acenter jbetween">
  303. <view class="item_name text_hide" style="width: 400rpx;">{{pageData.goods_name}}</view>
  304. </view>
  305. <view class="hflex acenter jbetween">
  306. <view class="item_spec text_hide" style="width: 450rpx;">{{pageData.goods_sku_text}}</view>
  307. </view>
  308. <view class="info">
  309. <view class="info_text" v-if="pageData.goods_pay_type == 1">先付款后服务</view>
  310. <view class="info_text" v-else>先预约后付款</view>
  311. </view>
  312. </view>
  313. </view>
  314. <view class="cell hflex acenter jbetween">
  315. <view class="label">服务类型:</view>
  316. <view class="label">{{pageData.category_name}}</view>
  317. </view>
  318. <view class="cell hflex acenter jbetween" v-if="pageData.status == 1">
  319. <view class="label">支付金额:</view>
  320. <view class="label">{{pageData.current_goods_pay_amount}}</view>
  321. </view>
  322. <view class="cell hflex acenter jbetween" v-if="pageData.status == 1">
  323. <view class="label">付款备注:</view>
  324. <view class="label">{{pageData.remark?pageData.remark: '-'}}</view>
  325. </view>
  326. </view>
  327. <view class="box" >
  328. <view class="title">订单信息</view>
  329. <view class="cell hflex acenter jbetween">
  330. <view class="text">订单编号:</view>
  331. <view class="text">{{pageData.order_sn}}</view>
  332. </view>
  333. <view class="cell hflex acenter jbetween">
  334. <view class="text">订单时间:</view>
  335. <view class="text">{{pageData.createtime}}</view>
  336. </view>
  337. <view class="cell hflex acenter jbetween">
  338. <view class="text">订单总价:</view>
  339. <view class="text">¥{{pageData.current_goods_amount}}</view>
  340. </view>
  341. <view class="cell hflex acenter jbetween">
  342. <view class="text">优惠券抵扣:</view>
  343. <view class="text">¥{{pageData.current_goods_coupon_amount}}</view>
  344. </view>
  345. <view class="cell hflex acenter jbetween">
  346. <view class="text">总优惠金额:</view>
  347. <view class="text">¥{{pageData.current_goods_coupon_amount}}</view>
  348. </view>
  349. <view class="cell hflex acenter jbetween">
  350. <view class="text">余额抵扣现金:</view>
  351. <view class="text">¥{{pageData.use_balance}}</view>
  352. </view>
  353. <view class="cell hflex acenter jbetween">
  354. <view class="text">实际支付金额:</view>
  355. <view class="text">¥{{pageData.no_use_balance}}</view>
  356. </view>
  357. </view>
  358. <view class="box" >
  359. <view class="title">支付信息</view>
  360. <view class="cell hflex acenter jbetween">
  361. <view class="text">支付方式:</view>
  362. <view class="text">{{pageData.status !== 0?'微信':''}}</view>
  363. </view>
  364. <view class="cell hflex acenter jbetween">
  365. <view class="text">支付时间:</view>
  366. <view class="text">{{pageData.paytime}}</view>
  367. </view>
  368. <view class="cell hflex acenter jbetween">
  369. <view class="text">支付金额:</view>
  370. <view class="text">{{pageData.status !== 0?'¥' + pageData.no_use_balance:''}}</view>
  371. </view>
  372. </view>
  373. <view class="" style="height: 186rpx;"></view>
  374. <view class="bottom hflex jend" v-if="pageData.status !== 2">
  375. <view class="btn" v-if="pageData.status == 0 && Number(pageData.current_goods_amount) == 0" @click="estimateOpen">待评估价格</view>
  376. <view class="btn" v-if="pageData.status == 1" @click="complete">已完成</view>
  377. </view>
  378. </block>
  379. <block v-if="identity == 5 || type == 'sports'">
  380. <view class="box" >
  381. <view class="top hflex acenter jbetween">
  382. <view class="hflex acenter">
  383. <u-icon name="order" color="#999999" size="20"></u-icon>
  384. <view class="top_text">{{pageData.order_sn}}</view>
  385. </view>
  386. <view class="status" v-if="pageData.status == 1">进行中</view>
  387. <view class="status" v-if="pageData.status == 2">已完成</view>
  388. </view>
  389. <view class="good hflex">
  390. <image :src="pageData.goods.goods_image" mode="aspectFill" class="item_img"></image>
  391. <view class="vflex img_right">
  392. <view class="hflex acenter jbetween">
  393. <view class="item_name text_hide" style="width: 400rpx;">{{pageData.goods.goods_name}}</view>
  394. </view>
  395. <view class="hflex acenter jbetween">
  396. <view class="item_spec text_hide" style="width: 450rpx;">{{pageData.community.name}}</view>
  397. </view>
  398. <view class="item_spec text_hide">订单时间:{{pageData.createtime}}</view>
  399. </view>
  400. </view>
  401. </view>
  402. <view class="box">
  403. <view class="title">用户信息</view>
  404. <view class="cell hflex acenter jbetween">
  405. <view class="text">用户姓名:</view>
  406. <view class="text">{{pageData.user.nickname}}</view>
  407. </view>
  408. <view class="cell hflex acenter jbetween">
  409. <view class="text">用户手机号:</view>
  410. <view class="text">{{pageData.user.mobile}}</view>
  411. </view>
  412. <view class="cell hflex acenter jbetween">
  413. <view class="text">社区:</view>
  414. <view class="text">{{pageData.community.name}}</view>
  415. </view>
  416. <view class="cell hflex acenter jbetween">
  417. <view class="text">门牌信息:</view>
  418. <view class="text">{{pageData.service.address}}</view>
  419. </view>
  420. <view class="cell hflex acenter jbetween">
  421. <view class="text">授课老师名称:</view>
  422. <view class="text">{{pageData.coach.name}}</view>
  423. </view>
  424. <view class="cell hflex acenter jbetween">
  425. <view class="text">老师手机号:</view>
  426. <view class="text">{{pageData.coach.mobile}}</view>
  427. </view>
  428. <view class="cell hflex acenter jbetween">
  429. <view class="text">订单规格:</view>
  430. <view class="text">{{pageData.goods.goods_sku_text}}</view>
  431. </view>
  432. <view class="cell hflex acenter jbetween" v-if="pageData.goods.sport_type == 'month'">
  433. <view class="text">月卡时间:</view>
  434. <view class="text">{{pageData.goods.sport_sum_count}}</view>
  435. </view>
  436. <view class="cell hflex acenter jbetween" v-if="pageData.goods.sport_type == 'whole'">
  437. <view class="text">包场时长:</view>
  438. <view class="text">{{pageData.goods.sport_sum_count}}</view>
  439. </view>
  440. <view class="cell hflex acenter jbetween" v-if="pageData.goods.sport_type == 'whole'">
  441. <view class="text">开始时间:</view>
  442. <view class="text">{{pageData.goods.sport_whole_start_time}}</view>
  443. </view>
  444. <view class="cell hflex acenter jbetween" v-if="pageData.goods.sport_type == 'whole'">
  445. <view class="text">结束时间:</view>
  446. <view class="text">{{pageData.goods.sport_whole_end_time}}</view>
  447. </view>
  448. <view class="cell hflex acenter jbetween" v-if="pageData.goods.sport_type == 'times'">
  449. <view class="text">课程次数:</view>
  450. <view class="text">{{pageData.goods.sport_sum_count}}</view>
  451. </view>
  452. <view class="cell hflex acenter jbetween" v-if="pageData.goods.sport_type == 'times'">
  453. <view class="text">剩余次数:</view>
  454. <view class="text">{{pageData.goods.sport_remain_verify_count == -1 ? '无限制' : pageData.goods.sport_remain_verify_count}}</view>
  455. </view>
  456. <view class="cell hflex acenter jbetween" v-if="pageData.verify_log.length > 0">
  457. <view class="text">核销时间:</view>
  458. <view class="hflex acenter" @click="openTime">
  459. <view class="text">{{pageData.verify_log[0].createtime}}</view>
  460. <u-icon name="arrow-right" size="14"></u-icon>
  461. </view>
  462. </view>
  463. </view>
  464. <view class="box" >
  465. <view class="title">订单信息</view>
  466. <view class="cell hflex acenter jbetween">
  467. <view class="text">订单编号:</view>
  468. <view class="text">{{pageData.order_sn}}</view>
  469. </view>
  470. <view class="cell hflex acenter jbetween">
  471. <view class="text">订单时间:</view>
  472. <view class="text">{{pageData.createtime}}</view>
  473. </view>
  474. <view class="cell hflex acenter jbetween">
  475. <view class="text">订单总价:</view>
  476. <view class="text">¥{{pageData.type_goods_amount}}</view>
  477. </view>
  478. <view class="cell hflex acenter jbetween">
  479. <view class="text">优惠券抵扣:</view>
  480. <view class="text">¥{{pageData.type_coupon_amount}}</view>
  481. </view>
  482. <view class="cell hflex acenter jbetween">
  483. <view class="text">总优惠金额:</view>
  484. <view class="text">¥{{pageData.type_coupon_amount}}</view>
  485. </view>
  486. <view class="cell hflex acenter jbetween">
  487. <view class="text">余额抵扣现金:</view>
  488. <view class="text">¥{{pageData.type_use_balance}}</view>
  489. </view>
  490. <view class="cell hflex acenter jbetween">
  491. <view class="text">实际支付金额:</view>
  492. <view class="text">¥{{pageData.type_pay_amount}}</view>
  493. </view>
  494. </view>
  495. <view class="box" >
  496. <view class="title">支付信息</view>
  497. <view class="cell hflex acenter jbetween">
  498. <view class="text">支付方式:</view>
  499. <view class="text">{{pageData.pay_type == 'wechat' ? '微信支付' : '微信支付'}}</view>
  500. </view>
  501. <view class="cell hflex acenter jbetween">
  502. <view class="text">支付时间:</view>
  503. <view class="text">{{pageData.paytime}}</view>
  504. </view>
  505. <view class="cell hflex acenter jbetween">
  506. <view class="text">支付金额:</view>
  507. <view class="text">¥{{pageData.type_pay_amount}}</view>
  508. </view>
  509. </view>
  510. <view class="" style="height: 186rpx;"></view>
  511. <view class="bottom hflex jend" v-if="pageData.status == 1">
  512. <view class="btn" @click="writeOffOpen">核销</view>
  513. </view>
  514. </block>
  515. <u-popup :show="estimate_show" @close="close">
  516. <view class="popup">
  517. <view class="popu_top border_bottom hflex acenter jbetween">
  518. <view></view>
  519. <view class="title">待评估价格</view>
  520. <u-icon name="close" color="#000000" size="26" @click="close"></u-icon>
  521. </view>
  522. <view class="popu_form">
  523. <view class="hflex acenter">
  524. <view class="form_label">商品价格:</view>
  525. <u-input placeholder="请输入评估后的价格" border="surround" v-model="estimate_price">
  526. <u--text text="¥" slot="prefix" margin="0 3px 0 0" type="tips"></u--text>
  527. </u-input>
  528. </view>
  529. <view class="hflex acenter" style="margin-top: 60rpx;">
  530. <view class="form_label">付款备注:</view>
  531. <u-input placeholder="请输入备注信息" border="surround" v-model="remarks">
  532. </u-input>
  533. </view>
  534. </view>
  535. <view class="popu_bottom hflex jend">
  536. <view class="btn btn1" @click="estimateSure">确认</view>
  537. </view>
  538. </view>
  539. </u-popup>
  540. <u-popup :show="assign_show" @close="close">
  541. <view class="popup">
  542. <view class="popu_top hflex acenter jbetween">
  543. <view></view>
  544. <view class="title">指派配送人员</view>
  545. <u-icon name="close" color="#000000" size="26" @click="close"></u-icon>
  546. </view>
  547. <view class="popu_list hflex">
  548. <view class="left">{{pageData.community_name}}</view>
  549. <scroll-view class="right vflex acenter jcenter" :scroll-y="true">
  550. <block v-for="(item,index) in deliveryList" :key="index">
  551. <view class="name" :class="active === index ? 'active' : ''" @click="selectDelivery(index)">{{item.delivery_name}}</view>
  552. </block>
  553. </scroll-view>
  554. </view>
  555. <view class="popu_bottom hflex jend">
  556. <view class="btn" @click="sure">确认</view>
  557. </view>
  558. </view>
  559. </u-popup>
  560. <u-popup :show="send_show" @close="close">
  561. <view class="popup">
  562. <view class="popu_top border_bottom hflex acenter jbetween">
  563. <view></view>
  564. <view class="title">配送人员</view>
  565. <u-icon name="close" color="#000000" size="26" @click="close"></u-icon>
  566. </view>
  567. <view class="popu_form">
  568. <view class="hflex acenter">
  569. <!-- <view class="form_label">商品价格:</view> -->
  570. <u-input placeholder="请输入配送员的姓名" border="surround" v-model="appliance_name">
  571. </u-input>
  572. </view>
  573. <view class="hflex acenter" style="margin-top: 60rpx;">
  574. <!-- <view class="form_label">付款备注:</view> -->
  575. <u-input placeholder="请输入配送员的联系方式" border="surround" v-model="appliance_phone">
  576. </u-input>
  577. </view>
  578. </view>
  579. <view class="popu_bottom hflex jend">
  580. <view class="btn btn1" @click="sendAppliance(2)">立即发货</view>
  581. </view>
  582. </view>
  583. </u-popup>
  584. <u-popup :show="write_show" @close="close">
  585. <view class="popup">
  586. <view class="popu_top border_bottom hflex acenter jbetween">
  587. <view></view>
  588. <view class="title">核销</view>
  589. <u-icon name="close" color="#000000" size="26" @click="close"></u-icon>
  590. </view>
  591. <view class="popu_form2">
  592. <view class="hflex acenter">
  593. <u-input placeholder="请您输入6位数的核销码" border="surround" v-model="write_code">
  594. </u-input>
  595. </view>
  596. </view>
  597. <view class="popu_bottom vflex acenter jcenter">
  598. <view class="btn btn1" @click="writeOff">确认核销</view>
  599. <view class="text" @click="scan">扫一扫</view>
  600. </view>
  601. </view>
  602. </u-popup>
  603. <u-popup :show="time_show" @close="close">
  604. <view class="popup">
  605. <view class="popu_top border_bottom hflex acenter jbetween">
  606. <view></view>
  607. <view class="title">核销时间</view>
  608. <u-icon name="close" color="#000000" size="26" @click="close"></u-icon>
  609. </view>
  610. <scroll-view scroll-y="true" class="scroll-Y vflex acenter jcenter popu_scroll">
  611. <block v-for="(item,index) in pageData.verify_log" :key="index">
  612. <view class="scroll_item">{{item.createtime}}</view>
  613. </block>
  614. </scroll-view>
  615. </view>
  616. </u-popup>
  617. </view>
  618. </template>
  619. <!-- 订单详情 -->
  620. <script>
  621. //
  622. import $api from '@/static/js/api.js'
  623. var that = ''
  624. export default {
  625. data() {
  626. return {
  627. pageData: {},
  628. id: 0,
  629. type: '',
  630. identity: 0,
  631. imgUrl: $api.config.imgUrl,
  632. estimate_show: false,
  633. estimate_price: '',
  634. remarks: '',
  635. active: 0,
  636. assign_show: false,
  637. deliveryList: [],
  638. send_show: false,
  639. appliance_name: '',
  640. appliance_phone: '',
  641. write_show: false,
  642. write_code: '',
  643. time_show: false
  644. }
  645. },
  646. onLoad(options) {
  647. that = this
  648. that.id = Number(options.id)
  649. if(options.type) {
  650. that.type = options.type
  651. }
  652. that.identity = uni.getStorageSync('identity')
  653. that.getData()
  654. },
  655. methods: {
  656. getData() {
  657. let url = ''
  658. if(that.identity == 2 && that.type == 'life_supermarket') {
  659. url = '/api/merchant.community.order/get_info'
  660. } else if(that.identity == 4 || that.type == 'home_service') {
  661. url = '/api/merchant_service_order/order_detail'
  662. } else if(that.identity == 3 || that.type == 'daily_appliance') {
  663. url = '/api/merchant.appliance.order/get_info'
  664. } else if(that.identity == 5 || that.type == 'sports') {
  665. url = '/api/merchant.sport.order/get_info'
  666. } else {
  667. return
  668. }
  669. $api.req({
  670. url: url,
  671. data: {
  672. id: that.id
  673. }
  674. }, function(res) {
  675. if(res.code == 1) {
  676. that.pageData = res.data
  677. }
  678. })
  679. },
  680. // 评估价格弹窗
  681. estimateOpen() {
  682. that.estimate_show = true
  683. },
  684. close() {
  685. that.send_show = false
  686. that.estimate_show = false
  687. that.assign_show = false
  688. that.write_show = false
  689. that.time_show = false
  690. },
  691. estimateSure() {
  692. if(that.estimate_price == '') {
  693. $api.info("请输入评估后的价格")
  694. return
  695. }
  696. $api.req({
  697. url: '/api/merchant_service_order/assess_price',
  698. data: {
  699. id: that.pageData.id,
  700. price: that.estimate_price,
  701. remark: that.remarks
  702. }
  703. }, function(res) {
  704. if(res.code == 1) {
  705. $api.info(res.msg)
  706. that.close()
  707. that.getData()
  708. }
  709. })
  710. },
  711. complete() {
  712. $api.req({
  713. url: '/api/merchant_service_order/complete_order',
  714. data: {
  715. id: that.pageData.id
  716. }
  717. }, function(res) {
  718. if(res.code == 1) {
  719. $api.info(res.msg)
  720. that.getData()
  721. }
  722. })
  723. },
  724. // 打开配送人员列表
  725. open() {
  726. that.assign_show = true
  727. that.getDelivery()
  728. // uni.hideTabBar()
  729. },
  730. // 获取配送人员
  731. getDelivery() {
  732. $api.req({
  733. url: '/api/merchant.community.delivery/index',
  734. }, function(res) {
  735. if(res.code == 1) {
  736. that.deliveryList = res.data
  737. }
  738. })
  739. },
  740. // 选择配送人员
  741. sure() {
  742. $api.req({
  743. url: '/api/merchant.community.order/add_delivery',
  744. data: {
  745. id: that.pageData.id,
  746. delivery_id: that.deliveryList[that.active].user_id
  747. }
  748. }, function(res) {
  749. if(res.code == 1) {
  750. $api.info(res.msg)
  751. that.close()
  752. that.getData()
  753. }
  754. })
  755. },
  756. // 点击配送人员
  757. selectDelivery(index) {
  758. that.active = index
  759. },
  760. // 家电配送人员
  761. send(index) {
  762. that.order_index = index
  763. that.send_show = true
  764. },
  765. // 立即发货
  766. sendAppliance(index) {
  767. let data = {}
  768. if(index == 2) {
  769. data= {
  770. id: that.pageData.id,
  771. status: '2',
  772. delivery_name: that.appliance_name,
  773. delivery_mobile: that.appliance_phone
  774. }
  775. } else if(index == 4) {
  776. data= {
  777. id: that.pageData.id,
  778. status: '4'
  779. }
  780. }
  781. $api.req({
  782. url: '/api/merchant.appliance.order/make_order',
  783. data: data,
  784. }, function(res) {
  785. if(res.code == 1) {
  786. $api.info(res.msg)
  787. that.close()
  788. that.getData()
  789. }
  790. })
  791. },
  792. // 打开核销时间
  793. openTime() {
  794. that.time_show = true
  795. },
  796. // 打开核销
  797. writeOffOpen() {
  798. that.write_show = true
  799. },
  800. // 扫一扫
  801. scan() {
  802. // #ifdef MP-WEIXIN
  803. uni.scanCode({
  804. success: function (res) {
  805. console.log('条码类型:' + res.scanType);
  806. console.log('条码内容:' + res.result);
  807. that.write_code = res.result
  808. that.writeOff()
  809. }
  810. });
  811. // #endif
  812. // #ifdef H5
  813. $api.info("请使用小程序扫码核销或输入核销码")
  814. // #endif
  815. },
  816. // 核销
  817. writeOff() {
  818. if(that.write_code == '') {
  819. $api.info("请先输入6位数的核销码")
  820. return
  821. }
  822. $api.req({
  823. url: '/api/merchant.sport.order/verify',
  824. data: {
  825. verify_code: that.write_code,
  826. id: that.pageData.id
  827. }
  828. }, function(res) {
  829. that.write_code = ''
  830. if(res.code == 1) {
  831. $api.info(res.msg)
  832. that.close()
  833. that.getData()
  834. } else {
  835. $api.info(res.msg)
  836. }
  837. })
  838. },
  839. }
  840. }
  841. </script>
  842. <style lang="scss" scoped>
  843. .content::v-deep {
  844. background: #F1F2F4;
  845. .box {
  846. width: 702rpx;
  847. box-sizing: border-box;
  848. padding: 20rpx;
  849. margin: 24rpx auto 0;
  850. background: #FFFFFF;
  851. border-radius: 20rpx;
  852. .box_top {
  853. width: 100%;
  854. padding-bottom: 20rpx;
  855. border-bottom: 1px solid #F5F5F5;
  856. .top_img {
  857. width: 38rpx;
  858. height: 39rpx;
  859. margin-right: 24rpx;
  860. }
  861. .top_text {
  862. font-size: 28rpx;
  863. font-family: PingFangSC-Medium, PingFang SC;
  864. font-weight: 500;
  865. color: #666666;
  866. line-height: 40rpx;
  867. }
  868. }
  869. .address_icon {
  870. width: 80rpx;
  871. height: 80rpx;
  872. margin-right: 34rpx;
  873. }
  874. .title {
  875. font-size: 28rpx;
  876. font-family: PingFangSC-Medium, PingFang SC;
  877. font-weight: 500;
  878. color: #333333;
  879. line-height: 40rpx;
  880. }
  881. .cell {
  882. width: 100%;
  883. padding: 40rpx 0 0;
  884. .text {
  885. font-size: 24rpx;
  886. font-family: PingFangSC-Medium, PingFang SC;
  887. font-weight: 500;
  888. color: #666666;
  889. line-height: 34rpx;
  890. }
  891. }
  892. .status2 {
  893. font-size: 24rpx;
  894. font-family: PingFangSC-Medium, PingFang SC;
  895. font-weight: 500;
  896. color: #FF2828;
  897. line-height: 40rpx;
  898. }
  899. .top {
  900. width: 100%;
  901. padding-bottom: 24rpx;
  902. border-bottom: 1px solid #F5F5F5;
  903. .top_text {
  904. font-size: 36rpx;
  905. font-family: PingFangSC-Medium, PingFang SC;
  906. font-weight: 500;
  907. color: #333333;
  908. line-height: 50rpx;
  909. padding: 0 0 0 10rpx;
  910. }
  911. .status {
  912. font-size: 28rpx;
  913. font-family: PingFangSC-Medium, PingFang SC;
  914. font-weight: 500;
  915. color: #EE8529;
  916. line-height: 40rpx;
  917. }
  918. .status1 {
  919. color: #5ACD4E;
  920. }
  921. }
  922. .good {
  923. width: 100%;
  924. box-sizing: border-box;
  925. padding: 52rpx 0 0;
  926. .item_img {
  927. width: 142rpx;
  928. height: 142rpx;
  929. margin-right: 12rpx;
  930. }
  931. .img_right {
  932. width: calc(100% - 154rpx);
  933. .item_name {
  934. font-size: 28rpx;
  935. font-family: PingFangSC-Medium, PingFang SC;
  936. font-weight: 500;
  937. color: #333333;
  938. line-height: 40rpx;
  939. }
  940. .item_price {
  941. font-size: 28rpx;
  942. font-family: PingFangSC-Medium, PingFang SC;
  943. font-weight: 500;
  944. color: #333333;
  945. line-height: 28rpx;
  946. }
  947. .item_spec {
  948. font-size: 28rpx;
  949. font-family: PingFangSC-Regular, PingFang SC;
  950. font-weight: 400;
  951. color: #999999;
  952. line-height: 40rpx;
  953. padding: 16rpx 0;
  954. }
  955. }
  956. }
  957. .info {
  958. padding: 8rpx 0;
  959. .info_text {
  960. width: 152rpx;
  961. font-size: 20rpx;
  962. font-family: PingFangSC-Medium, PingFang SC;
  963. font-weight: 500;
  964. color: #999999;
  965. line-height: 28rpx;
  966. border-radius: 16rpx;
  967. border: 2rpx solid #999999;
  968. padding: 2rpx 0;
  969. text-align: center;
  970. box-sizing: border-box;
  971. }
  972. }
  973. .cell {
  974. padding: 28rpx 0 0;
  975. .label {
  976. font-size: 28rpx;
  977. font-family: PingFangSC-Medium, PingFang SC;
  978. font-weight: 500;
  979. color: #333333;
  980. line-height: 40rpx;
  981. }
  982. }
  983. }
  984. .bottom {
  985. width: 100%;
  986. height: 166rpx;
  987. background: #FFFFFF;
  988. box-shadow: 0rpx -1rpx 0rpx 0rpx rgba(0,0,0,0.1);
  989. box-sizing: border-box;
  990. padding: 10rpx 24rpx;
  991. position: fixed;
  992. bottom: 0;
  993. .btn {
  994. height: 72rpx;
  995. background: #FFFFFF;
  996. border-radius: 36rpx;
  997. border: 2rpx solid #EE8529;
  998. font-size: 28rpx;
  999. font-family: PingFangSC-Medium, PingFang SC;
  1000. font-weight: 500;
  1001. color: #EE8529;
  1002. line-height: 72rpx;
  1003. padding: 0 40rpx;
  1004. }
  1005. }
  1006. .popup {
  1007. background: #FFFFFF;
  1008. border-radius: 20rpx 20rpx 0rpx 0rpx;
  1009. .popu_top {
  1010. width: 100%;
  1011. height: 88rpx;
  1012. box-sizing: border-box;
  1013. padding: 0 30rpx;
  1014. .title {
  1015. font-size: 28rpx;
  1016. font-family: PingFangSC-Medium, PingFang SC;
  1017. font-weight: 500;
  1018. color: #333333;
  1019. line-height: 40rpx;
  1020. }
  1021. }
  1022. .popu_scroll {
  1023. width: 100%;
  1024. padding: 72rpx 0;
  1025. height: 400rpx;
  1026. .scroll_item {
  1027. font-size: 24rpx;
  1028. font-family: PingFangSC-Regular, PingFang SC;
  1029. font-weight: 400;
  1030. color: #999999;
  1031. line-height: 34rpx;
  1032. padding-bottom: 28rpx;
  1033. text-align: center;
  1034. }
  1035. }
  1036. .popu_form {
  1037. width: 100%;
  1038. box-sizing: border-box;
  1039. padding: 80rpx 50rpx 178rpx 32rpx;
  1040. .form_label {
  1041. font-size: 28rpx;
  1042. font-family: PingFangSC-Medium, PingFang SC;
  1043. font-weight: 500;
  1044. color: #333333;
  1045. line-height: 40rpx;
  1046. }
  1047. .u-input {
  1048. border-radius: 20rpx !important;
  1049. border: 2rpx solid #CCCCCC !important;
  1050. padding: 24rpx;
  1051. height: 0 88rpx;
  1052. }
  1053. }
  1054. .popu_form2 {
  1055. width: 100%;
  1056. box-sizing: border-box;
  1057. padding: 80rpx 72rpx 80rpx 72rpx;
  1058. .u-input {
  1059. border-radius: 44rpx !important;
  1060. border: 2rpx solid #CCCCCC !important;
  1061. padding: 24rpx;
  1062. height: 0 88rpx;
  1063. }
  1064. }
  1065. .border_bottom {
  1066. border-bottom: 1px solid #FFF5ED;
  1067. }
  1068. .popu_list {
  1069. background: #FFF5ED;
  1070. padding: 36rpx 0 0;
  1071. .left {
  1072. width: 238rpx;
  1073. height: 120rpx;
  1074. font-size: 28rpx;
  1075. font-family: PingFangSC-Medium, PingFang SC;
  1076. font-weight: 500;
  1077. color: #EE8529;
  1078. line-height: 120rpx;
  1079. background: #FFFFFF;
  1080. text-align: center;
  1081. }
  1082. .right {
  1083. width: calc(100% - 238rpx);
  1084. background: #FFFFFF;
  1085. height: 672rpx;
  1086. .name {
  1087. padding: 28rpx 0;
  1088. text-align: center;
  1089. font-size: 28rpx;
  1090. font-family: PingFangSC-Regular, PingFang SC;
  1091. font-weight: 400;
  1092. color: #666666;
  1093. line-height: 40rpx;
  1094. }
  1095. .active {
  1096. color: #EE8529;
  1097. }
  1098. }
  1099. }
  1100. .popu_bottom {
  1101. width: 100%;
  1102. margin-bottom: 60rpx;
  1103. .btn {
  1104. width: 316rpx;
  1105. height: 72rpx;
  1106. background: #FFFFFF;
  1107. border-radius: 36rpx;
  1108. border: 2rpx solid #EE8529;
  1109. font-size: 28rpx;
  1110. font-family: PingFangSC-Medium, PingFang SC;
  1111. font-weight: 500;
  1112. color: #EE8529;
  1113. line-height: 72rpx;
  1114. text-align: center;
  1115. margin: 2rpx 24rpx;
  1116. }
  1117. .btn1 {
  1118. width: 630rpx !important;
  1119. height: 88rpx !important;
  1120. background: #EE8529 !important;
  1121. border-radius: 20rpx !important;
  1122. color: #FFFFFF !important;
  1123. line-height: 88rpx ;
  1124. margin: 0 auto;
  1125. }
  1126. .text {
  1127. width: 100%;
  1128. text-align: center;
  1129. font-size: 28rpx;
  1130. font-family: PingFangSC-Medium, PingFang SC;
  1131. font-weight: 500;
  1132. color: #EE8529;
  1133. line-height: 40rpx;
  1134. padding-top: 80rpx;
  1135. }
  1136. }
  1137. }
  1138. }
  1139. </style>