diff --git a/.eslintrc.js b/.eslintrc.js
index 5fd41c1f8a..0b18a8ab9c 100644
--- a/.eslintrc.js
+++ b/.eslintrc.js
@@ -166,7 +166,12 @@ module.exports = {
// selector:
// @ 'ExportDefaultDeclaration > Identifier, ExportNamedDeclaration[source=null] > ExportSpecifier',
// message: 'Export in one statement'
- // }
+ // },
+ ...['path', 'fs-extra', 'webpack', 'lodash'].map((m) => ({
+ selector: `ImportDeclaration[importKind=value]:has(Literal[value=${m}]) > ImportSpecifier[importKind=value]`,
+ message:
+ 'Default-import this, both for readability and interoperability with ESM',
+ })),
],
'no-template-curly-in-string': WARNING,
'no-unused-expressions': [WARNING, {allowTaggedTemplates: true}],
@@ -312,5 +317,11 @@ module.exports = {
'@typescript-eslint/explicit-module-boundary-types': OFF,
},
},
+ {
+ files: ['*.test.ts', '*.test.tsx'],
+ rules: {
+ 'import/no-extraneous-dependencies': OFF,
+ },
+ },
],
};
diff --git a/__tests__/validate-package-json.test.ts b/__tests__/validate-package-json.test.ts
index 2f9031833a..9eab91288f 100644
--- a/__tests__/validate-package-json.test.ts
+++ b/__tests__/validate-package-json.test.ts
@@ -4,7 +4,6 @@
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
-/* eslint-disable import/no-extraneous-dependencies */
import {Globby} from '@docusaurus/utils';
import fs from 'fs-extra';
diff --git a/packages/docusaurus-logger/src/__tests__/index.test.ts b/packages/docusaurus-logger/src/__tests__/index.test.ts
index 5ae55907b7..e78571a0f2 100644
--- a/packages/docusaurus-logger/src/__tests__/index.test.ts
+++ b/packages/docusaurus-logger/src/__tests__/index.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import logger from '../index';
describe('formatters', () => {
diff --git a/packages/docusaurus-mdx-loader/src/remark/transformImage/__tests__/index.test.ts b/packages/docusaurus-mdx-loader/src/remark/transformImage/__tests__/index.test.ts
index dc1ed9e171..9ab5161441 100644
--- a/packages/docusaurus-mdx-loader/src/remark/transformImage/__tests__/index.test.ts
+++ b/packages/docusaurus-mdx-loader/src/remark/transformImage/__tests__/index.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import remark from 'remark';
import mdx from 'remark-mdx';
diff --git a/packages/docusaurus-mdx-loader/src/remark/unwrapMdxCodeBlocks/__tests__/index.test.ts b/packages/docusaurus-mdx-loader/src/remark/unwrapMdxCodeBlocks/__tests__/index.test.ts
index fa49602667..d18b4634e0 100644
--- a/packages/docusaurus-mdx-loader/src/remark/unwrapMdxCodeBlocks/__tests__/index.test.ts
+++ b/packages/docusaurus-mdx-loader/src/remark/unwrapMdxCodeBlocks/__tests__/index.test.ts
@@ -5,22 +5,20 @@
* LICENSE file in the root directory of this source tree.
*/
-import {join} from 'path';
+import path from 'path';
import remark from 'remark';
import mdx from 'remark-mdx';
import vfile from 'to-vfile';
import plugin from '..';
-const processFixture = async (name) => {
- const path = join(__dirname, '__fixtures__', name);
- const file = await vfile.read(path);
+const processFixture = async (name: string) => {
+ const file = await vfile.read(path.join(__dirname, '__fixtures__', name));
const result = await remark().use(mdx).use(plugin).process(file);
return result.toString();
};
-const processFixtureAST = async (name) => {
- const path = join(__dirname, '__fixtures__', name);
- const file = await vfile.read(path);
+const processFixtureAST = async (name: string) => {
+ const file = await vfile.read(path.join(__dirname, '__fixtures__', name));
return remark().use(mdx).use(plugin).parse(file);
};
diff --git a/packages/docusaurus-migrate/src/__tests__/migration.test.ts b/packages/docusaurus-migrate/src/__tests__/migration.test.ts
index d3b6bd6315..8129bab620 100644
--- a/packages/docusaurus-migrate/src/__tests__/migration.test.ts
+++ b/packages/docusaurus-migrate/src/__tests__/migration.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {migrateDocusaurusProject} from '../index';
import path from 'path';
import fs from 'fs-extra';
diff --git a/packages/docusaurus-plugin-content-blog/src/__tests__/feed.test.ts b/packages/docusaurus-plugin-content-blog/src/__tests__/feed.test.ts
index bd77b29115..6ac05193ce 100644
--- a/packages/docusaurus-plugin-content-blog/src/__tests__/feed.test.ts
+++ b/packages/docusaurus-plugin-content-blog/src/__tests__/feed.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import fs from 'fs-extra';
import {createBlogFeedFiles} from '../feed';
diff --git a/packages/docusaurus-plugin-content-blog/src/__tests__/index.test.ts b/packages/docusaurus-plugin-content-blog/src/__tests__/index.test.ts
index b3fad925a6..2f76680913 100644
--- a/packages/docusaurus-plugin-content-blog/src/__tests__/index.test.ts
+++ b/packages/docusaurus-plugin-content-blog/src/__tests__/index.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import pluginContentBlog from '../index';
import type {DocusaurusConfig, LoadContext, I18n} from '@docusaurus/types';
diff --git a/packages/docusaurus-plugin-content-blog/src/__tests__/linkify.test.ts b/packages/docusaurus-plugin-content-blog/src/__tests__/linkify.test.ts
index d745399331..bdfffa7ffb 100644
--- a/packages/docusaurus-plugin-content-blog/src/__tests__/linkify.test.ts
+++ b/packages/docusaurus-plugin-content-blog/src/__tests__/linkify.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import fs from 'fs-extra';
import path from 'path';
import {linkify, type LinkifyParams, getSourceToPermalink} from '../blogUtils';
diff --git a/packages/docusaurus-plugin-content-docs/src/__tests__/cli.test.ts b/packages/docusaurus-plugin-content-docs/src/__tests__/cli.test.ts
index 25f438bbe1..c9235e35cf 100644
--- a/packages/docusaurus-plugin-content-docs/src/__tests__/cli.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/__tests__/cli.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import {cliDocsVersionCommand} from '../cli';
import type {
diff --git a/packages/docusaurus-plugin-content-docs/src/__tests__/docs.test.ts b/packages/docusaurus-plugin-content-docs/src/__tests__/docs.test.ts
index 0c1d36d50a..5348c845c6 100644
--- a/packages/docusaurus-plugin-content-docs/src/__tests__/docs.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/__tests__/docs.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import {loadContext} from '@docusaurus/core/src/server/index';
import {
diff --git a/packages/docusaurus-plugin-content-docs/src/__tests__/index.test.ts b/packages/docusaurus-plugin-content-docs/src/__tests__/index.test.ts
index bcbaa522a8..885916099c 100644
--- a/packages/docusaurus-plugin-content-docs/src/__tests__/index.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/__tests__/index.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import {isMatch} from 'picomatch';
import commander from 'commander';
@@ -29,7 +30,7 @@ import type {
} from '../sidebars/types';
import {toSidebarsProp} from '../props';
-import {validate} from 'webpack';
+import webpack from 'webpack';
import {DefaultSidebarItemsGenerator} from '../sidebars/generator';
import {DisabledSidebars} from '../sidebars';
@@ -311,7 +312,7 @@ describe('simple website', () => {
undefined,
content,
);
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
diff --git a/packages/docusaurus-plugin-content-docs/src/__tests__/lastUpdate.test.ts b/packages/docusaurus-plugin-content-docs/src/__tests__/lastUpdate.test.ts
index 01356ccdcb..2ec2a16e4c 100644
--- a/packages/docusaurus-plugin-content-docs/src/__tests__/lastUpdate.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/__tests__/lastUpdate.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import fs from 'fs-extra';
import path from 'path';
import shell from 'shelljs';
diff --git a/packages/docusaurus-plugin-content-docs/src/__tests__/versions.test.ts b/packages/docusaurus-plugin-content-docs/src/__tests__/versions.test.ts
index 3ac367db68..aed0e9ec25 100644
--- a/packages/docusaurus-plugin-content-docs/src/__tests__/versions.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/__tests__/versions.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import {
getVersionsFilePath,
diff --git a/packages/docusaurus-plugin-content-docs/src/markdown/__tests__/linkify.test.ts b/packages/docusaurus-plugin-content-docs/src/markdown/__tests__/linkify.test.ts
index 79c2fc91f5..56ed2072fa 100644
--- a/packages/docusaurus-plugin-content-docs/src/markdown/__tests__/linkify.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/markdown/__tests__/linkify.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import fs from 'fs-extra';
import path from 'path';
import {linkify} from '../linkify';
diff --git a/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/generator.test.ts b/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/generator.test.ts
index 73c2357cd9..5491b18e67 100644
--- a/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/generator.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/generator.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {DefaultSidebarItemsGenerator} from '../generator';
import type {SidebarItemsGenerator} from '../types';
import {DefaultNumberPrefixParser} from '../../numberPrefix';
diff --git a/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/processor.test.ts b/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/processor.test.ts
index 68d65a2d3a..f5021fd8d9 100644
--- a/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/processor.test.ts
+++ b/packages/docusaurus-plugin-content-docs/src/sidebars/__tests__/processor.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {processSidebars} from '../processor';
import type {
SidebarItem,
diff --git a/packages/docusaurus-theme-classic/src/theme/MDXComponents/index.tsx b/packages/docusaurus-theme-classic/src/theme/MDXComponents/index.tsx
index 2cdcf65db4..8f9605c2a5 100644
--- a/packages/docusaurus-theme-classic/src/theme/MDXComponents/index.tsx
+++ b/packages/docusaurus-theme-classic/src/theme/MDXComponents/index.tsx
@@ -6,8 +6,8 @@
*/
import React, {
- type ComponentProps,
isValidElement,
+ type ComponentProps,
type ReactElement,
} from 'react';
import Head from '@docusaurus/Head';
@@ -52,7 +52,7 @@ const MDXComponents: MDXComponentsObject = {
const shouldBeInline = React.Children.toArray(props.children).every(
(el) =>
(typeof el === 'string' && !el.includes('\n')) ||
- (React.isValidElement(el) && inlineElements.includes(el.props.mdxType)),
+ (isValidElement(el) && inlineElements.includes(el.props.mdxType)),
);
return shouldBeInline ? : ;
diff --git a/packages/docusaurus-theme-classic/src/theme/Tabs/index.tsx b/packages/docusaurus-theme-classic/src/theme/Tabs/index.tsx
index 6036ffad40..efaae4c055 100644
--- a/packages/docusaurus-theme-classic/src/theme/Tabs/index.tsx
+++ b/packages/docusaurus-theme-classic/src/theme/Tabs/index.tsx
@@ -8,7 +8,6 @@
import React, {
useState,
cloneElement,
- Children,
isValidElement,
type ReactElement,
} from 'react';
@@ -40,7 +39,7 @@ function TabsComponent(props: Props): JSX.Element {
groupId,
className,
} = props;
- const children = Children.map(props.children, (child) => {
+ const children = React.Children.map(props.children, (child) => {
if (isValidElement(child) && isTabItem(child)) {
return child;
}
diff --git a/packages/docusaurus-theme-common/src/components/Collapsible/index.tsx b/packages/docusaurus-theme-common/src/components/Collapsible/index.tsx
index f1af0aa293..a608d03772 100644
--- a/packages/docusaurus-theme-common/src/components/Collapsible/index.tsx
+++ b/packages/docusaurus-theme-common/src/components/Collapsible/index.tsx
@@ -11,11 +11,11 @@ import React, {
useEffect,
useRef,
useCallback,
+ useLayoutEffect,
type RefObject,
type Dispatch,
type SetStateAction,
type ReactNode,
- useLayoutEffect,
} from 'react';
const DefaultAnimationEasing = 'ease-in-out';
diff --git a/packages/docusaurus-theme-common/src/components/Details/index.tsx b/packages/docusaurus-theme-common/src/components/Details/index.tsx
index 541568432c..d5b1b77f5a 100644
--- a/packages/docusaurus-theme-common/src/components/Details/index.tsx
+++ b/packages/docusaurus-theme-common/src/components/Details/index.tsx
@@ -6,10 +6,10 @@
*/
import React, {
- type ComponentProps,
- type ReactElement,
useRef,
useState,
+ type ComponentProps,
+ type ReactElement,
} from 'react';
import useIsBrowser from '@docusaurus/useIsBrowser';
import clsx from 'clsx';
diff --git a/packages/docusaurus-theme-common/src/utils/announcementBarUtils.tsx b/packages/docusaurus-theme-common/src/utils/announcementBarUtils.tsx
index 0983cca167..93eb7cbeff 100644
--- a/packages/docusaurus-theme-common/src/utils/announcementBarUtils.tsx
+++ b/packages/docusaurus-theme-common/src/utils/announcementBarUtils.tsx
@@ -10,9 +10,8 @@ import React, {
useEffect,
useCallback,
useMemo,
- type ReactNode,
useContext,
- createContext,
+ type ReactNode,
} from 'react';
import useIsBrowser from '@docusaurus/useIsBrowser';
import {createStorageSlot} from './storageUtils';
@@ -96,7 +95,9 @@ const useAnnouncementBarContextValue = (): AnnouncementBarAPI => {
);
};
-const AnnouncementBarContext = createContext(null);
+const AnnouncementBarContext = React.createContext(
+ null,
+);
export function AnnouncementBarProvider({
children,
diff --git a/packages/docusaurus-theme-common/src/utils/colorModeUtils.tsx b/packages/docusaurus-theme-common/src/utils/colorModeUtils.tsx
index c955206c1a..d662fb4caf 100644
--- a/packages/docusaurus-theme-common/src/utils/colorModeUtils.tsx
+++ b/packages/docusaurus-theme-common/src/utils/colorModeUtils.tsx
@@ -11,6 +11,7 @@ import React, {
useEffect,
useContext,
useMemo,
+ useRef,
type ReactNode,
} from 'react';
import {ReactContextError} from './reactUtils';
@@ -96,7 +97,7 @@ function useColorModeContextValue(): ColorModeContextValue {
// be reset to dark when exiting print mode, disregarding user settings. When
// the listener fires only because of a print/screen switch, we don't change
// color mode. See https://github.com/facebook/docusaurus/pull/6490
- const previousMediaIsPrint = React.useRef(false);
+ const previousMediaIsPrint = useRef(false);
useEffect(() => {
if (disableSwitch && !respectPrefersColorScheme) {
diff --git a/packages/docusaurus-theme-common/src/utils/docsPreferredVersion/DocsPreferredVersionProvider.tsx b/packages/docusaurus-theme-common/src/utils/docsPreferredVersion/DocsPreferredVersionProvider.tsx
index fb9c534ef4..49c74aa7b0 100644
--- a/packages/docusaurus-theme-common/src/utils/docsPreferredVersion/DocsPreferredVersionProvider.tsx
+++ b/packages/docusaurus-theme-common/src/utils/docsPreferredVersion/DocsPreferredVersionProvider.tsx
@@ -6,12 +6,11 @@
*/
import React, {
- createContext,
- type ReactNode,
useContext,
useEffect,
useMemo,
useState,
+ type ReactNode,
} from 'react';
import {useThemeConfig, type DocsVersionPersistence} from '../useThemeConfig';
import {isDocsPluginEnabled} from '../docsUtils';
@@ -131,7 +130,9 @@ function useContextValue() {
type DocsPreferredVersionContextValue = ReturnType;
-const Context = createContext(null);
+const Context = React.createContext(
+ null,
+);
export function DocsPreferredVersionContextProvider({
children,
diff --git a/packages/docusaurus-theme-common/src/utils/docsUtils.tsx b/packages/docusaurus-theme-common/src/utils/docsUtils.tsx
index be21b456b3..f6863ce2de 100644
--- a/packages/docusaurus-theme-common/src/utils/docsUtils.tsx
+++ b/packages/docusaurus-theme-common/src/utils/docsUtils.tsx
@@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
-import React, {createContext, type ReactNode, useContext} from 'react';
+import React, {type ReactNode, useContext} from 'react';
import {
useActivePlugin,
useAllDocsData,
@@ -29,7 +29,7 @@ export const isDocsPluginEnabled: boolean = !!useAllDocsData;
// Inspired by https://github.com/jamiebuilds/unstated-next/blob/master/src/unstated-next.tsx
const EmptyContextValue: unique symbol = Symbol('EmptyContext');
-const DocsVersionContext = createContext<
+const DocsVersionContext = React.createContext<
PropVersionMetadata | typeof EmptyContextValue
>(EmptyContextValue);
@@ -69,7 +69,7 @@ export function useDocById(id: string | undefined): PropVersionDoc | undefined {
return doc;
}
-const DocsSidebarContext = createContext<
+const DocsSidebarContext = React.createContext<
PropSidebar | null | typeof EmptyContextValue
>(EmptyContextValue);
diff --git a/packages/docusaurus-theme-common/src/utils/mobileSecondaryMenu.tsx b/packages/docusaurus-theme-common/src/utils/mobileSecondaryMenu.tsx
index 94cccc2aed..ed898a9033 100644
--- a/packages/docusaurus-theme-common/src/utils/mobileSecondaryMenu.tsx
+++ b/packages/docusaurus-theme-common/src/utils/mobileSecondaryMenu.tsx
@@ -7,12 +7,11 @@
import React, {
useState,
- type ReactNode,
useContext,
- createContext,
useEffect,
- type ComponentType,
useMemo,
+ type ReactNode,
+ type ComponentType,
} from 'react';
import {ReactContextError} from './reactUtils';
@@ -46,7 +45,7 @@ function useContextValue() {
type ContextValue = ReturnType;
-const Context = createContext(null);
+const Context = React.createContext(null);
export function MobileSecondaryMenuProvider({
children,
diff --git a/packages/docusaurus-theme-common/src/utils/scrollUtils.tsx b/packages/docusaurus-theme-common/src/utils/scrollUtils.tsx
index 7c4fa30033..74e372a1d9 100644
--- a/packages/docusaurus-theme-common/src/utils/scrollUtils.tsx
+++ b/packages/docusaurus-theme-common/src/utils/scrollUtils.tsx
@@ -6,14 +6,13 @@
*/
import React, {
- createContext,
- type ReactNode,
useCallback,
useContext,
useEffect,
useLayoutEffect,
useMemo,
useRef,
+ type ReactNode,
} from 'react';
import {useDynamicCallback, ReactContextError} from './reactUtils';
import ExecutionEnvironment from '@docusaurus/ExecutionEnvironment';
@@ -57,7 +56,7 @@ function useScrollControllerContextValue(): ScrollController {
);
}
-const ScrollMonitorContext = createContext(
+const ScrollMonitorContext = React.createContext(
undefined,
);
diff --git a/packages/docusaurus-theme-common/src/utils/tabGroupChoiceUtils.tsx b/packages/docusaurus-theme-common/src/utils/tabGroupChoiceUtils.tsx
index 4348a74a98..02ad080f8c 100644
--- a/packages/docusaurus-theme-common/src/utils/tabGroupChoiceUtils.tsx
+++ b/packages/docusaurus-theme-common/src/utils/tabGroupChoiceUtils.tsx
@@ -9,7 +9,6 @@ import React, {
useState,
useCallback,
useEffect,
- createContext,
useMemo,
useContext,
type ReactNode,
@@ -24,7 +23,7 @@ type TabGroupChoiceContextValue = {
readonly setTabGroupChoices: (groupId: string, newChoice: string) => void;
};
-const TabGroupChoiceContext = createContext<
+const TabGroupChoiceContext = React.createContext<
TabGroupChoiceContextValue | undefined
>(undefined);
diff --git a/packages/docusaurus-theme-translations/__tests__/update.test.ts b/packages/docusaurus-theme-translations/__tests__/update.test.ts
index b76e11d33a..23778fb854 100644
--- a/packages/docusaurus-theme-translations/__tests__/update.test.ts
+++ b/packages/docusaurus-theme-translations/__tests__/update.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {extractThemeCodeMessages} from '../update';
import path from 'path';
import fs from 'fs-extra';
diff --git a/packages/docusaurus-utils-validation/src/__tests__/validationUtils.test.ts b/packages/docusaurus-utils-validation/src/__tests__/validationUtils.test.ts
index 8da4c3d1ed..f52ec99b0b 100644
--- a/packages/docusaurus-utils-validation/src/__tests__/validationUtils.test.ts
+++ b/packages/docusaurus-utils-validation/src/__tests__/validationUtils.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import Joi from '../Joi';
import {JoiFrontMatter} from '../JoiFrontMatter';
import {validateFrontMatter} from '../validationUtils';
@@ -21,7 +22,9 @@ describe('validateFrontMatter', () => {
});
test('should reject bad values', () => {
- const consoleError = jest.spyOn(console, 'error').mockImplementation();
+ const consoleError = jest
+ .spyOn(console, 'error')
+ .mockImplementation(() => {});
const schema = Joi.object<{test: string}>({
test: Joi.string(),
});
diff --git a/packages/docusaurus-utils/src/__tests__/emitUtils.test.ts b/packages/docusaurus-utils/src/__tests__/emitUtils.test.ts
index da0273cc7a..8f10d21b1a 100644
--- a/packages/docusaurus-utils/src/__tests__/emitUtils.test.ts
+++ b/packages/docusaurus-utils/src/__tests__/emitUtils.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {genChunkName, readOutputHTMLFile, generate} from '../emitUtils';
import path from 'path';
import fs from 'fs-extra';
diff --git a/packages/docusaurus-utils/src/__tests__/jsUtils.test.ts b/packages/docusaurus-utils/src/__tests__/jsUtils.test.ts
index d2b9aea231..acba208ffb 100644
--- a/packages/docusaurus-utils/src/__tests__/jsUtils.test.ts
+++ b/packages/docusaurus-utils/src/__tests__/jsUtils.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {
removeSuffix,
removePrefix,
diff --git a/packages/docusaurus/src/client/LinksCollector.tsx b/packages/docusaurus/src/client/LinksCollector.tsx
index 70009f093c..33580a6e82 100644
--- a/packages/docusaurus/src/client/LinksCollector.tsx
+++ b/packages/docusaurus/src/client/LinksCollector.tsx
@@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
-import React, {type ReactNode, useContext, createContext} from 'react';
+import React, {type ReactNode, useContext} from 'react';
type LinksCollector = {
collectLink: (link: string) => void;
@@ -26,7 +26,7 @@ export const createStatefulLinksCollector = (): StatefulLinksCollector => {
};
};
-const Context = createContext({
+const Context = React.createContext({
collectLink: () => {
// noop by default for client
// we only use the broken links checker server-side
diff --git a/packages/docusaurus/src/client/__tests__/normalizeLocation.test.ts b/packages/docusaurus/src/client/__tests__/normalizeLocation.test.ts
index bb6e927389..478c1f146a 100644
--- a/packages/docusaurus/src/client/__tests__/normalizeLocation.test.ts
+++ b/packages/docusaurus/src/client/__tests__/normalizeLocation.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import normalizeLocation from '../normalizeLocation';
describe('normalizeLocation', () => {
diff --git a/packages/docusaurus/src/client/clientEntry.tsx b/packages/docusaurus/src/client/clientEntry.tsx
index db766906b9..bb5ecdf3e9 100644
--- a/packages/docusaurus/src/client/clientEntry.tsx
+++ b/packages/docusaurus/src/client/clientEntry.tsx
@@ -6,7 +6,7 @@
*/
import React from 'react';
-import {hydrate, render} from 'react-dom';
+import ReactDOM from 'react-dom';
import {BrowserRouter} from 'react-router-dom';
import {HelmetProvider} from 'react-helmet-async';
@@ -30,7 +30,8 @@ if (ExecutionEnvironment.canUseDOM) {
// first-load experience.
// For development, there is no existing markup so we had to render it.
// We also preload async component to avoid first-load loading screen.
- const renderMethod = process.env.NODE_ENV === 'production' ? hydrate : render;
+ const renderMethod =
+ process.env.NODE_ENV === 'production' ? ReactDOM.hydrate : ReactDOM.render;
preload(routes, window.location.pathname).then(() => {
renderMethod(
diff --git a/packages/docusaurus/src/client/exports/Interpolate.tsx b/packages/docusaurus/src/client/exports/Interpolate.tsx
index 323369b3ba..8b894f7032 100644
--- a/packages/docusaurus/src/client/exports/Interpolate.tsx
+++ b/packages/docusaurus/src/client/exports/Interpolate.tsx
@@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
-import React, {type ReactNode} from 'react';
+import React, {isValidElement, type ReactNode} from 'react';
import type {
InterpolateProps,
InterpolateValues,
@@ -49,7 +49,7 @@ export function interpolate(
const value = values?.[key];
if (typeof value !== 'undefined') {
- const element = React.isValidElement(value)
+ const element = isValidElement(value)
? value
: // For non-React elements: basic primitive->string conversion
String(value);
diff --git a/packages/docusaurus/src/client/exports/__tests__/BrowserOnly.test.tsx b/packages/docusaurus/src/client/exports/__tests__/BrowserOnly.test.tsx
index 89161383b5..c1264c2216 100644
--- a/packages/docusaurus/src/client/exports/__tests__/BrowserOnly.test.tsx
+++ b/packages/docusaurus/src/client/exports/__tests__/BrowserOnly.test.tsx
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import React from 'react';
import renderer from 'react-test-renderer';
import BrowserOnly from '../BrowserOnly';
diff --git a/packages/docusaurus/src/client/exports/__tests__/useBaseUrl.test.ts b/packages/docusaurus/src/client/exports/__tests__/useBaseUrl.test.ts
index 2aec76be8a..e6c8dbc612 100644
--- a/packages/docusaurus/src/client/exports/__tests__/useBaseUrl.test.ts
+++ b/packages/docusaurus/src/client/exports/__tests__/useBaseUrl.test.ts
@@ -5,12 +5,13 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import useBaseUrl, {useBaseUrlUtils} from '../useBaseUrl';
import useDocusaurusContext from '../useDocusaurusContext';
-jest.mock('../useDocusaurusContext', () => jest.fn(), {virtual: true});
+jest.mock('../useDocusaurusContext');
-const mockedContext = useDocusaurusContext;
+const mockedContext = useDocusaurusContext as jest.Mock;
const forcePrepend = {forcePrependBaseUrl: true};
diff --git a/packages/docusaurus/src/commands/swizzle/__tests__/index.test.ts b/packages/docusaurus/src/commands/swizzle/__tests__/index.test.ts
index f1bf3de6c5..37504725f2 100644
--- a/packages/docusaurus/src/commands/swizzle/__tests__/index.test.ts
+++ b/packages/docusaurus/src/commands/swizzle/__tests__/index.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import fs from 'fs-extra';
import {ThemePath, createTempSiteDir, Components} from './testUtils';
diff --git a/packages/docusaurus/src/deps.d.ts b/packages/docusaurus/src/deps.d.ts
index 8d4bb2d8ad..fc3a7287ff 100644
--- a/packages/docusaurus/src/deps.d.ts
+++ b/packages/docusaurus/src/deps.d.ts
@@ -62,7 +62,7 @@ declare module '@slorber/static-site-generator-webpack-plugin' {
}
declare module 'webpack/lib/HotModuleReplacementPlugin' {
- import {HotModuleReplacementPlugin} from 'webpack';
+ import type {HotModuleReplacementPlugin} from 'webpack';
export default HotModuleReplacementPlugin;
}
diff --git a/packages/docusaurus/src/server/__tests__/brokenLinks.test.ts b/packages/docusaurus/src/server/__tests__/brokenLinks.test.ts
index 45ad7cb3f8..8e923a2481 100644
--- a/packages/docusaurus/src/server/__tests__/brokenLinks.test.ts
+++ b/packages/docusaurus/src/server/__tests__/brokenLinks.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import _ from 'lodash';
import {handleBrokenLinks} from '../brokenLinks';
@@ -157,7 +158,7 @@ describe('handleBrokenLinks', () => {
test('no-op for ignore', async () => {
// In any case, _.mapValues will always be called, unless handleBrokenLinks
// has already bailed
- const lodashMock = jest.spyOn(_, 'mapValues').mockImplementation();
+ const lodashMock = jest.spyOn(_, 'mapValues');
await handleBrokenLinks({
allCollectedLinks,
onBrokenLinks: 'ignore',
diff --git a/packages/docusaurus/src/server/__tests__/duplicateRoutes.test.ts b/packages/docusaurus/src/server/__tests__/duplicateRoutes.test.ts
index 8da06f2da2..61308eef02 100644
--- a/packages/docusaurus/src/server/__tests__/duplicateRoutes.test.ts
+++ b/packages/docusaurus/src/server/__tests__/duplicateRoutes.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {handleDuplicateRoutes} from '../duplicateRoutes';
import type {RouteConfig} from '@docusaurus/types';
diff --git a/packages/docusaurus/src/server/__tests__/i18n.test.ts b/packages/docusaurus/src/server/__tests__/i18n.test.ts
index a78e5fbf3f..d78679ff70 100644
--- a/packages/docusaurus/src/server/__tests__/i18n.test.ts
+++ b/packages/docusaurus/src/server/__tests__/i18n.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {loadI18n, localizePath, getDefaultLocaleConfig} from '../i18n';
import {DEFAULT_I18N_CONFIG} from '../configValidation';
import path from 'path';
@@ -79,7 +80,7 @@ describe('defaultLocaleConfig', () => {
});
describe('loadI18n', () => {
- const consoleSpy = jest.spyOn(console, 'warn').mockImplementation();
+ const consoleSpy = jest.spyOn(console, 'warn').mockImplementation(() => {});
beforeEach(() => {
consoleSpy.mockClear();
});
diff --git a/packages/docusaurus/src/server/themes/alias.ts b/packages/docusaurus/src/server/themes/alias.ts
index c3f7a5952e..0a63d80a83 100644
--- a/packages/docusaurus/src/server/themes/alias.ts
+++ b/packages/docusaurus/src/server/themes/alias.ts
@@ -20,6 +20,7 @@ export function sortAliases(aliases: ThemeAliases): ThemeAliases {
const entries = _.sortBy(Object.entries(aliases), ([alias]) => alias);
// @theme/NavbarItem should be after @theme/NavbarItem/LocaleDropdown
entries.sort(([alias1], [alias2]) =>
+ // eslint-disable-next-line no-nested-ternary
alias1.includes(`${alias2}/`) ? -1 : alias2.includes(`${alias1}/`) ? 1 : 0,
);
return Object.fromEntries(entries);
diff --git a/packages/docusaurus/src/server/translations/__tests__/translations.test.ts b/packages/docusaurus/src/server/translations/__tests__/translations.test.ts
index 6c3273e45f..305c5a8aeb 100644
--- a/packages/docusaurus/src/server/translations/__tests__/translations.test.ts
+++ b/packages/docusaurus/src/server/translations/__tests__/translations.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import {
ensureTranslationFileContent,
writeTranslationFileContent,
@@ -560,7 +561,7 @@ describe('getPluginsDefaultCodeTranslationMessages', () => {
});
describe('applyDefaultCodeTranslations', () => {
- const consoleSpy = jest.spyOn(console, 'warn').mockImplementation();
+ const consoleSpy = jest.spyOn(console, 'warn').mockImplementation(() => {});
beforeEach(() => {
consoleSpy.mockClear();
});
diff --git a/packages/docusaurus/src/server/translations/__tests__/translationsExtractor.test.ts b/packages/docusaurus/src/server/translations/__tests__/translationsExtractor.test.ts
index ae482052e3..dd333ebde3 100644
--- a/packages/docusaurus/src/server/translations/__tests__/translationsExtractor.test.ts
+++ b/packages/docusaurus/src/server/translations/__tests__/translationsExtractor.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import fs from 'fs-extra';
import tmp from 'tmp-promise';
import {
diff --git a/packages/docusaurus/src/webpack/__tests__/base.test.ts b/packages/docusaurus/src/webpack/__tests__/base.test.ts
index 8e2ccb9703..397781eb84 100644
--- a/packages/docusaurus/src/webpack/__tests__/base.test.ts
+++ b/packages/docusaurus/src/webpack/__tests__/base.test.ts
@@ -5,6 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
+import {jest} from '@jest/globals';
import path from 'path';
import {
diff --git a/packages/docusaurus/src/webpack/__tests__/client.test.ts b/packages/docusaurus/src/webpack/__tests__/client.test.ts
index 17f7815a2e..e5e526a915 100644
--- a/packages/docusaurus/src/webpack/__tests__/client.test.ts
+++ b/packages/docusaurus/src/webpack/__tests__/client.test.ts
@@ -5,7 +5,8 @@
* LICENSE file in the root directory of this source tree.
*/
-import {validate} from 'webpack';
+import {jest} from '@jest/globals';
+import webpack from 'webpack';
import createClientConfig from '../client';
import loadSetup from '../../server/__tests__/testUtils';
@@ -15,7 +16,7 @@ describe('webpack dev config', () => {
console.log = jest.fn();
const props = await loadSetup('simple');
const config = await createClientConfig(props);
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
@@ -23,7 +24,7 @@ describe('webpack dev config', () => {
console.log = jest.fn();
const props = await loadSetup('custom');
const config = await createClientConfig(props);
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
});
diff --git a/packages/docusaurus/src/webpack/__tests__/server.test.ts b/packages/docusaurus/src/webpack/__tests__/server.test.ts
index 9c612f492c..6be134ac5f 100644
--- a/packages/docusaurus/src/webpack/__tests__/server.test.ts
+++ b/packages/docusaurus/src/webpack/__tests__/server.test.ts
@@ -5,7 +5,8 @@
* LICENSE file in the root directory of this source tree.
*/
-import {validate} from 'webpack';
+import {jest} from '@jest/globals';
+import webpack from 'webpack';
import createServerConfig from '../server';
import loadSetup from '../../server/__tests__/testUtils';
@@ -15,7 +16,7 @@ describe('webpack production config', () => {
console.log = jest.fn();
const props = await loadSetup('simple');
const config = await createServerConfig({props});
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
@@ -23,7 +24,7 @@ describe('webpack production config', () => {
console.log = jest.fn();
const props = await loadSetup('custom');
const config = await createServerConfig({props});
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
});
diff --git a/packages/docusaurus/src/webpack/__tests__/utils.test.ts b/packages/docusaurus/src/webpack/__tests__/utils.test.ts
index e6fdb6d329..1dc3fb7fb2 100644
--- a/packages/docusaurus/src/webpack/__tests__/utils.test.ts
+++ b/packages/docusaurus/src/webpack/__tests__/utils.test.ts
@@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
-import {validate, type Configuration, type RuleSetRule} from 'webpack';
+import webpack, {type Configuration, type RuleSetRule} from 'webpack';
import path from 'path';
import {
@@ -86,7 +86,7 @@ describe('extending generated webpack config', () => {
filename: 'new.bundle.js',
},
});
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
@@ -116,7 +116,7 @@ describe('extending generated webpack config', () => {
filename: 'new.bundle.js',
},
});
- const errors = validate(config);
+ const errors = webpack.validate(config);
expect(errors).toBeUndefined();
});
diff --git a/packages/docusaurus/src/webpack/plugins/ChunkAssetPlugin.ts b/packages/docusaurus/src/webpack/plugins/ChunkAssetPlugin.ts
index ea2f4fd349..b1eaf0f527 100644
--- a/packages/docusaurus/src/webpack/plugins/ChunkAssetPlugin.ts
+++ b/packages/docusaurus/src/webpack/plugins/ChunkAssetPlugin.ts
@@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
-import {Template, type Compiler} from 'webpack';
+import webpack, {type Compiler} from 'webpack';
const pluginName = 'chunk-asset-plugin';
@@ -48,7 +48,7 @@ export default class ChunkAssetPlugin {
chunkNameToId,
)}[chunkId]||chunkId; return __webpack_require__.p + __webpack_require__.u(chunkId); };`,
);
- return Template.asString(buf);
+ return webpack.Template.asString(buf);
});
});
}
diff --git a/packages/lqip-loader/src/__tests__/lqip.test.ts b/packages/lqip-loader/src/__tests__/lqip.test.ts
index 22f7f1ce56..180be8b0f0 100644
--- a/packages/lqip-loader/src/__tests__/lqip.test.ts
+++ b/packages/lqip-loader/src/__tests__/lqip.test.ts
@@ -13,7 +13,9 @@ describe('lqip library', () => {
const invalidPath = path.join(__dirname, '__fixtures__', 'docusaurus.svg');
it('should reject unknown or unsupported file format', async () => {
- await expect(lqip.base64(invalidPath)).rejects.toBeTruthy();
+ await expect(lqip.base64(invalidPath)).rejects.toThrow(
+ /Error: Input file is missing or uses unsupported image format, lqip v.*/,
+ );
});
it('should generate a valid base64', async () => {
diff --git a/packages/lqip-loader/src/__tests__/utils.test.ts b/packages/lqip-loader/src/__tests__/utils.test.ts
index 960cfaa984..f0bd6d021f 100644
--- a/packages/lqip-loader/src/__tests__/utils.test.ts
+++ b/packages/lqip-loader/src/__tests__/utils.test.ts
@@ -11,36 +11,35 @@ import type {Palette} from 'node-vibrant/lib/color';
import {toPalette, toBase64} from '../utils';
-describe('lqip-loader', () => {
- describe('toBase64', () => {
- test('should return a properly formatted Base64 image string', () => {
- const expected = '';
- const mockedMimeType = 'image/jpeg';
- const mockedBase64Data = Buffer.from('hello world');
- expect(toBase64(mockedMimeType, mockedBase64Data)).toEqual(expected);
- });
- });
-
- describe('toPalette', () => {
- let correctTestSwatch: Palette = {};
- let testSwatchWithNull: Palette & {Vibrant?: null} = {};
-
- beforeAll(() => {
- const imgPath = path.join(__dirname, '__fixtures__', 'endi.jpg');
- const vibrant = new Vibrant(imgPath, {});
-
- return vibrant.getPalette().then((palette) => {
- correctTestSwatch = {...palette};
- testSwatchWithNull = {...palette, Vibrant: null};
- });
- });
-
- it('should return 6 hex colours sorted by popularity', () => {
- expect(toPalette(correctTestSwatch)).toHaveLength(6);
- });
-
- it('should return 5 hex colours with no errors if a palette was incomplete', () => {
- expect(toPalette(testSwatchWithNull)).toHaveLength(5);
- });
+describe('toBase64', () => {
+ test('should return a properly formatted Base64 image string', () => {
+ const mockedMimeType = 'image/jpeg';
+ const mockedBase64Data = Buffer.from('hello world');
+ expect(toBase64(mockedMimeType, mockedBase64Data)).toEqual(
+ '',
+ );
+ });
+});
+
+describe('toPalette', () => {
+ let correctTestSwatch: Palette = {};
+ let testSwatchWithNull: Palette & {Vibrant?: null} = {};
+
+ beforeAll(() => {
+ const imgPath = path.join(__dirname, '__fixtures__/endi.jpg');
+ const vibrant = new Vibrant(imgPath, {});
+
+ return vibrant.getPalette().then((palette) => {
+ correctTestSwatch = {...palette};
+ testSwatchWithNull = {...palette, Vibrant: null};
+ });
+ });
+
+ it('should return 6 hex colours sorted by popularity', () => {
+ expect(toPalette(correctTestSwatch)).toHaveLength(6);
+ });
+
+ it('should return 5 hex colours with no errors if a palette was incomplete', () => {
+ expect(toPalette(testSwatchWithNull)).toHaveLength(5);
});
});
diff --git a/website/_dogfooding/_pages tests/link-tests.tsx b/website/_dogfooding/_pages tests/link-tests.tsx
index bfd7364fd1..d0afa2ef4f 100644
--- a/website/_dogfooding/_pages tests/link-tests.tsx
+++ b/website/_dogfooding/_pages tests/link-tests.tsx
@@ -5,12 +5,12 @@
* LICENSE file in the root directory of this source tree.
*/
-import React from 'react';
+import React, {useRef} from 'react';
import Layout from '@theme/Layout';
import Link from '@docusaurus/Link';
export default function LinkTest(): JSX.Element {
- const anchorRef = React.useRef(null);
+ const anchorRef = useRef(null);
return (
diff --git a/website/_dogfooding/_pages tests/markdownPageTests.md b/website/_dogfooding/_pages tests/markdownPageTests.md
index 2f7ecdcb8f..0f1ba8ec80 100644
--- a/website/_dogfooding/_pages tests/markdownPageTests.md
+++ b/website/_dogfooding/_pages tests/markdownPageTests.md
@@ -102,7 +102,7 @@ import MyComponentSource from '!!raw-loader!@site/src/pages/examples/\_myCompone
```jsx live
function Demo() {
- React.useEffect(() => console.log('mount'), []);
+ useEffect(() => console.log('mount'), []);
return null;
}
```
diff --git a/website/src/components/APITable/index.tsx b/website/src/components/APITable/index.tsx
index aef73f8728..5608d543b5 100644
--- a/website/src/components/APITable/index.tsx
+++ b/website/src/components/APITable/index.tsx
@@ -6,14 +6,12 @@
*/
import React, {
- Children,
type ComponentProps,
type ReactElement,
type ReactNode,
isValidElement,
useRef,
useEffect,
- forwardRef,
} from 'react';
import {useHistory} from '@docusaurus/router';
import styles from './styles.module.css';
@@ -27,41 +25,41 @@ interface Props {
function getText(node: ReactElement): string {
let curNode: ReactNode = node;
while (isValidElement(curNode)) {
- [curNode] = Children.toArray(curNode.props.children);
+ [curNode] = React.Children.toArray(curNode.props.children);
}
return curNode as string;
}
-const APITableRow = forwardRef(
- (
- {
- name,
- children,
- }: {name: string | undefined; children: ReactElement>},
- ref: React.ForwardedRef,
- ) => {
- const entryName = getText(children);
- const id = name ? `${name}-${entryName}` : entryName;
- const anchor = `#${id}`;
- const history = useHistory();
- return (
- {
+function APITableRow(
+ {
+ name,
+ children,
+ }: {name: string | undefined; children: ReactElement>},
+ ref: React.ForwardedRef,
+) {
+ const entryName = getText(children);
+ const id = name ? `${name}-${entryName}` : entryName;
+ const anchor = `#${id}`;
+ const history = useHistory();
+ return (
+ {
+ history.push(anchor);
+ }}
+ onKeyDown={(e: React.KeyboardEvent) => {
+ if (e.key === 'Enter') {
history.push(anchor);
- }}
- onKeyDown={(e: React.KeyboardEvent) => {
- if (e.key === 'Enter') {
- history.push(anchor);
- }
- }}>
- {children.props.children}
-
- );
- },
-);
+ }
+ }}>
+ {children.props.children}
+
+ );
+}
+
+const APITableRowComp = React.forwardRef(APITableRow);
/*
* Note: this is not a quite robust component since it makes a lot of
@@ -69,19 +67,19 @@ const APITableRow = forwardRef(
* should be generally correct in the MDX context.
*/
export default function APITable({children, name}: Props): JSX.Element {
- const [thead, tbody] = Children.toArray(
+ const [thead, tbody] = React.Children.toArray(
children.props.children,
) as ReactElement[];
const highlightedRow = useRef(null);
useEffect(() => {
highlightedRow.current?.focus();
}, [highlightedRow]);
- const rows = Children.map(
+ const rows = React.Children.map(
tbody.props.children,
(row: ReactElement>) => (
-
+
{row}
-
+
),
);
diff --git a/website/src/data/__tests__/user.test.ts b/website/src/data/__tests__/user.test.ts
index 1489ff70db..183d9c37ee 100644
--- a/website/src/data/__tests__/user.test.ts
+++ b/website/src/data/__tests__/user.test.ts
@@ -6,12 +6,10 @@
*/
import {TagList, sortedUsers, type User} from '../users';
-// eslint-disable-next-line import/no-extraneous-dependencies
import {Joi} from '@docusaurus/utils-validation';
import fs from 'fs-extra';
import path from 'path';
-// eslint-disable-next-line import/no-extraneous-dependencies
import imageSize from 'image-size';
declare global {
diff --git a/website/src/pages/showcase/_components/ShowcaseCard/index.tsx b/website/src/pages/showcase/_components/ShowcaseCard/index.tsx
index 61ad51a292..a09b4c5e49 100644
--- a/website/src/pages/showcase/_components/ShowcaseCard/index.tsx
+++ b/website/src/pages/showcase/_components/ShowcaseCard/index.tsx
@@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/
-import React, {memo} from 'react';
+import React from 'react';
import clsx from 'clsx';
import Image from '@theme/IdealImage';
import Link from '@docusaurus/Link';
@@ -95,4 +95,4 @@ function ShowcaseCard({user}: {user: User}) {
);
}
-export default memo(ShowcaseCard);
+export default React.memo(ShowcaseCard);
diff --git a/website/src/pages/showcase/_components/ShowcaseTagSelect/index.tsx b/website/src/pages/showcase/_components/ShowcaseTagSelect/index.tsx
index d0d58328a4..29ed978841 100644
--- a/website/src/pages/showcase/_components/ShowcaseTagSelect/index.tsx
+++ b/website/src/pages/showcase/_components/ShowcaseTagSelect/index.tsx
@@ -6,12 +6,12 @@
*/
import React, {
- type ComponentProps,
- type ReactNode,
- type ReactElement,
useCallback,
useState,
useEffect,
+ type ComponentProps,
+ type ReactNode,
+ type ReactElement,
} from 'react';
import {useHistory, useLocation} from '@docusaurus/router';
import {toggleListItem} from '@site/src/utils/jsUtils';