Observador por Abandono de Carrinho


8

Eu preciso de ajuda!!!

Estou criando um módulo que se integra a outra plataforma via API. Já obtive o Observador ou Evento para registro do cliente ( customer_register_success ), compra concluída ( checkout_onepage_controller_success_action ).

A ajuda de que preciso é como obter o Observer em carrinhos abandonados ?, ou qual seria o melhor método para obter essas informações e enviá-las via API.


2
qual é a sua definição de carros abandonados?
Philipp Sander

Quando o cliente adicionado produtos para o carro e não fazer a compra
Knaimero

3
Não fez a compra dentro de 2 minutos, 10 minutos, uma hora ou um dia? De qualquer forma, a qualquer hora que você escolher para sua definição, você pode observar um evento que acontece, e não algo que não acontece. Na minha opinião, para seu caso de uso, o melhor conceito seria um cronjob que verifica cotações ativas com a última interação anterior a x minutos / horas / dias.
HelgeB

Obrigado. O Magento, ao fazer uma compra e fechar o comércio eletrônico, cria automaticamente um registro que você pode ver nos admin -> relatórios -> Carrinhos abandonados. Minha pergunta existe: existe uma maneira de obter essas informações?
Knaimero

Não existe tal evento para obtê-lo, você pode obter coleção citação que não é ordenado entre tempo específico
Ketan Borada

Respostas:


3
  • Não existe esse evento para obter carrinhos abandonados, você deve criá-lo personalizado.
  • Eu tenho uma idéia para superar isso, você tem que criar cron que é executado a cada hora específica e coletar todas as cotações que não são ordenadas e entre o tempo definido (diferença entre o tempo de cotação criado e atualizado). você tem que apenas gerenciar updatedAtFromeupdatedAtTo
  • Ao fazer isso, você coletará todos os dados das cotações e, nessa coleção, poderá despachar eventos e passar todos os dados de cotação e dados do cliente para esse evento em um único evento ou saperate para todas as cotações e passar esses dados para a API do observador.

Eu criei o script que você pode aplicar na sua função de bloqueio. Estou usando esse script de trabalho para enviar itens de carrinho por e-mail ao meu cliente depois que eles saíram sem pedido.

<?php 
ob_start();
use Magento\Framework\App\Bootstrap;
include('app/bootstrap.php');
$bootstrap = Bootstrap::create(BP, $_SERVER);
$objectManager = $bootstrap->getObjectManager();
$state = $objectManager->get('Magento\Framework\App\State');
$state->setAreaCode('frontend');
ini_set('memory_limit', '1024M');
$objectManager = \Magento\Framework\App\ObjectManager::getInstance();
$resource = $objectManager->create('Magento\Framework\App\ResourceConnection');
$updatedAtFrom = '2019-06-19 19:00:00'; //Add current time
$updatedAtTo   = '2019-06-19 20:30:00';  // $updatedAtFrom  + 90 minutes ,add 90 minutes in current time to abondened cart

        $connection = $resource->getConnection();


        $select = $connection->select()
            ->from(
                ['q' => $resource->getTableName('quote')],
                [
                    'store_id'    => 'q.store_id',
                    'quote_id'    => 'q.entity_id',
                    'customer_id' => 'q.customer_id',
                    'updated_at'  => 'q.updated_at',
                    'created_at'  => 'q.created_at',
                ]
            )
            ->joinLeft(
                ['qa' => $resource->getTableName('quote_address')],
                'q.entity_id = qa.quote_id AND qa.address_type = "billing"',
                [
                    'customer_email'     => new \Zend_Db_Expr('IFNULL(q.customer_email, qa.email)'),
                    'customer_firstname' => new \Zend_Db_Expr('IFNULL(q.customer_firstname, qa.firstname)'),
                    'customer_lastname'  => new \Zend_Db_Expr('IFNULL(q.customer_lastname, qa.lastname)'),
                ]
            )
            ->joinInner(
                ['qi' => $resource->getTableName('quote_item')],
                'q.entity_id = qi.quote_id',
                [
                    'i_created_at' => new \Zend_Db_Expr('MAX(qi.created_at)'),
                ]
            )
            ->joinLeft(array('order' => $resource->getTableName('sales_order')),
                'order.quote_id = q.entity_id',
                array()
            )
            ->where('order.entity_id IS NULL')
            ->where('q.is_active = 1')
            ->where('q.items_count > 0')
            ->where('q.customer_email IS NOT NULL OR qa.email IS NOT NULL')
            ->where('qi.parent_item_id IS NULL')
            ->group('q.entity_id')
            ->having(
                '(q.created_at > ? OR MAX(qi.created_at) > ?)',
                $updatedAtFrom
            )
            ->having(
                '(q.created_at < ? OR MAX(qi.created_at) < ?)',
                $updatedAtTo
            )
            ->order('q.updated_at');

        $quotes = $connection->fetchAll($select);


        foreach ($quotes as $quote) {

            $params = [

                'store_id'       => $quote['store_id'],
                'quote_id'              => $quote['quote_id'],
                'customer_id'           => $quote['customer_id'],
                'customer_email' => $quote['customer_email'],
                'customer_tname'  => $quote['customer_firstname'] . ' ' . $quote['customer_lastname'],
                'created_at'     => max($quote['created_at'], $quote['i_created_at']),
            ];

            echo $quote['quote_id'];

            /*$this->eventdispatch->register(
                'quote_abandoned',
                [$params['quote_id']],
                $params
            );*/ 
            // Dispatch Event here and writelogic in that event which you want
        }

?>

A consulta resultante do script acima é:

SELECT `q`.`store_id`, `q`.`entity_id` AS `quote_id`, `q`.`customer_id`, `q`.`updated_at`, `q`.`created_at`, IFNULL(q.customer_email, qa.email) AS `customer_email`, IFNULL(q.customer_firstname, qa.firstname) AS `customer_firstname`, IFNULL(q.customer_lastname, qa.lastname) AS `customer_lastname`, MAX(qi.created_at) AS `i_created_at` FROM `quote` AS `q` LEFT JOIN `quote_address` AS `qa` ON q.entity_id = qa.quote_id AND qa.address_type = "billing" INNER JOIN `quote_item` AS `qi` ON q.entity_id = qi.quote_id LEFT JOIN `sales_order` AS `order` ON order.quote_id = q.entity_id WHERE (order.entity_id IS NULL) AND (q.is_active = 1) AND (q.items_count > 0) AND (q.customer_email IS NOT NULL OR qa.email IS NOT NULL) AND (qi.parent_item_id IS NULL) GROUP BY `q`.`entity_id` HAVING ((q.created_at > '2019-06-19 19:00:00' OR MAX(qi.created_at) > '2019-06-19 19:00:00')) AND ((q.created_at < '2019-06-19 20:30:00' OR MAX(qi.created_at) < '2019-06-19 20:30:00')) ORDER BY `q`.`updated_at` ASC 
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.