QueryTransactions.tsx 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import React, { PureComponent } from 'react';
  2. import { QueryTransaction as QueryTransactionModel } from 'app/types/explore';
  3. import ElapsedTime from './ElapsedTime';
  4. function formatLatency(value) {
  5. return `${(value / 1000).toFixed(1)}s`;
  6. }
  7. interface QueryTransactionProps {
  8. transaction: QueryTransactionModel;
  9. }
  10. class QueryTransaction extends PureComponent<QueryTransactionProps> {
  11. render() {
  12. const { transaction } = this.props;
  13. const className = transaction.done ? 'query-transaction' : 'query-transaction query-transaction--loading';
  14. return (
  15. <div className={className}>
  16. <div className="query-transaction__type">{transaction.resultType}:</div>
  17. <div className="query-transaction__duration">
  18. {transaction.done ? formatLatency(transaction.latency) : <ElapsedTime />}
  19. </div>
  20. </div>
  21. );
  22. }
  23. }
  24. interface QueryTransactionsProps {
  25. transactions: QueryTransactionModel[];
  26. }
  27. export default class QueryTransactions extends PureComponent<QueryTransactionsProps> {
  28. render() {
  29. const { transactions } = this.props;
  30. return (
  31. <div className="query-transactions">
  32. {transactions.map((t, i) => <QueryTransaction key={`${t.query}:${t.resultType}`} transaction={t} />)}
  33. </div>
  34. );
  35. }
  36. }