mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-06-10 22:50:46 +02:00
26820bc327
[web] Add library page with navbar and sidebar layout GitOrigin-RevId: b27f8e5dca13bae0cab83a919097c927a025e028
138 lines
4.3 KiB
TypeScript
138 lines
4.3 KiB
TypeScript
import { type Ref, useState } from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { Question, User } from '@phosphor-icons/react'
|
|
import { Dropdown } from 'react-bootstrap'
|
|
import getMeta from '@/utils/meta'
|
|
import OLTooltip from '@/shared/components/ol/ol-tooltip'
|
|
import { NavDropdownMenuItems } from '@/shared/components/navbar/nav-dropdown-from-data'
|
|
import { NavbarDropdownItemData } from '@/shared/components/types/navbar'
|
|
import { useContactUsModal } from '@/shared/hooks/use-contact-us-modal'
|
|
import { UserProvider } from '@/shared/context/user-context'
|
|
import { AccountMenuItems } from '@/shared/components/navbar/account-menu-items'
|
|
import { sendMB } from '@/infrastructure/event-tracking'
|
|
|
|
export function SidebarLowerSection({
|
|
showThemeToggle = false,
|
|
accountRef,
|
|
onAccountOpen,
|
|
children,
|
|
}: {
|
|
showThemeToggle?: boolean
|
|
accountRef?: Ref<HTMLDivElement>
|
|
onAccountOpen?: () => void
|
|
children?: React.ReactNode
|
|
}) {
|
|
const { t } = useTranslation()
|
|
const [showAccountDropdown, setShowAccountDropdown] = useState(false)
|
|
const [showHelpDropdown, setShowHelpDropdown] = useState(false)
|
|
const { showModal: showContactUsModal, modal: contactUsModal } =
|
|
useContactUsModal({
|
|
autofillProjectUrl: false,
|
|
})
|
|
const { sessionUser, showSubscriptionLink, items } = getMeta('ol-navbar')
|
|
const helpItem = items.find(
|
|
item => item.text === 'help_and_resources'
|
|
) as NavbarDropdownItemData
|
|
|
|
return (
|
|
<>
|
|
{children}
|
|
<nav
|
|
className="d-flex flex-row gap-3 mb-2"
|
|
aria-label={t('account_help')}
|
|
>
|
|
{helpItem && (
|
|
<Dropdown
|
|
className="ds-nav-icon-dropdown"
|
|
onToggle={show => {
|
|
setShowHelpDropdown(show)
|
|
if (show) {
|
|
sendMB('menu-expand', { item: 'help', location: 'sidebar' })
|
|
}
|
|
}}
|
|
role="menu"
|
|
>
|
|
<Dropdown.Toggle role="menuitem" aria-label={t('help')}>
|
|
<OLTooltip
|
|
description={t('help')}
|
|
id="help-icon"
|
|
overlayProps={{
|
|
placement: 'top',
|
|
}}
|
|
hidden={showHelpDropdown}
|
|
>
|
|
<div>
|
|
<Question size={24} />
|
|
</div>
|
|
</OLTooltip>
|
|
</Dropdown.Toggle>
|
|
<Dropdown.Menu
|
|
as="ul"
|
|
role="menu"
|
|
align="end"
|
|
popperConfig={{
|
|
modifiers: [{ name: 'offset', options: { offset: [0, 5] } }],
|
|
}}
|
|
>
|
|
<NavDropdownMenuItems
|
|
dropdown={helpItem.dropdown}
|
|
showContactUsModal={showContactUsModal}
|
|
location="sidebar"
|
|
/>
|
|
</Dropdown.Menu>
|
|
</Dropdown>
|
|
)}
|
|
{sessionUser && (
|
|
<Dropdown
|
|
className="ds-nav-icon-dropdown"
|
|
onToggle={show => {
|
|
setShowAccountDropdown(show)
|
|
if (show) {
|
|
sendMB('menu-expand', {
|
|
item: 'account',
|
|
location: 'sidebar',
|
|
})
|
|
onAccountOpen?.()
|
|
}
|
|
}}
|
|
role="menu"
|
|
>
|
|
<Dropdown.Toggle role="menuitem" aria-label={t('Account')}>
|
|
<OLTooltip
|
|
description={t('Account')}
|
|
id="open-account"
|
|
overlayProps={{
|
|
placement: 'top',
|
|
}}
|
|
hidden={showAccountDropdown}
|
|
>
|
|
<div ref={accountRef}>
|
|
<User size={24} />
|
|
</div>
|
|
</OLTooltip>
|
|
</Dropdown.Toggle>
|
|
<Dropdown.Menu
|
|
as="ul"
|
|
role="menu"
|
|
align="end"
|
|
popperConfig={{
|
|
modifiers: [{ name: 'offset', options: { offset: [-50, 5] } }],
|
|
}}
|
|
>
|
|
<AccountMenuItems
|
|
sessionUser={sessionUser}
|
|
showSubscriptionLink={showSubscriptionLink}
|
|
showThemeToggle={showThemeToggle}
|
|
/>
|
|
</Dropdown.Menu>
|
|
</Dropdown>
|
|
)}
|
|
</nav>
|
|
<div className="ds-nav-ds-name" translate="no">
|
|
<span>Digital Science</span>
|
|
</div>
|
|
<UserProvider>{contactUsModal}</UserProvider>
|
|
</>
|
|
)
|
|
}
|