Co to jest reverseMetadataMerge w składnikach interfejsu użytkownika?


Odpowiedzi:


11

Wspomniane ustawienie jest używane w vendor/magento/framework/View/Element/UiComponentFactory.php

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

spowoduje to scalenie już zdefiniowanych metadanych vendor/magento/module-customer/view/base/ui_component/customer_form.xmlz innymi metadanymi zdefiniowanymi w konstruktorze dostawcy danych.

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;
}

W przypadku dokumentacji twoim dostawcą danych jest vendor/magento/module-customer/Model/Customer/DataProvider.phpten wewnątrz konstruktora

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

który dodaje kilka innych atrybutów. W przypadku klienta są to atrybuty pokazane na niebiesko na poniższym obrazku

dodane przez klienta atrybuty

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.