@ -325,6 +325,7 @@ class TextView(ListView, CompMixin):
inicio_vigencia = None
inicio_vigencia = None
fim_vigencia = None
fim_vigencia = None
ta_vigencia = None
def get ( self , request , * args , * * kwargs ) :
def get ( self , request , * args , * * kwargs ) :
ta = TextoArticulado . objects . get ( pk = self . kwargs [ ' ta_id ' ] )
ta = TextoArticulado . objects . get ( pk = self . kwargs [ ' ta_id ' ] )
@ -427,14 +428,19 @@ class TextView(ListView, CompMixin):
self . inicio_vigencia = None
self . inicio_vigencia = None
self . fim_vigencia = None
self . fim_vigencia = None
self . ta_vigencia = None
if ' sign ' in self . kwargs :
if ' sign ' in self . kwargs :
signer = Signer ( )
signer = Signer ( )
try :
try :
string = signer . unsign ( self . kwargs [ ' sign ' ] ) . split ( ' , ' )
string = signer . unsign ( self . kwargs [ ' sign ' ] ) . split ( ' , ' )
self . inicio_vigencia = parse_date ( string [ 0 ] )
self . ta_vigencia = int ( string [ 0 ] )
self . fim_vigencia = parse_date ( string [ 1 ] )
self . inicio_vigencia = parse_date ( string [ 1 ] )
self . fim_vigencia = parse_date ( string [ 2 ] )
except :
except :
return { }
return Dispositivo . objects . filter (
ordem__gt = 0 ,
ta_id = self . kwargs [ ' ta_id ' ] ,
) . select_related ( * DISPOSITIVO_SELECT_RELATED )
return Dispositivo . objects . filter (
return Dispositivo . objects . filter (
inicio_vigencia__lte = self . fim_vigencia ,
inicio_vigencia__lte = self . fim_vigencia ,
@ -1015,17 +1021,26 @@ class ActionsEditMixin:
base_anterior = Dispositivo . objects . order_by ( ' -ordem ' ) . filter (
base_anterior = Dispositivo . objects . order_by ( ' -ordem ' ) . filter (
ta_id = base . ta_id ,
ta_id = base . ta_id ,
ordem__lt = base . ordem
ordem__lt = base . ordem
) [ : 1 ]
) . first ( )
data = { }
data = { }
if base_anterior . exists ( ) :
if base_anterior :
if base . dispositivo_pai_id :
data = self . get_json_for_refresh ( base_anterior )
data = { ' pk ' : base_anterior [ 0 ] . pk ,
' pai ' : [ base . dispositivo_pai_id , ] }
else :
else :
data = { ' pk ' : base_anterior [ 0 ] . pk , ' pai ' : [ - 1 , ] }
base_anterior = Dispositivo . objects . order_by ( ' ordem ' ) . filter (
ta_id = base . ta_id ,
ordem__lt = base . ordem
) . first ( )
if base_anterior :
data = self . get_json_for_refresh ( base_anterior )
else :
data [ ' pk ' ] = ' '
# TODO: a linha abaixo causa atualização da tela inteira...
# retirar a linha abaixo e identificar atualizações pontuais
data [ ' pai ' ] = [ - 1 , ]
self . remover_dispositivo ( base , bloco )
data [ ' message ' ] = str ( self . remover_dispositivo ( base , bloco ) )
return data
return data
def remover_dispositivo ( self , base , bloco ) :
def remover_dispositivo ( self , base , bloco ) :
@ -1034,12 +1049,12 @@ class ActionsEditMixin:
n = base . dispositivo_subsequente
n = base . dispositivo_subsequente
if n :
if n :
print ( n . id , n )
# print(n.id, n )
n . dispositivo_substituido = p
n . dispositivo_substituido = p
n . save ( )
n . save ( )
if p :
if p :
print ( p . id , p )
# print(p.id, p )
p . dispositivo_subsequente = n
p . dispositivo_subsequente = n
if n :
if n :
p . fim_vigencia = n . ini_vigencia - timedelta ( days = 1 )
p . fim_vigencia = n . ini_vigencia - timedelta ( days = 1 )
@ -1058,38 +1073,51 @@ class ActionsEditMixin:
p . dispositivos_filhos_set . add ( d )
p . dispositivos_filhos_set . add ( d )
p . save ( )
p . save ( )
base . delete ( )
base . delete ( )
elif not bloco :
else :
if not bloco :
for d in base . dispositivos_filhos_set . all ( ) :
for d in base . dispositivos_filhos_set . all ( ) :
# inserções automáticas são excluidas junto com sua base,
# inserções automáticas são excluidas junto com sua base,
# independente da escolha do usuário
# independente da escolha do usuário
d_nivel_old = d . nivel
if d . tipo_dispositivo . possiveis_pais . filter (
if d . tipo_dispositivo . possiveis_pais . filter (
pai = base . tipo_dispositivo ,
pai = base . tipo_dispositivo ,
perfil__padrao = True ,
perfil__padrao = True ,
filho_de_insercao_automatica = True ) . exists ( ) :
filho_de_insercao_automatica = True ) . exists ( ) :
continue
continue
# encontrar possível pai que será o primeiro parent possível
# encontrar possível pai que será o primeiro parent
# dos parents do dispostivo
# possível dos parents do dispostivo
# imediatamente anterior ao dispositivo base
# imediatamente anterior ao dispositivo base
anterior = Dispositivo . objects . order_by ( ' -ordem ' ) . filter (
anterior = Dispositivo . objects . order_by ( ' -ordem ' ) . filter (
ta_id = base . ta_id ,
ta_id = base . ta_id ,
ordem__lt = d . ordem
ordem__lt = base . ordem
) . exclude ( pk = base . pk ) . first ( )
) . first ( )
if not anterior :
return _ ( ' Não é possível excluir este Dispositivo sem '
' excluir toda a sua estrutura!!! ' )
if anterior . tipo_dispositivo == d . tipo_dispositivo :
if anterior . tipo_dispositivo == d . tipo_dispositivo :
d . dispositivo_pai = anterior . dispositivo_pai
d . dispositivo_pai = anterior . dispositivo_pai
d . nivel = anterior . nivel
d . nivel = anterior . nivel
if not d . tipo_dispositivo . contagem_continua :
if not d . tipo_dispositivo . contagem_continua :
d . set_numero_completo ( anterior . get_numero_completo ( ) )
d . set_numero_completo (
anterior . get_numero_completo ( ) )
if d . dispositivo_substituido != anterior :
if d . dispositivo_substituido != anterior :
d . transform_in_next ( )
d . transform_in_next ( )
d . rotulo = d . rotulo_padrao ( )
d . rotulo = d . rotulo_padrao ( )
else :
else :
parents = anterior . get_parents ( )
parents = [ anterior , ] + anterior . get_parents ( )
for candidato in parents :
for candidato in parents :
if candidato . tipo_dispositivo == d . tipo_dispositivo :
if candidato == base :
return _ ( ' Não é possível excluir este '
' Dispositivo sem '
' excluir toda a sua estrutura!!! ' )
if ( candidato . tipo_dispositivo ==
d . tipo_dispositivo ) :
d . dispositivo_pai = candidato . dispositivo_pai
d . dispositivo_pai = candidato . dispositivo_pai
d . nivel = candidato . nivel
d . nivel = candidato . nivel
if not d . tipo_dispositivo . contagem_continua :
if not d . tipo_dispositivo . contagem_continua :
@ -1103,14 +1131,20 @@ class ActionsEditMixin:
pai = candidato . tipo_dispositivo ,
pai = candidato . tipo_dispositivo ,
perfil__padrao = True ) . exists ( ) :
perfil__padrao = True ) . exists ( ) :
d . dispositivo_pai = candidato
d . dispositivo_pai = candidato
if ' ; ' in d . tipo_dispositivo . rotulo_prefixo_texto :
if ' ; ' in d . tipo_dispositivo . \
rotulo_prefixo_texto :
d . set_numero_completo ( [ 0 , 0 , 0 , 0 , 0 , 0 , ] )
d . set_numero_completo ( [ 0 , 0 , 0 , 0 , 0 , 0 , ] )
else :
else :
d . set_numero_completo ( [ 1 , 0 , 0 , 0 , 0 , 0 , ] )
d . set_numero_completo ( [ 1 , 0 , 0 , 0 , 0 , 0 , ] )
d . nivel = candidato . nivel + 1
d . nivel = candidato . nivel + 1
break
break
d . save ( )
if not parents :
d . dispositivo_pai = anterior
d . nivel = anterior . nivel + 1
d . save ( clean = False )
if d . nivel != d_nivel_old :
d . organizar_niveis ( )
d . organizar_niveis ( )
if base . nivel :
if base . nivel :
@ -1121,20 +1155,66 @@ class ActionsEditMixin:
ordem__gt = base . ordem ,
ordem__gt = base . ordem ,
tipo_dispositivo = base . tipo_dispositivo )
tipo_dispositivo = base . tipo_dispositivo )
numero_completo_base = base . get_numero_completo ( )
# Religar numeração de dispositivos de contagem contínua
base . delete ( )
# que seram excluidos
proximo_independente_base = irmaos_posteriores . first ( )
proxima_articulacao = base . get_proximo_nivel_zero ( )
if not proximo_independente_base :
proximo_independente_base = Dispositivo . objects . \
order_by ( ' ordem ' ) . filter (
ta_id = base . ta_id ,
ordem__gt = base . ordem ,
nivel__lte = base . nivel )
if proximo_independente_base :
dcc = Dispositivo . objects . order_by ( ' ordem ' ) . filter (
ta_id = base . ta_id ,
ordem__gt = base . ordem ,
ordem__lt = proximo_independente_base . ordem ,
tipo_dispositivo__contagem_continua = True )
religado = { }
for d in dcc :
if d . tipo_dispositivo . class_css in religado :
continue
religado [
d . tipo_dispositivo . class_css ] = d . dispositivo0
if proxima_articulacao :
dcc_a_religar = Dispositivo . objects . filter (
ta_id = d . ta_id ,
ordem__gt = proximo_independente_base . ordem ,
tipo_dispositivo = d . tipo_dispositivo ,
ordem__lt = proxima_articulacao . ordem )
else :
dcc_a_religar = Dispositivo . objects . filter (
ta_id = base . ta_id ,
ordem__gt = proximo_independente_base . ordem ,
tipo_dispositivo = d . tipo_dispositivo )
primeiro_a_religar = 0
for dr in dcc_a_religar :
if not primeiro_a_religar :
primeiro_a_religar = dr . dispositivo0
dr . dispositivo0 = (
dr . dispositivo0 -
primeiro_a_religar + d . dispositivo0 )
dr . rotulo = dr . rotulo_padrao ( )
dr . save ( )
base . delete ( )
else :
else :
proxima_articulacao = base . get_proximo_nivel_zero ( )
proxima_articulacao = base . get_proximo_nivel_zero ( )
numero_completo_base = base . get_numero_completo ( )
if proxima_articulacao :
if proxima_articulacao :
irmaos_posteriores = Dispositivo . objects . filter (
irmaos_posteriores = Dispositivo . objects . filter (
ta_id = base . ta_id ,
ta_id = base . ta_id ,
ordem__gt = base . ordem ,
ordem__gt = base . ordem ,
tipo_dispositivo = base . tipo_dispositivo ,
tipo_dispositivo = base . tipo_dispositivo ,
ordem__lt = proxima_articulacao . ordem
ordem__lt = proxima_articulacao . ordem )
)
else :
else :
irmaos_posteriores = Dispositivo . objects . filter (
irmaos_posteriores = Dispositivo . objects . filter (
ta_id = base . ta_id ,
ta_id = base . ta_id ,
@ -1143,44 +1223,71 @@ class ActionsEditMixin:
base . delete ( )
base . delete ( )
numero_completo_irmao = None
if ( len ( irmaos_posteriores ) == 1 and
' ; ' in irmaos_posteriores [ 0 ] .
tipo_dispositivo . rotulo_prefixo_texto ) :
i = irmaos_posteriores [ 0 ]
i . set_numero_completo ( [ 0 , 0 , 0 , 0 , 0 , 0 , ] )
i . rotulo = i . rotulo_padrao ( local_insert = 1 )
i . save ( )
else :
for irmao in irmaos_posteriores :
for irmao in irmaos_posteriores :
numero_completo_irmao = irmao . get_numero_completo ( )
irmao . transform_in_prior ( )
irmao . set_numero_completo ( numero_completo_base )
numero_completo_base = numero_completo_irmao
irmao . rotulo = irmao . rotulo_padrao ( )
irmao . rotulo = irmao . rotulo_padrao ( )
irmao . save ( )
irmao . save ( )
else :
else :
proxima_articulacao = base . get_proximo_nivel_zero ( )
proxima_articulacao = base . get_proximo_nivel_zero ( )
# Dispostivos de Contagem contínua de dentro da base
# Renumerar Dispostivos de Contagem Contínua de dentro da base
if not proxima_articulacao :
dcc = Dispositivo . objects . order_by ( ' ordem ' ) . filter (
dcc = Dispositivo . objects . order_by ( ' ordem ' ) . filter (
ta_id = base . ta_id ,
ta_id = base . ta_id ,
ordem__gt = base . ordem ,
ordem__gt = base . ordem ,
tipo_dispositivo__contagem_continua = True )
tipo_dispositivo__contagem_continua = True )
else :
dcc = Dispositivo . objects . order_by ( ' ordem ' ) . filter (
ta_id = base . ta_id ,
ordem__gt = base . ordem ,
ordem__lt = proxima_articulacao . ordem ,
tipo_dispositivo__contagem_continua = True )
for d in dcc :
base_adicao = { }
nivel_zero_anterior = base . get_nivel_zero_anterior ( )
if nivel_zero_anterior :
nivel_zero_anterior = nivel_zero_anterior . ordem
else :
nivel_zero_anterior = 0
dcc = list ( dcc )
for d in dcc : # ultimo DCC do tipo encontrado
if d . tipo_dispositivo . class_css not in base_adicao :
ultimo_dcc = Dispositivo . objects . order_by (
ultimo_dcc = Dispositivo . objects . order_by (
' ordem ' ) . filter (
' ordem ' ) . filter (
ta_id = base . ta_id ,
ta_id = base . ta_id ,
ordem__lt = d . ordem ,
ordem__lt = base . ordem ,
ordem__gt = nivel_zero_anterior ,
tipo_dispositivo__contagem_continua = True ,
tipo_dispositivo__contagem_continua = True ,
tipo_dispositivo = d . tipo_dispositivo ) . last ( )
tipo_dispositivo = d . tipo_dispositivo ) . last ( )
if not ultimo_dcc :
if not ultimo_dcc :
break
break
d . set_numero_completo ( ultimo_dcc . get_numero_completo ( ) )
if d . dispositivo_substituido != ultimo_dcc :
base_adicao [
d . transform_in_next ( )
d . tipo_dispositivo . class_css ] = ultimo_dcc . \
dispositivo0
d . rotulo = d . rotulo_padrao ( )
d . dispositivo0 + = base_adicao [ d . tipo_dispositivo . class_css ]
d . save ( clean = False )
base . delete ( )
d . rotulo = d . rotulo_padrao ( )
dcc . reverse ( )
for d in dcc :
d . save ( )
elif bloco :
# TODO: reorganizar dispositivos de contagem continua
base . delete ( )
base . delete ( )
return ' '
def add_prior ( self , context ) :
def add_prior ( self , context ) :
return { }
return { }
@ -1238,6 +1345,7 @@ class ActionsEditMixin:
ultimo_irmao = Dispositivo . objects . order_by (
ultimo_irmao = Dispositivo . objects . order_by (
' -ordem ' ) . filter (
' -ordem ' ) . filter (
ordem__lte = base . ordem ,
ordem__lte = base . ordem ,
ordem__gte = parents [ - 1 ] . ordem ,
tipo_dispositivo_id = tipo . pk ,
tipo_dispositivo_id = tipo . pk ,
ta_id = base . ta_id ) [ : 1 ]
ta_id = base . ta_id ) [ : 1 ]
@ -1268,7 +1376,7 @@ class ActionsEditMixin:
if qtd_existente > = pp [ 0 ] . quantidade_permitida :
if qtd_existente > = pp [ 0 ] . quantidade_permitida :
return { ' pk ' : base . pk ,
return { ' pk ' : base . pk ,
' pai ' : [ base . dispositivo_pai . pk , ] ,
' pai ' : [ base . dispositivo_pai . pk , ] ,
' alert ' : str ( _ ( ' Limite de inserções de '
' message ' : str ( _ ( ' Limite de inserções de '
' dispositivos deste tipo '
' dispositivos deste tipo '
' foi excedido. ' ) )
' foi excedido. ' ) )
}
}
@ -1280,7 +1388,6 @@ class ActionsEditMixin:
dp . ordem = ordem
dp . ordem = ordem
dp . incrementar_irmaos ( variacao , [ local_add , ] , force = False )
dp . incrementar_irmaos ( variacao , [ local_add , ] , force = False )
dp . clean ( )
dp . save ( )
dp . save ( )
dp_auto_insert = None
dp_auto_insert = None
@ -1300,7 +1407,6 @@ class ActionsEditMixin:
dp . rotulo = dp . rotulo_padrao ( )
dp . rotulo = dp . rotulo_padrao ( )
dp . texto = ' '
dp . texto = ' '
dp . ordem = dp . ordem + Dispositivo . INTERVALO_ORDEM
dp . ordem = dp . ordem + Dispositivo . INTERVALO_ORDEM
dp . clean ( )
dp . save ( )
dp . save ( )
dp_auto_insert = dp
dp_auto_insert = dp
dp = Dispositivo . objects . get ( pk = dp_pk )
dp = Dispositivo . objects . get ( pk = dp_pk )
@ -1377,58 +1483,38 @@ class ActionsEditMixin:
filho . tipo_dispositivo . class_css ]
filho . tipo_dispositivo . class_css ]
filho . rotulo = filho . rotulo_padrao ( )
filho . rotulo = filho . rotulo_padrao ( )
filho . clean ( )
filho . save ( )
filho . save ( )
''' Renumerar dispositivos de
''' Renumerar dispositivos de
contagem continua , caso a inserção seja uma articulação '''
contagem continua , caso a inserção seja uma articulação '''
numtipos = { }
if dp . nivel == 0 :
if dp . nivel == 0 :
proxima_articulacao = Dispositivo . objects . filter (
proxima_articulacao = dp . get_proximo_nivel_zero ( )
ordem__gt = dp . ordem ,
nivel = 0 ,
ta_id = dp . ta_id ) [ : 1 ]
if not proxima_articulacao . exists ( ) :
if not proxima_articulacao :
filhos_continuos = list ( Dispositivo . objects . filter (
filhos_continuos = list ( Dispositivo . objects . filter (
ordem__gt = dp . ordem ,
ordem__gt = dp . ordem ,
ta_id = dp . ta_id ,
ta_id = dp . ta_id ,
tipo_dispositivo__contagem_continua = True ) )
tipo_dispositivo__contagem_continua = True ) )
else :
else :
filhos_continuos = list ( Dispositivo . objects . filter (
filhos_continuos = list ( Dispositivo . objects . filter (
Q ( ordem__gt = dp . ordem ) &
ordem__gt = dp . ordem ,
Q ( ordem__lt = proxima_articulacao [ 0 ] . ordem ) ,
ordem__lt = proxima_articulacao . ordem ,
ta_id = dp . ta_id ,
ta_id = dp . ta_id ,
tipo_dispositivo__contagem_continua = True ) )
tipo_dispositivo__contagem_continua = True ) )
for filho in filhos_continuos :
base_reducao = { }
if filho . tipo_dispositivo . class_css in numtipos :
for filho in filhos_continuos :
if filho . dispositivo_substituido is None :
if filho . tipo_dispositivo . class_css not in base_reducao :
numtipos [ filho . tipo_dispositivo . class_css ] + = 1
base_reducao [ filho . tipo_dispositivo . class_css ] = \
else :
filho . dispositivo0 - 1
t = filho . tipo_dispositivo
prefixo = t . rotulo_prefixo_texto . split ( ' ; ' )
if len ( prefixo ) > 1 :
count_irmaos_m_tipo = Dispositivo . objects . filter (
~ Q ( pk = filho . pk ) ,
tipo_dispositivo = t ,
dispositivo_pai = filho . dispositivo_pai ) [ : 1 ]
if count_irmaos_m_tipo . exists ( ) :
numtipos [ filho . tipo_dispositivo . class_css ] = 1
else :
numtipos [ filho . tipo_dispositivo . class_css ] = 0
else :
numtipos [ filho . tipo_dispositivo . class_css ] = 1
filho . dispositivo0 = numtipos [
filho . dispositivo0 - = base_reducao [
filho . tipo_dispositivo . class_css ]
filho . tipo_dispositivo . class_css ]
filho . rotulo = filho . rotulo_padrao ( )
filho . rotulo = filho . rotulo_padrao ( )
filho . clean ( )
filho . save ( )
filho . save ( )
except Exception as e :
except Exception as e :