LimeSurvey Plugin Settings
Bismark
Posted on May 26, 2022
In my last article I created a simple plugin for LimeSurvey,
that is used at the command line, which can be useful for cronjobs.
The next step could be some plugin settings. There are two types.
Global Plugin Settings
Global Plugin Settings are defined in a variable $settings
protected $settings = [
'setting1' => [
'type' => 'string',
'label' => 'Setting One',
'help' => 'This might be a useful hint',
'default' => ''
]
];
You can access this setting via:
var_dump($this->get('setting1'));
Survey Level Plugin Settings
In order to create some settings on survey level, you have to subscribe two events in your init()
method.
public function init()
{
/* @see https://manual.limesurvey.org/BeforeSurveySettings */
$this->subscribe('beforeSurveySettings');
/* @see https://manual.limesurvey.org/NewSurveySettings */
$this->subscribe('newSurveySettings');
}
Next we define a field isActive
of type boolean.
There are several types available. See some examples here:
public function beforeSurveySettings()
{
$event = $this->event;
$surveyId = $event->get('survey');
$event->set("surveysettings.{$this->id}", [
'name' => get_class($this),
'settings' => [
'isActive' => [
'type' => 'boolean',
'label' => 'enable plugin for this survey',
'current' => $this->get('isActive', 'Survey', $surveyId, false),
'help' => 'some useful hint'
]
]
]);
}
The following code is needed to save your survey settings:
public function newSurveySettings()
{
$event = $this->event;
foreach ($event->get('settings') as $name => $value) {
$this->set($name, $value, 'Survey', $event->get('survey'));
}
}
That's it.
Bye!
💖 💪 🙅 🚩
Bismark
Posted on May 26, 2022
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.