Sha256: 008ef36d8c54f93fb29670ff3554cf0933aac6dca495f7ca55b0eab8cdd81368
Contents?: true
Size: 1.63 KB
Versions: 15
Compression:
Stored size: 1.63 KB
Contents
# frozen_string_literal: true module Decidim module Debates module Metrics class DebatesMetricManage < Decidim::MetricManage def metric_name "debates" end def save cumulative.each do |key, cumulative_value| next if cumulative_value.zero? quantity_value = quantity[key] || 0 category_id, space_type, space_id = key record = Decidim::Metric.find_or_initialize_by(day: @day.to_s, metric_type: @metric_name, organization: @organization, decidim_category_id: category_id, participatory_space_type: space_type, participatory_space_id: space_id) record.assign_attributes(cumulative: cumulative_value, quantity: quantity_value) record.save! end end private def query return @query if @query @query = Decidim::Debates::Debate.where(component: visible_component_ids_from_spaces(retrieve_participatory_spaces)).joins(:component) .left_outer_joins(:category) @query = @query.where("decidim_debates_debates.start_time <= ?", end_time) @query = @query.group("decidim_categorizations.decidim_category_id", :participatory_space_type, :participatory_space_id) @query end def quantity @quantity ||= query.where("decidim_debates_debates.start_time >= ?", start_time).count end end end end end
Version data entries
15 entries across 15 versions & 1 rubygems