Current Path : /var/www/www-root/data/www/monolith-realty.ru/bitrix/modules/main/classes/general/ |
Current File : /var/www/www-root/data/www/monolith-realty.ru/bitrix/modules/main/classes/general/admin_notify.php |
<?php IncludeModuleLangFile(__FILE__); class CAdminNotify { const TYPE_NORMAL = 'M'; const TYPE_ERROR = 'E'; protected static function CleanCache() { global $CACHE_MANAGER; $rsLangs = CLanguage::GetList('lid'); while ($arLang = $rsLangs->Fetch()) { $CACHE_MANAGER->Clean("admin_notify_list_" . $arLang['LANGUAGE_ID']); } $CACHE_MANAGER->Clean("admin_notify_list"); } public static function Add($arFields) { global $DB; if (!self::CheckFields($arFields)) { return false; } if (!isset($arFields['ENABLE_CLOSE'])) { $arFields['ENABLE_CLOSE'] = 'Y'; } if (isset($arFields['TAG']) && trim($arFields['TAG']) <> '') { $arFields['TAG'] = trim($arFields['TAG']); self::DeleteByTag($arFields['TAG']); } else { $arFields['TAG'] = ""; } $arFields['PUBLIC_SECTION'] = (isset($arFields['PUBLIC_SECTION']) && $arFields['PUBLIC_SECTION'] == 'Y' ? 'Y' : 'N'); if (!isset($arFields['NOTIFY_TYPE']) || !in_array($arFields['NOTIFY_TYPE'], [self::TYPE_NORMAL, self::TYPE_ERROR])) { $arFields['NOTIFY_TYPE'] = self::TYPE_NORMAL; } $arFields_i = [ 'MODULE_ID' => isset($arFields['MODULE_ID']) ? trim($arFields['MODULE_ID']) : "", 'TAG' => $arFields['TAG'], 'MESSAGE' => trim($arFields['MESSAGE']), 'ENABLE_CLOSE' => $arFields['ENABLE_CLOSE'], 'PUBLIC_SECTION' => $arFields['PUBLIC_SECTION'], 'NOTIFY_TYPE' => $arFields['NOTIFY_TYPE'], ]; $ID = $DB->Add('b_admin_notify', $arFields_i, ['MESSAGE']); if ($ID) { if (!empty($arFields['LANG']) && is_array($arFields['LANG'])) { foreach ($arFields['LANG'] as $strLang => $strMess) { $arFields_l = [ 'NOTIFY_ID' => $ID, 'LID' => $strLang, 'MESSAGE' => trim($strMess), ]; $DB->Add('b_admin_notify_lang', $arFields_l, ['MESSAGE']); } } } self::CleanCache(); return $ID; } private static function CheckFields($arFields) { $aMsg = []; if (is_set($arFields, 'MODULE_ID') && trim($arFields['MODULE_ID']) == '') { $aMsg[] = ['id' => 'MODULE_ID', 'text' => GetMessage('MAIN_AN_ERROR_MODULE_ID')]; } if (is_set($arFields, 'TAG') && trim($arFields['TAG']) == '') { $aMsg[] = ['id' => 'TAG', 'text' => GetMessage('MAIN_AN_ERROR_TAG')]; } if (!is_set($arFields, 'MESSAGE') || trim($arFields['MESSAGE']) == '') { $aMsg[] = ['id' => 'MESSAGE', 'text' => GetMessage('MAIN_AN_ERROR_MESSAGE')]; } if (is_set($arFields, 'ENABLE_CLOSE') && !($arFields['ENABLE_CLOSE'] == 'Y' || $arFields['ENABLE_CLOSE'] == 'N')) { $aMsg[] = ['id' => 'ENABLE_CLOSE', 'text' => GetMessage('MAIN_AN_ERROR_ENABLE_CLOSE')]; } if (!empty($aMsg)) { $e = new CAdminException($aMsg); $GLOBALS['APPLICATION']->ThrowException($e); return false; } return true; } public static function Delete($ID) { global $DB; $ID = (int)$ID; if ($ID <= 0) { return false; } $strSql = "DELETE FROM b_admin_notify_lang WHERE NOTIFY_ID = " . $ID; $DB->Query($strSql); $strSql = "DELETE FROM b_admin_notify WHERE ID = " . $ID; $DB->Query($strSql); self::CleanCache(); return true; } public static function DeleteByModule($moduleId) { global $DB; $strSql = "DELETE FROM b_admin_notify_lang WHERE NOTIFY_ID IN (SELECT ID FROM b_admin_notify WHERE MODULE_ID = '" . $DB->ForSQL($moduleId) . "')"; $DB->Query($strSql); $strSql = "DELETE FROM b_admin_notify WHERE MODULE_ID = '" . $DB->ForSQL($moduleId) . "'"; $DB->Query($strSql); self::CleanCache(); return true; } public static function DeleteByTag($tagId) { global $DB; $tagId = (string)$tagId; if ($tagId == '') { return false; } $strSql = "DELETE FROM b_admin_notify_lang WHERE NOTIFY_ID IN (SELECT ID FROM b_admin_notify WHERE TAG like '%" . $DB->ForSQL($tagId) . "%')"; $DB->Query($strSql); $strSql = "DELETE FROM b_admin_notify WHERE TAG like '%" . $DB->ForSQL($tagId) . "%'"; $DB->Query($strSql); self::CleanCache(); return true; } public static function GetHtml() { global $CACHE_MANAGER; $arNotify = false; if ($CACHE_MANAGER->Read(86400, "admin_notify_list_" . LANGUAGE_ID)) { $arNotify = $CACHE_MANAGER->Get("admin_notify_list_" . LANGUAGE_ID); } if ($arNotify === false) { $arNotify = []; $CBXSanitizer = new CBXSanitizer; $CBXSanitizer->AddTags([ 'a' => ['href', 'style'], 'b' => [], 'u' => [], 'i' => [], 'br' => [], 'span' => ['style'], ]); $dbRes = self::GetList(); while ($ar = $dbRes->Fetch()) { $ar["MESSAGE"] = $CBXSanitizer->SanitizeHtml(('' != $ar['MESSAGE_LANG'] ? $ar['MESSAGE_LANG'] : $ar['MESSAGE'])); $arNotify[] = $ar; } $CACHE_MANAGER->Set("admin_notify_list_" . LANGUAGE_ID, $arNotify); } $html = ""; foreach ($arNotify as $value) { $className = ($value['NOTIFY_TYPE'] == self::TYPE_ERROR ? 'adm-warning-block adm-warning-block-red' : 'adm-warning-block'); $html .= '<div class="' . $className . '" data-id="' . (int)$value['ID'] . '" data-ajax="Y"><span class="adm-warning-text">' . $value['MESSAGE'] . '</span><span class="adm-warning-icon"></span>' . ($value['ENABLE_CLOSE'] == 'Y' ? '<span onclick="BX.adminPanel ? BX.adminPanel.hideNotify(this.parentNode) : BX.admin.panel.hideNotify(this.parentNode);" class="adm-warning-close"></span>' : '') . '</div>'; } return $html; } public static function GetList($arSort = [], $arFilter = []) { global $DB; $arSqlSearch = []; if (!is_array($arFilter)) { $arFilter = []; } if (!isset($arFilter['LID'])) { $arFilter['LID'] = LANGUAGE_ID; } if (!isset($arFilter['PUBLIC_SECTION'])) { $arFilter['PUBLIC_SECTION'] = 'N'; } $strFrom = ''; $strSelect = "AN.*"; if (is_array($arFilter)) { foreach ($arFilter as $key => $val) { if ((string)$val == '' || $val == 'NOT_REF') { continue; } switch (strtoupper($key)) { case 'ID': $arSqlSearch[] = GetFilterQuery('AN.ID', $val, 'N'); break; case 'MODULE_ID': $arSqlSearch[] = GetFilterQuery('AN.MODULE_ID', $val); break; case 'TAG': $arSqlSearch[] = GetFilterQuery('AN.TAG', $val); break; case 'MESSAGE': $arSqlSearch[] = GetFilterQuery('AN.MESSAGE', $val); break; case 'ENABLE_CLOSE': $arSqlSearch[] = ($val == 'Y') ? "AN.ENABLE_CLOSE='Y'" : "AN.ENABLE_CLOSE='N'"; break; case 'LID': $strSelect .= ", ANL.MESSAGE as MESSAGE_LANG"; $strFrom = 'LEFT JOIN b_admin_notify_lang ANL ON (AN.ID = ANL.NOTIFY_ID AND ANL.LID = \'' . $DB->ForSQL($val) . '\')'; break; case 'PUBLIC_SECTION': $arSqlSearch[] = ($val == 'Y') ? "AN.PUBLIC_SECTION='Y'" : "AN.PUBLIC_SECTION='N'"; } } } $sOrder = ''; foreach ($arSort as $key => $val) { $ord = (strtoupper($val) <> 'ASC' ? 'DESC' : 'ASC'); switch (strtoupper($key)) { case 'ID': $sOrder .= ', AN.ID ' . $ord; break; case 'MODULE_ID': $sOrder .= ', AN.MODULE_ID ' . $ord; break; case 'ENABLE_CLOSE': $sOrder .= ', AN.ENABLE_CLOSE ' . $ord; break; } } if ($sOrder == '') { $sOrder = 'AN.ID DESC'; } $strSqlOrder = ' ORDER BY ' . TrimEx($sOrder, ','); $strSqlSearch = GetFilterSqlSearch($arSqlSearch); $strSql = "SELECT " . $strSelect . " FROM b_admin_notify AN " . $strFrom . " WHERE " . $strSqlSearch . " " . $strSqlOrder; $res = $DB->Query($strSql); return $res; } }