// @flow import type { Node } from 'react'; import * as PAGES from 'constants/pages'; import * as ICONS from 'constants/icons'; import React from 'react'; import Button from 'component/button'; import classnames from 'classnames'; import NotificationBubble from 'component/notificationBubble'; import { PINNED_LABEL_1, PINNED_URI_1, PINNED_URI_2, PINNED_LABEL_2 } from 'config'; // @if TARGET='app' import { IS_MAC } from 'component/app/view'; // @endif const ESCAPE_KEY_CODE = 27; const BACKSLASH_KEY_CODE = 220; const HOME = { label: 'Home', navigate: `/`, icon: ICONS.HOME, }; const RECENT_FROM_FOLLOWING = { label: 'Following', navigate: `/$/${PAGES.CHANNELS_FOLLOWING}`, icon: ICONS.SUBSCRIBE, }; type Props = { subscriptions: Array, followedTags: Array, email: ?string, uploadCount: number, doSignOut: () => void, sidebarOpen: boolean, setSidebarOpen: boolean => void, isMediumScreen: boolean, isOnFilePage: boolean, unreadCount: number, purchaseSuccess: boolean, doClearPurchasedUriSuccess: () => void, user: ?User, }; function SideNavigation(props: Props) { const { subscriptions, followedTags, doSignOut, email, purchaseSuccess, doClearPurchasedUriSuccess, sidebarOpen, setSidebarOpen, isMediumScreen, isOnFilePage, unreadCount, user, } = props; const TOP_LEVEL_LINKS: Array<{ label: string, navigate: string, icon: string, extra?: Node, hideForUnauth?: boolean, }> = [ HOME, RECENT_FROM_FOLLOWING, { label: 'Your Tags', navigate: `/$/${PAGES.TAGS_FOLLOWING}`, icon: ICONS.TAG, hideForUnauth: true, }, { label: 'Discover', navigate: `/$/${PAGES.DISCOVER}`, icon: ICONS.DISCOVER, }, { label: IS_WEB ? 'Purchased' : 'Library', navigate: `/$/${PAGES.LIBRARY}`, icon: ICONS.PURCHASED, hideForUnauth: true, }, { ...(PINNED_URI_1 && PINNED_LABEL_1 ? { label: PINNED_LABEL_1, navigate: PINNED_URI_1, icon: ICONS.PINNED, } : {}), }, { ...(PINNED_URI_2 && PINNED_LABEL_2 ? { label: PINNED_LABEL_2, navigate: PINNED_URI_2, icon: ICONS.PINNED, } : {}), }, ]; const ABSOLUTE_LINKS: Array<{ label: string, navigate?: string, onClick?: () => any, icon: string, extra?: Node, hideForUnauth?: boolean, }> = [ { label: 'Upload', navigate: `/$/${PAGES.UPLOAD}`, icon: ICONS.PUBLISH, }, { label: 'New Channel', navigate: `/$/${PAGES.CHANNEL_NEW}`, icon: ICONS.CHANNEL, hideForUnauth: true, }, { label: 'Uploads', navigate: `/$/${PAGES.UPLOADS}`, icon: ICONS.PUBLISH, hideForUnauth: true, }, { label: 'Channels', navigate: `/$/${PAGES.CHANNELS}`, icon: ICONS.CHANNEL, hideForUnauth: true, }, { label: 'Creator Analytics', navigate: `/$/${PAGES.CREATOR_DASHBOARD}`, icon: ICONS.ANALYTICS, hideForUnauth: true, }, { label: 'Wallet', navigate: `/$/${PAGES.WALLET}`, icon: ICONS.WALLET, hideForUnauth: true, }, { label: 'Notifications', navigate: `/$/${PAGES.NOTIFICATIONS}`, icon: ICONS.NOTIFICATION, extra: , hideForUnauth: true, }, { label: 'Rewards', navigate: `/$/${PAGES.REWARDS}`, icon: ICONS.REWARDS, hideForUnauth: true, }, { label: 'Invites', navigate: `/$/${PAGES.INVITE}`, icon: ICONS.INVITE, hideForUnauth: true, }, { label: 'Settings', navigate: `/$/${PAGES.SETTINGS}`, icon: ICONS.SETTINGS, hideForUnauth: true, }, { label: 'Help', navigate: `/$/${PAGES.HELP}`, icon: ICONS.HELP, hideForUnauth: true, }, { label: 'Sign Out', onClick: doSignOut, icon: ICONS.SIGN_OUT, hideForUnauth: true, }, ]; const UNAUTH_LINKS: Array<{ label: string, navigate: string, icon: string, extra?: Node, hideForUnauth?: boolean, }> = [ { label: 'Sign In', navigate: `/$/${PAGES.AUTH_SIGNIN}`, icon: ICONS.SIGN_IN, }, { label: 'Sign Up', navigate: `/$/${PAGES.AUTH}`, icon: ICONS.SIGN_UP, }, { label: 'Settings', navigate: `/$/${PAGES.SETTINGS}`, icon: ICONS.SETTINGS, }, { label: 'Help', navigate: `/$/${PAGES.HELP}`, icon: ICONS.HELP, }, ]; const notificationsEnabled = user && user.experimental_ui; const isAuthenticated = Boolean(email); const [pulseLibrary, setPulseLibrary] = React.useState(false); const isPersonalized = !IS_WEB || isAuthenticated; const isAbsolute = isOnFilePage || isMediumScreen; const microNavigation = !sidebarOpen || isMediumScreen; const subLinks = email ? ABSOLUTE_LINKS.filter(link => { if (!notificationsEnabled && link.icon === ICONS.NOTIFICATION) { return false; } return true; }) : UNAUTH_LINKS; React.useEffect(() => { if (purchaseSuccess) { setPulseLibrary(true); let timeout = setTimeout(() => { setPulseLibrary(false); doClearPurchasedUriSuccess(); }, 2500); return () => clearTimeout(timeout); } }, [setPulseLibrary, purchaseSuccess, doClearPurchasedUriSuccess]); React.useEffect(() => { function handleKeydown(e: SyntheticKeyboardEvent<*>) { if (e.keyCode === ESCAPE_KEY_CODE && isAbsolute) { setSidebarOpen(false); } else if (e.keyCode === BACKSLASH_KEY_CODE) { const hasActiveInput = document.querySelector('input:focus'); if (!hasActiveInput) { setSidebarOpen(!sidebarOpen); } } } window.addEventListener('keydown', handleKeydown); return () => window.removeEventListener('keydown', handleKeydown); }, [sidebarOpen, setSidebarOpen, isAbsolute]); return (
{!isOnFilePage && ( )} {(isOnFilePage || isMediumScreen) && sidebarOpen && ( <>
setSidebarOpen(false)} /> )}
); } export default SideNavigation;