import loggers.Logger as Logger
import cv2
import os


class Printer(Logger.Logger):
    def __init__(self, project_cfg) -> None:
        super().__init__(project_cfg=project_cfg)
        self.project_cfg = project_cfg
        print("PROJECT: ", self.project_cfg.project_name)
        if self.project_cfg.video_frequency > 0:
            self.video_path = os.path.join(self.project_cfg.log_dir, "videos")
            os.makedirs(self.video_path, exist_ok=True)

    def log(self, parameter, value, step, step_name=None):
        print(
            f"\nphase:{self.phase_name},step: {step}| parameter: {parameter} = {value}"
        )

    def finish(self):
        print("Finished Training")

    def log_video(self, video_id, video_frames, video_metrics, step):
        print(
            f"\nphase:{self.phase_name},step: {step}| VIDEO:{video_id} = {video_metrics}"
        )

        height, width, layers = video_frames[0].shape

        full_path = os.path.join(self.video_path, f"step_{step}_{video_id}.mp4")

        video = cv2.VideoWriter(
            full_path, cv2.VideoWriter_fourcc(*"mp4v"), 30, (width, height)
        )

        for frame in video_frames:
            video.write(cv2.cvtColor(frame, cv2.COLOR_RGB2BGR))

        video.release()
