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

Вывод атрибутов из шаблона


Evgenka

Recommended Posts

Добрый день.

Извиняюсь, если создал тему не в том разделе, но, к сожалению, для ocstore 1.5.5.1 нет уже раздела.

Очень надеюсь на помощь, или совет. Проблема в следующем:

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

Но у некоторых товаров уже присутствуют атрибуты и вот тут заключается сама проблема. По возможностям данного дополнения, оно все равно при выборе нужного шаблона атрибутов загружает их все, не смотря на то, что некоторые из данных атрибутов уже имеются у данного товара. Вот собственно и бьюсь за то, что бы сравнить уже имеющиеся у товара атрибуты и загрузить из шаблона только недостающие.

Что сделал:

при нажатии кнопки "Загрузить" передаю в функцию loadatts() product_id редактируемого товара.

Далее в этой же функции получаем уже имеющиеся у товара атрибуты

          $this->load->model('catalog/product');
		  $product_attributes = $this->model_catalog_product->getProductAttributes($this->request->get['product_id']);

Атрибуты шаблона, которые необходимо загрузить, получаются следующим образом:

            $query = $this->db->query("SELECT atts FROM " . DB_PREFIX . "category WHERE category_id = '" . (int)$this->request->get['catid'] . "'");
            $atts = unserialize($query->row['atts']);

И далее идет перебор массива атрибутов с добавлением их в карточке товара:

              $attribute_row = 0;
              foreach ($atts as $product_attribute) {
                echo '<tbody id="attribute-row' . $attribute_row. '" style="background:turquoise;"><tr>
                      <td class="left">
                        <input type="text" name="product_attribute[' . $attribute_row. '][name]" value="' . $product_attribute['name']. '" />
                        <input type="hidden" name="product_attribute[' . $attribute_row. '][attribute_id]" value="' . $product_attribute['attribute_id']. '" />
                      </td> <td class="left"> <br />';
                foreach ($languages as $language) {
                  echo ' <textarea name="product_attribute[' . $attribute_row. '][product_attribute_description][' . $language['language_id']. '][text]" cols="40" rows="5">' ;
                  if ( isset($product_attribute['product_attribute_description'][$language['language_id']]) )
                    echo  $product_attribute['product_attribute_description'][$language['language_id']]['text'];
                  else
                    echo '';
                  echo '</textarea> <img src="view/image/flags/' . $language['image']. '" title="' . $language['name']. '" align="top" /><br /> ';
                }
                echo '</td> <td class="left">
                      <a onclick="$(\'#attribute-row' . $attribute_row. '\').remove()" class="button">'
                      . $this->data['button_remove'] .
                      '</a></td>
                      </tr> </tbody>';
                $attribute_row++;
              }

 

Собственно что имеем:

два массива атрибутов $atts (атрибуты из шаблона для данной категории товаров) и $product_attributes (атрибуты, которые уже присутствуют у данного товара).

Никак не могу дописать условие, что бы в цикле при переборе атрибутов $atts сравнивалось значение attribute_id с уже имеющимся attribute_id у массива $product_attributes и соответственно при их совпадении атрибут не добавлялся, не создавая дубль.

Буду благодарен за любой совет.

Спасибо.

 

Змінено користувачем Evgenka
Надіслати
Поділитися на інших сайтах


Не верно мыслите

проще не пребирать/искать
проще удалить и вставить
Т.е.
при вставке
$('#attr_idNNNN').remove()
$('#block').append('<span id="attr_idNNNN">')
 

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

Пошел другим путем.

Сравнил два массива и удалил все совпадения по attribute_id. Ну и далее перебирается уже массив, в котором только уникальные attribute_id

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


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

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

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

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

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

Вхід

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

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

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

×
×
  • Створити...

Important Information

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