from typing import Any, Dict, Tuple, Optional, List
import copy
import re

from rllm.environments.base.base_env import BaseEnv
from rllm.environments.games.twentyfortyeight_utils import GAME_CONFIG

WINDOW_WIDTH = 400
WINDOW_HEIGHT = 400
WINDOW_SCORE_HEIGHT = 60
WINDOW_BG_COLOR = (250, 248, 238)

BOARD_PADDING = 20
BOARD_BG_COLOR = (186, 172, 160)
TILE_PADDING = 5
TILE_COLOR_MAP = {
    0: (204, 193, 178),
    2: (238, 228, 218),
    4: (237, 224, 200),
    8: (242, 177, 121),
    16: (245, 149, 99),
    32: (246, 124, 95),
    64: (246, 94, 59),
    128: (237, 207, 114),
    256: (237, 204, 97),
    512: (237, 200, 80),
    1024: (237, 197, 63),
    2048: (237, 194, 46),
}
TILE_COLOR_DEFAULT = (60, 58, 50)
BORDER_RADIUS = 4

FONT_NAME = "Comic Sans MS"
FONT_DARK_COLOR = (119, 110, 101)
FONT_LIGHT_COLOR = (249, 246, 242)
FONT_SCORE_COLOR = (0, 0, 0)
FONT_SIZE = 40

class TwentyFortyEightEnv(BaseEnv):
    def __init__(self, task: dict):
        self.task = task
        self.max_turns = task.get("max_turns", 30)
        self.seed = task.get("seed", 1)

    def reset(self):
        pass

    def step(self, action: Any):
        pass

    def get_reward_and_next_obs(self, task: dict, action: Any):
        pass

    def from_dict(env_args: dict) -> "TwentyFortyEightEnv":
        return TwentyFortyEightEnv(task=env_args)