Jump to content
Sign in to follow this  
Moonwalker

[РЕШЕНО] Слетает главная категория при копировании карточки товара

Recommended Posts

Всем привет.

Ситуация следующая: при копировании карточки товара во вновь созданной карточке почему-то слетает главная категория. При этом слетает не полностью, а на несколько уровней вверх (если быть точным, то до 1-го уровня).

Например: у товара главная категория "Категория1-->Подкатегория2-->Подкатегория3". После копирования карточки у новой главной будет стоять "Категория1".

Есть возможность как-то пофиксить эту проблему? А то напрягает с определенного момента ))

оцСторе 1.5.5.1.1.

Share this post


Link to post
Share on other sites

Хотел бы поднять данную тему очень актуально сейчас при заполнение товара в магазин.

Share this post


Link to post
Share on other sites

Я так посмотрел за это отвечает /public_html/admin/model/catalog/product.php
 

	public function copyProduct($product_id) {
		$query = $this->db->query("SELECT DISTINCT * FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "'");
		
		if ($query->num_rows) {
			$data = array();
			
			$data = $query->row;
			
			$data['sku'] = '';
			$data['upc'] = '';
			$data['viewed'] = '0';
			$data['keyword'] = '';
			$data['status'] = '0';
						
			$data = array_merge($data, array('product_attribute' => $this->getProductAttributes($product_id)));
			$data = array_merge($data, array('product_description' => $this->getProductDescriptions($product_id)));			
			$data = array_merge($data, array('product_discount' => $this->getProductDiscounts($product_id)));
			$data = array_merge($data, array('product_filter' => $this->getProductFilters($product_id)));
			$data = array_merge($data, array('product_image' => $this->getProductImages($product_id)));		
			$data = array_merge($data, array('product_option' => $this->getProductOptions($product_id)));
			$data = array_merge($data, array('product_related' => $this->getProductRelated($product_id)));
			$data = array_merge($data, array('product_reward' => $this->getProductRewards($product_id)));
			$data = array_merge($data, array('product_special' => $this->getProductSpecials($product_id)));
			$data = array_merge($data, array('product_category' => $this->getProductCategories($product_id)));
			$data = array_merge($data, array('product_download' => $this->getProductDownloads($product_id)));
			$data = array_merge($data, array('product_layout' => $this->getProductLayouts($product_id)));
			$data = array_merge($data, array('product_store' => $this->getProductStores($product_id)));
			
			$this->addProduct($data);
		}
	} 

 Далее есть обработка данной строки.

Вопрос почему данная функция запрашивает после копирования ГЛАВНУЮ ДИРЕКТОРИЮ! А не оставляет все как есть?

	public function getProductCategories($product_id) {
		$product_category_data = array();
		
		$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_to_category WHERE product_id = '" . (int)$product_id . "'");
		
		foreach ($query->rows as $result) {
			$product_category_data[] = $result['category_id'];
		}

		return $product_category_data;
	}

Share this post


Link to post
Share on other sites

Методом тыка понял что там есть еще одна функция которая отвечает как раз за "Главную категорию"

 

В этом файле /public_html/admin/model/catalog/product.php

 

Нужно добавить вот эту строку!

$data = array_merge($data, array('main_category_id' => $this->getProductMainCategoryId($product_id)));

 

после вот этой (309 строка)

$data = array_merge($data, array('product_special' => $this->getProductSpecials($product_id)));

 

У кого работает напишите, сюда чо как!

Share this post


Link to post
Share on other sites

Вроде работает! Надо будет потестить еще, но уже сейчас не могу выразить все слова благодарности ))) Особенно от партнера, который и занимается ассортиментом ))

Share this post


Link to post
Share on other sites

Вроде работает! Надо будет потестить еще, но уже сейчас не могу выразить все слова благодарности ))) Особенно от партнера, который и занимается ассортиментом ))

 

Тогда возможно вы имеете и такую проблему! https://opencartforum.com/topic/38545-%D1%80%D0%B5%D1%88%D0%B5%D0%BD%D0%BE%D0%BD%D0%B5-%D0%BF%D1%80%D0%B0%D0%B2%D0%B8%D0%BB%D1%8C%D0%BD%D0%BE%D0%B5-%D1%84%D0%BE%D1%80%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5-%D1%81%D0%BF%D0%B8%D1%81%D0%BA%D0%B0-%D0%BA%D0%B0%D1%82%D0%B5/

Share this post


Link to post
Share on other sites

Не, с этим проблемы нет. Все строго по алфавиту. Но спасибо, что делитесь ))

Share this post


Link to post
Share on other sites

Не, с этим проблемы нет. Все строго по алфавиту. Но спасибо, что делитесь ))

Исправь шапку [РЕШЕНО]

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
You are posting as a guest. If you have an account, please sign in.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.

×

Important Information

On our site, cookies are used and personal data is processed to improve the user interface. To find out what and what personal data we are processing, please go to the link. If you click "I agree," it means that you understand and accept all the conditions specified in this Privacy Notice.