如何在洋红色中“覆盖”字段集


How to 'override' a fieldset in magento?

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

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

David,

您可以覆盖/修改网格应用程序''代码''核心''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;
}