Magento:获取礼品卡代码和金额


Magento: getting giftcard code and amount

我在检索订单中使用的礼品卡代码和金额时遇到困难。例如,在Mage/Sales/Model/Order/Pdf/Abstract.php中,有一段代码适用于销售/订单模型。即

($order instanceof Mage_Sales_Model_Order) is true in the PDF example

$order = Mage::getModel('sales/order')->load($orderID); in another example

在打印的发票 PDF 中,"总计"部分显示使用的礼品卡以及使用的优惠券代码。优惠券代码可以通过$order->getCouponCode()获得。

如何从$order获取礼品卡代码和金额?我试过了

$order->getGiftcertCode();
$order->getGiftcertAmount();

但这些不会返回任何内容。有什么想法吗?

可能有几种方法可以做到这一点,但我以前不必这样做,所以通过查看Magento数据库中的sales_flat_order表,我可以看到有许多字段可用于引用不同的礼品卡金额:

base_gift_cards_amount
gift_cards_amount
base_gift_cards_invoiced
gift_cards_invoiced
base_gift_cards_refunded
gift_cards_refunded

可以通过以下调用访问这些内容:

$order->getBaseGiftCardsAmount();
$order->getGiftCardsAmount();
$order->getBaseGiftCardsInvoiced();
$order->getGiftCardsInvoiced();
$order->getBaseGiftCardsRefunded();
$order->getGiftCardsRefunded();

您要使用的那个可能是$order->getGiftCardsAmount()

为了获取礼品卡详细信息,它们作为序列化数组存储在上表的"gift_cards"列中。因此,要获取该数组,请调用

$cards = unserialize($order->getGiftCards());

print_r $cards,你会看到这样的东西:

Array
(
    [0] => Array
         (
             [i] => 1
             [c] => {{Gift Card Code}}
             [a] => {{Gift Card Amount}}
             [ba] => {{Gift Card Base Amount}}
         )
)

所以

foreach ($cards as $card) {
    echo "Code: " . $card['c'] . "'n";
    echo "Amount: " . $card['a'] . "'n";
}

应该工作得很好。