|
1 | | -import { cloneElement, forwardRef, memo, MouseEvent, useContext, useState } from "react"; |
| 1 | +import { cloneElement, memo, MouseEvent, useState } from "react"; |
2 | 2 | import styled from "@emotion/styled"; |
3 | 3 | import { ItemActionProps } from "./types"; |
4 | 4 | import DxcIcon from "../icon/Icon"; |
5 | 5 | import { TooltipWrapper } from "../tooltip/Tooltip"; |
6 | | -import ContextualMenuContext from "./ContextualMenuContext"; |
7 | 6 |
|
8 | 7 | const Action = styled.button<{ |
9 | 8 | depthLevel: ItemActionProps["depthLevel"]; |
10 | 9 | selected: ItemActionProps["selected"]; |
11 | | - displayGroupLines: boolean; |
12 | | - responsiveView?: boolean; |
13 | 10 | }>` |
14 | 11 | box-sizing: content-box; |
15 | 12 | border: none; |
16 | 13 | border-radius: var(--border-radius-s); |
17 | | - ${({ displayGroupLines, depthLevel, responsiveView }) => ` |
18 | | - ${!responsiveView ? `padding: var(--spacing-padding-xxs) var(--spacing-padding-xxs) var(--spacing-padding-xxs) calc(var(--spacing-padding-xs) + ${!displayGroupLines ? depthLevel : 0} * var(--spacing-padding-l))` : "padding: var(--spacing-padding-xxs) var(--spacing-padding-none)"}; |
19 | | - ${displayGroupLines && depthLevel > 0 ? "margin-left: var(--spacing-padding-xs);" : ""} |
20 | | - `} |
| 14 | + padding: var(--spacing-padding-xxs) var(--spacing-padding-xxs) var(--spacing-padding-xxs) |
| 15 | + ${({ depthLevel }) => `calc(var(--spacing-padding-xs) + ${depthLevel} * var(--spacing-padding-l))`}; |
21 | 16 | display: flex; |
22 | 17 | align-items: center; |
23 | 18 | gap: var(--spacing-gap-m); |
24 | | - justify-content: ${({ responsiveView }) => (responsiveView ? "center" : "space-between")}; |
| 19 | + justify-content: space-between; |
25 | 20 | background-color: ${({ selected }) => (selected ? "var(--color-bg-primary-lighter)" : "transparent")}; |
26 | 21 | height: var(--height-s); |
27 | 22 | cursor: pointer; |
28 | 23 | overflow: hidden; |
29 | | - text-decoration: none; |
30 | 24 |
|
31 | 25 | &:hover { |
32 | 26 | background-color: ${({ selected }) => |
@@ -69,64 +63,31 @@ const Text = styled.span<{ selected: ItemActionProps["selected"] }>` |
69 | 63 | overflow: hidden; |
70 | 64 | `; |
71 | 65 |
|
72 | | -const Control = styled.span` |
73 | | - display: flex; |
74 | | - align-items: center; |
75 | | - padding: var(--spacing-padding-none); |
76 | | - justify-content: flex-end; |
77 | | - align-items: center; |
78 | | - gap: var(--spacing-gap-s); |
79 | | -`; |
80 | | - |
81 | | -const ItemAction = memo( |
82 | | - forwardRef<HTMLButtonElement, ItemActionProps>( |
83 | | - ({ badge, collapseIcon, depthLevel, icon, label, href, ...props }, ref) => { |
84 | | - const [hasTooltip, setHasTooltip] = useState(false); |
85 | | - const modifiedBadge = badge && cloneElement(badge, { size: "small" }); |
86 | | - const { displayControlsAfter, responsiveView, displayGroupLines, allowNavigation } = |
87 | | - useContext(ContextualMenuContext) ?? {}; |
| 66 | +const ItemAction = memo(({ badge, collapseIcon, depthLevel, icon, label, ...props }: ItemActionProps) => { |
| 67 | + const [hasTooltip, setHasTooltip] = useState(false); |
| 68 | + const modifiedBadge = badge && cloneElement(badge, { size: "small" }); |
88 | 69 |
|
89 | | - return ( |
90 | | - <TooltipWrapper condition={hasTooltip} label={label}> |
91 | | - <Action |
92 | | - as={allowNavigation && href ? "a" : "button"} |
93 | | - role={allowNavigation && href ? "link" : "button"} |
94 | | - ref={ref} |
95 | | - depthLevel={depthLevel} |
96 | | - displayGroupLines={!!displayGroupLines} |
97 | | - responsiveView={responsiveView} |
98 | | - {...(allowNavigation && href && { href })} |
99 | | - {...props} |
| 70 | + return ( |
| 71 | + <TooltipWrapper condition={hasTooltip} label={label}> |
| 72 | + <Action depthLevel={depthLevel} {...props}> |
| 73 | + <Label> |
| 74 | + {collapseIcon && <Icon>{collapseIcon}</Icon>} |
| 75 | + {icon && depthLevel === 0 && <Icon>{typeof icon === "string" ? <DxcIcon icon={icon} /> : icon}</Icon>} |
| 76 | + <Text |
| 77 | + selected={props.selected} |
| 78 | + onMouseEnter={(event: MouseEvent<HTMLSpanElement>) => { |
| 79 | + const text = event.currentTarget; |
| 80 | + setHasTooltip(text.scrollWidth > text.clientWidth); |
| 81 | + }} |
100 | 82 | > |
101 | | - <Label> |
102 | | - {!displayControlsAfter && <Control>{collapseIcon && <Icon>{collapseIcon}</Icon>}</Control>} |
103 | | - <TooltipWrapper condition={responsiveView} label={label}> |
104 | | - <Icon>{typeof icon === "string" ? <DxcIcon icon={icon} /> : icon}</Icon> |
105 | | - </TooltipWrapper> |
106 | | - {!responsiveView && ( |
107 | | - <Text |
108 | | - selected={props.selected} |
109 | | - onMouseEnter={(event: MouseEvent<HTMLSpanElement>) => { |
110 | | - const text = event.currentTarget; |
111 | | - setHasTooltip(text.scrollWidth > text.clientWidth); |
112 | | - }} |
113 | | - > |
114 | | - {label} |
115 | | - </Text> |
116 | | - )} |
117 | | - </Label> |
118 | | - {!responsiveView && ( |
119 | | - <Control> |
120 | | - {modifiedBadge} |
121 | | - {displayControlsAfter && collapseIcon && <Icon>{collapseIcon}</Icon>} |
122 | | - </Control> |
123 | | - )} |
124 | | - </Action> |
125 | | - </TooltipWrapper> |
126 | | - ); |
127 | | - } |
128 | | - ) |
129 | | -); |
| 83 | + {label} |
| 84 | + </Text> |
| 85 | + </Label> |
| 86 | + {modifiedBadge} |
| 87 | + </Action> |
| 88 | + </TooltipWrapper> |
| 89 | + ); |
| 90 | +}); |
130 | 91 |
|
131 | 92 | ItemAction.displayName = "ItemAction"; |
132 | 93 |
|
|
0 commit comments