0

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

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

4

2 回答 2

0

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

于 2013-10-28T13:47:39.303 回答
0

解决了!将整个事情追踪到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;
}
于 2013-11-01T05:17:57.357 回答