x-ui-design 0.8.11 → 0.8.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/types/components/DatePicker/RangePicker/RangePicker.d.ts +1 -1
- package/dist/esm/types/components/Dropdown/Dropdown.d.ts +1 -1
- package/dist/esm/types/components/Popover/Popover.d.ts +1 -1
- package/dist/esm/types/types/datepicker.d.ts +1 -1
- package/dist/esm/types/types/dropdown.d.ts +1 -2
- package/dist/esm/types/types/popover.d.ts +4 -1
- package/dist/index.esm.js +24 -19
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +24 -19
- package/dist/index.js.map +1 -1
- package/lib/components/DatePicker/RangePicker/RangePicker.tsx +4 -4
- package/lib/components/Dropdown/Dropdown.tsx +2 -3
- package/lib/components/Popover/Popover.tsx +25 -18
- package/lib/components/Popover/style.css +4 -0
- package/lib/types/datepicker.ts +1 -1
- package/lib/types/dropdown.ts +1 -2
- package/lib/types/popover.ts +4 -1
- package/package.json +1 -1
- package/src/app/page.tsx +1 -1
|
@@ -26,7 +26,7 @@ const RangePicker = ({
|
|
|
26
26
|
picker = 'date',
|
|
27
27
|
locale,
|
|
28
28
|
disabledDate,
|
|
29
|
-
|
|
29
|
+
onVisibleChange,
|
|
30
30
|
onCalendarChange,
|
|
31
31
|
style = {},
|
|
32
32
|
className = '',
|
|
@@ -96,7 +96,7 @@ const RangePicker = ({
|
|
|
96
96
|
!triggerRef.current.contains(event.target as Node)
|
|
97
97
|
) {
|
|
98
98
|
setIsOpen(false);
|
|
99
|
-
|
|
99
|
+
onVisibleChange?.(false);
|
|
100
100
|
}
|
|
101
101
|
};
|
|
102
102
|
|
|
@@ -133,7 +133,7 @@ const RangePicker = ({
|
|
|
133
133
|
[formatDate(begin), formatDate(end)], {}
|
|
134
134
|
);
|
|
135
135
|
setIsOpen(false);
|
|
136
|
-
|
|
136
|
+
onVisibleChange?.(false);
|
|
137
137
|
}
|
|
138
138
|
};
|
|
139
139
|
|
|
@@ -439,7 +439,7 @@ const RangePicker = ({
|
|
|
439
439
|
|
|
440
440
|
if (!isOpen) {
|
|
441
441
|
setIsOpen(!isOpen);
|
|
442
|
-
|
|
442
|
+
onVisibleChange?.(!isOpen);
|
|
443
443
|
}
|
|
444
444
|
}}
|
|
445
445
|
>
|
|
@@ -19,7 +19,7 @@ const Dropdown = ({
|
|
|
19
19
|
menu,
|
|
20
20
|
open: controlledOpen,
|
|
21
21
|
defaultOpen = false,
|
|
22
|
-
|
|
22
|
+
onVisibleChange,
|
|
23
23
|
trigger = 'hover',
|
|
24
24
|
placement = 'bottomLeft',
|
|
25
25
|
overlayClassName = '',
|
|
@@ -33,7 +33,6 @@ const Dropdown = ({
|
|
|
33
33
|
className = '',
|
|
34
34
|
overlay,
|
|
35
35
|
prefixCls = prefixClsDropdown,
|
|
36
|
-
onVisibleChange
|
|
37
36
|
}: DropdownProps) => {
|
|
38
37
|
const [open, setOpen] = useState<boolean>(controlledOpen ?? defaultOpen);
|
|
39
38
|
const [_hover, setHover] = useState<boolean>(controlledOpen ?? defaultOpen);
|
|
@@ -80,7 +79,7 @@ const Dropdown = ({
|
|
|
80
79
|
setOpen(next);
|
|
81
80
|
}
|
|
82
81
|
|
|
83
|
-
|
|
82
|
+
onVisibleChange?.(next);
|
|
84
83
|
onVisibleChange?.(next)
|
|
85
84
|
};
|
|
86
85
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React, { useRef, useState } from "react";
|
|
1
|
+
import React, { useRef, useState, useEffect } from "react";
|
|
2
2
|
import { usePosition } from "../../hooks/usePosition";
|
|
3
3
|
import { clsx } from '../../helpers';
|
|
4
4
|
import { PopoverProps } from "../../types/popover";
|
|
@@ -14,8 +14,11 @@ const Popover = ({
|
|
|
14
14
|
trigger = "click",
|
|
15
15
|
placement = "bottom",
|
|
16
16
|
open,
|
|
17
|
+
visible,
|
|
18
|
+
title,
|
|
19
|
+
overlayClassName = '',
|
|
17
20
|
overlayStyle = {},
|
|
18
|
-
|
|
21
|
+
onVisibleChange,
|
|
19
22
|
getPopupContainer
|
|
20
23
|
}: PopoverProps) => {
|
|
21
24
|
const triggerRef = useRef<HTMLDivElement>(null);
|
|
@@ -23,9 +26,8 @@ const Popover = ({
|
|
|
23
26
|
|
|
24
27
|
const [innerOpen, setInnerOpen] = useState(false);
|
|
25
28
|
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
const [_hover, setHover] = useState<boolean>(isOpen);
|
|
29
|
+
const [hover, setHover] = useState(false);
|
|
30
|
+
const isOpen = visible !== undefined ? visible : open !== undefined ? open : innerOpen;
|
|
29
31
|
|
|
30
32
|
const { dropdownPosition, shouldShowAbove } = usePosition({
|
|
31
33
|
isOpen,
|
|
@@ -37,22 +39,21 @@ const Popover = ({
|
|
|
37
39
|
});
|
|
38
40
|
|
|
39
41
|
const toggle = () => {
|
|
40
|
-
|
|
42
|
+
const newState = !isOpen;
|
|
43
|
+
onVisibleChange ? onVisibleChange(newState) : setInnerOpen(newState);
|
|
41
44
|
};
|
|
42
45
|
|
|
43
46
|
const show = () => {
|
|
44
47
|
setHover(true);
|
|
45
|
-
|
|
46
48
|
if (trigger === "hover") {
|
|
47
|
-
|
|
49
|
+
onVisibleChange ? onVisibleChange(true) : setInnerOpen(true);
|
|
48
50
|
}
|
|
49
51
|
};
|
|
50
52
|
|
|
51
53
|
const hide = () => {
|
|
52
54
|
setHover(false);
|
|
53
|
-
|
|
54
55
|
if (trigger === "hover") {
|
|
55
|
-
|
|
56
|
+
onVisibleChange ? onVisibleChange(false) : setInnerOpen(false);
|
|
56
57
|
}
|
|
57
58
|
};
|
|
58
59
|
|
|
@@ -64,32 +65,38 @@ const Popover = ({
|
|
|
64
65
|
return (
|
|
65
66
|
<div className={`${prefixCls}-wrapper`}>
|
|
66
67
|
<div ref={triggerRef}>
|
|
67
|
-
<div className={`${prefixCls}-wrapper-content`} {...childProps}>
|
|
68
|
+
<div className={`${prefixCls}-wrapper-content`} {...childProps}>
|
|
69
|
+
{children}
|
|
70
|
+
</div>
|
|
68
71
|
|
|
69
72
|
{isOpen && (
|
|
70
73
|
<ConditionalWrapper
|
|
71
|
-
condition={getPopupContainer
|
|
72
|
-
wrapper={(element) =>
|
|
73
|
-
|
|
74
|
+
condition={!!getPopupContainer}
|
|
75
|
+
wrapper={(element) =>
|
|
76
|
+
getPopupContainer
|
|
77
|
+
? createPortal(element, getPopupContainer(popupRef.current as HTMLElement))
|
|
78
|
+
: <>{element}</>
|
|
79
|
+
}
|
|
80
|
+
>
|
|
74
81
|
<div
|
|
75
82
|
ref={popupRef}
|
|
76
|
-
className={clsx(prefixCls, `${prefixCls}-${placement}
|
|
83
|
+
className={clsx(prefixCls, `${prefixCls}-${placement}`, overlayClassName)}
|
|
77
84
|
style={{
|
|
78
|
-
zIndex:
|
|
85
|
+
zIndex: hover ? 1000 : 1,
|
|
79
86
|
...overlayStyle,
|
|
80
87
|
position: "absolute",
|
|
81
88
|
...dropdownPosition
|
|
82
89
|
}}
|
|
83
90
|
>
|
|
91
|
+
{title && <div className={`${prefixCls}-title`}>{title}</div>}
|
|
84
92
|
<div className={`${prefixCls}-inner`}>{content}</div>
|
|
85
93
|
<div className={`${prefixCls}-arrow ${shouldShowAbove ? 'bottom' : ''}`} />
|
|
86
94
|
</div>
|
|
87
95
|
</ConditionalWrapper>
|
|
88
96
|
)}
|
|
89
97
|
</div>
|
|
90
|
-
|
|
91
98
|
</div>
|
|
92
99
|
);
|
|
93
100
|
};
|
|
94
101
|
|
|
95
|
-
export default Popover;
|
|
102
|
+
export default Popover;
|
package/lib/types/datepicker.ts
CHANGED
|
@@ -58,7 +58,7 @@ export type TDatePickerProps = DefaultProps & {
|
|
|
58
58
|
dateString: string | string[],
|
|
59
59
|
info: BaseInfo
|
|
60
60
|
) => void;
|
|
61
|
-
|
|
61
|
+
onVisibleChange?: ((open: boolean) => void) | undefined;
|
|
62
62
|
getPopupContainer?: (node: HTMLElement) => HTMLElement;
|
|
63
63
|
showToday?: boolean;
|
|
64
64
|
inputReadOnly?: boolean;
|
package/lib/types/dropdown.ts
CHANGED
|
@@ -18,7 +18,7 @@ export type DropdownProps = DefaultProps & {
|
|
|
18
18
|
menu?: { items: DropdownItemType[] };
|
|
19
19
|
open?: boolean;
|
|
20
20
|
defaultOpen?: boolean;
|
|
21
|
-
|
|
21
|
+
onVisibleChange?: ((open: boolean) => void) | undefined;
|
|
22
22
|
trigger?: TriggerType;
|
|
23
23
|
placement?: Placement;
|
|
24
24
|
overlayClassName?: string;
|
|
@@ -31,7 +31,6 @@ export type DropdownProps = DefaultProps & {
|
|
|
31
31
|
autoAdjustOverflow?: boolean;
|
|
32
32
|
popupRender?: (node: ReactNode) => ReactNode;
|
|
33
33
|
overlay?: ReactElement | OverlayFunc;
|
|
34
|
-
onVisibleChange?: ((open: boolean) => void) | undefined;
|
|
35
34
|
}
|
|
36
35
|
|
|
37
36
|
|
package/lib/types/popover.ts
CHANGED
|
@@ -8,6 +8,9 @@ export interface PopoverProps {
|
|
|
8
8
|
placement?: "top" | "bottom" | "left" | "right" | "topRight" | "bottomRight" | "topLeft" | "bottomLeft";
|
|
9
9
|
open?: boolean;
|
|
10
10
|
overlayStyle?: CSSProperties;
|
|
11
|
-
|
|
11
|
+
overlayClassName?: string;
|
|
12
|
+
title?: string | ReactNode;
|
|
13
|
+
visible?: boolean;
|
|
14
|
+
onVisibleChange?: ((open: boolean) => void) | undefined;
|
|
12
15
|
getPopupContainer?: ((node: HTMLElement) => HTMLElement) | undefined
|
|
13
16
|
}
|
package/package.json
CHANGED
package/src/app/page.tsx
CHANGED
|
@@ -9,7 +9,7 @@ export default function Home() {
|
|
|
9
9
|
<div style={{ width: 700, overflow: 'auto' }}>
|
|
10
10
|
<div style={{ height: 200, border: '1px solid' }}>
|
|
11
11
|
<div style={{ height: 100 }}>
|
|
12
|
-
<Popover content={<div>
|
|
12
|
+
<Popover title="sdfdsfdsf" content={<div>
|
|
13
13
|
<button>Click Popover</button>
|
|
14
14
|
<br />
|
|
15
15
|
<button>Click Popover</button>
|