mirror of
https://github.com/salesagility/SuiteCRM.git
synced 2024-11-22 07:52:36 +00:00
167 lines
8.2 KiB
PHP
Executable File
167 lines
8.2 KiB
PHP
Executable File
<?php
|
|
/**
|
|
*
|
|
* SugarCRM Community Edition is a customer relationship management program developed by
|
|
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
|
|
*
|
|
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
|
|
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
|
|
*
|
|
* 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 and "Supercharged by SuiteCRM" logo. If the display of the logos is not
|
|
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
|
|
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
|
|
*/
|
|
|
|
require_once('modules/ModuleBuilder/MB/AjaxCompose.php') ;
|
|
require_once('modules/ModuleBuilder/MB/ModuleBuilder.php') ;
|
|
require_once('modules/ModuleBuilder/views/view.relationship.php') ;
|
|
require_once('modules/ModuleBuilder/Module/StudioModule.php') ;
|
|
require_once('modules/ModuleBuilder/Module/StudioBrowser.php') ;
|
|
|
|
#[\AllowDynamicProperties]
|
|
class ViewRelationships extends SugarView
|
|
{
|
|
/**
|
|
* @see SugarView::_getModuleTitleParams()
|
|
*/
|
|
protected function _getModuleTitleParams($browserTitle = false)
|
|
{
|
|
global $mod_strings;
|
|
|
|
return array(
|
|
translate('LBL_MODULE_NAME', 'Administration'),
|
|
ModuleBuilderController::getModuleTitle(),
|
|
);
|
|
}
|
|
|
|
public function display()
|
|
{
|
|
$moduleName = ! empty($_REQUEST [ 'view_module' ]) ? $_REQUEST [ 'view_module' ] : $_REQUEST [ 'edit_module' ] ;
|
|
$smarty = new Sugar_Smarty() ;
|
|
// set the mod_strings as we can be called after doing a Repair and the mod_strings are set to Administration
|
|
$GLOBALS['mod_strings'] = return_module_language($GLOBALS['current_language'], 'ModuleBuilder');
|
|
$smarty->assign('mod_strings', $GLOBALS [ 'mod_strings' ]) ;
|
|
$smarty->assign('view_module', $moduleName) ;
|
|
|
|
$ajax = new AjaxCompose() ;
|
|
$json = getJSONobj() ;
|
|
$this->fromModuleBuilder = !empty($_REQUEST [ 'MB' ]) || (!empty($_REQUEST['view_package']) && $_REQUEST['view_package'] != 'studio') ;
|
|
$smarty->assign('fromModuleBuilder', $this->fromModuleBuilder);
|
|
if (!$this->fromModuleBuilder) {
|
|
$smarty->assign('view_package', '') ;
|
|
|
|
$relationships = new DeployedRelationships($moduleName) ;
|
|
$ajaxRelationships = $this->getAjaxRelationships($relationships) ;
|
|
$smarty->assign('relationships', $json->encode($ajaxRelationships)) ;
|
|
$smarty->assign('empty', ((is_countable($ajaxRelationships) ? count($ajaxRelationships) : 0) == 0)) ;
|
|
$smarty->assign('studio', true) ;
|
|
|
|
//crumb
|
|
global $app_list_strings ;
|
|
$moduleNames = array_change_key_case($app_list_strings [ 'moduleList' ]) ;
|
|
$translatedModule = $moduleNames [ strtolower($moduleName) ] ;
|
|
$ajax->addCrumb(translate('LBL_STUDIO'), 'ModuleBuilder.main("studio")') ;
|
|
$ajax->addCrumb($translatedModule, 'ModuleBuilder.getContent("module=ModuleBuilder&action=wizard&view_module=' . $moduleName . '")') ;
|
|
$ajax->addCrumb(translate('LBL_RELATIONSHIPS'), '') ;
|
|
$ajax->addSection('center', $moduleName . ' ' . translate('LBL_RELATIONSHIPS'), $this->fetchTemplate($smarty, 'modules/ModuleBuilder/tpls/studioRelationships.tpl'));
|
|
} else {
|
|
$smarty->assign('view_package', $_REQUEST [ 'view_package' ]) ;
|
|
|
|
$mb = new ModuleBuilder() ;
|
|
$module = & $mb->getPackageModule($_REQUEST [ 'view_package' ], $_REQUEST [ 'view_module' ]) ;
|
|
$package = $mb->packages [ $_REQUEST [ 'view_package' ] ] ;
|
|
$package->loadModuleTitles();
|
|
$relationships = new UndeployedRelationships($module->getModuleDir()) ;
|
|
$ajaxRelationships = $this->getAjaxRelationships($relationships) ;
|
|
$smarty->assign('relationships', $json->encode($ajaxRelationships)) ;
|
|
$smarty->assign('empty', ((is_countable($ajaxRelationships) ? count($ajaxRelationships) : 0) == 0)) ;
|
|
|
|
$module->help [ 'default' ] = (empty($_REQUEST [ 'view_module' ])) ? 'create' : 'modify' ;
|
|
$module->help [ 'group' ] = 'module' ;
|
|
|
|
$ajax->addCrumb(translate('LBL_MODULEBUILDER'), 'ModuleBuilder.main("mb")') ;
|
|
$ajax->addCrumb($package->name, 'ModuleBuilder.getContent("module=ModuleBuilder&action=package&package=' . $package->name . '")') ;
|
|
$ajax->addCrumb($moduleName, 'ModuleBuilder.getContent("module=ModuleBuilder&action=module&view_package=' . $package->name . '&view_module=' . $moduleName . '")') ;
|
|
$ajax->addCrumb(translate('LBL_RELATIONSHIPS'), '') ;
|
|
$ajax->addSection('center', $moduleName . ' ' . translate('LBL_RELATIONSHIPS'), $this->fetchTemplate($smarty, 'modules/ModuleBuilder/tpls/studioRelationships.tpl'));
|
|
}
|
|
echo $ajax->getJavascript() ;
|
|
}
|
|
|
|
/*
|
|
* Encode the relationships for this module for display in the Ext grid layout
|
|
*/
|
|
public function getAjaxRelationships($relationships)
|
|
{
|
|
$ajaxrels = array( ) ;
|
|
foreach ($relationships->getRelationshipList() as $relationshipName) {
|
|
$rel = $relationships->get($relationshipName)->getDefinition() ;
|
|
$rel [ 'lhs_module' ] = translate($rel [ 'lhs_module' ]) ;
|
|
$rel [ 'rhs_module' ] = translate($rel [ 'rhs_module' ]) ;
|
|
|
|
//#28668 , translate the relationship type before render it .
|
|
switch ($rel['relationship_type']) {
|
|
case 'one-to-one':
|
|
$rel['relationship_type'] = translate('LBL_ONETOONE');
|
|
break;
|
|
case 'one-to-many':
|
|
$rel['relationship_type'] = translate('LBL_ONETOMANY');
|
|
break;
|
|
case 'many-to-one':
|
|
$rel['relationship_type'] = translate('LBL_MANYTOONE');
|
|
break;
|
|
case 'many-to-many':
|
|
$rel['relationship_type'] = translate('LBL_MANYTOMANY');
|
|
break;
|
|
default: $rel['relationship_type'] = '';
|
|
}
|
|
$rel [ 'name' ] = $relationshipName ;
|
|
if ($rel [ 'is_custom' ] && isset($rel [ 'from_studio' ]) && $rel [ 'from_studio' ]) {
|
|
$rel [ 'name' ] = $relationshipName . "*";
|
|
}
|
|
$ajaxrels [] = $rel ;
|
|
}
|
|
return $ajaxrels ;
|
|
}
|
|
|
|
/**
|
|
* fetchTemplate
|
|
* This function overrides fetchTemplate from SugarView.
|
|
*
|
|
* @param FieldViewer $mixed the Sugar_Smarty instance
|
|
* @param string $template the file to fetch
|
|
* @return string contents from calling the fetch method on the Sugar_Smarty instance
|
|
*/
|
|
protected function fetchTemplate($smarty/*, $template*/)
|
|
{
|
|
$template = func_get_arg(1);
|
|
return $smarty->fetch($this->getCustomFilePathIfExists($template));
|
|
}
|
|
}
|