Додавання блоку 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 є блоком навряд чи помилка, тому версію функції потрібно не змінювати. 😜
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'
);

Також ось корисна стаття


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();

}

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.