-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix proposal creation for SimpleProposal x Awesome proposal private f…
…ields - remove old proposals_controller.rb overload - overload SimpleProposals proposals_controller_override.rb
- Loading branch information
Showing
3 changed files
with
202 additions
and
308 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
198 changes: 198 additions & 0 deletions
198
app/controllers/concerns/decidim/simple_proposal/proposals_controller_override.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,198 @@ | ||
# frozen_string_literal: true | ||
|
||
module Decidim | ||
module SimpleProposal | ||
module ProposalsControllerOverride | ||
extend ActiveSupport::Concern | ||
|
||
included do | ||
def index | ||
if component_settings.participatory_texts_enabled? | ||
@proposals = ::Decidim::Proposals::Proposal | ||
.where(component: current_component, deleted_at: nil) | ||
.published | ||
.not_hidden | ||
.only_amendables | ||
.includes(:category, :scope) | ||
.order(position: :asc) | ||
render "decidim/proposals/proposals/participatory_texts/participatory_text" | ||
else | ||
@base_query = search | ||
.results | ||
.where(deleted_at: nil) | ||
.published | ||
.not_hidden | ||
|
||
@proposals = @base_query.includes(:component, :coauthorships) | ||
@all_geocoded_proposals = @base_query.geocoded.where.not(latitude: Float::NAN, longitude: Float::NAN) | ||
|
||
@voted_proposals = if current_user | ||
::Decidim::Proposals::ProposalVote.where( | ||
author: current_user, | ||
proposal: @proposals.pluck(:id) | ||
).pluck(:decidim_proposal_id) | ||
else | ||
[] | ||
end | ||
@proposals = paginate(@proposals) | ||
@proposals = reorder(@proposals) | ||
end | ||
end | ||
|
||
def new | ||
if proposal_draft.present? | ||
redirect_to edit_draft_proposal_path(proposal_draft, component_id: proposal_draft.component.id, question_slug: proposal_draft.component.participatory_space.slug) | ||
else | ||
enforce_permission_to :create, :proposal | ||
@step = :step_1 | ||
@proposal ||= Decidim::Proposals::Proposal.new(component: current_component) | ||
@form = form_proposal_model | ||
@form.body = translated_proposal_body_template | ||
@form.attachment = form_attachment_new | ||
end | ||
end | ||
|
||
def create | ||
enforce_permission_to :create, :proposal | ||
@step = :step_1 | ||
@form = form(Decidim::Proposals::ProposalForm).from_params(proposal_creation_params) | ||
|
||
@proposal = Decidim::Proposals::Proposal.new(@form.attributes.except( | ||
:user_group_id, | ||
:category_id, | ||
:scope_id, | ||
:has_address, | ||
:attachment, | ||
:body_template, | ||
:suggested_hashtags, | ||
:photos, | ||
:add_photos, | ||
:documents, | ||
:add_documents | ||
).merge( | ||
component: current_component | ||
)) | ||
user_group = Decidim::UserGroup.find_by( | ||
organization: current_organization, | ||
id: params[:proposal][:user_group_id] | ||
) | ||
@proposal.add_coauthor(current_user, user_group: user_group) | ||
|
||
# We could set these when creating proposal, but We want to call update because after that proposal becomes persisted | ||
# and it adds coauthor correctly. | ||
@proposal.update(title: { I18n.locale => @form.attributes[:title] }) | ||
@proposal.update( | ||
body: { I18n.locale => @form.attributes[:body] }, | ||
private_body: { I18n.locale => @form.attributes[:private_body] } | ||
) | ||
|
||
Decidim::Proposals::UpdateProposal.call(@form, current_user, @proposal) do | ||
on(:ok) do |proposal| | ||
flash[:notice] = I18n.t("proposals.update_draft.success", scope: "decidim") | ||
redirect_to "#{Decidim::ResourceLocatorPresenter.new(proposal).path}/preview" | ||
end | ||
|
||
on(:invalid) do | ||
flash.now[:alert] = I18n.t("proposals.update_draft.error", scope: "decidim") | ||
render :new | ||
end | ||
end | ||
end | ||
|
||
# Overridden because of a core bug when the command posts the "invalid" | ||
# signal and when rendering the form. | ||
def update_draft | ||
enforce_permission_to :edit, :proposal, proposal: @proposal | ||
@step = :step_1 | ||
|
||
@form = form_proposal_params | ||
Decidim::Proposals::UpdateProposal.call(@form, current_user, @proposal) do | ||
on(:ok) do |proposal| | ||
flash[:notice] = I18n.t("proposals.update_draft.success", scope: "decidim") | ||
redirect_to "#{Decidim::ResourceLocatorPresenter.new(proposal).path}/preview" | ||
end | ||
|
||
on(:invalid) do | ||
flash.now[:alert] = I18n.t("proposals.update_draft.error", scope: "decidim") | ||
fix_form_photos_and_documents | ||
render :edit_draft | ||
end | ||
end | ||
end | ||
|
||
# On invalid render edit instead of edit_draft | ||
def update | ||
enforce_permission_to :edit, :proposal, proposal: @proposal | ||
|
||
@form = form_proposal_params | ||
|
||
Decidim::Proposals::UpdateProposal.call(@form, current_user, @proposal) do | ||
on(:ok) do |proposal| | ||
flash[:notice] = I18n.t("proposals.update.success", scope: "decidim") | ||
redirect_to Decidim::ResourceLocatorPresenter.new(proposal).path | ||
end | ||
|
||
on(:invalid) do | ||
flash.now[:alert] = I18n.t("proposals.update.error", scope: "decidim") | ||
fix_form_photos_and_documents | ||
render :edit | ||
end | ||
end | ||
end | ||
|
||
private | ||
|
||
def form_proposal_params | ||
form(Decidim::Proposals::ProposalForm).from_params(params) | ||
end | ||
|
||
def default_filter_params | ||
{ | ||
search_text: "", | ||
origin: default_filter_origin_params, | ||
activity: "all", | ||
category_id: default_filter_category_params, | ||
state: %w(accepted evaluating state_not_published not_answered rejected), | ||
scope_id: default_filter_scope_params, | ||
related_to: "", | ||
type: "all" | ||
} | ||
end | ||
|
||
def can_show_proposal? | ||
return false if @proposal&.deleted_at.present? | ||
return true if @proposal&.amendable? || current_user&.admin? | ||
|
||
Decidim::Proposals::Proposal.only_visible_emendations_for(current_user, current_component).published.include?(@proposal) | ||
end | ||
|
||
def fix_form_photos_and_documents | ||
return unless @form | ||
|
||
@form.photos = map_attachment_objects(@form.photos) | ||
@form.documents = map_attachment_objects(@form.documents) | ||
end | ||
|
||
# Maps the attachment objects for the proposal form in case there are errors | ||
# on the form when it is being saved. Without this, the form would throw | ||
# an exception because it expects these objects to be Attachment records. | ||
def map_attachment_objects(attachments) | ||
return attachments unless attachments.is_a?(Array) | ||
|
||
attachments.map do |attachment| | ||
if attachment.is_a?(String) || attachment.is_a?(Integer) | ||
Decidim::Attachment.find_by(id: attachment) | ||
else | ||
attachment | ||
end | ||
end | ||
end | ||
|
||
# TODO: Remove after feature/configurable_order_for_proposals is merged! | ||
# def default_order | ||
# "recent" | ||
# end | ||
end | ||
end | ||
end | ||
end |
Oops, something went wrong.