我有我的app/views/devise
的意见,我想要做的就是能够传递一些实例变量到我的edit.html.erb
。我是否可以自定义Devise的注册控制器而无需创建自己的视图集?
有没有办法让我这样做,而不必将我的registrations/edit.html.erb
移动到另一个文件夹?
编辑1
这是我做了什么。
app/views/users/registrations_controller.rb
:
class Users::RegistrationsController < Devise::RegistrationsController
def edit
if current_user_subscribed?
@plan = Stripe::Plan.retrieve(current_user.plan_name)
end
super
end
end
这是我routes.rb
:
devise_for :users, controllers: {
invitations: 'invitations',
registrations: 'users/registrations'
},
path_names: { :sign_up => "register",
:sign_in => "login",
:sign_out => "logout",
:settings => "settings" }
这是我app/views/devise/registrations/edit.html.erb
:
<% if current_user_subscribed? %>
<div class="col-md-12 subscribed-card">
<%= render partial: "subscriptions/card_brand", locals: { brand: current_user.card_brand, plan: @plan } %>
</div>
<% end %>
这是我app/views/subscriptions/_card_brand.html.erb
<div class="payment-card">
<div class="row">
<h2>Subscribed To: <%= plan.name %> for <%= formatted_price(plan.amount) %></h2>
</div>
</div>
但是,这是我收到的错误:
NoMethodError at /settings
undefined method `name' for nil:NilClass
编辑2
这是我的服务器日志,这似乎并没有被请求发送到Users::RegistrationsController
就像我会想要:
Processing by Devise::RegistrationsController#edit as HTML
User Load (3.1ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT $2 [["id", 7], ["LIMIT", 1]]
Rendering devise/registrations/edit.html.erb within layouts/devise
Role Load (3.4ms) SELECT "roles".* FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'coach') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]]
School Load (1.6ms) SELECT "schools".* FROM "schools" WHERE "schools"."school_type" IN (1, 2)
Rendered subscriptions/_card_brand.html.erb (12.2ms)
Rendered devise/registrations/edit.html.erb within layouts/devise (904.5ms)
Completed 500 Internal Server Error in 994ms (ActiveRecord: 35.1ms)
我错过了什么?
这正是我所做的,但它不起作用。等一下,我会用我的代码更新这个问题并告诉你。 – marcamillion
我敢肯定,这应该工作,我以前做过。目前无法测试,但稍后会进行测试。 – fbelanger
查看更新的问题。 – marcamillion