import os
import shutil

from PIL import Image

SQUARE_SIZE = 97
DISTANCE_BETWEEN_SQUARES = 108
LEFT_PAGE_X = 8
RIGHT_PAGE_X = 301
PAGE_Y = 6
PAGE_WIDTH = 224
PAGE_HEIGHT = 330

TEST_IMAGE_XY = (114, 220)
TEST_IMAGE_SIZE = 108


def split_bongard_problem(image_path, output_path):
    whole_problem = Image.open(image_path).convert("RGB")

    os.makedirs(output_path, exist_ok=True)
    split_bongard_page(whole_problem, f"{output_path}/left", LEFT_PAGE_X, PAGE_Y)
    split_bongard_page(whole_problem, f"{output_path}/right", RIGHT_PAGE_X, PAGE_Y)
    split_bongard_problem_in_half(image_path, output_path)
    shutil.copy(image_path, f"{output_path}/whole.png")


def split_bongard_page(
    whole_problem: Image, output_path: str, x_location: int, y_location: int
):
    x = x_location
    y = y_location

    os.makedirs(output_path, exist_ok=True)

    for i in range(3):
        x = x_location
        for j in range(2):
            box = (x, y, x + SQUARE_SIZE, y + SQUARE_SIZE)
            region = whole_problem.crop(box)
            region.save(f"{output_path}/{i * 2 + j}.png")
            x += DISTANCE_BETWEEN_SQUARES
        y += DISTANCE_BETWEEN_SQUARES


def split_bongard_problem_in_half(image_path, output_path):
    os.makedirs(output_path, exist_ok=True)
    whole_problem = Image.open(image_path).convert("RGB")

    left_box = (0, 0, PAGE_WIDTH, PAGE_HEIGHT)
    right_box = (292, 0, 292 + PAGE_WIDTH, PAGE_HEIGHT)

    left_image = whole_problem.crop(left_box)
    left_image.save(f"{output_path}/left-full.png")

    right_image = whole_problem.crop(right_box)
    right_image.save(f"{output_path}/right.png")

    mask = Image.new("RGB", (TEST_IMAGE_SIZE, TEST_IMAGE_SIZE), color="white")

    left_image.paste(mask, TEST_IMAGE_XY)
    left_image.save(f"{output_path}/left.png")

    right_image.paste(mask, TEST_IMAGE_XY)
    right_image.save(f"{output_path}/right-full.png")
