Allow to define presets for typical configurations (fences_presets submodule)

Created on 11 April 2022, almost 3 years ago
Updated 13 May 2024, 11 months ago

Problem/Motivation

Allow to define typical, named presets (profiles) to select from when configuring field display settings instead of setting each value individually.

On each field's display settings, "fences presets" can be used as follows:

Use the settings from the global preset, but don't store the reference so that the field settings are standalone like entered manually. The settings shouldn't be disabled, when a preset is used, as they are completely detached from the global preset and can be further overwritten per field display setting (if necessary).

This should be implemented as submodule: fences_presets

Steps to reproduce

Remaining tasks

  • Create a "fences_presets" submodule. (use drush gen to generate the module and move it into a new "modules" folder)
  • Create a "fences_preset" config entity (might be possible to generate one through drush gen otherwise checkout the config_entity_example although its routing doesn't seem up-to-date.... otherwise look for config entities in core.)
  • The config entity should have the following basic properties:
  1. ID
  2. label
  3. status (enabled / disabled)
  4. description
  • And the following fences properties (see fences.module, these should be wrapped inside a fieldset on display):
  1. field_tag
  2. field_classes
  3. field_items_wrapper_tag
  4. field_items_wrapper_classes
  5. field_item_tag
  6. field_item_classes
  7. label_tag
  8. label_classes
  • The config entity should have an add / edit form, delete form and config entity collection (should be auto generated through drush gen, otherwise see examples module / core implementations)
  • The select should include an option "No preset" which is selected by default and does not change any settings (also very good for the follow-up issue so that there is a way to change from a preset to the "No preset" option if there are a few unique or specific changes to one item).
  • Create a new select render element inside "fences_field_formatter_third_party_settings_form()", called "fences_presets", where the preset config entities can be selected from, note that this form element should be purely cosmetic and not save any real value in the config, it's just used to be picked up by the JavaScript. ALTERNATIVELY, we could also render the select via JavaScript, but that's not good for the follow-up issue, where we want to reference the preset entities.
  • Once, the value from the "fences_presets" select changes, we need to load the values of the selected preset and pass it to JavaScript. Inside our JavaScript, we need to populate the fences options with the values from our selected preset entity (field_tag on fences_field_tag, field_classes on fences_field_classes, etc.). This should be done by passing an array representation of the fences presets into "drupalSettings", through attaching the JS library in fences_field_formatter_third_party_settings_form() and passing the config entities to drupalSettings. This way, JavaScript can simply access "drupalSettings" and get the config entity (by config entity ID).

And that's it! The config entity itself should not update, when a preset is overridden on a field formatter setting. This part will be tackled in the future through: 📌 Add option to ovewrite fences presets in the formatter settings (preset by reference) Active .

Tests are needed as well.

Proposed resolution

Allow to define presets for typical configurations.

User interface changes

A simple select, with presets separated with optgroups:

API changes

Data model changes

✨ Feature request
Status

Fixed

Version

3.0

Component

Code (fences)

Created by

🇩🇪Germany Anybody Porta Westfalica

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.

  • This feature would still be sooo so useful!

  • 🇩🇪Germany Anybody Porta Westfalica

    Definitely yes!! ;)

    Perhaps Leon will be able to do this in some months ;) Perhaps you need to sponsor him :P

  • 🇩🇪Germany Anybody Porta Westfalica
  • Pipeline finished with Skipped
    over 1 year ago
    #59292
  • 🇩🇪Germany Grevil

    Ok, I entirely rewrote the issue summary for @LRWebks to have a better understanding of the whole thing. I also moved "reference" part in a separate follow-up issue, here: 📌 Add option to ovewrite fences presets in the formatter settings (preset by reference) Active .

  • Pipeline finished with Success
    about 1 year ago
    Total: 143s
    #123339
  • Pipeline finished with Success
    about 1 year ago
    Total: 146s
    #124910
  • Pipeline finished with Success
    about 1 year ago
    #124930
  • Pipeline finished with Success
    about 1 year ago
    Total: 148s
    #124958
  • Pipeline finished with Failed
    about 1 year ago
    Total: 160s
    #138850
  • Pipeline finished with Success
    about 1 year ago
    Total: 159s
    #138883
  • Pipeline finished with Success
    about 1 year ago
    Total: 164s
    #138888
  • First commit to issue fork.
  • Status changed to Needs work 12 months ago
  • 🇩🇪Germany lrwebks Porta Westfalica

    Well, let's finally tackle this issue then! I'll start with this now.

  • Assigned to lrwebks
  • 🇩🇪Germany lrwebks Porta Westfalica
  • 🇩🇪Germany Grevil
  • Pipeline finished with Success
    12 months ago
    Total: 170s
    #146932
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 12 months ago
    56 pass
  • Pipeline finished with Success
    12 months ago
    Total: 1113s
    #146947
  • 🇩🇪Germany lrwebks Porta Westfalica

    Quick question: In the issue description, you state:

    Add a "default_preset" config entity through adding a config entity yml in config/install. Which holds the "Default Preset". This preset should be selected on default, when being on the formatter settings page and having this module installed.

    Why would we want to do that, though? The default values apply either way.
    If it is just in order to have a preset that appears when we open the config so the preset select isn't empty, wouldn't it be better if we had a "No preset" option that is selected by default and does not change anything?
    This would also help with the follow-up issue so that when config entities are changed within the display settings form, we had the option "No preset" so that no preset would be changed if the values are changed within the display settings form. (If you make custom changes and don't want any preset to be changed due to those, you select "No preset" and do your changes then)

  • 🇩🇪Germany Grevil

    Yes indeed, that would make much more sense.

    Thinking about this, I am unsure, what my intentions behind a default preset were.

  • 🇩🇪Germany lrwebks Porta Westfalica
  • Pipeline finished with Success
    12 months ago
    Total: 381s
    #147015
  • Pipeline finished with Success
    12 months ago
    Total: 166s
    #147095
  • Pipeline finished with Success
    12 months ago
    Total: 173s
    #147106
  • 🇩🇪Germany Grevil

    Just had a quick look at the code, looks good right now!

  • Pipeline finished with Success
    12 months ago
    Total: 192s
    #148216
  • Pipeline finished with Success
    12 months ago
    Total: 175s
    #148257
  • Pipeline finished with Success
    12 months ago
    Total: 174s
    #148302
  • 🇩🇪Germany lrwebks Porta Westfalica

    I've been thinking a bit about this part of the plan:

    Create a new select render element inside "fences_field_formatter_third_party_settings_form()", called "fences_presets", where the preset config entities can be selected from, note that this form element should be purely cosmetic and not save any real value in the config, it's just used to be picked up by the JavaScript.

    The question is: Should it be purely cosmetic, though?
    I believe that I would be more handy if the selected preset is saved in the config, so that it later appears as the selected option and the person editing the form knows that the values match this preset.
    Example: You create about 50 presets (a lot) and then use one of the presets to pre-set the values of the display settings form. Later you re-open the settings page, but since the select value isn't stored anywhere, the select will again say "No preset" and you don't know which one you picked... If the preset select value was saved, you'd know which preset is currently active OR you get to know that a certain preset was used in the first place, and you cannot simply tweak any value because that might ruin the layout.
    Also, if you DO tweak settings that were originally filled in by a preset, the selected preset name would still be visible in the select, and you would know which one to pick if you want to revert your small tweaks again. That'd be really handy, in my opinion.

  • Pipeline finished with Success
    12 months ago
    Total: 414s
    #151796
  • Pipeline finished with Skipped
    12 months ago
    #151812
  • Pipeline finished with Success
    12 months ago
    Total: 167s
    #153160
  • Pipeline finished with Success
    12 months ago
    Total: 172s
    #153208
  • Pipeline finished with Success
    12 months ago
    Total: 170s
    #153220
  • Status changed to Needs review 12 months ago
  • 🇩🇪Germany lrwebks Porta Westfalica
  • Assigned to Grevil
  • 🇩🇪Germany Anybody Porta Westfalica
  • Pipeline finished with Success
    12 months ago
    Total: 184s
    #153755
  • Pipeline finished with Success
    12 months ago
    Total: 155s
    #153841
  • Pipeline finished with Success
    12 months ago
    Total: 155s
    #153842
  • Issue was unassigned.
  • Status changed to Needs work 12 months ago
  • 🇩🇪Germany Grevil
  • 🇩🇪Germany Grevil

    All reviewed. I am unsure who should finish this. @Anybody should decide, based on the reviews.

  • Pipeline finished with Success
    12 months ago
    Total: 168s
    #154387
  • Pipeline finished with Failed
    12 months ago
    Total: 144s
    #154450
  • Pipeline finished with Success
    12 months ago
    Total: 169s
    #154568
  • 🇩🇪Germany Anybody Porta Westfalica

    Ok I just generated an example config entity in drush and there the "status" works as expected!
    The form value is saved correctly and the status value is correctly being exported to the config:

    +++ b/tmp/drush_tmp_1713947716_6628c444d2a0e/example_config_entity.example_config_entity.test.yml
    @@ -1,6 +1,6 @@
     uuid: e36536f1-6b42-4014-8e37-8e6020d492a9
     langcode: de
    -status: true
    +status: false
     dependencies: {  }
     id: test
     label: test
    

    I'll start a code comparison.

  • 🇩🇪Germany Anybody Porta Westfalica

    Oay this doesn't make any sense to me. The form structure and Config Entity structure are exactly the same. For the generated code it works with status, for the implementation here it doesn't.

    The generated code doesn't even have "status" in config_export annotation, but the value is saved!

    Maybe a local issue? @Grevil could you give it a try in your environment?

  • Pipeline finished with Success
    12 months ago
    Total: 171s
    #155164
  • Assigned to Grevil
  • 🇩🇪Germany Anybody Porta Westfalica

    @Grevil & @LRWebks: Here's my guess:

    toArray() is used internally in Drupal if present and this overrides the regular class properties getting. toArray() has no status and so it's missing ... Let's see!

  • 🇩🇪Germany Grevil

    Indeed, @Anybody "toArray()" is already declared by its parent.

    @LRWebks, usually your IDE will let you know about this when defining a new method:

    So if that is the case, check the outcome of the already existing method, and decide whether to:

    • Overwrite the method.
    • Extend the method.
    • Create a separate method, as the original implementation focuses on something entirely different.

    In this case, the already existing implementation does exactly what we need, so we do not need to define our own method.

    BUT this still doesn't fix the problem for only loading active presets. I'll have a quick dig and otherwise we need to do it via a tiny workaound.

  • Pipeline finished with Success
    12 months ago
    Total: 205s
    #156504
  • Pipeline finished with Success
    12 months ago
    Total: 175s
    #156510
  • Pipeline finished with Success
    12 months ago
    #156518
  • Pipeline finished with Success
    12 months ago
    Total: 179s
    #156531
  • Pipeline finished with Success
    12 months ago
    Total: 175s
    #157281
  • Pipeline finished with Canceled
    12 months ago
    Total: 71s
    #157294
  • Pipeline finished with Success
    12 months ago
    Total: 178s
    #157300
  • Pipeline finished with Success
    12 months ago
    Total: 204s
    #157303
  • Pipeline finished with Success
    12 months ago
    Total: 187s
    #157313
  • Pipeline finished with Success
    12 months ago
    Total: 180s
    #157357
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    57 pass, 2 fail
  • Assigned to Anybody
  • Status changed to Needs review 11 months ago
  • 🇩🇪Germany Grevil

    Should be all done! Unfortunately, we get a schema error, when saving the entity inside our test. No idea why... I defined it just as the main module would...

    Drupal\Core\Config\Schema\SchemaIncompleteException: Schema errors for core.entity_view_display.node.article.default with the following errors: core.entity_view_display.node.article.default:content.body.third_party_settings.fences.fences_presets missing schema in Drupal\Core\Config\Development\ConfigSchemaChecker->onConfigSave() (line 98 of core/lib/Drupal/Core/Config/Development/ConfigSchemaChecker.php).

    @Anybody, any idea?
    Using "field.formatter.third_party.fences_presets" instead of "field.formatter.third_party.fences.fences_presets" won't fix it either.

  • Pipeline finished with Failed
    11 months ago
    Total: 206s
    #157418
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    58 pass
  • Pipeline finished with Success
    11 months ago
    #157475
  • Assigned to Grevil
  • Status changed to Needs work 11 months ago
  • 🇩🇪Germany Grevil

    Found the problem and fixed it!

    Now I only need to add two more default presets.

  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    58 pass
  • Pipeline finished with Canceled
    11 months ago
    #157485
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    58 pass
  • Assigned to Anybody
  • 🇩🇪Germany Grevil

    Alright, all done! Please do a final review @Anybody!

  • Status changed to Needs review 11 months ago
  • 🇩🇪Germany Grevil
  • Pipeline finished with Success
    11 months ago
    #157487
  • Assigned to Grevil
  • Status changed to Needs work 11 months ago
  • 🇩🇪Germany Anybody Porta Westfalica

    Nice, Thomas (at my pc) and me left some comments. We're close to the finish line, great job!

  • Pipeline finished with Success
    11 months ago
    #159446
  • Pipeline finished with Success
    11 months ago
    #159466
  • 🇩🇪Germany Grevil

    As stated in the MR, concerning the need of a schema definition:

    Yea, this doesn't seem to be easily implemented, unfortunately. There seems to be no hook_field_formatter_third_party_settings_form_save() hook, and I don't want to overwrite the form['actions']['save'] call, as we are already using a custom hook to add our render elements, and we would then also overwrite the save of the main modules form implementation. Also, it wouldn't be wise to reimplement an already existing core save method (Hence we are not in a class context, we can not simply extend it).

    BUT, I think having a schema definition for the select element isn't that bad. It feels a bit dirty to always save an empty value as a third party setting, but there could be worse. Let's create a follow-up issue to fix this inconvenience and move on for now.

  • Assigned to Anybody
  • Status changed to Needs review 11 months ago
  • 🇩🇪Germany Grevil
  • 🇩🇪Germany Grevil

    All done! We are now using an inline template as a workaround, which doesn't get saved and is purely cosmetic. Please review!

  • Pipeline finished with Success
    11 months ago
    Total: 206s
    #159544
  • Assigned to Grevil
  • Status changed to Needs work 11 months ago
  • 🇩🇪Germany Anybody Porta Westfalica

    Really, really awesome work!
    Left some final comments, afterwards we should merge it and create a new tagged release containing the submodule.

    Could you also add some lines about the feature on the project page?

  • Issue was unassigned.
  • Status changed to RTBC 11 months ago
  • 🇩🇪Germany Grevil
  • Status changed to Fixed 11 months ago
  • 🇩🇪Germany Grevil
  • 🇩🇪Germany Grevil

    Added a new section, quickly going over the new submodule!

  • Pipeline finished with Success
    11 months ago
    Total: 429s
    #166345
  • Pipeline finished with Success
    11 months ago
    Total: 342s
    #166351
  • Pipeline finished with Skipped
    11 months ago
    #167020
  • Pipeline finished with Success
    11 months ago
    Total: 307s
    #168322
  • Pipeline finished with Success
    11 months ago
    Total: 222s
    #168328
  • Pipeline finished with Skipped
    11 months ago
    #168330
  • Pipeline finished with Success
    11 months ago
    Total: 177s
    #170587
  • Pipeline finished with Success
    11 months ago
    Total: 139s
    #170621
  • Pipeline finished with Success
    11 months ago
    Total: 149s
    #171426
  • Pipeline finished with Skipped
    11 months ago
    #171531
  • Automatically closed - issue fixed for 2 weeks with no activity.

  • Pipeline finished with Success
    11 months ago
    Total: 200s
    #171788
  • Pipeline finished with Success
    11 months ago
    Total: 141s
    #175708
  • Pipeline finished with Failed
    11 months ago
    Total: 503s
    #179531
  • Pipeline finished with Canceled
    11 months ago
    Total: 109s
    #179551
  • Pipeline finished with Failed
    11 months ago
    Total: 255s
    #179554
  • Pipeline finished with Failed
    11 months ago
    Total: 185s
    #179557
  • Pipeline finished with Canceled
    11 months ago
    Total: 102s
    #179563
  • Pipeline finished with Canceled
    11 months ago
    Total: 26s
    #179564
  • Pipeline finished with Success
    11 months ago
    Total: 4564s
    #179567
  • Pipeline finished with Canceled
    10 months ago
    #182644
  • Pipeline finished with Success
    10 months ago
    Total: 191s
    #182646
  • Pipeline finished with Failed
    10 months ago
    Total: 226s
    #183150
  • Pipeline finished with Canceled
    10 months ago
    Total: 61s
    #183167
  • Pipeline finished with Success
    10 months ago
    Total: 265s
    #183168
  • Pipeline finished with Skipped
    10 months ago
    #183646
  • Pipeline finished with Failed
    10 months ago
    Total: 1977s
    #189614
  • Pipeline finished with Failed
    10 months ago
    #189645
  • Pipeline finished with Failed
    10 months ago
    Total: 243s
    #189647
  • Pipeline finished with Failed
    10 months ago
    #189653
  • Pipeline finished with Success
    10 months ago
    Total: 245s
    #189667
  • Pipeline finished with Success
    10 months ago
    #189673
  • Pipeline finished with Success
    10 months ago
    Total: 266s
    #189682
  • Pipeline finished with Skipped
    10 months ago
    #207378
  • Pipeline finished with Failed
    10 months ago
    Total: 639s
    #207373
  • Pipeline finished with Failed
    9 months ago
    Total: 458s
    #218464
  • Pipeline finished with Failed
    9 months ago
    Total: 217s
    #218471
  • Pipeline finished with Failed
    9 months ago
    #218492
  • Pipeline finished with Failed
    9 months ago
    Total: 247s
    #218495
  • Pipeline finished with Success
    9 months ago
    Total: 190s
    #222079
  • Pipeline finished with Success
    9 months ago
    Total: 167s
    #222091
  • Pipeline finished with Success
    9 months ago
    Total: 151s
    #222293
  • Pipeline finished with Success
    9 months ago
    Total: 217s
    #229400
  • Pipeline finished with Success
    9 months ago
    Total: 219s
    #229405
  • Pipeline finished with Success
    9 months ago
    Total: 196s
    #229422
  • Pipeline finished with Success
    9 months ago
    Total: 389s
    #230756
  • Pipeline finished with Success
    9 months ago
    Total: 264s
    #230779
  • Pipeline finished with Success
    9 months ago
    Total: 179s
    #230881
  • Pipeline finished with Success
    9 months ago
    Total: 183s
    #232312
  • Pipeline finished with Success
    9 months ago
    Total: 181s
    #232321
  • Pipeline finished with Failed
    9 months ago
    #232843
  • Pipeline finished with Failed
    9 months ago
    #232853
  • Pipeline finished with Canceled
    9 months ago
    Total: 240s
    #232860
  • Pipeline finished with Failed
    9 months ago
    Total: 245s
    #232864
  • Pipeline finished with Success
    9 months ago
    Total: 322s
    #232869
  • Pipeline finished with Failed
    9 months ago
    Total: 382257s
    #229408
  • Pipeline finished with Success
    9 months ago
    Total: 181s
    #233682
  • Pipeline finished with Success
    8 months ago
    Total: 78s
    #234029
  • Pipeline finished with Success
    8 months ago
    Total: 79s
    #234030
  • Pipeline finished with Success
    8 months ago
    Total: 253s
    #234425
  • Pipeline finished with Canceled
    8 months ago
    Total: 94s
    #234436
  • Pipeline finished with Success
    8 months ago
    Total: 319s
    #234437
  • Pipeline finished with Failed
    8 months ago
    Total: 458s
    #235181
  • Pipeline finished with Failed
    8 months ago
    Total: 381s
    #235196
  • Pipeline finished with Success
    8 months ago
    Total: 594s
    #235210
  • Pipeline finished with Failed
    8 months ago
    Total: 261s
    #236665
  • Pipeline finished with Success
    8 months ago
    Total: 173s
    #237463
  • Pipeline finished with Success
    8 months ago
    Total: 379s
    #237811
  • Pipeline finished with Success
    8 months ago
    Total: 254s
    #237815
Production build 0.71.5 2024