2 /*********************************************************************************
3 * SugarCRM is a customer relationship management program developed by
4 * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
6 * This program is free software; you can redistribute it and/or modify it under
7 * the terms of the GNU Affero General Public License version 3 as published by the
8 * Free Software Foundation with the addition of the following permission added
9 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
11 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13 * This program is distributed in the hope that it will be useful, but WITHOUT
14 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
18 * You should have received a copy of the GNU Affero General Public License along with
19 * this program; if not, see http://www.gnu.org/licenses or write to the Free
20 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
23 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
24 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26 * The interactive user interfaces in modified source and object code versions
27 * of this program must display Appropriate Legal Notices, as required under
28 * Section 5 of the GNU Affero General Public License version 3.
30 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31 * these Appropriate Legal Notices must retain the display of the "Powered by
32 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
33 * technical reasons, the Appropriate Legal Notices must display the words
34 * "Powered by SugarCRM".
35 ********************************************************************************/
37 require_once('modules/ModuleBuilder/MB/AjaxCompose.php');
39 class ViewModule extends SugarView
42 * @see SugarView::_getModuleTitleParams()
44 protected function _getModuleTitleParams()
49 translate('LBL_MODULE_NAME','Administration'),
50 $mod_strings['LBL_MODULEBUILDER'],
57 $smarty = new Sugar_Smarty();
59 require_once('modules/ModuleBuilder/MB/ModuleBuilder.php');
60 $mb = new ModuleBuilder();
61 $mb->getPackage($_REQUEST['view_package']);
62 $package = $mb->packages[$_REQUEST['view_package']];
63 $module_name = (!empty($_REQUEST['view_module']))?$_REQUEST['view_module']:'';
64 $package->getModule($module_name);
65 $this->module = $package->modules[$module_name];
66 $this->loadPackageHelp($module_name);
68 // set up the list of either available types for a new module, or implemented types for an existing one
69 $types = (empty($module_name)) ? MBModule::getTypes() : $this->module->mbvardefs->templates ;
71 foreach( $types as $type=>$definition)
73 $translated_type[$type]=translate('LBL_TYPE_'.strtoupper($type),'ModuleBuilder');
75 natcasesort($translated_type);
76 $smarty->assign('types',$translated_type);
78 $smarty->assign('package', $package);
79 $smarty->assign('module', $this->module);
80 $smarty->assign('mod_strings', $mod_strings);
82 $ajax = new AjaxCompose();
83 $ajax->addCrumb($GLOBALS['mod_strings']['LBL_MODULEBUILDER'], 'ModuleBuilder.main("mb")');
84 $ajax->addCrumb(' '. $package->name,'ModuleBuilder.getContent("module=ModuleBuilder&action=package&package='.$package->name.'")');
85 if(empty($module_name))$module_name = translate('LBL_NEW_MODULE', 'ModuleBuilder');
86 $ajax->addCrumb($module_name, '');
87 $html=$smarty->fetch('modules/ModuleBuilder/tpls/MBModule/module.tpl');
88 if(!empty($_REQUEST['action']) && $_REQUEST['action']=='SaveModule')
89 $html .="<script>ModuleBuilder.treeRefresh('ModuleBuilder')</script>";
90 $ajax->addSection('center', translate('LBL_SECTION_MODULE', 'ModuleBuilder'), $html);
92 echo $ajax->getJavascript();
95 function loadPackageHelp(
99 $this->module->help['default'] = (empty($name))?'create':'modify';
100 $this->module->help['group'] = 'module';