Placing a block containing a form in navigation layout prevents layout builder from saving

Created on 12 December 2024, 4 months ago

Problem/Motivation

Since 📌 Provide a way for other modules to flag block plugin implementations as 'navigation safe' Active introduced a way to add additional types of blocks to be placed in Navigation via Layout Builder, it is now possible to add blocks that contain <form> tags when rendered. This means that after these blocks have been placed and saved, the layout cannot be saved again, because the layout form contains nested <form> tags. This identical problem affected default and override entity layouts in Layout Builder and was fixed in #3045171: Form blocks rendered inside layout builder break save . However, the fix was strictly limited to the entity view display form and the individual entity layout form.

Steps to reproduce

  1. Install Drupal with standard profile
  2. Install navigation module
  3. Create a block that has a form in it, such as a search block or views block with an exposed form
  4. Implement hook_block_alter() in some module and set 'allow_in_navigation' for the block's definition to TRUE.
  5. Log in as administrator
  6. Go to /admin/config/user-interface/navigation-block
  7. Click on the +Add block link
  8. Click the link with the text matching the block's label
  9. Press the Add block button
  10. Press Save and confirm you see a successful "Saved navigation blocks" message
  11. (Optional) Go through similar steps to add any other block, but it's the same without doing it
  12. Press Save
  13. Observe that the warning message "You have unsaved changes." appears no matter how many times you press Save

Proposed resolution

The solution in [##3045171] use a form API #process callback added to the layout_builder element in DefaultsEntityForm and LayoutBuilderWidget, combined with a controller service decorator LayoutBuilderHtmlEntityFormController to move the layout builder element outside the form render array. This works because the layout builder element does not itself set values in form state, but instead interacts with the temp store to save layout data on form submit. However, the #process callback and controller apply only to the the entity form routes for the default entity display and entity layout. The navigation layout form is not a layout form, nor does Drupal\navigation\Form\LayoutForm add the #process callback to the layout builder element.

This is probably best solved by:

  1. Moving the #process callback layoutBuilderElementGetKeys() from the widget and the default display forms to the LayoutBuilder render element
  2. Instead of decorating the entity form controller service, use an event subscriber to KernelEvents::VIEW, and alter any form render array that contains the layout builder element keys

Remaining tasks

User interface changes

Introduced terminology

API changes

Data model changes

Release notes snippet

🐛 Bug report
Status

Active

Version

11.0 🔥

Component

layout_builder.module

Created by

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @godotislate
  • Merge request !10539Resolve #3493671 "Placing a block" → (Closed) created by godotislate
  • Pipeline finished with Failed
    4 months ago
    Total: 135s
    #367027
  • Pipeline finished with Failed
    4 months ago
    Total: 135s
    #367030
  • Pipeline finished with Success
    4 months ago
    #367033
  • Pipeline finished with Failed
    4 months ago
    Total: 113s
    #367095
  • Pipeline finished with Success
    4 months ago
    Total: 934s
    #367100
  • Merge request !10540Draft: Test only. → (Closed) created by godotislate
  • Pipeline finished with Failed
    4 months ago
    Total: 1243s
    #367105
  • Pipeline finished with Failed
    4 months ago
    Total: 698s
    #367119
  • Put up MR 10539, which is ready for review. I'm not sure what's going on with the add tests, since the test-only job passes when it shouldn't. So I also pushed up a Test-only MR, which was failing in the wrong place. Meanwhile the test was consistently failing/passing as expected locally.

  • 🇪🇸Spain plopesc Valladolid

    Thank you for noticing this and trying to help Navigation to be more stable. :)

    Tested the MR code locally and fixes the issue with the form save process.

    While testing it manually, noticed that a new blue rectangle appears on the Navigation Blocks page. See screenshot:

    I think it could be easily removed using CSS, but wanted to flag it, just in case it could be an indicator of a possible issue.

  • While testing it manually, noticed that a new blue rectangle appears on the Navigation Blocks page.

    Oh, interesting. With the LB element moved outside the form, I assume it's picked up some sort of border CSS rule. Will investigate.

  • Pipeline finished with Failed
    4 months ago
    Total: 394s
    #367812
  • Pipeline finished with Success
    4 months ago
    Total: 1778s
    #367826
  • Added a class to the layout builder element and updated the CSS selector to hide the border.

    Not sure what's going on with the test. I think there might be some difference between my local env and Gitlab CI for browser-based tests. I'll look into that later when I have to time to revisit.

  • Pipeline finished with Failed
    4 months ago
    Total: 392s
    #367893
  • Pipeline finished with Failed
    4 months ago
    Total: 386s
    #367900
  • godotislate changed the visibility of the branch 3493671-test-only to hidden.

  • Pipeline finished with Success
    4 months ago
    Total: 527s
    #368067
  • Pipeline finished with Failed
    4 months ago
    Total: 555s
    #368074
  • Pipeline finished with Failed
    4 months ago
    #368096
  • Pipeline finished with Failed
    4 months ago
    Total: 661s
    #368108
  • Pipeline finished with Failed
    4 months ago
    Total: 132s
    #369138
  • Pipeline finished with Failed
    4 months ago
    Total: 519s
    #369140
  • Pipeline finished with Failed
    4 months ago
    Total: 633s
    #369146
  • Pipeline finished with Failed
    4 months ago
    Total: 753s
    #370072
  • Pipeline finished with Failed
    4 months ago
    Total: 156s
    #370100
  • Pipeline finished with Failed
    4 months ago
    Total: 562s
    #370108
  • Pipeline finished with Failed
    4 months ago
    Total: 695s
    #370122
  • Pipeline finished with Failed
    4 months ago
    Total: 365s
    #370142
  • Pipeline finished with Failed
    4 months ago
    Total: 416s
    #370154
  • Pipeline finished with Success
    4 months ago
    Total: 495s
    #370163
  • Pipeline finished with Success
    4 months ago
    Total: 431s
    #370181
  • Pipeline finished with Success
    4 months ago
    Total: 590s
    #370197
  • Pipeline finished with Success
    4 months ago
    Total: 689s
    #370212
  • Pipeline finished with Success
    4 months ago
    Total: 396s
    #370229
  • Pipeline finished with Success
    4 months ago
    Total: 1146s
    #370235
  • Created separate issue about strange behavior with the browser based tests not running as expected: 🐛 Functional Javascript test false postive and missing browser output Active

  • Pipeline finished with Success
    3 months ago
    Total: 1156s
    #379162
  • Refactored so that an event subscriber isn't necessary. #pre_render and #post_render callbacks can handle it. Tests pass, but still not getting the test only build to fail as expected in CI, though.

  • Pipeline finished with Failed
    3 months ago
    Total: 153s
    #379274
  • Pipeline finished with Failed
    3 months ago
    Total: 167s
    #379282
  • Pipeline finished with Success
    3 months ago
    Total: 843s
    #379283
  • 🇪🇸Spain plopesc Valladolid

    Thank you for pushing this one!

    Tested the feature branch manually after the refactor and it is working as expected, solving the reported bug for Navigation & Layout Builder integration. Also tested manually in an entity form and no regressions were noticed.

    Added a minor comment in the MR.

    Regarding the test only build, not sure if we could go ahead with this one, or some extra work might be needed.

  • Pipeline finished with Failed
    3 months ago
    Total: 129s
    #379597
  • Thanks for the review, @plopesc. I made the suggested change as well as a similar one I forgot.

    Not sure what's going on with the test. I created 🐛 Functional Javascript test false postive and missing browser output Active , because I have observed some unexpected behavior going on with the browser-based tests at least, but I've made little headway in identifying the cause. Postponing this issue on the resolving the tests.

  • Pipeline finished with Success
    3 months ago
    Total: 7906s
    #379618
  • Tried re-running the test-only job, and it failed as expected! https://git.drupalcode.org/issue/drupal-3493671/-/jobs/3825109.

    I'm not sure what's differe, but unpostponing and putting back to NR.

  • Pipeline finished with Failed
    3 months ago
    Total: 112s
    #383995
  • Pipeline finished with Failed
    3 months ago
    Total: 113s
    #384012
  • Pipeline finished with Success
    3 months ago
    Total: 1214s
    #384018
  • Did a bit of docblock clean up. Test only fails correctly still, so this is ready.

  • 🇺🇸United States nicxvan

    Ok this was a doozy to test.

    I pulled down 11.x and created a custom module with the block_alter and confirmed the issue occurs, checked this branch out and confirmed it is fixed.

    Read through the code a few times, looks good once the two comments are addressed.

  • Pipeline finished with Success
    3 months ago
    Total: 1030s
    #391156
  • 🇺🇸United States nicxvan

    Comments were addressed, looks great!

  • 🇳🇿New Zealand quietone

    After reading the issue and MR, I didn't find any unanswered questions. I updated credit.

  • Pipeline finished with Failed
    2 months ago
    Total: 672s
    #407486
    • catch committed 38dd1c40 on 11.x
      Issue #3493671 by godotislate, plopesc, nicxvan: Placing a block...
  • 🇬🇧United Kingdom catch

    This looks like a really nice clean-up, didn't expect a negative diffstat from the issue title.

    Committed/pushed to 11.x, thanks!

  • Status changed to Fixed about 1 month ago
  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024