import pandas as pd
import numpy as np

class Diagnosis:
    
    def __init__(self):
        pass
    
    def to_dict(self):
        return self.__dict__
    
    @staticmethod
    def get_diagnosis_list(conn, hadm_id):
        query = f"""
        SELECT
        
        seq_num,
        diagnoses_icd.icd_code,
        diagnoses_icd.icd_version,
        long_title
        
        FROM mimiciv_hosp.diagnoses_icd
        JOIN mimiciv_hosp.d_icd_diagnoses
        ON diagnoses_icd.icd_code = d_icd_diagnoses.icd_code
        WHERE hadm_id = {hadm_id}
        """
        
        df = pd.read_sql(query, conn)
        df = df.replace({np.nan: None})
        diagnosis_list = []
        for index, row in df.iterrows():
            diagnosis = Diagnosis()
            diagnosis.seq_num = row['seq_num']
            diagnosis.icd_code = row['icd_code']
            diagnosis.icd_version = row['icd_version']
            diagnosis.long_title = row['long_title']
            diagnosis_list.append(diagnosis)
        return diagnosis_list
    
    @staticmethod
    def from_dict(diagnosis_dict):
        diagnosis = Diagnosis()
        for key, value in diagnosis_dict.items():
            setattr(diagnosis, key, value)
        return diagnosis