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' import { gameClassifyEnum } from "@/components/QueryForm/const" function columns12(): { label: string, fieldSHow?: { label: string, saveField: string, defaultValue: any[], data: any[] }, data: any[] }[] { const roiC = Array(30).fill('').map((_item: string, index: number) => { let data = { title: `${index + 1}日ROI`, dataIndex: `roi${index + 1}`, 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 = 18 const zC = Array(30).fill('').map((_item: string, index: number) => { let field = `amountD${index + 1}Trend` if (index === 29) [ field = 'amountM1Trend' ] 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 '--' }, } data['default'] = defaultStart + index return data }) let mDefaultStart = 48, count = 0 const Mc = [2, 3, 6].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: "1年", default: 51, dataIndex: "amountY1Trend", 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 && 365 <= day) { 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) Mc.push({ title: "总", default: 52, 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: 'gameName', label: '基本信息', align: 'center', width: 95, default: 2, render: (a: string, b: any) => () }, { title: '推广游戏CP名称', dataIndex: 'gameCp', label: '基本信息', align: 'center', width: 95, default: 3, render: (a: string, b: any) => () }, { title: '推广游戏应用类型', dataIndex: 'gameType', label: '基本信息', align: 'center', width: 95, default: 4, render: (a: string, b: any) => () }, { title: '充值时间', dataIndex: 'dt', label: '基本信息', align: 'center', width: 110, default: 5, sorter: true, render: (a: string, b: any) => () }, { title: '消耗', dataIndex: 'cost', label: '基本信息', align: 'center', width: 70, default: 6, 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: 7, render: (a: string) => }, { title: '注册成本', dataIndex: 'registerCost', label: '用户数据', align: 'center', width: 70, sorter: true, default: 8, 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: 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: '新用户创角率', dataIndex: 'roleNumRate', 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: 9, render: (a: string) => }, { title: '首日新用户充值金额', dataIndex: 'firstNewUserAmount', label: '付费数据', align: 'center', width: 70, sorter: true, default: 10, 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: 11, render: (a: string) => }, { title: '新用户累计充值金额', dataIndex: 'buyNewUserTotalAmount', label: '付费数据', align: 'center', width: 70, sorter: true, default: 12, render: (a: string) => }, { title: '首日ROI', dataIndex: 'firstRoi', label: '付费数据', align: 'center', width: 70, sorter: true, default: 13, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '毛利额', dataIndex: 'grossProfit', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => }, { title: '当天回收率', 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: 'roiTotal', label: '付费数据', align: 'center', width: 80, default: 14, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '首日付费率', 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: '新用户付费比', dataIndex: 'newUserAmountRatio', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '首日客单价', 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: '账面客单价', dataIndex: 'paperAvg', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '首日充值成本', dataIndex: 'firstAmountCost', label: '付费数据', align: 'center', width: 70, sorter: true, default: 15, render: (a: string) => }, { title: '当天充值成本', dataIndex: 'todayAmountCost', label: '付费数据', align: 'center', width: 70, sorter: true, default: 16, render: (a: string) => }, { title: '当天复充率', dataIndex: 'todayAgainRate', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: number) => = 1 ? { color: 'red' } : { color: '#0f990f' }} suffix="%" /> }, { title: '新增注册ARPPU', dataIndex: 'newRegArpu', label: '付费数据', align: 'center', width: 70, sorter: true, default: 17, render: (a: string) => }, { title: '首日付费ARPPU', dataIndex: 'firstArpu', label: '付费数据', align: 'center', width: 70, sorter: true, render: (a: string) => }, { title: '当天付费ARPPU', 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