From 5dd2f7400cd81858ed7898fccdd3e95fcd980784 Mon Sep 17 00:00:00 2001 From: Zach Shilton <4624598+zchsh@users.noreply.github.com> Date: Mon, 25 Sep 2023 13:57:30 -0400 Subject: [PATCH] feat(openapi): support dynamic API service icon (#2174) * feat(openapi): support dynamic API spec icon * feat: use vault icon for HCP Vault Secrets --- .../hcp/api-docs/vault-secrets/[[...page]].tsx | 2 ++ .../components/open-api-overview/index.tsx | 9 +++++---- src/views/open-api-docs-view/index.tsx | 2 ++ src/views/open-api-docs-view/server.ts | 3 +++ src/views/open-api-docs-view/types.ts | 17 +++++++++++++++++ 5 files changed, 29 insertions(+), 4 deletions(-) diff --git a/src/pages/hcp/api-docs/vault-secrets/[[...page]].tsx b/src/pages/hcp/api-docs/vault-secrets/[[...page]].tsx index 6956279c8a..2ef40b8ce9 100644 --- a/src/pages/hcp/api-docs/vault-secrets/[[...page]].tsx +++ b/src/pages/hcp/api-docs/vault-secrets/[[...page]].tsx @@ -25,6 +25,7 @@ import type { */ const PAGE_CONFIG: OpenApiDocsPageConfig = { productSlug: 'hcp', + serviceProductSlug: 'vault', basePath: '/hcp/api-docs/vault-secrets', githubSourceDirectory: { owner: 'hashicorp', @@ -98,6 +99,7 @@ export const getStaticProps: GetStaticProps< return await getOpenApiDocsStaticProps({ basePath: PAGE_CONFIG.basePath, productSlug: PAGE_CONFIG.productSlug, + serviceProductSlug: PAGE_CONFIG.serviceProductSlug, statusIndicatorConfig: PAGE_CONFIG.statusIndicatorConfig, navResourceItems: PAGE_CONFIG.navResourceItems, massageSchemaForClient: PAGE_CONFIG.massageSchemaForClient, diff --git a/src/views/open-api-docs-view/components/open-api-overview/index.tsx b/src/views/open-api-docs-view/components/open-api-overview/index.tsx index 2443cf0bdd..b74bc104c3 100644 --- a/src/views/open-api-docs-view/components/open-api-overview/index.tsx +++ b/src/views/open-api-docs-view/components/open-api-overview/index.tsx @@ -3,17 +3,16 @@ * SPDX-License-Identifier: MPL-2.0 */ -// Third-party -import { IconVaultColor16 } from '@hashicorp/flight-icons/svg-react/vault-color-16' // Components import Badge from 'components/badge' import IconTile from 'components/icon-tile' +import ProductIcon from 'components/product-icon' // Local import { Status } from './components/status' // Types import type { StatusIndicatorConfig } from 'views/open-api-docs-view/types' -// Types import type { ReactNode } from 'react' +import type { ProductSlug } from 'types/products' // Styles import s from './open-api-overview.module.css' @@ -31,6 +30,7 @@ export interface OpenApiOverviewProps { id: string } badgeText: string + serviceProductSlug: ProductSlug statusIndicatorConfig?: StatusIndicatorConfig contentSlot?: ReactNode className?: string @@ -39,6 +39,7 @@ export interface OpenApiOverviewProps { export function OpenApiOverview({ heading, badgeText, + serviceProductSlug, statusIndicatorConfig, contentSlot, }: OpenApiOverviewProps) { @@ -46,7 +47,7 @@ export function OpenApiOverview({
- +

diff --git a/src/views/open-api-docs-view/index.tsx b/src/views/open-api-docs-view/index.tsx index 0e70d7793d..eb384e2388 100644 --- a/src/views/open-api-docs-view/index.tsx +++ b/src/views/open-api-docs-view/index.tsx @@ -33,6 +33,7 @@ function OpenApiDocsView({ navResourceItems, breadcrumbLinks, statusIndicatorConfig, + serviceProductSlug, }: OpenApiDocsViewProps) { return ( = async () => { export async function getStaticProps({ context, productSlug, + serviceProductSlug = productSlug, versionData, basePath, statusIndicatorConfig, @@ -76,6 +77,7 @@ export async function getStaticProps({ }: { context: GetStaticPropsContext productSlug: ProductSlug + serviceProductSlug?: ProductSlug versionData: OpenApiDocsVersionData[] basePath: string statusIndicatorConfig?: StatusIndicatorConfig @@ -149,6 +151,7 @@ export async function getStaticProps({ title: schemaData.info.title, }, productData, + serviceProductSlug, topOfPageHeading: { text: schemaData.info.title, id: topOfPageId, diff --git a/src/views/open-api-docs-view/types.ts b/src/views/open-api-docs-view/types.ts index 8c92f1d9a5..2457b74e35 100644 --- a/src/views/open-api-docs-view/types.ts +++ b/src/views/open-api-docs-view/types.ts @@ -171,6 +171,14 @@ export interface OpenApiDocsViewProps { * Some temporary data we'll remove for the production implementation. */ _placeholder: $TSFixMe + + /** + * Product slug to use for the theming of the service itself. + * For example, many product-themed services exist within the broader + * HCP product context. In those cases, the API docs pages would have + * `productData` for `hcp`, and a different `serviceProductSlug` here. + */ + serviceProductSlug: ProductSlug } /** @@ -181,6 +189,15 @@ export interface OpenApiDocsPageConfig { * The product slug is used to fetch product data for the layout. */ productSlug: ProductSlug + + /** + * Optional slug used to theme smaller elements within the service API docs. + * For example, HCP consul will have a `productSlug` of `hcp`, + * but a `serviceProductSlug` of `consul`. If omitted, the `productSlug` + * will be used. + */ + serviceProductSlug?: ProductSlug + /** * The baseUrl is used to generate * breadcrumb links, sidebar nav levels, and version switcher links.