Robert Hopman

Joined

290 Experience
2 Lessons Completed
0 Questions Solved

Activity

Have you looked at this gem: https://github.com/schneems/wicked ?

Refactored into:

class SubmissionsController < ApplicationController
include Wicked::Wizard
steps :name, :details, :comments, :submit, :thankyou

def show
    get_company
    set_package
    render_wizard
end

def update
    case step
    when :thankyou
        get_company
        render_wizard @company
    when :submit
        get_company
        set_package
        if request.put?
            create_customer
            do_payment
            render_wizard @company
        end
    else
        get_company
        params[:company][:status] = 'active' if step == steps.last
        @company.update_attributes(company_params)
        render_wizard @company
    end
end

def get_company
    @company = Company.find(params[:company_id])
end

def create_customer
    @customer = Stripe::Customer.create(
        :email => params[:stripeEmail],
        :source  => params[:stripeToken]
    )
end

def set_package
    @amount = 50
    @amount_in_decimals = @amount / 100.00
    @description = "Premium Package"
end

def do_payment
    Stripe::Charge.create(
        :customer    => @customer.id,
        :amount      => @amount,
        :description => @description,
        :currency    => "eur"
    )

    rescue Stripe::CardError => e
        flash[:error] = e.message
end

Hey Chris, thanks.

Added a couple of spaces in the submit.html.erb template, otherwise it wouldn't be visible.

Right now I get this error message when the submit.html.erb loads: Cannot charge a customer that has no active card.

I want to understand how I can improve my controller. The goal is to not have the error message when the submit page loads. But only if there's an actual user submitting false information.

class SubmissionsController < ApplicationController
include Wicked::Wizard
steps :name, :details, :comments, :submit, :thankyou

def show
@company = Company.find(params[:company_id])
render_wizard
end

def update
@company = Company.find(params[:company_id])

one time checkout
@amount = 50
@description = 'Premium Package'

customer = Stripe::Customer.create(
:email => params[:stripeEmail],
:source  => params[:stripeToken]
)

Stripe::Charge.create(
:customer    => customer.id,
:amount      => @amount,
:description => @description,
:currency    => 'eur'
)

rescue Stripe::CardError => e
flash[:error] = e.message

params[:company][:status] = step.to_s
params[:company][:status] = 'active' if step == steps.last
@company.update_attributes(company_params)
render_wizard @company
end

private ...

Here's the submit.html.erb

< %= form_for @company, url: wizard_path, method: :put do |f| %>
< article>
< % if flash[:error].present? %>
< div id="error_explanation">
< p><%= flash[:error] %></p>
</ div>
< % end %>
< label class="amount">
< span>Amount: €0.50</span>
< /label>
< /article>

< script src="https://checkout.stripe.com/checkout.js" class="stripe-button"
data-key="<%= Rails.configuration.stripe[:publishable_key] %>"
data-description=<% @description %>
data-amount=<% @amount %>
data-locale="auto"></script>
< % end %>

If I can provide more context, please advise.

Screencast tutorials to help you learn Ruby on Rails, Javascript, Hotwire, Turbo, Stimulus.js, PostgreSQL, MySQL, Ubuntu, and more.

© 2024 GoRails, LLC. All rights reserved.