import React from "react";

import Link from "next/link";
import { useRouter } from "next/router";

// mobx
import { observer } from "mobx-react-lite";
// lib
import { useMobxStore } from "lib/mobx/store-provider";
// components
import { CommentCard, AddComment } from "components/issues/peek-overview";
// ui
import { Icon, PrimaryButton } from "components/ui";
// types
import { IIssue } from "types/issue";

type Props = {
  issueDetails: IIssue;
};

export const PeekOverviewIssueActivity: React.FC<Props> = observer((props) => {
  const router = useRouter();
  const { workspace_slug } = router.query;

  const { issueDetails: issueDetailStore, project: projectStore, user: userStore } = useMobxStore();

  const comments = issueDetailStore.details[issueDetailStore.peekId || ""]?.comments || [];

  const user = userStore?.currentUser;

  return (
    <div className="pb-10">
      <h4 className="font-medium">Activity</h4>
      {workspace_slug && (
        <div className="mt-4">
          <div className="space-y-4">
            {comments.map((comment: any) => (
              <CommentCard key={comment.id} comment={comment} workspaceSlug={workspace_slug?.toString()} />
            ))}
          </div>
          {user ? (
            <>
              {projectStore.deploySettings?.comments && (
                <div className="mt-4">
                  <AddComment disabled={!userStore.currentUser} />
                </div>
              )}
            </>
          ) : (
            <div className="bg-custom-background-80 px-2 py-2.5 flex items-center justify-between gap-2 border border-custom-border-300 rounded mt-4">
              <p className="flex gap-2 text-sm text-custom-text-200 break-words overflow-hidden">
                <Icon iconName="lock" className="!text-sm" />
                Sign in to add your comment
              </p>
              <Link href={`/?next_path=${router.asPath}`}>
                <a>
                  <PrimaryButton className="flex-shrink-0 !px-7">Sign in</PrimaryButton>
                </a>
              </Link>
            </div>
          )}
        </div>
      )}
    </div>
  );
});