tamper-8.x-1.x-dev/src/Plugin/Tamper/Sprintf.php
src/Plugin/Tamper/Sprintf.php
<?php
namespace Drupal\tamper\Plugin\Tamper;
use Drupal\Core\Form\FormStateInterface;
use Drupal\tamper\Exception\TamperException;
use Drupal\tamper\TamperBase;
use Drupal\tamper\TamperableItemInterface;
/**
* Plugin implementation of the Sprintf plugin.
*
* @Tamper(
* id = "sprintf",
* label = @Translation("Format string"),
* description = @Translation("Format string"),
* category = @Translation("Text"),
* itemUsage = "ignored"
* )
*/
class Sprintf extends TamperBase {
const SETTING_TEXT_FORMAT = 'format';
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
$config = parent::defaultConfiguration();
$config[self::SETTING_TEXT_FORMAT] = '%s';
return $config;
}
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$form[self::SETTING_TEXT_FORMAT] = [
'#type' => 'textfield',
'#title' => $this->t('Format'),
'#default_value' => $this->getSetting(self::SETTING_TEXT_FORMAT),
'#size' => 60,
'#maxlength' => 128,
'#required' => TRUE,
'#description' => $this->t('See the <a href="@url">sprintf</a> documentation for more details.', ['@url' => 'http://www.php.net/manual/en/function.sprintf.php']),
];
return $form;
}
/**
* {@inheritdoc}
*/
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
parent::submitConfigurationForm($form, $form_state);
$this->setConfiguration([
self::SETTING_TEXT_FORMAT => $form_state->getValue(self::SETTING_TEXT_FORMAT),
]);
}
/**
* {@inheritdoc}
*/
public function tamper($data, ?TamperableItemInterface $item = NULL) {
// Don't process empty or null values.
if (is_null($data) || $data === '') {
return $data;
}
if (!is_string($data) && !is_numeric($data)) {
throw new TamperException('Input should be a string or numeric.');
}
return sprintf($this->getSetting(self::SETTING_TEXT_FORMAT), $data);
}
}
