You are here

public static function DateRangeFieldItemList::processDefaultValue in Drupal 10

Same name and namespace in other branches
  1. 8 core/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeFieldItemList.php \Drupal\datetime_range\Plugin\Field\FieldType\DateRangeFieldItemList::processDefaultValue()
  2. 9 core/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeFieldItemList.php \Drupal\datetime_range\Plugin\Field\FieldType\DateRangeFieldItemList::processDefaultValue()

Processes the default value before being applied.

Defined or configured default values of a field might need some processing in order to be a valid runtime value for the field type; e.g., a date field could process the defined value of 'NOW' to a valid date.

Parameters

array $default_value: The unprocessed default value defined for the field, as a numerically indexed array of items, each item being an array of property/value pairs.

\Drupal\Core\Entity\FieldableEntityInterface $entity: The entity for which the default value is generated.

\Drupal\Core\Field\FieldDefinitionInterface $definition: The definition of the field.

Return value

array The return default value for the field.

Overrides DateTimeFieldItemList::processDefaultValue

File

core/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeFieldItemList.php, line 96

Class

DateRangeFieldItemList
Represents a configurable entity daterange field.

Namespace

Drupal\datetime_range\Plugin\Field\FieldType

Code

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);

  // Allow either the start or end date to have a default, but not require
  // defaults for both.
  if (!empty($default_value[0]['default_date_type']) || !empty($default_value[0]['default_end_date_type'])) {

    // A default value should be in the format and timezone used for date
    // storage. All-day ranges are stored the same as date+time ranges.  We
    // only provide a default value for the first item, as do all fields.
    // Otherwise, there is no way to clear out unwanted values on multiple
    // value fields.
    $storage_format = $definition
      ->getSetting('datetime_type') == DateRangeItem::DATETIME_TYPE_DATE ? DateTimeItemInterface::DATE_STORAGE_FORMAT : DateTimeItemInterface::DATETIME_STORAGE_FORMAT;
    $default_values = [
      [],
    ];
    if (!empty($default_value[0]['default_date_type'])) {
      $start_date = new DrupalDateTime($default_value[0]['default_date'], DateTimeItemInterface::STORAGE_TIMEZONE);
      $start_value = $start_date
        ->format($storage_format);
      $default_values[0]['value'] = $start_value;
      $default_values[0]['start_date'] = $start_date;
    }
    if (!empty($default_value[0]['default_end_date_type'])) {
      $end_date = new DrupalDateTime($default_value[0]['default_end_date'], DateTimeItemInterface::STORAGE_TIMEZONE);
      $end_value = $end_date
        ->format($storage_format);
      $default_values[0]['end_value'] = $end_value;
      $default_values[0]['end_date'] = $end_date;
    }
    $default_value = $default_values;
  }
  return $default_value;
}