Version Notes
- Improvement of product mapping
- Improvement of product description
- Added displaying icecat names on product listing/shopping cart
- Added all ICEcat data available as variables on product detail page
- Fixed issue with Yes/No indication
- Fixed image displaying on product listing/shopping cart
Download this release
Release Info
| Developer | IceShop |
| Extension | IcecatLive |
| Version | 1.1.0 |
| Comparing to | |
| See all releases | |
Code changes from version 1.0.0 to 1.1.0
- app/code/local/Bintime/Icecatimport/Helper/Catalog/Image.php +2 -2
- app/code/local/Bintime/Icecatimport/Helper/Image.php +3 -0
- app/code/local/Bintime/Icecatimport/Helper/Output.php +23 -1
- app/code/local/Bintime/Icecatimport/Model/Import.php +74 -41
- app/code/local/Bintime/Icecatimport/Model/Observer.php +1 -0
- app/code/local/Bintime/Icecatimport/etc/config.xml +1 -1
- package.xml +10 -7
app/code/local/Bintime/Icecatimport/Helper/Catalog/Image.php
CHANGED
|
@@ -21,8 +21,8 @@ class Bintime_Icecatimport_Helper_Catalog_Image extends Mage_Catalog_Helper_Imag
|
|
| 21 |
$imageFile = mage::getsingleton('icecatimport/import')->getLowPicUrl();
|
| 22 |
}
|
| 23 |
if ($attributeName == 'thumbnail' && $imageFile == null ) {
|
| 24 |
-
|
| 25 |
-
|
| 26 |
}
|
| 27 |
|
| 28 |
if ($attributeName == 'small_image' && $imageFile == null) {
|
| 21 |
$imageFile = mage::getsingleton('icecatimport/import')->getLowPicUrl();
|
| 22 |
}
|
| 23 |
if ($attributeName == 'thumbnail' && $imageFile == null ) {
|
| 24 |
+
// $imageFile = $product->getData($attributeName);
|
| 25 |
+
$imageFile = Mage::helper('icecatimport/image')->getImage($product);
|
| 26 |
}
|
| 27 |
|
| 28 |
if ($attributeName == 'small_image' && $imageFile == null) {
|
app/code/local/Bintime/Icecatimport/Helper/Image.php
CHANGED
|
@@ -13,6 +13,9 @@ class Bintime_Icecatimport_Helper_Image extends Mage_Core_Helper_Abstract
|
|
| 13 |
*/
|
| 14 |
|
| 15 |
public function getImage($_product) {
|
|
|
|
|
|
|
|
|
|
| 16 |
$sku = $_product->getData(Mage::getStoreConfig('icecat_root/icecat/sku_field'));
|
| 17 |
|
| 18 |
$manufacturerId = $_product->getData(Mage::getStoreConfig('icecat_root/icecat/manufacturer'));
|
| 13 |
*/
|
| 14 |
|
| 15 |
public function getImage($_product) {
|
| 16 |
+
|
| 17 |
+
$_product = $_product->load($_product->getId());
|
| 18 |
+
|
| 19 |
$sku = $_product->getData(Mage::getStoreConfig('icecat_root/icecat/sku_field'));
|
| 20 |
|
| 21 |
$manufacturerId = $_product->getData(Mage::getStoreConfig('icecat_root/icecat/manufacturer'));
|
app/code/local/Bintime/Icecatimport/Helper/Output.php
CHANGED
|
@@ -49,7 +49,7 @@ class Bintime_Icecatimport_Helper_Output extends Mage_Catalog_Helper_Output
|
|
| 49 |
{
|
| 50 |
|
| 51 |
//if we on product page then mage::registry('product' exist
|
| 52 |
-
if ($product->getId() == $this->iceCatModel->entityId && $name = $this->iceCatModel->getProductName()) {
|
| 53 |
return $name;
|
| 54 |
}
|
| 55 |
|
|
@@ -75,5 +75,27 @@ class Bintime_Icecatimport_Helper_Output extends Mage_Catalog_Helper_Output
|
|
| 75 |
else return parent::productAttribute($product, $attributeHtml, $attributeName);
|
| 76 |
}
|
| 77 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 78 |
}
|
| 79 |
?>
|
| 49 |
{
|
| 50 |
|
| 51 |
//if we on product page then mage::registry('product' exist
|
| 52 |
+
if ($product->getId() == $this->iceCatModel->entityId && $name = $product->getData('brand_name') . ' ' . $this->iceCatModel->getProductName()) {
|
| 53 |
return $name;
|
| 54 |
}
|
| 55 |
|
| 75 |
else return parent::productAttribute($product, $attributeHtml, $attributeName);
|
| 76 |
}
|
| 77 |
|
| 78 |
+
public function getWarrantyInfo(){
|
| 79 |
+
return $this->iceCatModel->getWarrantyInfo();
|
| 80 |
+
}
|
| 81 |
+
public function getShortSummaryDescription(){
|
| 82 |
+
return $this->iceCatModel->getShortSummaryDescription();
|
| 83 |
+
}
|
| 84 |
+
public function getLongSummaryDescription(){
|
| 85 |
+
return $this->iceCatModel->getLongSummaryDescription();
|
| 86 |
+
}
|
| 87 |
+
|
| 88 |
+
public function getManualPDF(){
|
| 89 |
+
return $this->iceCatModel->getManualPDF();
|
| 90 |
+
}
|
| 91 |
+
|
| 92 |
+
public function getPDF(){
|
| 93 |
+
return $this->iceCatModel->getPDF();
|
| 94 |
+
}
|
| 95 |
+
|
| 96 |
+
public function getIceCatMedia(){
|
| 97 |
+
$media = (array)$this->iceCatModel->getIceCatMedia();
|
| 98 |
+
return (array_key_exists('@attributes', $media)) ? $media['@attributes'] : array();
|
| 99 |
+
}
|
| 100 |
}
|
| 101 |
?>
|
app/code/local/Bintime/Icecatimport/Model/Import.php
CHANGED
|
@@ -7,18 +7,26 @@
|
|
| 7 |
class Bintime_Icecatimport_Model_Import extends Mage_Core_Model_Abstract {
|
| 8 |
|
| 9 |
public $entityId;
|
| 10 |
-
private $productDescriptionList
|
| 11 |
private $productDescription;
|
| 12 |
private $fullProductDescription;
|
| 13 |
private $lowPicUrl;
|
| 14 |
private $highPicUrl;
|
| 15 |
private $errorMessage;
|
| 16 |
-
private $galleryPhotos
|
| 17 |
private $productName;
|
| 18 |
-
private $relatedProducts
|
| 19 |
private $thumb;
|
| 20 |
private $errorSystemMessage; //depricated
|
| 21 |
-
private $_cacheKey
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 22 |
|
| 23 |
protected function _construct()
|
| 24 |
{
|
|
@@ -94,13 +102,8 @@ class Bintime_Icecatimport_Model_Import extends Mage_Core_Model_Abstract {
|
|
| 94 |
}
|
| 95 |
|
| 96 |
if ($this->checkIcecatResponse($productId, $vendorName)){
|
| 97 |
-
// $_newProduct = Mage::getModel('catalog/product')->load($productId);
|
| 98 |
-
//echo $_newProduct->getDescription();die;
|
| 99 |
-
//$this->productDescription = $_newProduct->getDescription();
|
| 100 |
return false;
|
| 101 |
}
|
| 102 |
-
//$_newProduct = Mage::getModel('catalog/product')->load($productId);
|
| 103 |
-
//$_newProduct->getDescription();die();
|
| 104 |
|
| 105 |
$this->loadProductDescriptionList();
|
| 106 |
$this->loadOtherProductParams($productId);
|
|
@@ -211,7 +214,31 @@ class Bintime_Icecatimport_Model_Import extends Mage_Core_Model_Abstract {
|
|
| 211 |
public function getEAN(){
|
| 212 |
return $this->EAN;
|
| 213 |
}
|
| 214 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 215 |
/**
|
| 216 |
* Form related products Array
|
| 217 |
*/
|
|
@@ -263,38 +290,44 @@ class Bintime_Icecatimport_Model_Import extends Mage_Core_Model_Abstract {
|
|
| 263 |
* Form Array of non feature-value product params
|
| 264 |
*/
|
| 265 |
private function loadOtherProductParams($productId){
|
| 266 |
-
$this->productDescription = (string) $this->simpleDoc->Product->ProductDescription['ShortDesc'];
|
| 267 |
-
|
| 268 |
|
| 269 |
-
|
| 270 |
-
|
| 271 |
-
|
| 272 |
-
|
| 273 |
-
|
| 274 |
-
|
| 275 |
-
|
| 276 |
-
|
| 277 |
-
|
| 278 |
-
|
| 279 |
-
|
| 280 |
-
|
| 281 |
-
|
| 282 |
-
|
| 283 |
-
|
| 284 |
-
|
| 285 |
-
|
| 286 |
-
|
| 287 |
-
|
| 288 |
-
|
| 289 |
-
|
| 290 |
-
|
| 291 |
-
|
| 292 |
-
|
| 293 |
-
|
| 294 |
-
|
| 295 |
-
|
| 296 |
-
|
| 297 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 298 |
}
|
| 299 |
|
| 300 |
/**
|
| 7 |
class Bintime_Icecatimport_Model_Import extends Mage_Core_Model_Abstract {
|
| 8 |
|
| 9 |
public $entityId;
|
| 10 |
+
private $productDescriptionList = array();
|
| 11 |
private $productDescription;
|
| 12 |
private $fullProductDescription;
|
| 13 |
private $lowPicUrl;
|
| 14 |
private $highPicUrl;
|
| 15 |
private $errorMessage;
|
| 16 |
+
private $galleryPhotos = array();
|
| 17 |
private $productName;
|
| 18 |
+
private $relatedProducts = array();
|
| 19 |
private $thumb;
|
| 20 |
private $errorSystemMessage; //depricated
|
| 21 |
+
private $_cacheKey = 'bintime_icecatimport_';
|
| 22 |
+
|
| 23 |
+
private $_warrantyInfo = '';
|
| 24 |
+
private $_shortSummaryDesc = '';
|
| 25 |
+
private $_longSummaryDesc = '';
|
| 26 |
+
|
| 27 |
+
private $_manualPdfUrl = '';
|
| 28 |
+
private $_pdfUrl = '';
|
| 29 |
+
private $_multimedia = '';
|
| 30 |
|
| 31 |
protected function _construct()
|
| 32 |
{
|
| 102 |
}
|
| 103 |
|
| 104 |
if ($this->checkIcecatResponse($productId, $vendorName)){
|
|
|
|
|
|
|
|
|
|
| 105 |
return false;
|
| 106 |
}
|
|
|
|
|
|
|
| 107 |
|
| 108 |
$this->loadProductDescriptionList();
|
| 109 |
$this->loadOtherProductParams($productId);
|
| 214 |
public function getEAN(){
|
| 215 |
return $this->EAN;
|
| 216 |
}
|
| 217 |
+
|
| 218 |
+
public function getWarrantyInfo(){
|
| 219 |
+
return $this->_warrantyInfo;
|
| 220 |
+
}
|
| 221 |
+
|
| 222 |
+
public function getShortSummaryDescription(){
|
| 223 |
+
return $this->_shortSummaryDesc;
|
| 224 |
+
}
|
| 225 |
+
|
| 226 |
+
public function getLongSummaryDescription(){
|
| 227 |
+
return $this->_longSummaryDesc;
|
| 228 |
+
}
|
| 229 |
+
|
| 230 |
+
public function getManualPDF(){
|
| 231 |
+
return $this->_manualPdfUrl;
|
| 232 |
+
}
|
| 233 |
+
|
| 234 |
+
public function getPDF(){
|
| 235 |
+
return $this->_pdfUrl;
|
| 236 |
+
}
|
| 237 |
+
|
| 238 |
+
public function getIceCatMedia(){
|
| 239 |
+
return $this->_multimedia;
|
| 240 |
+
}
|
| 241 |
+
|
| 242 |
/**
|
| 243 |
* Form related products Array
|
| 244 |
*/
|
| 290 |
* Form Array of non feature-value product params
|
| 291 |
*/
|
| 292 |
private function loadOtherProductParams($productId){
|
|
|
|
|
|
|
| 293 |
|
| 294 |
+
$productTag = $this->simpleDoc->Product;
|
| 295 |
+
|
| 296 |
+
$this->productDescription = (string)$productTag->ProductDescription['ShortDesc'];
|
| 297 |
+
$this->fullProductDescription = (string)$productTag->ProductDescription['LongDesc'];
|
| 298 |
+
$this->_warrantyInfo = (string)$productTag->ProductDescription['WarrantyInfo'];
|
| 299 |
+
$this->_shortSummaryDesc = (string)$productTag->SummaryDescription->ShortSummaryDescription;
|
| 300 |
+
$this->_longSummaryDesc = (string)$productTag->SummaryDescription->LongSummaryDescription;
|
| 301 |
+
|
| 302 |
+
$this->_manualPdfUrl = (string)$productTag->ProductDescription['ManualPDFURL'];
|
| 303 |
+
$this->_pdfUrl = (string)$productTag->ProductDescription['PDFURL'];
|
| 304 |
+
|
| 305 |
+
$this->_multimedia = $productTag->ProductMultimediaObject->MultimediaObject;
|
| 306 |
+
|
| 307 |
+
$this->lowPicUrl = (string)$productTag["LowPic"];
|
| 308 |
+
$this->highPicUrl = (string)$productTag["HighPic"];
|
| 309 |
+
$this->productName = (string)$productTag["Name"];
|
| 310 |
+
$this->productId = (string)$productTag['Prod_id'];
|
| 311 |
+
$this->thumb = (string)$productTag['ThumbPic'];
|
| 312 |
+
$this->vendor = (string)$productTag->Supplier['Name'];
|
| 313 |
+
|
| 314 |
+
$prodEAN = $productTag->EANCode;
|
| 315 |
+
$EANstr='';
|
| 316 |
+
$EANarr=null;
|
| 317 |
+
$j = 0;//counter
|
| 318 |
+
foreach($prodEAN as $ellEAN){
|
| 319 |
+
$EANarr[]=$ellEAN['EAN'];$j++;
|
| 320 |
+
}
|
| 321 |
+
$i = 0;
|
| 322 |
+
$str = '';
|
| 323 |
+
for($i=0;$i<$j;$i++){
|
| 324 |
+
$g = $i%2;
|
| 325 |
+
if($g == '0'){if($j == 1){$str .= $EANarr[$i].'<br>';} else {$str .= $EANarr[$i].', ';}
|
| 326 |
+
}
|
| 327 |
+
else {if($i != $j-1){$str .= $EANarr[$i].', <br>';}else {$str .= $EANarr[$i].' <br>';}}
|
| 328 |
+
}
|
| 329 |
+
$this->EAN = $str;
|
| 330 |
+
|
| 331 |
}
|
| 332 |
|
| 333 |
/**
|
app/code/local/Bintime/Icecatimport/Model/Observer.php
CHANGED
|
@@ -96,6 +96,7 @@ class Bintime_Icecatimport_Model_Observer
|
|
| 96 |
foreach ($supplierList as $supplier) {
|
| 97 |
$supplierSymbolList = $supplier->Symbol;
|
| 98 |
$supplierId = $supplier['supplier_id'];
|
|
|
|
| 99 |
foreach($supplierSymbolList as $symbol) {
|
| 100 |
$symbolName = (string)$symbol;
|
| 101 |
$connection->insert($mappingTable."_temp", array('supplier_id' => $supplierId, 'supplier_symbol' => $symbolName));
|
| 96 |
foreach ($supplierList as $supplier) {
|
| 97 |
$supplierSymbolList = $supplier->Symbol;
|
| 98 |
$supplierId = $supplier['supplier_id'];
|
| 99 |
+
$connection->insert($mappingTable."_temp", array('supplier_id' => $supplierId, 'supplier_symbol' => (string)$supplier['name']));
|
| 100 |
foreach($supplierSymbolList as $symbol) {
|
| 101 |
$symbolName = (string)$symbol;
|
| 102 |
$connection->insert($mappingTable."_temp", array('supplier_id' => $supplierId, 'supplier_symbol' => $symbolName));
|
app/code/local/Bintime/Icecatimport/etc/config.xml
CHANGED
|
@@ -139,7 +139,7 @@
|
|
| 139 |
<crontab>
|
| 140 |
<jobs>
|
| 141 |
<icecatimport>
|
| 142 |
-
<schedule><cron_expr
|
| 143 |
<run><model>icecatimport/observer::load</model></run>
|
| 144 |
</icecatimport>
|
| 145 |
</jobs>
|
| 139 |
<crontab>
|
| 140 |
<jobs>
|
| 141 |
<icecatimport>
|
| 142 |
+
<schedule><cron_expr>* * * * *</cron_expr></schedule>
|
| 143 |
<run><model>icecatimport/observer::load</model></run>
|
| 144 |
</icecatimport>
|
| 145 |
</jobs>
|
package.xml
CHANGED
|
@@ -1,20 +1,23 @@
|
|
| 1 |
<?xml version="1.0"?>
|
| 2 |
<package>
|
| 3 |
<name>IcecatLive</name>
|
| 4 |
-
<version>1.
|
| 5 |
<stability>stable</stability>
|
| 6 |
<license uri="http://opensource.org/licenses/osl-3.0.php">OSL v.3</license>
|
| 7 |
<channel>community</channel>
|
| 8 |
<extends/>
|
| 9 |
<summary>ICEcat to Magento Open Source Connector</summary>
|
| 10 |
<description>ICEcat to Magento Open Source Connector - rich content in your magento shop</description>
|
| 11 |
-
<notes>-
|
| 12 |
-
|
| 13 |
-
|
|
|
|
|
|
|
|
|
|
| 14 |
<authors><author><name>IceShop</name><user>IceShop</user><email>support@iceshop.nl</email></author></authors>
|
| 15 |
-
<date>2012-
|
| 16 |
-
<time>
|
| 17 |
-
<contents><target name="magelocal"><dir name="Bintime"><dir name="Icecatimport"><dir name="Block"><file name="Attributes.php" hash="ae93e0a964e8880e5b65fb5d08f1edf9"/><file name="Media.php" hash="a71e447a139b851da50937bccaf8bd37"/><file name="Related.php" hash="7ca2ad6520f2644ad1302c02d1cd6853"/><file name="Upsell.php" hash="624bd7b9c8708a67079efb2478a5a37d"/></dir><dir name="controllers"><file name="ImageController.php" hash="cdf4984c268346088729831b7abdf026"/></dir><dir name="etc"><file name="config.xml" hash="
|
| 18 |
<compatible/>
|
| 19 |
<dependencies><required><php><min>5.2.0</min><max>6.0.0</max></php></required></dependencies>
|
| 20 |
</package>
|
| 1 |
<?xml version="1.0"?>
|
| 2 |
<package>
|
| 3 |
<name>IcecatLive</name>
|
| 4 |
+
<version>1.1.0</version>
|
| 5 |
<stability>stable</stability>
|
| 6 |
<license uri="http://opensource.org/licenses/osl-3.0.php">OSL v.3</license>
|
| 7 |
<channel>community</channel>
|
| 8 |
<extends/>
|
| 9 |
<summary>ICEcat to Magento Open Source Connector</summary>
|
| 10 |
<description>ICEcat to Magento Open Source Connector - rich content in your magento shop</description>
|
| 11 |
+
<notes>- Improvement of product mapping
|
| 12 |
+
- Improvement of product description
|
| 13 |
+
- Added displaying icecat names on product listing/shopping cart
|
| 14 |
+
- Added all ICEcat data available as variables on product detail page
|
| 15 |
+
- Fixed issue with Yes/No indication
|
| 16 |
+
- Fixed image displaying on product listing/shopping cart</notes>
|
| 17 |
<authors><author><name>IceShop</name><user>IceShop</user><email>support@iceshop.nl</email></author></authors>
|
| 18 |
+
<date>2012-08-21</date>
|
| 19 |
+
<time>16:02:42</time>
|
| 20 |
+
<contents><target name="magelocal"><dir name="Bintime"><dir name="Icecatimport"><dir name="Block"><file name="Attributes.php" hash="ae93e0a964e8880e5b65fb5d08f1edf9"/><file name="Media.php" hash="a71e447a139b851da50937bccaf8bd37"/><file name="Related.php" hash="7ca2ad6520f2644ad1302c02d1cd6853"/><file name="Upsell.php" hash="624bd7b9c8708a67079efb2478a5a37d"/></dir><dir name="controllers"><file name="ImageController.php" hash="cdf4984c268346088729831b7abdf026"/></dir><dir name="etc"><file name="config.xml" hash="13d5b3c94451f13119c90a8added2374"/><file name="system.xml" hash="5138720902ed8c530d7c91b82d0f4935"/></dir><dir name="Helper"><dir name="Catalog"><file name="Image.php" hash="d300efd5dc51ad649023aab95d6b5fd7"/></dir><file name="Getdata.php" hash="b36ed387b06e2d2aa9860f693dda3f03"/><file name="Image.php" hash="000f0665c72b96ac03ca07dc3046a202"/><file name="Output.php" hash="21f46a7252ddfab8ae7d44384d205da2"/></dir><dir name="Model"><dir name="Catalog"><file name="Category.php" hash="21abeb7a7c2c85db8ce4d2f4ed203f50"/><file name="Product.php" hash="232f34dade19ddcf09d2da92e15cb682"/><file name="Search.php" hash="99c7eb706e67e01ea8167ebe88fe72d9"/></dir><dir name="System"><dir name="Config"><file name="Attributes.php" hash="23284e0d38677b4544fc87642a6bc8b5"/><file name="LanguageList.xml" hash="391ef56fab212879709780df5a7710e7"/><file name="Locales.php" hash="b8c699fa2a6f657b6d52d86e656872cc"/><file name="Subscription.php" hash="62168986f7a4eb3f10d38ac627aa6510"/></dir></dir><file name="Imagescollection.php" hash="718b575ef9472f85c323fa40f80bbd05"/><file name="Import.php" hash="2e243371496d5ddff593591a619aa348"/><file name="Observer.php" hash="b97aaab8b60091bb481ad25b28126896"/><file name="Relatedcollection.php" hash="2ddf62c43a66c3fd70bf651d0078dbc1"/></dir><dir name="sql"><dir name="icecatimport_setup"><file name="mysql4-install-0.1.0.php" hash="a8f750e7667f8ef0dd077100c9fddf48"/><file name="mysql4-upgrade-0.1.0-0.1.1.php" hash="c0581c5b00420492714bd7e3cc66cb6d"/></dir></dir></dir></dir></target><target name="mageetc"><dir name="modules"><file name="Bintime_Icecatimport.xml" hash="daf681aae3e710568d210313816a9d5f"/></dir></target></contents>
|
| 21 |
<compatible/>
|
| 22 |
<dependencies><required><php><min>5.2.0</min><max>6.0.0</max></php></required></dependencies>
|
| 23 |
</package>
|
