first commit

This commit is contained in:
CHIEFSOFT\ameye
2024-06-08 17:09:23 -04:00
commit df3a033196
17887 changed files with 8637778 additions and 0 deletions
@@ -0,0 +1,156 @@
<?php
/**
* @file controllers/grid/submissions/ExportPublishedSubmissionsListGridCellProvider.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 ExportPublishedSubmissionsListGridCellProvider
*
* @ingroup controllers_grid_submissions
*
* @brief Class for a cell provider that can retrieve labels from submissions
*/
namespace APP\controllers\grid\submissions;
use APP\core\Application;
use APP\facades\Repo;
use APP\submission\Submission;
use PKP\controllers\grid\DataObjectGridCellProvider;
use PKP\controllers\grid\GridHandler;
use PKP\core\PKPApplication;
use PKP\linkAction\LinkAction;
use PKP\linkAction\request\AjaxModal;
use PKP\linkAction\request\RedirectAction;
use PKP\plugins\ImportExportPlugin;
class ExportPublishedSubmissionsListGridCellProvider extends DataObjectGridCellProvider
{
/** @var ImportExportPlugin */
public $_plugin;
public $_authorizedRoles;
public $_titleColumn;
/**
* Constructor
*
* @param null|mixed $authorizedRoles
*/
public function __construct($plugin, $authorizedRoles = null)
{
$this->_plugin = $plugin;
if ($authorizedRoles) {
$this->_authorizedRoles = $authorizedRoles;
}
parent::__construct();
}
//
// Template methods from GridCellProvider
//
/**
* Get cell actions associated with this row/column combination
*
* @copydoc GridCellProvider::getCellActions()
*/
public function getCellActions($request, $row, $column, $position = GridHandler::GRID_ACTION_POSITION_DEFAULT)
{
$submission = $row->getData();
$columnId = $column->getId();
assert($submission instanceof Submission && !empty($columnId));
switch ($columnId) {
case 'title':
$this->_titleColumn = $column;
$title = $submission->getCurrentPublication()->getLocalizedTitle(null, 'html');
if (empty($title)) {
$title = __('common.untitled');
}
$authorsInTitle = $submission->getCurrentPublication()->getShortAuthorString();
$title = $authorsInTitle . '; ' . $title;
return [
new LinkAction(
'itemWorkflow',
new RedirectAction(
Repo::submission()->getWorkflowUrlByUserRoles($submission)
),
htmlspecialchars($title)
)
];
case 'issue':
$contextId = $submission->getContextId();
$issueId = $submission->getCurrentPublication()->getData('issueId');
$issue = Repo::issue()->get($issueId);
$issue = $issue->getJournalId() == $contextId ? $issue : null;
if ($issue) {
// Link to the issue edit modal
$application = Application::get();
$dispatcher = $application->getDispatcher();
return [
new LinkAction(
'edit',
new AjaxModal(
$dispatcher->url($request, PKPApplication::ROUTE_COMPONENT, null, 'grid.issues.BackIssueGridHandler', 'editIssue', null, ['issueId' => $issue->getId()]),
__('plugins.importexport.common.settings.DOIPluginSettings')
),
$issue->getIssueIdentification(),
null
)
];
}
break;
case 'status':
$status = $submission->getData($this->_plugin->getDepositStatusSettingName());
$statusNames = $this->_plugin->getStatusNames();
$statusActions = $this->_plugin->getStatusActions($submission);
if ($status && array_key_exists($status, $statusActions)) {
assert(array_key_exists($status, $statusNames));
return [$statusActions[$status]];
}
break;
}
return parent::getCellActions($request, $row, $column, $position);
}
/**
* Extracts variables for a given column from a data element
* so that they may be assigned to template before rendering.
*
* @copydoc DataObjectGridCellProvider::getTemplateVarsFromRowColumn()
*/
public function getTemplateVarsFromRowColumn($row, $column)
{
$submission = $row->getData();
$columnId = $column->getId();
assert($submission instanceof Submission && !empty($columnId));
switch ($columnId) {
case 'id':
return ['label' => $submission->getId()];
case 'title':
return ['label' => ''];
case 'issue':
return ['label' => ''];
case 'status':
$status = $submission->getData($this->_plugin->getDepositStatusSettingName());
$statusNames = $this->_plugin->getStatusNames();
$statusActions = $this->_plugin->getStatusActions($submission);
if ($status) {
if (array_key_exists($status, $statusActions)) {
$label = '';
} else {
assert(array_key_exists($status, $statusNames));
$label = $statusNames[$status];
}
} else {
$label = $statusNames[EXPORT_STATUS_NOT_DEPOSITED];
}
return ['label' => $label];
}
}
}
@@ -0,0 +1,321 @@
<?php
/**
* @file controllers/grid/submissions/ExportPublishedSubmissionsListGridHandler.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 ExportPublishedSubmissionsListGridHandler
*
* @ingroup controllers_grid_submissions
*
* @brief Handle exportable published submissions list grid requests.
*/
namespace APP\controllers\grid\submissions;
use APP\core\Application;
use APP\facades\Repo;
use APP\issue\Collector;
use PKP\controllers\grid\feature\PagingFeature;
use PKP\controllers\grid\feature\selectableItems\SelectableItemsFeature;
use PKP\controllers\grid\GridColumn;
use PKP\controllers\grid\GridHandler;
use PKP\plugins\ImportExportPlugin;
use PKP\plugins\PluginRegistry;
use PKP\security\authorization\PolicySet;
use PKP\security\authorization\RoleBasedHandlerOperationPolicy;
use PKP\security\Role;
class ExportPublishedSubmissionsListGridHandler extends GridHandler
{
/** @var ImportExportPlugin */
public $_plugin;
/**
* Constructor
*/
public function __construct()
{
parent::__construct();
$this->addRoleAssignment(
[Role::ROLE_ID_MANAGER, Role::ROLE_ID_SITE_ADMIN],
['fetchGrid', 'fetchRow']
);
}
//
// Implement template methods from PKPHandler
//
/**
* @copydoc PKPHandler::authorize()
*/
public function authorize($request, &$args, $roleAssignments)
{
$rolePolicy = new PolicySet(PolicySet::COMBINING_PERMIT_OVERRIDES);
foreach ($roleAssignments as $role => $operations) {
$rolePolicy->addPolicy(new RoleBasedHandlerOperationPolicy($request, $role, $operations));
}
$this->addPolicy($rolePolicy);
return parent::authorize($request, $args, $roleAssignments);
}
/**
* @copydoc GridHandler::initialize()
*
* @param null|mixed $args
*/
public function initialize($request, $args = null)
{
parent::initialize($request, $args);
$context = $request->getContext();
// Basic grid configuration.
$this->setTitle('plugins.importexport.common.export.articles');
$pluginCategory = $request->getUserVar('category');
$pluginPathName = $request->getUserVar('plugin');
// Allow for plugins that have already been loaded (e.g. by injection from a generic plugin)
$this->_plugin = PluginRegistry::getPlugin($pluginCategory, $pluginPathName);
// Otherwise, load the plugin as specified
$this->_plugin ??= PluginRegistry::loadPlugin($pluginCategory, $pluginPathName);
assert(isset($this->_plugin));
// Grid columns.
$cellProvider = $this->getGridCellProvider();
$this->addColumn(
new GridColumn(
'id',
null,
__('common.id'),
'controllers/grid/gridCell.tpl',
$cellProvider,
['alignment' => GridColumn::COLUMN_ALIGNMENT_LEFT,
'width' => 10]
)
);
$this->addColumn(
new GridColumn(
'title',
'grid.submission.itemTitle',
null,
null,
$cellProvider,
['html' => true,
'alignment' => GridColumn::COLUMN_ALIGNMENT_LEFT]
)
);
$this->addColumn(
new GridColumn(
'issue',
'issue.issue',
null,
null,
$cellProvider,
['alignment' => GridColumn::COLUMN_ALIGNMENT_LEFT,
'width' => 20]
)
);
if (method_exists($this, 'addAdditionalColumns')) {
$this->addAdditionalColumns($cellProvider);
}
$this->addColumn(
new GridColumn(
'status',
'common.status',
null,
null,
$cellProvider,
['alignment' => GridColumn::COLUMN_ALIGNMENT_LEFT,
'width' => 10]
)
);
}
//
// Implemented methods from GridHandler.
//
/**
* @copydoc GridHandler::initFeatures()
*/
public function initFeatures($request, $args)
{
return [new SelectableItemsFeature(), new PagingFeature()];
}
/**
* @copydoc GridHandler::getRequestArgs()
*/
public function getRequestArgs()
{
return array_merge(parent::getRequestArgs(), ['category' => $this->_plugin->getCategory(), 'plugin' => basename($this->_plugin->getPluginPath())]);
}
/**
* @copydoc GridHandler::isDataElementSelected()
*/
public function isDataElementSelected($gridDataElement)
{
return false; // Nothing is selected by default
}
/**
* @copydoc GridHandler::getSelectName()
*/
public function getSelectName()
{
return 'selectedSubmissions';
}
/**
* @copydoc GridHandler::getFilterForm()
*/
protected function getFilterForm()
{
return 'controllers/grid/submissions/exportPublishedSubmissionsGridFilter.tpl';
}
/**
* @copydoc GridHandler::renderFilter()
*/
public function renderFilter($request, $filterData = [])
{
$context = $request->getContext();
$issues = Repo::issue()->getCollector()
->filterByContextIds([$context->getId()])
->filterByPublished(true)
->orderBy(Collector::ORDERBY_PUBLISHED_ISSUES)
->getMany();
foreach ($issues as $issue) {
$issueOptions[$issue->getId()] = $issue->getIssueIdentification();
}
$issueOptions[0] = __('plugins.importexport.common.filter.issue');
ksort($issueOptions);
$statusNames = $this->_plugin->getStatusNames();
$filterColumns = $this->getFilterColumns();
$allFilterData = array_merge(
$filterData,
[
'columns' => $filterColumns,
'issues' => $issueOptions,
'status' => $statusNames,
'gridId' => $this->getId(),
]
);
return parent::renderFilter($request, $allFilterData);
}
/**
* @copydoc GridHandler::getFilterSelectionData()
*/
public function getFilterSelectionData($request)
{
$search = (string) $request->getUserVar('search');
$column = (string) $request->getUserVar('column');
$issueId = (int) $request->getUserVar('issueId');
$statusId = (string) $request->getUserVar('statusId');
return [
'search' => $search,
'column' => $column,
'issueId' => $issueId,
'statusId' => $statusId,
];
}
/**
* @copydoc GridHandler::loadData()
*/
protected function loadData($request, $filter)
{
$context = $request->getContext();
[$search, $column, $issueId, $statusId] = $this->getFilterValues($filter);
$title = $author = null;
if ($column == 'title') {
$title = $search;
} elseif ($column == 'author') {
$author = $search;
}
$pubIdStatusSettingName = null;
if ($statusId) {
$pubIdStatusSettingName = $this->_plugin->getDepositStatusSettingName();
}
return Repo::submission()->dao->getExportable(
$context->getId(),
null,
$title,
$author,
$issueId,
$pubIdStatusSettingName,
$statusId,
$this->getGridRangeInfo($request, $this->getId())
);
}
//
// Own protected methods
//
/**
* Get which columns can be used by users to filter data.
*
* @return array
*/
protected function getFilterColumns()
{
return [
'title' => __('submission.title'),
'author' => __('submission.authors')
];
}
/**
* Process filter values, assigning default ones if
* none was set.
*
* @return array
*/
protected function getFilterValues($filter)
{
if (isset($filter['search']) && $filter['search']) {
$search = $filter['search'];
} else {
$search = null;
}
if (isset($filter['column']) && $filter['column']) {
$column = $filter['column'];
} else {
$column = null;
}
if (isset($filter['issueId']) && $filter['issueId']) {
$issueId = $filter['issueId'];
} else {
$issueId = null;
}
if (isset($filter['statusId']) && $filter['statusId'] != EXPORT_STATUS_ANY) {
$statusId = $filter['statusId'];
} else {
$statusId = null;
}
return [$search, $column, $issueId, $statusId];
}
/**
* Get the grid cell provider instance
*
* @return ExportPublishedSubmissionsListGridCellProvider
*/
public function getGridCellProvider()
{
// Fetch the authorized roles.
$authorizedRoles = $this->getAuthorizedContextObject(Application::ASSOC_TYPE_USER_ROLES);
return new ExportPublishedSubmissionsListGridCellProvider($this->_plugin, $authorizedRoles);
}
}