Comment vérifier si la facturation et adresse de livraison sont égaux?
-
16-10-2019 - |
Question
Je suis en train de vérifier si la facturation et l'adresse d'expédition sont égaux lors de la création de fichiers PDF facture.
Ce que j'ai essayé jusqu'à présent était:
$order = $invoice->getOrder();
if( $order->getBillingAddress()->getData() != $order->getShippingAddress()->getData() )
ou
$order = $invoice->getOrder();
if( $order->getShippingAddress()->getData('same_as_billing')!='1' )
mais ni travaux. J'ai aussi essayé d'obtenir la citation en utilisant $order->getQuote()
mais cela ne fonctionne pas non plus.
Y at-il moyen de vérifier si la facturation et l'adresse d'expédition sont égaux?
La solution 3
Bon, alors voici ma tentative suite à la suggestion de ProxiBlue:
$excludeKeys = array('entity_id', 'customer_address_id', 'quote_address_id', 'region_id', 'customer_id', 'address_type');
$oBillingAddress = $order->getBillingAddress()->getData();
$oShippingAddress = $order->getShippingAddress()->getData();
$oBillingAddressFiltered = array_diff_key($oBillingAddress, array_flip($excludeKeys));
$oShippingAddressFiltered = array_diff_key($oShippingAddress, array_flip($excludeKeys));
$addressDiff = array_diff($oBillingAddressFiltered, $oShippingAddressFiltered);
if( $addressDiff ) { // billing and shipping addresses are different
// Print stuff
}
En fait, je me déshabille quelques clés en utilisant un tableau de $excludeKeys
, donc array_diff
sera comparer uniquement les données pertinentes. Pour enlever plusieurs clés sans avoir à créer une boucle, j'utilise array_diff_key
en combinaison avec array_flip
pour se débarrasser des clés du tableau inutile.
Améliorations et accueil des commentaires. :)
Autres conseils
Utilisez array_diff.
$order = $invoice->getOrder();
$billing = $order->getBillingAddress()->getData();
$shipping = $order->getShippingAddress()->getData();
$diff = array_diff($billing,$shipping);
ref: http://us3.php.net/array_diff
vous pouvez avoir à enlever quelques-unes des données de chaque tableau, avant la diff. Je suis sûr que vous pouvez travailler dehors;)
Bien qu'il y ait déjà une réponse acceptée, je voudrais partager cette solution que j'ai vu (similaire) une fois dans un module 3ème partie:
function serializeAddress(Mage_Sales_Model_Quote_Address $address) {
return serialize(
array(
'firstname' => $address->getFirstname(),
'lastname' => $address->getLastname(),
'street' => $address->getStreet(),
'city' => $address->getCity(),
'postcode' => $address->getPostcode(),
//add the attributes you want to check for here for ex. company,...
)
);
}
Ce qui a ensuite été appelé:
$shippingAddress = $invoice->getShippingAddress();
if (!$shippingAddress->getSameAsBilling()) {
$shippingData = $this->serializeAddress($shippingAddress);
$billingData = $this->serializeAddress($invoice->getBillingAddress());
if (strcmp($shippingData, $billingData) != 0) {
return false;
}
}
Vous devez obtenir la citation en utilisant
$order = $invoice->getOrder();
$quote = Mage::getModel('sales/quote')->load($order->getQuoteId());
Ensuite, vous pouvez obtenir l'adresse de livraison du devis et vérifier si elle est marquée comme étant la même que l'adresse de facturation:
if($quote->getShippingAddress()->getSameAsBilling()){
// do stuff
}
a dû comparer les adresses - l'un d'entre eux vient d'être créé (non enregistré). Peut-être que quelqu'un aide:
fonction de la réponse @Alphawolf:
public function isDifferentAddresses(Mage_Customer_Model_Address $adr1, Mage_Customer_Model_Address $adr2, array $excludeKeys = array())
{
if (!count($excludeKeys)) {
$excludeKeys = array(
'entity_id',
'entity_type_id',
'attribute_set_id',
'is_active',
'increment_id',
'parent_id',
'created_at',
'updated_at',
'customer_id',
'customer_address_id',
'quote_address_id',
'region_id',
'address_type',
'is_default_billing',
'is_default_shipping',
'save_in_address_book'
);
}
$excludeKeys = array_flip($excludeKeys);
$adr1Filtered = array_diff_key($adr1->getData(), $excludeKeys);
$adr2Filtered = array_diff_key($adr2->getData(), $excludeKeys);
$diff = array_diff_assoc($adr1Filtered, $adr2Filtered);
return !empty($diff);
}
EDIT 20 01 2016
im en utilisant la méthode suivante depuis que j'ai posté la version ci-dessus et il fonctionne pour moi - pensait que cela peut aider quelqu'un:
/**
* returns if address 1 is different to address 2
*
* @param Mage_Customer_Model_Address $adr1
* @param Mage_Customer_Model_Address $adr2
* @param array $excludeKeys
*
* @return bool
*/
public function isDifferentAddresses(Mage_Customer_Model_Address $adr1,
Mage_Customer_Model_Address $adr2, array $excludeKeys = array()
) {
if (!count($excludeKeys)) {
$excludeKeys = array(
'prefix',
'suffix',
//'region',
//'region_id',
'entity_id',
'vat_id',
'entity_type_id',
'attribute_set_id',
'is_active',
'increment_id',
'parent_id',
'created_at',
'updated_at',
'customer_id',
'customer_address_id',
'quote_address_id',
'address_type',
'is_default_billing',
'is_default_shipping',
'save_in_address_book'
);
}
$excludeKeys = array_flip($excludeKeys);
$adr1Filtered = array_diff_key($adr1->getData(), $excludeKeys);
$adr2Filtered = array_diff_key($adr2->getData(), $excludeKeys);
$diff = array_diff_assoc($adr1Filtered, $adr2Filtered);
return !empty($diff);
}