function smart_date_tokens in Smart Date 3.4.x
Same name and namespace in other branches
- 8.2 smart_date.tokens.inc \smart_date_tokens()
- 8 smart_date.tokens.inc \smart_date_tokens()
- 3.x smart_date.tokens.inc \smart_date_tokens()
- 3.0.x smart_date.tokens.inc \smart_date_tokens()
- 3.1.x smart_date.tokens.inc \smart_date_tokens()
- 3.2.x smart_date.tokens.inc \smart_date_tokens()
- 3.3.x smart_date.tokens.inc \smart_date_tokens()
Implements hook_tokens().
File
- ./
smart_date.tokens.inc, line 82 - Provides tokens for the smart_date module.
Code
function smart_date_tokens($type, $tokens, array $data, array $options, BubbleableMetadata $bubbleable_metadata) {
$replacements = [];
if (empty($data['field_property'])) {
return $replacements;
}
foreach ($tokens as $token => $original) {
$list = $data[$data['field_name']];
if (!$list instanceof SmartDateFieldItemList) {
continue;
}
$delta = 0;
$parts = explode(':', $token, 2);
// Test for a delta as the first part.
if (is_numeric($parts[0])) {
if (count($parts) > 1) {
$delta = $parts[0];
$parts = explode(':', $parts[1], 2);
$property_name = $parts[0];
$format_value = isset($parts[1]) ? $parts[1] : NULL;
}
else {
continue;
}
}
else {
$property_name = $parts[0];
$format_value = isset($parts[1]) ? $parts[1] : NULL;
}
// Now parse out the pieces of the token name.
$name_parts = explode('-', $property_name);
$approach = array_pop($name_parts);
$field = $list
->first();
if ($approach == 'custom') {
if (!$format_value) {
// This token requires a value, so skip if absent.
continue;
}
// Get the requested property and apply the provided format.
if ($name_parts && ($prop_needed = array_pop($name_parts))) {
$field_ts = $field
->get($prop_needed)
->getValue();
$replacements[$original] = \Drupal::service('date.formatter')
->format($field_ts, '', $format_value);
}
}
elseif ($approach == 'format') {
if (!$format_value) {
// Our tokens require a value, so skip if absent.
$format_value = 'default';
}
$format = SmartDateFormat::load($format_value);
$settings = $format
->getOptions();
// Apply the specified smart date format.
// If a property was specified, only use that.
if ($name_parts && ($prop_needed = array_pop($name_parts))) {
$field_ts = $field
->get($prop_needed)
->getValue();
$replacements[$original] = SmartDateTrait::formatSmartDate($field_ts, $field_ts, $settings, NULL, 'string');
}
else {
$start = $field
->get('value')
->getValue();
$end = $field
->get('end_value')
->getValue();
$replacements[$original] = SmartDateTrait::formatSmartDate($start, $end, $settings, NULL, 'string');
}
}
}
return $replacements;
}