'use client'; import { Chart } from '@/components/report/chart'; import { useEventQueryFilters } from '@/hooks/useEventQueryFilters'; import { cn } from '@/utils/cn'; import { Widget, WidgetBody } from '../Widget'; import { WidgetButtons, WidgetHead } from './overview-widget'; import { useOverviewOptions } from './useOverviewOptions'; import { useOverviewWidget } from './useOverviewWidget'; interface OverviewTopPagesProps { projectId: string; } export default function OverviewTopPages({ projectId }: OverviewTopPagesProps) { const { interval, range, previous } = useOverviewOptions(); const [filters, setFilter] = useEventQueryFilters(); const [widget, setWidget, widgets] = useOverviewWidget('pages', { top: { title: 'Top pages', btn: 'Top pages', chart: { projectId, events: [ { segment: 'event', filters, id: 'A', name: 'screen_view', }, ], breakdowns: [ { id: 'A', name: 'path', }, ], chartType: 'bar', lineType: 'monotone', interval, name: 'Top sources', range, previous, metric: 'sum', }, }, entries: { title: 'Entry Pages', btn: 'Entries', chart: { projectId, events: [ { segment: 'event', filters, id: 'A', name: 'session_start', }, ], breakdowns: [ { id: 'A', name: 'path', }, ], chartType: 'bar', lineType: 'monotone', interval, name: 'Top sources', range, previous, metric: 'sum', }, }, exits: { title: 'Exit Pages', btn: 'Exits', chart: { projectId, events: [ { segment: 'event', filters, id: 'A', name: 'session_end', }, ], breakdowns: [ { id: 'A', name: 'path', }, ], chartType: 'bar', lineType: 'monotone', interval, name: 'Top sources', range, previous, metric: 'sum', }, }, }); return ( <>
{widget.title}
{widgets.map((w) => ( ))}
{ setFilter('path', item.name); }} />
); }