이 튜토리얼 을 따라 그리드를 만들었습니다. 4 개의 그리드를 더 만들고 싶습니다. 문제는이 모든 그리드를 탭에 추가해야한다는 것입니다
지금까지 다음과 같이 블록을로드하는 컨트롤러를 만들었습니다.
class Lime_Customgrid_Adminhtml_CustomController extends Mage_Adminhtml_Controller_Action
{
public function indexAction()
{
$this->_title($this->__('Custom'))->_title($this->__('Custom Lime'));
$this->loadLayout();
$this->_setActiveMenu('sales/sales');
$this->_addContent($this->getLayout()->createBlock('lime_customgrid/adminhtml_table_custom'));
$this->renderLayout();
}
}
블록> Adminhtml> 테이블> 사용자 정의> Custom.php :
<?php
class Lime_Customgrid_Block_Adminhtml_Table_Custom extends Mage_Adminhtml_Block_Widget_Tabs
{
public function __construct()
{
parent::__construct();
$this->setId('custom_tabs');
// $this->setDestElementId('edit_form');
$this->setTitle(Mage::helper('lime_customgrid')->__('Custom tabs'));
}
protected function _beforeToHtml()
{
$this->addTab(
'form_listing',
array(
'label' => Mage::helper('lime_customgrid')->__('Listing'),
'title' => Mage::helper('lime_customgrid')->__('Listing'),
'content' => $this->getLayout()->createBlock(
'lime_customgrid/adminhtml_table_custom_tab_grid'
)
->toHtml(),
)
);
$this->addTab(
'form_attributes_listing',
array(
'label' => Mage::helper('lime_customgrid')->__('Set Attributes'),
'title' => Mage::helper('lime_customgrid')->__('Set Attributes'),
'content' => $this->getLayout()->createBlock(
'lime_customgrid/adminhtml_table_custom_tab_grid'
)
->toHtml(),
)
);
return parent::_beforeToHtml();
}
}
블록> Adminhtml> 테이블> 사용자 정의> 탭> Grid.php :
<?php
class Lime_Customgrid_Block_Adminhtml_Table_Custom_Tab_Grid extends Mage_Adminhtml_Block_Widget_Grid
{
public function __construct()
{
parent::__construct();
$this->setId('lime_order_grid');
$this->setDefaultSort('increment_id');
$this->setDefaultDir('DESC');
$this->setSaveParametersInSession(true);
$this->setUseAjax(true);
}
protected function _prepareCollection()
{
$collection = Mage::getResourceModel('sales/order_collection')
->join(array('a' => 'sales/order_address'), 'main_table.entity_id = a.parent_id AND a.address_type != \'billing\'', array(
'city' => 'city',
'country_id' => 'country_id'
))
->join(array('c' => 'customer/customer_group'), 'main_table.customer_group_id = c.customer_group_id', array(
'customer_group_code' => 'customer_group_code'
))
->addExpressionFieldToSelect(
'fullname',
'CONCAT({{customer_firstname}}, \' \', {{customer_lastname}})',
array('customer_firstname' => 'main_table.customer_firstname', 'customer_lastname' => 'main_table.customer_lastname'))
->addExpressionFieldToSelect(
'products',
'(SELECT GROUP_CONCAT(\' \', x.name)
FROM sales_flat_order_item x
WHERE {{entity_id}} = x.order_id
AND x.product_type != \'configurable\')',
array('entity_id' => 'main_table.entity_id')
)
;
$this->setCollection($collection);
parent::_prepareCollection();
return $this;
}
protected function _prepareColumns()
{
$helper = Mage::helper('lime_customgrid');
$currency = (string) Mage::getStoreConfig(Mage_Directory_Model_Currency::XML_PATH_CURRENCY_BASE);
$this->addColumn('increment_id', array(
'header' => $helper->__('Order #'),
'index' => 'increment_id'
));
$this->addColumn('purchased_on', array(
'header' => $helper->__('Purchased On'),
'type' => 'datetime',
'index' => 'created_at'
));
$this->addColumn('products', array(
'header' => $helper->__('Products Purchased'),
'index' => 'products',
'filter_index' => '(SELECT GROUP_CONCAT(\' \', x.name) FROM sales_flat_order_item x WHERE main_table.entity_id = x.order_id AND x.product_type != \'configurable\')'
));
$this->addColumn('fullname', array(
'header' => $helper->__('Name'),
'index' => 'fullname',
'filter_index' => 'CONCAT(customer_firstname, \' \', customer_lastname)'
));
$this->addColumn('city', array(
'header' => $helper->__('City'),
'index' => 'city'
));
$this->addColumn('country', array(
'header' => $helper->__('Country'),
'index' => 'country_id',
'renderer' => 'adminhtml/widget_grid_column_renderer_country'
));
$this->addColumn('customer_group', array(
'header' => $helper->__('Customer Group'),
'index' => 'customer_group_code'
));
$this->addColumn('grand_total', array(
'header' => $helper->__('Grand Total'),
'index' => 'grand_total',
'type' => 'currency',
'currency_code' => $currency
));
$this->addColumn('shipping_method', array(
'header' => $helper->__('Shipping Method'),
'index' => 'shipping_description'
));
$this->addColumn('order_status', array(
'header' => $helper->__('Status'),
'index' => 'status',
'type' => 'options',
'options' => Mage::getSingleton('sales/order_config')->getStatuses(),
));
$this->addExportType('*/*/exportLimeCsv', $helper->__('CSV'));
$this->addExportType('*/*/exportLimeExcel', $helper->__('Excel XML'));
return parent::_prepareColumns();
}
public function getGridUrl()
{
return $this->getUrl('*/*/grid', array('_current'=>true));
}
}
결과는 다음 페이지 매김을로드하기 위해 클릭해도 관리 대시 보드로 리디렉션됩니다.
magento.stackexchange.com/questions/170233/…
—
Divyesh
이것이 여러분들을 도울 수 있기를 바랍니다 magento.stackexchange.com/questions/82159/…
—
Pradeep Kumar