/** * Save product category relations * * @param Varien_Object $object * @return Mage_Catalog_Model_Resource_Product */ protected function _saveCategories(Varien_Object $object) { //pr($object->getData('category_subjects'));die(); $l_aCategorySubjects = $object->getData('category_subjects'); if (!is_array($l_aCategorySubjects)) { $l_aCategorySubjects = array(); } /** * If category ids data is not declared we haven't do manipulations */ if (!$object->hasCategoryIds()) { return $this; } $categoryIds = $object->getCategoryIds(); $oldCategoryIds = $this->getCategoryIds($object); $object->setIsChangedCategories(false); $insert = array_diff($categoryIds, $oldCategoryIds); $delete = array_diff($oldCategoryIds, $categoryIds); $need_to_be_updated = array_diff($oldCategoryIds, $delete); $write = $this->_getWriteAdapter(); if (!empty($need_to_be_updated)) { foreach ($need_to_be_updated as $categoryId) { if (empty($categoryId)) { continue; } if (isset($l_aCategorySubjects[$categoryId])) { $data = array('subject' => isset($l_aCategorySubjects[$categoryId]) ? $l_aCategorySubjects[$categoryId]['subject'] : null, 'subsubject' => isset($l_aCategorySubjects[$categoryId]) ? $l_aCategorySubjects[$categoryId]['subsubject'] : null); $write->update($this->_productCategoryTable, $data, 'category_id = ' . (int) $categoryId . ' AND product_id = ' . (int) $object->getId()); } } } if (!empty($insert)) { $data = array(); foreach ($insert as $categoryId) { if (empty($categoryId)) { continue; } $data[] = array('category_id' => (int) $categoryId, 'product_id' => (int) $object->getId(), 'position' => 1, 'subject' => isset($l_aCategorySubjects[$categoryId]) ? $l_aCategorySubjects[$categoryId]['subject'] : null, 'subsubject' => isset($l_aCategorySubjects[$categoryId]) ? $l_aCategorySubjects[$categoryId]['subsubject'] : null); } if ($data) { $write->insertMultiple($this->_productCategoryTable, $data); } } if (!empty($delete)) { foreach ($delete as $categoryId) { $where = array('product_id = ?' => (int) $object->getId(), 'category_id = ?' => (int) $categoryId); $write->delete($this->_productCategoryTable, $where); } } if (!empty($insert) || !empty($delete)) { $object->setAffectedCategoryIds(array_merge($insert, $delete)); $object->setIsChangedCategories(true); } return $this; }
/** * Process fblock data before save * * @param Varien_Object $object * @return MF_Flexibleblock_Model_Resource_Fblock */ protected function _beforeSave(Varien_Object $object) { /** * Check if declared category ids in object data. */ if ($object->hasCategoryIds() && is_array($object->getCategoryIds()) && count($object->getCategoryIds())) { $categoryIds = Mage::getResourceSingleton('catalog/category')->verifyIds($object->getCategoryIds()); $object->setData('category_ids', implode(',', $categoryIds)); } //echo '<pre>';print_r($object->getData());exit; return parent::_beforeSave($object); }
protected function _beforeSave(Varien_Object $object) { if ($object->hasCategoryIds()) { $categoryIds = Mage::getResourceSingleton('catalog/category')->verifyIds($object->getCategoryIds()); $object->setCategoryIds($categoryIds); } if (!$object->getSku() && Mage::getStoreConfigFlag('udprod/general/auto_sku')) { $adapter = $this->_getReadAdapter(); $pidSuffix = $adapter->fetchOne($adapter->select()->from($this->getEntityTable(), 'max(entity_id)')); do { $object->setSku($object->getUdropshipVendor() . '-' . ++$pidSuffix); } while (Mage::helper('udropship/catalog')->getPidBySku($object->getSku(), $object->getId())); } $vId = Mage::getSingleton('udropship/session')->getVendorId(); if (!$vId && Mage::app()->getStore()->isAdmin() && Mage::helper('udropship')->isModuleActive('umicrosite') && ($v = Mage::helper('umicrosite')->getAdminhtmlVendor())) { $vId = $v->getId(); } else { $vId = $object->getData('udropship_vendor'); } if (Mage::getStoreConfigFlag('udprod/general/prefix_sku_vid') && $vId && 0 !== strpos($object->getSku(), $vId . '-')) { $object->setSku($vId . '-' . $object->getSku()); } if (Mage::getStoreConfigFlag('udprod/general/unique_vendor_sku') && $vId && !Mage::helper('udropship')->isUdmultiActive()) { $vSkuAttr = Mage::getStoreConfig('udropship/vendor/vendor_sku_attribute'); if ($vSkuAttr && $vSkuAttr != 'sku') { if (!$object->getData($vSkuAttr)) { Mage::throwException('Vendor SKU attribute is empty'); } elseif (Mage::helper('udropship/catalog')->getPidByVendorSku($object->getData($vSkuAttr), $vId, $object->getId())) { Mage::throwException(Mage::helper('udropship')->__('Vendor SKU "%s" is already used', $object->getData($vSkuAttr))); } } } if (Mage::helper('udropship')->hasMageFeature('resource_1.6')) { return Mage_Catalog_Model_Resource_Abstract::_beforeSave($object); } else { return Mage_Catalog_Model_Resource_Eav_Mysql4_Abstract::_beforeSave($object); } }
/** * Save product category relations * * @param Varien_Object $object * @return Mage_Catalog_Model_Resource_Product */ protected function _saveCategories(Varien_Object $object) { /** * If category ids data is not declared we haven't do manipulations */ if (!$object->hasCategoryIds()) { return $this; } $categoryIds = $object->getCategoryIds(); $oldCategoryIds = $this->getCategoryIds($object); $object->setIsChangedCategories(false); $insert = array_diff($categoryIds, $oldCategoryIds); $delete = array_diff($oldCategoryIds, $categoryIds); $write = $this->_getWriteAdapter(); if (!empty($insert)) { $data = array(); foreach ($insert as $categoryId) { if (empty($categoryId)) { continue; } $data[] = array('category_id' => (int) $categoryId, 'product_id' => (int) $object->getId(), 'position' => 1); } if ($data) { $write->insertMultiple($this->_productCategoryTable, $data); } } if (!empty($delete)) { foreach ($delete as $categoryId) { $where = array('product_id = ?' => (int) $object->getId(), 'category_id = ?' => (int) $categoryId); $write->delete($this->_productCategoryTable, $where); } } if (!empty($insert) || !empty($delete)) { $object->setAffectedCategoryIds(array_merge($insert, $delete)); $object->setIsChangedCategories(true); } return $this; }