* Update index to make it clear what has hasn't updated to Next/React yet * Typescriptify events and experiments * Typescript the old JS for easier integration * Update release-notes.ts * Lint * Run npm i * Fix a few lint issues * Update airgap-links.ts * Update airgap-links.ts * Update set-next-env to ts * Update airgap-links.ts * Update package-lock.json * Update set-next-env.ts * Update package-lock.json * Revert "Update package-lock.json" This reverts commit b45e8250beeb700719d3b44e1092b0bbd093baba. * readd fsevents * Revert "readd fsevents" This reverts commit 419f3c35080ac4a9072f0b4e8e291e1712ce3639. * Update openapi-schema-check.yml * Revert "Update openapi-schema-check.yml" This reverts commit 5e9f4a29ea11ee343ca17291a40a751920c5b923. * Update package-lock.json * Update package-lock.json
35 lines
1.4 KiB
TypeScript
35 lines
1.4 KiB
TypeScript
import escape from 'lodash/escape'
|
|
const wordsLongerThan18Chars = /[\S]{18,}/g
|
|
const camelCaseChars = /([a-z])([A-Z])/g
|
|
const underscoresAfter12thChar = /([\w:]{12}[^_]*?)_/g
|
|
const slashChars = /([/\\])/g
|
|
|
|
// This module improves table rendering on reference pages by inserting a <wbr>
|
|
// tag in code terms that use camelcase, slashes, or underscores, inspired by
|
|
// http://heap.ch/blog/2016/01/19/camelwrap/
|
|
export default function () {
|
|
const codeTerms = document.querySelectorAll('#article-contents table code')
|
|
if (!codeTerms) return
|
|
|
|
codeTerms.forEach((node) => {
|
|
// Do the wrapping on the inner text only, so we don't modify hrefs
|
|
const oldText = escape(node.textContent || '')
|
|
|
|
const newText = oldText.replace(wordsLongerThan18Chars, (str) => {
|
|
return (
|
|
str
|
|
// 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_`
|
|
.replace(underscoresAfter12thChar, '$1_<wbr>')
|
|
// Some Actions reference pages have tables with code terms separated by slashes
|
|
.replace(slashChars, '$1<wbr>')
|
|
)
|
|
})
|
|
|
|
node.innerHTML = node.innerHTML.replace(oldText, newText)
|
|
})
|
|
}
|