-
-
Notifications
You must be signed in to change notification settings - Fork 262
Expand file tree
/
Copy pathDivider.tsx
More file actions
37 lines (30 loc) · 1.05 KB
/
Divider.tsx
File metadata and controls
37 lines (30 loc) · 1.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import * as React from 'react';
import { clsx } from 'clsx';
import { MenuContext } from './context/MenuContext';
import { useMeasure } from './context/PathContext';
import type { MenuDividerType } from './interface';
import { useFullPath } from './context/PathContext';
export type DividerProps = Omit<MenuDividerType, 'type'>;
export default function Divider(props: DividerProps) {
const { className, style, itemRender: propItemRender, eventOpt } = props;
const { prefixCls, itemRender: contextItemRender } = React.useContext(MenuContext);
const measure = useMeasure();
const connectedKeyPath = useFullPath();
if (measure) {
return null;
}
const renderNode = (
<li role="separator" className={clsx(`${prefixCls}-item-divider`, className)} style={style} />
);
const mergedItemRender = propItemRender || contextItemRender;
if (typeof mergedItemRender === 'function') {
return mergedItemRender(renderNode, {
item: {
type: 'divider',
...eventOpt,
},
keys: connectedKeyPath,
});
}
return renderNode;
}