Как создать собственный заголовок электронной почты


18

Я вижу в транзакционной электронной почте Новый шаблон заказа, есть этот тег, который вызывает заголовочный файл HTML, который находится в app/locale/en_US/template/email/html

{{template config_path="design/email/header"}}

Я хочу создать новый заголовок, поэтому я создал новый файл app/local/en_US/template/email/html/header2.htmlи использовать код

{{template config_path="design/email/header2"}}

Но это не работает. С этим кодом заголовок не включается в электронное письмо. Любые идеи, почему или как правильно создать собственный заголовок электронной почты?


1
у вас есть заголовок, определенный в пути конфигурацииdesign/email/header2
Дэвид Мэннерс

Да. Я считаю, что правильный путь. приложение / местные / en_US / шаблон / электронная почта / html / header2.html.
Джастин Лок

Ответы:


2

Вы также можете реализовать класс по умолчанию Magento для работы с несколькими (верхние и нижние колонтитулы).

Создать файл:

приложение / местные / Mage / Adminhtml / модель / System / Config / Source / Email / template.php

<?php
/**
 * Magento
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Open Software License (OSL 3.0)
 * that is bundled with this package in the file LICENSE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://opensource.org/licenses/osl-3.0.php
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@magento.com so we can send you a copy immediately.
 *
 * DISCLAIMER
 *
 * Do not edit or add to this file if you wish to upgrade Magento to newer
 * versions in the future. If you wish to customize Magento for your
 * needs please refer to http://www.magento.com for more information.
 *
 * @category    Mage
 * @package     Mage_Adminhtml
 * @copyright  Copyright (c) 2006-2016 X.commerce, Inc. and affiliates (http://www.magento.com)
 * @license    http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
 */


/**
 * Adminhtml config system template source
 *
 * @category   Mage
 * @package    Mage_Adminhtml
 * @author      Magento Core Team <core@magentocommerce.com>
 */
class Mage_Adminhtml_Model_System_Config_Source_Email_Template extends Varien_Object
{
    /**
     * Config xpath to email template node
     *
     */
    const XML_PATH_TEMPLATE_EMAIL = 'global/template/email/';

    /**
     * Generate list of email templates
     *
     * @return array
     */
    public function toOptionArray()
    {
        if(!$collection = Mage::registry('config_system_email_template')) {
            $collection = Mage::getResourceModel('core/email_template_collection')
            ->load();

            Mage::register('config_system_email_template', $collection);
        }
        $options = $collection->toOptionArray();
        $templateName = Mage::helper('adminhtml')->__('Default Template from Locale');
        $nodeName = str_replace('/', '_', $this->getPath());

        // Implementation for various templates config.
        $templatesNodes = Mage::app()->getConfig()->getNode('global/template/email');
        if(count($templatesNodes)) {
            foreach($templatesNodes as $nodes) {
                foreach($nodes as $code => $config) {
                    if(strpos($code, $nodeName) !== false) {
                        $templateLabelNode = Mage::app()->getConfig()->getNode(self::XML_PATH_TEMPLATE_EMAIL . $code . '/label');
                        if ($templateLabelNode) {
                            $templateName = Mage::helper('adminhtml')->__((string)$templateLabelNode);
                            $templateName = Mage::helper('adminhtml')->__('%s (Default Template from Locale)', $templateName);
                        }
                        array_unshift(
                            $options,
                            array(
                                'value'=> str_replace('/', '_', $code),
                                'label' => $templateName
                                )
                            );
                    }
                }
            }
        }

        return $options;
    }

}

Затем в вашем пользовательском модуле вы можете использовать, как в следующем примере в вашем config.xml:

<global>
    <template>
            <email>
                <design_email_header_custom_black translate="label" module="custom_module">
                    <label>Email - Header (CUSTOM BLACK)</label>
                    <file>html/header-custom-black.html</file>
                    <type>text</type>
                </design_email_header_custom_black>
                <design_email_header_custom_white translate="label" module="custom_module">
                    <label>Email - Header (CUSTOM WHITE)</label>
                    <file>html/header-custom-white.html</file>
                    <type>text</type>
                </design_email_header_custom_white>
                <design_email_footer_custom_black translate="label" module="custom_module">
                    <label>Email - Footer (CUSTOM BLACK)</label>
                    <file>html/footer-custom-black.html</file>
                    <type>text</type>
                </design_email_footer_custom_black>
                <design_email_footer_custom_white translate="label" module="custom_module">
                    <label>Email - Footer (CUSTOM WHITE)</label>
                    <file>html/footer-custom-white.html</file>
                    <type>text</type>
                </design_email_footer_custom_white>
            </email>
        </template>
</global>

Таким образом, у вас есть эти варианты на выбор:

Система> Конфигурация> Дизайн> Транзакционная электронная почта


1

Это может помочь объяснить это:
используйте несколько нижних колонтитулов для электронной почты.

Что они спрашивают:

Используйте несколько нижних колонтитулов для электронной почты

вверх голос 1 голос вниз любимый Можно ли использовать несколько нижних колонтитулов для транзакционных электронных писем?

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

В настоящее время я загружаю нижний колонтитул с этой строкой: {{template config_path = "design / email / footer"}}

Как я могу загрузить определенный шаблон в транзакционной электронной почте?


1

design / email / header Это относится к опции конфигурации, а НЕ к шаблону.

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

<config>
    <sections>
        <design>
            <groups>
                <email>
                    <fields>
                        <header2 translate="label">
                            <label>Email Header Template 2</label>
                            <frontend_type>select</frontend_type>
                            <source_model>adminhtml/system_config_source_email_template</source_model>
                            <sort_order>30</sort_order>
                            <show_in_default>1</show_in_default>
                            <show_in_website>1</show_in_website>
                            <show_in_store>1</show_in_store>
                        </header2>

В качестве альтернативы просто создайте новый статический блок CMS, а затем вставьте его поверх содержимого электронной почты следующим образом.

{{block type="cms/block" block_id="email-header-sales" }}

Замена.

{{template config_path="design/email/header"}}

Мне нужно было разрешить в cms/blockразделе Система -> Разрешения -> блоки
Коллин Андерсон

1

Также вам нужно изменить код в app/code/core/Mage/Core/etc/config.xml

<global>
    <template>
            <email>
                <design_email_header translate="label" module="core">
                    <label>Email - Header</label>
                    <file>html/header2.html(your file name)</file>
                    <type>text</type>
                </design_email_header>

Вместо того, чтобы делать это в основном файле, попробуйте сделать это в своем пользовательском модуле.

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.