import React from "react";
import { useRouter } from "next/router";
import { useForm, Controller } from "react-hook-form";

// services
import { FileService } from "services/file.service";
// components
import { LiteTextEditorWithRef } from "@plane/lite-text-editor";
// ui
import { Button, Tooltip } from "@plane/ui";
import { Globe2, Lock } from "lucide-react";

// types
import type { IIssueComment } from "types";

const defaultValues: Partial<IIssueComment> = {
  access: "INTERNAL",
  comment_html: "",
};

type IIssueCommentEditor = {
  disabled?: boolean;
  onSubmit: (data: IIssueComment) => Promise<void>;
  showAccessSpecifier?: boolean;
};

type commentAccessType = {
  icon: any;
  key: string;
  label: "Private" | "Public";
};
const commentAccess: commentAccessType[] = [
  {
    icon: Lock,
    key: "INTERNAL",
    label: "Private",
  },
  {
    icon: Globe2,
    key: "EXTERNAL",
    label: "Public",
  },
];

// services
const fileService = new FileService();

export const IssueCommentEditor: React.FC<IIssueCommentEditor> = (props) => {
  const { disabled = false, onSubmit, showAccessSpecifier = false } = props;

  const editorRef = React.useRef<any>(null);

  const router = useRouter();
  const { workspaceSlug } = router.query;

  const {
    control,
    formState: { isSubmitting },
    handleSubmit,
    reset,
  } = useForm<IIssueComment>({ defaultValues });

  const handleAddComment = async (formData: IIssueComment) => {
    if (!formData.comment_html || isSubmitting) return;

    await onSubmit(formData).then(() => {
      reset(defaultValues);
      editorRef.current?.clearEditor();
    });
  };

  return (
    <form onSubmit={handleSubmit(handleAddComment)}>
      <div className="space-y-2">
        <div className="relative">
          {showAccessSpecifier && (
            <div className="absolute bottom-2 left-3 z-[1]">
              <Controller
                control={control}
                name="access"
                render={({ field: { onChange, value } }) => (
                  <div className="flex border border-custom-border-300 divide-x divide-custom-border-300 rounded overflow-hidden">
                    {commentAccess.map((access) => (
                      <Tooltip key={access.key} tooltipContent={access.label}>
                        <button
                          type="button"
                          onClick={() => onChange(access.key)}
                          className={`grid place-items-center p-1 hover:bg-custom-background-80 ${
                            value === access.key ? "bg-custom-background-80" : ""
                          }`}
                        >
                          <access.icon
                            className={`w-4 h-4 -mt-1 ${
                              value === access.key ? "!text-custom-text-100" : "!text-custom-text-400"
                            }`}
                          />
                        </button>
                      </Tooltip>
                    ))}
                  </div>
                )}
              />
            </div>
          )}
          <Controller
            name="access"
            control={control}
            render={({ field: { onChange: onAccessChange, value: accessValue } }) => (
              <Controller
                name="comment_html"
                control={control}
                render={({ field: { onChange: onCommentChange, value: commentValue } }) => (
                  <LiteTextEditorWithRef
                    onEnterKeyPress={handleSubmit(handleAddComment)}
                    uploadFile={fileService.getUploadFileFunction(workspaceSlug as string)}
                    deleteFile={fileService.deleteImage}
                    ref={editorRef}
                    value={!commentValue || commentValue === "" ? "<p></p>" : commentValue}
                    customClassName="p-3 min-h-[100px] shadow-sm"
                    debouncedUpdatesEnabled={false}
                    onChange={(comment_json: Object, comment_html: string) => onCommentChange(comment_html)}
                    commentAccessSpecifier={{ accessValue, onAccessChange, showAccessSpecifier, commentAccess }}
                  />
                )}
              />
            )}
          />
        </div>

        <Button variant="neutral-primary" type="submit" disabled={isSubmitting || disabled}>
          {isSubmitting ? "Adding..." : "Comment"}
        </Button>
      </div>
    </form>
  );
};