"""
Text processing utilities for the LLM user simulator.
Contains attribute mappings and text formatting functions.
"""

ATTRIBUTE_NAME_MAPPING = {
    # Distance and location
    "distance_to_park_km": "proximity to the national park (in kms)",
    "location": "location",
    
    # Pricing
    "price": "nightly price",
    "budget": "total budget",
    
    # Quality ratings
    "review_score": "guest review ratings",
    "rating": "guest ratings", 
    "star_rating": "hotel star rating",
    
    # Hotel characteristics
    "brand": "hotel brand",
    "bed_type": "bed type",
    
    # Accommodation amenities (has_ prefix)
    "has_restaurant": "has an on-site restaurant",
    "has_pool": "has swimming pool",
    "has_kitchenette": "has kitchenette",
    "has_gym": "has fitnesss center",
    "has_air_conditioning": "has air conditioning",
    "has_airport_shuttle": "has airport shuttle service",
    "has_spa": "has spa facilities",
    
    # Accommodation amenities (simplified names)
    "pool": "swimming pool",
    "wifi": "WiFi availability",
    "fitness_center": "fitness facilities",
    "parking": "parking availability"
}


def get_natural_attribute_name(attribute: str) -> str:
    """Convert technical attribute name to natural language description."""
    return ATTRIBUTE_NAME_MAPPING.get(attribute, attribute.replace('_', ' '))


# def get_weight_context(weight: float) -> str:
#     """Provide contextual description for weight on 0-1 scale."""
#     # Weights are on 0-1 scale where 1.0 = highest importance, 0.0 = lowest
#     if weight >= 0.8:
#         return "very high priority"
#     elif weight >= 0.6:
#         return "high priority"
#     elif weight >= 0.4:
#         return "moderate priority" 
#     elif weight >= 0.2:
#         return "low priority"
#     else:
#         return "very low priority"


def format_constraints_natural_language(hard_constraints: list, start_number: int = 1) -> str:
    """Convert hard constraints JSON to natural language format with clear emphasis."""
    if not hard_constraints:
        return "No specific hard constraints provided."
    
    formatted_constraints = []
    for i, constraint in enumerate(hard_constraints, start_number):
        if isinstance(constraint, dict):
            # Handle structured constraint objects
            attribute = constraint['attribute']
            
            # Special handling for max_occupancy to clarify per-room meaning
            if attribute == 'max_occupancy':
                constraint_text = f"\t HARD CONSTRAINT {i}: {attribute.replace('_', ' ')} per room "
            else:
                constraint_text = f"\t HARD CONSTRAINT {i}: {attribute.replace('_', ' ')} "
            
            if "type" in constraint and "value" in constraint:
                constraint_text += f"{constraint['type'].replace('_', ' ')}: {constraint['value']}"
            else:
                constraint_text += str(constraint)
        elif isinstance(constraint, str):
            # Handle simple string constraints
            constraint_text = f"\t HARD CONSTRAINT {i}: {constraint}"
        else:
            constraint_text = f"\t HARD CONSTRAINT {i}: {str(constraint)}"
        formatted_constraints.append(constraint_text)
    
    return "\n".join(formatted_constraints)