123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- import {Fragment} from 'react';
- import {Link} from 'react-router';
- import GridEditable, {
- COL_WIDTH_UNDEFINED,
- GridColumnHeader,
- GridColumnOrder,
- } from 'sentry/components/gridEditable';
- import {RateUnits} from 'sentry/utils/discover/fields';
- import {useLocation} from 'sentry/utils/useLocation';
- import {useParams} from 'sentry/utils/useParams';
- import {useResourcePagesQuery} from 'sentry/views/performance/browser/resources/utils/useResourcePageQuery';
- import {useResourceSummarySort} from 'sentry/views/performance/browser/resources/utils/useResourceSummarySort';
- import {DurationCell} from 'sentry/views/starfish/components/tableCells/durationCell';
- import {renderHeadCell} from 'sentry/views/starfish/components/tableCells/renderHeadCell';
- import {ThroughputCell} from 'sentry/views/starfish/components/tableCells/throughputCell';
- type Row = {
- 'avg(http.response_content_length)': number;
- 'avg(span.self_time)': number;
- 'spm()': number;
- transaction: string;
- };
- type Column = GridColumnHeader<keyof Row>;
- function ResourceSummaryTable() {
- const location = useLocation();
- const {groupId} = useParams();
- const sort = useResourceSummarySort();
- const {data, isLoading} = useResourcePagesQuery(groupId, {sort});
- const columnOrder: GridColumnOrder<keyof Row>[] = [
- {key: 'transaction', width: COL_WIDTH_UNDEFINED, name: 'Found on page'},
- {
- key: 'spm()',
- width: COL_WIDTH_UNDEFINED,
- name: 'Throughput',
- },
- {
- key: 'avg(span.self_time)',
- width: COL_WIDTH_UNDEFINED,
- name: 'Avg Duration',
- },
- {
- key: 'avg(http.response_content_length)',
- width: COL_WIDTH_UNDEFINED,
- name: 'Avg Resource Size',
- },
- ];
- const renderBodyCell = (col: Column, row: Row) => {
- const {key} = col;
- if (key === 'spm()') {
- return <ThroughputCell rate={row[key] * 60} unit={RateUnits.PER_SECOND} />;
- }
- if (key === 'avg(span.self_time)') {
- return <DurationCell milliseconds={row[key]} />;
- }
- if (key === 'transaction') {
- return (
- <Link
- to={{
- pathname: location.pathname,
- query: {
- ...location.query,
- transaction: row[key],
- },
- }}
- >
- {row[key]}
- </Link>
- );
- }
- return <span>{row[key]}</span>;
- };
- return (
- <Fragment>
- <GridEditable
- data={data || []}
- isLoading={isLoading}
- columnOrder={columnOrder}
- columnSortBy={[
- {
- key: sort.field,
- order: sort.kind,
- },
- ]}
- grid={{
- renderHeadCell: column =>
- renderHeadCell({
- column,
- location,
- sort,
- }),
- renderBodyCell,
- }}
- location={location}
- />
- </Fragment>
- );
- }
- export const getActionName = (transactionOp: string) => {
- switch (transactionOp) {
- case 'ui.action.click':
- return 'Click';
- default:
- return transactionOp;
- }
- };
- export default ResourceSummaryTable;
|