Files
crm.twinpol.com/modules/ModuleBuilder/parsers/views/PopupMetaDataParser.php
2025-05-12 15:44:39 +00:00

234 lines
8.7 KiB
PHP
Executable File

<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/*********************************************************************************
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2010 SugarCRM Inc.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero 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 Affero General Public License for more
* details.
*
* You should have received a copy of the GNU Affero 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 Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero 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/views/SearchViewMetaDataParser.php') ;
require_once 'modules/ModuleBuilder/parsers/constants.php' ;
class PopupMetaDataParser 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_AVAILABLE' => 'getAdditionalFields' , 'LBL_HIDDEN' => 'getAvailableFields' ) ;
public static $reserveProperties = array('moduleMain', 'varName' , 'orderBy', 'whereClauses', 'searchInputs', 'create');
public static $defsMap = array(MB_POPUPSEARCH => 'searchdefs' , MB_POPUPLIST => 'listviewdefs');
/*
* 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 ($view, $moduleName , $packageName = '')
{
$this->search = ($view == MB_POPUPSEARCH) ? true : false;
$this->_moduleName = $moduleName;
$this->_packageName = $packageName;
$this->_view = $view ;
$this->columns = array ( 'LBL_DEFAULT' => 'getDefaultFields' , 'LBL_HIDDEN' => 'getAvailableFields' ) ;
if ($this->search)
{
$this->columns = array ( 'LBL_DEFAULT' => 'getSearchFields' , 'LBL_HIDDEN' => 'getAvailableFields' ) ;
parent::__construct ( MB_POPUPSEARCH, $moduleName, $packageName ) ;
} else
{
parent::__construct ( MB_POPUPLIST, $moduleName, $packageName ) ;
}
$this->_viewdefs = $this->mergeFieldDefinitions($this->_viewdefs, $this->_fielddefs);
}
/**
* Dashlets contain both a searchview and list view definition, therefore we need to merge only the relevant info
*/
function mergeFieldDefinitions ( $viewdefs, $fielddefs ) {
$viewdefs = $this->_viewdefs = array_change_key_case($viewdefs );
$viewdefs = $this->_viewdefs = $this->convertSearchToListDefs($viewdefs);
return $viewdefs;
}
function convertSearchToListDefs($defs) {
$temp = array();
foreach($defs as $key=>$value) {
if(!is_array($value)){
$temp[$value] = array('name'=>$value);
}else{
$temp[$key] = $value;
if(isset($value['name']) && $value['name'] != $key){
$temp[$value['name']] = $value;
unset($temp[$key] );
}else if( !isset($value['name']) ){
$temp[$key]['name'] = $key;
}
}
}
return $temp;
}
function getOriginalViewDefs(){
$defs = parent::getOriginalViewDefs();
return $this->convertSearchToListDefs($defs);
}
public function getSearchFields()
{
$searchFields = array ( ) ;
foreach ( $this->_viewdefs as $key => $def )
{
if (isset($this->_fielddefs [ $key ] )) {
$searchFields [ $key ] = self::_trimFieldDefs ( $this->_fielddefs [ $key ] ) ;
if (!empty($def['label']))
$searchFields [ $key ]['label'] = $def['label'];
}
else {
$searchFields [ $key ] = $def;
}
}
return $searchFields ;
}
function handleSave ($populate = true)
{
if (empty ( $this->_packageName ))
{
foreach(array(MB_CUSTOMMETADATALOCATION , MB_BASEMETADATALOCATION) as $value){
$file = $this->implementation->getFileName(MB_POPUPLIST, $this->_moduleName, $value);
if(file_exists($file)){
break;
}
}
$writeFile = $this->implementation->getFileName(MB_POPUPLIST, $this->_moduleName);
if(!file_exists($writeFile)){
mkdir_recursive ( dirname ( $writeFile ) ) ;
}
}
else{
$writeFile = $file = $this->implementation->getFileName(MB_POPUPLIST, $this->_moduleName, $this->_packageName);
}
$this->implementation->_history->append ( $file ) ;
if ($populate)
$this->_populateFromRequest() ;
$out = "<?php\n" ;
//Load current module languages
global $mod_strings , $current_language;
$oldModStrings = $mod_strings;
$GLOBALS['mod_strings'] = return_module_language($current_language , $this->_moduleName);
require($file);
if (!isset($popupMeta)) {
sugar_die ("unable to load Module Popup Definition");
}
if ($this->_view == MB_POPUPSEARCH)
{
foreach($this->_viewdefs as $k => $v){
if(isset($this->_viewdefs[$k]) && isset($this->_viewdefs[$k]['default'])){
unset($this->_viewdefs[$k]['default']);
}
}
$this->_viewdefs = $this->convertSearchToListDefs($this->_viewdefs);
$popupMeta['searchdefs'] = $this->_viewdefs;
$this->addNewSearchDef($this->_viewdefs , $popupMeta);
} else
{
$popupMeta['listviewdefs'] = array_change_key_case($this->_viewdefs , CASE_UPPER );
}
$allProperties = array_merge(self::$reserveProperties , array('searchdefs', 'listviewdefs'));
$out .= "\$popupMeta = array (\n";
foreach( $allProperties as $p){
if(isset($popupMeta[$p])){
$out .= " '$p' => ". var_export_helper ($popupMeta[$p]) . ",\n";
}
}
$out .= ");\n";
file_put_contents($writeFile, $out);
//return back mod strings
$GLOBALS['mod_strings'] = $oldModStrings;
}
public function addNewSearchDef($searchDefs, &$popupMeta){
if(!empty($searchDefs)){
$this->__diffAndUpdate( $searchDefs , $popupMeta['whereClauses'] , true);
$this->__diffAndUpdate( $searchDefs , $popupMeta['searchInputs'] );
}
}
private function __diffAndUpdate($newDefs , &$targetDefs , $forWhere = false){
if(!is_array($targetDefs)){
$targetDefs = array();
}
foreach($newDefs as $key =>$def){
if(!isset($targetDefs[$key]) && $forWhere){
$targetDefs[$key] = $this->__getTargetModuleName($def).'.'.$key;
}else if( !in_array($key , $targetDefs ) && !$forWhere){
array_push($targetDefs , $key);
}
}
if($forWhere){
foreach(array_diff( array_keys($targetDefs) , array_keys($newDefs) ) as $key ){
unset($targetDefs[$key]);
}
}else{
foreach($targetDefs as $key =>$value){
if(!isset($newDefs[$value]))
unset($targetDefs[$key]);
}
}
}
private function __getTargetModuleName($def){
$dir = strtolower($this->implementation->getModuleDir());
if(isset($this->_fielddefs[$def['name']]) && isset($this->_fielddefs[$def['name']]['source']) && $this->_fielddefs[$def['name']]['source'] == 'custom_fields'){
return $dir.'_cstm';
}
return $dir;
}
}
?>