/** @format */ /** * External dependencies */ import { __ } from '@wordpress/i18n'; import { Component } from '@wordpress/element'; import { compose } from '@wordpress/compose'; import PropTypes from 'prop-types'; /** * WooCommerce dependencies */ import { getDateParamsFromQuery } from '@woocommerce/date'; import { getNewPath } from '@woocommerce/navigation'; import { SummaryList, SummaryListPlaceholder, SummaryNumber } from '@woocommerce/components'; /** * Internal dependencies */ import { getSummaryNumbers } from 'store/reports/utils'; import ReportError from 'analytics/components/report-error'; import { calculateDelta, formatValue } from './utils'; import withSelect from 'wc-api/with-select'; export class ReportSummary extends Component { render() { const { charts, query, selectedChart, summaryData } = this.props; const { totals, isError, isRequesting } = summaryData; if ( isError ) { return ; } if ( isRequesting ) { return ; } const primaryTotals = totals.primary || {}; const secondaryTotals = totals.secondary || {}; const { compare } = getDateParamsFromQuery( query ); const summaryNumbers = charts.map( chart => { const { key, label, type } = chart; const delta = calculateDelta( primaryTotals[ key ], secondaryTotals[ key ] ); const href = getNewPath( { chart: key } ); const prevValue = formatValue( type, secondaryTotals[ key ] ); const isSelected = selectedChart.key === key; const value = formatValue( type, primaryTotals[ key ] ); return ( ); } ); return { summaryNumbers }; } } ReportSummary.propTypes = { charts: PropTypes.array.isRequired, endpoint: PropTypes.string.isRequired, query: PropTypes.object.isRequired, selectedChart: PropTypes.object.isRequired, }; export default compose( withSelect( ( select, props ) => { const { query, endpoint } = props; const summaryData = getSummaryNumbers( endpoint, query, select ); return { summaryData, }; } ) )( ReportSummary );