import numpy as np
from furniture_bench_api.api.api_skills import APISkills
from furniture_bench_api.furniture_bench_environment import FurnitureBenchEnvironment
import json
import logging
import uuid
from dataclasses import dataclass
from datetime import datetime
from pathlib import Path
from typing import Dict, Optional

import open3d
from furniture_bench.envs.furniture_sim_env import ASSET_ROOT

# import uuid

# isort: off
import cv2
import furniture_bench
from furniture_bench.sim_config import sim_config
import torch


# isort: on

print(furniture_bench.__name__)
import gymnasium as gym
from isaacgym import gymtorch
from python_utils.transformations import absolute_to_relative, affine_transform

from furniture_bench_api.utils.pose_utils import (
    get_part_poses_from_obs,
    get_pose_from_obs,
    transform_pose_in_local_coords,
)

env = gym.make(
    "FurnitureSim-v0",
    furniture="lamp",  # Specifies the type of furniture [lamp | square_table | desk | drawer | cabinet | round_table | stool | chair | one_leg].
    num_envs=1,  # Number of parallel environments.
    obs_keys=[
            "robot_state/ee_pos",
            "robot_state/ee_quat",
            "robot_state/ee_pos_vel",
            "robot_state/ee_ori_vel",
            "robot_state/gripper_width",
            "robot_state/joint_positions",
            "color_image1",
            "color_image2",
            "parts_poses",
        ]
,  # List of observations.
    concat_robot_state=False,  # Whether to return robot_state in a vector or dictionary.
    use_april_tag_coords=False,  # Whether to use AprilTag coordinates for parts
    resize_img=False,  # If true, images are resized to 224 x 224.
    headless=True,  # If true, simulation runs without GUI.
    compute_device_id=0,  # GPU device ID for simulation.
    graphics_device_id=0,  # GPU device ID for rendering.
    init_assembled=False,  # If true, the environment is initialized with assembled furniture.
    np_step_out=False,  # If true, env.step() returns Numpy arrays.
    channel_first=False,  # If true, images are returned in channel first format.
    randomness="low",  # Level of randomness in the environment [low | med | high].
    high_random_idx=-1,  # Index of the high randomness level (range: [0-2]). Default -1 will randomly select the index within the range.
    save_camera_input=False,  # If true, the initial camera inputs are saved.
    record=True,  # If true, videos of the wrist and front cameras' RGB inputs are recorded.
    max_env_steps=1000,  # Maximum number of steps per episode.
    act_rot_repr="quat",  # Representation of rotation for action space. Options are 'quat' and 'axis'.
)
env.reset()
n_env = env.env.env
def action_tensor(ac):
    if isinstance(ac, (list, np.ndarray)):
        return torch.tensor(ac).float().to(n_env.device)

    ac = ac.clone()
    if len(ac.shape) == 1:
        ac = ac[None]
    return ac.tile(1, 1).float().to(n_env.device)

done = False
while not done:
    action, skill_complete = n_env.get_assembly_action()
    action = action_tensor(action)
    ob, rew, done, _ = env.step(action)

n_env.video_writer.release()