import os
import sys
import time
import gymnasium as gym
import numpy as np

# Add project root to Python path to find the env module
repo_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.append(repo_path)

def main():
    # # Register the environment with GUI enabled
    gym.register(
        id='traffic-stop-all-v0',
        entry_point='env.turtlebot_env2:TurtlebotEnv2',
        max_episode_steps=1000,
        kwargs={
            'gui': True,  # Enable GUI for visualization
            'tb2_speed': 0.5,
            'tb3_speed': 0.3,
            'render_mode': 'human'  # Enable human rendering
        }
    )
    
    gym.register(
        id='traffic-stop-v0',
        entry_point='env.turtlebot_env:TurtlebotEnv',
        max_episode_steps=1000,
        kwargs={
            'gui': True,  # Enable GUI for visualization
            'tb2_speed': 0.5,
            'render_mode': 'human'  # Enable human rendering
        }
    )
    
    gym.register(
        id='fetch-v0',
        entry_point='env.fetch_env:FetchEnv',
        max_episode_steps=1000,
        kwargs={
            'gui': True,  # Enable GUI for visualization
            'render_mode': 'human'  # Enable human rendering
        }
    )

    # Create environment
    # env = gym.make('traffic-stop-all-v0')
    env = gym.make('fetch-v0')
    # Get the underlying environment from the wrapper
    unwrapped_env = env.unwrapped
    
    print("Keyboard Teleop Controls:")
    print("------------------------")
    print("Arrow Keys: Control the robot")
    print("  ↑: Move forward")
    print("  ↓: Move backward")
    print("  ←: Turn left")
    print("  →: Turn right")
    print("Q: Quit")
    print("------------------------")

    try:
        # Reset environment
        obs, _ = env.reset()
        
        done = False
        total_reward = 0
        steps = 0
        
        while not done:
            # Process keyboard events and get robot state
            unwrapped_env.sim.process_keyboard_events()
            
            # Apply keyboard controls
            unwrapped_env.sim.keyboard_teleop()
            
            # Step simulation
            obs, reward, terminated, truncated, info = env.step([0, 0])  # Dummy action, real control is via keyboard
            done = terminated or truncated
            
            total_reward += reward
            steps += 1
            
            # Print relevant information
            if steps % 10 == 0:  # Print every 10 steps to avoid spam
                # position, orientation = unwrapped_env.sim.fetch_controller.get_pose()
                print(f"\rStep: {steps} | Reward: {total_reward:.2f} | Done: {done}", end="")
            
            # Optional: add a small sleep to control simulation speed
            time.sleep(0.01)
            
            if done:
                print(f"\nEpisode finished after {steps} steps")
                print(f"Final reward: {total_reward}")
                print(f"End reason: {info.get('reason', 'unknown')}")
                
                # Ask if user wants to reset and continue
                user_input = input("\nPress 'R' to reset, 'Q' to quit: ").lower()
                if user_input == 'r':
                    obs, _ = env.reset()
                    done = False
                    total_reward = 0
                    steps = 0
                else:
                    break

    except KeyboardInterrupt:
        print("\nManually interrupted")
    finally:
        env.close()
        print("Environment closed")

if __name__ == "__main__":
    main()
