Bagaimana cara memeriksa apakah alamat penagihan dan pengiriman sama?

16

Saya mencoba memeriksa apakah alamat penagihan dan pengiriman sama ketika membuat PDF faktur.

Apa yang saya coba sejauh ini adalah:

$order = $invoice->getOrder();
if( $order->getBillingAddress()->getData() != $order->getShippingAddress()->getData() )

atau

$order = $invoice->getOrder();
if( $order->getShippingAddress()->getData('same_as_billing')!='1' )

tapi tidak ada yang berhasil. Saya juga mencoba untuk mendapatkan penawaran dengan menggunakan $order->getQuote()tetapi itu tidak berhasil.

Apakah ada cara untuk memeriksa apakah penagihan dan alamat pengiriman sama?

oschloebe
sumber

Jawaban:

10

Gunakan 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

Anda mungkin harus menghapus beberapa data dari setiap array, sebelum diff. Saya yakin Anda bisa menyelesaikannya;)

ProxiBlue
sumber
2
Meskipun ini akan bekerja di hampir semua kasus praktis, itu seharusnya array_diff_assockarena array_diff hanya membandingkan nilai, jadi jika Anda misalnya mengganti nama depan dan nama belakang, alamat akan tetap diperlakukan sama
Fabian Schmengler
7

Meskipun sudah ada jawaban yang diterima, saya ingin membagikan solusi ini yang saya lihat (serupa) satu kali dalam modul pihak ke-3:

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,...
            )
        );
}

Yang kemudian disebut:

$shippingAddress = $invoice->getShippingAddress();

if (!$shippingAddress->getSameAsBilling()) {

     $shippingData = $this->serializeAddress($shippingAddress);
     $billingData = $this->serializeAddress($invoice->getBillingAddress());

     if (strcmp($shippingData, $billingData) != 0) {
        return false;
     }
}
Anna Völkl
sumber
5

Oke, jadi inilah upaya saya mengikuti saran 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
}

Pada dasarnya saya menghapus beberapa kunci dengan menggunakan $excludeKeysarray, jadi hanya array_diffakan membandingkan data yang relevan. Untuk menghapus beberapa kunci tanpa harus membuat lingkaran, saya menggunakan array_diff_keydalam kombinasi dengan array_flipuntuk menyingkirkan kunci array yang tidak perlu.

Perbaikan dan umpan balik diterima. :)

oschloebe
sumber
1
Meskipun ini akan bekerja di hampir semua kasus praktis, seharusnya array_diff_assockarena array_diff hanya membandingkan nilai, jadi jika Anda misalnya mengganti nama depan dan nama belakang, alamat akan tetap diperlakukan sama.
Fabian Schmengler
3

Anda perlu menggunakan penawaran

$order = $invoice->getOrder();
$quote = Mage::getModel('sales/quote')->load($order->getQuoteId());

Kemudian Anda bisa mendapatkan alamat pengiriman dari kutipan dan memeriksa apakah itu ditandai sama dengan alamat penagihan:

if($quote->getShippingAddress()->getSameAsBilling()){
    // do stuff
}
gebrial
sumber
Di mana itu ditandai sebagai sama? Sepertinya itu tidak berfungsi untuk saya, karena pelanggan selalu menandainya sama meskipun alamat default jelas berbeda.
TheKitMurkit
0

harus membandingkan alamat - salah satunya baru saja dibuat (tidak disimpan). Mungkin itu membantu seseorang:

berdasarkan jawaban @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

Saya menggunakan metode berikut karena saya memposting versi di atas dan itu bekerja untuk saya - saya pikir itu dapat membantu seseorang:

/**
 * 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);
}
cottton
sumber