PrimaryItems.tsx 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import { memo } from 'react';
  2. import dynamic from 'next/dynamic';
  3. import { SidebarContentsType } from '~/interfaces/ui';
  4. import { useIsAiEnabled } from '~/stores-universal/context';
  5. import { useSidebarMode } from '~/stores/ui';
  6. import { PrimaryItem } from './PrimaryItem';
  7. import styles from './PrimaryItems.module.scss';
  8. // Do not SSR Socket.io to make it work
  9. const PrimaryItemForNotification = dynamic(
  10. () => import('../InAppNotification/PrimaryItemForNotification').then(mod => mod.PrimaryItemForNotification), { ssr: false },
  11. );
  12. type Props = {
  13. onItemHover?: (contents: SidebarContentsType) => void,
  14. }
  15. export const PrimaryItems = memo((props: Props) => {
  16. const { onItemHover } = props;
  17. const { data: sidebarMode } = useSidebarMode();
  18. const { data: isAiEnabled } = useIsAiEnabled();
  19. if (sidebarMode == null) {
  20. return <></>;
  21. }
  22. return (
  23. <div className={styles['grw-primary-items']}>
  24. <PrimaryItem sidebarMode={sidebarMode} contents={SidebarContentsType.TREE} label="Page Tree" iconName="list" onHover={onItemHover} />
  25. <PrimaryItem sidebarMode={sidebarMode} contents={SidebarContentsType.CUSTOM} label="Custom Sidebar" iconName="code" onHover={onItemHover} />
  26. <PrimaryItem sidebarMode={sidebarMode} contents={SidebarContentsType.RECENT} label="Recent Changes" iconName="update" onHover={onItemHover} />
  27. <PrimaryItem sidebarMode={sidebarMode} contents={SidebarContentsType.BOOKMARKS} label="Bookmarks" iconName="bookmarks" onHover={onItemHover} />
  28. <PrimaryItem sidebarMode={sidebarMode} contents={SidebarContentsType.TAG} label="Tags" iconName="local_offer" onHover={onItemHover} />
  29. <PrimaryItemForNotification sidebarMode={sidebarMode} onHover={onItemHover} />
  30. {isAiEnabled && (
  31. <PrimaryItem
  32. sidebarMode={sidebarMode}
  33. contents={SidebarContentsType.AI_ASSISTANT}
  34. label="AI Assistant"
  35. iconName="growi_ai"
  36. isCustomIcon
  37. onHover={onItemHover}
  38. />
  39. )}
  40. </div>
  41. );
  42. });