Class: Decidim::Proposals::WithdrawProposal
- Defined in:
- decidim-proposals/app/commands/decidim/proposals/withdraw_proposal.rb
Overview
A command with all the business logic when a user withdraws a new proposal.
Instance Method Summary collapse
-
#call ⇒ Object
Executes the command.
-
#initialize(proposal, current_user) ⇒ WithdrawProposal
constructor
Public: Initializes the command.
Methods inherited from Command
call, #evaluate, #method_missing, #respond_to_missing?, #transaction, #with_events
Constructor Details
#initialize(proposal, current_user) ⇒ WithdrawProposal
Public: Initializes the command.
proposal - The proposal to withdraw. current_user - The current user.
11 12 13 14 |
# File 'decidim-proposals/app/commands/decidim/proposals/withdraw_proposal.rb', line 11 def initialize(proposal, current_user) @proposal = proposal @current_user = current_user end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Decidim::Command
Instance Method Details
#call ⇒ Object
Executes the command. Broadcasts these events:
-
:ok when everything is valid, together with the proposal.
-
:has_votes if the proposal already has votes or does not belong to current user.
Returns nothing.
22 23 24 25 26 27 28 29 30 31 |
# File 'decidim-proposals/app/commands/decidim/proposals/withdraw_proposal.rb', line 22 def call return broadcast(:has_votes) if @proposal.votes.any? transaction do @proposal.withdraw! reject_emendations_if_any end broadcast(:ok, @proposal) end |