Obtenha o texto do atributo em vez do ID na grade personalizada do cliente
-
12-12-2019 - |
Pergunta
Quero mostrar um atributo personalizado de um cliente na grade de clientes adminhtml.Consegui fazer isso criando um novo módulo e estendendo o setCollection
método de Mage_Adminhtml_Block_Customer_Grid
public function setCollection($collection)
{
$collection->addAttributeToSelect('x_customer_category');
parent::setCollection($collection);
}
E adiciono a coluna via observador à view
/**
* Adds column to admin customers grid
*
* @param Varien_Event_Observer $observer
*
* @return Mscg_TemplateOverwrite_Model_Customer_Observer
*/
public function addCustomerGroupToGrid(Varien_Event_Observer $observer)
{
$block = $observer->getBlock();
if (!isset($block)) {
return $this;
}
if ($block->getType() == 'adminhtml/customer_grid') {
/* @var $block Mage_Adminhtml_Block_Customer_Grid */
$block->addColumnAfter('x_customer_category', array(
'header' => 'x_customer_category',
'type' => 'text',
'index' => 'x_customer_category',
), 'email');
}
}
No entanto, como este é um atributo opcional, obtenho apenas o ID do valor selecionado para o cliente, mas quero o valor do texto, não o valor da entidade de determinado atributo.
Como eu posso fazer isso?
Solução
Você precisa alterar o tipo de coluna de text
para options
e adicione um options
elemento que contém seus valores neste formato key => value
.
Algo assim:
$block->addColumnAfter('x_customer_category', array(
'header' => 'x_customer_category',
'type' => 'options',
'index' => 'x_customer_category',
'options' => array(
'id1' => 'label 1',
'id2' => 'label 2',
),
), 'email');
Se os valores possíveis forem dinâmicos você deve primeiro construir um array com todos os valores.Você deve saber uma maneira de recuperar todos os valores possíveis e apenas atribuir o array obtido ao options
elemento.
Se o seu atributo for um atributo de seleção padrão, você poderá construí-lo assim:
$attribute = Mage::getModel('eav/config')->getAttribute('customer', 'x_customer_category');
$options = $attribute->getSource()->getAllOptions(false);
$values = array();
foreach ($options as $option){
$values[$option['value']] = $option['label'];
}
Em seguida, adicione sua coluna assim:
$block->addColumnAfter('x_customer_category', array(
'header' => 'x_customer_category',
'type' => 'options',
'index' => 'x_customer_category',
'options' => $values,
), 'email');