first commit
This commit is contained in:
@@ -0,0 +1,117 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @file classes/controllers/grid/GridCellProvider.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 GridCellProvider
|
||||
*
|
||||
* @ingroup controllers_grid
|
||||
*
|
||||
* @brief Base class for a grid column's cell provider.
|
||||
*
|
||||
* Grid cell providers provide formatted data to grid columns.
|
||||
* For general information about grids, see GridHandler.
|
||||
*/
|
||||
|
||||
namespace PKP\controllers\grid;
|
||||
|
||||
use APP\core\Request;
|
||||
use APP\template\TemplateManager;
|
||||
use PKP\facades\Locale;
|
||||
|
||||
class GridCellProvider
|
||||
{
|
||||
/**
|
||||
* Constructor
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
}
|
||||
|
||||
//
|
||||
// Public methods
|
||||
//
|
||||
|
||||
/**
|
||||
* To be used by a GridRow to generate a rendered representation of
|
||||
* the element for the given column.
|
||||
*
|
||||
* @param \PKP\controllers\grid\GridRow $row
|
||||
* @param GridColumn $column
|
||||
*
|
||||
* @return string the rendered representation of the element for the given column
|
||||
*/
|
||||
public function render($request, $row, $column)
|
||||
{
|
||||
$columnId = $column->getId();
|
||||
assert(!empty($columnId));
|
||||
|
||||
// Construct a default cell id (null for "nonexistent" new rows)
|
||||
$rowId = $row->getId(); // Potentially null (indicating row not backed in the DB)
|
||||
$cellId = isset($rowId) ? $rowId . '-' . $columnId : null;
|
||||
|
||||
// Assign values extracted from the element for the cell.
|
||||
$templateMgr = TemplateManager::getManager($request);
|
||||
$templateVars = $this->getTemplateVarsFromRowColumn($row, $column);
|
||||
foreach ($templateVars as $varName => $varValue) {
|
||||
$templateMgr->assign($varName, $varValue);
|
||||
}
|
||||
$templateMgr->assign([
|
||||
'id' => $cellId,
|
||||
'column' => $column,
|
||||
'actions' => $this->getCellActions($request, $row, $column),
|
||||
'flags' => $column->getFlags(),
|
||||
'formLocales' => Locale::getSupportedFormLocales(),
|
||||
]);
|
||||
$template = $column->getTemplate();
|
||||
assert(!empty($template));
|
||||
return $templateMgr->fetch($template);
|
||||
}
|
||||
|
||||
//
|
||||
// Protected template methods
|
||||
//
|
||||
/**
|
||||
* Subclasses have to implement this method to extract variables
|
||||
* for a given column from a data element so that they may be assigned
|
||||
* to template before rendering.
|
||||
*
|
||||
* @param \PKP\controllers\grid\GridRow $row
|
||||
* @param GridColumn $column
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function getTemplateVarsFromRowColumn($row, $column)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Subclasses can override this template method to provide
|
||||
* cell specific actions.
|
||||
*
|
||||
* NB: The default implementation delegates to the grid column for
|
||||
* cell-specific actions. Another thinkable implementation would
|
||||
* be row-specific actions in which case action instantiation
|
||||
* should be delegated to the row.
|
||||
*
|
||||
* @param Request $request
|
||||
* @param \PKP\controllers\grid\GridRow $row
|
||||
* @param GridColumn $column
|
||||
* @param int $position GRID_ACTION_POSITION_...
|
||||
*
|
||||
* @return array an array of LinkAction instances
|
||||
*/
|
||||
public function getCellActions($request, $row, $column, $position = GridHandler::GRID_ACTION_POSITION_DEFAULT)
|
||||
{
|
||||
return $column->getCellActions($request, $row, $position);
|
||||
}
|
||||
}
|
||||
|
||||
if (!PKP_STRICT_MODE) {
|
||||
class_alias('\PKP\controllers\grid\GridCellProvider', '\GridCellProvider');
|
||||
}
|
||||
Reference in New Issue
Block a user