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_Core 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 * Block, that can get data from layout or from registry. 00029 * Can compare its data values by specified keys 00030 * 00031 * @category Mage 00032 * @package Mage_Core 00033 * @author Magento Core Team <core@magentocommerce.com> 00034 */ 00035 class Mage_Core_Block_Template_Facade extends Mage_Core_Block_Template 00036 { 00037 /** 00038 * Just set data, like Varien_Object 00039 * 00040 * This method is to be used in layout. 00041 * In layout it can be understood better, than setSomeKeyBlahBlah() 00042 * 00043 * @param string $key 00044 * @param string $value 00045 */ 00046 public function setDataByKey($key, $value) 00047 { 00048 $this->_data[$key] = $value; 00049 } 00050 00051 /** 00052 * Also set data, but take the value from registry by registry key 00053 * 00054 * @param string $key 00055 * @param string $registryKey 00056 */ 00057 public function setDataByKeyFromRegistry($key, $registryKey) 00058 { 00059 $registryItem = Mage::registry($registryKey); 00060 if (empty($registryItem)) { 00061 return; 00062 } 00063 $value = $registryItem->getData($key); 00064 $this->setDataByKey($key, $value); 00065 } 00066 00067 /** 00068 * Check if data values by specified keys are equal 00069 * $conditionKeys can be array or arbitrary set of params (func_get_args()) 00070 * 00071 * @param array $conditionKeys 00072 * @return bool 00073 */ 00074 public function ifEquals($conditionKeys) 00075 { 00076 if (!is_array($conditionKeys)) { 00077 $conditionKeys = func_get_args(); 00078 } 00079 00080 // evaluate conditions (equality) 00081 if (!empty($conditionKeys)) { 00082 foreach ($conditionKeys as $key) { 00083 if (!isset($this->_data[$key])) { 00084 return false; 00085 } 00086 } 00087 $lastValue = $this->_data[$key]; 00088 foreach ($conditionKeys as $key) { 00089 if ($this->_data[$key] !== $lastValue) { 00090 return false; 00091 } 00092 } 00093 } 00094 return true; 00095 } 00096 }