使用Devise创建一个两步注册表单

时间:2016-01-20 01:27:24

标签: ruby-on-rails devise

我的应用程序允许两种用户:经销商和买家。他们每个人都有不同的自定义字段,然后我需要在注册中添加第一步,用户可以选择他的用户类型,电子邮件地址和密码。点击注册后,它将被重定向到一个页面以完成其个人资料。

设备注册视图使用以下代码:

<h2>Sign up</h2>

<%= simple_form_for(resource, as: resource_name, url: registration_path(resource_name)) do |f| %>
  <%= f.error_notification %>

  <div class="form-inputs">
    <%= f.input :email, required: true, autofocus: true %>
    <%= f.input :password, required: true, hint: ("#{@minimum_password_length} characters minimum" if @minimum_password_length) %>
    <%= f.input :password_confirmation, required: true %>
  </div>

  <div class="form-actions">
    <%= f.button :submit, "Sign up" %>
  </div>
<% end %>

<%= render "devise/shared/links" %>

但是我需要将注册表单添加到我的应用程序布局中,因为它可以从导航栏访问。我是否必须按原样复制Devise视图代码?我的意思是,视图使用Devise控制器上定义的变量。它可以在我的布局/其他控制器上工作吗?

1 个答案:

答案 0 :(得分:0)

如果您的意思是表单应该在导航栏中可见(而不是只包含指向注册页面的链接的导航栏),那么是的,它会在您将其作为:url的任何位置使用在simple_form_for语句中指定。

那就是说,我建议不要将此代码复制到application.html.erb布局:您应该将其放在部分(例如_sign_up.html.erb)中,并且只从应用程序布局中呈现它:

<%= render 'sign_up' unless user_signed_in? %>