From 96ef1a37216e173df9587238e2798cd6e4793d88 Mon Sep 17 00:00:00 2001 From: Gururaj J <89023023+Gururajj77@users.noreply.github.com> Date: Tue, 21 May 2024 23:46:20 +0530 Subject: [PATCH] refactor: converted index.js to index.ts for `OverflowMenu` (#16494) * refactor: converted index.js to index.ts for overflowmenu * feat: exported props for overflowmenu --- .../components/OverflowMenu/OverflowMenu.tsx | 17 +++++++++++------ .../OverflowMenu/{index.js => index.tsx} | 7 +++++-- 2 files changed, 16 insertions(+), 8 deletions(-) rename packages/react/src/components/OverflowMenu/{index.js => index.tsx} (79%) diff --git a/packages/react/src/components/OverflowMenu/OverflowMenu.tsx b/packages/react/src/components/OverflowMenu/OverflowMenu.tsx index bc1b96e23580..157a976655de 100644 --- a/packages/react/src/components/OverflowMenu/OverflowMenu.tsx +++ b/packages/react/src/components/OverflowMenu/OverflowMenu.tsx @@ -7,7 +7,7 @@ import invariant from 'invariant'; import PropTypes from 'prop-types'; -import React from 'react'; +import React, { ComponentType } from 'react'; import classNames from 'classnames'; import ClickListener from '../../internal/ClickListener'; import FloatingMenu, { @@ -97,15 +97,20 @@ export const getMenuOffset = (menuBody, direction, trigger, flip) => { }; interface Offset { - top: number; - left: number; + top?: number | null | undefined; + left?: number | null | undefined; } -interface OverflowMenuProps { +type IconProps = { + className?: string; + 'aria-label'?: string; +}; + +export interface OverflowMenuProps { /** * Specify a label to be read by screen readers on the container node */ - ['aria-label']: string; + ['aria-label']?: string; /** * Deprecated, please use `aria-label` instead. @@ -198,7 +203,7 @@ interface OverflowMenuProps { /** * Function called to override icon rendering. */ - renderIcon?: React.ElementType; + renderIcon?: ComponentType; /** * Specify a CSS selector that matches the DOM element that should diff --git a/packages/react/src/components/OverflowMenu/index.js b/packages/react/src/components/OverflowMenu/index.tsx similarity index 79% rename from packages/react/src/components/OverflowMenu/index.js rename to packages/react/src/components/OverflowMenu/index.tsx index e0d3a8583bf8..4d0185f8d877 100644 --- a/packages/react/src/components/OverflowMenu/index.js +++ b/packages/react/src/components/OverflowMenu/index.tsx @@ -7,13 +7,16 @@ import React from 'react'; import { useFeatureFlag } from '../FeatureFlags'; +import { type OverflowMenuProps } from './OverflowMenu'; import { OverflowMenu as OverflowMenuV12 } from './next'; import { OverflowMenu as OverflowMenuComponent } from './OverflowMenu'; import { createClassWrapper } from '../../internal/createClassWrapper'; -const OverflowMenuV11 = createClassWrapper(OverflowMenuComponent); +const OverflowMenuV11 = createClassWrapper( + OverflowMenuComponent as typeof React.Component +); function OverflowMenu(props) { const enableV12OverflowMenu = useFeatureFlag('enable-v12-overflowmenu'); @@ -28,4 +31,4 @@ function OverflowMenu(props) { OverflowMenu.displayName = 'OverflowMenu'; export default OverflowMenu; -export { OverflowMenu }; +export { OverflowMenu, type OverflowMenuProps };