Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

Помогите наладить JS, объединить


Recommended Posts

Продавец модуля проигнорил... переделываю его сам.

 

Сначала купил модуль категории во вкладках, переверстал его под себя, добавил имеющийся у меня функционал кнопочек и поле изменения кол-ва товара, потом купил модуль вывод опций в рекомедуемых и интегрировал его в предыдущий модуль. Опции вывел, они добавлялись в корзину, но через раз (к одному товару 1 опция добавится, а потом глушняк - не добавляется)! К тому же там у меня конфликт скриптов (не совместимы классы onclick="....)

 

В общем, на данный момент у меня: не добавляется опция в корзину и не добавляется выбранное кл-во товара...  Пожалуйста, помогите решить проблему, очень нужно!

 

randprod.tpl (шаблон модуля - категории во вкладках) В нём же конфликтующие скрипты для кнопок и добавления опций.

<div id="tabs" class="htabs">
<?php foreach ($categories as $category) { ?>
<a href="#catagory<?php echo $module.$category['category_id']; ?>" class="selected"><?php echo $category['name']; ?></a>
<?php } ?>
</div>

<?php ?>

<?php foreach ($categories as $category) { 
    $products = $category['products'];
?>
<div id="catagory<?php echo $module.$category['category_id']; ?>" class="tab-content" >

<div class="box-product">
<?php foreach ($products as $product) { ?>
<div class="gutter-sizer">


<div class="image"><img src="<?php echo $product['thumb']; ?>" alt="<?php echo $product['name']; ?>" /></div>
<div class="name"><a href="<?php echo $product['href']; ?>"><?php echo $product['name']; ?></a></div>

<?php if ($product['price']) { ?>
<div class="price">
<?php if (!$product['special']) { ?>
<?php echo $product['price']; ?>
<?php } else { ?>
<span class="price-old"><?php echo $product['price']; ?></span> <span class="price-new"><?php echo $product['special']; ?></span>
<?php } ?>
</div>
<?php } ?>
<?php if ($product['rating']) { ?>
<div class="rating"><img src="catalog/view/theme/default/image/stars-<?php echo $product['rating']; ?>.png" alt="<?php echo $product['reviews']; ?>" /></div>
<?php } ?>

    
<div class="buton_container">
 

<?php if ($product['options']) { ?>
<div class="options" id="option_<?php echo $product['product_id']; ?>">
							<br />
							<?php foreach ($product['options'] as $option) { ?>
							<?php if ($option['type'] == 'select') { ?>
							<div id="option-<?php echo $option['product_option_id']; ?>" class="option">
							  <?php if ($option['required']) { ?>
							  <span class="required">*</span>
							  <?php } ?>
							  <b><?php echo $option['name']; ?>:</b><br />
							  <select name="option[<?php echo $option['product_option_id']; ?>]">
								<option value=""><?php echo $text_select; ?></option>
								<?php foreach ($option['option_value'] as $option_value) { ?>
								<option value="<?php echo $option_value['product_option_value_id']; ?>"><?php echo $option_value['name']; ?>
								<?php if ($option_value['price']) { ?>
								(<?php echo $option_value['price_prefix']; ?><?php echo $option_value['price']; ?>)
								<?php } ?>
								</option>
								<?php } ?>
							  </select>
							</div>
							<br />
							<?php } ?>
							
							<?php } ?>

						  </div>
<?php } ?>	  


<input type="button" value="-" class="minus">
<span class="buton_input"><input type="text" maxlength="3" value="1" size="4" class="item-<?php echo $product['product_id']; ?> kolvo" /></span>
<input type="button" value="+" class="plus">


<div class="cart">
<input type="button" value="добавить к заказу" onclick="add_bc('<?php echo $product['product_id']; ?>');" class="button" />
</div>

</div>
</div>
<?php } ?>
</div></div>


<?php } ?>
<script type="text/javascript">
				function add_bc(product_id) {
					data = $('#option_'+product_id+' input[type=\'text\'], #option_'+product_id+' input[type=\'radio\']:checked, #option_'+product_id+' input[type=\'checkbox\']:checked, #option_'+product_id+' select, #option_'+product_id+' textarea');
					$.ajax({
							url: 'index.php?route=checkout/cart/add',
							type: 'post',
							data: data.serialize() + '&product_id=' + product_id,
							dataType: 'json',
							beforeSend: function(){
							},
								success: function(json) {
									$('.success, .warning, .attention, information, .error').remove();
									if (json['error']) {
										if (json['error']['warning']) {
											$('#notification').html('<div class="warning" style="display: none;">' + json['error']['warning'] + '<img src="catalog/view/theme/default/image/close.png" alt="" class="close" /></div>');
										
											$('.warning').fadeIn('slow');
										}
										
										for (i in json['error']) {
											$('#option-' + i).after('<span class="error">' + json['error'][i] + '</span>');
										}
									}	 
												
									if (json['success']) {
										$('#notification').html('<div class="success" style="display: none;">' + json['success'] + '<img src="catalog/view/theme/default/image/close.png" alt="" class="close" /></div>');
					
										$('.success').fadeIn('slow');
					
										$('#cart-total').html(json['total']);
				
										$('html, body').animate({ scrollTop: 0 }, 'slow'); 
									}	
								}
						});
				}
				</script>			
		<script type="text/javascript"><!--
$('.plus').click(function() {

              var text1 = parseInt( $('.buton_input:first', $(this).parent()).children('input').val()) + 1;
              $('.buton_input:first', $(this).parent()).children('input').val(text1);   
              
              var text1 = parseInt( $('.az_input2:first', $(this).parent()).children('input').val()) + 1;
              $('.input2:first', $(this).parent()).children('input').val(text1);   
          
        }); 
        
        $('.minus').click(function(){
    
    
        var text = parseInt( $('.buton_input:first', $(this).parent()).children('input').val()) - 1;
            if ( parseInt(text) >= 0 ){
          $('.buton_input:first', $(this).parent()).children('input').val(text);   
            }
            
              var text = parseInt( $('.az_input2:first', $(this).parent()).children('input').val()) - 1;
            if ( parseInt(text) >= 0 ){
          $('.input2:first', $(this).parent()).children('input').val(text);   
            }
        });

function addQtyToCart(product_id) {
  var qty = $('.item-' + product_id).val();
  if ((parseFloat(qty) != parseInt(qty)) || isNaN(qty)) {
		qty = 1;
  }
  addToCart(product_id, qty);
}


$('.colorbox').colorbox({
	overlayClose: true,
	opacity: 0.5
});
//--></script> 

Мой common.js

$(document).ready(function() {
	/* Search */
	$('.button-search').bind('click', function() {
		url = $('base').attr('href') + 'index.php?route=product/search';
				 
		var filter_name = $('input[name=\'filter_name\']').attr('value');
		
		if (filter_name) {
			url += '&filter_name=' + encodeURIComponent(filter_name);
		}
		
		location = url;
	});
	
	$('#header input[name=\'filter_name\']').bind('keydown', function(e) {
		if (e.keyCode == 13) {
			url = $('base').attr('href') + 'index.php?route=product/search';
			 
			var filter_name = $('input[name=\'filter_name\']').attr('value');
			
			if (filter_name) {
				url += '&filter_name=' + encodeURIComponent(filter_name);
			}
			
			location = url;
		}
	});
	
	/* Ajax Cart */
	$('#cart > .heading a').live('click', function() {
		$('#cart').addClass('active');
		
		$('#cart').load('index.php?route=module/cart #cart > *');
		
		$('#cart').live('mouseleave', function() {
			$(this).removeClass('active');
		});
	});
	
	/* Mega Menu */
	$('#menu ul > li > a + div').each(function(index, element) {
		// IE6 & IE7 Fixes
		if ($.browser.msie && ($.browser.version == 7 || $.browser.version == 6)) {
			var category = $(element).find('a');
			var columns = $(element).find('ul').length;
			
			$(element).css('width', (columns * 143) + 'px');
			$(element).find('ul').css('float', 'left');
		}		
		
		var menu = $('#menu').offset();
		var dropdown = $(this).parent().offset();
		
		i = (dropdown.left + $(this).outerWidth()) - (menu.left + $('#menu').outerWidth());
		
		if (i > 0) {
			$(this).css('margin-left', '-' + (i + 5) + 'px');
		}
	});

	// IE6 & IE7 Fixes
	if ($.browser.msie) {
		if ($.browser.version <= 6) {
			$('#column-left + #column-right + #content, #column-left + #content').css('margin-left', '195px');
			
			$('#column-right + #content').css('margin-right', '195px');
		
			$('.box-category ul li a.active + ul').css('display', 'block');	
		}
		
		if ($.browser.version <= 7) {
			$('#menu > ul > li').bind('mouseover', function() {
				$(this).addClass('active');
			});
				
			$('#menu > ul > li').bind('mouseout', function() {
				$(this).removeClass('active');
			});	
		}
	}
	
	$('.success img, .warning img, .attention img, .information img').live('click', function() {
		$(this).parent().fadeOut('slow', function() {
			$(this).remove();
		});
	});	
});

function getURLVar(urlVarName) {
	var urlHalves = String(document.location).toLowerCase().split('?');
	var urlVarValue = '';
	
	if (urlHalves[1]) {
		var urlVars = urlHalves[1].split('&');

		for (var i = 0; i <= (urlVars.length); i++) {
			if (urlVars[i]) {
				var urlVarPair = urlVars[i].split('=');
				
				if (urlVarPair[0] && urlVarPair[0] == urlVarName.toLowerCase()) {
					urlVarValue = urlVarPair[1];
				}
			}
		}
	}
	
	return urlVarValue;
} 

function addToCart(product_id, quantity) {
	quantity = typeof(quantity) != 'undefined' ? quantity : 1;

	$.ajax({
		url: 'index.php?route=checkout/cart/add',
		type: 'post',
		data: 'product_id=' + product_id + '&quantity=' + quantity,
		dataType: 'json',
		success: function(json) {
			$('.success, .warning, .attention, .information, .error').remove();
			
			if (json['redirect']) {
				location = json['redirect'];
			}
			
			if (json['success']) {
				$('#notification').html('<div class="success" style="display: none;">' + json['success'] + '<img src="catalog/view/theme/default/image/close.png" alt="" class="close" /></div>');
				
				$('.success').fadeIn('slow');
				
				$('#cart-total').html(json['total']);
				
			}	
		}
	});
}
function addToWishList(product_id) {
	$.ajax({
		url: 'index.php?route=account/wishlist/add',
		type: 'post',
		data: 'product_id=' + product_id,
		dataType: 'json',
		success: function(json) {
			$('.success, .warning, .attention, .information').remove();
						
			if (json['success']) {
				$('#notification').html('<div class="success" style="display: none;">' + json['success'] + '<img src="catalog/view/theme/default/image/close.png" alt="" class="close" /></div>');
				
				$('.success').fadeIn('slow');
				
				$('#wishlist-total').html(json['total']);
				
			}	
		}
	});
}

function addToCompare(product_id) { 
	$.ajax({
		url: 'index.php?route=product/compare/add',
		type: 'post',
		data: 'product_id=' + product_id,
		dataType: 'json',
		success: function(json) {
			$('.success, .warning, .attention, .information').remove();
						
			if (json['success']) {
				$('#notification').html('<div class="success" style="display: none;">' + json['success'] + '<img src="catalog/view/theme/default/image/close.png" alt="" class="close" /></div>');
				
				$('.success').fadeIn('slow');
				
				$('#compare-total').html(json['total']);
				
			}
		}
	});
}

Контроллекр модуля категории во вкладках

 

class ControllerModulerandprod extends Controller {
protected $category_id = 0;
protected $path = array();

protected function index($setting) {
$this->language->load('module/randprod');
static $module = 0;
static $inc_js = 0;
$this->data['heading_title'] = $this->language->get('heading_title');
$this->data['button_cart'] = $this->language->get('button_cart');
$this->data['text_select'] = $this->language->get('text_select');

$this->load->model('tool/image');
$this->load->model('catalog/category');
$this->load->model('catalog/product');
$categories = $this->getCategoriesBySort($setting['categories']);

$this->data['categories'] = array();


if (isset($setting['limit_carousel']) && $setting['limit_carousel']) {
$this->data['limit_carousel'] = $setting['limit_carousel'];
} else {
$this->data['limit_carousel'] = 5;
}

if (isset($setting['wrap_carousel']) && $setting['wrap_carousel']) {
$this->data['wrap_carousel'] = $setting['wrap_carousel'];
} else {
$this->data['wrap_carousel'] = false;
}

if (isset($setting['auto_carousel']) && $setting['auto_carousel']) {
$this->data['auto_carousel'] = $setting['auto_carousel'];
} else {
$this->data['auto_carousel'] = false;
}

foreach ($categories as $category) {

$category_info = $this->model_catalog_category->getCategory($category);
if (!$category_info) continue;
$this->data['categories'][$category]['name'] = $category_info['name'];
$this->data['categories'][$category]['category_id'] = $category;
$this->data['categories'][$category]['href'] = $this->url->link('product/category', 'path=' . $category);
$sort = false;
$order = false;
$products = array();
if (isset($setting['sort']) && $setting['sort']) {
if ($setting['sort']=="bestseller") {
$this->load->model('module/randprod');
$results = $this->model_module_randprod->getBestSellerProductsByCategoryId($setting['limit'],$category);
} else {
$s = explode("-",$setting['sort']);
$sort = $s[0];
$order = $s[1];

$data = array(
'filter_category_id' => $category,
'start' => 0,
'limit' => $setting['limit'],
'sort' => $sort,
'order' => $order
);
$results = $this->model_catalog_product->getProducts($data);
}
}
foreach ($results as $result) {
if ($result['image']) {
$image = $this->model_tool_image->resize($result['image'], $setting['image_width'], $setting['image_height']);
} else {
$image = false;
}

if (($this->config->get('config_customer_price') && $this->customer->isLogged()) || !$this->config->get('config_customer_price')) {
$price = $this->currency->format($this->tax->calculate($result['price'], $result['tax_class_id'], $this->config->get('config_tax')));
} else {
$price = false;
}

if ((float)$result['special']) {
$special = $this->currency->format($this->tax->calculate($result['special'], $result['tax_class_id'], $this->config->get('config_tax')));
} else {
$special = false;
}

if ($this->config->get('config_review_status')) {
$rating = $result['rating'];
} else {
$rating = false;
}
$product_options = array();

foreach ($this->model_catalog_product->getProductOptions($result['product_id']) as $option) {
if ($option['type'] == 'select' || $option['type'] == 'radio' || $option['type'] == 'checkbox' || $option['type'] == 'image') {
$option_value_data = array();

foreach ($option['option_value'] as $option_value) {
if (!$option_value['subtract'] || ($option_value['quantity'] > 0)) {
if ((($this->config->get('config_customer_price') && $this->customer->isLogged()) || !$this->config->get('config_customer_price')) && (float)$option_value['price']) {
$price = $this->currency->format($this->tax->calculate($option_value['price'], $result['tax_class_id'], $this->config->get('config_tax')));
} else {
$price = false;
}

$option_value_data[] = array(
'product_option_value_id' => $option_value['product_option_value_id'],
'option_value_id' => $option_value['option_value_id'],
'name' => $option_value['name'],
'image' => $this->model_tool_image->resize($option_value['image'], 50, 50),
'price' => $price,
'price_prefix' => $option_value['price_prefix']
);
}
}

$product_options[] = array(
'product_option_id' => $option['product_option_id'],
'option_id' => $option['option_id'],
'name' => $option['name'],
'type' => $option['type'],
'option_value' => $option_value_data,
'required' => $option['required']
);
} elseif ($option['type'] == 'text' || $option['type'] == 'textarea' || $option['type'] == 'file' || $option['type'] == 'date' || $option['type'] == 'datetime' || $option['type'] == 'time') {
$product_options[] = array(
'product_option_id' => $option['product_option_id'],
'option_id' => $option['option_id'],
'name' => $option['name'],
'type' => $option['type'],
'option_value' => $option['option_value'],
'required' => $option['required']
);
}
}

$products[] = array(

'product_id' => $result['product_id'],
'thumb' => $image,
'name' => $result['name'],
'options' => $product_options,

'price' => $price,
'special' => $special,
'rating' => $rating,
'reviews' => sprintf($this->language->get('text_reviews'), (int)$result['reviews']),
'href' => $this->url->link('product/product', 'product_id=' . $result['product_id'])
);


}

//foreach products
$this->data['categories'][$category]['products'] = $products;
}//foreach categories


$this->data['module'] = $module++;

if (isset($setting['carousel']) && $setting['carousel']==1 && $inc_js==0) {
$inc_js=1;
$this->document->addScript('catalog/view/javascript/jquery/jquery.jcarousel.min.js');
$this->document->addStyle('catalog/view/theme/' . $this->config->get('config_template') . '/stylesheet/carousel.css');
}

if (isset($setting['carousel']) && $setting['carousel']==1) {
if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/module/randprod_carousel.tpl')) {
$this->template = $this->config->get('config_template') . '/template/module/randprod_carousel.tpl';
} else {
$this->template = 'default/template/module/randprod_carousel.tpl';
}
} else {
if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/module/randprod.tpl')) {
$this->template = $this->config->get('config_template') . '/template/module/randprod.tpl';
} else {
$this->template = 'default/template/module/randprod.tpl';
}
}


$this->render();
}

private function getCategoriesBySort($categories){

$data = array();
if ($categories) {
$query = $this->db->query("SELECT category_id FROM " . DB_PREFIX . "category c WHERE category_id in (".implode(",",$categories).") ORDER BY c.sort_order");

foreach ($query->rows as $row) {
$data[]=$row['category_id'];
}
}
return $data;
}

}

?>

Надіслати
Поділитися на інших сайтах


Створіть аккаунт або увійдіть для коментування

Ви повинні бути користувачем, щоб залишити коментар

Створити обліковий запис

Зареєструйтеся для отримання облікового запису. Це просто!

Зареєструвати аккаунт

Вхід

Уже зареєстровані? Увійдіть тут.

Вхід зараз
  • Зараз на сторінці   0 користувачів

    • Ні користувачів, які переглядиють цю сторінку
×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.