searchviewmetadataparser.php
来自「SugarCRM5.1 开源PHP客户关系管理系统」· PHP 代码 · 共 133 行
PHP
133 行
<?phpif(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');/********************************************************************************* * SugarCRM is a customer relationship management program developed by * SugarCRM, Inc. Copyright (C) 2004 - 2007 SugarCRM Inc. * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License version 3 as published by the * Free Software Foundation with the addition of the following permission added * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program; if not, see http://www.gnu.org/licenses or write to the Free * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. * * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road, * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU General Public License version 3. * * In accordance with Section 7(b) of the GNU General Public License version 3, * these Appropriate Legal Notices must retain the display of the "Powered by * SugarCRM" logo. If the display of the logo is not reasonably feasible for * technical reasons, the Appropriate Legal Notices must display the words * "Powered by SugarCRM". *********************************************************************************/require_once ('modules/ModuleBuilder/parsers/views/ListLayoutMetaDataParser.php') ;require_once 'modules/ModuleBuilder/parsers/constants.php' ;class SearchViewMetaDataParser extends ListLayoutMetaDataParser{ // Columns is used by the view to construct the listview - each column is built by calling the named function public $columns = array ( 'LBL_DEFAULT' => 'getDefaultFields' , 'LBL_HIDDEN' => 'getAvailableFields' ) ; /* * Constructor * Must set: * $this->columns Array of 'Column LBL'=>function_to_retrieve_fields_for_this_column() - expected by the view * * @param string moduleName The name of the module to which this listview belongs * @param string packageName If not empty, the name of the package to which this listview belongs */ function __construct ($searchLayout, $moduleName , $packageName = '') { $GLOBALS [ 'log' ]->debug ( get_class ( $this ) . ": __construct( $searchLayout , $moduleName , $packageName )" ) ; $this->_searchLayout = $searchLayout ; $this->_view = $searchLayout; // BEGIN ASSERTIONS if ($searchLayout != 'basic_search' && $searchLayout != 'advanced_search') { sugar_die ( "SearchLayoutMetaDataParser: View $searchLayout is not supported" ) ; } // END ASSERTIONS if (empty ( $packageName )) { require_once 'modules/ModuleBuilder/parsers/views/DeployedMetaDataImplementation.php' ; $this->implementation = new DeployedMetaDataImplementation ( MB_SEARCHVIEW, $moduleName ) ; } else { require_once 'modules/ModuleBuilder/parsers/views/UndeployedMetaDataImplementation.php' ; $this->implementation = new UndeployedMetaDataImplementation ( MB_SEARCHVIEW, $moduleName, $packageName ) ; } $this->_saved = array_change_key_case ( $this->implementation->getViewdefs () ) ; // force to lower case so don't have problems with case mismatches later if(isset($this->_saved['templatemeta'])) {
$this->_saved['templateMeta'] = $this->_saved['templatemeta'];
unset($this->_saved['templatemeta']);
}
// convert the search view layout (which has it's own unique layout form) to the standard listview layout so that the parser methods and views can be reused $this->_viewdefs = $this->convertSearchViewToListView ( $this->_saved [ 'layout' ] [ $this->_searchLayout ] ) ; $this->_fielddefs = $this->mergeFieldDefinitions ( $this->_viewdefs, $this->implementation->getModuleFieldDefs () ); // Now create the merged list of field definitions - the definition comes from the module, overridden by any values set in the viewdef for the field //$GLOBALS['log']->debug( get_class($this)."->__construct(): _viewdefs = ".print_r($this->_viewdefs,true)); } /* * Save the modified searchLayout * Have to preserve the original layout format, which is array('metadata'=>array,'layouts'=>array('basic'=>array,'advanced'=>array)) */ function handleSave () { $this->_populateFromRequest() ; $this->_saved [ 'layout' ] [ $this->_searchLayout ] = $this->convertSearchViewToListView($this->_viewdefs);; $this->implementation->deploy ( $this->_saved ) ; } private function convertSearchViewToListView ($viewdefs) {
$temp = array ( ) ; foreach ( $viewdefs as $key => $value ) { if (! is_array ( $value )) { $key = $value ; $def = array ( ) ; $def[ 'name' ] = $key; $value = $def ; }
if (!isset ( $value [ 'name' ] ))
{
$value [ 'name' ] = $key;
} else { $key = $value [ 'name' ] ; // override key with name, needed when the entry lacks a key } // now add in the standard listview default=>true $value [ 'default' ] = true ; $temp [ strtolower ( $key ) ] = $value ; } return $temp ; }}?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?