| Server IP : 195.134.90.114 / Your IP : 216.73.216.86 Web Server : Apache/2.4.58 System : Linux nepub 6.8.0-88-generic #89-Ubuntu SMP PREEMPT_DYNAMIC Sat Oct 11 01:02:46 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 8.2.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /var/www/html/public_html/lib/pkp/classes/controllers/grid/ |
Upload File : |
<?php
/**
* @file classes/controllers/grid/DateGridCellProvider.inc.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 DateGridCellProvider
* @ingroup controllers_grid
*
* @brief Wraps date formatting support around a provided DataProvider.
*/
use function PHP81_BC\strftime;
import('lib.pkp.classes.controllers.grid.GridCellProvider');
class DateGridCellProvider extends GridCellProvider {
/** @var The actual data provider to wrap */
var $_dataProvider;
/** @var The format to use; see strftime */
var $_format;
/**
* Constructor
* @param $dataProvider DataProvider The object to wrap
* @param $format string See strftime
*/
function __construct($dataProvider, $format) {
parent::__construct();
$this->_dataProvider = $dataProvider;
$this->_format = $format;
}
//
// Template methods from GridCellProvider
//
/**
* Fetch a value from the provided DataProvider (in constructor)
* and format it as a date.
* @param $row GridRow
* @param $column GridColumn
* @return array
*/
function getTemplateVarsFromRowColumn($row, $column) {
$v = $this->_dataProvider->getTemplateVarsFromRowColumn($row, $column);
$v['label'] = strftime($this->_format, strtotime($v['label']));
return $v;
}
}