我刚刚在magento的注册表单中添加了第二个姓氏字段,并从Mage_Customer_Model_Customer
修改了方法getName,以便在名称打印的任何地方都包含第二个名称。除了管理客户列表之外,它可以在任何地方工作,其中从Mage_Customer
的config.xml读取字段集。我的问题是,如何从我的自定义模块中“覆盖”该字段集?
为了记录,我已经尝试将fieldset
标记放在我的config.xml中而没有运气。
答案 0 :(得分:0)
David,您可以覆盖/修改网格app \ code \ core \ Mage \ Adminhtml \ Block \ Customer \ Grid.php并修改_prepareCollection以将您的字段包含在集合中,并使用addColumn方法显示secondlast名称。
答案 1 :(得分: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;
}