Magento受注グリッドに顧客のメールを表示したいと思います。ローカルメールモジュールのMage_Adminhtml_Block_Sales_Order_Grid
を書き換えて、顧客の電子メールの新しい列を追加する必要があります。私は注文ごとに電子メールの価値を持っていますが、ソートとフィルタリングは期待通りに機能しません。受注グリッドMagentoでフィルタとソートが機能しない
私はこの問題をソートするのに1日以上を費やしましたが運はありませんでした。また、私はあまりにも答えのいくつかを参照してください。
以下私はreferring this answerを試してみましたあるコードで、
public function setCollection($collection)
{
$collection->getSelect()->joinLeft(
array('sfo'=>'sales_flat_order'),
'main_table.entity_id=' . 'sfo' . '.entity_id',
array('*')
);
$collection->getSelect()->joinLeft(
array('sfoa'=>'sales_flat_order_address'),
'main_table.entity_id=' . 'sfoa' . '.parent_id',
array('email')
);
$collection->getSelect()->group(array('main_table.entity_id'));
$collection->addFilterToMap('increment_id', 'main_table.increment_id');
parent::setCollection($collection);
}
protected function _prepareColumns()
{
$this->addColumnAfter('email', array(
'header' => Mage::helper('sales')->__('Customer Email'),
'width' => '80px',
'type' => 'text',
'index' => 'email',
'filter_index' => 'sfoa.email',
'filter_condition_callback' => 'filter_last_login',
'order_callback' => 'sort_last_login',
), 'erp_confirm_order');
return parent::_prepareColumns();
}
public function getGridUrl()
{
return $this->getUrl('*/*/grid', array('_current'=>true));
}
function filter_last_login($collection, $column)
{
if (!$column->getFilter()->getCondition()) {
return;
}
$condition = $collection->getConnection()
->prepareSqlCondition('sfoa.email', $column->getFilter()->getCondition());
$collection->getSelect()->where($condition);
}
function sort_last_login($collection, $column)
{
$collection->getSelect()->order($column->getIndex() . ' ' . strtoupper($column->getDir()));
}
protected function _setCollectionOrder($column)
{
if ($column->getOrderCallback()) {
call_user_func($column->getOrderCallback(), $this->getCollection(), $column);
return $this;
}
return parent::_setCollectionOrder($column);
}
編集1
私は顧客の電子メールの列をフィルタリング&をソートするときに何も働かない、私も、私はエラーを取得しています残りのデフォルトのグリッド列をクリックします。
Integrity constraint violation: 1052 Column 'increment_id' in order clause is ambiguous, query was: SELECT `main_table`.*, `sfo`.*, `sfoa`.`email` FROM `sales_flat_order_grid` AS `main_table`
LEFT JOIN `sales_flat_order` AS `sfo` ON main_table.entity_id=sfo.entity_id
LEFT JOIN `sales_flat_order_address` AS `sfoa` ON main_table.entity_id=sfoa.parent_id GROUP BY `main_table`.`entity_id` ORDER BY increment_id ASC LIMIT 20
ご迷惑をおかけして申し訳ありません。 ありがとう、
あなたはすべてのエラーメッセージを取得してくださいか、それは単にまったく何もしないのですか? – Ian
@Ian並べ替えとフィルタリングは何も起こりません。親切に編集を確認する1.ありがとう。 –