Топик переименован , т.к. я разобрался где ошибка.
Вобщем, суть в том, что надо сделать для toppages отдельный тег, выводящий отдельное число (заданное в админке) страниц в хедер помимо тех, которые он и так выводит. Я написал toppages.header.php, код работает в хедере, но на индексе не выводится news. Ругается вот так:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'l' at line 5
Вот запрос из news.functions.php, на который собственно и ругается
$sql = sed_sql_query("SELECT p.*, u.user_name, user_avatar FROM $db_pages AS p
LEFT JOIN $db_users AS u ON u.user_id=p.page_ownerid
WHERE page_state=0 AND page_cat != 'system'
AND page_begin<'".$sys['now_offset']."' AND page_expire>'".$sys['now_offset']."'
AND page_cat IN ('".implode("','", $catsub)."') ORDER BY page_".$order." ".$way." LIMIT $d, $limit" );
Если убрать из пятой строчки
ORDER BY page_".$order." ".$way." LIMIT $d, $limit" , то работает, но тогда, соответственно, в новостях выводятся все статьи без ограничения и сортировки по дате. Подскажите, пожалуйста, как их совместить.
Вот сам toppages.header.php.
<?PHP
/* ====================
Seditio - Website engine
Copyright Neocrome
http://www.neocrome.net
[BEGIN_SED]
File=plugins/toppages/toppages.header.php
Version=110
Updated=2006-jan-24
Type=Plugin
Author=Azazello
Description=
[END_SED]
[BEGIN_SED_EXTPLUGIN]
Code=toppages
Part=header
File=toppages.header
Hooks=header.tags
Tags=header.tpl:{PLUGIN_TOPPAGES.categorycodehere}
Minlevel=0
Order=10
[END_SED_EXTPLUGIN]
==================== */
if (!defined('SED_CODE')) { die('Wrong URL.'); }
/* ============ MASKS FOR THE HTML OUTPUTS =========== */
$cfg['plu_mask_headertoppages'] = "%2\$s" . "<br>";
//(%3\$s)
// %1\$s = Link to the category
// %2\$s = Link to the page
// %3\$s = Count
$limittp = $cfg['plugin']['toppages']['headermaxpages'];
if (!defined('SED_CODE')) { die('Wrong URL.'); }
$plu_empty = $L['None']."<br />";
function sed_get_headertoppages($c, $limittp, $mask)
{
global $L, $db_pages, $usr, $cfg, $sed_cat, $sed_catacc, $plu_empty;
$mtch = $sed_cat[$c]['path'].".";
$mtchlen = strlen($mtch);
$catsub = array();
$catsub[] = $c;
@reset($sed_cat);
while (list($i,$x) = each($sed_cat) )
{
if (substr($x['path'],0,$mtchlen)==$mtch)
{
$catsub[] = $i;
}
}
$sql = sed_sql_query("SELECT page_id,page_cat,page_title,page_count,page_alias,page_img,page_extra2,page_key FROM $db_pages
WHERE page_state=0
AND page_cat NOT LIKE 'system'
AND page_cat IN ('".implode("','", $catsub)."')
ORDER by page_count DESC LIMIT $limittp");
while ($row = sed_sql_fetcharray($sql))
{
$row['page_urlpar'] = (empty($row['page_alias'])) ? "id=".$row['page_id'] : "al=".$row['page_alias'];
/* ------ Oughtem -------*/
$headertoppages_width = $cfg['plugin']['toppages']['hwidth'];
$headertoppages_height = $cfg['plugin']['toppages']['hheight'];
$headertoppages_linkclass = $cfg['plugin']['toppages']['hlinkclass'];
$headertoppages_divclass = $cfg['plugin']['toppages']['hdivclass'];
$headertoppages_cut = $cfg['plugin']['toppages']['hcut'];
$headertoppages_pageav = $cfg['plugin']['toppages']['hpageav'];
$headertoppages_defav = $cfg['plugin']['toppages']['hdefav'];
if ($row['page_img'] == "")
{
$topicon = $row['page_extra2'];
}
elseif ($row['page_extra2'] == "")
{
$topicon = "".$headertoppages_pageav."".$row['page_img']."";
}
if ($row['page_img'] == "")
{
if ($row['page_extra2'] == "")
{
$topicon = "".$headertoppages_defav."";
}
}
/* ------ // Oughtem -------*/
$res .= (sed_auth('page', $row['page_cat'], 'R')) ? sprintf($mask,
"<a class=\"".$headertoppages_linkclass."\" href=\"page.php?".$row['page_urlpar']."\"><img src=\"".$topicon."\" border=\"0\" width=\"".$headertoppages_width."\" height=\"".$headertoppages_height."\" align=\"left\" alt=\"".$row['page_title']."\" ></a>",
"<a href=\"page.php?".$row['page_urlpar']."\" title=\"".sed_cc(sed_cutstring(stripslashes($row['page_key']),$headertoppages_cut))." ".$L['examened']." ".$row['page_count']." ".$L['examenedcount']."\">".sed_cc(sed_cutstring(stripslashes($row['page_key']),$headertoppages_cut))."</a>"
//,
//"<a href=\"page.php?".$row['page_urlpar']."\">".$row['page_count']."</a>"
//"<img src=\"".$row['page_img']."\" alt=\"".$row['page_title']."\" >"
// "<a href=\"list.php?c=".$row['page_cat']."\">".$sed_cat[$row['page_cat']]['title']."</a>",
) : '';
}
$res = (empty($res)) ? $plu_empty : $res;
return($res);
}
if ($cfg['plugin']['toppages']['headermaxpages']>0 && !empty($cfg['plugin']['toppages']['categories']))
{
$cats = explode(',', $cfg['plugin']['toppages']['categories']);
foreach($cats as $k => $i)
{
$i = trim($i);
$toppages[$i] = sed_get_headertoppages(
$i,
$cfg['plugin']['toppages']['headermaxpages'],
$cfg['plu_mask_headertoppages']);
}
}
$t-> assign(array(
"PLUGIN_TOPPAGESHEADER" => $toppages,
"PLUGIN_TOPPAGESHEADER_MAXLINES" => $cfg['plugin']['toppages']['headermaxpages']
));
?>