13 changed files with 665 additions and 65 deletions
@ -0,0 +1,27 @@
|
||||
<template> |
||||
<view v-html="aboutUs"></view> |
||||
</template> |
||||
|
||||
<script> |
||||
import {getConfig} from "@/api/other"; |
||||
|
||||
export default { |
||||
data() { |
||||
return {aboutUs:''}; |
||||
}, |
||||
onLoad() { |
||||
this.getAboutUs(); |
||||
}, |
||||
methods:{ |
||||
getAboutUs(){ |
||||
getConfig('aboutUs').then(res =>{ |
||||
this.aboutUs = res.data.aboutUs; |
||||
}) |
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style lang="scss"> |
||||
|
||||
</style> |
@ -0,0 +1,29 @@
|
||||
<template> |
||||
<view v-html="privacyPolicy"></view> |
||||
</template> |
||||
|
||||
<script> |
||||
import {getConfig} from "@/api/other"; |
||||
|
||||
export default { |
||||
data() { |
||||
return { |
||||
privacyPolicy:'' |
||||
}; |
||||
}, |
||||
onLoad() { |
||||
this.getPrivacyPolicy(); |
||||
}, |
||||
methods:{ |
||||
getPrivacyPolicy(){ |
||||
getConfig('privacyPolicy').then(res => { |
||||
this.privacyPolicy = res.data; |
||||
}) |
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style lang="scss"> |
||||
|
||||
</style> |
@ -0,0 +1,224 @@
|
||||
.order-capsule-container{ |
||||
position: sticky; |
||||
|
||||
box-sizing: border-box; |
||||
width:100%; |
||||
padding:10rpx; |
||||
border:2rpx solid #262626; |
||||
border-radius: 45rpx; |
||||
box-shadow: 1rpx 4rpx 12rpx 0rpx rgba(90,104,103,0.24); |
||||
background-color: #F8FAFA; |
||||
.order-capsule{ |
||||
box-sizing: border-box; |
||||
padding:20rpx; |
||||
text-align: center; |
||||
font: { |
||||
size:30rpx; |
||||
weight:500; |
||||
} |
||||
line-height:30rpx; |
||||
border:2rpx solid rgba(0,0,0,0); |
||||
&.active{ |
||||
background:{ |
||||
color:#4DC3B8; |
||||
} |
||||
color:#FFFFFF; |
||||
border:2rpx solid #262626; |
||||
border-radius:35rpx; |
||||
} |
||||
} |
||||
} |
||||
.order-screen-container{ |
||||
.order-screen{ |
||||
padding:40rpx 0 20rpx 0; |
||||
padding-right: 66rpx; |
||||
font-size: 28rpx; |
||||
line-height: 53rpx; |
||||
color:#646464; |
||||
font-weight: 400; |
||||
position: relative; |
||||
&.active{ |
||||
color:#000000; |
||||
font-size: 32rpx; |
||||
font-weight: 500; |
||||
.order-screen-active{ |
||||
display:flex; |
||||
} |
||||
} |
||||
.order-screen-active{ |
||||
display: none; |
||||
align-items: center; |
||||
justify-content: center; |
||||
position: absolute; |
||||
top: 90rpx; |
||||
left: 12rpx; |
||||
.img{ |
||||
width:37rpx; |
||||
} |
||||
} |
||||
|
||||
} |
||||
.order-screen-time-container{ |
||||
flex:1; |
||||
margin-left:auto; |
||||
justify-content: flex-end; |
||||
.order-screen{ |
||||
// padding-right:0; |
||||
} |
||||
} |
||||
.order-screen-time-title{ |
||||
color:#B5B5B5; |
||||
font-size:26rpx; |
||||
font-weight: 400; |
||||
line-height:53rpx; |
||||
padding-right: 16rpx; |
||||
} |
||||
.order-screen-time-buttton-container{ |
||||
padding-right: 0; |
||||
} |
||||
.order-screen-time-buttton{ |
||||
padding:8rpx 19rpx; |
||||
color:#4EC2B7; |
||||
font-size: 28rpx; |
||||
font-weight: 400; |
||||
background-color:#ffffff; |
||||
border:1px solid #4EC2B7; |
||||
border-radius: 10rpx; |
||||
line-height: 28rpx; |
||||
box-shadow: 0rpx 4rpx 5rpx 0rpx rgba(82,84,84,0.1), 2rpx -4rpx 0rpx 0rpx rgba(78,194,183,0.2); |
||||
} |
||||
} |
||||
.order-screen-top{ |
||||
position: sticky; |
||||
left:0; |
||||
z-index: 9999; |
||||
background-color:#fff; |
||||
padding:25rpx; |
||||
} |
||||
.app-wallpaper{ |
||||
position: relative; |
||||
background:{ |
||||
size: 100% 100%; |
||||
repeat: no-repeat; |
||||
}; |
||||
.order-list-container{ |
||||
width:100%; |
||||
//max-height: 1000rpx; |
||||
height: 100%; |
||||
//overflow: auto; |
||||
box-sizing: border-box; |
||||
|
||||
.order-list-item{ |
||||
margin-bottom:30rpx; |
||||
width:100%; |
||||
box-sizing: border-box; |
||||
.order-card-container{ |
||||
width:100%; |
||||
box-sizing: border-box; |
||||
padding:10rpx 10rpx; |
||||
position: relative; |
||||
box-sizing: border-box; |
||||
.order-card-container-background{ |
||||
|
||||
width:100%; |
||||
height:90%; |
||||
position: absolute; |
||||
left:0rpx; |
||||
z-index: -1; |
||||
bottom:0rpx; |
||||
border: 3rpx solid #262626; |
||||
box-shadow: 2rpx 6rpx 11rpx 0rpx rgba(159,167,185,0.3); |
||||
border-radius: 26rpx; |
||||
background: { |
||||
color:#EED9AD; |
||||
}; |
||||
} |
||||
.order-card-container-background-main{ |
||||
|
||||
width:100%; |
||||
background:{ |
||||
color:#FFFFFF; |
||||
} |
||||
border-radius: 26rpx; |
||||
border: 3rpx solid #262626; |
||||
padding:7rpx; |
||||
box-sizing:border-box; |
||||
.order-card-col{ |
||||
width:100%; |
||||
box-sizing: border-box; |
||||
padding:15rpx; |
||||
background:{ |
||||
size:100% 100%; |
||||
position: center center; |
||||
repeat:no-repeat; |
||||
} |
||||
} |
||||
} |
||||
|
||||
|
||||
.order-card-left{ |
||||
.img{ |
||||
width:200rpx; |
||||
height:200rpx; |
||||
border-radius: 30rpx; |
||||
} |
||||
} |
||||
.order-card-right{ |
||||
padding-left:20rpx; |
||||
.order-card-title{ |
||||
padding-top:5px; |
||||
font-size:32rpx; |
||||
font-weight: 500; |
||||
line-height: 30rpx; |
||||
color:#131313; |
||||
} |
||||
.order-card-tag-container{ |
||||
padding-top:18rpx; |
||||
.order-card-tag{ |
||||
padding:9rpx 20rpx; |
||||
background:{ |
||||
color:#E9FBF7; |
||||
} |
||||
color:#4DC3B8; |
||||
font-size:26rpx; |
||||
font-weight:400; |
||||
line-height:1; |
||||
border-radius:6rpx; |
||||
&+.order-card-tag{ |
||||
margin-left:9rpx; |
||||
} |
||||
} |
||||
} |
||||
.order-card-day{ |
||||
|
||||
} |
||||
.order-card-pay-time{ |
||||
|
||||
} |
||||
.order-card-day,.order-card-pay-time{ |
||||
padding-top:20rpx; |
||||
font-size:28rpx; |
||||
font-weight:400; |
||||
line-height:30rpx; |
||||
color:#767676; |
||||
.card-label{ |
||||
color:#1B1B1B; |
||||
} |
||||
} |
||||
} |
||||
.order-card-bottom{ |
||||
padding-top:30rpx; |
||||
justify-content: center; |
||||
} |
||||
.card-button{ |
||||
&:nth-child(1){ |
||||
padding-right:23rpx; |
||||
} |
||||
&:nth-child(2){ |
||||
padding-left:23rpx; |
||||
} |
||||
} |
||||
} |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,245 @@
|
||||
<template> |
||||
<view class="order-screen-top" :style="{ |
||||
top:topStyle |
||||
}"> |
||||
<view class="order-capsule-container row"> |
||||
<view class="order-capsule col-4" |
||||
v-for="(item,index) in screenMenu" |
||||
:class="{active:(item.value === screenCheck)}" |
||||
@click="selectScreen(item)" |
||||
> |
||||
{{ item.name }} |
||||
</view> |
||||
|
||||
</view> |
||||
<view class="order-screen-container row"> |
||||
<view class="order-screen" v-for="(date, index) in dateSelectData" @click="dayActiveToggle(date)" :class="{active:dayActive === date.value}"> |
||||
{{ date.title }} |
||||
<view class="order-screen-active"> |
||||
<image mode="widthFix" class="img" :src="staticImage.screenActiveImg" /> |
||||
</view> |
||||
</view> |
||||
|
||||
<view class="order-screen-time-container row"> |
||||
<view class="order-screen order-screen-time-title"> |
||||
05/06-08-03 |
||||
</view> |
||||
<view class="order-screen order-screen-time-buttton-container"> |
||||
<view class="order-screen-time-buttton"> |
||||
时间 |
||||
</view> |
||||
</view> |
||||
</view> |
||||
|
||||
</view> |
||||
</view> |
||||
<view class="app-wallpaper" :style="{ |
||||
backgroundImage:'url('+staticImage.wallpaperBgImage+')' |
||||
}"> |
||||
|
||||
|
||||
<view class="order-list-container"> |
||||
<view class="order-list-item" v-for="(item,index) in orderList"> |
||||
<view class="order-card-container row"> |
||||
<view class="order-card-container-background col-12"></view> |
||||
<view class="order-card-container-background-main row"> |
||||
<view class="order-card-col row" :style="{backgroundImage:'url('+staticImage.orderCardBackground+')'}"> |
||||
<view class="order-card-left"> |
||||
<image class="img" :src="petImage" mode="aspectFill" /> |
||||
</view> |
||||
<view class="order-card-right"> |
||||
<view class="order-card-title">{{item.addr}}</view> |
||||
<view class="order-card-tag-container row"> |
||||
<view class="order-card-tag" v-for="(server, i) in item.services" wx:key="i">{{ server }}</view> |
||||
</view> |
||||
<view class="order-card-day"><text class="card-label">上门:</text>{{item.do_date}} {{ item.do_time }} |
||||
</view> |
||||
<view class="order-card-pay-time"><text class="card-label">下单时间:</text>{{item.create_time}} |
||||
</view> |
||||
</view> |
||||
<view class="order-card-bottom col-12 row"> |
||||
<view class="card-button" @click="navTo('/pages/ChatDetail/index?id=' + item.id)"> |
||||
<MzButton |
||||
title="立即沟通" |
||||
font-color="#3E3221" |
||||
button-color="#F7E1C3" |
||||
button-width="255rpx"></MzButton> |
||||
</view> |
||||
<view class="card-button" @click="navTo('/pages/FeedLog/index?pet_id=' + item.pet_id)"> |
||||
<MzButton |
||||
title="喂养档案" |
||||
font-color="#FFFFFF" |
||||
button-color="#4DC3B8" |
||||
button-width="255rpx"></MzButton> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
<u-loadmore :status="status" fontSize="28" |
||||
color="#ACB4B6" |
||||
line |
||||
line-color="#ACB4B6" |
||||
marginBottom="30" marginTop="30" @loadmore="getOrderList()"/> |
||||
</view> |
||||
|
||||
<!-- <RightNav></RightNav> --> |
||||
</template> |
||||
|
||||
<script> |
||||
import { |
||||
imghost |
||||
} from '@/config/host.js' |
||||
import HeaderNav from '@/components/HeaderNav/Index.vue'; |
||||
import FooterNav from '@/components/FooterNav/Index.vue'; |
||||
import RightNav from '@/components/RightNav/Index.vue'; |
||||
import MzButton from '@/components/MzButton/Index.vue'; |
||||
import api from '@/utils/functions.js'; |
||||
import {getOrderList} from "@/api/order"; |
||||
import log from "@/utils/log"; |
||||
export default { |
||||
components: { |
||||
HeaderNav, |
||||
FooterNav, |
||||
RightNav, |
||||
MzButton |
||||
}, |
||||
computed:{ |
||||
topStyle(){ |
||||
return (uni.getStorageSync('sysInfo').sysAndMenuHeight)+'px' |
||||
}, |
||||
}, |
||||
data() { |
||||
return { |
||||
title: 'Hello', |
||||
loading: true, |
||||
status: 'loadmore', |
||||
screenCheck:'', |
||||
screenMenu:[ |
||||
{ |
||||
name:'全部', |
||||
value:'', |
||||
},{ |
||||
name:'待服务', |
||||
value:'0', |
||||
},{ |
||||
name:'已完成', |
||||
value:'2', |
||||
}, |
||||
], |
||||
dateSelectData:[ |
||||
{title:"全部", value: 0}, |
||||
{title:"今天", value: 1}, |
||||
{title:"明天", value: 2}, |
||||
], |
||||
staticImage: { |
||||
screenActiveImg: imghost + '/static/image/order-screen-active.png', |
||||
orderCardBackground: imghost + '/static/image/order-card-background.png', |
||||
wallpaperBgImage:imghost +'/static/image/background.png' |
||||
}, |
||||
indexBanner: [{ |
||||
image: imghost + '/static/image/banner.png', |
||||
url: '', |
||||
}], |
||||
user: { |
||||
avatar: imghost + '/static/image/banner.png', |
||||
nickname: '清晨的风', |
||||
coupons: 221, |
||||
id: 88685 |
||||
}, |
||||
isTop: false, |
||||
pagePadding: 100, |
||||
petImage: imghost + '/static/image/pet_avatar1.jpeg', |
||||
orderList:[], |
||||
dayActive: 0, |
||||
statusActive: 1, |
||||
page:1, |
||||
is_buy:'', |
||||
start_time:'', |
||||
end_time:'', |
||||
} |
||||
}, |
||||
onLoad(options) { |
||||
this.screenCheck = options.type; |
||||
this.is_buy = options.is_buy; |
||||
}, |
||||
methods: { |
||||
selectScreen(item){ |
||||
this.screenCheck = item.value; |
||||
this.page = 1; |
||||
this.status = "loadmore"; |
||||
this.orderList = []; |
||||
this.getOrderList(); |
||||
}, |
||||
navTo(url){ |
||||
uni.navigateTo({ |
||||
url:url |
||||
}) |
||||
}, |
||||
getOrderList(filter = { |
||||
status: "", |
||||
start_time: this.start_time, |
||||
end_time: this.end_time, |
||||
}){ |
||||
filter.is_worker = 0; |
||||
filter.page = this.page++; |
||||
filter.limit = 5; |
||||
filter.is_buy = this.is_buy; |
||||
if (this.screenCheck !== '') { |
||||
filter.status = this.screenCheck; |
||||
} |
||||
|
||||
if (this.status === 'nomore') { |
||||
return; |
||||
} |
||||
this.status = 'loading'; |
||||
getOrderList(filter).then(data => { |
||||
if (filter.page === 1){ |
||||
this.orderList = data.data; |
||||
}else{ |
||||
this.orderList.push(...data.data); |
||||
} |
||||
|
||||
this.status = data.data.length < filter.limit ? 'nomore' : 'loadmore'; |
||||
}); |
||||
}, |
||||
dayActiveToggle(date){ |
||||
this.dayActive = date.value; |
||||
this.page = 1; |
||||
this.orderList = []; |
||||
this.status = "loadmore"; |
||||
|
||||
let currentTime = new Date().getTime(); |
||||
let unitDay = 86400000; |
||||
let today = uni.$u.timeFormat(currentTime, 'yyyy-mm-dd'); |
||||
let tomorrow = uni.$u.timeFormat(currentTime + unitDay, 'yyyy-mm-dd'); |
||||
let acquired = uni.$u.timeFormat(currentTime + unitDay * 2, 'yyyy-mm-dd'); |
||||
this.start_time = ['', today, tomorrow][date.value]; |
||||
this.end_time = ['', tomorrow, acquired][date.value]; |
||||
this.getOrderList(); |
||||
}, |
||||
|
||||
}, |
||||
onPageScroll(res) { |
||||
if(res.scrollTop <= 20){ |
||||
uni.$emit('isTop', true); |
||||
}else{ |
||||
uni.$emit('isTop', false); |
||||
} |
||||
}, |
||||
|
||||
mounted() { |
||||
this.getOrderList(); |
||||
}, |
||||
created() { |
||||
this.pagePadding = (api.navHeight().navPaddingTop + |
||||
api.navHeight().navHeight + (api.navHeight().headerPadding * 2)) |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style lang="scss"> |
||||
@import './components/index.scss'; |
||||
</style> |
Loading…
Reference in new issue