Your IP : 3.137.219.123
<?php
/**
* Bitrix Framework
* @package bitrix
* @subpackage main
* @copyright 2001-2013 Bitrix
* @global CMain $APPLICATION
* @global CUser $USER
* @global CDatabase $DB
* @global CUserTypeManager $USER_FIELD_MANAGER
*/
require_once(dirname(__FILE__)."/../include/prolog_admin_before.php");
require_once($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/main/prolog.php");
define("HELP_FILE", "users/user_edit.php");
$strRedirect_admin = BX_ROOT."/admin/user_admin.php?lang=".LANG;
$strRedirect = BX_ROOT."/admin/user_edit.php?lang=".LANG;
ClearVars();
$canViewUserList = ($USER->CanDoOperation('view_subordinate_users') || $USER->CanDoOperation('view_all_users') || $USER->CanDoOperation('edit_all_users') || $USER->CanDoOperation('edit_subordinate_users'));
if(!($USER->CanDoOperation('view_own_profile') || $USER->CanDoOperation('edit_own_profile') || $canViewUserList))
$APPLICATION->AuthForm(GetMessage("ACCESS_DENIED"));
$ID = intval($_REQUEST["ID"]);
$COPY_ID = intval($_REQUEST["COPY_ID"]);
$uid = $USER->GetID();
if($USER->CanDoOperation('edit_own_profile') && !$canViewUserList)
{
$ID = $uid;
if($ID <= 0)
$APPLICATION->AuthForm(GetMessage("ACCESS_DENIED"));
$COPY_ID = 0;
}
IncludeModuleLangFile(__FILE__);
$PROPERTY_ID = "USER";
$message = null;
$strError = '';
$res = true;
if($COPY_ID<=0)
{
$arUserGroups = CUser::GetUserGroup($ID);
}
else
{
$arUserGroups = array();
$ID = $COPY_ID;
}
$selfEdit = ($USER->CanDoOperation('edit_own_profile') && $ID == $uid);
$arUserSubordinateGroups = array();
if($USER->CanDoOperation('edit_subordinate_users') && !$USER->CanDoOperation('edit_all_users'))
{
$arUserSubordinateGroups = array(2);
$arUserGroups_u = CUser::GetUserGroup($uid);
for ($j = 0,$len = count($arUserGroups_u); $j < $len; $j++)
{
$arSubordinateGroups = CGroup::GetSubordinateGroups($arUserGroups_u[$j]);
$arUserSubordinateGroups = array_merge ($arUserSubordinateGroups, $arSubordinateGroups);
}
$arUserSubordinateGroups = array_unique($arUserSubordinateGroups);
if (count(array_diff($arUserGroups, $arUserSubordinateGroups)) > 0 && !$selfEdit)
LocalRedirect(BX_ROOT."/admin/user_admin.php?lang=".LANG);
}
$editable = ($USER->IsAdmin() ||
$selfEdit ||
($USER->CanDoOperation('edit_subordinate_users') && !in_array(1, $arUserGroups)) ||
($USER->CanDoOperation('edit_all_users') && !in_array(1, $arUserGroups))
);
$canSelfEdit = true;
if($ID==$uid && !($USER->CanDoOperation('edit_php') || ($USER->CanDoOperation('edit_all_users') && $USER->CanDoOperation('edit_groups'))))
$canSelfEdit = false;
$showGroupTabs = (($USER->CanDoOperation('view_subordinate_users') || $USER->CanDoOperation('view_all_users')) && $canSelfEdit);
$aTabs = array();
$aTabs[] = array("DIV" => "edit1", "TAB" => GetMessage("MAIN_USER_TAB1"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage("MAIN_USER_TAB1_TITLE"));
if($showGroupTabs)
$aTabs[] = array("DIV" => "edit2", "TAB" => GetMessage("GROUPS"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage("MAIN_USER_TAB2_TITLE"));
$aTabs[] = array("DIV" => "edit3", "TAB" => GetMessage("USER_PERSONAL_INFO"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage("USER_PERSONAL_INFO"));
$aTabs[] = array("DIV" => "edit4", "TAB" => GetMessage("MAIN_USER_TAB4"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage("USER_WORK_INFO"));
$aTabs[] = array("DIV" => "edit_rating", "TAB" => GetMessage("USER_RATING_INFO"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage("USER_RATING_INFO"));
$i = 1;
$db_opt_res = CModule::GetList();
while ($opt_res = $db_opt_res->Fetch())
{
$mdir = $opt_res["ID"];
if (file_exists($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir) && is_dir($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir))
{
$ofile = $_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir."/options_user_settings.php";
if(file_exists($ofile))
{
IncludeModuleLangFile($ofile);
$mname = str_replace(".", "_", $mdir);
$aTabs[] = array("DIV" => "edit_".$mname, "TAB" => GetMessage($mname."_TAB"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage($mname."_TAB_TITLE"));
$i++;
}
}
}
if(($editable && $ID!=$USER->GetID()) || $USER->IsAdmin())
$aTabs[] = array("DIV" => "edit".($i+5), "TAB" => GetMessage("MAIN_USER_TAB5"), "ICON"=>"main_user_edit", "TITLE"=>GetMessage("USER_ADMIN_NOTES"));
//Add user fields tab only when there is fields defined or user has rights for adding new field
if(
(count($USER_FIELD_MANAGER->GetUserFields($PROPERTY_ID)) > 0) ||
($USER_FIELD_MANAGER->GetRights($PROPERTY_ID) >= "W")
)
{
$aTabs[] = $USER_FIELD_MANAGER->EditFormTab($PROPERTY_ID);
}
$tabControl = new CAdminForm("user_edit", $aTabs);
if(
$_SERVER["REQUEST_METHOD"]=="POST"
&& (
$_REQUEST["save"]<>''
|| $_REQUEST["apply"]<>''
|| $_REQUEST["Update"]=="Y"
|| $_REQUEST["save_and_add"]<>''
)
&& $editable
&& check_bitrix_sessid()
)
{
if(COption::GetOptionString('main', 'use_encrypted_auth', 'N') == 'Y')
{
//possible encrypted user password
$sec = new CRsaSecurity();
if(($arKeys = $sec->LoadKeys()))
{
$sec->SetKeys($arKeys);
$errno = $sec->AcceptFromForm(array('NEW_PASSWORD', 'NEW_PASSWORD_CONFIRM'));
if($errno == CRsaSecurity::ERROR_SESS_CHECK)
$strError .= GetMessage("main_profile_sess_expired").'<br />';
elseif($errno < 0)
$strError .= GetMessage("main_profile_decode_err", array("#ERRCODE#"=>$errno)).'<br />';
}
}
if($strError == '')
{
$user = new CUser;
$arPERSONAL_PHOTO = $_FILES["PERSONAL_PHOTO"];
$arWORK_LOGO = $_FILES["WORK_LOGO"];
$arUser = false;
if($ID > 0 && $COPY_ID <= 0)
{
$dbUser = CUser::GetById($ID);
$arUser = $dbUser->Fetch();
}
if($arUser)
{
$arPERSONAL_PHOTO["old_file"] = $arUser["PERSONAL_PHOTO"];
$arPERSONAL_PHOTO["del"] = $_POST["PERSONAL_PHOTO_del"];
$arWORK_LOGO["old_file"] = $arUser["WORK_LOGO"];
$arWORK_LOGO["del"] = $_POST["WORK_LOGO_del"];
}
$arFields = array(
"TITLE" => $_POST["TITLE"],
"NAME" => $_POST["NAME"],
"LAST_NAME" => $_POST["LAST_NAME"],
"SECOND_NAME" => $_POST["SECOND_NAME"],
"EMAIL" => $_POST["EMAIL"],
"LOGIN" => $_POST["LOGIN"],
"PERSONAL_PROFESSION" => $_POST["PERSONAL_PROFESSION"],
"PERSONAL_WWW" => $_POST["PERSONAL_WWW"],
"PERSONAL_ICQ" => $_POST["PERSONAL_ICQ"],
"PERSONAL_GENDER" => $_POST["PERSONAL_GENDER"],
"PERSONAL_BIRTHDAY" => $_POST["PERSONAL_BIRTHDAY"],
"PERSONAL_PHOTO" => $arPERSONAL_PHOTO,
"PERSONAL_PHONE" => $_POST["PERSONAL_PHONE"],
"PERSONAL_FAX" => $_POST["PERSONAL_FAX"],
"PERSONAL_MOBILE" => $_POST["PERSONAL_MOBILE"],
"PERSONAL_PAGER" => $_POST["PERSONAL_PAGER"],
"PERSONAL_STREET" => $_POST["PERSONAL_STREET"],
"PERSONAL_MAILBOX" => $_POST["PERSONAL_MAILBOX"],
"PERSONAL_CITY" => $_POST["PERSONAL_CITY"],
"PERSONAL_STATE" => $_POST["PERSONAL_STATE"],
"PERSONAL_ZIP" => $_POST["PERSONAL_ZIP"],
"PERSONAL_COUNTRY" => $_POST["PERSONAL_COUNTRY"],
"PERSONAL_NOTES" => $_POST["PERSONAL_NOTES"],
"WORK_COMPANY" => $_POST["WORK_COMPANY"],
"WORK_DEPARTMENT" => $_POST["WORK_DEPARTMENT"],
"WORK_POSITION" => $_POST["WORK_POSITION"],
"WORK_WWW" => $_POST["WORK_WWW"],
"WORK_PHONE" => $_POST["WORK_PHONE"],
"WORK_FAX" => $_POST["WORK_FAX"],
"WORK_PAGER" => $_POST["WORK_PAGER"],
"WORK_STREET" => $_POST["WORK_STREET"],
"WORK_MAILBOX" => $_POST["WORK_MAILBOX"],
"WORK_CITY" => $_POST["WORK_CITY"],
"WORK_STATE" => $_POST["WORK_STATE"],
"WORK_ZIP" => $_POST["WORK_ZIP"],
"WORK_COUNTRY" => $_POST["WORK_COUNTRY"],
"WORK_PROFILE" => $_POST["WORK_PROFILE"],
"WORK_LOGO" => $arWORK_LOGO,
"WORK_NOTES" => $_POST["WORK_NOTES"],
"AUTO_TIME_ZONE" => ($_POST["AUTO_TIME_ZONE"] == "Y" || $_POST["AUTO_TIME_ZONE"] == "N"? $_POST["AUTO_TIME_ZONE"] : ""),
"XML_ID" => $_POST["XML_ID"],
);
if(isset($_POST["TIME_ZONE"]))
$arFields["TIME_ZONE"] = $_POST["TIME_ZONE"];
if($USER->CanDoOperation('edit_all_users') || $USER->CanDoOperation('edit_subordinate_users'))
{
if($_POST["LID"] <> '')
$arFields["LID"] = $_POST["LID"];
if(isset($_POST["LANGUAGE_ID"]))
$arFields["LANGUAGE_ID"] = $_POST["LANGUAGE_ID"];
if(isset($_POST['EXTERNAL_AUTH_ID']))
$arFields['EXTERNAL_AUTH_ID'] = $_POST["EXTERNAL_AUTH_ID"];
if ($ID == 1 && $COPY_ID <= 0)
$arFields["ACTIVE"] = "Y";
else
$arFields["ACTIVE"] = $_POST["ACTIVE"];
if($showGroupTabs && isset($_REQUEST["GROUP_ID_NUMBER"]))
{
$GROUP_ID_NUMBER = intval($_REQUEST["GROUP_ID_NUMBER"]);
$GROUP_ID = array();
$ind = -1;
for ($i = 0; $i <= $GROUP_ID_NUMBER; $i++)
{
if (${"GROUP_ID_ACT_".$i} == "Y")
{
$gr_id = intval(${"GROUP_ID_".$i});
if($gr_id == 1 && !$USER->IsAdmin())
continue;
if ($USER->CanDoOperation('edit_subordinate_users') && !$USER->CanDoOperation('edit_all_users') && !in_array($gr_id, $arUserSubordinateGroups))
continue;
$ind++;
$GROUP_ID[$ind]["GROUP_ID"] = $gr_id;
$GROUP_ID[$ind]["DATE_ACTIVE_FROM"] = ${"GROUP_ID_FROM_".$i};
$GROUP_ID[$ind]["DATE_ACTIVE_TO"] = ${"GROUP_ID_TO_".$i};
}
}
if ($ID == "1" && $COPY_ID<=0)
{
$ind++;
$GROUP_ID[$ind]["GROUP_ID"] = 1;
$GROUP_ID[$ind]["DATE_ACTIVE_FROM"] = false;
$GROUP_ID[$ind]["DATE_ACTIVE_TO"] = false;
}
$arFields["GROUP_ID"]=$GROUP_ID;
}
if (($editable && $ID!=$USER->GetID()) || $USER->IsAdmin())
$arFields["ADMIN_NOTES"] = $_POST["ADMIN_NOTES"];
}
if($_POST["NEW_PASSWORD"] <> '')
{
$arFields["PASSWORD"] = $_POST["NEW_PASSWORD"];
$arFields["CONFIRM_PASSWORD"] = $_POST["NEW_PASSWORD_CONFIRM"];
}
$USER_FIELD_MANAGER->EditFormAddFields($PROPERTY_ID, $arFields);
if($ID>0 && $COPY_ID<=0)
{
$res = $user->Update($ID, $arFields, true);
}
elseif($USER->CanDoOperation('edit_all_users') || $USER->CanDoOperation('edit_subordinate_users'))
{
$ID = $user->Add($arFields);
$res = ($ID > 0);
if(COption::GetOptionString("main", "event_log_register", "N") === "Y" && $res)
{
$res_log["user"] = ($_POST["NAME"] != "" || $_POST["LAST_NAME"] != "") ? trim($_POST["NAME"]." ".$_POST["LAST_NAME"]) : $_POST["LOGIN"];
CEventLog::Log("SECURITY", "USER_REGISTER", "main", $ID, serialize($res_log));
}
$new = "Y";
}
if ($USER->CanDoOperation('edit_ratings') && ($selfEdit || $ID!=$USER->GetID()) && is_array($_POST['RATING_BONUS']))
{
foreach ($_POST['RATING_BONUS'] as $ratingId => $ratingBonus)
{
if ($new == "Y" && $ratingBonus == 0)
{
continue;
}
$arParam = array(
'RATING_ID' => $ratingId,
'ENTITY_ID' => $ID,
'BONUS' => $ratingBonus,
);
CRatings::UpdateRatingUserBonus($arParam);
}
}
$strError .= $user->LAST_ERROR;
if ($APPLICATION->GetException())
{
$err = $APPLICATION->GetException();
$strError .= $err->GetString();
$APPLICATION->ResetException();
}
}
if($strError == '' && $ID>0)
{
if(is_array($_REQUEST["profile_module_id"]) && count($_REQUEST["profile_module_id"])>0)
{
$db_opt_res = CModule::GetList();
while ($opt_res = $db_opt_res->Fetch())
{
if (in_array($opt_res["ID"], $_REQUEST["profile_module_id"]))
{
$mdir = $opt_res["ID"];
if (file_exists($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir) && is_dir($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir))
{
$ofile = $_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir."/options_user_settings_set.php";
if (file_exists($ofile))
{
$MODULE_RIGHT = $APPLICATION->GetGroupRight($mdir);
if ($MODULE_RIGHT>="R")
{
include($ofile);
$mname = str_replace(".", "_", $mdir);
if(!${$mname."_res"})
{
$res = false;
if($APPLICATION->GetException())
{
$err = $APPLICATION->GetException();
$strError .= $err->GetString();
$APPLICATION->ResetException();
}
else
{
$strError .= ${$mname."WarningTmp"};
}
}
}
}
}
}
}
}
if($strError == '' && $res)
{
if($_POST["user_info_event"] == "Y")
{
$arMess = false;
$res_site = CSite::GetByID($_POST["LID"]);
if($res_site_arr = $res_site->Fetch())
$arMess = IncludeModuleLangFile(__FILE__, $res_site_arr["LANGUAGE_ID"], true);
if($new == "Y")
{
$text = ($arMess !== false? $arMess["ACCOUNT_INSERT"] : GetMessage("ACCOUNT_INSERT"));
}
else
{
$text = ($arMess !== false? $arMess["ACCOUNT_UPDATE"] : GetMessage("ACCOUNT_UPDATE"));
}
CUser::SendUserInfo($ID, $_POST["LID"], $text, true);
}
if($USER->CanDoOperation('edit_all_users') || $USER->CanDoOperation('edit_subordinate_users') || ($USER->CanDoOperation('edit_own_profile') && $ID==$uid))
{
if($_POST["save"] <> '')
LocalRedirect($strRedirect_admin);
elseif($_POST["apply"] <> '')
LocalRedirect($strRedirect."&ID=".$ID."&".$tabControl->ActiveTabParam());
elseif(strlen($save_and_add)>0)
LocalRedirect($strRedirect."&ID=0&".$tabControl->ActiveTabParam());
}
elseif($new=="Y")
LocalRedirect($strRedirect."&ID=".$ID."&".$tabControl->ActiveTabParam());
}
}
}
$str_GROUP_ID = array();
$user = CUser::GetByID($ID);
if(!$user->ExtractFields("str_"))
{
$ID = 0;
$str_ACTIVE = "Y";
$str_LID = CSite::GetDefSite();
}
else
{
$dbUserGroup = CUser::GetUserGroupList($ID);
while ($arUserGroup = $dbUserGroup->Fetch())
{
$str_GROUP_ID[intval($arUserGroup["GROUP_ID"])]["DATE_ACTIVE_FROM"] = $arUserGroup["DATE_ACTIVE_FROM"];
$str_GROUP_ID[intval($arUserGroup["GROUP_ID"])]["DATE_ACTIVE_TO"] = $arUserGroup["DATE_ACTIVE_TO"];
}
}
if($COPY_ID > 0)
{
$str_PERSONAL_PHOTO = "";
$str_WORK_LOGO = "";
}
if($strError <> '' || !$res)
{
$save_PERSONAL_PHOTO = $str_PERSONAL_PHOTO;
$save_WORK_LOGO = $str_WORK_LOGO;
$DB->InitTableVarsForEdit("b_user", "", "str_");
$str_PERSONAL_PHOTO = $save_PERSONAL_PHOTO;
$str_WORK_LOGO = $save_WORK_LOGO;
$GROUP_ID_NUMBER = intval($_REQUEST["GROUP_ID_NUMBER"]);
$str_GROUP_ID = array();
for ($i = 0; $i <= $GROUP_ID_NUMBER; $i++)
{
if (${"GROUP_ID_ACT_".$i} == "Y")
{
$str_GROUP_ID[intval(${"GROUP_ID_".$i})]["DATE_ACTIVE_FROM"] = ${"GROUP_ID_FROM_".$i};
$str_GROUP_ID[intval(${"GROUP_ID_".$i})]["DATE_ACTIVE_TO"] = ${"GROUP_ID_TO_".$i};
}
}
}
if($ID>0 && $COPY_ID<=0)
$APPLICATION->SetTitle(GetMessage("EDIT_USER_TITLE", array("#ID#"=>$ID)));
else
$APPLICATION->SetTitle(GetMessage("NEW_USER_TITLE"));
require_once ($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/main/include/prolog_admin_after.php");
$aMenu = array();
if($canViewUserList)
{
$aMenu[] = array(
"TEXT" => GetMessage("RECORD_LIST"),
"LINK" => "/bitrix/admin/user_admin.php?lang=".LANGUAGE_ID."&apply_filter=Y",
"ICON" => "btn_list",
"TITLE" => GetMessage("RECORD_LIST_TITLE"),
);
}
if($USER->CanDoOperation('edit_all_users') || $USER->CanDoOperation('edit_subordinate_users'))
{
if ($ID>0 && $COPY_ID<=0)
{
$aMenu[] = array("SEPARATOR"=>"Y");
$aMenu[] = array(
"TEXT" => GetMessage("MAIN_NEW_RECORD"),
"LINK" => "/bitrix/admin/user_edit.php?lang=".LANGUAGE_ID,
"ICON" => "btn_new",
"TITLE" => GetMessage("MAIN_NEW_RECORD_TITLE"),
);
$aMenu[] = array(
"TEXT" => GetMessage("MAIN_COPY_RECORD"),
"LINK" => "/bitrix/admin/user_edit.php?lang=".LANGUAGE_ID.htmlspecialcharsbx("©_ID=").$ID,
"ICON" => "btn_copy",
"TITLE" => GetMessage("MAIN_COPY_RECORD_TITLE"),
);
if ($ID!=1)
{
$aMenu[] = array(
"TEXT" => GetMessage("MAIN_DELETE_RECORD"),
"LINK" => "javascript:if(confirm('".GetMessage("MAIN_DELETE_RECORD_CONF")."')) window.location='/bitrix/admin/user_admin.php?action=delete&ID=".$ID."&lang=".LANGUAGE_ID."&".bitrix_sessid_get()."';",
"ICON" => "btn_delete",
"TITLE" => GetMessage("MAIN_DELETE_RECORD_TITLE"),
);
}
}
}
if(!empty($aMenu))
$aMenu[] = array("SEPARATOR"=>"Y");
$context = new CAdminContextMenu($aMenu);
$context->Show();
if ($e = $APPLICATION->GetException())
$message = new CAdminMessage(GetMessage("MAIN_ERROR_SAVING"), $e);
if($message)
echo $message->Show();
if($strError <> '')
{
$e = new CAdminException(array(array('text' => $strError)));
$message = new CAdminMessage(GetMessage("MAIN_ERROR_SAVING"), $e);
echo $message->Show();
//echo CAdminMessage::ShowMessage(Array("MESSAGE"=>$strError, "HTML"=>true, "TYPE"=>"ERROR"));
}
//We have to explicitly call calendar and editor functions because
//first output may be discarded by form settings
$tabControl->BeginPrologContent();
if(method_exists($USER_FIELD_MANAGER, 'showscript'))
echo $USER_FIELD_MANAGER->ShowScript();
CAdminCalendar::ShowScript();
$tabControl->EndPrologContent();
$tabControl->BeginEpilogContent();
?>
<?=bitrix_sessid_post()?>
<input type="hidden" name="Update" value="Y">
<input type="hidden" name="COPY_ID" value=<?echo $COPY_ID?>>
<?
$tabControl->EndEpilogContent();
$limitUsersCount = $users_cnt = 0;
if($ID <= 0)
{
$users_cnt = CUser::GetActiveUsersCount();
$limitUsersCount = intval(COption::GetOptionInt("main", "PARAM_MAX_USERS", 0));
}
$tabControl->Begin(array(
"FORM_ACTION" => $APPLICATION->GetCurPage()."?ID=".intval($ID)."&lang=".LANG,
"FORM_ATTRIBUTES" => ($ID <= 0 && $limitUsersCount > 0 && $limitUsersCount <= $users_cnt? 'onsubmit="alert(\''.GetMessage("USER_EDIT_WARNING_MAX").'\')"':''),
));
$tabControl->BeginNextFormTab();
$tabControl->AddViewField("DATE_REGISTER", GetMessage("USER_EDIT_DATE_REGISTER"), ($ID>0 && $COPY_ID<=0? $str_DATE_REGISTER:''));
$tabControl->AddViewField("LAST_UPDATE", GetMessage('LAST_UPDATE'), ($ID>0 && $COPY_ID<=0? $str_TIMESTAMP_X:''));
$tabControl->AddViewField("LAST_LOGIN", GetMessage('LAST_LOGIN'), ($ID>0 && $COPY_ID<=0? $str_LAST_LOGIN:''));
if($ID <> 1 || $COPY_ID > 0):
$tabControl->BeginCustomField("ACTIVE", GetMessage('ACTIVE'));
?>
<tr>
<td><?echo $tabControl->GetCustomLabelHTML()?></td>
<td>
<?if($canSelfEdit):?>
<input type="checkbox" name="ACTIVE" value="Y"<?if($str_ACTIVE=="Y") echo " checked"?>>
<?else:?>
<input type="checkbox" <?if($str_ACTIVE=="Y") echo " checked"?> disabled>
<input type="hidden" name="ACTIVE" value="<?=$str_ACTIVE;?>">
<?endif;?>
</tr>
<?
$tabControl->EndCustomField("ACTIVE", '<input type="hidden" name="ACTIVE" value="'.$str_ACTIVE.'">');
else:
$tabControl->HideField('ACTIVE');
endif;
$emailRequired = (COption::GetOptionString("main", "new_user_email_required", "Y") <> "N");
$tabControl->AddEditField("TITLE", GetMessage("USER_EDIT_TITLE"), false, array("size"=>30), $str_TITLE);
$tabControl->AddEditField("NAME", GetMessage('NAME'), false, array("size"=>30), $str_NAME);
$tabControl->AddEditField("LAST_NAME", GetMessage('LAST_NAME'), false, array("size"=>30), $str_LAST_NAME);
$tabControl->AddEditField("SECOND_NAME", GetMessage('SECOND_NAME'), false, array("size"=>30), $str_SECOND_NAME);
$tabControl->AddEditField("EMAIL", GetMessage('EMAIL'), $emailRequired, array("size"=>30), $str_EMAIL);
$tabControl->AddEditField("LOGIN", GetMessage('LOGIN'), true, array("size"=>30), $str_LOGIN);
$tabControl->BeginCustomField("PASSWORD", GetMessage('NEW_PASSWORD_REQ'), true);
$bSecure = false;
if(!CMain::IsHTTPS() && COption::GetOptionString('main', 'use_encrypted_auth', 'N') == 'Y')
{
$sec = new CRsaSecurity();
if(($arKeys = $sec->LoadKeys()))
{
$sec->SetKeys($arKeys);
$sec->AddToForm('user_edit_form', array('NEW_PASSWORD', 'NEW_PASSWORD_CONFIRM'));
$bSecure = true;
}
}
?>
<tr id="bx_pass_row" style="display:<?=($str_EXTERNAL_AUTH_ID <> ''? 'none':'')?>;"<?if($ID<=0 || $COPY_ID>0):?> class="adm-detail-required-field"<?endif?>>
<td><?echo GetMessage('NEW_PASSWORD_REQ')?>:<sup><span class="required">1</span></sup></td>
<td><input type="password" name="NEW_PASSWORD" size="30" maxlength="50" value="<? echo htmlspecialcharsbx($NEW_PASSWORD) ?>" autocomplete="off" style="vertical-align:middle;">
<?if($bSecure):?>
<span class="bx-auth-secure" id="bx_auth_secure" title="<?echo GetMessage("AUTH_SECURE_NOTE")?>" style="display:none">
<div class="bx-auth-secure-icon"></div>
</span>
<noscript>
<span class="bx-auth-secure" title="<?echo GetMessage("AUTH_NONSECURE_NOTE")?>">
<div class="bx-auth-secure-icon bx-auth-secure-unlock"></div>
</span>
</noscript>
<script type="text/javascript">
document.getElementById('bx_auth_secure').style.display = 'inline-block';
</script>
<?endif?>
</td>
</tr>
<tr id="bx_pass_confirm_row" style="display:<?=($str_EXTERNAL_AUTH_ID <> ''? 'none':'')?>;"<?if($ID<=0 || $COPY_ID>0):?> class="adm-detail-required-field"<?endif?>>
<td><?echo GetMessage('NEW_PASSWORD_CONFIRM')?></td>
<td><input type="password" name="NEW_PASSWORD_CONFIRM" size="30" maxlength="50" value="<? echo htmlspecialcharsbx($NEW_PASSWORD_CONFIRM) ?>" autocomplete="off"></td>
</tr>
<?
$tabControl->EndCustomField("PASSWORD");
?>
<?if($USER->CanDoOperation('view_all_users')):?>
<?
$arAuthList = array();
$rExtAuth = CUser::GetExternalAuthList();
while($arExtAuth = $rExtAuth->GetNext())
$arAuthList[$arExtAuth['ID']] = $arExtAuth;
if($str_EXTERNAL_AUTH_ID <> '' && !array_key_exists($str_EXTERNAL_AUTH_ID, $arAuthList))
$arAuthList[$str_EXTERNAL_AUTH_ID] = array('ID'=>$str_EXTERNAL_AUTH_ID, 'NAME'=>$str_EXTERNAL_AUTH_ID);
if(!empty($arAuthList)):
$tabControl->BeginCustomField("EXTERNAL_AUTH_ID", GetMessage('MAIN_USERED_AUTH_TYPE'));
?>
<tr>
<td><?echo $tabControl->GetCustomLabelHTML()?></td>
<td>
<script type="text/javascript">
function BXAuthSwitch(val)
{
BX('bx_user_info_event').disabled = (val != '');
BX('bx_pass_row').style.display = BX('bx_pass_confirm_row').style.display = (val == ''? '':'none');
}
</script>
<select id="bx_EXTERNAL_AUTH_ID" name="EXTERNAL_AUTH_ID"<?if(!$canSelfEdit) echo " disabled"?> onchange="BXAuthSwitch(this.value)">
<option value=""><?echo GetMessage("MAIN_USERED_AUTH_INT")?></option>
<?foreach($arAuthList as $arExtAuth):?>
<option value="<?=$arExtAuth['ID']?>"<?if($str_EXTERNAL_AUTH_ID == $arExtAuth['ID']) echo ' selected';?>><?=$arExtAuth['NAME']?></option>
<?endforeach;?>
</select>
</td>
</tr>
<?
$tabControl->EndCustomField("EXTERNAL_AUTH_ID", '<input type="hidden" name="EXTERNAL_AUTH_ID" value="'.$str_EXTERNAL_AUTH_ID.'">');
endif;
endif;
$tabControl->AddEditField("XML_ID", GetMessage("MAIN_USER_EDIT_EXT"), false, array("size"=>30, "maxlength"=>255), $str_XML_ID);
?>
<?
if($USER->CanDoOperation('view_subordinate_users') || $USER->CanDoOperation('view_all_users') || $USER->CanDoOperation('edit_all_users') || $USER->CanDoOperation('edit_subordinate_users')):
$tabControl->BeginCustomField("LID", GetMessage("MAIN_DEFAULT_SITE"));
?>
<tr>
<td><?echo $tabControl->GetCustomLabelHTML()?></td>
<?if(!$canSelfEdit) $dis = " disabled"?>
<td><?=CSite::SelectBox("LID", $str_LID, "", "", "style=\"width:220px\"".$dis);?></td>
</tr>
<?
$tabControl->EndCustomField("LID", '<input type="hidden" name="LID" value="'.$str_LID.'">');
$langOptions = array("" => GetMessage("user_edit_lang_not_set"));
$languages = \Bitrix\Main\Localization\LanguageTable::getList(array("filter" => array("ACTIVE" => "Y"), "order" => array("SORT" => "ASC", "NAME" => "ASC")));
while($language = $languages->fetch())
{
$langOptions[$language["LID"]] = \Bitrix\Main\Text\HtmlFilter::encode($language["NAME"]);
}
$tabControl->AddDropDownField("LANGUAGE_ID", GetMessage("user_edit_lang"), false, $langOptions, $str_LANGUAGE_ID);
$params = array('id="bx_user_info_event"');
if(!$canSelfEdit || $str_EXTERNAL_AUTH_ID <> '')
{
$params[] = "disabled";
}
$tabControl->AddCheckBoxField("user_info_event", GetMessage('INFO_FOR_USER'), false, "Y", ($_REQUEST["user_info_event"]=="Y"), $params);
endif;
if(CTimeZone::Enabled())
{
$tabControl->AddSection("USER_TIME_ZONE", GetMessage("user_edit_time_zones"));
$tabControl->AddDropDownField("AUTO_TIME_ZONE", GetMessage("user_edit_time_zones_auto"), false, array(""=>GetMessage("user_edit_time_zones_auto_def"), "Y"=>GetMessage("user_edit_time_zones_auto_yes"), "N"=>GetMessage("user_edit_time_zones_auto_no")), $str_AUTO_TIME_ZONE, array('onchange="this.form.TIME_ZONE.disabled=(this.value != \'N\')"'));
$tabControl->AddDropDownField("TIME_ZONE", GetMessage("user_edit_time_zones_zones"), false, CTimeZone::GetZones(), $str_TIME_ZONE, ($str_AUTO_TIME_ZONE<>"N"? array('disabled') : array()));
}
?>
<?
if($showGroupTabs):
$tabControl->BeginNextFormTab();
$tabControl->BeginCustomField("GROUP_ID", GetMessage("user_edit_form_groups"));
?>
<tr>
<td colspan="2" align="center">
<table border="0" cellpadding="0" cellspacing="0" class="internal" style="width:80%;">
<tr class="heading">
<td colspan="2"><?echo GetMessage("TBL_GROUP")?></td>
<td><?=GetMessage('TBL_GROUP_DATE')?></td>
</tr>
<?
$ind = -1;
$dbGroups = CGroup::GetList(($b = "c_sort"), ($o = "asc"), array("ANONYMOUS" => "N"));
while ($arGroups = $dbGroups->Fetch())
{
$arGroups["ID"] = intval($arGroups["ID"]);
if (!$USER->CanDoOperation('edit_all_users') && $USER->CanDoOperation('edit_subordinate_users') && !in_array($arGroups["ID"], $arUserSubordinateGroups) || $arGroups["ID"] == 2)
continue;
if($arGroups["ID"]==1 && !$USER->IsAdmin())
continue;
$ind++;
?>
<tr>
<td>
<input type="hidden" name="GROUP_ID_<?=$ind?>" value="<?=$arGroups["ID"]?>" /><input type="checkbox" name="GROUP_ID_ACT_<?=$ind?>" id="GROUP_ID_ACT_ID_<?=$ind?>" value="Y"<?
if (array_key_exists($arGroups["ID"], $str_GROUP_ID))
echo " checked=\"checked\"";
?> />
</td>
<td class="align-left">
<label for="GROUP_ID_ACT_ID_<?= $ind ?>"><?=htmlspecialcharsbx($arGroups["NAME"])?> [<a href="/bitrix/admin/group_edit.php?ID=<?=$arGroups["ID"]?>&lang=<?=LANGUAGE_ID?>" title="<?=GetMessage("MAIN_VIEW_GROUP")?>"><?echo intval($arGroups["ID"])?></a>]</label>
</td>
<td>
<?= CalendarDate("GROUP_ID_FROM_".$ind, (array_key_exists($arGroups["ID"], $str_GROUP_ID) ? htmlspecialcharsbx($str_GROUP_ID[$arGroups["ID"]]["DATE_ACTIVE_FROM"]) : ""), $tabControl->GetFormName(), "22")?>
<?= CalendarDate("GROUP_ID_TO_".$ind, (array_key_exists($arGroups["ID"], $str_GROUP_ID) ? htmlspecialcharsbx($str_GROUP_ID[$arGroups["ID"]]["DATE_ACTIVE_TO"]) : ""), $tabControl->GetFormName(), "22")?>
</td>
</tr>
<?
}
?>
</table><input type="hidden" name="GROUP_ID_NUMBER" value="<?= $ind ?>"></td>
</tr>
<?
$tabControl->EndCustomField("GROUP_ID");
endif;
?>
<?
$tabControl->BeginNextFormTab();
$tabControl->AddEditField("PERSONAL_PROFESSION", GetMessage('USER_PROFESSION'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_PROFESSION);
$tabControl->AddEditField("PERSONAL_WWW", GetMessage('USER_WWW'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_WWW);
$tabControl->AddEditField("PERSONAL_ICQ", GetMessage('USER_ICQ'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_ICQ);
$tabControl->AddDropDownField("PERSONAL_GENDER", GetMessage('USER_GENDER'), false, array(""=>GetMessage("USER_DONT_KNOW"), "M"=>GetMessage("USER_MALE"), "F"=>GetMessage("USER_FEMALE")), $str_PERSONAL_GENDER);
$tabControl->AddCalendarField("PERSONAL_BIRTHDAY", GetMessage("USER_BIRTHDAY_DT").":", $str_PERSONAL_BIRTHDAY);
$tabControl->AddFileField("PERSONAL_PHOTO", GetMessage("USER_PHOTO"), $str_PERSONAL_PHOTO, array("iMaxW"=>150, "iMaxH"=>150));
$tabControl->AddSection("USER_PHONES", GetMessage("USER_PHONES"));
$tabControl->AddEditField("PERSONAL_PHONE", GetMessage('USER_PHONE'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_PHONE);
$tabControl->AddEditField("PERSONAL_FAX", GetMessage('USER_FAX'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_FAX);
$tabControl->AddEditField("PERSONAL_MOBILE", GetMessage('USER_MOBILE'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_MOBILE);
$tabControl->AddEditField("PERSONAL_PAGER", GetMessage('USER_PAGER'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_PAGER);
$tabControl->AddSection("USER_POST_ADDRESS", GetMessage("USER_POST_ADDRESS"));
$tabControl->BeginCustomField("PERSONAL_COUNTRY", GetMessage('USER_COUNTRY'));
?>
<tr>
<td><?echo $tabControl->GetCustomLabelHTML()?></td>
<td><?echo SelectBoxFromArray("PERSONAL_COUNTRY", GetCountryArray(), $str_PERSONAL_COUNTRY, GetMessage("USER_DONT_KNOW"));?></td>
</tr>
<?
$tabControl->EndCustomField("PERSONAL_COUNTRY", '<input type="hidden" name="PERSONAL_COUNTRY" value="'.$str_PERSONAL_COUNTRY.'">');
$tabControl->AddEditField("PERSONAL_STATE", GetMessage('USER_STATE'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_STATE);
$tabControl->AddEditField("PERSONAL_CITY", GetMessage('USER_CITY'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_CITY);
$tabControl->AddEditField("PERSONAL_ZIP", GetMessage('USER_ZIP'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_ZIP);
$tabControl->AddTextField("PERSONAL_STREET", GetMessage("USER_STREET"), $str_PERSONAL_STREET, array("cols"=>40, "rows"=>3));
$tabControl->AddEditField("PERSONAL_MAILBOX", GetMessage('USER_MAILBOX'), false, array("size"=>30, "maxlength"=>255), $str_PERSONAL_MAILBOX);
$tabControl->AddTextField("PERSONAL_NOTES", GetMessage("USER_NOTES"), $str_PERSONAL_NOTES, array("cols"=>40, "rows"=>5));
$tabControl->BeginNextFormTab();
$tabControl->AddEditField("WORK_COMPANY", GetMessage('USER_COMPANY'), false, array("size"=>30, "maxlength"=>255), $str_WORK_COMPANY);
$tabControl->AddEditField("WORK_WWW", GetMessage('USER_WWW'), false, array("size"=>30, "maxlength"=>255), $str_WORK_WWW);
$tabControl->AddEditField("WORK_DEPARTMENT", GetMessage('USER_DEPARTMENT'), false, array("size"=>30, "maxlength"=>255), $str_WORK_DEPARTMENT);
$tabControl->AddEditField("WORK_POSITION", GetMessage('USER_POSITION'), false, array("size"=>30, "maxlength"=>255), $str_WORK_POSITION);
$tabControl->AddTextField("WORK_PROFILE", GetMessage("USER_WORK_PROFILE"), $str_WORK_PROFILE, array("cols"=>40, "rows"=>5));
$tabControl->AddFileField("WORK_LOGO", GetMessage("USER_LOGO"), $str_WORK_LOGO, array("iMaxW"=>150, "iMaxH"=>150));
$tabControl->AddSection("USER_WORK_PHONES", GetMessage("USER_PHONES"));
$tabControl->AddEditField("WORK_PHONE", GetMessage('USER_PHONE'), false, array("size"=>30, "maxlength"=>255), $str_WORK_PHONE);
$tabControl->AddEditField("WORK_FAX", GetMessage('USER_FAX'), false, array("size"=>30, "maxlength"=>255), $str_WORK_FAX);
$tabControl->AddEditField("WORK_PAGER", GetMessage('USER_PAGER'), false, array("size"=>30, "maxlength"=>255), $str_WORK_PAGER);
$tabControl->AddSection("USER_WORK_POST_ADDRESS", GetMessage("USER_POST_ADDRESS"));
$tabControl->BeginCustomField("WORK_COUNTRY", GetMessage('USER_COUNTRY'));
?>
<tr>
<td><?echo $tabControl->GetCustomLabelHTML()?></td>
<td><?echo SelectBoxFromArray("WORK_COUNTRY", GetCountryArray(), $str_WORK_COUNTRY, GetMessage("USER_DONT_KNOW"));?></td>
</tr>
<?
$tabControl->EndCustomField("WORK_COUNTRY", '<input type="hidden" name="WORK_COUNTRY" value="'.$str_WORK_COUNTRY.'">');
$tabControl->AddEditField("WORK_STATE", GetMessage('USER_STATE'), false, array("size"=>30, "maxlength"=>255), $str_WORK_STATE);
$tabControl->AddEditField("WORK_CITY", GetMessage('USER_CITY'), false, array("size"=>30, "maxlength"=>255), $str_WORK_CITY);
$tabControl->AddEditField("WORK_ZIP", GetMessage('USER_ZIP'), false, array("size"=>30, "maxlength"=>255), $str_WORK_ZIP);
$tabControl->AddTextField("WORK_STREET", GetMessage("USER_STREET"), $str_WORK_STREET, array("cols"=>40, "rows"=>3));
$tabControl->AddEditField("WORK_MAILBOX", GetMessage('USER_MAILBOX'), false, array("size"=>30, "maxlength"=>255), $str_WORK_MAILBOX);
$tabControl->AddTextField("WORK_NOTES", GetMessage("USER_NOTES"), $str_WORK_NOTES, array("cols"=>40, "rows"=>5));
$tabControl->BeginNextFormTab();
$tabControl->BeginCustomField("RATING_BOX", GetMessage("USER_RATING_INFO"), false);
?>
<tr>
<td width="100%" colspan="100%">
<?
$i = 1;
$aTabs2 = array();
$arRatings = array();
$rsRatings = CRatings::GetList(array('ID' => 'ASC'), array('ACTIVE' => 'Y', 'ENTITY_ID' => 'USER'));
while ($arRatingsTmp = $rsRatings->GetNext())
{
if ($arRatingsTmp['AUTHORITY'] == 'Y')
$arRatingsTmp['NAME'] = '<span class="required">[A]</span> '.$arRatingsTmp['NAME'];
$aTabs2[] = array("DIV"=>"rating_".$i, "TAB" => $arRatingsTmp['NAME'], "TITLE" => GetMessage('RATING_TAB_INFO'));
$arRatings[$arRatingsTmp['ID']] = $arRatingsTmp;
$i++;
}
if (is_array($arRatings) && !empty($arRatings))
{
$ratingWeightType = COption::GetOptionString("main", "rating_weight_type", "auto");
$authorityRatingId = CRatings::GetAuthorityRating();
$arAuthorityUserProp = CRatings::GetRatingUserPropEx($authorityRatingId, $ID);
$viewTabControl = new CAdminViewTabControl("tabControlRating", $aTabs2);
$viewTabControl->Begin();
foreach($arRatings as $ratingId => $arRating)
{
$arRatingResult = CRatings::GetRatingResult($ratingId, $ID);
$arRatingUserProp = CRatings::GetRatingUserPropEx($ratingId, $ID);
$viewTabControl->BeginNextTab();
?>
<table cellspacing="7" cellpadding="0" border="0" width="100%" class="edit-table">
<? if ($USER->CanDoOperation('edit_ratings') && ($selfEdit || $ID!=$uid)): ?>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_BONUS')?>:<sup><span class="required">2</span></sup></td>
<td><?=InputType('text', "RATING_BONUS[$ratingId]", floatval($arRatingUserProp['BONUS']), false, false, '', 'size="5" maxlength="11"')?> <?=($ratingWeightType == 'auto'? 'x '.GetMessage('RATING_NORM_VOTE_WEIGHT'): '')?></td>
</tr>
<? endif; ?>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_POSITION')?>:</td>
<td>
<?$APPLICATION->IncludeComponent(
"bitrix:rating.result", "",
array(
"RESULT_TYPE" => 'POSITION',
"SHOW_RATING_NAME" => 'N',
"RATING_ID" => $arRatingResult['RATING_ID'],
"ENTITY_ID" => $arRatingResult['ENTITY_ID'],
"CURRENT_POSITION" => $arRatingResult['CURRENT_POSITION'],
"PREVIOUS_POSITION" => $arRatingResult['PREVIOUS_POSITION'],
),
null,
array("HIDE_ICONS" => "Y")
);?>
</td>
</tr>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_CURRENT_VALUE')?>:</td>
<td><?=floatval($arRatingResult['CURRENT_VALUE']);?></td>
</tr>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_PREVIOUS_VALUE')?>:</td>
<td><?=floatval($arRatingResult['PREVIOUS_VALUE']);?></td>
</tr>
<?
if ($arRating['AUTHORITY'] == 'Y')
{
if ($ratingWeightType == 'auto')
{
$voteWeight = COption::GetOptionString("main", "rating_vote_weight", 1);
$voteWeightUser = $voteWeight>0? round(floatval($arAuthorityUserProp['VOTE_WEIGHT']/$voteWeight), 4): 0;
$communitySize = COption::GetOptionString("main", "rating_community_size", 1);
$communityAuthority = COption::GetOptionString("main", "rating_community_authority", 1);
$normVoteCount = $voteWeight>0?floor(floatval($arRatingResult['CURRENT_VALUE'])/$voteWeight): 0;
$sRatingAuthorityWeight = COption::GetOptionString("main", "rating_authority_weight_formula", 'Y');
if ($sRatingAuthorityWeight == 'Y')
$voteWeightAuthority = $communityAuthority > 0? round($communitySize*$voteWeightUser/$communityAuthority,4): 0;
else
$voteWeightAuthority = 1;
?>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_VOTE_NORM_VOTE')?>:</td>
<td><?=$normVoteCount?></td>
</tr>
<?
}
else
{
$voteWeightAuthority = round(floatval($arAuthorityUserProp['VOTE_WEIGHT']), 4);
}
?>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_VOTE_WEIGHT')?>:</td>
<td><?=round(floatval($arAuthorityUserProp['VOTE_WEIGHT']), 4)?></td>
</tr>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_VOTE_WEIGHT_AUTHORITY')?>:</td>
<td><?=$voteWeightAuthority?></td>
</tr>
<tr>
<td class="field-name" width="40%"><?=GetMessage('RATING_VOTE_AUTHORITY_COUNT')?>:</td>
<td><?=floatval($arRatingUserProp['VOTE_COUNT']);?></td>
</tr>
<?
}
?>
</table>
<?
}
$viewTabControl->End();
}
else
echo GetMessage('RATING_NOT_AVAILABLE');
?>
</td>
</tr>
<?
$tabControl->EndCustomField("RATING_BOX");
$db_opt_res = CModule::GetList();
while ($opt_res = $db_opt_res->Fetch())
{
$mdir = $opt_res["ID"];
if (file_exists($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir) && is_dir($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir))
{
$ofile = $_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/".$mdir."/options_user_settings.php";
if (file_exists($ofile))
{
$mname = str_replace(".", "_", $mdir);
$tabControl->BeginNextFormTab();
$tabControl->BeginCustomField("MODULE_TAB_".$mname, GetMessage($mname."_TAB"));
include($ofile);
$tabControl->EndCustomField("MODULE_TAB_".$mname);
}
}
}
if (($editable && $ID!=$USER->GetID()) || $USER->IsAdmin()):
$tabControl->BeginNextFormTab();
$tabControl->BeginCustomField("ADMIN_NOTES", GetMessage("USER_ADMIN_NOTES"));
?>
<tr>
<td align="center" colspan="2"><textarea name="ADMIN_NOTES" cols="50" rows="10" style="width:100%;"><?echo $str_ADMIN_NOTES?></textarea></td>
</tr>
<?
$tabControl->EndCustomField("ADMIN_NOTES", '<input type="hidden" name="ADMIN_NOTES" value="'.$str_ADMIN_NOTES.'">');
endif;
//Add user fields tab only when there is fields defined or user has rights for adding new field
if(
(count($USER_FIELD_MANAGER->GetUserFields($PROPERTY_ID)) > 0) ||
($USER_FIELD_MANAGER->GetRights($PROPERTY_ID) >= "W")
)
{
$tabControl->BeginNextFormTab();
$tabControl->ShowUserFields($PROPERTY_ID, $ID, ($strError <> '' || !$res));
}
if($canViewUserList)
{
$tabControl->Buttons(array(
"disabled" => !$editable,
"btnSaveAndAdd" => true,
"back_url" => "user_admin.php?lang=".LANGUAGE_ID,
));
}
else
{
$tabControl->Buttons(array(
"disabled" => !$editable,
"btnSave" => false,
"btnCancel" => false,
"btnSaveAndAdd" => true,
));
}
$tabControl->Show();
$tabControl->ShowWarnings($tabControl->GetName(), $message);
?>
<?if(!defined('BX_PUBLIC_MODE') || BX_PUBLIC_MODE != 1):?>
<?echo BeginNote();?>
<span class="required">1</span> <?$GROUP_POLICY = CUser::GetGroupPolicy($ID);echo $GROUP_POLICY["PASSWORD_REQUIREMENTS"];?><br>
<span class="required">2</span> <?echo GetMessage("RATING_BONUS_NOTICE")?><br>
<?echo EndNote();?>
<?endif;?>
<?
require_once ($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/main/include/epilog_admin.php");