Enable automatically on fields with #maxlength

Created on 22 May 2023, almost 2 years ago
Updated 5 June 2023, almost 2 years ago

Problem/Motivation

We want to inform our users whenever a field has a maxlength. Text fields already have a hard limit (255 by default) so having to enable maxlength on each field is redundant.
We would like to be able to have the maxlength module automatically enabled on any field that has a #maxlength key (while still be able to set another limit in the form mode if we need to).

Steps to reproduce

  1. Enable the maxlength module.
  2. Create a text field with a character limit (in storage config).
  3. maxlength does not display anything on this field.

Proposed resolution

MaxLengthCallbacks::maxlengthPreRender() could use #maxlength if #maxlength_js is false.

Remaining tasks

  • ❌Get maintainer approval for the proposed resolution
  • ❌Implement resolution
  • ❌Write test coverage (contact a maintainer if you need help)
  • ❌Maintainer review via the UI
  • ❌Maintainer Code Review #1
  • ❌Maintainer code review #2
  • ❌Merge into dev branch, with credit to author and participants
Feature request
Status

Closed: works as designed

Version

2.1

Component

Code

Created by

🇫🇷France prudloff Lille

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

Comments & Activities

  • Issue created by @prudloff
  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.5 + Environment: PHP 8.1 & MySQL 5.7
    last update almost 2 years ago
    6 fail
  • @prudloff opened merge request.
  • 🇺🇸United States cedewey Denver, CO

    Hi Pierre,

    Thanks for the feature request. We should think through the workflow for this to decide whether it is a feature we'll incorporate into the module.

    I don't think we should enable MaxLength on all fields because not everyone wants to see that countdown message for every field that has a maxlength value.

    We could provide a configuration option that is something like, "Display countdown message on all fields with a maxlength." But then we start getting into overridden settings with one behavior set on a MaxLength configuration page and other settings being defined at the form display level.

    I'm afraid this feature request is going against our values of

    • intuitive for site builders
    • sustainable for site owners

    However, I'd like to hear any additional thoughts you have on this.

    Thanks!

  • 🇫🇷France prudloff Lille

    I totally agree this should not be enabled automatically.

    If you don't want to add a setting for this, I guess we could also publish this as a separate contrib module that depends on maxlength.

  • Status changed to Closed: works as designed almost 2 years ago
  • 🇺🇸United States cedewey Denver, CO

    I think a contrib module is the best way to go. If you end up creating it, let us know and we'll be happy to reference it on the project page and mention it in the documentation. Thanks!

  • 🇫🇷France prudloff Lille

    I published a new contrib module here: https://www.drupal.org/project/maxlength_auto/

  • 🇺🇸United States cedewey Denver, CO

    Nice! I just updated the MaxLength project description and the documentation mentioning it. Thanks for contributing that module!

Production build 0.71.5 2024