纸通宝小程序
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 

170 lines
4.7 KiB

// pages/moment/price/index.js
import { getCategoryList, getCategoryPrice } from "../../../../api/moment"
const util = require('../../../../utils/util')
const storage = require('../../../../utils/storage')
const event = require('../../../../utils/event')
var wxCharts = require('../../../libs/wxcharts')
const app = getApp()
var lineChart = null
const colors = ['#FF4229', '#FFAD2A', '#297BFF', '#29FF46', '#AD29FF']
Page({
/**
* 页面的初始数据
*/
data: {
height: app.globalData.fragmentHeight,
chartList: null,
idList: '',
loading: true,
requesting: false,
finished: false,
orderList: [],
form: { pageNum: 1 ,
pageSize:15}
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
event.on('EventMessage', this, this.onEvent)
var cateIds = storage.get('cateIdList' + app.globalData.userInfo.userId)
if(!util.isEmpty(cateIds)){
this.data.idList = cateIds
this.fetchChartList()
} else {
wx.showLoading({ title: '加载中', mask: true })
getCategoryList().then(result => {
this.data.idList = ''
var size = result.data.records.length >= 5 ? 5 : result.data.records.length
for (let index = 0; index < size; index++) {
if(util.isEmpty(this.data.idList)){
this.data.idList = result.data.records[index].id
} else {
this.data.idList += ',' + result.data.records[index].id
}
}
storage.put('cateIdList' + app.globalData.userInfo.userId, this.data.idList)
this.fetchChartList()
wx.hideLoading()
}).catch(err => {
//异常回调
wx.hideLoading()
})
}
},
onEvent: function (message) {
if (message.what == 502) {
var cateIds = storage.get('cateIdList' + app.globalData.userInfo.userId)
if(!util.isEmpty(cateIds)){
this.data.idList = cateIds
}
this.fetchChartList()
}
},
//***********************************fetchChartList*****************************************//
fetchChartList: function(){
getCategoryPrice({idList: this.data.idList}).then(result => {
if(result.data.length <= 0){
return
}
var respList = result.data
var categoriesList = []
var serieList = []
var min = Number.MAX_VALUE
var max = 0
for (let index = 0; index < respList.length; index++) {
const element = respList[index]
var dataList = []
if(index == 0){
element.list.forEach(item => {
categoriesList.push(item.data.substring(5))
// var price = math.times(item.unitPrice, 1000)
var price = item.unitPrice
if(min > price){
min = price
}
if(max < price){
max = price
}
dataList.push(price)
})
} else {
element.list.forEach(item => {
var price = item.unitPrice
if(min > price){
min = price
}
dataList.push(price)
})
}
var series = {
name: element.name,
data: dataList,
format: function (val, name) {
return val + '元/吨'
},
color: colors[index]
}
serieList.push(series)
}
this.setData({ chartList: { categories: categoriesList, serieList: serieList } })
// if(min < 50){
// min = 50
// }
this.initChart(min - 50, max + 50)
})
},
touchHandler: function (e) {
if(lineChart){
lineChart.scrollStart(e)
}
},
moveHandler: function (e) {
if(lineChart){
lineChart.scroll(e)
}
},
touchEndHandler: function (e) {
if(lineChart){
lineChart.scrollEnd(e)
lineChart.showToolTip(e, {
format: function (item, category) {
return category + ' ' + item.name + ':' + item.data
}
})
}
},
initChart: function (min, max) {
lineChart = new wxCharts({
canvasId: 'lineChart',
type: 'line',
categories: this.data.chartList.categories,
animation: false,
title: { name: '纸品单价 (元/吨)' },
series: this.data.chartList.serieList,
xAxis: { disableGrid: false },
yAxis: {
// title: '纸品单价 (元/吨)',
format: function (val) {
return val
},
min,
max
},
width: 350,
height: 200,
dataLabel: false,
dataPointShape: 'circle',
enableScroll: false,
extra: { lineStyle: 'curve' }
}, this)
},
toPaperList: function(){
wx.navigateTo({ url: '/pages/moment/paper/index' })
},
onUnload: function(){
event.remove('EventMessage', this)
}
})