mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 20:29:29 +00:00
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:
+95
-55
@@ -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> </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> </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> </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> </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
@@ -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;
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
||||
?>
|
||||
|
||||
Reference in New Issue
Block a user