我要求呼叫中心代理根据电子邮件地址搜索客户.但我不想在客户网格中显示电子邮件地址,除非他们搜索电子邮件.
I have a requirement for call centre agents to search for a customer based on email address. But I don't want to show the email address in the customer grid unless they search for a email.
我该怎么做??
Magento 版本:1.4.1.1
Magento Version: 1.4.1.1
提前致谢.
编写一个扩展的自定义模块:
Write a custom module that extend:
/app/code/core/Mage/Adminhtml/Block/Customer/Grid.php
阅读更多@如何从 eav_attribute 表中获取实体(例如客户)的数据以显示在客户网格中以供管理员使用(删除带有 sales_order_grid 的行)
Read more @ How to get data for an entity (for example customer) from eav_attribute table to be shown in Customer Grid for admin (remove line with sales_order_grid)
将 '_prepareColumns()' 方法复制到您的自定义模块并进行更改
Copy '_prepareColumns()' method to your custom module and change
$this->addColumn('email', array(
'header' => Mage::helper('customer')->__('Email'),
'width' => '150',
'index' => 'email'
'renderer' = new MageIgniter_MaskEmail_Block_Adminhtml_Renderer_Data() // added this line
));
阅读更多@http://www.magentocommerce.com/boards/viewthread/192232/#t239222
创建类:
class MageIgniter_MaskEmail_Block_Adminhtml_Renderer_Data extends Mage_Adminhtml_Block_Widget_Grid_Column_Renderer_Action
{
public function render(Varien_Object $row)
{
return $this->_getValue($row);
}
public function _getValue(Varien_Object $row)
{
$val = $row->getData($this->getColumn()->getIndex()); // row value
$search_filter = base64_decode($this->getRequest()->getParam('filter'));
// print_r($search_filter) : email=rs%40cs.com&customer_since%5Blocale%5D=en_US
//read more @ http://inchoo.net/ecommerce/magento/what-is-base64-encoding-and-how-can-we-benefit-from-it/
// check if $search_filter contain email and equal to the search email
parse_str($search_filter, $query)
if(isset($query['email'] && $val == $query['email']){ // or array_key_exist()
return $val;
}
else{
return 'xxxxxxxx';
}
}
}
这是基于 Magento v1.7
This is base off Magento v1.7
这篇关于Magento 客户网格 - 屏蔽电子邮件地址的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
在 SELECT(MYSQL/PHP) 中加入 2 个表Joining 2 tables in SELECT(MYSQL/PHP)(在 SELECT(MYSQL/PHP) 中加入 2 个表)
如何使<option selected=“selected">由How to make lt;option selected=quot;selectedquot;gt; set by MySQL and PHP?(如何使lt;option selected=“selectedgt;由 MySQL 和 PHP 设置?)
使用 PHP 中的数组自动填充选择框Auto populate a select box using an array in PHP(使用 PHP 中的数组自动填充选择框)
PHP SQL SELECT where like search item with multiple wordsPHP SQL SELECT where like search item with multiple words(PHP SQL SELECT where like search item with multiple words)
json_encode 从 MSSQL-SELECT 产生 JSON_ERROR_UTF8json_encode produce JSON_ERROR_UTF8 from MSSQL-SELECT(json_encode 从 MSSQL-SELECT 产生 JSON_ERROR_UTF8)
MySQL ORDER BY rand(),名称 ASCMySQL ORDER BY rand(), name ASC(MySQL ORDER BY rand(),名称 ASC)