# frozen_string_literal: true module Decidim module ParticipatoryProcesses module Admin # A command with all the business logic when creating a new participatory # process group in the system. class UpdateParticipatoryProcessGroup < Decidim::Command include ::Decidim::AttachmentAttributesMethods # Public: Initializes the command. # # participatory_process_group - the ParticipatoryProcessGroup to update # form - A form object with the params. def initialize(participatory_process_group, form) @participatory_process_group = participatory_process_group @form = form end # Executes the command. Broadcasts these events: # # - :ok when everything is valid. # - :invalid if the form wasn't valid and we couldn't proceed. # # Returns nothing. def call return broadcast(:invalid) if form.invalid? update_participatory_process_group if @participatory_process_group.valid? broadcast(:ok, @participatory_process_group) else form.errors.add(:hero_image, @participatory_process_group.errors[:hero_image]) if @participatory_process_group.errors.include? :hero_image broadcast(:invalid) end end private attr_reader :form def update_participatory_process_group Decidim.traceability.perform_action!( "update", @participatory_process_group, form.current_user ) do @participatory_process_group.assign_attributes(attributes) @participatory_process_group.save! if @participatory_process_group.valid? end end def attributes { title: form.title, description: form.description, hashtag: form.hashtag, group_url: form.group_url, participatory_processes: participatory_processes, developer_group: form.developer_group, local_area: form.local_area, meta_scope: form.meta_scope, participatory_scope: form.participatory_scope, participatory_structure: form.participatory_structure, target: form.target, promoted: form.promoted }.merge(attachment_attributes(:hero_image)) end def participatory_processes Decidim::ParticipatoryProcess.where(id: form.participatory_process_ids) end end end end end