import React, { Component } from "react"; import { Row, Col, Tabs, Table, Divider, Spin } from "antd"; import { ContainerOutlined, BlockOutlined, SmileOutlined, TagsOutlined, GlobalOutlined, FullscreenOutlined, DingtalkOutlined, CarryOutOutlined } from "@ant-design/icons"; import { stores_Context } from "../config"; import { Line, Pie } from "@ant-design/charts"; import { observer } from "mobx-react"; import * as config from "../config"; import { NavLink } from "react-router-dom"; import * as comm from "../utils/commons"; import { utils, writeFileXLSX } from "xlsx"; import DateGroupRadio from '../components/DateGroupRadio'; import SearchForm from './../components/search/SearchForm'; class Orders extends Component { static contextType = stores_Context; constructor(props) { super(props); } format_data(data) { const { date_picker_store, orders_store } = this.context; const result = { dataSource: [], columns: [] }; if (!comm.empty(data)) { const ordercountTotal1 = data.ordercountTotal1; const ordercountTotal2 = data.ordercountTotal2; if (date_picker_store.start_date_cp && date_picker_store.end_date_cp) { // 有比较的数据 result.columns = [ { title: "", children: [ { title: (
{date_picker_store.start_date.format(config.DATE_FORMAT)}~{date_picker_store.end_date.format(config.DATE_FORMAT)}
{date_picker_store.start_date_cp.format(config.DATE_FORMAT)}~{date_picker_store.end_date_cp.format(config.DATE_FORMAT)}
), dataIndex: "OrderType", render: (text, record) => {text}, }, ], }, { title: "数量", children: [ { title: comm.show_vs_tag(ordercountTotal1.OrderCount_vs, ordercountTotal1.OrderCount_diff, ordercountTotal1.OrderCount, ordercountTotal2.OrderCount), dataIndex: "OrderCount", }, ], }, { title: "成交数", children: [ { title: comm.show_vs_tag(ordercountTotal1.CJCount_vs, ordercountTotal1.CJCount_diff, ordercountTotal1.CJCount, ordercountTotal2.CJCount), dataIndex: "CJCount", }, ], }, { title: "成交人数", children: [ { title: comm.show_vs_tag(ordercountTotal1.CJPersonNum_vs, ordercountTotal1.CJPersonNum_diff, ordercountTotal1.CJPersonNum, ordercountTotal2.CJPersonNum), dataIndex: "CJPersonNum", }, ], }, { title: "成交率", children: [ { title: comm.show_vs_tag(ordercountTotal1.CJrate_vs, ordercountTotal1.CJrate_diff, ordercountTotal1.CJrate, ordercountTotal2.CJrate), dataIndex: "CJrate", }, ], }, { title: "成交毛利(预计)", children: [ { title: comm.show_vs_tag(ordercountTotal1.YJLY_vs, ordercountTotal1.YJLY_diff, ordercountTotal1.YJLY, ordercountTotal2.YJLY), dataIndex: "YJLY", }, ], }, { title: "单个订单价值", children: [ { title: comm.show_vs_tag(ordercountTotal1.Ordervalue_vs, ordercountTotal1.Ordervalue_diff, ordercountTotal1.Ordervalue, ordercountTotal2.Ordervalue), dataIndex: "Ordervalue", }, ], }, ]; // 1.找出两个数组OrderType相同的数据做比较显示 2.找出两组数据OrderType都不相同的数据做显示 let has_same_type = false; // 数组1在数组2中是否找到相同的类型 for (const item of data.ordercount1) { has_same_type = false; // 数组1在数组2中相同的类型 for (const item2 of data.ordercount2) { if (item.OrderType === item2.OrderType) { has_same_type = true; result.dataSource.push({ key: item.key, OrderType: item.OrderType, OrderTypeSN: item.OrderTypeSN, OrderCount: comm.show_vs_tag(item.OrderCount_vs, item.OrderCount_diff, item.OrderCount, item2.OrderCount), CJCount: comm.show_vs_tag(item.CJCount_vs, item.CJCount_diff, item.CJCount, item2.CJCount), CJPersonNum: comm.show_vs_tag(item.CJPersonNum_vs, item.CJPersonNum_diff, item.CJPersonNum, item2.CJPersonNum), CJrate: comm.show_vs_tag(item.CJrate_vs, item.CJrate_diff, item.CJrate, item2.CJrate), YJLY: comm.show_vs_tag(item.YJLY_vs, item.YJLY_diff, item.YJLY, item2.YJLY), Ordervalue: comm.show_vs_tag(item.Ordervalue_vs, item.Ordervalue_diff, item.Ordervalue, item2.Ordervalue), }); } } // 数组1中不在数组2的类型 if (has_same_type === false) { result.dataSource.push({ key: item.key, OrderType: item.OrderType, OrderTypeSN: item.OrderTypeSN, OrderCount: comm.show_vs_tag(comm.formatPercent(item.OrderCount), item.OrderCount, item.OrderCount, 0), CJCount: comm.show_vs_tag(comm.formatPercent(item.CJCount), item.CJCount, item.CJCount, 0), CJPersonNum: comm.show_vs_tag(comm.formatPercent(item.CJPersonNum), item.CJPersonNum, item.CJPersonNum, 0), CJrate: comm.show_vs_tag(item.CJrate, item.CJrate, item.CJrate, 0), YJLY: comm.show_vs_tag(comm.formatPercent(item.YJLY), item.YJLY, item.YJLY, 0), Ordervalue: comm.show_vs_tag(comm.formatPercent(item.Ordervalue), item.Ordervalue, item.Ordervalue, 0), }); } } // 数组2中不在数组1的类型 for (const item2 of data.ordercount2) { has_same_type = false; for (const item of data.ordercount1) { if (item.OrderType === item2.OrderType) { has_same_type = true; } } if (has_same_type === false) { result.dataSource.push({ key: item2.key, OrderType: item2.OrderType, OrderTypeSN: item2.OrderTypeSN, OrderCount: comm.show_vs_tag(comm.formatPercent(-item2.OrderCount), -item2.OrderCount, 0, item2.OrderCount), CJCount: comm.show_vs_tag(comm.formatPercent(-item2.CJCount), -item2.CJCount, 0, item2.CJCount), CJPersonNum: comm.show_vs_tag(comm.formatPercent(-item2.CJPersonNum), -item2.CJPersonNum, 0, item2.CJPersonNum), CJrate: comm.show_vs_tag(-item2.CJrate, -item2.CJrate, 0, item2.CJrate), YJLY: comm.show_vs_tag(comm.formatPercent(-item2.YJLY), -item2.YJLY, 0, item2.YJLY), Ordervalue: comm.show_vs_tag(comm.formatPercent(-item2.Ordervalue), -item2.Ordervalue, 0, item2.Ordervalue), }); } } } else { result.columns = [ { title: "", children: [ { title: (
{date_picker_store.start_date.format(config.DATE_FORMAT)}~{date_picker_store.end_date.format(config.DATE_FORMAT)}
), dataIndex: "OrderType", render: (text, record) => {text}, }, ], }, { title: "数量", children: [{ title: ordercountTotal1.OrderCount, dataIndex: "OrderCount" }], sorter: (a, b) => b.OrderCount - a.OrderCount, }, { title: "成交数", children: [{ title: ordercountTotal1.CJCount, dataIndex: "CJCount" }], sorter: (a, b) => b.CJCount - a.CJCount, }, { title: "成交人数", children: [{ title: ordercountTotal1.CJPersonNum, dataIndex: "CJPersonNum" }], sorter: (a, b) => b.CJPersonNum - a.CJPersonNum, }, { title: "成交率", children: [{ title: ordercountTotal1.CJrate, dataIndex: "CJrate" }], sorter: (a, b) => parseInt(b.CJrate) - parseInt(a.CJrate), }, { title: "成交毛利(预计)", children: [{ title: ordercountTotal1.YJLY, dataIndex: "YJLY" }], sorter: (a, b) => parseFloat(b.YJLY.replace(/,/g, "")) - parseFloat(a.YJLY.replace(/,/g, "")), }, { title: "单个订单价值", children: [{ title: ordercountTotal1.Ordervalue, dataIndex: "Ordervalue" }], sorter: (a, b) => parseFloat(b.Ordervalue.replace(/,/g, "")) - parseFloat(a.Ordervalue.replace(/,/g, "")), }, ]; result.dataSource = data.ordercount1; } } return result; } render() { const { orders_store, date_picker_store } = this.context; const table_data = orders_store.orderCountData_Form ? this.format_data(orders_store.orderCountData_Form) : []; const data_source = orders_store.orderCountData ? orders_store.orderCountData : []; const avg_line_y = Math.round(orders_store.avgLine1); const pie_data = comm.empty(orders_store.orderCountData_Form) ? [] : orders_store.orderCountData_Form.ordercount1; // 饼图的显示 const pie_data2 = comm.empty(orders_store.orderCountData_Form) ? [] : orders_store.orderCountData_Form.ordercount2; const config = { data: data_source, padding: "auto", xField: "xField", yField: "yField", seriesField: "seriesField", // xAxis: { // type: "timeCat", // }, point: { size: 4, shape: "cicle", }, annotations: [ { type: "text", position: ["start", avg_line_y], content: avg_line_y, offsetX: -15, style: { fill: "#F4664A", textBaseline: "bottom", }, }, { type: "line", start: [-10, avg_line_y], end: ["max", avg_line_y], style: { stroke: "#F4664A", lineDash: [2, 2], }, }, ], label: {}, // 显示标签 legend: { itemValue: { formatter: (text, item) => { const items = data_source.filter(d => d.seriesField === item.value); // 按站点筛选 return items.length ? items.reduce((a, b) => a + b.yField, 0) : ""; // 计算总数 }, }, }, tooltip: { customItems: (originalItems) => { // process originalItems, return originalItems.map(ele => ({...ele, name: ele.data?.seriesField || ele.data?.xField})); }, title: (title, datum) => { let ret = title; switch (orders_store.lineChartXGroup) { case 'day': ret = `${title} ${comm.getWeek(datum.xField)}`; // 显示周几 break; default: break; } return ret; }, }, smooth: true, }; const pie_config = { appendPadding: 10, data: [], angleField: "OrderCount", colorField: "OrderType", radius: 0.8, label: { type: "outer", content: "{name} {value} \n {percentage}", }, legend: false, // 不显示图例 interactions: [ { type: "element-selected", }, { type: "element-active", }, ], }; const tableProps = { dataSource: table_data.dataSource, columns: table_data.columns, size: 'small', pagination: false, scroll: { x: '100%' }, loading: orders_store.loading, }; return (
{ orders_store.setSearchValues(obj, form); orders_store.getOrderCount(); orders_store.onChange_Tabs(orders_store.active_tab_key); }} /> orders_store.onChange_Tabs(active_key)} items={[ { key: 'Form', label: ( 来源类型 ), }, { key: 'Product', label: ( 产品类型 ), }, { key: 'Country', label: ( 国籍 ), }, { key: 'line', label: ( 线路 ), }, { key: 'city', label: ( 目的地 ), }, { key: 'LineClass', label: ( 页面类型 ), }, { key: 'GuestGroupType', label: ( 客群类别 ), }, { key: 'TravelMotivation', label: ( 出行动机 ), }, ].map((ele) => { return { ...ele, children: ( <> { const wb = utils.table_to_book(document.getElementById(`table_to_xlsx_${ele.key}`).getElementsByTagName('table')[0]); writeFileXLSX(wb, `${ele.key}.xlsx`); }} > 导出excel ), }; })} /> ); } } export default observer(Orders);