Probleme bei der Dynamischen Erzeugung einer Überschrift

Gesperrt
korthi
Beiträge: 13
Registriert: Di 14. Okt 2003, 13:36
Wohnort: Erfurt
Kontaktdaten:

Probleme bei der Dynamischen Erzeugung einer Überschrift

Beitrag von korthi » Di 28. Okt 2003, 15:29

Hallo Leute,
mal wieder ein Problemchen, wo ich nicht weiterkomme:

Ich möchte oberhalb der Hauptnavigation den Namen der Übergeordneten Kategorie als Überschrift anzeigen lassen. Dafür hab ich im Output der Hauptnavigation bisher folgendes dazugepackt ($parent existiert schon).

Code: Alles auswählen

###########
$dbueberschrift = new DB_Contenido;
$sql= "SELECT
                    name
                FROM
                     ".$cfg["tab"]["cat_lang"]." 
                WHERE
                   idcat   = $parent";
$dbueberschrift->query($sql);
$dbueberschrift->next_record();
global $ueberschrift=$dbueberschrift->f("name");
echo $ueberschrift;
###########
Leider funktioniert es irgendwie nicht! Kann mir jemand helfen?
Danke im Vorraus,
Korthi.
Grüße, korthi.
<a href="http://www.post-sv-erfurt.de">www.post-sv-erfurt.de</a>

HerrB
Beiträge: 6935
Registriert: Do 22. Mai 2003, 12:44
Wohnort: Berlin
Kontaktdaten:

Beitrag von HerrB » Di 28. Okt 2003, 18:23

Ähm, so vielleicht (Variable ausserhalb des SQL-Strings):

Code: Alles auswählen

########### 
$dbueberschrift = new DB_Contenido; 
$sql= "SELECT 
                    name 
                FROM 
                     ".$cfg["tab"]["cat_lang"]." 
                WHERE 
                   idcat   = ".$parent; 
$dbueberschrift->query($sql); 
$dbueberschrift->next_record(); 
global $ueberschrift=$dbueberschrift->f("name"); 
echo $ueberschrift; 
###########
Gruß
HerrB

korthi
Beiträge: 13
Registriert: Di 14. Okt 2003, 13:36
Wohnort: Erfurt
Kontaktdaten:

Beitrag von korthi » Mi 29. Okt 2003, 10:46

:cry: Nee. leider nicht.

Die Lampe bleibt rot und zeigt mir die Fehlerquelle nicht an.

Danke trotzdem...

Ich glaub auch nicht, das es an dem sql-String liegt, denn wenn ich die Zeile

Code: Alles auswählen

global $ueberschrift=$dbueberschrift->f("name"); 
ist zumindest das Lämpchen grün
Zuletzt geändert von korthi am Mi 29. Okt 2003, 10:51, insgesamt 1-mal geändert.
Grüße, korthi.
<a href="http://www.post-sv-erfurt.de">www.post-sv-erfurt.de</a>

timo
Beiträge: 6284
Registriert: Do 15. Mai 2003, 18:32
Wohnort: Da findet ihr mich nie!
Kontaktdaten:

Beitrag von timo » Mi 29. Okt 2003, 10:50

Fahr mal mit der Maus über die Lampe - da steht evtl, was im Modul nicht stimmt.

Bei mir ist die Lampe grün :)

korthi
Beiträge: 13
Registriert: Di 14. Okt 2003, 13:36
Wohnort: Erfurt
Kontaktdaten:

Beitrag von korthi » Mi 29. Okt 2003, 11:01

Dann hat dein Lämpchen vielleicht einen Wackelkontakt :roll:

Nee, im Ernst, das Lämpchen bleibt bei mir rot und im Tooltip steht nur "Fehler in Modul. Fehlerquelle: "

Nicht wirklich hilfreich!

Vielleicht nochmal der gesamte Code des Outputteils:

Code: Alles auswählen

<?php

/***********************************************
* CONTENIDO MODUL - OUTPUT
*
* Modulname   :     Navigation 1.1
* Author      :     Jan Lengowski
* Copyright   :     Contenido - four for business
* Created     :     15-05-2003
* Modified    :     26-05-2003
************************************************/

if ( !is_object($db2) ) {
    $db2 = new DB_Contenido;
}

/**
 * Check if a category is child
 * of another category
 *
 * @return boolean true/false
 * @author Jan Lengowski <Jan.Lengowski@4fb.de>
 * @copyright four for business AG 2003
 */
$fetternavipunkt=0;
function catIsChildOf($id, $idparent) {

    global $cfg, $client, $lang;

    $db = new DB_Contenido;

    $parent = $id;

    while ( $parent != 0 ) {

        $sql = "SELECT
                    a.parentid
                FROM
                    ".$cfg["tab"]["cat"]." AS a,
                    ".$cfg["tab"]["cat_lang"]." AS b
                WHERE
                    a.idclient  = '".$client."' AND
                    b.idlang    = '".$lang."' AND
                    a.idcat     = b.idcat AND
                    a.idcat   = '".$parent."'";

        $db->query($sql);
        $db->next_record();

        $parent = $db->f("parentid");
########### 
$dbueberschrift = new DB_Contenido; 
$sql= "SELECT 
                    name 
                FROM 
                     ".$cfg["tab"]["cat_lang"]." 
                WHERE 
                   idcat   = ".$parent; 
$dbueberschrift->query($sql); 
$dbueberschrift->next_record(); 
global $ueberschrift=$dbueberschrift->f("name"); 
echo $ueberschrift; 
###########
/*** Umrechnung Navigation ***/
global $fetternavipunkt;
switch($parent)
{
   case 29:
      $fetternavipunkt=120;
      break;
   case 43:
      $fetternavipunkt=122;
      break;
   case 11:
      $fetternavipunkt=123;
      break;
   case 12:
      $fetternavipunkt=124;
   break;
   case 13:
      $fetternavipunkt=125;
      break;
   case 19:
      $fetternavipunkt=126;
      break;
}
/*** Ende Umrechnung Navigation ***/
      
        if ($parent == $idparent) {

            return true;
        }

    }

    return false;

}

if ( catIsChildOf($idcat, CMS_VALUE[0]) ) {
    $sel_idcat = $idcat;
} else {
    $sel_idcat = CMS_VALUE[0];
}

/* Include Template Class */
include_once($cfg["path"]["contenido"] . 'classes/class.template.php');

/**
 * Array storing alle the
 * navigation data
 */
$navitems = array();


/* Template Instance */
$tpl = new Template;

/**
 * Recursive function for creating
 * the navigation array
 * @param Int $idcat Category id
 */
function nav($idcat) {

        global $navitems, $client, $lang, $cfg;

        $db  = new DB_Contenido;
        $db2 = new DB_Contenido;

        $sql = "SELECT parentid FROM ".$cfg["tab"]["cat"]." WHERE idcat = '$idcat'";

        $db->query($sql);
        $db->next_record();

        $parentid = $db->f("parentid");
        if ( $parentid == 0 ) {

           if ( $idcat != CMS_VALUE[0] ){

                $navitems = array();
              
                $sql = "SELECT
                            A.idcat,
                            C.name
                        FROM
                            ".$cfg["tab"]["cat_tree"]." AS A,
                            ".$cfg["tab"]["cat"]." AS B,
                            ".$cfg["tab"]["cat_lang"]." AS C
                        WHERE
                            A.idcat     = B.idcat   AND
                            B.idcat     = C.idcat   AND
                            B.idclient  = '$client' AND
                            C.idlang    = '$lang'   AND
                            C.visible   = '1'       AND
                            B.parentid  = 'CMS_VALUE[0]'
                        ORDER
                            BY A.idtree";

                      $db->query($sql);

                      while ($db->next_record()) {

                            /* Check for external redirects... */
                            $sql = "SELECT
                                        a.external_redirect AS ext
                                    FROM
                                        ".$cfg["tab"]["art_lang"]." AS a,
                                        ".$cfg["tab"]["cat_art"]." AS b,
                                        ".$cfg["tab"]["cat"]." AS c
                                    WHERE
                                        b.idcat     = '".$db->f("idcat")."' AND
                                        b.is_start  = '1' AND
                                        c.idclient  = '".$client."' AND
                                        c.idcat     = b.idcat AND
                                        a.idart     = b.idart AND
                                        a.idlang    = '".$lang."'";

                            $db2->query($sql);
                            $db2->next_record();

                            $target = ( $db2->f("ext") == 0 ) ? '_self' : '_blank';

                            $navitems[$db->f("idcat")] = array("idcat"      => $db->f("idcat"),
                                                                "name"      => $db->f("name"),
                                                                "target"    => $target);
                      }

           }
           
           return true;
        }

        $sql = "SELECT
                    A.idcat,
                    C.name
                FROM
                    ".$cfg["tab"]["cat_tree"]." AS A,
                    ".$cfg["tab"]["cat"]." AS B,
                    ".$cfg["tab"]["cat_lang"]." AS C
                WHERE
                    A.idcat     = B.idcat   AND
                    B.idcat     = C.idcat   AND
                    B.idclient  = '$client' AND
                    C.idlang    = '$lang'   AND
                    C.visible   = '1'       AND
                    B.parentid  = '$parentid'
                ORDER BY
                    A.idtree";

        $db->query($sql);

        while ($db->next_record()) {

                /* Check for external redirects... */
                $sql = "SELECT
                            a.external_redirect AS ext
                        FROM
                            ".$cfg["tab"]["art_lang"]." AS a,
                            ".$cfg["tab"]["cat_art"]." AS b,
                            ".$cfg["tab"]["cat"]." AS c
                        WHERE
                            b.idcat     = '".$db->f("idcat")."' AND
                            b.is_start  = '1' AND
                            c.idclient  = '".$client."' AND
                            c.idcat     = b.idcat AND
                            a.idart     = b.idart AND
                            a.idlang    = '".$lang."'";

                $db2->query($sql);
                $db2->next_record();

                $target = ( $db2->f("ext") == 0 ) ? '_self' : '_blank';
                
                $tmp_nav[$db->f("idcat")] = array("idcat"   => $db->f("idcat"),
                                                  "name"    => $db->f("name"),
                                                  "target"  => $target);
        }

        $tmp_nav[$idcat]["sub"] = $navitems;
        $navitems = $tmp_nav;

        /* Function call */
        nav($parentid);

}  // end function

$sql = "SELECT
            A.idcat,
            C.name
        FROM
            ".$cfg["tab"]["cat_tree"]." AS A,
            ".$cfg["tab"]["cat"]." AS B,
            ".$cfg["tab"]["cat_lang"]." AS C
        WHERE
            A.idcat     = B.idcat   AND
            B.idcat     = C.idcat   AND
            B.idclient  = '$client' AND
            C.idlang    = '$lang'   AND
            C.visible   = '1'       AND
            B.parentid  = '$sel_idcat'
        ORDER BY
            A.idtree";

$db->query($sql);

while ( $db->next_record() ) {

        /* Check for external redirects... */
        $sql = "SELECT
                    a.external_redirect AS ext
                FROM
                    ".$cfg["tab"]["art_lang"]." AS a,
                    ".$cfg["tab"]["cat_art"]." AS b,
                    ".$cfg["tab"]["cat"]." AS c
                WHERE
                    b.idcat     = '".$db->f("idcat")."' AND
                    b.is_start  = '1' AND
                    c.idclient  = '".$client."' AND
                    c.idcat     = b.idcat AND
                    a.idart     = b.idart AND
                    a.idlang    = '".$lang."'";

        $db2->query($sql);
        $db2->next_record();

        $target = ( $db2->f("ext") == 0 ) ? '_self' : '_blank';

        $navitems[$db->f("idcat")] = array("idcat"  => $db->f("idcat"),
                                           "name"   => $db->f("name"),
                                           "target" => $target);
}

/* Create Navigation Array */
nav($sel_idcat);
/* Start Output buffer */
ob_start();

/* ***echo '<table cellspacing="0" cellpadding="0" border="0">';*** */

foreach ($navitems as $key => $data) {

    /* 1. Navigations Ebene */
    $tpl->reset();
    $tpl->set('d', 'NAME',  $data['name']);
    $tpl->set('d', 'TARGET', $data['target']);
    $tpl->set('d', 'HREF',  $sess->url('front_content.php?idcat='.$data['idcat']));
    $tpl->next();

    if ($idcat == $data['idcat'] || is_array($data['sub'])) {
        $tpl->generate('templates/navfirst_on.html');
    } else {
        $tpl->generate('templates/navfirst_off.html');
    }

    if (is_array($data['sub'])) {

        foreach ($data['sub'] as $key => $data) {

            /* 2. Navigations Ebene */
            $tpl->reset();
            $tpl->set('d', 'NAME',  $data['name']);
            $tpl->set('d', 'TARGET', $data['target']);
            $tpl->set('d', 'HREF',  $sess->url('front_content.php?idcat='.$data['idcat']));
            $tpl->next();

            if ($idcat == $data['idcat'] || is_array($data['sub'])) {
                $tpl->generate('templates/navsecond_on.html');
            } else {
                $tpl->generate('templates/navsecond_off.html');
            }

            if (is_array($data['sub'])) {

                foreach ($data['sub'] as $key => $data) {

                    /* 3. Navigations Ebene */
                    $tpl->reset();
                    $tpl->set('d', 'NAME',  $data['name']);
                    $tpl->set('d', 'TARGET', $data['target']);
                    $tpl->set('d', 'HREF',  $sess->url('front_content.php?idcat='.$data['idcat']));
                    $tpl->next();

                    if ($idcat == $data['idcat']) {
                        $tpl->generate('templates/navthird_on.html');
                    } else {
                        $tpl->generate('templates/navthird_off.html');
                    }

                } // end foreach

            } // end if

        } // end foreach

    } // end if

} // end foreach

/* ****echo '</table>';******/

/* Read out buffer */
$html = ob_get_contents();

/* Clean buffer */
ob_end_clean();

/* Output buffer-contents */
global $navihtml;
$navihtml=$html;
?>
Die Ausgabe in die Variable $navihtml am Ende hat ürigens nix mit dem Thema zu tun.
Grüße, korthi.
<a href="http://www.post-sv-erfurt.de">www.post-sv-erfurt.de</a>

timo
Beiträge: 6284
Registriert: Do 15. Mai 2003, 18:32
Wohnort: Da findet ihr mich nie!
Kontaktdaten:

Beitrag von timo » Mi 29. Okt 2003, 11:12

Eigentlich ist es ganz einfach :)

global $foo = "bar"; geht nicht.

Du müßtest es dann so schreiben:

global $foo;
$foo = "bar";

Oder global gleich ganz weglassen.

korthi
Beiträge: 13
Registriert: Di 14. Okt 2003, 13:36
Wohnort: Erfurt
Kontaktdaten:

Beitrag von korthi » Mi 29. Okt 2003, 11:16

:D Danke Timo, Du bist der Größte !!!
Grüße, korthi.
<a href="http://www.post-sv-erfurt.de">www.post-sv-erfurt.de</a>

timo
Beiträge: 6284
Registriert: Do 15. Mai 2003, 18:32
Wohnort: Da findet ihr mich nie!
Kontaktdaten:

Beitrag von timo » Mi 29. Okt 2003, 11:26

nein, nur 1.79m :D

Gesperrt