Magento2 envoie l'ID d'insertionListing to grid


8

Comment puis-je envoyer un identifiant de mon formulaire à une grille de liste d'insertion?

Ce que je veux faire, c'est dans ma forme, je charge une grille avec insert Listing.

Dans cette grille, je veux tous les résultats avec l'id du formulaire.

<insertListing name="insertlisting_colors_one">
        <argument name="data" xsi:type="array">
            <item name="config" xsi:type="array">
                <item name="autoRender" xsi:type="boolean">true</item>
                <item name="imports" xsi:type="array">
                    <item name="spd_id" xsi:type="string">${ $.provider }:data.spd_id</item>
                </item>
                <item name="ns" xsi:type="string">colors_one_grid</item>
            </item>
        </argument>
    </insertListing>

Ci-dessous le code dans la grille

<item name="filter_url_params" xsi:type="array">
                    <item name="color_amount" xsi:type="string">1</item>

                    <item name="spd_id" xsi:type="string">${ $.parentName }.spd_id</item>
                </item>

1
Avez-vous une solution pour cela ... ou quelqu'un d'autre .. Je suis également confronté au même problème ... n'importe qui peut aider?
Ashish Raj

Réponses:


1

Pour ajouter une liste d'insertions par paramètre du composant ui parent, nous pouvons utiliser le code ci-dessous.

Ici, la externalProviderbalise est pour ajouter le fournisseur source de la liste que nous insérons.

Ici, la importsbalise est utilisée pour importer les paramètres de la source de données du formulaire actuel

Ici, la exportsbalise est utilisée pour exporter les paramètres de données de formulaire actuels vers la liste qui va être insérée.

<insertListing name="insertlisting_colors_one">
    <argument name="data" xsi:type="array">
        <item name="config" xsi:type="array">
            <item name="autoRender" xsi:type="boolean">true</item>
            <item name="ns" xsi:type="string">colors_one_grid</item>
            <item name="externalProvider" xsi:type="string">colors_one_listing.colors_one_listing_data_source</item><!-- your insert listing data provider source -->
            <item name="imports" xsi:type="array">
                <item name="spd_id" xsi:type="string">${ $.provider }:data.spd_id</item>
            </item>
            <item name="exports" xsi:type="array">
                <item name="spd_id" xsi:type="string">${ $.externalProvider }:params.spd_id</item>
            </item>
        </item>
    </argument>
</insertListing>

Ajoutez la jointure avec la colonne appropriée à la collection actuelle pour l'utiliser dans le filtre du fournisseur de données de la liste insérée.

Dans le fournisseur de données, ajoutez un filtre pour ce paramètre:

$collection->addFieldToFilter('spd_id', $this->request->getParam('spd_id'));

J'ai essayé votre exemple, mais cela ne fonctionne pas. Savez-vous pourquoi je n'obtiens pas l'ID parent au fournisseur de réseau?
Deep Joshi

0

Vous devez définir une valeur pour le paramètre render_url sur la insertListing , puis mettre à jour cette URL à l'intérieur de votre fournisseur de données. Il est nécessaire d'effectuer cette action deux fois car vous devrez avoir un fournisseur de données pour votre composant de formulaire et un autre spécifique pour le composant de liste.

1 - Déclaration correcte du composant insertListing: (Vendor / Module / view / adminhtml / ui_component / vendor_module_form.xml)

<insertListing name="testInsertListing">
        <argument name="data" xsi:type="array">
            <item name="config" xsi:type="array">
                <item name="dataLinks" xsi:type="array">
                    <item name="imports" xsi:type="boolean">false</item>
                    <item name="exports" xsi:type="boolean">true</item>
                </item>
                <item name="autoRender" xsi:type="boolean">true</item>
                <!-- the namespace attribute should be the name of the listing XML file -->
                <item name="ns" xsi:type="string">vendor_module_listing</item>
                <!-- This is the default render_url. We are going to update this value
                    in the DataProvider -->
                <item name="render_url" xsi:type="url" path="mui/index/render"/>
                <!-- Here we add the parameters that we want to add to the render_url. -->
                <item name="filter_url_params" xsi:type="array">
                    <!-- You can add as many as you want -->
                    <item name="id" xsi:type="string">*</item>
                </item>
                <item name="storageConfig" xsi:type="array">
                    <item name="indexField" xsi:type="string">id</item>
                </item>
            </item>
        </argument>
    </insertListing>

2 - Ajoutez les modifications suivantes au fournisseur de données de la page Formulaire. Cela changera le render_url en ajoutant le paramètre "id" à la fin de l'URL:

(Vendeur / Module / Ui / DataProvider / [chemin d'accès à votre fournisseur de données.php] )

  • Ajoutez la classe RequestInterface:
  • Déclarez l'attribut $ request sur votre classe Data Provider.
  • Ajoutez un objet RequestInterface à la méthode __construct; appelez la méthode prepareUpdateUrl ().
  • Ajoutez prepareUpdateUrl () à votre classe:

Remarque: ne copiez / collez pas le bloc entier ci-dessous sur votre fournisseur de données. Au lieu de cela, choisissez les éléments manquants dans votre code

<?php use Magento\Framework\App\RequestInterface;
use Magento\Framework\UrlInterface;

class MyListingDataProvider extends AbstractDataProvider
{
    protected $data;
    protected $meta;
    protected $collection;
    protected $urlBuilder;

    public function __construct(
        string $name,
        string $primaryFieldName,
        string $requestFieldName,
        Collection $collection,
        RequestInterface $request,
        UrlInterface $urlBuilder,
        array $meta = [],
        array $data = []
    )
    {
        $this->collection = $collection;
        $this->data = $data;
        $this->meta = $meta;
        $this->request = $request;
        $this->urlBuilder = $urlBuilder;

        $this->prepareUpdateUrl();

        parent::__construct($name, $primaryFieldName, $requestFieldName, $this->meta, $data);
    }

    protected function prepareUpdateUrl()
    {
        $id = $this->request->getParam('id');

        $this->meta = array_replace_recursive(
            $this->meta,
            [
                'testInsertListing' =>
                    ['arguments' => [
                        'data' => [
                            'config' => [
                                'render_url' => $this->urlBuilder
                                    ->getUrl('mui/index/render/id/' . $id),
                                'update_url' => $this->urlBuilder->getUrl('mui/index/render/id/' . $id)
                            ]
                        ],
                    ]
                ]
            ]
        );
    }

    //Implement the other methods you need
}

3 - Mettez à jour votre composant d'annonce. Il doit avoir un paramètre updateUrl à l'intérieur du composant DataSource:

(Vendeur / Module / view / adminhtml / ui_component / vendor_module_listing.xml)

<?xml version="1.0" encoding="UTF-8"?>
<listing xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Ui:etc/ui_configuration.xsd">
    <argument name="data" xsi:type="array">
        <item name="js_config" xsi:type="array">
            <item name="provider" xsi:type="string">
                vendor_module_listing.module_listing_data_source
            </item>
        </item>
    </argument>
    <settings>
        <spinner>vendor_module_listing_columns</spinner>
        <deps>
            <dep>vendor_module_listing.module_listing_data_source</dep>
        </deps>
    </settings>
    <dataSource name="module_listing_data_source">
        <argument name="dataProvider" xsi:type="configurableObject">
            <argument name="class" xsi:type="string">Vendor\Module\Ui\DataProvider\[name-of-your-listing-data-provider-class]</argument>
            <argument name="name" xsi:type="string">module_listing_data_source</argument>
            <argument name="primaryFieldName" xsi:type="string">id</argument>
            <argument name="requestFieldName" xsi:type="string">id</argument>
            <argument name="data" xsi:type="array">
                <item name="config" xsi:type="array">
                    <item name="component" xsi:type="string">Magento_Ui/js/grid/provider</item>
                    <item name="update_url" xsi:type="url" path="mui/index/render"/>
                    <item name="storageConfig" xsi:type="array">
                        <item name="indexField" xsi:type="string">id</item>
                    </item>
                    <!-- fields to be added to the URL when retrieving the data -->
                    <item name="filter_url_params" xsi:type="array">
                        <item name="id" xsi:type="string">*</item>
                    </item>
                </item>
            </argument>
        </argument>
    </dataSource>
    <columns name="vendor_module_listing_columns">

        <!-- Declare your columns here -->

    </columns>
</listing>

4 - Mettez à jour votre fournisseur de données de référencement pour modifier la updateUrl sur le composant de référencement ci-dessus

(Fournisseur / Module / Ui / DataProvider / [chemin-vers-votre-LISTING-data-provider.php] )

Remarque: ne copiez / collez pas le bloc entier ci-dessous sur votre fournisseur de données. Au lieu de cela, choisissez les éléments manquants dans votre code

 <?php

    use Magento\Framework\App\RequestInterface;

    class MyListingDataProvider extends AbstractDataProvider
    {
        protected $request; 

        public function __construct(
            string $name,
            string $primaryFieldName,
            string $requestFieldName,
            Collection $collection,
            RequestInterface $request,
            array $meta = [],
            array $data = []
        )
        {
            $this->collection = $collection;
            $this->request = $request;
            $this->data = $data;

            parent::__construct($name, $primaryFieldName, $requestFieldName, $meta, $data);

            $this->prepareUpdateUrl();
        }

        protected function prepareUpdateUrl()
        {
            if (!isset($this->data['config']['filter_url_params'])) {
                return;
            }

            foreach ($this->data['config']['filter_url_params']
                     as $paramName => $paramValue) {
                if ('*' == $paramValue) {
                    $paramValue = $this->request->getParam($paramName);
                }
                if ($paramValue) {
                    $this->data['config']['update_url'] = sprintf(
                        '%s%s/%s/',
                        $this->data['config']['update_url'],
                        $paramName,
                        $paramValue
                    );
                }
            }
        }

         //Get the parameter "id" inside of the getData() method:

        public function getData()
        {
        $item_id = $this->request->getParam('id');

        //Apply a filter to your collection using $item_id

        /**
        Return your data in the appropriate format
        $totalRecords should be an integer
        $items should be an array
        */
        return array('totalRecords' => $totalRecords, 'items' => $items);

        }

    }

Faites-moi savoir si vous avez encore des problèmes. Je ne pourrai peut-être pas répondre aux commentaires, mais je peux mettre à jour ma réponse.

En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.