ave-cms/functions/func.fields.php

759 lines
21 KiB
PHP
Raw Normal View History

2017-06-24 00:58:56 +03:00
<?php
/**
* AVE.cms
*
* @package AVE.cms
* @version 3.x
* @filesource
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
*
* @license GPL v.2
*/
/**
* Определяем пустое изображение
*/
2018-03-26 10:33:20 +03:00
$img_pixel = 'templates/images/default.png';
2017-06-24 00:58:56 +03:00
/**
* Проверка папки /fields/ на наличие полей
*/
if (is_dir(BASE_DIR . '/fields/'))
{
$d = dir(BASE_DIR . '/fields');
while (false !== ($entry = $d->read()))
{
$field_dir = $d->path . '/' . $entry;
if (is_dir($field_dir) && file_exists($field_dir . '/field.php'))
2018-03-26 10:33:20 +03:00
{
require_once ($field_dir . '/field.php');
}
2017-06-24 00:58:56 +03:00
}
$d->Close();
}
/**
* Проверка папок /fields/ в модулях, на наличие полей
*/
2018-05-16 23:14:07 +03:00
if (is_dir(BASE_DIR . '/modules/'))
2017-06-24 00:58:56 +03:00
{
2018-05-16 23:14:07 +03:00
$d = dir(BASE_DIR . '/modules');
2017-06-24 00:58:56 +03:00
2018-05-16 23:14:07 +03:00
while (false !== ($entry = $d->read()))
{
$module_dir = $d->path . '/' . $entry;
2017-06-24 00:58:56 +03:00
2018-05-16 23:14:07 +03:00
if (is_dir($module_dir) && file_exists($module_dir . '/field.php'))
require_once($module_dir . '/field.php');
}
$d->Close();
}
2017-06-24 00:58:56 +03:00
/**
* Поле по умолчанию
*
* @param $field_value
* @param $action
* @param int $field_id
* @param string $tpl
* @param int $tpl_empty
* @param null $maxlength
* @param array $document_fields
* @param int $rubric_id
* @param null $default
*
* @return string
*/
2018-03-26 10:33:20 +03:00
function get_field_default($field_value, $action, $field_id=0, $tpl='', $tpl_empty=0, &$maxlength=null, $document_fields=array(), $rubric_id=0, $default=null, $_tpl=null)
2017-06-24 00:58:56 +03:00
{
switch ($action)
{
case 'edit':
2018-03-26 10:33:20 +03:00
return '<input type="text" style="width: 100%" name="feld[' . $field_id . ']" value="' . $field_value . '">';
2017-06-24 00:58:56 +03:00
case 'doc':
case 'req':
2018-03-12 23:35:55 +03:00
if (! $tpl_empty)
2017-06-24 00:58:56 +03:00
{
$field_param = explode('|', $field_value);
$field_value = preg_replace_callback(
'/\[tag:parametr:(\d+)\]/i',
function($data) use($field_param)
{
return $field_param[(int)$data[1]];
},
$tpl
);
}
return $field_value;
2018-03-12 23:35:55 +03:00
default:
return $field_value;
2017-06-24 00:58:56 +03:00
}
}
/**
* Возвращаем тип поля
*
2018-09-20 11:04:28 +03:00
* @param string $type
*
2017-11-17 12:02:05 +03:00
* @return mixed
2017-06-24 00:58:56 +03:00
*/
2018-03-26 10:33:20 +03:00
function get_field_type ($type = '')
2017-06-24 00:58:56 +03:00
{
static $fields;
2017-11-17 12:02:05 +03:00
if (is_array($fields))
2017-06-24 00:58:56 +03:00
return $fields;
$arr = get_defined_functions();
$fields = array();
$field = array();
2017-11-17 12:02:05 +03:00
foreach ($arr['user'] as $v)
2017-06-24 00:58:56 +03:00
{
2017-11-17 12:02:05 +03:00
if (trim(substr($v, 0, strlen('get_field_'))) == 'get_field_')
2017-06-24 00:58:56 +03:00
{
$d = '';
$name = @$v('', 'name', '', '', 0, $d);
$id = substr($v, strlen('get_field_'));
if ($name != false && is_string($name))
2018-09-20 11:04:28 +03:00
$fields[] = array('id' => $id, 'name' => $name);
2017-06-24 00:58:56 +03:00
if (! empty($type) && $id == $type)
2018-09-20 11:04:28 +03:00
$field = array('id' => $id, 'name' => $name);
2017-06-24 00:58:56 +03:00
}
2018-03-26 10:33:20 +03:00
else
continue;
2017-06-24 00:58:56 +03:00
}
$fields = msort($fields, array('name'));
2017-11-17 12:02:05 +03:00
return (! empty($type))
? $field
: $fields;
2017-06-24 00:58:56 +03:00
}
/**
* Возвращаем алиас по номеру поля
*
* @param $id
* @return string
*/
2017-11-17 12:02:05 +03:00
function get_field_alias($id)
{
2017-06-24 00:58:56 +03:00
global $AVE_DB;
2017-11-17 12:02:05 +03:00
static $alias_field_id = array();
if (isset($alias_field_id[$id]))
2018-03-26 10:33:20 +03:00
return $alias_field_id[$id];
2017-11-17 12:02:05 +03:00
2018-09-20 11:04:28 +03:00
$alias_field_id[$id] = $AVE_DB->Query("SELECT rubric_field_alias FROM " . PREFIX . "_rubric_fields WHERE Id=" . intval($id))->GetCell();
2017-11-17 12:02:05 +03:00
2017-06-24 00:58:56 +03:00
return $alias_field_id[$id];
}
/**
* Возвращаем номер поля по рубрике и алиасу
*
* @param $rubric_id
* @param $alias
*
* @return string
*/
2018-03-12 23:35:55 +03:00
function get_field_num($rubric_id, $alias)
{
2017-06-24 00:58:56 +03:00
global $AVE_DB;
2018-03-12 23:35:55 +03:00
static $alias_field_id = array();
if (isset($alias_field_id[$rubric_id][$alias]))
return $alias_field_id[$rubric_id][$alias];
$sql = "
SELECT Id
2018-03-26 10:33:20 +03:00
FROM
" . PREFIX . "_rubric_fields
WHERE
2018-09-20 11:04:28 +03:00
(rubric_field_alias = '" . addslashes($alias) . "'
OR Id = '" . intval($alias) . "')
2018-03-26 10:33:20 +03:00
AND
2018-09-20 11:04:28 +03:00
rubric_id = " . intval($rubric_id)
2018-03-12 23:35:55 +03:00
;
$alias_field_id[$rubric_id][$alias] = $AVE_DB->Query($sql)->GetCell();
2017-06-24 00:58:56 +03:00
return $alias_field_id[$rubric_id][$alias];
}
2018-03-12 23:35:55 +03:00
2017-06-24 00:58:56 +03:00
/**
* Возвращаем
*
* @param $id
*
* @return string
*/
function get_field_default_value($id)
{
global $AVE_DB;
static $alias_field_id = array();
2018-05-16 23:14:07 +03:00
if (isset($alias_field_id[$id]))
2017-06-24 00:58:56 +03:00
return $alias_field_id[$id];
2018-03-12 23:35:55 +03:00
$sql = "
2018-03-26 10:33:20 +03:00
SELECT
rubric_field_default
FROM
" . PREFIX . "_rubric_fields
WHERE
Id = ".intval($id)
2018-03-12 23:35:55 +03:00
;
$alias_field_id[$id] = $AVE_DB->Query($sql)->GetCell();
2017-06-24 00:58:56 +03:00
return $alias_field_id[$id];
}
2018-03-12 23:35:55 +03:00
2017-06-24 00:58:56 +03:00
/**
* Возвращаем шаблон tpl или пусто
*
2018-03-26 10:33:20 +03:00
* @param string $dir папка шаблона
2017-06-24 00:58:56 +03:00
* @param int $field_id идентификатор поля
2018-03-26 10:33:20 +03:00
* @param string $type тип поля
* @param int $_tpl номер шаблона
2017-06-24 00:58:56 +03:00
*
* @return string
*/
2018-03-26 10:33:20 +03:00
function get_field_tpl($dir = '', $field_id = 0, $type = 'admin', $_tpl = null)
2018-03-12 23:35:55 +03:00
{
2018-03-26 10:33:20 +03:00
if (! $type)
return false;
2018-03-12 23:35:55 +03:00
2018-03-26 10:33:20 +03:00
$alias_field_id = get_field_alias($field_id);
2017-06-24 00:58:56 +03:00
2018-03-26 10:33:20 +03:00
// Если существет файл с ID поля и ID шаблона
if (file_exists($dir.'field-'.$type.'-'.$field_id.'-'.$_tpl.'.tpl'))
$tpl = $dir.'field-'.$type.'-'.$field_id.'-'.$_tpl.'.tpl';
// Если существет файл с аласом поля и ID шаблона
else if (file_exists($dir.'field-'.$type.'-'.$alias_field_id.'-'.$_tpl.'.tpl'))
$tpl = $dir.'field-'.$type.'-'.$alias_field_id.'-'.$_tpl.'.tpl';
// Если существет файл с ID поля
else if (file_exists($dir.'field-'.$type.'-'.$field_id.'.tpl'))
$tpl = $dir.'field-'.$type.'-'.$field_id.'.tpl';
// Если существет файл с алиасом поля
else if (file_exists($dir.'field-'.$type.'-'.$alias_field_id.'.tpl'))
$tpl = $dir.'field-'.$type.'-'.$alias_field_id.'.tpl';
// Если существет файл c типом поля
else if (file_exists($dir.'field-'.$type.'.tpl'))
$tpl = $dir.'field-'.$type.'.tpl';
// Если существет файл c ID поля
else if (file_exists($dir.'field-'.$field_id.'.tpl'))
$tpl = $dir.'field-'.$field_id.'.tpl';
// Иначе
else
$tpl = $dir.'field.tpl';
2017-06-24 00:58:56 +03:00
return $tpl;
}
/**
* Формирование поля документа в соответствии с шаблоном отображения
*
* @param int $field_id идентификатор поля
* @param int $document_id
*
2018-09-20 11:04:28 +03:00
* @param null $_tpl
*
2017-06-24 00:58:56 +03:00
* @return string
*/
2018-09-20 11:04:28 +03:00
function document_get_field($field_id, $document_id = null, $_tpl = null, $maxlength = null)
2017-06-24 00:58:56 +03:00
{
global $AVE_Core;
2018-03-26 10:33:20 +03:00
if (! $_tpl && is_array($field_id))
$_tpl = $field_id[2];
2017-06-24 00:58:56 +03:00
if (is_array($field_id))
$field_id = $field_id[1];
$document_fields = get_document_fields(empty($document_id)
? $AVE_Core->curentdoc->Id
: intval($document_id));
if (! is_array($document_fields[$field_id]))
$field_id = intval($document_fields[$field_id]);
if (empty($document_fields[$field_id]))
return '';
$field_value = trim($document_fields[$field_id]['field_value']);
$tpl_field_empty = $document_fields[$field_id]['tpl_field_empty'];
// if ($field_value == '' && $tpl_field_empty) return '';
$field_type = $document_fields[$field_id]['rubric_field_type'];
$rubric_field_template = trim($document_fields[$field_id]['rubric_field_template']);
$rubric_field_default = $document_fields[$field_id]['rubric_field_default'];
// $field_value = parse_hide($field_value);
// $field_value = ($length != '') ? truncate_text($field_value, $length, '…', true) : $field_value;
$func = 'get_field_' . $field_type;
2017-11-17 12:02:05 +03:00
if (! is_callable($func))
2017-06-24 00:58:56 +03:00
$func = 'get_field_default';
2018-03-26 10:33:20 +03:00
$field_value = $func($field_value, 'doc', $field_id, $rubric_field_template, $tpl_field_empty, $maxlength, $document_fields, RUB_ID, $rubric_field_default, $_tpl);
2017-06-24 00:58:56 +03:00
return $field_value;
}
/**
* Функция получения содержимого поля для обработки в шаблоне рубрики
*
* @param int $field_id идентификатор поля, для [tag:fld:12] $field_id = 12
* @param int $length необязательный параметр,
* количество возвращаемых символов содержимого поля.
* если данный параметр указать со знаком минус
* содержимое поля будет очищено от HTML-тегов.
* @return string
*/
function document_get_field_value($field_id, $length = 0)
{
2017-11-17 12:02:05 +03:00
if (! is_numeric($field_id))
return '';
2017-06-24 00:58:56 +03:00
$document_fields = get_document_fields(get_current_document_id());
$field_value = trim($document_fields[$field_id]['field_value']);
if ($field_value != '')
{
2018-05-16 23:14:07 +03:00
$field_value = strip_tags($field_value); // "<br /><strong><em><p><i>"
2017-06-24 00:58:56 +03:00
if (is_numeric($length) && $length != 0)
{
if ($length < 0)
{
$field_value = strip_tags($field_value);
$field_value = preg_replace('/ +/', ' ', $field_value);
$field_value = trim($field_value);
$length = abs($length);
}
$field_value = truncate_text($field_value, $length, '…', true);
}
}
return $field_value;
}
/**
* Возвращаем истинное значение поля для документа
*
* @param int $document_id id документа
* @param string $field id поля или его алиас
*
* @return string
*/
function get_document_field($document_id, $field)
{
$document_fields = get_document_fields($document_id);
if (! is_array($document_fields[$field]))
$field = intval($document_fields[$field]);
if (empty($document_fields[$field]))
return false;
$field_value = $document_fields[$field]['field_value'];
return $field_value;
}
/**
* Функция возвращает массив со значениями полей
*
* @param $document_id
* @param array $values если надо вернуть документ с произвольными значениями - используется для ревизий документов
* @internal param int $id id документа
2017-11-17 12:02:05 +03:00
* @return mixed
2017-06-24 00:58:56 +03:00
*/
function get_document_fields($document_id, $values = null)
{
2018-09-20 11:04:28 +03:00
global $AVE_DB, $AVE_Core; //$request_documents
2017-06-24 00:58:56 +03:00
static $document_fields = array();
2017-11-17 12:02:05 +03:00
if (! is_numeric($document_id))
2017-06-24 00:58:56 +03:00
return false;
2018-03-12 23:35:55 +03:00
if (! isset($document_fields[$document_id]))
2017-06-24 00:58:56 +03:00
{
$document_fields[$document_id] = false;
$where = "WHERE doc_field.document_id = '" . $document_id . "'";
2018-05-16 23:14:07 +03:00
$query = "
2017-06-24 00:58:56 +03:00
SELECT
2018-05-16 23:14:07 +03:00
# DOC FIELDS = $document_id
doc.document_author_id,
2017-06-24 00:58:56 +03:00
doc_field.Id,
doc_field.document_id,
doc_field.rubric_field_id,
2018-05-16 23:14:07 +03:00
doc_field.field_value,
text_field.field_value as field_value_more,
2017-06-24 00:58:56 +03:00
rub_field.rubric_field_alias,
rub_field.rubric_field_type,
rub_field.rubric_field_default,
rub_field.rubric_field_title,
rub_field.rubric_field_template,
rub_field.rubric_field_template_request
FROM
" . PREFIX . "_document_fields AS doc_field
JOIN
" . PREFIX . "_rubric_fields AS rub_field
ON doc_field.rubric_field_id = rub_field.Id
LEFT JOIN
" . PREFIX . "_document_fields_text AS text_field
2018-05-16 23:14:07 +03:00
ON (doc_field.rubric_field_id = text_field.rubric_field_id AND doc_field.document_id = text_field.document_id)
2017-06-24 00:58:56 +03:00
JOIN
" . PREFIX . "_documents AS doc
2018-05-16 23:14:07 +03:00
ON doc.Id = doc_field.document_id
2017-06-24 00:58:56 +03:00
" . $where;
2018-05-16 23:14:07 +03:00
$cache_id = (int)$AVE_Core->curentdoc->Id;
$cache_id = 'documents/fields/' . (floor($cache_id / 1000)) . '/' . $cache_id;
2017-06-24 00:58:56 +03:00
2018-05-16 23:14:07 +03:00
$cache_file = md5($query) . '.fields';
$cache_dir = BASE_DIR . '/tmp/cache/sql/' . (trim($cache_id) > ''
? trim($cache_id) . '/'
: substr($cache_file, 0, 2) . '/' . substr($cache_file, 2, 2) . '/' . substr($cache_file, 4, 2) . '/');
// Наличие файла
if (file_exists($cache_dir . $cache_file))
2017-06-24 00:58:56 +03:00
{
2018-05-16 23:14:07 +03:00
// Получаем время создания файла
$file_time = filemtime($cache_dir . $cache_file);
// Получаем время для проверки
$cache_time = $AVE_Core->curentdoc->rubric_changed_fields;
// Сравниваем временные метки
if (! $cache_time || $cache_time > $file_time)
unlink ($cache_dir . $cache_file);
2017-06-24 00:58:56 +03:00
}
2018-05-16 23:14:07 +03:00
// Безусловный кеш
$sql = $AVE_DB->Query($query, -1, 'fld_' . $document_id, true, '.fields');
// Вдруг памяти мало!!!!
if (memory_panic() && (count($document_fields) > 3))
$document_fields = array();
2017-06-24 00:58:56 +03:00
while ($row = $sql->FetchAssocArray())
{
$row['tpl_req_empty'] = (trim($row['rubric_field_template_request']) == '');
$row['tpl_field_empty'] = (trim($row['rubric_field_template']) == '');
2018-09-20 11:04:28 +03:00
$row['field_value'] = (string)$row['field_value'] . (string)$row['field_value_more'];
2017-06-24 00:58:56 +03:00
2018-09-20 11:04:28 +03:00
if ($values)
2017-06-24 00:58:56 +03:00
$row['field_value']=(isset($values[$row['rubric_field_id']]) ? $values[$row['rubric_field_id']] : $row['field_value']);
if ($row['field_value'] === '')
{
$row['rubric_field_template_request'] = preg_replace('/\[tag:if_notempty](.*?)\[\/tag:if_notempty]/si', '', $row['rubric_field_template_request']);
$row['rubric_field_template_request'] = trim(str_replace(array('[tag:if_empty]','[/tag:if_empty]'), '', $row['rubric_field_template_request']));
$row['rubric_field_template'] = preg_replace('/\[tag:if_notempty](.*?)\[\/tag:if_notempty]/si', '', $row['rubric_field_template']);
$row['rubric_field_template'] = trim(str_replace(array('[tag:if_empty]','[/tag:if_empty]'), '', $row['rubric_field_template']));
}
else
{
$row['rubric_field_template_request'] = preg_replace('/\[tag:if_empty](.*?)\[\/tag:if_empty]/si', '', $row['rubric_field_template_request']);
$row['rubric_field_template_request'] = trim(str_replace(array('[tag:if_notempty]','[/tag:if_notempty]'), '', $row['rubric_field_template_request']));
$row['rubric_field_template'] = preg_replace('/\[tag:if_empty](.*?)\[\/tag:if_empty]/si', '', $row['rubric_field_template']);
$row['rubric_field_template'] = trim(str_replace(array('[tag:if_notempty]','[/tag:if_notempty]'), '', $row['rubric_field_template']));
}
$document_fields[$row['document_id']][$row['rubric_field_id']] = $row;
$document_fields[$row['document_id']][$row['rubric_field_alias']] = $row['rubric_field_id'];
}
}
2018-03-12 23:35:55 +03:00
2017-06-24 00:58:56 +03:00
return $document_fields[$document_id];
}
/**
* Возвращает содержимое поля документа по номеру
*
* @param int $field_id ([tag:fld:X]) - номер поля
* @param int $doc_id
* @param int $parametr ([tag:parametr:X]) - часть поля
*
* @return string
*/
function get_field($field_id, $doc_id = null, $parametr = null)
{
global $req_item_id;
2017-11-17 12:02:05 +03:00
//-- Если не передан $doc_id, то проверяем реквест
if (! $doc_id && $req_item_id)
$doc_id = $req_item_id;
//-- Или берём для текущего дока
2017-06-24 00:58:56 +03:00
elseif (! $doc_id && $_REQUEST['id'] > 0)
$doc_id = $_REQUEST['id'];
2017-11-17 12:02:05 +03:00
//-- Возвращаем FALSE, если не число
elseif (! is_numeric($doc_id))
return false;
2017-06-24 00:58:56 +03:00
2017-11-17 12:02:05 +03:00
//-- Забираем из базы массив полей
2017-06-24 00:58:56 +03:00
$field = get_document_field($doc_id, $field_id);
2017-11-17 12:02:05 +03:00
//-- Возвращаем нужную часть поля
2017-06-24 00:58:56 +03:00
if ($parametr !== null)
{
2017-11-17 12:02:05 +03:00
$field = explode("|", $field);
2017-06-24 00:58:56 +03:00
$field = array_values(array_diff($field, array('')));
$field = $field[$parametr];
}
return $field;
}
/**
* Возвращает содержимое поля документа по номеру
*
* @param int $field_id ([tag:fld:X]) - номер поля
* @param int $doc_id
* @param int $parametr ([tag:parametr:X]) - часть поля
*
2017-11-17 12:02:05 +03:00
* @return mixed
2017-06-24 00:58:56 +03:00
*/
function get_true_field($field_id, $doc_id = null, $parametr = null)
{
global $req_item_id, $AVE_DB;
2017-11-17 12:02:05 +03:00
//-- Если не передан $doc_id, то проверяем реквест
2017-06-24 00:58:56 +03:00
if (! $doc_id && $req_item_id)
$doc_id = $req_item_id;
2017-11-17 12:02:05 +03:00
//-- Или берём для текущего дока
2017-06-24 00:58:56 +03:00
elseif (! $doc_id && $_REQUEST['id'] > 0)
$doc_id = $_REQUEST['id'];
2017-11-17 12:02:05 +03:00
//-- Возвращаем FALSE, если не число
elseif (! is_numeric($doc_id))
return false;
2017-06-24 00:58:56 +03:00
2017-11-17 12:02:05 +03:00
//-- Забираем поле из базы
2017-06-24 00:58:56 +03:00
$sql = "
SELECT
doc_field.field_value,
text_field.field_value AS field_value_more
FROM
" . PREFIX . "_document_fields AS doc_field
LEFT JOIN
" . PREFIX . "_document_fields_text AS text_field
ON (doc_field.rubric_field_id = text_field.rubric_field_id AND doc_field.document_id = text_field.document_id)
WHERE
doc_field.document_id = '" . $doc_id . "'
AND
doc_field.rubric_field_id = '" . $field_id . "'
";
$query = $AVE_DB->Query($sql)->FetchRow();
$field = (string)$query->field_value . (string)$query->field_value_more;
2017-11-17 12:02:05 +03:00
unset ($sql, $query);
2017-06-24 00:58:56 +03:00
2017-11-17 12:02:05 +03:00
//-- Возвращаем нужную часть поля
2017-06-24 00:58:56 +03:00
if ($parametr !== null)
{
$field = explode("|", $field);
$field = array_values(array_diff($field, array('')));
$field = $field[$parametr];
}
return $field;
}
2017-11-17 12:02:05 +03:00
2017-06-24 00:58:56 +03:00
/**
* Возвращает элемент сериализованного поля по номеру и ключу
*
* @param int $field_id ([tag:fld:X]) - номер поля
* @param int $item_id - номер элемента
* @param int $doc_id ([tag:docid]) - id документа
* @param int $parametr ([tag:parametr:X]) - номер параметра элемента
* @return string
*/
function get_element($field_id, $item_id = 0, $parametr = null, $doc_id = null)
{
global $req_item_id;
2017-11-17 12:02:05 +03:00
//-- Если не передан $doc_id, то проверяем реквест
if (! $doc_id && $req_item_id)
2017-06-24 00:58:56 +03:00
$doc_id = $req_item_id;
2017-11-17 12:02:05 +03:00
//-- Или берём для текущего дока
2017-06-24 00:58:56 +03:00
elseif (! $doc_id && $_REQUEST['id'] > 0)
$doc_id = $_REQUEST['id'];
2017-11-17 12:02:05 +03:00
//-- Возвращаем FALSE, если не число
elseif (! is_numeric($doc_id))
return false;
2017-06-24 00:58:56 +03:00
2017-11-17 12:02:05 +03:00
//-- Забираем из базы поле
2017-06-24 00:58:56 +03:00
$field = get_field($field_id, $doc_id);
$field = unserialize($field);
// возвращаем нужную часть поля
if ($parametr !== null)
{
$field = $field[$item_id];
$field = explode("|", $field);
$field = $field[$parametr];
}
else
{
$field = $field[$item_id];
$field = explode("|", $field);
$field = $field[0];
}
return $field;
}
2017-11-17 12:02:05 +03:00
/**
* Возвращает сериализованны(й|е) элемент(ы) поля
*
* @param int $field_id ([tag:fld:X]) - номер поля
* @param int $item_id - номер элемента
* @param int $doc_id ([tag:docid]) - id документа
* @return mixed
*/
function get_serialize($field_id, $item_id = null, $doc_id = null)
{
global $req_item_id;
//-- Если не передан $doc_id, то проверяем реквест
if (! $doc_id && $req_item_id)
$doc_id = $req_item_id;
//-- Или берём для текущего дока
elseif (! $doc_id && $_REQUEST['id'] > 0)
$doc_id = $_REQUEST['id'];
//-- Возвращаем FALSE, если не число
elseif (! is_numeric($doc_id))
return false;
//-- Забираем поле
$field = get_field($field_id, $doc_id);
$field = unserialize($field);
$field_data = array();
//-- Если получили массив из данных, собираем новый
if (! empty($field))
foreach ($field AS $k => $v)
$field_data[$k] = explode('|', $v);
//-- Иначе возвращаем FALSE
else
return false;
unset($field);
//-- Если пришло $item_id
if (is_numeric($item_id))
return $field_data[$item_id];
else
return $field_data;
}
2017-06-24 00:58:56 +03:00
/**
* Возвращает элемент сериализованного поля по номеру и ключу, через тег [tag:fld:XXX][XXX][XXX]
*
* @return string
*/
2018-03-26 10:33:20 +03:00
function get_field_element()
2017-06-24 00:58:56 +03:00
{
$param = func_get_args();
2018-03-26 10:33:20 +03:00
// Field ID
$param_1 = isset($param[0]) ? $param[0] : null;
// Item ID
$param_2 = isset($param[1]) ? $param[1] : null;
// Param ID
$param_3 = isset($param[2]) ? $param[2] : null;
// Document ID
$param_4 = isset($param[3]) ? $param[3] : null;
$return = get_element($param_1, $param_2, $param_3, $param_4);
2017-06-24 00:58:56 +03:00
return $return;
}
2018-03-12 23:35:55 +03:00
/**
* Возвращает наименование поля документа по номеру
*
2018-09-20 11:04:28 +03:00
* @param int $field_id ([tag:fld:X]) - номер поля
* @param int $doc_id
2018-03-12 23:35:55 +03:00
*
* @return string
*/
function get_field_name($field_id, $doc_id = null)
{
global $req_item_id;
//-- Если не передан $doc_id, то проверяем реквест
if (! $doc_id && $req_item_id)
$doc_id = $req_item_id;
//-- Или берём для текущего дока
elseif (! $doc_id && $_REQUEST['id'] > 0)
$doc_id = $_REQUEST['id'];
//-- Возвращаем FALSE, если не число
elseif (! is_numeric($doc_id))
return false;
$document_fields = get_document_fields($doc_id);
if (empty($document_fields[$field_id]))
return false;
$field_name = $document_fields[$field_id]['rubric_field_title'];
return $field_name;
}
?>