Добавить пользовательские данные для выставления счетов на адрес, отформатированный для выставления счетов, в распоряжениях администратора Woocommerce. - PullRequest
2 голосов
/ 27 марта 2019

В Woocommerce я хотел бы видеть пользовательские метаданные на страницах редактирования заказа администратора, используя woocommerce_localisation_address_formats hook.

На основе " Заказ редактирования Woocommerce на панели администратора " код ответа, который я слегка изменил следующим образом:

add_filter( 'woocommerce_localisation_address_formats', 'admin_localisation_address_formats', 50, 1 );
function admin_localisation_address_formats( $address_formats ){
    if( is_admin() ){
        $address_formats = array();

        $countries = array('default', 'AU', 'AT', 'BE', 'CA', 'CH', 'CL', 'CN', 'CZ',
        'DE', 'EE', 'FI', 'DK', 'FR', 'HK', 'HU', 'IN', 'IS', 'IT', 'JP', 'TW', 'LI',
        'NL', 'NZ', 'NO', 'PL', 'PT', 'SK', 'SI', 'ES', 'SE', 'TR', 'US', 'VN' );

        foreach( $countries as $country_code ) {
            $address_formats[$country_code] = "{company}\n{name}\n{address_1} {address_2} {postcode}\n{city} {state}\n{country}\n{billing_nombrecontacto}";
        }
    }
    return $address_formats;
}

Где {billing_nombrecontacto} должны быть пользовательские данные для вставки в страницы заказа администратора ... Но это ничего не делает.

Чтобы добавить billing_nombrecontacto Я использовал следующий код:

add_filter('woocommerce_billing_fields', 'custom_woocommerce_billing_fields');
function custom_woocommerce_billing_fields($fields,$fields2)
{
    $fields['billing_nombrecontacto'] = array(
        'label' => __('Nombre de contacto', 'woocommerce'), // Add custom field label
        'placeholder' => _x('Nombre de contacto', 'placeholder', 'woocommerce'), // Add custom field placeholder
        'required' => false, // if field is required or not
        'clear' => false, // add clear or not
        'type' => 'text', // add field type
        'class' => array('my-css')    // add class name

    );

    $fields['billing_cuit'] = array(
        'label' => __('CUIT', 'woocommerce'), // Add custom field label
        'placeholder' => _x('CUIT', 'placeholder', 'woocommerce'), // Add custom field placeholder
        'required' => false, // if field is required or not
        'clear' => false, // add clear or not
        'type' => 'text', // add field type
        'class' => array('my-css')    // add class name

    );

    $fields['billing_emaildelvendedor'] = array(
        'label' => __('Email del Contacto', 'woocommerce'), // Add custom field label
        'placeholder' => _x('email del Vendedor', 'placeholder', 'woocommerce'), // Add custom field placeholder
        'required' => false, // if field is required or not
        'clear' => false, // add clear or not
        'type' => 'text', // add field type
        'class' => array('my-css')    // add class name

    );

    $fields['billing_nombrecontacto']['priority'] = 102;

    return  $fields;
}

Данные собраны правильно, я вижу их в своем аккаунте для этого настраиваемого поля.

Как сделатьэто работает?Я застрял.

1 Ответ

2 голосов
/ 27 марта 2019

Обновление: Добавлена ​​дополнительная отсутствующая функция, отображающая значение поля billing_nombrecontacto ...

Я пересмотрел ваш существующий код и добавил еще немного кода, чтобы сделать егоработа:

// Add / Display additional billing fields in checkout and My account > Edit adresses > Billing form
add_filter( 'woocommerce_billing_fields', 'additional_billing_fields', 10, 1 );
function additional_billing_fields( $fields )
{
    $fields['billing_nombrecontacto'] = array(
        'type'        => 'text', // add field type
        'label'       => __('Nombre de contacto', 'woocommerce'), // Add custom field label
        'placeholder' => _x('Nombre de contacto', 'placeholder', 'woocommerce'), // Add custom field placeholder
        'class'       => array('my-css'), // add class name
        'required'    => false, // if field is required or not
        'clear'       => false, // add clear or not
        'priority'    => 102,    // define the priority
    );

    $fields['billing_cuit'] = array(
        'type'        => 'text', // add field type
        'label'       => __('CUIT', 'woocommerce'), // Add custom field label
        'placeholder' => _x('CUIT', 'placeholder', 'woocommerce'), // Add custom field placeholder
        'class'       => array('my-css'), // add class name
        'required'    => false, // if field is required or not
        'clear'       => false, // add clear or not

    );

    $fields['billing_emaildelvendedor'] = array(
        'type'        => 'text', // add field type
        'label'       => __('Email del Contacto', 'woocommerce'), // Add custom field label
        'placeholder' => _x('email del Vendedor', 'placeholder', 'woocommerce'), // Add custom field placeholder
        'class'       => array('my-css'),  // add class name
        'required'    => false, // if field is required or not
        'clear'       => false, // add clear or not

    );

    return  $fields;
}

// Adding custom placeholder to woocommerce formatted billing address only on Backend
add_filter( 'woocommerce_localisation_address_formats', 'admin_localisation_address_formats', 50, 1 );
function admin_localisation_address_formats( $address_formats ){
    // Only in backend (Admin)
    if( is_admin() ) {
        foreach( $address_formats as $country_code => $address_format ) {
            $address_formats[$country_code] .= "\n{nombrecontacto}";
        }
    }
    return $address_formats;
}

// Custom placeholder replacement to woocommerce formatted billing address
add_filter( 'woocommerce_formatted_address_replacements', 'custom_formatted_address_replacements', 10, 2 );
function custom_formatted_address_replacements( $replacements, $args  ) {
    $replacements['{nombrecontacto}'] = ! empty($args['nombrecontacto'])  ? $args['nombrecontacto'] : '';

    return $replacements;
}

// Get the field values to be displayed in admin Order edit pages
add_filter('woocommerce_order_formatted_billing_address', 'add_woocommerce_order_fields', 10, 2);
function add_woocommerce_order_fields($address, $order ) {
    $address['nombrecontacto'] = $order->get_meta('_billing_nombrecontacto');

    return $address;
}

Код помещается в файл function.php вашей активной дочерней темы (или активной темы).Проверено и работает.

enter image description here


Бонус - Сделать поле редактируемым:

// Make the custom billing field Editable in Admin order pages
add_filter('woocommerce_admin_billing_fields', 'add_woocommerce_admin_billing_fields');
function add_woocommerce_admin_billing_fields($billing_fields) {
    $billing_fields['nombrecontacto'] = array( 'label' => __('Nombre contacto', 'woocommerce') );

    return $billing_fields;
}

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...