Edit file File name : UserViewHelper.php Content :<?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". */ if (!defined('sugarEntry') || !sugarEntry) { die('Not A Valid Entry Point'); } /** * This helper handles the rest of the fields for the Users Edit and Detail views. * There are a lot of fields on those views that do not map directly to being used on the metadata based UI, so they are handled here. */ class UserViewHelper { /** * The smarty template handler for the template * @var SugarSmarty */ protected $ss; /** * The bean that we are viewing. * @var SugarBean */ protected $bean; /** * What type of view we are looking at, valid values are 'EditView' and 'DetailView' * @var string */ protected $viewType; /** * Is the current user an admin for the Users module * @var bool */ protected $is_current_admin; /** * Is the current user a system wide admin * @var bool */ protected $is_super_admin; /** * The current user type * One of: REGULAR ADMIN GROUP PORTAL_ONLY * @var string */ public $usertype; /** * Constructor, pass in the smarty template, the bean and the viewtype */ public function __construct(Sugar_Smarty &$smarty, SugarBean &$bean, $viewType = 'EditView') { $this->ss = $smarty; $this->bean = $bean; $this->viewType = $viewType; } /** * This function populates the smarty class that was passed in through the constructor */ public function setupAdditionalFields() { $this->assignUserTypes(); $this->setupButtonsAndTabs(); $this->setupUserTypeDropdown(); $this->setupPasswordTab(); $this->setupEmailSettings(); $this->setupThemeTab(); $this->setupAdvancedTab(); } protected function assignUserTypes() { global $current_user, $app_list_strings; // There is a lot of extra stuff that needs to go in here to properly render $this->is_current_admin = is_admin($current_user) || $current_user->isAdminForModule('Users'); $this->is_super_admin = is_admin($current_user); $this->usertype = 'REGULAR'; if ($this->is_super_admin) { $this->usertype = 'Administrator'; } // check if the user has access to the User Management $this->ss->assign('USER_ADMIN', $current_user->isAdminForModule('Users') && !is_admin($current_user)); if ($this->is_current_admin) { $this->ss->assign('IS_ADMIN', '1'); } else { $this->ss->assign('IS_ADMIN', '0'); } if ($this->is_super_admin) { $this->ss->assign('IS_SUPER_ADMIN', '1'); } else { $this->ss->assign('IS_SUPER_ADMIN', '0'); } $this->ss->assign('IS_PORTALONLY', '0'); $this->ss->assign('IS_GROUP', '0'); if ((!empty($this->bean->is_group) && $this->bean->is_group) || (isset($_REQUEST['usertype']) && $_REQUEST['usertype'] == 'group')) { $this->ss->assign('IS_GROUP', '1'); $this->usertype = 'GROUP'; } $edit_self = $current_user->id == $this->bean->id; $admin_edit_self = is_admin($current_user) && $edit_self; if (isset($_REQUEST['showEmailSettingsPopup']) && $_REQUEST['showEmailSettingsPopup']) { $this->ss->assign('showEmailSettingsPopup', true); } $this->ss->assign('IS_FOCUS_ADMIN', is_admin($this->bean)); if ($edit_self) { $this->ss->assign('EDIT_SELF', '1'); } if ($admin_edit_self) { $this->ss->assign('ADMIN_EDIT_SELF', '1'); } } protected function setupButtonsAndTabs() { global $current_user; if (isset($GLOBALS['sugar_config']['show_download_tab'])) { $enable_download_tab = $GLOBALS['sugar_config']['show_download_tab']; } else { $enable_download_tab = true; } $this->ss->assign('SHOW_DOWNLOADS_TAB', $enable_download_tab); $the_query_string = 'module=Users&action=DetailView'; if (isset($_REQUEST['record'])) { $the_query_string .= '&record=' . $_REQUEST['record']; } $buttons_header = array(); $buttons_footer = array(); if (!$this->bean->is_group) { if ($this->bean->id == $current_user->id) { $reset_pref_warning = translate('LBL_RESET_PREFERENCES_WARNING', 'Users'); $reset_home_warning = translate('LBL_RESET_HOMEPAGE_WARNING', 'Users'); } else { $reset_pref_warning = translate('LBL_RESET_PREFERENCES_WARNING_USER', 'Users'); $reset_home_warning = translate('LBL_RESET_HOMEPAGE_WARNING_USER', 'Users'); } //bug 48170 $user_preference_url = "module=Users&action=resetPreferences"; if (isset($_REQUEST['record'])) { $user_preference_url .= "&record=" . $_REQUEST['record']; } $buttons_header[] = "<input type='button' class='button' id='reset_user_preferences_header' onclick='if(confirm(\"{$reset_pref_warning}\"))window.location=\"" . $_SERVER['PHP_SELF'] . '?' . $user_preference_url . "&reset_preferences=true\";' value='" . translate('LBL_RESET_PREFERENCES', 'Users') . "' />"; $buttons_header[] = "<input type='button' class='button' id='reset_homepage_header' onclick='if(confirm(\"{$reset_home_warning}\"))window.location=\"" . $_SERVER['PHP_SELF'] . '?' . $the_query_string . "&reset_homepage=true\";' value='" . translate('LBL_RESET_HOMEPAGE', 'Users') . "' />"; $buttons_footer[] = "<input type='button' class='button' id='reset_user_preferences_footer' onclick='if(confirm(\"{$reset_pref_warning}\"))window.location=\"" . $_SERVER['PHP_SELF'] . '?' . $user_preference_url . "&reset_preferences=true\";' value='" . translate('LBL_RESET_PREFERENCES', 'Users') . "' />"; $buttons_footer[] = "<input type='button' class='button' id='reset_homepage_footer' onclick='if(confirm(\"{$reset_home_warning}\"))window.location=\"" . $_SERVER['PHP_SELF'] . '?' . $the_query_string . "&reset_homepage=true\";' value='" . translate('LBL_RESET_HOMEPAGE', 'Users') . "' />"; } if (isset($buttons_header)) { $this->ss->assign("BUTTONS_HEADER", $buttons_header); } if (isset($buttons_footer)) { $this->ss->assign("BUTTONS_FOOTER", $buttons_footer); } if (isset($this->bean->id)) { $this->ss->assign('ID', $this->bean->id); } } /** * setupUserTypeDropdown * * This function handles setting up the user type dropdown field. It determines which user types are available for the current user. * At the end of the function two Smarty variables (USER_TYPE_DROPDOWN and USER_TYPE_READONLY) are assigned. * */ public function setupUserTypeDropdown() { global $current_user; //if this is an existing bean and the type is empty, then populate user type if (!empty($this->bean->id) && empty($this->bean->user_type)) { $this->setUserType($this->bean); $userType = $this->bean->user_type; } else { $userType = $this->usertype; } $availableUserTypes = array(); $userTypes = array( 'RegularUser' => array( 'label' => translate('LBL_REGULAR_USER', 'Users'), 'description' => translate('LBL_REGULAR_DESC', 'Users'), ), 'GROUP' => array( 'label' => translate('LBL_GROUP_USER', 'Users'), 'description' => translate('LBL_GROUP_DESC', 'Users'), ), 'Administrator' => array( 'label' => translate('LBL_ADMIN_USER', 'Users'), 'description' => translate('LBL_ADMIN_DESC', 'Users'), ), ); if ($userType == 'GROUP' || $userType == 'PORTAL_ONLY') { $availableUserTypes = array($this->usertype); } else { if ($this->ss->get_template_vars('USER_ADMIN')) { $availableUserTypes = array('RegularUser'); } elseif ($this->ss->get_template_vars('ADMIN_EDIT_SELF')) { $availableUserTypes = array('Administrator'); } elseif ($this->ss->get_template_vars('IS_SUPER_ADMIN')) { $availableUserTypes = array( 'RegularUser', 'Administrator', ); } else { $availableUserTypes = array($userType); } } $userTypeDropdown = '<select id="UserType" name="UserType" onchange="user_status_display(this);" '; if (count($availableUserTypes) == 1) { $userTypeDropdown .= ' disabled '; } $userTypeDropdown .= '>'; $userTypeDescription = ''; $setSelected = !empty($this->bean->id); foreach ($availableUserTypes as $currType) { if ($setSelected && $currType == $userType) { $userTypeDropdown .= '<option value="' . $currType . '" SELECTED>' . $userTypes[$currType]['label'] . '</option>'; } else { $userTypeDropdown .= '<option value="' . $currType . '">' . $userTypes[$currType]['label'] . '</option>'; } } $userTypeDropdown .= '</select><div id="UserTypeDesc"> </div>'; $this->ss->assign('USER_TYPE_DROPDOWN', $userTypeDropdown); $this->ss->assign('USER_TYPE_READONLY', $userTypes[$userType]['label'] . "<input type='hidden' id='UserType' value='{$userType}'><div id='UserTypeDesc'> </div>"); } protected function setupPasswordTab() { global $current_user; $this->ss->assign('PWDSETTINGS', isset($GLOBALS['sugar_config']['passwordsetting']) ? $GLOBALS['sugar_config']['passwordsetting'] : array()); $enable_syst_generate_pwd = false; if (isset($GLOBALS['sugar_config']['passwordsetting']) && isset($GLOBALS['sugar_config']['passwordsetting']['SystemGeneratedPasswordON'])) { $enable_syst_generate_pwd = $GLOBALS['sugar_config']['passwordsetting']['SystemGeneratedPasswordON']; } // If new regular user without system generated password or new portal user if (((isset($enable_syst_generate_pwd) && !$enable_syst_generate_pwd && $this->usertype != 'GROUP') || $this->usertype == 'PORTAL_ONLY') && empty($this->bean->id)) { $this->ss->assign('REQUIRED_PASSWORD', '1'); } else { $this->ss->assign('REQUIRED_PASSWORD', '0'); } // If my account page or portal only user or regular user without system generated password or a duplicate user if ((($current_user->id == $this->bean->id) || $this->usertype == 'PORTAL_ONLY' || (($this->usertype == 'REGULAR' || $this->usertype == 'Administrator' || (isset($_REQUEST['isDuplicate']) && $_REQUEST['isDuplicate'] == 'true' && $this->usertype != 'GROUP')) && !$enable_syst_generate_pwd)) && !$this->bean->external_auth_only) { $this->ss->assign('CHANGE_PWD', '1'); } else { $this->ss->assign('CHANGE_PWD', '0'); } // Make sure group users don't get a password change prompt if ($this->usertype == 'GROUP') { $this->ss->assign('CHANGE_PWD', '0'); } $configurator = new Configurator(); if (isset($configurator->config['passwordsetting']) && ($configurator->config['passwordsetting']['SystemGeneratedPasswordON'] || $configurator->config['passwordsetting']['forgotpasswordON']) && $this->usertype != 'GROUP' && $this->usertype != 'PORTAL_ONLY') { $this->ss->assign('REQUIRED_EMAIL_ADDRESS', '1'); } else { $this->ss->assign('REQUIRED_EMAIL_ADDRESS', '0'); } if ($this->usertype == 'GROUP' || $this->usertype == 'PORTAL_ONLY') { $this->ss->assign('HIDE_FOR_GROUP_AND_PORTAL', 'none'); $this->ss->assign('HIDE_CHANGE_USERTYPE', 'none'); $this->ss->assign('HIDE_IF_GAUTH_UNCONFIGURED', 'none'); } else { $this->ss->assign('HIDE_FOR_NORMAL_AND_ADMIN', 'none'); if (!$this->is_current_admin) { $this->ss->assign('HIDE_CHANGE_USERTYPE', 'none'); } else { $this->ss->assign('HIDE_STATIC_USERTYPE', 'none'); } } } protected function setupThemeTab() { $user_theme = $this->bean->getPreference('user_theme'); if (isset($user_theme)) { $this->ss->assign("THEMES", get_select_options_with_id(SugarThemeRegistry::availableThemes(), $user_theme)); } else { $this->ss->assign("THEMES", get_select_options_with_id(SugarThemeRegistry::availableThemes(), $GLOBALS['sugar_config']['default_theme'])); } $this->ss->assign("SHOW_THEMES", count(SugarThemeRegistry::availableThemes()) > 1); $this->ss->assign("USER_THEME_COLOR", $this->bean->getPreference('user_theme_color')); $this->ss->assign("USER_THEME_FONT", $this->bean->getPreference('user_theme_font')); $this->ss->assign("USER_THEME", $user_theme); // Build a list of themes that support group modules $this->ss->assign("DISPLAY_GROUP_TAB", 'none'); $selectedTheme = $user_theme; if (!isset($user_theme)) { $selectedTheme = $GLOBALS['sugar_config']['default_theme']; } $themeList = SugarThemeRegistry::availableThemes(); $themeGroupList = array(); foreach ($themeList as $themeId => $themeName) { $currThemeObj = SugarThemeRegistry::get($themeId); if (isset($currThemeObj->group_tabs) && $currThemeObj->group_tabs == 1) { $themeGroupList[$themeId] = true; if ($themeId == $selectedTheme) { $this->ss->assign("DISPLAY_GROUP_TAB", ''); } } else { $themeGroupList[$themeId] = false; } } $this->ss->assign("themeGroupListJSON", json_encode($themeGroupList)); } /** * setup advanced tab */ protected function setupAdvancedTab() { $this->setupAdvancedTabUserSettings(); $this->setupAdvancedTabTeamSettings(); $this->setupAdvancedTabNavSettings(); $this->setupAdvancedTabLocaleSettings(); $this->setupAdvancedTabPdfSettings(); } protected function setupAdvancedTabUserSettings() { global $current_user, $locale, $app_strings, $app_list_strings, $sugar_config; // This is for the "Advanced" tab, it's not controlled by the metadata UI so we have to do more for it. $this->ss->assign('EXPORT_DELIMITER', $this->bean->getPreference('export_delimiter')); if ($this->bean->receive_notifications || (!isset($this->bean->id) && $admin->settings['notify_send_by_default'])) { $this->ss->assign("RECEIVE_NOTIFICATIONS", "checked"); } //jc:12293 - modifying to use the accessor method which will translate the //available character sets using the translation files $export_charset = $locale->getExportCharset('', $this->bean); $export_charset_options = $locale->getCharsetSelect(); $this->ss->assign('EXPORT_CHARSET', get_select_options_with_id($export_charset_options, $export_charset)); $this->ss->assign('EXPORT_CHARSET_DISPLAY', $export_charset); //end:12293 if ($this->bean->getPreference('use_real_names') == 'on' || (empty($this->bean->id) && isset($GLOBALS['sugar_config']['use_real_names']) && $GLOBALS['sugar_config']['use_real_names'] && $this->bean->getPreference('use_real_names') != 'off')) { $this->ss->assign('USE_REAL_NAMES', 'CHECKED'); } if ($this->bean->getPreference('mailmerge_on') == 'on') { $this->ss->assign('MAILMERGE_ON', 'checked'); } if ($this->bean->getPreference('no_opps') == 'on') { $this->ss->assign('NO_OPPS', 'CHECKED'); } $reminder_time = $this->bean->getPreference('reminder_time'); if (empty($reminder_time)) { $reminder_time = -1; } $email_reminder_time = $this->bean->getPreference('email_reminder_time'); if (empty($email_reminder_time)) { $email_reminder_time = -1; } $this->ss->assign("REMINDER_TIME_OPTIONS", $app_list_strings['reminder_time_options']); $this->ss->assign("EMAIL_REMINDER_TIME_OPTIONS", $app_list_strings['reminder_time_options']); $this->ss->assign("REMINDER_TIME", $reminder_time); $this->ss->assign("EMAIL_REMINDER_TIME", $email_reminder_time); $remindersDefaultPreferences = Reminder::loadRemindersDefaultValuesData($this->bean); $this->ss->assign("REMINDER_CHECKED", $remindersDefaultPreferences['popup']); $this->ss->assign("EMAIL_REMINDER_CHECKED", $remindersDefaultPreferences['email']); $this->ss->assign("REMINDER_TABINDEX", "12"); $publish_key = $this->bean->getPreference('calendar_publish_key'); $this->ss->assign('CALENDAR_PUBLISH_KEY', $publish_key); $publish_url = $sugar_config['site_url'] . '/vcal_server.php'; $token = "/"; //determine if the web server is running IIS //if so then change the publish url if (isset($_SERVER) && !empty($_SERVER['SERVER_SOFTWARE'])) { $position = strpos(strtolower($_SERVER['SERVER_SOFTWARE']), 'iis'); if ($position !== false) { $token = '?parms='; } } $publish_url .= $token . "type=vfb&source=outlook&key=<span id=\"cal_pub_key_span\">$publish_key</span>"; if (!empty($this->bean->email1)) { $publish_url .= '&email=' . $this->bean->email1; } else { $publish_url .= '&user_name=' . $this->bean->user_name; } $ical_url = $sugar_config['site_url'] . "/ical_server.php?type=ics&key=<span id=\"ical_pub_key_span\">$publish_key</span>"; if (!empty($this->bean->email1)) { $ical_url .= '&email=' . $this->bean->email1; } else { $ical_url .= '&user_name=' . $this->bean->user_name; } $this->ss->assign("CALENDAR_PUBLISH_URL", $publish_url); $this->ss->assign("CALENDAR_SEARCH_URL", $sugar_config['site_url'] . "/vcal_server.php/type=vfb&key=<span id=\"search_pub_key_span\">$publish_key</span>&email=%NAME%@%SERVER%"); $this->ss->assign("CALENDAR_ICAL_URL", $ical_url); $this->ss->assign("SETTINGS_URL", $sugar_config['site_url']); // Set Google Auth variables $this->setGoogleAuthVariables($sugar_config); } /** * Set Google Auth variables * * @param array $sugar_config */ protected function setGoogleAuthVariables($sugar_config) { $this->ss->assign("GOOGLE_API_TOKEN_ENABLE_NEW", "none"); // Hide new token button by default $this->ss->assign("GOOGLE_API_TOKEN_NEW_URL", $sugar_config['site_url'] . "/index.php?entryPoint=saveGoogleApiKey&getnew"); $this->ss->assign("GOOGLE_API_TOKEN_BTN", "Disabled"); if (isset($sugar_config['google_auth_json']) && !empty($sugar_config['google_auth_json'])) { $json = base64_decode($sugar_config['google_auth_json']); if (!$config = json_decode($json, true)) { // Check if the JSON is valid $this->ss->assign("GOOGLE_API_TOKEN", "INVALID AUTH KEY"); $this->ss->assign("GOOGLE_API_TOKEN_COLOR", "red"); $this->ss->assign("GOOGLE_API_TOKEN_ENABLE_NEW", "inline"); } else { $this->setGoogleAuthAccessToken(); } } else { $this->ss->assign("GOOGLE_API_TOKEN", "DISABLED"); $this->ss->assign("GOOGLE_API_TOKEN_COLOR", "black"); $this->ss->assign("HIDE_IF_GAUTH_UNCONFIGURED", "none"); } if ($this->bean->getPreference('syncGCal', 'GoogleSync') == '1') { $this->ss->assign('GSYNC_CAL', ' checked'); } } /** * set Google Auth Access Token in template */ protected function setGoogleAuthAccessToken() { $accessToken = json_decode(base64_decode($this->bean->getPreference('GoogleApiToken', 'GoogleSync'))); if (!empty($this->bean->getPreference('GoogleApiToken', 'GoogleSync')) && $accessToken = json_decode(base64_decode($this->bean->getPreference('GoogleApiToken', 'GoogleSync')))) { // Check if the user has a token $this->ss->assign("GOOGLE_API_TOKEN", "CONFIGURED"); $this->ss->assign("GOOGLE_API_TOKEN_COLOR", "green"); $this->ss->assign("GOOGLE_API_TOKEN_BTN", "Reauthorize"); $this->ss->assign("GOOGLE_API_TOKEN_ENABLE_NEW", "inline"); } else { $this->ss->assign("GOOGLE_API_TOKEN", "UNCONFIGURED"); $this->ss->assign("GOOGLE_API_TOKEN_COLOR", "black"); $this->ss->assign("GOOGLE_API_TOKEN_ENABLE_NEW", "inline"); $this->ss->assign("GOOGLE_API_TOKEN_BTN", "Authorize"); } } protected function setupAdvancedTabTeamSettings() { global $sugar_config; $authclass = ''; if (!empty($sugar_config['authenticationClass'])) { $this->ss->assign('EXTERNAL_AUTH_CLASS_1', $sugar_config['authenticationClass']); $this->ss->assign('EXTERNAL_AUTH_CLASS', $sugar_config['authenticationClass']); $authclass = $sugar_config['authenticationClass']; } else { if (!empty($GLOBALS['system_config']->settings['system_ldap_enabled'])) { $this->ss->assign('EXTERNAL_AUTH_CLASS_1', translate('LBL_LDAP', 'Users')); $this->ss ->assign('EXTERNAL_AUTH_CLASS', translate('LBL_LDAP_AUTHENTICATION', 'Users')); $authclass = 'LDAPAuthenticate'; } } if (!empty($this->bean->external_auth_only)) { $this->ss->assign('EXTERNAL_AUTH_ONLY_CHECKED', 'CHECKED'); } if ($this->is_super_admin && !empty($authclass)) { $this->ss->assign('DISPLAY_EXTERNAL_AUTH', true); } } protected function setupAdvancedTabNavSettings() { global $app_list_strings; // Grouped tabs? $useGroupTabs = $this->bean->getPreference('navigation_paradigm'); if (!isset($useGroupTabs)) { if (!isset($GLOBALS['sugar_config']['default_navigation_paradigm'])) { $GLOBALS['sugar_config']['default_navigation_paradigm'] = 'gm'; } $useGroupTabs = $GLOBALS['sugar_config']['default_navigation_paradigm']; } $this->ss->assign("USE_GROUP_TABS", ($useGroupTabs == 'gm') ? 'checked' : ''); if ($this->bean->getPreference('sort_modules_by_name')) { $this->ss->assign('SORT_MODULES_BY_NAME', ' checked'); } $user_subpanel_tabs = $this->bean->getPreference('subpanel_tabs'); if (isset($user_subpanel_tabs)) { $this->ss->assign("SUBPANEL_TABS", $user_subpanel_tabs ? 'checked' : ''); } else { $this->ss->assign("SUBPANEL_TABS", $GLOBALS['sugar_config']['default_subpanel_tabs'] ? 'checked' : ''); } if ($this->bean->getPreference('count_collapsed_subpanels')) { $this->ss->assign("COUNT_COLLAPSED_SUBPANELS", 'checked'); } /* Module Tab Chooser */ require_once(get_custom_file_if_exists('include/templates/TemplateGroupChooser.php')); require_once(get_custom_file_if_exists('modules/MySettings/TabController.php')); $chooser = new TemplateGroupChooser(); $controller = new TabController(); if ($this->is_current_admin || $controller->get_users_can_edit()) { $chooser->display_hide_tabs = true; } else { $chooser->display_hide_tabs = false; } $chooser->args['id'] = 'edit_tabs'; $chooser->args['values_array'] = $controller->get_tabs($this->bean); foreach ($chooser->args['values_array'][0] as $key => $value) { $chooser->args['values_array'][0][$key] = $app_list_strings['moduleList'][$key]; } foreach ($chooser->args['values_array'][1] as $key => $value) { $chooser->args['values_array'][1][$key] = $app_list_strings['moduleList'][$key]; } foreach ($chooser->args['values_array'][2] as $key => $value) { $chooser->args['values_array'][2][$key] = $app_list_strings['moduleList'][$key]; } $chooser->args['left_name'] = 'display_tabs'; $chooser->args['right_name'] = 'hide_tabs'; $chooser->args['left_label'] = translate('LBL_DISPLAY_TABS', 'Users'); $chooser->args['right_label'] = translate('LBL_HIDE_TABS', 'Users'); require_once(get_custom_file_if_exists('include/Smarty/plugins/function.sugar_help.php')); $chooser->args['title'] = translate('LBL_EDIT_TABS', 'Users') . smarty_function_sugar_help(array("text" => translate('LBL_CHOOSE_WHICH', 'Users')), $ss); $this->ss->assign('TAB_CHOOSER', $chooser->display()); $this->ss->assign('CHOOSER_SCRIPT', 'set_chooser();'); $this->ss->assign('CHOOSE_WHICH', translate('LBL_CHOOSE_WHICH', 'Users')); } protected function setupAdvancedTabLocaleSettings() { global $locale, $sugar_config, $app_list_strings; /////////////////////////////////////////////////////////////////////////////// //// LOCALE SETTINGS //// Date/time format $dformat = $locale->getPrecedentPreference($this->bean->id ? 'datef' : 'default_date_format', $this->bean); $tformat = $locale->getPrecedentPreference($this->bean->id ? 'timef' : 'default_time_format', $this->bean); $nformat = $locale->getPrecedentPreference('default_locale_name_format', $this->bean); if (!array_key_exists($nformat, $sugar_config['name_formats'])) { $nformat = $sugar_config['default_locale_name_format']; } $timeOptions = get_select_options_with_id($sugar_config['time_formats'], $tformat); $dateOptions = get_select_options_with_id($sugar_config['date_formats'], $dformat); $nameOptions = get_select_options_with_id($locale->getUsableLocaleNameOptions($sugar_config['name_formats']), $nformat); $this->ss->assign('TIMEOPTIONS', $timeOptions); $this->ss->assign('DATEOPTIONS', $dateOptions); $this->ss->assign('NAMEOPTIONS', $nameOptions); $this->ss->assign('DATEFORMAT', $sugar_config['date_formats'][$dformat]); $this->ss->assign('TIMEFORMAT', $sugar_config['time_formats'][$tformat]); $this->ss->assign('NAMEFORMAT', $sugar_config['name_formats'][$nformat]); //// Timezone if (empty($this->bean->id)) { // remove default timezone for new users(set later) $this->bean->user_preferences['timezone'] = ''; } $userTZ = $this->bean->getPreference('timezone'); if (empty($userTZ) && !$this->bean->is_group && !$this->bean->portal_only) { $userTZ = TimeDate::guessTimezone(); $this->bean->setPreference('timezone', $userTZ); } if (!$this->bean->getPreference('ut')) { $this->ss->assign('PROMPTTZ', ' checked'); } $this->ss->assign('TIMEZONE_CURRENT', $userTZ); $this->ss->assign('TIMEZONEOPTIONS', TimeDate::getTimezoneList()); $this->ss->assign("TIMEZONE", TimeDate::tzName($userTZ)); // FG - Bug 4236 - Managed First Day of Week $fdowDays = array(); foreach ($app_list_strings['dom_cal_day_long'] as $d) { if ($d != "") { $fdowDays[] = $d; } } $this->ss->assign("FDOWOPTIONS", $fdowDays); $currentFDOW = $this->bean->get_first_day_of_week(); if (!isset($currentFDOW)) { $currentFDOW = 0; } $this->ss->assign("FDOWCURRENT", $currentFDOW); $this->ss->assign("FDOWDISPLAY", $fdowDays[$currentFDOW]); //// Numbers and Currency display require_once(get_custom_file_if_exists('modules/Currencies/ListCurrency.php')); $currency = new ListCurrency(); // 10/13/2006 Collin - Changed to use Localization.getConfigPreference // This was the problem- Previously, the "-99" currency id always assumed // to be defaulted to US Dollars. However, if someone set their install to use // Euro or other type of currency then this setting would not apply as the // default because it was being overridden by US Dollars. $cur_id = $locale->getPrecedentPreference('currency', $this->bean); if ($cur_id) { $selectCurrency = $currency->getSelectOptions($cur_id); $this->ss->assign("CURRENCY", $selectCurrency); } else { $selectCurrency = $currency->getSelectOptions(); $this->ss->assign("CURRENCY", $selectCurrency); } $currencyList = array(); foreach ($locale->currencies as $id => $val) { $currencyList[$id] = $val['symbol']; } $currencySymbolJSON = json_encode($currencyList); $this->ss->assign('currencySymbolJSON', $currencySymbolJSON); $currencyDisplay = BeanFactory::newBean('Currencies'); if (isset($cur_id)) { $currencyDisplay->retrieve($cur_id); $this->ss->assign('CURRENCY_DISPLAY', $currencyDisplay->iso4217 . ' ' . $currencyDisplay->symbol); } else { $this->ss->assign("CURRENCY_DISPLAY", $currencyDisplay->getDefaultISO4217() . ' ' . $currencyDisplay->getDefaultCurrencySymbol()); } // fill significant digits dropdown $significantDigits = $locale->getPrecedentPreference('default_currency_significant_digits', $this->bean); $sigDigits = ''; for ($i = 0; $i <= 6; $i++) { if ($significantDigits == $i) { $sigDigits .= "<option value=\"$i\" selected=\"true\">$i</option>"; } else { $sigDigits .= "<option value=\"$i\">{$i}</option>"; } } $this->ss->assign('sigDigits', $sigDigits); $this->ss->assign('CURRENCY_SIG_DIGITS', $significantDigits); $num_grp_sep = $this->bean->getPreference('num_grp_sep'); $dec_sep = $this->bean->getPreference('dec_sep'); $this->ss->assign("NUM_GRP_SEP", (empty($num_grp_sep) ? $GLOBALS['sugar_config']['default_number_grouping_seperator'] : $num_grp_sep)); $this->ss->assign("DEC_SEP", (empty($dec_sep) ? $GLOBALS['sugar_config']['default_decimal_seperator'] : $dec_sep)); $this->ss->assign('getNumberJs', $locale->getNumberJs()); //// Name display format $this->ss->assign('default_locale_name_format', $locale->getLocaleFormatMacro($this->bean)); $this->ss->assign('getNameJs', $locale->getNameJs()); $this->ss->assign('NAME_FORMAT', $this->bean->getLocaleFormatDesc()); //// END LOCALE SETTINGS } protected function setupAdvancedTabPdfSettings() { } protected function setupEmailSettings() { global $current_user, $app_list_strings; $this->ss->assign("MAIL_SENDTYPE", get_select_options_with_id($app_list_strings['notifymail_sendtype'], $this->bean->getPreference('mail_sendtype'))); /////////////////////////////////////////////////////////////////////////////// //// EMAIL OPTIONS // We need to turn off the requiredness of emails if it is a group or portal user if ($this->usertype == 'GROUP' || $this->usertype == 'PORTAL_ONLY') { global $dictionary; $dictionary['User']['fields']['email1']['required'] = false; } // hack to disable email field being required if it shouldn't be required if ($this->ss->get_template_vars("REQUIRED_EMAIL_ADDRESS") == '0') { $GLOBALS['dictionary']['User']['fields']['email1']['required'] = false; } $this->ss->assign("NEW_EMAIL", '<span id="email_span">' . getEmailAddressWidget($this->bean, "email1", $this->bean->email1, $this->viewType) . '</span>'); // hack to undo that previous hack if ($this->ss->get_template_vars("REQUIRED_EMAIL_ADDRESS") == '0') { $GLOBALS['dictionary']['User']['fields']['email1']['required'] = true; } $raw_email_link_type = $this->bean->getPreference('email_link_type'); if ($this->viewType == 'EditView') { $this->ss->assign('EMAIL_LINK_TYPE', get_select_options_with_id($app_list_strings['dom_email_link_type'], $raw_email_link_type)); } else { $this->ss->assign('EMAIL_LINK_TYPE', $app_list_strings['dom_email_link_type'][$raw_email_link_type]); } $rawEditorType = $this->bean->getEditorType(); if ($this->viewType == 'EditView') { $this->ss->assign('EDITOR_TYPE', get_select_options_with_id($app_list_strings['dom_editor_type'], $rawEditorType)); } else { $this->ss->assign('EDITOR_TYPE', $app_list_strings['dom_editor_type'][$rawEditorType]); } ///// END EMAIL OPTIONS /////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////// /// Handle email account selections for users ///////////////////////////////////////////// if (!($this->usertype == 'GROUP' || $this->usertype == 'PORTAL_ONLY')) { // email smtp $systemOutboundEmail = new OutboundEmail(); $systemOutboundEmail = $systemOutboundEmail->getSystemMailerSettings(); $mail_smtpserver = $systemOutboundEmail->mail_smtpserver; $mail_smtptype = $systemOutboundEmail->mail_smtptype; $mail_smtpport = $systemOutboundEmail->mail_smtpport; $mail_smtpssl = $systemOutboundEmail->mail_smtpssl; $mail_smtpuser = ""; $mail_smtppass = ""; $mail_smtpdisplay = $systemOutboundEmail->mail_smtpdisplay; $mail_smtpauth_req = true; if (!$systemOutboundEmail->isAllowUserAccessToSystemDefaultOutbound()) { $mail_smtpauth_req = $systemOutboundEmail->mail_smtpauth_req; $userOverrideOE = $systemOutboundEmail->getUsersMailerForSystemOverride($this->bean->id); if ($userOverrideOE != null) { $mail_smtpuser = $userOverrideOE->mail_smtpuser; $mail_smtppass = $userOverrideOE->mail_smtppass; } } $this->ss->assign("mail_smtpdisplay", $mail_smtpdisplay); $this->ss->assign("mail_smtpserver", $mail_smtpserver); $this->ss->assign("mail_smtpuser", $mail_smtpuser); $this->ss->assign("mail_smtppass", ""); $this->ss->assign("mail_haspass", empty($systemOutboundEmail->mail_smtppass) ? 0 : 1); $this->ss->assign("mail_smtpauth_req", $mail_smtpauth_req); $this->ss->assign('MAIL_SMTPPORT', $mail_smtpport); $this->ss->assign('MAIL_SMTPSSL', $mail_smtpssl); } } /** * setUserType * This function is used to set the user_type variable for a given User instance * * @param Mixed $user The user instance to set the user_type variable on * @return String value representing the user type */ public function setUserType($user) { //bug #49175: user's always regular //need to get user_type from bean $user->user_type = ''; if ($user->is_admin) { $user->user_type = 'Administrator'; } elseif ($user->is_group) { $user->user_type = 'GROUP'; } else { $user->user_type = 'RegularUser'; } } } Save