class RollingInterval in Recurring Time Period 8
Provides a period based on a rolling interval from the start date.
Plugin annotation
@RecurringPeriod(
id = "rolling_interval",
label = @Translation("Rolling interval"),
description = @Translation("Provide a period based on a rolling interval"),
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\recurring_period\Plugin\RecurringPeriod\RecurringPeriodBase implements ContainerFactoryPluginInterface, RecurringPeriodInterface uses StringTranslationTrait
- class \Drupal\recurring_period\Plugin\RecurringPeriod\RollingInterval
- class \Drupal\recurring_period\Plugin\RecurringPeriod\RecurringPeriodBase implements ContainerFactoryPluginInterface, RecurringPeriodInterface uses StringTranslationTrait
Expanded class hierarchy of RollingInterval
File
- src/
Plugin/ RecurringPeriod/ RollingInterval.php, line 16
Namespace
Drupal\recurring_period\Plugin\RecurringPeriodView source
class RollingInterval extends RecurringPeriodBase {
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
return [
// The interval configuration.
'interval' => [
// The interval period. This is the ID of an interval plugin, for
// example 'month'.
'period' => '',
// The interval. This is a value which multiplies the period.
'interval' => '',
],
] + parent::defaultConfiguration();
}
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$config = $this
->getConfiguration();
$form['interval'] = [
'#type' => 'interval',
'#title' => 'Interval',
'#default_value' => $config['interval'],
];
return $form;
}
/**
* {@inheritdoc}
*/
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
$values = $form_state
->getValue($form['#parents']);
$this->configuration['interval'] = $values['interval'];
}
/**
* {@inheritdoc}
*/
public function calculateDate(\DateTimeImmutable $start) {
return $this
->calculateEnd($start);
}
/**
* {@inheritdoc}
*/
public function calculateStart(\DateTimeImmutable $date) {
// For a rolling interval, the start date is the same as the given date.
return $date;
}
/**
* {@inheritdoc}
*/
public function calculateEnd(\DateTimeImmutable $start) {
// Get our interval values from our configuration.
$config = $this
->getConfiguration();
$interval_configuration = $config['interval'];
// The interval plugin ID is the 'period' value.
$interval_plugin_id = $interval_configuration['period'];
// Create a DateInterval that represents the interval.
// TODO: This can be removed when https://www.drupal.org/node/2900435 lands.
$interval_plugin_definition = $this->pluginManagerIntervals
->getDefinition($interval_plugin_id);
$value = $interval_configuration['interval'] * $interval_plugin_definition['multiplier'];
$date_interval = \DateInterval::createFromDateString($value . ' ' . $interval_plugin_definition['php']);
return $start
->add($date_interval);
}
/**
* {@inheritdoc}
*/
public function getPeriodLabel(\DateTimeImmutable $start, \DateTimeImmutable $end) {
// Get our interval values from our configuration.
$config = $this
->getConfiguration();
$interval_configuration = $config['interval'];
// The interval plugin ID is the 'period' value.
$interval_plugin_id = $interval_configuration['period'];
$interval_plugin_definition = $this->pluginManagerIntervals
->getDefinition($interval_plugin_id);
return $this
->t("@count @interval from @start-date", [
'@count' => $config['interval']['interval'],
'@interval' => $config['interval']['interval'] == 1 ? $interval_plugin_definition['singular'] : $interval_plugin_definition['plural'],
'@start-date' => $start
->format(\DateTimeInterface::RSS),
]);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
RecurringPeriodBase:: |
protected | property | The Interval Plugin Manager service. | |
RecurringPeriodBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
|
RecurringPeriodBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
RecurringPeriodBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
RecurringPeriodBase:: |
public | function |
Gets the plugin description. Overrides RecurringPeriodInterface:: |
|
RecurringPeriodBase:: |
public | function |
Gets the plugin label. Overrides RecurringPeriodInterface:: |
|
RecurringPeriodBase:: |
public | function |
Calculates the period after the given period. Overrides RecurringPeriodInterface:: |
|
RecurringPeriodBase:: |
public | function |
Gets a period object that contains the given date. Overrides RecurringPeriodInterface:: |
|
RecurringPeriodBase:: |
public | function |
Gets a period object that begins on a given date. Overrides RecurringPeriodInterface:: |
|
RecurringPeriodBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
|
RecurringPeriodBase:: |
public | function |
Form validation handler. Overrides PluginFormInterface:: |
|
RecurringPeriodBase:: |
public | function |
Constructs a new plugin instance. Overrides PluginBase:: |
|
RecurringPeriodInterface:: |
constant | Represents an unlimited end time. | ||
RollingInterval:: |
public | function |
Form constructor. Overrides RecurringPeriodBase:: |
|
RollingInterval:: |
public | function |
Calculates the end date and time for the period. Overrides RecurringPeriodInterface:: |
|
RollingInterval:: |
public | function |
Calculates the end date and time for the period. Overrides RecurringPeriodBase:: |
|
RollingInterval:: |
public | function |
Calculates the end of the previous period. Overrides RecurringPeriodBase:: |
|
RollingInterval:: |
public | function |
Gets default configuration for this plugin. Overrides RecurringPeriodBase:: |
|
RollingInterval:: |
public | function |
Gets a label for the period starting from the given date. Overrides RecurringPeriodBase:: |
|
RollingInterval:: |
public | function |
Form submission handler. Overrides RecurringPeriodBase:: |
|
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |