Drag-and-drop reordering doesn't work if the region content is nested in other elements

Created on 19 June 2019, almost 6 years ago
Updated 29 August 2024, 7 months ago

For example, in a custom layout situation where the region content appears in a structure like this:

<div {{ region_attributes.first }}>
  <div>
    {{ content.first }}
  </div>
</div>

The Drag-and-drop reordering doesn't work because the selector takes .js-layout-builder-region > .js-layout-builder-block instead of .js-layout-builder-region .js-layout-builder-block.

🐛 Bug report
Status

Needs work

Version

11.0 🔥

Component
Layout builder 

Last updated about 2 hours ago

Created by

🇲🇰Macedonia dejanp

Live updates comments and jobs are added and updated live.
  • Blocks-Layouts

    Blocks and Layouts Initiative. See the #2811175 Add layouts to Drupal issue.

  • 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.

  • Needs issue summary update

    Issue summaries save everyone time if they are kept up-to-date. See Update issue summary task instructions.

Sign in to follow issues

Comments & Activities

Not all content is available!

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

  • First commit to issue fork.
  • @bernardm28 opened merge request.
  • 🇺🇸United States bernardm28 Tennessee

    Rerolls the patch to make it compatible with 9.5

  • @bernardm28 opened merge request.
  • First commit to issue fork.
  • 🇺🇸United States ctrladel North Carolina, USA

    Looked like the reroll was missing the tests that were in the patch from #25 so pushed those to both the 9.5 and 10 MRs

  • Fixed for drupal/core:9.5.3

  • Status changed to Needs review almost 2 years ago
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update almost 2 years ago
    Patch Failed to Apply
  • 🇮🇳India zeeshan_khan

    Patch rerolled for 9.5.x
    Added reroll diff.

  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update almost 2 years ago
    Custom Commands Failed
  • Status changed to Needs work almost 2 years ago
  • 🇺🇸United States smustgrave

    Was previously tagged for tests which still need to happen.

    Also issue summary could use some updating.

    Thanks.

  • 🇧🇪Belgium weseze

    Rerolled for D10.1.x

  • 🇺🇸United States xeiro

    I can confirm #44 patch applies to D10.1.8

  • 🇮🇳India zeeshan_khan

    @weseze - Please provide interdiff
    Also we need a re-roll for 11.x

  • last update about 1 year ago
    26,092 pass, 1,820 fail
  • Patches here aren't working for me with a setup like this:

    <div class="layout-builder__region js-layout-builder-region layout__region layout__region--content">
      <div class="js-layout-builder-block layout-builder-block contextual-region">Block 1</div>
      <div class="js-layout-builder-block layout-builder-block contextual-region">Block 2</div>
      <div class="js-layout-builder-block layout-builder-block contextual-region">Block 3</div>
      <div class="my-custom-wrapper-here">
        <div class="js-layout-builder-block layout-builder-block contextual-region">Block 4</div>
        <div class="js-layout-builder-block layout-builder-block contextual-region">Block 5</div>
      </div>
    </div>
    

    It sounds like I should expect to be able to drag and drop 'Block 4' and 'Block 5' around after applying some of the patches here, however I am unable to.

    From the original post:

    The Drag-and-drop reordering doesn't work because the selector takes instead of .

    Is something incorrect with my formatting perhaps? Seems like what I have should work?

  • 🇫🇷France Grimreaper France 🇫🇷

    Hi,

    Thanks for all the work done on this issue.

    Patch from comment 44 applies on Core 10.3.1 and fixes the issue for me. I have a layout with multiple levels of nesting mixed with other sections with "standards" layouts and now it works perfectly.

    https://git.drupalcode.org/project/ui_suite_bootstrap/-/blob/5.0.x/templ...

    Where:
    - <div{{ attributes.addClass('accordion-item') }}> is the region div.
    - {{ content }} is the region content

  • 🇮🇳India heykarthikwithu Bengaluru 🌍

    #44 was not working in my case, made change suggested in #47, works for me (attached the patch)

Production build 0.71.5 2024