229 lines
6.7 KiB
PHP
229 lines
6.7 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @file controllers/grid/subscriptions/IndividualSubscriptionsGridHandler.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 IndividualSubscriptionsGridHandler
|
|
*
|
|
* @ingroup controllers_grid_subscriptions
|
|
*
|
|
* @brief Handle subscription grid requests.
|
|
*/
|
|
|
|
namespace APP\controllers\grid\subscriptions;
|
|
|
|
use APP\core\Request;
|
|
use APP\facades\Repo;
|
|
use APP\notification\NotificationManager;
|
|
use APP\subscription\IndividualSubscriptionDAO;
|
|
use APP\subscription\SubscriptionDAO;
|
|
use PKP\controllers\grid\GridColumn;
|
|
use PKP\core\JSONMessage;
|
|
use PKP\db\DAO;
|
|
use PKP\db\DAORegistry;
|
|
use PKP\identity\Identity;
|
|
use PKP\notification\PKPNotification;
|
|
|
|
class IndividualSubscriptionsGridHandler extends SubscriptionsGridHandler
|
|
{
|
|
/**
|
|
* @copydoc SubscriptionsGridHandler::initialize()
|
|
*
|
|
* @param null|mixed $args
|
|
*/
|
|
public function initialize($request, $args = null)
|
|
{
|
|
parent::initialize($request, $args);
|
|
|
|
// Basic grid configuration.
|
|
$this->setTitle('subscriptionManager.individualSubscriptions');
|
|
|
|
//
|
|
// Grid columns.
|
|
//
|
|
$cellProvider = new SubscriptionsGridCellProvider();
|
|
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'name',
|
|
'common.name',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'email',
|
|
'user.email',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'subscriptionType',
|
|
'manager.subscriptions.subscriptionType',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'status',
|
|
'manager.subscriptions.form.status',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'dateStart',
|
|
'manager.subscriptions.dateStart',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'dateEnd',
|
|
'manager.subscriptions.dateEnd',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
$this->addColumn(
|
|
new GridColumn(
|
|
'referenceNumber',
|
|
'manager.subscriptions.referenceNumber',
|
|
null,
|
|
null,
|
|
$cellProvider
|
|
)
|
|
);
|
|
}
|
|
|
|
|
|
//
|
|
// Implement methods from GridHandler.
|
|
//
|
|
/**
|
|
* @copydoc GridHandler::renderFilter()
|
|
*/
|
|
public function renderFilter($request, $filterData = [])
|
|
{
|
|
$userDao = Repo::user()->dao;
|
|
return parent::renderFilter($request, array_merge_recursive(
|
|
$filterData,
|
|
[
|
|
'fieldOptions' => [
|
|
Identity::IDENTITY_SETTING_GIVENNAME => 'user.givenName',
|
|
Identity::IDENTITY_SETTING_FAMILYNAME => 'user.familyName',
|
|
$userDao::USER_FIELD_USERNAME => 'user.username',
|
|
$userDao::USER_FIELD_EMAIL => 'user.email',
|
|
SubscriptionDAO::SUBSCRIPTION_MEMBERSHIP => 'user.subscriptions.form.membership',
|
|
SubscriptionDAO::SUBSCRIPTION_REFERENCE_NUMBER => 'manager.subscriptions.form.referenceNumber',
|
|
SubscriptionDAO::SUBSCRIPTION_NOTES => 'manager.subscriptions.form.notes',
|
|
],
|
|
'matchOptions' => [
|
|
'contains' => 'form.contains',
|
|
'is' => 'form.is'
|
|
]
|
|
]
|
|
));
|
|
}
|
|
|
|
/**
|
|
* @copydoc GridHandler::loadData()
|
|
*/
|
|
protected function loadData($request, $filter)
|
|
{
|
|
// Get the context.
|
|
$journal = $request->getContext();
|
|
|
|
$subscriptionDao = DAORegistry::getDAO('IndividualSubscriptionDAO'); /** @var IndividualSubscriptionDAO $subscriptionDao */
|
|
$rangeInfo = $this->getGridRangeInfo($request, $this->getId());
|
|
return $subscriptionDao->getByJournalId($journal->getId(), null, $filter['searchField'], $filter['searchMatch'], $filter['search'] ? $filter['search'] : null, null, null, null, $rangeInfo);
|
|
}
|
|
|
|
|
|
//
|
|
// Public grid actions.
|
|
//
|
|
/**
|
|
* Edit an existing subscription.
|
|
*
|
|
* @param array $args
|
|
* @param Request $request
|
|
*
|
|
* @return JSONMessage JSON object
|
|
*/
|
|
public function editSubscription($args, $request)
|
|
{
|
|
// Form handling.
|
|
$subscriptionForm = new IndividualSubscriptionForm($request, $request->getUserVar('rowId'));
|
|
$subscriptionForm->initData();
|
|
|
|
return new JSONMessage(true, $subscriptionForm->fetch($request));
|
|
}
|
|
|
|
/**
|
|
* Update an existing subscription.
|
|
*
|
|
* @param array $args
|
|
* @param Request $request
|
|
*
|
|
* @return JSONMessage JSON object
|
|
*/
|
|
public function updateSubscription($args, $request)
|
|
{
|
|
$subscriptionId = $request->getUserVar('subscriptionId');
|
|
// Form handling.
|
|
$subscriptionForm = new IndividualSubscriptionForm($request, $subscriptionId);
|
|
$subscriptionForm->readInputData();
|
|
|
|
if ($subscriptionForm->validate()) {
|
|
$subscriptionForm->execute();
|
|
$notificationManager = new NotificationManager();
|
|
$notificationManager->createTrivialNotification($request->getUser()->getId(), PKPNotification::NOTIFICATION_TYPE_SUCCESS);
|
|
// Prepare the grid row data.
|
|
return DAO::getDataChangedEvent($subscriptionId);
|
|
} else {
|
|
return new JSONMessage(true, $subscriptionForm->fetch($request));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Delete a subscription.
|
|
*
|
|
* @param array $args
|
|
* @param Request $request
|
|
*
|
|
* @return JSONMessage JSON object
|
|
*/
|
|
public function deleteSubscription($args, $request)
|
|
{
|
|
if (!$request->checkCSRF()) {
|
|
return new JSONMessage(false);
|
|
}
|
|
|
|
$context = $request->getContext();
|
|
$user = $request->getUser();
|
|
|
|
// Identify the subscription ID.
|
|
$subscriptionId = $request->getUserVar('rowId');
|
|
$subscriptionDao = DAORegistry::getDAO('IndividualSubscriptionDAO'); /** @var IndividualSubscriptionDAO $subscriptionDao */
|
|
$subscriptionDao->deleteById($subscriptionId, $context->getId());
|
|
return DAO::getDataChangedEvent();
|
|
}
|
|
}
|