import {useMemo, useEffect} from 'react';
import LayoutDefault from '../layouts/Default';
import moment from 'moment';
import {useRouter} from 'next/router';
import Loading from '../containers/Loading';
import DashboardEvents from '../containers/DashboardEvents';
import DashboardEmpty from '../containers/DashboardEmpty';
import Fab from '../containers/Fab';
import {useTranslation} from 'react-i18next';
import {makeStyles} from '@material-ui/core/styles';
import useProfile from '../hooks/useProfile';
import useAuthStore from '../stores/useAuthStore';
const Dashboard = () => {
  const isAuth = useAuthStore(s => !!s.token);
  const {profile, isReady} = useProfile();
  const router = useRouter();
  const {t} = useTranslation();
  const classes = useStyles();
  const {events = []} = profile || {};
  useEffect(() => {
    if (!isAuth) router.push('/');
  }, [isAuth]);
  const pastEvents = useMemo(
    () =>
      events
        .filter(({date}) => date && moment(date).isBefore(moment(), 'day'))
        .sort(sortDesc),
    [events]
  );
  const futureEvents = useMemo(
    () =>
      events
        .filter(({date}) => date && moment(date).isSameOrAfter(moment(), 'day'))
        .sort(sortDesc),
    [events]
  );
  const noDateEvents = useMemo(() => events.filter(({date}) => !date), [
    events,
  ]);
  if (!isAuth || !isReady)
    return (
      
        
      
    );
  const menuActions = [
    {
      label: t('menu.new_event'),
      onClick: () => router.push('/'),
      id: 'AddEventTabs',
    },
    {
      label: t('menu.profile'),
      onClick: () => router.push('/profile'),
      id: 'ProfileTabs',
    },
  ];
  return (
    
      {!events || events.length === 0 ? (
        
      ) : (
        
      )}
       router.push('/')} aria-label="add-event">
        {t('dashboard.actions.add_event')}
      
    
  );
};
const sortDesc = ({date: dateA}, {date: dateB}) => dateB.localeCompare(dateA);
const useStyles = makeStyles(theme => ({
  root: {
    marginTop: theme.mixins.toolbar.minHeight,
  },
}));
export default Dashboard;