O observador de eventos review_save_after não está sendo executado corretamente

8

Estou usando a versão Magento 1.8. Eu escrevi um observador que deve ser executado quando o administrador salvar uma revisão do produto com o status "Aprovado". E eu criei um atributo de classificação para cada produto com seleção múltipla e ele deve ser atualizado automaticamente sempre que o administrador salvar a revisão de um produto.

Nota: as análises estão em Relatórios / análises / análises de produtos.

Código etc / Config.xml:

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

código de modo / 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();
    }
}

Quando o administrador está tentando salvar a revisão de um produto, o código do observador acima está sendo executado e a revisão está sendo atualizada corretamente, mas o produto está obtendo o valor da revisão anterior em vez da revisão atualizada mais recente.

Eu escrevi, <review_save_after>mas obtendo valor anterior. Como é chamado o evento após "Salvar comentário" Está correto ou não?

Por favor, diga-me onde estou errado.

Desde já, obrigado.

Sivakumar
fonte

Respostas:

4

Depois de muita pesquisa, consegui uma solução ... :-) Mas podemos fazer isso com muita facilidade.

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();
        }
    }
Sivakumar
fonte
1
<review_save_after>
 <observers>
    <efkadminhtml>
        <type>singleton</type> 
        <class>efkadminhtml/observer</class>
        <method>ratingsUpdate</method>
    </efkadminhtml>
</observers>

adicione Type e depois tente

Keyul Shah
fonte
Eu coloquei essa linha <type> singleton </type> . Mas nenhum efeito ainda está recebendo o mesmo problema.
Sivakumar
tente fazer logon usando Mage :: log ('test'). e por favor me avise
Keyul Shah
Mage :: log ('test') está exibindo teste . A função de observador está em execução.
Sivakumar
Em seguida, seu observador está funcionando bem
Keyul Shah
2
letsmakeitgo.com/blog/2011/06/… siga este link para codificação
Keyul Shah