Немає жодної функції сортування за
через те, що getAllItems
йде від array
об'єкта і відповідно до могоconcept you cannot sort this by field.
public function getAllItems()
{
$items = array();
foreach ($this->getItemsCollection() as $item) {
if (!$item->isDeleted()) {
$items[] = $item;
}
}
return $items;
}
У цьому випадку ви можете використовувати getItemsCollection().
потім сортувати функцію seOrder у будь-якому полі
$items=$quote->getItemsCollection()->setOrder('updated_at', 'desc');
foreach ($items as $item) {
if (!$item->isDeleted()) {
//Do your code $item
}
}
Редагувати:
Перепишіть клас Mage_Sales_Model_Quote
Це буде краще уявлення про те , щоб переписати клас Mage_Sales_Model_Quote
.В цей виклик Magento є called getAllItems()
функція і г etItemsCollection() function
основний чуйним для отримання всіх елементів.
<global>
<models>
<magento65343>
<class>StackExchange_Magento65343_Model</class>
<resourceModel>magento65343_mysql4</resourceModel>
</magento65343>
<sales>
<rewrite>
<quote>StackExchange_Magento65343_Model_Sales_Quote</quote>
</rewrite>
</sales>
</models>
Переписати клас:
<?php
class StackExchange_Magento65343_Model_Sales_Quote extends Mage_Sales_Model_Quote
{
}
Використовуйте функцію setOrder () для сортування:
Функція setOrder () сортує колекцію елементів за полями
<?php
class StackExchange_Magento65343_Model_Sales_Quote extends Mage_Sales_Model_Quote
{
public function getItemsCollection($useCache = true)
{
if ($this->hasItemsCollection()) {
return $this->getData('items_collection');
}
if (is_null($this->_items)) {
$this->_items = Mage::getModel('sales/quote_item')->getCollection()->setOrder('updated_at', 'desc');
$this->_items->setQuote($this);
}
return $this->_items;
}
}