Remove button in entity browser field widget doesn't work

Created on 5 April 2020, almost 5 years ago
Updated 21 March 2023, almost 2 years ago

A notice stopping the "Remove" buttons to works when they is two of them inside the same entity

Notice: Undefined offset: -2 in /xxxxxxxxxxxx/web/modules/contrib/entity_browser/src/Plugin/Field/FieldWidget/EntityReferenceBrowserWidget.php on line 817

This notice causes ajax to fail, resulting in the field being broken unless the visitor reloads the page.

🐛 Bug report
Status

Postponed: needs info

Version

2.9

Component

Field widget

Created by

🇫🇷France steveoriol Grenoble 🇫🇷

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 cbfannin

    #11 worked for me on v2.9

    Added other related issues.

    I would also add this is very strange. Before patching, our remove button worked fine on Pantheon Test environment. It only did not work on local, multidev, and dev environments. But after the patch, it now works on local, multidev, and dev.

  • Status changed to RTBC almost 2 years ago
  • 🇺🇸United States cbfannin

    In following up with the environments that the remove functionality works on vs those it does not work on, I realized it works when Devel is disabled on Test and Live environments on Pantheon. The remove functionality does not work when Devel is enabled on Dev and Local. As soon as I disabled Devel on my local and tried to remove the file from the field, the remove functionality worked.

  • 🇺🇸United States cbfannin

    I did a clean install on simplytest.me with 8.x-2.9 and no longer seeing this issue.

    My test steps were:
    - Installed 8.x-2.9 (unpatched)
    - Created a new Entity Browser adding the upload widget.
    - Added an entity reference field to the page node type.
    - Set the entity reference field's form display to Entity Browser.
    - Created a new node.
    - Selected an image with the new field.
    - Saved the node.
    - Edited the node.
    - Clicked the "Removed" button.
    Result: The image was removed with no reported errors.

    Again this was a clean install with no patches.
    If anyone wants to provide their test steps, I am more than happy to test again.

  • 🇨🇭Switzerland berdir Switzerland

    Setting to needs work for steps to confirm what exactly causes this, also closed 🐛 Undefined array key on file remove Closed: duplicate as a duplicate.

    Also should be a merge request now. Not against merging it as it shouldn't cause issues, but having steps to reproduce and preferably tests would make it easier to verify.

  • Status changed to Needs work 6 months ago
  • 🇨🇭Switzerland berdir Switzerland
  • 🇪🇸Spain eduardo morales alberti Spain, 🇪🇺

    @berdir as said in the comment #3247212-6: Ajax error on delete item

    We're seeing the same issue. It doesn't actually cause a problem unless PHP has the display_errors option switched on.

    Here the problem is caused by having both an Entity Browser field and a core Media Library field on the same form. When trying to remove an item from the media widget, the Entity Browser code is getting confused because the button for core Media Library is also called remove_button

    Attaching patch which checks the field name on the triggering element matches the expected one for this widget. This allows both the media library and entity browser to function correctly again here.

    We are unsure how to cover it with tests, but the patch #3125117-11: Remove button in entity browser field widget doesn't work works for us.

  • 🇪🇸Spain eduardo morales alberti Spain, 🇪🇺

    We test it on a simpletestme https://master-cg4lcdtc1ja3gfni2izgajxkko4dkwxp.tugboatqa.com/

    Steps to reproduce:

    • We installed the drupal 10.3.9
    • Installed the entity browser and created a reference field to content with this widget
    • Installed media and media library
    • Created a content with a media and saved the content
    • Edit again the content and remove the media
    • Review the logs

    It is tested on a clean environment so RTBC

    @berdir do you need more info?

  • First commit to issue fork.
  • Merge request !67Add patch from #11 → (Open) created by AndyF
  • 🇬🇧United Kingdom AndyF

    I was also seeing this error on a node edit form with both a media browser and entity browser. The patch from #11 fixed it. I've moved it to an MR, still could do with tests.

  • Pipeline finished with Success
    about 2 months ago
    Total: 238s
    #356427
  • 🇬🇧United Kingdom AndyF

    Like #14 I'm finding it only actually breaks when devel's enabled; otherwise it generates the same warning but things carry on functioning.

    And in case it's not clear, it's the media library widget that stops working for me (ie you can't remove the image), not the entity browser.

    For me, with devel enabled and set to the PHP warning get prepended to the JSON responses preventing them from being parsed, it seems to be fixed with https://gitlab.com/drupalspoons/devel/-/merge_requests/149.

Production build 0.71.5 2024