##parameters=sessao,imagem,data,lst_protocolos,dic_cabecalho,lst_rodape,dic_filtro
"""relatorio_protocolo.py
   External method para gerar o arquivo rml do resultado de uma pesquisa de protocolos
   Autor: Luciano De Fazio
   Empresa: OpenLegis Consultoria
   versão: 1.0
"""
import time
from trml2pdf import parseString
def cabecalho(dic_cabecalho,imagem):
    """Gera o codigo rml do cabecalho"""
    tmp_data=''
    tmp_data+='\t\t\t\t\n'
    tmp_data+='\t\t\t\t2cm 25.4cm 19cm 25.4cm\n'
    tmp_data+='\t\t\t\t\n'
    tmp_data+='\t\t\t\t' + dic_cabecalho['nom_casa'] + '\n'
    tmp_data+='\t\t\t\t\n'
    tmp_data+='\t\t\t\tSistema de Apoio ao Processo Legislativo\n'
    tmp_data+='\t\t\t\t\n'
    tmp_data+='\t\t\t\tRelatório de Controle do Protocolo\n'
    return tmp_data
def rodape(lst_rodape):
    """Gera o codigo rml do rodape"""
    tmp_data=''
    tmp_data+='\t\t\t\t2cm 3.2cm 19cm 3.2cm\n'
    tmp_data+='\t\t\t\t\n'
    tmp_data+='\t\t\t\t' + lst_rodape[2] + '\n'
    tmp_data+='\t\t\t\tPágina \n'
    tmp_data+='\t\t\t\t' + lst_rodape[0] + '\n'
    tmp_data+='\t\t\t\t' + lst_rodape[1] + '\n'
    return tmp_data
def paraStyle():
    """Gera o codigo rml que define o estilo dos paragrafos"""
    tmp_data=''
    tmp_data+='\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\t\t\n'
    tmp_data+='\t\t\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\t\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\n'
    return tmp_data
def protocolos(lst_protocolos):
    """Gera o codigo rml do conteudo da pesquisa de protocolos"""
    tmp_data=''
    #inicio do bloco que contem os flowables
    tmp_data+='\t\n'
    for dic in lst_protocolos:
        #espaco inicial
        tmp_data+='\t\t\n'
        tmp_data+='\t\t\t \n'
        tmp_data+='\t\t\n'
        tmp_data+='\t\t\n'
        tmp_data+='\t\t\t \n'
        tmp_data+='\t\t\n'
        #condicao para a quebra de pagina
        tmp_data+='\t\t\n'
        #protocolos 
        if dic['titulo']!=None:
            tmp_data+='\t\tProtocolo ' + dic['titulo'] + '\n'
            tmp_data+='\t\t\n'
            tmp_data+='\t\t\t \n'
            tmp_data+='\t\t\n'
        if dic['txt_assunto']!=None:
            txt_assunto = dic['txt_assunto'].replace('&','&')
            tmp_data+='\t\t' + txt_assunto + '\n'
        if dic['txt_interessado']!=None:
           tmp_data+='\t\tInteressado: ' + dic['txt_interessado'] + '\n'
        elif dic['nom_autor']!=None:
           tmp_data+='\t\tAutor: ' + dic['nom_autor'] + '\n'
        if dic['natureza']!=None:
            tmp_data+='\t\tNatureza Processo: ' + dic['natureza'] + '\n'
        if dic['processo']!=None:
            tmp_data+='\t\tClassificação: ' + dic['processo'] + '\n'
        if dic['data']!=None:
            tmp_data+='\t\tData Protocolo: ' + dic['data'] + '\n'
        if dic['anulado']!="":
            tmp_data+='\t\t** PROTOCOLO ANULADO ** ' '\n'
    tmp_data+='\t\n'
    return tmp_data
def principal(imagem, lst_protocolos, dic_cabecalho, lst_rodape):
    """Funcao pricipal que gera a estrutura global do arquivo rml"""
    arquivoPdf=str(int(time.time()*100))+".pdf"
    tmp_data=''
    tmp_data+='\n'
    tmp_data+='\n'
    tmp_data+='\n'
    tmp_data+='\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\t\t\n'
    tmp_data+=cabecalho(dic_cabecalho,imagem)
    tmp_data+=rodape(lst_rodape)
    tmp_data+='\t\t\t\n'
    tmp_data+='\t\t\t\n'
    tmp_data+='\t\t\n'
    tmp_data+='\t\n'
    tmp_data+=paraStyle()
    tmp_data+=protocolos(lst_protocolos)
    tmp_data+='\n'
    tmp_pdf=parseString(tmp_data)
    return tmp_pdf
#     if hasattr(context.temp_folder,arquivoPdf):
#         context.temp_folder.manage_delObjects(ids=arquivoPdf)
#     context.temp_folder.manage_addFile(arquivoPdf)
#     arq=context.temp_folder[arquivoPdf]
#     arq.manage_edit(title='Arquivo PDF temporário.',filedata=tmp_pdf,content_type='application/pdf')
#     return "/temp_folder/"+arquivoPdf
# return principal(sessao,imagem,data,lst_protocolos,dic_cabecalho,lst_rodape,dic_filtro)