<template>
  <div>
    <div id="viewData"></div>
  </div>
</template>

<script>
import * as G2 from '@antv/g2'
import { getLineDispatchQuantity } from '@/api/manage'

const DataSet = require('@antv/data-set')

export default {
  name: 'G2Line',
  data () {
    return {
      viewRecords: [],
      chart: null
    }
  },
  mounted () {
    this.getLineDispatchQuantity()
    this.createView()
  },
  methods: {
    getLineDispatchQuantity (groupName, type = 'day', startTime, endTime) {
      getLineDispatchQuantity({
        'groupName': groupName,
        'type': type,
        'startTime': startTime,
        'endTime': endTime
      }).then(res => {
        this.viewCharts(res.data)
      })
    },
    viewCharts (viewRecords, type = 'day') {
      var ds = new DataSet()
      console.log(this.lineDispatchQuantity)
      var dv = ds.createView().source(viewRecords)
      dv.transform({
        type: 'fold',
        fields: ['success', 'fail'], // 展开字段集
        key: 'name',
        value: 'viewTotal',
        retains: ['total', 'createDt']
      })

      console.log(dv.rows)
      this.chart.source(dv, {
        date: {
          type: 'cat'
        }
      })
      this.chart.axis('viewTotal', {
        label: {
          textStyle: {
            fill: '#aaaaaa'
          }
        }
      })
      this.chart.tooltip({
        crosshairs: {
          type: 'line'
        }
      })
      this.chart.line().position('createDt*viewTotal').color('name', ['#1890ff', '#c28c62']).shape('smooth')
      this.chart.point().position('createDt*viewTotal').color('name', ['#1890ff', '#c28c62']).size(4).shape('circle').style({
        stroke: '#fff',
        lineWidth: 1
      })

      this.chart.render()
    },
    createView () {
      this.chart = new G2.Chart({
        container: 'viewData',
        forceFit: true,
        height: 410,
        padding: [20, 90, 60, 50]
      })
    }
  }
}
</script>