umami/src/app/(main)/websites/[websiteId]/WebsiteExpandedView.tsx

161 lines
4.4 KiB
TypeScript
Raw Normal View History

2023-10-17 06:55:59 +02:00
import { Icons, Icon, Text, Dropdown, Item } from 'react-basics';
2023-02-04 17:59:52 +01:00
import BrowsersTable from 'components/metrics/BrowsersTable';
import CountriesTable from 'components/metrics/CountriesTable';
2023-04-14 07:28:29 +02:00
import RegionsTable from 'components/metrics/RegionsTable';
import CitiesTable from 'components/metrics/CitiesTable';
2023-02-04 17:59:52 +01:00
import DevicesTable from 'components/metrics/DevicesTable';
import LanguagesTable from 'components/metrics/LanguagesTable';
import OSTable from 'components/metrics/OSTable';
import PagesTable from 'components/metrics/PagesTable';
import QueryParametersTable from 'components/metrics/QueryParametersTable';
import ReferrersTable from 'components/metrics/ReferrersTable';
import ScreenTable from 'components/metrics/ScreenTable';
import EventsTable from 'components/metrics/EventsTable';
2023-10-03 18:45:02 +02:00
import SideNav from 'components/layout/SideNav';
import { useNavigation, useMessages, useLocale } from 'components/hooks';
2023-10-03 18:45:02 +02:00
import LinkButton from 'components/common/LinkButton';
2023-12-10 11:02:24 +01:00
import styles from './WebsiteExpandedView.module.css';
2023-02-04 17:59:52 +01:00
const views = {
url: PagesTable,
2023-03-31 14:55:28 +02:00
title: PagesTable,
2023-02-04 17:59:52 +01:00
referrer: ReferrersTable,
browser: BrowsersTable,
os: OSTable,
device: DevicesTable,
screen: ScreenTable,
country: CountriesTable,
2023-04-14 07:28:29 +02:00
region: RegionsTable,
city: CitiesTable,
2023-02-04 17:59:52 +01:00
language: LanguagesTable,
event: EventsTable,
query: QueryParametersTable,
};
2023-12-10 11:02:24 +01:00
export default function WebsiteExpandedView({
2023-12-03 12:07:03 +01:00
websiteId,
2023-12-13 09:02:54 +01:00
domainName,
2023-12-03 12:07:03 +01:00
}: {
websiteId: string;
2023-12-13 09:02:54 +01:00
domainName?: string;
2023-12-03 12:07:03 +01:00
}) {
const { dir } = useLocale();
2023-03-22 22:05:55 +01:00
const { formatMessage, labels } = useMessages();
2023-02-04 17:59:52 +01:00
const {
2023-10-17 06:55:59 +02:00
router,
2024-01-30 09:10:25 +01:00
renderUrl,
2023-02-04 17:59:52 +01:00
query: { view },
2023-10-03 18:45:02 +02:00
} = useNavigation();
2023-02-04 17:59:52 +01:00
const items = [
{
key: 'url',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.pages),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'url' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'referrer',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.referrers),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'referrer' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'browser',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.browsers),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'browser' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'os',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.os),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'os' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'device',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.devices),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'device' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'country',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.countries),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'country' }),
2023-02-04 17:59:52 +01:00
},
2023-04-14 07:28:29 +02:00
{
key: 'region',
label: formatMessage(labels.regions),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'region' }),
2023-04-14 07:28:29 +02:00
},
{
key: 'city',
label: formatMessage(labels.cities),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'city' }),
2023-04-14 07:28:29 +02:00
},
2023-02-04 17:59:52 +01:00
{
key: 'language',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.languages),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'language' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'screen',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.screens),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'screen' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'event',
2023-02-04 17:59:52 +01:00
label: formatMessage(labels.events),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'event' }),
2023-02-04 17:59:52 +01:00
},
{
key: 'query',
2023-07-11 10:19:47 +02:00
label: formatMessage(labels.queryParameters),
2024-01-30 09:10:25 +01:00
url: renderUrl({ view: 'query' }),
2023-02-04 17:59:52 +01:00
},
];
const DetailsComponent = views[view] || (() => null);
2023-02-04 17:59:52 +01:00
2023-12-10 11:02:24 +01:00
const handleChange = (view: any) => {
2024-01-30 09:10:25 +01:00
router.push(renderUrl({ view }));
2023-10-17 06:55:59 +02:00
};
2023-12-10 11:02:24 +01:00
const renderValue = (value: string) => items.find(({ key }) => key === value)?.label;
2023-10-17 06:55:59 +02:00
2023-02-04 17:59:52 +01:00
return (
2023-10-03 18:45:02 +02:00
<div className={styles.layout}>
<div className={styles.menu}>
2024-04-03 02:06:06 +02:00
<LinkButton
href={renderUrl({ view: undefined })}
className={styles.back}
variant="quiet"
scroll={false}
>
<Icon rotate={dir === 'rtl' ? 0 : 180}>
2023-10-15 22:12:29 +02:00
<Icons.ArrowRight />
</Icon>
2023-10-03 18:45:02 +02:00
<Text>{formatMessage(labels.back)}</Text>
</LinkButton>
2023-10-17 06:55:59 +02:00
<SideNav className={styles.nav} items={items} selectedKey={view} shallow={true} />
<Dropdown
className={styles.dropdown}
items={items}
value={view}
renderValue={renderValue}
2024-01-19 01:46:40 +01:00
onChange={handleChange}
2023-10-17 06:55:59 +02:00
alignment="end"
>
{({ key, label }) => <Item key={key}>{label}</Item>}
</Dropdown>
2023-10-03 18:45:02 +02:00
</div>
<div className={styles.content}>
2023-02-04 17:59:52 +01:00
<DetailsComponent
websiteId={websiteId}
2023-12-13 09:02:54 +01:00
domainName={domainName}
2023-02-04 17:59:52 +01:00
animate={false}
virtualize={true}
2023-10-15 22:12:29 +02:00
itemCount={25}
2023-12-10 11:02:24 +01:00
allowFilter={true}
allowSearch={true}
2023-02-04 17:59:52 +01:00
/>
2023-10-03 18:45:02 +02:00
</div>
</div>
2023-02-04 17:59:52 +01:00
);
}