Example #1
0
 /**
  * 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;
 }
Example #2
0
 /**
  * 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);
 }
Example #3
0
 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;
 }