save_edit may share the same #attribute instance; leads to incorrect label

Created on 15 August 2023, over 1 year ago
Updated 16 August 2023, over 1 year ago

Problem/Motivation

The label for the submit button is appearing as the same label as the save_edit button

Steps to reproduce

  1. composer require drupal/save_edit:^1.4
  2. drush en save_edit_3381269 (see custom module .zip uploaded below)
  3. go to /admin/config/save_edit/settings
  4. Enable for a bundle
  5. Try to add that bundle, e.g. /node/add/page
  6. In the actions area, observe that the button labels are duplicated. (and the foo class as well)

If $form["actions"]["submit"]["#attributes"] is an instance of \Drupal\Core\Template\AttributeArray when $form["actions"]["submit"] is used as the template for $form['actions']['save_edit'], then the object is shared and the <button[value]> attribute may be incorrect, resulting in a button that shows the wrong label.

Proposed resolution

When copying $form['actions']['save_edit'] = $form['actions']['submit']; the #attributes object needs to be cloned.

Remaining tasks

Merge the pull request.

User interface changes

None

API changes

None

Data model changes

None

πŸ› Bug report
Status

Fixed

Version

1.0

Component

Code

Created by

πŸ‡ΊπŸ‡ΈUnited States aklump

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

Comments & Activities

Production build 0.71.5 2024