AVE.CMS v3.28
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

204 lines
5.1 KiB

8 years ago
<?
7 years ago
/**
* AVE.cms
*
* @package AVE.cms
* @version 3.x
* @filesource
* @copyright © 2007-2015 AVE.cms, http://www.ave-cms.ru
*
* @license GPL v.2
*/
// Документ из рубрики (Checkbox)
function get_field_doc_from_rub_check($field_value, $action, $field_id=0, $tpl='', $tpl_empty=0, &$maxlength=null, $document_fields=array(), $rubric_id=0, $default=null, $_tpl=null)
{
global $AVE_DB, $AVE_Template;
8 years ago
7 years ago
$fld_dir = dirname(__FILE__) . '/';
$tpl_dir = $fld_dir . 'tpl/';
$fld_name = basename($fld_dir);
8 years ago
7 years ago
$lang_file = $fld_dir . 'lang/' . (defined('ACP') ? $_SESSION['admin_language'] : $_SESSION['user_language']) . '.txt';
8 years ago
7 years ago
$AVE_Template->config_load($lang_file, 'lang');
$AVE_Template->assign('config_vars', $AVE_Template->get_config_vars());
$AVE_Template->config_load($lang_file, 'admin');
8 years ago
7 years ago
$res = array();
8 years ago
7 years ago
switch ($action)
{
case 'edit':
if (isset($default))
{
$parent = $AVE_DB->Query("
SELECT
MIN(document_parent) AS min
FROM
". PREFIX ."_documents
WHERE
rubric_id IN (" . $default . ")
")->GetCell();
$sql = $AVE_DB->Query("
8 years ago
SELECT
7 years ago
Id, document_parent, document_title
8 years ago
FROM
". PREFIX ."_documents
WHERE
rubric_id IN (" . $default . ")
7 years ago
");
8 years ago
7 years ago
$field_value_array = explode('|', $field_value);
$field_value_array = array_values(array_diff($field_value_array, array('')));
8 years ago
7 years ago
$cats = array();
8 years ago
7 years ago
while($cat = $sql->FetchAssocArray())
{
$cat['checked'] = ((in_array($cat['Id'], $field_value_array) == false) ? "0" : "1");
$cats_ID[$cat['Id']][] = $cat;
$cats[$cat['document_parent']][$cat['Id']] = $cat;
}
8 years ago
7 years ago
$AVE_Template->assign('subtpl', $tpl_dir."list.tpl");
$AVE_Template->assign('fields', doc_from_rub_check_tree($cats, $parent));
$AVE_Template->assign('field_id', $field_id);
$AVE_Template->assign('doc_id', (isset($_REQUEST['Id']) ? (int)$_REQUEST['Id'] : 0));
$AVE_Template->assign('field_value', $field_value);
}
else
8 years ago
{
7 years ago
$AVE_Template->assign('error', $AVE_Template->get_config_vars('error'));
8 years ago
}
7 years ago
$tpl_file = get_field_tpl($tpl_dir, $field_id, 'admin', $_tpl);
8 years ago
7 years ago
$AVE_Template->assign('subtpl', $tpl_dir."list.tpl");
8 years ago
7 years ago
return $AVE_Template->fetch($tpl_file);
break;
8 years ago
7 years ago
case 'doc':
$field_value_array = explode('|', $field_value);
$field_value_array = array_values(array_diff($field_value_array, array('')));
8 years ago
7 years ago
if ($field_value_array != false)
8 years ago
{
7 years ago
foreach ($field_value_array as $list_item)
8 years ago
{
7 years ago
if ($list_item)
8 years ago
{
7 years ago
if ($tpl_empty)
{
$list_item = $AVE_DB->Query("
SELECT
Id,
document_title,
document_alias,
document_breadcrum_title
FROM
".PREFIX."_documents
WHERE
Id = '" . $list_item . "'
")->FetchAssocArray();
}
8 years ago
}
7 years ago
$res[] = $list_item;
8 years ago
}
}
7 years ago
$tpl_file = get_field_tpl($tpl_dir, $field_id, 'doc', $_tpl);
8 years ago
7 years ago
if ($tpl_empty && $tpl_file)
{
8 years ago
7 years ago
$AVE_Template->assign('field_id', $field_id);
$AVE_Template->assign('field_value', $res);
$AVE_Template->assign('field_count', count($res));
$AVE_Template->assign('default', $default);
8 years ago
7 years ago
return $AVE_Template->fetch($tpl_file);
}
8 years ago
7 years ago
return (!empty($res)) ? implode(PHP_EOL, $res) : $tpl;
break;
8 years ago
7 years ago
case 'req':
$field_value_array = explode('|', $field_value);
$field_value_array = array_values(array_diff($field_value_array, array('')));
8 years ago
7 years ago
if ($field_value_array != false)
8 years ago
{
7 years ago
foreach ($field_value_array as $list_item)
8 years ago
{
7 years ago
if ($list_item)
8 years ago
{
7 years ago
if ($tpl_empty)
{
$list_item = $AVE_DB->Query("
SELECT
Id,
document_title,
document_alias,
document_breadcrum_title
FROM
".PREFIX."_documents
WHERE
Id = '" . $list_item . "'
")->FetchAssocArray();
}
8 years ago
}
7 years ago
$res[] = $list_item;
8 years ago
}
}
7 years ago
$tpl_file = get_field_tpl($tpl_dir, $field_id, 'req', $_tpl);
8 years ago
7 years ago
if ($tpl_empty && $tpl_file)
{
$AVE_Template->assign('field_id', $field_id);
$AVE_Template->assign('field_value', $res);
$AVE_Template->assign('field_count', count($res));
$AVE_Template->assign('default', $default);
8 years ago
7 years ago
return $AVE_Template->fetch($tpl_file);
}
8 years ago
7 years ago
return (!empty($res)) ? implode(PHP_EOL, $res) : $tpl;
break;
8 years ago
7 years ago
case 'name' :
return $AVE_Template->get_config_vars('name');
break;
8 years ago
7 years ago
}
8 years ago
7 years ago
return ($res ? $res : $field_value);
}
8 years ago
7 years ago
if (! function_exists('doc_from_rub_check_tree'))
8 years ago
{
7 years ago
function doc_from_rub_check_tree($cats, $parent)
8 years ago
{
7 years ago
if (is_array($cats) and isset($cats[$parent]))
{
foreach ($cats[$parent] as $cat)
{
$array[$cat['Id']]['Id'] = $cat['Id'];
$array[$cat['Id']]['checked'] = $cat['checked'];
$array[$cat['Id']]['document_title'] = $cat['document_title'];
$array[$cat['Id']]['child'] = doc_from_rub_check_tree($cats, $cat['Id']);
}
}
else
{
return null;
}
return $array;
8 years ago
}
}
?>