Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
wp-content
/
test
/
wp-content
/
plugins
/
woocommerce
/
src
/
Admin
/
RemoteInboxNotifications
:
TotalPaymentsVolumeProcessor.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php /** * Rule processor that passes when a store's payments volume exceeds a provided amount. */ namespace Automattic\WooCommerce\Admin\RemoteInboxNotifications; defined( 'ABSPATH' ) || exit; use Automattic\WooCommerce\Admin\API\Reports\Revenue\Query as RevenueQuery; use Automattic\WooCommerce\Admin\API\Reports\TimeInterval; /** * Rule processor that passes when a store's payments volume exceeds a provided amount. */ class TotalPaymentsVolumeProcessor implements RuleProcessorInterface { /** * Compare against the store's total payments volume. * * @param object $rule The rule being processed by this rule processor. * @param object $stored_state Stored state. * * @return bool The result of the operation. */ public function process( $rule, $stored_state ) { $dates = TimeInterval::get_timeframe_dates( $rule->timeframe ); $reports_revenue = $this->get_reports_query( array( 'before' => $dates['end'], 'after' => $dates['start'], 'interval' => 'year', 'fields' => array( 'total_sales' ), ) ); $report_data = $reports_revenue->get_data(); if ( ! $report_data || ! isset( $report_data->totals->total_sales ) ) { return false; } $value = $report_data->totals->total_sales; return ComparisonOperation::compare( $value, $rule->value, $rule->operation ); } /** * Validates the rule. * * @param object $rule The rule to validate. * * @return bool Pass/fail. */ public function validate( $rule ) { $allowed_timeframes = array( 'last_week', 'last_month', 'last_quarter', 'last_6_months', 'last_year', ); if ( ! isset( $rule->timeframe ) || ! in_array( $rule->timeframe, $allowed_timeframes, true ) ) { return false; } if ( ! isset( $rule->value ) || ! is_numeric( $rule->value ) ) { return false; } if ( ! isset( $rule->operation ) ) { return false; } return true; } /** * Get the report query. * * @param array $args The query args. * * @return RevenueQuery The report query. */ protected function get_reports_query( $args ) { return new RevenueQuery( $args ); } }