HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/components/
Upload File :
Current File : //home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/components/PKPStatsComponent.php
<?php
/**
 * @file components/PKPStatsComponent.php
 *
 * Copyright (c) 2014-2021 Simon Fraser University
 * Copyright (c) 2000-2021 John Willinsky
 * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
 *
 * @class PKPStatsComponent
 *
 * @ingroup classes_components_stats
 *
 * @brief A class to prepare the data object for a statistics UI component
 */

namespace PKP\components;

use PKP\statistics\PKPStatisticsHelper;

class PKPStatsComponent
{
    /** @var string The URL to the /stats API endpoint */
    public $apiUrl = '';

    /** @var array Configuration for the columns to display in the table */
    public $tableColumns = [];

    /** @var string Retrieve stats after this date */
    public $dateStart = '';

    /** @var string Retrieve stats before this date */
    public $dateEnd = '';

    /** @var array Quick options to provide for configuring the date range */
    public $dateRangeOptions = [];

    /** @var array|null Configuration assoc array for available filters */
    public $filters = null;

    /**
     * Constructor
     *
     * @param string $apiUrl The URL to fetch stats from
     * @param array $args Optional arguments
     */
    public function __construct($apiUrl, $args = [])
    {
        $this->apiUrl = $apiUrl;
        $this->init($args);
    }

    /**
     * Initialize the handler with config parameters
     *
     * @param array $args Configuration params
     */
    public function init($args = [])
    {
        foreach ($args as $key => $value) {
            if (property_exists($this, $key)) {
                $this->{$key} = $value;
            }
        }
    }

    /**
     * Retrieve the configuration data to be used when initializing this
     * handler on the frontend
     *
     * @return array Configuration data
     */
    public function getConfig()
    {
        $config = [
            'apiUrl' => $this->apiUrl,
            'tableColumns' => $this->tableColumns,
            'dateStart' => $this->dateStart,
            'dateStartMin' => PKPStatisticsHelper::STATISTICS_EARLIEST_DATE,
            'dateEnd' => $this->dateEnd,
            'dateEndMax' => date('Y-m-d', strtotime('yesterday')),
            'dateRangeOptions' => $this->dateRangeOptions,
            'activeFilters' => [],
            'isLoadingItems' => false,
            'isSidebarVisible' => false,
        ];

        if ($this->filters) {
            $config['filters'] = $this->filters;
        }

        return $config;
    }
}