import random
import pandas as pd
import os
from datetime import datetime
from ecc_area import get_v2_highlight_coords
from utils import convert_to_image


def shuffle_ecc_bits(qr_string, ec_level="L"):
    """
    Shuffle only the error correction codeword area of the QR code.

    Args:
        qr_string (str): 25x25=625 bits '0'/'1' string
        ec_level (str): ECC level ('L', 'M', 'Q', 'H')

    Returns:
        str: New bit string with only the ECC area shuffled
    """
    size = 25
    coords = get_v2_highlight_coords(ec_level)
    idxs = [r * size + c for r, c in coords]

    qr_list = list(qr_string)
    ecc_bits = [qr_list[i] for i in idxs]
    random.shuffle(ecc_bits)
    for i, idx in enumerate(idxs):
        qr_list[idx] = ecc_bits[i]
    return ''.join(qr_list)


if __name__ == "__main__":
    version = 2
    mask = 0
    ec_levels = ['L', 'M', 'Q', 'H']
    
    for ec_level in ec_levels:
        base_dir = f"./dataset_segno/ver{version}"
        data_dir = f"data_domain_ver{version}_mask{mask}_{ec_level}_sensitivity"
        input_dir = os.path.join(base_dir, data_dir)
        output_dir = os.path.join(input_dir, "ecc_shuffled/")
        input_file = os.path.join(input_dir, "testset.csv")
        
        if not os.path.exists(output_dir):
            os.makedirs(output_dir)
            
        df = pd.read_csv(input_file)
        
        output_df = pd.DataFrame()
        output_df['target'] = df['target']
        output_df['input'] = df['input']
        output_df['ecc_shuffled'] = df['input'].apply(
            lambda x: shuffle_ecc_bits(x, ec_level=ec_level)
        )
        
        output_df.to_csv(
            os.path.join(output_dir, "dataset_ecc_shuffled.csv"),
            index=False
        )
        
        with open(os.path.join(output_dir, 'setting.txt'), 'w') as f:
            f.write(f"date and time: {datetime.now()}\n")
            f.write(f"version: {version}\n")
            f.write(f"mask: {mask}\n")
            f.write(f"ec_level: {ec_level}\n")
            f.write(f"input_file: {input_file}\n")
            f.write(f"output_dir: {output_dir}\n")
            f.write(f"data_num: {len(output_df)}\n")


    sample = '1111111011100110001111111100000100001101010100000110111010000111111010111011011101011010001101011101101110100100010100101110110000010010111100010000011111111010101010101111111000000000001010110000000000101110110110010100010011000100010111111011000001000001110001101001010101100100101010101010011000010000111001101000101000010011100001101001111000011110111011110010011010010110111000100010110110010001101000111010110111111100100000000101001001000110111111111000101110101010011100000101111001110001001110111010100101001111100001011101001100010010111110101110101011011010101100110000010010100110011100101111111001110011000011011'
    
    img = convert_to_image(sample)
    img.save('original.png')
    
    shuffled = shuffle_ecc_bits(sample, ec_level="L")
    img = convert_to_image(shuffled)
    img.save('shuffled.png')