select / dropdown属性をカテゴリに追加し、それをバックエンドに表示して、ストアの所有者が選択できるようにします。いくつかの調査の後、私は次のことを行うことがわかりました:
- Setupscriptを介して属性を作成する
- UIコンポーネント宣言を介してそれを含める
だからこれは私がやったことです:
public function install(ModuleDataSetupInterface $setup, ModuleContextInterface $context)
{
/** @var $eavSetup \Magento\Eav\Setup\EavSetup */
$eavSetup = $this->eavSetupFactory->create(['setup' => $setup]);
$eavSetup->addAttribute(
\Magento\Catalog\Model\Category::ENTITY,
'attribute_code',
[
'type' => 'int',
'label' => 'Top Navigation CMS Block',
'input' => 'select',
'source' => 'Magento\Catalog\Model\Category\Attribute\Source\Page',
'required' => false,
'sort_order' => 10,
'global' => \Magento\Eav\Model\Entity\Attribute\ScopedAttributeInterface::SCOPE_STORE,
'group' => 'MyOwnGroup'
]
);
}
view / adminhtml / ui_component / category_form.xml:
<?xml version="1.0" encoding="UTF-8"?>
<form xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Ui:etc/ui_configuration.xsd">
<fieldset name="content">
<field name="attribute_code">
<argument name="data" xsi:type="array">
<item name="config" xsi:type="array">
<item name="sortOrder" xsi:type="number">61</item>
<item name="dataType" xsi:type="string">string</item>
<item name="formElement" xsi:type="string">select</item>
<item name="label" xsi:type="string" translate="true">Top Navigation CMS Block</item>
</item>
</argument>
</field>
</fieldset>
</form>
しかし、それだけでは十分ではなく、バックエンドでのタブのソートが混同されています。ドロップダウンもレンダリングされますが、オプションはありません。だから私もあなたが編集する必要があることがわかりましたMagento\Catalog\Model\Category\DataProvider::getFieldsMap()
。これを行うには、di.xmlで上書きする必要があります。
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
<preference for="Magento\Catalog\Model\Category\DataProvider" type="Vendor\Module\Model\Category\DataProvider" />
</config>
モジュール自体のデータプロバイダーでは、関数に属性を追加する必要があります。そして、それは機能します。
だからここに私の質問があります:
- 私はあなたが本当にそれを機能させるためにこのデータプロバイダーを上書きする必要があるとは思いません、もっと良い方法があるはずです
- コード内に新しい属性を宣言する必要がある場所が3つあります(セットアップスクリプト、UIコンポーネント、データプロバイダー)。これだけのオーバーヘッドが必要だとは思えません。
- 属性に冗長な情報があるのはなぜですか?たとえば、ラベルはセットアップスクリプトとuiコンポーネント内にあり、バックエンドのラベルはuiコンポーネント宣言から読み取られます。
私はすでにドロップダウンタイプのカテゴリ属性を作成しています。DataProviderを上書きする必要はありません。
—
Dhiren Vasoya 2017年
ソリューションを投稿できますか?
—
テスター
回答を投稿しますので、ご確認ください。
—
Dhiren Vasoya 2017年