%PDF-
%PDF-
Mini Shell
Mini Shell
<?
if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true)die();
if (!CModule::IncludeModule("socialnetwork"))
{
ShowError(GetMessage("SONET_MODULE_NOT_INSTALL"));
return;
}
if (strLen($arParams["USER_VAR"]) <= 0)
$arParams["USER_VAR"] = "user_id";
if (strLen($arParams["PAGE_VAR"]) <= 0)
$arParams["PAGE_VAR"] = "page";
$arParams["SET_NAV_CHAIN"] = ($arParams["SET_NAV_CHAIN"] == "N" ? "N" : "Y");
$arParams["PATH_TO_USER"] = trim($arParams["PATH_TO_USER"]);
if (strlen($arParams["PATH_TO_USER"]) <= 0)
$arParams["PATH_TO_USER"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=user&".$arParams["USER_VAR"]."=#user_id#");
$arParams["ITEMS_COUNT"] = IntVal($arParams["ITEMS_COUNT"]);
if ($arParams["ITEMS_COUNT"] <= 0)
$arParams["ITEMS_COUNT"] = 30;
// for bitrix:main.user.link
if (IsModuleInstalled('intranet'))
{
$arTooltipFieldsDefault = serialize(array(
"EMAIL",
"PERSONAL_MOBILE",
"WORK_PHONE",
"PERSONAL_ICQ",
"PERSONAL_PHOTO",
"PERSONAL_CITY",
"WORK_COMPANY",
"WORK_POSITION",
));
$arTooltipPropertiesDefault = serialize(array(
"UF_DEPARTMENT",
"UF_PHONE_INNER",
));
}
else
{
$arTooltipFieldsDefault = serialize(array(
"PERSONAL_ICQ",
"PERSONAL_BIRTHDAY",
"PERSONAL_PHOTO",
"PERSONAL_CITY",
"WORK_COMPANY",
"WORK_POSITION"
));
$arTooltipPropertiesDefault = serialize(array());
}
if (!array_key_exists("SHOW_FIELDS_TOOLTIP", $arParams))
$arParams["SHOW_FIELDS_TOOLTIP"] = unserialize(COption::GetOptionString("socialnetwork", "tooltip_fields", $arTooltipFieldsDefault));
if (!array_key_exists("USER_PROPERTY_TOOLTIP", $arParams))
$arParams["USER_PROPERTY_TOOLTIP"] = unserialize(COption::GetOptionString("socialnetwork", "tooltip_properties", $arTooltipPropertiesDefault));
if (!$GLOBALS["USER"]->IsAuthorized())
{
$arResult["NEED_AUTH"] = "Y";
}
else
{
$arNavParams = array("nPageSize" => $arParams["ITEMS_COUNT"], "bDescPageNumbering" => false);
$arNavigation = CDBResult::GetNavParams($arNavParams);
/*********************** ACTIONS *******************************/
if ($_REQUEST["action"] == "clear_ban" && check_bitrix_sessid() && IntVal($_REQUEST["eventID"]) > 0)
{
$errorMessage = "";
if (!CSocNetUserRelations::UnBanMember($GLOBALS["USER"]->GetID(), IntVal($_REQUEST["eventID"])))
{
if ($e = $APPLICATION->GetException())
$errorMessage .= $e->GetString();
}
if (strlen($errorMessage) > 0)
$arResult["ErrorMessage"] = $errorMessage;
}
elseif ($_SERVER["REQUEST_METHOD"]=="POST" && strlen($_POST["delete"]) > 0 && check_bitrix_sessid())
{
$errorMessage = "";
$arIDs = array();
if (strlen($errorMessage) <= 0)
{
for ($i = 0; $i <= IntVal($_POST["max_count"]); $i++)
{
if ($_POST["checked_".$i] == "Y")
$arIDs[] = IntVal($_POST["id_".$i]);
}
if (count($arIDs) <= 0)
$errorMessage .= GetMessage("SONET_C32_NOT_SELECTED").". ";
}
if (strlen($errorMessage) <= 0)
{
foreach($arIDs as $ban_id)
{
if (!CSocNetUserRelations::UnBanMember($GLOBALS["USER"]->GetID(), $ban_id))
{
if ($e = $APPLICATION->GetException())
$errorMessage .= $e->GetString();
}
}
}
if (strlen($errorMessage) > 0)
$arResult["ErrorMessage"] = $errorMessage;
}
/********************* END ACTIONS *****************************/
if ($arParams["SET_TITLE"] == "Y")
$APPLICATION->SetTitle(GetMessage("SONET_C32_PAGE_TITLE"));
if ($arParams["SET_NAV_CHAIN"] != "N")
$APPLICATION->AddChainItem(GetMessage("SONET_C32_PAGE_TITLE"));
$arResult["Ban"] = false;
$dbBan = CSocNetUserRelations::GetRelatedUsers($GLOBALS["USER"]->GetID(), SONET_RELATIONS_BAN, $arNavParams);
if ($dbBan)
{
$arResult["Ban"] = array();
$arResult["Ban"]["List"] = false;
while ($arBan = $dbBan->GetNext())
{
if ($arResult["Ban"]["List"] == false)
$arResult["Ban"]["List"] = array();
$pref = (($GLOBALS["USER"]->GetID() == $arBan["FIRST_USER_ID"]) ? "SECOND" : "FIRST");
$bInitiated = ((($GLOBALS["USER"]->GetID() == $arBan["FIRST_USER_ID"]) && ($arBan["INITIATED_BY"] == "F"))
|| (($GLOBALS["USER"]->GetID() == $arBan["SECOND_USER_ID"]) && ($arBan["INITIATED_BY"] == "S")));
$pu = CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_USER"], array("user_id" => $arBan[$pref."_USER_ID"]));
$canViewProfile = CSocNetUserPerms::CanPerformOperation($GLOBALS["USER"]->GetID(), $arBan[$pref."_USER_ID"], "viewprofile", CSocNetUser::IsCurrentUserModuleAdmin());
if (intval($arParams["THUMBNAIL_LIST_SIZE"]) > 0)
{
if (intval($arBan[$pref."_USER_PERSONAL_PHOTO"]) <= 0)
{
switch ($arBan[$pref."_USER_PERSONAL_GENDER"])
{
case "M":
$suffix = "male";
break;
case "F":
$suffix = "female";
break;
default:
$suffix = "unknown";
}
$arBan[$pref."_USER_PERSONAL_PHOTO"] = COption::GetOptionInt("socialnetwork", "default_user_picture_".$suffix, false, SITE_ID);
}
$arImage = CSocNetTools::InitImage($arBan[$pref."_USER_PERSONAL_PHOTO"], $arParams["THUMBNAIL_LIST_SIZE"], "/bitrix/images/socialnetwork/nopic_30x30.gif", 30, $pu, $canViewProfile);
}
else // old
$arImage = CSocNetTools::InitImage($arBan[$pref."_USER_PERSONAL_PHOTO"], 150, "/bitrix/images/socialnetwork/nopic_user_150.gif", 150, $pu, $canViewProfile);
$arResult["Ban"]["List"][] = array(
"ID" => $arBan["ID"],
"USER_ID" => $arBan[$pref."_USER_ID"],
"USER_NAME" => $arBan[$pref."_USER_NAME"],
"USER_LAST_NAME" => $arBan[$pref."_USER_LAST_NAME"],
"USER_SECOND_NAME" => $arBan[$pref."_USER_SECOND_NAME"],
"USER_LOGIN_NAME" => $arBan[$pref."_USER_LOGIN_NAME"],
"USER_PERSONAL_PHOTO" => $arBan[$pref."_USER_PERSONAL_PHOTO"],
"USER_PERSONAL_PHOTO_FILE" => $arImage["FILE"],
"USER_PERSONAL_PHOTO_IMG" => $arImage["IMG"],
"USER_PROFILE_URL" => $pu,
"SHOW_PROFILE_LINK" => $canViewProfile,
"DELETE_FROM_BAN_LINK" => htmlspecialcharsbx($APPLICATION->GetCurUri("eventID=".$arBan["ID"]."&action=clear_ban&".bitrix_sessid_get()."")),
"CAN_DELETE_BAN" => $bInitiated,
);
}
$arResult["NAV_STRING"] = $dbBan->GetPageNavStringEx($navComponentObject, GetMessage("SONET_C32_NAV"), "", false);
}
}
$this->IncludeComponentTemplate();
?>
Zerion Mini Shell 1.0