From 7e89d49ffe7cecff6a82d00886c0722ac2a0d5cd Mon Sep 17 00:00:00 2001 From: Jan Peer Stoecklmair Date: Fri, 6 May 2022 14:59:06 +0200 Subject: [PATCH 1/3] feat(theme-classic): allow className as option for type: "search" --- .../src/__tests__/validateThemeConfig.test.ts | 6 ++++++ packages/docusaurus-theme-classic/src/theme-classic.d.ts | 1 + .../src/theme/Navbar/Content/index.tsx | 6 +++--- .../src/theme/Navbar/Search/index.tsx | 8 ++++++-- .../docusaurus-theme-classic/src/validateThemeConfig.ts | 1 + website/docs/api/themes/theme-configuration.md | 1 + 6 files changed, 18 insertions(+), 5 deletions(-) diff --git a/packages/docusaurus-theme-classic/src/__tests__/validateThemeConfig.test.ts b/packages/docusaurus-theme-classic/src/__tests__/validateThemeConfig.test.ts index a4ca7e346018..e95e10bada60 100644 --- a/packages/docusaurus-theme-classic/src/__tests__/validateThemeConfig.test.ts +++ b/packages/docusaurus-theme-classic/src/__tests__/validateThemeConfig.test.ts @@ -242,6 +242,12 @@ describe('themeConfig', () => { position: 'left', label: 'Current version', }, + // Search with className + { + type: 'search', + position: 'right', + className: 'search-bar-wrapper', + }, ], }, }; diff --git a/packages/docusaurus-theme-classic/src/theme-classic.d.ts b/packages/docusaurus-theme-classic/src/theme-classic.d.ts index ef8c33023fd2..e2f671457e22 100644 --- a/packages/docusaurus-theme-classic/src/theme-classic.d.ts +++ b/packages/docusaurus-theme-classic/src/theme-classic.d.ts @@ -775,6 +775,7 @@ declare module '@theme/Navbar/Search' { export interface Props { readonly children: ReactNode; + readonly className?: string; } export default function NavbarSearch(props: Props): JSX.Element; diff --git a/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx b/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx index 9ab92085eca5..038950d3d36d 100644 --- a/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx +++ b/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx @@ -56,7 +56,7 @@ export default function NavbarContent(): JSX.Element { const items = useNavbarItems(); const [leftItems, rightItems] = splitNavbarItems(items); - const autoAddSearchBar = !items.some((item) => item.type === 'search'); + const searchBarItem = items.find((item) => item.type === 'search'); return ( - {autoAddSearchBar && ( - + {searchBarItem && ( + )} diff --git a/packages/docusaurus-theme-classic/src/theme/Navbar/Search/index.tsx b/packages/docusaurus-theme-classic/src/theme/Navbar/Search/index.tsx index 8d3fe1b19d2f..236d237aa082 100644 --- a/packages/docusaurus-theme-classic/src/theme/Navbar/Search/index.tsx +++ b/packages/docusaurus-theme-classic/src/theme/Navbar/Search/index.tsx @@ -6,10 +6,14 @@ */ import React from 'react'; +import clsx from 'clsx'; import type {Props} from '@theme/Navbar/Search'; import styles from './styles.module.css'; -export default function NavbarSearch({children}: Props): JSX.Element { - return
{children}
; +export default function NavbarSearch({ + children, + className, +}: Props): JSX.Element { + return
{children}
; } diff --git a/packages/docusaurus-theme-classic/src/validateThemeConfig.ts b/packages/docusaurus-theme-classic/src/validateThemeConfig.ts index 9bdf1a8d9da8..0ca924712099 100644 --- a/packages/docusaurus-theme-classic/src/validateThemeConfig.ts +++ b/packages/docusaurus-theme-classic/src/validateThemeConfig.ts @@ -202,6 +202,7 @@ const LocaleDropdownNavbarItemSchema = NavbarItemBaseSchema.append({ const SearchItemSchema = Joi.object({ type: Joi.string().equal('search').required(), + className: Joi.string().default(''), }); const NavbarItemSchema = Joi.object({ diff --git a/website/docs/api/themes/theme-configuration.md b/website/docs/api/themes/theme-configuration.md index 02e3c66db8f5..41ee5ae27758 100644 --- a/website/docs/api/themes/theme-configuration.md +++ b/website/docs/api/themes/theme-configuration.md @@ -602,6 +602,7 @@ However, with this special navbar item type, you can change the default location | --- | --- | --- | --- | | `type` | `'search'` | **Required** | Sets the type of this item to a search bar. | | `position` | 'left' \| 'right' | `'left'` | The side of the navbar this item should appear on. | +| `className` | `string` | `''` | Custom CSS class for this navbar item. | From b42d3fc0baf3e60f712b1ebe1230f208b823b27a Mon Sep 17 00:00:00 2001 From: Jan Peer Stoecklmair Date: Fri, 6 May 2022 16:55:09 +0200 Subject: [PATCH 2/3] fixup! feat(theme-classic): allow className as option for type: "search" --- packages/docusaurus-theme-classic/src/theme-classic.d.ts | 1 + .../src/theme/Navbar/Content/index.tsx | 4 ++-- .../src/theme/NavbarItem/SearchNavbarItem.tsx | 7 +++++-- 3 files changed, 8 insertions(+), 4 deletions(-) diff --git a/packages/docusaurus-theme-classic/src/theme-classic.d.ts b/packages/docusaurus-theme-classic/src/theme-classic.d.ts index e2f671457e22..cfeccd35ef3c 100644 --- a/packages/docusaurus-theme-classic/src/theme-classic.d.ts +++ b/packages/docusaurus-theme-classic/src/theme-classic.d.ts @@ -834,6 +834,7 @@ declare module '@theme/NavbarItem/DropdownNavbarItem' { declare module '@theme/NavbarItem/SearchNavbarItem' { export interface Props { readonly mobile?: boolean; + readonly className?: string; } export default function SearchNavbarItem(props: Props): JSX.Element; diff --git a/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx b/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx index 038950d3d36d..cbd137c06437 100644 --- a/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx +++ b/packages/docusaurus-theme-classic/src/theme/Navbar/Content/index.tsx @@ -74,8 +74,8 @@ export default function NavbarContent(): JSX.Element { <> - {searchBarItem && ( - + {!searchBarItem && ( + )} diff --git a/packages/docusaurus-theme-classic/src/theme/NavbarItem/SearchNavbarItem.tsx b/packages/docusaurus-theme-classic/src/theme/NavbarItem/SearchNavbarItem.tsx index dfefa83dc154..b533468cd17a 100644 --- a/packages/docusaurus-theme-classic/src/theme/NavbarItem/SearchNavbarItem.tsx +++ b/packages/docusaurus-theme-classic/src/theme/NavbarItem/SearchNavbarItem.tsx @@ -10,13 +10,16 @@ import type {Props} from '@theme/NavbarItem/SearchNavbarItem'; import SearchBar from '@theme/SearchBar'; import NavbarSearch from '@theme/Navbar/Search'; -export default function SearchNavbarItem({mobile}: Props): JSX.Element | null { +export default function SearchNavbarItem({ + mobile, + className, +}: Props): JSX.Element | null { if (mobile) { return null; } return ( - + ); From 54253da08ff21eadaeeb3d78e80f52da26bc9b66 Mon Sep 17 00:00:00 2001 From: Joshua Chen Date: Wed, 25 May 2022 18:27:56 +0800 Subject: [PATCH 3/3] refactor --- packages/docusaurus-theme-classic/src/validateThemeConfig.ts | 2 +- website/docs/api/themes/theme-configuration.md | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/docusaurus-theme-classic/src/validateThemeConfig.ts b/packages/docusaurus-theme-classic/src/validateThemeConfig.ts index 0ca924712099..340400b9f261 100644 --- a/packages/docusaurus-theme-classic/src/validateThemeConfig.ts +++ b/packages/docusaurus-theme-classic/src/validateThemeConfig.ts @@ -202,7 +202,7 @@ const LocaleDropdownNavbarItemSchema = NavbarItemBaseSchema.append({ const SearchItemSchema = Joi.object({ type: Joi.string().equal('search').required(), - className: Joi.string().default(''), + className: Joi.string(), }); const NavbarItemSchema = Joi.object({ diff --git a/website/docs/api/themes/theme-configuration.md b/website/docs/api/themes/theme-configuration.md index 41ee5ae27758..d1291bbc3cbc 100644 --- a/website/docs/api/themes/theme-configuration.md +++ b/website/docs/api/themes/theme-configuration.md @@ -602,7 +602,7 @@ However, with this special navbar item type, you can change the default location | --- | --- | --- | --- | | `type` | `'search'` | **Required** | Sets the type of this item to a search bar. | | `position` | 'left' \| 'right' | `'left'` | The side of the navbar this item should appear on. | -| `className` | `string` | `''` | Custom CSS class for this navbar item. | +| `className` | `string` | / | Custom CSS class for this navbar item. |