Magento 2.1 dodaje nowy problem typu komponentu

16

Dodałem nowy typ elementu formularza o nazwie Company\Module\Data\Form\Element\PdfButton, gdy jest, version EE 2.0.7i użyłem tego elementu na karcie niestandardowej (dodanej przez przesłonięcie Magento\Catalog\Block\Adminhtml\Product\Edit\Tabs) strony administratora edycji produktu.

Po aktualizacji do Magento EE 2.1 karta niestandardowa zniknęła. Aby się pojawił, dodałem modyfikator, aby utworzyć nową kartę na stronie produktu. Z powodzeniem dodałem nową kartę, kopiując modyfikator do pliku dostawcy i wstrzykując go do mojego modułu.

Ale kiedy chcę użyć mojego niestandardowego elementu. Tak więc w polu potomnym meta-tablicy dodałem następujący kod:

$children[$website['id']] = [
                'arguments' => [
                    'data' => [
                        'config' => [
                            'dataType' => Form\Element\DataType\Number::NAME,
                            'componentType' => Form\Field::NAME,
                            'formElement' => Form\Element\Wysiwyg2::NAME,
                            'description' => __($website['name']),
                            'tooltip' => $tooltip,
                            'sortOrder' => $sortOrder,
                            'dataScope' => 'website_ids.' . $website['id'],
                            'label' => "Pdf Upload",
                            'valueMap' => [
                                'true' => (string)$website['id'],
                                'false' => '0',
                            ],
                            'value' => $isChecked ? (string)$website['id'] : '0',
                        ],
                    ],
                ],
            ];

po tym skopiowałem Form\Element\Wysiwygi wkleiłem jako Form\Element\Wysiwyg2. W klasie Wysiwyg2 :

<?php

/**
 * Copyright © 2016 Magento. All rights reserved.
 * See COPYING.txt for license details.
 */
namespace Magento\Ui\Component\Form\Element;

use Magento\Framework\Data\Form\Element\Editor;
use Magento\Framework\Data\Form;
use Magento\Framework\Data\FormFactory;
use Magento\Framework\DataObject;
use Magento\Framework\View\Element\UiComponent\ContextInterface;
use Magento\Ui\Component\Wysiwyg\ConfigInterface;

/**
 * Class Input
 */
class Wysiwyg2 extends AbstractElement
{
    const NAME = 'wysiwyg2';

    /**
     * @var Form
     */
    protected $form;

    /**
     * @var Editor
     */
    protected $editor;

    /**
     * @param ContextInterface $context
     * @param FormFactory $formFactory
     * @param ConfigInterface $wysiwygConfig
     * @param array $components
     * @param array $data
     * @param array $config
     */
    public function __construct(
        ContextInterface $context,
        FormFactory $formFactory,
        ConfigInterface $wysiwygConfig,
        array $components = [],
        array $data = [],
        array $config = []
    ) {
        $wysiwygConfigData = isset($config['wysiwygConfigData']) ? $config['wysiwygConfigData'] : [];
        $this->form = $formFactory->create();
        $this->editor = $this->form->addField(
            $context->getNamespace() . '_' . $data['name'],
            'Magento\Framework\Data\Form\Element\Editor',
            [
                'force_load' => true,
                'rows' => 20,
                'name' => $data['name'],
                'config' => $wysiwygConfig->getConfig($wysiwygConfigData),
                'wysiwyg' => isset($config['wysiwyg']) ? $config['wysiwyg'] : null,
            ]
        );
        $data['config']['content'] = $this->editor->getElementHtml();

        parent::__construct($context, $components, $data);
    }

    /**
     * Get component name
     *
     * @return string
     */
    public function getComponentName()
    {
        return static::NAME;
    }}

Ale jest błąd i nie wiem, gdzie powinienem dodać do niego nazwę.

1 exception(s):
Exception #0 (Magento\Framework\Exception\LocalizedException): The requested component ("wysiwyg2") is not found. Before using, you must add the implementation.

Exception #0 (Magento\Framework\Exception\LocalizedException): The requested component ("wysiwyg2") is not found. Before using, you must add the implementation.
#0 /var/www/vhosts/plchk/vendor/magento/module-ui/Model/Manager.php(207): Magento\Framework\View\Element\UiComponent\Config\Provider\Component\Definition->getComponentData('wysiwyg2')
#1 /var/www/vhosts/plchk/vendor/magento/framework/View/Element/UiComponentFactory.php(187): Magento\Ui\Model\Manager->createRawComponentData('wysiwyg2')
#2 /var/www/vhosts/plchk/vendor/magento/module-ui/Component/Form/Field.php(82): Magento\Framework\View\Element\UiComponentFactory->create(1, 'wysiwyg2', Array)
#3 /var/www/vhosts/plchk/vendor/magento/framework/View/Layout/Generator/UiComponent.php(148): Magento\Ui\Component\Form\Field->prepare()
#4 /var/www/vhosts/plchk/vendor/magento/framework/View/Layout/Generator/UiComponent.php(145): Magento\Framework\View\Layout\Generator\UiComponent->prepareComponent(Object(Magento\Ui\Component\Form\Field))
Yau Thomas
źródło

Odpowiedzi:

1

O ile mi wiadomo, próbujesz dodać cały nowy typ komponentu interfejsu użytkownika, który wywołuje wysiwyg2.

Ale niestety znany jest problem z dodawaniem nowego typu komponentu interfejsu użytkownika (tak, tylko inny). Możesz sprawdzić oryginalny problem w dowolnym miejscu .

Przyjrzyjmy się, jak Magento 2 radzi sobie ze składnikami interfejsu użytkownika w formie produktu.

vendor / magento / module-catalogue / Ui / DataProvider / Product / Form / Modifier / Eav.php

/**
 * Add wysiwyg properties
 *
 * @param ProductAttributeInterface $attribute
 * @param array $meta
 * @return array
 */
private function customizeWysiwyg(ProductAttributeInterface $attribute, array $meta)
{
    if (!$attribute->getIsWysiwygEnabled()) {
        return $meta;
    }

    $meta['arguments']['data']['config']['formElement'] = WysiwygElement::NAME;
    $meta['arguments']['data']['config']['wysiwyg'] = true;
    $meta['arguments']['data']['config']['wysiwygConfigData'] = [
        'add_variables' => false,
        'add_widgets' => false,
        'add_directives' => true,
        'use_container' => true,
        'container_class' => 'hor-scroll',
    ];

    return $meta;
}

I w środku public function setupAttributeMeta(ProductAttributeInterface $attribute, $groupCode, $sortOrder)

Wiersz 633 (może być inny dla każdej wersji)

        case 'textarea':
            $meta = $this->customizeWysiwyg($attribute, $meta);
            break;

Jak widać, customizeWysiwyg()zakodowane formElementdo wysiwyg.

Jeśli chcesz wysiwyg2pracować, musisz napisać wtyczkę, setupAttributeMeta()aby dodać coś takiego$meta = $this->customizeWysiwyg2($attribute, $meta);

Ale nie zachęcam do tego, możesz po prostu stworzyć preferencje \Magento\Ui\Component\Form\Element\Wysiwyg, a następnie w konstruktorze możesz zrobić coś takiego

/**
 * Wysiwyg constructor.
 *
 * @param \Magento\Framework\View\Element\UiComponent\ContextInterface $context
 * @param \Magento\Framework\Data\FormFactory                          $formFactory
 * @param \Magento\Ui\Component\Wysiwyg\ConfigInterface                $wysiwygConfig
 * @param array                                                        $components
 * @param array                                                        $data
 * @param array                                                        $config
 */
public function __construct(
    ContextInterface $context,
    FormFactory $formFactory,
    ConfigInterface $wysiwygConfig,
    array $components = [],
    array $data = [],
    array $config = []
) {
    // Override the component for the WYSIWYG
    // This is not done using definition.xml due to https://github.com/magento/magento2/issues/5647
    $data['config']['component'] = 'Stackoverflow_Toan/js/form/element/wysiwyg';

    // Override the templates to include our KnockoutJS code
    $data['config']['template'] = 'Stackoverflow_Toan/wysiwyg';
    $data['config']['elementTmpl'] = 'Stackoverflow_Toan/wysiwyg';

    parent::__construct($context, $formFactory, $wysiwygConfig, $components, $data, $config);
}

W ten sposób możesz mieć własny jsComponent, szablony nokaut ..etc i gotowy do dostosowania do wszystkiego, co chcesz.

Mam nadzieję że to pomoże :)

Toan Nguyen
źródło