Magento 2: Переместить кнопку размещения заказа с платежа на боковую панель на странице оформления заказа?

13

Я хочу переместить кнопку размещения заказа с оплаты на боковую панель на странице оформления заказа.

введите описание изображения здесь

Кто-нибудь может дать мне предложение?

Редактировать : это вообще возможно (с предоставленным ответом / подходом) ?

Из моего исследования каждый метод оплаты имеет свой собственный шаблон .html, включая собственную кнопку. Эта кнопка не загружается из шаблона knockout.js. Например, часть «бесплатного» метода оплаты:

    <div class="checkout-agreements-block">
        <!-- ko foreach: $parent.getRegion('before-place-order') -->
            <!-- ko template: getTemplate() --><!-- /ko -->
        <!--/ko-->
    </div>
    <div class="actions-toolbar">
        <div class="primary">
            <button class="action primary checkout"
                    type="submit"
                    data-bind="
                    click: placeOrder,
                    attr: {title: $t('Place Order')},
                    css: {disabled: !isPlaceOrderActionAllowed()}
                    ">
                <span data-bind="i18n: 'Place Order'"></span>
            </button>
        </div>
    </div>

Хотя способ оплаты «чек / денежный перевод» выглядит следующим образом (только различия есть, enable: (getCode() == isChecked())но эй, различия все же есть, и нет «1 всемогущей общей кнопки заказа места»):

  <div class="checkout-agreements-block">
        <!-- ko foreach: $parent.getRegion('before-place-order') -->
            <!-- ko template: getTemplate() --><!-- /ko -->
        <!--/ko-->
    </div>
    <div class="actions-toolbar">
        <div class="primary">
            <button class="action primary checkout"
                    type="submit"
                    data-bind="
                    click: placeOrder,
                    attr: {title: $t('Place Order')},
                    css: {disabled: !isPlaceOrderActionAllowed()},
                    enable: (getCode() == isChecked())
                    "
                    disabled>
                <span data-bind="i18n: 'Place Order'"></span>
            </button>
        </div>
    </div>

Приведенный ответ только перемещает соглашения, что приводит к чему-то вроде этого:

введите описание изображения здесь

ТУЙЕН ТРАН ТАН
источник
Привет - вы нашли разумный способ сделать это в конце концов? Спасибо
Том Бурман
Как вы добились успеха в проверке флажка условий?
Кондор

Ответы:

6

У меня было аналогичное требование изменить кнопку порядка размещения внизу сводного блока. Так как для каждого способа оплаты есть кнопка «Разместить заказ». Я создал пользовательскую кнопку размещения заказа рядом с блоком сводки заказа. Нажав на кнопку, я нажал кнопку размещения заказа выбранного способа оплаты.

Шаг 1:

Создать checkout_index_index.xmlфайл в

app / code / VendorName / PlaceOrder / view / frontend / путь к макету

<?xml version="1.0"?>
<page xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" layout="checkout" xsi:noNamespaceSchemaLocation="urn:magento:framework:View/Layout/etc/page_configuration.xsd">
    <head>
        <css src="VendorName_PlaceOrder::css/place_order_button.css"/>
    </head>
    <body>
        <referenceBlock name="checkout.root">
            <arguments>
                <argument name="jsLayout" xsi:type="array">
                    <item name="components" xsi:type="array">
                        <item name="checkout" xsi:type="array">
                            <item name="children" xsi:type="array">
                                <item name="sidebar" xsi:type="array">
                                    <item name="children" xsi:type="array">
                                        <item name="summary" xsi:type="array">
                                            <item name="component" xsi:type="string">VendorName_PlaceOrder/js/view/summary</item>
                                            <item name="config" xsi:type="array">
                                                <item name="template" xsi:type="string">VendorName_PlaceOrder/summary</item>
                                            </item>
                                        </item>
                                    </item>
                                </item>
                            </item>
                        </item>
                    </item>
                </argument>
            </arguments>
        </referenceBlock>
    </body>
</page>

Шаг 2:

Создать файл summary.htmlв пути

Приложение / код / ​​Имя_вендор / PlaceOrder / вид / интерфейс / веб / шаблон

<div class="opc-block-summary" data-bind="blockLoader: isLoading">
    <span data-bind="i18n: 'Order Summary'" class="title"></span>
    <!-- ko foreach: elems() -->
        <!-- ko template: getTemplate() --><!-- /ko -->
    <!-- /ko -->
</div>
<!-- ko if: (isVisible()) -->
<div class="actions-toolbar-trigger" id="place-order-trigger-wrapper">
    <button type="button" class="button action primary" id="place-order-trigger" value="Place Order" >
        <span>Place Order</span>
    </button>
</div>
<!-- /ko -->

Шаг 3:

Создать файл summary.jsв пути

Приложение / код / ​​Имя_вендор / PlaceOrder / вид / интерфейс / веб / JS / просмотр

define(
    [
        'jquery',
        'ko',
        'Magento_Checkout/js/view/summary',
        'Magento_Checkout/js/model/step-navigator',
    ],
    function(
        $,
        ko,
        Component,
        stepNavigator
    ) {
        'use strict';

        return Component.extend({

            isVisible: function () {
                return stepNavigator.isProcessed('shipping');
            },
            initialize: function () {
                $(function() {
                    $('body').on("click", '#place-order-trigger', function () {
                        $(".payment-method._active").find('.action.primary.checkout').trigger( 'click' );
                    });
                });
                var self = this;
                this._super();
            }

        });
    }
);

Шаг 4:

Чтобы скрыть кнопку размещения заказа по умолчанию, используйте файл CSS следующим образом

Приложение / код / ​​Имя_вендора / PlaceOrder / вид / интерфейс / веб / CSS / place_order_button.css

.payment-method-content .actions-toolbar{
    display: none;
}

Прикреплен скриншот!

введите описание изображения здесь

Хариса
источник
Здравствуйте @Haritha, я попробовал ваше решение, но оно не работает. Кнопка не отображается на странице оформления заказа. Можете ли вы помочь мне в этом.?
Привет Mayank Zalavadia, Можете ли вы проверить, загружен ли ваш пользовательский модуль после модуля Magento_Checkout в app / etc / config.php
Haritha
Я уже проверил это, и теперь оно работает, но я не могу добавить кнопку «Разместить заказ», как вы упоминаете на скриншоте. Отображается только в резюме. Можете ли вы помочь мне переместить кнопку «Разместить заказ» в том же месте, что вы упоминаете на скриншоте.
Можете поделиться своим скриншотом?
Харита
Скриншот проверки nimb.ws/5EdgS2
1

Все эти ответы не являются полными, потому что отсутствует файл registration.php для модуля регистрации

Это лучший ответ, который я нашел.

https://github.com/davidroberto/magento2-place_order_sidebar

Вот полный модуль, который вам нужно только поместить в App / code и запустить php bin / magento setup: команда upgrade

Надеюсь, это поможет!

Драган Драган
источник
спасибо, это работает для меня.
Сарвеш Динешкумар Патель
0

сначала вам нужно создать checkout_index_index.xml в вашей теме, затем нужно отключить элемент before-place-order в строке 314:

 <item name="before-place-order" xsi:type="array">

с:

<item name="before-place-order" xsi:type="array">
      <item name="componentDisabled" xsi:type="boolean">true</item>
</item>

Затем вам нужно повторно добавить этот элемент в конце оформления заказа после кнопки размещения заказа, например:

<item name="after-place-agreements" xsi:type="array">
<item name="component" xsi:type="string">uiComponent</item>
<item name="displayArea" xsi:type="string">after-place-agreements</item>
<item name="dataScope" xsi:type="string">before-place-order</item>
<item name="provider" xsi:type="string">checkoutProvider</item>
<item name="config" xsi:type="array">
    <item name="template" xsi:type="string">Magento_Checkout/payment/before-place-order</item>
</item>
<item name="children" xsi:type="array">
    <item name="agreementss" xsi:type="array">
        <item name="component" xsi:type="string">Magento_CheckoutAgreements/js/view/checkout-agreements</item>
        <item name="sortOrder" xsi:type="string">100</item>
        <item name="displayArea" xsi:type="string">after-place-agreements</item>
        <item name="dataScope" xsi:type="string">checkoutAgreements</item>
        <item name="provider" xsi:type="string">checkoutProvider</item>
    </item>
</item>

Затем скопируйте в шаблон по умолчанию (html) после размещения заказа:

<!-- ko foreach: getRegion('after-place-agreements') -->
<!-- ko template: getTemplate() --><!-- /ko -->
Magento Learner
источник