$57 GRAYBYTE WORDPRESS FILE MANAGER $99

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 104.21.43.35 | ADMIN IP 216.73.216.180
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : mail

/home/bravrvjk/itiministry.org/wp-content/plugins/give/src/API/Endpoints/Reports/

HOME
Current File : /home/bravrvjk/itiministry.org/wp-content/plugins/give/src/API/Endpoints/Reports//Income.php
<?php

/**
 * Income over time endpoint
 *
 * @package Give
 */

namespace Give\API\Endpoints\Reports;

class Income extends Endpoint
{

    protected $payments;

    public function __construct()
    {
        $this->endpoint = 'income';
    }

    public function getReport($request)
    {
        $start = date_create($request->get_param('start'));
        $end = date_create($request->get_param('end'));
        $diff = date_diff($start, $end);

        $dataset = [];

        switch (true) {
            case ($diff->days > 12):
                $interval = round($diff->days / 12);
                $data = $this->get_data($start, $end, 'P' . $interval . 'D');
                break;
            case ($diff->days > 5):
                $data = $this->get_data($start, $end, 'P1D');
                break;
            case ($diff->days > 4):
                $data = $this->get_data($start, $end, 'PT12H');
                break;
            case ($diff->days > 2):
                $data = $this->get_data($start, $end, 'PT3H');
                break;
            case ($diff->days >= 0):
                $data = $this->get_data($start, $end, 'PT1H');
                break;
        }

        return $data;
    }

    public function get_data($start, $end, $intervalStr)
    {
        $tooltips = [];
        $income = [];

        $interval = new \DateInterval($intervalStr);

        $periodStart = clone $start;
        $periodEnd = clone $start;

        // Subtract interval to set up period start
        date_sub($periodStart, $interval);

        while ($periodStart < $end) {
            $values = $this->get_values($periodStart->format('Y-m-d H:i:s'), $periodEnd->format('Y-m-d H:i:s'));
            $incomeForPeriod = $values['earnings'];
            $donorsForPeriod = $values['donor_count'];
            $time = $periodEnd->format('Y-m-d H:i:s');

            switch ($intervalStr) {
                case 'P1D':
                    $time = $periodStart->format('Y-m-d');
                    $periodLabel = $periodStart->format('l');
                    break;
                case 'PT12H':
                case 'PT3H':
                case 'PT1H':
                    $periodLabel = $periodStart->format('D ga') . ' - ' . $periodEnd->format('D ga');
                    break;
                default:
                    $periodLabel = $periodStart->format('M j, Y') . ' - ' . $periodEnd->format('M j, Y');
            }

            $income[] = [
                'x' => $time,
                'y' => $incomeForPeriod,
            ];

            $tooltips[] = [
                'title' => give_currency_filter(
                    give_format_amount($incomeForPeriod),
                    [
                        'currency_code' => $this->currency,
                        'decode_currency' => true,
                        'sanitize' => false,
                    ]
                ),
                'body' => $donorsForPeriod . ' ' . __('Donors', 'give'),
                'footer' => $periodLabel,
            ];

            // Add interval to set up next period
            date_add($periodStart, $interval);
            date_add($periodEnd, $interval);
        }

        if ($intervalStr === 'P1D') {
            $income = array_slice($income, 1);
            $tooltips = array_slice($tooltips, 1);
        }

        // Create data object to be returned, with 'highlights' object containing total and average figures to display
        $data = [
            'datasets' => [
                [
                    'data' => $income,
                    'tooltips' => $tooltips,
                ],
            ],
        ];

        return $data;
    }

    public function get_values($startStr, $endStr)
    {
        $paymentObjects = $this->getPayments($startStr, $endStr);

        $earnings = 0;
        $donors = [];

        foreach ($paymentObjects as $paymentObject) {
            if ($paymentObject->date >= $startStr && $paymentObject->date < $endStr) {
                if ($paymentObject->status == 'publish' || $paymentObject->status == 'give_subscription') {
                    $earnings += $paymentObject->total;
                    $donors[] = $paymentObject->donor_id;
                }
            }
        }

        $unique = array_unique($donors);

        return [
            'earnings' => $earnings,
            'donor_count' => count($unique),
        ];
    }

}


Current_dir [ WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
4 Apr 2026 1.57 AM
bravrvjk / bravrvjk
0755
AverageDonation.php
6.889 KB
17 Jun 2022 4.03 AM
bravrvjk / bravrvjk
0644
DonationsVsIncome.php
2.99 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
Endpoint.php
11.735 KB
28 Jan 2026 8.00 PM
bravrvjk / bravrvjk
0644
FormPerformance.php
4.083 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
Income.php
4.313 KB
17 Jun 2022 4.03 AM
bravrvjk / bravrvjk
0644
IncomeBreakdown.php
4.339 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
PaymentMethods.php
2.419 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
PaymentStatuses.php
3.766 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
RecentDonations.php
2.134 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
TopDonors.php
2.963 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
TotalDonors.php
5.502 KB
17 Jun 2022 4.03 AM
bravrvjk / bravrvjk
0644
TotalIncome.php
6.009 KB
17 Jun 2022 4.03 AM
bravrvjk / bravrvjk
0644
TotalRefunds.php
5.35 KB
17 Jun 2022 4.03 AM
bravrvjk / bravrvjk
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF