salesagility_SuiteCRM/modules/ModuleBuilder/views/view.relationships.php

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));
}
}