# Effective Addresses Extend any ActiveRecord object to have one or more named addresses. Includes a geographic region-aware custom form input backed by Carmen. Creates methods such as `user.billing_address` and `user.billing_address=` for dealing with a has_many :addresses relationship as a single method. Adds region-aware validations for provinces/states and postal codes. Includes a Formtastic and SimpleForm one-liner method to drop in address fields to any form. Uses the Carmen gem internally so when a Country is selected, an AJAX request populates the province/state fields as appropriate. Rails 3.2.x and Rails 4 Support ## Getting Started Add to your Gemfile: ```ruby gem 'effective_addresses' ``` Run the bundle command to install it: ```console bundle install ``` Then run the generator: ```ruby rails generate effective_addresses:install ``` The generator will install an initializer which describes all configuration options and creates a database migration. If you want to tweak the table name (to use something other than the default `addresses`), manually adjust both the configuration file and the migration now. Then migrate the database: ```ruby rake db:migrate ``` And require the javascript in your application.js: ```ruby //= require effective_addresses ``` ## Usage ### Model Add the mixin to your existing model and specify the name or names of the addresses it should respond to: ```ruby class User acts_as_addressable :billing end ``` This adds the following getters and setters: ```ruby @user.billing_address @user.billing_address= @user.billing_addresses ``` Calling `user.billing_address` will return a single `Effective::Address` object. Calling `user.billing_addresses` will return an array of `Effective:Address` objects. You can also specify a `:presence` validation as follows: ```ruby class User acts_as_addressable :billing => true, :shipping => false end ``` or ```ruby class User acts_as_addressable :billing => {:presence => true, :use_full_name => false} end ``` or ```ruby class User acts_as_addressable :billing validates_presence_of :billing_address end ``` This means when a User is created, it will not be valid unless a billing_address exist and is valid. ### Full Name Sometimes you want to collect a `full_name` field with your addresses, such as in the case of a mailing address; other times, it's an unnecessary field. When you specify the config option `config.use_full_name = true` all `acts_as_addressable` defined addresses will use `use_full_name => true` by default. This can be overridden on a per-address basis when declared in the model. When `use_full_name == true`, any calls to `effective_address_fields` form helper will display the full_name input, and the model will `validate_presence_of :full_name`. ### Address Validations Address1, City, Country and Postal/Zip Code are all required fields. If the selected Country has provinces/states (not all countries do), then the province/state field will be required. If the country is Canada or United States, then the postal/zip code formatting will be enforced. This validation on the postal code/zip format can be disabled via the config/initializers `validate_postal_code_format` setting Canadian postal codes will be automatically upcased and formatted to a consistent format: `T5Z 3A4` (capitalized with a single space). ### Multiple Addresses Everytime an address is changed, an additional address record is created. The latest address will always be returned by: ```ruby @user.billing_address ``` You can find all past addresses (including the current one) by: ```ruby @user.billing_addresses ``` ### Strong Parameters Make your controller aware of the `acts_as_addressable` passed parameters: ```ruby def permitted_params params.require(:base_object).permit( :billing_address => EffectiveAddresses.permitted_params, :shipping_address => EffectiveAddresses.permitted_params ) end ``` The actual permitted parameters are: ```ruby [:full_name, :address1, :address2, :city, :country_code, :state_code, :postal_code] ``` ### Form Helpers Use the helper in a Formtastic or SimpleForm form to quickly create the address fields. This example is in HAML: ```ruby = semantic_form_for @user do |f| %h3 Billing Address = effective_address_fields(f, :billing_address) = f.action :submit = simple_form_for @user do |f| %h3 Billing Address = effective_address_fields(f, :billing_address) = f.submit 'Save' ``` Currently only supports Formtastic and SimpleForm. When you select a country from the select input an AJAX GET request will be made to `effective_addresses.address_subregions_path` (`/addresses/subregions/:country_code`) which populates the province/state dropdown with the selected country's states or provinces. ## License MIT License. Copyright [Code and Effect Inc.](http://www.codeandeffect.com/) Code and Effect is the product arm of [AgileStyle](http://www.agilestyle.com/), an Edmonton-based shop that specializes in building custom web applications with Ruby on Rails. ## Testing The test suite for this gem is unfortunately not yet complete. Run tests by: ```ruby rake spec ``` ## Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Bonus points for test coverage 6. Create new Pull Request