function image_field_storage_config_update in Drupal 9
Same name and namespace in other branches
- 8 core/modules/image/image.module \image_field_storage_config_update()
Implements hook_ENTITY_TYPE_update() for 'field_storage_config'.
File
- core/
modules/ image/ image.module, line 374 - Exposes global functionality for creating image styles.
Code
function image_field_storage_config_update(FieldStorageConfigInterface $field_storage) {
if ($field_storage
->getType() != 'image') {
// Only act on image fields.
return;
}
$prior_field_storage = $field_storage->original;
// The value of a managed_file element can be an array if #extended == TRUE.
$uuid_new = $field_storage
->getSetting('default_image')['uuid'];
$uuid_old = $prior_field_storage
->getSetting('default_image')['uuid'];
$file_new = $uuid_new ? \Drupal::service('entity.repository')
->loadEntityByUuid('file', $uuid_new) : FALSE;
if ($uuid_new != $uuid_old) {
// Is there a new file?
if ($file_new) {
$file_new
->setPermanent();
$file_new
->save();
\Drupal::service('file.usage')
->add($file_new, 'image', 'default_image', $field_storage
->uuid());
}
// Is there an old file?
if ($uuid_old && ($file_old = \Drupal::service('entity.repository')
->loadEntityByUuid('file', $uuid_old))) {
\Drupal::service('file.usage')
->delete($file_old, 'image', 'default_image', $field_storage
->uuid());
}
}
// If the upload destination changed, then move the file.
if ($file_new && StreamWrapperManager::getScheme($file_new
->getFileUri()) != $field_storage
->getSetting('uri_scheme')) {
$directory = $field_storage
->getSetting('uri_scheme') . '://default_images/';
\Drupal::service('file_system')
->prepareDirectory($directory, FileSystemInterface::CREATE_DIRECTORY);
file_move($file_new, $directory . $file_new
->getFilename());
}
}