# parameters=sessao,imagem,data,lst_materias,dic_cabecalho,lst_rodape,dic_filtro """relatorio_materia.py External method para gerar o arquivo rml do resultado de uma pesquisa de matérias Autor: Leandro Gasparotto Valladares Empresa: Interlegis 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 25cm 19cm 25cm\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\t' + \ dic_cabecalho['nom_estado'] + '\n' tmp_data += '\t\t\t\t\n' tmp_data += '\t\t\t\tSECRETARIA\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\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 materias(lst_materias): """Gera o codigo rml do conteudo da pesquisa de materias""" tmp_data = '' # inicio do bloco que contem os flowables tmp_data += '\t\n' for dic in lst_materias: # 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' # materias # if dic['titulo']!=None: # tmp_data+='\t\t' + dic['titulo'] + '\n' # tmp_data+='\t\t\n' # tmp_data+='\t\t\t \n' # tmp_data+='\t\t\n' if dic['materia'] != None: tmp_data += '\t\t\n' tmp_data += '\t\t\t \n' tmp_data += '\t\t\n' tmp_data += '\t\tINDICAÇÃO: ' + \ dic['materia'] + '\n' tmp_data += '\t\t\n' tmp_data += '\t\t\t \n' tmp_data += '\t\t\n' if dic['dat_apresentacao'] != None: tmp_data += '\t\tDATA DE ENTRADA: ' + \ dic['dat_apresentacao'] + '\n' tmp_data += '\t\t\n' tmp_data += '\t\t\t \n' tmp_data += '\t\t\n' if dic['nom_autor'] != None: tmp_data += '\t\tAUTOR: ' + \ dic['nom_autor'] + '\n' tmp_data += '\t\t\n' tmp_data += '\t\t\t \n' tmp_data += '\t\t\n' if dic['txt_ementa'] != None: txt_ementa = dic['txt_ementa'].replace('&', '&') tmp_data += '\t\tEMENTA: ' + \ dic['txt_ementa'] + '\n' tmp_data += '\t\t\n' tmp_data += '\t\t\t \n' tmp_data += '\t\t\n' tmp_data += '\t\n' return tmp_data def principal(imagem, lst_materias, dic_cabecalho, lst_rodape): """Funcao pricipal que gera a estrutura global do arquivo rml""" # if sessao: # arquivoPdf=sessao+".pdf" # else: # arquivoPdf=str(int(time.time()*100))+".pdf" arquivoPdf = str(int(time.time() * 100)) + ".pdf" tmp_data = '' tmp_data += '\n' tmp_data += '\n' tmp_data += '\n' tmp_data += '\t\n' tmp_data += paraStyle() tmp_data += materias(lst_materias) tmp_data += '\n' tmp_pdf = parseString(tmp_data) return tmp_pdf # try: # tmp_pdf=parseString(unicode(tmp_data, 'utf-8')) # except: # tmp_pdf=parseString(unicode(tmp_data, '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,data,lst_materias,dic_cabecalho,lst_rodape,dic_filtro)