"""Evaluation of whether top examples of components have a theme.

- Each item is a list of examples. These are either random examples or component top examples.
- Evaluator is asked if there is a theme to this grouping of examples and, if so, to write it down (maybe have option of there is a theme but not sure how to explain it?).
- I'll only include the example text; no labels, model predictions, or coefficients.
"""
import abc
from typing import List, Optional

from transformers import PreTrainedTokenizer

from npeff_torch.examination.top_examples import top_examples_common
from npeff_torch.examination.top_examples import top_examples_latex

###############################################################################


R"""
Possible Options:
    - fraction of random example groups
    - whether to shuffle component top examples

    - number of examples to list
    - total number of groupings
"""

# Look at the human evals from SAE papers.

###############################################################################

_DEFAULT_LATEX_FILE_HEADER = R"""% Please use XeLaTex to handle unicode properly.
\documentclass[11pt]{article}

\usepackage[margin=1in]{geometry} 
\usepackage[dvipsnames]{xcolor}
\usepackage{bold-extra}

"""

###############################################################################


class HumevTopExamplesThemeLatexGeneratorAbc(abc.ABC):

    #######################################################
    # Equivalent of "protected" methods.

    def make_latex_file_header(self) -> str:
        return _DEFAULT_LATEX_FILE_HEADER

    #######################################################

    @abc.abstractmethod
    def make_latex_intro(self) -> str:
        # Should contain information to help reviewers about the task.
        raise NotImplementedError

    @abc.abstractmethod
    def make_example_latex_string(self, example_info: 'top_examples_common.TopExampleInfo') -> str:
        # Typically should just be the example text.
        # NOTE: Not all of the information will be present in the example_info.
        raise NotImplementedError

    #######################################################

    def generate_latex(
        self,
        example_groups: List[List['top_examples_common.TopExampleInfo']],
    ) -> str:
        ret = [
            self.make_latex_file_header(),
            '',
            R"\begin{document}",
            '',
            self.make_latex_intro(),
            '',
            R'\section{Groups}',
            '',
        ]

        for i, example_group in enumerate(example_groups):
            # To match the latex section headers, we use a 1-based index here.
            ret.append(R'\subsection{Group ' + str(i + 1) + R'}')
            
            if self.components_fontsize is not None:
                ret.append(R'\begin{' + self.components_fontsize + R'}')

            for example_info in example_group:
                ret.append(self.make_example_latex_string(example_info))

            if self.components_fontsize is not None:
                ret.append(R'\end{' + self.components_fontsize + R'}')

            ret.append('')

        ret.append(R"\end{document}")

        return "\n".join(ret)

    #######################################################

    @classmethod
    def create(
        cls,
        tokenizer: PreTrainedTokenizer,
        components_fontsize: Optional[str] = 'footnotesize',
        **kwargs,
    ):
        return cls(
            tokenizer=tokenizer,
            components_fontsize=components_fontsize,
            **kwargs,
        )
