Che cos'è reverseMetadataMerge nei componenti dell'interfaccia utente?


Risposte:


10

L'impostazione menzionata viene utilizzata in vendor/magento/framework/View/Element/UiComponentFactory.php

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

questo unirà i metadati già definiti nel vendor/magento/module-customer/view/base/ui_component/customer_form.xmlcon alcuni altri metadati definiti nel costruttore del fornitore di dati.

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

Nel caso della documentazione il tuo fornitore di dati è vendor/magento/module-customer/Model/Customer/DataProvider.phpquello all'interno del costruttore

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

che aggiunge altri attributi. Nel caso del cliente gli attributi sono quelli mostrati in blu nella seguente immagine

attributi aggiunti dal cliente

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.