Jump to content
  • Checkout
  • Login
  • Get in touch

osCommerce

The e-commerce.

Show all subcategories in category box?!


nlaur86

Recommended Posts

Posted

Hello!

 

I want to show the whole category-subcategory tree in the category box but I can't do it :(.

I tryed some contributions but some of them were not working and some of them modified my SEO links (don't know why :( ). I finally found one contrib that is working almost ok but I can't get it to "look nice". The contribution I tryed is "Show Sub-categories".

 

The problem is with the infobox, I think. I have a customized design and I think there are some changes at the infobox design too. So, after I modify my categories.php the result look like the image attached:

infobox.jpg

 

My original categories.php (that works but the subcategories are not shown) looks like this:

 

<?php

 function tep_show_category($counter, $count) {
   global $tree, $categories_string, $cPath_array;

if ($count == 0 ) $kk=' class="bg_list_un"'; else $kk=' class="bg_list"'; 
 $count++;

   $categories_string .= '<li'.$kk.'><b>';

   for ($i=0; $i<$tree[$counter]['level']; $i++) {
     $categories_string .= '<div>';
   }

   $categories_string .= '<a href="';

   if ($tree[$counter]['parent'] == 0) {
     $cPath_new = 'cPath=' . $counter;
   } else {
     $cPath_new = 'cPath=' . $tree[$counter]['path'];
   }

   $categories_string .= tep_href_link(FILENAME_DEFAULT, $cPath_new) . '">';

   if (isset($cPath_array) && in_array($counter, $cPath_array)) {
     $categories_string .= '<font color="#67BA0A"><b>';
   }

// display category name
   $categories_string .= $tree[$counter]['name'];

   if (isset($cPath_array) && in_array($counter, $cPath_array)) {
     $categories_string .= '</b></font>';
   }

   if (tep_has_category_subcategories($counter)) {


             if (isset($cPath_array) && in_array($counter, $cPath_array)) {






     $categories_string .= '<font color="#67BA0A">▼</font>';
     }
     else
     {
           $categories_string .= '▼';

     }
   }



   if (SHOW_COUNTS == 'true') {
     $products_in_category = tep_count_products_in_category($counter);
     if ($products_in_category > 0) {


         if (isset($cPath_array) && in_array($counter, $cPath_array)) {


       		$categories_string .= '<font color="67BA0A"> (' . $products_in_category . ')</font>';
			}
			else
			{


               		$categories_string .= ' (' . $products_in_category . ')';
}


     }
   }

   $categories_string .= '</a>';

   for ($i=0; $i<$tree[$counter]['level']; $i++) {
     $categories_string .= '</div>';
   }

   $categories_string .= '</b></li>';

   if ($tree[$counter]['next_id'] != false) {
     tep_show_category($tree[$counter]['next_id'], $count);
   }
 }
?>
<!-- categories //-->
         <tr>
           <td>
<?php
 $info_box_contents = array();
 $info_box_contents[] = array('text' => BOX_HEADING_CATEGORIES);

 new infoBoxHeading($info_box_contents, true, false);

$count = 0;

 $categories_string = '';
 $tree = array();

 $categories_query = tep_db_query("select c.categories_id, cd.categories_name, c.parent_id from " . TABLE_CATEGORIES . " c, " . TABLE_CATEGORIES_DESCRIPTION . " cd where c.parent_id = '0' AND c.status_categ = '1' and c.categories_id = cd.categories_id and cd.language_id='" . (int)$languages_id ."' order by sort_order, cd.categories_name");
 while ($categories = tep_db_fetch_array($categories_query))  {
   $tree[$categories['categories_id']] = array('name' => $categories['categories_name'],
                                               'parent' => $categories['parent_id'],
                                               'level' => 0,
                                               'path' => $categories['categories_id'],
                                               'next_id' => false);

   if (isset($parent_id)) {
     $tree[$parent_id]['next_id'] = $categories['categories_id'];
   }

   $parent_id = $categories['categories_id'];

   if (!isset($first_element)) {
     $first_element = $categories['categories_id'];
   }
 }

 //------------------------
 if (tep_not_null($cPath)) {
   $new_path = '';
   reset($cPath_array);
   while (list($key, $value) = each($cPath_array)) {
     unset($parent_id);
     unset($first_id);
     $categories_query = tep_db_query("select c.categories_id, cd.categories_name, c.parent_id from " . TABLE_CATEGORIES . " c, " . TABLE_CATEGORIES_DESCRIPTION . " cd where c.parent_id = '" . (int)$value . "' AND c.status_categ = '1' and c.categories_id = cd.categories_id and cd.language_id='" . (int)$languages_id ."' order by sort_order, cd.categories_name");
     if (tep_db_num_rows($categories_query)) {
       $new_path .= $value;
       while ($row = tep_db_fetch_array($categories_query)) {
         $tree[$row['categories_id']] = array('name' => $row['categories_name'],
                                              'parent' => $row['parent_id'],
                                              'level' => $key+1,
                                              'path' => $new_path . '_' . $row['categories_id'],
                                              'next_id' => false);

         if (isset($parent_id)) {
           $tree[$parent_id]['next_id'] = $row['categories_id'];
         }

         $parent_id = $row['categories_id'];

         if (!isset($first_id)) {
           $first_id = $row['categories_id'];
         }

         $last_id = $row['categories_id'];
       }
       $tree[$last_id]['next_id'] = $tree[$value]['next_id'];
       $tree[$value]['next_id'] = $first_id;
       $new_path .= '_';
     } else {
       break;
     }
   }
 }
 tep_show_category($first_element, $count); 

 $info_box_contents = array();
 $info_box_contents[] = array('text' => '<ul>' . $categories_string . '</ul>');

 new infoBox($info_box_contents);
?>
           </td>
         </tr>
<!-- categories_eof //-->

 

So, anyone can help me??? Thank you!

Archived

This topic is now archived and is closed to further replies.

×
×
  • Create New...