traceContextVitals.tsx 1.0 KB

12345678910111213141516171819202122232425262728293031323334
  1. import {VitalPill} from 'sentry/views/insights/browser/webVitals/components/webVitalMeters';
  2. import type {WebVitals} from 'sentry/views/insights/browser/webVitals/types';
  3. import type {TraceTree} from 'sentry/views/performance/newTraceDetails/traceModels/traceTree';
  4. type Props = {
  5. tree: TraceTree;
  6. };
  7. const ALLOWED_VITALS = ['lcp', 'fcp', 'cls', 'ttfb', 'inp'];
  8. export function TraceContextVitals({tree}: Props) {
  9. const hasWebVitals = tree.vital_types.has('web');
  10. const hasValidWebVitals = Array.from(tree.vitals.values()).some(vitalGroup =>
  11. vitalGroup.some(vital => ALLOWED_VITALS.includes(vital.key))
  12. );
  13. if (!hasWebVitals || !hasValidWebVitals) {
  14. return null;
  15. }
  16. return ALLOWED_VITALS.map(webVital => {
  17. let vital: TraceTree.CollectedVital | undefined;
  18. tree.vitals.forEach(entry => (vital = entry.find(v => v.key === webVital)));
  19. return (
  20. <VitalPill
  21. key={vital?.key}
  22. webVital={webVital as WebVitals}
  23. score={vital?.score}
  24. meterValue={vital?.measurement.value}
  25. />
  26. );
  27. });
  28. }