from isaaclab.utils import configclass

from .rough_env_cfg import AnymalDRoughEnvCfg
# from p4rl.tasks.locomotion.velocity.velocity_env_cfg import ObservationsWithHistoryCfg, ObservationsWithNoiseFreeHistoryCfg, ObservationsWithHistoryNEWCfg
from p4rl.tasks.locomotion.velocity.velocity_env_cfg import ObservationsWithHistoryNEWCfg


@configclass
class AnymalDFlatEnvCfg(AnymalDRoughEnvCfg):
    def __post_init__(self):
        # post init of parent
        super().__post_init__()

        # override rewards
        self.rewards.flat_orientation_l2.weight = -5.0
        self.rewards.dof_torques_l2.weight = -2.5e-5
        self.rewards.feet_air_time.weight = 0.5
        # change terrain to flat
        self.scene.terrain.terrain_type = "plane"
        self.scene.terrain.terrain_generator = None
        # no height scan
        self.scene.height_scanner = None
        self.observations.policy.height_scan = None
        # no terrain curriculum
        self.curriculum.terrain_levels = None


class AnymalDFlatEnvCfg_PLAY(AnymalDFlatEnvCfg):
    def __post_init__(self) -> None:
        # post init of parent
        super().__post_init__()

        # make a smaller scene for play
        self.scene.num_envs = 50
        self.scene.env_spacing = 2.5
        # disable randomization for play
        self.observations.policy.enable_corruption = False
        # remove random pushing
        self.events.base_external_force_torque = None
        self.events.push_robot = None

        ## IF RECORDING VIDEO:
        self.viewer.origin_type = "asset_root"
        self.viewer.env_index = 0
        # self.viewer.eye = (6.0, 6.0, 6.0)
        self.viewer.eye = (2.5, 2.5, 2.5)
        self.viewer.lookat = (0.0, 0.0, 0.0)
        self.viewer.asset_name = "robot"


@configclass
class InvDynamicLocomotionVelocityFlatEnvCfg(AnymalDFlatEnvCfg):
    """Configuration for the locomotion environment specifically for P4RL learning with pretrained dynamics module."""
    def __post_init__(self) -> None:
        # post init of parent
        super().__post_init__()
        self.observations = ObservationsWithHistoryNEWCfg()

@configclass
class InvDynamicLocomotionVelocityFlatEnvCfg_PLAY(AnymalDFlatEnvCfg_PLAY):
    """Configuration for the locomotion environment specifically for P4RL learning with pretrained dynamics module."""
    def __post_init__(self) -> None:
        # post init of parent
        super().__post_init__()
        self.observations = ObservationsWithHistoryNEWCfg()


# @configclass
# class ForDynamicLocomotionVelocityFlatEnvCfg(AnymalDFlatEnvCfg):
#     """Configuration for the locomotion environment specifically for P4RL learning with pretrained dynamics module."""
#     def __post_init__(self) -> None:
#         # post init of parent
#         super().__post_init__()
#         self.observations = ObservationsWithHistoryCfg()

# @configclass
# class ForDynamicLocomotionVelocityFlatEnvCfg_PLAY(AnymalDFlatEnvCfg_PLAY):
#     """Configuration for the locomotion environment specifically for P4RL learning with pretrained dynamics module."""
#     def __post_init__(self) -> None:
#         # post init of parent
#         super().__post_init__()

#         self.observations = ObservationsWithHistoryCfg()
#         self.observations.policy.enable_corruption = False


# @configclass
# class DynamicsDataCollectionLocomotionVelocityFlatEnvCfg(AnymalDFlatEnvCfg):
#     """Configuration for the locomotion environment specifically for dynamics data collection."""
#     def __post_init__(self) -> None:
#         # post init of parent
#         super().__post_init__()
#         self.observations = ObservationsWithNoiseFreeHistoryCfg()