parent
d8a4e83078
commit
f4e7782a86
7 changed files with 1110 additions and 0 deletions
@ -0,0 +1,85 @@ |
||||
<template> |
||||
<view class="margin radius bg-white"> |
||||
<view class="main-money "> |
||||
<view class="padding-xs flex align-center"> |
||||
<view class="flex-sub text-center padding-top-lg"> |
||||
<view class="txet-xxs"> |
||||
<text class="">交易金额</text> |
||||
</view> |
||||
<view class=" text-sl padding padding-top-xs"><text class=""> |
||||
¥{{basicData.totalAmout|numberFilter}} |
||||
|
||||
</text></view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
<view class="bg-white to-top"> |
||||
<view class=" flex "> |
||||
<view class="padding text-center flex-sub"> |
||||
<text>交易笔数</text> |
||||
<view class="padding-sm"> |
||||
<text class="text-lg oil-main-color padding-top-xs">{{basicData.totalCount}}</text> |
||||
</view> |
||||
</view> |
||||
<view class="padding text-center flex-sub"> |
||||
<text>客单均价</text> |
||||
<view class="padding-sm"> |
||||
<text class="text-lg oil-main-color">¥{{basicData.totalAmout/basicData.totalAccount|numberFilter}}</text> |
||||
</view> |
||||
</view> |
||||
<view class="padding text-center flex-sub"> |
||||
<text>顾客数</text> |
||||
<view class="padding-sm"> |
||||
<text class="text-lg oil-main-color padding-top-xs">{{basicData.totalAccount}}</text> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
|
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
export default { |
||||
props: { |
||||
basicData: { |
||||
type: Object, |
||||
default () {} |
||||
} |
||||
}, |
||||
data() { |
||||
return { |
||||
|
||||
} |
||||
}, |
||||
methods: { |
||||
showModal() { |
||||
this.$emit('showModal') |
||||
} |
||||
}, |
||||
watch: { |
||||
basicData: { |
||||
handler(newVal, oldVal) { |
||||
console.log('深度监听', newVal, oldVal) |
||||
this.basicData = newVal |
||||
}, |
||||
deep: true |
||||
} |
||||
}, |
||||
filters: { |
||||
numberFilter(value) { |
||||
if (value) { |
||||
value = value - 1 + 1 |
||||
return value.toFixed(2) |
||||
} else { |
||||
return '0.00' |
||||
} |
||||
|
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style> |
||||
|
||||
</style> |
@ -0,0 +1,198 @@ |
||||
<template> |
||||
<view class="qiun-columns"> |
||||
<!--#ifdef H5 --> |
||||
<view class="qiun-bg-white qiun-title-bar qiun-common-mt"> |
||||
<view class="qiun-title-dot-light">页面地址</view> |
||||
</view> |
||||
<view class="qiun-bg-white qiun-padding"> |
||||
<text>pages/basic/area/time</text> |
||||
</view> |
||||
<!--#endif--> |
||||
<view class="qiun-bg-white qiun-title-bar qiun-common-mt"> |
||||
<view class="qiun-title-dot-light">单量</view> |
||||
</view> |
||||
<view class="qiun-charts"> |
||||
<!--#ifdef MP-ALIPAY --> |
||||
<canvas canvas-id="canvasLineA" id="canvasLineA" class="charts" :width="cWidth*pixelRatio" :height="cHeight*pixelRatio" |
||||
:style="{'width':cWidth+'px','height':cHeight+'px'}" @touchstart="touchLineA"></canvas> |
||||
<!--#endif--> |
||||
<!--#ifndef MP-ALIPAY --> |
||||
<canvas canvas-id="canvasLineA" id="canvasLineA" class="charts" @touchstart="touchLineA"></canvas> |
||||
<!--#endif--> |
||||
</view> |
||||
<!--#ifdef H5 --> |
||||
<view class="qiun-bg-white qiun-title-bar qiun-common-mt"> |
||||
<view class="qiun-title-dot-light">标准数据格式</view> |
||||
</view> |
||||
<view class="qiun-bg-white qiun-padding"> |
||||
<textarea class="qiun-textarea" auto-height="true" maxlength="-1" v-model="textarea" /> |
||||
</view> |
||||
<view class="qiun-text-tips">Tips:修改后点击更新图表</view> |
||||
<button class="qiun-button" @tap="changeData()">更新图表</button> |
||||
<!--#endif--> |
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
import uCharts from '@/js_sdk/u-charts/u-charts/u-charts.js'; |
||||
import { isJSON } from '@/common/checker.js'; |
||||
|
||||
var _self; |
||||
var canvaLineA = null; |
||||
export default { |
||||
props: { |
||||
chartData: { |
||||
type: Array, |
||||
default: [] |
||||
} |
||||
}, |
||||
|
||||
data() { |
||||
return { |
||||
cWidth: '', |
||||
cHeight: '', |
||||
pixelRatio: 1, |
||||
textarea: '' |
||||
} |
||||
}, |
||||
created() { |
||||
_self = this; |
||||
//#ifdef MP-ALIPAY |
||||
uni.getSystemInfo({ |
||||
success: function (res) { |
||||
if (res.pixelRatio > 1) { |
||||
//正常这里给2就行,如果pixelRatio=3性能会降低一点 |
||||
//_self.pixelRatio =res.pixelRatio; |
||||
_self.pixelRatio = 2; |
||||
} |
||||
} |
||||
}); |
||||
//#endif |
||||
this.cWidth = uni.upx2px(650); |
||||
this.cHeight = uni.upx2px(500); |
||||
console.log('chartData', this.chartData) |
||||
}, |
||||
watch: { |
||||
chartData: { |
||||
handler(newVal, oldVal) { |
||||
console.log('深度监听', newVal, oldVal) |
||||
this.chartData = newVal |
||||
this.getServerData() |
||||
}, |
||||
deep: true |
||||
} |
||||
}, |
||||
methods: { |
||||
getServerData() { |
||||
if (this.chartData) { |
||||
let LineA = { |
||||
series: [{ |
||||
name: '交易时段分布', data: this.chartData |
||||
}] |
||||
} |
||||
_self.textarea = JSON.stringify(LineA); |
||||
console.log('-----------------------') |
||||
console.log('_self.textarea', _self.textarea) |
||||
console.log('LineA', LineA) |
||||
console.log('-----------------------') |
||||
_self.showLineA("canvasLineA", LineA); |
||||
} |
||||
}, |
||||
formatDateTime(timeStamp) { |
||||
var date = new Date(); |
||||
date.setTime(timeStamp); |
||||
|
||||
var m = date.getMonth() + 1; |
||||
m = m < 10 ? ('0' + m) : m; |
||||
var d = date.getDate(); |
||||
d = d < 10 ? ('0' + d) : d; |
||||
|
||||
return m + '-' + d |
||||
}, |
||||
showLineA(canvasId, chartData) { |
||||
canvaLineA = new uCharts({ |
||||
$this: _self, |
||||
canvasId: canvasId, |
||||
type: 'area', |
||||
fontSize: 11, |
||||
padding: [15, 20, 0, 15], |
||||
legend: false, |
||||
dataLabel: true, |
||||
dataPointShape: true, |
||||
background: '#FFFFFF', |
||||
pixelRatio: _self.pixelRatio, |
||||
// categories: chartData.categories, |
||||
series: chartData.series, |
||||
animation: true, |
||||
xAxis: { |
||||
type: 'grid', |
||||
gridColor: '#CCCCCC', |
||||
gridType: 'dash', |
||||
dashLength: 8, |
||||
boundaryGap: 'justify', |
||||
splitNumber: 5, |
||||
format: (val) => { |
||||
// console.log('----', val, '-----') |
||||
// console.log('----', this.formatDateTime(val, 'str'), '-----') |
||||
return this.formatDateTime(val) } |
||||
}, |
||||
yAxis: { |
||||
gridType: 'dash', |
||||
gridColor: '#CCCCCC', |
||||
dashLength: 8, |
||||
splitNumber: 5, |
||||
format: (val) => { return val + '单' } |
||||
}, |
||||
width: _self.cWidth * _self.pixelRatio, |
||||
height: _self.cHeight * _self.pixelRatio, |
||||
extra: { |
||||
area: { |
||||
type: 'curve', |
||||
addLine: true, |
||||
gradient: true |
||||
} |
||||
} |
||||
}); |
||||
|
||||
}, |
||||
touchLineA(e) { |
||||
var that = this |
||||
canvaLineA.showToolTip(e, { |
||||
format: function (item, category) { |
||||
console.log(' item.data', item.data) |
||||
return that.formatDateTime(item.data[0])+' ' + item.data[1] + '单 ' + '交易金额' + item.data[2] + '元' |
||||
} |
||||
}); |
||||
}, |
||||
changeData() { |
||||
if (isJSON(_self.textarea)) { |
||||
let newdata = JSON.parse(_self.textarea); |
||||
canvaLineA.updateData({ |
||||
series: newdata.series, |
||||
categories: newdata.categories |
||||
}); |
||||
} else { |
||||
uni.showToast({ |
||||
title: '数据格式错误', |
||||
image: '../../../static/images/alert-warning.png' |
||||
}) |
||||
} |
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style scoped> |
||||
/*样式的width和height一定要与定义的cWidth和cHeight相对应*/ |
||||
.qiun-charts { |
||||
width: 640upx; |
||||
height: 500rpx; |
||||
background-color: #ffffff; |
||||
} |
||||
|
||||
.charts { |
||||
width: 640upx; |
||||
height: 500rpx; |
||||
background-color: #ffffff; |
||||
} |
||||
</style> |
@ -0,0 +1,193 @@ |
||||
<template> |
||||
<view class="qiun-columns"> |
||||
<!--#ifdef H5 --> |
||||
<view class="qiun-bg-white qiun-title-bar qiun-common-mt"> |
||||
<view class="qiun-title-dot-light">页面地址</view> |
||||
</view> |
||||
<view class="qiun-bg-white qiun-padding"> |
||||
<text>pages/basic/area/time</text> |
||||
</view> |
||||
<!--#endif--> |
||||
<view class="qiun-bg-white qiun-title-bar qiun-common-mt"> |
||||
<view class="qiun-title-dot-light">单量</view> |
||||
</view> |
||||
<view class="qiun-charts"> |
||||
<!--#ifdef MP-ALIPAY --> |
||||
<canvas canvas-id="canvasLineA" id="canvasLineA" class="charts" :width="cWidth*pixelRatio" :height="cHeight*pixelRatio" |
||||
:style="{'width':cWidth+'px','height':cHeight+'px'}" @touchstart="touchLineA"></canvas> |
||||
<!--#endif--> |
||||
<!--#ifndef MP-ALIPAY --> |
||||
<canvas canvas-id="canvasLineA" id="canvasLineA" class="charts" @touchstart="touchLineA"></canvas> |
||||
<!--#endif--> |
||||
</view> |
||||
<!--#ifdef H5 --> |
||||
<view class="qiun-bg-white qiun-title-bar qiun-common-mt"> |
||||
<view class="qiun-title-dot-light">标准数据格式</view> |
||||
</view> |
||||
<view class="qiun-bg-white qiun-padding"> |
||||
<textarea class="qiun-textarea" auto-height="true" maxlength="-1" v-model="textarea" /> |
||||
</view> |
||||
<view class="qiun-text-tips">Tips:修改后点击更新图表</view> |
||||
<button class="qiun-button" @tap="changeData()">更新图表</button> |
||||
<!--#endif--> |
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
import uCharts from '@/js_sdk/u-charts/u-charts/u-charts.js'; |
||||
import { isJSON } from '@/common/checker.js'; |
||||
|
||||
var _self; |
||||
var canvaLineA = null; |
||||
export default { |
||||
props: { |
||||
chartData: { |
||||
type: Array, |
||||
default: [] |
||||
} |
||||
}, |
||||
|
||||
data() { |
||||
return { |
||||
cWidth: '', |
||||
cHeight: '', |
||||
pixelRatio: 1, |
||||
textarea: '' |
||||
} |
||||
}, |
||||
created() { |
||||
_self = this; |
||||
//#ifdef MP-ALIPAY |
||||
uni.getSystemInfo({ |
||||
success: function (res) { |
||||
if (res.pixelRatio > 1) { |
||||
//正常这里给2就行,如果pixelRatio=3性能会降低一点 |
||||
//_self.pixelRatio =res.pixelRatio; |
||||
_self.pixelRatio = 2; |
||||
} |
||||
} |
||||
}); |
||||
//#endif |
||||
this.cWidth = uni.upx2px(650); |
||||
this.cHeight = uni.upx2px(500); |
||||
console.log('chartData', this.chartData) |
||||
}, |
||||
watch: { |
||||
chartData: { |
||||
handler(newVal, oldVal) { |
||||
console.log('深度监听', newVal, oldVal) |
||||
this.chartData = newVal |
||||
this.getServerData() |
||||
}, |
||||
deep: true |
||||
} |
||||
}, |
||||
methods: { |
||||
getServerData() { |
||||
if (this.chartData) { |
||||
let LineA = { |
||||
series: [{ |
||||
name: '交易时段分布', data: this.chartData |
||||
}] |
||||
} |
||||
_self.textarea = JSON.stringify(LineA); |
||||
console.log('-----------------------') |
||||
console.log('_self.textarea', _self.textarea) |
||||
console.log('LineA', LineA) |
||||
console.log('-----------------------') |
||||
_self.showLineA("canvasLineA", LineA); |
||||
} |
||||
}, |
||||
formatDateTime(timeStr) { |
||||
console.log('-----------------------') |
||||
console.log('timeStr', timeStr) |
||||
console.log('-----------------------') |
||||
return (timeStr > 0 ? timeStr.toFixed(0) : 0) + ':00' |
||||
}, |
||||
showLineA(canvasId, chartData) { |
||||
canvaLineA = new uCharts({ |
||||
$this: _self, |
||||
canvasId: canvasId, |
||||
type: 'area', |
||||
fontSize: 11, |
||||
padding: [15, 20, 0, 15], |
||||
legend: false, |
||||
dataLabel: true, |
||||
dataPointShape: true, |
||||
background: '#FFFFFF', |
||||
pixelRatio: _self.pixelRatio, |
||||
// categories: chartData.categories, |
||||
series: chartData.series, |
||||
animation: true, |
||||
xAxis: { |
||||
type: 'grid', |
||||
gridColor: '#CCCCCC', |
||||
gridType: 'dash', |
||||
dashLength: 8, |
||||
boundaryGap: 'justify', |
||||
splitNumber: 5, |
||||
format: (val) => { |
||||
// console.log('----', val, '-----') |
||||
// console.log('----', this.formatDateTime(val, 'str'), '-----') |
||||
return this.formatDateTime(val) } |
||||
}, |
||||
yAxis: { |
||||
gridType: 'dash', |
||||
gridColor: '#CCCCCC', |
||||
dashLength: 8, |
||||
splitNumber: 5, |
||||
format: (val) => { return val + '单' } |
||||
}, |
||||
width: _self.cWidth * _self.pixelRatio, |
||||
height: _self.cHeight * _self.pixelRatio, |
||||
extra: { |
||||
area: { |
||||
type: 'curve', |
||||
addLine: true, |
||||
gradient: true |
||||
} |
||||
} |
||||
}); |
||||
|
||||
}, |
||||
touchLineA(e) { |
||||
var that = this |
||||
canvaLineA.showToolTip(e, { |
||||
format: function (item, category) { |
||||
console.log(' item.data', item.data) |
||||
return (item.data[0] + ':00 ') + item.data[1] + '单 ' + '交易金额' + item.data[2] + '元' |
||||
} |
||||
}); |
||||
}, |
||||
changeData() { |
||||
if (isJSON(_self.textarea)) { |
||||
let newdata = JSON.parse(_self.textarea); |
||||
canvaLineA.updateData({ |
||||
series: newdata.series, |
||||
categories: newdata.categories |
||||
}); |
||||
} else { |
||||
uni.showToast({ |
||||
title: '数据格式错误', |
||||
image: '../../../static/images/alert-warning.png' |
||||
}) |
||||
} |
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style scoped> |
||||
/*样式的width和height一定要与定义的cWidth和cHeight相对应*/ |
||||
.qiun-charts { |
||||
width: 640upx; |
||||
height: 500rpx; |
||||
background-color: #ffffff; |
||||
} |
||||
|
||||
.charts { |
||||
width: 640upx; |
||||
height: 500rpx; |
||||
background-color: #ffffff; |
||||
} |
||||
</style> |
@ -0,0 +1,39 @@ |
||||
<template> |
||||
<view class="page-content my-bg"> |
||||
<cu-custom bgColor="bg-gradual-pink" :isBack="true"> |
||||
<block slot="backText">返回</block> |
||||
<block slot="content">列表</block> |
||||
</cu-custom> |
||||
<view class=""> |
||||
<analysis-card /> |
||||
</view> |
||||
<view class="margin bg-white radius"> |
||||
<view class="margin"> |
||||
<area-time /> |
||||
</view> |
||||
</view> |
||||
|
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
import areaTime from '../../area-time.vue' |
||||
import analysisCard from '../../analysis-card.vue' |
||||
export default { |
||||
components: { |
||||
areaTime,analysisCard |
||||
}, |
||||
data() { |
||||
return { |
||||
|
||||
} |
||||
}, |
||||
methods: { |
||||
|
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style> |
||||
|
||||
</style> |
@ -0,0 +1,179 @@ |
||||
// 昨日经营分析 |
||||
<template> |
||||
<view class="page-content my-bg"> |
||||
<cu-custom bgColor="bg-main-oil" :isBack="true"> |
||||
<block slot="backText">返回</block> |
||||
<block slot="content">日报</block> |
||||
</cu-custom> |
||||
<view class="card-container"> |
||||
<view class="cu-capsule-container"> |
||||
<view class="cu-capsule round bg-white solid line-gray" @tap="showModal"> |
||||
<view class='cu-tag bg-white'> |
||||
{{selDate}} |
||||
</view> |
||||
<view class="cu-tag bg-white"> |
||||
<text class='cuIcon-usefullfill rr90 padding-left-xs'></text> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
|
||||
<analysis-card @showModal="showModal" :basicData="basicData" /> |
||||
</view> |
||||
<view class="margin bg-white radius"> |
||||
<view class="margin"> |
||||
<area-time :chartData="detailData" /> |
||||
</view> |
||||
</view> |
||||
<view class="cu-modal bottom-modal" style="z-index: 999999;" :class="dialogModal"> |
||||
<view class="cu-dialog"> |
||||
<view class="cu-bar bg-white "> |
||||
<view class="action text-blue" @tap="hideModal">取消</view> |
||||
<view class="content">选择日期</view> |
||||
<view class="action text-green" @tap="onConfirm">确定</view> |
||||
</view> |
||||
|
||||
<picker-view :value="value" style="min-height: 250upx;width: 100%;" @change="bindChange"> |
||||
<picker-view-column> |
||||
<view class="item" v-for="(item,index) in years" :key="index">{{item}}年</view> |
||||
</picker-view-column> |
||||
<picker-view-column> |
||||
<view class="item" v-for="(item,index) in months" :key="index">{{item}}月</view> |
||||
</picker-view-column> |
||||
<picker-view-column> |
||||
<view class="item" v-for="(item,index) in days" :key="index">{{item}}日</view> |
||||
</picker-view-column> |
||||
</picker-view> |
||||
|
||||
</view> |
||||
</view> |
||||
|
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
import areaTime from '../../area-time.vue' |
||||
import analysisCard from '../../analysis-card.vue' |
||||
import cloudSiteApi from '@/api/cloud-site.js' |
||||
export default { |
||||
components: { |
||||
areaTime, |
||||
analysisCard |
||||
}, |
||||
data: function() { |
||||
const date = new Date() |
||||
const years = [] |
||||
const year = date.getFullYear() |
||||
const months = [] |
||||
const month = date.getMonth() + 1 |
||||
const days = [] |
||||
const day = date.getDate() |
||||
for (let i = 2020; i <= date.getFullYear(); i++) { |
||||
years.push(i) |
||||
} |
||||
for (let i = 1; i <= month; i++) { |
||||
months.push(i) |
||||
} |
||||
for (let i = 1; i <= 31; i++) { |
||||
days.push(i) |
||||
} |
||||
return { |
||||
title: 'picker-view', |
||||
years: [2020], |
||||
year: 2020, |
||||
months: months, |
||||
dialogModal: '', |
||||
month: month, |
||||
days: days, |
||||
day: day, |
||||
// value: [9999, month - 1, day - 1], |
||||
value: [0, month - 1, day - 1], |
||||
selDate: year + '-' + month + '-' + day, |
||||
detailData: [], |
||||
basicData: { |
||||
totalAccount: 0, |
||||
totalAmout: 0, |
||||
totalCount: 0 |
||||
} |
||||
} |
||||
}, |
||||
|
||||
onPullDownRefresh() { |
||||
this.onConfirm() |
||||
// this.getUserInfo() |
||||
// uni.stopPullDownRefresh(); |
||||
}, |
||||
onShow() { |
||||
this.formatDate() |
||||
this.getDaily() |
||||
}, |
||||
methods: { |
||||
getDaily() { |
||||
cloudSiteApi.getAnyDay(this.selDate).then(res => { |
||||
uni.stopPullDownRefresh(); |
||||
if (res.code === 20000) { |
||||
this.basicData = res.data.basicData |
||||
this.detailData = res.data.detailData |
||||
} |
||||
}) |
||||
}, |
||||
onConfirm() { |
||||
this.hideModal() |
||||
this.formatDate() |
||||
this.getDaily() |
||||
}, |
||||
formatDate() { |
||||
var m = '' |
||||
var d = '' |
||||
if (this.month < 10) { |
||||
m = '0' + this.month |
||||
} else { |
||||
m = this.month |
||||
} |
||||
if (this.day < 10) { |
||||
d = '0' + this.day |
||||
} else { |
||||
d = this.day |
||||
} |
||||
this.selDate = this.year + '-' + m + '-' + d |
||||
this.selDate = this.selDate.toString() |
||||
console.log(this.selDate) |
||||
}, |
||||
showModal(e) { |
||||
this.dialogModal = 'show' |
||||
}, |
||||
hideModal(e) { |
||||
this.dialogModal = null |
||||
}, |
||||
bindChange: function(e) { |
||||
const val = e.detail.value |
||||
this.year = this.years[val[0]] |
||||
this.month = this.months[val[1]] |
||||
this.day = this.days[val[2]] |
||||
console.log('年鱼儿', this.year, this.month, this.day) |
||||
|
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style scoped> |
||||
.card-container { |
||||
position: relative; |
||||
|
||||
} |
||||
|
||||
.card-container .cu-capsule { |
||||
margin: auto; |
||||
margin-bottom: -40px; |
||||
|
||||
} |
||||
|
||||
.cu-capsule-container { |
||||
min-width: 100%; |
||||
text-align: center; |
||||
} |
||||
|
||||
.rr90 { |
||||
rotate: 180deg; |
||||
} |
||||
</style> |
@ -0,0 +1,180 @@ |
||||
// 昨日经营分析 |
||||
<template> |
||||
<view class="page-content my-bg"> |
||||
<cu-custom bgColor="bg-main-oil" :isBack="true"> |
||||
<block slot="backText">返回</block> |
||||
<block slot="content">月报</block> |
||||
</cu-custom> |
||||
<view class="card-container"> |
||||
<view class="cu-capsule-container"> |
||||
<view class="cu-capsule round bg-white solid line-gray" @tap="showModal"> |
||||
<view class='cu-tag bg-white'> |
||||
{{selDate}} |
||||
</view> |
||||
<view class="cu-tag bg-white"> |
||||
<text class='cuIcon-usefullfill rr90 padding-left-xs'></text> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
|
||||
<analysis-card @showModal="showModal" :basicData="basicData" /> |
||||
<view class="margin bg-white radius"> |
||||
<view class="margin" style="position: relative;z-index: 1;"> |
||||
<area-month :chartData="detailData" /> |
||||
</view> |
||||
</view> |
||||
<view class="cu-modal bottom-modal" style="z-index: 999999;" :class="dialogModal"> |
||||
<view class="cu-dialog"> |
||||
<view class="cu-bar bg-white "> |
||||
<view class="action text-blue" @tap="hideModal">取消</view> |
||||
<view class="content">选择日期</view> |
||||
<view class="action text-green" @tap="onConfirm">确定</view> |
||||
</view> |
||||
<picker-view :value="value" style="min-height: 250upx;width: 100%;" @change="bindChange"> |
||||
<picker-view-column> |
||||
<view class="item" v-for="(item,index) in years" :key="index">{{item}}年</view> |
||||
</picker-view-column> |
||||
<picker-view-column> |
||||
<view class="item" v-for="(item,index) in months" :key="index">{{item}}月</view> |
||||
</picker-view-column> |
||||
</picker-view> |
||||
|
||||
</view> |
||||
</view> |
||||
|
||||
</view> |
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
import areaMonth from '../../area-month.vue' |
||||
import analysisCard from '../../analysis-card.vue' |
||||
import cloudSiteApi from '@/api/cloud-site.js' |
||||
export default { |
||||
components: { |
||||
areaMonth, |
||||
analysisCard |
||||
}, |
||||
data: function() { |
||||
const date = new Date() |
||||
const years = [] |
||||
const year = date.getFullYear() |
||||
const months = [] |
||||
const month = date.getMonth() + 1 |
||||
const days = [] |
||||
const day = date.getDate() - 1 |
||||
for (let i = 2020; i <= date.getFullYear(); i++) { |
||||
years.push(i) |
||||
} |
||||
for (let i = 1; i <= month; i++) { |
||||
months.push(i) |
||||
} |
||||
for (let i = 1; i <= 31; i++) { |
||||
days.push(i) |
||||
} |
||||
return { |
||||
title: 'picker-view', |
||||
years: [2020], |
||||
year: 2020, |
||||
months: months, |
||||
dialogModal: '', |
||||
month: month, |
||||
days: days, |
||||
day: day, |
||||
// value: [9999, month - 1, day - 1], |
||||
value: [0, month - 1, day - 1], |
||||
selDate: year + '-' + month, |
||||
detailData: [], |
||||
basicData: { |
||||
totalAccount: 0, |
||||
totalAmout: 0, |
||||
totalCount: 0 |
||||
} |
||||
} |
||||
}, |
||||
|
||||
onPullDownRefresh() { |
||||
this.onConfirm() |
||||
// this.getUserInfo() |
||||
// uni.stopPullDownRefresh(); |
||||
}, |
||||
onShow() { |
||||
this.formatDate() |
||||
this.getMonthly() |
||||
var date = '2019-9-5'; |
||||
date = date.substring(0, 19); |
||||
date = date.replace(/-/g, '/'); |
||||
var timestamp = new Date(date).getTime(); |
||||
console.log(timestamp) |
||||
}, |
||||
methods: { |
||||
getMonthly() { |
||||
cloudSiteApi.getAnyMonth(this.selDate+'-5').then(res => { |
||||
uni.stopPullDownRefresh() |
||||
if (res.code === 20000) { |
||||
this.basicData = res.data.basicData |
||||
res.data.detailData.forEach(item => { |
||||
var date = item[0] |
||||
date = date.substring(0, 19); |
||||
date = date.replace(/-/g, '/'); |
||||
item[0] = new Date(date).getTime(); |
||||
}) |
||||
this.detailData = res.data.detailData |
||||
} |
||||
}) |
||||
}, |
||||
onConfirm() { |
||||
this.hideModal() |
||||
this.formatDate() |
||||
this.getMonthly() |
||||
}, |
||||
formatDate() { |
||||
var m = '' |
||||
var d = '' |
||||
if (this.month < 10) { |
||||
m = '0' + this.month |
||||
} else { |
||||
m = this.month |
||||
} |
||||
this.selDate = this.year + '-' + m |
||||
console.log(this.selDate) |
||||
}, |
||||
showModal(e) { |
||||
this.dialogModal = 'show' |
||||
}, |
||||
hideModal(e) { |
||||
this.dialogModal = null |
||||
}, |
||||
bindChange: function(e) { |
||||
const val = e.detail.value |
||||
this.year = this.years[val[0]] |
||||
this.month = this.months[val[1]] |
||||
this.day = this.days[val[2]] |
||||
console.log('年鱼儿', this.year, this.month, this.day) |
||||
|
||||
} |
||||
} |
||||
} |
||||
</script> |
||||
|
||||
<style scoped> |
||||
.card-container { |
||||
position: relative; |
||||
|
||||
} |
||||
|
||||
.card-container .cu-capsule { |
||||
margin: auto; |
||||
margin-bottom: -40px; |
||||
|
||||
} |
||||
|
||||
.cu-capsule-container { |
||||
min-width: 100%; |
||||
text-align: center; |
||||
} |
||||
|
||||
.rr90 { |
||||
rotate: 180deg; |
||||
} |
||||
</style> |
@ -0,0 +1,236 @@ |
||||
<template> |
||||
<view class="page-content my-bg"> |
||||
<cu-custom class="main-topbar bg-main-oil" bgColor="bg-main-oil" :isBack="true"> |
||||
<block slot="content">经营分析</block> |
||||
<block slot="backText" class="back-text">返回</block> |
||||
</cu-custom> |
||||
|
||||
<view class="main-money bg-main-oil"> |
||||
<view class="padding-xs flex align-center"> |
||||
<view class="flex-sub text-center padding-top-lg"> |
||||
<view class="txet-xxs"> |
||||
<text class="text-white">昨日交易金额(元)</text> |
||||
</view> |
||||
<view class=" text-sl padding padding-top-xs"><text class="text-white">¥{{basicData.totalAmout|numberFilter}}</text></view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
|
||||
<view class="bg-main-oil bg-main-color main-money"> |
||||
|
||||
</view> |
||||
<view class="bg-white radius margin-left margin-right to-top"> |
||||
<view class=" flex "> |
||||
<view class="padding text-center flex-sub" @tap="routerTo('/pages/orderList/dailyOrder/dailyOrder')"> |
||||
<text>交易笔数</text> |
||||
<view class="padding-sm"> |
||||
<text class="oil-main-color">{{basicData.totalCount}}</text> |
||||
</view> |
||||
<!-- <button class="cu-btn bg-main-oil text-white text-sm "> |
||||
查看明细 |
||||
</button> --> |
||||
</view> |
||||
<view class="padding text-center flex-sub"> |
||||
<text>顾客数</text> |
||||
<view class="padding-sm"> |
||||
<text class="oil-main-color">{{basicData.totalAccount}}</text> |
||||
</view> |
||||
<!-- <button class="cu-btn bg-main-oil text-white text-sm "> |
||||
查看明细 |
||||
</button> --> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
<view class="margin"> |
||||
<view class="cu-list menu-avatar radius"> |
||||
<view class="cu-item" @tap="routerTo('/packageChart/operation-analysis/analysis/daily')"> |
||||
<view class="cu-avatar lg" :style="'background-image: url('+mainURL+'rb.png)'"> |
||||
</view> |
||||
<view class="content "> |
||||
<text>经营分析——日报</text> |
||||
</view> |
||||
<view class="action"> |
||||
<button class="cu-btn padding-left-xs padding-right-xs bg-white"> |
||||
<text class="cuIcon-right"></text> |
||||
</button> |
||||
</view> |
||||
|
||||
</view> |
||||
<view class="cu-item" @tap="routerTo('/packageChart/operation-analysis/analysis/monthly')"> |
||||
<view class="cu-avatar lg" :style="'background-image: url('+mainURL+'yb.png)'"> |
||||
</view> |
||||
<view class="content"> |
||||
<text> 经营分析——月报</text> |
||||
</view> |
||||
<view class="action "> |
||||
<button class="cu-btn padding-left-xs padding-right-xs bg-white" @tap="routerTo('path')"> |
||||
<text class="cuIcon-right"></text> |
||||
</button> |
||||
</view> |
||||
|
||||
</view> |
||||
</view> |
||||
</view> |
||||
</view> |
||||
</template> |
||||
|
||||
<script> |
||||
import staffApi from '@/api/staff.js' |
||||
import cloudSiteApi from '@/api/cloud-site.js' |
||||
export default { |
||||
data() { |
||||
|
||||
return { |
||||
mainURL: this.global.mainURL, |
||||
basicData: { |
||||
totalAccount: 0, |
||||
totalAmout: 0, |
||||
totalCount: 0 |
||||
}, |
||||
scanUrl: '', |
||||
userMenu: uni.getStorageSync('userMenu'), |
||||
loginUser: uni.getStorageSync('loginUser'), |
||||
title: 'Hello', |
||||
cuIconList: [] |
||||
}; |
||||
}, |
||||
|
||||
onShow() { |
||||
this.getYesterday() |
||||
}, |
||||
onPullDownRefresh() { |
||||
this.getYesterday() |
||||
}, |
||||
filters: { |
||||
|
||||
numberFilter(value) { |
||||
if (value) { |
||||
value = value - 1 + 1 |
||||
return value.toFixed(2) |
||||
} else { |
||||
return '0.00' |
||||
} |
||||
|
||||
} |
||||
}, |
||||
methods: { |
||||
getSiteInfo() { |
||||
cloudSiteApi.getSiteDetail().then(res => { |
||||
if (res.code === 20000) { |
||||
this.site = res.data.site |
||||
this.oilList = res.data.oil |
||||
uni.setStorage({ |
||||
key: 'oilSite', |
||||
data: res.data.site |
||||
}) |
||||
} |
||||
}) |
||||
}, |
||||
getYesterday() { |
||||
cloudSiteApi.getYesterday().then(res => { |
||||
uni.stopPullDownRefresh() |
||||
if (res.code === 20000) { |
||||
this.basicData = res.data |
||||
} |
||||
}) |
||||
}, |
||||
scanQr() { |
||||
var that = this |
||||
uni.scanCode({ |
||||
onlyFromCamera: true, |
||||
success: function(res) { |
||||
console.log('条码类型:' + res.scanType); |
||||
console.log('条码内容:' + res.result); |
||||
uni.setStorageSync('qrCode', res.result) |
||||
uni.navigateTo({ |
||||
url: that.scanUrl, |
||||
fail: (err) => { |
||||
console.log(err) |
||||
}, |
||||
success: (res) => { |
||||
console.log('chengg', res) |
||||
} |
||||
}) |
||||
} |
||||
}) |
||||
}, |
||||
// 方便开发 |
||||
// scanQr() { |
||||
// uni.setStorageSync('qrCode', 'XM&1299257961238990848') |
||||
// uni.navigateTo({ |
||||
// url: '/pages/stationDetail/stationDetail', |
||||
// fail: (err) => { |
||||
// console.log(err) |
||||
// }, |
||||
// success: (res) => { |
||||
// console.log('chengg', res) |
||||
// } |
||||
// }) |
||||
|
||||
// }, |
||||
routerTo(url, name) { |
||||
|
||||
uni.navigateTo({ |
||||
url: url |
||||
}) |
||||
} |
||||
} |
||||
}; |
||||
</script> |
||||
|
||||
<style scoped> |
||||
.bottom-bar { |
||||
position: relative; |
||||
padding-top: 50px; |
||||
margin-bottom: 0; |
||||
margin-top: 0; |
||||
} |
||||
|
||||
.bottom-bar-fixed { |
||||
position: fixed; |
||||
bottom: 0; |
||||
padding-top: 70rpx; |
||||
width: 100%; |
||||
} |
||||
|
||||
.main-money { |
||||
position: relative; |
||||
z-index: 1; |
||||
} |
||||
|
||||
.van-tag { |
||||
display: inline-block; |
||||
padding: 0.3rem 0.4rem; |
||||
position: absolute; |
||||
right: 1px; |
||||
font-size: 12px; |
||||
top: 25%; |
||||
background-color: #b9ffca; |
||||
border-radius: 10rem 0 0 10rem; |
||||
border-color: transparent; |
||||
} |
||||
|
||||
.bg-main-color { |
||||
min-height: 160rpx; |
||||
} |
||||
|
||||
.to-top { |
||||
position: relative; |
||||
top: -140rpx; |
||||
z-index: 1; |
||||
} |
||||
|
||||
.cu-list { |
||||
position: relative; |
||||
top: -140rpx; |
||||
z-index: 1; |
||||
} |
||||
|
||||
.cu-list.grid>.cu-item [class*=cuIcon] { |
||||
font-size: 75rpx; |
||||
} |
||||
|
||||
.cu-avatar { |
||||
background-color: transparent; |
||||
} |
||||
</style> |
Loading…
Reference in new issue