O que é reverseMetadataMerge nos componentes da interface do usuário?


Respostas:


10

A configuração mencionada é usada em vendor/magento/framework/View/Element/UiComponentFactory.php

 $reverseMerge = isset($componentArguments['data']['reverseMetadataMerge'])
            && $componentArguments['data']['reverseMetadataMerge'];
        $bundleComponents = $this->mergeMetadata($identifier, $bundleComponents, $reverseMerge);

isso mesclará os metadados já definidos vendor/magento/module-customer/view/base/ui_component/customer_form.xmlcom outros metadados definidos no construtor do provedor de dados.

protected function mergeMetadata($identifier, array $bundleComponents, $reverseMerge = false)
{
    $dataProvider = $this->getDataProvider($identifier, $bundleComponents);
    if ($dataProvider instanceof DataProviderInterface) {
        $metadata = [
            $identifier => [
                'children' => $dataProvider->getMeta(),
            ],
        ];
        $bundleComponents = $this->mergeMetadataItem($bundleComponents, $metadata, $reverseMerge);
    }

    return $bundleComponents;
}

No caso da documentação, seu provedor de dados é vendor/magento/module-customer/Model/Customer/DataProvider.phpque dentro do construtor há

 $this->meta['customer']['children'] = $this->getAttributesMeta(
        $this->eavConfig->getEntityType('customer')
    );
    $this->meta['address']['children'] = $this->getAttributesMeta(
        $this->eavConfig->getEntityType('customer_address')
    );

que adiciona alguns outros atributos. No caso do cliente, os atributos são os mostrados em azul na imagem a seguir

atributos adicionados pelo cliente

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.