Skip to content

Commit

Permalink
fix(OverlayTrigger): convert to an arrow function to fix type issues (#…
Browse files Browse the repository at this point in the history
…6709)

* Convert OverlayTrigger to an arrow function to fix type issues

Fixes #6708

* Use React.FC to suppress propTypes exports in the .d.ts file
Fix type mismatches

Fixes #6708
  • Loading branch information
snstanton authored Oct 21, 2023
1 parent 80afd3e commit 4e609e2
Showing 1 changed file with 21 additions and 11 deletions.
32 changes: 21 additions & 11 deletions src/OverlayTrigger.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import { useUncontrolledProp } from 'uncontrollable';
import useMergedRefs from '@restart/hooks/useMergedRefs';
import Overlay, { OverlayChildren, OverlayProps } from './Overlay';
import safeFindDOMNode from './safeFindDOMNode';
import { Placement } from './types';

export type OverlayTriggerType = 'hover' | 'click' | 'focus';

Expand Down Expand Up @@ -36,6 +37,7 @@ export interface OverlayTriggerProps

target?: never;
onHide?: never;
placement?: Placement;
}

function normalizeDelay(delay?: OverlayDelay) {
Expand Down Expand Up @@ -66,7 +68,11 @@ function handleMouseOverOut(
}
}

const triggerType = PropTypes.oneOf(['click', 'hover', 'focus']);
const triggerType = PropTypes.oneOf<OverlayTriggerType>([
'click',
'hover',
'focus',
]);

const propTypes = {
children: PropTypes.oneOfType([PropTypes.element, PropTypes.func]).isRequired,
Expand All @@ -78,16 +84,19 @@ const propTypes = {
*
* @type {'hover' | 'click' |'focus' | Array<'hover' | 'click' |'focus'>}
*/
trigger: PropTypes.oneOfType([triggerType, PropTypes.arrayOf(triggerType)]),
trigger: PropTypes.oneOfType([
triggerType.isRequired,
PropTypes.arrayOf(triggerType.isRequired),
]),

/**
* A millisecond delay amount to show and hide the Overlay once triggered
*/
delay: PropTypes.oneOfType([
PropTypes.number,
PropTypes.number.isRequired,
PropTypes.shape({
show: PropTypes.number,
hide: PropTypes.number,
show: PropTypes.number.isRequired,
hide: PropTypes.number.isRequired,
}),
]),

Expand Down Expand Up @@ -124,10 +133,11 @@ const propTypes = {
/**
* An element or text to overlay next to the target.
*/
overlay: PropTypes.oneOfType([PropTypes.func, PropTypes.element.isRequired]),
overlay: PropTypes.oneOfType([PropTypes.func, PropTypes.element.isRequired])
.isRequired,

/**
* A Popper.js config object passed to the the underlying popper instance.
* A Popper.js config object passed to the underlying popper instance.
*/
popperConfig: PropTypes.object,

Expand All @@ -145,7 +155,7 @@ const propTypes = {
/**
* The placement of the Overlay in relation to it's `target`.
*/
placement: PropTypes.oneOf([
placement: PropTypes.oneOf<Placement>([
'auto-start',
'auto',
'auto-end',
Expand All @@ -164,7 +174,7 @@ const propTypes = {
]),
};

function OverlayTrigger({
const OverlayTrigger: React.FC<OverlayTriggerProps> = ({
trigger = ['hover', 'focus'],
overlay,
children,
Expand All @@ -178,7 +188,7 @@ function OverlayTrigger({
placement,
flip = placement && placement.indexOf('auto') !== -1,
...props
}: OverlayTriggerProps) {
}: OverlayTriggerProps) => {
const triggerNodeRef = useRef(null);
const mergedRef = useMergedRefs<unknown>(
triggerNodeRef,
Expand Down Expand Up @@ -307,7 +317,7 @@ function OverlayTrigger({
</Overlay>
</>
);
}
};

OverlayTrigger.propTypes = propTypes;

Expand Down

0 comments on commit 4e609e2

Please sign in to comment.