import numpy as np
import gymnasium as gym

import shapely
from shapely import Point

import os
from typing import Optional

from loguru import logger

from shapely import LineString

from ..colour_utils import Highlight

from molecule_movement.envs.MoleculeEnvironment import MoleculeEnvironment
from molecule_movement import Goal, Obstacle, Molecule
from molecule_movement.parsing import FixedVoltageDataParser, MoleculeDataProcessor
from molecule_movement.sampling import CircularSampler, Sampler
from molecule_movement.matching import RandomMatching, GreedyMatching, HungarianMatching
from molecule_movement.scheduling import SATBasedScheduling, SortScheduling
from molecule_movement.shapes import RECTANGLE, TRIANGLE, DDNB, resize



class EmptyEnvironment(MoleculeEnvironment):
    def __init__(
            self,
            molecule_transition_data_x: str | os.PathLike,
            molecule_transition_data_y: str | os.PathLike,
            molecule_rotation_data: str | os.PathLike,
            molecules: list[Molecule],
            goals: list[Goal],
            obstacles: list[Obstacle],
            **kwargs
            ):
        self.molecule_transition_data_x = molecule_transition_data_x
        self.molecule_transition_data_y = molecule_transition_data_y
        self.molecule_rotation_data     = molecule_rotation_data

        self.molecules = molecules
        self.obstacles = goals
        self.goals = obstacles

        super().__init__(**kwargs)

    def _parse_molecule_data(self):
        self.data_processor = MoleculeDataProcessor(FixedVoltageDataParser(self.molecule_transition_data_x, self.molecule_transition_data_y, self.molecule_rotation_data, voltage=1700, name="DDNB"),
                                                    dimensions_x=(-2.1, 2.1),
                                                    dimensions_y=(-2.1, 2.1),
                                                    step_x=0.3,
                                                    step_y=0.3)
        self.molecule_transition_data = self.data_processor.get_molecular_data()

    def _create_initial_distribution(self, seed: Optional[int] = None):
        pass

    def _set_goals(self, seed: Optional[int] = None) -> None:
        pass

    def _set_obstacles(self, seed: Optional[int] = None) -> None:
        pass

    def _get_matching(self, seed: Optional[int] = None):
        self.matching = HungarianMatching(self.molecules, self.goals).compute_matching()
