Según su pregunta, supongo que ya tiene configurados sus atributos de extensión. He llevado a cabo una modificación similar y espero que mi respuesta ayude.
En su módulo personalizado, cree un archivo requirejs-config para extender el procesador de envío predeterminado / predeterminado
Espacio de nombres / CustomModule / view / frontend / requirejs-config.js
var config = {
"mapa": {
"*": {
'Magento_Checkout / js / model / shipping-save-processor / default': 'Namespace_CustomModule / js / model / shipping-save-processor / default'
}
}
};
Agregue su atributo de extensión a la carga útil.
/ * definición global, alerta * /
definir(
[
'jquery',
'ko',
'Magento_Checkout / js / model / quote',
'Magento_Checkout / js / model / resource-url-manager',
'mago / almacenamiento',
'Magento_Checkout / js / model / payment-service',
'Magento_Checkout / js / model / payment / method-converter',
'Magento_Checkout / js / model / error-processor',
'Magento_Checkout / js / model / full-screen-loader',
'Magento_Checkout / js / action / select-billing-address'
],
función (
PS
ko,
citar,
resourceUrlManager,
almacenamiento,
servicio de pago,
methodConverter,
errorProcessor,
fullScreenLoader,
selectBillingAddressAction
) {
'uso estricto';
regreso {
saveShippingInformation: function () {
carga útil var;
if (! quote.billingAddress ()) {
selectBillingAddressAction (quote.shippingAddress ());
}
// Agregar los atributos de extensión a su dirección de envío
carga útil = {
Datos del Domicilio: {
shipping_address: quote.shippingAddress (),
billing_address: quote.billingAddress (),
shipping_method_code: quote.shippingMethod (). method_code,
shipping_carrier_code: quote.shippingMethod (). carrier_code,
atributos_extensión: {
custom_field: $ ('# custom_field'). val (),
}
}
};
fullScreenLoader.startLoader ();
return storage.post (
resourceUrlManager.getUrlForSetShippingInformation (cita),
JSON.stringify (carga útil)
).hecho(
función (respuesta) {
quote.setTotals (response.totals);
paymentService.setPaymentMethods (methodConverter (response.payment_methods));
fullScreenLoader.stopLoader ();
}
).fallar(
función (respuesta) {
errorProcessor.process (respuesta);
fullScreenLoader.stopLoader ();
}
);
}
};
}
);
Guarde el atributo en su presupuesto con un complemento (no estoy seguro si podría usar un observador aquí, no lo he verificado).
di.xml
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
<type name="Magento\Checkout\Model\ShippingInformationManagement">
<plugin name="Namespace_CustomModule_save_delivery_date_in_quote" type="Namespace\CustomModule\Plugin\Checkout\SaveAddressInformation" />
</type>
</config>
SaveAddressInformation.php
clase SaveAddressInformation
{
protegido $ quoteRepository;
función pública __construct (
\ Magento \ Quote \ Model \ QuoteRepository $ quoteRepository
) {
$ this-> quoteRepository = $ quoteRepository;
}
/ **
* @param \ Magento \ Checkout \ Model \ ShippingInformationManagement $ subject
* @param $ cartId
* @param \ Magento \ Checkout \ Api \ Data \ ShippingInformationInterface $ addressInformation
* /
función pública beforeSaveAddressInformation (
\ Magento \ Checkout \ Model \ ShippingInformationManagement $ subject,
$ cartId,
\ Magento \ Checkout \ Api \ Data \ ShippingInformationInterface $ addressInformation
) {
$ extensionAttributes = $ addressInformation-> getExtensionAttributes ();
$ customField = $ extensionAttributes-> getCustomField ();
$ quote = $ this-> quoteRepository-> getActive ($ cartId);
$ quote-> setCustomField ($ customField);
}
}
Guarde el atributo en su pedido con un observador events.xml
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd">
<event name="sales_model_service_quote_submit_before">
<observer name="unique_observer_name" instance="Namespace\CustomModule\Observer\SaveCustomFieldToOrder"/>
</event>
</config>
SaveCustomFieldToOrder.php
La clase SaveCustomFieldToOrder implementa ObserverInterface
{
/ **
* @var \ Magento \ Framework \ ObjectManagerInterface
* /
protegido $ _objectManager;
/ **
* @param \ Magento \ Framework \ ObjectManagerInterface $ objectmanager
* /
función pública __construct (\ Magento \ Framework \ ObjectManagerInterface $ objectmanager)
{
$ this -> _ objectManager = $ objectmanager;
}
ejecución de función pública (EventObserver $ observer)
{
$ orden = $ observador-> getOrder ();
$ quoteRepository = $ this -> _ objectManager-> create ('Magento \ Quote \ Model \ QuoteRepository');
/ ** @var \ Magento \ Quote \ Model \ Quote $ quote * /
$ quote = $ quoteRepository-> get ($ order-> getQuoteId ());
$ order-> setCustomField ($ quote-> getCustomField ());
devuelve $ this;
}
}