2022-11-27 15:03:07 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Country Functions
|
|
|
|
*
|
|
|
|
* @package EDD
|
|
|
|
* @subpackage Functions
|
|
|
|
* @copyright Copyright (c) 2018, Easy Digital Downloads, LLC
|
|
|
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
|
|
|
|
* @since 1.6
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Exit if accessed directly
|
|
|
|
defined( 'ABSPATH' ) || exit;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Shop Base Country
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return string $country The two letter country code for the shop's base country
|
|
|
|
*/
|
|
|
|
function edd_get_shop_country() {
|
|
|
|
$country = edd_get_option( 'base_country', 'US' );
|
|
|
|
|
|
|
|
return apply_filters( 'edd_shop_country', $country );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Shop Base State
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return string $state The shop's base state name
|
|
|
|
*/
|
|
|
|
function edd_get_shop_state() {
|
|
|
|
$state = edd_get_option( 'base_state', false );
|
|
|
|
|
|
|
|
return apply_filters( 'edd_shop_state', $state );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Shop States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
*
|
|
|
|
* @param string $country
|
|
|
|
* @return array A list of states for the selected country
|
|
|
|
*/
|
|
|
|
function edd_get_shop_states( $country = null ) {
|
2023-07-19 21:08:59 +00:00
|
|
|
if ( empty( $country ) ) {
|
2022-11-27 15:03:07 +00:00
|
|
|
$country = edd_get_shop_country();
|
2023-07-19 21:08:59 +00:00
|
|
|
}
|
2022-11-27 15:03:07 +00:00
|
|
|
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
$states = $countries->get_states( $country );
|
2022-11-27 15:03:07 +00:00
|
|
|
|
|
|
|
return apply_filters( 'edd_shop_states', $states, $country );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Country List
|
|
|
|
*
|
|
|
|
* @since 1.0
|
|
|
|
* @return array $countries A list of the available countries
|
|
|
|
*/
|
|
|
|
function edd_get_country_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
return apply_filters( 'edd_countries', include EDD_PLUGIN_DIR . 'i18n/countries.php' );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get States List
|
|
|
|
*
|
|
|
|
* @since 1.2
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function edd_get_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_us_states', $countries->get_states( 'US' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Angola States
|
|
|
|
*
|
|
|
|
* @since 2.8.5
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_angola_provinces_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_angola_provinces', $countries->get_states( 'AO' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Provinces List
|
|
|
|
*
|
|
|
|
* @since 1.2
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function edd_get_provinces_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_canada_provinces', $countries->get_states( 'CA' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Australian States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_australian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_australian_states', $countries->get_states( 'AU' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Bangladeshi States (districts)
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_bangladeshi_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_bangladeshi_states', $countries->get_states( 'BD' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Brazil States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_brazil_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_brazil_states', $countries->get_states( 'BR' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Bulgarian States
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_bulgarian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_bulgarian_states', $countries->get_states( 'BG' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Hong Kong States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_hong_kong_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_hong_kong_states', $countries->get_states( 'HK' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Hungary States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_hungary_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_hungary_states', $countries->get_states( 'HU' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Japanese States
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_japanese_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_japanese_states', $countries->get_states( 'JP' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Chinese States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_chinese_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_chinese_states', $countries->get_states( 'CN' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get United Kingdom States
|
|
|
|
*
|
|
|
|
* @since 2.9
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_united_kingdom_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_united_kingdom_states', $countries->get_states( 'GB' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get New Zealand States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_new_zealand_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_new_zealand_states', $countries->get_states( 'NZ' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Peruvian States
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_peruvian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_peruvian_states', $countries->get_states( 'PE' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Indonesian States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_indonesian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_indonesia_states', $countries->get_states( 'ID' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Indian States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_indian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_indian_states', $countries->get_states( 'IN' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Iranian States
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_iranian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_iranian_states', $countries->get_states( 'IR' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Italian Provinces
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_italian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_italian_states', $countries->get_states( 'IT' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Malaysian States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_malaysian_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_malaysian_states', $countries->get_states( 'MY' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Mexican States
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_mexican_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_mexican_states', $countries->get_states( 'MX' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Nepalese States (Districts)
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_nepalese_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_nepalese_states', $countries->get_states( 'NP' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get South African States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_south_african_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_south_african_states', $countries->get_states( 'ZA' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Thailand States
|
|
|
|
*
|
|
|
|
* @since 1.6
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_thailand_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_thailand_states', $countries->get_states( 'TH' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Turkey States
|
|
|
|
*
|
|
|
|
* @since 2.2.3
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_turkey_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_turkey_states', $countries->get_states( 'TR' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Spain States
|
|
|
|
*
|
|
|
|
* @since 2.2
|
|
|
|
* @return array $states A list of states
|
|
|
|
*/
|
|
|
|
function edd_get_spain_states_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
|
|
|
|
return apply_filters( 'edd_spain_states', $countries->get_states( 'ES' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of Netherland's provinces.
|
|
|
|
*
|
|
|
|
* @since 3.0
|
|
|
|
* @return array $states A list of Netherland's provinces.
|
|
|
|
*/
|
|
|
|
function edd_get_netherlands_provinces_list() {
|
2023-07-19 21:08:59 +00:00
|
|
|
$countries = new EDD\Utils\Countries();
|
2022-11-27 15:03:07 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filters the list of Netherland's provinces.
|
|
|
|
*
|
|
|
|
* @since 3.0
|
|
|
|
*
|
|
|
|
* @param array $states A list of Netherland's provinces.
|
|
|
|
*/
|
2023-07-19 21:08:59 +00:00
|
|
|
return apply_filters( 'edd_netherlands_provinces', $countries->get_states( 'NL' ) );
|
2022-11-27 15:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Given a country code, return the country name
|
|
|
|
*
|
|
|
|
* @since 2.8.7
|
|
|
|
* @param string $country_code The ISO Code for the country
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function edd_get_country_name( $country_code = '' ) {
|
|
|
|
$country_list = edd_get_country_list();
|
|
|
|
$country_name = isset( $country_list[ $country_code ] ) ? $country_list[ $country_code ] : $country_code;
|
|
|
|
|
|
|
|
return apply_filters( 'edd_get_country_name', $country_name, $country_code );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Given a country and state code, return the state name
|
|
|
|
*
|
|
|
|
* @since 2.9
|
|
|
|
* @param string $country_code The ISO Code for the country
|
|
|
|
* @param string $state_code The ISO Code for the state
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function edd_get_state_name( $country_code = '', $state_code = '' ) {
|
2023-07-19 21:08:59 +00:00
|
|
|
if ( empty( $country_code ) ) {
|
|
|
|
$country_code = edd_get_shop_country();
|
|
|
|
}
|
|
|
|
$countries = new EDD\Utils\Countries();
|
|
|
|
$state_name = $countries->get_state_name( $country_code, $state_code );
|
2022-11-27 15:03:07 +00:00
|
|
|
|
|
|
|
return apply_filters( 'edd_get_state_name', $state_name, $state_code );
|
|
|
|
}
|