confirm.vue 44 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651
  1. <!-- 确认订单 -->
  2. <template>
  3. <view class="order-wrap">
  4. <!-- 地址栏 -->
  5. <view class="head_box" v-if="orderPre.need_address" @tap="jump('/pages/user/address/list', { from: 'order' })">
  6. <view class="add-address-box u-flex u-flex-1" v-if="!addressId">
  7. <view class="box-bg u-p-30 u-flex-1 u-flex u-row-between">
  8. <text class="select-notice">请选择收货地址</text>
  9. <text class="u-iconfont uicon-arrow-right" style="color: #bfbfbf;"></text>
  10. </view>
  11. </view>
  12. <view class="add-address-box u-p-30" v-else>
  13. <view class="top u-flex">
  14. <text class="name">{{ addressData.consignee }}</text>
  15. <text class="phone">{{ addressData.phone }}</text>
  16. <text class="tag" v-show="addressData.is_default == 1">默认</text>
  17. </view>
  18. <view class="detail u-flex u-row-between">
  19. <view class="address">
  20. {{ addressData.province_name }}{{ addressData.city_name }}{{ addressData.area_name }}{{ addressData.address }}
  21. </view>
  22. <text class="u-iconfont uicon-arrow-right" style="color: #bfbfbf;"></text>
  23. </view>
  24. </view>
  25. </view>
  26. <view class="u-m-b-10">
  27. <!-- 确认订单商品卡片 -->
  28. <view class="goods-list" v-for="g in perGoodsList" :key="g.sku_price_id">
  29. <view class="goods-card u-p-30">
  30. <shopro-mini-card :title="g.detail.title" :image="g.detail.image">
  31. <template #describe>
  32. <view class="order-sku u-ellipsis-1">
  33. <text class="order-num">
  34. {{ g.detail.current_sku_price && g.detail.current_sku_price.goods_sku_text ? g.detail.current_sku_price.goods_sku_text : '' }}
  35. </text>
  36. </view>
  37. </template>
  38. <template #cardBottom>
  39. <view class="goods-price u-flex u-row-between">
  40. <view class="">
  41. <text
  42. v-show="orderType === 'score'">{{ g.detail.current_sku_price.score }}积分+</text>
  43. <text>¥{{ g.detail.current_sku_price.price }}</text>
  44. </view>
  45. <text class="goods-num">x{{ g.goods_num }}</text>
  46. </view>
  47. </template>
  48. </shopro-mini-card>
  49. </view>
  50. <!-- 配送方式 -->
  51. <view class="logistic item-list u-flex u-row-between" @tap="onSelExpressType(g)">
  52. <view class="item-title">配送方式</view>
  53. <view class="u-flex">
  54. <view class="detail">{{ getCurGoodsExpress(g) }}</view>
  55. <text class="u-iconfont uicon-arrow-right" style="color: #bfbfbf;"></text>
  56. </view>
  57. </view>
  58. </view>
  59. <block v-if="perGoodsList.length">
  60. <!-- 备注 -->
  61. <view class="remark-box u-flex item-list u-p-30">
  62. <view class="item-title">备注</view>
  63. <input class="item-input " placeholder-class="input-pl" type="text" v-model="remark"
  64. placeholder="建议留言前先于卖家沟通确认" />
  65. </view>
  66. <!-- 选择优惠券 -->
  67. <sh-select-coupon v-if="hasCoupons" :couponList="couponList" @change="selectCoupon"></sh-select-coupon>
  68. <!-- 积分 -->
  69. <view class="score item-list u-flex u-row-between" v-show="orderType === 'score'">
  70. <view class="u-flex"><text class="item-title">积分</text></view>
  71. <view class="price">-{{ orderPre.score_amount || 0 }}积分</view>
  72. </view>
  73. <!-- 金额明细 -->
  74. <view class=" u-flex u-row-between item-list border-top u-m-b-10">
  75. <view class="item-title">商品金额</view>
  76. <view class="u-flex">
  77. <text class="price">¥{{ orderPre.goods_amount || '0.00' }}</text>
  78. </view>
  79. </view>
  80. <!-- 活动优惠 -->
  81. <u-collapse
  82. v-if="orderPre.activity_discount_infos && orderPre.activity_discount_infos.length && Number(orderPre.activity_discount_money)"
  83. event-type="close" :arrow="true" :accordion="true" arrowColor="#bfbfbf"
  84. :head-style="{ background: '#fff', height: '100rpx' }">
  85. <u-collapse-item>
  86. <block slot="title">
  87. <view style="width: 680rpx;padding-right: 0;" class="u-flex u-row-between item-list">
  88. <view class="item-title">活动优惠</view>
  89. <view class="u-flex">
  90. <text class="price"
  91. style="margin-right: 0;">-¥{{ orderPre.activity_discount_money || '0.00' }}</text>
  92. </view>
  93. </view>
  94. </block>
  95. <view class="" v-for="item in orderPre.activity_discount_infos" :key="item.activity_id">
  96. <view class="u-flex u-row-between item-list" v-if="item.activity_type !== 'free_shipping'">
  97. <view class="item-title">{{ item.activity_title }}</view>
  98. <view class="u-flex">
  99. <text class="price"
  100. style="color: #666;">-¥{{ item.activity_discount_money || '0.00' }}</text>
  101. </view>
  102. </view>
  103. </view>
  104. </u-collapse-item>
  105. </u-collapse>
  106. <!-- 价格 -->
  107. <view class="price-box u-flex u-row-between item-list">
  108. <view class="item-title u-flex u-col-center">
  109. <view class="u-m-r-10">运费</view>
  110. <view class="activity-title" v-if="Number(orderPre.dispatch_discount_money) > 0">活动减¥
  111. {{ orderPre.dispatch_discount_money }}</view>
  112. </view>
  113. <view class="u-flex">
  114. <text class="origin-price u-m-r-10"
  115. v-if="Number(orderPre.dispatch_discount_money) > 0">-¥{{ orderPre.dispatch_amount }}</text>
  116. <text
  117. class="price">¥{{ Number(orderPre.dispatch_amount) - Number(orderPre.dispatch_discount_money) || '0.00' }}</text>
  118. </view>
  119. </view>
  120. <!-- 发票 -->
  121. <view v-if="orderPre && Number(orderPre.invoice_amount)"
  122. class="u-flex u-row-between item-list u-p-20 border-top">
  123. <view class="item-title">申请发票</view>
  124. <view class="u-flex u-col-center" @tap="onInvoice">
  125. <text class="selected-invoice"
  126. style="font-size: 28rpx;color:#c4c4c4;">{{ selectedInvoice }}</text>
  127. <text class="u-iconfont uicon-arrow-right" style="color: #bfbfbf;"></text>
  128. </view>
  129. </view>
  130. </block>
  131. </view>
  132. <!-- 底部 -->
  133. <view class="foot-box-wrap">
  134. <view class="foot-box u-flex u-row-between safe-area-inset-bottom">
  135. <view class="u-flex">
  136. <text class="num">共{{ totalNum }}件</text>
  137. <view class="all-money">
  138. <text>合计:</text>
  139. <text class="price">¥{{ orderPre.total_fee || '0.00' }}</text>
  140. </view>
  141. </view>
  142. <button class="cu-btn sub-btn" @tap="subOrder" :disabled="isDisabled"
  143. hover-class="btn-hover">提交订单</button>
  144. </view>
  145. </view>
  146. <!-- 发票弹窗 -->
  147. <u-popup v-model="showInvoice" @close="showInvoice = false" safe-area-inset-bottom mode="bottom"
  148. :closeable="false" border-radius="20">
  149. <view class="invoice-modal page_box">
  150. <view class="invoice-head u-flex u-col-center">
  151. <view class="head-nav u-flex u-col-center u-row-center" @tap="changeInvoiceType('person')">
  152. <text class="nav-title " :class="{ 'nav-title--active': invoiceType === 'person' }">个人</text>
  153. <view v-show="invoiceType === 'person'" class="head-nav--active"></view>
  154. </view>
  155. <view class="head-nav u-flex u-col-center u-row-center" @tap="changeInvoiceType('company')">
  156. <text class="nav-title"
  157. :class="{ 'nav-title--active': invoiceType === 'company' }">企/事业单位</text>
  158. <view v-show="invoiceType === 'company'" class="head-nav--active"></view>
  159. </view>
  160. </view>
  161. <view class="invoice-content content_box">
  162. <u-form
  163. :labelStyle="{ 'font-size': '28rpx', 'font-weight': '600', color: '#595959', 'padding-left': '20rpx' }"
  164. label-position="left" :model="invoiceForm.model" :rules="invoiceForm.rules" ref="invoiceRef"
  165. :errorType="['toast']">
  166. <u-form-item class="u-p-r-20" label-width="150" label="名称:" prop="header_name">
  167. <u-input placeholder="请填写名称" v-model="invoiceForm.model.header_name" type="text"></u-input>
  168. </u-form-item>
  169. <u-form-item class="u-p-r-20" v-if="invoiceType === 'company'" label-width="220" label="纳税人识别号:"
  170. prop="tax_no">
  171. <u-input placeholder="请输入纳税人识别号" v-model="invoiceForm.model.tax_no" type="text"></u-input>
  172. </u-form-item>
  173. <u-form-item class="u-p-r-20" label-width="150" label="手机号:" prop="mobile">
  174. <u-input placeholder="请输入填写手机号" v-model="invoiceForm.model.mobile" type="number"></u-input>
  175. </u-form-item>
  176. </u-form>
  177. </view>
  178. <view class="invoice-foot">
  179. <view class="invoite-price u-flex u-col-center u-row-center u-m-b-40">
  180. <text class="price-title">可开票金额:</text>
  181. <text class="price-num">{{ orderPre.invoice_amount }}元</text>
  182. </view>
  183. <view class="u-flex u-col-center u-row-around u-p-b-30">
  184. <button class="cancel-btn u-reset-button" @tap="cancelInvoice">取消</button>
  185. <button class="save-btn u-reset-button" @tap="saveInvoice">确定</button>
  186. </view>
  187. </view>
  188. </view>
  189. </u-popup>
  190. <!-- 配送方式弹窗 -->
  191. <u-popup v-model="showExpressType" @close="showExpressType = false" safe-area-inset-bottom mode="bottom"
  192. :closeable="false" border-radius="20">
  193. <!-- 配送方式tab-->
  194. <view class="express-type page_box">
  195. <view class="express-type__head head-box u-flex u-col-center">
  196. <view class="express-type__head-nav u-flex u-col-center u-row-center"
  197. v-for="(nav, index) in expressType" :key="nav.id" @tap="changeExpressType(nav.value)"
  198. v-if="inExpressType.includes(nav.value)">
  199. <text class="head-nav__title"
  200. :class="{ 'head-nav__title--active': expressTypeCur === nav.value }">{{ nav.title }}</text>
  201. <view :class="expressClass" v-show="expressTypeCur === nav.value"></view>
  202. </view>
  203. </view>
  204. <view class="express-type__content content_box">
  205. <!-- 快递 -->
  206. <!-- 空 -->
  207. <view class="empty-address u-flex u-col-center"
  208. v-if="!addressId && expressTypeCur !== 'selfetch' && expressTypeCur !== 'autosend'"
  209. @tap="jump('/pages/user/address/list', { from: 'order' })">
  210. 请选择收货地址
  211. <text class="u-iconfont uicon-arrow-right" style="color: #999;"></text>
  212. </view>
  213. <!-- 地址 -->
  214. <view class="express-address" v-if="expressTypeCur == 'express' && addressId">
  215. <view class="express-top u-flex u-row-between"
  216. @tap="jump('/pages/user/address/list', { from: 'order' })">
  217. <view class="u-flex">
  218. <text class="tag" style="white-space: nowrap;"
  219. v-show="addressData.is_default == 1">默认</text>
  220. <text
  221. class="address">{{ addressData.province_name }}{{ addressData.city_name }}{{ addressData.area_name }}{{ addressData.address }}</text>
  222. <view class="address-guide"><text class="u-iconfont uicon-arrow-right"
  223. style="color: #bfbfbf"></text></view>
  224. </view>
  225. <view class="address-location u-flex-col u-col-center">
  226. <image class="location-img" :src="$IMG_URL + '/imgs/order/e0.png'" mode=""></image>
  227. <text class="location-text">物流快递</text>
  228. </view>
  229. </view>
  230. <view class="express-content">
  231. <view class="phone-box1">
  232. <text class="name">{{ addressData.consignee }}</text>
  233. <text class="phone">{{ addressData.phone }}</text>
  234. </view>
  235. </view>
  236. </view>
  237. <!-- 自提 -->
  238. <view class="express-address" v-if="expressTypeCur == 'selfetch'">
  239. <!-- 定位 -->
  240. <view class="u-flex-col u-col-center location-box" v-if="!lat">
  241. <image class="nolocation-img" :src="$IMG_URL + '/imgs/order/location.png'" mode=""></image>
  242. <text class="location-title">开启定位服务</text>
  243. <text class="location-tip">为你推荐更精准的位置信息噢~</text>
  244. <button class="u-reset-button open-location" @tap="getLocation">去开启</button>
  245. </view>
  246. <!-- 已定位 -->
  247. <view class="" v-else>
  248. <view class="express-top u-flex u-col-center u-row-between"
  249. @tap="jump('/pages/order/express/store-address', { goodsId: currentGoodsId, lat: lat, lng: lng, storeId: storeInfo ? storeInfo.id : 0 })">
  250. <view class="u-flex">
  251. <text class="tag1" v-if="addressData.is_default == 1">最近</text>
  252. <text class="address">{{ storeInfo ? storeInfo.name : '暂无自提点' }}</text>
  253. <text class="u-iconfont uicon-arrow-right" style="color: #999;"></text>
  254. </view>
  255. <view class="address-location u-flex-col u-col-center">
  256. <image class="location-img" :src="$IMG_URL + '/imgs/order/e1.png'" mode=""></image>
  257. <view class="location-text">距您{{ storeInfo ? storeInfo.distance_text : 0 }}</view>
  258. </view>
  259. </view>
  260. <view class="express-content u-flex u-col-cetner">
  261. <view class="time-box">
  262. <view class="box-title u-m-b-20">到店时间</view>
  263. <view class="box-content u-flex u-col-center" @tap="checkExpressTime('selfetch')">
  264. <text
  265. class="box-text">{{ checkTime['day'][checkDayCur].title }}{{ checkTime['time'][checkTimeCur] }}</text>
  266. <text class="u-iconfont uicon-arrow-right" style="color: #999;"></text>
  267. </view>
  268. </view>
  269. <view class="box-line"></view>
  270. <view class="phone-box">
  271. <view class="box-title u-m-b-20">预留电话</view>
  272. <view class="box-content u-flex" style="width: 340rpx;">
  273. <u-input placeholder="请输入预留电话" placeholderStyle="font-size:24rpx" border
  274. height="40" :focus="getFocus" v-model="selfPhone" type="number"></u-input>
  275. </view>
  276. </view>
  277. </view>
  278. <view class="express-bottom" @tap="checkProtocol">
  279. <u-checkbox active-color="#f0c785" :value="isProtocol">
  280. <view class="protocol">
  281. 同意并接受
  282. <text class="protocol-text"
  283. @tap.stop="jump('/pages/public/richtext', { id: initStore.selfetch_protocol })">《到店自提服务协议》</text>
  284. </view>
  285. </u-checkbox>
  286. </view>
  287. </view>
  288. </view>
  289. <!-- 商家配送 -->
  290. <view class="express-address" v-if="expressTypeCur == 'store' && addressId">
  291. <view class="express-top u-flex u-row-between"
  292. @tap="jump('/pages/user/address/list', { from: 'order' })">
  293. <view class="">
  294. <text class="tag" v-if="addressData.is_default == 1">默认</text>
  295. <text
  296. class="address">{{ addressData.province_name }}{{ addressData.city_name }}{{ addressData.area_name }}{{ addressData.address }}</text>
  297. <text class="address-guide u-iconfont uicon-arrow-right" style="color: #999;"></text>
  298. </view>
  299. <view class="address-location u-flex-col u-col-center">
  300. <image class="location-img" :src="$IMG_URL + '/imgs/order/e2.png'" mode=""></image>
  301. <text class="location-text">商家配送</text>
  302. </view>
  303. </view>
  304. <view class="express-content u-flex">
  305. <view class="time-box">
  306. <view class="box-title u-m-b-20">配送时间</view>
  307. <view class="box-content u-flex" @tap="checkExpressTime('store')">
  308. <text
  309. class="box-text">{{ checkTime['day'][checkDayCur].title }}{{ checkTime['time'][checkTimeCur] }}</text>
  310. <text class="u-iconfont uicon-arrow-right" style="color: #999"></text>
  311. </view>
  312. </view>
  313. <view class="box-line"></view>
  314. <view class="phone-box">
  315. <view class="box-title u-m-b-20">预留电话</view>
  316. <view class="box-content u-flex">
  317. <view class="box-content u-flex" style="width: 340rpx;">
  318. <u-input placeholder="请输入预留电话" placeholderStyle="font-size:24rpx" border
  319. height="40" :focus="getFocus" v-model="selfPhone" type="number"></u-input>
  320. </view>
  321. </view>
  322. </view>
  323. </view>
  324. </view>
  325. <!-- 自动发货 -->
  326. <view class="express-address" v-if="expressTypeCur == 'autosend'">
  327. <view class="express-top u-flex u-row-between">
  328. <text class="dispatch-notice">订单支付完成后,请在订单详情页查看发货信息</text>
  329. <view class="address-location u-flex-col u-col-center">
  330. <image class="location-img" :src="$IMG_URL + '/imgs/order/e3.png'" mode=""></image>
  331. <text class="location-text">自动发货</text>
  332. </view>
  333. </view>
  334. </view>
  335. </view>
  336. <view class="express-type__bottom u-flex u-row-between u-p-b-20"
  337. v-show="expressTypeCur !== 'selfetch' || (expressTypeCur == 'selfetch' && lat)">
  338. <button class="u-reset-button cancel-btn" @tap="hideExpressType">取消</button>
  339. <button class="u-reset-button save-btn" @tap="saveExpressType">确定</button>
  340. </view>
  341. </view>
  342. </u-popup>
  343. <!-- 配送时间弹窗 -->
  344. <u-popup v-model="showCheckTime" mode="bottom" safe-area-inset-bottom :closeable="true"
  345. close-icon-pos="top-right" border-radius="20">
  346. <view class="checkTime-box page_box">
  347. <view class="checkTime-head">选择{{ checkType }}时间</view>
  348. <view class="checkTime-content content_box u-flex">
  349. <view class="checkTime-content__left">
  350. <view class="left-item u-flex u-row-center u-col-center" @tap="check('day', index)"
  351. :class="{ 'item--active': checkDayCur == index }" v-for="(day, index) in checkTime.day"
  352. :key="day.value">
  353. {{ day.title }}
  354. </view>
  355. </view>
  356. <scroll-view class="checkTime-content__right scroll-box" :scroll-into-view="'c' + checkTimeId"
  357. scroll-y scroll-with-animation>
  358. <view class="right-item" :id="'c' + time.split(':')[0]" @tap="check('time', index)"
  359. :class="{ 'item--active': checkTimeCur == index }" v-for="(time, index) in checkTime.time"
  360. :key="time">
  361. {{ time }}
  362. </view>
  363. </scroll-view>
  364. </view>
  365. <view class=" checkTime-foot u-flex u-row-center u-col-center"><button class="u-reset-button save-btn"
  366. @tap="showCheckTime = false">保存并使用</button></view>
  367. </view>
  368. </u-popup>
  369. </view>
  370. </template>
  371. <script>
  372. import shSelectCoupon from './components/sh-select-coupon.vue';
  373. import { mapMutations, mapActions, mapState, mapGetters } from 'vuex';
  374. import Auth from '@/shopro/permission/index.js';
  375. export default {
  376. components: {
  377. shSelectCoupon
  378. },
  379. data() {
  380. return {
  381. platform: this.$platform.get(),
  382. totalNum: 0,
  383. couponList: [], //优惠券列表
  384. addressData: {}, //收货地址
  385. addressId: 0, //收货地址ID
  386. customStyle: {
  387. //自定义按钮样式
  388. width: '210rpx',
  389. lineHeight: '70rpx',
  390. background: 'linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1))',
  391. boxShadow: ' 0px 7rpx 6rpx 0px rgba(229, 138, 0, 0.22)',
  392. borderRadius: '100rpx',
  393. fontSize: '28rpx',
  394. border: 'none',
  395. color: '#fff',
  396. margin: '0'
  397. },
  398. isDisabled: false, //提交
  399. showCheckTime: false, //配送时间弹窗。
  400. checkTime: {}, //配送时间数据
  401. showExpressType: false, //配送方式弹窗
  402. expressTypeMap: {
  403. express: '物流快递',
  404. selfetch: '到店/自提',
  405. store: '商家配送',
  406. autosend: '自动发货'
  407. },
  408. expressType: [
  409. //配送方式
  410. {
  411. id: 'e1',
  412. title: '物流快递',
  413. value: 'express'
  414. },
  415. {
  416. id: 'e2',
  417. title: '到店/自提',
  418. value: 'selfetch'
  419. },
  420. {
  421. id: 'e3',
  422. title: '商家配送',
  423. value: 'store'
  424. },
  425. {
  426. id: 'e4',
  427. title: '自动发货',
  428. value: 'autosend'
  429. }
  430. ],
  431. storeList: [], //门店列表
  432. storeInfo: {
  433. id: 0,
  434. name: '',
  435. dispatch_text: ''
  436. }, //自提点商家信息
  437. from: '',
  438. orderType: '',
  439. grouponBuyType: 'alone',
  440. grouponId: 0,
  441. goodsList: [], //传递过来的参数
  442. perGoodsList: {}, //确认单订单商品
  443. currentGoodsId: 0, //当前商品id.
  444. currentSkuId: 0, //商品的规格ID
  445. remark: '',
  446. orderPre: {},
  447. couponId: 0,
  448. couponPrice: '选择优惠券',
  449. expressTypeCur: '',
  450. inExpressType: [], //当前商品支持的配送方式。
  451. isProtocol: true, //自提协议。
  452. selfPhone: '', //编辑手机号
  453. getFocus: false, //获取焦点。
  454. checkType: '自提',
  455. checkTimeCur: 0, //默认选中时间。
  456. checkTimeId: 'c1', //锚点用
  457. checkDayCur: 0, //默认日期
  458. lat: 0, //地理位置
  459. lng: 0,
  460. showInvoice: false, //申请发票
  461. invoiceType: 'person',
  462. selectedInvoice: '不开具发票',
  463. invoiceForm: {
  464. model: {
  465. header_name: '',
  466. mobile: '',
  467. tax_no: '',
  468. type: 'person'
  469. },
  470. rules: {
  471. mobile: [{
  472. required: true,
  473. message: '请输入手机号',
  474. trigger: ['change', 'blur']
  475. },
  476. {
  477. validator: (rule, value, callback) => {
  478. return this.$u.test.mobile(value);
  479. },
  480. message: '手机号码不正确',
  481. trigger: ['change', 'blur']
  482. }
  483. ],
  484. header_name: [{
  485. required: true,
  486. message: '请填写名称',
  487. trigger: ['change', 'blur']
  488. }]
  489. }
  490. }
  491. };
  492. },
  493. computed: {
  494. ...mapGetters(['initStore']),
  495. expressClass() {
  496. let cl = 'head-nav--active';
  497. const { expressType, expressTypeCur } = this;
  498. if (expressTypeCur === 0) {
  499. cl = 'head-nav__left--active';
  500. }
  501. if (expressTypeCur === expressType.length - 1) {
  502. cl = 'head-nav__right--active';
  503. }
  504. return cl;
  505. },
  506. // 是否可以使用优惠券
  507. hasCoupons() {
  508. if (this.couponList.length && !this.orderPre.activity_type) {
  509. return true;
  510. }
  511. return Boolean(
  512. this.couponList.length &&
  513. this.orderPre.activity_type &&
  514. this.orderPre.activity_type.indexOf('groupon') === -1 &&
  515. this.orderPre.activity_type.indexOf('seckill') === -1 &&
  516. this.orderType !== 'score'
  517. );
  518. }
  519. },
  520. onShow() {
  521. // 监听选择自提点
  522. uni.$once('SELECT_STORE', res => {
  523. this.storeInfo = JSON.parse(res.storeInfo);
  524. });
  525. // 监听地址
  526. uni.$on('SELECT_ADDRESS', res => {
  527. if (res.addressData) {
  528. this.addressData = JSON.parse(res.addressData);
  529. this.addressId = this.addressData.id;
  530. } else {
  531. this.addressId = 0;
  532. }
  533. this.getPre();
  534. res.addressData && uni.$off('SELECT_ADDRESS');
  535. });
  536. },
  537. async onLoad() {
  538. this.goodsList = this.$Route.query.goodsList;
  539. this.from = this.$Route.query.from;
  540. this.orderType = this.$Route.query.orderType;
  541. this.grouponBuyType = this.$Route.query.grouponBuyType;
  542. this.grouponId = this.$Route.query.grouponId;
  543. await this.init();
  544. },
  545. methods: {
  546. ...mapActions(['getCartList']),
  547. // 切换发票类型
  548. changeInvoiceType(type) {
  549. this.invoiceType = type;
  550. this.invoiceForm.model.type = type;
  551. },
  552. // 点击开发票
  553. onInvoice() {
  554. this.showInvoice = !this.showInvoice;
  555. this.$nextTick(() => {
  556. if (this.showInvoice) {
  557. this.invoiceForm.model.type = 'person';
  558. this.$refs.invoiceRef.setRules(this.invoiceForm.rules);
  559. }
  560. });
  561. },
  562. // 发票确认取消
  563. cancelInvoice() {
  564. this.selectedInvoice = '不开具发票';
  565. Object.keys(this.invoiceForm.model).map(key => (this.invoiceForm.model[key] = ''));
  566. this.showInvoice = false;
  567. },
  568. saveInvoice() {
  569. this.$refs.invoiceRef.validate(valid => {
  570. if (valid) {
  571. if (this.invoiceType === 'company' && !this.invoiceForm.model.tax_no) {
  572. this.$u.toast('请输入纳税人识别号');
  573. }
  574. this.selectedInvoice = this.invoiceForm.model.header_name;
  575. this.showInvoice = false;
  576. }
  577. });
  578. },
  579. // 初始化
  580. init() {
  581. uni.showLoading({
  582. title: '加载中...',
  583. mask: true
  584. });
  585. return Promise.all([this.getDefaultAddress(), this.initDate(), this.getCoupons()]).then(() => {
  586. uni.hideLoading();
  587. });
  588. },
  589. jump(path, parmas) {
  590. this.$Router.push({
  591. path: path,
  592. query: parmas
  593. });
  594. },
  595. // 格式化选择时间
  596. initDate() {
  597. let week = {
  598. 0: '周日',
  599. 1: '周一',
  600. 2: '周二',
  601. 3: '周三',
  602. 4: '周四',
  603. 5: '周五',
  604. 6: '周六'
  605. };
  606. let now = new Date().getTime();
  607. let today = this.$u.timeFormat(now);
  608. let tomorrow = this.$u.timeFormat(now + 86400000);
  609. let aftertomorrow = this.$u.timeFormat(now + 172800000);
  610. let week1 = week[new Date().getDay()];
  611. let week2 = week[new Date(now + 86400000).getDay()];
  612. let week3 = week[new Date(now + 172800000).getDay()];
  613. let obj = {
  614. day: [{
  615. title: '今天(' + week1 + ')',
  616. value: today
  617. },
  618. {
  619. title: '明天(' + week2 + ')',
  620. value: tomorrow
  621. },
  622. {
  623. title: '后天(' + week3 + ')',
  624. value: aftertomorrow
  625. }
  626. ],
  627. time: ['08:00', '09:00', '10:00', '11:00', '12:00', '13:00', '14:00', '15:00', '16:00', '17:00',
  628. '18:00', '19:00'
  629. ]
  630. };
  631. this.checkTime = obj;
  632. },
  633. // 格式日期
  634. check(type, index) {
  635. if (type == 'time') {
  636. this.checkTimeCur = index;
  637. this.checkTimeId = this.checkTime['time'][index].split(':')[[0]];
  638. }
  639. if (type == 'day') {
  640. this.checkDayCur = index;
  641. }
  642. },
  643. // 获取当前商品配送方式
  644. getCurGoodsExpress(goods) {
  645. for (let item of this.goodsList) {
  646. if (item.goods_id == goods.goods_id && goods.sku_price_id == item.sku_price_id) {
  647. return this.expressTypeMap[item.dispatch_type];
  648. }
  649. }
  650. },
  651. // 获取位置
  652. async getLocation() {
  653. let authState = await new Auth('userLocation').check();
  654. // #ifdef MP || APP-VUE
  655. authState &&
  656. uni.getLocation({
  657. type: 'gcj02',
  658. success: res => {
  659. this.lng = res.longitude;
  660. this.lat = res.latitude;
  661. this.getStoreAddress();
  662. },
  663. fail: err => {
  664. console.log('确认订单自提位置:', err);
  665. }
  666. });
  667. // #endif
  668. // #ifdef H5
  669. uni.getLocation({
  670. type: 'gcj02',
  671. success: res => {
  672. this.lng = res.longitude;
  673. this.lat = res.latitude;
  674. this.getStoreAddress();
  675. }
  676. });
  677. // #endif
  678. },
  679. // 获取商品支持的自提点。
  680. getStoreAddress() {
  681. let that = this;
  682. that.$http('goods.storeAddress', {
  683. id: that.currentGoodsId,
  684. latitude: that.lat,
  685. longitude: that.lng
  686. }).then(res => {
  687. if (res.code == 1) {
  688. that.storeInfo = res.data.data[0];
  689. that.storeList = res.data.data;
  690. }
  691. });
  692. },
  693. // 订单信息
  694. getPre() {
  695. let that = this;
  696. that.$http('order.pre', {
  697. goods_list: that.goodsList,
  698. from: that.from,
  699. address_id: that.addressId,
  700. coupons_id: that.couponId,
  701. order_type: that.orderType,
  702. buy_type: that.grouponBuyType,
  703. groupon_id: that.grouponId
  704. }).then(res => {
  705. if (res.data) {
  706. that.orderPre = res.data;
  707. that.perGoodsList = res.data.new_goods_list;
  708. that.totalNum = 0;
  709. that.perGoodsList.map(item => {
  710. item.selType = item.dispatch_type;
  711. that.totalNum += item.goods_num;
  712. that.goodsList.forEach(goods => {
  713. if (item.goods_id == goods.goods_id && item.sku_price_id == goods
  714. .sku_price_id) {
  715. goods.dispatch_type = item.dispatch_type;
  716. if (item.store_id) {
  717. goods.store_id = item.store_id;
  718. }
  719. }
  720. });
  721. });
  722. }
  723. });
  724. },
  725. // 提交订单
  726. subOrder() {
  727. let that = this;
  728. that.isDisabled = true;
  729. that.$http(
  730. 'order.createOrder', {
  731. goods_list: that.goodsList,
  732. from: that.from,
  733. address_id: that.addressId,
  734. coupons_id: that.couponId,
  735. remark: that.remark,
  736. order_type: that.orderType,
  737. buy_type: that.grouponBuyType,
  738. groupon_id: that.grouponId,
  739. invoice: Number(that.orderPre.invoice_amount) && that.selectedInvoice !== '不开具发票' ? { ...that
  740. .invoiceForm.model, amount: that.orderPre.invoice_amount } : {}
  741. },
  742. '提交中...'
  743. ).then(res => {
  744. that.isDisabled = false;
  745. if (res.code === 1) {
  746. that.getCartList();
  747. that.$Router.replace({
  748. path: res.data.status > 0 ? `/pages/order/payment/result` :
  749. `/pages/order/payment/method`,
  750. query: {
  751. orderId: res.data.id,
  752. payState: res.data.status > 0 ? 'success' : 'paying',
  753. orderType: 'goods'
  754. }
  755. });
  756. }
  757. });
  758. },
  759. // 初始地址
  760. getDefaultAddress() {
  761. this.$http('address.defaults', {}, '', false).then(res => {
  762. if (res.code === 1 && res.data) {
  763. this.addressData = res.data;
  764. this.addressId = res.data.id;
  765. }
  766. this.getPre();
  767. });
  768. },
  769. // 可用优惠券
  770. getCoupons() {
  771. let that = this;
  772. that.$http('order.coupons', {
  773. goods_list: that.goodsList,
  774. from: that.from,
  775. address_id: that.addressId,
  776. coupons_id: that.couponId,
  777. order_type: that.orderType
  778. }).then(res => {
  779. if (res.code === 1) {
  780. that.couponList = res.data;
  781. }
  782. });
  783. },
  784. // 选择优惠券
  785. selectCoupon(index) {
  786. this.couponId = index >= 0 ? this.couponList[index].user_coupons_id : 0;
  787. this.getPre();
  788. },
  789. // 显示配送方式弹窗
  790. async onSelExpressType(goods) {
  791. this.showExpressType = true;
  792. this.inExpressType = goods.detail.dispatch_type_arr;
  793. this.currentGoodsId = goods.goods_id;
  794. this.currentSkuId = goods.sku_price_id;
  795. this.goodsList.forEach(item => {
  796. if (item.goods_id == this.currentGoodsId && this.currentSkuId == item.sku_price_id) {
  797. this.expressTypeCur = item.dispatch_type;
  798. this.selfPhone = item.dispatch_phone ? item.dispatch_phone : this.addressData && this
  799. .addressData.phone;
  800. this.checkDayCur = item.checkDayCur ? item.checkDayCur : 0;
  801. this.checkTimeCur = item.checkTimeCur ? item.checkTimeCur : 0;
  802. if (this.expressTypeCur == 'selfetch') {
  803. !this.lat && this.getLocation();
  804. this.storeList.forEach(store => {
  805. if (item.store_id == store.id) {
  806. this.storeInfo = store;
  807. }
  808. });
  809. this.selfPhone = item.dispatch_phone ? item.dispatch_phone : this.addressData &&
  810. this.addressData.phone;
  811. }
  812. }
  813. });
  814. },
  815. // 关闭配送方式弹窗
  816. hideExpressType() {
  817. this.showExpressType = false;
  818. this.changeGoodsList();
  819. },
  820. // 保存配送方式
  821. saveExpressType() {
  822. if (this.expressTypeCur === 'selfetch') {
  823. if (!this.storeInfo) {
  824. this.$u.toast('暂无自提点,请选择其他配送方式');
  825. return false;
  826. }
  827. if (!this.isProtocol) {
  828. this.$u.toast('请先勾选门店协议');
  829. return false;
  830. }
  831. }
  832. this.showExpressType = false;
  833. this.changeGoodsList();
  834. this.getPre();
  835. },
  836. // 更改提交数据
  837. changeGoodsList() {
  838. this.goodsList.forEach(goods => {
  839. if (goods.goods_id == this.currentGoodsId && this.currentSkuId == goods.sku_price_id) {
  840. goods.dispatch_type = this.expressTypeCur;
  841. goods.dispatch_phone = this.selfPhone;
  842. goods.dispatch_date = this.checkTime['day'][this.checkDayCur].value + ' ' + this.checkTime[
  843. 'time'][this.checkTimeCur] + ':00';
  844. if (this.expressTypeCur == 'selfetch') {
  845. if (!this.storeInfo) {
  846. this.$u.toast('暂无自提点,请选择其他配送方式');
  847. return false;
  848. }
  849. goods.store_id = this.storeInfo.id;
  850. }
  851. goods.checkDayCur = this.checkDayCur;
  852. goods.checkTimeCur = this.checkTimeCur;
  853. }
  854. });
  855. },
  856. // 选择快递方式
  857. changeExpressType(cur) {
  858. this.expressTypeCur = cur;
  859. this.getFocus = false;
  860. cur === 'selfetch' && !this.lat && this.getLocation();
  861. },
  862. // 是否同意协议
  863. checkProtocol() {
  864. this.isProtocol = !this.isProtocol;
  865. },
  866. // 选择配送时间
  867. checkExpressTime(type) {
  868. switch (type) {
  869. case 'store':
  870. this.checkType = '配送';
  871. break;
  872. case 'selfetch':
  873. this.checkType = '自提';
  874. break;
  875. default:
  876. this.checkType = '自提';
  877. }
  878. this.showCheckTime = !this.showCheckTime;
  879. }
  880. }
  881. };
  882. </script>
  883. <style lang="scss" scoped>
  884. // 发票弹窗
  885. .invoice-modal {
  886. width: 750rpx;
  887. background-color: #fff;
  888. border-radius: 20rpx 20rpx 0 0;
  889. height: 700rpx;
  890. overflow: visible;
  891. .invoice-foot {
  892. .price-title {
  893. font-size: 28rpx;
  894. font-weight: 400;
  895. color: #333333;
  896. }
  897. .price-num {
  898. font-size: 28rpx;
  899. font-weight: 500;
  900. color: #eab662;
  901. }
  902. .cancel-btn {
  903. width: 335rpx;
  904. line-height: 74rpx;
  905. background: rgba(238, 238, 238, 1);
  906. border-radius: 37rpx;
  907. font-size: 28rpx;
  908. font-weight: 400;
  909. color: rgba(51, 51, 51, 1);
  910. }
  911. .save-btn {
  912. width: 335rpx;
  913. line-height: 74rpx;
  914. background: linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1));
  915. border-radius: 37rpx;
  916. font-size: 28rpx;
  917. font-weight: 400;
  918. color: rgba(255, 255, 255, 1);
  919. }
  920. }
  921. .invoice-head {
  922. width: 100%;
  923. height: 80rpx;
  924. background: #f8e3bd;
  925. border-radius: 20rpx 20rpx 0 0;
  926. .head-nav {
  927. width: (750rpx/2);
  928. position: relative;
  929. height: 100%;
  930. }
  931. .nav-title {
  932. font-size: 24rpx;
  933. font-weight: 500;
  934. color: #666;
  935. position: relative;
  936. z-index: 6;
  937. }
  938. .nav-title--active {
  939. color: #a8700d;
  940. font-size: 26rpx;
  941. }
  942. .head-nav--active {
  943. position: absolute;
  944. left: 50%;
  945. transform: translateX(-50%);
  946. bottom: 0;
  947. background: #fff;
  948. width: 100%;
  949. height: 80rpx;
  950. background-color: #fff;
  951. border-radius: 20rpx 20rpx 0px 0px;
  952. &::after {
  953. content: '';
  954. display: block;
  955. width: 40rpx;
  956. height: 80rpx;
  957. position: absolute;
  958. transform: skewX(20deg);
  959. background: #fff;
  960. border-top-right-radius: 20rpx;
  961. top: 0;
  962. right: -15rpx;
  963. }
  964. &::before {
  965. content: '';
  966. display: block;
  967. width: 40rpx;
  968. height: 80rpx;
  969. position: absolute;
  970. transform: skewX(-20deg);
  971. background: #fff;
  972. border-top-left-radius: 20rpx;
  973. top: 0;
  974. left: -15rpx;
  975. }
  976. }
  977. }
  978. }
  979. // 收货地址栏
  980. .head_box {
  981. background-color: #fff;
  982. }
  983. .add-address-box {
  984. min-height: 100rpx;
  985. background: url($IMG_URL+'/imgs/order/order_address_line.png') no-repeat;
  986. background-size: 100% auto;
  987. background-position: bottom center;
  988. .select-notice {
  989. font-weight: 400;
  990. color: rgba(153, 153, 153, 1);
  991. line-height: 40rpx;
  992. }
  993. .name,
  994. .phone {
  995. font-size: 30rpx;
  996. font-weight: 500;
  997. }
  998. .phone {
  999. margin: 0 20rpx;
  1000. }
  1001. .tag {
  1002. background: rgba(233, 191, 113, 0.2);
  1003. border-radius: 6rpx;
  1004. padding: 0 16rpx;
  1005. line-height: 38rpx;
  1006. color: #a8700d;
  1007. font-size: 22rpx;
  1008. }
  1009. .detail {
  1010. .address {
  1011. margin-top: 25rpx;
  1012. width: 543rpx;
  1013. font-size: 26rpx;
  1014. font-weight: 400;
  1015. color: rgba(153, 153, 153, 1);
  1016. line-height: 40rpx;
  1017. }
  1018. }
  1019. }
  1020. // 备注
  1021. .remark-box {
  1022. margin-top: 20rpx;
  1023. background: #fff;
  1024. padding: 25rpx;
  1025. .item-input {
  1026. flex: 1;
  1027. text-align: end;
  1028. font-size: 28rpx;
  1029. }
  1030. .input-pl {
  1031. color: #c4c4c4;
  1032. }
  1033. }
  1034. // 商品卡片
  1035. .goods-list {
  1036. background: #fff;
  1037. margin-top: 20rpx;
  1038. .goods-card {
  1039. min-height: 200rpx;
  1040. .goods-price {
  1041. font-size: 30rpx;
  1042. font-weight: 500;
  1043. width: 480rpx;
  1044. color: #333333;
  1045. .goods-num {
  1046. font-size: 28rpx;
  1047. color: #c4c4c4;
  1048. }
  1049. }
  1050. .order-sku {
  1051. font-size: 24rpx;
  1052. font-weight: 400;
  1053. color: rgba(153, 153, 153, 1);
  1054. width: 440rpx;
  1055. margin-bottom: 20rpx;
  1056. .order-num {
  1057. margin-right: 10rpx;
  1058. }
  1059. }
  1060. }
  1061. }
  1062. .item-list {
  1063. height: 100rpx;
  1064. background: #fff;
  1065. padding: 0 25rpx;
  1066. .item-title {
  1067. font-size: 28rpx;
  1068. margin-right: 20rpx;
  1069. .activity-title {
  1070. font-size: 26rpx;
  1071. color: #999;
  1072. }
  1073. }
  1074. .detail {
  1075. font-size: 28rpx;
  1076. color: #333;
  1077. }
  1078. .origin-price {
  1079. font-size: 26rpx;
  1080. color: #666;
  1081. text-decoration: line-through;
  1082. }
  1083. .price {
  1084. font-size: 26rpx;
  1085. color: #ff0000;
  1086. margin-right: 40rpx;
  1087. }
  1088. .sel-coupon {
  1089. font-size: 26rpx;
  1090. color: #c4c4c4;
  1091. margin-right: 20rpx;
  1092. }
  1093. }
  1094. .logistic,
  1095. .price-box,
  1096. .remark-box,
  1097. .score,
  1098. .coupon {
  1099. border-top: 1rpx solid rgba(#dfdfdf, 0.5);
  1100. }
  1101. .border-top {
  1102. border-top: 1rpx solid rgba(#dfdfdf, 0.5);
  1103. }
  1104. .foot-box-wrap {
  1105. height: calc(100rpx + env(safe-area-inset-bottom) / 2);
  1106. padding-bottom: calc(env(safe-area-inset-bottom) / 2);
  1107. position: relative;
  1108. width: 100%;
  1109. z-index: 70;
  1110. }
  1111. .foot-box {
  1112. position: fixed;
  1113. display: flex;
  1114. align-items: center;
  1115. width: 100%;
  1116. height: calc(100rpx + env(safe-area-inset-bottom) / 2);
  1117. border-top: 1rpx solid #eeeeee;
  1118. background-color: #fff;
  1119. z-index: 998;
  1120. bottom: 0;
  1121. padding-bottom: calc(env(safe-area-inset-bottom) / 2);
  1122. padding: 0 30rpx;
  1123. .btn-hover {
  1124. color: #fff;
  1125. }
  1126. .num {
  1127. font-size: 26rpx;
  1128. color: #999;
  1129. }
  1130. .all-money {
  1131. margin: 0 60rpx 0 20rpx;
  1132. .price {
  1133. color: #ff0000;
  1134. }
  1135. }
  1136. .sub-btn {
  1137. width: 210rpx;
  1138. line-height: 70rpx;
  1139. background: linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1));
  1140. box-shadow: 0px 7rpx 6rpx 0px rgba(229, 138, 0, 0.22);
  1141. border-radius: 50rpx;
  1142. font-size: 28rpx;
  1143. color: #fff;
  1144. }
  1145. }
  1146. // 弹窗之配送方式
  1147. // 配送方式
  1148. .express-type {
  1149. width: 750rpx;
  1150. background-color: #fff;
  1151. border-radius: 20rpx 20rpx 0 0;
  1152. height: 700rpx;
  1153. overflow: visible;
  1154. .express-type__head {
  1155. width: 100%;
  1156. height: 80rpx;
  1157. background: #f8e3bd;
  1158. border-radius: 20rpx 20rpx 0 0;
  1159. &-nav {
  1160. width: (750rpx/4);
  1161. position: relative;
  1162. height: 100%;
  1163. }
  1164. .head-nav--active {
  1165. position: absolute;
  1166. left: 50%;
  1167. transform: translateX(-50%);
  1168. bottom: 0;
  1169. background: #fff;
  1170. width: 100%;
  1171. height: 80rpx;
  1172. background-color: #fff;
  1173. border-radius: 20rpx 20rpx 0px 0px;
  1174. &::after {
  1175. content: '';
  1176. display: block;
  1177. width: 40rpx;
  1178. height: 80rpx;
  1179. position: absolute;
  1180. transform: skewX(20deg);
  1181. background: #fff;
  1182. border-top-right-radius: 20rpx;
  1183. top: 0;
  1184. right: -15rpx;
  1185. }
  1186. &::before {
  1187. content: '';
  1188. display: block;
  1189. width: 40rpx;
  1190. height: 80rpx;
  1191. position: absolute;
  1192. transform: skewX(-20deg);
  1193. background: #fff;
  1194. border-top-left-radius: 20rpx;
  1195. top: 0;
  1196. left: -15rpx;
  1197. }
  1198. }
  1199. .head-nav__left--active {
  1200. position: absolute;
  1201. left: 50%;
  1202. transform: translateX(-50%);
  1203. bottom: 0;
  1204. background: #fff;
  1205. width: 100%;
  1206. height: 74rpx;
  1207. background-color: #fff;
  1208. border-radius: 20rpx 20rpx 0px 0px;
  1209. &::after {
  1210. content: '';
  1211. display: block;
  1212. width: 40rpx;
  1213. height: 74rpx;
  1214. position: absolute;
  1215. transform: skewX(20deg);
  1216. background: #fff;
  1217. border-top-right-radius: 20rpx;
  1218. top: 0;
  1219. right: -15rpx;
  1220. }
  1221. }
  1222. .head-nav__right--active {
  1223. position: absolute;
  1224. left: 50%;
  1225. transform: translateX(-50%);
  1226. bottom: 0;
  1227. background: #fff;
  1228. width: 100%;
  1229. height: 74rpx;
  1230. background-color: #fff;
  1231. border-radius: 20rpx 20rpx 0px 0px;
  1232. &::before {
  1233. content: '';
  1234. display: block;
  1235. width: 40rpx;
  1236. height: 74rpx;
  1237. position: absolute;
  1238. transform: skewX(-20deg);
  1239. background: #fff;
  1240. border-top-left-radius: 20rpx;
  1241. top: 0;
  1242. left: -15rpx;
  1243. }
  1244. }
  1245. .head-nav__title {
  1246. font-size: 24rpx;
  1247. font-weight: 500;
  1248. color: #666;
  1249. position: relative;
  1250. z-index: 6;
  1251. }
  1252. .head-nav__title--active {
  1253. color: #a8700d;
  1254. font-size: 26rpx;
  1255. }
  1256. }
  1257. .express-type__content {
  1258. .empty-address {
  1259. height: 120rpx;
  1260. padding: 0 25rpx;
  1261. font-size: 28rpx;
  1262. font-weight: 400;
  1263. color: rgba(153, 153, 153, 1);
  1264. }
  1265. // 无定位
  1266. .location-box {
  1267. height: 500rpx;
  1268. justify-content: center;
  1269. .nolocation-img {
  1270. width: 74rpx;
  1271. height: 90rpx;
  1272. margin-bottom: 40rpx;
  1273. }
  1274. .location-title {
  1275. font-size: 35rpx;
  1276. font-weight: bold;
  1277. color: rgba(70, 53, 27, 1);
  1278. margin-bottom: 20rpx;
  1279. }
  1280. .location-tip {
  1281. font-size: 28rpx;
  1282. font-weight: 400;
  1283. color: rgba(153, 153, 153, 1);
  1284. margin-bottom: 40rpx;
  1285. }
  1286. .open-location {
  1287. width: 492rpx;
  1288. line-height: 70rpx;
  1289. background: linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1));
  1290. box-shadow: 0px 7rpx 6rpx 0px rgba(229, 138, 0, 0.22);
  1291. border-radius: 35rpx;
  1292. font-size: 28rpx;
  1293. font-weight: 500;
  1294. color: rgba(255, 255, 255, 1);
  1295. }
  1296. }
  1297. // 快递
  1298. .express-address {
  1299. position: relative;
  1300. padding: 30rpx 25rpx;
  1301. background: url($IMG_URL+'/imgs/order/address_bg.png') no-repeat;
  1302. background-size: 430rpx 300rpx;
  1303. background-position: top right;
  1304. .express-top {
  1305. margin-bottom: 20rpx;
  1306. width: 550rpx;
  1307. text-align: left;
  1308. .address {
  1309. font-size: 28rpx;
  1310. font-weight: 500;
  1311. color: rgba(51, 51, 51, 1);
  1312. line-height: 40rpx;
  1313. text-align: left;
  1314. }
  1315. .dispatch-notice {
  1316. font-size: 28rpx;
  1317. font-weight: 500;
  1318. color: rgba(51, 51, 51, 1);
  1319. line-height: 40rpx;
  1320. text-align: left;
  1321. }
  1322. .address-location {
  1323. position: absolute;
  1324. right: 60rpx;
  1325. top: 30rpx;
  1326. .location-img {
  1327. width: 80rpx;
  1328. height: 90rpx;
  1329. }
  1330. .location-text {
  1331. font-size: 18rpx;
  1332. font-weight: 500;
  1333. color: rgba(51, 51, 51, 1);
  1334. }
  1335. }
  1336. .tag {
  1337. background: rgba(233, 191, 113, 0.2);
  1338. border-radius: 6rpx;
  1339. padding: 0 16rpx;
  1340. line-height: 38rpx;
  1341. color: #a8700d;
  1342. font-size: 22rpx;
  1343. margin-right: 20rpx;
  1344. }
  1345. .tag1 {
  1346. background: rgba(53, 190, 105, 0.2);
  1347. border-radius: 6rpx;
  1348. padding: 0 16rpx;
  1349. line-height: 38rpx;
  1350. color: #1bbc50;
  1351. font-size: 22rpx;
  1352. margin-right: 20rpx;
  1353. }
  1354. .address-guide {
  1355. position: absolute;
  1356. right: 25rpx;
  1357. top: 40rpx;
  1358. color: #999999;
  1359. }
  1360. }
  1361. .express-content {
  1362. margin-bottom: 20rpx;
  1363. .box-line {
  1364. width: 1rpx;
  1365. height: 61rpx;
  1366. border-left: 1rpx solid rgba(238, 238, 238, 1);
  1367. margin: 0 40rpx;
  1368. }
  1369. .phone-box1 {
  1370. .name,
  1371. .phone {
  1372. font-size: 26rpx;
  1373. font-weight: 400;
  1374. color: rgba(102, 102, 102, 1);
  1375. }
  1376. .phone {
  1377. margin-left: 20rpx;
  1378. }
  1379. }
  1380. .time-box,
  1381. .phone-box {
  1382. text-align: left;
  1383. min-height: 120rpx;
  1384. .box-title {
  1385. font-size: 24rpx;
  1386. font-weight: 400;
  1387. color: #666;
  1388. padding-bottom: 10rpx;
  1389. }
  1390. .box-text {
  1391. font-size: 24rpx;
  1392. font-weight: 500;
  1393. color: #333;
  1394. }
  1395. .edit-phone {
  1396. width: 160rpx;
  1397. font-size: 24rpx;
  1398. font-weight: 500;
  1399. color: #333;
  1400. }
  1401. .box-icon {
  1402. font-size: 28rpx;
  1403. color: #999;
  1404. display: inline-block;
  1405. width: 40rpx;
  1406. text-align: center;
  1407. line-height: 40rpx;
  1408. }
  1409. }
  1410. }
  1411. .express-bottom {
  1412. .protocol {
  1413. font-size: 24rpx;
  1414. font-weight: 400;
  1415. color: rgba(102, 102, 102, 1);
  1416. .protocol-text {
  1417. color: #6487a4;
  1418. }
  1419. }
  1420. }
  1421. }
  1422. }
  1423. .express-type__bottom {
  1424. height: 90rpx;
  1425. padding: 0 30rpx;
  1426. .cancel-btn {
  1427. width: 335rpx;
  1428. line-height: 74rpx;
  1429. background: rgba(238, 238, 238, 1);
  1430. border-radius: 37rpx;
  1431. font-size: 28rpx;
  1432. font-weight: 400;
  1433. color: rgba(51, 51, 51, 1);
  1434. }
  1435. .save-btn {
  1436. width: 335rpx;
  1437. line-height: 74rpx;
  1438. background: linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1));
  1439. border-radius: 37rpx;
  1440. font-size: 28rpx;
  1441. font-weight: 400;
  1442. color: rgba(255, 255, 255, 1);
  1443. }
  1444. }
  1445. }
  1446. // 选择配送给时间
  1447. .checkTime-box {
  1448. background: rgba(255, 255, 255, 1);
  1449. border-radius: 20rpx 20rpx 0px 0px;
  1450. height: 720rpx;
  1451. text-align: center;
  1452. .checkTime-head {
  1453. font-size: 32rpx;
  1454. font-weight: 500;
  1455. color: rgba(51, 51, 51, 1);
  1456. line-height: 100rpx;
  1457. position: relative;
  1458. }
  1459. .checkTime-foot {
  1460. height: 100rpx;
  1461. .save-btn {
  1462. width: 690rpx;
  1463. line-height: 80rpx;
  1464. background: linear-gradient(90deg, rgba(240, 199, 133, 1), rgba(246, 214, 157, 1));
  1465. border-radius: 40rpx;
  1466. font-size: 30rpx;
  1467. font-weight: 500;
  1468. color: rgba(255, 255, 255, 1);
  1469. }
  1470. }
  1471. .checkTime-content {
  1472. .checkTime-content__left {
  1473. height: 100%;
  1474. width: 190rpx;
  1475. background: #f5f5f5;
  1476. .left-item {
  1477. font-size: 26rpx;
  1478. font-weight: 500;
  1479. color: rgba(51, 51, 51, 1);
  1480. height: 100rpx;
  1481. width: 100%;
  1482. }
  1483. }
  1484. .checkTime-content__right {
  1485. flex: 1;
  1486. height: 100%;
  1487. overflow-y: auto;
  1488. .right-item {
  1489. font-size: 26rpx;
  1490. font-weight: 500;
  1491. color: rgba(51, 51, 51, 1);
  1492. width: 100%;
  1493. text-align: center;
  1494. border-bottom: 1rpx solid rgba(#dfdfdf, 0.6);
  1495. margin: 0 30rpx;
  1496. line-height: 100rpx;
  1497. }
  1498. }
  1499. .item--active {
  1500. font-size: 26rpx;
  1501. font-weight: 500;
  1502. color: rgba(168, 112, 13, 1) !important;
  1503. background-color: #fff;
  1504. }
  1505. }
  1506. }
  1507. </style>