CIS Menue optimiert - Eintraege werden nun mit einem einzelnen SELECT gesammelt geladen anstatt für jeden Menüpunkt einen eigenen SELECT Befehl abzusetzen.

This commit is contained in:
Andreas Österreicher
2012-08-13 09:16:18 +00:00
parent fd41c5d7ba
commit 92df449eef
2 changed files with 243 additions and 57 deletions
+95 -55
View File
@@ -32,7 +32,8 @@ foreach($_REQUEST as $key=>$value)
//Parameter fuer Include Addons
$includeparams = array();
$contentobjects=array();
$chldsobject = array();
/**
* Zeichnet einen Menueeintrag aus dem CMS System
*
@@ -41,78 +42,117 @@ $includeparams = array();
function drawSubmenu($content_id)
{
global $sprache;
global $contentarr;
global $childsobject;
global $contentobjects;
$content = new content();
$sprache = getSprache();
//$arr = $content->getMenueArray($content_id, $sprache, true);
$content->getChilds($content_id);
foreach ($content->result as $row)
{
drawEntry($row, $sprache);
}
// Daten Laden
// Alle Kindelemente des Contents holen
$ids = $content->getAllChilds($content_id);
// Alle vorkommenden Contenteintraege laden
$content->loadArray($ids, $sprache, true);
$contentobjects = $content->result;
// Baumstruktur laden
$childsobject = $content->getChildArray($content_id);
// Menue rausschreiben
drawSubmenu1($content_id);
}
function drawSubmenu1($content_id)
{
global $childsobject;
global $contentobjects;
if(isset($childsobject[$content_id]) && count($childsobject[$content_id])>0)
{
// jeden Untermenuepunkt durchlaufen
foreach($childsobject[$content_id] as $entry)
{
$contentobj=null;
//Content Objekt suchen
foreach($contentobjects as $row)
{
if($row->content_id==$entry)
{
$contentobj = $row;
break;
}
}
if(!is_null($contentobj))
{
//Eintrag zeichnen
drawEntry($contentobj);
}
}
}
}
/**
* Zeichnet den Menueeintrag samt Untermenues
* @param $item Menue Array
*/
function drawEntry($item, $sprache)
function drawEntry($item)
{
$content = new content();
global $childsobject;
//pruefen ob der Content eine Berechtigung erfordert
if($content->islocked($item->content_id))
if($item->locked)
{
$user = get_uid();
$content = new content();
//wenn der User nicht berechtigt ist, dann wird der Eintrag nicht angezeigt
if(!$content->berechtigt($item->content_id, $user))
return;
}
$content = new content();
if($content->getContent($item->child_content_id, $sprache, null, true, true))
if(isset($childsobject[$item->content_id]) && count($childsobject[$item->content_id])>0)
{
if($content->hasChilds($content->content_id))
{
echo '
<tr>
<td class="tdwidth10" nowrap>&nbsp;</td>
<td class="tdwrap">';
if($content->template_kurzbz=='include')
IncludeMenuAddon($content);
elseif($content->template_kurzbz=='redirect')
Redirect($content, $content->content_id);
else
DrawLink(APP_ROOT.'cms/content.php?content_id='.$content->content_id,'content',$content->titel, $content->content_id);
echo '
<table class="menue" id="Content'.$content->content_id.'" style="display: '.($content->menu_open?'visible':'none').'">';
$content->getChilds($content->content_id);
foreach($content->result as $row)
{
drawEntry($row, $sprache);
}
echo '
</table>
</td>
</tr>';
}
// Eintrag hat Untermenue -> Aufklappbar machen
echo '
<tr>
<td class="tdwidth10" nowrap>&nbsp;</td>
<td class="tdwrap">';
if($item->template_kurzbz=='include')
IncludeMenuAddon($item);
elseif($item->template_kurzbz=='redirect')
Redirect($item, $item->content_id);
else
{
echo '
<tr>
<td class="tdwidth10" nowrap>&nbsp;</td>
<td class="tdwrap">';
if($content->template_kurzbz=='include')
IncludeMenuAddon($content);
elseif($content->template_kurzbz=='redirect')
Redirect($content);
else
DrawLink(APP_ROOT.'cms/content.php?content_id='.$content->content_id,'content',$content->titel);
echo '
</td>
</tr>';
}
DrawLink(APP_ROOT.'cms/content.php?content_id='.$item->content_id,'content',$item->titel, $item->content_id);
echo '
<table class="menue" id="Content'.$item->content_id.'" style="display: '.($item->menu_open?'visible':'none').'">';
drawSubmenu1($item->content_id);
echo '
</table>
</td>
</tr>';
}
else
{
// Normaler Eintrag ohne Untermenue
echo '
<tr>
<td class="tdwidth10" nowrap>&nbsp;</td>
<td class="tdwrap">';
if($item->template_kurzbz=='include')
IncludeMenuAddon($item);
elseif($item->template_kurzbz=='redirect')
Redirect($item);
else
DrawLink(APP_ROOT.'cms/content.php?content_id='.$item->content_id,'content',$item->titel);
echo '
</td>
</tr>';
}
}
@@ -199,4 +239,4 @@ function IncludeMenuAddon($content)
$includeparams['content']=$content;
include(dirname(__FILE__).'/menu/'.$url);
}
}
}
+148 -2
View File
@@ -1303,6 +1303,152 @@ class content extends basis_db
return false;
}
}
/**
* Laedt alle Content Eintraege unterhalb eines Contents
* (Ohne Newseintraege)
*/
public function getAllChilds($content_id)
{
$qry = "
SELECT
content_id
FROM
campus.tbl_content
WHERE
content_id IN(
WITH RECURSIVE childs(content_id, child_content_id) as
(
SELECT content_id, child_content_id FROM campus.tbl_contentchild
WHERE content_id=".$this->db_add_param($content_id, FHC_INTEGER)."
UNION ALL
SELECT cc.child_content_id, null FROM campus.tbl_contentchild cc, childs
WHERE cc.content_id=childs.content_id
)
SELECT content_id
FROM childs
GROUP BY content_id)
AND template_kurzbz<>'news'
";
$ids=array();
if($result = $this->db_query($qry))
{
while($row = $this->db_fetch_object($result))
{
$ids[] = $row->content_id;
}
return $ids;
}
}
/**
*
* Laedt Contenteintraege anhand einer ID Liste
* @param $ids Array mit Content IDs
* @param $sprache
* @param $sichtbar
*/
public function loadArray($ids, $sprache, $sichtbar=null)
{
$qry='';
foreach($ids as $id)
{
if($qry!='')
$qry.='UNION ALL';
$qry.= " SELECT
content_id, titel, oe_kurzbz, template_kurzbz, sprache,
contentsprache_id, version, sichtbar, content, reviewvon, reviewamum,
tbl_contentsprache.updateamum, tbl_contentsprache.updatevon,
tbl_contentsprache.insertamum, tbl_contentsprache.insertvon,
menu_open, aktiv, gesperrt_uid, beschreibung,
(SELECT CASE WHEN count(*)>0 THEN true ELSE false END
FROM campus.tbl_contentgruppe WHERE content_id=tbl_content.content_id) as locked
FROM
campus.tbl_content
JOIN campus.tbl_contentsprache USING(content_id)
WHERE
tbl_content.content_id=".$this->db_add_param($id, FHC_INTEGER)."
AND tbl_contentsprache.sprache=".$this->db_add_param($sprache);
if($sichtbar)
$qry.=" AND sichtbar=true";
//Hoechste (sichtbare) Version
$qry.=" AND version=(SELECT max(version) FROM campus.tbl_contentsprache
WHERE content_id=".$this->db_add_param($id, FHC_INTEGER)."
AND tbl_contentsprache.sprache=".$this->db_add_param($sprache);
if($sichtbar)
$qry.=" AND sichtbar=true";
$qry.=")";
}
if($result = $this->db_query($qry))
{
while($row = $this->db_fetch_object($result))
{
$obj = new content();
$obj->content_id = $row->content_id;
$obj->titel = $row->titel;
$obj->oe_kurzbz = $row->oe_kurzbz;
$obj->template_kurzbz = $row->template_kurzbz;
$obj->sprache = $row->sprache;
$obj->contentsprache_id = $row->contentsprache_id;
$obj->version = $row->version;
$obj->sichtbar = $obj->db_parse_bool($row->sichtbar);
$obj->content = $row->content;
$obj->reviewvon = $row->reviewvon;
$obj->reviewamum = $row->reviewamum;
$obj->updateamum = $row->updateamum;
$obj->updatevon = $row->updatevon;
$obj->insertamum = $row->insertamum;
$obj->insertvon = $row->insertvon;
$obj->menu_open = $this->db_parse_bool($row->menu_open);
$obj->aktiv = $this->db_parse_bool($row->aktiv);
$obj->gesperrt_uid = $row->gesperrt_uid;
$obj->beschreibung = $row->beschreibung;
$obj->locked = $this->db_parse_bool($row->locked);
$this->result[] = $obj;
}
return true;
}
else
{
$this->errormsg = 'Fehler beim Laden der Daten';
return false;
}
}
/**
*
* Laedt rekursiv alle Kindelemente eines Contents und liefert diese als Array zurueck
* @param $content_id
* @return Array mit IDs der Kindelemente
*/
public function getChildArray($content_id)
{
$qry = "
WITH RECURSIVE childs(content_id, child_content_id, sort) as
(
SELECT content_id, child_content_id, sort FROM campus.tbl_contentchild
WHERE content_id=".$this->db_add_param($content_id, FHC_INTEGER)."
UNION ALL
SELECT cc.content_id, cc.child_content_id, cc.sort FROM campus.tbl_contentchild cc, childs
WHERE cc.content_id=childs.child_content_id
)
SELECT content_id, child_content_id
FROM childs ORDER BY content_id, sort
";
$childs=array();
if($result = $this->db_query($qry))
{
while($row = $this->db_fetch_object($result))
{
if($row->child_content_id!='')
$childs[$row->content_id][]=$row->child_content_id;
}
return $childs;
}
}
}
?>
?>