Class: Effective::OrdersController

Inherits:
ApplicationController
  • Object
show all
Includes:
Concerns::Purchase, CrudController, Providers::Cheque, Providers::Etransfer, Providers::Free, Providers::MarkAsPaid, Providers::Moneris, Providers::MonerisCheckout, Providers::Paypal, Providers::Phone, Providers::Pretend, Providers::Refund, Providers::Stripe
Defined in:
app/controllers/effective/orders_controller.rb

Instance Method Summary collapse

Methods included from Providers::Stripe

#stripe

Methods included from Providers::Refund

#refund, #refund_params

Methods included from Providers::Pretend

#pretend, #pretend_params

Methods included from Providers::Phone

#phone, #phone_params

Methods included from Providers::Paypal

#paypal_postback

Methods included from Providers::MonerisCheckout

#moneris_checkout

Methods included from Providers::Moneris

#moneris_postback

Methods included from Providers::MarkAsPaid

#mark_as_paid, #mark_as_paid_params

Methods included from Providers::Free

#free, #free_params

Methods included from Providers::Etransfer

#etransfer, #etransfer_params

Methods included from Providers::Cheque

#cheque, #cheque_params

Instance Method Details

#bulk_send_buyer_receiptObject



121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# File 'app/controllers/effective/orders_controller.rb', line 121

def bulk_send_buyer_receipt
  @orders = Effective::Order.purchased.where(id: params[:ids])

  begin
    EffectiveResources.authorize!(self, :index, Effective::Order.new(user: current_user))

    @orders.each do |order|
      next unless EffectiveResources.authorized?(self, :show, order)
      order.send_order_receipt_to_buyer!
    end

    render json: { status: 200, message: "Successfully sent #{@orders.length} receipt emails"}
  rescue => e
    render json: { status: 500, message: "Bulk send buyer receipt error: #{e.message}" }
  end
end

#createObject

Confirms an order from the cart.



44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'app/controllers/effective/orders_controller.rb', line 44

def create
  @order ||= Effective::Order.new(view_context.current_cart)
  EffectiveResources.authorize!(self, :create, @order)

  @order.assign_attributes(checkout_params)

  if (@order.confirm! rescue false)
    redirect_to(effective_orders.order_path(@order))
  else
    flash.now[:danger] = "Unable to proceed: #{flash_errors(@order)}. Please try again."
    render :new
  end
end

#declinedObject



102
103
104
105
# File 'app/controllers/effective/orders_controller.rb', line 102

def declined
  @order = Effective::Order.declined.find(params[:id])
  EffectiveResources.authorize!(self, :show, @order)
end

#deferredObject



97
98
99
100
# File 'app/controllers/effective/orders_controller.rb', line 97

def deferred
  @order = Effective::Order.deferred.find(params[:id])
  EffectiveResources.authorize!(self, :show, @order)
end

#editObject

Always step1



71
72
73
74
# File 'app/controllers/effective/orders_controller.rb', line 71

def edit
  @order ||= Effective::Order.was_not_purchased.find(params[:id])
  EffectiveResources.authorize!(self, :edit, @order)
end

#newObject

If you want to use the Add to Cart -> Checkout flow Add one or more items however you do. redirect_to effective_orders.new_order_path, which is here. This is the entry point for any Checkout button. It displayes an order based on the cart Always step1



31
32
33
34
35
36
37
38
39
40
41
# File 'app/controllers/effective/orders_controller.rb', line 31

def new
  @order ||= Effective::Order.new(view_context.current_cart)

  EffectiveResources.authorize!(self, :new, @order)

  unless @order.valid?
    flash[:danger] = "Unable to proceed: #{flash_errors(@order)}. Please try again."
    redirect_to(effective_orders.cart_path)
    return
  end
end

#purchasedObject

Thank you for Purchasing this Order. This is where a successfully purchased order ends up



92
93
94
95
# File 'app/controllers/effective/orders_controller.rb', line 92

def purchased # Thank You!
  @order = Effective::Order.purchased.find(params[:id])
  EffectiveResources.authorize!(self, :show, @order)
end

#send_buyer_receiptObject



107
108
109
110
111
112
113
114
115
116
117
118
119
# File 'app/controllers/effective/orders_controller.rb', line 107

def send_buyer_receipt
  @order = Effective::Order.purchased.find(params[:id])

  EffectiveResources.authorize!(self, :show, @order)

  if @order.send_order_receipt_to_buyer!
    flash[:success] = "A receipt has been sent to #{@order.emails_send_to}"
  else
    flash[:danger] = "Unable to send receipt."
  end

  redirect_to effective_orders.order_path(@order)
end

#showObject

If you want to use the order = Effective::Order.new(@thing); order.save! flow Add one or more items to the order. redirect_to effective_orders.order_path(order), which is here This is the entry point for an existing order. Might render step1 or step2



63
64
65
66
67
68
# File 'app/controllers/effective/orders_controller.rb', line 63

def show
  @order = Effective::Order.find(params[:id])
  EffectiveResources.authorize!(self, :show, @order)

  @page_title ||= ((@order.user == current_user && !@order.purchased?) ? 'Checkout' : @order.to_s)
end

#updateObject

Confirms the order from existing order



77
78
79
80
81
82
83
84
85
86
87
88
89
# File 'app/controllers/effective/orders_controller.rb', line 77

def update
  @order ||= Effective::Order.was_not_purchased.find(params[:id])
  EffectiveResources.authorize!(self, :update, @order)

  @order.assign_attributes(checkout_params)

  if (@order.confirm! rescue false)
    redirect_to(effective_orders.order_path(@order))
  else
    flash.now[:danger] = "Unable to proceed: #{flash_errors(@order)}. Please try again."
    render :edit
  end
end