2011-09-20 3 views
0

Я пытаюсь создать систему управления учетными записями, которая позволяет учетной записи иметь один платежный адрес. Я хочу, чтобы учетная запись и адрес имели собственный контроллер и модель. Пользователь-администратор создаст новую учетную запись, а затем перенаправляется для создания нового платежного адреса для этой учетной записи. Первая часть работает, я могу создать учетную запись, но второй сохраняет только атрибут account_id в таблице адресов. Ниже мой код:Невозможно реализовать has_one отношения

accounts_controller

class AccountsController < ApplicationController 
def new 
    @account = Account.new 
end 
def create 
    @account = Account.new(params[:account]) 
    @account.build_address 
    if @account.save 
    flash[:success] = "Customer Account has been successfully created!" 
    redirect_to '/newaddress' 
    else 
    render 'new' 
    end 
end 
end 

addresses_controller

class AddressesController < ApplicationController 
    def new 
    @address = Address.new 
    end 
    def create 
    @account = Account.find(params[:account]) 
    @address = @account.create_address(params[:address]) 
    redirect_to root_path 
    end 
end 

account_model

class Account < ActiveRecord::Base 
    has_one :address 
    accepts_nested_attributes_for :address 
    attr_accessible :contactFirstName, :contactLastName, :contactEmail, :contactPhone, :business_name 
end 

address_model

class Address < ActiveRecord::Base 
    attr_accessible :city, :state, :street, :zipCode 
    belongs_to :account 
end 

Я также добавил следующее к моему routes.rb файл

resources :accounts do 
    resources :addresses 
end 

Последняя, ​​ниже схема для relavant таблиц

create_table "accounts", :force => true do |t| 
    t.string "contactEmail" 
    t.string "contactFirstName" 
    t.string "contactLastName" 
    t.string "contactPhone" 
    t.datetime "joinDate" 
    t.string "business_name" 
    t.datetime "created_at" 
    t.datetime "updated_at" 
end 
create_table "addresses", :force => true do |t| 
    t.string "city" 
    t.string "state" 
    t.string "street" 
    t.string "zipCode" 
    t.integer "account_id" 
    t.datetime "created_at" 
    t.datetime "updated_at" 
end 

(Я еще новичок в программировании и рельсы, так что я отправил насколько я думал, будет актуальным.)

Добавлен журнал с того момента, когда я открою новую страницу учетной записи и перейду к новой странице адреса.

Started GET "/newaccount" for 127.0.0.1 at Tue Sep 20 17:21:56 -0500 2011 
    Processing by AccountsController#new as HTML 
Rendered shared/_error_messages.html.erb (0.6ms) 
Rendered accounts/_account_fields.html.erb (13.0ms) 
Rendered layouts/_stylesheets.html.erb (1.2ms) 
    User Load (2.5ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IS NULL LIMIT 1 
    CACHE (0.0ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IS NULL LIMIT 1 
Rendered layouts/_header.html.erb (19.4ms) 
Rendered layouts/_footer.html.erb (1.0ms) 
Rendered accounts/new.html.erb within layouts/application (50.3ms) 
Completed 200 OK in 168ms (Views: 64.6ms | ActiveRecord: 2.5ms) 

Started POST "/accounts" for 127.0.0.1 at Tue Sep 20 17:22:11 -0500 2011 
    Processing by AccountsController#create as HTML 
    Parameters: {"commit"=>"Next", "account"=>{"business_name"=>"FooBar", "contactLastName"=>"Bar", "contactPhone"=>"1231231234", "contactEmail"=>"[email protected]", "contactFirstName"=>"Foo"}, "authenticity_token"=>"lJG89TIjcJighmFUWLg1uR9sJq0CHLvceeLH9QNocGY=", "utf8"=>"✓"} 
    SQL (0.1ms) BEGIN 
    SQL (0.3ms) SELECT 1 FROM `accounts` WHERE (LOWER(`accounts`.`contactEmail`) = LOWER('[email protected]')) LIMIT 1 
    SQL (1.2ms) describe `accounts` 
    AREL (0.4ms) INSERT INTO `accounts` (`created_at`, `contactFirstName`, `business_name`, `contactPhone`, `updated_at`, `contactEmail`, `contactLastName`, `joinDate`) VALUES ('2011-09-20 22:22:11', 'Foo', 'FooBar', '1231231234', '2011-09-20 22:22:11', '[email protected]', 'Bar', NULL) 
    SQL (1.5ms) describe `addresses` 
    AREL (0.2ms) INSERT INTO `addresses` (`zipCode`, `state`, `city`, `updated_at`, `account_id`, `street`, `created_at`) VALUES (NULL, NULL, NULL, '2011-09-20 22:22:11', 31, NULL, '2011-09-20 22:22:11') 
    SQL (26.3ms) COMMIT 
Redirected to http://localhost:3500/newaddress 
Completed 302 Found in 85ms 

Started GET "/newaddress" for 127.0.0.1 at Tue Sep 20 17:22:11 -0500 2011 
    Processing by AddressesController#new as HTML 
Rendered addresses/_address_fields.html.erb (83.4ms) 
Rendered layouts/_stylesheets.html.erb (1.4ms) 
    User Load (0.2ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IS NULL LIMIT 1 
    CACHE (0.0ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IS NULL LIMIT 1 
Rendered layouts/_header.html.erb (17.1ms) 
Rendered layouts/_footer.html.erb (0.9ms) 
Rendered addresses/new.html.erb within layouts/application (113.6ms) 
Completed 200 OK in 126ms (Views: 119.6ms | ActiveRecord: 30.3ms) 

Started POST "/newaddress" for 127.0.0.1 at Tue Sep 20 17:22:29 -0500 2011 
    Processing by AddressesController#new as HTML 
    Parameters: {"address"=>{"city"=>"Boston", "street"=>"123 Main St", "zipCode"=>"02222", "state"=>"MA"}, "commit"=>"Create", "authenticity_token"=>"lJG89TIjcJighmFUWLg1uR9sJq0CHLvceeLH9QNocGY=", "utf8"=>"✓"} 
Rendered addresses/_address_fields.html.erb (10.3ms) 
Rendered layouts/_stylesheets.html.erb (1.2ms) 
    User Load (0.2ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IS NULL LIMIT 1 
    CACHE (0.0ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IS NULL LIMIT 1 
Rendered layouts/_header.html.erb (17.2ms) 
Rendered layouts/_footer.html.erb (0.9ms) 
Rendered addresses/new.html.erb within layouts/application (40.1ms) 
Completed 200 OK in 54ms (Views: 47.3ms | ActiveRecord: 0.2ms) 
+0

я могу заставить его работать, если формы находятся на той же странице, с помощью fields_for: адрес. Это заставляет меня думать, что когда у меня есть каждая форма на собственной странице, я не передаю ей правильный account_id, чтобы он знал, где писать в таблице адресов. –

+0

Я бы использовал fields_for then и визуально выделил их с помощью Ajax (например, если вам нужно, чтобы он выглядел как шаг 1, шаг 2 и т. Д.) – jschorr

ответ

0

Как быстрый взгляд, вы передаете только Params [: счета], журнал хвост и посмотреть, что вам нужно, чтобы вы добавили журнал

class AddressesController < ApplicationController 
def new 
    @address = Address.new 
    end 
def create 
    @account = Account.find(params[:account]) 
    @address = @account.create_address(params[:address]) 
    redirect_to root_path 
end 
end 

Ass, вы можете увидеть теперь, когда вы размещаете newaddress

Parameters: {"address"=>{"city"=>"Boston", "street"=>"123 Main St", "zipCode"=>"02222", "state"=>"MA"}, "commit"=>"Create", "authenticity_token"=>"lJG89TIjcJighmFUWLg1uR9sJq0CHLvceeLH9QNocGY=", "utf8"=>"✓"} 

и контроллер имеют

def create 
@account = Account.find(params[:account]) 
@address = @account.create_address(params[:address]) 
redirect_to root_path 

конец

Как вы можете видеть, нет @account = Account.find (PARAMS [: счета])

Так вы объясняете имеет нулевое значение, вы можете добавить скрытое поле с ACCOUNT_ID, чтобы сформировать или уловом другой способ зависит от вашего приложения.

+0

Я взглянул на журнал, но я до сих пор не вижу, что я «Я делаю неправильно. Я вижу, что POST/accounts» создает account_id для поля адресов, но POST '/ newaddress' ничего не создает.Я не уверен, что еще мне нужно передать. –

+0

вставьте журнал при попытке создать адрес. – twooface

+0

Я добавил журнал. Спасибо за вашу помощь. Кроме того, таблица users - это таблица для пользователя admin, который создает учетные записи и связанные с ними адреса фактурирования. –

0

Линия в в классе Address выглядит неправильно для меня (вынимают _attributes):

class Address < ActiveRecord::Base 
    attr_accessible :city, :state, :street, :zipCode 
    belongs_to :account 
end 
+0

Я это заметил. Я попытался добавить «_трибуты» на основе предложения некоторых, но теперь удалил его. Даже без работы он не работает. –

+0

Прокомментируйте attr_accessible в Account.rb и дайте мне знать, что вы получаете – jschorr

+0

Я прокомментировал это, но он все еще не работает. Метод post для/newaddress просто не делает ничего. –