import WidthEllipsis from "@/components/widthEllipsis" import { Statistic } from "antd" import React from "react" import { version } from "../../components/TableData" import moment from "moment" import style from '../../extensionData/everyday/index.less' function columns12(): { label: string, fieldSHow?: { label: string, saveField: string, defaultValue: any[], data: any[] }, data: any[] }[] { const roiC = Array(29).fill('').map((_item: string, index: number) => { let data = { title: `${index + 2}日ROI`, dataIndex: `roi${index + 2}`, label: '付费数据', align: 'center', width: 80, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> } index++; return data }) let defaultValue = [ // 默认展示字段 { label: '充值人数', key: 'rechargeUserCount', type: '付费趋势' }, { label: '充值金额', key: 'rechargeMoney', type: '付费趋势' }, { label: '增', key: 'increase', type: '付费趋势' }, { label: '回', key: 'back', type: '付费趋势' }, { label: '倍', key: 'multiples', type: '付费趋势' }, ] const getFieldDta = () => { let mySelectFieldData = localStorage.getItem(`myAdFieldConfig${version}_投手推广每日数据`) let newSelectFieldData: any = {} if (mySelectFieldData) { newSelectFieldData = JSON.parse(mySelectFieldData).date_field } else { newSelectFieldData = defaultValue } return newSelectFieldData } // 总付费趋势 let defaultStart = 16 const zC = Array(90).fill('').map((_item: string, index: number) => { let field = `amountD${index + 1}Trend` let data = { title: `D${index + 1}`, dataIndex: `D${index + 1}`, label: "时间区间跨度", width: 110, render: (a: any, b: any) => { let date1 = moment() if (b?.pitcher === '总计') { if (b?.beginDay) { date1 = moment(b.beginDay) } else { date1 = moment() } } else { date1 = moment(b.dt) } let dt = moment() let day = dt.diff(date1, 'day'); let fieldData = getFieldDta() if (fieldData?.length > 0 && index <= day) { let data: any = {} let keyS: string[] = fieldData?.map((item: any) => item.key) switch (fieldData[0].type) { case '付费趋势': if (b?.[field]) { data = b?.[field] return
{keyS?.includes('rechargeUserCount') && 充人:{data?.rechargeUserCount}} {keyS?.includes('rechargeMoney') && 充金:} {keyS?.includes('increase') && 增:{(data?.increase * 100)?.toFixed(2)}%} {keyS?.includes('back') && 回:{(data?.back * 100)?.toFixed(2)}%} {keyS?.includes('multiples') && 倍:{data?.multiples?.toFixed(2)}}
} return '--' } } return '--' }, } if (index < 30) { data['default'] = defaultStart + index } return data }) // let mDefaultStart = 109, count = 0 const Mc = [4, 5, 6, 7, 8, 9, 10, 11, 12].map(index => { let field = `amountM${index}Trend` let data = { title: `M${index}`, dataIndex: `M${index}`, label: "时间区间跨度", width: 110, render: (a: any, b: any) => { let date1 = moment() if (b?.pitcher === '总计') { if (b?.beginDay) { date1 = moment(b.beginDay) } else { date1 = moment() } } else { date1 = moment(b.dt) } let dt = moment() let day = dt.diff(date1, 'day'); let fieldData = getFieldDta() if (fieldData?.length > 0 && index * 30 <= day) { let data: any = {} let keyS: string[] = fieldData?.map((item: any) => item.key) switch (fieldData[0].type) { case '付费趋势': if (b?.[field]) { data = b?.[field] return
{keyS?.includes('rechargeUserCount') && 充人:{data?.rechargeUserCount}} {keyS?.includes('rechargeMoney') && 充金:} {keyS?.includes('increase') && 增:{(data?.increase * 100)?.toFixed(2)}%} {keyS?.includes('back') && 回:{(data?.back * 100)?.toFixed(2)}%} {keyS?.includes('multiples') && 倍:{data?.multiples?.toFixed(2)}}
} return '--' } } return '--' }, } // data['default'] = mDefaultStart + count // count++; return data }) Mc.push({ title: "总", default: 46, dataIndex: "amountSumTrend", label: "时间区间跨度", align: "center", width: 110, render: (a: any, b: any) => { let fieldData = getFieldDta() if (fieldData?.length > 0) { let data: any = {} let keyS: string[] = fieldData?.map((item: any) => item.key) switch (fieldData[0].type) { case '付费趋势': if (a) { data = a return
{keyS?.includes('rechargeUserCount') && 充人:{data?.rechargeUserCount}} {keyS?.includes('rechargeMoney') && 充金:} {keyS?.includes('increase') && 增:{(data?.increase * 100)?.toFixed(2)}%} {keyS?.includes('back') && 回:{(data?.back * 100)?.toFixed(2)}%} {keyS?.includes('multiples') && 倍:{data?.multiples?.toFixed(2)}}
} return '--' } } return '--' }, } as any) return [ { label: '基本信息', data: [ { title: '投手', dataIndex: 'pitcher', label: '基本信息', align: 'center', width: 95, default: 1, render: (a: string, b: any) => () }, { title: '推广媒体', dataIndex: 'accountType', label: '基本信息', align: 'center', width: 95, default: 2, render: (a: string, b: any) => () }, { title: '时间', dataIndex: 'dt', label: '基本信息', align: 'center', width: 110, default: 3, sorter: true, render: (a: string, b: any) => () }, { title: '消耗', dataIndex: 'cost', label: '基本信息', align: 'center', width: 70, default: 4, sorter: true, render: (a: string) => }, { title: '推广账号数量', dataIndex: 'accountCount', label: '基本信息', align: 'center', width: 80, sorter: true, render: (a: string) => }, { title: '推广渠道数量', dataIndex: 'agentCount', label: '基本信息', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '推广计划数量', dataIndex: 'planCount', label: '基本信息', align: 'center', width: 70, sorter: true, render: (a: string) => } ] }, { label: '用户数据', data: [ { title: '注册人数', dataIndex: 'registerNum', label: '用户数据', align: 'center', width: 70, sorter: true, default: 5, render: (a: string) => }, { title: '注册成本', dataIndex: 'registerCost', label: '用户数据', align: 'center', width: 70, sorter: true, default: 6, render: (a: string) => }, { title: '创角人数', tips: '包含新老用户创角', dataIndex: 'roleNum', label: '用户数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '首日创角人数', dataIndex: 'firstRoleNum', label: '用户数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '新用户累计创角人数', dataIndex: 'newUserTotalRoleNum', label: '用户数据', align: 'center', width: 100, sorter: true, render: (a: string) => }, { title: '首日创角成本', dataIndex: 'firstRoleCost', label: '用户数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '新用户累计创角成本', dataIndex: 'newUserTotalRoleCost', label: '用户数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, // { // title: '创角量', dataIndex: 'roleNum', label: '用户数据', align: 'center', width: 70, sorter: true, // render: (a: string) => // }, // { // title: '首日创角量', dataIndex: 'firstRoleNum', label: '用户数据', align: 'center', width: 70, sorter: true, // render: (a: string) => // }, // { // title: '新用户累计创角量', dataIndex: 'newUserTotalRoleNum', label: '用户数据', align: 'center', width: 70, sorter: true, // render: (a: string) => // }, { title: '首日创角率', dataIndex: 'firstRoleRate', label: '用户数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 50 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '新用户创角率', tips: '新用户累计创角人数/注册人数', dataIndex: 'newUserTotalRoleRate', label: '用户数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 50 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> } ] }, { label: '付费数据', data: [ { title: '首日新用户充值次数', dataIndex: 'firstNewUserAmountCount', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '首日新用户充值人数', dataIndex: 'firstNewUserAmountNum', label: '付费数据', align: 'center', width: 70, sorter: true, default: 7, render: (a: string) => }, { title: '首日新用户充值金额', dataIndex: 'firstNewUserAmount', label: '付费数据', align: 'center', width: 70, sorter: true, default: 8, render: (a: string) => }, { title: '老用户充值次数', dataIndex: 'oldAmountCount', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '老用户充值人数', dataIndex: 'oldAmountNum', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '老用户充值金额', dataIndex: 'oldAmount', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '账面充值次数', dataIndex: 'amountCount', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '账面充值人数', dataIndex: 'amountNum', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '账面充值金额', dataIndex: 'amount', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '新用户累计充值次数', dataIndex: 'buyNewUserTotalAmountCount', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '新用户累计充值人数', dataIndex: 'buyNewUserTotalAmountNum', label: '付费数据', align: 'center', width: 70, sorter: true, default: 9, render: (a: string) => }, { title: '新用户累计充值金额', dataIndex: 'buyNewUserTotalAmount', label: '付费数据', align: 'center', width: 70, sorter: true, default: 10, render: (a: string) => }, { title: '首日ROI', tips: '首日新用户充值金额/实际消耗', dataIndex: 'firstRoi', label: '付费数据', align: 'center', width: 70, sorter: true, default: 11, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '毛利额', dataIndex: 'grossProfit', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => }, { title: '至今回收率', tips: '新用户累计充值金额/实际消耗', dataIndex: 'todayRoi', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, ...roiC, { title: '60日ROI', dataIndex: 'roi60', label: '付费数据', align: 'center', width: 80, sorter: true, render: (a: number) => = 0.9 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '90日ROI', dataIndex: 'roi90', label: '付费数据', align: 'center', width: 80, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '180日ROI', dataIndex: 'roi180', label: '付费数据', align: 'center', width: 80, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '1年ROI', dataIndex: 'roi1yaer', label: '付费数据', align: 'center', width: 80, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '总ROI', dataIndex: 'todayRoi', label: '付费数据', align: 'center', width: 80, default: 12, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '首日付费率', tips: '首日新用户充值人数/注册人数', dataIndex: 'firstRate', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '至今付费率', tips: '至今付费率(总)=新用户累计充值人数/注册人数', dataIndex: 'todayRate', label: '付费数据', align: 'center', width: 80, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '新用户付费比', tips: '首日新用户充值人数/账面充值人数', dataIndex: 'newUserAmountRatio', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '首日客单价', tips: '首日新用户充值金额/首日新用户充值次数', dataIndex: 'firstAvg', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '至今客单价', dataIndex: 'buyAvg', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '账面客单价', tips: '账面充值金额/账面充值次数', dataIndex: 'paperAvg', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '首日充值成本', tips: '实际消耗/首日新用户充值人数', dataIndex: 'firstAmountCost', label: '付费数据', align: 'center', width: 70, sorter: true, default: 13, render: (a: string) => }, { title: '至今充值成本', dataIndex: 'todayAmountCost', label: '付费数据', align: 'center', width: 70, sorter: true, default: 14, render: (a: string) => }, { title: '至今复充率', tips: '新用户复充人数/新用户累计充值人数(新用户复充人数为累计值充值次数n≥2)', dataIndex: 'todayAgainRate', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '新增注册ARPPU', tips: '新用户累计充值金额/注册人数', dataIndex: 'newRegArpu', label: '付费数据', align: 'center', width: 70, sorter: true, default: 15, render: (a: string) => }, { title: '首日付费ARPPU', tips: '首日新用户充值金额/首日新用户充值人数', dataIndex: 'firstArpu', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '至今付费ARPPU', tips: '新用户累计充值金额/新用户累计充值人数', dataIndex: 'todayArpu', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '账面ARPPU', dataIndex: 'paperArpu', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => } ] }, { fieldSHow: { label: '日期区间字段展示', saveField: 'date_field', defaultValue, data: [ { label: '付费趋势', data: defaultValue }, ] }, label: '时间区间跨度', data: [ ...zC, ...Mc ] } ] } export default columns12