2017-04-09 01:28:15 +05:00
< ? php
/**
* Класс работы с календарями событий - модуля Unicalendar
*
* @ autor Repellent
* @ package AVE . cms
* @ subpackage module_unicalendar
* @ filesource
*/
class Unicalendar
{
/**
* ФУНКЦИИ ПУБЛИЧНОЙ ЧАСТИ
*/
/**
* Вывод календаря событий
* @ param string $tpl_dir - путь к папке с шаблонами модуля
* @ param int $id - идентификатор календаря
*/
function unicalendarShow ( $tpl_dir , $id )
{
2017-05-06 00:56:07 +05:00
require ( BASE_DIR . '/modules/unicalendar/lang/ru.php' ); // загружаем файл ленгов для php переменных
// подключаем JS скрипты и CSS файлы календаря в секцию head
$eventCalendar_css = '<link rel="stylesheet" href="' . ABS_PATH . 'modules/unicalendar/css/eventCalendar.css" type="text/css" media="screen" charset="utf-8" />' ;
$eventCalendar_theme_responsive_css = '<link rel="stylesheet" href="' . ABS_PATH . 'modules/unicalendar/css/eventCalendar_theme_responsive.css" type="text/css" media="screen" charset="utf-8" />' ;
$moment_js = '<script src="' . ABS_PATH . 'modules/unicalendar/js/moment.js" type="text/javascript" charset="utf-8"></script>' ;
$jquery_eventCalendar_js = '<script src="' . ABS_PATH . 'modules/unicalendar/js/jquery.eventCalendar.js" type="text/javascript" charset="utf-8"></script>' ;
$GLOBALS [ 'user_header' ][ 'module_unicalendar_' ] = $eventCalendar_css . " \n " . $eventCalendar_theme_responsive_css . " \n " . $moment_js . " \n " . $jquery_eventCalendar_js ;
2017-04-09 01:28:15 +05:00
global $AVE_DB , $AVE_Template ;
$sql = $AVE_DB -> Query ( "
SELECT *
FROM " . PREFIX . " _module_unicalendar
WHERE id = '" . $id . "'
" );
$unicalendars = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $unicalendars , $row );
}
foreach ( $unicalendars as $k => $v )
{
2017-05-06 00:56:07 +05:00
$uevents = $v [ 'uca_events' ];
$urubric_id = $v [ 'uca_rubric_id' ];
$udoc_id = $v [ 'uca_doc_id' ];
$uca_day = $v [ 'uca_day' ];
$uca_scroll = $v [ 'uca_scroll' ];
$uca_link = $v [ 'uca_link' ];
$uca_descript = $v [ 'uca_descript' ];
2017-04-09 01:28:15 +05:00
}
2017-04-12 01:06:21 +05:00
// Если выбрали вывести все документы из заданной рубрики - документы с Id=1 (Главная) и 404 страница - выводиться не будут!
2017-04-09 01:28:15 +05:00
if ( $uevents != '' && $uevents == '1' ){
$sql = $AVE_DB -> Query ( "
SELECT Id , document_alias , document_title , document_published , document_meta_description
FROM " . PREFIX . " _documents
2017-04-12 01:06:21 +05:00
WHERE rubric_id = '" . $urubric_id . "' AND Id != 1 && Id != '".PAGE_NOT_FOUND_ID."'
2017-04-09 01:28:15 +05:00
" );
$results = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $results , $row );
}
2017-05-06 00:56:07 +05:00
//получаем данные всех документов из заданной рубрики циклом, формируем строку JSON
foreach ( $results as $k => $v )
{
$uni_data .= " { \" date \" : \" " . pretty_date ( strftime ( '%Y-%m-%d %H:%M:%S' , $v [ 'document_published' ])) . " \" , \" title \" : \" " . $v [ 'document_title' ] . " \" , \" description \" : \" " . $v [ 'document_meta_description' ] . " \" , \" url \" : \" " . $v [ 'document_alias' ] . " \" }, " ;
}
$js_data_files = " $ (function() { " . " var data " . $id . " = [ " . $uni_data . " ]; $ ( \" #eventCalendar " . $id . " \" ).eventCalendar( { jsonData: data " . $id . " , jsonDateFormat: \" human \" , startWeekOnMonday: " . $uca_day . " , eventsScrollable: " . $uca_scroll . " , openEventInNewWindow: " . $uca_link . " , dateFormat: \" dddd DD-MM-YYYY \" , showDescription: " . $uca_descript . " , locales: { locale: \" " . $uca_locale . " \" , txt_noEvents: \" " . $uca_no_events . " \" , txt_SpecificEvents_prev: \" \" , txt_SpecificEvents_after: \" " . $uca_real_events . " \" , txt_NextEvents: \" " . $uca_next_events . " \" , txt_GoToEventUrl: \" " . $uca_look_events . " \" , moment: { \" months \" : " . $uca_months_events . " , \" monthsShort \" : " . $uca_monshort_events . " , \" weekdays \" : " . $uca_weekdays_events . " , \" weekdaysShort \" : " . $uca_wdayshort_events . " , \" weekdaysMin \" : " . $uca_wdaymin_events . " }}});}); " ;
2017-04-09 01:28:15 +05:00
2017-05-06 00:56:07 +05:00
// Создаем js файл для календаря с названием dataXXX.js - где XXX = Id календаря
$fdir = " /modules/unicalendar/js/data-files/ " ;
mkdir ( BASE_DIR . $fdir , 0777 , true );
chmod ( BASE_DIR . $fdir , 0777 );
$df = fopen ( BASE_DIR . " /modules/unicalendar/js/data-files/data " . $id . " .js " , " w " )
or die ( $uca_not_write_file ); // ругаемся если нет прав на запись в директорию data-files !
flock ( $df , 2 );
fwrite ( $df , $js_data_files );
flock ( $df , 3 );
fclose ( $df );
// Записываем в секции <head> подключение js файла с данными календаря, согласно Id этого календаря
$data_dir = " /modules/unicalendar/js/data-files " ;
$filename = BASE_DIR . $data_dir . " /data " . $id . " .js " ;
if ( file_exists ( $filename ))
{
$GLOBALS [ 'user_header' ][ 'module_unicalendar_' . $id ] = '<script src="' . ABS_PATH . 'modules/unicalendar/js/data-files/data' . $id . '.js" type="text/javascript" charset="utf-8"></script>' ; // подключаем в секции <head> js файл с данным , согласно Id календаря
}
else {
echo $uca_file_not_found . $id . " .js " ; // если не смогли подключить файл -выводим сообщение-подсказку
};
2017-04-09 01:28:15 +05:00
}
2017-05-06 00:56:07 +05:00
// Если выбрали вывести выбранные документы из заданной рубрики - документы с Id=1 (Главная) и 404 страница - выводиться не будут!
2017-04-09 01:28:15 +05:00
if ( $uevents != '' && $uevents == '2' ){
$sql = $AVE_DB -> Query ( "
SELECT Id , document_alias , document_title , document_published , document_meta_description
FROM " . PREFIX . " _documents
2017-04-12 01:06:21 +05:00
WHERE rubric_id = '" . $urubric_id . "' AND Id != 1 && Id != '".PAGE_NOT_FOUND_ID."' AND $udoc_id
2017-04-09 01:28:15 +05:00
" );
$results = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $results , $row );
}
2017-05-06 00:56:07 +05:00
//получаем данные выбранных документов из заданной рубрики циклом, формируем строку JSON
foreach ( $results as $k => $v )
{
$uni_data .= " { \" date \" : \" " . pretty_date ( strftime ( '%Y-%m-%d %H:%M:%S' , $v [ 'document_published' ])) . " \" , \" title \" : \" " . $v [ 'document_title' ] . " \" , \" description \" : \" " . $v [ 'document_meta_description' ] . " \" , \" url \" : \" " . $v [ 'document_alias' ] . " \" }, " ;
}
$js_data_files = " $ (function() { " . " var data " . $id . " = [ " . $uni_data . " ]; $ ( \" #eventCalendar " . $id . " \" ).eventCalendar( { jsonData: data " . $id . " , jsonDateFormat: \" human \" , startWeekOnMonday: " . $uca_day . " , eventsScrollable: " . $uca_scroll . " , openEventInNewWindow: " . $uca_link . " , dateFormat: \" dddd DD-MM-YYYY \" , showDescription: " . $uca_descript . " , locales: { locale: \" " . $uca_locale . " \" , txt_noEvents: \" " . $uca_no_events . " \" , txt_SpecificEvents_prev: \" \" , txt_SpecificEvents_after: \" " . $uca_real_events . " \" , txt_NextEvents: \" " . $uca_next_events . " \" , txt_GoToEventUrl: \" " . $uca_look_events . " \" , moment: { \" months \" : " . $uca_months_events . " , \" monthsShort \" : " . $uca_monshort_events . " , \" weekdays \" : " . $uca_weekdays_events . " , \" weekdaysShort \" : " . $uca_wdayshort_events . " , \" weekdaysMin \" : " . $uca_wdaymin_events . " }}});}); " ;
// Создаем js файл для календаря с названием dataXXX.js - где XXX = Id календаря
$fdir = " /modules/unicalendar/js/data-files/ " ;
mkdir ( BASE_DIR . $fdir , 0777 , true );
chmod ( BASE_DIR . $fdir , 0777 );
$df = fopen ( BASE_DIR . " /modules/unicalendar/js/data-files/data " . $id . " .js " , " w " )
or die ( $uca_not_write_file ); // ругаемся если нет прав на запись в директорию data-files !
flock ( $df , 2 );
fwrite ( $df , $js_data_files );
flock ( $df , 3 );
fclose ( $df );
// Записываем в секции <head> подключение js файла с данными календаря, согласно Id этого календаря
$data_dir = " /modules/unicalendar/js/data-files " ;
$filename = BASE_DIR . $data_dir . " /data " . $id . " .js " ;
if ( file_exists ( $filename ))
{
$GLOBALS [ 'user_header' ][ 'module_unicalendar_' . $id ] = '<script src="' . ABS_PATH . 'modules/unicalendar/js/data-files/data' . $id . '.js" type="text/javascript" charset="utf-8"></script>' ; // подключаем в секции <head> js файл с данным , согласно Id календаря
}
else {
echo $uca_file_not_found . $id . " .js " ; // если не смогли подключить файл -выводим сообщение-подсказку
};
}
2017-04-09 01:28:15 +05:00
2017-05-06 00:56:07 +05:00
$AVE_Template -> assign ( 'id' , $id );
2017-04-09 01:28:15 +05:00
$AVE_Template -> display ( $tpl_dir . 'unicalendar.tpl' );
}
/**
* ФУНКЦИИ АДМИНИСТРАТИВНОЙ ЧАСТИ
*/
/**
* Вывод списка календарей
*
* @ param string $tpl_dir - путь к папке с шаблонами модуля
*/
function unicalendarList ( $tpl_dir )
{
global $AVE_DB , $AVE_Template ;
$unicalendars = array ();
$limit = 20 ;
$start = get_current_page () * $limit - $limit ;
$sql = $AVE_DB -> Query ( "
SELECT SQL_CALC_FOUND_ROWS
u .* ,
COUNT ( u . id ) AS uca_count
FROM
" . PREFIX . " _module_unicalendar AS u
GROUP BY u . id
ORDER BY u . id ASC
LIMIT " . $start . " , " . $limit . "
" );
$sql_num = $AVE_DB -> Query ( " SELECT FOUND_ROWS() " );
$num = $sql_num -> GetCell ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $unicalendars , $row );
}
if ( $num > $limit )
{
$page_nav = " <li><a href= \" index.php?do=modules&action=modedit&mod=unicalendar&moduleaction=1&page= { s}&cp= " . SESSION . " \" > { t}</a></li> " ;
$page_nav = get_pagination ( ceil ( $num / $limit ), 'page' , $page_nav );
}
else
{
$page_nav = '' ;
}
$AVE_Template -> assign ( 'page_nav' , $page_nav );
if ( ! empty ( $_REQUEST [ 'alert' ]))
{
$AVE_Template -> assign ( 'alert' , htmlspecialchars ( stripslashes ( $_REQUEST [ 'alert' ])));
}
$AVE_Template -> assign ( 'unicalendars' , $unicalendars );
$AVE_Template -> assign ( 'formaction' , 'index.php?do=modules&action=modedit&mod=unicalendar&moduleaction=new&sub=save&cp=' . SESSION );
$AVE_Template -> assign ( 'content' , $AVE_Template -> fetch ( $tpl_dir . 'admin_unicalendar_list.tpl' ));
}
/**
* Создание календаря
*
*/
function unicalendarNew ()
{
if ( isset ( $_REQUEST [ 'sub' ]) && $_REQUEST [ 'sub' ] == 'save' )
{
global $AVE_DB ;
$cont = true ;
$alert = '' ;
if ( empty ( $_POST [ 'uca_title' ]))
{
$alert = '&alert=empty_uca_title' ;
$cont = false ;
}
if ( $cont )
{
$AVE_DB -> Query ( "
INSERT
INTO " . PREFIX . " _module_unicalendar
SET
id = '' ,
uca_title = '" . $_POST[' uca_title '] . "' ,
uca_events = '" . $_POST[' uca_events '] . "' ,
uca_rubric_id = '" . $_POST[' uca_rubric_id '] . "' ,
2017-05-06 00:56:07 +05:00
uca_rubric_title = '" . $_POST[' uca_rubric_title '] . "' ,
2017-04-09 20:38:10 +05:00
uca_doc_id = '" . $_POST[' uca_doc_id '] . "' ,
uca_link = '" . $_POST[' uca_link '] . "' ,
uca_day = '" . $_POST[' uca_day '] . "' ,
uca_scroll = '" . $_POST[' uca_scroll '] . "' ,
uca_descript = '" . $_POST[' uca_descript '] . "'
2017-04-09 01:28:15 +05:00
" );
}
header ( 'Location:index.php?do=modules&action=modedit&mod=unicalendar&moduleaction=1' . $alert );
exit ;
}
}
2017-05-06 00:56:07 +05:00
/**
* Редактирование календаря
* @ param int $unicalendar_id - идентификатор календаря
*/
function unicalendarEdit ( $tpl_dir , $unicalendar_id )
{
global $AVE_DB , $AVE_Template ;
$sql = $AVE_DB -> Query ( "
SELECT *
FROM " . PREFIX . " _module_unicalendar
WHERE id = '" . $unicalendar_id . "'
" );
$unicalendars = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $unicalendars , $row );
}
foreach ( $unicalendars as $k => $v )
{
$uevents = $v [ 'uca_events' ];
$urubric_id = $v [ 'uca_rubric_id' ];
$udoc_id = $v [ 'uca_doc_id' ];
}
if ( $uevents == 2 )
{
$sql = $AVE_DB -> Query ( "
SELECT Id , document_alias , document_title , document_published , document_meta_description
FROM " . PREFIX . " _documents
WHERE rubric_id = '" . $urubric_id . "' AND Id != 1 && Id != '".PAGE_NOT_FOUND_ID."'
" );
$unidocs = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $unidocs , $row );
}
$AVE_Template -> assign ( 'unidocs' , $unidocs );
$sql = $AVE_DB -> Query ( "
SELECT Id
FROM " . PREFIX . " _documents
WHERE rubric_id = '" . $urubric_id . "' AND Id != 1 && Id != '".PAGE_NOT_FOUND_ID."' AND $udoc_id
" );
$check_docs = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $check_docs , $row );
}
$AVE_Template -> assign ( 'check_docs' , $check_docs );
}
$AVE_Template -> assign ( 'unicalendars' , $unicalendars );
$AVE_Template -> assign ( 'content' , $AVE_Template -> fetch ( $tpl_dir . 'admin_unicalendar_edit.tpl' ));
}
/**
* Сохранение календаря после редактирования
* @ param int $unicalendar_id - идентификатор календаря
*/
function unicalendarEditSave ( $unicalendar_id )
{
global $AVE_DB ;
$AVE_DB -> Query ( "
UPDATE
" . PREFIX . " _module_unicalendar
SET
uca_title = '" . $_POST[' uca_title '] . "' ,
uca_doc_id = '" . $_POST[' uca_doc_id '] . "' ,
uca_events = '" . $_POST[' uca_events '] . "' ,
uca_rubric_id = '" . $_POST[' uca_rubric_id '] . "' ,
uca_rubric_title = '" . $_POST[' uca_rubric_title '] . "' ,
uca_link = '" . $_POST[' uca_link '] . "' ,
uca_day = '" . $_POST[' uca_day '] . "' ,
uca_scroll = '" . $_POST[' uca_scroll '] . "' ,
uca_descript = '" . $_POST[' uca_descript '] . "'
WHERE id = '" . $unicalendar_id . "'
" );
$as = array ();
$as -> $_POST [ 'uca_title' ];
$as -> $_POST [ 'uca_rubric_title' ];
echo json_encode ( $as );
exit ;
}
/**
* Выбор событий календаря
*
*/
function unicalendarEventsNew ()
{
require_once ( BASE_DIR . '/modules/unicalendar/lang/ru.php' ); // загружаем файл ленгов для php переменных
if ( isset ( $_POST [ 'c' ])) // если пришел запрос вывести все категории, получаем данные и отдаем их в шаблон (выпадающий список)
{
global $AVE_DB ;
$sql = $AVE_DB -> Query ( "
SELECT Id , rubric_title
FROM " . PREFIX . " _rubrics
" );
echo " <option style='color: #ABABAB;' value='' > " . $select_category . " </option> " ;
while ( $result = $sql -> FetchRow ())
{
echo " <option value= " . $result -> Id . " > " . $result -> rubric_title . " </option> " ;
};
}
if ( isset ( $_POST [ 'a' ])) // если пришел запрос вывести все документы (не будет выведен документ с Id=1 это Главная страница и документ Ошибка 404), получаем и выводим чекбоксами
{
global $AVE_DB ;
$sql = $AVE_DB -> Query ( "
SELECT Id , document_alias , document_title , document_published , document_meta_description
FROM " . PREFIX . " _documents
WHERE rubric_id = '" . $_POST[' b '] . "' AND Id != 1 && Id != '".PAGE_NOT_FOUND_ID."'
" );
$u_sel_doc = array ();
while ( $row = $sql -> FetchAssocArray ())
{
array_push ( $u_sel_doc , $row );
}
foreach ( $u_sel_doc as $k => $v )
{
echo " <tr class='noborder'><td align='center'><input type='checkbox' class='my-checkbox' name='u_chek " . $v [ 'Id' ] . " ' value=' " . $v [ 'Id' ] . " '></td> " . " <td align='center'> " . $v [ 'Id' ] . " </td> " . " <td> " . $v [ 'document_title' ] . " </td> " . " <td align='center'> " . $v [ 'document_published' ] = pretty_date ( strftime ( TIME_FORMAT , $v [ 'document_published' ])) . " </td></tr> " ;
}
}
exit ;
}
2017-04-09 01:28:15 +05:00
/**
* Удаление календаря
*
* @ param int $unicalendar_id - идентификатор календаря
*/
function unicalendarDelete ( $unicalendar_id )
{
global $AVE_DB ;
$AVE_DB -> Query ( " DELETE FROM " . PREFIX . " _module_unicalendar WHERE id = ' " . $unicalendar_id . " ' " );
2017-05-06 00:56:07 +05:00
// Удаляем js файл с данными из директории /modules/unicalendar/js/data-files/
$data_dir = " /modules/unicalendar/js/data-files " ;
$filename = BASE_DIR . $data_dir . " /data " . $unicalendar_id . " .js " ;
if ( file_exists ( $filename ))
{
unlink ( $filename );
}
2017-04-09 01:28:15 +05:00
header ( 'Location:index.php?do=modules&action=modedit&mod=unicalendar&moduleaction=1&cp=' . SESSION );
exit ;
}
}
?>