Add 'lang' attribute option

Created on 23 December 2024, 3 months ago

Problem/Motivation

When an English page declared by (<html lang="en">) has links in Spanish text (lets just use Spanish as the example), a screen reader will read the link text in an English accent.

Proposed resolution

With accessibility becoming ever more important, it would be nice to have the 'lang' attribute available as an input text box or select list where we can add language options. This way a screen reader will use a Spanish accent to read link text that is in Spanish.

The link with the lang attribute would look like this and this would read better via a screen reader.

<a lang="es" href="/informacion-en-espanol">Información en español</a>

Feature request
Status

Active

Version

2.2

Component

Code

Created by

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

Merge Requests

Comments & Activities

  • Issue created by @jdewit
  • 🇮🇳India sayan_k_dutta

    Working on it.

  • Thank you so much @sayan_k_dutta.

  • 🇮🇳India sayan_k_dutta

    Made the code changes required to display a option to enter lang attribute in the link form. But drupal ckeditor5 seems to filter out the attribute, as it is not being rendered in the link form. Someone please review the code changes.

  • Pipeline finished with Failed
    3 months ago
    Total: 417s
    #397679
  • @sayan_k_dutta. Could you upload a patch so we can test it out and help debug. Thanks.

  • 🇮🇳India sayan_k_dutta

    Here is the patch attached.

  • You had two "console.log" statements in js/ckeditor5_plugins/editorAdvancedLink/src/editoradvancedlinkediting.js that were throwing console errors for me. I removed them in my testing and rebuilt editorAdvancedLink.js.

    After I enabled the Language attribute in the text editor settings things are working. See the screenshot "ckeditor-settings-enable-language.png" for reference.

    I'm seeing the Language option in the Advanced dropdown. See the screenshot "lang-attribute-in-advanced.png" for reference.

    The lang attribute is showing up in the link markup. See the screenshot "lang-attribute-markup.png".

    I think all you have to do is remove those two console.log lines and rebuild the JS.

  • 🇮🇳India sayan_k_dutta

    Thanks @jdewit, overlooked it. Made the changes.

  • Pipeline finished with Failed
    3 months ago
    Total: 408s
    #399040
  • Status changed to Needs work about 1 month ago
  • Hey @sayan_k_dutta,

    It seems that the recent changes you've made are causing failures of PHPStan and upgrade status. Could you please address these issues?

  • 🇮🇳India keshav patel

    keshav patel made their first commit to this issue’s fork.

  • Pipeline finished with Failed
    about 1 month ago
    Total: 424s
    #434282
  • 🇮🇳India keshav patel

    Fixed some Drupal coding standard issues, but I think there are 4 such issue which we've to live with or we can suppress them:

    FILE: src/Plugin/CKEditor4To5Upgrade/AdvancedLink.php
    -----------------------------------------------------------------------------------------------------------------------------
    FOUND 3 ERRORS AFFECTING 3 LINES
    -----------------------------------------------------------------------------------------------------------------------------
     30 | ERROR | Public method name "AdvancedLink::mapCKEditor4ToolbarButtonToCKEditor5ToolbarItem" is not in lowerCamel format
     37 | ERROR | Public method name "AdvancedLink::mapCKEditor4SettingsToCKEditor5Configuration" is not in lowerCamel format
     44 | ERROR | Public method name "AdvancedLink::computeCKEditor5PluginSubsetConfiguration" is not in lowerCamel format
    -----------------------------------------------------------------------------------------------------------------------------
    Reason: Core too uses naming in the same format. (@see Drupal\ckeditor5\Plugin\CKEditor4To5UpgradePluginInterface)
    
    FILE: /tests/src/Kernel/CKEditor4To5Upgrade/UpgradePathCompletenessTest.php
    ------------------------------------------------------------------------------------------------------------
    FOUND 1 ERROR AFFECTING 1 LINE
    ------------------------------------------------------------------------------------------------------------
     15 | ERROR | Class name doesn't match filename; expected "class UpgradePathCompletenessTest"
    ------------------------------------------------------------------------------------------------------------
    Reason: Class exists with the same name (@see line:42), but there are multiple classes on the same file.
    
  • Pipeline finished with Failed
    about 1 month ago
    Total: 418s
    #434479
  • Pipeline finished with Failed
    about 1 month ago
    Total: 552s
    #434488
  • Pipeline finished with Failed
    about 1 month ago
    Total: 500s
    #434593
  • Pipeline finished with Failed
    2 days ago
    Total: 426s
    #462221
Production build 0.71.5 2024