El observador de eventos review_save_after no se ejecuta correctamente


8

Estoy usando la versión 1.8 de Magento. He escrito un observador que debe ejecutarse cuando el administrador guarda una revisión del producto con el estado "Aprobado". Y he creado un atributo de calificación para cada producto con selección múltiple y debe actualizarse automáticamente cada vez que el administrador guarde la revisión de un producto.

Nota: Las revisiones se encuentran en Informes / Revisiones / Revisiones de productos.

Código etc / Config.xml:

<review_save_after>
    <observers>
        <efkadminhtml>
            <class>efkadminhtml/observer</class>
            <method>ratingsUpdate</method>
        </efkadminhtml>
    </observers>
</review_save_after>

modo / Código de observador

public function ratingsUpdate(Varien_Event_Observer $observer)
{
    $object = $observer->getEvent()->getObject();
    $statusId = $object->getStatusId();

    if($statusId == 1) {
        $common = Mage::getSingleton('catalog/common');
        $attribute = $common->getAttribute('ratings');
        Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);

        $productId = $object->getEntityPkValue();
        $product = Mage::getModel('catalog/product')->load($productId);
        $avgRating = Mage::getBlockSingleton('efkreports/product_allReviews')->getAvgReview($product->getId());

        Mage::log($avgRating);
        Mage::log($attribute->getOptionId(round($avgRating)));
        $product->setRatings($attribute->getOptionId(round($avgRating)));
        //$product->setRatings(round($avgRating));
        $product->save();
    }
}

Cuando el administrador intenta guardar la revisión de un producto, el código de observador anterior se está ejecutando y la revisión se está actualizando correctamente, pero el producto está obteniendo un valor de revisión anterior en lugar de la última revisión actualizada.

Escribí <review_save_after>pero obteniendo valor anterior. ¿Cómo se llama el evento después de "Guardar revisión"? ¿Es correcto o no?

Por favor dime dónde estoy equivocado.

Gracias por adelantado.

Respuestas:


4

Después de mucha investigación obtuve una solución ... :-) Pero podemos hacer esto muy fácilmente.

public function ratingsUpdate(Varien_Event_Observer $observer)
    {
        $object = $observer->getEvent()->getObject();
        $data = $object->getData();

        $newRatings = $data['ratings'];
        $reviewId = $data['review_id'];

        $newSumRatings = 0;
        foreach($newRatings as $r) {
            $value = $r % 5;
            $newSumRatings += ($value) ? $value : 5;
        }
        $newAvgRating = $newSumRatings;

        $statusId = $object->getStatusId();
        if($statusId == 1) {
            $common = Mage::getSingleton('catalog/common');
            $attribute = $common->getAttribute('ratings');
            Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);

            $productId = $object->getEntityPkValue();
            $product = Mage::getModel('catalog/product')->load($productId);

            $reviews = Mage::getModel('review/review')
                ->getResourceCollection()
                ->addStoreFilter(Mage::app()->getStore()->getId()) 
                ->addEntityFilter('product', (int)$productId)
                ->addStatusFilter(Mage_Review_Model_Review::STATUS_APPROVED)
                ->setDateOrder()
                ->addRateVotes();

            $avg = 0;

            if (count($reviews) > 0) {
                foreach ($reviews->getItems() as $review) {
                    $temp = 0;
                    if($reviewId == $review->getReviewId()) {
                        $sum += $newSumRatings;
                    } else {
                        foreach( $review->getRatingVotes() as $vote ) {
                            $temp += $vote->getPercent() / 20;
                        }
                        $sum += $temp;  
                    }
                }

                $avg = $sum / (count($reviews) * 3);
            }

            $product->setRatings($attribute->getOptionId(round($avg)));
            $product->save();
        }
    }

1
<review_save_after>
 <observers>
    <efkadminhtml>
        <type>singleton</type> 
        <class>efkadminhtml/observer</class>
        <method>ratingsUpdate</method>
    </efkadminhtml>
</observers>

agregue Type y luego intente


He puesto esa línea <type> singleton </type> . Pero ningún efecto sigue teniendo el mismo problema.
Sivakumar

intente iniciar sesión utilizando Mage :: log ('prueba'). y por favor hágamelo saber
Keyul Shah

Mage :: log ('prueba') está mostrando prueba . La función de observador se está ejecutando.
Sivakumar

Entonces su observador está trabajando bien
Keyul Shah

2
letsmakeitgo.com/blog/2011/06/… siga este enlace para la codificación
Keyul Shah
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.