我在检索订单中使用的礼品卡代码和金额时遇到困难。例如,在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";
}
应该工作得很好。