// 活跃会员统计 import { connect, CurrentUser } from "umi"; import { ConnectState } from "@/models/connect"; import { useEffect, useRef, useState } from "react"; import { Button, Col, Drawer, FormInstance, Row, Spin } from "antd"; import ProForm, { ProFormDateRangePicker, ProFormSelect } from "@ant-design/pro-form"; import './ActiveMemberStatistics.less' import { handeGetMembershipCount } from "../service"; import session from "@/utils/session"; import ProTable, { ActionType } from "@ant-design/pro-table"; import MemberInfor from "../memberInfor"; import moment from 'moment' const ActiveMemberStatistics: React.FC<{ currentUser: CurrentUser | undefined }> = (props) => { const { currentUser } = props const formRef = useRef(); const actionRef = useRef(); // 选择的tab const [selectPageTab, setSelectPageTab] = useState(1) // 会员类型数据 const [membershipType, setMembershipType] = useState() // 会员数量 const [memberShipTotal, setMemberShipTotal] = useState(1) // 会员等级数据 const [revenueList, setRevenueList] = useState() // 显示详情抽屉 const [showDetail, setShowDetail] = useState(false) const [currentRow, setCurrentRow] = useState() // 抽屉显示的标题 const [currentDrawerTitle, setCurrentDrawerTitle] = useState() // 1 是 会员类型 2是 会员等级 const [searchType, setSearchType] = useState() // 对应的枚举类型 const [valueType, setValueType] = useState() // 显示加载效果 const [showLoading, setShowLoading] = useState(false) let MEMBERSHIPLEVELYNObj = session.get('MEMBERSHIPLEVELYNObj') let MEMBERSHIPLEVELYNList = session.get('MEMBERSHIPLEVELYNList') let MEMBERSHIPTYPEYNObj = session.get('MEMBERSHIPTYPEYNObj') let MEMBERSHIPTYPEYNList = session.get('MEMBERSHIPTYPEYNList') const handleGetData = async (formData?: any) => { console.log('formDataformDataformData', formData); let [start, end] = ['', ''] if (formData && formData?.searchTime) { [start, end] = formData.searchTime } const req: any = { CalcType: 4, // 活跃会员 OwnerUnitId: currentUser?.OwnerUnitId, ExcludeTest: formData ? formData?.ExcludeTest === 1 ? true : false : true, StartDate: start ? start : "", EndDate: end ? end : "", MembershipType: formData?.MembershipType || "", // MembershipLevel: formData?.MembershipLevel || "", MembershipLevel: "", } setShowLoading(true) const data = await handeGetMembershipCount(req) setShowLoading(false) console.log('datadatadatadata', data); setMembershipType(data.List) setMemberShipTotal(data.OtherData) } // 点击事件 const handleShowTableData = async (type: number, memberType: any) => { // type 1 的话是 会员类型 2 的话是 会员等级 memberType 对应的枚举值 setCurrentDrawerTitle(`${type === 1 ? '会员类型' : type === 2 ? '会员等级' : ''}【${type === 1 ? MEMBERSHIPTYPEYNObj && memberType ? MEMBERSHIPTYPEYNObj[memberType] : '' : type === 2 ? MEMBERSHIPLEVELYNObj && memberType ? MEMBERSHIPLEVELYNObj[memberType] : '' : ''}】`) setSearchType(type) setValueType(memberType) setShowDetail(true) } useEffect(() => { handleGetData() }, []) return (
{ showLoading ?
加载中...
: '' }
{/*
{ setSelectPageTab(1) }}>会员类型
{ setSelectPageTab(2) }}>会员等级
*/} { console.log('valuesvaluesvaluesvalues', values); handleGetData(values) }} > {/* */} {/* */}
{ membershipType && membershipType.length > 0 ? <>
会员类型{memberShipTotal ? `(${memberShipTotal}人)` : ""}
{ membershipType.map((item: any) => { return
{item.label === '0' ? '未授权用户' : MEMBERSHIPLEVELYNObj && item.label ? MEMBERSHIPLEVELYNObj[item.label] : ''}
{item.value}
占比
{item.key ? item.key + '%' : ""}
}) }
: "" }
{ revenueList && revenueList.length > 0 ? <>
营销活动
{ revenueList.map((item: any) => { return
{item.label}
{item.value}
占比
{item.key ? item.key + '%' : ""}
}) }
: "" }
{ setSearchType(null) setValueType(null) setShowDetail(false) }} >
) } export default connect(({ user }: ConnectState) => ({ currentUser: user.currentUser }))(ActiveMemberStatistics);