import { faList as listIcon, faLink as createIcon, faTags as tagsIcon, faPen as editIcon, faHome as overviewIcon, faGlobe as domainsIcon, } from '@fortawesome/free-solid-svg-icons'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import type { FC } from 'react'; import type { NavLinkProps } from 'react-router-dom'; import { NavLink, useLocation } from 'react-router-dom'; import classNames from 'classnames'; import type { DeleteServerButtonProps } from '../servers/DeleteServerButton'; import type { SelectedServer } from '../servers/data'; import { isServerWithId } from '../servers/data'; import './AsideMenu.scss'; export interface AsideMenuProps { selectedServer: SelectedServer; showOnMobile?: boolean; } interface AsideMenuItemProps extends NavLinkProps { to: string; className?: string; } const AsideMenuItem: FC = ({ children, to, className, ...rest }) => ( classNames('aside-menu__item', className, { 'aside-menu__item--selected': isActive })} to={to} {...rest} > {children} ); export const AsideMenu = (DeleteServerButton: FC) => ( { selectedServer, showOnMobile = false }: AsideMenuProps, ) => { const hasId = isServerWithId(selectedServer); const serverId = hasId ? selectedServer.id : ''; const { pathname } = useLocation(); const asideClass = classNames('aside-menu', { 'aside-menu--hidden': !showOnMobile, }); const buildPath = (suffix: string) => `/server/${serverId}${suffix}`; return ( ); };