from olym_gen.markdown_converter.markdown_convert_base import MarkdownConverterBase, get_parser
from typing import Any


class MarkdownConvertProof(MarkdownConverterBase):
    """
    Convert proof data to Markdown format.
    """

    @property
    def _title(self) -> str:
        return "Math Olympiad Proofs"

    def _get_subheader_content(self, data: dict[str, Any], index: str) -> str:
        """
        Get the content for the subheader.
        Args:
            data (dict[str, Any]): The dictionary containing the extracted data.
            index (str): The index name to use for the subheader.
        Returns:
            str: The subheader string.
        """
        subheader = f"{'#' * (self.index_names.index(index) + 1)} {index.capitalize()} {data.get(index + '_id', 'unknown')} "
        if index == 'problem':
            subheader += data.get('field', 'unknown').capitalize()
        subheader += "\n\n"
        return subheader

    def _get_subheader_description(self, data: dict[str, Any],
                                   index: str) -> str:
        if index == 'problem':
            description = self._hide_detail(content=data.get(
                'question', 'Not Available'),
                                            summary="Problem Description")
        elif index == 'proof':
            description = self._hide_detail(content=data.get(
                'orig_solution', 'Not Available'),
                                            summary="Original Solution")
        elif index == 'generate':
            description = self._hide_detail(content=data.get(
                'thinking', 'Not Available'),
                                            summary="Thinking Process")
            description += self._hide_detail(content=data.get(
                'new_solution', 'Not Available'),
                                             summary="New Solution")
        else:
            description = ""
        return description


def main():
    parser = get_parser()
    parser.add_argument(
        '--no_proof',
        action='store_true',
        help=
        "If set, the original proof data will not be included in the Markdown output."
    )
    args = parser.parse_args()
    converter = MarkdownConvertProof(
        save_dir=args.save_dir,
        index_names=['problem', 'proof', 'generate']
        if not args.no_proof else ['problem', 'generate'],
        output_dir=args.output_dir)
    converter.convert(args.lines)
    print(f"Markdown file saved to {converter.output_dir}")


if __name__ == "__main__":
    main()
