-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathKBARTExportSettingsForm.inc.php
92 lines (79 loc) · 2.87 KB
/
KBARTExportSettingsForm.inc.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
import('lib.pkp.classes.form.Form');
class KBARTExportSettingsForm extends Form {
/** @var KBARTExportPlugin */
public $plugin;
/**
* @copydoc Form::__construct()
*/
public function __construct($plugin) {
// Define the settings template and store a copy of the plugin object
parent::__construct($plugin->getTemplateResource('settings.tpl'));
$this->plugin = $plugin;
// Always add POST and CSRF validation to secure your form.
$this->addCheck(new FormValidatorPost($this));
$this->addCheck(new FormValidatorCSRF($this));
}
/**
* Load settings already saved in the database
*
* Settings are stored by context, so that each journal or press
* can have different settings.
*/
public function initData() {
$context = Application::get()->getRequest()->getContext();
// $contextId = $context ? $context->getId() : CONTEXT_SITE;
$contextId = CONTEXT_SITE;
$this->setData('providerName', $this->plugin->getSetting($contextId, 'providerName'));
$this->setData('regionConsortium', $this->plugin->getSetting($contextId, 'regionConsortium'));
$this->setData('packageName', $this->plugin->getSetting($contextId, 'packageName'));
parent::initData();
}
/**
* Load data that was submitted with the form
*/
public function readInputData() {
$this->readUserVars(['providerName']);
$this->readUserVars(['regionConsortium']);
$this->readUserVars(['packageName']);
parent::readInputData();
}
/**
* Fetch any additional data needed for your form.
*
* Data assigned to the form using $this->setData() during the
* initData() or readInputData() methods will be passed to the
* template.
*
* @return string
*/
public function fetch($request, $template = null, $display = false) {
// Pass the plugin name to the template so that it can be
// used in the URL that the form is submitted to
$templateMgr = TemplateManager::getManager($request);
$templateMgr->assign('pluginName', $this->plugin->getName());
return parent::fetch($request, $template, $display);
}
/**
* Save the settings
*
* @return null|mixed
*/
public function execute() {
$context = Application::get()->getRequest()->getContext();
// $contextId = $context ? $context->getId() : CONTEXT_SITE;
$contextId = CONTEXT_SITE;
$this->plugin->updateSetting($contextId, 'providerName', $this->getData('providerName'));
$this->plugin->updateSetting($contextId, 'regionConsortium', $this->getData('regionConsortium'));
$this->plugin->updateSetting($contextId, 'packageName', $this->getData('packageName'));
// Tell the user that the save was successful.
import('classes.notification.NotificationManager');
$notificationMgr = new NotificationManager();
$notificationMgr->createTrivialNotification(
Application::get()->getRequest()->getUser()->getId(),
NOTIFICATION_TYPE_SUCCESS,
['contents' => __('common.changesSaved')]
);
return parent::execute();
}
}