Enable ConfigTarget to format error messages

Created on 16 October 2024, 6 months ago

Problem/Motivation

The Content Security Policy module has a lengthy form with two vertical tabs that have identical components, and each component has similar fields. To help users locate which item failed validation, the message included the vertical tab and component for the error.
In converting to use config validation and #config_target for the form, the error message is now only the one provided by the violated constraint.

Overriding the form's formatMultipleViolationsMessage() allows parsing the $form_element_name to provide additional context, but it is only called when an element receives multiple violations. Single violations can't be changed to provide additional context, and the message format differs between single and multiple violations.

Proposed resolution

- Add a formatViolations property to ConfigTarget that accepts an optional callable.
- Add a formatViolationsMessage() method to ConfigTarget that is called instead of ConfigFormBase::formatMultipleViolationsMessage() if present.
- Always call formatViolationsMessage() for any number of violations.

Remaining tasks

User interface changes

Introduced terminology

API changes

Data model changes

Release notes snippet

Feature request
Status

Active

Version

11.0 🔥

Component

forms system

Created by

🇨🇦Canada gapple

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

Merge Requests

Comments & Activities

Production build 0.71.5 2024