NAME
Interchange6::Schema::Result::Zone
TABLE: zones
DESCRIPTION
In the context of zones the term 'state' refers to state, province or other principal subdivision of a country as defined in ISO 3116-2. Countries to be added to a zone must already exist in Interchange6::Schema::Result::Country and states in Interchange6::Schema::Result::State.
Zones can contain any of the following:
No countries and no states
An empty zone must be created before countries/states are added but otherwise is probably not useful.
Multiple countries
For example to create a trading group like the European Union.
A single country
Probably what to use in combination with postal ranges.
A single country with a single state
For example Qubec in Canada which has GST + QST
A single country with multiple states
For example a group containing all Canadian provinces that charge only GST.
The following combinations are NOT allowed:
Multiple countries with one or more states
One or more states with no country
Countries and states should be added to and removed from the zone using these methods which are described further below:
add_countries
remove_countries
add_states
remove_states
NOTE: avoid using other methods from DBIx::Class::Relationship::Base since you may inadvertently end up with an invalid zone.
ACCESSORS
NOTE: postal_range_state and postal_range_end are only really useful when the zone contains a single country.
zones_id
data_type: 'integer'
is_auto_increment: 1
is_nullable: 0
sequence: 'zones_id_seq'
zone
For example for storing the UPS/USPS zone code or perhaps a simple name for the zone.
data_type: 'varchar'
default_value: (empty string)
is_nullable: 1
size: 255
postal_range_start
data_type: 'varchar'
default_value: (empty string)
is_nullable: 0
size: 255
postal_range_end
data_type: 'varchar'
default_value: (empty string)
is_nullable: 0
size: 255
created
data_type: 'datetime'
set_on_create: 1
is_nullable: 0
last_modified
data_type: 'datetime'
set_on_create: 1
set_on_update: 1
is_nullable: 0
PRIMARY KEY
UNIQUE CONSTRAINTS
zones_zone
On ( zone )
RELATIONS
ZoneCountry
Type: has_many
Related object: Interchange6::Schema::Result::ZoneCountry
countries
Type: many_to_many
Accessor to related Country results ordered by name.
ZoneState
Type: has_many
Related object: Interchange6::Schema::Result::ZoneState
states
Type: many_to_many
Accessor to related State results ordered by name.
METHODS
new
Should not be called directly. Used to set default values for certain rows.
add_countries
Argument is either a Interchange6::Schema::Result::Country object or an arrayref of the same.
Throws an exception on failure.
has_country
Argument can be Interchange6::Schema::Result::Country, country name or iso code. Returns 1 if zone includes that country else 0;
country_count
Takes no args. Returns the number of countries in the zone.
remove_countries
Argument is either a Interchange6::Schema::Result::Country object or an arrayref of the same.
Throws an exception on failure.
add_states
Argument is either a Interchange6::Schema::Result::State object or an arrayref of the same.
Throws an exception on failure.
has_state
Argument can be Interchange6::Schema::Result::State, state name or iso code. Returns 1 if zone includes that state else 0;
state_count
Takes no args. Returns the number of states in the zone.
remove_states
Argument is either a Interchange6::Schema::Result::State object or an arrayref of the same.
Returns the Zone object or undef on failure. Errors are available via errors method inherited from Interchange6::Schema::Role::Errors.