Просмотр события «Добавить в корзину» - идентификатор товара в кавычках пуст


11

Я пытаюсь поймать событие, которое происходит, когда товар добавлен в корзину. В настоящее время я смотрю следующее событие: checkout_cart_product_add_after

Согласно источнику magento, это событие происходит после того, как все сделано в Цитате. но когда я получаю доступ к идентификатору корзины и идентификатору котировки, значения становятся пустыми:

$quoteItem = $observer->getQuoteItem();
$quote_item_id = $quoteItem->getItemId();
$cart = Mage::getSingleton('checkout/session');
$quote_id= $cart->getQuoteId();

Вышеуказанное возвращает пустое значение для обоих идентификаторов, если в корзине нет товаров, если в корзине уже есть товар, идентификатор корзины имеет значение, а quote_item_id - нет.

Заметьте, что это было задано ранее, но вопрос так и не был решен, и обсуждение закончилось отклонением от этого вопроса. Мне нужен quote_item_id.


попробуйте с$quoteItem = $observer->getEvent()->getQuoteItem();
Мариус

То же самое, идентификатор приходит пустым.
Нуно Фуртадо

Добавьте это в своем обозревателе Mage::log($quoteItem)и посмотрите, var/log/system.logкак выглядит элемент цитаты. Может быть, у вас есть идея оттуда.
Мариус

это огромное количество информации, я легко потеряюсь в этом
Нуно Фуртадо

1
= D все еще слишком велик, я попробовал Mage :: getLog ($ quoteItem-> debug ()), и я заметил, что в результирующем массиве нет itemid. Кажется, в элементе stock_item внутри цитаты есть item_id, но я даже не уверен, что это такое. Изменить: это не так, это значение всегда одинаково
Нуно Фуртадо

Ответы:


22

Не делай этого.

Ваша проблема в том, что корзина еще не сохранена, посмотрите здесь:

https://github.com/LokeyCoding/magento-mirror/blob/magento-1.7/app/code/core/Mage/Checkout/controllers/CartController.php#L201-L206

public function addAction()
{
// ...
        $cart->addProduct($product, $params); // <-- you are inside this method
        if (!empty($related)) {
            $cart->addProductsByIds(explode(',', $related));
        }

        $cart->save(); // here is the saving, and therefore after this line,
                       //  quote and items have an id
// ...
        Mage::dispatchEvent('checkout_cart_add_product_complete',
            array('product' => $product, 'request' => $this->getRequest(), 'response' => $this->getResponse())
        );

То, что вы хотите, это слушать checkout_cart_add_product_complete

Если вы хотите узнать, какие предметы были добавлены в этом раунде, просто отметьте их checkout_cart_product_add_afterкак, $quoteItem->setIsNew()тогда вы можете зарегистрироваться checkout_cart_add_product_completeна$quoteItem->getIsNew()


Я подумал, что это так, проблема в том, что событие только отправляет продукт. Это хорошая идея, чтобы получить корзину из сессии и получить последний из массива allitems? я волнуюсь, что может быть какое-то состояние гонки
Нуно Фуртадо

1
Отредактировал ответ. Вам нужно пометить элементы цитаты, затем позволить magento сохранить их, а затем вы знаете свой элемент цитаты и продукт :)
Fabian Blechschmidt

@FabianBlechschmidt есть событие, которое будет вызвано при обновлении корзины?
Бабочка

да, многие, вы можете просто подключиться к dispatchEvent и проверить его: magento.stackexchange.com/a/9155/217 И обязательно прочитайте комментарий от ben!
Фабиан Блехшмидт

5

Вы можете использовать checkout_cart_product_add_afterсобытие с этим:

$observer->getEvent()->getQuoteItem()->getProduct()->getData()

Возвращенные данные выглядят примерно так:

Array
(
    [store_id] => 1
    [entity_id] => 1
    [entity_type_id] => 4
    [attribute_set_id] => 4
    [type_id] => simple
    [sku] => TESTSKU
    [has_options] => 0
    [required_options] => 0
    [created_at] => 2015-02-10T12:11:50-05:00
    [updated_at] => 2015-02-10 17:18:47
    [name] => Demo Product
    [url_key] => demo-product
    [country_of_manufacture] => 
    [msrp_enabled] => 2
    [msrp_display_actual_price_type] => 4
    [meta_title] => 
    [meta_description] => 
    [image] => no_selection
    [small_image] => no_selection
    [thumbnail] => no_selection
    [custom_design] => 
    [page_layout] => 
    [options_container] => container1
    [gift_message_available] => 
    [url_path] => demo-product.html
    [weight] => 1.0000
    [price] => 12.9900
    [special_price] => 
    [msrp] => 
    [status] => 1
    [visibility] => 4
    [tax_class_id] => 2
    [is_recurring] => 0
    [description] => It's a sample product, what do you want?
    [short_description] => It's a demo product
    [meta_keyword] => 
    [custom_layout_update] => 
    [news_from_date] => 
    [news_to_date] => 
    [special_from_date] => 
    [special_to_date] => 
    [custom_design_from] => 
    [custom_design_to] => 
    [group_price] => Array
        (
        )

    [group_price_changed] => 0
    [media_gallery] => Array
        (
            [images] => Array
                (
                )

            [values] => Array
                (
                )

        )

    [tier_price] => Array
        (
        )

    [tier_price_changed] => 0
    [stock_item] => Mage_CatalogInventory_Model_Stock_Item Object
    (
        // Crazy recursion happens here
    )
    [is_in_stock] => 1
    [is_salable] => 1
    [website_ids] => Array
        (
            [0] => 1
        )
    [cart_qty] => 1
    [qty] => 1
    [stick_within_parent] => 
    [customer_group_id] => 0
    [final_price] => 
)

Это было проверено на Magento 1.9.1.0, но, насколько я могу судить, это должно работать на 1.7


2

Вы можете использовать следующее событие

sales_quote_item_set_product

и получить идентификатор элемента в обозревателе, как это.

$quote_item = $observer->getEvent()->getQuoteItem();
$item_id = $quote_item->getItemId();

Это событие вызывается для каждого элемента цитаты каждый раз при создании корзины, а не только при добавлении элемента в корзину.
Rooster242

1

Я решил эту проблему, вызвав save на $ cart и quoteItem. Не выбрав это как правильный, так как я не уверен, что это лучший метод.

Решение Фабиана Блехшмидта намного лучше, используйте его.

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.