import { gql, useQuery } from '@apollo/client' import { getGetServerSideProps } from '@/api/ssrApollo' import Layout from '@/components/layout' import Col from 'react-bootstrap/Col' import Row from 'react-bootstrap/Row' import { SubAnalyticsHeader } from '@/components/sub-analytics-header' import { useRouter } from 'next/router' import dynamic from 'next/dynamic' import PageLoading from '@/components/page-loading' import { WhenAreaChartSkeleton, WhenComposedChartSkeleton, WhenLineChartSkeleton } from '@/components/charts-skeletons' const WhenAreaChart = dynamic(() => import('@/components/charts').then(mod => mod.WhenAreaChart), { loading: () => }) const WhenLineChart = dynamic(() => import('@/components/charts').then(mod => mod.WhenLineChart), { loading: () => }) const WhenComposedChart = dynamic(() => import('@/components/charts').then(mod => mod.WhenComposedChart), { loading: () => }) const GROWTH_QUERY = gql` query Growth($when: String!, $from: String, $to: String, $sub: String, $subSelect: Boolean = false) { registrationGrowth(when: $when, from: $from, to: $to) @skip(if: $subSelect) { time data { name value } } itemGrowth(when: $when, from: $from, to: $to) @skip(if: $subSelect) { time data { name value } } spendingGrowth(when: $when, from: $from, to: $to) @skip(if: $subSelect) { time data { name value } } spenderGrowth(when: $when, from: $from, to: $to) @skip(if: $subSelect) { time data { name value } } stackingGrowth(when: $when, from: $from, to: $to) @skip(if: $subSelect) { time data { name value } } stackerGrowth(when: $when, from: $from, to: $to) @skip(if: $subSelect) { time data { name value } } itemGrowthSubs(when: $when, from: $from, to: $to, sub: $sub) @include(if: $subSelect) { time data { name value } } revenueGrowthSubs(when: $when, from: $from, to: $to, sub: $sub) @include(if: $subSelect) { time data { name value } } }` const variablesFunc = vars => ({ ...vars, subSelect: vars.sub !== 'all' }) export const getServerSideProps = getGetServerSideProps({ query: GROWTH_QUERY, variables: variablesFunc }) export default function Growth ({ ssrData }) { const router = useRouter() const { when, from, to, sub } = router.query const { data } = useQuery(GROWTH_QUERY, { variables: { when, from, to, sub, subSelect: sub !== 'all' } }) if (!data && !ssrData) return const { registrationGrowth, itemGrowth, spendingGrowth, spenderGrowth, stackingGrowth, stackerGrowth, itemGrowthSubs, revenueGrowthSubs } = data || ssrData if (sub === 'all') { return (
stackers
stacking
spenders
spending
registrations
items
) } else { return (
items
sats
) } }