import Avatar from '@/components/common/avatar';
import Card from '@/components/common/card';
import PageHeading from '@/components/common/page-heading';
import OwnerLayout from '@/components/layouts/owner';
import ErrorMessage from '@/components/ui/error-message';
import Loader from '@/components/ui/loader/loader';
import NotFound from '@/components/ui/not-found';
import Select from '@/components/ui/select/select';
import { Routes } from '@/config/routes';
import {
  useNotifyLogReadMutation,
  useNotifyLogsQuery,
} from '@/data/notify-logs';
import { useOrderQuery } from '@/data/order';
import { useMeQuery } from '@/data/user';
import { SortOrder } from '@/types';
import { adminAndOwnerOnly, getAuthCredentials } from '@/utils/auth-utils';
import cn from 'classnames';
import dayjs from 'dayjs';
import relativeTime from 'dayjs/plugin/relativeTime';
import timezone from 'dayjs/plugin/timezone';
import utc from 'dayjs/plugin/utc';
import { useTranslation } from 'next-i18next';
import { serverSideTranslations } from 'next-i18next/serverSideTranslations';
import { useRouter } from 'next/router';
import { useState } from 'react';
import { ActionMeta } from 'react-select';

dayjs.extend(relativeTime);
dayjs.extend(utc);
dayjs.extend(timezone);

const NotifyLogItem = ({ item }: any) => {
  const { t } = useTranslation();
  const router = useRouter();
  const { permissions } = getAuthCredentials();
  const { locale } = useRouter();

  const { mutate: seenNotifyLog, isLoading: creating } =
    useNotifyLogReadMutation();

  const orderID = item?.notify_type === 'order' ? item?.notify_tracker : '';

  const { order } = useOrderQuery({
    id: orderID,
    language: locale!,
  });

  let notifyLogText = '';
  switch (item?.notify_type) {
    case 'order':
      notifyLogText = 'text-created-new-order';
      break;

    case 'message':
      notifyLogText = 'text-sent-new-message';
      break;

    case 'store_notice':
      notifyLogText = 'text-sent-new-store-notice';
      break;
  }

  const handleClickOnNotification = (value: any) => {
    seenNotifyLog({ input: value });

    // prepare url for admin & vendor
    let redirectTo;
    switch (value?.notify_type) {
      case 'order':
        //@ts-ignore
        const shopURL = order?.shop?.slug;
        redirectTo = permissions?.includes('super_admin')
          ? Routes?.order?.details(value?.notify_tracker)
          : shopURL + Routes?.order?.details(value?.notify_tracker);
        break;

      case 'message':
        //@ts-ignore
        redirectTo = Routes?.shopMessage?.details(value?.notify_tracker);
        break;

      case 'store_notice':
        //@ts-ignore
        redirectTo =
          '/shops/' + Routes?.storeNotice?.details(value?.notify_tracker);

        break;
    }

    router.push('/' + redirectTo);
  };

  return (
    <>
      <div
        className={cn(
          "relative flex cursor-pointer rounded-lg bg-white p-4 border-s-4 before:absolute before:top-1/2 before:h-2.5 before:w-2.5 before:-translate-y-1/2 before:rounded-full before:bg-accent before:opacity-0 before:content-[''] before:end-4 md:before:end-7 xl:p-7",
          item?.is_read
            ? 'border-gray-300'
            : 'border-accent before:opacity-100',
        )}
        onClick={() => handleClickOnNotification(item)}
      >
        <Avatar
          name={item?.sender_user?.name}
          size="lg"
          src={item?.sender_user?.profile?.avatar.thumbnail}
        />
        <div className="ps-4">
          <div className="mb-0.5 gap-2 text-[15px]">
            <span className="font-semibold text-heading">
              {item?.sender_user?.name}
            </span>{' '}
            {t(notifyLogText)}
            <span
              className={cn(
                'inline-block font-medium text-accent hover:text-accent',
                item?.is_read ? 'text-gray-500/80' : 'text-accent',
              )}
            >
              #{item?.notify_tracker}
            </span>
          </div>
          <span
            className={cn(
              'text-sm font-medium',
              item?.is_read ? 'text-gray-500/80' : 'text-accent',
            )}
          >
            {dayjs(item?.created_at).format('MMM DD, YYYY')} at{' '}
            {dayjs(item?.created_at).format('hh:mm A')}
          </span>
        </div>
      </div>
    </>
  );
};

type Props = {
  onTargetFilter: (newValue: any, actionMeta: ActionMeta<unknown>) => void;
  className?: string;
};

function NotificationFilter({ onTargetFilter, className }: Props) {
  const { t } = useTranslation();
  const notificationTypeOptions = [
    { name: 'All', value: '' },
    { name: 'Order', value: 'order' },
    { name: 'Store Notice', value: 'store_notice' },
    { name: 'Messages', value: 'message' },
  ];
  return (
    <div className={cn('flex w-full', className)}>
      <div className="w-full">
        <Select
          options={notificationTypeOptions}
          getOptionLabel={(option: any) => option.name}
          getOptionValue={(option: any) => option.value}
          placeholder={t('common:filter-by-notification-type')}
          onChange={onTargetFilter}
          isClearable={true}
          defaultValue={[
            {
              name: 'All',
              value: '',
            },
          ]}
        />
      </div>
    </div>
  );
}

export default function NotifyLogsPageForVendor() {
  const { t } = useTranslation();
  const { locale } = useRouter();
  const [target, setTarget] = useState<string>('');
  const [page, setPage] = useState(1);
  const { data, isLoading: loading, error } = useMeQuery();

  const {
    notifyLogs,
    loading: loadingLogs,
    paginatorInfo,
    error: errorLogs,
  } = useNotifyLogsQuery({
    receiver: data?.id,
    notify_type: target,
    language: locale,
    limit: 30,
    orderBy: 'created_at',
    sortedBy: SortOrder.Desc,
    page,
  });

  if (loadingLogs) return <Loader text={t('common:text-loading')} />;
  if (error) return <ErrorMessage message={error.message} />;

  return (
    <>
      <Card className="mb-8 flex flex-col items-center md:flex-row">
        <div className="mb-4 md:mb-0 md:w-1/4">
          <PageHeading title={t('form:form-title-all-notifications')} />
        </div>

        <div className="flex w-full flex-col items-center space-y-4 ms-auto md:w-2/3 md:flex-row md:space-y-0 xl:w-3/4 2xl:w-2/5">
          {/* <NotificationFilter
            className="md:ms-6"
            onTargetFilter={(target: any) => {
              setTarget(target?.value!);
              setPage(1);
            }}
          /> */}
        </div>
      </Card>

      <div className={`space-y-3.5`}>
        {notifyLogs ? (
          notifyLogs?.map((item: any) => {
            return <NotifyLogItem item={item} key={item.id} />;
          })
        ) : (
          <NotFound text="text-no-log-found" className="mx-auto w-7/12" />
        )}
      </div>
    </>
  );
}

NotifyLogsPageForVendor.authenticate = {
  permissions: adminAndOwnerOnly,
};

NotifyLogsPageForVendor.Layout = OwnerLayout;
export const getServerSideProps = async ({ locale }: any) => ({
  props: {
    ...(await serverSideTranslations(locale, ['form', 'common', 'table'])),
  },
});
