UNPKG

@hashicorp/react-subnav

Version:

Displays a navigation bar, with links and a call-to-action.

116 lines (111 loc) 6.24 kB
/** * Copyright (c) HashiCorp, Inc. * SPDX-License-Identifier: MPL-2.0 */ import { camelCase } from 'camel-case' import LinkWrap from '@hashicorp/react-link-wrap' import InlineSvg from '@hashicorp/react-inline-svg' import s from './style.module.css' import classNames from 'classnames' /* main logos, for light theme */ import ConsulLogo from '@hashicorp/mktg-logos/product/consul/primary/color.svg?include' import ConsulLogoAttr from '@hashicorp/mktg-logos/product/consul/primary/attributed_color.svg?include' import HashiCorpLogo from '@hashicorp/mktg-logos/corporate/hashicorp/primary/black.svg?include' import HCPLogo from '@hashicorp/mktg-logos/product/hcp/primary/black.svg?include' import NomadLogo from '@hashicorp/mktg-logos/product/nomad/primary/color.svg?include' import NomadLogoAttr from '@hashicorp/mktg-logos/product/nomad/primary/attributed_color.svg?include' import PackerLogo from '@hashicorp/mktg-logos/product/packer/primary/color.svg?include' import PackerLogoAttr from '@hashicorp/mktg-logos/product/packer/primary/attributed_color.svg?include' import TerraformLogo from '@hashicorp/mktg-logos/product/terraform/primary/color.svg?include' import TerraformLogoAttr from '@hashicorp/mktg-logos/product/terraform/primary/attributed_color.svg?include' import VagrantLogo from '@hashicorp/mktg-logos/product/vagrant/primary/color.svg?include' import VagrantLogoAttr from '@hashicorp/mktg-logos/product/vagrant/primary/attributed_color.svg?include' import VaultLogo from '@hashicorp/mktg-logos/product/vault/primary/color.svg?include' import VaultLogoAttr from '@hashicorp/mktg-logos/product/vault/primary/attributed_color.svg?include' import BoundaryLogo from '@hashicorp/mktg-logos/product/boundary/primary/color.svg?include' import BoundaryLogoAttr from '@hashicorp/mktg-logos/product/boundary/primary/attributed_color.svg?include' import WaypointLogo from '@hashicorp/mktg-logos/product/waypoint/primary/color.svg?include' import WaypointLogoAttr from '@hashicorp/mktg-logos/product/waypoint/primary/attributed_color.svg?include' import TerraformCloudLogo from '@hashicorp/mktg-logos/product/terraform-cloud/primary/color.svg?include' import TerraformCloudLogoAttr from '@hashicorp/mktg-logos/product/terraform-cloud/primary/attributed_color.svg?include' /* white logos, for dark theme */ import ConsulLogoWhite from '@hashicorp/mktg-logos/product/consul/primary/colorwhite.svg?include' import ConsulLogoWhiteAttr from '@hashicorp/mktg-logos/product/consul/primary/attributed_colorwhite.svg?include' import HashiCorpLogoWhite from '@hashicorp/mktg-logos/corporate/hashicorp/primary/white.svg?include' import HCPLogoWhite from '@hashicorp/mktg-logos/product/hcp/primary/white.svg?include' import NomadLogoWhite from '@hashicorp/mktg-logos/product/nomad/primary/colorwhite.svg?include' import NomadLogoWhiteAttr from '@hashicorp/mktg-logos/product/nomad/primary/attributed_colorwhite.svg?include' import PackerLogoWhite from '@hashicorp/mktg-logos/product/packer/primary/colorwhite.svg?include' import PackerLogoWhiteAttr from '@hashicorp/mktg-logos/product/packer/primary/attributed_colorwhite.svg?include' import TerraformLogoWhite from '@hashicorp/mktg-logos/product/terraform/primary/colorwhite.svg?include' import TerraformLogoWhiteAttr from '@hashicorp/mktg-logos/product/terraform/primary/attributed_colorwhite.svg?include' import VagrantLogoWhite from '@hashicorp/mktg-logos/product/vagrant/primary/colorwhite.svg?include' import VagrantLogoWhiteAttr from '@hashicorp/mktg-logos/product/vagrant/primary/attributed_colorwhite.svg?include' import VaultLogoWhite from '@hashicorp/mktg-logos/product/vault/primary/colorwhite.svg?include' import VaultLogoAttrWhite from '@hashicorp/mktg-logos/product/vault/primary/attributed_colorwhite.svg?include' import BoundaryLogoWhite from '@hashicorp/mktg-logos/product/boundary/primary/colorwhite.svg?include' import BoundaryLogoWhiteAttr from '@hashicorp/mktg-logos/product/boundary/primary/attributed_colorwhite.svg?include' import WaypointLogoWhite from '@hashicorp/mktg-logos/product/waypoint/primary/colorwhite.svg?include' import WaypointLogoWhiteAttr from '@hashicorp/mktg-logos/product/waypoint/primary/attributed_colorwhite.svg?include' import TerraformCloudLogoWhite from '@hashicorp/mktg-logos/product/terraform-cloud/primary/colorwhite.svg?include' import TerraformCloudLogoWhiteAttr from '@hashicorp/mktg-logos/product/terraform-cloud/primary/attributed_colorwhite.svg?include' const logoDict = { light: { boundary: BoundaryLogo, hashiCorpBoundary: BoundaryLogoAttr, consul: ConsulLogo, hashicorp: HashiCorpLogo, hashiCorpConsul: ConsulLogoAttr, hcp: HCPLogo, nomad: NomadLogo, hashiCorpNomad: NomadLogoAttr, packer: PackerLogo, hashiCorpPacker: PackerLogoAttr, terraform: TerraformLogo, hashiCorpTerraform: TerraformLogoAttr, tfc: TerraformCloudLogo, hashiCorpTfc: TerraformCloudLogoAttr, vagrant: VagrantLogo, hashiCorpVagrant: VagrantLogoAttr, vault: VaultLogo, hashiCorpVault: VaultLogoAttr, waypoint: WaypointLogo, hashiCorpWaypoint: WaypointLogoAttr, }, dark: { boundary: BoundaryLogoWhite, hashiCorpBoundary: BoundaryLogoWhiteAttr, consul: ConsulLogoWhite, hashicorp: HashiCorpLogoWhite, hashiCorpConsul: ConsulLogoWhiteAttr, hcp: HCPLogoWhite, nomad: NomadLogoWhite, hashiCorpNomad: NomadLogoWhiteAttr, packer: PackerLogoWhite, hashiCorpPacker: PackerLogoWhiteAttr, terraform: TerraformLogoWhite, hashiCorpTerraform: TerraformLogoWhiteAttr, tfc: TerraformCloudLogoWhite, hashiCorpTfc: TerraformCloudLogoWhiteAttr, vagrant: VagrantLogoWhite, hashiCorpVagrant: VagrantLogoWhiteAttr, vault: VaultLogoWhite, hashiCorpVault: VaultLogoAttrWhite, waypoint: WaypointLogoWhite, hashiCorpWaypoint: WaypointLogoWhiteAttr, }, } function TitleLink({ text, url, product, Link, theme }) { const Logo = logoDict[theme][camelCase(text)] return ( <LinkWrap Link={Link} className={classNames(s.root, s[`brand-${product}`], s[camelCase(text)])} href={url} title={text} > {Logo ? <InlineSvg src={Logo} /> : text} </LinkWrap> ) } export default TitleLink