# parameters=sessao,imagem,dat_ordem,lst_splen,lst_pauta,dic_cabecalho,lst_rodape
"""relatorio_ordem.py
   External method para gerar o arquivo rml da ordem do dia
   Autor: Leandro Gasparotto Valladares
   Empresa: Interlegis
   versão: 1.0
"""
import os
import time
from trml2pdf import parseString
def cabecalho(dic_cabecalho, dat_ordem, imagem):
    """Gera o codigo rml do cabecalho"""
    tmp = ''
    tmp += '\t\t\t\t\n'
    tmp += '\t\t\t\t2cm 25cm 19cm 25cm\n'
    tmp += '\t\t\t\t\n'
    #tmp+='\t\t\t\t' + str(dic_cabecalho['nom_casa']) + '\n'
    #tmp+='\t\t\t\t\n'
    tmp += '\t\t\t\t' + \
        str(dic_cabecalho['nom_estado']) + '\n'
    tmp += '\t\t\t\t\n'
    tmp += '\t\t\t\t' + \
        str(dic_cabecalho['nom_casa']) + '\n'
    tmp += '\t\t\t\t\n'
    #tmp+='\t\t\t\t' + "Palacio 11 de Outubro" + '\n'
    #tmp+='\t\t\t\t\n'
    tmp += '\t\t\t\tRelatório da Ordem do Dia\n'
    return tmp
def rodape(lst_rodape):
    """ Gera o codigo rml do rodape"""
    tmp = ''
    tmp += '\t\t\t\t2cm 3.2cm 19cm 3.2cm\n'
    tmp += '\t\t\t\t\n'
    tmp += '\t\t\t\t' + \
        lst_rodape[2] + '\n'
    tmp += '\t\t\t\tPágina \n'
    tmp += '\t\t\t\t' + \
        lst_rodape[0] + '\n'
    tmp += '\t\t\t\t' + \
        lst_rodape[1] + '\n'
    return tmp
def paraStyle():
    """ Gera o codigo rml que define o estilo dos paragrafos"""
    tmp = ''
    tmp += '\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\t\n'
    tmp += '\t\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\n'
    return tmp
# def splen(lst_splen):
def pauta(lst_splen, lst_pauta):
    """ Funcao que gera o codigo rml da sessao plenaria """
    tmp = ''
    # inicio do bloco
    tmp += '\t\n'
    for dicsp in lst_splen:
        # espaço inicial
        tmp += '\t\t\n'
        tmp += '\t\t\t \n'
        tmp += '\t\t\n'
        tmp += '\t\t\n'
        tmp += '\t\t\t \n'
        tmp += '\t\t\n'
        # condicao para a quebra de pagina
        tmp += '\t\t\n'
        # sessao plenaria
        if dicsp['sessao'] != None:
            tmp += '\t\t' + \
                dicsp['sessao'].replace('&', '&') + '\n'
            tmp += '\t\t\n'
            tmp += '\t\t\t \n'
            tmp += '\t\t\n'
        if dicsp['datasessao'] != None:
            tmp += '\t\t' + \
                dicsp['datasessao'].replace('&', '&') + '\n'
            tmp += '\t\t\n'
            tmp += '\t\t\t \n'
            tmp += '\t\t\n'
#    tmp+='\t\n'
#    return tmp
#
# def pauta(lst_pauta):
#    """ Funcao que gera o codigo rml da pauta da ordem do dia"""
#    tmp=''
    # inicio do bloco que contem os flowables
#    tmp+='\t\n'
    for dic in lst_pauta:
        # espaco inicial
        tmp += '\t\t\n'
        tmp += '\t\t\t \n'
        tmp += '\t\t\n'
        tmp += '\t\t\n'
        tmp += '\t\t\t \n'
        tmp += '\t\t\n'
        # condicao para a quebra de pagina
        tmp += '\t\t\n'
        # pauta
        if dic['num_ordem'] != None:
            tmp += '\t\tItem nº ' + \
                str(dic['num_ordem']) + ''
        if dic['id_materia'] != None:
            tmp += '\t\t' + dic['id_materia'] + '\n'
            tmp += '\t\t\n'
            tmp += '\t\t\t \n'
            tmp += '\t\t\n'
        if dic['txt_ementa'] != None:
            tmp += '\t\t' + \
                dic['txt_ementa'].replace('&', '&') + '\n'
            tmp += '\t\t\n'
            tmp += '\t\t\t \n'
            tmp += '\t\t\n'
        if dic['des_numeracao'] != None:
            tmp += '\t\tProcesso: ' + \
                dic['des_numeracao'] + '\n'
        if dic['des_turno'] != None:
            tmp += '\t\tTurno: ' + \
                dic['des_turno'] + '\n'
        if dic['nom_autor'] != None:
            tmp += '\t\tAutor: ' + \
                dic['nom_autor'] + '\n'
        if dic['des_situacao'] != None:
            tmp += '\t\tSituação: ' + \
                dic['des_situacao'] + '\n'
#       if dic['des_numeracao']!=None:
#           tmp+='\t\tProcesso Nº: ' + dic['des_numeracao'] + '\n'
#        indice = 0
#        for relator in dic['lst_relator']:
#            indice = indice + 1
#            if (relator != None):
#                if (indice < 2):
#                    tmp+='\t\tRelator: ' + relator + '\n'
#                else:
#                    tmp+='\t\t              ' + relator + '
\n'
    tmp += '\t\n'
    return tmp
def principal(imagem, lst_splen, lst_pauta, dic_cabecalho, lst_rodape):
    """Funcao principal que gera a estrutura global do arquivo rml contendo o relatorio de uma ordem do dia.
    ordem_dia_[data da ordem do dia do relatório].pdf
    Retorna:
    Parâmetros:
    dat_ordem       => A data da ordem do dia.
        splen       => Uma lista de dicionários contendo as sessões plenárias do dia.
        pauta       => Uma lista de dicionários contendo a pauta da ordem do dia numa sessão plenária.
        cabecalho   => Um dicionário contendo informações para o Cabeçalho do relatório, incluindo a imagem.
        rodapé      => Uma lista contendo informações para o Rodapé do relatório.
    """
    arquivoPdf = str(int(time.time() * 100)) + ".pdf"
    tmp = ''
    tmp += '\n'
    tmp += '\n'
    tmp += '\n'
    tmp += '\t\n'
    tmp += '\t\t\n'
    tmp += '\t\t\t\n'
    tmp += cabecalho(dic_cabecalho, dat_ordem, imagem)
    tmp += rodape(lst_rodape)
    tmp += '\t\t\t\n'
    tmp += '\t\t\t\n'
    tmp += '\t\t\n'
    tmp += '\t\n'
    tmp += paraStyle()
#   tmp+=splen(lst_splen)
    tmp += pauta(lst_splen, lst_pauta)
    tmp += '\n'
    tmp_pdf = parseString(tmp)
    return tmp_pdf
# try:
# tmp_pdf=parseString(unicode(tmp, 'utf-8'))
# except:
# tmp_pdf=parseString(unicode(tmp, 'utf-8'))
#     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, dat_ordem, lst_splen, lst_pauta,
# dic_cabecalho, lst_rodape)