Добавление пользовательского столбца в customer_entity

Я пытаюсь добавить пользовательский столбец в customer_entity, который должен редактироваться в форме клиента в бэкэнде.

Я могу добавить столбец в таблицу базы данных с помощью скрипта UpdateSchema в моем модуле.

Но как я могу заполнить его в форме клиента и в сетке?

Что я пробовал до сих пор:

  • Я добавил атрибут с тем же именем (= имя столбца) с помощью UpdateDataScript, $ customerSetup-> addAttribute ()...
  • Customer_grid_flat корректно обновляется при сохранении пользователя, но значение в таблице customer_entity не изменилось. Он сохраняет свои значения в таблице атрибутов (customer_entity_varchar).

Как правильно настроить пользовательский столбец, чтобы его значение сохранялось в "customer_entity", а не в "customer_entity_varchar"?

1 ответ

Решение

Решение: Мой пользовательский атрибут теперь правильно сохраняется в таблице customer_entity.

UpgradeSchema.php

<?php

namespace Custom\MyModule\Setup;

use Magento\Framework\Setup\UpgradeSchemaInterface;
use Magento\Framework\Setup\ModuleContextInterface;
use Magento\Framework\Setup\SchemaSetupInterface;

class UpgradeSchema implements UpgradeSchemaInterface
{
    const CUSTOM_ATTRIBUTE_ID = 'custom_attribute';
    /**
     * @param SchemaSetupInterface $setup
     * @param ModuleContextInterface $context
     */
    public function upgrade(SchemaSetupInterface $setup, ModuleContextInterface $context)
    {
        $setup->startSetup();

        if (version_compare($context->getVersion(), '0.0.3', '<')) {
            $setup->getConnection()->addColumn(
                $setup->getTable('customer_entity'),
                self::CUSTOM_ATTRIBUTE_ID,
                [
                    'type' => \Magento\Framework\DB\Ddl\Table::TYPE_TEXT,
                    'nullable' => true,
                    'default' => null,
                    'comment' => 'Custom Attribute'
                ]
            );
        }

        $setup->endSetup();


    }
}

UpgradeData.php

<?php

namespace Custom\MyModule\Setup;

use Magento\Customer\Model\Customer;
use Magento\Customer\Setup\CustomerSetupFactory;
use Magento\Eav\Setup\EavSetupFactory;
use Magento\Framework\Indexer\IndexerRegistry;
use Magento\Framework\Setup\UpgradeDataInterface;
use Magento\Framework\Setup\ModuleContextInterface;
use Magento\Framework\Setup\ModuleDataSetupInterface;
use Magento\TestFramework\Helper\Eav;

class UpgradeData implements UpgradeDataInterface
{
    /**
     * @var CustomerSetupFactory
     */
    private $customerSetupFactory;

    /**
     * @var IndexerRegistry
     */
    protected $indexerRegistry;

    /**
     * @var \Magento\Eav\Model\Config
     */
    protected $eavConfig;

    /**
     * @var \Magento\Eav\Model\Setup
     */
    protected $eavSetupFactory;

    /**
     * @param CustomerSetupFactory $customerSetupFactory
     * @param IndexerRegistry $indexerRegistry
     * @param \Magento\Eav\Model\Config $eavConfig
     */
    public function __construct(
        CustomerSetupFactory $customerSetupFactory,
        IndexerRegistry $indexerRegistry,
        \Magento\Eav\Model\Config $eavConfig,
        EavSetupFactory $eavSetupFactory
    )
    {
        $this->customerSetupFactory = $customerSetupFactory;
        $this->indexerRegistry = $indexerRegistry;
        $this->eavConfig = $eavConfig;
        $this->eavSetupFactory = $eavSetupFactory;
    }

    /**
     * Upgrades data for a module
     *
     * @param ModuleDataSetupInterface $setup
     * @param ModuleContextInterface $context
     * @return void
     */
    public function upgrade(ModuleDataSetupInterface $setup, ModuleContextInterface $context)
    {
        $dbVersion = $context->getVersion();

        if (version_compare($dbVersion, '0.0.3', '<')) {

            $customerSetup = $this->customerSetupFactory->create(['setup' => $setup]);

            $customerSetup->addAttribute(
                'customer',
                UpgradeSchema::CUSTOM_ATTRIBUTE_CODE,
                [
                    'label' => 'Custom Attribute',
                    'required' => 0,
                    'visible' => 1, //<-- important, to display the attribute in customer edit
                    'input' => 'text',
                    'type' => 'static',
                    'system' => 0, // <-- important, to have the value be saved
                    'position' => 40,
                    'sort_order' => 40
                ]
            );

            /** @var  EavSetupFactory $eavSetup */
            $eavSetup = $this->eavSetupFactory->create(['setup' => $setup]);
            $typeId = $eavSetup->getEntityTypeId('customer');

            $attribute = $eavSetup->getAttribute($typeId, UpgradeSchema::CUSTOM_ATTRIBUTE_ID);

            $customerSetup->getSetup()->getConnection()->insertMultiple(
                $customerSetup->getSetup()->getTable('customer_form_attribute'),
                array('form_code' => 'adminhtml_customer', 'attribute_id' => $attribute['attribute_id'])
            );

            $setup->endSetup();
        }
    }
}
Другие вопросы по тегам