Tout d'abord, vous définissez un nouvel élément en shippingAdditional
créant un fichier view/frontend/layout/checkout_index_index.xml
comme celui-ci
<?xml version="1.0"?>
<page xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" layout="1column" xsi:noNamespaceSchemaLocation="urn:magento:framework:View/Layout/etc/page_configuration.xsd">
<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="steps" xsi:type="array">
<item name="children" xsi:type="array">
<item name="shipping-step" xsi:type="array">
<item name="children" xsi:type="array">
<item name="shippingAddress" xsi:type="array">
<item name="children" xsi:type="array">
<item name="shippingAdditional" xsi:type="array">
<item name="component" xsi:type="string">uiComponent</item>
<item name="displayArea" xsi:type="string">shippingAdditional</item>
<item name="children" xsi:type="array">
<item name="carrier_custom" xsi:type="array">
<item name="component" xsi:type="string">Vendor_Module/js/view/checkout/shipping/carrier_custom</item>
</item>
</item>
</item>
</item>
</item>
</item>
</item>
</item>
</item>
</item>
</item>
</item>
</argument>
</arguments>
</referenceBlock>
</body>
</page>
Ensuite, créez le fichier view/frontend/web/js/view/checkout/shipping/carrier_custom.js
comme ceci
define([
'jquery',
'ko',
'uiComponent',
'Magento_Checkout/js/model/quote'
], function ($, ko, Component, quote) {
'use strict';
return Component.extend({
defaults: {
template: 'Vendor_Module/checkout/shipping/carrier_custom'
},
initObservable: function () {
this.selectedMethod = ko.computed(function() {
var method = quote.shippingMethod();
var selectedMethod = method != null ? method.carrier_code + '_' + method.method_code : null;
return selectedMethod;
}, this);
return this;
},
});
});
Et puis créez un fichier view/frontend/web/template/checkout/shipping/carrier_custom.html
<div id="my-carrier-custom-block-wrapper" data-bind="visible: selectedMethod() == 'mycarrier_mymethod'">
<p data-bind="i18n: 'This is custom block shown only when selected specific method'"></p>
</div>
Fondamentalement, le fichier XML indique à la caisse de lancer le fichier js qui est un uiComponent. Il lance un modèle de selectedMethod
désactivation et utilise la fonction pour obtenir la valeur de l'expédition actuellement sélectionnée (carrier_method). Si la valeur est ce que vous voulez, elle affichera le bloc. Vous pouvez le modifier selon vos besoins, ie. vérification uniquement du transporteur sélectionné. Parce que selectedMethod
est défini car knockout.computed()
il sera réévalué chaque fois que l'utilisateur change de support car il quote.shippingMethod()
est observable.
j'ai mis à jour parce que le chemin du modèle était incorrect