2012-05-25 09:48:56 +00:00
< ? php
class AchMenu extends RenderNodeIterator {
2012-05-27 19:08:28 +00:00
var $open ;
2012-05-25 09:48:56 +00:00
function AchMenu ( $open = false , $lang = 'en' ) {
global $db ;
2012-05-27 19:08:28 +00:00
$this -> open = $open ;
$res = $db -> sqlQuery ( " SELECT * FROM ach_category LEFT JOIN (ach_category_lang) ON (acl_lang=' " . $lang . " ' AND acl_category=ac_id) WHERE ac_parent IS NULL ORDER by ac_order ASC, acl_name ASC " );
2012-05-25 09:48:56 +00:00
$sz = sizeof ( $res );
for ( $i = 0 ; $i < $sz ; $i ++ ) {
$this -> nodes [] = new AchMenuNode ( $res [ $i ], $open , $lang );
}
}
2012-05-27 19:08:28 +00:00
function getCat () {
return $this -> open ;
}
2012-05-25 09:48:56 +00:00
}
class AchMenuNode extends RenderNodeIterator {
2012-05-27 19:08:28 +00:00
private $id ;
private $parent ;
private $name ;
private $open ;
private $image ;
private $order ;
2012-05-25 09:48:56 +00:00
function AchMenuNode ( & $data , $open , $lang ) {
global $db ;
$this -> id = $data [ 'ac_id' ];
$this -> parent = $data [ 'ac_parent' ];
$this -> name = $data [ 'acl_name' ];
2012-05-27 19:08:28 +00:00
$this -> image = $data [ 'ac_image' ];
$this -> order = $data [ 'ac_order' ];
2012-05-25 09:48:56 +00:00
$this -> open = ( $open == $data [ 'ac_id' ]);
2012-05-27 19:08:28 +00:00
$res = $db -> sqlQuery ( " SELECT * FROM ach_category LEFT JOIN (ach_category_lang) ON (acl_lang=' " . $lang . " ' AND acl_category=ac_id) WHERE ac_parent=' " . $this -> id . " ' ORDER by ac_order ASC, acl_name ASC " );
2012-05-25 09:48:56 +00:00
$sz = sizeof ( $res );
for ( $i = 0 ; $i < $sz ; $i ++ ) {
$this -> nodes [] = new AchMenuNode ( $res [ $i ], $open , $lang );
}
}
function getID () {
return $this -> id ;
}
function getName () {
return $this -> name ;
}
function getParent () {
return $this -> parent ;
}
function isOpen () {
return $this -> open ;
}
2012-05-27 19:08:28 +00:00
function getImage () {
return $this -> image ;
}
function getOrder () {
return $this -> order ;
}
2012-05-25 09:48:56 +00:00
}
?>