class SmartDateFieldItemList in Smart Date 3.0.x
Same name and namespace in other branches
- 8.2 src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- 8 src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- 3.x src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- 3.1.x src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- 3.2.x src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- 3.3.x src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- 3.4.x src/Plugin/Field/FieldType/SmartDateFieldItemList.php \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
Represents a configurable entity smartdate field.
Hierarchy
- class \Drupal\Core\TypedData\TypedData implements PluginInspectionInterface, TypedDataInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Core\TypedData\Plugin\DataType\ItemList implements \Drupal\Core\TypedData\Plugin\DataType\IteratorAggregate, ListInterface
- class \Drupal\Core\Field\FieldItemList implements FieldItemListInterface
- class \Drupal\datetime\Plugin\Field\FieldType\DateTimeFieldItemList
- class \Drupal\smart_date\Plugin\Field\FieldType\SmartDateFieldItemList
- class \Drupal\datetime\Plugin\Field\FieldType\DateTimeFieldItemList
- class \Drupal\Core\Field\FieldItemList implements FieldItemListInterface
- class \Drupal\Core\TypedData\Plugin\DataType\ItemList implements \Drupal\Core\TypedData\Plugin\DataType\IteratorAggregate, ListInterface
Expanded class hierarchy of SmartDateFieldItemList
2 files declare their use of SmartDateFieldItemList
- SmartDateDefaultWidget.php in src/
Plugin/ Field/ FieldWidget/ SmartDateDefaultWidget.php - smart_date.tokens.inc in ./
smart_date.tokens.inc - Provides tokens for the smart_date module.
File
- src/
Plugin/ Field/ FieldType/ SmartDateFieldItemList.php, line 16
Namespace
Drupal\smart_date\Plugin\Field\FieldTypeView source
class SmartDateFieldItemList extends DateTimeFieldItemList {
/**
* {@inheritdoc}
*/
public function defaultValuesForm(array &$form, FormStateInterface $form_state) {
if (empty($this
->getFieldDefinition()
->getDefaultValueCallback())) {
if ($this
->getFieldDefinition()
->getDefaultValueLiteral()) {
$default_value = $this
->getFieldDefinition()
->getDefaultValueLiteral()[0];
}
else {
$default_value = [];
}
$element = parent::defaultValuesForm($form, $form_state);
$element['default_date_type']['#options']['next_hour'] = t('Next hour');
unset($element['default_time_type']);
$this
->addDurationConfig($element, $default_value);
return $element;
}
}
/**
* {@inheritdoc}
*/
public static function addDurationConfig(array &$element, array $default_value) {
$description = '<p>' . t('The possible durations this field can contain. Enter one value per line, in the format key|label.');
$description .= '<br/>' . t('The key is the stored value, and must be numeric or "custom" to allow an arbitrary length. The label will be used in edit forms.');
$description .= '<br/>' . t('The label is optional: if a line contains a single number, it will be used as key and label.') . '</p>';
$element['default_duration_increments'] = [
'#type' => 'textarea',
'#title' => t('Allowed duration increments'),
'#description' => $description,
'#default_value' => isset($default_value['default_duration_increments']) ? $default_value['default_duration_increments'] : "30\n60|1 hour\n90\n120|2 hours\ncustom",
'#required' => TRUE,
];
$element['default_duration'] = [
'#type' => 'textfield',
'#title' => t('Default duration'),
'#description' => t('Set which of the duration increments provided above that should be selected by default.'),
'#default_value' => isset($default_value['default_duration']) ? $default_value['default_duration'] : '60',
'#required' => TRUE,
];
return $element;
}
/**
* {@inheritdoc}
*/
public function defaultValuesFormValidate(array $element, array &$form, FormStateInterface $form_state) {
if ($duration = $form_state
->getValue([
'default_value_input',
'default_duration',
])) {
$increments = SmartDateListItemBase::parseValues($form_state
->getValue([
'default_value_input',
'default_duration_increments',
]));
// Handle a false result: will display the proper error later.
if (!$increments) {
$increments = [];
}
$increment_min = -1;
// Iterate through returned array and throw an error for an invalid key.
foreach ($increments as $key => $label) {
if (intval($key) == 0 && $key !== '0' && $key !== 0 && $key !== 'custom') {
$form_state
->setErrorByName('default_value_input][default_duration_increments', $this
->t('Invalid tokens in the allowed increments specified. Please provide either integers or "custom" as the key for each value.'));
break;
}
else {
$increment_min = $increment_min < intval($key) ? intval($key) : $increment_min;
}
}
if (!in_array('custom', $increments)) {
if ($increment_min < 0) {
$form_state
->setErrorByName('default_value_input][default_duration_increments', $this
->t('Unable to parse valid durations from the allowed increments specified.'));
}
else {
$messenger = \Drupal::messenger();
$messenger
->addMessage($this
->t('No string to allow for custom values, so the provided increments will be strictly enforced.'), 'warning');
}
}
if (!isset($increments[$duration])) {
$form_state
->setErrorByName('default_value_input][default_duration', $this
->t('Please specify a default duration that is one of the provided options.'));
}
}
// Use the parent class method to validate relative dates.
DateTimeFieldItemList::defaultValuesFormValidate($element, $form, $form_state);
}
/**
* {@inheritdoc}
*/
public function defaultValuesFormSubmit(array $element, array &$form, FormStateInterface $form_state) {
if (strlen((string) $form_state
->getValue([
'default_value_input',
'default_duration',
])) && strlen((string) $form_state
->getValue([
'default_value_input',
'default_duration_increments',
]))) {
if ($duration = $form_state
->getValue([
'default_value_input',
'default_duration',
])) {
$form_state
->setValueForElement($element['default_duration'], $duration);
}
if ($duration_increments = $form_state
->getValue([
'default_value_input',
'default_duration_increments',
])) {
$form_state
->setValueForElement($element['default_duration_increments'], $duration_increments);
}
return [
$form_state
->getValue('default_value_input'),
];
}
// Use the parent class method to store current date configuration.
DateTimeFieldItemList::defaultValuesFormSubmit($element, $form, $form_state);
return [];
}
/**
* {@inheritdoc}
*/
public static function processDefaultValue($default_value, FieldableEntityInterface $entity, FieldDefinitionInterface $definition) {
// Explicitly call the base class so that we can get the default value
// types.
$default_value = FieldItemList::processDefaultValue($default_value, $entity, $definition);
// No default set, so nothing to do.
if (empty($default_value[0]['default_date_type'])) {
return $default_value;
}
// A default date+time value should be in the format and timezone used
// for date storage.
$date = new DrupalDateTime($default_value[0]['default_date'], DateTimeItemInterface::STORAGE_TIMEZONE);
$format = DateTimeItemInterface::DATETIME_STORAGE_FORMAT;
// If using 'next_hour' for 'default_date_type', do custom processing.
if ($default_value[0]['default_date_type'] == 'next_hour') {
$date
->modify('+1 hour');
// After conversion to timestamp, we round up, so offset for this.
$min = (int) $date
->format('i') + 1;
$date
->modify('-' . $min . ' minutes');
}
$value = $date
->getTimestamp();
// Round up to the next minute.
$second = $date
->format("s");
if ($second > 0) {
$value += 60 - $second;
}
// Calculate the end value.
$duration = (int) $default_value[0]['default_duration'];
$end_value = $value + $duration * 60;
$default_value = [
[
'value' => $value,
'end_value' => $end_value,
'date' => $date,
],
];
return $default_value;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DateTimeFieldItemList:: |
constant | Defines the default value as relative. | ||
DateTimeFieldItemList:: |
constant | Defines the default value as now. | ||
DependencySerializationTrait:: |
protected | property | ||
DependencySerializationTrait:: |
protected | property | ||
DependencySerializationTrait:: |
public | function | 2 | |
DependencySerializationTrait:: |
public | function | 2 | |
FieldItemList:: |
protected | property | The langcode of the field values held in the object. | |
FieldItemList:: |
protected | property |
Numerically indexed array of field items. Overrides ItemList:: |
1 |
FieldItemList:: |
public | function |
Checks data value access. Overrides AccessibleInterface:: |
1 |
FieldItemList:: |
public | function |
Applies the default value. Overrides TypedData:: |
|
FieldItemList:: |
protected | function |
Helper for creating a list item object. Overrides ItemList:: |
|
FieldItemList:: |
public | function |
Contains the default access logic of this field. Overrides FieldItemListInterface:: |
3 |
FieldItemList:: |
protected | function | Returns the widget object used in default value form. | |
FieldItemList:: |
protected | function | Calls a method on each FieldItem. | |
FieldItemList:: |
public | function |
Defines custom delete behavior for field values. Overrides FieldItemListInterface:: |
2 |
FieldItemList:: |
public | function |
Defines custom revision delete behavior for field values. Overrides FieldItemListInterface:: |
1 |
FieldItemList:: |
public | function |
Determines equality to another object implementing FieldItemListInterface. Overrides FieldItemListInterface:: |
2 |
FieldItemList:: |
public | function |
Filters out empty field items and re-numbers the item deltas. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Populates a specified number of field items with valid sample data. Overrides FieldItemListInterface:: |
1 |
FieldItemList:: |
public | function |
Gets a list of validation constraints. Overrides TypedData:: |
1 |
FieldItemList:: |
public | function |
Gets the entity that field belongs to. Overrides FieldItemListInterface:: |
1 |
FieldItemList:: |
public | function |
Gets the field definition. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Gets the langcode of the field values held in the object. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Returns the value of a given field setting. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Returns the array of field settings. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Determines whether the field has relevant changes. Overrides FieldItemListInterface:: |
1 |
FieldItemList:: |
public | function |
Defines custom post-save behavior for field values. Overrides FieldItemListInterface:: |
1 |
FieldItemList:: |
public | function |
Defines custom presave behavior for field values. Overrides FieldItemListInterface:: |
1 |
FieldItemList:: |
public | function |
Sets the langcode of the field values held in the object. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Sets the data value. Overrides ItemList:: |
|
FieldItemList:: |
public | function |
Returns a renderable array for the field items. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Magic method: Gets a property value of to the first field item. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Magic method: Determines whether a property of the first field item is set. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Magic method: Sets a property value of the first field item. Overrides FieldItemListInterface:: |
|
FieldItemList:: |
public | function |
Magic method: Unsets a property of the first field item. Overrides FieldItemListInterface:: |
|
ItemList:: |
public | function |
Appends a new item to the list. Overrides ListInterface:: |
|
ItemList:: |
public | function | ||
ItemList:: |
public | function |
Filters the items in the list using a custom callback. Overrides ListInterface:: |
|
ItemList:: |
public | function |
Returns the first item in this list. Overrides ListInterface:: |
|
ItemList:: |
public | function |
Returns the item at the specified position in this list. Overrides ListInterface:: |
2 |
ItemList:: |
public | function |
Gets the definition of a contained item. Overrides ListInterface:: |
|
ItemList:: |
public | function | ||
ItemList:: |
public | function |
Returns a string representation of the data. Overrides TypedData:: |
|
ItemList:: |
public | function |
Gets the data value. Overrides TypedData:: |
|
ItemList:: |
public | function |
Determines whether the list contains any non-empty items. Overrides ListInterface:: |
|
ItemList:: |
public | function | 1 | |
ItemList:: |
public | function | ||
ItemList:: |
public | function | ||
ItemList:: |
public | function | ||
ItemList:: |
public | function |
React to changes to a child property or item. Overrides TraversableTypedDataInterface:: |
1 |
ItemList:: |
protected | function | Renumbers the items in the list. | |
ItemList:: |
public | function |
Removes the item at the specified position. Overrides ListInterface:: |
|
ItemList:: |
public | function |
Sets the value of the item at a given position in the list. Overrides ListInterface:: |
|
ItemList:: |
public | function | Magic method: Implements a deep clone. | |
SmartDateFieldItemList:: |
public static | function | ||
SmartDateFieldItemList:: |
public | function |
Returns a form for the default value input. Overrides DateTimeFieldItemList:: |
|
SmartDateFieldItemList:: |
public | function |
Processes the submitted default value. Overrides DateTimeFieldItemList:: |
|
SmartDateFieldItemList:: |
public | function |
Validates the submitted default value. Overrides DateTimeFieldItemList:: |
|
SmartDateFieldItemList:: |
public static | function |
Processes the default value before being applied. Overrides DateTimeFieldItemList:: |
|
StringTranslationTrait:: |
protected | property | The string translation service. | 4 |
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. | |
TypedData:: |
protected | property | The data definition. | 1 |
TypedData:: |
protected | property | The property name. | |
TypedData:: |
protected | property | The parent typed data object. | |
TypedData:: |
public static | function |
Constructs a TypedData object given its definition and context. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Gets the data definition. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the name of a property or item. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the parent data structure; i.e. either complex data or a list. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
|
TypedData:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
TypedData:: |
public | function |
Returns the property path of the data. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the root of the typed data tree. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Sets the context of a property or item via a context aware parent. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Validates the currently set data value. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function | Constructs a TypedData object given its definition and context. | 3 |
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. | |
TypedDataTrait:: |
public | function | Gets the typed data manager. | 2 |
TypedDataTrait:: |
public | function | Sets the typed data manager. | 2 |