Non-translatable fields validation error when using Layout builder

Created on 9 June 2022, almost 3 years ago
Updated 7 January 2025, 3 months ago

Problem/Motivation

There is an issue when you use Layout builder and Entity blocks on a multilingual website. If you try to translate already existing page, you will get an error message:

Non-translatable fields can only be changed when updating the original language.

The reason for this is that the Layout builder compares source lang and translation lang values and in order for this comparison to work, it converts the sections to arrays. This is happening in LayoutSectionItemList.php file under the equals() method.

EntityBlock exposes it's label as a FormattableMarkup object, which breaks the comparison. It needs a string for the comparison to work.

Steps to reproduce

1. Go to a multilingual website and enable Layout builder and Entity blocks modules.
2. Enable Landing page on the Article content type.
3. Create Article node and attack Entity block to it.
4. Try to create a translation of that article in another language.
5. Enjoy the EntityUntranslatableFieldsConstraint

Proposed resolution

Prepared a patch that converts the FormattableMarkup to a string and allows the comparison to work without a problem.

User interface changes

Since the labels are saved on submit, a re-submit of all existing Entity blocks is needed.

πŸ› Bug report
Status

Postponed: needs info

Version

1.0

Component

Code

Created by

πŸ‡§πŸ‡¬Bulgaria yivanov

Live updates comments and jobs are added and updated live.
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.

Production build 0.71.5 2024