Clean up JS for ConfigEntryReference component

This commit is contained in:
Luke Kysow 2021-01-06 10:20:15 -08:00
parent 4d4af4552d
commit 3f6fd7d66c
1 changed files with 23 additions and 65 deletions

View File

@ -31,12 +31,8 @@ import EnterpriseAlertBase from '@hashicorp/react-enterprise-alert'
* - type <optional>: the type and default of this key, e.g. string: "default". * - type <optional>: the type and default of this key, e.g. string: "default".
*/ */
export default function ConfigEntryReference({ keys, topLevel = true }) { export default function ConfigEntryReference({ keys, topLevel = true }) {
let kubeKeys = keys // Kube needs to have its non-top-level keys nested under a "spec" key.
if (topLevel) { const kubeKeys = topLevel ? toKubeKeys(keys) : keys
// Kube needs to have its non-top-level keys nested under a "spec" key.
kubeKeys = toKubeKeys(keys)
}
return ( return (
<Tabs> <Tabs>
<Tab heading="HCL">{renderKeys(keys, true)}</Tab> <Tab heading="HCL">{renderKeys(keys, true)}</Tab>
@ -52,40 +48,23 @@ export default function ConfigEntryReference({ keys, topLevel = true }) {
* @returns {JSX.Element|null} * @returns {JSX.Element|null}
*/ */
function renderKeys(keys, isHCLTab) { function renderKeys(keys, isHCLTab) {
if (!keys) { if (!keys) return null
return null return <ul>{keys.map((key) => renderKey(key, isHCLTab))}</ul>
}
return (
<ul>
{keys.map((key) => {
return renderKey(key, isHCLTab)
})}
</ul>
)
} }
/** /**
* Renders a single key as its HTML element. * Renders a single key as its HTML element.
* *
* @param {object} key * @param {object} key
* @param {boolea} isHCLTab * @param {boolean} isHCLTab
* @returns {JSX.Element|null} * @returns {JSX.Element|null}
*/ */
function renderKey(key, isHCLTab) { function renderKey(key, isHCLTab) {
let keyName = key.name if (!key.name) return null
if (!keyName) { if (isHCLTab && key.hcl === false) return null
return null if (!isHCLTab && key.yaml === false) return null
}
if (!isHCLTab) { const keyName = isHCLTab ? key.name : toYAMLKeyName(key.name)
keyName = toYAMLKeyName(keyName)
}
if (isHCLTab && key.hcl === false) {
return null
}
if (!isHCLTab && key.yaml === false) {
return null
}
let description = '' let description = ''
if (key.description) { if (key.description) {
@ -98,21 +77,9 @@ function renderKey(key, isHCLTab) {
} }
} }
let htmlDescription = '' const htmlDescription = description && markdownToHtml(' - ' + description)
if (description !== '') { const type = key.type && <code>{`(${key.type})`}</code>
htmlDescription = markdownToHtml(' - ' + description) const enterpriseAlert = key.enterprise && <EnterpriseAlert inline />
}
let type = ''
if (key.type) {
type = <code>{'(' + key.type + ')'}</code>
}
let enterpriseAlert = ''
if (key.enterprise) {
enterpriseAlert = <EnterpriseAlert inline />
}
const keyLower = keyName.toLowerCase() const keyLower = keyName.toLowerCase()
return ( return (
@ -144,12 +111,8 @@ function renderKey(key, isHCLTab) {
* @returns {array} * @returns {array}
*/ */
function toKubeKeys(keys) { function toKubeKeys(keys) {
const topLevelKeys = keys.filter((key) => { const topLevelKeys = keys.filter((key) => isTopLevelKubeKey(key.name))
return isTopLevelKubeKey(key.name) const keysUnderSpec = keys.filter((key) => !isTopLevelKubeKey(key.name))
})
const keysUnderSpec = keys.filter((key) => {
return !isTopLevelKubeKey(key.name)
})
return topLevelKeys.concat([{ name: 'spec', children: keysUnderSpec }]) return topLevelKeys.concat([{ name: 'spec', children: keysUnderSpec }])
} }
@ -171,26 +134,21 @@ function toYAMLKeyName(hclKey) {
return hclKey.toLowerCase() return hclKey.toLowerCase()
} }
let indexFirstLowercaseChar = 0 let indexFirstLowercaseChar = hclKey
for (let i = 0; i < hclKey.length; i++) { .split('')
if (hclKey[i].toLowerCase() === hclKey[i]) { .findIndex((c) => c === c.toLowerCase())
indexFirstLowercaseChar = i
break
}
}
// Special case to handle something like ACLToken => aclToken. // Special case to handle something like ACLToken => aclToken.
if (indexFirstLowercaseChar > 1) { if (indexFirstLowercaseChar > 1) {
indexFirstLowercaseChar-- indexFirstLowercaseChar--
} }
let yamlKey = '' let lowercasePortion = ''
for (let i = 0; i < indexFirstLowercaseChar; i++) { for (let i = 0; i < indexFirstLowercaseChar; i++) {
yamlKey += hclKey[i].toLowerCase() lowercasePortion += hclKey[i].toLowerCase()
} }
yamlKey += hclKey.split('').slice(indexFirstLowercaseChar).join('') return (
lowercasePortion + hclKey.split('').slice(indexFirstLowercaseChar).join('')
return yamlKey )
} }
/** /**