Здесь нужны некоторые предложения.
Я пытаюсь изменить свой калькулятор доставки (а не калькулятор калькуляции на основе https://docs.woocommerce.com/document/tutorial-customizing-checkout-fields-using-actions-and-filters/ )
Я просматриваю код, и я не могу воспроизвести то, что я пытаюсь выполнить, как показано здесь:
Я просто хочу скрыть параметры State & Country и сделать так, чтобы вы могли вводить только почтовый индекс. Я пробовал очевидное, скрывая его в таблице стилей CSS / переопределении, просто делая ширину / длину «0».
#add_payment_method .cart-collaterals .cart_totals table select, .woocommerce-cart .cart-collaterals .cart_totals table select, .woocommerce-checkout .cart-collaterals .cart_totals table select { width: 0 height: 0;}
Но для правильного расчета по-прежнему требуется состояние страны. Я даже настроил на заднем конце woocommerce просто вычислить «1 почтовый индекс (например: 48081)», например, и введя только этот почтовый индекс, даже если он имеет выделенную ему скорость, и, к сожалению, это не разрешите это.
Теперь я нахожусь в SFTP своего сервера VIA FileZilla, создавая резервную копию файла shipping-calculator.php и редактируя его соответствующим образом, и мне было интересно, есть ли что-то конкретное в этом коде, которое поможет мне в этом:
<?php /** * Shipping Calculator * * This template can be overridden by copying it to yourtheme/woocommerce/cart/shipping-calculator.php. * * HOWEVER, on occasion WooCommerce will need to update template files and you * (the theme developer) will need to copy the new files to your theme to * maintain compatibility. We try to do this as little as possible, but it does * happen. When this occurs the version of the template file will be bumped and * the readme will list any important changes. * * @see https://docs.woocommerce.com/document/template-structure/ * @author WooThemes * @package WooCommerce/Templates * @version 2.0.8 */ if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly } if ( 'no' === get_option( 'woocommerce_enable_shipping_calc' ) || ! WC()->cart->needs_shipping() ) { return; } ?> <?php do_action( 'woocommerce_before_shipping_calculator' ); ?> <form class="woocommerce-shipping-calculator" action="<?php echo esc_url( wc_get_cart_url() ); ?>" method="post"> <p><a href="#" class="shipping-calculator-button"><?php _e( 'Calculate Shipping', 'woocommerce' ); ?></a></p> <section class="shipping-calculator-form" style="display:none;"> <p class="form-row form-row-wide" id="calc_shipping_country_field"> <select name="calc_shipping_country" id="calc_shipping_country" class="country_to_state" rel="calc_shipping_state"> <option value=""><?php _e( 'Select a country…', 'woocommerce' ); ?></option> <?php foreach( WC()->countries->get_shipping_countries() as $key => $value ) echo '<option value="' . esc_attr( $key ) . '"' . selected( WC()->customer->get_shipping_country(), esc_attr( $key ), false ) . '>' . esc_html( $value ) . '</option>'; ?> </select> </p> <p class="form-row form-row-wide" id="calc_shipping_state_field"> <?php $current_cc = WC()->customer->get_shipping_country(); $current_r = WC()->customer->get_shipping_state(); $states = WC()->countries->get_states( $current_cc ); // Hidden Input if ( is_array( $states ) && empty( $states ) ) { ?><input type="hidden" name="calc_shipping_state" id="calc_shipping_state" placeholder="<?php esc_attr_e( 'State / county', 'woocommerce' ); ?>" /><?php // Dropdown Input } elseif ( is_array( $states ) ) { ?><span> <select name="calc_shipping_state" id="calc_shipping_state" placeholder="<?php esc_attr_e( 'State / county', 'woocommerce' ); ?>"> <option value=""><?php _e( 'Select a state…', 'woocommerce' ); ?></option> <?php foreach ( $states as $ckey => $cvalue ) echo '<option value="' . esc_attr( $ckey ) . '" ' . selected( $current_r, $ckey, false ) . '>' . __( esc_html( $cvalue ), 'woocommerce' ) .'</option>'; ?> </select> </span><?php // Standard Input } else { ?><input type="text" class="input-text" value="<?php echo esc_attr( $current_r ); ?>" placeholder="<?php esc_attr_e( 'State / county', 'woocommerce' ); ?>" name="calc_shipping_state" id="calc_shipping_state" /><?php } ?> </p> <?php if ( apply_filters( 'woocommerce_shipping_calculator_enable_city', false ) ) : ?> <p class="form-row form-row-wide" id="calc_shipping_city_field"> <input type="text" class="input-text" value="<?php echo esc_attr( WC()->customer->get_shipping_city() ); ?>" placeholder="<?php esc_attr_e( 'City', 'woocommerce' ); ?>" name="calc_shipping_city" id="calc_shipping_city" /> </p> <?php endif; ?> <?php if ( apply_filters( 'woocommerce_shipping_calculator_enable_postcode', true ) ) : ?> <p class="form-row form-row-wide" id="calc_shipping_postcode_field"> <input type="text" class="input-text" value="<?php echo esc_attr( WC()->customer->get_shipping_postcode() ); ?>" placeholder="<?php esc_attr_e( 'Postcode / ZIP', 'woocommerce' ); ?>" name="calc_shipping_postcode" id="calc_shipping_postcode" /> </p> <?php endif; ?> <p><button type="submit" name="calc_shipping" value="1" class="button"><?php _e( 'Update Totals', 'woocommerce' ); ?></button></p> <?php wp_nonce_field( 'woocommerce-cart' ); ?> </section> </form> <?php do_action( 'woocommerce_after_shipping_calculator' ); ?>
EDIT: (через 4 часа после оригинальной записи)
Изменения, которые я сделал до сих пор:
<p class="form-row form-row-wide" id="calc_shipping_country_field"> <select name="calc_shipping_country" id="calc_shipping_country" class="country_to_state" rel="calc_shipping_state"> <option value="US" selected="selected">United States (US)</option> <?php foreach( WC()->countries->get_shipping_countries() as $key => $value ) echo '<option value="' . esc_attr( $key ) . '"' . selected( WC()->customer->get_shipping_country(), esc_attr( $key ), false ) . '>' . esc_html( $value ) . '</option>'; ?> </select> </p>
^ Я обновил поле страны этим кодом, заставив клиентов в США при расчете доставки и смог скрыть этот прямой ввод VIA, переопределяющий структуру CSS страницы. Я знаю, что это может быть далеко от первоначального ответа, который мне нужен, но в настоящее время я работаю над этим. Все, что мне нужно сейчас, это Zip Code, чтобы правильно соответствовать состоянию. Если еще раз, кто-то предлагает нечто совершенно иное.
Я смог решить проблему, обновив исходный выбор выбора стран только ТОЛЬКО в Соединенных Штатах, так что заметьте, это будет работать только в одной стране для людей, которые могут наткнуться на это, отредактировав код PHP:
<p class="form-row form-row-wide" id="calc_shipping_country_field"> <select name="calc_shipping_country" id="calc_shipping_country" class="country_to_state" rel="calc_shipping_state"> <option value=""><?php _e( 'Select a country…', 'woocommerce' ); ?></option> <?php foreach( WC()->countries->get_shipping_countries() as $key => $value ) echo '<option value="' . esc_attr( $key ) . '"' . selected( WC()->customer->get_shipping_country(), esc_attr( $key ), false ) . '>' . esc_html( $value ) . '</option>'; ?> </select> </p>
в
<p class="form-row form-row-wide" id="calc_shipping_country_field"> <select name="calc_shipping_country" id="calc_shipping_country" class="country_to_state" rel="calc_shipping_state"> <option value="US" selected="selected">United States (US)</option> <?php foreach( WC()->countries->get_shipping_countries() as $key => $value ) echo '<option value="' . esc_attr( $key ) . '"' . selected( WC()->customer->get_shipping_country(), esc_attr( $key ), false ) . '>' . esc_html( $value ) . '</option>'; ?> </select> </p>
Затем создайте пользовательскую страницу для корзины и переопределите таблицу стилей CSS с помощью:
#add_payment_method .cart-collaterals .cart_totals table select, .woocommerce-cart .cart-collaterals .cart_totals table select, .woocommerce-checkout .cart-collaterals .cart_totals table select { width: 0 height: 0;}
После того, как вы сделали все это, вам нужно зайти в задний конец и настроить настройки зоны доставки, чтобы отразить диапазон состояний Zip Code следующим образом: (Удалите состояния после этого, они были там для справки.)
Зоны доставки – WooCommerce
Еще одно большое спасибо @LoicTheAztec, хотя за то, что он помог мне, его путь был изначально ответом, который я искал, делая все это только через PHP, но я ленился и скорректировал таблицу стилей CSS.
Обновлен код
Если вы продаете только в штатах, поскольку ваше обновление вопроса подтверждает:
Вы можете попытаться заменить строку 54 на шаблон калькулятора доставки:
if ( is_array( $states ) && empty( $states ) ) {
от
if ( empty($current_r) ) {
И строка 59 заменить:
} elseif ( is_array( $states ) ) {
от
} elseif ( false ) {
Сюда:
1) если клиент зарегистрирован и состояние доставки определено, вы получаете предварительно заполненный стандартный ввоз 2) если клиент не вошел в систему, вы получаете поле скрытого ввода (пустое).
Попробуйте, так как я не могу проверить это на самом деле, потому что это слишком сильно зависит от настроек woocommerce.