"""
This file contains data loader for the MECCANO dataset
"""

import os

import torch

from utils.utils import (
    _extract_frames_h5py,
    _sample_frames_gen_labels_h5py
)
import utils.logger as logging


logger = logging.get_logger(__name__)


class MECCANO(torch.utils.data.Dataset):
    """
    MECCANO loader
    """
    def __init__(self, cfg, mode='all', transforms=None):
        # Loading necessary paths and data
        self.cfg = cfg
        self.mode = mode
        self.transforms = transforms
        assert mode in ['train', 'val', 'test', 'all'], ('Wrong mode selected'
        '. Options are: train, val, test, all')
        videos_path = self.cfg.MECCANO.VIDEOS_DIR
        anns_path = self.cfg.MECCANO.ANNS_DIR
        assert os.path.isdir(videos_path), 'Wrong videos path provided!'
        assert os.path.isdir(anns_path), ('Wrong annotations path '
                                                    'provided!')
        self.videos = [
            os.path.join(videos_path, file) for file in os.listdir(videos_path)
        ]
        self.annotations = [
            os.path.join(anns_path, file) for file in os.listdir(anns_path)
        ]
        assert len(self.videos) == len(self.annotations), 'Trahimaam!'

        if self.mode == 'all':
            # No need to trim the videos and annotations list
            pass
        elif self.mode == 'train':
            raise NotImplementedError
        elif self.mode == 'val':
            raise NotImplementedError
        elif self.mode == 'test':
            raise NotImplementedError

        self._construct_loader()

    def _construct_loader(self):
        """
        This method constructs the video and annotation loader

        Returns:
            None
        """
        self.package = list()
        # Sorting the videos based on subject number
        self.videos = sorted(
            self.videos, key=lambda a: a.split('/')[-1].split('.')[0]
    )
        for video in self.videos:
            video_name = video.split('/')[-1].split('.')[0]
            for annotation in self.annotations:
                if video_name in annotation:
                    self.package.append((video, annotation))
                    break
        assert len(self.package) == len(self.videos) == len(self.annotations)

    def __len__(self):
        """
        Returns:
            (int): number of videos and annotations in the dataset
        """
        return len(self.package)

    def __getitem__(self, index):
        video_path, annotation_path = self.package[index]
        h5_file_path = _extract_frames_h5py(
            video_path,
            self.cfg.MECCANO.FRAMES_DIR
        )
        frames, labels = _sample_frames_gen_labels_h5py(
            self.cfg,
            h5_file_path,
            video_path,
            annotation_path,
            transforms=self.transforms
        )
        return frames, labels, video_path.split('/')[-1].split('.')[0]
