00001 <?php 00002 /** 00003 * Magento 00004 * 00005 * NOTICE OF LICENSE 00006 * 00007 * This source file is subject to the Open Software License (OSL 3.0) 00008 * that is bundled with this package in the file LICENSE.txt. 00009 * It is also available through the world-wide-web at this URL: 00010 * http://opensource.org/licenses/osl-3.0.php 00011 * If you did not receive a copy of the license and are unable to 00012 * obtain it through the world-wide-web, please send an email 00013 * to license@magentocommerce.com so we can send you a copy immediately. 00014 * 00015 * DISCLAIMER 00016 * 00017 * Do not edit or add to this file if you wish to upgrade Magento to newer 00018 * versions in the future. If you wish to customize Magento for your 00019 * needs please refer to http://www.magentocommerce.com for more information. 00020 * 00021 * @category Mage 00022 * @package Mage_Cms 00023 * @copyright Copyright (c) 2008 Irubin Consulting Inc. DBA Varien (http://www.varien.com) 00024 * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) 00025 */ 00026 00027 /** 00028 * CMS block model 00029 * 00030 * @category Mage 00031 * @package Mage_Cms 00032 * @author Magento Core Team <core@magentocommerce.com> 00033 */ 00034 00035 class Mage_Cms_Model_Mysql4_Block_Collection extends Mage_Core_Model_Mysql4_Collection_Abstract 00036 { 00037 00038 protected function _construct() 00039 { 00040 $this->_init('cms/block'); 00041 } 00042 00043 public function toOptionArray() 00044 { 00045 return $this->_toOptionArray('block_id', 'title'); 00046 } 00047 00048 /** 00049 * Add Filter by store 00050 * 00051 * @param int|Mage_Core_Model_Store $store 00052 * @return Mage_Cms_Model_Mysql4_Page_Collection 00053 */ 00054 public function addStoreFilter($store, $withAdmin = true) 00055 { 00056 if ($store instanceof Mage_Core_Model_Store) { 00057 $store = array($store->getId()); 00058 } 00059 00060 $this->getSelect()->join( 00061 array('store_table' => $this->getTable('cms/block_store')), 00062 'main_table.block_id = store_table.block_id', 00063 array() 00064 ) 00065 ->where('store_table.store_id in (?)', ($withAdmin ? array(0, $store) : $store)) 00066 ->group('main_table.block_id'); 00067 00068 return $this; 00069 } 00070 }