Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refs #32819 -- Added id to ErrorList class and template. #18871

Merged
merged 1 commit into from
Dec 5, 2024

Conversation

smithdc1
Copy link
Member

@smithdc1 smithdc1 commented Dec 1, 2024

Trac ticket number

ticket-32819

Branch description

Step 1 of ticket 32819 is to add an id to the error list template so the aria-describedby has something to point to. See #17520

Checklist

  • This PR targets the main branch.
  • The commit message is written in past tense, mentions the ticket number, and ends with a period.
  • I have checked the "Has patch" ticket flag in the Trac system.
  • I have added or updated relevant tests.
  • I have added or updated relevant docs, including release notes if applicable.
  • I have attached screenshots in both light and dark modes for any UI changes.

Sorry, something went wrong.

@smithdc1 smithdc1 force-pushed the ticket_32819_errorlist_id branch from af927c7 to ecc0259 Compare December 1, 2024 08:03
@smithdc1 smithdc1 marked this pull request as ready for review December 1, 2024 09:11
@sarahboyce sarahboyce added the selenium Apply to have Selenium tests run on a PR label Dec 1, 2024
Copy link
Contributor

@sarahboyce sarahboyce left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for pulling this out @smithdc1

@@ -1043,6 +1043,13 @@ Customizing the error list format
Defaults to ``None`` which means to use the default renderer
specified by the :setting:`FORM_RENDERER` setting.

.. attribute:: field_id
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you think it's worth mentioning that this defaults to the auto_id for field errors and no id is associated to non-field errors?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I made some changes here, could you have another look? I'm not sure if we need to go further and mention non-field errors.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks great thank you!

@smithdc1 smithdc1 force-pushed the ticket_32819_errorlist_id branch 2 times, most recently from 4d2c195 to a986c89 Compare December 4, 2024 07:46
Copy link
Contributor

@sarahboyce sarahboyce left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Checked the docs and the rendering of errors seems to always have auto_id=False so I don't think we need any more doc updates 🎊

I have a suggestion on the release note but otherwise I think this is good to go 👍

@@ -1416,7 +1430,7 @@ Methods of ``BoundField``

.. method:: BoundField.render(template_name=None, context=None, renderer=None)

The render method is called by ``as_field_group``. All arguments are
The render method is called by ``as_field_group``. All arguments are
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This disappears when rebasing main 👍

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll rebase 👍

Comment on lines 233 to 234
* :class:`~django.forms.ErrorList` now accepts a ``field_id`` argument and an
``id`` HTML element is added to the default ``ErrorList`` template.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
* :class:`~django.forms.ErrorList` now accepts a ``field_id`` argument and an
``id`` HTML element is added to the default ``ErrorList`` template.
* The new ``field_id`` argument for :class:`~django.forms.ErrorList` allows an
HTML ``id`` attribute to be added in the error template. The default template
uses the format ``id="{{ field_id }}_error"`` where ``field_id`` is the
field's :attr:`~.BoundField.auto_id`.

Possibly? Or

* The new ``field_id`` argument for :class:`~django.forms.ErrorList` allows an
  HTML ``id`` attribute to be added in the error template. See
  :attr:`.ErrorList.field_id` for details.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like your second suggestion.

@smithdc1 smithdc1 force-pushed the ticket_32819_errorlist_id branch 2 times, most recently from 30df69b to 7126d66 Compare December 4, 2024 09:35
Copy link
Contributor

@sarahboyce sarahboyce left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you ⭐

@sarahboyce sarahboyce merged commit edd74c3 into django:main Dec 5, 2024
44 checks passed
@smithdc1 smithdc1 deleted the ticket_32819_errorlist_id branch December 5, 2024 11:35
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
selenium Apply to have Selenium tests run on a PR
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

2 participants