]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - modules/Users/EditView.php
Release 6.1.5
[Github/sugarcrm.git] / modules / Users / EditView.php
1 <?php
2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4  * SugarCRM is a customer relationship management program developed by
5  * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
6  * 
7  * This program is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU Affero General Public License version 3 as published by the
9  * Free Software Foundation with the addition of the following permission added
10  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13  * 
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
17  * details.
18  * 
19  * You should have received a copy of the GNU Affero General Public License along with
20  * this program; if not, see http://www.gnu.org/licenses or write to the Free
21  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22  * 02110-1301 USA.
23  * 
24  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26  * 
27  * The interactive user interfaces in modified source and object code versions
28  * of this program must display Appropriate Legal Notices, as required under
29  * Section 5 of the GNU Affero General Public License version 3.
30  * 
31  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32  * these Appropriate Legal Notices must retain the display of the "Powered by
33  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34  * technical reasons, the Appropriate Legal Notices must display the words
35  * "Powered by SugarCRM".
36  ********************************************************************************/
37
38 /*********************************************************************************
39
40  * Description:  TODO: To be written.
41  * Portions created by SugarCRM are Copyright(C) SugarCRM, Inc.
42  * All Rights Reserved.
43  * Contributor(s): ______________________________________..
44  ********************************************************************************/
45
46 $sugar_smarty = new Sugar_Smarty();
47 require_once('include/export_utils.php');
48 require_once('modules/Configurator/Configurator.php');
49 require_once('modules/Users/Forms.php');
50 require_once('modules/Users/UserSignature.php');
51
52 global $app_strings;
53 global $app_list_strings;
54 global $mod_strings;
55
56 $admin = new Administration();
57 $admin->retrieveSettings();
58
59 $focus = new User();
60 $is_current_admin=is_admin($current_user)
61                 ||is_admin_for_module($GLOBALS['current_user'],'Users');
62 $is_super_admin = is_admin($current_user);
63 if(!$is_current_admin && $_REQUEST['record'] != $current_user->id) sugar_die("Unauthorized access to administration.");
64
65 if(isset($_REQUEST['record'])) {
66     $focus->retrieve($_REQUEST['record']);
67 }
68
69 if(!$is_super_admin && is_admin_for_module($GLOBALS['current_user'],'Users') && $focus->is_admin == 1) sugar_die("Unauthorized access to administrator.");
70
71 if(isset($_REQUEST['isDuplicate']) && $_REQUEST['isDuplicate'] == 'true') {
72         $focus->id = "";
73         $focus->user_name = "";
74 }else if(!isset($_REQUEST['record'])){
75     define('SUGARPDF_USE_DEFAULT_SETTINGS', true);
76 }
77
78
79
80
81
82
83
84
85 $the_query_string = 'module=Users&action=DetailView';
86 if(isset($_REQUEST['record'])) {
87     $the_query_string .= '&record='.$_REQUEST['record'];
88 }
89 $buttons = "";
90 if (!$current_user->is_group){
91     if ($focus->id == $current_user->id) {
92         $reset_pref_warning = $mod_strings['LBL_RESET_PREFERENCES_WARNING'];
93         $reset_home_warning = $mod_strings['LBL_RESET_HOMEPAGE_WARNING'];
94     }
95     else {
96         $reset_pref_warning = $mod_strings['LBL_RESET_PREFERENCES_WARNING_USER'];
97         $reset_home_warning = $mod_strings['LBL_RESET_HOMEPAGE_WARNING_USER'];
98     }
99         $buttons .="<input type='button' class='button' onclick='if(confirm(\"{$reset_pref_warning}\"))window.location=\"".$_SERVER['PHP_SELF'] .'?'.$the_query_string."&reset_preferences=true\";' value='".$mod_strings['LBL_RESET_PREFERENCES']."' />";
100         $buttons .="&nbsp;<input type='button' class='button' onclick='if(confirm(\"{$reset_home_warning}\"))window.location=\"".$_SERVER['PHP_SELF'] .'?'.$the_query_string."&reset_homepage=true\";' value='".$mod_strings['LBL_RESET_HOMEPAGE']."' />";
101 }
102 if (isset($buttons)) $sugar_smarty->assign("BUTTONS", $buttons);
103
104 echo "\n<p>\n";
105 $params = array();
106 if(empty($focus->id)){
107         $params[] = "<span class='pointer'>&raquo;</span>".$GLOBALS['app_strings']['LBL_CREATE_BUTTON_LABEL'];
108 }else{
109         $params[] = "<span class='pointer'>&raquo;</span><a href='index.php?module=Users&action=DetailView&record={$focus->id}'>".$locale->getLocaleFormattedName($focus->first_name,$focus->last_name)."</a>";
110         $params[] = $GLOBALS['app_strings']['LBL_EDIT_BUTTON_LABEL'];
111 }
112 echo getClassicModuleTitle("Users", $params, true);
113
114 $GLOBALS['log']->info('User edit view');
115 $sugar_smarty->assign('MOD', $mod_strings);
116 $sugar_smarty->assign('APP', $app_strings);
117
118 if(isset($_REQUEST['error_string'])) $sugar_smarty->assign('ERROR_STRING', '<span class="error">Error: '.$_REQUEST['error_string'].'</span>');
119 if(isset($_REQUEST['error_password'])) $sugar_smarty->assign('ERROR_PASSWORD', '<span id="error_pwd" class="error">Error: '.$_REQUEST['error_password'].'</span>');
120
121 if(isset($_REQUEST['isDuplicate']) && $_REQUEST['isDuplicate'] == 'true') {
122
123         $sugar_smarty->assign('RETURN_MODULE', $_REQUEST['return_module']);
124         $sugar_smarty->assign('RETURN_ACTION', $_REQUEST['return_action']);
125         $sugar_smarty->assign('RETURN_ID', $_REQUEST['record']);
126
127 } else {
128         if(isset($_REQUEST['return_module'])) $sugar_smarty->assign('RETURN_MODULE', $_REQUEST['return_module']);
129         else { $sugar_smarty->assign('RETURN_MODULE', $focus->module_dir);}
130         if(isset($_REQUEST['return_id'])) $sugar_smarty->assign('RETURN_ID', $_REQUEST['return_id']);
131         else { $sugar_smarty->assign('RETURN_ID', $focus->id); }
132         if(isset($_REQUEST['return_action'])) $sugar_smarty->assign('RETURN_ACTION', $_REQUEST['return_action']);
133         else { $sugar_smarty->assign('RETURN_ACTION', 'DetailView'); }
134 }
135
136
137 $sugar_smarty->assign('JAVASCRIPT',user_get_validate_record_js().user_get_chooser_js().user_get_confsettings_js().'<script type="text/javascript" language="Javascript" src="modules/Users/User.js"></script>');
138 $sugar_smarty->assign('PRINT_URL', 'index.php?'.$GLOBALS['request_string']);
139 $sugar_smarty->assign('ID', $focus->id);
140
141 $sugar_smarty->assign('USER_NAME', $focus->user_name);
142 $sugar_smarty->assign('FIRST_NAME', $focus->first_name);
143 $sugar_smarty->assign('LAST_NAME', $focus->last_name);
144 $sugar_smarty->assign('TITLE', $focus->title);
145 $sugar_smarty->assign('DEPARTMENT', $focus->department);
146 $sugar_smarty->assign('REPORTS_TO_ID', $focus->reports_to_id);
147 $sugar_smarty->assign('REPORTS_TO_NAME', get_assigned_user_name($focus->reports_to_id));
148 $sugar_smarty->assign('PHONE_HOME', $focus->phone_home);
149 $sugar_smarty->assign('PHONE_MOBILE', $focus->phone_mobile);
150 $sugar_smarty->assign('PHONE_WORK', $focus->phone_work);
151 $sugar_smarty->assign('PHONE_OTHER', $focus->phone_other);
152 $sugar_smarty->assign('PHONE_FAX', $focus->phone_fax);
153 $sugar_smarty->assign('EMAIL1', $focus->email1);
154 $sugar_smarty->assign('EMAIL2', $focus->email2);
155 $sugar_smarty->assign('ADDRESS_STREET', $focus->address_street);
156 $sugar_smarty->assign('ADDRESS_CITY', $focus->address_city);
157 $sugar_smarty->assign('ADDRESS_STATE', $focus->address_state);
158 $sugar_smarty->assign('ADDRESS_POSTALCODE', $focus->address_postalcode);
159 $sugar_smarty->assign('ADDRESS_COUNTRY', $focus->address_country);
160 $sugar_smarty->assign('DESCRIPTION', $focus->description);
161 $sugar_smarty->assign('EXPORT_DELIMITER', $focus->getPreference('export_delimiter'));
162 $sugar_smarty->assign('PWDSETTINGS', isset($GLOBALS['sugar_config']['passwordsetting']) ? $GLOBALS['sugar_config']['passwordsetting'] : array());
163
164 if(!empty($GLOBALS['sugar_config']['authenticationClass'])){
165                 $sugar_smarty->assign('EXTERNAL_AUTH_CLASS_1', $GLOBALS['sugar_config']['authenticationClass']);
166                 $sugar_smarty->assign('EXTERNAL_AUTH_CLASS', $GLOBALS['sugar_config']['authenticationClass']);
167 }else{
168         if(!empty($GLOBALS['system_config']->settings['system_ldap_enabled'])){
169                 $sugar_smarty->assign('EXTERNAL_AUTH_CLASS_1', $mod_strings['LBL_LDAP']);
170                 $sugar_smarty->assign('EXTERNAL_AUTH_CLASS', $mod_strings['LBL_LDAP_AUTHENTICATION']);
171         }
172 }
173 if(!empty($focus->external_auth_only))$sugar_smarty->assign('EXTERNAL_AUTH_ONLY_CHECKED', 'CHECKED');
174 if ($is_current_admin)
175         $sugar_smarty->assign('IS_ADMIN','1');
176 else
177         $sugar_smarty->assign('IS_ADMIN', '0');
178
179 if ($is_super_admin)
180     $sugar_smarty->assign('IS_SUPER_ADMIN','1');
181 else
182     $sugar_smarty->assign('IS_SUPER_ADMIN', '0');
183
184
185 //jc:12293 - modifying to use the accessor method which will translate the
186 //available character sets using the translation files
187 $sugar_smarty->assign('EXPORT_CHARSET', get_select_options_with_id($locale->getCharsetSelect(), $locale->getExportCharset('', $focus)));
188 //end:12293
189
190 if( $focus->getPreference('use_real_names') == 'on' || ( empty($focus->id) && isset($GLOBALS['sugar_config']['use_real_names'])
191        && $GLOBALS['sugar_config']['use_real_names'] && $focus->getPreference('use_real_names') != 'off') )
192 {
193
194         $sugar_smarty->assign('USE_REAL_NAMES', 'CHECKED');
195 }
196 if($focus->getPreference('no_opps') == 'on') {
197     $sugar_smarty->assign('NO_OPPS', 'CHECKED');
198 }
199
200
201 // check if the user has access to the User Management
202 $sugar_smarty->assign('USER_ADMIN',is_admin_for_module($current_user,'Users')&& !is_admin($current_user));
203
204
205 ///////////////////////////////////////////////////////////////////////////////
206 ////    NEW USER CREATION ONLY
207 if(empty($focus->id)) {
208         $sugar_smarty->assign('SHOW_ADMIN_CHECKBOX','height="30"');
209         $sugar_smarty->assign('NEW_USER','1');
210 }else{
211         $sugar_smarty->assign('NEW_USER','0');
212         $sugar_smarty->assign('NEW_USER_TYPE','DISABLED');
213 }
214
215 ////    END NEW USER CREATION ONLY
216 ///////////////////////////////////////////////////////////////////////////////
217
218 ///////////////////////////////////////////////////////////////////////////////
219 ////    REDIRECTS FROM COMPOSE EMAIL SCREEN
220 if(isset($_REQUEST['type']) && (isset($_REQUEST['return_module']) && $_REQUEST['return_module'] == 'Emails')) {
221         $sugar_smarty->assign('REDIRECT_EMAILS_TYPE', $_REQUEST['type']);
222 }
223 ////    END REDIRECTS FROM COMPOSE EMAIL SCREEN
224 ///////////////////////////////////////////////////////////////////////////////
225
226
227 ///////////////////////////////////////////////////////////////////////////////
228 ////    LOCALE SETTINGS
229 ////    Date/time format
230 $dformat = $locale->getPrecedentPreference($focus->id?'datef':'default_date_format', $focus);
231 $tformat = $locale->getPrecedentPreference($focus->id?'timef':'default_time_format', $focus);
232 $timeOptions = get_select_options_with_id($sugar_config['time_formats'], $tformat);
233 $dateOptions = get_select_options_with_id($sugar_config['date_formats'], $dformat);
234 $sugar_smarty->assign('TIMEOPTIONS', $timeOptions);
235 $sugar_smarty->assign('DATEOPTIONS', $dateOptions);
236 //// Timezone
237 if(empty($focus->id)) { // remove default timezone for new users(set later)
238     $focus->user_preferences['timezone'] = '';
239 }
240 require_once('include/timezone/timezones.php');
241 global $timezones;
242
243 $userTZ = $focus->getPreference('timezone');
244 if(empty($userTZ) && !$focus->is_group && !$focus->portal_only) {
245         $focus->setPreference('timezone', date('T'));
246 }
247
248 if(empty($userTZ) && !$focus->is_group && !$focus->portal_only)
249         $userTZ = lookupTimezone();
250
251 if(!$focus->getPreference('ut')) {
252         $sugar_smarty->assign('PROMPTTZ', ' checked');
253 }
254
255 $timezoneOptions = '';
256 ksort($timezones);
257 foreach($timezones as $key => $value) {
258         $selected =($userTZ == $key) ? ' SELECTED="true"' : '';
259         $dst = !empty($value['dstOffset']) ? '(+DST)' : '';
260         $gmtOffset =($value['gmtOffset'] / 60);
261
262         if(!strstr($gmtOffset,'-')) {
263                 $gmtOffset = '+'.$gmtOffset;
264         }
265   $timezoneOptions .= "<option value='$key'".$selected.">".str_replace(array('_','North'), array(' ', 'N.'),translate('timezone_dom','',$key)). "(GMT".$gmtOffset.") ".$dst."</option>";
266 }
267 $sugar_smarty->assign('TIMEZONEOPTIONS', $timezoneOptions);
268
269 //// Numbers and Currency display
270 require_once('modules/Currencies/ListCurrency.php');
271 $currency = new ListCurrency();
272
273 // 10/13/2006 Collin - Changed to use Localization.getConfigPreference
274 // This was the problem- Previously, the "-99" currency id always assumed
275 // to be defaulted to US Dollars.  However, if someone set their install to use
276 // Euro or other type of currency then this setting would not apply as the
277 // default because it was being overridden by US Dollars.
278 $cur_id = $locale->getPrecedentPreference('currency', $focus);
279 if($cur_id) {
280         $selectCurrency = $currency->getSelectOptions($cur_id);
281         $sugar_smarty->assign("CURRENCY", $selectCurrency);
282 } else {
283         $selectCurrency = $currency->getSelectOptions();
284         $sugar_smarty->assign("CURRENCY", $selectCurrency);
285 }
286
287 $currenciesVars = "";
288 foreach($locale->currencies as $id => $arrVal) {
289         $currenciesVars .= "currencies['{$id}'] = '{$arrVal['symbol']}';\n";
290 }
291 $currencySymbolsJs = <<<eoq
292 var currencies = new Object;
293 {$currenciesVars}
294 function setSymbolValue(id) {
295         document.getElementById('symbol').value = currencies[id];
296 }
297 eoq;
298 $sugar_smarty->assign('currencySymbolJs', $currencySymbolsJs);
299
300
301 // fill significant digits dropdown
302 $significantDigits = $locale->getPrecedentPreference('default_currency_significant_digits', $focus);
303 $sigDigits = '';
304 for($i=0; $i<=6; $i++) {
305         if($significantDigits == $i) {
306            $sigDigits .= "<option value=\"$i\" selected=\"true\">$i</option>";
307         } else {
308            $sigDigits .= "<option value=\"$i\">{$i}</option>";
309         }
310 }
311
312 $sugar_smarty->assign('sigDigits', $sigDigits);
313
314 $num_grp_sep = $focus->getPreference('num_grp_sep');
315 $dec_sep = $focus->getPreference('dec_sep');
316 $sugar_smarty->assign("NUM_GRP_SEP",(empty($num_grp_sep) ? $sugar_config['default_number_grouping_seperator'] : $num_grp_sep));
317 $sugar_smarty->assign("DEC_SEP",(empty($dec_sep) ? $sugar_config['default_decimal_seperator'] : $dec_sep));
318 $sugar_smarty->assign('getNumberJs', $locale->getNumberJs());
319
320 //// Name display format
321 $sugar_smarty->assign('default_locale_name_format', $locale->getLocaleFormatMacro($focus));
322 $sugar_smarty->assign('getNameJs', $locale->getNameJs());
323 ////    END LOCALE SETTINGS
324 ///////////////////////////////////////////////////////////////////////////////
325
326 //require_once($theme_path.'config.php');
327
328
329 // Grouped tabs?
330 $useGroupTabs = $current_user->getPreference('navigation_paradigm');
331 if ( ! isset($useGroupTabs) ) {
332     if ( ! isset($GLOBALS['sugar_config']['default_navigation_paradigm']) ) {
333         $GLOBALS['sugar_config']['default_navigation_paradigm'] = 'gm';
334     }
335     $useGroupTabs = $GLOBALS['sugar_config']['default_navigation_paradigm'];
336 }
337 $sugar_smarty->assign("USE_GROUP_TABS",($useGroupTabs=='gm')?'checked':'');
338
339 $user_max_tabs = $focus->getPreference('max_tabs');
340 if(isset($user_max_tabs) && $user_max_tabs > 0) {
341         $sugar_smarty->assign("MAX_TAB", $user_max_tabs);
342 } elseif(SugarThemeRegistry::current()->maxTabs > 0) {
343     $sugar_smarty->assign("MAX_TAB", SugarThemeRegistry::current()->maxTabs);
344 } else {
345     $sugar_smarty->assign("MAX_TAB", $GLOBALS['sugar_config']['default_max_tabs']);
346 }
347 $sugar_smarty->assign("MAX_TAB_OPTIONS", range(1, 10));
348
349 $user_subpanel_tabs = $focus->getPreference('subpanel_tabs');
350 if(isset($user_subpanel_tabs)) {
351     $sugar_smarty->assign("SUBPANEL_TABS", $user_subpanel_tabs?'checked':'');
352 } else {
353     $sugar_smarty->assign("SUBPANEL_TABS", $GLOBALS['sugar_config']['default_subpanel_tabs']?'checked':'');
354 }
355
356 $user_theme = $focus->getPreference('user_theme');
357 if(isset($user_theme)) {
358     $sugar_smarty->assign("THEMES", get_select_options_with_id(SugarThemeRegistry::availableThemes(), $user_theme));
359 } else {
360     $sugar_smarty->assign("THEMES", get_select_options_with_id(SugarThemeRegistry::availableThemes(), $GLOBALS['sugar_config']['default_theme']));
361 }
362 $sugar_smarty->assign("SHOW_THEMES",count(SugarThemeRegistry::availableThemes()) > 1);
363 $sugar_smarty->assign("USER_THEME_COLOR", $focus->getPreference('user_theme_color'));
364 $sugar_smarty->assign("USER_THEME_FONT", $focus->getPreference('user_theme_font'));
365 $sugar_smarty->assign("USER_THEME", $user_theme);
366
367 // Build a list of themes that support group modules
368 $sugar_smarty->assign("DISPLAY_GROUP_TAB", 'none');
369
370 $selectedTheme = $user_theme;
371 if(!isset($user_theme)) {
372     $selectedTheme = $GLOBALS['sugar_config']['default_theme'];
373 }
374
375 $themeList = SugarThemeRegistry::availableThemes();
376 $themeGroupList = array();
377
378 foreach ( $themeList as $themeId => $themeName ) {
379     $currThemeObj = SugarThemeRegistry::get($themeId);
380     if ( isset($currThemeObj->group_tabs) && $currThemeObj->group_tabs == 1 ) {
381         $themeGroupList[$themeId] = true;
382         if ( $themeId == $selectedTheme ) {
383             $sugar_smarty->assign("DISPLAY_GROUP_TAB", '');
384         }
385     } else {
386         $themeGroupList[$themeId] = false;
387     }
388 }
389 $sugar_smarty->assign("themeGroupListJSON",json_encode($themeGroupList));
390
391 $sugar_smarty->assign("MAIL_SENDTYPE", get_select_options_with_id($app_list_strings['notifymail_sendtype'], $focus->getPreference('mail_sendtype')));
392 $reminder_time = $focus->getPreference('reminder_time');
393 if(empty($reminder_time)){
394         $reminder_time = -1;
395 }
396 $sugar_smarty->assign("REMINDER_TIME_OPTIONS", get_select_options_with_id($app_list_strings['reminder_time_options'],$reminder_time));
397 if($reminder_time > -1){
398         $sugar_smarty->assign("REMINDER_TIME_DISPLAY", 'inline');
399         $sugar_smarty->assign("REMINDER_CHECKED", 'checked');
400 }else{
401         $sugar_smarty->assign("REMINDER_TIME_DISPLAY", 'none');
402 }
403 //Add Custom Fields
404 $xtpl = $sugar_smarty;
405 require_once('modules/DynamicFields/templates/Files/EditView.php');
406
407 $edit_self = $current_user->id == $focus->id;
408 $admin_edit_self = is_admin($current_user) && $edit_self;
409
410 if($is_current_admin) {
411         $status  = "<td scope='row'><slot>".$mod_strings['LBL_STATUS'].": <span class='required'>".$app_strings['LBL_REQUIRED_SYMBOL']."</span></slot></td>\n";
412         $status .= "<td><select name='status' tabindex='1'";
413         if((!empty($sugar_config['default_user_name']) &&
414                 $sugar_config['default_user_name']== $focus->user_name &&
415                 isset($sugar_config['lock_default_user_name']) &&
416                 $sugar_config['lock_default_user_name']) || $admin_edit_self)
417         {
418                 $status .= ' disabled="disabled" ';
419         }
420         $status .= ">";
421         $status .= get_select_options_with_id($app_list_strings['user_status_dom'], $focus->status);
422         $status .= "</select></td>\n";
423         $sugar_smarty->assign("USER_STATUS_OPTIONS", $status);
424 }
425 if($is_current_admin && $_REQUEST['module'] != 'DynamicLayout' && !empty($_SESSION['editinplace'])){
426         $record = '';
427         if(!empty($_REQUEST['record'])){
428                 $record =       $_REQUEST['record'];
429         }
430         $sugar_smarty->assign("ADMIN_EDIT","<a href='index.php?action=index&module=DynamicLayout&from_action=".$_REQUEST['action'] ."&from_module=".$_REQUEST['module'] ."&record=".$record. "'>".SugarThemeRegistry::current()->getImage("EditLayout","border='0' alt='Edit Layout' align='bottom'")."</a>");
431 }
432
433 if(!empty($sugar_config['default_user_name']) &&
434         $sugar_config['default_user_name'] == $focus->user_name &&
435         isset($sugar_config['lock_default_user_name']) &&
436         $sugar_config['lock_default_user_name'])
437 {
438         $status .= ' disabled ';
439         $sugar_smarty->assign('FIRST_NAME_DISABLED', 'disabled="disabled"');
440         $sugar_smarty->assign('USER_NAME_DISABLED', 'disabled="disabled"');
441         $sugar_smarty->assign('LAST_NAME_DISABLED', 'disabled="disabled"');
442         $sugar_smarty->assign('IS_ADMIN_DISABLED', 'disabled="disabled"');
443         $sugar_smarty->assign('IS_PORTAL_ONLY_DISABLED', 'disabled="disabled"');
444         $sugar_smarty->assign('IS_GROUP_DISABLED', 'disabled="disabled"');
445 }
446
447 if($focus->receive_notifications ||(!isset($focus->id) && $admin->settings['notify_send_by_default'])) $sugar_smarty->assign("RECEIVE_NOTIFICATIONS", "checked");
448 if($focus->getPreference('mailmerge_on') == 'on') {
449         $sugar_smarty->assign('MAILMERGE_ON', 'checked');
450 }
451 $usertype='REGULAR';
452 if(!empty($focus->is_admin) && $focus->is_admin){
453    $usertype='ADMIN';
454 }
455
456
457
458 if((!empty($focus->is_group) && $focus->is_group)  || (isset($_REQUEST['usertype']) && $_REQUEST['usertype']=='group')){
459         $sugar_smarty->assign('IS_GROUP', '1');
460         $usertype='GROUP';
461 } else
462         $sugar_smarty->assign('IS_GROUP', '0');
463
464 $sugar_smarty->assign("USER_TYPE_DESC", $mod_strings['LBL_'.$usertype.'_DESC']);
465 $sugar_smarty->assign("USER_TYPE_LABEL", $mod_strings['LBL_'.$usertype.'_USER']);
466 $sugar_smarty->assign('USER_TYPE',$usertype);
467
468 $enable_syst_generate_pwd=false;
469 if(isset($sugar_config['passwordsetting']) && isset($sugar_config['passwordsetting']['SystemGeneratedPasswordON'])){
470         $enable_syst_generate_pwd=$sugar_config['passwordsetting']['SystemGeneratedPasswordON'];
471 }
472
473 // If new regular user without system generated password or new portal user
474 if(((isset($enable_syst_generate_pwd) && !$enable_syst_generate_pwd && $usertype!='GROUP') || $usertype =='PORTAL_ONLY') && empty($focus->id))
475         $sugar_smarty->assign('REQUIRED_PASSWORD','1');
476 else
477     $sugar_smarty->assign('REQUIRED_PASSWORD','0');
478
479 // If my account page or portal only user or regular user without system generated password or a duplicate user
480 if((($current_user->id == $focus->id) || $usertype=='PORTAL_ONLY' || (($usertype=='REGULAR' || (isset($_REQUEST['isDuplicate']) && $_REQUEST['isDuplicate'] == 'true' && $usertype!='GROUP')) && !$enable_syst_generate_pwd)) && !$focus->external_auth_only )
481    $sugar_smarty->assign('CHANGE_PWD', '1');
482 else
483    $sugar_smarty->assign('CHANGE_PWD', '0');
484
485 // Make sure group users don't get a password change prompt
486 if ( $usertype == 'GROUP' ) {
487     $sugar_smarty->assign('CHANGE_PWD', '0');
488 }
489
490 $configurator = new Configurator();
491 if ( isset($configurator->config['passwordsetting']) && ($configurator->config['passwordsetting']['SystemGeneratedPasswordON'] || $configurator->config['passwordsetting']['forgotpasswordON'])
492         && $usertype != 'GROUP' && $usertype != 'PORTAL_ONLY' )
493         $sugar_smarty->assign('REQUIRED_EMAIL_ADDRESS','1');
494 else
495         $sugar_smarty->assign('REQUIRED_EMAIL_ADDRESS','0');
496 if($usertype=='GROUP' || $usertype=='PORTAL_ONLY'){
497         $sugar_smarty->assign('HIDE_FOR_GROUP_AND_PORTAL', 'none');
498         $sugar_smarty->assign('HIDE_CHANGE_USERTYPE','none');}
499 else{
500         $sugar_smarty->assign('HIDE_FOR_NORMAL_AND_ADMIN','none');
501         if (!$is_current_admin)
502                 $sugar_smarty->assign('HIDE_CHANGE_USERTYPE','none');
503         else
504                 $sugar_smarty->assign('HIDE_STATIC_USERTYPE','none');
505         }
506
507 $sugar_smarty->assign('IS_FOCUS_ADMIN', is_admin($focus));
508
509 $disable_download_tab = !isset($sugar_config['disable_download_tab']) ? false : $sugar_config['disable_download_tab'];
510
511 if($edit_self && !$disable_download_tab) {
512         $sugar_smarty->assign('EDIT_SELF','1');
513 }
514 if($admin_edit_self) {
515         $sugar_smarty->assign('ADMIN_EDIT_SELF','1');
516 }
517
518
519 /////////////////////////////////////////////
520 /// Handle email account selections for users
521 /////////////////////////////////////////////
522  $hide_if_can_use_default = true;
523 if( !($usertype=='GROUP' || $usertype=='PORTAL_ONLY') )
524 {
525     // email smtp
526     $systemOutboundEmail = new OutboundEmail();
527     $systemOutboundEmail = $systemOutboundEmail->getSystemMailerSettings();
528     $mail_smtpserver = $systemOutboundEmail->mail_smtpserver;
529     $mail_smtptype = $systemOutboundEmail->mail_smtptype;
530     $mail_smtpport = $systemOutboundEmail->mail_smtpport;
531     $mail_smtpssl = $systemOutboundEmail->mail_smtpssl;
532     $mail_smtpuser = "";
533     $mail_smtppass = "";
534     $mail_smtpdisplay = $systemOutboundEmail->mail_smtpdisplay;
535     $hide_if_can_use_default = true;
536     $mail_smtpauth_req=true;
537
538     if( !$systemOutboundEmail->isAllowUserAccessToSystemDefaultOutbound() )
539     {
540
541         $mail_smtpauth_req = $systemOutboundEmail->mail_smtpauth_req;
542         $userOverrideOE = $systemOutboundEmail->getUsersMailerForSystemOverride($current_user->id);
543         if($userOverrideOE != null) {
544
545             $mail_smtpuser = $userOverrideOE->mail_smtpuser;
546             $mail_smtppass = $userOverrideOE->mail_smtppass;
547
548         }
549
550
551         if(!$mail_smtpauth_req &&
552             ( empty($systemOutboundEmail->mail_smtpserver) || empty($systemOutboundEmail->mail_smtpuser)
553             || empty($systemOutboundEmail->mail_smtppass)))
554         {
555             $hide_if_can_use_default = true;
556         }
557         else{
558             $hide_if_can_use_default = false;
559         }
560     }
561
562     $sugar_smarty->assign("mail_smtpdisplay", $mail_smtpdisplay);
563     $sugar_smarty->assign("mail_smtpserver", $mail_smtpserver);
564     $sugar_smarty->assign("mail_smtpuser", $mail_smtpuser);
565     $sugar_smarty->assign("mail_smtppass", "");
566     $sugar_smarty->assign("mail_haspass", empty($systemOutboundEmail->mail_smtppass)?0:1);
567     $sugar_smarty->assign("mail_smtpauth_req", $mail_smtpauth_req);
568     $sugar_smarty->assign('MAIL_SMTPPORT',$mail_smtpport);
569     $sugar_smarty->assign('MAIL_SMTPSSL',$mail_smtpssl);
570 }
571 $sugar_smarty->assign('HIDE_IF_CAN_USE_DEFAULT_OUTBOUND',$hide_if_can_use_default );
572
573 $reports_to_change_button_html = '';
574
575 if($is_current_admin) {
576         //////////////////////////////////////
577         ///
578         /// SETUP USER POPUP
579
580         $reportsDisplayName = showFullName() ? 'name' : 'user_name';
581         $popup_request_data = array(
582                 'call_back_function' => 'set_return',
583                 'form_name' => 'EditView',
584                 'field_to_name_array' => array(
585                         'id' => 'reports_to_id',
586                         "$reportsDisplayName" => 'reports_to_name',
587                         ),
588                 );
589
590         $json = getJSONobj();
591         $encoded_popup_request_data = $json->encode($popup_request_data);
592         $sugar_smarty->assign('encoded_popup_request_data', $encoded_popup_request_data);
593
594         //
595         ///////////////////////////////////////
596
597         $reports_to_change_button_html = '<input type="button"'
598         . " title=\"{$app_strings['LBL_SELECT_BUTTON_TITLE']}\""
599         . " accesskey=\"{$app_strings['LBL_SELECT_BUTTON_KEY']}\""
600         . " value=\"{$app_strings['LBL_SELECT_BUTTON_LABEL']}\""
601         . ' tabindex="5" class="button" name="btn1"'
602         . " onclick='open_popup(\"Users\", 600, 400, \"\", true, false, {$encoded_popup_request_data});'"
603         . "' />";
604 } else {
605         $sugar_smarty->assign('IS_ADMIN_DISABLED', 'disabled="disabled"');
606 }
607 $sugar_smarty->assign('REPORTS_TO_CHANGE_BUTTON', $reports_to_change_button_html);
608
609 /* Module Tab Chooser */
610 require_once('include/templates/TemplateGroupChooser.php');
611 require_once('modules/MySettings/TabController.php');
612 $chooser = new TemplateGroupChooser();
613 $controller = new TabController();
614
615
616 if($is_current_admin || $controller->get_users_can_edit()) {
617         $chooser->display_hide_tabs = true;
618 } else {
619         $chooser->display_hide_tabs = false;
620 }
621
622 $chooser->args['id'] = 'edit_tabs';
623 $chooser->args['values_array'] = $controller->get_tabs($focus);
624 foreach($chooser->args['values_array'][0] as $key=>$value) {
625     $chooser->args['values_array'][0][$key] = $app_list_strings['moduleList'][$key];
626 }
627
628 foreach($chooser->args['values_array'][1] as $key=>$value) {
629     $chooser->args['values_array'][1][$key] = $app_list_strings['moduleList'][$key];
630 }
631
632 foreach($chooser->args['values_array'][2] as $key=>$value) {
633     $chooser->args['values_array'][2][$key] = $app_list_strings['moduleList'][$key];
634 }
635
636 $chooser->args['left_name'] = 'display_tabs';
637 $chooser->args['right_name'] = 'hide_tabs';
638
639 $chooser->args['left_label'] =  $mod_strings['LBL_DISPLAY_TABS'];
640 $chooser->args['right_label'] =  $mod_strings['LBL_HIDE_TABS'];
641 $chooser->args['title'] =  $mod_strings['LBL_EDIT_TABS'].' <img border="0" src="themes/default/images/helpInline.gif" onmouseover="return overlib(\'Choose which tabs are displayed.\', FGCLASS, \'olFgClass\', CGCLASS, \'olCgClass\', BGCLASS, \'olBgClass\', TEXTFONTCLASS, \'olFontClass\', CAPTIONFONTCLASS, \'olCapFontClass\', CLOSEFONTCLASS, \'olCloseFontClass\', WIDTH, -1, NOFOLLOW, \'ol_nofollow\' );" onmouseout="return nd();"/>';
642 $sugar_smarty->assign('TAB_CHOOSER', $chooser->display());
643 $sugar_smarty->assign('CHOOSER_SCRIPT','set_chooser();');
644 $sugar_smarty->assign('CHOOSE_WHICH', $mod_strings['LBL_CHOOSE_WHICH']);
645 ///////////////////////////////////////////////////////////////////////////////
646 ////    EMAIL OPTIONS
647 // We need to turn off the requiredness of emails if it is a group or portal user
648 if ($usertype == 'GROUP' || $usertype == 'PORTAL_ONLY' ) {
649     global $dictionary;
650     $dictionary['User']['fields']['email1']['required'] = false;
651 }
652 // hack to disable email field being required if it shouldn't be required
653 if ( $sugar_smarty->get_template_vars("REQUIRED_EMAIL_ADDRESS") == '0' )
654     $GLOBALS['dictionary']['User']['fields']['email1']['required'] = false;
655 $sugar_smarty->assign("NEW_EMAIL", getEmailAddressWidget($focus, "email1", $focus->email1, "EditView"));
656 // hack to undo that previous hack
657 if ( $sugar_smarty->get_template_vars("REQUIRED_EMAIL_ADDRESS") == '0' )
658     $GLOBALS['dictionary']['User']['fields']['email1']['required'] = true;
659 $sugar_smarty->assign('EMAIL_LINK_TYPE', get_select_options_with_id($app_list_strings['dom_email_link_type'], $focus->getPreference('email_link_type')));
660 /////   END EMAIL OPTIONS
661 ///////////////////////////////////////////////////////////////////////////////
662
663
664 if ($is_current_admin) {
665 $employee_status = '<select tabindex="5" name="employee_status">';
666 $employee_status .= get_select_options_with_id($app_list_strings['employee_status_dom'], $focus->employee_status);
667 $employee_status .= '</select>';
668 } else {
669         $employee_status = $focus->employee_status;
670 }
671 $sugar_smarty->assign('EMPLOYEE_STATUS_OPTIONS', $employee_status);
672 $sugar_smarty->assign('EMPLOYEE_STATUS_OPTIONS', $employee_status);
673
674 $messenger_type = '<select tabindex="5" name="messenger_type">';
675 $messenger_type .= get_select_options_with_id($app_list_strings['messenger_type_dom'], $focus->messenger_type);
676 $messenger_type .= '</select>';
677 $sugar_smarty->assign('MESSENGER_TYPE_OPTIONS', $messenger_type);
678 $sugar_smarty->assign('MESSENGER_ID', $focus->messenger_id);
679
680 $sugar_smarty->assign('CALENDAR_PUBLISH_KEY', $focus->getPreference('calendar_publish_key' ));
681 //$sugar_smarty->parse('main.freebusy');
682
683
684 $sugar_smarty->display('modules/Users/EditView.tpl');
685 $json = getJSONobj();
686
687 require_once('include/QuickSearchDefaults.php');
688 $qsd = new QuickSearchDefaults();
689 $sqs_objects = array('EditView_reports_to_name' => $qsd->getQSUser());
690 $sqs_objects['EditView_reports_to_name']['populate_list'] = array('reports_to_name', 'reports_to_id');
691
692
693 $quicksearch_js = '<script type="text/javascript" language="javascript">
694                     sqs_objects = ' . $json->encode($sqs_objects) . '; enableQS();</script>';
695 echo $quicksearch_js;
696
697 //echo $str;
698 //BUG #16298
699 ?>