$58 GRAYBYTE WORDPRESS FILE MANAGER $41

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/Tracking/TrackingData/

HOME
Current File : /home/bravrvjk/itiministry.org/wp-content/plugins/give/src/Tracking/TrackingData//DonationData.php
<?php

namespace Give\Tracking\TrackingData;

use Give\Framework\Database\DB;
use Give\Tracking\Contracts\TrackData;
use Give\Tracking\Helpers\DonationStatuses;

/**
 * Class DonationData
 *
 * Represents donation data.
 *
 * @package Give\Tracking\TrackingData
 *
 * @since 2.10.0
 */
class DonationData implements TrackData
{
    private $donationStatuses;

    /**
     * DonationData constructor.
     */
    public function __construct()
    {
        $this->donationStatuses = DonationStatuses::getCompletedDonationsStatues(true);
    }

    /**
     * @inheritdoc
     * @return array|void
     */
    public function get()
    {
        return [
            'first_donation_date' => $this->getFirstDonationDate(),
            'last_donation_date' => $this->getLastDonationDate(),
            'revenue' => $this->getRevenueTillNow(),
        ];
    }

    /**
     * Get first donation date.
     *
     * @since 2.10.0
     * @return string
     */
    private function getFirstDonationDate()
    {
        global $wpdb;

        $date = DB::get_var(
            "
			SELECT post_date_gmt
			FROM {$wpdb->posts} as p
				INNER JOIN {$wpdb->donationmeta} as dm ON p.id=dm.donation_id
			WHERE post_status IN ({$this->donationStatuses})
				AND dm.meta_key='_give_payment_mode'
				AND dm.meta_value='live'
			ORDER BY post_date_gmt ASC
			LIMIT 1
			"
        );

        return $date ? strtotime($date) : '';
    }

    /**
     * Get last donation date.
     *
     * @since 2.10.0
     * @return string
     */
    private function getLastDonationDate()
    {
        global $wpdb;

        $date = DB::get_var(
            "
			SELECT post_date_gmt
			FROM {$wpdb->posts} as p
				INNER JOIN {$wpdb->donationmeta} as dm ON p.id=dm.donation_id
			WHERE post_status IN ({$this->donationStatuses})
				AND dm.meta_key='_give_payment_mode'
				AND dm.meta_value='live'
			ORDER BY post_date_gmt DESC
			LIMIT 1
			"
        );

        return $date ? strtotime($date) : '';
    }

    /**
     * Returns revenue till current date.
     *
     * @since 2.10.0
     * @return int
     */
    public function getRevenueTillNow()
    {
        global $wpdb;

        $result = (int)DB::get_var(
            "
			SELECT SUM(r.amount)
			FROM {$wpdb->give_revenue} as r
				INNER JOIN {$wpdb->donationmeta} as dm ON r.donation_id=dm.donation_id
			WHERE dm.meta_key='_give_payment_mode'
				AND dm.meta_value='live'
			"
        );

        return $result ?: 0;
    }
}


Current_dir [ WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
4 Apr 2026 1.57 AM
bravrvjk / bravrvjk
0755
ActiveDonationFormsData.php
0.704 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
CampaignsData.php
1.118 KB
11 Jun 2025 10.57 PM
bravrvjk / bravrvjk
0644
DonationData.php
2.413 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
DonationFormsData.php
7.116 KB
1 May 2024 11.40 PM
bravrvjk / bravrvjk
0644
DonationMetricsData.php
2.943 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
EditedDonationFormsData.php
0.467 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
GivePluginSettingsData.php
2.408 KB
1 May 2024 11.40 PM
bravrvjk / bravrvjk
0644
PluginsData.php
1.524 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
ServerData.php
1.727 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
ThemeData.php
1.337 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
WebsiteData.php
1.24 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644
WebsiteInfoData.php
0.843 KB
24 Nov 2021 4.55 AM
bravrvjk / bravrvjk
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF