Rails 4 Дублирование модельных объектов и объединение новых атрибутов объектов (Amoeba Gem)
Что я делаю: дублирую запись моей модели Project, затем перезаписываю измененные атрибуты из объекта, представленного формой. Новая запись должна быть изменена, но иметь все ассоциации как оригинал.
Первым шагом, который я предпринял, было дублирование объекта AR Model, включая его ассоциации, которые я делаю с гемом Amoeba.
projects_controller.rb
...
def create
if params[:copy]
orig_project = Project.find params[:copy]
@new_project = orig_project.amoeba_dup
...
Теперь я хотел бы объединить мои project_params с объектом @new_project, перезаписывая атрибуты, если они отличаются.
projects_controller.rb
...
def create
if params[:copy]
orig_project = Project.find params[:copy]
@new_project = orig_project.amoeba_dup
my_merge_method(@new_project,project_params)
...
if @new_project.save
Может ли кто-нибудь предоставить хороший способ сделать это с помощью магии рельсов? Спасибо
1 ответ
Возиться с консолью rails Я обнаружил, что метод update_attributes для объектов модели AR делает то, что я хочу.
Например
new_project = orig_project.amoeba_dup
new_project.update_attributes(project_params)
... оставит ассоциации нетронутыми, но перезапишет new_project
с project_params
Вот вывод консоли rails, чтобы доказать это.
35: def create
36: if params[:copy]
37: orig_project = Project.find params[:copy]
38: @project = orig_project.amoeba_dup
39:
=> 40: binding.pry
41: else
42: @project = Project.new(project_params)
43: end
44:
45: respond_to do |format|
46: if @project.save
47: format.html { redirect_to @project, notice: 'Project was successfully created.' }
48: format.json { render action: 'show', status: :created, location: @project }
49: else
50: format.html { render action: 'new' }
51: format.json { render json: @project.errors, status: :unprocessable_entity }
52: end
53: end
54: end
[1] pry(#<ProjectsController>)> params[:copy]
=> "201"
[2] pry(#<ProjectsController>)> @project
=> #<Project:0x00000005c38e58
id: nil,
name: "Corn Flour Milling with Setup",
scheduled_start_date: Tue, 29 Dec 2015,
estimated_end_date: Wed, 27 Jan 2016,
employees_needed: 2,
incoming_packaging: "Boxes",
final_product_packaging: "Boxes",
sample_instructions: "One 18 oz every pallet.\r\nMilled Corn Flour\r\nLot Number\r\nBag Number\r\nNet Weight",
project_description: "Mill the piss out of this.",
project_type: "Production",
building_id: "5",
paid_status: false,
material_total_weight_lbs: 40000,
shifts: 1.0,
shift_hrs: 8,
rate_lb_hr: 2000,
company_id: 1,
created_at: nil,
updated_at: nil>
[4] pry(#<ProjectsController>)> @project.setups
=> [#<Setup:0x00000005c73210 id: 22, created_at: Thu, 21 Jan 2016 14:33:09 UTC +00:00, updated_at: Thu, 21 Jan 2016 14:33:09 UTC +00:00>]
[5] pry(#<ProjectsController>)> project_params
=> {"name"=>"Corn Flour Milling with Setup",
"scheduled_start_date"=>"2016-03-25", #changed this value
"estimated_end_date"=>"2016-03-30", #changed this value
"employees_needed"=>"2",
"incoming_packaging"=>"Boxes",
"final_product_packaging"=>"Boxes",
"sample_instructions"=>"One 18 oz every pallet.\r\nMilled Corn Flour\r\nLot Number\r\nBag Number\r\nNet Weight",
"project_description"=>"Mill the piss out of this.",
"project_type"=>"Production",
"building_id"=>"5",
"paid_status"=>"false",
"material_total_weight_lbs"=>"40000",
"shifts"=>"1.0",
"shift_hrs"=>"8",
"rate_lb_hr"=>"2000",
"company_id"=>"1"}
[7] pry(#<ProjectsController>)> @project.update_attributes(project_params)
(0.6ms) BEGIN
Company Load (1.3ms) SELECT "companies".* FROM "companies" WHERE "companies"."id" = $1 LIMIT 1 [["id", 1]]
SQL (1.3ms) INSERT INTO "projects" ("name", "scheduled_start_date", "estimated_end_date", "employees_needed", "incoming_packaging", "final_product_packaging", "sample_instructions", "project_description", "project_type", "building_id", "paid_status", "material_total_weight_lbs", "shifts", "shift_hrs", "rate_lb_hr", "company_id", "created_at", "updated_at") VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, $15, $16, $17, $18) RETURNING "id" [["name", "Corn Flour Milling with Setup"], ["scheduled_start_date", "2016-03-25"], ["estimated_end_date", "2016-03-30"], ["employees_needed", 2], ["incoming_packaging", "Boxes"], ["final_product_packaging", "Boxes"], ["sample_instructions", "One 18 oz every pallet.\r\nMilled Corn Flour\r\nLot Number\r\nBag Number\r\nNet Weight"], ["project_description", "Mill the piss out of this."], ["project_type", "Production"], ["building_id", "5"], ["paid_status", "f"], ["material_total_weight_lbs", 40000], ["shifts", 1.0], ["shift_hrs", 8], ["rate_lb_hr", 2000], ["company_id", 1], ["created_at", "2016-01-21 20:07:26.508713"], ["updated_at", "2016-01-21 20:07:26.508713"]]
SQL (1.8ms) INSERT INTO "projects_setups" ("setup_id", "project_id") VALUES ($1, $2) [["setup_id", 22], ["project_id", 217]]
(32.1ms) COMMIT
=> true
[8] pry(#<ProjectsController>)>