База знаний
Экспорт в YML PROFAQ (Общие вопросы)Интеграция с OZONИнтеграция с Яндекс.МаркетИнтеграция с AliExpressSEO-фильтрMeta Robots TagИнформация о доставке и оплатеЧасто задаваемые вопросыГруппы товаровSEO-оптимизацияКаталог отзывовGoogle ПокупкиЭлектронная коммерцияПоиск PROSEO-регионыТурбо-страницыSEO-редиректыLink canonical ​Last-Modified​Заказ обратного звонка​HTML-карта сайта​Навигация в хлебных крошкахКупить в 1 кликКупить в 1 клик 2.0Sitemap PROЗаказ в 1 шагБренды PROМассовые измененияЗащита контента для Shop-ScriptАвтообновление курса валют Защита контента для приложения «Блог»Передача заказов из корзин Турбо-страницFast indexЦены ProИнтеграция с МегаМаркетMobisite 3.0Megashop 3.0MobiSite 2.0MegaShop 2.0VK пиксель PROЭквайринг EpayБлижайший срок доставкиДополнительный поиск товаров в категорииТриггеры PROПоделиться корзинойОбновление остатков и цен по коду артикулаОбщие вопросы
Войдите в личный кабинет для возможности задавать вопросы и отвечать на комментарии.
Полезная информация

Как передать информации из плагинов в «Яндекс.Маркет PRO»

Поддержка Bodysite
Поддержка Bodysite
12 августа 2020 10:16
+1

В плагин «Яндекс.Маркет PRO» можно передавать информацию из любых плагинов:

1. Для передачи данных о предоставляемых плагином значениях используется событие importexport_backend_field_value_source

Пример кода:

public function handleImportexportBackendFieldValueSource($params)
{
    $variable_meta = [
        'id' => 'variable_id',
        'name' => 'Имя значения',
    ];

    return [
        $variable_meta,
    ];
}

2. Для получения значения используется событие importexport_field_value_data_provider. Нужно вернуть экземпляр класса, у которого реализованы методы getSkuVariableValue и getAllSkuVariableValues

Пример кода: 

public function handleImportexportFieldValueDataProvider($params)
{
    return new PluginDataProvider();
}

class PluginDataProvider
{
    /**
     * @param $sku_id
     * @param $variable_id
     * @param array $extra_params
     * @return mixed
     */
    public function getSkuVariableValue($sku_id, $variable_id, array $extra_params)
    {
        return null; // нет значения

        /* или */

        return [
            'type' => 'simple',
            'value' => 'sku value',
        ];
    }

    /**
     * @param $sku_id
     * @param $variable_id
     * @param array $extra_params
     * @return array
     */
    public function getAllSkuVariableValues($sku_id, $variable_id, array $extra_params)
    {
        /* возвращает массив, формат каждого элемента такой же, как и в getSkuVariableValue */
    }
}

Поддерживаемые типы (ключ 'type'):

// 'simple', например
[
    'type' => 'simple',
    'value' => 'sku value',
]
//или можно вернуть просто строчку 'sku value'.

// 'count', например
[
    'type' => 'count',
    'count' => 18,
]

// 'feature_value', например
[
    'type' => 'feature_value',
    'feature_id' => 1,
    'feature_value_rows' => [
        ['id' => 2, 'value' => 'some value', ....],
    ],
]

// 'price', например
[
    'type' => 'price',
    'price' => 150.50,
    'currency_id' => 'RUB',
]