source: publico/il.sapl/trunk/il/sapl/skins/relatorios/pdf_materia_preparar_pysc.py @ 7878

Última Alteração nesse arquivo desde 7878 foi 7878, incluída por gustavolepri, 5 anos atrás

merge com as alterações da 2.5

File size: 6.1 KB
Linha 
1import os
2
3request=context.REQUEST
4#print request
5#return printed
6response=request.RESPONSE
7session= request.SESSION
8
9data=DateTime().strftime('%d/%m/%Y')
10
11#Abaixo é gerada a string para o rodapé da página
12casa={}
13aux=context.sapl_documentos.props_sapl.propertyItems()
14for item in aux:
15    casa[item[0]]=item[1]
16localidade=context.zsql.localidade_obter_zsql(cod_localidade=casa["cod_localidade"])
17if len(casa["num_cep"])==8:
18    cep=casa["num_cep"][:4]+"-"+casa["num_cep"][5:]
19else:
20    cep=""
21
22linha1=casa["end_casa"]
23if cep!="":
24    if casa["end_casa"]!="" and casa["end_casa"]!=None:
25        linha1 = linha1 + " - "
26    linha1 = linha1 + "CEP "+cep
27if localidade[0].nom_localidade!="" and localidade[0].nom_localidade!=None:
28    linha1 = linha1 + " - "+localidade[0].nom_localidade+" "+localidade[0].sgl_uf
29if casa["num_tel"]!="" and casa["num_tel"]!=None:
30    linha1 = linha1 + " Tel.: "+ casa["num_tel"]
31
32linha2=casa["end_web_casa"]
33if casa["end_email_casa"]!="" and casa["end_email_casa"]!=None:
34    if casa["end_web_casa"]!="" and casa["end_web_casa"]!=None:
35        linha2 = linha2 + " - "
36    linha2 =  linha2 + "E-mail: "+casa["end_email_casa"]
37
38data_emissao=DateTime().strftime("%d/%m/%Y")
39rodape=[linha1,linha2,data_emissao]
40
41#Por fim, gera-se as entradas para o cabeçalho
42estados=context.zsql.localidade_obter_zsql(tip_localidade="u")
43for uf in estados:
44    if localidade[0].sgl_uf==uf.sgl_uf:
45        nom_estado=uf.nom_localidade
46        break
47cabecalho={}
48cabecalho["nom_casa"]=casa["nom_casa"]
49cabecalho["nom_estado"]="Estado de "+nom_estado
50
51# tenta buscar o logotipo da casa LOGO_CASA
52if hasattr(context.sapl_documentos.props_sapl,'logo_casa.gif'):
53    imagem = context.sapl_documentos.props_sapl['logo_casa.gif'].absolute_url()
54else:
55    imagem = context.imagens.absolute_url() + "/brasao_transp.gif"
56
57#Por fim, utiliza o PythonScript para pesquisar as matérias e gerar os dados
58
59materias=[]
60REQUEST=context.REQUEST
61for materia in context.zsql.materia_pesquisar_zsql(tip_id_basica=REQUEST['lst_tip_materia'], num_ident_basica=REQUEST['txt_numero'],
62    ano_ident_basica=REQUEST['txt_ano'], ind_tramitacao=REQUEST['rad_tramitando'],
63    des_assunto=REQUEST['txt_assunto'], nom_relator=REQUEST['txt_relator'],
64    cod_status=REQUEST['lst_status'], des_tipo_autor=REQUEST['lst_tip_autor'],
65    dat_apresentacao=REQUEST['dt_apres'], dat_apresentacao2=REQUEST['dt_apres2'],
66    dat_publicacao=REQUEST['dt_public'], dat_publicacao2=REQUEST['dt_public2'],
67    cod_partido=REQUEST['lst_cod_partido'],cod_autor=REQUEST['hdn_cod_autor'],
68    rd_ordem=REQUEST['rd_ordenacao'],rd_ordem_td=REQUEST['rd_ordem_td']):
69
70    dic={}
71
72    dic['titulo']=materia.sgl_tipo_materia+" "+materia.des_tipo_materia+" "+str(materia.num_ident_basica)+"/"+str(materia.ano_ident_basica)
73    dic['txt_ementa']=materia.txt_ementa
74    dic['nom_autor'] = " "
75    for autoria in context.zsql.autoria_obter_zsql(cod_materia=materia.cod_materia):
76        for autor in context.zsql.autor_obter_zsql(cod_autor=autoria.cod_autor):
77            if autor.des_tipo_autor=='Parlamentar':
78                for parlamentar in context.zsql.parlamentar_obter_zsql(cod_parlamentar=autor.cod_parlamentar):
79                    dic['nom_autor']=parlamentar.nom_completo
80            elif autor.des_tipo_autor=='Comissao':
81                for comissao in context.zsql.comissao_obter_zsql(cod_comissao=autor.cod_comissao):
82                    dic['nom_autor']=comissao.nom_comissao
83            else:
84                dic['nom_autor']=autor.nom_autor
85
86    des_status = ''
87    txt_tramitacao=''
88
89    dic['localizacao_atual']=" "
90    for tramitacao in context.zsql.tramitacao_obter_zsql(cod_materia=materia.cod_materia,ind_ult_tramitacao=1):
91        if tramitacao.cod_unid_tram_dest:
92            cod_unid_tram = tramitacao.cod_unid_tram_dest
93        else:
94            cod_unid_tram = tramitacao.cod_unid_tram_local
95
96        for unidade_tramitacao in context.zsql.unidade_tramitacao_obter_zsql(cod_unid_tramitacao = cod_unid_tram):
97            if unidade_tramitacao.cod_orgao:
98                dic['localizacao_atual']=unidade_tramitacao.nom_orgao
99            else:
100                dic['localizacao_atual']=unidade_tramitacao.nom_comissao
101
102        des_status=tramitacao.des_status
103        txt_tramitacao=tramitacao.txt_tramitacao
104
105    dic['des_situacao']=des_status
106    dic['ultima_acao']=txt_tramitacao
107
108
109    dic['norma_vinculada']=" "
110    for norma_vinculada in context.zsql.materia_buscar_norma_juridica_zsql(cod_materia=materia.cod_materia):
111        dic['norma_vinculada']=norma_vinculada.des_norma+" "+str(norma_vinculada.num_norma)+"/"+str(norma_vinculada.ano_norma)
112
113    materias.append(dic)
114
115filtro={} # Dicionário que conterá os dados do filtro
116
117# Atribuições diretas do REQUEST
118filtro['numero']=REQUEST.txt_numero
119filtro['ano']=REQUEST.txt_ano
120filtro['autor']=REQUEST.hdn_txt_autor
121filtro['tipo_autor']=REQUEST.lst_tip_autor
122filtro['relator']=REQUEST.txt_relator
123filtro['assunto']=REQUEST.txt_assunto
124
125# Atribuição do restante dos dados que precisam de processamento
126if REQUEST.hdn_txt_autor=='  ': # Corrige bug do Netscape
127    filtro['autor']=''
128
129filtro['tipo_materia']=''
130if REQUEST.lst_tip_materia!='':
131    for tipo_materia in context.zsql.tipo_materia_legislativa_obter_zsql(ind_excluido=0, tip_materia=REQUEST.lst_tip_materia):
132        filtro['tipo_materia']= tipo_materia.sgl_tipo_materia + ' - ' + tipo_materia.des_tipo_materia
133
134filtro['partido']=''
135if REQUEST.lst_cod_partido!='':
136    for partido in context.zsql.partido_obter_zsql(ind_excluido=0,cod_partido=REQUEST.lst_cod_partido):
137        filtro['partido']=partido.sgl_partido + ' - ' + partido.nom_partido
138
139filtro['tramitando']=''
140if REQUEST.rad_tramitando=='1':
141    filtro['tramitacao']='Sim'
142elif REQUEST['rad_tramitando']=='0':
143    filtro['tramitacao']='Não'
144
145filtro['situacao_atual']=''
146if REQUEST.lst_status!='':
147    for status in context.zsql.status_tramitacao_obter_zsql(ind_excluido=0,cod_status=REQUEST.lst_status):
148        filtro['situacao_atual']=status.sgl_status + ' - ' + status.des_status
149
150sessao=session.id
151caminho = context.pdf_materia_gerar(sessao,imagem,data,materias,cabecalho,rodape,filtro)
152if caminho=='aviso':
153    return response.redirect('mensagem_emitir_proc')
154else:
155    response.redirect(caminho)
Note: Veja TracBrowser para ajuda no uso do navegador do trac.
 

The contents and data of this website are published under license:
Creative Commons 4.0 Brasil - Atribuir Fonte - Compartilhar Igual.