Обновление WooCommerce 3.0 мне не понравилось. Я добавил настраиваемое обязательное поле, чтобы оформить заказ на доменное имя, и сейчас не могу понять, как его сохранить. Этот код добавляет поле еще правильно:
add_action( 'woocommerce_after_order_notes', 'add_domain_checkout_field' );
function add_domain_checkout_field( $checkout ) {
echo '<div id="add_domain_checkout_field"><h2>' . __('Domain') . '</h2>';
woocommerce_form_field( 'sitelink_domain', array(
'type' => 'text',
'required' => true,
'class' => array('my-field-class form-row-wide'),
'label' => __('Domain where SiteLink will be installed'),
'placeholder' => __('Enter your URL'),
), $checkout->get_value( 'sitelink_domain' ));
echo '</div>';
}
И я пытаюсь сохранить это так:
add_action( 'woocommerce_checkout_create_order', 'add_domain_to_order_meta', 10, 2 );
function add_domain_to_order_meta( $order, $data ) {
if ( ! empty( $_POST['sitelink_domain'] ) ) {
$order->add_meta_data( 'ssla_sitelink_url', sanitize_text_field( $_POST['sitelink_domain'] ) );
}
}
Однако мета не представляется добавленной или сохраненной где-либо.
Я знаю что $_POST
переменная есть, я вывел ошибку, чтобы увидеть.
Тестирование некоторых захватов и регистрации ошибок сбивает меня с толку:
$sitelink_domain = $subscription->get_meta_data( 'ssla_sitelink_url' );
error_log( print_r( $sitelink_domain, true ) );
// Вывод:
[21-Apr-2017 01:26:27 UTC] Array
(
[0] => stdClass Object
(
[id] => 270086
[key] => _ssla_sitelink_url
[value] => lololol.com
)
[1] => stdClass Object
(
[id] => 270089
[key] => _download_permissions_granted
[value] => 1
)
)
Тем не мение,
$sitelink_domain = $subscription->get_meta( 'ssla_sitelink_url' );
error_log( 'Domain: ' . $sitelink_domain );
Выход просто:
[21-Apr-2017 01:27:39 UTC] Domain:
Во-первых, вам нужно проверить поле, когда форма оформления заказа опубликована и поле является обязательным и не является обязательным, используя woocommerce_checkout_process
Хук действия:
add_action('woocommerce_checkout_process', 'domain_checkout_field_process');
function domain_checkout_field_process() {
// Check if it's set and if it's not set, we add an error.
if ( ! $_POST['sitelink_domain'] )
wc_add_notice( __( 'Please enter the domain where the SiteLink will be installed.' ), 'error' );
}
Поскольку это настраиваемое поле оформления заказа, вы можете использовать woocommerce_checkout_update_order_meta
Действие ловушка, чтобы сохранить новое поле для заказа пользовательских полей:
add_action( 'woocommerce_checkout_update_order_meta', 'domain_checkout_field_update_order_meta' );
function domain_checkout_field_update_order_meta( $order_id ) {
if ( ! empty( $_POST['sitelink_domain'] ) ) {
update_post_meta( $order_id, 'ssla_sitelink_url', sanitize_text_field( $_POST['sitelink_domain'] ) );
}
}
использование woocommerce_admin_order_data_after_billing_address
Хук действия для отображения значения настраиваемого поля на странице редактирования заказа администратора:
add_action( 'woocommerce_admin_order_data_after_billing_address', 'domain_checkout_field_display_admin_order_meta', 10, 1 );
function domain_checkout_field_display_admin_order_meta($order){
// Get the custom field value
$domain_siteLink = get_post_meta( $order->get_id(), 'ssla_sitelink_url', true );
// Display the custom field:
echo '<p><strong>' . __('Domain SiteLink', 'woocommerce') . ': </strong>' . $domain_siteLink . '</p>';
}
Отобразите метку и значение настраиваемого поля в заказах внешнего интерфейса и уведомлениях по электронной почте:
add_action( 'woocommerce_order_item_meta_end', 'custom_custom', 10, 3 );
function custom_custom( $item_id, $item, $order ){
// Get the custom field value
$domain_siteLink = get_post_meta( $order->get_id(), 'ssla_sitelink_url', true );
// Display the custom field:
echo '<p><strong>' . __('Domain SiteLink', 'woocommerce') . ': </strong>' . $domain_siteLink . '</p>';
}
Этот код находится в файле function.php вашей активной дочерней темы (или темы), а также в любом файле плагина.
Этот код работает для WooCommerce 3.0+
Вы можете добавить дополнительные метаданные заказа, как показано ниже.
add_action('woocommerce_add_order_item_meta','add_values_to_order_item_meta',1,2);
if(!function_exists('add_values_to_order_item_meta'))
{
function add_values_to_order_item_meta($item_id, $values)
{
global $woocommerce,$wpdb;
$user_custom_values = $values['user_custom_data_value'];
if(!empty($user_custom_values))
{
wc_add_order_item_meta($item_id,'user_custom_data',$user_custom_values);
}
}
}