Skip to content

Commit

Permalink
fix: fix picker in shadowdom (ant-design#213)
Browse files Browse the repository at this point in the history
Co-authored-by: 礼上 <[email protected]>
  • Loading branch information
icaife and 礼上 authored Feb 7, 2021
1 parent ce17134 commit 4704670
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 13 deletions.
23 changes: 12 additions & 11 deletions src/hooks/usePickerInput.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import type * as React from 'react';
import { useState, useEffect, useRef } from 'react';
import KeyCode from 'rc-util/lib/KeyCode';
import { addGlobalMouseDownEvent } from '../utils/uiUtil';
import { addGlobalMouseDownEvent, getTargetFromEvent } from '../utils/uiUtil';

export default function usePickerInput({
open,
Expand All @@ -21,10 +21,7 @@ export default function usePickerInput({
isClickOutside: (clickElement: EventTarget | null) => boolean;
triggerOpen: (open: boolean) => void;
forwardKeyDown: (e: React.KeyboardEvent<HTMLInputElement>) => boolean;
onKeyDown: (
e: React.KeyboardEvent<HTMLInputElement>,
preventDefault: () => void,
) => void;
onKeyDown: (e: React.KeyboardEvent<HTMLInputElement>, preventDefault: () => void) => void;
blurToCancel?: boolean;
onSubmit: () => void | boolean;
onCancel: () => void;
Expand All @@ -49,7 +46,7 @@ export default function usePickerInput({
setTyping(true);
triggerOpen(true);
},
onKeyDown: e => {
onKeyDown: (e) => {
const preventDefault = (): void => {
preventDefaultRef.current = true;
};
Expand Down Expand Up @@ -98,7 +95,7 @@ export default function usePickerInput({
}
},

onFocus: e => {
onFocus: (e) => {
setTyping(true);
setFocused(true);

Expand All @@ -107,7 +104,7 @@ export default function usePickerInput({
}
},

onBlur: e => {
onBlur: (e) => {
if (preventBlurRef.current || !isClickOutside(document.activeElement)) {
preventBlurRef.current = false;
return;
Expand Down Expand Up @@ -145,16 +142,20 @@ export default function usePickerInput({

// Global click handler
useEffect(() =>
addGlobalMouseDownEvent(({ target }: MouseEvent) => {
addGlobalMouseDownEvent((e: MouseEvent) => {
const target = getTargetFromEvent(e);

if (open) {
if (!isClickOutside(target)) {
const clickedOutside = isClickOutside(target);

if (!clickedOutside) {
preventBlurRef.current = true;

// Always set back in case `onBlur` prevented by user
requestAnimationFrame(() => {
preventBlurRef.current = false;
});
} else if (!focused) {
} else if (!focused || clickedOutside) {
triggerOpen(false);
}
}
Expand Down
15 changes: 13 additions & 2 deletions src/utils/uiUtil.ts
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ export function addGlobalMouseDownEvent(callback: ClickEventHandler) {
if (!globalClickFunc && typeof window !== 'undefined' && window.addEventListener) {
globalClickFunc = (e: MouseEvent) => {
// Clone a new list to avoid repeat trigger events
[...clickCallbacks].forEach(queueFunc => {
[...clickCallbacks].forEach((queueFunc) => {
queueFunc(e);
});
};
Expand All @@ -219,6 +219,17 @@ export function addGlobalMouseDownEvent(callback: ClickEventHandler) {
};
}

export function getTargetFromEvent(e: Event) {
const target = e.target as HTMLElement;

// get target if in shadow dom
if (e.composed && target.shadowRoot) {
return (e.composedPath?.()[0] || target) as HTMLElement;
}

return target;
}

// ====================== Mode ======================
const getYearNextMode = (next: PanelMode): PanelMode => {
if (next === 'month' || next === 'date') {
Expand Down Expand Up @@ -261,5 +272,5 @@ export function elementsContains(
elements: (HTMLElement | undefined | null)[],
target: HTMLElement,
) {
return elements.some(ele => ele && ele.contains(target));
return elements.some((ele) => ele && ele.contains(target));
}

0 comments on commit 4704670

Please sign in to comment.