Моей проблемы немного связана с this question, и соответствующим solution оказался полезным и полезным, однако есть небольшое отступление от этого вопроса, который я хотел бы объяснить далее:Рубин на Rails проверка не отображаются сообщений об ошибках
Я использовал active_record-acts_as камень над devise камень, чтобы создать модель с несколькими формами регистрации и единого входа в аккаунт форме, так что у меня есть модель DEViSE под названием Client и другие клиентские типы, такие как Компания и Индивидуальные действуют как модель клиента Devise, и все эти разработки MTI были основаны o на макете отличается от application.html.erb макета, и я назвал его client_authentication_layout.html.erb
Резюмируя мой вопрос, у меня есть контроллеров для каждого из моих моделей с соответствующими видом и я переопределение клиент разработал вид модели, чтобы я мог отображать формы и представления Компании и отдельных лиц в виде вкладки, которая была успешной.
Для ясности, вот модели:
client.rb
class Client < ActiveRecord::Base
actable
# Include default devise modules. Others available are:
# :confirmable, :lockable, :timeoutable and :omniauthable
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable
validates :email, :encrypted_password, presence: true
end
company.rb
class Company < ActiveRecord::Base
acts_as :client
validates :company_name,
:company_url,
:country,
:contact_person,
:phone_number,
presence: true
end
individual.rb
class Individual < ActiveRecord::Base
acts_as :client
end
Для ясности здесь Контроллер компании:
class CompaniesController < ApplicationController
# GET /companies/new
def new
@company = Company.new
end
# POST /companies
# POST /companies.json
def create
@company = Company.new(company_params)
if @company.save
redirect_to root_path, notice: 'Company was successfully created.'
else
redirect_to new_client_registration_path
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_company
@company = Company.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def company_params
params.require(:company).permit(:company_logo, :company_name, :company_url, :country, :contact_person, :phone_number, :email, :password, :password_confirmation)
end
end
Для ясности, вот мое мнение:
компания/new.html.erb
<%= simple_form_for(Company.new) do |f| %>
<div class="form-row">
<%= f.input :company_name, placeholder: 'Company Name', label: false %>
<%= f.input :company_url, placeholder: 'Company URL', label: false %>
<%= f.input :country, placeholder: 'Country', label: false %>
<%= f.input :contact_person, placeholder: 'Contact Person', label: false %>
<%= f.input :phone_number, placeholder: 'Phone Number', label: false %>
<%= f.input :email, required: true, autofocus: true, placeholder: 'Email', label: false %>
<%= f.input :password, required: true, placeholder: 'Password', label: false %>
<%= f.input :password_confirmation, required: true, placeholder: 'Password Confirmation', label: false %>
</div>
<%= render 'shared/two_breaks' %>
<div class='form-row'>
<div class="col-md-12 form-group">
<%= f.submit 'Get Started', class: 'btn btn-company' %>
</div>
<%= render 'shared/four_breaks' %>
</div>
<% end %>
индивидуальные/new.html.erb
<%= simple_form_for(Individual.new) do |f| %>
<div class="form-inputs">
<%= f.input :first_name, placeholder: 'First Name', label: false %>
<%= f.input :last_name, placeholder: 'Last Name', label: false %>
<%= f.input :about_me, placeholder: 'Type in a little details about yourself.', label: false %>
<%= f.input :gender, placeholder: 'Choose gender', label: false %>
<%= f.input :country, placeholder: 'Country', label: false %>
<%= f.input :phone_number, placeholder: 'Phone Number', label: false %>
<%= f.input :email, required: true, autofocus: true, placeholder: 'Email', label: false %>
<%= f.input :password, required: true, placeholder: 'Password', label: false %>
<%= f.input :password_confirmation, required: true, placeholder: 'Password Confirmation', label: false %>
</div>
<%= render 'shared/two_breaks' %>
<div class='form-row'>
<div class="col-md-12 form-group">
<%= f.submit 'Get Started', class: 'btn btn-individual' %>
</div>
<%= render 'shared/four_breaks' %>
</div>
<% end %>
client_au thentication_layout.html.erb
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="ROBOTS" content="NOODP" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>FarFlung Jobs</title>
<!-- /.You can include style.css into stylesheet_link_tag too. If you do so, dont forget to add style.css in asset.rb -->
<%= stylesheet_link_tag 'clients_authentication', media: 'all' %>
<%= javascript_include_tag 'clients_authentication' %>
<%= csrf_meta_tags %>
</head>
<body>
<%= yield %>
</body>
</html>
Мои вкладками Форма оказания компании и индивидуальные Просмотров на клиента Devise Посмотреть
<div class="container">
<div class="row">
<div class="col-md-6 col-md-offset-3">
<!--col-sm-6 col-sm-offset-3 col-xs-4 col-xs-offset-3-->
<div class="panel panel-login">
<div class="panel-heading">
<div class="row">
<div class="col-xs-6 tabs">
<a href="#" class="active" id="company-form-link"><div class="company">COMPANY</div></a>
</div>
<div class="col-xs-6 tabs">
<a href="#" id="individual-form-link"><div class="individual">INDIVIDUAL</div></a>
</div>
</div>
</div>
<div class="panel-body">
<div class="row">
<div class="col-lg-12">
<div id="company-form" role="form" style="display: block;">
<h2>COMPANY</h2>
<%= render 'companies/form' %>
</div>
<div id="individual-form" role="form" style="display: none;">
<h2>INDIVIDUAL</h2>
<%= render 'individuals/form' %>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="container">
<div class="row">
<div class="col-md-12 text-center">
<span class="agreement">
<p>By clicking Get Started, you agree to the FarFlung <a tabindex="2" href="https://www.linkedin.com/legal/user-agreement">User Agreement</a>, </p>
<p><a tabindex="2" href="https://www.linkedin.com/legal/privacy-policy">Privacy Policy</a>, and <a tabindex="2" href="https://www.linkedin.com/legal/cookie-policy">Cookie Policy</a>.</p>
</span>
</div>
</div>
</div>
Rails консоли
>> c = Company.new
#<Company id: nil, company_logo: nil, company_name: nil, company_url: nil, country: nil, contact_person: nil, phone_number: nil, created_at: nil, updated_at: nil>
>> c.valid?
false
>> c.errors.full_messages
["Email can't be blank", "Email can't be blank", "Password can't be blank", "Encrypted password can't be blank", "Company name can't be blank", "Company url can't be blank", "Country can't be blank", "Contact person can't be blank", "Phone number can't be blank"]
>> c.errors
#<ActiveModel::Errors:0x74f6ee0 @base=#<Company id: nil, company_logo: nil, company_name: nil, company_url: nil, country: nil, contact_person: nil, phone_number: nil, created_at: nil, updated_at: nil>, @messages={:email=>["can't be blank", "can't be blank"], :password=>["can't be blank"], :encrypted_password=>["can't be blank"], :company_name=>["can't be blank"], :company_url=>["can't be blank"], :country=>["can't be blank"], :contact_person=>["can't be blank"], :phone_number=>["can't be blank"]}>
Однако, если Я представляю emp ty, и валидации вступают в силу, он просто не отображается в формах, созданных simple_form, где лежит основная ошибка.
Чтобы решить эту проблему, я выполнил вышеупомянутое решение, указанное выше, которое оказалось успешным. Но это влияет на все другие успешные формы проверки в других макетах моего приложения. Только формы, оснащенные client_authentication_layout.html.erb
, не подтверждают проверку в браузере.
Как решить эту проблему? Заранее спасибо.