繁体   English   中英

如何“覆盖” Magento中的字段集?

[英]How to 'override' a fieldset in magento?

我刚刚在magento的注册表中添加了第二个姓氏字段,并修改了Mage_Customer_Model_Customer getName方法,以便在打印名称的所有地方都包含第二个名字。 它可以在除管理员客户列表之外的任何地方使用,该列表从Mage_Customer的config.xml中读取Mage_Customer 我的问题是,如何从自定义模块中“覆盖”该字段集?

作为记录,我已经尝试将fieldset标签放在config.xml中,但没有运气。

大卫,您可以覆盖/修改网格app \\ code \\ core \\ Mage \\ Adminhtml \\ Block \\ Customer \\ Grid.php并修改_prepareCollection以将您的字段包括在集合中,并使用addColumn方法显示第二个名字。

解决了! 将整个内容Mage_Customer_Model_Resource_Customer_Collection ,其中存在一个名为addNameToSelect()的方法,该方法实际上将整个名称(前缀,第一名,中间名,姓氏,后缀)连接在一起,所以我最后要做的是重写此特定方法并添加第二个姓氏那里。

代码如下:

/**
 * Add Name to select
 *
 * @return Mage_Customer_Model_Resource_Customer_Collection
 */
public function addNameToSelect()
{
    $fields = array();
    $customerAccount = Mage::getConfig()->getFieldset('customer_account');
    foreach ($customerAccount as $code => $node) {
        if ($node->is('name')) {
            $fields[$code] = $code;
        }
    }

    $adapter = $this->getConnection();
    $concatenate = array();
    if (isset($fields['prefix'])) {
        $concatenate[] = $adapter->getCheckSql(
            '{{prefix}} IS NOT NULL AND {{prefix}} != \'\'',
            $adapter->getConcatSql(array('LTRIM(RTRIM({{prefix}}))', '\' \'')),
            '\'\'');
    }
    $concatenate[] = 'LTRIM(RTRIM({{firstname}}))';
    $concatenate[] = '\' \'';
    if (isset($fields['middlename'])) {
        $concatenate[] = $adapter->getCheckSql(
            '{{middlename}} IS NOT NULL AND {{middlename}} != \'\'',
            $adapter->getConcatSql(array('LTRIM(RTRIM({{middlename}}))', '\' \'')),
            '\'\'');
    }
    $concatenate[] = 'LTRIM(RTRIM({{lastname}}))';

    //HERE I ADDED THE SECOND LAST NAME
    if (isset($fields['lastname2'])) {
        $concatenate[] = $adapter->getCheckSql(
            '{{lastname2}} IS NOT NULL AND {{lastname2}} != \'\'',
            $adapter->getConcatSql(array('\' \'','LTRIM(RTRIM({{lastname2}}))', '\' \'')),
            '\'\'');
    }


    if (isset($fields['suffix'])) {
        $concatenate[] = $adapter
                ->getCheckSql('{{suffix}} IS NOT NULL AND {{suffix}} != \'\'',
            $adapter->getConcatSql(array('\' \'', 'LTRIM(RTRIM({{suffix}}))')),
            '\'\'');
    }

    $nameExpr = $adapter->getConcatSql($concatenate);

    $this->addExpressionAttributeToSelect('name', $nameExpr, $fields);

    return $this;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM