Добавление блока CMS через скрипт установки

19

Я работаю над сайтом, на котором, как мне кажется, 9 отдельных экземпляров Magento, один и тот же сайт.

Поэтому существуют строгие процедуры, касающиеся любых внутренних данных - конфигурации и даже для блоков CMS.

Я хотел бы узнать, как добавить блок CMS через скрипт установки.

Фрэнсис Ким
источник

Ответы:

36

Для этого я предлагаю использовать dataпапку одного из ваших пользовательских модулей.
Допустим, модуль в данный момент находится в версии 1.0.4.

Создайте файл data/[module]_setup/data-upgrade-1.0.4-1.0.5.phpсо следующим содержанием:

Изменить: изменил имя файла

$content = 'BLOCK CONTENT HERE';
//if you want one block for each store view, get the store collection
$stores = Mage::getModel('core/store')->getCollection()->addFieldToFilter('store_id', array('gt'=>0))->getAllIds();
//if you want one general block for all the store viwes, uncomment the line below
//$stores = array(0);
foreach ($stores as $store){
    $block = Mage::getModel('cms/block');
    $block->setTitle('Block title here');
    $block->setIdentifier('block_identifier_here');
    $block->setStores(array($store));
    $block->setIsActive(1);
    $block->setContent($content);
    $block->save();
}

После этого просто измените версию, config.xmlчтобы 1.0.5очистить кеш и обновить любую страницу.

Мариус
источник
Добавление CMS является блоком, вряд ли является ошибкой, поэтому версия функции должна быть увеличена. User
user487772
Будет ли Mage::app()->getStores()делать то же самое?
user487772
4

Вместо того, чтобы использовать sqlпапку, вы должны поместить в нее любые сценарии установки, модифицирующие данные CMS data. Посмотрите app/code/core/Mage/Cms/data/cms_setupна несколько хороших примеров. Эти сценарии установки добавляют статические блоки и страницы CMS.

Для изменения значений конфигурации используйте этот код:

$installer->setConfigData(
    Mage_Page_Model_Config::XML_PATH_CMS_LAYOUTS,
    'your_value_here'
);

Также вот полезная статья

jharrison.au
источник
1

Вы также можете использовать приведенный ниже код в скрипте обновления:

$installer = $this;
/* @var $installer Mage_Core_Model_Resource_Setup */
$connection = $installer->getConnection();
/* @var $connection Varien_Db_Adapter_Pdo_Mysql */

$installer->startSetup();
$connection->insert($installer->getTable('cms/block'), array(
    'title'             => 'Footer Links',  
    'identifier'        => 'footer-links',
    'content'           => '<ul>\r\n<li><a href=\"{{store direct_url=\"about-magento-demo-store\"}}\">About Us</a></li>\r\n<li class=\"last\"><a href=\"{{store direct_url=\"customer-service\"}}\">Customer Service</a></li>\r\n</ul>',
    'creation_time'     => now(),
    'update_time'       => now(),
));
$connection->insert($installer->getTable('cms/block_store'), array(
    'block_id'   => $connection->lastInsertId(),
    'store_id'  => 0
));
$installer->endSetup();
Биджал Бхавсар
источник
Не следует добавлять контент в базу данных с помощью прямого SQL, если этого можно избежать (что почти всегда). В этом случае вы можете использовать модель cms / block для безопасного добавления данных.
Ян
0

Следующий код создает и обновляет статический блок с использованием сценариев magento.

http://www.pearlbells.co.uk/how-to-create-and-update-the-static-blocks-using-magento-script/

function createBlock($blockData) {

$block = Mage::getModel('cms/block')->load($blockData['identifier']);
$block->setTitle($blockData['title']);
$block->setIdentifier($blockData['identifier']);
$block->setStores(array($blockData['storeId']));
$block->setIsActive($blockData['active']);
$block->setContent($blockData['content']);
$block->save();

}

Лиз Айпе С
источник