Carriles 2: has_many: a través de la validación?
-
21-09-2019 - |
Pregunta
Rails 2.1.0 (No se puede actualizar por ahora debido a varias limitaciones) Estoy tratando de conseguir esto. ¿Alguna pista?
- Un proyecto tiene muchos usuarios a través de unirse modelo
- Un usuario tiene muchos proyectos a través de unirse modelo
- administración hereda de la clase Clase de usuario. También tiene un poco de materia específica de administración.
- administración como herencia para Supervisor y Operador
- Proyecto tiene un administrador, un supervisor y muchos operadores.
Ahora quiero 1. presentar los datos de proyecto, administrador, supervisor y operador en una sola forma de proyecto 2. validar todos y mostrar los errores en la forma de proyectos.
Project has_many :projects_users ; has_many :users, :through => :projects_users
User has_many :projects_users ; has_many :projects, :through => :projects_users
ProjectsUser = :id integer, :user_id :integer, :project_id :integer
ProjectUser belongs_to :project, belongs_to :user
Admin < User # User has 'type:string' column for STI
Supervisor < User
Operator < User
Es correcto el enfoque? Cualquiera y todas las sugerencias son bienvenidas.
Solución 3
Terminé usando atributos virtuales para el administrador, supervisor y operadores todo lo demás fue a través de las asociaciones de ORM
Otros consejos
Creo que una sola mesa Inberitance y formas anidadas pueden ayudarle a cabo aquí. Es posible que quiero leer sobre ello en la documentación. http://api.rubyonrails.org/classes/ActiveRecord/Base.html
me di cuenta de las mentiras de respuesta en herencia simple mesa con has_many: a través
class Project < ActiveRecord::Base
has_many :projects_users, :dependent => :destroy
has_many :users, :through => :projects_users, :dependent => :destroy
has_one :admin, :through => :projects_users, :source => :user, :conditions => {:type => "Admin"}
has_one :supervisor, :through => :projects_users, :source => :user, :conditions => {:type => "Supervisor"}
has_many :operators, :through => :projects_users, :source => :user, :conditions => {:type => "Operator"}
validates_presence_of :name
validates_associated :admin
def admin_attributes=(attributes)
# build an admin object and apply to this relation
end
def supervisor_attributes=(attributes)
# build a supervisor object and apply to this relation
end
def operator_attributes=(operator_attributes)
operator_attributes.each do |attributes|
# build an operator object for each set of attributes and apply to this relation
end
end
end
class User < ActiveRecord::Base
has_many :projects_users, :dependent => :destroy
has_many :projects, :through => :projects_users, :dependent => :destroy
validates_presence_of :name
validates_associated :projects
end
class ProjectsUser < ActiveRecord::Base
belongs_to :project
belongs_to :user
end
class Admin < User
end
class Supervisor < User
end
class Operator < User
end
Ahora podemos tener la siguiente
project1.users # User objects for admin, supervisor and operators
project1.admin # User object for Admin
project1.supervisor # User object for Supervisor
project1.operators # User objects for Operator
una forma compleja que incluye todos estos pueden tener
<% form_for :project ...
<% fields_for "project[admin_attributes]", @project.admin do |admin_form|
...
<% @project.operators.each do |operator| %>
<% fields_for "project[operator_attributes][]", operator do |operator_form| %>
y así sucesivamente ...