import json
from typing import Any, Dict, List
from copy import deepcopy

from stardojo.provider import BaseModuleProvider, BaseProvider
from stardojo.log import Logger
from stardojo.config import Config
from stardojo.memory import LocalMemory
from stardojo.provider import VideoRecordProvider
from stardojo import constants
from stardojo.utils.json_utils import parse_semi_formatted_text
from stardojo.utils.image_utils import segment_toolbar, segment_new_icon, segement_inventory

config = Config()
logger = Logger()
memory = LocalMemory()


class InformationGatheringProvider(BaseModuleProvider):

    def __init__(self,
                 *args,
                 template_path: str,
                 llm_provider: Any = None,
                 gm: Any = None,
                 **kwargs):

        super(InformationGatheringProvider, self).__init__(template_path = template_path, **kwargs)

        self.template_path = template_path
        self.llm_provider = llm_provider
        self.gm = gm


    @BaseModuleProvider.debug
    @BaseModuleProvider.error
    @BaseModuleProvider.write
    def __call__(self,
                 *args,
                 **kwargs):

        params = deepcopy(memory.working_area)

        self._check_input_keys(params)

        message_prompts = self.llm_provider.assemble_prompt(template_str=self.template, params=params)
        logger.debug(f'{logger.UPSTREAM_MASK}{json.dumps(message_prompts, ensure_ascii=False)}\n')

        response = {}
        try:
            response, info = self.llm_provider.create_completion(message_prompts)
            logger.debug(f'{logger.DOWNSTREAM_MASK}{response}\n')

            # Convert the response to dict
            response = parse_semi_formatted_text(response)

        except Exception as e:
            logger.error(f"Response of image description is not in the correct format: {e}, retrying...")

        self._check_output_keys(response)

        del params

        return response

class RDR2InformationGatheringProvider(BaseProvider):
    def __init__(self,
                 *args,
                 planner = None,
                 gm = None,
                 **kwargs):
        super(RDR2InformationGatheringProvider, self).__init__()
        self.planner = planner
        self.gm = gm

    def __call__(self, *args, **kwargs):

        params = deepcopy(memory.working_area)

        data = self.planner.information_gathering(input=params)

        response = data['res_dict']

        del params

        return response

class StardewInformationGatheringProvider(BaseProvider):
    def __init__(self,
                 *args,
                 planner = None,
                 gm = None,
                 **kwargs):
        super(StardewInformationGatheringProvider, self).__init__()
        self.planner = planner
        self.gm = gm

    def __call__(self, *args, **kwargs):

        params = deepcopy(memory.working_area)

        data = self.planner.information_gathering(input=params)

        response = data['res_dict']

        del params

        return response