Version Notes
Improvements:
- Added import errors indication.
- Added grid for not imported images.
- Added method to run only images import.
- Added statistics import images.
Download this release
Release Info
| Developer | IceShop |
| Extension | ice_import |
| Version | 1.7.13 |
| Comparing to | |
| See all releases | |
Code changes from version 1.7.12 to 1.7.13
- app/code/community/ICEshop/Iceimport/Block/Adminhtml/Images/List/Grid.php +151 -0
- app/code/community/ICEshop/Iceimport/Block/Adminhtml/System/Config/Form/Button.php +49 -0
- app/code/community/ICEshop/Iceimport/Block/Adminhtml/System/Config/Form/Exportall.php +49 -0
- app/code/community/ICEshop/Iceimport/Block/Adminhtml/System/Config/Form/Updatebutton.php +49 -0
- app/code/community/ICEshop/Iceimport/Helper/System/Systemcheck.php +51 -0
- app/code/community/ICEshop/Iceimport/Model/Convert/Adapter/Product.php +60 -24
- app/code/community/ICEshop/Iceimport/Model/Dataflow/Convert/Parser/Csv.php +32 -0
- app/code/community/ICEshop/Iceimport/Model/Observer.php +228 -2
- app/code/community/ICEshop/Iceimport/controllers/Adminhtml/IceimagesController.php +12 -0
- app/code/community/ICEshop/Iceimport/controllers/Adminhtml/IceimportController.php +243 -14
- app/code/community/ICEshop/Iceimport/controllers/Adminhtml/IceimportimagesController.php +18 -0
- app/code/community/ICEshop/Iceimport/etc/config.xml +1 -3
- app/code/community/ICEshop/Iceimport/sql/iceimport_setup/{mysql4-install-1.7.9.php → mysql4-install-1.7.13} +0 -0
- app/code/community/ICEshop/Iceimport/sql/iceimport_setup/mysql4-upgrade-1.7.9-1.7.13 +75 -0
- package.xml +8 -6
app/code/community/ICEshop/Iceimport/Block/Adminhtml/Images/List/Grid.php
ADDED
|
@@ -0,0 +1,151 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
|
| 3 |
+
class ICEshop_Iceimport_Block_Adminhtml_Images_List_Grid extends Mage_Adminhtml_Block_Widget_Grid
|
| 4 |
+
{
|
| 5 |
+
public function __construct()
|
| 6 |
+
{
|
| 7 |
+
parent::__construct();
|
| 8 |
+
$this->setId('iceimportGrid');
|
| 9 |
+
$this->setUseAjax(true);
|
| 10 |
+
// $this->setVarNameFilter('iceimport_filter');
|
| 11 |
+
// $this->setDefaultLimit($this->getCountImagesNotImport());
|
| 12 |
+
// $this->setPagerVisibility(false);
|
| 13 |
+
// $this->setFilterVisibility(false);
|
| 14 |
+
// $this->setSaveParametersInSession(true);
|
| 15 |
+
$this->_prepareCollection;
|
| 16 |
+
}
|
| 17 |
+
|
| 18 |
+
protected function _getStore()
|
| 19 |
+
{
|
| 20 |
+
$storeId = (int) $this->getRequest()->getParam('store', 0);
|
| 21 |
+
return Mage::app()->getStore($storeId);
|
| 22 |
+
}
|
| 23 |
+
|
| 24 |
+
protected function _prepareCollection()
|
| 25 |
+
{
|
| 26 |
+
|
| 27 |
+
$store = $this->_getStore();
|
| 28 |
+
$collection = Mage::getModel('catalog/product')->getCollection();
|
| 29 |
+
$collection->addAttributeToSort('entity_id', 'DESC');
|
| 30 |
+
|
| 31 |
+
$collection->getSelect()->joinLeft( array('pt'=> 'iceshop_iceimport_image_queue'),
|
| 32 |
+
'e.`entity_id` = pt.`entity_id`', array('*'))->where("pt.`is_downloaded`=2")->limit(20, 10);
|
| 33 |
+
|
| 34 |
+
if($this->checkExistingAttribute('catalog_product', 'sku')){
|
| 35 |
+
$collection->addAttributeToSelect('sku');
|
| 36 |
+
}
|
| 37 |
+
|
| 38 |
+
if ($store->getId()) {
|
| 39 |
+
$adminStore = Mage_Core_Model_App::ADMIN_STORE_ID;
|
| 40 |
+
|
| 41 |
+
if($this->checkExistingAttribute('catalog_product', 'mpn')){
|
| 42 |
+
$collection->joinAttribute(
|
| 43 |
+
'mpn',
|
| 44 |
+
'catalog_product/mpn',
|
| 45 |
+
'entity_id',
|
| 46 |
+
null,
|
| 47 |
+
'inner',
|
| 48 |
+
$adminStore
|
| 49 |
+
);
|
| 50 |
+
}
|
| 51 |
+
$collection->joinAttribute(
|
| 52 |
+
'image_url',
|
| 53 |
+
'iceshop_iceimport_image_queue/image_url',
|
| 54 |
+
'entity_id',
|
| 55 |
+
null,
|
| 56 |
+
'inner',
|
| 57 |
+
$store->getId()
|
| 58 |
+
);
|
| 59 |
+
}
|
| 60 |
+
else {
|
| 61 |
+
if($this->checkExistingAttribute('catalog_product', 'mpn')){
|
| 62 |
+
$collection->joinAttribute('mpn', 'catalog_product/mpn', 'entity_id', null, 'inner');
|
| 63 |
+
}
|
| 64 |
+
}
|
| 65 |
+
|
| 66 |
+
$this->setCollection($collection);
|
| 67 |
+
|
| 68 |
+
parent::_prepareCollection();
|
| 69 |
+
$this->getCollection()->addWebsiteNamesToResult();
|
| 70 |
+
return $this;
|
| 71 |
+
|
| 72 |
+
}
|
| 73 |
+
|
| 74 |
+
public function checkExistingAttribute($group, $attribut){
|
| 75 |
+
$eav = Mage::getModel('eav/config');
|
| 76 |
+
$attribute = $eav->getAttribute($group, $attribut);
|
| 77 |
+
return $attribute->getId();
|
| 78 |
+
}
|
| 79 |
+
|
| 80 |
+
|
| 81 |
+
protected function _prepareColumns()
|
| 82 |
+
{
|
| 83 |
+
if ($this->_isExport) {
|
| 84 |
+
$this->setDefaultLimit($this->getCountImagesNotImport());
|
| 85 |
+
}
|
| 86 |
+
$this->addColumn('entity_id',
|
| 87 |
+
array(
|
| 88 |
+
'header'=> Mage::helper('catalog')->__('ID'),
|
| 89 |
+
'width' => '50px',
|
| 90 |
+
'type' => 'number',
|
| 91 |
+
'index' => 'entity_id',
|
| 92 |
+
));
|
| 93 |
+
$this->addColumn('image_url',
|
| 94 |
+
array(
|
| 95 |
+
'header'=> Mage::helper('catalog')->__('Url'),
|
| 96 |
+
'index' => 'image_url',
|
| 97 |
+
'filter' => FALSE
|
| 98 |
+
));
|
| 99 |
+
|
| 100 |
+
if($this->checkExistingAttribute('catalog_product', 'sku')){
|
| 101 |
+
$this->addColumn('sku',
|
| 102 |
+
array(
|
| 103 |
+
'header'=> Mage::helper('catalog')->__('SKU'),
|
| 104 |
+
'width' => '80px',
|
| 105 |
+
'index' => 'sku',
|
| 106 |
+
));
|
| 107 |
+
}
|
| 108 |
+
|
| 109 |
+
if($this->checkExistingAttribute('catalog_product', 'mpn')){
|
| 110 |
+
$this->addColumn('mpn',
|
| 111 |
+
array(
|
| 112 |
+
'header'=> Mage::helper('catalog')->__('Manufacturer product number'),
|
| 113 |
+
'width' => '80px',
|
| 114 |
+
'index' => 'mpn',
|
| 115 |
+
));
|
| 116 |
+
}
|
| 117 |
+
$this->addExportType('*/iceimport/exportIceimportimagesCsv', Mage::helper('iceimport')->__('CSV'));
|
| 118 |
+
$this->addExportType('*/iceimport/exportIceimportimagesExcel', Mage::helper('iceimport')->__('Excel XML'));
|
| 119 |
+
|
| 120 |
+
return parent::_prepareColumns();
|
| 121 |
+
}
|
| 122 |
+
|
| 123 |
+
public function getGridUrl()
|
| 124 |
+
{
|
| 125 |
+
return $this->getUrl('*/iceimport/grid', array('_current'=>true));
|
| 126 |
+
}
|
| 127 |
+
|
| 128 |
+
public function getRowUrl($row)
|
| 129 |
+
{
|
| 130 |
+
return $this->getUrl('*/catalog_product/edit', array(
|
| 131 |
+
'store'=>$this->getRequest()->getParam('store'),
|
| 132 |
+
'id'=>$row->getId())
|
| 133 |
+
);
|
| 134 |
+
}
|
| 135 |
+
|
| 136 |
+
public function getCountImagesNotImport(){
|
| 137 |
+
try{
|
| 138 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 139 |
+
$tablePrefix = '';
|
| 140 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 141 |
+
if (!empty($tPrefix)) {
|
| 142 |
+
$tablePrefix = $tPrefix[0];
|
| 143 |
+
}
|
| 144 |
+
return $return_resulr = $db_res->fetchOne("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 145 |
+
WHERE `is_downloaded` = 2");
|
| 146 |
+
|
| 147 |
+
} catch (Exception $e){
|
| 148 |
+
}
|
| 149 |
+
}
|
| 150 |
+
|
| 151 |
+
}
|
app/code/community/ICEshop/Iceimport/Block/Adminhtml/System/Config/Form/Button.php
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Iceshop_Iceimport_Block_Adminhtml_System_Config_Form_Button extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 3 |
+
{
|
| 4 |
+
/*
|
| 5 |
+
* Set templated
|
| 6 |
+
*/
|
| 7 |
+
protected function _construct()
|
| 8 |
+
{
|
| 9 |
+
parent::_construct();
|
| 10 |
+
}
|
| 11 |
+
|
| 12 |
+
/**
|
| 13 |
+
* Return element html
|
| 14 |
+
*
|
| 15 |
+
* @param Varien_Data_Form_Element_Abstract $element
|
| 16 |
+
* @return string
|
| 17 |
+
*/
|
| 18 |
+
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 19 |
+
{
|
| 20 |
+
return $this->_toHtml();
|
| 21 |
+
}
|
| 22 |
+
|
| 23 |
+
/**
|
| 24 |
+
* Return ajax url for button
|
| 25 |
+
*
|
| 26 |
+
* @return string
|
| 27 |
+
*/
|
| 28 |
+
public function getAjaxCheckUrl()
|
| 29 |
+
{
|
| 30 |
+
return Mage::helper('adminhtml')->getUrl('adminhtml/iceimportimages/check/');
|
| 31 |
+
}
|
| 32 |
+
|
| 33 |
+
/**
|
| 34 |
+
* Generate button html
|
| 35 |
+
*
|
| 36 |
+
* @return string
|
| 37 |
+
*/
|
| 38 |
+
public function getButtonHtml()
|
| 39 |
+
{
|
| 40 |
+
$prod_button = $this->getLayout()->createBlock('adminhtml/widget_button')
|
| 41 |
+
->setData(array(
|
| 42 |
+
'id' => 'iceimport_images_button',
|
| 43 |
+
'label' => $this->helper('adminhtml')->__('Import images'),
|
| 44 |
+
'onclick' => 'javascript:import_prod_images(1,0); return false;'
|
| 45 |
+
));
|
| 46 |
+
$buttons = $prod_button->toHtml();
|
| 47 |
+
return $buttons;
|
| 48 |
+
}
|
| 49 |
+
}
|
app/code/community/ICEshop/Iceimport/Block/Adminhtml/System/Config/Form/Exportall.php
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Iceshop_Iceimport_Block_Adminhtml_System_Config_Form_Exportall extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 3 |
+
{
|
| 4 |
+
/*
|
| 5 |
+
* Set templated
|
| 6 |
+
*/
|
| 7 |
+
protected function _construct()
|
| 8 |
+
{
|
| 9 |
+
parent::_construct();
|
| 10 |
+
}
|
| 11 |
+
|
| 12 |
+
/**
|
| 13 |
+
* Return element html
|
| 14 |
+
*
|
| 15 |
+
* @param Varien_Data_Form_Element_Abstract $element
|
| 16 |
+
* @return string
|
| 17 |
+
*/
|
| 18 |
+
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 19 |
+
{
|
| 20 |
+
return $this->_toHtml();
|
| 21 |
+
}
|
| 22 |
+
|
| 23 |
+
/**
|
| 24 |
+
* Return ajax url for button
|
| 25 |
+
*
|
| 26 |
+
* @return string
|
| 27 |
+
*/
|
| 28 |
+
public function getAjaxCheckUrl()
|
| 29 |
+
{
|
| 30 |
+
return Mage::helper('adminhtml')->getUrl('adminhtml/iceimport/exportIceimportimagesCsvAll/');
|
| 31 |
+
}
|
| 32 |
+
|
| 33 |
+
/**
|
| 34 |
+
* Generate button html
|
| 35 |
+
*
|
| 36 |
+
* @return string
|
| 37 |
+
*/
|
| 38 |
+
public function getButtonHtml()
|
| 39 |
+
{
|
| 40 |
+
$prod_button = $this->getLayout()->createBlock('adminhtml/widget_button')
|
| 41 |
+
->setData(array(
|
| 42 |
+
'id' => 'iceimport_exportall_button',
|
| 43 |
+
'label' => $this->helper('adminhtml')->__('Export All to CSV'),
|
| 44 |
+
'onclick' => "setLocation('" . $this->getUrl('adminhtml/iceimport/exportIceimportimagesCsvAll/') . "')"
|
| 45 |
+
));
|
| 46 |
+
$buttons = $prod_button->toHtml();
|
| 47 |
+
return $buttons;
|
| 48 |
+
}
|
| 49 |
+
}
|
app/code/community/ICEshop/Iceimport/Block/Adminhtml/System/Config/Form/Updatebutton.php
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Iceshop_Iceimport_Block_Adminhtml_System_Config_Form_Updatebutton extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 3 |
+
{
|
| 4 |
+
/*
|
| 5 |
+
* Set templated
|
| 6 |
+
*/
|
| 7 |
+
protected function _construct()
|
| 8 |
+
{
|
| 9 |
+
parent::_construct();
|
| 10 |
+
}
|
| 11 |
+
|
| 12 |
+
/**
|
| 13 |
+
* Return element html
|
| 14 |
+
*
|
| 15 |
+
* @param Varien_Data_Form_Element_Abstract $element
|
| 16 |
+
* @return string
|
| 17 |
+
*/
|
| 18 |
+
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 19 |
+
{
|
| 20 |
+
return $this->_toHtml();
|
| 21 |
+
}
|
| 22 |
+
|
| 23 |
+
/**
|
| 24 |
+
* Return ajax url for button
|
| 25 |
+
*
|
| 26 |
+
* @return string
|
| 27 |
+
*/
|
| 28 |
+
public function getAjaxCheckUrl()
|
| 29 |
+
{
|
| 30 |
+
return Mage::helper('adminhtml')->getUrl('adminhtml/iceimportimages/check/');
|
| 31 |
+
}
|
| 32 |
+
|
| 33 |
+
/**
|
| 34 |
+
* Generate button html
|
| 35 |
+
*
|
| 36 |
+
* @return string
|
| 37 |
+
*/
|
| 38 |
+
public function getButtonHtml()
|
| 39 |
+
{
|
| 40 |
+
$prod_button = $this->getLayout()->createBlock('adminhtml/widget_button')
|
| 41 |
+
->setData(array(
|
| 42 |
+
'id' => 'iceimport_images_button',
|
| 43 |
+
'label' => $this->helper('adminhtml')->__('Try again'),
|
| 44 |
+
'onclick' => 'javascript:import_prod_images(1,1); return false;'
|
| 45 |
+
));
|
| 46 |
+
$buttons = $prod_button->toHtml();
|
| 47 |
+
return $buttons;
|
| 48 |
+
}
|
| 49 |
+
}
|
app/code/community/ICEshop/Iceimport/Helper/System/Systemcheck.php
CHANGED
|
@@ -615,9 +615,60 @@ class ICEshop_Iceimport_Helper_System_Systemcheck extends Mage_Core_Helper_Abstr
|
|
| 615 |
}
|
| 616 |
}
|
| 617 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 618 |
$problems_digest = new Varien_Object();
|
| 619 |
$problems_digest->setData('problems', $problems);
|
| 620 |
$problems_digest->setData('count', $count);
|
| 621 |
return $problems_digest;
|
| 622 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 623 |
}
|
| 615 |
}
|
| 616 |
}
|
| 617 |
|
| 618 |
+
$try_delete_product = $DB_logger->getLogEntryByKey('error_try_delete_product');
|
| 619 |
+
$delete_product_percentage = $DB_logger->getLogEntryByKey('error_try_delete_product_percentage');
|
| 620 |
+
if(!empty($delete_product_percentage) && !empty($try_delete_product)) {
|
| 621 |
+
$problems['iceimport_delete_product'][] = array(
|
| 622 |
+
'label' => 'There is a problem during last import',
|
| 623 |
+
'current_value' => $try_delete_product['log_value'].$delete_product_percentage['log_value']
|
| 624 |
+
);
|
| 625 |
+
$count++;
|
| 626 |
+
}
|
| 627 |
+
|
| 628 |
$problems_digest = new Varien_Object();
|
| 629 |
$problems_digest->setData('problems', $problems);
|
| 630 |
$problems_digest->setData('count', $count);
|
| 631 |
return $problems_digest;
|
| 632 |
}
|
| 633 |
+
|
| 634 |
+
public function setWarningIceimport($massage){
|
| 635 |
+
Mage::getSingleton('adminhtml/session')->addNotice('Warning!'.$massage);
|
| 636 |
+
}
|
| 637 |
+
|
| 638 |
+
|
| 639 |
+
public function getImagesStatistics(){
|
| 640 |
+
try{
|
| 641 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 642 |
+
$tablePrefix = '';
|
| 643 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 644 |
+
if (!empty($tPrefix)) {
|
| 645 |
+
$tablePrefix = $tPrefix[0];
|
| 646 |
+
}
|
| 647 |
+
$statistic_check = array();
|
| 648 |
+
$statistic_check['total_entries']['type'] = 'total_entries';
|
| 649 |
+
$statistic_check['total_entries']['label'] = 'Total Images Entries:';
|
| 650 |
+
$count_value = $db_res->fetchRow("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue`");
|
| 651 |
+
$total_entries = $count_value['COUNT(*)'];
|
| 652 |
+
$statistic_check['total_entries']['value'] = $total_entries;
|
| 653 |
+
|
| 654 |
+
$statistic_check['total_download']['type'] = 'total_download';
|
| 655 |
+
$statistic_check['total_download']['label'] = 'Total Images Downloaded:';
|
| 656 |
+
$count_value = $db_res->fetchRow("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue` WHERE `is_downloaded` = 1");
|
| 657 |
+
$statistic_check['total_download']['value'] = $count_value['COUNT(*)'] . " ( " . round($count_value['COUNT(*)'] * 100 / $total_entries, 2) . "% )";
|
| 658 |
+
|
| 659 |
+
$statistic_check['total_waiting_download']['type'] = 'total_waiting_download';
|
| 660 |
+
$statistic_check['total_waiting_download']['label'] = 'Images Waiting Download:';
|
| 661 |
+
$count_value = $db_res->fetchRow("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue` WHERE `is_downloaded` = 0");
|
| 662 |
+
$statistic_check['total_waiting_download']['value'] = $count_value['COUNT(*)'] . " ( " . round($count_value['COUNT(*)'] * 100 / $total_entries, 2) . "% )";
|
| 663 |
+
|
| 664 |
+
$statistic_check['total_error_download']['type'] = 'total_error_download';
|
| 665 |
+
$statistic_check['total_error_download']['label'] = 'Images Download Error:';
|
| 666 |
+
$count_value = $db_res->fetchRow("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue` WHERE `is_downloaded` = 2");
|
| 667 |
+
$statistic_check['total_error_download']['value'] = $count_value['COUNT(*)'] . " ( " . round($count_value['COUNT(*)'] * 100 / $total_entries, 2) . "% )";
|
| 668 |
+
|
| 669 |
+
return $statistic_check;
|
| 670 |
+
} catch (Exception $e){
|
| 671 |
+
}
|
| 672 |
+
}
|
| 673 |
+
|
| 674 |
}
|
app/code/community/ICEshop/Iceimport/Model/Convert/Adapter/Product.php
CHANGED
|
@@ -226,7 +226,7 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 226 |
$tax_reprobel = $iceimportAttributes['tax_reprobel'];
|
| 227 |
}
|
| 228 |
|
| 229 |
-
// set status value
|
| 230 |
$statusValue = (!empty($iceimportAttributes['status']) && $iceimportAttributes['status'] == 'Enabled') ? 1 : 2;
|
| 231 |
$productData['int']['status'] = $statusValue;
|
| 232 |
|
|
@@ -412,24 +412,27 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 412 |
$this->_addImageToQueue($productId, $productImage);
|
| 413 |
}
|
| 414 |
|
| 415 |
-
if ($counter < $import_total) {
|
| 416 |
-
$session->setData("counter", (int)++$counter);
|
| 417 |
-
}
|
| 418 |
|
| 419 |
-
|
|
|
|
|
|
|
|
|
|
| 420 |
$this->_runCategoriesSorting();
|
| 421 |
$DB_logger = Mage::helper('iceimport/db');
|
| 422 |
$this->deleteOldProducts($DB_logger);
|
| 423 |
|
| 424 |
-
$session->unsetData('import_total');
|
| 425 |
-
$session->unsetData('counter');
|
| 426 |
|
| 427 |
$DB_logger->insertLogEntry('error' . md5(microtime(true)), 'New products skipped while export according to Iceimport settings: ' . $skipped_counter, 'stat');
|
| 428 |
-
$session->unsetData('skipped_counter');
|
| 429 |
|
| 430 |
$date = date('m/d/Y H:i:s');
|
| 431 |
$DB_logger->insertLogEntry('iceimport_import_ended', $date);
|
| 432 |
}
|
|
|
|
|
|
|
|
|
|
| 433 |
|
| 434 |
return true;
|
| 435 |
}
|
|
@@ -644,16 +647,25 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 644 |
}
|
| 645 |
|
| 646 |
$not_delete_category = $this->getCategoryIdEmtyUnspsc($storeId);
|
| 647 |
-
$noDelCategory = '
|
| 648 |
-
|
| 649 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 650 |
}
|
| 651 |
|
| 652 |
if (!empty($mapCategoryIds)) {
|
| 653 |
foreach ($mapCategoryIds as $delCategoryId) {
|
| 654 |
$delCategoryId = (int)$delCategoryId;
|
| 655 |
-
$coreSaveSQL .= "DELETE FROM `{$this->_tablePrefix}catalog_category_product`
|
| 656 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
| 657 |
}
|
| 658 |
}
|
| 659 |
try {
|
|
@@ -888,6 +900,7 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 888 |
echo $product->getCategory() . '<br>';
|
| 889 |
unset($product);
|
| 890 |
} else {
|
|
|
|
| 891 |
Mage::log('Unable download file to ' . $productId, $logFileName);
|
| 892 |
continue;
|
| 893 |
}
|
|
@@ -910,6 +923,21 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 910 |
}
|
| 911 |
}
|
| 912 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 913 |
/**
|
| 914 |
* @param $categories
|
| 915 |
* @param $storeId
|
|
@@ -922,16 +950,17 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 922 |
{
|
| 923 |
|
| 924 |
// check if product exists
|
| 925 |
-
$categoryId = $this->_getCategoryIdByUnspsc($unspsc);
|
| 926 |
|
| 927 |
$categoryIds = array();
|
| 928 |
if (!empty($categoryId)) {
|
|
|
|
| 929 |
// merge categories by unspsc
|
| 930 |
$categoryMergedArray = $this->_categoryMapper($categories, $unspscPath);
|
| 931 |
foreach ($categoryMergedArray as $category) {
|
| 932 |
$categoryName = $category['name'];
|
| 933 |
$categoryUnspsc = $category['unspsc'];
|
| 934 |
-
$categoryTreeId = $this->_getCategoryIdByUnspsc($categoryUnspsc);
|
| 935 |
// check category name to current store
|
| 936 |
$categoryBindArray = array(
|
| 937 |
':store_id' => 0,
|
|
@@ -1008,7 +1037,7 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1008 |
$categoryCreateArray = array();
|
| 1009 |
for ($i = count($categoryMergedArray) - 1; $i >= 0; $i--) {
|
| 1010 |
$category = $categoryMergedArray[$i];
|
| 1011 |
-
$checkCategoryId = $this->_getCategoryIdByUnspsc($category['unspsc']);
|
| 1012 |
if ($checkCategoryId != null) {
|
| 1013 |
$categoryId = $this->_buildCategoryTree($checkCategoryId, $storeId, $categoryCreateArray, $categoryActive);
|
| 1014 |
$categoryIds[] = (int)$categoryId;
|
|
@@ -1056,10 +1085,10 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1056 |
* @param $unspsc
|
| 1057 |
* @return int|null
|
| 1058 |
*/
|
| 1059 |
-
protected function _getCategoryIdByUnspsc($unspsc)
|
| 1060 |
{
|
| 1061 |
if ($unspsc == 'default_root') {
|
| 1062 |
-
return Mage::app()->getStore(
|
| 1063 |
} else {
|
| 1064 |
$categoryId = $this->_connRes->fetchRow(
|
| 1065 |
"SELECT entity_id
|
|
@@ -1528,6 +1557,7 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1528 |
{
|
| 1529 |
$delete_old_products = (int)Mage::getStoreConfig('iceshop_iceimport_importprod_root/importprod/delete_old_products');
|
| 1530 |
if ($delete_old_products) {
|
|
|
|
| 1531 |
try {
|
| 1532 |
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 1533 |
$db_res->query("SELECT @is_iceimport_id := `attribute_id`
|
|
@@ -1540,6 +1570,7 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1540 |
ON cpe.entity_id = cpev.entity_id
|
| 1541 |
AND cpev.value = 1
|
| 1542 |
AND cpev.attribute_id = @is_iceimport_id");
|
|
|
|
| 1543 |
$count_prod = $count_prod['count_prod'];
|
| 1544 |
|
| 1545 |
if ($count_prod > 0) {
|
|
@@ -1554,12 +1585,14 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1554 |
ON cpe.entity_id = iip.product_id
|
| 1555 |
WHERE iip.product_id IS NULL");
|
| 1556 |
|
| 1557 |
-
if(!empty($count_del_prod['
|
| 1558 |
-
$count_del_prod = $count_del_prod['
|
| 1559 |
} else {
|
| 1560 |
$count_del_prod = 0;
|
| 1561 |
}
|
| 1562 |
|
|
|
|
|
|
|
| 1563 |
if ($count_del_prod > 0) {
|
| 1564 |
//iceimport products to delete exists, amount > 0
|
| 1565 |
$delete_old_products_tolerance = (int)Mage::getStoreConfig('iceshop_iceimport_importprod_root/importprod/delete_old_products_tolerance');
|
|
@@ -1581,10 +1614,13 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1581 |
$db_res->query("DELETE FROM {$this->_tablePrefix}iceshop_iceimport_imported_product_ids");
|
| 1582 |
} else {
|
| 1583 |
$error_message = 'Attempt to delete more old products than allowed in Iceimport configuration. Interruption of the process.';
|
| 1584 |
-
$DB_logger->insertLogEntry('
|
| 1585 |
-
$
|
| 1586 |
-
$
|
|
|
|
|
|
|
| 1587 |
print $error_message;
|
|
|
|
| 1588 |
exit;
|
| 1589 |
}
|
| 1590 |
}
|
|
@@ -1634,7 +1670,7 @@ class ICEshop_Iceimport_Model_Convert_Adapter_Product extends Mage_Catalog_Model
|
|
| 1634 |
$query = "SELECT ccev.`entity_id` FROM `{$this->_tablePrefix}catalog_category_entity_varchar` AS ccev
|
| 1635 |
LEFT JOIN `{$this->_tablePrefix}eav_attribute` AS ea
|
| 1636 |
ON ea.`attribute_id` = ccev.`attribute_id`
|
| 1637 |
-
WHERE ea.`attribute_code`='unspsc' AND ccev.`
|
| 1638 |
|
| 1639 |
return $this->_connRes->fetchAll($query, array( ':store_id' => $store_id ));
|
| 1640 |
}
|
| 226 |
$tax_reprobel = $iceimportAttributes['tax_reprobel'];
|
| 227 |
}
|
| 228 |
|
| 229 |
+
// set status value
|
| 230 |
$statusValue = (!empty($iceimportAttributes['status']) && $iceimportAttributes['status'] == 'Enabled') ? 1 : 2;
|
| 231 |
$productData['int']['status'] = $statusValue;
|
| 232 |
|
| 412 |
$this->_addImageToQueue($productId, $productImage);
|
| 413 |
}
|
| 414 |
|
|
|
|
|
|
|
|
|
|
| 415 |
|
| 416 |
+
$counter_sum = $counter + $skipped_counter;
|
| 417 |
+
|
| 418 |
+
if (isset($counter) && isset($skipped_counter) && isset($import_total) && $counter_sum == $import_total) {
|
| 419 |
+
|
| 420 |
$this->_runCategoriesSorting();
|
| 421 |
$DB_logger = Mage::helper('iceimport/db');
|
| 422 |
$this->deleteOldProducts($DB_logger);
|
| 423 |
|
| 424 |
+
// $session->unsetData('import_total');
|
| 425 |
+
// $session->unsetData('counter');
|
| 426 |
|
| 427 |
$DB_logger->insertLogEntry('error' . md5(microtime(true)), 'New products skipped while export according to Iceimport settings: ' . $skipped_counter, 'stat');
|
| 428 |
+
// $session->unsetData('skipped_counter');
|
| 429 |
|
| 430 |
$date = date('m/d/Y H:i:s');
|
| 431 |
$DB_logger->insertLogEntry('iceimport_import_ended', $date);
|
| 432 |
}
|
| 433 |
+
if ($counter < $import_total) {
|
| 434 |
+
$session->setData("counter", (int)++$counter);
|
| 435 |
+
}
|
| 436 |
|
| 437 |
return true;
|
| 438 |
}
|
| 647 |
}
|
| 648 |
|
| 649 |
$not_delete_category = $this->getCategoryIdEmtyUnspsc($storeId);
|
| 650 |
+
$noDelCategory = '';
|
| 651 |
+
if(!empty($not_delete_category)){
|
| 652 |
+
foreach ($not_delete_category as $category_ID ){
|
| 653 |
+
$noDelCategory .= ''.$category_ID['entity_id'] . ',';
|
| 654 |
+
}
|
| 655 |
+
}
|
| 656 |
+
if(!empty($noDelCategory)){
|
| 657 |
+
$noDelCategory = substr($noDelCategory, 0, -1);
|
| 658 |
}
|
| 659 |
|
| 660 |
if (!empty($mapCategoryIds)) {
|
| 661 |
foreach ($mapCategoryIds as $delCategoryId) {
|
| 662 |
$delCategoryId = (int)$delCategoryId;
|
| 663 |
+
$coreSaveSQL .= "DELETE FROM `{$this->_tablePrefix}catalog_category_product`";
|
| 664 |
+
if(!empty($noDelCategory)){
|
| 665 |
+
$coreSaveSQL .= "WHERE `category_id` NOT IN({$noDelCategory},{$delCategoryId}) AND `product_id` = @product_id;";
|
| 666 |
+
} else {
|
| 667 |
+
$coreSaveSQL .= "WHERE `category_id`!={$delCategoryId} AND `product_id` = @product_id;";
|
| 668 |
+
}
|
| 669 |
}
|
| 670 |
}
|
| 671 |
try {
|
| 900 |
echo $product->getCategory() . '<br>';
|
| 901 |
unset($product);
|
| 902 |
} else {
|
| 903 |
+
$this->setImageAsDownloadedError($queueId);
|
| 904 |
Mage::log('Unable download file to ' . $productId, $logFileName);
|
| 905 |
continue;
|
| 906 |
}
|
| 923 |
}
|
| 924 |
}
|
| 925 |
|
| 926 |
+
/**
|
| 927 |
+
* @param bool $queueId
|
| 928 |
+
*/
|
| 929 |
+
private function setImageAsDownloadedError($queueId = false)
|
| 930 |
+
{
|
| 931 |
+
if ($queueId) {
|
| 932 |
+
$this->_connRes->query(
|
| 933 |
+
"UPDATE `{$this->_tablePrefix}iceshop_iceimport_image_queue`
|
| 934 |
+
SET is_downloaded = 2
|
| 935 |
+
WHERE queue_id = :queue_id",
|
| 936 |
+
array(':queue_id' => $queueId)
|
| 937 |
+
);
|
| 938 |
+
}
|
| 939 |
+
}
|
| 940 |
+
|
| 941 |
/**
|
| 942 |
* @param $categories
|
| 943 |
* @param $storeId
|
| 950 |
{
|
| 951 |
|
| 952 |
// check if product exists
|
| 953 |
+
$categoryId = $this->_getCategoryIdByUnspsc($unspsc,$storeId);
|
| 954 |
|
| 955 |
$categoryIds = array();
|
| 956 |
if (!empty($categoryId)) {
|
| 957 |
+
|
| 958 |
// merge categories by unspsc
|
| 959 |
$categoryMergedArray = $this->_categoryMapper($categories, $unspscPath);
|
| 960 |
foreach ($categoryMergedArray as $category) {
|
| 961 |
$categoryName = $category['name'];
|
| 962 |
$categoryUnspsc = $category['unspsc'];
|
| 963 |
+
$categoryTreeId = $this->_getCategoryIdByUnspsc($categoryUnspsc,$storeId);
|
| 964 |
// check category name to current store
|
| 965 |
$categoryBindArray = array(
|
| 966 |
':store_id' => 0,
|
| 1037 |
$categoryCreateArray = array();
|
| 1038 |
for ($i = count($categoryMergedArray) - 1; $i >= 0; $i--) {
|
| 1039 |
$category = $categoryMergedArray[$i];
|
| 1040 |
+
$checkCategoryId = $this->_getCategoryIdByUnspsc($category['unspsc'],$storeId);
|
| 1041 |
if ($checkCategoryId != null) {
|
| 1042 |
$categoryId = $this->_buildCategoryTree($checkCategoryId, $storeId, $categoryCreateArray, $categoryActive);
|
| 1043 |
$categoryIds[] = (int)$categoryId;
|
| 1085 |
* @param $unspsc
|
| 1086 |
* @return int|null
|
| 1087 |
*/
|
| 1088 |
+
protected function _getCategoryIdByUnspsc($unspsc,$storeId = 0)
|
| 1089 |
{
|
| 1090 |
if ($unspsc == 'default_root') {
|
| 1091 |
+
return Mage::app()->getStore($storeId)->getRootCategoryId();
|
| 1092 |
} else {
|
| 1093 |
$categoryId = $this->_connRes->fetchRow(
|
| 1094 |
"SELECT entity_id
|
| 1557 |
{
|
| 1558 |
$delete_old_products = (int)Mage::getStoreConfig('iceshop_iceimport_importprod_root/importprod/delete_old_products');
|
| 1559 |
if ($delete_old_products) {
|
| 1560 |
+
|
| 1561 |
try {
|
| 1562 |
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 1563 |
$db_res->query("SELECT @is_iceimport_id := `attribute_id`
|
| 1570 |
ON cpe.entity_id = cpev.entity_id
|
| 1571 |
AND cpev.value = 1
|
| 1572 |
AND cpev.attribute_id = @is_iceimport_id");
|
| 1573 |
+
|
| 1574 |
$count_prod = $count_prod['count_prod'];
|
| 1575 |
|
| 1576 |
if ($count_prod > 0) {
|
| 1585 |
ON cpe.entity_id = iip.product_id
|
| 1586 |
WHERE iip.product_id IS NULL");
|
| 1587 |
|
| 1588 |
+
if(!empty($count_del_prod['count__del_prod'])){
|
| 1589 |
+
$count_del_prod = $count_del_prod['count__del_prod'];
|
| 1590 |
} else {
|
| 1591 |
$count_del_prod = 0;
|
| 1592 |
}
|
| 1593 |
|
| 1594 |
+
$delete_old_products_tolerance = (int)Mage::getStoreConfig('iceshop_iceimport_importprod_root/importprod/delete_old_products_tolerance');
|
| 1595 |
+
|
| 1596 |
if ($count_del_prod > 0) {
|
| 1597 |
//iceimport products to delete exists, amount > 0
|
| 1598 |
$delete_old_products_tolerance = (int)Mage::getStoreConfig('iceshop_iceimport_importprod_root/importprod/delete_old_products_tolerance');
|
| 1614 |
$db_res->query("DELETE FROM {$this->_tablePrefix}iceshop_iceimport_imported_product_ids");
|
| 1615 |
} else {
|
| 1616 |
$error_message = 'Attempt to delete more old products than allowed in Iceimport configuration. Interruption of the process.';
|
| 1617 |
+
$DB_logger->insertLogEntry('error_try_delete_product', $error_message);
|
| 1618 |
+
// $DB_logger->insertLogEntry('error' . md5(microtime(true)), $error_message, 'error');
|
| 1619 |
+
$error_message2 = 'Old product percentage: ' . round(($count_del_prod / $count_prod * 100), 2) . '%';
|
| 1620 |
+
$DB_logger->insertLogEntry('error_try_delete_product_percentage', $error_message2);
|
| 1621 |
+
// $DB_logger->insertLogEntry('error' . md5(microtime(true)), $error_message2, 'error');
|
| 1622 |
print $error_message;
|
| 1623 |
+
print $error_message2;
|
| 1624 |
exit;
|
| 1625 |
}
|
| 1626 |
}
|
| 1670 |
$query = "SELECT ccev.`entity_id` FROM `{$this->_tablePrefix}catalog_category_entity_varchar` AS ccev
|
| 1671 |
LEFT JOIN `{$this->_tablePrefix}eav_attribute` AS ea
|
| 1672 |
ON ea.`attribute_id` = ccev.`attribute_id`
|
| 1673 |
+
WHERE ea.`attribute_code`='unspsc' AND (ccev.`store_id` = 0 OR ccev.`store_id`=:store_id) AND ccev.`value` IS NULL;";
|
| 1674 |
|
| 1675 |
return $this->_connRes->fetchAll($query, array( ':store_id' => $store_id ));
|
| 1676 |
}
|
app/code/community/ICEshop/Iceimport/Model/Dataflow/Convert/Parser/Csv.php
CHANGED
|
@@ -15,8 +15,11 @@ class ICEshop_Iceimport_Model_Dataflow_Convert_Parser_Csv extends Mage_Dataflow_
|
|
| 15 |
|
| 16 |
public function parse()
|
| 17 |
{
|
|
|
|
| 18 |
$DB_logger = Mage::helper('iceimport/db');
|
| 19 |
$date = date('m/d/Y H:i:s');
|
|
|
|
|
|
|
| 20 |
$DB_logger->insertLogEntry('iceimport_import_started', $date);
|
| 21 |
|
| 22 |
$default_attr_set_id = Mage::getModel('catalog/product')->getResource()->getEntityType()->getDefaultAttributeSetId();
|
|
@@ -154,8 +157,37 @@ class ICEshop_Iceimport_Model_Dataflow_Convert_Parser_Csv extends Mage_Dataflow_
|
|
| 154 |
if (isset($skipped_counter)) {
|
| 155 |
$session->unsetData("skipped_counter");
|
| 156 |
}
|
|
|
|
| 157 |
|
| 158 |
return $this;
|
| 159 |
}
|
| 160 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 161 |
}
|
| 15 |
|
| 16 |
public function parse()
|
| 17 |
{
|
| 18 |
+
$this->clearIceimportIds();
|
| 19 |
$DB_logger = Mage::helper('iceimport/db');
|
| 20 |
$date = date('m/d/Y H:i:s');
|
| 21 |
+
$DB_logger->deleteLogEntry('error_try_delete_product');
|
| 22 |
+
$DB_logger->deleteLogEntry('error_try_delete_product_percentage');
|
| 23 |
$DB_logger->insertLogEntry('iceimport_import_started', $date);
|
| 24 |
|
| 25 |
$default_attr_set_id = Mage::getModel('catalog/product')->getResource()->getEntityType()->getDefaultAttributeSetId();
|
| 157 |
if (isset($skipped_counter)) {
|
| 158 |
$session->unsetData("skipped_counter");
|
| 159 |
}
|
| 160 |
+
$this->updateCatalogCategoryChildren();
|
| 161 |
|
| 162 |
return $this;
|
| 163 |
}
|
| 164 |
|
| 165 |
+
|
| 166 |
+
public function clearIceimportIds(){
|
| 167 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 168 |
+
$tablePrefix = '';
|
| 169 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 170 |
+
if (!empty($tPrefix)) {
|
| 171 |
+
$tablePrefix = $tPrefix[0];
|
| 172 |
+
}
|
| 173 |
+
$db_res->query("DELETE FROM {$tablePrefix}iceshop_iceimport_imported_product_ids");
|
| 174 |
+
}
|
| 175 |
+
|
| 176 |
+
|
| 177 |
+
/**
|
| 178 |
+
* Update path to children category/root
|
| 179 |
+
*/
|
| 180 |
+
public function updateCatalogCategoryChildren(){
|
| 181 |
+
try{
|
| 182 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 183 |
+
$tablePrefix = '';
|
| 184 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 185 |
+
if (!empty($tPrefix)) {
|
| 186 |
+
$tablePrefix = $tPrefix[0];
|
| 187 |
+
}
|
| 188 |
+
$db_res->query('UPDATE `'.$tablePrefix.'catalog_category_entity` SET children_count = (SELECT COUNT(*) FROM (SELECT * FROM `'.$tablePrefix.'catalog_category_entity`) AS table2 WHERE path LIKE CONCAT(`'.$tablePrefix.'catalog_category_entity`.path,"/%"));');
|
| 189 |
+
} catch (Exception $e){
|
| 190 |
+
}
|
| 191 |
+
}
|
| 192 |
+
|
| 193 |
}
|
app/code/community/ICEshop/Iceimport/Model/Observer.php
CHANGED
|
@@ -33,10 +33,10 @@ class ICEshop_Iceimport_Model_Observer
|
|
| 33 |
$DB_logger->insertLogEntry('iceimport_import_status_cron', 'Started');
|
| 34 |
$DB_logger->insertLogEntry('iceimport_import_started', $date);
|
| 35 |
$DB_logger->insertLogEntry('iceimport_import_ended', '');
|
|
|
|
|
|
|
| 36 |
$this->setCroneStatus('running',$date_crone_start);
|
| 37 |
|
| 38 |
-
|
| 39 |
-
|
| 40 |
//init DB data
|
| 41 |
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 42 |
$tablePrefix = '';
|
|
@@ -209,5 +209,231 @@ class ICEshop_Iceimport_Model_Observer
|
|
| 209 |
}
|
| 210 |
}
|
| 211 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 212 |
}
|
| 213 |
|
| 33 |
$DB_logger->insertLogEntry('iceimport_import_status_cron', 'Started');
|
| 34 |
$DB_logger->insertLogEntry('iceimport_import_started', $date);
|
| 35 |
$DB_logger->insertLogEntry('iceimport_import_ended', '');
|
| 36 |
+
$DB_logger->deleteLogEntry('error_try_delete_product');
|
| 37 |
+
$DB_logger->deleteLogEntry('error_try_delete_product_percentage');
|
| 38 |
$this->setCroneStatus('running',$date_crone_start);
|
| 39 |
|
|
|
|
|
|
|
| 40 |
//init DB data
|
| 41 |
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 42 |
$tablePrefix = '';
|
| 209 |
}
|
| 210 |
}
|
| 211 |
|
| 212 |
+
|
| 213 |
+
/**
|
| 214 |
+
* Method import imges for product
|
| 215 |
+
*/
|
| 216 |
+
public function importImages(){
|
| 217 |
+
|
| 218 |
+
$DB_logger = Mage::helper('iceimport/db');
|
| 219 |
+
$import_info = array();
|
| 220 |
+
if($_GET['import_run']==1){
|
| 221 |
+
$iceimport_count_images = $this->getCountImagesNotImport($_GET['update_images']);
|
| 222 |
+
$DB_logger->insertLogEntry('iceimport_count_images', $iceimport_count_images);
|
| 223 |
+
} else {
|
| 224 |
+
$iceimport_count_images = $DB_logger->getLogEntryByKey('iceimport_count_images');
|
| 225 |
+
if(!empty($iceimport_count_images)){
|
| 226 |
+
$iceimport_count_images = $iceimport_count_images ['log_value'];
|
| 227 |
+
}
|
| 228 |
+
}
|
| 229 |
+
|
| 230 |
+
$iceimport_current_images_import = $DB_logger->getLogEntryByKey('iceimport_current_images_import');
|
| 231 |
+
if(!empty($iceimport_current_images_import)){
|
| 232 |
+
$iceimport_current_images_import = $iceimport_current_images_import['log_value'];
|
| 233 |
+
}
|
| 234 |
+
|
| 235 |
+
if(empty($iceimport_count_images)){
|
| 236 |
+
$iceimport_count_images = $this->getCountImagesNotImport($_GET['update_images']);
|
| 237 |
+
$DB_logger->insertLogEntry('iceimport_count_images', $iceimport_count_images);
|
| 238 |
+
}
|
| 239 |
+
$import_info['count_images'] = $iceimport_count_images;
|
| 240 |
+
|
| 241 |
+
|
| 242 |
+
if(empty($iceimport_current_images_import)){
|
| 243 |
+
$iceimport_current_images_import = 1;
|
| 244 |
+
$DB_logger->insertLogEntry('iceimport_current_images_import', $iceimport_current_images_import);
|
| 245 |
+
} else {
|
| 246 |
+
$iceimport_current_images_import = $iceimport_current_images_import + 1;
|
| 247 |
+
$DB_logger->insertLogEntry('iceimport_current_images_import', $iceimport_current_images_import);
|
| 248 |
+
}
|
| 249 |
+
if($_GET['import_run']==1){
|
| 250 |
+
$iceimport_current_images_import = 1;
|
| 251 |
+
$DB_logger->insertLogEntry('iceimport_current_images_import', $iceimport_current_images_import);
|
| 252 |
+
}
|
| 253 |
+
$import_info['current_images_import'] = $iceimport_current_images_import;
|
| 254 |
+
|
| 255 |
+
// download & set product images
|
| 256 |
+
$queueList = $this->getImageResourceOne($_GET['update_images']);
|
| 257 |
+
if (count($queueList) > 0) {
|
| 258 |
+
$mediaDir = Mage::getBaseDir('media');
|
| 259 |
+
foreach ($queueList as $queue) {
|
| 260 |
+
$queueId = $queue['queue_id'];
|
| 261 |
+
$productId = $queue['entity_id'];
|
| 262 |
+
$imageUrl = $queue['image_url'];
|
| 263 |
+
|
| 264 |
+
$preImageName = explode('/', $imageUrl);
|
| 265 |
+
$imageName = array_pop($preImageName);
|
| 266 |
+
if (file_exists($mediaDir . DS . $imageName)) {
|
| 267 |
+
$imageName = rand() . '_' . time() . $imageName;
|
| 268 |
+
}
|
| 269 |
+
|
| 270 |
+
if (file_put_contents($mediaDir . DS . $imageName, file_get_contents($imageUrl))) {
|
| 271 |
+
$product = Mage::getModel('catalog/product')->load($productId);
|
| 272 |
+
$product->addImageToMediaGallery($mediaDir . DS . $imageName,
|
| 273 |
+
array('image', 'small_image', 'thumbnail'),
|
| 274 |
+
true, true
|
| 275 |
+
);
|
| 276 |
+
$product->save();
|
| 277 |
+
$this->setImageAsDownloaded($queueId);
|
| 278 |
+
unset($product);
|
| 279 |
+
$import_info['images_error'] = 0;
|
| 280 |
+
} else {
|
| 281 |
+
$this->setImageAsDownloadedError($queueId);
|
| 282 |
+
|
| 283 |
+
$iceimport_images_error_entity_id = $DB_logger->getLogEntryByKey('iceimport_images_error_entity_id');
|
| 284 |
+
if(empty($iceimport_images_error_entity_id)){
|
| 285 |
+
$DB_logger->insertLogEntry('iceimport_images_error_entity_id', $productId);
|
| 286 |
+
$DB_logger->insertLogEntry('iceimport_images_error_entity_id_log', $productId);
|
| 287 |
+
} else {
|
| 288 |
+
if(!empty($iceimport_images_error_entity_id)){
|
| 289 |
+
$iceimport_images_error_entity_id = $iceimport_images_error_entity_id['log_value'];
|
| 290 |
+
$DB_logger->insertLogEntry('iceimport_images_error_entity_id_log', $iceimport_images_error_entity_id . ', ' . $productId);
|
| 291 |
+
$DB_logger->insertLogEntry('iceimport_images_error_entity_id', $iceimport_images_error_entity_id . ', ' . $productId);
|
| 292 |
+
|
| 293 |
+
}
|
| 294 |
+
}
|
| 295 |
+
$import_info['images_error'] = 1;
|
| 296 |
+
$import_info['images_error_text'] = 'Requested file is not accessible. '.$imageUrl;
|
| 297 |
+
}
|
| 298 |
+
}
|
| 299 |
+
$import_info['done'] = 0;
|
| 300 |
+
} else {
|
| 301 |
+
$import_info['done'] = 1;
|
| 302 |
+
if($import_info['count_images'] == 0){
|
| 303 |
+
$import_info['current_images_import'] = 0;
|
| 304 |
+
}
|
| 305 |
+
$DB_logger->deleteLogEntry('iceimport_current_images_import');
|
| 306 |
+
$DB_logger->deleteLogEntry('iceimport_count_images');
|
| 307 |
+
}
|
| 308 |
+
|
| 309 |
+
if($import_info['current_images_import'] == $import_info['count_images'] || $import_info['done'] == 1){
|
| 310 |
+
$import_info['done'] = 1;
|
| 311 |
+
$DB_logger->deleteLogEntry('iceimport_images_error_entity_id');
|
| 312 |
+
$DB_logger->deleteLogEntry('iceimport_current_images_import');
|
| 313 |
+
$DB_logger->deleteLogEntry('iceimport_count_images');
|
| 314 |
+
}elseif ($import_info['count_images'] == 0 || $import_info['current_images_import'] == 0) {
|
| 315 |
+
$import_info['count_images'] = 0;
|
| 316 |
+
$import_info['current_images_import'] = 0;
|
| 317 |
+
|
| 318 |
+
$import_info['done'] = 1;
|
| 319 |
+
$DB_logger->deleteLogEntry('iceimport_current_images_import');
|
| 320 |
+
$DB_logger->deleteLogEntry('iceimport_count_images');
|
| 321 |
+
echo json_encode($import_info);
|
| 322 |
+
exit();
|
| 323 |
+
} else {
|
| 324 |
+
$import_info['done'] = 0;
|
| 325 |
+
}
|
| 326 |
+
echo json_encode($import_info);
|
| 327 |
+
|
| 328 |
+
}
|
| 329 |
+
|
| 330 |
+
/**
|
| 331 |
+
* @return mixed
|
| 332 |
+
*/
|
| 333 |
+
public function getImageResourceOne($update = 0)
|
| 334 |
+
{
|
| 335 |
+
try{
|
| 336 |
+
$DB_logger = Mage::helper('iceimport/db');
|
| 337 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 338 |
+
$tablePrefix = '';
|
| 339 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 340 |
+
if (!empty($tPrefix)) {
|
| 341 |
+
$tablePrefix = $tPrefix[0];
|
| 342 |
+
}
|
| 343 |
+
|
| 344 |
+
$iceimport_images_error_entity_id = $DB_logger->getLogEntryByKey('iceimport_images_error_entity_id');
|
| 345 |
+
if(empty($iceimport_images_error_entity_id)){
|
| 346 |
+
if($update){
|
| 347 |
+
return $db_res->fetchAll("SELECT `queue_id`, `entity_id`, `image_url`
|
| 348 |
+
FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 349 |
+
WHERE `is_downloaded` = 2 LIMIT 1");
|
| 350 |
+
}else{
|
| 351 |
+
return $db_res->fetchAll("SELECT `queue_id`, `entity_id`, `image_url`
|
| 352 |
+
FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 353 |
+
WHERE `is_downloaded` = 0 LIMIT 1");
|
| 354 |
+
}
|
| 355 |
+
|
| 356 |
+
} else {
|
| 357 |
+
$iceimport_images_error_entity_id = $iceimport_images_error_entity_id['log_value'];
|
| 358 |
+
if($update){
|
| 359 |
+
return $db_res->fetchAll("SELECT `queue_id`, `entity_id`, `image_url`
|
| 360 |
+
FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 361 |
+
WHERE `is_downloaded` = 2 AND entity_id NOT IN({$iceimport_images_error_entity_id}) LIMIT 1");
|
| 362 |
+
} else {
|
| 363 |
+
return $db_res->fetchAll("SELECT `queue_id`, `entity_id`, `image_url`
|
| 364 |
+
FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 365 |
+
WHERE `is_downloaded` = 0 AND entity_id NOT IN({$iceimport_images_error_entity_id}) LIMIT 1");
|
| 366 |
+
}
|
| 367 |
+
|
| 368 |
+
}
|
| 369 |
+
|
| 370 |
+
} catch (Exception $e){
|
| 371 |
+
}
|
| 372 |
+
}
|
| 373 |
+
|
| 374 |
+
/**
|
| 375 |
+
* Method fetch count not import images for product
|
| 376 |
+
* @return integer
|
| 377 |
+
*/
|
| 378 |
+
public function getCountImagesNotImport($update = 0){
|
| 379 |
+
try{
|
| 380 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 381 |
+
$tablePrefix = '';
|
| 382 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 383 |
+
if (!empty($tPrefix)) {
|
| 384 |
+
$tablePrefix = $tPrefix[0];
|
| 385 |
+
}
|
| 386 |
+
if($update){
|
| 387 |
+
return $return_resulr = $db_res->fetchOne("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 388 |
+
WHERE `is_downloaded` = 2");
|
| 389 |
+
} else {
|
| 390 |
+
return $return_resulr = $db_res->fetchOne("SELECT COUNT(*) FROM `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 391 |
+
WHERE `is_downloaded` = 0");
|
| 392 |
+
}
|
| 393 |
+
} catch (Exception $e){
|
| 394 |
+
}
|
| 395 |
+
}
|
| 396 |
+
|
| 397 |
+
|
| 398 |
+
|
| 399 |
+
/**
|
| 400 |
+
* @param bool $queueId
|
| 401 |
+
*/
|
| 402 |
+
private function setImageAsDownloaded($queueId = false)
|
| 403 |
+
{
|
| 404 |
+
if ($queueId) {
|
| 405 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 406 |
+
$tablePrefix = '';
|
| 407 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 408 |
+
if (!empty($tPrefix)) {
|
| 409 |
+
$tablePrefix = $tPrefix[0];
|
| 410 |
+
}
|
| 411 |
+
$db_res->query("UPDATE `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 412 |
+
SET is_downloaded = 1
|
| 413 |
+
WHERE queue_id = {$queueId}");
|
| 414 |
+
}
|
| 415 |
+
}
|
| 416 |
+
|
| 417 |
+
|
| 418 |
+
/**
|
| 419 |
+
* @param bool $queueId
|
| 420 |
+
*/
|
| 421 |
+
private function setImageAsDownloadedError($queueId = false)
|
| 422 |
+
{
|
| 423 |
+
if ($queueId) {
|
| 424 |
+
$db_res = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 425 |
+
$tablePrefix = '';
|
| 426 |
+
$tPrefix = (array)Mage::getConfig()->getTablePrefix();
|
| 427 |
+
if (!empty($tPrefix)) {
|
| 428 |
+
$tablePrefix = $tPrefix[0];
|
| 429 |
+
}
|
| 430 |
+
$db_res->query(
|
| 431 |
+
"UPDATE `{$tablePrefix}iceshop_iceimport_image_queue`
|
| 432 |
+
SET is_downloaded = 2
|
| 433 |
+
WHERE queue_id = :queue_id",
|
| 434 |
+
array(':queue_id' => $queueId)
|
| 435 |
+
);
|
| 436 |
+
}
|
| 437 |
+
}
|
| 438 |
}
|
| 439 |
|
app/code/community/ICEshop/Iceimport/controllers/Adminhtml/IceimagesController.php
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
|
| 3 |
+
class Iceshop_Icecatlive_Adminhtml_IceimagesController extends Mage_Adminhtml_Controller_Action
|
| 4 |
+
{
|
| 5 |
+
|
| 6 |
+
public function getGridTable()
|
| 7 |
+
{
|
| 8 |
+
return $this->getResponse()->setBody(
|
| 9 |
+
$this->getLayout()->createBlock('iceimport/adminhtml_images_list_grid')->toHtml()
|
| 10 |
+
);
|
| 11 |
+
}
|
| 12 |
+
}
|
app/code/community/ICEshop/Iceimport/controllers/Adminhtml/IceimportController.php
CHANGED
|
@@ -1,7 +1,14 @@
|
|
| 1 |
<?php
|
| 2 |
-
|
| 3 |
class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Controller_Action
|
| 4 |
{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 5 |
|
| 6 |
/**
|
| 7 |
* indexAction
|
|
@@ -35,20 +42,34 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 35 |
<?php
|
| 36 |
$i = 1;
|
| 37 |
foreach ($problems as $problem_section_name => $problem_section) {
|
| 38 |
-
|
| 39 |
-
|
| 40 |
-
|
| 41 |
-
|
| 42 |
-
|
| 43 |
-
|
| 44 |
-
|
| 45 |
-
|
| 46 |
-
|
| 47 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 48 |
}
|
| 49 |
-
print '</td>';
|
| 50 |
-
print '</tr>';
|
| 51 |
-
$i++;
|
| 52 |
}
|
| 53 |
}
|
| 54 |
?>
|
|
@@ -73,6 +94,10 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 73 |
$data_flows = $DB_checker->getRowCountByField($DB_checker->getTableName('dataflow_batch_import'), 'batch_id', false, ' ORDER BY 1 DESC LIMIT 50');
|
| 74 |
$currently_imported_products = $DB_checker->getRowsCount($DB_checker->_prefix . "iceshop_iceimport_imported_product_ids");
|
| 75 |
$table_name = $DB_checker->getTableName('dataflow_profile_history');
|
|
|
|
|
|
|
|
|
|
|
|
|
| 76 |
$last_started_by_cron = $DB_checker->getLogEntryByKey('iceimport_import_started');
|
| 77 |
$last_finished_by_cron = $DB_checker->getLogEntryByKey('iceimport_import_ended');
|
| 78 |
$import_status_cron = $DB_checker->getLogEntryByKey('iceimport_import_status_cron');
|
|
@@ -140,6 +165,7 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 140 |
<?php if (!empty($last_imported_products_count['log_value'])) echo $last_imported_products_count['log_value']; else echo "0"; ?>
|
| 141 |
</td>
|
| 142 |
</tr>
|
|
|
|
| 143 |
<tr>
|
| 144 |
<td class="label">
|
| 145 |
<label><?php print $helper->__("Removed out of date products last time "); ?>:</label>
|
|
@@ -148,6 +174,17 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 148 |
<?php if (!empty($last_deleted_products_count['log_value'])) echo $last_deleted_products_count['log_value']; else echo "0"; ?>
|
| 149 |
</td>
|
| 150 |
</tr>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 151 |
</table>
|
| 152 |
</div>
|
| 153 |
</div>
|
|
@@ -584,6 +621,63 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 584 |
</div>
|
| 585 |
</div>
|
| 586 |
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 587 |
<style>
|
| 588 |
.requirement-passed {
|
| 589 |
color: green;
|
|
@@ -593,6 +687,97 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 593 |
color: red;
|
| 594 |
}
|
| 595 |
</style>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 596 |
<?php
|
| 597 |
$system_check_content = ob_get_contents();
|
| 598 |
ob_end_clean();
|
|
@@ -885,4 +1070,48 @@ class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Con
|
|
| 885 |
print str_pad('', 100, '=') . "\n";
|
| 886 |
//========================================
|
| 887 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 888 |
}
|
| 1 |
<?php
|
| 2 |
+
require_once 'IceimagesController.php';
|
| 3 |
class ICEshop_Iceimport_Adminhtml_IceimportController extends Mage_Adminhtml_Controller_Action
|
| 4 |
{
|
| 5 |
+
public $_gridTables = NULL;
|
| 6 |
+
|
| 7 |
+
public function _construct() {
|
| 8 |
+
$this->_gridTables = new Iceshop_Icecatlive_Adminhtml_IceimagesController($this->getRequest(), $this->getResponse());
|
| 9 |
+
parent::_construct();
|
| 10 |
+
}
|
| 11 |
+
|
| 12 |
|
| 13 |
/**
|
| 14 |
* indexAction
|
| 42 |
<?php
|
| 43 |
$i = 1;
|
| 44 |
foreach ($problems as $problem_section_name => $problem_section) {
|
| 45 |
+
if($problem_section_name !='iceimport_delete_product'){
|
| 46 |
+
foreach ($problem_section as $problem_name => $problem_value) {
|
| 47 |
+
print '<tr>';
|
| 48 |
+
print '<td class="label">';
|
| 49 |
+
print '<label class="problem-digest">' . $helper->__('Problem') . " " . $i . ':</label>';
|
| 50 |
+
print '</td>';
|
| 51 |
+
print '<td class="value">';
|
| 52 |
+
if ($problem_section_name != 'iceimport_log') {
|
| 53 |
+
print '<span class="requirement-passed">"' . $problem_value['label'] . '"</span> ' . $helper->__('current value is') . ' <span class="requirement-failed">"' . $problem_value['current_value'] . '"</span> ' . $helper->__('and recommended value is') . ' <span class="requirement-passed">"' . (!empty($problem_value['recommended_value']) ? $problem_value['recommended_value'] : '') . '"</span>. ' . $helper->__(' Check this parameter in') . ' <a class="section-toggler-trigger-iceimport requirement-passed" data-href="#' . $problem_section_name . '-section" href="#' . $problem_section_name . '-section">' . ucfirst($problem_section_name) . '</a> ' . $helper->__('section') . '.';
|
| 54 |
+
} else {
|
| 55 |
+
print '<span class="requirement-passed">"' . $problem_value['label'] . '"</span> <span class="requirement-failed">"' . $problem_value['current_value'] . '"</span>. ' . $helper->__(' Check ') . ' <a class="section-toggler-trigger-iceimport requirement-passed" data-href="#' . $problem_section_name . '-section" href="#' . $problem_section_name . '-section">' . ucfirst($problem_section_name) . '</a> ' . $helper->__('section') . '.';
|
| 56 |
+
}
|
| 57 |
+
print '</td>';
|
| 58 |
+
print '</tr>';
|
| 59 |
+
$i++;
|
| 60 |
+
}
|
| 61 |
+
} else {
|
| 62 |
+
foreach ($problem_section as $problem_name => $problem_value) {
|
| 63 |
+
print '<tr>';
|
| 64 |
+
print '<td class="label">';
|
| 65 |
+
print '<label class="problem-digest">' . $helper->__('Problem') . " " . $i . ':</label>';
|
| 66 |
+
print '</td>';
|
| 67 |
+
print '<td class="value">';
|
| 68 |
+
print '<span class="requirement-failed">' . $problem_value['label'] . ': </span> <span class="requirement">' . $problem_value['current_value'] . '</span> ';
|
| 69 |
+
print '</td>';
|
| 70 |
+
print '</tr>';
|
| 71 |
+
$i++;
|
| 72 |
}
|
|
|
|
|
|
|
|
|
|
| 73 |
}
|
| 74 |
}
|
| 75 |
?>
|
| 94 |
$data_flows = $DB_checker->getRowCountByField($DB_checker->getTableName('dataflow_batch_import'), 'batch_id', false, ' ORDER BY 1 DESC LIMIT 50');
|
| 95 |
$currently_imported_products = $DB_checker->getRowsCount($DB_checker->_prefix . "iceshop_iceimport_imported_product_ids");
|
| 96 |
$table_name = $DB_checker->getTableName('dataflow_profile_history');
|
| 97 |
+
|
| 98 |
+
$try_delete_product = $DB_checker->getLogEntryByKey('error_try_delete_product');
|
| 99 |
+
$delete_product_percentage = $DB_checker->getLogEntryByKey('error_try_delete_product_percentage');
|
| 100 |
+
|
| 101 |
$last_started_by_cron = $DB_checker->getLogEntryByKey('iceimport_import_started');
|
| 102 |
$last_finished_by_cron = $DB_checker->getLogEntryByKey('iceimport_import_ended');
|
| 103 |
$import_status_cron = $DB_checker->getLogEntryByKey('iceimport_import_status_cron');
|
| 165 |
<?php if (!empty($last_imported_products_count['log_value'])) echo $last_imported_products_count['log_value']; else echo "0"; ?>
|
| 166 |
</td>
|
| 167 |
</tr>
|
| 168 |
+
|
| 169 |
<tr>
|
| 170 |
<td class="label">
|
| 171 |
<label><?php print $helper->__("Removed out of date products last time "); ?>:</label>
|
| 174 |
<?php if (!empty($last_deleted_products_count['log_value'])) echo $last_deleted_products_count['log_value']; else echo "0"; ?>
|
| 175 |
</td>
|
| 176 |
</tr>
|
| 177 |
+
<?php if(!empty($delete_product_percentage) && !empty($try_delete_product)) { ?>
|
| 178 |
+
<tr>
|
| 179 |
+
<td class="label">
|
| 180 |
+
<label><?php print $helper->__("Attempt to remove a large amount of products "); ?>:</label>
|
| 181 |
+
</td>
|
| 182 |
+
<td class="value">
|
| 183 |
+
<?php echo $try_delete_product['log_value'].$delete_product_percentage['log_value']; ?>
|
| 184 |
+
</td>
|
| 185 |
+
</tr>
|
| 186 |
+
<?php } ?>
|
| 187 |
+
|
| 188 |
</table>
|
| 189 |
</div>
|
| 190 |
</div>
|
| 621 |
</div>
|
| 622 |
</div>
|
| 623 |
</div>
|
| 624 |
+
<?php //Image Statistics ?>
|
| 625 |
+
<span id="iceimport_image-statistics-section"></span>
|
| 626 |
+
<div class="entry-edit">
|
| 627 |
+
<div class="entry-edit-head collapseable">
|
| 628 |
+
<a href="#" class="section-toggler-iceimport">Images Statistics</a>
|
| 629 |
+
</div>
|
| 630 |
+
|
| 631 |
+
<div class="fieldset iceimport-hidden">
|
| 632 |
+
<div class="hor-scroll">
|
| 633 |
+
<table class="form-list" cellspacing="0" cellpadding="0">
|
| 634 |
+
<?php
|
| 635 |
+
$image_statistics = $checker->getImagesStatistics();
|
| 636 |
+
print '<tbody>';
|
| 637 |
+
if(!empty($image_statistics)){
|
| 638 |
+
foreach ($image_statistics as $statistic){
|
| 639 |
+
if($statistic['type'] == 'total_error_download' && $statistic['value'] > 0){
|
| 640 |
+
$update_button = $this->getLayout()->createBlock('iceimport/adminhtml_system_config_form_updatebutton');
|
| 641 |
+
print '<tr>';
|
| 642 |
+
print "<td class=\"label\"><label>{$statistic['label']}</label></td>";
|
| 643 |
+
print "<td class=\"label\"><label>{$statistic['value']}</label></td>";
|
| 644 |
+
print "<td class=\"label\">{$update_button->getButtonHtml()}</td>";
|
| 645 |
+
print '</tr>';
|
| 646 |
+
} else if($statistic['type'] == 'total_waiting_download' && $statistic['value'] > 0){
|
| 647 |
+
$button = $this->getLayout()->createBlock('iceimport/adminhtml_system_config_form_button');
|
| 648 |
+
print '<tr>';
|
| 649 |
+
print "<td class=\"label\"><label>{$statistic['label']}</label></td>";
|
| 650 |
+
print "<td class=\"label\"><label>{$statistic['value']}</label></td>";
|
| 651 |
+
print "<td class=\"label\">{$button->getButtonHtml()}</td>";
|
| 652 |
+
print '</tr>';
|
| 653 |
+
} else {
|
| 654 |
+
if(!empty($statistic['label']) || !empty($statistic['value'])){
|
| 655 |
+
print '<tr>';
|
| 656 |
+
print "<td class=\"label\"><label>{$statistic['label']}</label></td>";
|
| 657 |
+
print "<td class=\"label\"><label>{$statistic['value']}</label></td>";
|
| 658 |
+
print "<td></td>";
|
| 659 |
+
print '</tr>';
|
| 660 |
+
}
|
| 661 |
+
}
|
| 662 |
+
}
|
| 663 |
+
}
|
| 664 |
+
print '</tbody>';
|
| 665 |
+
?>
|
| 666 |
+
</table>
|
| 667 |
+
<div id="gridActionClener" class="hor-scroll">
|
| 668 |
+
<?php
|
| 669 |
+
if(!empty($image_statistics)){
|
| 670 |
+
if(!empty( $image_statistics['total_error_download']['value'])&&$image_statistics['total_error_download']['value']>0){
|
| 671 |
+
$exportall_button = $this->getLayout()->createBlock('iceimport/adminhtml_system_config_form_exportall');
|
| 672 |
+
echo $this->_gridTables->getGridTable().$exportall_button->getButtonHtml();
|
| 673 |
+
|
| 674 |
+
}
|
| 675 |
+
}
|
| 676 |
+
?>
|
| 677 |
+
</div>
|
| 678 |
+
</div>
|
| 679 |
+
</div>
|
| 680 |
+
</div>
|
| 681 |
<style>
|
| 682 |
.requirement-passed {
|
| 683 |
color: green;
|
| 687 |
color: red;
|
| 688 |
}
|
| 689 |
</style>
|
| 690 |
+
<script type="text/javascript">
|
| 691 |
+
|
| 692 |
+
|
| 693 |
+
function import_prod_images(import_run, update){
|
| 694 |
+
$('loading_mask_loader').setStyle({
|
| 695 |
+
width: '430px',
|
| 696 |
+
marginLeft: '-235px',
|
| 697 |
+
top: '25%'
|
| 698 |
+
});
|
| 699 |
+
$('loading-mask').setStyle({
|
| 700 |
+
display: 'inline',
|
| 701 |
+
opacity: '0.90'
|
| 702 |
+
});
|
| 703 |
+
$$('#loading_mask_loader > img')[0].setStyle({
|
| 704 |
+
'display': 'inline'
|
| 705 |
+
});
|
| 706 |
+
var str = $('loading_mask_loader').innerHTML;
|
| 707 |
+
str = str.replace('<br>Please wait...', '');
|
| 708 |
+
$('loading_mask_loader').innerHTML = str;
|
| 709 |
+
|
| 710 |
+
new Ajax.Request('<?php echo Mage::helper("adminhtml")->getUrl("adminhtml/iceimportimages/check/"); ?>', {
|
| 711 |
+
method: 'get',
|
| 712 |
+
parameters: {import_run: import_run, update_images:update},
|
| 713 |
+
onSuccess: function(data){
|
| 714 |
+
var import_info = JSON.parse(data.responseText);
|
| 715 |
+
var images_error_text = '';
|
| 716 |
+
var images_error = import_info.images_error;
|
| 717 |
+
if(images_error){
|
| 718 |
+
images_error_text = '<p> Import images error: ' + import_info.images_error_text + '</p>';
|
| 719 |
+
}
|
| 720 |
+
var iceimport_count_images = '<p> Found images not imported: '+import_info.count_images+'</p>';
|
| 721 |
+
var iceimport_current_images_import = '<p> Current images import: '+import_info.current_images_import+'</p>';
|
| 722 |
+
if(import_info.done != 1){
|
| 723 |
+
if($('loading_mask_loader').select('#iceimport-images-response').size() == 0){
|
| 724 |
+
$('loading_mask_loader').insert({bottom: '<div id="iceimport-images-response" style="text-align: left">'
|
| 725 |
+
+iceimport_count_images
|
| 726 |
+
+iceimport_current_images_import
|
| 727 |
+
+images_error_text
|
| 728 |
+
+'</div>'});
|
| 729 |
+
}else{
|
| 730 |
+
$('iceimport-images-response').replace('<div id="iceimport-images-response" style="text-align: left">'
|
| 731 |
+
+iceimport_count_images
|
| 732 |
+
+iceimport_current_images_import
|
| 733 |
+
+images_error_text
|
| 734 |
+
+'</div>');
|
| 735 |
+
}
|
| 736 |
+
import_prod_images(0,update);
|
| 737 |
+
}else{
|
| 738 |
+
if($('loading_mask_loader').select('#iceimport-images-response').size() == 0){
|
| 739 |
+
$('loading_mask_loader').insert({bottom: '<div id="iceimport-images-response" style="text-align: left">'
|
| 740 |
+
+iceimport_count_images
|
| 741 |
+
+iceimport_current_images_import
|
| 742 |
+
+images_error_text
|
| 743 |
+
+'</div>'
|
| 744 |
+
+'<button id="iceimport_images_button_finish" onclick="javascript:hide_progress_popup(); return false;" title="Finish import" type="button" class="scalable " style=""><span><span><span>Finish import</span></span></span></button>'});
|
| 745 |
+
}else{
|
| 746 |
+
$('iceimport-images-response').replace('<div id="iceimport-images-response" style="text-align: left">'
|
| 747 |
+
+iceimport_count_images
|
| 748 |
+
+iceimport_current_images_import
|
| 749 |
+
+images_error_text
|
| 750 |
+
+'</div>'
|
| 751 |
+
+'<button id="iceimport_images_button_finish" onclick="javascript:hide_progress_popup(); return false;" title="Finish import" type="button" class="scalable " style=""><span><span><span>Finish import</span></span></span></button>');
|
| 752 |
+
}
|
| 753 |
+
$$('#loading_mask_loader > img')[0].setStyle({
|
| 754 |
+
'display': 'none'
|
| 755 |
+
});
|
| 756 |
+
var str = $('loading_mask_loader').innerHTML;
|
| 757 |
+
str = str.replace('<br>Please wait...', '');
|
| 758 |
+
$('loading_mask_loader').innerHTML = str;
|
| 759 |
+
}
|
| 760 |
+
},
|
| 761 |
+
onComplete: function(){
|
| 762 |
+
$('loading_mask').setStyle({
|
| 763 |
+
display: 'none'
|
| 764 |
+
});
|
| 765 |
+
},
|
| 766 |
+
onFailure: function() {
|
| 767 |
+
import_prod_images(1,update);
|
| 768 |
+
}
|
| 769 |
+
});
|
| 770 |
+
}
|
| 771 |
+
|
| 772 |
+
function hide_progress_popup(){
|
| 773 |
+
document.getElementById("iceimport_images_button_finish").remove();
|
| 774 |
+
document.getElementById('iceimport-images-response').innerHTML = '';
|
| 775 |
+
$('loading-mask').setStyle({
|
| 776 |
+
display: 'none'
|
| 777 |
+
});
|
| 778 |
+
}
|
| 779 |
+
|
| 780 |
+
</script>
|
| 781 |
<?php
|
| 782 |
$system_check_content = ob_get_contents();
|
| 783 |
ob_end_clean();
|
| 1070 |
print str_pad('', 100, '=') . "\n";
|
| 1071 |
//========================================
|
| 1072 |
}
|
| 1073 |
+
|
| 1074 |
+
|
| 1075 |
+
/**
|
| 1076 |
+
* Method for export to csv file
|
| 1077 |
+
*/
|
| 1078 |
+
public function exportIceimportimagesCsvAction()
|
| 1079 |
+
{
|
| 1080 |
+
$fileName = 'notimport_images.csv';
|
| 1081 |
+
$grid = $this->getLayout()->createBlock('iceimport/adminhtml_images_list_grid');
|
| 1082 |
+
$grid->setDefaultLimit($grid->getCountImagesNotImport());
|
| 1083 |
+
$this->_prepareDownloadResponse($fileName, $grid->getCsvFile());
|
| 1084 |
+
}
|
| 1085 |
+
|
| 1086 |
+
/**
|
| 1087 |
+
* Method for export to excel file
|
| 1088 |
+
*/
|
| 1089 |
+
public function exportIceimportimagesExcelAction() {
|
| 1090 |
+
$fileName = 'notimport_images.xml';
|
| 1091 |
+
$grid = $this->getLayout()->createBlock('iceimport/adminhtml_images_list_grid');
|
| 1092 |
+
$grid->setDefaultLimit($grid->getCountImagesNotImport());
|
| 1093 |
+
$this->_prepareDownloadResponse($fileName, $grid->getExcelFile($fileName));
|
| 1094 |
+
}
|
| 1095 |
+
|
| 1096 |
+
/**
|
| 1097 |
+
* Images grid for AJAX request
|
| 1098 |
+
*/
|
| 1099 |
+
public function gridAction() {
|
| 1100 |
+
$exportall_button = $this->getLayout()->createBlock('iceimport/adminhtml_system_config_form_exportall');
|
| 1101 |
+
$this->_gridTables->getGridTable().$exportall_button->getButtonHtml();
|
| 1102 |
+
}
|
| 1103 |
+
|
| 1104 |
+
/**
|
| 1105 |
+
* Method for export to csv file
|
| 1106 |
+
*/
|
| 1107 |
+
public function exportIceimportimagesCsvAllAction()
|
| 1108 |
+
{
|
| 1109 |
+
$fileName = 'notimport_images.csv';
|
| 1110 |
+
$grid = $this->getLayout()->createBlock('iceimport/adminhtml_images_list_grid');
|
| 1111 |
+
$grid->setDefaultLimit($grid->getCountImagesNotImport());
|
| 1112 |
+
$this->_prepareDownloadResponse($fileName, $grid->getCsvFile());
|
| 1113 |
+
}
|
| 1114 |
+
|
| 1115 |
+
|
| 1116 |
+
|
| 1117 |
}
|
app/code/community/ICEshop/Iceimport/controllers/Adminhtml/IceimportimagesController.php
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class ICEshop_Iceimport_Adminhtml_IceimportimagesController extends Mage_Adminhtml_Controller_Action
|
| 3 |
+
{
|
| 4 |
+
|
| 5 |
+
|
| 6 |
+
/**
|
| 7 |
+
* Return some checking result
|
| 8 |
+
*
|
| 9 |
+
* @return void
|
| 10 |
+
*/
|
| 11 |
+
public function checkAction()
|
| 12 |
+
{
|
| 13 |
+
|
| 14 |
+
$result = Mage::getModel('iceimport/observer')->importImages();
|
| 15 |
+
Mage::app()->getResponse()->setBody($result);
|
| 16 |
+
}
|
| 17 |
+
|
| 18 |
+
}
|
app/code/community/ICEshop/Iceimport/etc/config.xml
CHANGED
|
@@ -2,7 +2,7 @@
|
|
| 2 |
<config>
|
| 3 |
<modules>
|
| 4 |
<ICEshop_Iceimport>
|
| 5 |
-
<version>1.7.
|
| 6 |
</ICEshop_Iceimport>
|
| 7 |
</modules>
|
| 8 |
<admin>
|
|
@@ -117,7 +117,6 @@
|
|
| 117 |
<delete_old_products>1</delete_old_products>
|
| 118 |
<import_product_ean>1</import_product_ean>
|
| 119 |
<import_product_mpn>1</import_product_mpn>
|
| 120 |
-
<!--<import_product_brand>1</import_product_brand>-->
|
| 121 |
<import_product_brand_name>1</import_product_brand_name>
|
| 122 |
<import_product_name>1</import_product_name>
|
| 123 |
<import_product_short_description>1</import_product_short_description>
|
|
@@ -126,7 +125,6 @@
|
|
| 126 |
<import_product_summary_description>1</import_product_summary_description>
|
| 127 |
<import_prices>1</import_prices>
|
| 128 |
<import_stock>1</import_stock>
|
| 129 |
-
<!--<import_delivery_eta>1</import_delivery_eta>-->
|
| 130 |
<import_product_delivery_eta>1</import_product_delivery_eta>
|
| 131 |
<import_images>1</import_images>
|
| 132 |
<update_categories_from_csv>1</update_categories_from_csv>
|
| 2 |
<config>
|
| 3 |
<modules>
|
| 4 |
<ICEshop_Iceimport>
|
| 5 |
+
<version>1.7.13</version>
|
| 6 |
</ICEshop_Iceimport>
|
| 7 |
</modules>
|
| 8 |
<admin>
|
| 117 |
<delete_old_products>1</delete_old_products>
|
| 118 |
<import_product_ean>1</import_product_ean>
|
| 119 |
<import_product_mpn>1</import_product_mpn>
|
|
|
|
| 120 |
<import_product_brand_name>1</import_product_brand_name>
|
| 121 |
<import_product_name>1</import_product_name>
|
| 122 |
<import_product_short_description>1</import_product_short_description>
|
| 125 |
<import_product_summary_description>1</import_product_summary_description>
|
| 126 |
<import_prices>1</import_prices>
|
| 127 |
<import_stock>1</import_stock>
|
|
|
|
| 128 |
<import_product_delivery_eta>1</import_product_delivery_eta>
|
| 129 |
<import_images>1</import_images>
|
| 130 |
<update_categories_from_csv>1</update_categories_from_csv>
|
app/code/community/ICEshop/Iceimport/sql/iceimport_setup/{mysql4-install-1.7.9.php → mysql4-install-1.7.13}
RENAMED
|
File without changes
|
app/code/community/ICEshop/Iceimport/sql/iceimport_setup/mysql4-upgrade-1.7.9-1.7.13
ADDED
|
@@ -0,0 +1,75 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
include_once 'uninstall-old-version.php';
|
| 3 |
+
$unistaller_old_version = new Uninstall_Capacitywebsolutions_Importproduct();
|
| 4 |
+
$unistaller_old_version->uninstall();
|
| 5 |
+
$installer = $this;
|
| 6 |
+
$installer->startSetup();
|
| 7 |
+
|
| 8 |
+
$entityTypeId = $installer->getEntityTypeId('catalog_category');
|
| 9 |
+
$attributeSetId = $installer->getDefaultAttributeSetId($entityTypeId);
|
| 10 |
+
$attributeGroupId = $installer->getDefaultAttributeGroupId($entityTypeId, $attributeSetId);
|
| 11 |
+
|
| 12 |
+
$installer->addAttribute('catalog_category', 'unspsc', array(
|
| 13 |
+
'type' => 'varchar',
|
| 14 |
+
'label' => 'unspsc',
|
| 15 |
+
'input' => 'text',
|
| 16 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_STORE,
|
| 17 |
+
'visible' => true,
|
| 18 |
+
'required' => false,
|
| 19 |
+
'user_defined' => false,
|
| 20 |
+
'default' => 0
|
| 21 |
+
));
|
| 22 |
+
|
| 23 |
+
$installer->addAttributeToGroup(
|
| 24 |
+
$entityTypeId,
|
| 25 |
+
$attributeSetId,
|
| 26 |
+
$attributeGroupId,
|
| 27 |
+
'unspsc',
|
| 28 |
+
'11'
|
| 29 |
+
);
|
| 30 |
+
|
| 31 |
+
$attributeId = $installer->getAttributeId($entityTypeId, 'unspsc');
|
| 32 |
+
|
| 33 |
+
$installer->run("
|
| 34 |
+
|
| 35 |
+
DROP TABLE IF EXISTS `{$installer->getTable('iceimport_imported_product_ids')}`;
|
| 36 |
+
DROP TABLE IF EXISTS `{$installer->getTable('capacity_product_image_queue')}`;
|
| 37 |
+
DROP TABLE IF EXISTS `{$installer->getTable('iceshop_iceimport_image_queue')}`;
|
| 38 |
+
DROP TABLE IF EXISTS `{$installer->getTable('iceshop_iceimport_imported_product_ids')}`;
|
| 39 |
+
DROP TABLE IF EXISTS `{$installer->getTable('iceshop_extensions_logs')}`;
|
| 40 |
+
|
| 41 |
+
|
| 42 |
+
INSERT IGNORE INTO `{$installer->getTable('catalog_category_entity_varchar')}`
|
| 43 |
+
(`entity_type_id`, `attribute_id`, `entity_id`, `value`)
|
| 44 |
+
SELECT '{$entityTypeId}', '{$attributeId}', `entity_id`, '1'
|
| 45 |
+
FROM `{$installer->getTable('catalog_category_entity')}`;
|
| 46 |
+
|
| 47 |
+
CREATE TABLE IF NOT EXISTS `{$installer->getTable('iceshop_iceimport_image_queue')}` (
|
| 48 |
+
`queue_id` INT(10) NOT NULL AUTO_INCREMENT,
|
| 49 |
+
`entity_id` INT(10) UNSIGNED NOT NULL,
|
| 50 |
+
`image_url` VARCHAR(255) NOT NULL,
|
| 51 |
+
`is_downloaded` TINYINT NOT NULL DEFAULT 0,
|
| 52 |
+
PRIMARY KEY(`queue_id`),
|
| 53 |
+
UNIQUE KEY (`entity_id`, `image_url`),
|
| 54 |
+
CONSTRAINT `FK_CAP_PRD_IMG_QUEUE_ENTT_ID_CAT_PRD_ENTT_ENTT_ID` FOREIGN KEY (`entity_id`) REFERENCES `{$installer->getTable('catalog_product_entity')}` (`entity_id`) ON DELETE CASCADE
|
| 55 |
+
)ENGINE=InnoDB CHARSET=utf8 COMMENT='Table to manage product image import';
|
| 56 |
+
|
| 57 |
+
CREATE TABLE IF NOT EXISTS `{$installer->getTable('iceshop_iceimport_imported_product_ids')}` (
|
| 58 |
+
`product_id` int(11) NOT NULL,
|
| 59 |
+
`product_sku` varchar(255) DEFAULT NULL,
|
| 60 |
+
KEY `pi_idx` (`product_id`)
|
| 61 |
+
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
| 62 |
+
|
| 63 |
+
CREATE TABLE IF NOT EXISTS {$installer->getTable('iceshop_extensions_logs')} (
|
| 64 |
+
`log_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
|
| 65 |
+
`log_key` VARCHAR(255) NOT NULL,
|
| 66 |
+
`log_value` TEXT,
|
| 67 |
+
`log_type` VARCHAR(10) NOT NULL DEFAULT 'info',
|
| 68 |
+
`timecol` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
| 69 |
+
UNIQUE KEY (`log_key`),
|
| 70 |
+
KEY `IDX_LOG_TYPE` (`log_type`),
|
| 71 |
+
KEY `IDX_TIMECOL` (`timecol`)
|
| 72 |
+
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Iceshop Connector logs';
|
| 73 |
+
");
|
| 74 |
+
|
| 75 |
+
$installer->endSetup();
|
package.xml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
| 1 |
<?xml version="1.0"?>
|
| 2 |
<package>
|
| 3 |
<name>ice_import</name>
|
| 4 |
-
<version>1.7.
|
| 5 |
<stability>stable</stability>
|
| 6 |
<license uri="http://opensource.org/licenses/osl-3.0.php">OSL v.3</license>
|
| 7 |
<channel>community</channel>
|
|
@@ -9,12 +9,14 @@
|
|
| 9 |
<summary>Import categories & productsr</summary>
|
| 10 |
<description>This extension can use to import products with categories, multiple images and custom options from CSV file.</description>
|
| 11 |
<notes>Improvements:
|
| 12 |
-
-
|
| 13 |
-
-
|
|
|
|
|
|
|
| 14 |
<authors><author><name>IceShop</name><user>IceShop</user><email>support@iceshop.nl</email></author></authors>
|
| 15 |
-
<date>2015-04-
|
| 16 |
-
<time>
|
| 17 |
-
<contents><target name="magedesign"><dir name="adminhtml"><dir name="default"><dir name="default"><dir name="layout"><file name="ICEshop_Iceimport.xml" hash="566089f8d3a54436ae62ebd4c5124293"/></dir><dir name="template"><dir name="iceshop"><dir name="iceimport"><file name="notifications.phtml" hash="3d9336ffcd90d11a34271d01b0b7fa9e"/></dir></dir></dir></dir></dir></dir></target><target name="
|
| 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>ice_import</name>
|
| 4 |
+
<version>1.7.13</version>
|
| 5 |
<stability>stable</stability>
|
| 6 |
<license uri="http://opensource.org/licenses/osl-3.0.php">OSL v.3</license>
|
| 7 |
<channel>community</channel>
|
| 9 |
<summary>Import categories & productsr</summary>
|
| 10 |
<description>This extension can use to import products with categories, multiple images and custom options from CSV file.</description>
|
| 11 |
<notes>Improvements:
|
| 12 |
+
- Added import errors indication.
|
| 13 |
+
- Added grid for not imported images.
|
| 14 |
+
- Added method to run only images import.
|
| 15 |
+
- Added statistics import images.</notes>
|
| 16 |
<authors><author><name>IceShop</name><user>IceShop</user><email>support@iceshop.nl</email></author></authors>
|
| 17 |
+
<date>2015-04-29</date>
|
| 18 |
+
<time>12:54:45</time>
|
| 19 |
+
<contents><target name="magedesign"><dir name="adminhtml"><dir name="default"><dir name="default"><dir name="layout"><file name="ICEshop_Iceimport.xml" hash="566089f8d3a54436ae62ebd4c5124293"/></dir><dir name="template"><dir name="iceshop"><dir name="iceimport"><file name="notifications.phtml" hash="3d9336ffcd90d11a34271d01b0b7fa9e"/></dir></dir></dir></dir></dir></dir></target><target name="magecommunity"><dir name="ICEshop"><dir name="Iceimport"><dir name="Block"><dir name="Adminhtml"><dir name="Images"><dir name="List"><file name="Grid.php" hash="93aec656c6751a65cfefc2f8ebf473b7"/></dir></dir><file name="Notifications.php" hash="4355538a30333b5c61cfe1550ae0129b"/><dir name="System"><dir name="Config"><dir name="Form"><file name="Button.php" hash="056987a5987c129ccaeff6c04df8678d"/><file name="Exportall.php" hash="c329655e2fc2d0983688699adc400976"/><file name="Updatebutton.php" hash="8400ab44d28d6bf95ddca6dd5a0bd73c"/></dir></dir></dir></dir></dir><dir name="Helper"><file name="Data.php" hash="fd9775a248481ddd683926452affb9ff"/><file name="Db.php" hash="564941a7ee03c28f46d282681c0c7c10"/><file name="Format.php" hash="5c56ce9db24076c52b198325fb637758"/><dir name="System"><file name="System.php" hash="ff58fc97338b95e165de85ef640147de"/><file name="Systemcheck.php" hash="e87560c1f4b5de926b0b1aa3f60411b3"/></dir></dir><dir name="Model"><dir name="Convert"><dir name="Adapter"><file name="Product.php" hash="9281722241e6c4a8e3ec45a0383896c8"/></dir></dir><dir name="Dataflow"><dir name="Batch"><file name="Import.php" hash="52c0ed7367b2200a17a48103e953ae58"/></dir><dir name="Convert"><dir name="Parser"><file name="Csv.php" hash="052c8c5a800ab4a11c7ca60a45fd81ba"/></dir></dir></dir><file name="Observer.php" hash="64d712737e4d535d39d79127e2d02fb7"/><dir name="System"><dir name="Config"><file name="Checksystem.php" hash="260200dc8cecfa718b32fa47468282df"/><file name="Defaulttax.php" hash="898bf21060622bf8dc96469eb018c463"/><file name="Iceshoplink.php" hash="e77e62b0c00e2569ea5fdb0fb91ff90a"/><file name="Yesno.php" hash="59e349561a36e02f44b47301fce99ef5"/></dir></dir></dir><dir name="controllers"><dir name="Adminhtml"><file name="IceimagesController.php" hash="b43840720cb8fca823addc60402047ae"/><file name="IceimportController.php" hash="c36e98a83d726dbda41182af26f987a9"/><file name="IceimportimagesController.php" hash="441910744c4e8fb4e509caf5cc845a72"/></dir></dir><dir name="etc"><file name="adminhtml.xml" hash="2990ebf927b0476b7702731ad2979682"/><file name="config.xml" hash="20f10a52c443ee09685a85d53d58e7a0"/><file name="system.xml" hash="7d9ca6cae327ed02bebebaa54c686439"/></dir><dir name="sql"><dir name="iceimport_setup"><file name="mysql4-install-1.7.13" hash="e5b8e89aea9a674f0cd25718d5d62a1c"/><file name="mysql4-upgrade-0.1.0-1.7.0.php" hash="ff0682cde32b4f694bf1bed2c55a97f6"/><file name="mysql4-upgrade-1.4.0-1.7.0.php" hash="ff0682cde32b4f694bf1bed2c55a97f6"/><file name="mysql4-upgrade-1.5.0-1.7.0.php" hash="b51e20fdab764b90c6fd81551d9e368f"/><file name="mysql4-upgrade-1.6.0-1.7.0.php" hash="b51e20fdab764b90c6fd81551d9e368f"/><file name="mysql4-upgrade-1.6.0-1.7.5.php" hash="73e2587c366b1d3940d08e2a65dcc253"/><file name="mysql4-upgrade-1.7.5-1.7.9.php" hash="73e2587c366b1d3940d08e2a65dcc253"/><file name="mysql4-upgrade-1.7.6-1.7.9.php" hash="73e2587c366b1d3940d08e2a65dcc253"/><file name="mysql4-upgrade-1.7.9-1.7.13" hash="e5b8e89aea9a674f0cd25718d5d62a1c"/><file name="uninstall-old-version.php" hash="4269e8547005958b044946d5e2d670e9"/></dir></dir></dir></dir></target><target name="mage"><dir name="js"><dir name="ICEshop"><dir name="Iceimport"><file name="jquery-1.11.1.min.js" hash="056fd2a776eae867b7e2b5ddcb754d78"/><file name="script.js" hash="dabaaf1b4924cb8a2fd4e14de93f74e6"/></dir></dir></dir><dir name="skin"><dir name="adminhtml"><dir name="default"><dir name="default"><dir name="iceshop"><dir name="iceimport"><dir name="images"><file name="iceshop_logo_small_16px.png" hash="4ef632b4b89a047789307b301b9dfb6e"/></dir><file name="styles.css" hash="0136e37ac22d82753fafec8294bc8555"/></dir></dir></dir></dir></dir></dir></target><target name="mageetc"><dir name="modules"><file name="ICEshop_Iceimport.xml" hash="b94f339b79303bf7e78ba89290c66ada"/></dir></target></contents>
|
| 20 |
<compatible/>
|
| 21 |
<dependencies><required><php><min>5.2.0</min><max>6.0.0</max></php></required></dependencies>
|
| 22 |
</package>
|
