isAdminForModule('Users')
&& ($_REQUEST['record'] != $current_user->id)) sugar_die("Unauthorized access to administration.");
$is_current_admin=is_admin($current_user)
||$GLOBALS['current_user']->isAdminForModule('Users');
$focus = new User();
$detailView = new DetailView();
$offset=0;
if (isset($_REQUEST['offset']) || !empty($_REQUEST['record'])) {
$result = $detailView->processSugarBean("USER", $focus, $offset);
if($result == null) {
sugar_die($app_strings['ERROR_NO_RECORD']);
}
$focus=$result;
} else {
header("Location: index.php?module=Users&action=index");
}
if(isset($_REQUEST['isDuplicate']) && $_REQUEST['isDuplicate'] == 'true') {
$focus->id = "";
}
if(isset($_REQUEST['reset_preferences'])){
$focus->resetPreferences();
}
if(isset($_REQUEST['reset_homepage'])){
$focus->resetPreferences('Home');
if($focus->id == $current_user->id) {
$_COOKIE[$current_user->id . '_activePage'] = '0';
setcookie($current_user->id . '_activePage','0',3000);
}
}
$params = array();
$params[] = $locale->getLocaleFormattedName($focus->first_name,$focus->last_name);
$index_url = ($is_current_admin) ? "index.php?module=Users&action=index" : "index.php?module=Users&action=DetailView&record={$focus->id}";
echo getClassicModuleTitle("Users", $params, true,$index_url);
global $app_list_strings;
$GLOBALS['log']->info("User detail view");
$sugar_smarty = new Sugar_Smarty();
$sugar_smarty->assign("MOD", $mod_strings);
$sugar_smarty->assign("APP", $app_strings);
$sugar_smarty->assign("PRINT_URL", "index.php?".$GLOBALS['request_string']);
$sugar_smarty->assign("ID", $focus->id);
$sugar_smarty->assign("USER_NAME", $focus->user_name);
$sugar_smarty->assign("FULL_NAME", $focus->full_name);
if(!empty($GLOBALS['sugar_config']['authenticationClass'])){
$authclass = $GLOBALS['sugar_config']['authenticationClass'];
}else if(!empty($GLOBALS['system_config']->settings['system_ldap_enabled'])){
$authclass = 'LDAPAuthenticate';
}
if(is_admin($GLOBALS['current_user']) && !empty($authclass)){
$str = '
';
$str .= $authclass . ':';
$str .= ' | external_auth_only))$str .= ' CHECKED ';
$str .='/> | '. $mod_strings['LBL_EXTERNAL_AUTH_ONLY'] . ' ' . $authclass. ' |
';
$sugar_smarty->assign('EXTERNAL_AUTH', $str);
}
$edit_self = $current_user->id == $focus->id;
if($edit_self) {
$sugar_smarty->assign('EDIT_SELF','1');
}
if (isset($sugar_config['show_download_tab']))
{
$enable_download_tab = $sugar_config['show_download_tab'];
}else{
$enable_download_tab = true;
}
$sugar_smarty->assign('SHOW_DOWNLOADS_TAB', $enable_download_tab);
///////////////////////////////////////////////////////////////////////////////
//// TO SUPPORT LEGACY XTEMPLATES
$sugar_smarty->assign('FIRST_NAME', $focus->first_name);
$sugar_smarty->assign('LAST_NAME', $focus->last_name);
//// END SUPPORT LEGACY XTEMPLATES
///////////////////////////////////////////////////////////////////////////////
$status = '';
if(!empty($focus->status)) {
// jc:#12261 - while not apparent, replaced the explicit reference to the
// app_strings['user_status_dom'] element with a call to the ultility translate
// function to retrieved the mapped value for User::status
$status = translate('user_status_dom', '', $focus->status);
}
$sugar_smarty->assign("STATUS", $status);
$detailView->processListNavigation($sugar_smarty, "USER", $offset);
$reminder_time = $focus->getPreference('reminder_time');
if(empty($reminder_time)){
$reminder_time = -1;
}
if($reminder_time != -1){
$sugar_smarty->assign("REMINDER_CHECKED", 'checked');
$sugar_smarty->assign("REMINDER_TIME", translate('reminder_time_options', '', $reminder_time));
}
// Display the good usertype
$user_type_label=$mod_strings['LBL_REGULAR_USER'];
$usertype='RegularUser';
if((is_admin($current_user) || $_REQUEST['record'] == $current_user->id || $current_user->isAdminForModule('Users')) && $focus->is_admin == '1'){
$user_type_label=$mod_strings['LBL_ADMIN_USER'];
$usertype='Administrator';
}
$sugar_smarty->assign('IS_GROUP_OR_PORTAL','0');
if(!empty($focus->is_group) && $focus->is_group == 1){
$user_type_label=$mod_strings['LBL_GROUP_USER'];
$usertype='GroupUser';
$sugar_smarty->assign('IS_GROUP_OR_PORTAL','1');
}
$sugar_smarty->assign("USER_TYPE", $usertype);
$sugar_smarty->assign("USER_TYPE_LABEL", $user_type_label);
// adding custom fields:
$xtpl = $sugar_smarty;
require_once('modules/DynamicFields/templates/Files/DetailView.php');
$errors = "";
$msgGood = false;
if (isset($_REQUEST['pwd_set']) && $_REQUEST['pwd_set']!= 0){
if ($_REQUEST['pwd_set']=='4'){
require_once('modules/Users/password_utils.php');
$errors.=canSendPassword();
}
else {
$errors.=$mod_strings['LBL_NEW_USER_PASSWORD_'.$_REQUEST['pwd_set']];
$msgGood = true;
}
}else{
//IF FOCUS USER IS LOCKOUT
if($focus->getPreference('lockout')=='1')
$errors.=$mod_strings['ERR_USER_IS_LOCKED_OUT'];
}
$sugar_smarty->assign("ERRORS", $errors);
$sugar_smarty->assign("ERROR_MESSAGE", $msgGood ? $mod_strings['LBL_PASSWORD_SENT'] : $mod_strings['LBL_CANNOT_SEND_PASSWORD']);
$buttons = "";
if ((is_admin($current_user) || $_REQUEST['record'] == $current_user->id
)
&& !empty($sugar_config['default_user_name'])
&& $sugar_config['default_user_name'] == $focus->user_name
&& isset($sugar_config['lock_default_user_name'])
&& $sugar_config['lock_default_user_name']) {
$buttons .= " ";
}
elseif (is_admin($current_user)|| ($GLOBALS['current_user']->isAdminForModule('Users')&& !$focus->is_admin)
|| $_REQUEST['record'] == $current_user->id) {
$buttons .= " ";
if ((is_admin($current_user)|| $GLOBALS['current_user']->isAdminForModule('Users')
)
){
if (!$current_user->is_group){
$buttons .= " ";
if($focus->id != $current_user->id) {
$buttons .=" ";
}
if (!$focus->portal_only && !$focus->is_group && !$focus->external_auth_only
&& isset($sugar_config['passwordsetting']['SystemGeneratedPasswordON']) && $sugar_config['passwordsetting']['SystemGeneratedPasswordON']){
$buttons .= " ";
}
}
}
}
if(isset($_SERVER['QUERY_STRING'])) $the_query_string = $_SERVER['QUERY_STRING'];
else $the_query_string = '';
if (!$current_user->is_group){
if ($focus->id == $current_user->id) {
$reset_pref_warning = $mod_strings['LBL_RESET_PREFERENCES_WARNING'];
$reset_home_warning = $mod_strings['LBL_RESET_HOMEPAGE_WARNING'];
}
else {
$reset_pref_warning = $mod_strings['LBL_RESET_PREFERENCES_WARNING_USER'];
$reset_home_warning = $mod_strings['LBL_RESET_HOMEPAGE_WARNING_USER'];
}
$buttons .="";
$buttons .=" ";
}
if (isset($buttons)) $sugar_smarty->assign("BUTTONS", $buttons);
require_once("include/templates/TemplateGroupChooser.php");
require_once("modules/MySettings/TabController.php");
$chooser = new TemplateGroupChooser();
$controller = new TabController();
//if(is_admin($current_user) || $controller->get_users_can_edit())
if(is_admin($current_user)||$GLOBALS['current_user']->isAdminForModule('Users'))
{
$chooser->display_third_tabs = true;
$chooser->args['third_name'] = 'remove_tabs';
$chooser->args['third_label'] = $mod_strings['LBL_REMOVED_TABS'];
}
elseif(!$controller->get_users_can_edit())
{
$chooser->display_hide_tabs = false;
}
else
{
$chooser->display_hide_tabs = true;
}
$chooser->args['id'] = 'edit_tabs';
$chooser->args['values_array'] = $controller->get_tabs($focus);
$chooser->args['left_name'] = 'display_tabs';
$chooser->args['right_name'] = 'hide_tabs';
$chooser->args['left_label'] = $mod_strings['LBL_DISPLAY_TABS'];
$chooser->args['right_label'] = $mod_strings['LBL_HIDE_TABS'];
$chooser->args['title'] = $mod_strings['LBL_EDIT_TABS'];
$chooser->args['disable'] = true;
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];
}
$sugar_smarty->assign("TAB_CHOOSER", $chooser->display());
$sugar_smarty->assign("CHOOSE_WHICH", $mod_strings['LBL_CHOOSE_WHICH']);
if ($focus->receive_notifications) $sugar_smarty->assign("RECEIVE_NOTIFICATIONS", "checked");
if($focus->getPreference('mailmerge_on') == 'on') {
$sugar_smarty->assign("MAILMERGE_ON", "checked");
}
$sugar_smarty->assign("SETTINGS_URL", $sugar_config['site_url']);
$sugar_smarty->assign("EXPORT_DELIMITER", $focus->getPreference('export_delimiter'));
$sugar_smarty->assign('EXPORT_CHARSET', $locale->getExportCharset('', $focus));
$sugar_smarty->assign('USE_REAL_NAMES', $focus->getPreference('use_real_names'));
global $timedate;
$sugar_smarty->assign("DATEFORMAT", $sugar_config['date_formats'][$timedate->get_date_format()]);
$sugar_smarty->assign("TIMEFORMAT", $sugar_config['time_formats'][$timedate->get_time_format()]);
$userTZ = $focus->getPreference('timezone');
$sugar_smarty->assign("TIMEZONE", TimeDate::tzName($userTZ));
$datef = $focus->getPreference('datef');
$timef = $focus->getPreference('timef');
if(!empty($datef))
$sugar_smarty->assign("DATEFORMAT", $sugar_config['date_formats'][$datef]);
if(!empty($timef))
$sugar_smarty->assign("TIMEFORMAT", $sugar_config['time_formats'][$timef]);
$num_grp_sep = $focus->getPreference('num_grp_sep');
$dec_sep = $focus->getPreference('dec_sep');
$sugar_smarty->assign("NUM_GRP_SEP", (empty($num_grp_sep) ? $sugar_config['default_number_grouping_seperator'] : $num_grp_sep));
$sugar_smarty->assign("DEC_SEP", (empty($dec_sep) ? $sugar_config['default_decimal_seperator'] : $dec_sep));
$currency = new Currency();
if($focus->getPreference('currency') ) {
$currency->retrieve($focus->getPreference('currency'));
$sugar_smarty->assign("CURRENCY", $currency->iso4217 .' '.$currency->symbol );
} else {
$sugar_smarty->assign("CURRENCY", $currency->getDefaultISO4217() .' '.$currency->getDefaultCurrencySymbol() );
}
$sugar_smarty->assign('CURRENCY_SIG_DIGITS', $locale->getPrecedentPreference('default_currency_significant_digits', $focus));
$sugar_smarty->assign('NAME_FORMAT', $focus->getLocaleFormatDesc());
$sugar_smarty->assign("DESCRIPTION", nl2br(url2html($focus->description)));
$sugar_smarty->assign("TITLE", $focus->title);
$sugar_smarty->assign("DEPARTMENT", $focus->department);
$sugar_smarty->assign("REPORTS_TO_ID", $focus->reports_to_id);
$sugar_smarty->assign("REPORTS_TO_NAME", $focus->reports_to_name);
$sugar_smarty->assign("PHONE_HOME", $focus->phone_home);
$sugar_smarty->assign("PHONE_MOBILE", $focus->phone_mobile);
$sugar_smarty->assign("PHONE_WORK", $focus->phone_work);
$sugar_smarty->assign("PHONE_OTHER", $focus->phone_other);
$sugar_smarty->assign("PHONE_FAX", $focus->phone_fax);
if (!empty($focus->employee_status)) {
$sugar_smarty->assign("EMPLOYEE_STATUS", $app_list_strings['employee_status_dom'][$focus->employee_status]);
}
$sugar_smarty->assign("MESSENGER_ID", $focus->messenger_id);
$sugar_smarty->assign("MESSENGER_TYPE", $focus->messenger_type);
$sugar_smarty->assign("ADDRESS_STREET", $focus->address_street);
$sugar_smarty->assign("ADDRESS_CITY", $focus->address_city);
$sugar_smarty->assign("ADDRESS_STATE", $focus->address_state);
$sugar_smarty->assign("ADDRESS_POSTALCODE", $focus->address_postalcode);
$sugar_smarty->assign("ADDRESS_COUNTRY", $focus->address_country);
$sugar_smarty->assign("EMAIL_ADDRESSES", $focus->emailAddress->getEmailAddressWidgetDetailView($focus));
$sugar_smarty->assign("CALENDAR_PUBLISH_KEY", $focus->getPreference('calendar_publish_key' ));
if (! empty($current_user->email1))
{
$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&email='.$focus->email1.'&source=outlook&key='.$focus->getPreference('calendar_publish_key' );
$sugar_smarty->assign("CALENDAR_PUBLISH_URL", $publish_url);
$sugar_smarty->assign("CALENDAR_SEARCH_URL", $sugar_config['site_url'].'/vcal_server.php/type=vfb&email=%NAME%@%SERVER%');
}
else
{
$sugar_smarty->assign("CALENDAR_PUBLISH_URL", $sugar_config['site_url'].'/vcal_server.php/type=vfb&user_name='.$focus->user_name.'&source=outlook&key='.$focus->getPreference('calendar_publish_key' ));
$sugar_smarty->assign("CALENDAR_SEARCH_URL", $sugar_config['site_url'].'/vcal_server.php/type=vfb&email=%NAME%@%SERVER%');
}
// Grouped tabs?
$useGroupTabs = $current_user->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'];
}
$sugar_smarty->assign("USE_GROUP_TABS",($useGroupTabs=='gm')?'checked':'');
$user_max_tabs = intval($focus->getPreference('max_tabs'));
if(isset($user_max_tabs) && $user_max_tabs > 0)
$sugar_smarty->assign("MAX_TAB", $user_max_tabs);
elseif(isset($max_tabs) && $max_tabs > 0)
$sugar_smarty->assign("MAX_TAB", $max_tabs);
else
$sugar_smarty->assign("MAX_TAB", $GLOBALS['sugar_config']['default_max_tabs']);
$user_subpanel_tabs = $focus->getPreference('subpanel_tabs');
if(isset($user_subpanel_tabs)) {
$sugar_smarty->assign("SUBPANEL_TABS", $user_subpanel_tabs?'checked':'');
} else {
$sugar_smarty->assign("SUBPANEL_TABS", $GLOBALS['sugar_config']['default_subpanel_tabs']?'checked':'');
}
// Email Options
$sugar_smarty->assign("EMAIL_OPTIONS", $focus->emailAddress->getEmailAddressWidgetDetailView($focus));
$email_link_type = $focus->getPreference('email_link_type');
if ( !empty($email_link_type) )
$sugar_smarty->assign('EMAIL_LINK_TYPE',$app_list_strings['dom_email_link_type'][$focus->getPreference('email_link_type')]);
if ( $focus->getPreference('email_link_type') == 'sugar' )
$sugar_smarty->assign('SHOW_SMTP_SETTINGS',true);
//Handle outbound email templates
$oe = new OutboundEmail();
$userOverrideOE = $oe->getUsersMailerForSystemOverride($focus->id);
$mail_smtpuser = "";
$mail_smtpserver = "";
if($userOverrideOE == null)
{
$systemOE = $oe->getSystemMailerSettings();
$mail_smtpdisplay = $systemOE->mail_smtpdisplay;
$mail_smtpserver = $systemOE->mail_smtpserver;
$mail_smtptype = $systemOE->mail_smtptype;
if( $oe->isAllowUserAccessToSystemDefaultOutbound() )
$mail_smtpuser = $systemOE->mail_smtpuser;
}
else
{
$mail_smtpdisplay = $userOverrideOE->mail_smtpdisplay;
$mail_smtpuser = $userOverrideOE->mail_smtpuser;
$mail_smtpserver = $userOverrideOE->mail_smtpserver;
$mail_smtptype = $userOverrideOE->mail_smtptype;
}
$sugar_smarty->assign("MAIL_SMTPUSER", $mail_smtpuser);
$sugar_smarty->assign("MAIL_SMTPDISPLAY", $mail_smtpdisplay);
$show_roles = (!($focus->is_group=='1' || $focus->portal_only=='1'));
$sugar_smarty->assign('SHOW_ROLES', $show_roles);
// User Holidays subpanel on the advanced tab
global $modules_exempt_from_availability_check;
$modules_exempt_from_availability_check=array('Holidays'=>'Holidays',);
$locked = false;
if(!empty($GLOBALS['sugar_config']['lock_subpanels'])){
$locked = true;
}
$GLOBALS['sugar_config']['lock_subpanels'] = true;
$GLOBALS['sugar_config']['lock_subpanels'] = $locked;
$sugar_smarty->display('modules/Users/DetailView.tpl');
// Roles Grid and Roles subpanel should not be displayed for group and portal users
if($show_roles){
echo "";
require_once('modules/ACLRoles/DetailUserRole.php');
if(SugarOAuthServer::enabled()) {
$subpanel = new SubPanelTiles($focus, 'UserOAuth');
echo $subpanel->display(true,true);
}
echo "
";
}
echo "\n";
$savedSearch = new SavedSearch();
$json = getJSONobj();
$savedSearchSelects = $json->encode(array($GLOBALS['app_strings']['LBL_SAVED_SEARCH_SHORTCUT'] . '
' . $savedSearch->getSelect('Users')));
$str = "";
echo $str;
echo "";
$confirmDeleteJS = "
";
echo $confirmDeleteJS;