Skip to content

Commit

Permalink
Make CharacterCount's JS inject fallback hint if possible
Browse files Browse the repository at this point in the history
  • Loading branch information
romaricpascal committed Oct 17, 2022
1 parent f537fbc commit 1453b9e
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 8 deletions.
18 changes: 10 additions & 8 deletions src/govuk/components/character-count/character-count.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -92,20 +92,18 @@ function CharacterCount ($module, config) {
locale: closestAttributeValue($module, 'lang')
})

this.$module = $module
this.$textarea = $module.querySelector('.govuk-js-character-count')
this.$visibleCountMessage = null
this.$screenReaderCountMessage = null
this.lastInputTimestamp = null

// Determine the limit attribute (characters or words)
if (this.config.maxwords) {
this.maxLength = this.config.maxwords
} else if (this.config.maxlength) {
this.maxLength = this.config.maxlength
} else {
return
}

this.$module = $module
this.$textarea = $module.querySelector('.govuk-js-character-count')
this.$visibleCountMessage = null
this.$screenReaderCountMessage = null
this.lastInputTimestamp = null
}

/**
Expand All @@ -120,6 +118,10 @@ CharacterCount.prototype.init = function () {
var $textarea = this.$textarea
var $fallbackLimitMessage = document.getElementById($textarea.id + '-info')

if ($fallbackLimitMessage.textContent.match(/^\s*$/)) {
$fallbackLimitMessage.textContent = this.i18n.t('fallbackHint', { count: this.maxLength })
}

// Move the fallback count message to be immediately after the textarea
// Kept for backwards compatibility
$textarea.insertAdjacentElement('afterend', $fallbackLimitMessage)
Expand Down
22 changes: 22 additions & 0 deletions src/govuk/components/character-count/character-count.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -433,6 +433,28 @@ describe('Character count', () => {
const visibility = await page.$eval('.govuk-character-count__status', el => window.getComputedStyle(el).visibility)
expect(visibility).toEqual('visible')
})

it.only('injects the description of the textarea', async () => {
page.on('console', async (e) => {
const args = await Promise.all(
e.args().map((a) => a.jsonValue())
)
console[e.type() === 'warning' ? 'warn' : e.type()](...args)
})

await renderAndInitialise(page, 'character-count', {
nunjucksParams: examples['no maximum'],
javascriptConfig: {
maxlength: 10
}
})

const message = await page.$eval(
'.govuk-character-count__message',
(el) => el.innerHTML.trim()
)
expect(message).toEqual('No more than 10 characters')
})
})

describe('via `initAll`', () => {
Expand Down

0 comments on commit 1453b9e

Please sign in to comment.