mirror of https://github.com/interlegis/sigi.git
				
				
			
				 3 changed files with 42 additions and 375 deletions
			
			
		| @ -1,335 +0,0 @@ | |||
| from django.utils.translation import gettext as _ | |||
| from geraldo import ( | |||
|     ReportBand, | |||
|     ObjectValue, | |||
|     Label, | |||
|     ReportGroup, | |||
|     FIELD_ACTION_SUM, | |||
| ) | |||
| from reportlab.lib.units import cm | |||
| 
 | |||
| from sigi.apps.relatorios.reports import ReportDefault | |||
| 
 | |||
| 
 | |||
| # from abc import ABCMeta | |||
| 
 | |||
| 
 | |||
| class CasasAderidasReport(object): | |||
|     pass | |||
| 
 | |||
| 
 | |||
| class CasasNaoAderidasReport(object): | |||
|     pass | |||
| 
 | |||
| 
 | |||
| class CasasComEquipamentosReport(object): | |||
|     pass | |||
| 
 | |||
| 
 | |||
| class SemEquipamentosReport(object): | |||
|     pass | |||
| 
 | |||
| 
 | |||
| class ConvenioReport(ReportDefault): | |||
|     title = _("Relatório de Parcerias") | |||
| 
 | |||
|     class band_page_header(ReportDefault.band_page_header): | |||
| 
 | |||
|         label_top = ReportDefault.band_page_header.label_top | |||
|         label_left = [0, 2.5, 6, 8, 10, 12, 14, 16] | |||
|         elements = list(ReportDefault.band_page_header.elements) | |||
|         height = 4.7 * cm | |||
| 
 | |||
|         elements += [ | |||
|             Label( | |||
|                 text=_("UF"), | |||
|                 left=label_left[0] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Municipio"), | |||
|                 left=label_left[1] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Número do Convênio"), | |||
|                 left=label_left[2] * cm, | |||
|                 top=label_top, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Projeto"), | |||
|                 left=label_left[3] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Data do Convênio"), | |||
|                 left=label_left[4] * cm, | |||
|                 top=label_top, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Data de Publicação"), | |||
|                 left=label_left[5] * cm, | |||
|                 top=label_top, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Orgão"), | |||
|                 left=label_left[6] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|                 width=2 * cm, | |||
|             ), | |||
|         ] | |||
| 
 | |||
|     class band_page_footer(ReportDefault.band_page_footer): | |||
|         pass | |||
| 
 | |||
|     class band_detail(ReportDefault.band_detail): | |||
| 
 | |||
|         label_left = [0, 2.5, 6, 8, 10, 12, 14, 16] | |||
| 
 | |||
|         elements = [ | |||
|             ObjectValue( | |||
|                 attribute_name="casa_legislativa.municipio.uf.sigla", | |||
|                 left=label_left[0] * cm, | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="casa_legislativa.municipio.nome", | |||
|                 left=label_left[1] * cm, | |||
|             ), | |||
|             ObjectValue(attribute_name="num_convenio", left=label_left[2] * cm), | |||
|             ObjectValue( | |||
|                 attribute_name="projeto.sigla", left=label_left[3] * cm | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="data_retorno_assinatura", | |||
|                 left=label_left[4] * cm, | |||
|                 get_value=lambda instance: instance.data_retorno_assinatura.strftime( | |||
|                     "%d/%m/%Y" | |||
|                 ) | |||
|                 if instance.data_retorno_assinatura is not None | |||
|                 else "-", | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="data_pub_diario", | |||
|                 left=label_left[5] * cm, | |||
|                 get_value=lambda instance: instance.data_pub_diario.strftime( | |||
|                     "%d/%m/%Y" | |||
|                 ) | |||
|                 if instance.data_pub_diario is not None | |||
|                 else "-", | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="casa_legislativa.nome", left=label_left[6] * cm | |||
|             ), | |||
|         ] | |||
| 
 | |||
|     # groups = [ | |||
|     #    ReportGroup(attribute_name='casa_legislativa.municipio.uf', | |||
|     #                band_header=ReportBand( | |||
|     #                    height=0.7 * cm, | |||
|     #                    elements=[ | |||
|     #                        ObjectValue(attribute_name='casa_legislativa.municipio.uf', | |||
|     #                                    get_Value=lambda instance: '%s: %s' % (_('Casa Legislativa'), instance.casa_legislativa.uf) | |||
|     #                                    ) | |||
|     #                    ], | |||
|     #                    borders={'top': True}, | |||
|     #                ) | |||
|     #                ) | |||
|     # ] | |||
| 
 | |||
| 
 | |||
| class ConvenioReportSemAceite(ConvenioReport): | |||
|     class band_page_header(ReportDefault.band_page_header): | |||
| 
 | |||
|         label_top = ReportDefault.band_page_header.label_top | |||
|         label_left = [0, 2.5, 6, 8, 10, 12, 14, 16] | |||
|         elements = list(ReportDefault.band_page_header.elements) | |||
|         height = 4.7 * cm | |||
| 
 | |||
|         elements += [ | |||
|             Label( | |||
|                 text=_("UF"), | |||
|                 left=label_left[0] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Município"), | |||
|                 left=label_left[1] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Número do Convênio"), | |||
|                 left=label_left[2] * cm, | |||
|                 top=label_top, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Projeto"), | |||
|                 left=label_left[3] * cm, | |||
|                 top=label_top, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Data do Convênio"), | |||
|                 left=label_left[4] * cm, | |||
|                 top=label_top, | |||
|                 width=2 * cm, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Orgão"), | |||
|                 left=label_left[5] * cm, | |||
|                 top=label_top + 0.4 * cm, | |||
|                 width=2 * cm, | |||
|             ), | |||
|         ] | |||
| 
 | |||
|     class band_detail(ReportDefault.band_detail): | |||
| 
 | |||
|         label_left = [0, 2.5, 6, 8, 10, 12, 14, 16] | |||
| 
 | |||
|         elements = [ | |||
|             ObjectValue( | |||
|                 attribute_name="casa_legislativa.municipio.uf.sigla", | |||
|                 left=label_left[0] * cm, | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="casa_legislativa.municipio.nome", | |||
|                 left=label_left[1] * cm, | |||
|             ), | |||
|             ObjectValue(attribute_name="num_convenio", left=label_left[2] * cm), | |||
|             ObjectValue( | |||
|                 attribute_name="projeto.sigla", | |||
|                 left=label_left[3], | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="data_retorno_assinatura", | |||
|                 left=label_left[4] * cm, | |||
|                 get_value=lambda instance: instance.data_retorno_assinatura.strftime( | |||
|                     "%d/%m/%Y" | |||
|                 ) | |||
|                 if instance.data_retorno_assinatura is not None | |||
|                 else "-", | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="casa_legislativa.nome", left=label_left[5] * cm | |||
|             ), | |||
|         ] | |||
| 
 | |||
| 
 | |||
| float_duas_casas = lambda instance: "%.2f" % (instance) | |||
| 
 | |||
| 
 | |||
| class ConvenioReportRegiao(ReportDefault): | |||
|     title = _("Relatório de Parcerias por Região") | |||
| 
 | |||
|     class band_page_header(ReportDefault.band_page_header): | |||
|         label_top = ReportDefault.band_page_header.label_top | |||
|         label_left = [0.5, 6, 8, 10, 12, 14] | |||
|         map(lambda x: x - 0.4, label_left) | |||
| 
 | |||
|         elements = list(ReportDefault.band_page_header.elements) | |||
| 
 | |||
|         elements += [ | |||
|             Label( | |||
|                 text=_("UF"), | |||
|                 left=label_left[0] * cm, | |||
|                 top=label_top, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Total"), | |||
|                 left=label_left[1] * cm, | |||
|                 top=label_top, | |||
|             ), | |||
|             Label( | |||
|                 text=_("Aderidas"), | |||
|                 left=label_left[2] * cm, | |||
|                 top=label_top, | |||
|             ), | |||
|             Label(text="%", left=label_left[3] * cm, top=label_top), | |||
|             Label( | |||
|                 text=_("Ñ Aderidas"), | |||
|                 left=label_left[4] * cm, | |||
|                 top=label_top, | |||
|             ), | |||
|             Label(text="%", left=label_left[5] * cm, top=label_top), | |||
|         ] | |||
| 
 | |||
|     class band_detail(ReportDefault.band_detail): | |||
|         label_left = [0.5, 6, 8, 10, 12, 14] | |||
|         display_inline = True | |||
|         float_duas_casas = lambda instance: "%.2f" % ( | |||
|             instance.porc_casas_aderidas | |||
|         ) | |||
|         default_style = {"fontName": "Helvetica", "fontSize": 11} | |||
| 
 | |||
|         elements = [ | |||
|             ObjectValue( | |||
|                 attribute_name="estado", | |||
|                 left=label_left[0] * cm, | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="quant_casas", | |||
|                 left=label_left[1] * cm, | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="quant_casas_aderidas", left=label_left[2] * cm | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="porc_casas_aderidas", left=label_left[3] * cm | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="quant_casas_nao_aderidas", | |||
|                 left=label_left[4] * cm, | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="porc_casas_nao_aderidas", | |||
|                 left=label_left[5] * cm, | |||
|             ), | |||
|         ] | |||
| 
 | |||
|     class band_summary(ReportBand): | |||
|         label_left = [0.5, 6, 8, 10, 12, 14] | |||
|         elements = [ | |||
|             Label(text=_("Total"), top=0.1 * cm, left=label_left[0] * cm), | |||
|             ObjectValue( | |||
|                 attribute_name="quant_casas", | |||
|                 action=FIELD_ACTION_SUM, | |||
|                 left=label_left[1] * cm, | |||
|             ), | |||
|             ObjectValue( | |||
|                 attribute_name="quant_casas_aderidas", | |||
|                 action=FIELD_ACTION_SUM, | |||
|                 left=label_left[2] * cm, | |||
|             ), | |||
|             #            ObjectValue(attribute_name='porc_casas_aderidas', action=FIELD_ACTION_AVG, left=label_left[3]*cm, | |||
|             # get_value= lambda instance : lambda instance: '%.2f' %  (instance.porc_casas_aderidas), | |||
|             #            ), | |||
|             ObjectValue( | |||
|                 attribute_name="quant_casas_nao_aderidas", | |||
|                 action=FIELD_ACTION_SUM, | |||
|                 left=label_left[4] * cm, | |||
|             ), | |||
|             #            ObjectValue(attribute_name='porc_casas_nao_aderidas', left=label_left[5]*cm, | |||
|             #               get_value=lambda x: teste(), | |||
|             #            ), | |||
|         ] | |||
|         borders = {"top": True} | |||
| 
 | |||
| 
 | |||
| class ConvenioPorCMReport(ConvenioReport): | |||
|     title = _("Relatório de Parcerias por Câmara Municipal") | |||
| 
 | |||
| 
 | |||
| class ConvenioPorALReport(ConvenioReport): | |||
|     title = _("Relatório de Parcerias por Assembléia Legislativa") | |||
| 
 | |||
| 
 | |||
| class ConvenioReportSemAceiteCM(ConvenioReportSemAceite): | |||
|     title = _("Relatório de Parcerias por Câmara Municipal") | |||
| 
 | |||
| 
 | |||
| class ConvenioReportSemAceiteAL(ConvenioReportSemAceite): | |||
|     title = _("Relatório de Parcerias por Assembléia Legislativa") | |||
					Loading…
					
					
				
		Reference in new issue