import sys

from klayout import db
from klayout import lay
import pya
import os
from tqdm import tqdm

def gds_to_txt_img(file_dir, output_dir, output_type = 'png'):
    output_types = ['png', 'oas', 'txt']
    if output_type not in output_types:
        raise ValueError('output_type must be one of {}'.format(output_types))
    if not os.path.exists(output_dir):
        os.makedirs(output_dir, exist_ok=True)
    file_lists = os.listdir(file_dir)
    for file in tqdm(file_lists):
        # input_file = file_dir
        input_file = os.path.join(file_dir, file)
        layout = db.Layout()
        layout.read(input_file)
        layout_view = lay.LayoutView()
        layout_view.set_config("background-color", "#FFFFFF")
        layout_view.set_config("grid-visible", "false")
        layout_view.show_layout(layout, False)
        layout_view.max_hier()
        top_cell = layout.top_cell()
        layout_view.active_cellview().cell = top_cell
        # for lyp in layout_view.each_layer():
        #     if lyp.layer_index() == 1:
        #         lyp.fill_color = 4294967295
        #         lyp.frame_color = 4294967295
        #         lyp.dither_pattern = 0
        #         lyp.transparent = True
        #     if lyp.layer_index() == 0:
        #         lyp.fill_color = 4279966491
        #         lyp.frame_color = 4279966491
        #         lyp.dither_pattern = 0
        #         lyp.transparent = True
        box = top_cell.bbox()
        # print(box.width()//100, box.height()//100)
        # file_name = file_dir.split('.')[0]
        file_name = file.split('.')[0]
        # print(file_name)
        # img_dir = file_name + '.png'
        # txt_dir = file_name + '.txt'
        # oas_dir = file_name + '.oas'
        # img_dir = file_dir.replace('.oas','.png')
        # txt_dir = file_dir.replace('.oas','.txt')
        output_file_name = file_name + '.' + output_type
        output_file = os.path.join(output_dir, output_file_name)
        if output_type == 'png':
            layout_view.save_image_with_options(output_file, 256, 256)
        else:
            layout.write(output_file)
        # layout_view.save_image_with_options(img_dir, box.width()//20, box.height()//20)
        # layout.write(txt_dir)
        # layout.write(oas_dir)



def gds_to_txt_img2(file_dir, output_dir, output_type = 'png'):
    output_types = ['png', 'oas', 'txt']
    if output_type not in output_types:
        raise ValueError('output_type must be one of {}'.format(output_types))
    if not os.path.exists(output_dir):
        os.makedirs(output_dir, exist_ok=True)
    file_lists = os.listdir(file_dir)
    for file in tqdm(file_lists):
        # input_file = file_dir
        input_file = os.path.join(file_dir, file)
        layout = db.Layout()
        layout.read(input_file)
        layout_view = lay.LayoutView()
        #layout_view.set_config("background-color", "#FFFFFF")
        layout_view.set_config("background-color", "#000000")
        #layout_view.set_config("grid-visible", "false")
        layout_view.set_config("grid-visible", "true")
        layout_view.show_layout(layout, False)

        layout_view.max_hier()
        top_cell = layout.top_cell()
        layout_view.active_cellview().cell = top_cell
        box = top_cell.bbox()

        # color_map = {
        #     515: "#4D0000FF",   # Layer 515 -> red
        #     644: "#CCFF0000",   # Layer 644 -> green
        #     1457: "#4D00FF00"   # Layer 1457 -> blue
        # }
        color_map = {
            515: "#0022FF",   # Layer 515
            644: "#0DFF00",   # Layer 644
            1457: "#F6FF00",   # Layer 1457
        }
        
        frame_map = {
            515: "#FFFFFF",   # White frames
            644: "#FFFFFF",   # Yellow frames
            1457: "#FFFFFF"   # Magenta frames
        }

        for layer in layout_view.each_layer():
            ln = layer.source_layer
            if ln in color_map:
                c = int(color_map[ln].lstrip('#'), 16)
                fc = int(frame_map[ln].lstrip('#'), 16)
                layer.fill_color = c
                layer.frame_color = fc 
                layer.dither_pattern = 6
        layout_view.update_content()


        file_name = file.split('.')[0]
        output_file_name = file_name + '.' + output_type
        output_file = os.path.join(output_dir, output_file_name)
        if output_type == 'png':
            # layout_view.save_image_with_options(output_file, 2000, 2000)
            pb = layout_view.get_pixels_with_options(
                2000, 2000,
                0,    # linewidth
                0,    # oversampling
                0.0,  # resolution=auto-fit
            )
            pb.write_png(output_file)  
        else:
            layout.write(output_file)

if __name__ == "__main__":
    # gds_to_txt_img(sys.argv[1], sys.argv[2], sys.argv[3])
    gds_to_txt_img2(sys.argv[1], sys.argv[2], sys.argv[3])
    # gds_to_txt_img('samples/original/txt', 'samples/original/png', 'png')
    # gds_to_txt_img(sys.argv[1], sys.argv[2], 'png')
    # txt_dir = 'samples/txt'
    # for dir in os.listdir(txt_dir):
    #     file_dir = os.path.join(txt_dir, dir)
    #     if os.path.isdir(file_dir):
    #         output_dir = os.path.join('samples/img', dir)
    #         gds_to_txt_img(file_dir, output_dir, 'png')