2017-06-24 00:58:56 +03:00
|
|
|
<?php
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
/**
|
|
|
|
* AVE.cms
|
|
|
|
*
|
|
|
|
* @package AVE.cms
|
|
|
|
* @version 3.x
|
|
|
|
* @filesource
|
|
|
|
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
|
|
|
|
*
|
|
|
|
* @license GPL v.2
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Постраничная навигация документа
|
|
|
|
*
|
|
|
|
* @param string $text текст многострочной части документа
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function document_pagination($text)
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
global $AVE_Core;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
// IE8 <div style="page-break-after: always"><span style="display: none"> </span></div>
|
|
|
|
// Chrome <div style="page-break-after: always; "><span style="DISPLAY:none"> </span></div>
|
|
|
|
// FF <div style="page-break-after: always;"><span style="display: none;"> </span></div>
|
|
|
|
$pages = preg_split('#<div style="page-break-after:[; ]*always[; ]*"><span style="display:[ ]*none[;]*"> </span></div>#i', $text);
|
|
|
|
$total_page = @sizeof($pages);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
if ($total_page > 1)
|
|
|
|
{
|
|
|
|
$text = @$pages[get_current_page('artpage')-1];
|
|
|
|
|
|
|
|
$page_nav = ' <a class="pnav" href="index.php?id=' . $AVE_Core->curentdoc->Id
|
|
|
|
. '&doc=' . (empty($AVE_Core->curentdoc->document_alias) ? prepare_url($AVE_Core->curentdoc->document_title) : $AVE_Core->curentdoc->document_alias)
|
|
|
|
. '&artpage={s}'
|
2019-08-22 13:00:37 +03:00
|
|
|
. ((isset($_REQUEST['apage']) && is_numeric($_REQUEST['apage'])) ? '&apage=' . $_REQUEST['apage'] : '')
|
|
|
|
. ((isset($_REQUEST['page']) && is_numeric($_REQUEST['page'])) ? '&page=' . $_REQUEST['page'] : '')
|
2018-03-26 10:33:20 +03:00
|
|
|
. '">{t}</a> ';
|
|
|
|
$page_nav = get_pagination($total_page, 'artpage', $page_nav, get_settings('navi_box'));
|
|
|
|
|
|
|
|
$text .= rewrite_link($page_nav);
|
|
|
|
}
|
|
|
|
|
|
|
|
$pages = '<?php $GLOBALS[\'page_id\'][' . $_REQUEST['id'] . '][\'artpage\']=' . $total_page . '; ?>';
|
|
|
|
|
|
|
|
return $pages . $text;
|
2017-06-24 00:58:56 +03:00
|
|
|
}
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
/**
|
|
|
|
* Получить идентификатор текущего документа
|
|
|
|
*
|
|
|
|
* @return int идентификатор текущего документа
|
|
|
|
*/
|
|
|
|
function get_current_document_id()
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
$_REQUEST['id'] = (isset($_REQUEST['id']) && is_numeric($_REQUEST['id']))
|
|
|
|
? $_REQUEST['id']
|
|
|
|
: 1;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
return $_REQUEST['id'];
|
2017-06-24 00:58:56 +03:00
|
|
|
}
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
/**
|
|
|
|
* Получить идентификатор родительского документа
|
|
|
|
*
|
|
|
|
* @return int идентификатор родительского документа
|
|
|
|
*/
|
|
|
|
function get_parent_document_id()
|
|
|
|
{
|
|
|
|
global $AVE_DB;
|
|
|
|
return $AVE_DB->Query("SELECT document_parent FROM " . PREFIX . "_documents WHERE Id = '".get_current_document_id()."' ")->GetCell();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Функция отдаёт основные параметры дока
|
|
|
|
*
|
|
|
|
* @param int $doc_id - номер id документа
|
|
|
|
* @param string $key - параметр документа
|
|
|
|
*
|
2018-09-20 11:04:28 +03:00
|
|
|
* @return string | bool | array
|
2018-03-26 10:33:20 +03:00
|
|
|
*/
|
|
|
|
function get_document ($doc_id , $key ='')
|
|
|
|
{
|
|
|
|
global $AVE_DB;
|
|
|
|
|
|
|
|
$doc_id = (int)$doc_id;
|
|
|
|
|
|
|
|
if ($doc_id < 1)
|
|
|
|
return array();
|
|
|
|
|
|
|
|
static $get_documents_data = array();
|
|
|
|
|
|
|
|
if (! isset ($get_documents_data[$doc_id]))
|
|
|
|
{
|
2018-05-16 23:14:07 +03:00
|
|
|
$get_documents_data[$doc_id] = getDocument($doc_id);
|
|
|
|
|
|
|
|
$get_documents_data[$doc_id] = object2array($get_documents_data[$doc_id]);
|
2018-03-26 10:33:20 +03:00
|
|
|
|
|
|
|
$get_documents_data[$doc_id]['doc_title'] = $get_documents_data[$doc_id]['document_title'];
|
|
|
|
$get_documents_data[$doc_id]['feld'] = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($key) && $key != '')
|
|
|
|
return $get_documents_data[$doc_id][$key];
|
|
|
|
else
|
|
|
|
return $get_documents_data[$doc_id];
|
2017-06-24 00:58:56 +03:00
|
|
|
}
|
2018-05-16 23:14:07 +03:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Функция отдаёт основные параметры дока
|
|
|
|
*
|
|
|
|
* @param int $doc_id - номер id документа
|
|
|
|
*
|
2018-09-20 11:04:28 +03:00
|
|
|
* @return object | bool
|
2018-05-16 23:14:07 +03:00
|
|
|
*/
|
|
|
|
function getDocument ($doc_id)
|
|
|
|
{
|
|
|
|
global $AVE_DB;
|
|
|
|
|
|
|
|
$doc_id = (int)$doc_id;
|
|
|
|
|
|
|
|
if ($doc_id < 1)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
$sql = "
|
|
|
|
SELECT
|
|
|
|
# DOCUMENT = $doc_id
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_documents
|
|
|
|
WHERE
|
|
|
|
Id = '" . $doc_id . "'
|
|
|
|
";
|
|
|
|
|
|
|
|
$cache_time = (defined('CACHE_DOC_FILE') && CACHE_DOC_FILE)
|
|
|
|
? -1
|
|
|
|
: 0;
|
|
|
|
|
|
|
|
$data = $AVE_DB->Query($sql, $cache_time, 'dat_' . $doc_id, true, '.data')->FetchRow();
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
?>
|