* @copyright 2007-2019 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ use PrestaShop\PrestaShop\Core\Foundation\Templating\RenderableInterface; use PrestaShop\PrestaShop\Core\Foundation\Templating\RenderableProxy; class CheckoutProcessCore implements RenderableInterface { private $smarty; /** * @var CheckoutSession */ private $checkoutSession; private $steps = array(); private $has_errors; private $template = 'checkout/checkout-process.tpl'; public function __construct( Context $context, CheckoutSession $checkoutSession ) { $this->context = $context; $this->smarty = $this->context->smarty; $this->checkoutSession = $checkoutSession; } public function getTemplate() { return $this->template; } public function handleRequest(array $requestParameters = array()) { foreach ($this->getSteps() as $step) { $step->handleRequest($requestParameters); } return $this; } public function getCheckoutSession() { return $this->checkoutSession; } public function addStep(CheckoutStepInterface $step) { $step->setCheckoutProcess($this); $this->steps[] = $step; return $this; } public function getSteps() { return $this->steps; } public function setTemplate($templatePath) { $this->template = $templatePath; return $this; } public function render(array $extraParams = array()) { $scope = $this->smarty->createData( $this->smarty ); $params = array( 'steps' => array_map(function (CheckoutStepInterface $step) { return array( 'identifier' => $step->getIdentifier(), 'ui' => new RenderableProxy($step), ); }, $this->getSteps()), ); $scope->assign(array_merge($extraParams, $params)); $tpl = $this->smarty->createTemplate( $this->template, $scope ); return $tpl->fetch(); } public function setHasErrors($has_errors = true) { $this->has_errors = $has_errors; return $this; } public function hasErrors() { return $this->has_errors; } public function getDataToPersist() { $data = []; foreach ($this->getSteps() as $step) { $defaultStepData = array( 'step_is_reachable' => $step->isReachable(), 'step_is_complete' => $step->isComplete(), ); $stepData = array_merge($defaultStepData, $step->getDataToPersist()); $data[$step->getIdentifier()] = $stepData; } return $data; } public function restorePersistedData(array $data) { foreach ($this->getSteps() as $step) { $id = $step->getIdentifier(); if (array_key_exists($id, $data)) { $stepData = $data[$id]; $step ->setReachable($stepData['step_is_reachable']) ->setComplete($stepData['step_is_complete']) ->restorePersistedData($stepData); } } return $this; } public function setNextStepReachable() { foreach ($this->getSteps() as $step) { if (!$step->isReachable()) { $step->setReachable(true); break; } if (!$step->isComplete()) { break; } } return $this; } public function markCurrentStep() { $steps = $this->getSteps(); foreach ($steps as $step) { if ($step->isCurrent()) { // If a step marked itself as current // then we assume it has a good reason // to do so and we don't auto-advance. return $this; } } foreach ($steps as $position => $step) { $nextStep = ($position < count($steps) - 1) ? $steps[$position + 1] : null; if ($step->isReachable() && (!$step->isComplete() || ($nextStep && !$nextStep->isReachable()))) { $step->setCurrent(true); return $this; } } return $this; } public function invalidateAllStepsAfterCurrent() { $markAsUnreachable = false; foreach ($this->getSteps() as $step) { if ($markAsUnreachable) { $step->setComplete(false)->setReachable(false); } if ($step->isCurrent()) { $markAsUnreachable = true; } } return $this; } }