commit 29f8f4d0fce905c316f8807778afba88a4f16b5f
parent 56ba415d6d3e66e16663dd92eba2da0439ce09cb
Author: dankert <devnull@localhost>
Date: Thu, 14 Oct 2004 23:15:29 +0200
Erzeugen und Anzeigen einer Sitemap
Diffstat:
1 file changed, 115 insertions(+), 0 deletions(-)
diff --git a/dynamicClasses/Sitemap.class.php b/dynamicClasses/Sitemap.class.php
@@ -0,0 +1,114 @@
+<?php
+// ---------------------------------------------------------------------------
+// $Id$
+// ---------------------------------------------------------------------------
+// OpenRat Content Management System
+// Copyright (C) 2002 Jan Dankert, jandankert@jandankert.de
+//
+// This program is free software; you can redistribute it and/or
+// modify it under the terms of the GNU General Public License
+// as published by the Free Software Foundation; either version 2
+// of the License, or (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+// ---------------------------------------------------------------------------
+// $Log$
+// Revision 1.1 2004-10-14 21:15:29 dankert
+// Erzeugen und Anzeigen einer Sitemap
+//
+// ---------------------------------------------------------------------------
+
+
+
+/**
+ * Erstellen eines Menues
+ * @author Jan Dankert
+ */
+class Sitemap /*extends DynamicElement*/
+{
+ /**
+ * Bitte immer alle Parameter in dieses Array schreiben, dies ist fuer den Web-Developer hilfreich.
+ * @type String
+ */
+ var $parameters = Array(
+ 'beforeEntry'=>'Chars before an active menu entry'
+ );
+
+ /**
+ * Bitte immer eine Beschreibung benutzen, dies ist fuer den Web-Developer hilfreich.
+ * @type String
+ */
+ var $description = 'Creates a main menu.';
+
+
+ /**
+ * Zeichenkette, die vor einem aktiven Menuepunkt gezeigt wird
+ */
+ var $beforeEntry = '<li><strong>';
+ var $afterEntry = '</strong></li>';
+
+ var $api;
+
+ /**
+ * Erstellen einer Sitemap
+ */
+ function execute()
+ {
+ // Erstellen eines Untermenues
+
+ // Ermitteln der aktuellen Seite
+ $thispage = new Page( $this->api->getObjectId() );
+ $thispage->load(); // Seite laden
+
+ // uebergeordneter Ordner dieser Seite
+ $this->showFolder( Folder::getRootObjectId() );
+ }
+
+ function showFolder( $oid )
+ {
+ // uebergeordneter Ordner dieser Seite
+ $f = new Folder( $oid );
+
+ // Schleife ueber alle Objekte im aktuellen Ordner
+ foreach( $f->getObjectIds() as $id )
+ {
+ $o = new Object( $id );
+ $o->languageid = $this->page->languageid;
+ $o->load();
+
+ // Ordner
+ if ($o->isFolder )
+ {
+ $this->api->output( '<li><strong>'.$o->name.'</strong><br/>' );
+ $this->api->output( '<ul>' );
+ $this->showFolder( $id ); // Rekursiver Aufruf dieser Methode
+ $this->api->output( '</ul></li>' );
+ }
+
+ // Seiten und Verkn?fpungen
+ if ($o->isPage || $o->isLink )
+ {
+ // Wenn aktuelle Seite, dann markieren, sonst Link
+ if ( $this->api->getObjectId() == $id )
+ {
+ // aktuelle Seite
+ $this->api->output( '<li><strong>'.$o->name.'</strong></li>' );
+ }
+ else
+ {
+ // Link erzeugen
+ $this->api->output( '<li><a href="'.$this->api->page->path_to_object($id).'">'.$o->name.'</a></li>' );
+ }
+ }
+ }
+ }
+}
+
+?>+
\ No newline at end of file