from rlbench.task_environment import TaskEnvironment
from typing import List
from pyrep.objects.object import Object
import json
import re
import random
from pyrep.objects.shape import Shape
from pyrep.objects.joint import Joint
from pyrep.objects.dummy import Dummy
from pyrep.objects.proximity_sensor import ProximitySensor

def list_task_objects(env: TaskEnvironment) -> List[Object]:
    base = env._task.get_base()
    return base.get_objects_in_tree(exclude_base=True)

def to_camel_case(s):
    return ''.join(word.capitalize() for word in s.split('_'))

def object_names(env: TaskEnvironment, task_name: str = ""):
    objects_info = []
    task_objects = None
    if len(task_name) > 0:
        try:
            with open('./utils/object_mapping.json', 'r', encoding='utf-8') as f:
                task_objects_dict = json.load(f)['tasks']
                task_objects = task_objects_dict.get(task_name, None)
        except FileNotFoundError:
            print(f"WARNING: object_mapping.json not found. Falling back to default object filtering.")
            task_objects = None

    for o in list_task_objects(env):
        name = o.get_name()
        type = str(o.get_type())
        type_name = to_camel_case(type.split(".")[-1])
        
        if task_objects is not None:
            if name not in task_objects:
                continue
        else:
            if name != 'dirt_boundary' and any(sub in name for sub in ('waypoint', 'visual', 'spawn', 'wrap', 'topPlate', 'boundary', 'base', 'dynamic')):
                continue
            
            if task_name in ('WipeDesk',):
                exception_case_tuple = ('Cuboid',)
                if any(sub in name for sub in exception_case_tuple):
                    continue
            
            if task_name in ('UnplugCharger',):
                exception_case_tuple = ('hole', 'sensor')
                if any(sub in name for sub in exception_case_tuple):
                    continue
            
            if task_name in ('PutGroceriesInCupboard', 'PutAllGroceriesInCupboard'):
                exception_case_tuple = ('grasp_point', 'goal')
                if any(sub in name for sub in exception_case_tuple):
                    continue
        
        _type_registry = {'Shape': Shape, 'Joint': Joint, 'Dummy': Dummy, 'ProximitySensor': ProximitySensor}
        cls = _type_registry.get(type_name, None)
        obj = cls(name)
        pos = obj.get_position()
        # Convert numpy array to list for JSON serialization
        pos_list = pos.tolist() if hasattr(pos, 'tolist') else list(pos)
        objects_info.append({"type": type_name, "name": name, "position": pos_list})
    
    objects_info_str = ""
    for obj in objects_info:
        if "Cuboid" not in obj['name']:
            objects_info_str += f"\n- name: {obj['name']} | type: {obj['type']}"
    
    object_names = [obj['name'] for obj in objects_info if 'Cuboid' not in obj['name'] and 'phone_case' not in obj['name']]
    return objects_info_str, objects_info, object_names

def get_only_object_names(env: TaskEnvironment) -> List[str]:
    return [o.get_name() for o in list_task_objects(env)]

