| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154 |
- <template>
- <div class="mobile-content mobile-content-long mobile-pay">
- <div class="pay-head" @click="openAddrModal">
- <template v-if="selectedAddress && selectedAddress.name">
- <p class="info">
- {{selectedAddress.name}} {{selectedAddress.tel}}
- </p>
- <div class="addr">
- <img src="/images/mobile/center/user/addr-flag.png" alt="">
- <span>{{selectedAddress.area + selectedAddress.detailAddress}}</span>
- </div>
- <i class="iconfont icon-xiangyou fr"></i>
- </template>
- <template v-else>
- <div class="no-addr">暂无收货地址信息</div>
- </template>
- </div>
- <ul class="pay-store-list">
- <li class="ps-item" v-for="item in orderData">
- <p class="ps-store-name">{{item.storeName}}
- <a class="com-mobile-link" @click="linkSaler(item)"><i class="iconfont icon-kefu1"></i>联系卖家</a>
- </p>
- <div class="ps-goods-info clearfix" @click="showDetailList(item.goods)">
- <div class="fl">
- <!--<span class="inline-block arrow" @click="goodsScroll('left')">
- <i class="iconfont icon-xiangzuo"></i>
- </span>-->
- <ul class="ps-goods-list">
- <li class="inline-block" v-for="goods in item.goods">
- <div class="ps-goods-item text-ellipse" :class="{'pg-item-long': item.goods.length === 1}"><span>品牌:</span>{{goods.brName || '-'}}</div>
- <div class="ps-goods-item text-ellipse" :class="{'pg-item-long': item.goods.length === 1}"><span>类目:</span>{{goods.kiName || '-'}}</div>
- <div class="ps-goods-item text-ellipse" :class="{'pg-item-long': item.goods.length === 1}"><span>型号:</span>{{goods.cmpCode || '-'}}</div>
- <div class="ps-goods-item text-ellipse" :class="{'pg-item-long': item.goods.length === 1}"><span>规格:</span>{{goods.spec || '-'}}</div>
- </li>
- </ul>
- <span class="inline-block arrow" @click="goodsScroll('right')">
- <i class="iconfont icon-xiangyou"></i>
- </span>
- </div>
- <div class="fr">
- <p class="price text-ellipse"><span>{{payData.currency | currencyFilter}}</span>{{item.goodsPrice}}</p>
- <p class="count text-ellipse">共{{item.goods.length || 0}}件产品</p>
- </div>
- </div>
- <div class="ps-operate-line" @click="showRuleSet(item.storeid)">
- <span class="title">配送方式</span>
- <div class="fr">
- <div class="inline-block">
- <span v-if="fareRule[item.storeid] && fareRule[item.storeid][0]">{{fareRule[item.storeid][0].method | deliveryRuleFilter}}</span>
- <span v-if="fareRule[item.storeid] && fareRule[item.storeid][0]">{{fareRule[item.storeid][0].ruleName}}</span>
- <span v-if="!(fareRule[item.storeid] && fareRule[item.storeid][0])" class="red">当前地址不支持配送,请与卖家协商处理</span>
- </div>
- <i class="iconfont icon-xiangyou" v-if="fareRule[item.storeid] && fareRule[item.storeid][0]"></i>
- </div>
- </div>
- <div class="ps-operate-line ps-operate-takeself" v-if="checkShowTakeSelf(item)" @click="showTakeSelfSet(item.storeid)">
- <span class="title">自提点</span>
- <div class="fr">
- <div class="inline-block">
- <template v-if="takeSelfData[item.storeid] && takeSelfData[item.storeid]">
- <span>{{takeSelfData[item.storeid][0].takename}}</span>
- <span>地址:{{takeSelfData[item.storeid][0].area + takeSelfData[item.storeid][0].detailAddress}}</span>
- <span>营业时间:{{takeSelfData[item.storeid][0].businesstime}}</span>
- </template>
- <template v-else>暂无自提点信息</template>
- </div>
- </div>
- </div>
- <div class=""></div>
- <div class="ps-operate-line">
- <span class="title">订单备注</span>
- <input type="text" v-model="item.remark" placeholder="选填:填写内容需和卖家协商确认">
- </div>
- <div class="ps-operate-line ps-price">
- <span class="inline-block text-ellipse">
- 运费:<span class="ol-price" v-if="item.fare"><span v-if="item.fare.fare > 0">{{item.fare.currencyName | currencyFilter}}</span>{{item.fare.fare || 0}}</span>
- </span>
- <span class="inline-block text-ellipse">
- 店铺合计:<span class="ol-price"><span>{{payData.currency | currencyFilter}}</span>{{item.goodsFarePrice || 0}}</span>
- </span>
- </div>
- </li>
- </ul>
- <div class="ps-operate-line pay-operate">
- <span class="title">支付方式</span>
- <div class="fr">
- <span>线下支付</span>
- <!--<i class="iconfont icon-xiangyou"></i>-->
- </div>
- </div>
- <div class="ps-operate-line pay-invoice" @click="openInvoiceModal">
- <span class="title">开具发票</span>
- <div class="fr">
- <div class="inline-block" :style="!selectedInvoice ? 'line-height: unset;' : ''">
- <template v-if="selectedInvoice">
- <span>{{selectedInvoice.head}}</span>
- <span>{{selectedInvoice.kind === 1205 ? '增值税专用发票' : '增值税普通发票'}}</span>
- </template>
- <template v-else>
- <span>暂不开具发票</span>
- </template>
- </div>
- <i class="iconfont icon-xiangyou"></i>
- </div>
- </div>
- <div class="buy-wrap">
- <div class="fr">
- <span class="title">实付:</span><span class="ol-price price inline-block text-ellipse"><span>{{payData.currency | currencyFilter}}</span>{{allOrderPrice}}</span>
- <button class="buy-btn" @click="confirmOrder">提交订单</button>
- </div>
- </div>
- <!-- 联系卖家弹框start -->
- <link-user :infoObj="currentStoreInfo"
- :showLink="showLink"
- @closeAction="showLink = false">
- </link-user>
- <!-- 联系卖家弹框end -->
- <!-- 产品清单弹框start -->
- <modal-wrapper :showModal="showModal"
- :title="'产品清单'"
- @closeAction="showModal = false">
- <ul class="cGoods-list">
- <li v-for="cGoods in currentGoods" class="clearfix">
- <div class="fl">
- <div class="cg-param-line text-ellipse">
- <span>品牌:</span>{{cGoods.brName}}
- </div>
- <div class="cg-param-line text-ellipse">
- <span>物料名称(类目):</span>{{cGoods.kiName}}
- </div>
- <div class="cg-param-line text-ellipse">
- <span>型号:</span>{{cGoods.cmpCode}}
- </div>
- <div class="cg-param-line text-ellipse">
- <span>规格:</span>{{cGoods.spec}}
- </div>
- </div>
- <div class="fr">
- <p class="ol-price text-ellipse"><span>{{cGoods.currencyName | currencyFilter}}</span>{{cGoods.taxUnitprice}}</p>
- <p class="count text-ellipse">x {{cGoods.number}}</p>
- </div>
- </li>
- </ul>
- </modal-wrapper>
- <!-- 产品清单弹框end -->
- <!-- 选择配送方式弹框start -->
- <bottom-modal-wrapper :showModal="showDeliveryModal"
- :title="'选择配送方式'"
- @closeAction="onDeliveryModalClose">
- <ul class="delivery-rule-list">
- <li v-for="cdr in fareRule[currentDeliveryStoreId]" @click="checkDelivery(cdr)">
- <label class="bottom-modal-check mobile-cart-check" :class="{'active': cdr.$checked}">
- <input type="checkbox">
- <span>{{cdr.method | deliveryRuleFilter}}</span>
- </label>
- <div class="fr" v-if="cdr.fare && cdr.fare > 0">运费:<span class="ol-price"><span>{{cdr.currencyName | currencyFilter}}</span>{{cdr.fare}}</span></div>
- </li>
- </ul>
- </bottom-modal-wrapper>
- <!-- 选择配送方式弹框end -->
- <!-- 选择发票弹框start -->
- <modal-wrapper :showModal="showInvoiceModal"
- :title="'选择发票'"
- @closeAction="showInvoiceModal = false">
- <ul class="invoice-list">
- <li @click="setInvoiceCheck(-1)">
- <label class="bottom-modal-check mobile-cart-check" :class="{active: selectedInvoiceIndex === -1}">
- <input type="checkbox">
- </label>
- <span class="inv-head">暂不开票</span>
- </li>
- <li v-for="(inv, index) in invoiceData" @click="setInvoiceCheck(index)">
- <label class="bottom-modal-check mobile-cart-check" :class="{'active': selectedInvoiceIndex === index}">
- <input type="checkbox">
- </label>
- <span class="inv-head inline-block text-ellipse">{{inv.head}}</span>
- <img class="inv-type" :src="`/images/mobile/center/user/${inv.kind === 1205 ? 'invoice-spec' : 'invoice-nor'}.png`" alt="">
- <div class="content-line" v-if="inv.kind === 1205">
- <div class="title inline-block">单位地址:</div>
- <div class="content inline-block">{{inv.companyAddress || '-'}}</div>
- </div>
- <div class="content-line" v-if="inv.kind === 1205">
- <div class="title inline-block">单位电话:</div>
- <div class="content inline-block">{{inv.companyPhone || '-'}}</div>
- </div>
- <div class="content-line" v-if="inv.kind === 1205">
- <div class="title inline-block">税务登记号:</div>
- <div class="content inline-block">{{inv.companyTaxNumber || '-'}}</div>
- </div>
- <div class="content-line" v-if="inv.kind === 1205">
- <div class="title inline-block">开户银行:</div>
- <div class="content inline-block">{{inv.bankName || '-'}}</div>
- </div>
- <div class="content-line" v-if="inv.kind === 1205">
- <div class="title inline-block">开户银行账户:</div>
- <div class="content inline-block">{{inv.bankAccount || '-'}}</div>
- </div>
- <div class="content-line">
- <div class="title inline-block">收票人:</div>
- <div class="content inline-block">{{inv.name || '-'}}</div>
- </div>
- <div class="content-line">
- <div class="title inline-block">联系电话:</div>
- <div class="content inline-block">{{inv.telephone || '-'}}</div>
- </div>
- <div class="content-line">
- <div class="title inline-block">详细地址:</div>
- <div class="content inline-block">{{inv.area + inv.detailAddress}}</div>
- </div>
- </li>
- </ul>
- </modal-wrapper>
- <!-- 选择发票弹框end -->
- <!-- 选择地址弹框start -->
- <modal-wrapper :showModal="showAddrModal"
- :title="'收货地址'"
- @closeAction="showAddrModal = false">
- <ul class="addr-list">
- <li v-for="(addr, index) in addressData" :class="{active: selectedAddressIndex === index}" @click="setAddressCheck(index)">
- <div class="info-line">
- <label class="mobile-cart-check" :class="{active: selectedAddressIndex === index}">
- <input type="checkbox">
- </label>
- <span class="name inline-block text-ellipse">{{addr.name}}</span>
- <span class="tel inline-block text-ellipse">{{addr.tel}}</span>
- <i class="inline-block" v-if="addr.num === 1">默认地址</i>
- </div>
- <p>{{addr.area + addr.detailAddress}}</p>
- </li>
- </ul>
- </modal-wrapper>
- <!-- 选择地址弹框end -->
- <!-- 选择自提点弹框start -->
- <modal-wrapper :showModal="showTakeSelfModal"
- :title="'选择自提点'"
- @closeAction="showTakeSelfModal = false">
- <ul class="addr-list takeself-list">
- <li v-for="(takeself, index) in takeSelfData[currentTakeSelfStoreId]" @click="checkTakeSelf(index)" :class="{active: index === 0}">
- <div class="info-line">
- <label class="mobile-cart-check" :class="{active: index === 0}">
- <input type="checkbox">
- </label>
- <span class="name inline-block text-ellipse">{{takeself.takename}}</span>
- </div>
- <p><span>地址:</span>{{takeself.area + takeself.detailAddress}}</p>
- <p><span>营业时间:</span>{{takeself.businesstime}}</p>
- </li>
- </ul>
- </modal-wrapper>
- <!-- 选择自提点弹框end -->
- <remind-box :title="remindText" :timeoutCount="timeoutCount"></remind-box>
- </div>
- </template>
- <script>
- import { LinkUser, ModalWrapper, BottomModalWrapper } from '~components/mobile/base'
- import { RemindBox } from '~components/mobile/common'
- export default {
- layout: 'mobile',
- middleware: 'authenticated',
- data () {
- return {
- orderData: [],
- // 联系卖家店铺信息
- currentStoreInfo: {},
- showLink: false,
- showModal: false,
- showDeliveryModal: false,
- showInvoiceModal: false,
- showAddrModal: false,
- showTakeSelfModal: false,
- currentGoods: [],
- remindText: '',
- timeoutCount: '',
- // 配送规则
- fareRule: {},
- // 自提点
- takeSelfData: {},
- // 正在修改配送方式的店铺id
- currentDeliveryStoreId: '',
- // 订单总价
- allOrderPrice: 0,
- // 选中的发票
- selectedInvoiceIndex: -1,
- // 选中的地址
- selectedAddressIndex: 0,
- // 正在修改自提点的店铺id
- currentTakeSelfStoreId: ''
- }
- },
- components: {
- LinkUser,
- ModalWrapper,
- RemindBox,
- BottomModalWrapper
- },
- fetch ({ store, params }) {
- return Promise.all([
- store.dispatch('userCenter/loadPayInfo', {enOrderid: params.orderId}),
- store.dispatch('userCenter/loadAcceptAddress', {send: false}),
- store.dispatch('userCenter/loadPayInvoice')
- ])
- },
- // watch: {
- // '$store.state.userCenter.list.invoice.data': {
- // handler: function (val) {
- // this.invoiceData = this.baseUtils.deepCopy(val)
- // if (this.invoiceData && this.invoiceData.length) {
- // this.invoiceData.forEach(item => {
- // this.$set(item, '$checked', false)
- // })
- // }
- // },
- // immediate: true
- // }
- // },
- computed: {
- payData () {
- // // 人民币为专用增值税发票,美元不开发票 --1205专用增值税发票 --1206普通发票 --1207不开发票
- // let invoices = this.baseUtils.deepCopy(this.$store.state.userCenter.list.pay.data)
- // if (invoices.currency === 'USD') {
- // invoices.invoicetype = 1207
- // invoices.paytype = '1103'
- // } else {
- // invoices.invoicetype = 1205
- // invoices.paytype = '1102'
- // }
- // // 默认选择第三方配送 --1301第三方配送 --卖家配送 --1303上门自提
- // invoices.deliverytype = 1301
- // return invoices
- return this.$store.state.userCenter.list.pay.data
- },
- addressData () {
- return this.$store.state.userCenter.list.address.data
- },
- invoiceData () {
- return this.$store.state.userCenter.list.invoice.data
- },
- // 已选择完的发票
- selectedInvoice () {
- return this.selectedInvoiceIndex > -1 ? this.invoiceData[this.selectedInvoiceIndex] : null
- },
- // // 选择中选中的发票
- // checkedInvoiceObj () {
- // return this.invoiceData.find(item => {
- // return item.$checked
- // })
- // },
- selectedAddress () {
- // console.log(this.addressData[this.selectedAddressIndex])
- return this.addressData[this.selectedAddressIndex] || {}
- },
- ruleParamsArr () {
- let arr = []
- this.orderData.forEach(item => {
- item.goodsPrice = this.getTotalPrice(item)
- arr.push({
- uuid: item.storeid,
- fare: this.getTotalPrice(item)
- })
- })
- return arr
- }
- // // 选择自提点的列表统计
- // showTakeSelfList () {
- // let arr = {}
- // if (!this.showDeliveryModal || !this.showTakeSelfModal) { // 为了触发更新
- // for (let attr in this.fareRule) {
- // arr[attr] = this.fareRule[attr][0] && this.fareRule[attr][0].method === 1303
- // }
- // }
- // return arr
- // }
- // defaultAddress () {
- // return this.addressData.find(item => {
- // return item.num === 1
- // })
- // }
- },
- created () {
- this.initOrderData()
- },
- methods: {
- initOrderData () {
- this.payData.orderDetails.forEach(item => {
- let current = this.orderData.find(objItem => {
- return objItem.storeid === item.storeid
- })
- if (!current) {
- this.orderData.push({
- storeName: item.storeName,
- storeid: item.storeid,
- supEnUU: item.supEnUU,
- goods: [item]
- })
- } else {
- current.goods.push(item)
- }
- })
- this.getDeliveryRule()
- this.getTakeSelfInfo()
- },
- getDeliveryRule () {
- return this.$http.post(`/trade/distributionRule/usable/rule?area=${this.selectedAddress.area}`, this.ruleParamsArr)
- .then(res => {
- this.fareRule = res.data || {}
- this.initFare()
- }, err => {
- this.setRemindText(err.response.data || '系统错误')
- })
- },
- getTakeSelfInfo () {
- return this.$http.post(`/trade/takeSelf/store/takeSelf`, this.ruleParamsArr)
- .then(res => {
- this.takeSelfData = res.data || {}
- }, err => {
- this.setRemindText(err.response.data || '系统错误')
- })
- },
- initFare () {
- this.allOrderPrice = 0
- this.orderData.forEach(item => {
- item.fare = this.fareRule[item.storeid] && this.fareRule[item.storeid].length ? this.fareRule[item.storeid][0] : {}
- item.goodsPrice = this.getTotalPrice(item) // 总价
- // 包含运费的价格
- item.goodsFarePrice = this.baseUtils.priceFixed(item.goodsPrice + (item.fare && item.fare.fare ? item.fare.fare : 0))
- this.allOrderPrice += item.goodsFarePrice
- })
- },
- getTotalPrice (storeItem) {
- let price = 0
- storeItem.goods.forEach(item => {
- price += item.price
- })
- return Number(price.toFixed(6))
- },
- linkSaler (item) {
- this.$http.get(`/basic/enterprise/${item.supEnUU}/info`).then(res => {
- this.currentStoreInfo = res.data
- this.showLink = true
- }, err => {
- this.setRemindText(err.response.data || '系统错误')
- console.log(err)
- })
- },
- showDetailList (goods) {
- this.currentGoods = goods
- this.showModal = true
- },
- goodsScroll (type) {
- console.log(type)
- },
- setRemindText: function (str) {
- this.remindText = str
- this.timeoutCount++
- },
- checkShowTakeSelf (item) {
- return item.fare && item.fare.method === 1303
- },
- // 显示配送规则弹框
- showRuleSet: function (storeid) {
- if (this.fareRule[storeid] && this.fareRule[storeid].length) {
- this.currentDeliveryStoreId = storeid
- this.clearCurrentDeliveryCheck()
- this.fareRule[this.currentDeliveryStoreId][0].$checked = true
- this.showDeliveryModal = true
- }
- // console.log(storeid)
- },
- clearCurrentDeliveryCheck () {
- this.fareRule[this.currentDeliveryStoreId].forEach(item => {
- if (!item.hasOwnProperty('$checked')) {
- this.$set(item, '$checked', false)
- } else {
- item.$checked = false
- }
- })
- },
- checkDelivery (cdr) {
- if (!cdr.$checked) {
- this.clearCurrentDeliveryCheck()
- cdr.$checked = true
- }
- },
- onDeliveryModalClose (isSubmit) {
- if (!isSubmit) {
- this.showDeliveryModal = false
- // this.currentDeliveryRule = {}
- } else {
- let currentDi = this.fareRule[this.currentDeliveryStoreId]
- for (let i = 0; i < currentDi.length; i++) {
- if (currentDi[i].$checked) {
- this.baseUtils.exchangeArr(currentDi, i, 0)
- break
- }
- }
- this.initFare()
- this.showDeliveryModal = false
- }
- },
- // 显示自提点弹框
- showTakeSelfSet (storeid) {
- if (this.takeSelfData[storeid] && this.takeSelfData[storeid].length) {
- this.currentTakeSelfStoreId = storeid
- this.showTakeSelfModal = true
- }
- },
- checkTakeSelf (index) {
- // for (let i = 0; i < this.takeSelfData[this.currentTakeSelfStoreId].length; i++) {
- // if (item.id === this.takeSelfData[this.currentTakeSelfStoreId][i].id) {
- //
- // break
- // }
- // }
- if (index > 0) {
- this.baseUtils.exchangeArr(this.takeSelfData[this.currentTakeSelfStoreId], index, 0)
- }
- this.showTakeSelfModal = false
- },
- setInvoiceCheck (index) {
- if (this.selectedInvoiceIndex === index) {
- return
- }
- this.selectedInvoiceIndex = index
- this.showInvoiceModal = false
- },
- openInvoiceModal () {
- if (this.invoiceData && this.invoiceData.length) {
- this.showInvoiceModal = true
- } else {
- this.setRemindText('暂无发票信息,请前往pc端维护')
- }
- },
- setAddressCheck (index) {
- if (this.selectedAddressIndex === index) {
- return
- }
- this.selectedAddressIndex = index
- this.showAddrModal = false
- this.getDeliveryRule()
- },
- openAddrModal () {
- if (this.addressData && this.addressData.length) {
- this.showAddrModal = true
- } else {
- this.setRemindText('暂无收货地址,请前往pc端维护')
- }
- },
- // 配送规则校验
- checkRule () {
- let flag = true
- for (let attr in this.fareRule) {
- if (!this.fareRule[attr].length) {
- flag = false
- }
- }
- return flag
- },
- // 收货地址校验
- checkAddress () {
- if (!this.selectedAddress || !this.selectedAddress.id) {
- this.setRemindText('收货地址信息为空,请前往pc端添加收货地址')
- return false
- } else if (this.selectedAddress.area.indexOf('香港') > -1) {
- if (this.payData.currency === 'RMB') {
- this.setRemindText('当前选择的币别是RMB,地址却是香港')
- return false
- }
- } else {
- if (this.payData.currency === 'USD') {
- this.setRemindText('当前选择的币别是USD,地址却是内陆')
- return false
- }
- }
- return true
- },
- // 提交订单流程
- confirmOrder () {
- if (this.accountInvalid) {
- this.setRemindText('您的账户安全等级较低,请先在pc端进行信息完善')
- } else {
- if (this.payData.status === 502 || this.payData.status === 503) {
- this.underLinePaySubmitted()
- } else {
- if (!this.checkRule()) {
- this.setRemindText('当前地址部分卖家无法配送,请重新选择地址或与卖家协商处理')
- } else {
- let infos = []
- let info = this.generateOrderInfo()
- if (info) {
- infos.push(info)
- this.doSubmit(infos)
- }
- }
- }
- }
- },
- // 待付款订单-线下付款
- underLinePaySubmitted () {
- let arr = []
- if (this.payData.orderids) {
- arr = this.payData.orderids.split(',')
- } else {
- arr.push(this.payData.orderid)
- }
- let param = {
- orderid: this.baseUtils.enidfilter(arr.join('-'))
- }
- console.log(param)
- // 跳转至付款页面
- console.log('订单已存在,直接跳转至付款页面')
- this.$router.push(`/mobile/center/user/doPay/${encodeURIComponent(param.orderid)}`)
- return param
- },
- // 处理订单数据
- generateOrderInfo () {
- let orderInfo = {
- id: this.payData.id,
- orderid: this.payData.orderid
- }
- if (this.payData.currency === 'USD' && this.selectedInvoiceIndex !== -1) {
- this.setRemindText('美元请选择暂不开票')
- return false
- }
- if (this.checkAddress()) {
- orderInfo.add_id = this.selectedAddress.id
- } else {
- return false
- }
- let submitParam = this.orderSubmitParams()
- // 发票信息
- if (this.selectedInvoice) {
- if (this.selectedInvoice.kind === 1205) {
- orderInfo.invoicetype = '1205'
- } else if (this.selectedInvoice.kind === 1206) {
- if (submitParam.includeConsignment) {
- this.setRemindText('订单中包含寄售类型商品,请选择专票')
- return false
- }
- orderInfo.invoicetype = '1206'
- }
- if (this.selectedInvoice.id) {
- orderInfo.invoiceid = this.selectedInvoice.id
- } else {
- this.setRemindText('请添加发票信息')
- return false
- }
- } else {
- orderInfo.invoicetype = '1207'
- }
- orderInfo.totalprice = submitParam.goodsPrice
- orderInfo.currency = this.payData.currency
- orderInfo.orderRemark = JSON.stringify(submitParam.remarkObj)
- // 1103线下 1102线上
- orderInfo.paytype = '1103'
- orderInfo.splitInfo = {
- ruleList: JSON.stringify(submitParam.ruleList),
- takeList: JSON.stringify(submitParam.takeList)
- }
- orderInfo.orderDetails = this.convertOrderDetailParams()
- console.log(orderInfo)
- return orderInfo
- // 人民币为专用增值税发票,美元不开发票 --1205专用增值税发票 --1206普通发票 --1207不开发票
- // 默认选择第三方配送 --1301第三方配送 --卖家配送 --1303上门自提
- },
- // 订单提交的参数整合
- orderSubmitParams () {
- let params = {
- // 不包含运费的价格
- goodsPrice: 0,
- // 备注
- remarkObj: {},
- // 配送方式
- ruleList: {},
- // 自提点
- takeList: {},
- // 是否包含寄售商品
- includeConsignment: false
- }
- this.orderData.forEach(item => {
- params.goodsPrice += item.goodsPrice
- params.remarkObj[item.storeid] = item.remark
- params.ruleList[item.storeid] = item.fare
- params.takeList[item.storeid] = this.checkShowTakeSelf(item) && this.takeSelfData[item.storeid] ? [0] : null
- if (item.storeid === '33069557578d44e69bd91ad12d28a8d4') {
- params.includeConsignment = true
- }
- })
- return params
- },
- // 提取要提交到服务器的订单明细goods数据
- convertOrderDetailParams () {
- let orderDetails = []
- this.payData.orderDetails.forEach(item => {
- orderDetails.push({
- id: item.id,
- number: item.number,
- taxUnitprice: item.taxUnitprice,
- remark: item.remark,
- goodsnumber: item.goodsnumber,
- storeid: item.storeid
- })
- })
- return orderDetails
- },
- // 提交订单请求
- doSubmit (orders) {
- this.$http.put(`/trade/order/${this.baseUtils.enidfilter(this.payData.orderid)}/ensure`, orders)
- .then(res => {
- console.log(res)
- if (res.data.code === 1) {
- if (res.data.data && res.data.data[0]) {
- let orderids = []
- let batchCodes = []
- for (let i = 0; i < res.data.data.length; i++) {
- orderids.push(res.data.data[i].orderid)
- for (let j = 0; j < res.data.data[i].orderDetails.length; j++) {
- batchCodes.push(res.data.data[i].orderDetails[j].batchCode)
- }
- }
- // 如果不是立即购买,删除购物车里的对应信息
- if (!this.payData.buyNow) {
- this.$http.put('/trade/cart/delete', batchCodes)
- }
- // 跳转至订单提交完成页面
- console.log('订单提交完成,跳转至结果页')
- this.$router.push(`/mobile/center/user/doPay/${encodeURIComponent(this.baseUtils.enidfilter(orderids.join('-')))}`)
- }
- } else {
- if (res.data.data.code === 6) {
- this.setRemindText(res.data.message + ',请刷新界面之后重新操作')
- } else if (res.data.data.code === 7) {
- this.setRemindText(res.data.message + ',将为您跳转到购物车界面')
- setTimeout(() => {
- this.$router.push('/mobile/center/user/cart')
- }, 1500)
- } else {
- this.setRemindText(res.data.message)
- }
- }
- }, err => {
- console.log(err)
- this.setRemindText(err.response.data || '提交订单失败')
- })
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- $red-text: #f43938;
- .mobile-pay {
- margin-bottom: 2.02rem;
- .pay-head {
- height: 1.3rem;
- padding: .25rem 0 0 .21rem;
- position: relative;
- border-bottom: .18rem solid #f1f3f7;
- background: url('/images/mobile/center/user/addr-border.png') no-repeat;
- background-size: contain;
- background-position: bottom;
- .info {
- padding-left: .43rem;
- font-size: .3rem;
- font-weight: bold;
- }
- .addr {
- width: 6.5rem;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- img {
- height: .29rem;
- margin-right: .16rem;
- }
- span {
- font-size: .26rem;
- }
- }
- .icon-xiangyou {
- position: absolute;
- right: .21rem;
- top: .52rem;
- color: #bebebe;
- }
- .no-addr {
- margin-top: .15rem;
- text-align: center;
- padding-right: .21rem;
- }
- }
- .pay-store-list {
- .ps-item {
- border-bottom: .18rem solid #f1f3f7;
- .ps-store-name {
- height: .89rem;
- line-height: .89rem;
- padding: 0 .25rem;
- font-size: .28rem;
- text-align: left;
- }
- .ps-goods-info {
- background: #f0f0f0;
- .fl {
- padding: 0 .29rem 0 .1rem;
- position: relative;
- .ps-goods-list {
- width: 4.5rem;
- height: 100%;
- padding: .22rem 0;
- overflow-x: auto;
- white-space: nowrap;
- li {
- border-right: 1px solid #969696;
- .ps-goods-item {
- width: 2.25rem;
- padding-left: .12rem;
- font-size: .24rem;
- &.pg-item-long {
- width: 4.5rem;
- }
- span {
- color: #666;
- }
- }
- }
- }
- .arrow {
- position: absolute;
- height: 100%;
- color: #666;
- background: #dfdfdf;
- padding-top: .66rem;
- top: 0;
- &:first-child {
- left: 0;
- }
- &:last-child {
- right: 0;
- }
- }
- }
- .fr {
- width: 2.6rem;
- text-align: center;
- .price {
- color: #f43938;
- font-size: .32rem;
- margin-top: .44rem;
- padding-right: .05rem;
- span {
- font-size: .24rem;
- }
- }
- .count {
- font-size: .28rem;
- font-weight: bold;
- margin-top: .2rem;
- }
- }
- }
- }
- }
- .ps-operate-line {
- height: .89rem;
- line-height: .89rem;
- padding: 0 .21rem 0 .25rem;
- border-bottom: 1px solid #e4e4e4;
- font-size: .28rem;
- .fr {
- height: 100%;
- .inline-block {
- line-height: normal;
- text-align: right;
- span {
- font-size: .27rem;
- color: #666;
- &:first-child {
- color: #333;
- font-weight: bold;
- display: block;
- }
- &.red {
- color: $red-text;
- }
- }
- }
- i {
- color: #bebebe;
- margin-left: .14rem;
- }
- }
- input {
- width: 4.78rem;
- margin-left: .68rem;
- padding: 0 .1rem;
- height: .45rem;
- }
- &.ps-price {
- text-align: right;
- padding-right: .31rem;
- .inline-block {
- font-size: .26rem;
- max-width: 64%;
- &:first-child {
- max-width: 32%;
- margin-right: .18rem;
- }
- }
- }
- &.pay-operate {
- border-bottom: .11rem solid #f1f3f7;
- padding-top: 0;
- .fr {
- line-height: .78rem;
- i {
- position: static;
- }
- span {
- color: #333;
- font-size: .28rem;
- }
- }
- }
- &.pay-invoice {
- border-bottom: .11rem solid #f1f3f7;
- .fr {
- padding-top: 0;
- .inline-block {
- vertical-align: top;
- }
- i {
- float: right;
- }
- span {
- font-size: .28rem;
- color: #333;
- font-weight: normal !important;
- max-width: 5rem;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- }
- }
- }
- &.ps-operate-takeself {
- height: 1.35rem;
- line-height: 1.35rem;
- .fr {
- span {
- display: block;
- max-width: 5.5rem;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- }
- }
- }
- }
- .ol-price {
- color: #f43938;
- font-size: .32rem;
- span {
- font-size: .24rem;
- }
- }
- .buy-wrap {
- position: fixed;
- bottom: .98rem;
- height: 1.02rem;
- line-height: 1.02rem;
- padding-left: .27rem;
- background: #fff;
- width: 100%;
- border-top: .02rem solid #ccc;
- .fr {
- .title {
- font-size: .28rem;
- margin-right: .13rem;
- }
- .price {
- max-width: 3.6rem;
- vertical-align: top;
- span {
- margin-right: .08rem;
- }
- margin-right: .13rem;
- }
- .buy-btn {
- width: 2.08rem;
- height: 1.02rem;
- line-height: 1.02rem;
- text-align: center;
- font-size: .28rem;
- color: #fff;
- background: #fc2706;
- }
- }
- }
- .cGoods-list {
- background: #fff;
- li {
- padding: .3rem .32rem;
- border-bottom: 1px solid #e4e4e4;
- .fl {
- .cg-param-line {
- width: 3.65rem;
- margin-bottom: .23rem;
- &:last-child {
- margin-bottom: 0;
- }
- font-size: .28rem;
- span {
- color: #666;
- }
- }
- }
- .fr {
- text-align: right;
- p {
- width: 2.3rem;
- }
- .ol-price {
- margin-top: .59rem;
- }
- .count {
- color: #999;
- font-size: .24rem;
- margin-top: .32rem;
- }
- }
- }
- }
- .delivery-rule-list {
- li {
- background: #fff;
- text-align: left;
- padding: 0 .31rem 0 .25rem;
- height: .94rem;
- line-height: .94rem;
- .fr {
- height: 100%;
- .ol-price {
- margin-left: .23rem;
- }
- }
- }
- }
- .invoice-list {
- background: #f1f3f7;
- padding: .19rem 0;
- li {
- margin-bottom: .19rem;
- position: relative;
- &:last-child {
- margin-bottom: 0;
- }
- background: #fff;
- padding: .26rem .16rem .32rem .25rem;
- .inv-head {
- margin-left: .17rem;
- max-width: 5.3rem;
- }
- .inv-type {
- position: absolute;
- right: 0;
- top: 0;
- height: .85rem;
- }
- .content-line {
- margin-top: .23rem;
- padding-left: .53rem;
- .title {
- width: 34%;
- text-align: right;
- vertical-align: top;
- }
- .content {
- width: 66%;
- word-break: break-all;
- }
- }
- }
- }
- .addr-list {
- background: #f1f3f7;
- padding: .19rem 0;
- li {
- margin-bottom: .19rem;
- position: relative;
- &:last-child {
- margin-bottom: 0;
- }
- background: #fff;
- padding: .35rem .25rem .28rem;
- .info-line {
- font-size: .3rem;
- color: #666;
- .name {
- margin: 0 .27rem 0 .17rem;
- max-width: 1.5rem;
- }
- .tel {
- max-width: 2.3rem;
- }
- i {
- width: 1.08rem;
- height: .25rem;
- line-height: .25rem;
- font-size: .24rem;
- text-align: center;
- border: 1px solid #fc2706;
- border-radius: .04rem;
- color: #f43938;
- font-style: normal;
- margin-left: .48rem;
- }
- }
- p {
- margin-top: .19rem;
- word-break: break-all;
- padding-left: .54rem;
- font-size: .28rem;
- color: #999;
- }
- &.active {
- .info-line {
- color: #f43938;
- }
- p {
- color: #666;
- }
- }
- }
- }
- .takeself-list {
- li {
- .info-line {
- .name {
- max-width: 5.3rem;
- }
- }
- }
- }
- }
- </style>
|