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 / layout path

<?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パスにファイルを作成する

app / code / VendorName / PlaceOrder / view / frontend / web / template

<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パスにファイルを 作成する

app / code / VendorName / PlaceOrder / view / frontend / web / js / view

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ファイルを使用します

app / code / VendorName / PlaceOrder / view / frontend / web / css / place_order_button.css

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

添付はスクリーンショットです!

ここに画像の説明を入力してください


こんにちは@Haritha、私はあなたの解決策を試しましたが、うまくいきません。チェックアウトページにボタンが表示されない。これについて私を助けてくれませんか?

こんにちはMayank Zalavadia氏、app / etc / config.phpのMagento_Checkoutモジュールの後にカスタムモジュールが読み込まれているかどうかを確認できますか
Haritha

私はすでにそれを確認し、現在は機能していますが、スクリーンショットに記載されているように、[Place Order]ボタンを追加できません。要約にのみ表示されます。スクリーンショットで言及しているのと同じ場所に[注文する]ボタンを移動するのを手伝ってください。

スクリーンショットを共有できますか?
Haritha

nimb.ws/5EdgS2チェックスクリーンショット

1

登録モジュールのregistration.phpファイルが欠落しているため、これらの回答はすべて完了していません

これが私が見つけた最良の答えです。

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

App / codeの下に配置し、php bin / magento setup:upgradeコマンドを実行するだけでよい完全なモジュールを次に示します

この助けを願っています!!!


おかげで、うまくいきました。
sarvesh Dineshkumar Patel

0

最初にテーマにcheckout_index_index.xmlを作成する必要があり、次に314行でitem-place-orderの前に項目を無効にする必要があります。

 <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 -->
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.