Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/228.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如何在Magento的销售/订单网格中添加自定义列?_Php_Mysql_Magento_Magento 1.9.1 - Fatal编程技术网

Php 如何在Magento的销售/订单网格中添加自定义列?

Php 如何在Magento的销售/订单网格中添加自定义列?,php,mysql,magento,magento-1.9.1,Php,Mysql,Magento,Magento 1.9.1,我正在尝试将自定义列添加到我的销售/订单网格中。我的列将是跟踪编号和磁贴。标题基本上是快递代码,显示您通过哪个快递公司向您发送产品。 为此,我做了以下几件事 我已将文件从magento/app/code/core/Mage/Adminhtml/Block/Sales/Order/Grid.php复制到 magento/app/code/local/Mage/Adminhtml/Block/Sales/Order/Grid.php 这样我就可以添加列并自定义我的销售/订单表格 在Grid.php文

我正在尝试将自定义列添加到我的销售/订单网格中。我的列将是跟踪编号和磁贴。标题基本上是快递代码,显示您通过哪个快递公司向您发送产品。 为此,我做了以下几件事

  • 我已将文件从
    magento/app/code/core/Mage/Adminhtml/Block/Sales/Order/Grid.php
    复制到
  • magento/app/code/local/Mage/Adminhtml/Block/Sales/Order/Grid.php

    这样我就可以添加列并自定义我的销售/订单表格

  • 在Grid.php文件中,有_prepareCollections()函数
  • 这里是代码

    protected function _prepareCollection()
        {
            $collection = Mage::getResourceModel($this->_getCollectionClass());
            $this->setCollection($collection);
            $collection->getSelect();
            $collection->getSelect()->join('sales_flat_shipment_track', 'main_table.entity_id =sales_flat_shipment_track.order_id',array('track_number'=> new Zend_Db_Expr('group_concat(sales_flat_shipment_track.track_number SEPARATOR ",")'),'title' => new Zend_Db_Expr('group_concat(sales_flat_shipment_track.title SEPARATOR ",")')));
            return parent::_prepareCollection();    
        }
    
    现在我将在我的_prepareColumns()函数中添加我的列。代码是

    protected function _prepareColumns()
        {
            $this->addColumn('track_number', array(
                'header'=> Mage::helper('sales')->__(' Track Number'),
                'width' => '80px',
                'type'  => 'text',
                'index' => 'track_number',
                ));
            $this->addColumn('title', array(
    
                'header'=> Mage::helper('sales')->__('Title'),
                'width' => '80px',
                'index' => 'title',
                ));
    
    文件Grid.php在这里

    <?php
    /**
     * Magento
     *
     * NOTICE OF LICENSE
     *
     * This source file is subject to the Open Software License (OSL 3.0)
     * that is bundled with this package in the file LICENSE.txt.
     * It is also available through the world-wide-web at this URL:
     * http://opensource.org/licenses/osl-3.0.php
     * If you did not receive a copy of the license and are unable to
     * obtain it through the world-wide-web, please send an email
     * to license@magentocommerce.com so we can send you a copy immediately.
     *
     * DISCLAIMER
     *
     * Do not edit or add to this file if you wish to upgrade Magento to newer
     * versions in the future. If you wish to customize Magento for your
     * needs please refer to http://www.magentocommerce.com for more information.
     *
     * @category    Mage
     * @package     Mage_Adminhtml
     * @copyright   Copyright (c) 2014 Magento Inc. (http://www.magentocommerce.com)
     * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
     */
    
    /**
     * Adminhtml sales orders grid
     *
     * @category   Mage
     * @package    Mage_Adminhtml
     * @author      Magento Core Team <core@magentocommerce.com>
     */
    class Mage_Adminhtml_Block_Sales_Order_Grid extends Mage_Adminhtml_Block_Widget_Grid
    {
    
        public function __construct()
        {
            parent::__construct();
            $this->setId('sales_order_grid');
            $this->setUseAjax(true);
            $this->setDefaultSort('created_at');
            $this->setDefaultDir('DESC');
            $this->setSaveParametersInSession(true);
        }
    
        /**
         * Retrieve collection class
         *
         * @return string
         */
        protected function _getCollectionClass()
        {
            return 'sales/order_grid_collection';
        }
    
        protected function _prepareCollection()
        {
            $collection = Mage::getResourceModel($this->_getCollectionClass());
            $this->setCollection($collection);
            $collection->getSelect();
            $collection->getSelect()->join('sales_flat_shipment_track', 'main_table.entity_id =sales_flat_shipment_track.order_id',array('track_number'=> new Zend_Db_Expr('group_concat(sales_flat_shipment_track.track_number SEPARATOR ",")'),'title' => new Zend_Db_Expr('group_concat(sales_flat_shipment_track.title SEPARATOR ",")')));
            return parent::_prepareCollection();    
        }
    
        protected function _prepareColumns()
        {
            $this->addColumn('track_number', array(
                'header'=> Mage::helper('sales')->__(' Track Number'),
                'width' => '80px',
                'type'  => 'text',
                'index' => 'track_number',
                ));
            $this->addColumn('title', array(
    
                'header'=> Mage::helper('sales')->__('Title'),
                'width' => '80px',
                'index' => 'title',
                ));
    
            $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('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',
                                'data-column' => 'action',
                            )
                        ),
                        '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 parent::_prepareColumns();
        }
    
        protected function _prepareMassaction()
        {
            $this->setMassactionIdField('entity_id');
            $this->getMassactionBlock()->setFormFieldName('order_ids');
            $this->getMassactionBlock()->setUseSelectAll(false);
    
            if (Mage::getSingleton('admin/session')->isAllowed('sales/order/actions/cancel')) {
                $this->getMassactionBlock()->addItem('cancel_order', array(
                     'label'=> Mage::helper('sales')->__('Cancel'),
                     'url'  => $this->getUrl('*/sales_order/massCancel'),
                ));
            }
    
            if (Mage::getSingleton('admin/session')->isAllowed('sales/order/actions/hold')) {
                $this->getMassactionBlock()->addItem('hold_order', array(
                     'label'=> Mage::helper('sales')->__('Hold'),
                     'url'  => $this->getUrl('*/sales_order/massHold'),
                ));
            }
    
            if (Mage::getSingleton('admin/session')->isAllowed('sales/order/actions/unhold')) {
                $this->getMassactionBlock()->addItem('unhold_order', array(
                     'label'=> Mage::helper('sales')->__('Unhold'),
                     'url'  => $this->getUrl('*/sales_order/massUnhold'),
                ));
            }
    
            $this->getMassactionBlock()->addItem('pdfinvoices_order', array(
                 'label'=> Mage::helper('sales')->__('Print Invoices'),
                 'url'  => $this->getUrl('*/sales_order/pdfinvoices'),
            ));
    
            $this->getMassactionBlock()->addItem('pdfshipments_order', array(
                 'label'=> Mage::helper('sales')->__('Print Packingslips'),
                 'url'  => $this->getUrl('*/sales_order/pdfshipments'),
            ));
    
            $this->getMassactionBlock()->addItem('pdfcreditmemos_order', array(
                 'label'=> Mage::helper('sales')->__('Print Credit Memos'),
                 'url'  => $this->getUrl('*/sales_order/pdfcreditmemos'),
            ));
    
            $this->getMassactionBlock()->addItem('pdfdocs_order', array(
                 'label'=> Mage::helper('sales')->__('Print All'),
                 'url'  => $this->getUrl('*/sales_order/pdfdocs'),
            ));
    
            $this->getMassactionBlock()->addItem('print_shipping_label', array(
                 'label'=> Mage::helper('sales')->__('Print Shipping Labels'),
                 'url'  => $this->getUrl('*/sales_order_shipment/massPrintShippingLabel'),
            ));
    
            return $this;
        }
    
        public function getRowUrl($row)
        {
            if (Mage::getSingleton('admin/session')->isAllowed('sales/order/actions/view')) {
                return $this->getUrl('*/sales_order/view', array('order_id' => $row->getId()));
            }
            return false;
        }
    
        public function getGridUrl()
        {
            return $this->getUrl('*/*/grid', array('_current'=>true));
        }
    
    }
    
    此函数是正确的,其中写入的查询也是正确的

    编辑的部分

    我还想在my grid.php中过滤曲目编号和标题。我试过一些东西

    这段代码放在grid.php中

    protected function spaceSeparatedFilter($collection, $column)
    {
        $value = $column->getFilter()->getValue();
        if (!$value) {
    
            return $this;
        }
        //if there was a space input
            else if(preg_match('/s+/', $value))
        {
            //explode by space, getting array of IDs
            $val = explode(" ", $value);
            //filter the collection, where collection index (order_id) is present in $val array
            $this->getCollection()->addAttributeToFilter($column->getData('index'), array('in'=>$val));
        }
        else
        {
        //else use default grid filter functionality (like $value input)
        $this->getCollection()->addAttributeToFilter($column->getData('index'), array('like' => '%'.$value.'%'));
        }
        return $this;
    }
    
    现在我在addcolumn中添加了过滤条件

    $this->addColumn('track_number', array(
                'header'=> Mage::helper('sales')->__(' Track Number'),
                'width' => '80px',
                'type'  => 'text',
                'index' => 'track_number',
                'filter_condition_callback' => array($this, 'spaceSeparatedFilter'),
                ));
    
            $this->addColumn('title', array(
                'header'=> Mage::helper('sales')->__('Title'),
                'width' => '80px',
                'index' => 'title',
                'filter_condition_callback' => array($this, 'spaceSeparatedFilter'),
                ));
    
    但我无法在销售/订单网格中进行筛选。请让我知道这个问题的解决方案


    谢谢和问候。

    首先,您没有使用好的方法重写Magento文件。看看这个:

    完成后,在Grid.php中

    protected function _prepareCollection() {
        $collection = Mage::getResourceModel ( $this->_getCollectionClass () );
        $collection->join(array('so'=>'sales/order'), 'main_table.entity_id=so.entity_id', array('your_coustom_field'=>'your_coustom_field', 'customer_email'=>'customer_email' ), null,'left');
        $this->setCollection ( $collection );
        return parent::_prepareCollection();
    }
    
    然后在_preparecocolumn方法中添加

    $this->addColumn ( 'customer_email', array (
        'header' => Mage::helper ( 'sales' )->__ ( 'customer email' ),
        'index' => 'customer_email'
    ) );
    

    如果在您的
    \u prepareCollection
    方法中,我通过以下方式打印查询:

    echo $collection->getSelect()->assemble();
    
    我明白了:

    SELECT 
        `main_table`.*, 
        group_concat(sales_flat_shipment_track.track_number SEPARATOR ",") AS `track_number`, 
        group_concat(sales_flat_shipment_track.title SEPARATOR ",") AS `title` 
    
    FROM `sales_flat_order_grid` AS `main_table` 
    
    INNER JOIN `sales_flat_shipment_track` 
        ON main_table.entity_id = sales_flat_shipment_track.order_id
    
    通过这个查询,我将始终得到一个结果,即使是在表上没有订单时的一个“空”行。相反,我认为您试图实现的目标可以通过使用子查询来实现:

    SELECT 
        `main_table`.*, 
        (
            SELECT 
                group_concat(`t`.`track_number` SEPARATOR ",") AS `track_number`
    
            FROM `sales_flat_shipment_track` AS `t`
    
            WHERE `main_table`.`entity_id` = `t`.`order_id`
        ),
        (
            SELECT 
                group_concat(`t`.`title` SEPARATOR ",") AS `title`
    
            FROM `sales_flat_shipment_track` as `t`
    
            WHERE `main_table`.`entity_id` = `t`.`order_id`
        )
    
    FROM `sales_flat_order_grid` AS `main_table`;
    
    因此,要将其转换为Magento,它将如下所示:

    protected function _prepareCollection()
    {
        $collection = Mage::getResourceModel('sales/order_grid_collection');
    
        $collection->getSelect()
            ->from(
                array(),
                array(
                    'track_number' => new Zend_Db_Expr('(
                        SELECT GROUP_CONCAT(`t`.`track_number` SEPARATOR ",")
                        FROM `sales_flat_shipment_track` as `t`
                        WHERE `main_table`.`entity_id` = `t`.`order_id`
                    )'),
                    'title' => new Zend_Db_Expr('(
                        SELECT GROUP_CONCAT(`t`.`title` SEPARATOR ",")
                        FROM `sales_flat_shipment_track` as `t`
                        WHERE `main_table`.`entity_id` = `t`.`order_id`
                    )'),
                )
            );
    
        $this->setCollection($this);
    
        return parent::_prepareCollection();
    }
    
    SELECT GROUP_CONCAT(DISTINCT `t`.`title` SEPARATOR ",")
    
    关于重复的运营商名称,这在这种情况下是意料之中的。唯一的解决方法是在标题的子查询中添加一个
    DISTINCT
    单词,如下所示:

    protected function _prepareCollection()
    {
        $collection = Mage::getResourceModel('sales/order_grid_collection');
    
        $collection->getSelect()
            ->from(
                array(),
                array(
                    'track_number' => new Zend_Db_Expr('(
                        SELECT GROUP_CONCAT(`t`.`track_number` SEPARATOR ",")
                        FROM `sales_flat_shipment_track` as `t`
                        WHERE `main_table`.`entity_id` = `t`.`order_id`
                    )'),
                    'title' => new Zend_Db_Expr('(
                        SELECT GROUP_CONCAT(`t`.`title` SEPARATOR ",")
                        FROM `sales_flat_shipment_track` as `t`
                        WHERE `main_table`.`entity_id` = `t`.`order_id`
                    )'),
                )
            );
    
        $this->setCollection($this);
    
        return parent::_prepareCollection();
    }
    
    SELECT GROUP_CONCAT(DISTINCT `t`.`title` SEPARATOR ",")
    

    但我不确定你打算如何处理网格中的这些数据。希望能有所帮助。

    你好,瑞克先生,谢谢你的回复。我对这两列的过滤有疑问。我想在我的管理网格中过滤曲目号、标题。我该怎么做呢???嘿@JayDesai,如果你想提出一个新问题,我会尝试在那里回答。然后在你的下一篇评论中提供一个链接。谢谢你好,先生。上面提供的链接是我的新问题。请帮帮我。