Support typed_relation fields

Created on 6 September 2021, over 3 years ago
Updated 5 July 2024, 7 months ago

Problem/Motivation

Currently only fields of type entity_reference are supported. A variation on entity_reference fields are typed_relation fields from the Controlled Access Terms module, see https://git.drupalcode.org/project/controlled_access_terms/-/blob/8.x-1....

Proposed resolution

Alter field type check in class ReferenceFinder to allow typed_relation fields to be merged.

Feature request
Status

Needs work

Version

2.0

Component

Code

Created by

🇳🇿New Zealand jonathan_hunt

Live updates comments and jobs are added and updated live.
  • Needs tests

    The change is currently missing an automated test that fails when run with the original code, and succeeds when the bug has been fixed.

Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇩🇪Germany Anybody Porta Westfalica

    Thank you very much @jonathan_hunt. Could you please add tests, so we can be sure this works as expected for now and in the future?

  • First commit to issue fork.
  • 🇨🇦Canada rosiel

    I'm revisiting this as it's desired by the Islandora community.

    Is it possible to add tests for a field type that's defined by another module? I don't think further tests are possible unless we mock up a shim for the 'typed_relation' field type. That seems like overkill...

    Alternately, instead of testing $field_definition->getType(), we could test is_a($fieldDefinition->getClass(), 'Drupal\Core\Field\EntityReferenceFieldItemList', true). That would work both for entity reference fields and any field type that extends entity reference, including typed relation. This might prevent the need for any additional tests.

  • First commit to issue fork.
  • 🇨🇦Canada bibliophileaxe

    I've updated the code to check if the field class is an instance of EntityReferenceFieldItemList rather than adding a condition for another module. I agree with Rosie's comment that this does not require tests now as the current tests already check for this.

    I'd rather have an Event that could add additional context/conditions to make this more robust but since that would be a considerable change, this seems to be a decent solution.

Production build 0.71.5 2024