/** * Check if semilar event exist before start saving data * * @param AbstractModel $object * @return $this */ protected function _beforeSave(AbstractModel $object) { /** * Check if event already exist and merge previous data */ if (!$object->getId()) { $select = $this->_getReadAdapter()->select()->from($this->getMainTable())->where('type=?', $object->getType())->where('entity=?', $object->getEntity()); if ($object->hasEntityPk()) { $select->where('entity_pk=?', $object->getEntityPk()); } $data = $this->_getWriteAdapter()->fetchRow($select); if ($data) { $object->mergePreviousData($data); } } $object->cleanNewData(); return parent::_beforeSave($object); }
/** * Saves reference terms for a thesaurus. Reference term are used by expansions thesaurus only. * * @param \Magento\Framework\Model\AbstractModel $object Thesaurus to save * @param array $referenceTerms Thesaurus reference terms * * @return $this */ private function saveReferenceTerms(\Magento\Framework\Model\AbstractModel $object, $referenceTerms) { if ($object->getType() === ThesaurusInterface::TYPE_EXPANSION) { $this->getConnection()->insertOnDuplicate($this->getTable(ThesaurusInterface::REFERENCE_TABLE_NAME), $referenceTerms, array_keys(current($referenceTerms))); } return $this; }
/** * Save value prices * * @param \Magento\Framework\Model\AbstractModel $object * @return $this * @SuppressWarnings(PHPMD.CyclomaticComplexity) * @SuppressWarnings(PHPMD.ExcessiveMethodLength) */ protected function _saveValuePrices(\Magento\Framework\Model\AbstractModel $object) { $priceTable = $this->getTable('catalog_product_option_price'); $connection = $this->getConnection(); /* * Better to check param 'price' and 'price_type' for saving. * If there is not price skip saving price */ if ($object->getType() == \Magento\Catalog\Model\Product\Option::OPTION_TYPE_FIELD || $object->getType() == \Magento\Catalog\Model\Product\Option::OPTION_TYPE_AREA || $object->getType() == \Magento\Catalog\Model\Product\Option::OPTION_TYPE_FILE || $object->getType() == \Magento\Catalog\Model\Product\Option::OPTION_TYPE_DATE || $object->getType() == \Magento\Catalog\Model\Product\Option::OPTION_TYPE_DATE_TIME || $object->getType() == \Magento\Catalog\Model\Product\Option::OPTION_TYPE_TIME) { //save for store_id = 0 if (!$object->getData('scope', 'price')) { $statement = $connection->select()->from($priceTable, 'option_id')->where('option_id = ?', $object->getId())->where('store_id = ?', \Magento\Store\Model\Store::DEFAULT_STORE_ID); $optionId = $connection->fetchOne($statement); if ($optionId) { if ($object->getStoreId() == '0') { $data = $this->_prepareDataForTable(new \Magento\Framework\DataObject(['price' => $object->getPrice(), 'price_type' => $object->getPriceType()]), $priceTable); $connection->update($priceTable, $data, ['option_id = ?' => $object->getId(), 'store_id = ?' => \Magento\Store\Model\Store::DEFAULT_STORE_ID]); } } else { $data = $this->_prepareDataForTable(new \Magento\Framework\DataObject(['option_id' => $object->getId(), 'store_id' => \Magento\Store\Model\Store::DEFAULT_STORE_ID, 'price' => $object->getPrice(), 'price_type' => $object->getPriceType()]), $priceTable); $connection->insert($priceTable, $data); } } $scope = (int) $this->_config->getValue(\Magento\Store\Model\Store::XML_PATH_PRICE_SCOPE, \Magento\Store\Model\ScopeInterface::SCOPE_STORE); if ($object->getStoreId() != '0' && $scope == \Magento\Store\Model\Store::PRICE_SCOPE_WEBSITE) { $baseCurrency = $this->_config->getValue(\Magento\Directory\Model\Currency::XML_PATH_CURRENCY_BASE, 'default'); $storeIds = $this->_storeManager->getStore($object->getStoreId())->getWebsite()->getStoreIds(); if (is_array($storeIds)) { foreach ($storeIds as $storeId) { if ($object->getPriceType() == 'fixed') { $storeCurrency = $this->_storeManager->getStore($storeId)->getBaseCurrencyCode(); $rate = $this->_currencyFactory->create()->load($baseCurrency)->getRate($storeCurrency); if (!$rate) { $rate = 1; } $newPrice = $object->getPrice() * $rate; } else { $newPrice = $object->getPrice(); } $statement = $connection->select()->from($priceTable)->where('option_id = ?', $object->getId())->where('store_id = ?', $storeId); if ($connection->fetchOne($statement)) { $data = $this->_prepareDataForTable(new \Magento\Framework\DataObject(['price' => $newPrice, 'price_type' => $object->getPriceType()]), $priceTable); $connection->update($priceTable, $data, ['option_id = ?' => $object->getId(), 'store_id = ?' => $storeId]); } else { $data = $this->_prepareDataForTable(new \Magento\Framework\DataObject(['option_id' => $object->getId(), 'store_id' => $storeId, 'price' => $newPrice, 'price_type' => $object->getPriceType()]), $priceTable); $connection->insert($priceTable, $data); } } } } elseif ($scope == \Magento\Store\Model\Store::PRICE_SCOPE_WEBSITE && $object->getData('scope', 'price')) { $connection->delete($priceTable, ['option_id = ?' => $object->getId(), 'store_id = ?' => $object->getStoreId()]); } } return $this; }