Your IP : 3.133.129.119
<?
define("ADMIN_MODULE_NAME", "sender");
require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_admin_before.php");
if(!\Bitrix\Main\Loader::includeModule("sender"))
ShowError(\Bitrix\Main\Localization\Loc::getMessage("MAIN_MODULE_NOT_INSTALLED"));
IncludeModuleLangFile(__FILE__);
$POST_RIGHT = $APPLICATION->GetGroupRight("sender");
if($POST_RIGHT=="D")
$APPLICATION->AuthForm(GetMessage("ACCESS_DENIED"));
$sTableID = "tbl_sender_list";
$oSort = new CAdminSorting($sTableID, "ID", "desc");
$lAdmin = new CAdminList($sTableID, $oSort);
function CheckFilter()
{
global $FilterArr, $lAdmin;
foreach ($FilterArr as $f) global $$f;
return count($lAdmin->arFilterErrors)==0;
}
$FilterArr = Array(
"find",
);
$lAdmin->InitFilter($FilterArr);
if (CheckFilter())
{
$arFilter = Array(
"ID" => ($find!="" && $find_type == "id"? $find:$find_id),
"NAME" => ($find!="" && $find_type == "name"? $find:$find_name),
"CODE" => ($find!="" && $find_type == "code"? $find:$find_code),
);
foreach($arFilter as $k => $v) if(empty($v) && $v!==false) unset($arFilter[$k]);
}
if($lAdmin->EditAction() && $POST_RIGHT=="W")
{
foreach($FIELDS as $ID=>$arFields)
{
if(!$lAdmin->IsUpdated($ID))
continue;
$DB->StartTransaction();
$ID = IntVal($ID);
$dataPrimary = array('ID' => $ID);
$arData = \Bitrix\Sender\ListTable::getRowById($dataPrimary);
if($arData)
{
foreach($arFields as $key=>$value)
$arData[$key]=$value;
unset($arData['ID']);
$dataUpdateDb = \Bitrix\Sender\ListTable::update($dataPrimary, $arData);
if(!$dataUpdateDb->isSuccess())
{
$LAST_ERROR = $dataUpdateDb->getErrorMessages();
$LAST_ERROR = $LAST_ERROR[0];
$lAdmin->AddGroupError(GetMessage("rub_save_error")." ".$LAST_ERROR, $ID);
$DB->Rollback();
}
}
else
{
$lAdmin->AddGroupError(GetMessage("rub_save_error")." ".GetMessage("rub_no_rubric"), $ID);
$DB->Rollback();
}
$DB->Commit();
}
}
if(($arID = $lAdmin->GroupAction()) && $POST_RIGHT=="W")
{
if($_REQUEST['action_target']=='selected')
{
$dataListDb = \Bitrix\Sender\ListTable::getList(array(
'select' => array('ID'),
'filter' => $arFilter,
'order' => array($by=>$order)
));
while($arRes = $dataListDb->fetch())
$arID[] = $arRes['ID'];
}
foreach($arID as $ID)
{
if(strlen($ID)<=0)
continue;
$ID = IntVal($ID);
$dataPrimary = array('ID' => $ID);
switch($_REQUEST['action'])
{
case "delete":
@set_time_limit(0);
$DB->StartTransaction();
$dataDeleteDb = \Bitrix\Sender\ListTable::delete($dataPrimary);
if(!$dataDeleteDb->isSuccess())
{
$DB->Rollback();
$lAdmin->AddGroupError(GetMessage("rub_del_err"), $ID);
}
$DB->Commit();
break;
case "activate":
case "deactivate":
$arFields["ACTIVE"]=($_REQUEST['action']=="activate"?"Y":"N");
$dataUpdateDb = \Bitrix\Sender\ListTable::update($dataPrimary, $arFields);
if(!$dataUpdateDb->isSuccess())
{
$LAST_ERROR = $dataUpdateDb->getErrorMessages();
$LAST_ERROR = $LAST_ERROR[0];
$lAdmin->AddGroupError(GetMessage("rub_save_error").$LAST_ERROR, $ID);
}
break;
}
}
}
$listDb = \Bitrix\Sender\ListTable::getList(array(
'filter' => $arFilter,
'order' => array($by=>$order)
));
$rsData = new CAdminResult($listDb, $sTableID);
$rsData->NavStart();
$lAdmin->NavText($rsData->GetNavPrint(GetMessage("rub_nav")));
$lAdmin->AddHeaders(array(
array( "id" =>"ID",
"content" =>"ID",
"sort" =>"ID",
"align" =>"right",
"default" =>true,
),
array( "id" =>"NAME",
"content" =>GetMessage("rub_name"),
"sort" =>"NAME",
"default" =>true,
),
array( "id" =>"SORT",
"content" =>GetMessage("rub_sort"),
"sort" =>"SORT",
"align" =>"right",
"default" =>true,
),
array( "id" =>"CODE",
"content" =>GetMessage("rub_code"),
"sort" =>"CODE",
"default" =>true,
),
));
while($arRes = $rsData->NavNext(true, "f_")):
$row =& $lAdmin->AddRow($f_ID, $arRes);
$row->AddInputField("NAME", array("size"=>20));
$row->AddInputField("SORT", array("size"=>6));
$row->AddInputField("CODE", array("size"=>20));
$arActions = Array();
$arActions[] = array(
"ICON"=>"edit",
"DEFAULT"=>true,
"TEXT"=>GetMessage("rub_edit"),
"ACTION"=>$lAdmin->ActionDoGroup($f_ID, "edit")
);
if ($POST_RIGHT>="W")
$arActions[] = array(
"ICON"=>"delete",
"TEXT"=>GetMessage("rub_del"),
"ACTION"=>"if(confirm('".GetMessage('rub_del_conf')."')) ".$lAdmin->ActionDoGroup($f_ID, "delete")
);
$arActions[] = array("SEPARATOR"=>true);
if(is_set($arActions[count($arActions)-1], "SEPARATOR"))
unset($arActions[count($arActions)-1]);
$row->AddActions($arActions);
endwhile;
$lAdmin->AddFooter(
array(
array("title"=>GetMessage("MAIN_ADMIN_LIST_SELECTED"), "value"=>$rsData->SelectedRowsCount()),
array("counter"=>true, "title"=>GetMessage("MAIN_ADMIN_LIST_CHECKED"), "value"=>"0"),
)
);
$lAdmin->AddGroupActionTable(Array(
"delete"=>GetMessage("MAIN_ADMIN_LIST_DELETE"),
));
$aContext = array();
$lAdmin->AddAdminContextMenu($aContext);
$lAdmin->CheckListMode();
$APPLICATION->SetTitle(GetMessage("rub_title"));
require($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_admin_after.php");
$oFilter = new CAdminFilter(
$sTableID."_filter",
array(
)
);
?>
<form name="find_form" method="get" action="<?echo $APPLICATION->GetCurPage();?>">
<?$oFilter->Begin();?>
<tr>
<td><b><?=GetMessage("rub_f_find")?>:</b></td>
<td>
<input type="text" size="25" name="find" value="<?echo htmlspecialcharsbx($find)?>" title="<?=GetMessage("rub_f_find_title")?>">
<?
$arr = array(
"reference" => array(
"ID",
GetMessage("rub_f_name"),
GetMessage("rub_f_code"),
),
"reference_id" => array(
"id",
"name",
"code",
)
);
echo SelectBoxFromArray("find_type", $arr, $find_type, "", "");
?>
</td>
</tr>
<?
$oFilter->Buttons(array("table_id"=>$sTableID,"url"=>$APPLICATION->GetCurPage(),"form"=>"find_form"));
$oFilter->End();
?>
</form>
<?$lAdmin->DisplayList();?>
<?require($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/epilog_admin.php");?>