Default field enhancer for each field type

Created on 11 January 2019, about 6 years ago
Updated 29 February 2024, about 1 year ago

Problem/Motivation

Field Enhancers are a great tool, but some times it can be taxing to add the field enhancer you need on each instance of a field type.

Proposed resolution

Have a form where you can set a field enhancer to be used whenever none is specified for a given field type. We should also introduce a NULL field enhancer that removes any default enhancer that a field could get.

Remaining tasks

Determine the editorial UI for this.

Feature request
Status

Active

Version

3.0

Component

Code

Created by

e0ipso Can Picafort

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.

  • 🇺🇸United States jeffschuler Boulder, Colorado

    +1 for this.

    I want to apply the UrlLinkEnhancer to every Link field in all my entities...

  • Pipeline finished with Skipped
    almost 2 years ago
    #12370
  • Pipeline finished with Canceled
    over 1 year ago
    Total: 102s
    #23029
  • Pipeline finished with Success
    over 1 year ago
    Total: 192s
    #33274
  • Pipeline finished with Failed
    about 1 year ago
    Total: 157s
    #105923
  • Pipeline finished with Success
    about 1 year ago
    Total: 157s
    #105933
  • First commit to issue fork.
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    10 fail
  • Pipeline finished with Failed
    about 1 year ago
    Total: 196s
    #107241
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    11 pass, 4 fail
  • Pipeline finished with Running
    about 1 year ago
    #107305
  • Pipeline finished with Success
    about 1 year ago
    Total: 293s
    #107444
  • Status changed to Needs review about 1 year ago
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    11 pass, 4 fail
  • 🇺🇸United States afinnarn

    Adding a patch since I've seen people do this with MRs to reference...

    This MR includes a "Field Types" form adjacent to the resource overrides, allowing users to select which field types a default enhancer can apply. Individual field instance enhancers still override the default field type enhancer.

    Originally, I listed out all the field types so users could choose to add enhancers in one big form, but the way I was doing it I ran into `max_input_vars` issue on my work QA server. So, I switched to forcing users to declare the field types they wanted to include, which is probably better anyways since most people would only want to use this on a few field types.

    I think the form and form language could be improved, but the approach of adding to FieldItemNormalizer and checking an additional config made sense to me. However, feel free to suggest whatever changes make sense...also where to add tests/what tests would be helpful for this change as I am not super experienced with PHPUnit.

    I did not add the NULL enhancer, but that wouldn't be much work to add in this pattern.

    Also, I have a disabled key in settings that I didn't implement, but it would disable all field type enhancers only allowing the field instance overrides. The benefit would be mainly for debugging where you can keep your settings but have a flag to turn off the whole field type enhancer feature.

    From the Kernel tests, I keep seeing this failure repeated, but I don't think this code change has anything to do with something in the jsonapi module.

    Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException: The service "Drupal\jsonapi\Controller\TemporaryJsonapiFileFieldUploader" has a dependency on a non-existent service "file.validator". Did you mean one of these: "form_validator", "path.validator", "email.validator"?
    

    I also saw deprecations in the test logs, but other tests passed when I ran them.

  • The last submitted patch, 5: field-type-enhancer-3025283-5.patch, failed testing. View results
    - codesniffer_fixes.patch Interdiff of automated coding standards fixes only.

  • Pipeline finished with Success
    about 1 year ago
    Total: 377s
    #112200
  • Pipeline finished with Failed
    about 1 year ago
    Total: 1051s
    #113430
  • Pipeline finished with Success
    about 1 year ago
    Total: 343s
    #117444
  • Pipeline finished with Success
    about 1 year ago
    Total: 154s
    #120268
  • Pipeline finished with Success
    about 1 year ago
    Total: 148s
    #121107
  • Pipeline finished with Success
    about 1 year ago
    Total: 167s
    #122389
  • Pipeline finished with Success
    about 1 year ago
    Total: 167s
    #122403
  • Pipeline finished with Success
    12 months ago
    Total: 198s
    #141704
  • Pipeline finished with Skipped
    12 months ago
    #143232
  • Pipeline finished with Success
    12 months ago
    Total: 215s
    #143580
  • Pipeline finished with Success
    12 months ago
    Total: 195s
    #145440
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    10 fail
  • Pipeline finished with Failed
    11 months ago
    Total: 214s
    #160940
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    5 pass, 8 fail
  • Pipeline finished with Failed
    11 months ago
    Total: 255s
    #161046
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    6 pass, 6 fail
  • Pipeline finished with Failed
    11 months ago
    #161054
  • Pipeline finished with Skipped
    11 months ago
    #163579
  • Pipeline finished with Skipped
    11 months ago
    #179725
  • Pipeline finished with Success
    10 months ago
    Total: 150s
    #189730
  • Pipeline finished with Success
    10 months ago
    Total: 231s
    #189750
  • Pipeline finished with Success
    10 months ago
    #190136
  • Pipeline finished with Failed
    10 months ago
    Total: 241s
    #190200
  • Pipeline finished with Canceled
    10 months ago
    #190225
  • Pipeline finished with Success
    10 months ago
    Total: 445s
    #190233
  • Pipeline finished with Success
    10 months ago
    Total: 307s
    #190535
  • Pipeline finished with Success
    10 months ago
    #191813
  • Pipeline finished with Success
    10 months ago
    Total: 238s
    #193109
  • Pipeline finished with Skipped
    10 months ago
    #207260
  • Pipeline finished with Failed
    10 months ago
    Total: 1175s
    #208007
  • Pipeline finished with Canceled
    10 months ago
    Total: 5s
    #209149
  • Pipeline finished with Failed
    10 months ago
    Total: 753s
    #209150
  • Pipeline finished with Success
    9 months ago
    Total: 181s
    #212384
  • Pipeline finished with Success
    9 months ago
    Total: 557s
    #212623
  • Pipeline finished with Success
    9 months ago
    Total: 744s
    #212633
  • Pipeline finished with Success
    9 months ago
    Total: 166s
    #217956
  • Pipeline finished with Success
    9 months ago
    Total: 150s
    #227546
  • Pipeline finished with Canceled
    9 months ago
    Total: 216s
    #231581
  • Pipeline finished with Canceled
    9 months ago
    Total: 972s
    #231583
  • Pipeline finished with Success
    9 months ago
    Total: 969s
    #231584
  • 🇺🇸United States timcosgrove

    Rerolling #5 this for 3.25, though if the patch in #5 failed I expect it will fail. I will try to address the failures if they come up.

  • 🇺🇸United States timcosgrove

    Fixed some issues with the previous patch; removed the previous patch from display.

  • Pipeline finished with Success
    8 months ago
    Total: 201s
    #241636
  • Pipeline finished with Success
    8 months ago
    #241656
  • Pipeline finished with Canceled
    8 months ago
    Total: 31s
    #241724
  • Pipeline finished with Failed
    8 months ago
    Total: 212s
    #248077
  • Pipeline finished with Failed
    8 months ago
    Total: 199s
    #248130
  • Pipeline finished with Failed
    8 months ago
    Total: 472s
    #248139
  • Pipeline finished with Success
    8 months ago
    Total: 191s
    #256170
  • Pipeline finished with Success
    8 months ago
    Total: 240s
    #257933
  • Pipeline finished with Success
    8 months ago
    #261310
  • Pipeline finished with Canceled
    7 months ago
    Total: 130s
    #270144
  • Pipeline finished with Success
    7 months ago
    Total: 135s
    #271744
  • Pipeline finished with Canceled
    7 months ago
    #280262
  • Pipeline finished with Canceled
    7 months ago
    Total: 428s
    #280276
  • Pipeline finished with Failed
    7 months ago
    Total: 632s
    #280277
  • Pipeline finished with Success
    7 months ago
    Total: 552s
    #280293
  • Pipeline finished with Success
    7 months ago
    Total: 139s
    #283250
  • Pipeline finished with Failed
    7 months ago
    Total: 642s
    #285896
  • Pipeline finished with Success
    7 months ago
    Total: 334s
    #285903
  • Pipeline finished with Success
    7 months ago
    #287671
  • Pipeline finished with Success
    7 months ago
    Total: 322s
    #289260
  • Pipeline finished with Success
    7 months ago
    Total: 142s
    #290594
  • Pipeline finished with Success
    6 months ago
    Total: 132s
    #297190
  • Pipeline finished with Skipped
    6 months ago
    #301567
  • Pipeline finished with Skipped
    6 months ago
    #307606
  • Pipeline finished with Success
    6 months ago
    Total: 207s
    #308610
  • Pipeline finished with Success
    6 months ago
    Total: 169s
    #312652
  • Pipeline finished with Success
    6 months ago
    Total: 169s
    #312658
  • Pipeline finished with Success
    6 months ago
    Total: 176s
    #313049
  • Pipeline finished with Failed
    5 months ago
    #331928
  • Pipeline finished with Success
    4 months ago
    Total: 186s
    #349892
  • Pipeline finished with Skipped
    4 months ago
    #349936
  • Pipeline finished with Success
    4 months ago
    Total: 139s
    #358910
  • Pipeline finished with Failed
    3 months ago
    Total: 456s
    #379584
  • Pipeline finished with Success
    3 months ago
    Total: 363s
    #379637
  • Pipeline finished with Success
    3 months ago
    Total: 840s
    #386324
  • Pipeline finished with Canceled
    3 months ago
    Total: 53s
    #387121
  • Pipeline finished with Success
    3 months ago
    Total: 104s
    #387124
  • Pipeline finished with Success
    3 months ago
    Total: 101s
    #387148
  • First commit to issue fork.
  • Pipeline finished with Success
    3 months ago
    Total: 299s
    #388620
  • Pipeline finished with Success
    3 months ago
    Total: 186s
    #390741
  • Pipeline finished with Success
    3 months ago
    Total: 178s
    #390904
  • Pipeline finished with Success
    3 months ago
    Total: 193s
    #390908
  • Pipeline finished with Success
    2 months ago
    Total: 148s
    #405468
  • Pipeline finished with Success
    2 months ago
    Total: 182s
    #414064
  • Pipeline finished with Skipped
    about 2 months ago
    #418655
  • Pipeline finished with Success
    about 2 months ago
    Total: 256s
    #419059
  • Pipeline finished with Success
    about 2 months ago
    Total: 148s
    #423385
  • Pipeline finished with Failed
    about 2 months ago
    Total: 166s
    #424508
  • Pipeline finished with Failed
    about 2 months ago
    Total: 199s
    #424584
  • Pipeline finished with Success
    about 2 months ago
    Total: 148s
    #426573
  • Pipeline finished with Success
    about 2 months ago
    Total: 277s
    #431676
  • Pipeline finished with Success
    about 1 month ago
    Total: 232s
    #432538
  • Pipeline finished with Failed
    about 1 month ago
    Total: 215s
    #436183
  • Pipeline finished with Canceled
    about 1 month ago
    Total: 276s
    #436282
  • Pipeline finished with Success
    about 1 month ago
    Total: 381s
    #436288
  • Pipeline finished with Success
    about 1 month ago
    Total: 239s
    #436289
  • Pipeline finished with Success
    22 days ago
    Total: 169s
    #451451
  • Pipeline finished with Success
    11 days ago
    Total: 221s
    #459941
  • Pipeline finished with Success
    11 days ago
    Total: 223s
    #459945
  • Pipeline finished with Success
    7 days ago
    Total: 160s
    #462788
Production build 0.71.5 2024