umami/components/pages/reports/retention/RetentionTable.js

84 lines
2.5 KiB
JavaScript
Raw Normal View History

2023-08-04 20:10:03 +00:00
import { useContext } from 'react';
2023-08-07 21:01:53 +00:00
import { GridTable, GridColumn } from 'react-basics';
2023-08-16 17:50:28 +00:00
import classNames from 'classnames';
2023-08-04 20:10:03 +00:00
import { ReportContext } from '../Report';
2023-08-13 03:13:11 +00:00
import EmptyPlaceholder from 'components/common/EmptyPlaceholder';
2023-08-15 05:36:18 +00:00
import { useMessages } from 'hooks';
2023-08-16 17:50:28 +00:00
import { formatDate } from 'lib/date';
2023-08-13 03:13:11 +00:00
import styles from './RetentionTable.module.css';
2023-08-04 20:10:03 +00:00
export function RetentionTable() {
2023-08-15 05:36:18 +00:00
const { formatMessage, labels } = useMessages();
2023-08-04 20:10:03 +00:00
const { report } = useContext(ReportContext);
2023-08-13 03:13:11 +00:00
const { data } = report || {};
2023-08-07 21:01:53 +00:00
2023-08-13 03:13:11 +00:00
if (!data) {
return <EmptyPlaceholder />;
}
2023-08-16 17:50:28 +00:00
const rows = data.reduce((arr, { date, visitors }) => {
if (!arr.find(a => a.date === date)) {
return arr.concat({ date, visitors });
2023-08-13 03:13:11 +00:00
}
return arr;
}, []);
2023-08-16 17:50:28 +00:00
const days = [1, 2, 3, 4, 5, 6, 7, 14, 21, 30];
2023-08-13 03:13:11 +00:00
return (
<>
<div className={styles.table}>
2023-08-16 17:50:28 +00:00
<div className={classNames(styles.row, styles.header)}>
2023-08-15 05:36:18 +00:00
<div className={styles.date}>{formatMessage(labels.date)}</div>
2023-08-16 17:50:28 +00:00
<div className={styles.visitors}>{formatMessage(labels.visitors)}</div>
{days.map(n => (
<div key={n} className={styles.day}>
{formatMessage(labels.day)} {n}
2023-08-13 03:13:11 +00:00
</div>
))}
</div>
2023-08-16 17:50:28 +00:00
{rows.map(({ date, visitors }, i) => {
2023-08-13 03:13:11 +00:00
return (
<div key={i} className={styles.row}>
2023-08-16 17:50:28 +00:00
<div className={styles.date}>{formatDate(`${date} 00:00:00`, 'PP')}</div>
<div className={styles.visitors}>{visitors}</div>
2023-08-13 03:13:11 +00:00
{days.map((n, day) => {
return (
<div key={day} className={styles.cell}>
{data.find(row => row.date === date && row.day === day)?.percentage.toFixed(2)}
</div>
);
})}
</div>
);
})}
</div>
<DataTable data={data} />
</>
);
}
function DataTable({ data }) {
2023-08-04 20:10:03 +00:00
return (
2023-08-13 03:13:11 +00:00
<GridTable data={data || []}>
2023-08-08 18:57:58 +00:00
<GridColumn name="date" label={'Date'}>
{row => row.date}
</GridColumn>
<GridColumn name="day" label={'Day'}>
{row => row.day}
</GridColumn>
2023-08-13 03:13:11 +00:00
<GridColumn name="visitors" label={'Visitors'}>
2023-08-08 18:57:58 +00:00
{row => row.visitors}
</GridColumn>
<GridColumn name="returnVisitors" label={'Return Visitors'}>
{row => row.returnVisitors}
</GridColumn>
<GridColumn name="percentage" label={'Percentage'}>
{row => row.percentage}
2023-08-07 21:01:53 +00:00
</GridColumn>
</GridTable>
2023-08-04 20:10:03 +00:00
);
}
export default RetentionTable;