mirror of https://github.com/status-im/consul.git
Clean up JS for ConfigEntryReference component
This commit is contained in:
parent
4d4af4552d
commit
3f6fd7d66c
|
@ -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
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue