Magento добавляет столбец в сетку отгрузок продаж в Backend

Я не могу вытащить названия компаний для каждого заказа на странице сетки отгрузки. Я пытаюсь добавить столбец «Название компании» в сетке «ОТПРАВКА». Я скопировал файлы из /app/code/core/Mage/Adminhtml/Block/Sales/Shipment/Grid.php в /app/code/local/Mage/Adminhtml/Block/Sales/Shipment/Grid.php. Я сомневаюсь, в какой таблице я должен присоединиться к названию компании в функции _prepareCollection() или еще

Как добавить уже существующее название компании в форму клиента в сетке ОТПРАВКИ ??

<?php

class Mage_Adminhtml_Block_Sales_Shipment_Grid extends Mage_Adminhtml_Block_Widget_Grid
{

    /**
     * Initialization
     */
    public function __construct()
    {
        parent::__construct();
        $this->setId('sales_shipment_grid');
        $this->setDefaultSort('created_at');
        $this->setDefaultDir('DESC');
    }

    /**
     * Retrieve collection class
     *
     * @return string
     */
    protected function _getCollectionClass()
    {
        return 'sales/order_shipment_grid_collection';
    }

    /**
     * Prepare and set collection of grid
     *
     * @return Mage_Adminhtml_Block_Widget_Grid
     */
    protected function _prepareCollection()
    {
        $collection = Mage::getResourceModel($this->_getCollectionClass());
        $this->setCollection($collection);
        return parent::_prepareCollection();
    }

    /**
     * Prepare and add columns to grid
     *
     * @return Mage_Adminhtml_Block_Widget_Grid
     */
    protected function _prepareColumns()
    {
        $this->addColumn('increment_id', array(
            'header'    => Mage::helper('sales')->__('Shipment #'),
            'index'     => 'increment_id',
            'type'      => 'text',
        ));

        $this->addColumn('created_at', array(
            'header'    => Mage::helper('sales')->__('Date Shipped'),
            'index'     => 'created_at',
            'type'      => 'datetime',
        ));

        $this->addColumn('order_increment_id', array(
            'header'    => Mage::helper('sales')->__('Order #'),
            'index'     => 'order_increment_id',
            'type'      => 'text',
        ));

        $this->addColumn('order_created_at', array(
            'header'    => Mage::helper('sales')->__('Order Date'),
            'index'     => 'order_created_at',
            'type'      => 'datetime',
        ));
        $this->addColumn('company_name', array(
            'header'    => Mage::helper('sales')->__('Company Name'),
            'index'     => 'company_name',
            'type'      => 'text',
        ));

        $this->addColumn('shipping_name', array(
            'header' => Mage::helper('sales')->__('Ship to Name'),
            'index' => 'shipping_name',
        ));

        $this->addColumn('total_qty', array(
            'header' => Mage::helper('sales')->__('Total Qty'),
            'index' => 'total_qty',
            'type'  => 'number',
        ));

        $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_shipment/view'),
                        'field'   => 'shipment_id'
                    )
                ),
                'filter'    => false,
                'sortable'  => false,
                'is_system' => true
        ));

        $this->addExportType('*/*/exportCsv', Mage::helper('sales')->__('CSV'));
        $this->addExportType('*/*/exportExcel', Mage::helper('sales')->__('Excel XML'));

        return parent::_prepareColumns();
    }

    /**
     * Get url for row
     *
     * @param string $row
     * @return string
     */
    public function getRowUrl($row)
    {
        if (!Mage::getSingleton('admin/session')->isAllowed('sales/order/shipment')) {
            return false;
        }

        return $this->getUrl('*/sales_shipment/view',
            array(
                'shipment_id'=> $row->getId(),
            )
        );
    }

    /**
     * Prepare and set options for massaction
     *
     * @return Mage_Adminhtml_Block_Sales_Shipment_Grid
     */
    protected function _prepareMassaction()
    {
        $this->setMassactionIdField('entity_id');
        $this->getMassactionBlock()->setFormFieldName('shipment_ids');
        $this->getMassactionBlock()->setUseSelectAll(false);

        $this->getMassactionBlock()->addItem('pdfshipments_order', array(
             'label'=> Mage::helper('sales')->__('PDF Packingslips'),
             'url'  => $this->getUrl('*/sales_shipment/pdfshipments'),
        ));

        $this->getMassactionBlock()->addItem('print_shipping_label', array(
             'label'=> Mage::helper('sales')->__('Print Shipping Labels'),
             'url'  => $this->getUrl('*/sales_order_shipment/massPrintShippingLabel'),
        ));

        return $this;
    }

    /**
     * Get url of grid
     *
     * @return string
     */
    public function getGridUrl()
    {
        return $this->getUrl('*/*/*', array('_current' => true));
    }

}

person Phani Kumar    schedule 07.04.2015    source источник
comment
Можете ли вы вставить код, который вы изменили в Grid.php?   -  person adrien54    schedule 07.04.2015


Ответы (2)


Мне кажется, вам нужно добавить столбец (для названия компании) в скопированный файл, а также добавить дополнительный модуль визуализации для отображения нужных данных.

  1. добавьте приведенные ниже коды в файл app/code/local/Mage/Adminhtml/Block/Sales/Shipment/Grid.php.

    $this->addColumn('company_name', array( 'header' => Mage::helper('sales')->__('Company Name'), 'index' => 'company_name', 'type' => 'text', 'renderer' => 'Mage_Adminhtml_Block_Sales_Shipment_Renderer_Info' ));

  2. добавьте приведенные ниже коды в app/code/local/Mage/Adminhtml/Block/Sales/Shipment/Renderer/Info.php.

    <?php class Mage_Adminhtml_Block_Sales_Shipment_Renderer_Info extends Mage_Adminhtml_Block_Widget_Grid_Column_Renderer_Abstract { public function render(Varien_Object $row) { return 'example.com'; } }

person Milan Chandro    schedule 07.04.2015

Скопируйте основные файлы в локальный пул кода app/code/local/Mage/Adminhtml/Block/Sales/Shipment/Grid.php.

Добавьте приведенный ниже код в функцию _prepareColumns().

$this->addColumn('company_name', array( 
    'header' => Mage::helper('sales')->__('Company Name'), 
     'index' => 'company_name', 'type' => 'text', 
     'renderer' => 'Mage_Adminhtml_Block_Sales_Shipment_Renderer_Info' ));

app/code/local/Mage/Adminhtml/Block/Sales/Shipment/Renderer/Info.php

<?php

class Mage_Adminhtml_Block_Sales_Shipment_Renderer_Info extends Mage_Adminhtml_Block_Widget_Grid_Column_Renderer_Abstract {

public function render(Varien_Object $row) {
    $order = Mage::getModel('sales/order')->load($row['order_id']);
    if($order->getCustomerId() === NULL){
        echo "-";
    }
    else {
        $customer = Mage::getModel('customer/customer')->load($order->getCustomerId());
        $address_id = $customer->getDefaultBilling();
        if ((int)$address_id)
        {
            $address = Mage::getModel('customer/address')->load($address_id);
            echo $address->getCompany();
        }
    }
}

}

person Phani Kumar    schedule 10.04.2015