Добавить Поле Скидки В Таблицу заказов
-
16-10-2019 - |
Вопрос
Привет, ребята, я не понимаю, как добавить поле скидки В сетку администратора Magento.
Также, пожалуйста, объясните, как добавить отображение пользовательских табличных значений в таблицу заказов.
Решение
Да, у нас есть Решения для этого, мы должны переписать класс
mage_adminhtml_block_sales_order_grid_маги_администрации
1) Создайте пользовательский модуль в magento и сначала создайте файл конфигурации вашего модуля в папке app/etc/module/Keyul_Discountadd.xml.
<?xml version="1.0"?>
<config>
<modules>
<Keyul_Discountadd>
<active>true</active>
<codePool>local</codePool>
<version>0.1.0</version>
</Keyul_Discountadd>
</modules>
</config>
2) Создайте папки в app/code/local/Keyul/Discountadd/Block и app/ code/local/Keyul/Discountadd / etc соответственно.
3) создайте файл config.xml в папке etc, как показано ниже.
<?xml version="1.0"?>
<config>
<modules>
<Keyul_Discountadd>
<version>0.1.0</version>
</Keyul_Discountadd>
</modules>
<global>
<blocks>
<discountadd>
<class>Keyul_Discountadd_Block</class>
</discountadd>
<adminhtml>
<rewrite>
<sales_order_grid>Keyul_Discountadd_Block_Adminhtml_Sales_Order_Grid</sales_order_grid>
</rewrite>
</adminhtml>
</blocks>
</global>
</config>
4) создайте файл app\code\local\Keyul\Discountadd\Block\Adminhtml\Sales\Order\grid.php, как показано ниже.
Добавьте приведенный ниже код
<?php
class Keyul_Discountadd_Block_Adminhtml_Sales_Order_Grid extends Mage_Adminhtml_Block_Sales_Order_Grid
{
protected function _prepareCollection()
{
//$collection = Mage::getResourceModel($this->_getCollectionClass());
$collection = Mage::getResourceModel('sales/order_collection')
->addAttributeToSelect('*');
$this->setCollection($collection);
return parent::_prepareCollection();
}
protected function _prepareColumns()
{
$this->addColumn('real_order_id', array(
'header'=> Mage::helper('sales')->__('Order #'),
'width' => '80px',
'type' => 'text',
'index' => 'increment_id',
));
if (!Mage::app()->isSingleStoreMode()) {
$this->addColumn('store_id', array(
'header' => Mage::helper('sales')->__('Purchased From (Store)'),
'index' => 'store_id',
'type' => 'store',
'store_view'=> true,
'display_deleted' => true,
));
}
$this->addColumn('created_at', array(
'header' => Mage::helper('sales')->__('Purchased On'),
'index' => 'created_at',
'type' => 'datetime',
'width' => '100px',
));
$this->addColumn('billing_name', array(
'header' => Mage::helper('sales')->__('Bill to Name'),
'index' => 'billing_name',
));
$this->addColumn('shipping_name', array(
'header' => Mage::helper('sales')->__('Ship to Name'),
'index' => 'shipping_name',
));
$this->addColumn('discount_amount', array(
'header' => Mage::helper('sales')->__('discount_amount'),
'index' => 'discount_amount',
));
$this->addColumn('base_grand_total', array(
'header' => Mage::helper('sales')->__('G.T. (Base)'),
'index' => 'base_grand_total',
'type' => 'currency',
'currency' => 'base_currency_code',
));
$this->addColumn('grand_total', array(
'header' => Mage::helper('sales')->__('G.T. (Purchased)'),
'index' => 'grand_total',
'type' => 'currency',
'currency' => 'order_currency_code',
));
$this->addColumn('status', array(
'header' => Mage::helper('sales')->__('Status'),
'index' => 'status',
'type' => 'options',
'width' => '70px',
'options' => Mage::getSingleton('sales/order_config')->getStatuses(),
));
if (Mage::getSingleton('admin/session')->isAllowed('sales/order/actions/view')) {
$this->addColumn('action',
array(
'header' => Mage::helper('sales')->__('Action'),
'width' => '50px',
'type' => 'action',
'getter' => 'getId',
'actions' => array(
array(
'caption' => Mage::helper('sales')->__('View'),
'url' => array('base'=>'*/sales_order/view'),
'field' => 'order_id'
)
),
'filter' => false,
'sortable' => false,
'index' => 'stores',
'is_system' => true,
));
}
$this->addRssList('rss/order/new', Mage::helper('sales')->__('New Order RSS'));
$this->addExportType('*/*/exportCsv', Mage::helper('sales')->__('CSV'));
$this->addExportType('*/*/exportExcel', Mage::helper('sales')->__('Excel XML'));
return $this;
}
}
5) Очистите кэш и откройте таблицу продаж, в таблице появится скидка.
Примечание.Не изменяйте непосредственно в основных файлах, если вы хотите изменить, затем перепишите класс, а затем внесите изменения.
Другие советы
Здесь я снова с решением для добавления колонн в сетку продаж без использования переписывания, так как некоторое время Magento использует специальный sales_flat_order_grid
Таблица для создания страницы сетки заказа на продажу. Преимущество для этого заключается в том, что вам не нужно добавлять соединения или переписать файлы основных ядер для отображения дополнительных столбцов. В Добавить столбец в сетку (наблюдатель) - столбец 'store_id', где пункт является неоднозначной проблемой Я сделал полное расширение образца о том, как вы можете добавить дополнительный столбец. В примере измените имя столбца и ваше сделано.
Наблюдатель, используемый Magento для этого, заботится об обновлении для записей при изменении данных заказа.