Переместите раздел доставки в правую часть страницы оформления заказа woocommerce - PullRequest
1 голос
/ 08 мая 2020

Я изо всех сил пытался изменить макет страницы оформления заказа woocommerce. Я бы хотел переместить детали доставки вправо, чтобы они находились рядом с биллингом. Мне удалось переместить раздел деталей заказа на правую сторону с помощью css, но я также хочу, чтобы доставка переместилась туда, прямо над сводкой заказа, и я не могу сделать это в css.

образец изображения

1 Ответ

1 голос
/ 08 мая 2020

Вы должны переопределить форму оформления заказа WooCommerce.

Как переопределить:

Скопируйте форму оформления заказа с пути plugins/woocommerce/templates/checkout/form-checkout.php и вставьте активированную тему (например, здесь я вставляю его в свою настроенную дочернюю тему официальной темы WordPress twentytwenty) по следующему пути themes/twentytwenty-child/woocommerce/checkout/form-checkout.php


Переопределите содержимое следующим образом:

<?php
/**
 * Checkout Form
 *
 * This template can be overridden by copying it to yourtheme/woocommerce/checkout/form-checkout.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/
 * @package WooCommerce/Templates
 * @version 3.5.0
 */

if ( ! defined( 'ABSPATH' ) ) {
    exit;
}

do_action( 'woocommerce_before_checkout_form', $checkout );

// If checkout registration is disabled and not logged in, the user cannot checkout.
if ( ! $checkout->is_registration_enabled() && $checkout->is_registration_required() && ! is_user_logged_in() ) {
    echo esc_html( apply_filters( 'woocommerce_checkout_must_be_logged_in_message', __( 'You must be logged in to checkout.', 'woocommerce' ) ) );
    return;
}

?>

<form name="checkout" method="post" class="checkout woocommerce-checkout" action="<?php echo esc_url( wc_get_checkout_url() ); ?>" enctype="multipart/form-data">

    <?php if ( $checkout->get_checkout_fields() ) : ?>

        <?php do_action( 'woocommerce_checkout_before_customer_details' ); ?>

        <div class="col2-set" id="customer_details">
            <div class="col-1">
                <?php do_action( 'woocommerce_checkout_billing' ); ?>
            </div>
        </div>

        <?php do_action( 'woocommerce_checkout_after_customer_details' ); ?>

    <?php endif; ?>

    <?php do_action( 'woocommerce_checkout_before_order_review_heading' ); ?>
    <div class="col2-set">
        <div class="col-1">
            <h3 id="cus-shipping-heading">Shipping Details</h3>
            <?php do_action( 'woocommerce_checkout_shipping' ); ?>
        </div>
    </div>
    <h3 id="order_review_heading"><?php esc_html_e( 'Your order', 'woocommerce' ); ?></h3>

    <?php do_action( 'woocommerce_checkout_before_order_review' ); ?>

    <div id="order_review" class="woocommerce-checkout-review-order">
        <?php do_action( 'woocommerce_checkout_order_review' ); ?>
    </div>

    <?php do_action( 'woocommerce_checkout_after_order_review' ); ?>

</form>

<?php do_action( 'woocommerce_after_checkout_form', $checkout ); ?>

Объяснение изменений:

  1. Удален раздел доставки из div#customer_details
  2. Добавьте этот раздел рядом с крючком действия <?php do_action( 'woocommerce_checkout_before_order_review_heading' ); ?>
  3. Здесь это фрагмент добавленного нами раздела:

<div class="col2-set"> <div class="col-1"> <h3 id="cus-shipping-heading">Shipping Details</h3> <?php do_action( 'woocommerce_checkout_shipping' ); ?> </div> </div>


После изменения страница оформления заказа будет выглядеть так:

enter image description here

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