Browse Source

Code clean-up

3.1.x
Chi 3 years ago
parent
commit
4bbf7f4786
  1. 25
      src/UriExtractor.php
  2. 28
      src/UrlExtractor.php
  3. 2
      tests/src/Kernel/UriExtractorTest.php

25
src/UriExtractor.php

@ -32,26 +32,27 @@ class UriExtractor {
/** /**
* Returns a URI to the file. * Returns a URI to the file.
* *
* @param object|null $input * @param Object|null $input
* An object that contains the URI. * An object that contains the URI.
* *
* @return string|null * @return string|null
* A URI that may be used to access the file. * A URI that may be used to access the file.
*/ */
public function extractUri(?object $input): ?string { public function extractUri(?object $input): ?string {
if ($input instanceof ContentEntityInterface) { $entity = $input;
return self::getUriFromEntity($input); if ($input instanceof EntityReferenceFieldItemListInterface) {
if ($item = $input->first()) {
$entity = $item->entity;
} }
elseif ($input instanceof EntityReferenceFieldItemListInterface) {
$item = $input->first();
if (!empty($item) && $input->entity instanceof ContentEntityInterface) {
return $this->getUriFromEntity($item->entity);
} }
elseif ($input instanceof EntityReferenceItem) {
$entity = $input->entity;
} }
elseif ($input instanceof EntityReferenceItem && $input->entity instanceof ContentEntityInterface) { // Drupal does not clean up references to deleted entities. So that the
return self::getUriFromEntity($input->entity); // entity property might be empty while the field item might not.
} // @see https://www.drupal.org/project/drupal/issues/2723323
return NULL; return $entity instanceof ContentEntityInterface ?
$this->getUriFromEntity($entity) : NULL;
} }
/** /**
@ -61,7 +62,7 @@ class UriExtractor {
* Entity object that contains information about the file. * Entity object that contains information about the file.
* *
* @return string|null * @return string|null
* A URI that may be used to access the file. * A URI that can be used to access the file.
*/ */
private function getUriFromEntity(ContentEntityInterface $entity): ?string { private function getUriFromEntity(ContentEntityInterface $entity): ?string {
if ($entity instanceof MediaInterface) { if ($entity instanceof MediaInterface) {

28
src/UrlExtractor.php

@ -47,25 +47,27 @@ class UrlExtractor {
$url = file_create_url($input); $url = file_create_url($input);
return $relative ? file_url_transform_relative($url) : $url; return $relative ? file_url_transform_relative($url) : $url;
} }
elseif ($input instanceof ContentEntityInterface) {
return $this->getUrlFromEntity($input, $relative);
}
elseif ($input instanceof EntityReferenceFieldItemListInterface) {
$item = $input->first();
if (!empty($item) && $input->entity instanceof ContentEntityInterface) {
return $this->getUrlFromEntity($item->entity, $relative);
}
}
elseif ($input instanceof EntityReferenceItem && $input->entity instanceof ContentEntityInterface) {
return $this->getUrlFromEntity($input->entity, $relative);
}
elseif ($input instanceof LinkItemInterface) { elseif ($input instanceof LinkItemInterface) {
return $input->getUrl()->toString(); return $input->getUrl()->toString();
} }
elseif ($input instanceof FieldItemList && $input->first() instanceof LinkItemInterface) { elseif ($input instanceof FieldItemList && $input->first() instanceof LinkItemInterface) {
return $input->first()->getUrl()->toString(); return $input->first()->getUrl()->toString();
} }
return NULL;
$entity = $input;
if ($input instanceof EntityReferenceFieldItemListInterface) {
if ($item = $input->first()) {
$entity = $item->entity;
}
}
elseif ($input instanceof EntityReferenceItem) {
$entity = $input->entity;
}
// Drupal does not clean up references to deleted entities. So that the
// entity property might be empty while the field item might not.
// @see https://www.drupal.org/project/drupal/issues/2723323
return $entity instanceof ContentEntityInterface ?
$this->getUrlFromEntity($entity, $relative) : NULL;
} }
/** /**

2
tests/src/Kernel/UriExtractorTest.php

@ -12,7 +12,7 @@ final class UriExtractorTest extends AbstractExtractorTestCase {
/** /**
* Test callback. * Test callback.
*/ */
public function testUrlExtractor(): void { public function testUriExtractor(): void {
$extractor = $this->container->get('twig_tweak.uri_extractor'); $extractor = $this->container->get('twig_tweak.uri_extractor');

Loading…
Cancel
Save