from struct import dataclass
from rlnav.robot.tasks.task import BaseNavTask, TaskConfig


@dataclass
class ExploreTaskConfig(TaskConfig):
    pass


class ExploreTask(BaseNavTask):
    def sample_goal(self, observation: dict):
        return {}

    def compute_step(
        self,
        observation: dict,
        action: np.ndarray,
        next_observation: dict,
        goal: dict,
        num_steps: int,
    ) -> Tuple[float, bool, dict]:
        # Compute reward, termination, etc. from the base task
        reward, truncated, terminated, info = self.compute_step(
            observation, action, next_observation, goal, num_steps
        )

        # Survival reward
        reward = 1.0

        return (
            reward,
            truncated,
            terminated,
            info,
        )

    def __init__(self, config: ExploreTaskConfig):
        super().__init__(config)
