Добавление атрибутов в сущность customer
моя текущая цель-Добавить новый атрибут клиента (с int
type), который должен отображаться как select с предопределенными параметрами (загружается из модели с записями, редактируемыми в бэкэнде, что делается).
Я борюсь с правильным использованием $installer->addAttribute()
метод, особенно указывающий правильный параметр источника. Другая проблема-это новый атрибут не сохраняется в eav_entity_attribute таблице
Я на Magento CE 1.5.1.0
4 ответов
это код для базового С text
рендерер:
$installer = $this;
$installer->startSetup();
$setup = new Mage_Eav_Model_Entity_Setup('core_setup');
$setup->addAttribute('customer', 'your_attribute_code_here', array(
'input' => 'text',
'type' => 'int',
'label' => 'Some textual description',
'visible' => 1,
'required' => 0,
'user_defined' => 1,
));
$entityTypeId = $setup->getEntityTypeId('customer');
$attributeSetId = $setup->getDefaultAttributeSetId($entityTypeId);
$attributeGroupId = $setup->getDefaultAttributeGroupId($entityTypeId, $attributeSetId);
$setup->addAttributeToGroup(
$entityTypeId,
$attributeSetId,
$attributeGroupId,
'your_attribute_code_here',
'999' //sort_order
);
$oAttribute = Mage::getSingleton('eav/config')->getAttribute('customer', 'your_attribute_code_here');
$oAttribute->setData('used_in_forms', array('adminhtml_customer'));
$oAttribute->save();
$setup->endSetup();
необычным шагом для добавления атрибутов является setData('used_in_forms')
это кажется уникальным для атрибутов клиента. Без него поле не будет отображаться, во всяком случае, не в adminhtml. Вы можете увидеть допустимые параметры для этого массива в customer_form_attribute
таблицы базы данных.
С точки зрения использования select
с предопределенными параметрами, это то, что вам нужно:
$iAttributeId = $installer->getAttributeId($entityTypeId, 'your_attribute_code_here');
$aClasses = array('TV','DVD','Home Theatre','Air Conditioner','Stereo/Hifi','Game Console','Camcorder','VCR','Set Top Box','PVR');
$aOption = array();
$aOption['attribute_id'] = $iAttributeId;
for($iCount=0;$iCount<sizeof($aClasses);$iCount++){
$aOption['value']['option'.$iCount][0] = $aClasses[$iCount];
}
$setup->addAttributeOption($aOption);
и вот это walk-through при использовании пользовательского источника для раскрывающегося списка
надеюсь, это поможет,
JD
@Джонатан Деньответ велик и очень помог мне. Однако-до тех пор, пока вы установили свой setup
класс Mage_Customer_Model_Entity_Setup
, тогда Magento может сделать всю эту работу за вас:
<!-- config.xml Example -->
<?xml version="1.0"?>
<config>
<global>
<resources>
<acme_module_setup>
<setup>
<module>Acme_Module</module>
<class>Mage_Customer_Model_Entity_Setup</class>
</setup>
<connection>
<use>core_setup</use>
</connection>
</acme_module_setup>
</resources>
</global>
</config>
и вот это :
<?php
$installer = $this;
/* @var $installer Mage_Customer_Model_Entity_Setup */
$installer->startSetup();
$installer->addAttribute(
'customer',
'acme_imported',
array(
'group' => 'Default',
'type' => 'int',
'label' => 'Imported into Acme',
'input' => 'select',
'source' => 'eav/entity_attribute_source_boolean',
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_STORE,
'required' => 0,
'default' => 0,
'visible_on_front' => 1,
'used_for_price_rules' => 0,
'adminhtml_only' => 1,
)
);
$installer->endSetup();
на adminhtml_only
выше будет обрабатывать все used_in_forms
логика для вас. Кроме того, определение group
позаботится о присвоении его группе атрибутов.
просто вы должны добавить свой атрибут клиента под вашим настраиваемым файлом установки mysql модуля через следующий скрипт.
$installer = $this;
$installer->startSetup();
$installer->addAttribute("customer", "yourattributename", array(
"type" => "int",
"backend" => "",
"label" => "Bad Customer",
"input" => "select",
"source" => "eav/entity_attribute_source_boolean",
"visible" => true,
"required" => false,
"default" => "",
"frontend" => "",
"unique" => false,
"note" => ""
));
$attribute = Mage::getSingleton("eav/config")->getAttribute("customer", "yourattributename");
следующий скрипт, используемый для where want to use customer attribute
$used_in_forms=array();
$used_in_forms[]="adminhtml_customer";
$attribute->setData("used_in_forms", $used_in_forms)
->setData("is_used_for_customer_segment", true)
->setData("is_system", 0)
->setData("is_user_defined", 1)
->setData("is_visible", 0)
->setData("sort_order", 100)
;
$attribute->save();
$installer->endSetup();
решение предоставить Алекс и лука-порея оба работали для меня. Только мне нужно добавить функцию setter в наш AccountController.в PHP
$customer->setProfession($this->getRequest()->getPost('profession'))
->save(); // Added for updating Profession
где "профессия" была моим пользовательским атрибутом.