eventCreatedTooltip.tsx 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. import {Fragment} from 'react';
  2. import styled from '@emotion/styled';
  3. import moment from 'moment-timezone';
  4. import {t} from 'sentry/locale';
  5. import ConfigStore from 'sentry/stores/configStore';
  6. import space from 'sentry/styles/space';
  7. import {Event} from 'sentry/types/event';
  8. const formatDateDelta = (reference: moment.Moment, observed: moment.Moment) => {
  9. const duration = moment.duration(Math.abs(+observed - +reference));
  10. const hours = Math.floor(+duration / (60 * 60 * 1000));
  11. const minutes = duration.minutes();
  12. const results: string[] = [];
  13. if (hours) {
  14. results.push(`${hours} hour${hours !== 1 ? 's' : ''}`);
  15. }
  16. if (minutes) {
  17. results.push(`${minutes} minute${minutes !== 1 ? 's' : ''}`);
  18. }
  19. if (results.length === 0) {
  20. results.push('a few seconds');
  21. }
  22. return results.join(', ');
  23. };
  24. type Props = {
  25. event: Event;
  26. };
  27. export default function EventCreatedTooltip({event}: Props) {
  28. const user = ConfigStore.get('user');
  29. const options = user?.options ?? {};
  30. const format = options.clock24Hours ? 'HH:mm:ss z' : 'LTS z';
  31. const dateCreated = moment(event.dateCreated);
  32. const dateReceived = event.dateReceived ? moment(event.dateReceived) : null;
  33. return (
  34. <DescriptionList>
  35. <dt>{t('Occurred')}</dt>
  36. <dd>
  37. {dateCreated.format('ll')}
  38. <br />
  39. {dateCreated.format(format)}
  40. </dd>
  41. {dateReceived && (
  42. <Fragment>
  43. <dt>{t('Received')}</dt>
  44. <dd>
  45. {dateReceived.format('ll')}
  46. <br />
  47. {dateReceived.format(format)}
  48. </dd>
  49. <dt>{t('Latency')}</dt>
  50. <dd>{formatDateDelta(dateCreated, dateReceived)}</dd>
  51. </Fragment>
  52. )}
  53. </DescriptionList>
  54. );
  55. }
  56. const DescriptionList = styled('dl')`
  57. display: grid;
  58. grid-template-columns: max-content 1fr;
  59. gap: ${space(0.75)} ${space(1)};
  60. text-align: left;
  61. margin: 0;
  62. `;