24 lines
1.1 KiB
Ruby
24 lines
1.1 KiB
Ruby
|
class CarteController < ApplicationController
|
||
|
def show
|
||
|
@map_filter = MapFilter.new(params)
|
||
|
@map_filter.stats = stats
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def stats
|
||
|
departements_sql = "select departement, count(procedures.id) as nb_demarches, sum(procedures.estimated_dossiers_count) as nb_dossiers from services inner join procedures on services.id = procedures.service_id where procedures.hidden_at is null and procedures.aasm_state in ('publiee', 'close', 'depubliee')"
|
||
|
departements_sql += " and procedures.published_at >= '#{@map_filter.year}-01-01' and procedures.published_at <= '#{@map_filter.year}-12-31'" if @map_filter.year.present?
|
||
|
departements_sql += " group by services.departement"
|
||
|
departements = ActiveRecord::Base.connection.execute(ActiveRecord::Base.sanitize_sql(departements_sql))
|
||
|
departements.to_a.reduce(Hash.new({ nb_demarches: 0, nb_dossiers: 0 })) do |h, v|
|
||
|
h.merge(
|
||
|
v["departement"] => {
|
||
|
'nb_demarches': v["nb_demarches"].presence || 0,
|
||
|
'nb_dossiers': v['nb_dossiers'].presence || 0
|
||
|
}
|
||
|
)
|
||
|
end
|
||
|
end
|
||
|
end
|