Як перевірити, чи однакові рахунки та адреса доставки?


16

Я намагаюся перевірити, чи однакові платежі та адреса доставки при створенні PDF-файлів рахунків-фактур.

Що я намагався поки що:

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

або

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

але не працює. Я також намагався отримати цитату, використовуючи, $order->getQuote()але це теж не вийшло.

Чи є спосіб перевірити, чи однакові рахунки та адреса доставки?

Відповіді:


10

Використовуйте array_diff.

$order = $invoice->getOrder();
$billing = $order->getBillingAddress()->getData();
$shipping = $order->getShippingAddress()->getData();

$diff = array_diff($billing,$shipping);

посилання: http://us3.php.net/array_diff

можливо, вам доведеться викреслити деякі дані кожного масиву до розм. Я впевнений, що ти можеш це розробити;)


2
Хоча це буде працювати майже у всіх практичних випадках, це повинно бути array_diff_assocтому, що array_diff порівнює лише значення, тому, якщо ви, наприклад, переключите ім’я та прізвище, адреси все одно вважатимуться рівними
Fabian Schmengler

7

Незважаючи на те, що вже є прийнята відповідь, я хотів би поділитися цим рішенням, яке я бачив (подібне) одного разу в сторонньому модулі:

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

Який тоді називався:

$shippingAddress = $invoice->getShippingAddress();

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

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

     if (strcmp($shippingData, $billingData) != 0) {
        return false;
     }
}

5

Гаразд, ось ось моя спроба за пропозицією 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
}

В основному я знімаю деякі клавіші за допомогою $excludeKeysмасиву, тому array_diffбуду порівнювати лише відповідні дані. Щоб викреслити кілька клавіш, не створюючи циклу, я використовую array_diff_keyв поєднанні з, array_flipщоб позбутися від зайвих ключів масиву.

Покращення та зворотній зв'язок вітаються. :)


1
Хоча це буде працювати майже у всіх практичних випадках, це повинно бути array_diff_assocтому, що array_diff порівнює лише значення, тому, якщо ви, наприклад, переключите ім’я та прізвище, адреси все одно вважатимуться рівними.
Фабіан Шменглер

3

Вам потрібно отримати цитату, використовуючи

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

Тоді ви можете отримати адресу доставки з котирування і перевірити, чи позначена вона такою ж, як адреса платежу:

if($quote->getShippingAddress()->getSameAsBilling()){
    // do stuff
}

Де вона позначена як однакова? Здається, це не працює для мене, тому що клієнт завжди це позначав однаково, навіть якщо адреси за замовчуванням явно відрізняються.
TheKitMurkit

0

довелося порівняти адреси - одна з них була просто створена (не збережена). Можливо, це комусь допомагає:

на основі відповіді @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);
}

РЕДАКЦІЯ 20 01 2016

Я використовую наступний метод, оскільки я розмістив версію вище, і вона працює для мене - думав, що це може комусь допомогти:

/**
 * 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);
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.