Bonjour,
Je suis nul en programmation, donc je ne sais pas trop comment m'y prendre...
Je tourne sous oscommerce, et j'ai installé un script java pour avoir un menu horizontal dynamique, j'aimerai pouvoir y ajouter des onglets comme par exemple sur ce site : http://www.fnac.com car pour le moment je n'ai que des rectangle de couleur...
Je vous met ci-joint une capture de mon site, avec une courte explication de ce que je veux faire...
http://www.santenature.fr/test.JPG
Voici le script que j'utilise :
Le code du header relatif a ce script :
Et pour finir le code du fichier coolmenu.php (celui qui génère les tableaux)
Modifié par kervano (16 Apr 2007 - 15:15)
Je suis nul en programmation, donc je ne sais pas trop comment m'y prendre...
Je tourne sous oscommerce, et j'ai installé un script java pour avoir un menu horizontal dynamique, j'aimerai pouvoir y ajouter des onglets comme par exemple sur ce site : http://www.fnac.com car pour le moment je n'ai que des rectangle de couleur...
Je vous met ci-joint une capture de mon site, avec une courte explication de ce que je veux faire...
http://www.santenature.fr/test.JPG
Voici le script que j'utilise :
<script LANGUAGE="JavaScript1.2" SRC="includes/menu_animation.js"></SCRIPT>
Le code du header relatif a ce script :
<table border="0" width="100%" cellspacing="0" cellpadding="1">
<tr class="headerNavigation">
<td class="headerNavigation"> <?php echo $breadcrumb->trail(' » '); ?></td>
<td align="right" class="headerNavigation"><?php if (tep_session_is_registered('customer_id')) { ?><a href="<?php echo tep_href_link(FILENAME_LOGOFF, '', 'SSL'); ?>" class="headerNavigation"><?php echo HEADER_TITLE_LOGOFF; ?></a> | <?php } ?><a href="<?php echo tep_href_link(FILENAME_ACCOUNT, '', 'SSL'); ?>" class="headerNavigation"><?php echo HEADER_TITLE_MY_ACCOUNT; ?></a> </td>
</tr>
</table>
<table border="0" width="100%" cellspacing="0" cellpadding="0">
<tr><td width="100%" align=center>
<?php
if ((USE_CACHE == 'true') && empty($SID)) {
echo tep_cache_categories_box();
} else {
//include(DIR_WS_BOXES . 'categories.php');
include(DIR_WS_BOXES . 'coolmenu.php');
}
?>
</td></tr>
</table>
Et pour finir le code du fichier coolmenu.php (celui qui génère les tableaux)
<?php
/* ------------------------------------------------
coolMenu for osCommerce
author: Andreas Kothe
url: http://www.oddbyte.de
modified by: PinkCrow
url: http://www.pinkcrow.net
Released under the GNU General Public License
------------------------------------------------
*/
// --- CONFIG ---
define('SHOW_COUNT','false');
define('SUB_CATEGORIES','4');
if (MAX_MANUFACTURERS_LIST < 2) {
$cat_choose = array(array('id' => '', 'text' => BOX_CATEGORIES_CHOOSE));
} else {
$cat_choose = '';
}
?>
<!-- Copyright 2002 www.dhtmlcentral.com -- modified for PHP and osCommerce by Andreas Kothe - www.oddbyte.de -->
<script>
oCMenu=new makeCM("oCMenu") //Making the menu object. Argument: menuname
//Menu properties
oCMenu.pxBetween=0
oCMenu.fromLeft=220 //réglage gauche ou droite
oCMenu.fromTop=64 //réglage haut ou bas
oCMenu.rows=1
oCMenu.menuPlacement="left"
oCMenu.offlineRoot=""
oCMenu.onlineRoot=""
oCMenu.resizeCheck=1
oCMenu.wait=300
oCMenu.fillImg="cm_fill.gif"
oCMenu.zIndex=0
//Background bar properties
oCMenu.useBar=1
oCMenu.barWidth="menu"
oCMenu.barHeight="menu"
oCMenu.barClass="clBar"
oCMenu.barX="menu"
oCMenu.barY="menu"
oCMenu.barBorderX=0
oCMenu.barBorderY=0
oCMenu.barBorderClass=""
oCMenu.level[0]=new cm_makeLevel()
oCMenu.level[0].width=90 //réglage hauteur largeur case catégorie
oCMenu.level[0].height=20
oCMenu.level[0].regClass="clLevel0"
oCMenu.level[0].overClass="clLevel0over"
oCMenu.level[0].borderX=1
oCMenu.level[0].borderY=1
oCMenu.level[0].borderClass="clLevel0border"
oCMenu.level[0].offsetX=0
oCMenu.level[0].offsetY=20
oCMenu.level[0].rows=0
//oCMenu.level[0].arrow="images/arrow.gif"
oCMenu.level[0].arrow=""
oCMenu.level[0].arrowWidth=0
oCMenu.level[0].arrowHeight=0
oCMenu.level[0].align="center"
oCMenu.level[0].filter="progid:DXImageTransform.Microsoft.Fade(duration=0.2)"
<?php
for ($i=1; $i<SUB_CATEGORIES; $i++) {
echo'
oCMenu.level[' . $i . ']=new cm_makeLevel()
oCMenu.level[' . $i . '].width=150 //réglage hauteur largeur case article
oCMenu.level[' . $i . '].height=22
oCMenu.level[' . $i . '].regClass="clLevel1"
oCMenu.level[' . $i . '].overClass="clLevel1over"
oCMenu.level[' . $i . '].borderX=1
oCMenu.level[' . $i . '].borderY=1
oCMenu.level[' . $i . '].align="right"
oCMenu.level[' . $i . '].offsetX=0
oCMenu.level[' . $i . '].offsetY=0
oCMenu.level[' . $i . '].borderClass="clLevel1border"
oCMenu.level[' . $i . '].align="right"
oCMenu.level[' . $i . '].filter="progid:DXImageTransform.Microsoft.Fade(duration=0.2)"
';
} // end for
// ---
function blank_length($text) {
$count = 0;
while(substr($text, 0,12) == " ") {
$text = substr($text, 12);
$count++;
}
return $count;
}
// ---
function print_menu_line($categories, $depth_size,$depth_parentid, $depth) {
$size=0;
for($i=0; $depth_size[$i]!=0; $i++) {
$size++;
}
echo "oCMenu.makeMenu('";
if ($depth == 0) {
echo "top" . '_'.$depth_size[0] . "','','";
} else if ($depth == 1) {
echo "sub" .'_'.$depth_size[0] .'_'. $depth_size[1] . "','top" .'_'. $depth_size[0] . "','";
} else { // $depth < 1
echo "sub";
for ($i=0; $i<$size; $i++) {
echo ($depth_size[$i] != 0) ? '_'.$depth_size[$i] : '_';
}
echo "','sub";
for ($i=0; $i<$size-1; $i++) {
echo ($depth_size[$i] != 0) ? '_'.$depth_size[$i] : '_';
}
echo "','";
}
echo $categories['text'];
if (SHOW_COUNT == 'true') {
$products_in_category = tep_count_products_in_category($categories['id']);
if ($products_in_category > 0) {
echo "<FONT COLOR=\"#c0c0c0\"> (" . $products_in_category . ")</FONT>";
}
}
$cPathNew = "cPath=";
for ($i=0; $i<$size-1; $i++) {
$cPathNew .= ($depth_size[$i] != 0) ? $depth_parentid[$i].'_':'';
}
$cPathNew .= $categories['id'];
echo "','" . tep_href_link(FILENAME_DEFAULT,$cPathNew) . "')\n";
}
// ---
$categories = tep_get_categories('');
//$height.= 2.65*count($categories);
$height.= 0;
$depth=0;
$blank_length;
$depth_size;
$depth_parentid;
for($i=0; $i<count($categories); $i++) { // don't insert 1st entry ("please choose ...")
$blank_length = blank_length($categories[$i]['text']);
if($blank_length == $depth) {
$categories[$i]['depth'] = $depth;
$depth_size[$depth]++;
} else if ($blank_length > $depth) {
$depth++;
$categories[$i]['depth'] = $depth;
$depth_size[$depth]++;
} else if ($blank_length < $depth) {
for ($j=$depth; $j>$blank_length; $j--) {
$depth_size[$j] = 0;
$depth--;
}
$categories[$i]['depth'] = $depth;
$depth_size[$depth]++;
}
$depth_parentid[$categories[$i]['depth']] = $categories[$i]['id'];
// remove blanks
$categories[$i]['text'] = substr($categories[$i]['text'], 12*$blank_length);
print_menu_line($categories[$i], $depth_size,$depth_parentid, $depth);
}
?>
// create menu
oCMenu.construct()
<!-- Copyright 2002 www.dhtmlcentral.com -- modified for PHP and osCommerce by Andreas Kothe - www.oddbyte.de -->
</SCRIPT>
Modifié par kervano (16 Apr 2007 - 15:15)