D7 EFQ Finder to D8 Entity finder

Created on 29 May 2018, over 6 years ago
Updated 2 May 2023, over 1 year ago

We need to port the D7 feeds_tamper EFQ Finder plugin to D8 tamper.

📌 Task
Status

Needs work

Version

1.0

Component

Code

Created by

🇨🇦Canada jamesdixon

Live updates comments and jobs are added and updated live.
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.

  • 🇨🇦Canada liquidcms

    Went back to patch from #29 and fixed the deprecated method issues and it worked with D9.5

  • 🇳🇿New Zealand ericgsmith

    Hello all.

    Firstly I wanted to say thank you to everybody who has contributed to this issue. It has been a very long slog and so many people have contributed.

    I have taken a quick look and made some tidy ups.

    Please consider this a work in progress, and I have removed a bunch of stuff to get the tests going. I am not trying to discourage those ideas, I just wanted to share progress before I put them down.

    Namely
    - removed entity repository. Querying by uuid still works with entity query, I couldn't see why we needed to introduce another service for this field
    - used a Kernel test. We can maybe revisit this, but this is a complicate plugin - the current state of the unit test was not complete, and being unfamiliar with the work so far it was easier for me to look at this with a kernel test.

    Now a warning - I only looked at this via tests - I have not even looked at the UI or how that renders.

    Adding patch now but it is still needs a few improvements. I will try tidy up the issue summary and remaining steps soon.

  • 🇳🇿New Zealand ericgsmith
    1. +++ b/src/Plugin/Tamper/EntityFinder.php
      @@ -0,0 +1,280 @@
      +    // $form_state->setCached(FALSE);
      

      I need to revisit the form side - this should either be there or removed, advice welcomed on what this is for and what other plugins are doing.

    2. +++ b/src/Plugin/Tamper/EntityFinder.php
      @@ -0,0 +1,280 @@
      +      '#empty_option' => t('-- Select --'),
      

      Should be $this->t

    3. +++ b/src/Plugin/Tamper/EntityFinder.php
      @@ -0,0 +1,280 @@
      +  protected function getfields($entity_type, $bundle) {
      

      Case needs to match where this is called

  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.x + Environment: PHP 8.0 & MySQL 5.7
    last update over 1 year ago
    462 pass
  • 🇳🇿New Zealand ericgsmith

    Oops - wrong namespace in test - ignore 54

  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.x + Environment: PHP 8.0 & MySQL 5.7
    last update over 1 year ago
    463 pass
  • 🇳🇿New Zealand ericgsmith

    Ok cool, green test! A few coding standard violations in the plugin and test noted in ci

  • 🇮🇹Italy kopeboy Milan

    Thank you for the work you're doing to finally take tamper out of alpha stability! 🙏🏻 Unfortunately I'm not skilled enough to help directly with code but I'm with you emotionally and can test when ready 💪🏻

  • 🇵🇹Portugal jrochate

    Does not work with current DEV branch.

  • Merge request !29Resolve #2976175 "D7 efq finder" → (Open) created by megachriz
  • 🇳🇱Netherlands megachriz

    I'm hiding all the patches. Work should continue in the MR.

    And I wonder if this plugin should support config entity types? I limited it to content entity types for now, because I accidentally selected a config entity type and it resulted into the error that the entity type did not have base field definitions.

  • 🇳🇱Netherlands hepabolu

    FYI I've created a similar tamper module: https://github.com/hepabolu/feeds_tamper_lookup_entity

    This one works for me, but since this is my first Drupal module feel free to correct and improve or assimilate into your version.

  • 🇳🇱Netherlands megachriz

    Tests are passing! This looks ready for a new review!

    Highlights of the changes:

    • Column selection: if a field has more than one 'column', you can select a column. For example, a link field has "uri" and "title"; a body field has "value", "summary" and "format".
    • Selecting a bundle is optional. A field can be chosen without needing to select a bundle first. Selecting a bundle does narrow down the list of available fields.
    • The list of entity types are grouped by provider (usually the module defining them), making it easier to find the one you need.
    • Made updating the form via AJAX work outside of Feeds Tamper context.
    • Lots of automated tests.

    @hepabolu
    Thanks for your contribution 🙂. I see that your plugin has one feature that looks useful that Entity Finder currently doesn't have: a return field. Entity Finder now always returns the entity ID, but being able to select a different field to return sounds very useful.
    I'm not sure yet if we should add it to Entity Finder right now (since this issue has been open for a very long time already) or if it would be better to add it in a follow-up. Do you want to help adding that feature here?

Production build 0.71.5 2024