@ -499,8 +499,9 @@ def resumo_convenios(request): 
			
		
	
		
		
			
				
					        df  =  resumo . pop ( " data_frame " )         df  =  resumo . pop ( " data_frame " )  
			
		
	
		
		
			
				
					        col  =  df . columns [ 0 ]         col  =  df . columns [ 0 ]  
			
		
	
		
		
			
				
					        for  key ,  value  in  resumo . items ( ) :         for  key ,  value  in  resumo . items ( ) :  
			
		
	
		
		
			
				
					
					            if  type ( value )  is  dict :             if  hasattr ( value ,  " __iter__ " )  or  hasattr ( value ,  " __getitem__ " ) :  
			
				
				
			
		
	
		
		
			
				
					
					                for  k ,  v  in  value . items ( ) :                 value  =  value . items ( )  if  hasattr ( value ,  " items " )  else  value  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					                for  k ,  v  in  value :  
			
		
	
		
		
			
				
					                    df . loc [ f " { key }  -  { k } " ]  =  { col :  v }                     df . loc [ f " { key }  -  { k } " ]  =  { col :  v }  
			
		
	
		
		
			
				
					            else :             else :  
			
		
	
		
		
			
				
					                df . loc [ key ]  =  { col :  value }                 df . loc [ key ]  =  { col :  value }  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1127,56 +1128,67 @@ def report_sem_convenio(request): 
			
		
	
		
		
			
				
					def  busca_informacoes_camara ( tipos = [ " CM " ] ,  label_tipo = _ ( " Câmaras Municipais " ) ) : def  busca_informacoes_camara ( tipos = [ " CM " ] ,  label_tipo = _ ( " Câmaras Municipais " ) ) :  
			
		
	
		
		
			
				
					    camaras  =  Orgao . objects . filter ( tipo__sigla__in = tipos )     camaras  =  Orgao . objects . filter ( tipo__sigla__in = tipos )  
			
		
	
		
		
			
				
					    convenios  =  Convenio . objects . filter ( casa_legislativa__tipo__sigla__in = tipos )     convenios  =  Convenio . objects . filter ( casa_legislativa__tipo__sigla__in = tipos )  
			
		
	
		
		
			
				
					
					    convenios_em_andamento   =  convenios . filter ( data_retorno_assinatura = None )     convenios_vigentes   =  convenios . exclude ( data_retorno_assinatura = None ) . filter (  
			
				
				
			
		
	
		
		
			
				
					
					    convenios_vencidos  =  convenios . filter (         Q ( data_termino_vigencia__gte = timezone . localdate ( ) )   
			
				
				
			
		
	
		
		
			
				
					
					        data_termino_vigencia__lt = timezone . localdate ( )         |  Q ( data_termino_vigencia = None )  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					    )     )  
			
		
	
		
		
			
				
					
					    camaras_projetos_vigentes  =  camaras . exclude ( convenio = None ) . exclude (     convenios_andando  =  convenios . filter ( data_retorno_assinatura = None )  
			
				
				
			
		
	
		
		
			
				
					
					        convenio__in = convenios_vencidos     convenios_vencidos  =  convenios . exclude (  
			
				
				
			
		
	
		
		
			
				
					
					    )         Q ( data_retorno_assinatura = None )  |  Q ( data_termino_vigencia = None )  
			
				
				
			
		
	
		
		
			
				
					
					
    ) . filter ( data_termino_vigencia__lt = timezone . localdate ( ) )  
			
				
				
			
		
	
		
		
			
				
					    # Dataframe do resumo de camaras por projeto #  
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					    dataset  =  {     dataset  =  {  
			
		
	
		
		
			
				
					
					        d . pop ( " convenio__projeto__sigla " ) :  d         _ ( f " { label_tipo }  com convênios vigentes " ) :  {  
			
				
				
			
		
	
		
		
			
				
					
					        for  d  in  camaras . values ( " convenio__projeto__sigla " ) . annotate (             k :  v  
			
				
				
			
		
	
		
		
			
				
					
					            total = Count ( " id " ,  distinct = True ) ,             for  k ,  v  in  convenios_vigentes . values_list (  
			
				
				
			
		
	
		
		
			
				
					
					            andamento = Count (                 " projeto__sigla "  
			
				
				
			
		
	
		
		
			
				
					
					                " id " ,             ) . annotate ( Count ( " casa_legislativa_id " ,  distinct = True ) )  
			
				
				
			
		
	
		
		
			
				
					
					                filter = Q ( convenio__in = convenios_em_andamento ) ,         } ,  
			
				
				
			
		
	
		
		
			
				
					
					                distinct = True ,         _ ( f " { label_tipo }  com convênios em andamento " ) :  {  
			
				
				
			
		
	
		
		
			
				
					
					            ) ,             k :  v  
			
				
				
			
		
	
		
		
			
				
					
					            vigentes = Count (             for  k ,  v  in  convenios_andando . values_list (  
			
				
				
			
		
	
		
		
			
				
					
					                " id " ,  filter = Q ( id__in = camaras_projetos_vigentes ) ,  distinct = True                 " projeto__sigla "  
			
				
				
			
		
	
		
		
			
				
					
					            ) ,             ) . annotate ( Count ( " casa_legislativa_id " ,  distinct = True ) )  
			
				
				
			
		
	
		
		
			
				
					
					            vencidos = Count (         } ,  
			
				
				
			
		
	
		
		
			
				
					
					                " id " ,  filter = ~ Q ( id__in = camaras_projetos_vigentes ) ,  distinct = True         _ ( f " { label_tipo }  com convênios vencidos " ) :  {  
			
				
				
			
		
	
		
		
			
				
					
					            ) ,             k :  v  
			
				
				
			
		
	
		
		
			
				
					
					        )             for  k ,  v  in  convenios_vencidos . values_list (  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					                " projeto__sigla "  
			
		
	
		
		
			
				
					            ) . annotate ( Count ( " casa_legislativa_id " ,  distinct = True ) )  
			
		
	
		
		
			
				
					        } ,  
			
		
	
		
		
			
				
					    }     }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					    if  None  in  dataset :     ds_totais  =  (  
			
				
				
			
		
	
		
		
			
				
					
					        rec_none  =  dataset . pop ( None )         ( _ ( f " Total de  { label_tipo }  do país " ) ,  camaras . count ( ) ) ,  
			
				
				
			
		
	
		
		
			
				
					
					        camaras_sem_convenio  =  rec_none [ " total " ]         (  
			
				
				
			
		
	
		
		
			
				
					
					    else :             _ ( f " Total de  { label_tipo }  com convênio vigente " ) ,  
			
				
				
			
		
	
		
		
			
				
					
					        camaras_sem_convenio  =  0             convenios_vigentes . order_by ( " casa_legislativa_id " )  
			
				
				
			
		
	
		
		
			
				
					
					
            . distinct ( " casa_legislativa_id " )  
			
				
				
			
		
	
		
		
			
				
					
					    df  =  pd . DataFrame ( dataset )             . count ( ) ,  
			
				
				
			
		
	
		
		
			
				
					
					    df . rename (         ) ,  
			
				
				
			
		
	
		
		
			
				
					
					        index = {         (  
			
				
				
			
		
	
		
		
			
				
					
					            " total " :  _ ( f " Total de  { label_tipo }  conveniados " ) ,             _ ( f " Total de  { label_tipo }  com convênio em andamento " ) ,  
			
				
				
			
		
	
		
		
			
				
					
					            " andamento " :  _ ( f " { label_tipo }  com convênios em andamento " ) ,             convenios_andando . order_by ( " casa_legislativa_id " )  
			
				
				
			
		
	
		
		
			
				
					
					            " vigentes " :  _ ( f " { label_tipo }  com convênios vigentes " ) ,             . distinct ( " casa_legislativa_id " )  
			
				
				
			
		
	
		
		
			
				
					
					            " vencidos " :  _ ( f " { label_tipo }  com convênios vencidos " ) ,             . count ( ) ,  
			
				
				
			
		
	
		
		
			
				
					
					        } ,         ) ,  
			
				
				
			
		
	
		
		
			
				
					
					        inplace = True ,         (  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					            _ ( f " Total de  { label_tipo }  com convênio vencido " ) ,  
			
		
	
		
		
			
				
					            convenios_vencidos . order_by ( " casa_legislativa_id " )  
			
		
	
		
		
			
				
					            . distinct ( " casa_legislativa_id " )  
			
		
	
		
		
			
				
					            . count ( ) ,  
			
		
	
		
		
			
				
					        ) ,  
			
		
	
		
		
			
				
					    )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    df  =  (  
			
		
	
		
		
			
				
					        pd . DataFrame . from_dict ( dataset ,  orient = " index " )  
			
		
	
		
		
			
				
					        . replace ( np . NaN ,  0 )  
			
		
	
		
		
			
				
					        . convert_dtypes ( )  
			
		
	
		
		
			
				
					    )     )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    # Retornando listas em forma de dicionario     # Retornando listas em forma de dicionario  
			
		
	
		
		
			
				
					    return  {     return  {  
			
		
	
		
		
			
				
					        " data_frame " :  df ,         " data_frame " :  df ,  
			
		
	
		
		
			
				
					
					        " total_camaras " :  camaras . count ( ) ,         " totais " :  ds_totais ,  
			
				
				
			
		
	
		
		
			
				
					        " total_camaras_convenios_vigentes " :  camaras_projetos_vigentes . count ( ) ,  
			
		
	
		
		
			
				
					        " camaras_sem_convenio " :  camaras_sem_convenio ,  
			
		
	
		
		
	
		
		
			
				
					        " sem_convenio " :  sem_convenio ( ) ,         " sem_convenio " :  sem_convenio ( ) ,  
			
		
	
		
		
			
				
					    }     }