from openai import OpenAI
from typing import Dict, List
import re
import os

class StyleAgent:
    def __init__(self, api_key: str = "", base_url: str = ""):
        self.llm_client = OpenAI(
            api_key=api_key,
            base_url=base_url
        )
    
        self.styles = self._load_styles()
    
    def select_style(self, markdown_text: str) -> str:
        """
        Select an appropriate style based on the paper's markdown content
        Args:
            markdown_text: The markdown content of the paper
        Returns:
            The selected style's CSS code
        """
        if not markdown_text:
            return self.get_default_style()
            
        prompt = f"""Analyze the overall style and content of this academic paper to select the most appropriate presentation style.

Paper content:
{markdown_text[:1500]}...

Available styles:
1. tech_dark:
   - Suitable for: High-tech presentations, AI/ML research, innovative technology
   - Features: Dark theme, neon accents, glassmorphism effects, modern animations

2. modern_blue:
   - Suitable for: Professional presentations, business content, solution proposals
   - Features: Clean modern design, blue color scheme, card-based layout

3. modern:
   - Suitable for: Technical content, innovative research, methodology presentations
   - Features: Clear hierarchical structure, clean design elements

4. academic:
   - Suitable for: Theoretical research, mathematical proofs, traditional disciplines
   - Features: Formal layout, traditional academic elements

5. minimalist:
   - Suitable for: Data visualization, experimental results, concise concepts
   - Features: Minimal decoration, emphasis on core content

6. vibrant:
   - Suitable for: Innovative achievements, interactive systems, application demonstrations
   - Features: Dynamic visual effects, modern design

Based on the paper's overall characteristics, select the most appropriate style.
Please only return the style name (modern/academic/minimalist/vibrant).
"""
        
        messages = [
            {"role": "system", "content": """You are a professional academic presentation design expert. Your task is to select the most appropriate presentation style based on the paper's overall content characteristics.
Please carefully analyze the paper's theoretical depth, technical nature, innovation, and visual elements to choose a style that best highlights the paper's key features."""},
            {"role": "user", "content": prompt}
        ]
        
        response = self.llm_client.chat.completions.create(
            model="deepseek-chat",
            messages=messages,
            stream=False
        )
        
        style_choice = response.choices[0].message.content.strip().lower()
        
     
        if style_choice in self.styles:
            return self.styles[style_choice]
        return self.get_default_style()  
    
    def get_default_style(self) -> str:
        return self.styles.get("tech_dark", self.styles.get("modern", ""))
    
 

    def _load_styles(self) -> Dict[str, str]:
        styles = {}
        style_dir = os.path.join(os.path.dirname(os.path.dirname(__file__)), 'styles')
    
        for style_file in os.listdir(style_dir):
            if style_file.endswith('.css'):
                style_name = os.path.splitext(style_file)[0]
                with open(os.path.join(style_dir, style_file), 'r', encoding='utf-8') as f:
                    styles[style_name] = f.read()
        
        return styles
