Magento зарегистрироваться для регистрации на кассе

8

Кто-нибудь знает, можно ли перенести этап регистрации клиента на оформление заказа, как в исходной проверке Magento 1? Ищите расширение, которое будет делать это для меня, или совет о том, как я мог бы достичь этого.

Джейсон
источник
Вы можете добавить шаги к оформлению заказа,
выполнив
После завершения оформления заказа magento также дает возможность создать учетную запись на основе данных, указанных при оформлении заказа на странице успеха.
Харри
@harri Я знаю, что так оно и есть, но у нас есть клиент, который хочет, чтобы регистрация происходила одновременно с размещением заказа.
Джейсон
@ Джейсон Вы получили какое-нибудь решение для этого?
Рохит Кундейл
Проверьте здесь github.com/danslo/CleanCheckout
Sohel Rana

Ответы:

1

Я хотел бы создать шаг в кассе, чтобы определить погоду, в которую вы вошли, а затем соответственно отобразить форму.

Загрузите регистрационную форму в этот шаг через ajax и измените событие после регистрации, определяющее, была ли регистрация произведена извлечение, перенаправив обратно на извлечение, а не на панель мониторинга.

Я дошел до того, что добавил рабочий шаг, который показывает, когда не вошел в систему для регистрации, и перенаправил успешное завершение регистрации обратно, чтобы отключить предыдущий шаг для более удобного взаимодействия с пользователем.

Предоставление возможности входа в систему, если у пользователя есть учетная запись, но он еще не вошел в систему на этом этапе, улучшит ситуацию здесь.

Это полный код, если вы хотите проверить все, что было много, чтобы включить в ответ:

https://github.com/harrigo/RegisterCheckout

Создайте форму регистрации в контроллере:

Так как шаги извлечения должны phpбыть выполнены для получения URL-адреса формы, ключа и т. Д., Потребуется контроллер, чтобы мы могли загрузить эту форму регистра через ajax в шаг.

<?php
namespace Harrigo\RegisterCheckout\Controller\Index;

use Magento\Framework\Controller\ResultFactory;

class Register extends \Magento\Framework\App\Action\Action
{
    protected $resultPageFactory;

    /**
     * Constructor
     * 
     * @param \Magento\Framework\App\Action\Context  $context
     * @param \Magento\Framework\View\Result\PageFactory $resultPageFactory
     */
    public function __construct(
        \Magento\Framework\App\Action\Context $context,
        \Magento\Framework\View\Result\PageFactory $resultPageFactory
    )
    {
        $this->resultPageFactory = $resultPageFactory;
        $this->_resultFactory = $context->getResultFactory();
        parent::__construct($context);
    }

    /**
     * Execute view action
     * 
     * @return \Magento\Framework\Controller\ResultInterface
     */
    public function execute()
    {
        //if (isset($_POST["cart"])) {
            $resultLayout = $this->resultFactory->create(ResultFactory::TYPE_LAYOUT);
            return $resultLayout;   
        //}
        //$this->_redirect('checkout/');

    }
}

Контроллер / Index / register.php

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

<?xml version="1.0"?>
<layout xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:View/Layout/etc/layout_generic.xsd">
  <container name="root" label="Root">
            <block class="Magento\Framework\View\Element\Js\Components" name="customer_account_create_head_components" template="Magento_Customer::js/components.phtml"/>
            <block class="Magento\Customer\Block\Form\Register" name="customer_form_register" template="Harrigo_RegisterCheckout::register.phtml">
                <container name="form.additional.info" as="form_additional_info"/>
                <container name="customer.form.register.fields.before" as="form_fields_before" label="Form Fields Before" htmlTag="div" htmlClass="customer-form-before"/>
            </block>
            <block class="Magento\Cookie\Block\RequireCookie" name="require-cookie" template="Magento_Cookie::require_cookie.phtml">
                <arguments>
                    <argument name="triggers" xsi:type="array">
                        <item name="registerSubmitButton" xsi:type="string">.action.submit</item>
                    </argument>
                </arguments>
            </block>
            <block class="Magento\Framework\View\Element\Template" name="form_additional_info_customer" template="Magento_Customer::additionalinfocustomer.phtml"/>
  </container>
</layout>

/view/frontend/layout/harrigoregister_index_register.xml

Убедитесь, что в файле / etc / frontend модуля добавлен route.xml.

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../../../../../lib/internal/Magento/Framework/App/etc/routes.xsd">
    <router id="standard">
        <route id="harrigoregister" frontName="harrigoregister">
            <module name="Harrigo_RegisterCheckout" />
        </route>
    </router>
</config>

Создать шаг оформления заказа:

http://devdocs.magento.com/guides/v2.0/howdoi/checkout/checkout_new_step.html

Поскольку это первый шаг, убедитесь, что добавили миксины так же, как я это сделал в модуле, так как в данном случае devdocs неверен, что приводит к каждому шагу, показывающему:

<!--The 'step_code' value from the .js file should be used-->
<li id="registerstep" data-bind="fadeVisible: isVisible">
<div class="step-title" data-bind="i18n: 'Register'" data-role="title"></div>
    <div id="checkout-step-title"
         class="step-content"
         data-role="content">
        <form data-bind="submit: navigateToNextStep" novalidate="novalidate">
            <div class="actions-toolbar" id="shipping-method-buttons-container">
                <div class="primary">
                    <button data-role="opc-continue" type="submit" class="button action continue primary">
                        <span><!-- ko i18n: 'Continue as guest'--><!-- /ko --></span>
                    </button>
                </div>
            </div>
        </form>
    </div>  
    <div id="registerblock"></div>
</li>

Это не удавалось, если блок не загружался до вызова ajax, но в итоге использовал что-то вроде этого, чтобы получить нашу регистрационную форму из контроллера и плюнуть на шаг:

//waits for elements to load in checkout
function waitForElement(elementPath, callBack){
  window.setTimeout(function(){
    if($(elementPath).length){
      callBack(elementPath, $(elementPath));
    }else{
      waitForElement(elementPath, callBack);
    }
  },500)
}

//get crosssell products / newsletter
$.ajax({
  url: "/harrigoregister/index/register",
  type: "post",
  data: { 
    cart: "yes"
  },
  success: function(response) {
    waitForElement("#registerblock",function(){
                $("#registerblock").html(response);
        });
  },
  error: function(xhr) {
  }
});

Здесь намного больше шагов, просто следуйте инструкциям devdocs, следя за выполнением шага mixin, но используйте ниже для mixin, так как пример devdocs не работает:

define(
    [
        'ko',
        'Magento_Customer/js/model/customer'
    ], function (ko, customer) {
        'use strict';

        var mixin = {

            initialize: function () {
                if(!customer.isLoggedIn()) {
                    this.isVisible = ko.observable(false);
                    this.visible = ko.observable(false); // set visible to be initially false to have your step show first
                }
                    this._super();

                return this;
            }
        };

        return function (target) {
            return target.extend(mixin);
        };
    }
);

Основными отличиями были этапы оплаты и доставки с использованием isVisible и Visible, а devdocs использует только видимый в примере, поэтому для исправления необходимо добавить isVisible. Также пришлось внести коррективы для того, если шаг был отключен.

Изменить регистрацию перенаправления:

Magento 2 - перенаправить пользователя на определенную страницу после регистрации

<?php

namespace Harrigo\RegisterCheckout\Plugin;

use Magento\Framework\Controller\ResultFactory;
use Magento\Framework\Registry;
use Magento\Framework\UrlInterface;

class Redirect
{
    protected $coreRegistry;

    protected $url;

    protected $resultFactory;


    public function __construct(Registry $registry, UrlInterface $url, ResultFactory $resultFactory)
    {
        $this->coreRegistry = $registry;
        $this->url = $url;
        $this->resultFactory = $resultFactory;
    }

    public function aroundGetRedirect ($subject, \Closure $proceed)
    {
        //need to check out if registration was from checkouit
        /** @var \Magento\Framework\Controller\Result\Redirect $result */

        if ($_POST['checkout'] = 'true') {
            $result = $this->resultFactory->create(ResultFactory::TYPE_REDIRECT);
            $result->setUrl($this->url->getUrl('checkout'));
            return $result;
        }

        return $proceed();
    }
}

Пример грубый, но также пришлось переопределить register.phtml, чтобы добавить переменную post checkout, чтобы определить разницу между двумя формами. Там, где много шагов, которые я не показал, но проверьте модуль, который я создал для полного примера.

Харри
источник