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?

Était-ce utile?

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);
}
Licencié sous: CC-BY-SA avec attribution
Non affilié à magento.stackexchange
scroll top