12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427 |
- <template>
- <view :style="viewColor">
- <view class='my-order' :style="{'padding-top':statusBarHeight+'px'}">
- <view class="searchBox">
- <image src="../../../static/images/arrow-left.png" mode="" @click="toBack"></image>
- <navigator class="search acea-row row-middle" url="/pages/users/order_list/search" hover-class="none">
- <text class="iconfont icon-sousuo"></text>
- 搜索我的订单
- </navigator>
- </view>
- <view class='header'>
- <view class='picTxt acea-row row-between-wrapper'>
- <view class='text'>
- <view class='name'>消费订单</view>
- <view class="textValue"><text>{{orderData.orderCount || 0}}</text>单</view>
- </view>
- <view class='text'>
- <view class='name'>总消费</view>
- <view class="textValue"><text>{{orderData.orderPrice || 0}}</text>元</view>
- </view>
- <!-- <view class='pictrue'>
- <image src='/static/images/orderTime.png'></image>
- </view> -->
- </view>
- </view>
- <view class='nav acea-row row-around'>
- <view class='item' :class='orderStatus==-1 ? "on": ""' @click="statusClick(-1)">
- <view>全部</view>
- </view>
- <view class='item' :class='orderStatus==5 ? "on": ""' @click="statusClick(5)">
- <view>百分比付款</view>
- </view>
- <view class='item' :class='orderStatus==0 ? "on": ""' @click="statusClick(0)">
- <view>待付款</view>
- </view>
- <view class='item' :class='orderStatus==6 ? "on": ""' @click="statusClick(6)">
- <view>已超时</view>
- </view>
- <view class='item' :class='orderStatus==1 ? "on": ""' @click="statusClick(1)">
- <view>待发货</view>
- </view>
- <view class='item' :class='orderStatus==2 ? "on": ""' @click="statusClick(2)">
- <view>待收货</view>
- </view>
- <view class='item' :class='orderStatus==3 ? "on": ""' @click="statusClick(3)">
- <view>待评价</view>
- </view>
- </view>
- <!-- <view class='nav acea-row row-around'>
- <view class='item' :class='orderStatus==-1 ? "on": ""' @click="statusClick(-1)">
- <view>全部</view>
- <view class='num'>{{orderData.all || 0}}</view>
- </view>
- <view class='item' :class='orderStatus==0 ? "on": ""' @click="statusClick(0)">
- <view>待付款</view>
- <view class='num'>{{orderData.noPay || 0}}</view>
- </view>
- <view class='item' :class='orderStatus==1 ? "on": ""' @click="statusClick(1)">
- <view>待发货</view>
- <view class='num'>{{orderData.noPostage || 0}}</view>
- </view>
- <view class='item' :class='orderStatus==2 ? "on": ""' @click="statusClick(2)">
- <view>待收货</view>
- <view class='num '>{{orderData.noDeliver || 0}}</view>
- </view>
- <view class='item' :class='orderStatus==3 ? "on": ""' @click="statusClick(3)">
- <view>待评价</view>
- <view class='num'>{{orderData.noComment || 0}}</view>
- </view>
- </view> -->
- <!--定金预售订单-->
- <view v-if="presellProList.length > 0" class="event_container">
- <navigator class="acea-row row-between" url="/pages/users/presell_order_list/index" hover-class='none'>
- <view class="info">
- <view class="title">预售尾款订单转到这里了!</view>
- <view class="desc">有 <text class="t-color">{{ presellOrderCount }}</text> 笔预售尾款订单待付款,请点击查看
- </view>
- </view>
- <view class="photo acea-row row-between">
- <view class='picture'>
- <image
- :src='(presellProList[0].orderProduct[0].cart_info.productAttr && presellProList[0].orderProduct[0].cart_info.productAttr.image) || presellProList[0].orderProduct[0].cart_info.product.image'>
- </image>
- </view>
- <view class="more_btn"><text class="iconfont icon-gengduo3"></text></view>
- </view>
- </navigator>
- </view>
- <view class='list'>
- <!-- 代付款 -->
- <view v-if="orderList.length > 0">
- <block v-if="orderStatus == 0">
- <view class='item' v-for="(item,index) in orderList" :key="index">
- <view @click='goOrderDetails(item.group_order_id)'>
- <view class='title acea-row row-between-wrapper'>
- <view class="acea-row row-middle left-wrapper">
- {{item.group_order_sn}}
- </view>
- <view class='t-color'>
- {{ item.orderList[0].activity_type === 2 && item.orderList[0].orderProduct[0].cart_info.productPresell.presell_type ==2 ? "待付定金" : "待付款" }}
- </view>
- </view>
- <view v-for="(order,j) in item.orderList" :key="order.order_id+j">
- <!--预售-->
- <view v-if="order.activity_type === 2">
- <block v-for="(goods,g) in order.orderProduct">
- <view class='item-info acea-row row-between row-top'>
- <view class='pictrue'>
- <image
- :src='(goods.cart_info.productAttr && goods.cart_info.productAttr.image) || goods.cart_info.product.image'>
- </image>
- </view>
- <view class='text acea-row row-between'>
- <view class='name line1'>
- <text
- class="event_name event_bg">预售</text><text>{{goods.cart_info.product.store_name}}</text>
- <view class="event_ship event_color">发货时间:
- <!--全款预售-->
- <text
- v-if="goods.cart_info.productPresell.presell_type === 1">
- {{ goods.cart_info.productPresell.delivery_type === 1 ? '支付成功后' : '预售结束后' }}{{ goods.cart_info.productPresell.delivery_day }}天内
- </text>
- <!--定金预售-->
- <text
- v-if="goods.cart_info.productPresell.presell_type === 2">{{ goods.cart_info.productPresell.delivery_type === 1 ? '支付尾款后' : '预售结束后' }}{{ goods.cart_info.productPresell.delivery_day }}天内</text>
- </view>
- </view>
- <view class='money'>
- <view>¥{{goods.cart_info.productPresellAttr.presell_price}}
- </view>
- <view>x{{goods.product_num}}</view>
- </view>
- </view>
- <view v-if="goods.cart_info.productPresell.presell_type === 2"
- class="event_price">
- 定金待支付 <text class="t-color">¥{{ order.pay_price }}</text>
- 尾款待支付 <text
- class="t-color">¥{{ order.presellOrder.pay_price }}</text>
- </view>
- </view>
- </block>
- </view>
- <view v-else>
- <block v-for="(goods,g) in order.orderProduct">
- <view class='item-info acea-row row-between row-top'>
- <view class='pictrue'>
- <image
- :src='(goods.cart_info.productAttr && goods.cart_info.productAttr.image) || goods.cart_info.product.image'>
- </image>
- </view>
- <view class='text acea-row row-between'>
- <view class='name line2'>{{goods.cart_info.product.store_name}}
- </view>
- <view class='money' v-if="item.orderList[0].activity_type == 4">
- <view v-if="goods.cart_info.activeSku">
- ¥{{goods.cart_info.activeSku.active_price}}</view>
- <view>x{{goods.product_num}}</view>
- </view>
- <view v-else class='money'>
- <view>¥{{goods.cart_info.productAttr.price}}</view>
- <view>x{{goods.product_num}}</view>
- </view>
- </view>
- </view>
- </block>
- </view>
- </view>
- <view class="percentage">
- <view class="percentage_left" v-show="item.is_percentage==1">
- <view class="textBox">
- <text class="text1">百分比</text>
- <view class="text2">
- <text class="pay">付款</text>
- </view>
- </view>
- <view class="percentageTltle">
- 按{{100-item.residue_percentage}}%付款
- </view>
- </view>
- <view class='totalPrice' style="flex: 1;"
- v-if="item.orderList[0].activity_type !== 2">
- 共{{item.total_num || 0}}件商品,<text>{{item.is_percentage==1&&item.orderList[0].activity_type ==0?'首付款':'总金额'}}</text>
- <text class='money p-color'>¥{{item.pay_price}}</text>
- </view>
- </view>
- <view class='totalPrice' style="flex: 1;" v-show="orderStatus==5">
- 最晚付款时间:{{item.expire_time}}
- </view>
- <view class="fenxiao bottom">
- <view class="" style="display: flex;align-items: center;" @click.stop="toPurchase"
- v-show="orderStatus==5">
- <text>分销拓展抵扣详情</text>
- <text class='bnt b-color' style="margin-left: 20rpx;">分享</text>
- </view>
- <view class="" v-show="orderStatus!=5">
- </view>
- <view class='bottom acea-row row-right row-middle'>
- <view class='bnt b-color'
- @click.stop='goPay(item.pay_price,item.group_order_id)'>
- 惠拓购付款</view>
- </view>
- </view>
- </view>
- </view>
- </block>
- <!-- 待发货 待收货 待评价 已完成 -->
- <block v-else>
- <view class='item' v-for="(item,index) in orderList" :key="index">
- <view @click='goOrderDetails(item.order_id)'>
- <view class='title acea-row row-between-wrapper'>
- <view class="acea-row row-middle left-wrapper" @click.stop="goMall(item)">
- <text class="iconfont icon-shangjiadingdan"></text>
- <view class="store-name">{{item.merchant.mer_name}}</view>
- <text class="iconfont icon-xiangyou"></text>
- </view>
- <view v-if="item.status == 0" class='t-color'>
- <text
- v-if="item.order_type==1">{{item.takeOrderCount > 0 ? '部分核销' : '待核销'}}</text>
- <text v-else>待发货</text>
- </view>
- <view v-if="item.status == 1" class='t-color'>待收货</view>
- <view v-if="item.status == 2" class='t-color'>待评价</view>
- <view v-if="item.status == 3" class='t-color'>已完成</view>
- <view v-if="item.status == -1" class='t-color'>已退款</view>
- </view>
- <view v-if="item.activity_type === 2">
- <view class='item-info acea-row row-between row-top'
- v-for="(goods,index) in item.orderProduct" :key="index">
- <view class='pictrue'>
- <image
- :src='(goods.cart_info.productAttr && goods.cart_info.productAttr.image) || goods.cart_info.product.image'>
- </image>
- </view>
- <view class='text acea-row row-between'>
- <view class='name '>
- <view class='name' :class="item.status === 0 ? 'line1' : 'line2'">
- <text
- class="event_name event_bg">预售</text><text>{{goods.cart_info.product.store_name}}</text>
- <view v-if="item.status == 0" class="event_ship event_color">发货时间:
- <!--全款预售-->
- <text
- v-if="goods.cart_info.productPresell.presell_type === 1">{{ goods.cart_info.productPresell.delivery_type === 1 ? '支付成功后' : '预售结束后' }}{{ goods.cart_info.productPresell.delivery_day }}天内</text>
- <!--定金预售-->
- <text
- v-if="goods.cart_info.productPresell.presell_type === 2">{{ goods.cart_info.productPresell.delivery_type === 1 ? '支付尾款后' : '预售结束后' }}{{ goods.cart_info.productPresell.delivery_day }}天内</text>
- </view>
- </view>
- <view style="margin-top: 10rpx;" class="t-color">
- {{goods.is_refund==1?'退款中':goods.is_refund==2?'部分退款':goods.is_refund==3?'全部退款':''}}
- </view>
- </view>
- <view class='money'>
- <view>¥{{goods.cart_info.productPresellAttr.presell_price}}</view>
- <view>x{{goods.product_num}}</view>
- </view>
- </view>
- </view>
- </view>
- <view v-else>
- <view class='item-info acea-row row-between row-top'
- v-for="(goods,index) in item.orderProduct" :key="index">
- <view class='pictrue'>
- <image
- :src='(goods.cart_info.productAttr && goods.cart_info.productAttr.image) || goods.cart_info.product.image'>
- </image>
- </view>
- <view class='text acea-row row-between'>
- <view class='name '>
- <view class='name line2'>
- <text>{{goods.cart_info.product.store_name}}</text>
- </view>
- <view style="margin-top: 10rpx;" class="t-color">
- {{goods.is_refund==1?'退款中':goods.is_refund==2?'部分退款':goods.is_refund==3?'全部退款':''}}
- </view>
- </view>
- <view class='money' v-if="item.activity_type == 3">
- <view v-if="goods.cart_info.productAssistAttr">
- ¥{{goods.cart_info.productAssistAttr.assist_price}}</view>
- <view>x{{goods.product_num}}</view>
- </view>
- <view class='money' v-else-if="item.activity_type == 4">
- <view v-if="goods.cart_info.activeSku">
- ¥{{goods.cart_info.activeSku.active_price}}</view>
- <view>x{{goods.product_num}}</view>
- </view>
- <view class='money' v-else>
- <view>¥{{goods.cart_info.productAttr.price}}</view>
- <view>x{{goods.product_num}}</view>
- </view>
- </view>
- </view>
- </view>
- <view class='totalPrice' v-if="item.activity_type == 2">共{{item.orderNum || 0}}件商品,总金额
- <text class='money p-color'>¥{{item.presell_price}}</text>
- </view>
- <!-- <view class='totalPrice' v-else>共{{item.orderNum || 0}}件商品,总金额
- <text class='money p-color'>¥{{item.pay_price}}</text>
- </view> -->
- <view class="percentage" v-else>
- <view class="percentage_left" v-show="item.is_percentage==1">
- <view class="textBox">
- <text class="text1">百分比</text>
- <view class="text2">
- <text class="pay">付款</text>
- </view>
- </view>
- <view class="percentageTltle">
- 按{{100-item.start_percentage}}%付款
- </view>
- </view>
- <view class='totalPrice' style="flex: 1;">
- 共{{item.total_num || 0}}件商品,<text>{{item.is_percentage==1&&item.status!=0?'实付款':'总金额'}}</text>
- <text class='money p-color'>¥{{item.pay_price}}</text>
- </view>
- </view>
- <view class='totalPrice' style="flex: 1;"
- v-show="item.is_percentage==1&&item.status==4">
- 最晚付尾款时间:{{item.expire_time}}
- </view>
- <view class="fenxiao bottom"
- v-if="item.is_percentage==1&&item.status==4||item.status!=4&&item.status!=0&&item.status!=1&&item.status!=2&&item.status!=-1&&item.status!=3">
- <view class="" style="display: flex;align-items: center;"
- @click.stop="toPurchase(item.order_id)"
- v-show="item.is_percentage==1&&item.status==4||item.status==5">
- <text>分销拓展抵扣详情</text>
- <button @click.stop="share(item)" class='bnt b-color'
- style="margin-left: 20rpx;">分享</button>
- </view>
- <view class='bottom acea-row row-right row-middle'
- v-if="item.status!=4&&item.status!=0&&item.status!=5">
- <view class='bnt b-color'
- @click.stop='goPay(item.pay_price,item.group_order_id)'>
- 惠拓购付款</view>
- </view>
- <view class='bottom acea-row row-right row-middle'
- v-show="item.is_percentage==1&&item.status==4||item.status==5">
- <view class='bnt b-color' style="white-space: nowrap;"
- @click.stop='goFinalPay(item.pay_price,item.order_id)'>
- 支付尾款(¥{{((item.total_price*1+item.pay_postage*1) * item.residue_percentage) / 100>0?(item.total_price*(item.residue_percentage) / 100).toFixed(2):0}})
- </view>
- </view>
- </view>
- </view>
- <view class='bottom acea-row row-right row-middle'
- v-if="orderStatus!=5&&item.status!=4&&item.status!=5">
- <view v-if="!item.receipt && item.status != -1" class='bnt cancelBnt'
- @click.stop='applyInvoice(item.order_id)'>申请开票</view>
- <block v-if="item.status == 0 || item.status == 9 || item.status == -1">
- <view class='bnt b-color' @click='goOrderDetails(item.order_id)'>查看详情</view>
- </block>
- <block v-if="item.status == 1">
- <view class='bnt cancelBnt'
- v-if="item.delivery_type == 1 || item.delivery_type == 2"
- @click='goOrderDetails(item.order_id)'>查看物流</view>
- <view class='bnt b-color' @tap='confirmOrder(item,index)'>确认收货</view>
- </block>
- <block v-if="item.status == 2">
- <navigator v-if="community_status == 1 && !item.community_id"
- :url="'/pages/plantGrass/plant_release/index?order_id='+item.order_id"
- class='bnt colorBnt' hover-class="none">
- <text class="iconfont icon-fabu"></text>
- 发布种草
- </navigator>
- <view class='bnt b-color' @click='goOrderDetails_Evaluation(item.order_id)'>去评价
- </view>
- </block>
- <block v-if="item.status == 3">
- <view class='bnt b-color' @click='goOrderDetails(item.order_id)'
- v-if="item.activity_type == 2 || item.activity_type == 3 || item.activity_type == 10">
- 查看详情</view>
- <navigator v-if="community_status == 1 && !item.community_id"
- :url="'/pages/plantGrass/plant_release/index?order_id='+item.order_id"
- class='bnt colorBnt' hover-class="none">
- <text class="iconfont icon-fabu"></text>
- 发布种草
- </navigator>
- <view class='bnt b-color' @click='goOrderDetails(item.order_id)' v-else>再次购买</view>
- </block>
- </view>
- </view>
- </block>
- </view>
- </view>
- <view class='loadingicon acea-row row-center-wrapper' v-if="orderList.length>5">
- <text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadTitle}}
- </view>
- <view v-if="orderList.length == 0 && page > 1">
- <emptyPage title="暂无订单~"></emptyPage>
- </view>
- </view>
- <home></home>
- <authorize @onLoadFun="onLoadFun" :isAuto="isAuto" :isShowAuth="isShowAuth" @authColse="authColse"></authorize>
- <payment @finalPay='finalPay' ref="payment" :payMode='payMode' :isFinal="isFinal" :pay_close="pay_close"
- @onChangeFun='onChangeFun' :order_id="pay_order_id" :totalPrice='totalPrice'></payment>
- <addInvoicing ref="addInvoicing" @changeInvoiceClose="changeInvoiceClose" :invoice='invoice'></addInvoicing>
- <uni-popup ref="popup" type="center">
- <view class="popup" v-if="Object.keys(shareInfo).length!=0">
- <view class="image">
- <image :src='shareInfo.orderProduct[0].cart_info.product.image'></image>
- </view>
- <view class="title">
- <view>{{shareInfo.orderProduct[0].cart_info.product.store_name}}</view>
- <view class="price">¥{{shareInfo.orderProduct[0].cart_info.productAttr.price}}</view>
- </view>
- <button class="copybutton" @click="copyText">点击复制链接</button>
- </view>
- </uni-popup>
- </view>
- </template>
- <script>
- // +----------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2016~2021 https://www.crmeb.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +----------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +----------------------------------------------------------------------
- let app = getApp();
- import {
- getOrderList,
- orderData,
- unOrderCancel,
- orderDel,
- orderPay,
- groupOrderList,
- orderTake,
- applyInvoiceApi
- } from '@/api/order.js';
- import {
- getUserInfo
- } from '@/api/user.js';
- import {
- openOrderSubscribe
- } from '@/utils/SubscribeMessage.js';
- import payment from '@/components/payment';
- import home from '@/components/home/index.vue';
- import addInvoicing from '@/components/addInvoicing';
- import {
- mapGetters
- } from "vuex";
- import authorize from '@/components/Authorize';
- import emptyPage from '@/components/emptyPage.vue'
- import {
- configMap
- } from '@/utils'
- import {
- HTTP_REQUEST_URL
- } from '@/config/app';
- export default {
- components: {
- payment,
- emptyPage,
- home,
- authorize,
- addInvoicing
- },
- onLoad() {
- },
- data() {
- return {
- shareInfo: {},
- isFinal: false,
- statusBarHeight: 0,
- loading: false, //是否加载中
- loadend: false, //是否加载完毕
- loadTitle: '加载更多', //提示语
- orderList: [], //订单数组
- presellProList: [], //定金预售订单
- presellOrderCount: 0,
- orderData: {}, //订单详细统计
- orderStatus: 0, //订单状态
- page: 1,
- limit: 20,
- payMode: [{
- name: "微信支付",
- icon: "icon-weixinzhifu",
- value: 'wechat',
- title: '微信快捷支付',
- payStatus: 1
- },
- {
- name: "支付宝支付",
- icon: "icon-zhifubao",
- value: 'alipay',
- title: '支付宝支付',
- payStatus: this.$store.getters.globalData.alipay_open
- },
- {
- name: "余额支付",
- icon: "icon-yuezhifu",
- value: 'balance',
- title: '可用余额:',
- number: 0,
- payStatus: this.$store.getters.globalData.yue_pay_status
- }
- ],
- pay_close: false,
- pay_order_id: '',
- invoice_order_id: '',
- totalPrice: '0',
- isAuto: false, //没有授权的不会自动授权
- isShowAuth: false, //是否隐藏授权
- isReady: true,
- invoice: {
- invoice: false,
- add: false,
- }
- };
- },
- computed: {
- ...mapGetters(['isLogin', 'viewColor']),
- ...configMap(['hide_mer_status', 'community_status', 'alipay_open', 'yue_pay_status']),
- },
- watch: {
- alipay_open(n) {
- this.payMode[1].payStatus = n
- },
- yue_pay_status(n) {
- this.payMode[2].payStatus = n
- }
- },
- onShow() {
- var that = this
- that.$nextTick(function() {
- uni.getSystemInfo({
- success: function(res) {
- that.statusBarHeight = res.statusBarHeight;
- }
- });
- })
- if (this.isLogin) {
- this.page = 1;
- this.loadend = false;
- this.loading = false;
- this.getOrderData();
- this.getOrderList();
- this.getUserInfo();
- this.getpreSellOrderList();
- } else {
- this.isAuto = true;
- this.isShowAuth = true
- }
- },
- onReady() {},
- mounted: function() {},
- methods: {
- copyText() {
- let that = this
- let data = HTTP_REQUEST_URL + '/pages/index/index?order_id=' + this.order_id
- // let data='http://192.168.2.56:8080'+'/pages/index/index?order_id='+this.order_id
- uni.setClipboardData({
- data: data,
- success: function() {
- uni.showToast({
- title: '已复制'
- })
- that.$refs.popup.close()
- }
- });
- },
- share(item) {
- this.shareInfo = {}
- this.order_id = item.order_id
- uni.setStorageSync('order_id', item.order_id)
- // #ifdef MP-WEIXIN
- uni.setStorageSync('isIntegral', true)
- uni.switchTab({
- url: '/pages/index/index'
- });
- // #endif
- // #ifdef H5
- console.log(123, item)
- this.shareInfo = item
- this.$refs.popup.open()
- // #endif
- },
- toPurchase(id) {
- uni.navigateTo({
- url: '/pages/users/order_list/purchaseInfo?order_id=' + id
- })
- },
- toBack() {
- uni.navigateBack()
- },
- // 去商铺
- goMall(item) {
- if (this.hide_mer_status == 0) {
- uni.navigateTo({
- url: '/pages/store/home/index?id=' + item.mer_id
- })
- }
- },
- onLoadFun() {
- this.isShowAuth = false;
- this.getOrderData();
- this.getOrderList();
- this.getUserInfo();
- },
- // 授权关闭
- authColse: function(e) {
- this.isShowAuth = e
- },
- /**
- * 事件回调
- *
- */
- onChangeFun: function(e) {
- console.log(1121, e)
- let opt = e;
- let action = opt.action || null;
- let value = opt.value != undefined ? opt.value : null;
- (action && this[action]) && this[action](value);
- },
- /**
- * 获取用户信息
- *
- */
- getUserInfo: function() {
- let that = this;
- getUserInfo().then(res => {
- that.payMode[2].number = res.data.now_money;
- // that.$set(that, 'payMode', that.payMode);
- });
- },
- /**
- * 关闭支付组件
- *
- */
- payClose: function() {
- this.pay_close = false;
- },
- /**
- * 生命周期函数--监听页面加载
- */
- onLoad: function(options) {
- if (options.status) this.orderStatus = options.status;
- },
- /**
- * 获取订单统计数据
- *
- */
- getOrderData: function() {
- let that = this;
- orderData().then(res => {
- that.$set(that, 'orderData', res.data);
- })
- },
- /**
- * 取消订单
- *
- */
- cancelOrder: function(index, order_id) {
- let that = this;
- if (!order_id) return that.$util.Tips({
- title: '缺少订单号无法取消订单'
- });
- unOrderCancel(order_id).then(res => {
- return that.$util.Tips({
- title: res.message,
- icon: 'success'
- }, function() {
- that.orderList.splice(index, 1);
- that.$set(that, 'orderList', that.orderList);
- that.$set(that.orderData, 'unpaid_count', that.orderData.unpaid_count - 1);
- that.getOrderData();
- });
- }).catch(err => {
- return that.$util.Tips({
- title: err
- });
- });
- },
- /**
- * 打开支付组件
- *
- */
- goPay: function(pay_price, order_id) {
- this.isFinal = false
- this.$set(this, 'pay_close', true);
- this.order_id = order_id;
- this.pay_order_id = order_id.toString()
- this.$set(this, 'totalPrice', pay_price);
- },
- //尾款支付
- goFinalPay: function(pay_price, order_id) {
- console.log(this.$refs.payment)
- this.isFinal = true
- this.$set(this, 'pay_close', true);
- this.order_id = order_id;
- this.pay_order_id = order_id.toString()
- this.$set(this, 'totalPrice', pay_price);
- },
- finalPay() {
- this.statusClick(1)
- },
- /**
- * 支付成功回调
- *
- */
- pay_complete: function() {
- this.loadend = false;
- this.page = 1;
- this.$set(this, 'orderList', []);
- this.pay_close = false;
- this.pay_order_id = '';
- this.getOrderData();
- this.getOrderList();
- },
- /**
- * 支付失败回调
- *
- */
- pay_fail: function() {
- this.pay_close = false;
- this.pay_order_id = '';
- },
- /**
- * 去订单详情
- */
- goOrderDetails: function(order_id) {
- let self = this
- if (!order_id) return that.$util.Tips({
- title: '缺少订单号无法查看订单详情'
- });
- // #ifdef MP
- uni.showLoading({
- title: '正在加载',
- })
- openOrderSubscribe().then(() => {
- uni.hideLoading();
- if (self.orderStatus == 0) {
- uni.navigateTo({
- url: '/pages/order_details/stay?order_id=' + order_id
- })
- } else {
- uni.navigateTo({
- url: '/pages/order_details/index?order_id=' + order_id
- })
- }
- }).catch(() => {
- uni.hideLoading();
- })
- // #endif
- // #ifndef MP
- if (self.orderStatus == 0) {
- uni.navigateTo({
- url: '/pages/order_details/stay?order_id=' + order_id
- })
- } else {
- uni.navigateTo({
- url: '/pages/order_details/index?order_id=' + order_id
- })
- }
- // #endif
- },
- /**
- * 点击去评价
- */
- goOrderDetails_Evaluation: function(order_id) {
- let self = this
- if (!order_id) return that.$util.Tips({
- title: '缺少订单号无法查看订单详情和评价'
- });
- // #ifdef MP
- if (self.orderStatus == 0) {
- uni.navigateTo({
- url: '/pages/order_details/stay?order_id=' + order_id
- })
- } else {
- uni.navigateTo({
- url: '/pages/order_details/index?order_id=' + order_id
- })
- }
- // #endif
- // #ifndef MP
- if (self.orderStatus == 0) {
- uni.navigateTo({
- url: '/pages/order_details/stay?order_id=' + order_id
- })
- } else {
- uni.navigateTo({
- url: '/pages/order_details/index?order_id=' + order_id
- })
- }
- // #endif
- },
- /**
- * 切换类型
- */
- statusClick: function(status) {
- if (status == this.orderStatus) return;
- this.orderStatus = status;
- this.loadend = false;
- this.loading = false;
- this.page = 1;
- this.$set(this, 'orderList', []);
- this.getOrderList();
- },
- /**
- * 获取订单列表
- */
- getOrderList: function() {
- let that = this;
- if (that.loadend) return;
- if (that.loading) return;
- that.loading = true;
- that.loadTitle = "加载更多";
- if (that.isReady) {
- that.isReady = false
- if (that.orderStatus == 0) {
- groupOrderList({
- page: that.page,
- limit: that.limit,
- }).then(res => {
- that.isReady = true;
- let list = res.data.list || [];
- let loadend = list.length < that.limit;
- console.log(that.orderList)
- that.orderList = that.page == 1 ? list : that.$util.SplitArray(list, that
- .orderList);
- that.$set(that, 'orderList', that.orderList);
- console.log(that.orderList)
- that.getProductCount();
- that.loadend = loadend;
- that.loading = false;
- that.loadTitle = loadend ? "我也是有底线的" : '加载更多';
- that.page = that.page + 1
- })
- } else {
- getOrderList({
- status: that.orderStatus - 1,
- page: that.page,
- limit: that.limit,
- }).then(res => {
- let list = res.data.list || [];
- let loadend = list.length < that.limit;
- that.orderList = that.page == 1 ? list : that.$util.SplitArray(list, that
- .orderList);
- that.$set(that, 'orderList', that.orderList);
- that.getProductCount();
- that.loadend = loadend;
- that.loading = false;
- that.loadTitle = loadend ? "我也是有底线的" : '加载更多';
- that.page = that.page + 1;
- that.isReady = true;
- }).catch(err => {
- that.loading = false;
- that.loadTitle = "加载更多";
- })
- }
- }
- },
- /**
- * 获取定金预售订单列表
- */
- getpreSellOrderList: function() {
- let that = this;
- getOrderList({
- status: 10,
- page: 1,
- limit: 1,
- }).then(res => {
- let list = res.data.list || [];
- that.presellOrderCount = res.data.count;
- that.$set(that, 'presellProList', list);
- })
- },
- /**
- * 获取单个订单商品数量
- */
- getProductCount: function() {
- if (this.orderStatus !== 0) {
- this.orderList.forEach((item, i) => {
- let orderNum = 0
- if (item.orderProduct) {
- item.orderProduct.forEach((val) => {
- orderNum += val.product_num
- })
- this.orderList[i]['orderNum'] = orderNum;
- }
- })
- }
- },
- /**
- * 删除订单
- */
- delOrder: function(order_id, index) {
- let that = this;
- orderDel(order_id).then(res => {
- that.orderList.splice(index, 1);
- that.$set(that, 'orderList', that.orderList);
- that.$set(that.orderData, 'unpaid_count', that.orderData.unpaid_count - 1);
- that.getOrderData();
- return that.$util.Tips({
- title: '删除成功',
- icon: 'success'
- });
- }).catch(err => {
- return that.$util.Tips({
- title: err
- });
- })
- },
- // 确认收货
- confirmOrder: function(item, index) {
- let that = this;
- uni.showModal({
- title: '确认收货',
- content: '为保障权益,请收到货确认无误后,再确认收货',
- success: function(res) {
- if (res.confirm) {
- orderTake(item.order_id).then(res => {
- return that.$util.Tips({
- title: '操作成功',
- icon: 'success'
- }, function() {
- that.orderList.splice(index, 1);
- that.getOrderData();
- });
- }).catch(err => {
- return that.$util.Tips({
- title: err
- });
- })
- }
- }
- })
- },
- /*申请开票*/
- applyInvoice(order_id) {
- let that = this;
- that.invoice_order_id = order_id
- that.invoice.invoice = true;
- that.$refs.addInvoicing.getInvoiceDefault();
- that.$refs.addInvoicing.getInvoiceList();
- },
- // 关闭发票弹窗
- changeInvoiceClose: function(data) {
- if (data) this.getInvoiceData(data);
- this.$set(this.invoice, 'invoice', false);
- },
- // 开票回调
- getInvoiceData(data) {
- let that = this
- applyInvoiceApi(that.invoice_order_id, data).then(res => {
- return that.$util.Tips({
- title: res.message,
- });
- }).catch(err => {
- return that.$util.Tips({
- title: err
- });
- })
- }
- },
- onReachBottom: function() {
- this.getOrderList();
- }
- }
- </script>
- <style scoped lang="scss">
- .popup {
- width: 500rpx;
- height: auto;
- background-color: #fff;
- padding: 0 0 20rpx;
- .image {
- image {
- width: 500rpx;
- height: 500rpx;
- }
- }
- .title {
- padding: 0 20rpx;
- // display: flex;
- // justify-content: space-between;
- text {
- font-size: 20rpx;
- }
- .price {
- color: #E93323;
- font-weight: bold;
- }
- }
- .copybutton {
- height: 76rpx;
- border-radius: 38rpx;
- margin: 30rpx 30rpx 0;
- background-color: var(--view-theme);
- font-size: 30rpx;
- line-height: 76rpx;
- color: #FFFFFF;
- }
- }
- .fenxiao {
- padding: 0 20rpx;
- display: flex;
- justify-content: space-between;
- align-items: center;
- color: #AAAAAA;
- }
- .percentage {
- margin-top: 16rpx;
- margin-left: 20rpx;
- display: flex;
- justify-content: space-between;
- align-items: center;
- .percentage_left {
- .textBox {
- display: flex;
- transform: skewX(-15deg);
- width: 118rpx;
- white-space: nowrap;
- // height: 28rpx;
- // line-height: 28rpx;
- border: 4rpx solid #EB3B2B;
- border-radius: 3rpx;
- font-size: 16rpx;
- // background-color: #EB3B2B;
- .text1 {
- color: #EB3B2B;
- transform: skewX(15deg);
- display: inline-block;
- // background-color: #fff;
- }
- .text2 {
- color: #fff;
- background-color: #EB3B2B;
- // transform: skewX(15deg);
- display: inline-block;
- .pay {
- transform: skewX(15deg);
- display: inline-block;
- }
- }
- }
- .percentageTltle {
- margin-top: 4rpx;
- font-size: 28rpx;
- color: #EB3B2B;
- font-weight: bold;
- }
- }
- }
- .searchBox {
- padding: 0 30rpx;
- height: 70rpx;
- display: flex;
- align-items: center;
- image {
- vertical-align: middle;
- width: 48rpx;
- height: 48rpx;
- }
- }
- .my-order {
- width: 750rpx;
- height: 536rpx;
- background: linear-gradient(180deg, #EA3B2A 0%, #EA3B2A 70%, rgba(232, 51, 36, 0) 100%);
- }
- .my-order .header {
- height: 260rpx;
- padding: 0 30rpx;
- // background-color: var(--view-theme);
- }
- .t-color {
- font-weight: bold;
- color: var(--view-theme);
- }
- .p-color {
- color: var(--view-priceColor);
- }
- .b-color {
- background-color: var(--view-theme);
- }
- .my-order .header .picTxt {
- height: 190rpx;
- }
- .my-order .header .picTxt .text {
- display: flex;
- justify-content: space-between;
- padding: 0 20rpx;
- box-sizing: border-box;
- color: rgba(255, 255, 255, 0.8);
- font-size: 26rpx;
- // font-family: 'Guildford Pro';
- // width: 300rpx;
- height: 88rpx;
- line-height: 88rpx;
- background: #F24D3F;
- border-radius: 18rpx;
- border: 1rpx solid #FFFFFF;
- }
- .my-order .header .picTxt .text .name {
- font-size: 28rpx;
- font-weight: bold;
- color: #fff;
- }
- .my-order .header .picTxt .text .textValue {
- color: #fff;
- font-size: 24rpx;
- text {
- font-size: 56rpx;
- font-weight: bold;
- margin-right: 8rpx;
- }
- }
- .my-order .header .picTxt .pictrue {
- width: 122rpx;
- height: 109rpx;
- }
- .my-order .header .picTxt .pictrue image {
- width: 100%;
- height: 100%;
- }
- .my-order .nav {
- // background-color: #fff;
- width: 690rpx;
- // height: 140rpx;
- border-radius: 6rpx;
- margin: 20rpx auto 0 auto;
- }
- .my-order .nav .item {
- text-align: center;
- font-size: 26rpx;
- // color: #282828;
- color: #fff;
- padding: 0 0 6rpx;
- }
- .my-order .nav .item.on {
- font-weight: bold;
- border-bottom: 5rpx solid #fff;
- }
- .my-order .nav .item .num {
- margin-top: 18rpx;
- }
- .my-order .list {
- width: 690rpx;
- margin: 14rpx auto 0 auto;
- }
- .my-order .list .item {
- background-color: #fff;
- border-radius: 6rpx;
- margin-bottom: 14rpx;
- border-radius: 24rpx;
- }
- .my-order .list .item .title {
- height: 84rpx;
- padding: 0 30rpx;
- border-bottom: 1px solid #eee;
- font-size: 28rpx;
- color: #282828;
- .left-wrapper {
- .iconfont {
- margin-top: 5rpx;
- }
- .store-name {
- margin: 0 10rpx;
- }
- .icon-xiangyou {
- font-size: 20rpx;
- }
- }
- }
- .my-order .list .item .title .sign {
- font-size: 24rpx;
- padding: 0 7rpx;
- height: 36rpx;
- margin-right: 15rpx;
- }
- .my-order .list .item .item-info {
- padding: 0 30rpx;
- margin-top: 22rpx;
- }
- .my-order .list .item .item-info .pictrue {
- width: 120rpx;
- height: 120rpx;
- }
- .my-order .list .item .item-info .pictrue image {
- width: 100%;
- height: 100%;
- border-radius: 6rpx;
- }
- .my-order .list .item .item-info .text {
- width: 486rpx;
- font-size: 28rpx;
- color: #999;
- margin-top: 6rpx;
- }
- .my-order .list .item .item-info .text .name {
- width: 320rpx;
- color: #282828;
- }
- .event_bg {
- background: #FF7F00;
- }
- .event_color {
- color: #FF7F00;
- }
- .my-order .list .item .event_name {
- display: inline-block;
- margin-right: 9rpx;
- color: #fff;
- font-size: 20rpx;
- padding: 0 8rpx;
- line-height: 30rpx;
- text-align: center;
- border-radius: 6rpx;
- }
- .my-order .list .item .event_ship {
- font-size: 20rpx;
- margin-top: 10rpx;
- }
- .my-order .list .event_price {
- margin: 0 0 50rpx 120rpx;
- }
- .my-order .list .item .item-info .text .money {
- text-align: right;
- }
- .my-order .list .item .totalPrice {
- font-size: 26rpx;
- color: #282828;
- text-align: right;
- margin: 27rpx 0 0 30rpx;
- padding: 0 30rpx 30rpx 0;
- }
- .my-order .list .item .totalPrice .money {
- font-size: 28rpx;
- font-weight: bold;
- }
- .my-order .list .item .bottom {
- height: 107rpx;
- // padding: 0 30rpx;
- border-top: 1px solid #f0f0f0;
- }
- .my-order .list .item .bottom .bnt {
- // width: 200rpx;
- height: 60rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- color: #fff;
- border-radius: 50rpx;
- font-size: 27rpx;
- padding:0 10px;
- }
- .my-order .list .item .bottom .bnt.cancelBnt {
- border: 1px solid #ddd;
- color: #aaa;
- }
- .my-order .list .item .bottom .bnt.colorBnt {
- border: 1px solid var(--view-theme);
- color: var(--view-theme);
- }
- .my-order .list .item .bottom .bnt .icon-fabu {
- font-size: 26rpx;
- margin-right: 10rpx;
- }
- .my-order .list .item .bottom .bnt~.bnt {
- margin-left: 17rpx;
- }
- .noCart {
- margin-top: 171rpx;
- padding-top: 0.1rpx;
- }
- .noCart .pictrue {
- width: 414rpx;
- height: 336rpx;
- margin: 78rpx auto 56rpx auto;
- }
- .noCart .pictrue image {
- width: 100%;
- height: 100%;
- }
- .event_container {
- width: 690rpx;
- background-image: url(../static/images/presell_orderBg.png);
- background-size: cover;
- background-repeat: no-repeat;
- margin: 20rpx auto;
- padding: 26rpx 30rpx;
- border-radius: 16rpx;
- .info {
- width: 420rpx;
- .title {
- color: #282828;
- font-size: 26rpx;
- }
- .desc {
- color: #999;
- font-size: 24rpx;
- margin-top: 30rpx;
- }
- }
- .photo {
- width: 180rpx;
- .picture {
- width: 120rpx;
- height: 120rpx;
- image {
- width: 100%;
- height: 100%;
- border-radius: 8rpx;
- }
- }
- .more_btn {
- color: #fff;
- background: #F97E3B;
- width: 40rpx;
- height: 40rpx;
- border-radius: 40rpx;
- text-align: center;
- line-height: 40rpx;
- position: relative;
- top: 40rpx;
- text {
- font-size: 20rpx;
- }
- }
- }
- }
- .search {
- box-sizing: border-box;
- width: 400rpx;
- height: 70rpx;
- padding: 0 30rpx;
- border-radius: 35rpx;
- margin: 0 30rpx 0;
- background-color: #FFFFFF;
- font-size: 26rpx;
- color: #999999;
- .iconfont {
- margin-right: 10rpx;
- font-size: 23rpx;
- }
- }
- </style>
|