概要
woocommerce_get_zone_criteria
フィルターは、WooCommerceの配送ゾーンを設定する際に、ゾーンの条件をカスタマイズするために使用されます。このフィルターを利用すると、特定の地点や条件に基づいて、配送方法や料金を変えることができます。よく使われる機能には以下のようなものがあります:
- 住所に基づく配送ゾーンの動的生成
- カスタム条件を用いた送料の調整
- 特定のユーザーグループ向けの特別な配送オプション
- 地域別の税率設定
- 特定の商品のみ配送できるゾーンの指定
- 複数の条件に基づく配送方法の絞り込み
構文
add_filter('woocommerce_get_zone_criteria', 'customize_zone_criteria', 10, 2);
パラメータ
$criteria
(array): ゾーンの条件を表す配列。$zone
(object): 対象のゾーンオブジェクト。
戻り値
カスタマイズされた条件を持つ配列。
使用可能なプラグインのバージョン
- WooCommerce: 3.0以上
- WordPress: 4.0以上
この関数のアクションでの使用可能性
アクション | 使用例 |
---|---|
mu_plugin_loaded | |
registered_post_type | |
plugins_loaded | |
wp_roles_init | |
setup_theme | |
after_setup_theme | |
set_current_user | |
init | |
register_sidebar | |
wp_loaded | |
send_headers | |
parse_query | |
pre_get_posts | |
wp | |
template_redirect | |
get_header | |
wp_head |
サンプルコード
サンプルコード1: 地域に基づく配送ゾーンの条件を追加する
add_filter('woocommerce_get_zone_criteria', 'add_custom_shipping_criteria', 10, 2);
function add_custom_shipping_criteria($criteria, $zone) {
$criteria['custom_area'] = array(
'type' => 'custom',
'value' => 'my_custom_area'
);
return $criteria;
}
このコードは、配送ゾーンの条件にカスタムエリアを追加します。このエリアは特別な条件に基づいて配送方法を変更するために使われます。
サンプルコード2: 特定のIPアドレス範囲を条件に追加
add_filter('woocommerce_get_zone_criteria', 'add_ip_range_criteria', 10, 2);
function add_ip_range_criteria($criteria, $zone) {
$criteria['ip_range'] = array(
'type' => 'ip',
'value' => '192.168.1.0/24'
);
return $criteria;
}
このコードは、特定のIPアドレス範囲を基に配送条件を追加します。これにより、特定のネットワークからの注文に対して異なる配送オプションを設定できます。
サンプルコード3: ユーザーのロールに基づいた条件
add_filter('woocommerce_get_zone_criteria', 'add_user_role_criteria', 10, 2);
function add_user_role_criteria($criteria, $zone) {
$criteria['user_role'] = array(
'type' => 'role',
'value' => 'premium_subscriber'
);
return $criteria;
}
このサンプルは、特定のユーザーロール(ここでは「premium_subscriber」)に基づく配送条件を追加し、特典を受けられるユーザー向けの設定が可能です。
サンプルコード4: 時間帯に基づいた条件を追加
add_filter('woocommerce_get_zone_criteria', 'add_time_slot_criteria', 10, 2);
function add_time_slot_criteria($criteria, $zone) {
$current_hour = date('H');
if ($current_hour >= 9 && $current_hour <= 17) {
$criteria['time_slot'] = array('type' => 'time', 'value' => 'business_hours');
}
return $criteria;
}
このコードは、営業時間(9時から17時)に基づき、条件を追加してビジネス時間内の配送を行う設定を可能にします。
サンプルコード5: 配送先の国に基づく条件を追加
add_filter('woocommerce_get_zone_criteria', 'add_country_criteria', 10, 2);
function add_country_criteria($criteria, $zone) {
$criteria['country'] = array(
'type' => 'country',
'value' => array('JP', 'US') // 日本とアメリカ
);
return $criteria;
}
このサンプルのコードは、日本とアメリカに対する特定の配送条件を追加します。これにより、特定の国に応じた配送方法や料金を設定できます。