Você pode criar um módulo que disponibilize sua mensagem de bloqueio de cms ao modelo KO, adicionando à configuração do checkout.
Em Your/Module/etc/frontend/di.xml
nós adicionamos um novo provedor de configuração à configuração do checkout:
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
<type name="Magento\Checkout\Model\CompositeConfigProvider">
<arguments>
<argument name="configProviders" xsi:type="array">
<item name="cms_block_config_provider" xsi:type="object">Your\Module\Model\ConfigProvider</item>
</argument>
</arguments>
</type>
</config>
Em Your/Module/Model/ConfigProvider.php
nós temos o código que busca o html do bloco cms:
<?php
namespace Your\Module\Model;
use Magento\Checkout\Model\ConfigProviderInterface;
use Magento\Framework\View\LayoutInterface;
class ConfigProvider implements ConfigProviderInterface
{
/** @var LayoutInterface */
protected $_layout;
public function __construct(LayoutInterface $layout)
{
$this->_layout = $layout;
}
public function getConfig()
{
$cmsBlockId = 1; // id of cms block to use
return [
'cms_block_message' => $this->_layout->createBlock('Magento\Cms\Block\Block')->setBlockId($cmsBlockId)->toHtml()
];
}
}
Agora você deve substituir o modelo KO shipping.html no seu tema, para exibir o bloco cms da seguinte forma:
<div data-bind="html: window.checkoutConfig.cms_block_message"></div>
Nota: se você quiser usar tags html que contenham aspas duplas (por exemplo, uma tag html a) no bloco estático, deverá escapar das aspas duplas com uma barra invertida. Por exemplo:
Accept our <a target=\"_blank\" href=\"/privacy-policy\">privacy policy</a>
getConfig
método de\Magento\Checkout\Block\Cart\Sidebar
. Este método retorna uma matriz que é passada para javascript como owindow.checkout
objeto (isso ocorre emMagento/Checkout/view/frontend/templates/cart/minicart.phtml
).Eu acho que você não pode chamar bloco estático no arquivo .html, você precisa adicionar esse código de bloco estático no arquivo phtml
Experimente o caminho abaixo
tente adicionar o código abaixo manter por vir hacks css
Esta é uma solução temporária. Você pode obter outras boas respostas
fonte