Do not modify hrefs when wrapping code terms (#15785)

* do not modify hrefs when wrapping code terms

* lint
This commit is contained in:
Sarah Schneider 2020-09-28 16:50:29 -04:00 коммит произвёл GitHub
Родитель 42fda8ec4d
Коммит 91a74923c5
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 4AEE18F83AFDEB23
1 изменённых файлов: 11 добавлений и 6 удалений

Просмотреть файл

@ -11,16 +11,21 @@ export default function () {
if (!codeTerms) return
codeTerms.forEach(node => {
node.innerHTML = node.innerHTML.replace(wordsLongerThan18Chars, (str) => {
// Do the wrapping on the inner text only, so we don't modify hrefs
const oldText = node.textContent
const newText = oldText.replace(wordsLongerThan18Chars, (str) => {
return str
// GraphQL code terms use camelcase
// GraphQL code terms use camelcase
.replace(camelCaseChars, '$1<wbr>$2')
// REST code terms use underscores
// to keep word breaks looking nice, only break on underscores after the 12th char
// so `has_organization_projects` will break after `has_organization` instead of after `has_`
// REST code terms use underscores
// to keep word breaks looking nice, only break on underscores after the 12th char
// so `has_organization_projects` will break after `has_organization` instead of after `has_`
.replace(underscoresAfter12thChar, '$1_<wbr>')
// Some Actions reference pages have tables with code terms separated by slashes
// Some Actions reference pages have tables with code terms separated by slashes
.replace(slashChars, '$1<wbr>')
})
node.innerHTML = node.innerHTML.replace(oldText, newText)
})
}