Class: Gestorh::FolhaAgrupadaIdSeparado

Inherits:
GestorhRecord
  • Object
show all
Defined in:
app/models/gestorh/folha_agrupada_id_separado.rb

Instance Method Summary collapse

Instance Method Details

#diariasObject

diarias



73
74
75
76
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 73

def diarias
  self.daily_rates.where(date: [Date.new(self.ano, self.mes)..Date.new(self.ano, self.mes).at_end_of_month])
    .sum(:pago)
end

#diarias_negativasObject



83
84
85
86
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 83

def diarias_negativas
  self.daily_rates.where(pago: [-Float::INFINITY..0], date: [Date.new(self.ano, self.mes)..Date.new(self.ano, self.mes).at_end_of_month])
      .sum(:pago)
end

#diarias_positivasObject



78
79
80
81
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 78

def diarias_positivas
  self.daily_rates.where(pago: [0..Float::INFINITY], date: [Date.new(self.ano, self.mes)..Date.new(self.ano, self.mes).at_end_of_month])
      .sum(:pago)
end

#eventos_e_valoresObject



16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 16

def eventos_e_valores
  # .where.not('cdclassificacaoverba.cv_classificacao': 'DESCONTO_PREVIDENCIA_PUBLICA_IAPEP')
  Gestorh::MovimentoAcumulado.where(mv_regfolha: self.folhas, mv_matricula: self.matricula)
    .joins(verba: :classificacao_verba)
    .select('mv_regfolha as folha_id',
      'mv_verba as codigo_evento',
      'mv_referencia as fator',
      'cdverba.vb_nome as nome_evento',
      'mv_dc as status', 'mv_total as valor',
      'cdclassificacaoverba.cv_classificacao as tipo')
    .to_a
    .uniq{|x| [x.codigo_evento, x.status, x.valor] } # uniq temporario para remover verbas com 2 classificacoes
end

#gratificacoesObject



58
59
60
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 58

def gratificacoes
  self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_GRATIFICACOES' && x.status == 'C'}
end

#indenizacoesObject



50
51
52
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 50

def indenizacoes
  self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_INDENIZACOES' && x.status == 'C' }
end

#liquido_totalObject



12
13
14
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 12

def liquido_total
  self.rendimento_total - self.desconto_total
end

#remuneracao_paradigmaObject



30
31
32
33
34
35
36
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 30

def remuneracao_paradigma
  if Date.new(ano, mes, 1) < Date.new(2013,7,1)
    self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_REMUNERACAO' && x.status == 'C'}
  else
    []
  end
end

#subsidio_vantagens_pessoaisObject

sobrou da show



63
64
65
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 63

def subsidio_vantagens_pessoais
  self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_VANTAGENS_EVENTUAIS' || x.tipo == 'RENDIMENTO_VANTAGENS_PESSOAIS'}
end

#subsidio_vantagens_pessoais_eventuaisObject



67
68
69
70
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 67

def subsidio_vantagens_pessoais_eventuais
  self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_SUBSIDIO_DIFERENCA_FUNCAO' ||
    x.tipo == 'RENDIMENTO_VANTAGENS_PESSOAIS' || (x.tipo == 'RENDIMENTO_VANTAGENS_EVENTUAIS' && x.status == 'C')}
end

#subsidiosObject



42
43
44
45
46
47
48
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 42

def subsidios
  if Date.new(ano, mes, 1) < Date.new(2013,7,1)
    []
  else
    self.eventos_e_valores.select{|x| (x.tipo == 'RENDIMENTO_SUBSIDIO_DIFERENCA_FUNCAO' ||  x.tipo == 'RENDIMENTO_REMUNERACAO') && x.status == 'C'}
  end
end

#vantagens_eventuaisObject



54
55
56
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 54

def vantagens_eventuais
  self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_VANTAGENS_EVENTUAIS' && x.status == 'C'}
end

#vantagens_pessoaisObject



38
39
40
# File 'app/models/gestorh/folha_agrupada_id_separado.rb', line 38

def vantagens_pessoais
  self.eventos_e_valores.select{|x| x.tipo == 'RENDIMENTO_VANTAGENS_PESSOAIS' && x.status == 'C'}
end