diff --git a/components/brave_new_tab_ui/components/default/widget/index.tsx b/components/brave_new_tab_ui/components/default/widget/index.tsx
index f12762034580..4f5f4f394428 100644
--- a/components/brave_new_tab_ui/components/default/widget/index.tsx
+++ b/components/brave_new_tab_ui/components/default/widget/index.tsx
@@ -17,6 +17,7 @@ export interface WidgetProps {
isCryptoTab?: boolean
widgetTitle?: string
hideMenu?: boolean
+ isForeground?: boolean
onLearnMore?: () => void
onDisconnect?: () => void
onRefreshData?: () => void
@@ -31,19 +32,15 @@ const createWidget =
(WrappedComponent: React.ComponentType
constructor (props: P & WidgetProps) {
super(props)
this.state = {
- widgetMenuPersist: false
+ widgetMenuPersist: !!props.isForeground
}
}
- toggleWidgetHover = () => {
- this.setState({ widgetMenuPersist: !this.state.widgetMenuPersist })
- }
-
- persistWidgetHover = () => {
+ persistWidget = () => {
this.setState({ widgetMenuPersist: true })
}
- unpersistWidgetHover = () => {
+ unpersistWidget = () => {
this.setState({ widgetMenuPersist: false })
}
@@ -57,6 +54,7 @@ const createWidget =
(WrappedComponent: React.ComponentType
isCryptoTab,
widgetTitle,
hideMenu,
+ isForeground,
onLearnMore,
onDisconnect,
onRefreshData
@@ -67,7 +65,6 @@ const createWidget =
(WrappedComponent: React.ComponentType
(WrappedComponent: React.ComponentType
widgetMenuPersist={widgetMenuPersist}
preventFocus={preventFocus}
>
-
+
{hideWidget && !hideMenu && !preventFocus &&
(WrappedComponent: React.ComponentType
onLearnMore={onLearnMore}
onDisconnect={onDisconnect}
onRefreshData={onRefreshData}
+ isForeground={isForeground}
widgetMenuPersist={widgetMenuPersist}
- toggleWidgetHover={this.toggleWidgetHover}
textDirection={textDirection}
menuPosition={menuPosition}
hideWidget={hideWidget as HideWidgetFunction}
- unpersistWidgetHover={this.unpersistWidgetHover}
- onMouseEnter={this.persistWidgetHover}
+ persistWidget={this.persistWidget}
+ unpersistWidget={this.unpersistWidget}
/>
}
diff --git a/components/brave_new_tab_ui/components/default/widget/styles.ts b/components/brave_new_tab_ui/components/default/widget/styles.ts
index a11c49f21582..c200c065bc36 100644
--- a/components/brave_new_tab_ui/components/default/widget/styles.ts
+++ b/components/brave_new_tab_ui/components/default/widget/styles.ts
@@ -23,23 +23,10 @@ export const StyledWidgetContainer = styled('div')`
position: relative;
`
-export const StyledWidgetMenuContainer = styled('div')`
- visibility: hidden;
- pointer-events: none;
+export const StyledWidgetMenuContainer = styled<{}, 'div'>('div')`
position: absolute;
top: 5px;
right: 5px;
-
- ${StyledWidgetContainer}:hover & {
- visibility: visible;
- pointer-events: auto;
- }
-
- // Also hover when menu button has been clicked
- ${ p => p.widgetMenuPersist && `
- visibility: visible;
- pointer-events: auto;
- `}
`
interface WidgetVisibilityProps {
@@ -47,6 +34,7 @@ interface WidgetVisibilityProps {
preventFocus?: boolean
isCrypto?: boolean
isCryptoTab?: boolean
+ isForeground?: boolean
}
export const StyledWidget = styled('div')`
@@ -76,9 +64,10 @@ interface WidgetMenuProps {
textDirection: string
}
-export const StyledWidgetMenu = styled('div')`
+export const StyledWidgetMenu = styled('div')`
position absolute;
- width: 166px;
+ width: max-content;
+ min-width: 166px;
padding: 8px 0;
background-color: ${p => p.theme.color.contextMenuBackground};
color: ${p => p.theme.color.contextMenuForeground};
@@ -86,6 +75,13 @@ export const StyledWidgetMenu = styled('div')`
border-radius: 4px;
top: 48px;
z-index: 4;
+ visibility: hidden;
+ pointer-events: none;
+
+ ${p => p.widgetMenuPersist && `
+ visibility: visible;
+ pointer-events: auto;
+ `}
@media screen and (min-width: 1150px) {
${p => (p.menuPosition === 'right' && p.textDirection === 'ltr') || (p.menuPosition === 'left' && p.textDirection === 'rtl')
@@ -157,6 +153,21 @@ interface WidgetIconProps {
isBinance?: boolean
}
+export const StyledEllipsis = styled('div')`
+ visibility: hidden;
+ pointer-events: none;
+
+ ${p => (p.widgetMenuPersist || p.isForeground) && `
+ visibility: visible;
+ pointer-events: auto;
+ `}
+
+ ${StyledWidgetContainer}:hover & {
+ visibility: visible;
+ pointer-events: auto;
+ }
+`
+
export const StyledWidgetIcon = styled('div')`
height: 13px;
width: 13px;
@@ -168,5 +179,6 @@ export const StyledWidgetIcon = styled('div')`
}
`
export const StyledSpan = styled<{}, 'span'>('span')`
- height: 13px;
+ text-align: left;
+ margin-right: 10px;
`
diff --git a/components/brave_new_tab_ui/components/default/widget/widgetMenu.tsx b/components/brave_new_tab_ui/components/default/widget/widgetMenu.tsx
index d44efb1b6033..7bcfee157a4c 100644
--- a/components/brave_new_tab_ui/components/default/widget/widgetMenu.tsx
+++ b/components/brave_new_tab_ui/components/default/widget/widgetMenu.tsx
@@ -5,7 +5,7 @@
import * as React from 'react'
-import { StyledWidgetMenuContainer, StyledWidgetMenu, StyledWidgetButton, StyledWidgetIcon, StyledSpan, StyledWidgetLink } from './styles'
+import { StyledWidgetMenuContainer, StyledWidgetMenu, StyledWidgetButton, StyledWidgetIcon, StyledSpan, StyledWidgetLink, StyledEllipsis } from './styles'
import { IconButton } from '../../default'
import EllipsisIcon from './assets/ellipsis'
import HideIcon from './assets/hide'
@@ -18,12 +18,12 @@ interface Props {
menuPosition: 'right' | 'left'
hideWidget: () => void
textDirection: string
- toggleWidgetHover: () => void
widgetMenuPersist: boolean
- unpersistWidgetHover: () => void
+ persistWidget: () => void
+ unpersistWidget: () => void
widgetTitle?: string
+ isForeground?: boolean
onLearnMore?: () => void
- onMouseEnter: () => void
onDisconnect?: () => void
onRefreshData?: () => void
}
@@ -44,7 +44,7 @@ export default class WidgetMenu extends React.PureComponent {
handleClickOutsideMenu = (event: Event) => {
if (this.settingsMenuRef && !this.settingsMenuRef.current.contains(event.target)) {
- this.props.unpersistWidgetHover()
+ this.props.unpersistWidget()
this.closeMenu()
}
}
@@ -58,6 +58,10 @@ export default class WidgetMenu extends React.PureComponent {
}
toggleMenu = () => {
+ if (!this.state.showMenu) {
+ this.props.persistWidget()
+ }
+
this.setState({ showMenu: !this.state.showMenu })
}
@@ -67,7 +71,7 @@ export default class WidgetMenu extends React.PureComponent {
unmountWidget = () => {
this.props.hideWidget()
- this.props.unpersistWidgetHover()
+ this.props.unpersistWidget()
this.closeMenu()
}
@@ -82,8 +86,8 @@ export default class WidgetMenu extends React.PureComponent {
textDirection,
widgetMenuPersist,
widgetTitle,
+ isForeground,
onLearnMore,
- onMouseEnter,
onDisconnect,
onRefreshData
} = this.props
@@ -91,16 +95,16 @@ export default class WidgetMenu extends React.PureComponent {
const hideString = widgetTitle ? `${getLocale('hide')} ${widgetTitle}` : getLocale('hide')
return (
-
-
+
+
+
+
+
+
{showMenu &&
{
menuPosition={'left'}
isCrypto={true}
isCryptoTab={!showContent}
+ isForeground={showContent}
textDirection={textDirection}
preventFocus={false}
hideWidget={this.toggleShowRewards}
@@ -785,6 +786,7 @@ class NewTabPage extends React.Component {
isCryptoTab={!showContent}
menuPosition={'left'}
widgetTitle={'Binance'}
+ isForeground={showContent}
textDirection={textDirection}
preventFocus={false}
hideWidget={this.toggleShowBinance}
@@ -832,6 +834,7 @@ class NewTabPage extends React.Component {
isCryptoTab={!showContent}
menuPosition={'left'}
widgetTitle={'Gemini'}
+ isForeground={showContent}
textDirection={textDirection}
preventFocus={false}
hideWidget={this.toggleShowGemini}