const PublishMessageWarning = (): void => {
  const publishForm: HTMLFormElement | null = document.querySelector(
    "form[data-submit='validate-message']"
  );

  if (publishForm) {
    const messageTextArea: HTMLTextAreaElement | null =
      publishForm.querySelector("[name='message']");
    const submitButton: HTMLButtonElement | null = publishForm.querySelector(
      "button[type='submit']"
    );
    const publishMessageWarning: HTMLDivElement | null =
      publishForm.querySelector("[id='publish-warning']");

    if (
      messageTextArea &&
      submitButton &&
      submitButton.dataset.btnTextWarning &&
      submitButton.dataset.btnText &&
      publishMessageWarning
    ) {
      publishForm.addEventListener("submit", (event) => {
        if (
          messageTextArea.value === "" &&
          publishMessageWarning.classList.contains("hidden")
        ) {
          event.preventDefault();

          publishMessageWarning.classList.remove("hidden");
          messageTextArea.focus();
          submitButton.innerText = submitButton.dataset
            .btnTextWarning as string;
        }
      });

      messageTextArea.addEventListener("input", () => {
        if (
          submitButton.innerText !== submitButton.dataset.btnText &&
          messageTextArea.value !== ""
        ) {
          publishMessageWarning.classList.add("hidden");
          submitButton.innerText = submitButton.dataset.btnText as string;
        }
      });
    }
  }
};

export default PublishMessageWarning;