diff --git a/intaro.intarocrm/classes/general/ICMLLoader.php b/intaro.intarocrm/classes/general/ICMLLoader.php
new file mode 100644
index 00000000..c2ee5c29
--- /dev/null
+++ b/intaro.intarocrm/classes/general/ICMLLoader.php
@@ -0,0 +1,331 @@
+iblocks = json_decode($iblocks, true);
+ $loader->filename = $filename;
+ $loader->application = $APPLICATION;
+ $loader->Load();
+ $arIblocks = "'" . $iblocks . "'";
+ $arFilename = "'" . $filename . "'";
+ return "ICMLLoader::AgentLoad(" . $arIblocks . ", " . $arFilename . ");";
+ }
+ public function Load()
+ {
+ $categories = $this->GetCategories();
+
+ $offers = $this->GetOffers();
+
+ /*foreach ($offers as $obj)
+ if (is_array($obj))
+ foreach ($obj as $obj2)
+ print(htmlspecialcharsbx($obj2) . "
");
+ else
+ print(htmlspecialcharsbx($obj) . "
");
+ */
+
+
+ $this->PrepareFile();
+
+ $this->PreWriteCatalog();
+
+ $this->WriteCategories($categories);
+ $this->WriteOffers($offers);
+
+ $this->PostWriteCatalog();
+
+ $this->CloseFile();
+
+ }
+
+ protected function PrepareValue($text)
+ {
+
+ //$text = htmlspecialcharsbx($text);
+ //$text = str_replace('"', '"', $text);
+ //$text = preg_replace("/[\x1-\x8\xB-\xC\xE-\x1F]/", "", $text);
+ //$text = str_replace("'", "'", $text);
+ $text = $this->application->ConvertCharset($text, LANG_CHARSET, $this->encoding);
+ return $text;
+ }
+
+ protected function PrepareFile()
+ {
+ $fullFilename = $_SERVER["DOCUMENT_ROOT"] . $this->filename;
+ CheckDirPath($fullFilename);
+
+ if (!$this->fp = @fopen($fullFilename, "w"))
+ return false;
+ else
+ return true;
+ }
+
+ protected function PreWriteCatalog()
+ {
+ @fwrite($this->fp, "\n");
+ @fwrite($this->fp, "\n");
+
+ @fwrite($this->fp, "".$this->application->ConvertCharset(htmlspecialcharsbx(COption::GetOptionString("main", "site_name", "")), LANG_CHARSET, $encoding)."\n");
+
+ @fwrite($this->fp, "".$this->application->ConvertCharset(htmlspecialcharsbx(COption::GetOptionString("main", "site_name", "")), LANG_CHARSET, $encoding)."\n");
+
+ }
+
+ protected function WriteCategories($categories)
+ {
+ @fwrite($this->fp, "\n");
+ foreach ($categories as $category) {
+ @fwrite($this->fp, $category . "\n");
+ }
+ @fwrite($this->fp, "\n");
+ }
+ protected function WriteOffers($offers)
+ {
+ @fwrite($this->fp, "\n");
+ foreach ($offers as $offer) {
+ @fwrite($this->fp, $offer . "\n");
+ }
+ @fwrite($this->fp, "\n");
+ }
+
+ protected function PostWriteCatalog()
+ {
+ @fwrite($this->fp, "\n");
+ @fwrite($this->fp, "\n");
+ }
+
+ protected function CloseFile()
+ {
+ @fclose($this->fp);
+ }
+
+
+ protected function GetCategories()
+ {
+ $categories = array();
+ foreach ($this->iblocks as $id)
+ {
+ $filter = Array(
+ "IBLOCK_ID" => $id,
+ "ACTIVE" => "Y",
+ "IBLOCK_ACTIVE" => "Y",
+ "GLOBAL_ACTIVE" => "Y"
+ );
+
+
+ $dbRes = CIBlockSection::GetList(array("left_margin" => "asc"), $filter);
+ while ($arRes = $dbRes->Fetch())
+ {
+ $categories[] = $this->BuildCategory($arRes);
+ }
+ }
+ return $categories;
+
+ }
+
+ protected function BuildCategory($arCategory)
+ {
+ return "
+ 0 ?
+ " parentId=\"" . $arCategory["IBLOCK_SECTION_ID"] . "\""
+ :"")
+ . ">"
+ . $arCategory["NAME"]
+ . "";
+
+ }
+
+ protected function GetOffers()
+ {
+ $offers = Array();
+ foreach ($this->iblocks as $key => $id)
+ {
+
+ $iblock['IBLOCK_DB'] = CIBlock::GetByID($id)->Fetch();
+ $iblockOffer = CCatalogSKU::GetInfoByProductIBlock($id);
+
+
+ $arSelect = Array (
+ "ID",
+ "LID",
+ "IBLOCK_ID",
+ "IBLOCK_SECTION_ID",
+ "ACTIVE",
+ "ACTIVE_FROM",
+ "ACTIVE_TO",
+ "NAME",
+ "DETAIL_PICTURE",
+ "DETAIL_TEXT",
+ "DETAIL_PICTURE",
+ "LANG_DIR",
+ "DETAIL_PAGE_URL",
+ "PROPERTY_" . $this->articleProperties[$key]
+ );
+
+ $filter = Array (
+ "IBLOCK_ID" => $id,
+ "ACTIVE_DATE" => "Y",
+ "ACTIVE" => "Y",
+ "INCLUDE_SUBSECTIONS" => "Y"
+ );
+ $counter = 0;
+ $dbResProducts = CIBlockElement::GetList(array(), $filter, false, false, $arSelect);
+ while ($product = $dbResProducts->GetNextElement()) {
+
+ $product = $product->GetFields();
+
+ $categoriesString = "";
+
+
+ $existOffer = false;
+ if (!empty($iblockOffer['IBLOCK_ID'])) {
+ $arFilterOffer = Array (
+ 'IBLOCK_ID' => $iblockOffer['IBLOCK_ID'],
+ 'PROPERTY_'.$iblockOffer['SKU_PROPERTY_ID'] => $product["ID"]
+ );
+ $arSelectOffer = Array (
+ 'ID',
+ "NAME",
+ "DETAIL_TEXT",
+ "DETAIL_PAGE_URL",
+ "DETAIL_PICTURE",
+ "PROPERTY_" . $this->articleProperties[$key]
+ );
+
+ $rsOffers = CIBlockElement::GetList(array(), $arFilterOffer, false, false, $arSelectOffer);
+ while ($arOffer = $rsOffers->GetNext()) {
+
+ $dbResCategories = CIBlockElement::GetElementGroups($arOffer['ID'], true);
+ while ($arResCategory = $dbResCategories->Fetch()) {
+ $categoriesString .= "" . $arResCategory["ID"] . "\n";
+ }
+ $offer = CCatalogProduct::GetByID($arOffer['ID']);
+ $arOffer['QUANTITY'] = $offer["QUANTITY"];
+
+ $arOffer['PRODUCT_ID'] = $product["ID"];
+ $arOffer['DETAIL_PAGE_URL'] = $product["DETAIL_PAGE_URL"];
+ $arOffer['DETAIL_PICTURE'] = $product["DETAIL_PICTURE"];
+ $arOffer['PREVIEW_PICTURE'] = $product["PREVIEW_PICTURE"];
+ $arOffer['PRODUCT_NAME'] = $product["NAME"];
+ $arOffer['ARTICLE'] = $arOffer["PROPERTY_" . $this->articleProperties[$key] . "_VALUE"];
+
+ $dbPrice = GetCatalogProductPrice($arOffer["ID"],1);
+ $arOffer['PRICE'] = $dbPrice['PRICE'];
+
+
+
+ $offers[] = $this->BuildOffer($arOffer, $categoriesString, $iblock);
+ $existOffer = true;
+ }
+ }
+ if (!$existOffer) {
+ $dbResCategories = CIBlockElement::GetElementGroups($product["ID"], true);
+ while ($arResCategory = $dbResCategories->Fetch()) {
+ $categoriesString .= "" . $arResCategory["ID"] . "\n";
+ }
+
+
+ $offer = CCatalogProduct::GetByID($product['ID']);
+ $product['QUANTITY'] = $offer["QUANTITY"];
+
+ $product['PRODUCT_ID'] = $product["ID"];
+ $product['PRODUCT_NAME'] = $product["NAME"];
+ $product['ARTICLE'] = $product["PROPERTY_" . $this->articleProperties[$key] . "_VALUE"];
+
+ $dbPrice = GetCatalogProductPrice($product["ID"],1);
+ $product['PRICE'] = $dbPrice['PRICE'];
+
+ $offers[] = $this->BuildOffer($product, $categoriesString, $iblock);
+ }
+ }
+ }
+ return $offers;
+ }
+
+
+ protected function BuildOffer($arOffer, $categoriesString, $iblock)
+ {
+ $offer = "";
+ $offer .= "\n";
+ $offer .= "http://" . $iblock['IBLOCK_DB']['SERVER_NAME'] . $arOffer['DETAIL_PAGE_URL'] . "\n";
+
+ $offer .= "" . $arOffer['PRICE'] . "\n";
+ $offer .= $categoriesString;
+
+ $detailPicture = intval($arOffer["DETAIL_PICTURE"]);
+ $previewPicture = intval($arOffer["PREVIEW_PICTURE"]);
+
+ if ($detailPicture > 0 || $previewPicture > 0)
+ {
+ $picture = $detailPicture;
+ if ($picture <= 0) {
+ $picture = $previewPicture;
+ }
+
+ if ($arFile = CFile::GetFileArray($picture))
+ {
+ if(substr($arFile["SRC"], 0, 1) == "/")
+ $strFile = "http://" . $iblock['IBLOCK_DB']['SERVER_NAME'] . implode("/", array_map("rawurlencode", explode("/", $arFile["SRC"])));
+ elseif(preg_match("/^(http|https):\\/\\/(.*?)\\/(.*)\$/", $arFile["SRC"], $match))
+ $strFile = "http://" . $match[2] . '/' . implode("/", array_map("rawurlencode", explode("/", $match[3])));
+ else
+ $strFile = $arFile["SRC"];
+ $offer .= "" . $strFile . "\n";
+ }
+ }
+
+ $offer .= "" . $this->PrepareValue($arOffer["NAME"]) . "\n";
+ $offer .= "" . (strip_tags( html_entity_decode(str_replace(" ", ' ', $this->PrepareValue($arOffer["DETAIL_TEXT"]))))) .
+ "\n";
+
+
+ $offer .= "" . $arOffer["EXTERNAL_ID"] . "\n";
+ $offer .= "" . $arOffer["PRODUCT_NAME"] . "\n";
+ $offer .= "" . $arOffer["ARTICLE"] . "\n";
+
+ $offer.= "\n";
+ return $offer;
+ }
+
+
+
+}
\ No newline at end of file
diff --git a/intaro.intarocrm/include.php b/intaro.intarocrm/include.php
index 0851bb33..34c55087 100755
--- a/intaro.intarocrm/include.php
+++ b/intaro.intarocrm/include.php
@@ -4,6 +4,7 @@ CModule::AddAutoloadClasses(
array (
'IntaroCrm\RestApi' => 'classes/general/RestApi.php',
'ICrmOrderActions' => 'classes/general/ICrmOrderActions.php',
+ 'ICMLLoader' => 'classes/general/ICMLLoader.php',
'ICrmOrderEvent' => 'classes/general/events/ICrmOrderEvent.php'
)
);
\ No newline at end of file
diff --git a/intaro.intarocrm/install/export/intarocrm_run.php b/intaro.intarocrm/install/export/intarocrm_run.php
deleted file mode 100755
index 6b3b6b08..00000000
--- a/intaro.intarocrm/install/export/intarocrm_run.php
+++ /dev/null
@@ -1,1906 +0,0 @@
-
-//
IntaroCRM
-__IncludeLang(GetLangFileName($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/intaro.intarocrm/lang/", "/export_crm.php"));
-set_time_limit(0);
-
-
-CModule::IncludeModule("iblock");
-$db_res = CIBlock::GetList(Array("IBLOCK_TYPE"=>"ASC", "NAME"=>"ASC"),array('CHECK_PERMISSIONS' => 'Y','MIN_PERMISSION' => 'W'));
-$IBLOCK_ID = Array();
-while ($res = $db_res->Fetch())
-{
- if ($arCatalog = CCatalog::GetByIDExt($res["ID"]))
- {
- $arCat = CCatalog::GetByIDExt($res["ID"]);
- if($arCat['CATALOG_TYPE'] == "D" || $arCat['CATALOG_TYPE'] == "X" || $arCat['CATALOG_TYPE'] == "P")
- $arIBlockId[] = $res["ID"];
-
-
- }
-}
-
-global $USER, $APPLICATION;
-$bTmpUserCreated = false;
-if (!isset($USER) || !(($USER instanceof CUser) && ('CUser' == get_class($USER))))
-{
- $bTmpUserCreated = true;
- if (isset($USER))
- {
- $USER_TMP = $USER;
- unset($USER);
- }
-
- $USER = new CUser();
-}
-
-CCatalogDiscountSave::Disable();
-
-$arYandexFields = array('vendor', 'vendorCode', 'model', 'author', 'name','product_name','xml_id',
- 'publisher', 'series', 'year', 'ISBN', 'volume', 'part',
- 'language', 'binding', 'page_extent', 'table_of_contents',
- 'performed_by', 'performance_type', 'storage', 'format',
- 'recording_length', 'artist', 'title', 'year', 'media',
- 'starring', 'director', 'originalName', 'country', 'aliases',
- 'description', 'sales_notes', 'promo', 'provider', 'tarifplan',
- 'xCategory', 'additional', 'worldRegion', 'region', 'days', 'dataTour',
- 'hotel_stars', 'room', 'meal', 'included', 'transport', 'price_min',
- 'price_max', 'options', 'manufacturer_warranty', 'country_of_origin',
- 'downloadable', 'param', 'place', 'hall', 'hall_part', 'is_premiere',
- 'is_kids', 'date');
-
-if (!function_exists("yandex_replace_special"))
-{
- function yandex_replace_special($arg)
- {
- if (in_array($arg[0], array(""", "&", "<", ">")))
- return $arg[0];
- else
- return " ";
- }
-}
-
-if (!function_exists("yandex_text2xml"))
-{
- function yandex_text2xml($text, $bHSC = false, $bDblQuote = false)
- {
- global $APPLICATION;
-
- $bHSC = (true == $bHSC ? true : false);
- $bDblQuote = (true == $bDblQuote ? true: false);
-
- if ($bHSC)
- {
- $text = htmlspecialcharsbx($text);
- if ($bDblQuote)
- $text = str_replace('"', '"', $text);
- }
- $text = preg_replace("/[\x1-\x8\xB-\xC\xE-\x1F]/", "", $text);
- $text = str_replace("'", "'", $text);
- $text = $APPLICATION->ConvertCharset($text, LANG_CHARSET, 'windows-1251');
- return $text;
- }
-}
-
-if (!function_exists('yandex_get_value'))
-{
- function yandex_get_value($arOffer, $param, $PROPERTY, $IBLOCK_ID)
- {
-
- static $arProperties = null, $arUserTypes = null;
-
- if (!is_array($arProperties))
- {
- $dbRes = CIBlockProperty::GetList(
- array('ID' => 'ASC'),
- array('IBLOCK_ID' => $IBLOCK_ID, 'CHECK_PERMISSIONS' => 'N')
- );
-
- while ($arRes = $dbRes->Fetch())
- {
- $arProperties[$arRes['ID']] = $arRes;
- }
-
- if (!empty($arOffer['IBLOCK_ID']) && $arOffer['IBLOCK_ID'] != $IBLOCK_ID)
- {
- $dbRes = CIBlockProperty::GetList(
- array('ID' => 'ASC'),
- array('IBLOCK_ID' => $arOffer['IBLOCK_ID'], 'CHECK_PERMISSIONS' => 'N')
- );
-
- while ($arRes = $dbRes->Fetch())
- {
- $arProperties[$arRes['ID']] = $arRes;
- }
- }
- }
-
- $strProperty = '';
- $bParam = substr($param, 0, 6) == 'PARAM_';
- if (is_array($arProperties[$PROPERTY]))
- {
- $PROPERTY_CODE = $arProperties[$PROPERTY]['CODE'];
-
- $arProperty = $arOffer['PROPERTIES'][$PROPERTY_CODE] ? $arOffer['PROPERTIES'][$PROPERTY_CODE] : $arOffer['PROPERTIES'][$PROPERTY];
-
- $value = '';
- $description = '';
- switch ($arProperties[$PROPERTY]['PROPERTY_TYPE'])
- {
- case 'E':
- if (!empty($arProperty['VALUE']))
- {
- $arCheckValue = array();
- if (!is_array($arProperty['VALUE']))
- {
- $arProperty['VALUE'] = intval($arProperty['VALUE']);
- if (0 < $arProperty['VALUE'])
- $arCheckValue[] = $arProperty['VALUE'];
- }
- else
- {
- foreach ($arProperty['VALUE'] as &$intValue)
- {
- $intValue = intval($intValue);
- if (0 < $intValue)
- $arCheckValue[] = $intValue;
- }
- if (isset($intValue))
- unset($intValue);
- }
- if (!empty($arCheckValue))
- {
- $dbRes = CIBlockElement::GetList(array(), array('IBLOCK_ID' => $arProperties[$PROPERTY]['LINK_IBLOCK_ID'], 'ID' => $arCheckValue), false, false, array('NAME'));
- while ($arRes = $dbRes->Fetch())
- {
- $value .= ($value ? ', ' : '').$arRes['NAME'];
- }
- }
- }
- break;
- case 'G':
- if (!empty($arProperty['VALUE']))
- {
- $arCheckValue = array();
- if (!is_array($arProperty['VALUE']))
- {
- $arProperty['VALUE'] = intval($arProperty['VALUE']);
- if (0 < $arProperty['VALUE'])
- $arCheckValue[] = $arProperty['VALUE'];
- }
- else
- {
- foreach ($arProperty['VALUE'] as &$intValue)
- {
- $intValue = intval($intValue);
- if (0 < $intValue)
- $arCheckValue[] = $intValue;
- }
- if (isset($intValue))
- unset($intValue);
- }
- if (!empty($arCheckValue))
- {
- $dbRes = CIBlockSection::GetList(array(), array('IBLOCK_ID' => $arProperty['LINK_IBLOCK_ID'], 'ID' => $arCheckValue), false, array('NAME'));
- while ($arRes = $dbRes->Fetch())
- {
- $value .= ($value ? ', ' : '').$arRes['NAME'];
- }
- }
- }
- break;
- case 'L':
- if ($arProperty['VALUE'])
- {
- if (is_array($arProperty['VALUE']))
- $value .= implode(', ', $arProperty['VALUE']);
- else
- $value .= $arProperty['VALUE'];
- }
- break;
- default:
- if ($bParam && $arProperty['WITH_DESCRIPTION'] == 'Y')
- {
- $description = $arProperty['DESCRIPTION'];
- $value = $arProperty['VALUE'];
- }
- else
- {
- $value = is_array($arProperty['VALUE']) ? implode(', ', $arProperty['VALUE']) : $arProperty['VALUE'];
- }
- }
-
- // !!!! check multiple properties and properties like CML2_ATTRIBUTES
-
- if ($bParam)
- {
- if (is_array($description))
- {
- foreach ($value as $key => $val)
- {
- $strProperty .= $strProperty ? "\n" : "";
- $strProperty .= ''.yandex_text2xml($val, true).'';
- }
- }
- else
- {
- $strProperty .= ''.yandex_text2xml($value, true).'';
- }
- }
- else
- {
- $param_h = yandex_text2xml($param, true);
- $strProperty .= '<'.$param_h.'>'.yandex_text2xml($value, true).''.$param_h.'>';
- }
- }
-
- return $strProperty;
- //if (is_callable(array($arParams["arUserField"]["USER_TYPE"]['CLASS_NAME'], 'getlist')))
- }
-}
-
-$arRunErrors = array();
-
-if ($XML_DATA && CheckSerializedData($XML_DATA))
-{
- $XML_DATA = unserialize(stripslashes($XML_DATA));
- if (!is_array($XML_DATA)) $XML_DATA = array();
-}
-
-$XML_DATA = Array();
-foreach ($arIBlockId as $id)
-{
- $IBLOCK_ID = $id;
- $IBLOCK_ID = intval($IBLOCK_ID);
-
-
- $XML_DATA[$IBLOCK_ID]["TYPE"] = null;
- $XML_DATA[$IBLOCK_ID]["CURRENCY"] = Array (
- "RUB" => Array (
- "rate" => SITE,
- "plus" => null
- )
- );
- $XML_DATA[$IBLOCK_ID]["XML_DATA"] = Array();
- $XML_DATA[$IBLOCK_ID]["SKU_EXPORT"] = Array (
- "SKU_URL_TEMPLATE_TYPE" => 1,
- "SKU_URL_TEMPLATE" => null,
- "SKU_EXPORT_COND" => 1,
- "SKU_PROP_COND" => Array (
- "PROP_ID" => 0,
- "COND" => null,
- "VALUES" => Array()
- )
- );
-
- $properties = CIBlockProperty::GetList(
- Array(),
- Array(
- "ACTIVE"=>"Y",
- "IBLOCK_ID"=>$IBLOCK_ID,
- "CODE" => "ARTICLE"
- )
- )->Fetch();
-
- $XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS'][] = $properties['ID'];
-
- $db_iblock = CIBlock::GetByID($IBLOCK_ID);
- $ar_iblock[$IBLOCK_ID] = $db_iblock->Fetch();
- if (!($ar_iblock[$IBLOCK_ID]))
- {
- $arRunErrors[] = str_replace('#ID#', $IBLOCK_ID, GetMessage('YANDEX_ERR_NO_IBLOCK_FOUND_EXT'));
- }
- /*elseif (!CIBlockRights::UserHasRightTo($IBLOCK_ID, $IBLOCK_ID, 'iblock_admin_display'))
- {
- $arRunErrors[] = str_replace('#IBLOCK_ID#',$IBLOCK_ID,GetMessage('CET_ERROR_IBLOCK_PERM'));
- } */
- else
- {
- $SETUP_SERVER_NAME = trim($SETUP_SERVER_NAME);
-
- if (strlen($SETUP_SERVER_NAME) <= 0)
- {
- if (strlen($ar_iblock[$IBLOCK_ID]['SERVER_NAME']) <= 0)
- {
- $rsSite = CSite::GetList(($b="sort"), ($o="asc"), array("LID" => $ar_iblock[$IBLOCK_ID]["LID"]));
- if($arSite = $rsSite->Fetch())
- $ar_iblock[$IBLOCK_ID]["SERVER_NAME"] = $arSite["SERVER_NAME"];
- if(strlen($ar_iblock[$IBLOCK_ID]["SERVER_NAME"])<=0 && defined("SITE_SERVER_NAME"))
- $ar_iblock[$IBLOCK_ID]["SERVER_NAME"] = SITE_SERVER_NAME;
- if(strlen($ar_iblock[$IBLOCK_ID]["SERVER_NAME"])<=0)
- $ar_iblock[$IBLOCK_ID]["SERVER_NAME"] = COption::GetOptionString("main", "server_name", "");
- }
- }
- else
- {
- $ar_iblock[$IBLOCK_ID]['SERVER_NAME'] = $SETUP_SERVER_NAME;
- }
- $ar_iblock[$IBLOCK_ID]['PROPERTY'] = array();
- $rsProps = CIBlockProperty::GetList(array(),array('IBLOCK_ID' => $IBLOCK_ID, 'ACTIVE' => 'Y'));
- while ($arProp = $rsProps->Fetch())
- {
- $ar_iblock[$IBLOCK_ID]['PROPERTY'][$arProp['ID']] = $arProp;
- }
- }
-}
-$boolOffers = false;
-$arOffers = false;
-$arOfferIBlock = false;
-$intOfferIBlockID = 0;
-$arSelectOfferProps = array();
-$arSelectedPropTypes = array('S','N','L','E','G');
-$arOffersSelectKeys = array(
- YANDEX_SKU_EXPORT_ALL,
- YANDEX_SKU_EXPORT_MIN_PRICE,
- YANDEX_SKU_EXPORT_PROP,
-);
-$arCondSelectProp = array(
- 'ZERO',
- 'NONZERO',
- 'EQUAL',
- 'NONEQUAL',
-);
-$arPropertyMap = array();
-$arSKUExport = array();
-
-
-foreach ($arIBlockId as $id)
-{
- $IBLOCK_ID = $id;
- $arCatalog[$IBLOCK_ID] = CCatalog::GetByIDExt($IBLOCK_ID);
- if (empty($arCatalog[$IBLOCK_ID]))
- {
- $arRunErrors[] = str_replace('#ID#', $IBLOCK_ID, GetMessage('YANDEX_ERR_NO_IBLOCK_IS_CATALOG'));
- }
- else
- {
- $arOffers[$IBLOCK_ID] = CCatalogSKU::GetInfoByProductIBlock($IBLOCK_ID);
- if (!empty($arOffers[$IBLOCK_ID]['IBLOCK_ID']))
- {
- $intOfferIBlockID = $arOffers[$IBLOCK_ID]['IBLOCK_ID'];
- $rsOfferIBlocks = CIBlock::GetByID($intOfferIBlockID);
- if (($arOfferIBlock = $rsOfferIBlocks->Fetch()))
- {
- $boolOffers = true;
- $rsProps = CIBlockProperty::GetList(array('SORT' => 'ASC'),array('IBLOCK_ID' => $intOfferIBlockID,'ACTIVE' => 'Y'));
- while ($arProp = $rsProps->Fetch())
- {
- if ($arOffers[$IBLOCK_ID]['SKU_PROPERTY_ID'] != $arProp['ID'])
- {
- $ar_iblock[$IBLOCK_ID]['OFFERS_PROPERTY'][$arProp['ID']] = $arProp;
- if (in_array($arProp['PROPERTY_TYPE'],$arSelectedPropTypes))
- $arSelectOfferProps[] = $arProp['ID'];
- if (strlen($arProp['CODE']) > 0)
- {
- foreach ($ar_iblock[$IBLOCK_ID]['PROPERTY'] as &$arMainProp)
- {
- if ($arMainProp['CODE'] == $arProp['CODE'])
- {
- $arPropertyMap[$arProp['ID']] = $arMainProp['CODE'];
- break;
- }
- }
- if (isset($arMainProp))
- unset($arMainProp);
- }
- }
- }
- $arOfferIBlock['LID'] = $ar_iblock[$IBLOCK_ID]['LID'];
- }
- else
- {
- $arRunErrors[] = GetMessage('YANDEX_ERR_BAD_OFFERS_IBLOCK_ID');
- }
- }
- if (true == $boolOffers)
- {
- if (empty($XML_DATA[$IBLOCK_ID]['SKU_EXPORT']))
- {
- $arRunErrors[] = GetMessage('YANDEX_ERR_SKU_SETTINGS_ABSENT');
- }
- else
- {
- $arSKUExport = $XML_DATA[$IBLOCK_ID]['SKU_EXPORT'];;
- if (empty($arSKUExport['SKU_EXPORT_COND']) || !in_array($arSKUExport['SKU_EXPORT_COND'],$arOffersSelectKeys))
- {
- $arRunErrors[] = GetMessage('YANDEX_SKU_EXPORT_ERR_CONDITION_ABSENT');
- }
- if (YANDEX_SKU_EXPORT_PROP == $arSKUExport['SKU_EXPORT_COND'])
- {
- if (empty($arSKUExport['SKU_PROP_COND']) || !is_array($arSKUExport['SKU_PROP_COND']))
- {
- $arRunErrors[] = GetMessage('YANDEX_SKU_EXPORT_ERR_PROPERTY_ABSENT');
- }
- else
- {
- if (empty($arSKUExport['SKU_PROP_COND']['PROP_ID']) || !in_array($arSKUExport['SKU_PROP_COND']['PROP_ID'],$arSelectOfferProps))
- {
- $arRunErrors[] = GetMessage('YANDEX_SKU_EXPORT_ERR_PROPERTY_ABSENT');
- }
- if (empty($arSKUExport['SKU_PROP_COND']['COND']) || !in_array($arSKUExport['SKU_PROP_COND']['COND'],$arCondSelectProp))
- {
- $arRunErrors[] = GetMessage('YANDEX_SKU_EXPORT_ERR_PROPERTY_COND_ABSENT');
- }
- else
- {
- if ($arSKUExport['SKU_PROP_COND']['COND'] == 'EQUAL' || $arSKUExport['SKU_PROP_COND']['COND'] == 'NONEQUAL')
- {
- if (empty($arSKUExport['SKU_PROP_COND']['VALUES']))
- {
- $arRunErrors[] = GetMessage('YANDEX_SKU_EXPORT_ERR_PROPERTY_VALUES_ABSENT');
- }
- }
- }
- }
- }
- }
- }
-
- }
-}
-$V = Array (0);
-if (empty($arRunErrors))
-{
- $bAllSections = False;
- $arSections = array();
- if (is_array($V))
- {
- foreach ($V as $key => $value)
- {
- if (trim($value)=="0")
- {
- $bAllSections = True;
- break;
- }
-
- if (intval($value)>0)
- {
- $arSections[] = intval($value);
- }
- }
- }
-
- if (!$bAllSections && count($arSections)<=0)
- {
- $arRunErrors[] = GetMessage('YANDEX_ERR_NO_SECTION_LIST');
- }
-}
-
-if (!empty($XML_DATA[$IBLOCK_ID]['PRICE']))
-{
- if (intval($XML_DATA[$IBLOCK_ID]['PRICE']) > 0)
- {
- $rsCatalogGroups = CCatalogGroup::GetGroupsList(array('CATALOG_GROUP_ID' => $XML_DATA[$IBLOCK_ID]['PRICE'],'GROUP_ID' => 2));
- if (!($arCatalogGroup = $rsCatalogGroups->Fetch()))
- {
- $arRunErrors[] = GetMessage('YANDEX_ERR_BAD_PRICE_TYPE');
- }
- }
- else
- {
- $arRunErrors[] = GetMessage('YANDEX_ERR_BAD_PRICE_TYPE');
- }
-}
-
-if (strlen($SETUP_FILE_NAME) <= 0)
-{
- $arRunErrors[] = GetMessage("CATI_NO_SAVE_FILE");
-}
-elseif (preg_match(BX_CATALOG_FILENAME_REG,$SETUP_FILE_NAME))
-{
- $arRunErrors[] = GetMessage("CES_ERROR_BAD_EXPORT_FILENAME");
-}
-else
-{
- $SETUP_FILE_NAME = Rel2Abs("/", $SETUP_FILE_NAME);
-}
-if (empty($arRunErrors))
-{
-/* if ($GLOBALS["APPLICATION"]->GetFileAccessPermission($SETUP_FILE_NAME) < "W")
- {
- $arRunErrors[] = str_replace('#FILE#', $SETUP_FILE_NAME,GetMessage('YANDEX_ERR_FILE_ACCESS_DENIED'));
- } */
-}
-
-if (empty($arRunErrors))
-{
- CheckDirPath($_SERVER["DOCUMENT_ROOT"].$SETUP_FILE_NAME);
-
- if (!$fp = @fopen($_SERVER["DOCUMENT_ROOT"].$SETUP_FILE_NAME, "wb"))
- {
- $arRunErrors[] = str_replace('#FILE#', $_SERVER["DOCUMENT_ROOT"].$SETUP_FILE_NAME, GetMessage('YANDEX_ERR_FILE_OPEN_WRITING'));
- }
- else
- {
-
- if (!@fwrite($fp, ''))
- {
- $arRunErrors[] = str_replace('#FILE#', $_SERVER["DOCUMENT_ROOT"].$SETUP_FILE_NAME, GetMessage('YANDEX_ERR_SETUP_FILE_WRITE'));
- @fclose($fp);
- }
- else
- {
- fwrite($fp, ' $strReferer1 = htmlspecialchars($_GET["referer1"]); ?>');
- fwrite($fp, '');
- fwrite($fp, ' $strReferer2 = htmlspecialchars($_GET["referer2"]); ?>');
- }
- }
-}
-
-if (empty($arRunErrors))
-{
-
-
- @fwrite($fp, ' header("Content-Type: text/xml; charset=windows-1251");?>');
- @fwrite($fp, ' echo "<"."?xml version=\"1.0\" encoding=\"windows-1251\"?".">"?>');
- @fwrite($fp, "\n\n");
- @fwrite($fp, "\n");
- @fwrite($fp, "\n");
-
- @fwrite($fp, "".$APPLICATION->ConvertCharset(htmlspecialcharsbx(COption::GetOptionString("main", "site_name", "")), LANG_CHARSET, 'windows-1251')."\n");
-
- @fwrite($fp, "".$APPLICATION->ConvertCharset(htmlspecialcharsbx(COption::GetOptionString("main", "site_name", "")), LANG_CHARSET, 'windows-1251')."\n");
- @fwrite($fp, "http://".htmlspecialcharsbx($ar_iblock[$IBLOCK_ID]['SERVER_NAME'])."\n");
-
- $strTmp = "\n";
-
- if ($arCurrency = CCurrency::GetByID('RUR'))
- $RUR = 'RUR';
- else
- $RUR = 'RUB';
-
- $arCurrencyAllowed = array($RUR, 'USD', 'EUR', 'UAH', 'BYR', 'KZT');
-
- $BASE_CURRENCY = CCurrency::GetBaseCurrency();
- if (is_array($XML_DATA[$IBLOCK_ID]['CURRENCY']))
- {
- foreach ($XML_DATA[$IBLOCK_ID]['CURRENCY'] as $CURRENCY => $arCurData)
- {
- if (in_array($CURRENCY, $arCurrencyAllowed))
- {
- $strTmp.= " 0 ? ' plus="'.intval($arCurData['plus']).'"' : '')
- ." />\n";
- }
- }
- }
- else
- {
- $db_acc = CCurrency::GetList(($by="sort"), ($order="asc"));
- while ($arAcc = $db_acc->Fetch())
- {
- if (in_array($arAcc['CURRENCY'], $arCurrencyAllowed))
- $strTmp.= "\n";
- }
- }
- $strTmp.= "\n";
-
- @fwrite($fp, $strTmp);
-
- //*****************************************//
-
-
- //*****************************************//
- $intMaxSectionID = 0;
-
- $strTmpCat = "";
- $strTmpOff = "";
-
- $arAvailGroups[$IBLOCK_ID] = array();
- /*if (!$bAllSections)
- {
- for ($i = 0, $intSectionsCount = count($arSections); $i < $intSectionsCount; $i++)
- {
- $filter_tmp = $filter;
- $db_res = CIBlockSection::GetNavChain($IBLOCK_ID, $arSections[$i]);
- $curLEFT_MARGIN = 0;
- $curRIGHT_MARGIN = 0;
- while ($ar_res = $db_res->Fetch())
- {
- $curLEFT_MARGIN = intval($ar_res["LEFT_MARGIN"]);
- $curRIGHT_MARGIN = intval($ar_res["RIGHT_MARGIN"]);
- $arAvailGroups[$ar_res["ID"]] = array(
- "ID" => intval($ar_res["ID"]),
- "IBLOCK_SECTION_ID" => intval($ar_res["IBLOCK_SECTION_ID"]),
- "NAME" => $ar_res["NAME"]
- );
- if ($intMaxSectionID < $ar_res["ID"])
- $intMaxSectionID = $ar_res["ID"];
- }
-
- $filter = Array("IBLOCK_ID"=>$IBLOCK_ID, ">LEFT_MARGIN"=>$curLEFT_MARGIN, "$curRIGHT_MARGIN, "ACTIVE"=>"Y", "IBLOCK_ACTIVE"=>"Y", "GLOBAL_ACTIVE"=>"Y");
- $db_res = CIBlockSection::GetList(array("left_margin"=>"asc"), $filter);
- while ($ar_res = $db_res->Fetch())
- {
- $arAvailGroups[$ar_res["ID"]] = array(
- "ID" => intval($ar_res["ID"]),
- "IBLOCK_SECTION_ID" => intval($ar_res["IBLOCK_SECTION_ID"]),
- "NAME" => $ar_res["NAME"]
- );
- if ($intMaxSectionID < $ar_res["ID"])
- $intMaxSectionID = $ar_res["ID"];
- }
- }
- }
- else
- {*/
- //}
- foreach ($arIBlockId as $id)
- {
- $IBLOCK_ID = $id;
- $filter = Array("IBLOCK_ID"=>$IBLOCK_ID, "ACTIVE"=>"Y", "IBLOCK_ACTIVE"=>"Y", "GLOBAL_ACTIVE"=>"Y");
- $db_res = CIBlockSection::GetList(array("left_margin"=>"asc"), $filter);
- while ($ar_res = $db_res->Fetch())
- {
- $arAvailGroups[$IBLOCK_ID][$ar_res["ID"]] = array(
- "ID" => intval($ar_res["ID"]),
- "IBLOCK_SECTION_ID" => intval($ar_res["IBLOCK_SECTION_ID"]),
- "NAME" => $ar_res["NAME"]
- );
- if ($intMaxSectionID < $ar_res["ID"])
- $intMaxSectionID = $ar_res["ID"];
- }
-
-
- $arSectionIDs = array();
- foreach ($arAvailGroups[$IBLOCK_ID] as &$value)
- {
- $strTmpCat.= "0?" parentId=\"".$value["IBLOCK_SECTION_ID"]."\"":"").">".yandex_text2xml($value["NAME"], true)."\n";
- }
- if (isset($value))
- unset($value);
-
- if (!empty($arAvailGroups[$IBLOCK_ID]))
- $arSectionIDs = array_keys($arAvailGroups[$IBLOCK_ID]);
-
- $intMaxSectionID += 100000000;
-
- //*****************************************//
- $boolNeedRootSection = false;
-
-
- if ('D' == $arCatalog[$IBLOCK_ID]['CATALOG_TYPE'] || 'O' == $arCatalog[$IBLOCK_ID]['CATALOG_TYPE'])
- {
- $arSelect = array("ID", "LID", "IBLOCK_ID", "IBLOCK_SECTION_ID", "ACTIVE", "ACTIVE_FROM", "ACTIVE_TO", "NAME", "PREVIEW_PICTURE", "PREVIEW_TEXT", "PREVIEW_TEXT_TYPE", "DETAIL_PICTURE", "LANG_DIR", "DETAIL_PAGE_URL");
-
- $filter = Array("IBLOCK_ID"=>$IBLOCK_ID, "ACTIVE_DATE"=>"Y", "ACTIVE"=>"Y");
- if (!$bAllSections)
- {
- $filter["INCLUDE_SUBSECTIONS"] = "Y";
- $filter["SECTION_ID"] = $arSectionIDs;
- }
- $res = CIBlockElement::GetList(array(), $filter, false, false, $arSelect);
-
- $total_sum = 0;
- $is_exists = false;
- $cnt = 0;
-
- while ($obElement = $res->GetNextElement())
- {
- $arAcc = $obElement->GetFields();
- if (is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']))
- {
- $arAcc["PROPERTIES"] = $obElement->GetProperties();
- }
- $arAcc['CATALOG_QUANTITY'] = '';
- $arAcc['CATALOG_QUANTITY_TRACE'] = 'N';
- $arProduct = CCatalogProduct::GetByID($arAcc['ID']);
-
- if (!empty($arProduct))
- {
- $arAcc['CATALOG_QUANTITY'] = $arProduct['QUANTITY'];
- $arAcc['CATALOG_QUANTITY_TRACE'] = $arProduct['QUANTITY_TRACE'];
- }
- $str_QUANTITY = DoubleVal($arAcc["CATALOG_QUANTITY"]);
- $str_QUANTITY_TRACE = $arAcc["CATALOG_QUANTITY_TRACE"];
- if (($str_QUANTITY <= 0) && ($str_QUANTITY_TRACE == "Y"))
- $str_AVAILABLE = ' available="false"';
- else
- $str_AVAILABLE = ' available="true"';
-
- $minPrice = 0;
- $minPriceRUR = 0;
- $minPriceGroup = 0;
- $minPriceCurrency = "";
-
- if ($XML_DATA[$IBLOCK_ID]['PRICE'] > 0)
- {
- $rsPrices = CPrice::GetListEx(array(),array(
- 'PRODUCT_ID' => $arAcc['ID'],
- 'CATALOG_GROUP_ID' => $XML_DATA[$IBLOCK_ID]['PRICE'],
- 'CAN_BUY' => 'Y',
- 'GROUP_GROUP_ID' => array(2),
- '+<=QUANTITY_FROM' => 1,
- '+>=QUANTITY_TO' => 1,
- )
- );
- if ($arPrice = $rsPrices->Fetch())
- {
- /*$dbVAT = CCatalogProduct::GetVATInfo($arAcc['ID']);
- if ($arVat = $dbVAT->Fetch())
- {
- $arVat['RATE'] = floatval($arVat['RATE'] * 0.01);
- }
- else
- {
- $arVat = array('RATE' => 0, 'VAT_INCLUDED' => 'N');
- }
- $arPrice['VAT_RATE'] = $arVat['RATE'];
- $arPrice['VAT_INCLUDED'] = $arVat['VAT_INCLUDED'];
- if ($arPrice['VAT_INCLUDED'] == 'N')
- {
- $arPrice['PRICE'] *= (1 + $arPrice['VAT_RATE']);
- $arPrice['VAT_INCLUDED'] = 'Y';
- }
- $arPrice['PRICE'] = roundEx($arPrice['PRICE'], CATALOG_VALUE_PRECISION);
- $arDiscounts = CCatalogDiscount::GetDiscount(
- $arAcc['ID'],
- $IBLOCK_ID,
- array($XML_DATA[$IBLOCK_ID]['PRICE']),
- array(2),
- 'N',
- $ar_iblock['LID'],
- false
- );
- $minPrice = CCatalogProduct::CountPriceWithDiscount($arPrice['PRICE'], $arPrice["CURRENCY"], $arDiscounts);
- $minPriceGroup = $arPrice['CATALOG_GROUP_ID'];
- $minPriceCurrency = $arPrice["CURRENCY"];
- $minPriceRUR = CCurrencyRates::ConvertCurrency($arPrice['PRICE'], $arPrice["CURRENCY"], $RUR);
- */
- if ($arOptimalPrice = CCatalogProduct::GetOptimalPrice(
- $arAcc['ID'],
- 1,
- array(2), // anonymous
- 'N',
- array($arPrice),
- $ar_iblock['LID']
- ))
- {
- $minPrice = $arOptimalPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arOptimalPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
- }
- else
- {
- if ($arPrice = CCatalogProduct::GetOptimalPrice(
- $arAcc['ID'],
- 1,
- array(2), // anonymous
- 'N',
- array(),
- $ar_iblock[$IBLOCK_ID]['LID']
- ))
- {
- $minPrice = $arPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
-
- if ($minPrice <= 0) continue;
-
- $boolCurrentSections = false;
- $bNoActiveGroup = True;
- $strTmpOff_tmp = "";
- $db_res1 = CIBlockElement::GetElementGroups($arAcc["ID"], true);
- while ($ar_res1 = $db_res1->Fetch())
- {
- $boolCurrentSections = true;
- if (in_array(intval($ar_res1["ID"]), $arSectionIDs))
- {
- $strTmpOff_tmp.= "".$ar_res1["ID"]."\n";
- $bNoActiveGroup = False;
-
- }
- }
- if (false == $boolCurrentSections)
- {
- $boolNeedRootSection = true;
- $strTmpOff_tmp.= "".$intMaxSectionID."\n";
- }
- else
- {
- if ($bNoActiveGroup)
- continue;
- }
-
- if (strlen($arAcc['DETAIL_PAGE_URL']) <= 0)
- $arAcc['DETAIL_PAGE_URL'] = '/';
- else
- $arAcc['DETAIL_PAGE_URL'] = str_replace(' ', '%20', $arAcc['DETAIL_PAGE_URL']);
-
- if (is_array($XML_DATA[$IBLOCK_ID]) && $XML_DATA[$IBLOCK_ID]['TYPE'] && $XML_DATA[$IBLOCK_ID]['TYPE'] != 'none')
- $str_TYPE = ' type="'.htmlspecialcharsbx($XML_DATA[$IBLOCK_ID]['TYPE']).'"';
- else
- $str_TYPE = '';
-
- if (!isset($arProduct["ID"]))
- continue;
-
- $strTmpOff.= "\n";
- $strTmpOff.= "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].htmlspecialcharsbx($arAcc["~DETAIL_PAGE_URL"]).(strstr($arAcc['DETAIL_PAGE_URL'], '?') === false ? '?' : '&')."r1=&r2=\n";
-
- $strTmpOff.= "".$minPrice."\n";
- $strTmpOff.= "".$minPriceCurrency."\n";
-
- $strTmpOff.= $strTmpOff_tmp;
-
- if (intval($arAcc["DETAIL_PICTURE"])>0 || intval($arAcc["PREVIEW_PICTURE"])>0)
- {
- $pictNo = intval($arAcc["DETAIL_PICTURE"]);
- if ($pictNo<=0) $pictNo = intval($arAcc["PREVIEW_PICTURE"]);
-
- if ($ar_file = CFile::GetFileArray($pictNo))
- {
- if(substr($ar_file["SRC"], 0, 1) == "/")
- $strFile = "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].implode("/", array_map("rawurlencode", explode("/", $ar_file["SRC"])));
- elseif(preg_match("/^(http|https):\\/\\/(.*?)\\/(.*)\$/", $ar_file["SRC"], $match))
- $strFile = "http://".$match[2].'/'.implode("/", array_map("rawurlencode", explode("/", $match[3])));
- else
- $strFile = $ar_file["SRC"];
- $strTmpOff.="".$strFile."\n";
- }
- }
-
- $y = 0;
- foreach ($arYandexFields as $key)
- {
- switch ($key)
- {
- case 'name':
- if (is_array($XML_DATA[$IBLOCK_ID]) && ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model' || $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'))
- continue;
-
- $strTmpOff .= "".yandex_text2xml($arAcc["NAME"], true)."\n";
- break;
- case 'description':
- $strTmpOff .=
- "".
- yandex_text2xml(TruncateText(
- ($arAcc["PREVIEW_TEXT_TYPE"]=="html"?
- strip_tags(preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arAcc["~PREVIEW_TEXT"])) : preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arAcc["~PREVIEW_TEXT"])),
- 255), true).
- "\n";
- break;
- case 'param':
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS']))
- {
- foreach ($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS'] as $key => $prop_id)
- {
-
- $strParamValue = '';
- if ($prop_id)
- {
- $strParamValue = yandex_get_value($arAcc, 'PARAM_'.$key, $prop_id, $IBLOCK_ID);
- }
- if ('' != $strParamValue)
- $strTmpOff .= $strParamValue."\n";
- }
- }
- break;
- case 'xml_id':
-
-
- $strTmpOff .= "".yandex_text2xml($arAcc["EXTERNAL_ID"], true)."\n";
- break;
- case 'product_name':
- $strTmpOff .= "".yandex_text2xml($arAcc["NAME"], true)."\n";
- break;
- case 'model':
- case 'title':
- if (!is_array($XML_DATA[$IBLOCK_ID]) || !is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) || !$XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- if (
- $key == 'model' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model'
- ||
- $key == 'title' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'
- )
-
- $strTmpOff.= "<".$key.">".yandex_text2xml($arAcc["NAME"], true)."".$key.">\n";
- }
- else
- {
- $strValue = '';
- $strValue = yandex_get_value($arAcc, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strTmpOff .= $strValue."\n";
- }
- break;
- case 'year':
- $y++;
- if ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title')
- {
- if ($y == 1) continue;
- }
- else
- {
- if ($y > 1) continue;
- }
-
- // no break here
-
- default:
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- $strValue = '';
- $strValue = yandex_get_value($arAcc, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strTmpOff .= $strValue."\n";
- }
- }
- }
-
- $strTmpOff.= "\n";
- }
- }
- elseif ('P' == $arCatalog[$IBLOCK_ID]['CATALOG_TYPE'] || 'X' == $arCatalog[$IBLOCK_ID]['CATALOG_TYPE'])
- {
- $arOfferSelect = array("ID", "LID", "IBLOCK_ID", "ACTIVE", "NAME", "PREVIEW_PICTURE", "PREVIEW_TEXT", "PREVIEW_TEXT_TYPE", "DETAIL_PICTURE", "DETAIL_PAGE_URL");
- $arOfferFilter = array('IBLOCK_ID' => $intOfferIBlockID, 'PROPERTY_'.$arOffers[$IBLOCK_ID]['SKU_PROPERTY_ID'] => 0, "ACTIVE" => "Y", "ACTIVE_DATE" => "Y");
- if (YANDEX_SKU_EXPORT_PROP == $arSKUExport['SKU_EXPORT_COND'])
- {
- $strExportKey = '';
- $mxValues = false;
- if ($arSKUExport['SKU_PROP_COND']['COND'] == 'NONZERO' || $arSKUExport['SKU_PROP_COND']['COND'] == 'NONEQUAL')
- $strExportKey = '!';
- $strExportKey .= 'PROPERTY_'.$arSKUExport['SKU_PROP_COND']['PROP_ID'];
- if ($arSKUExport['SKU_PROP_COND']['COND'] == 'EQUAL' || $arSKUExport['SKU_PROP_COND']['COND'] == 'NONEQUAL')
- $mxValues = $arSKUExport['SKU_PROP_COND']['VALUES'];
- $arOfferFilter[$strExportKey] = $mxValues;
- }
-
- $arSelect = array("ID", "LID", "IBLOCK_ID", "IBLOCK_SECTION_ID", "ACTIVE", "ACTIVE_FROM", "ACTIVE_TO", "NAME", "PREVIEW_PICTURE", "PREVIEW_TEXT", "PREVIEW_TEXT_TYPE", "DETAIL_PICTURE", "DETAIL_PAGE_URL");
- $arFilter = Array("IBLOCK_ID"=>$IBLOCK_ID, "ACTIVE_DATE"=>"Y", "ACTIVE"=>"Y");
- if (!$bAllSections)
- {
- $arFilter["INCLUDE_SUBSECTIONS"] = "Y";
- $arFilter["SECTION_ID"] = $arSectionIDs;
- }
-
-
- $strOfferTemplateURL = '';
- if (!empty($arSKUExport['SKU_URL_TEMPLATE_TYPE']))
- {
- switch($arSKUExport['SKU_URL_TEMPLATE_TYPE'])
- {
- case YANDEX_SKU_TEMPLATE_PRODUCT:
- $strOfferTemplateURL = '#PRODUCT_URL#';
- break;
- case YANDEX_SKU_TEMPLATE_CUSTOM:
- if (!empty($arSKUExport['SKU_URL_TEMPLATE']))
- $strOfferTemplateURL = $arSKUExport['SKU_URL_TEMPLATE'];
- break;
- case YANDEX_SKU_TEMPLATE_OFFERS:
- default:
- $strOfferTemplateURL = '';
- break;
- }
- }
-
- $rsItems = CIBlockElement::GetList(array(), $arFilter, false, false, $arSelect);
-
- while ($obItem = $rsItems->GetNextElement())
- {
- $arItem = $obItem->GetFields();
-
- $arItem['PROPERTIES'] = $obItem->GetProperties();
- if (!empty($arItem['PROPERTIES']))
- {
- $arCross = array();
- foreach ($arItem['PROPERTIES'] as &$arProp)
- {
- $arCross[$arProp['ID']] = $arProp;
- }
- if (isset($arProp))
- unset($arProp);
- $arItem['PROPERTIES'] = $arCross;
- }
- $boolItemExport = false;
- $boolItemOffers = false;
- $arItem['OFFERS'] = array();
-
- $boolCurrentSections = false;
- $boolNoActiveSections = true;
- $strSections = '';
- $rsSections = CIBlockElement::GetElementGroups($arItem["ID"]);
- while ($arSection = $rsSections->Fetch())
- {
- $boolCurrentSections = true;
- if (in_array(intval($arSection["ID"]), $arSectionIDs))
- {
- $strSections .= "".$arSection["ID"]."\n";
- $boolNoActiveSections = false;
- }
- }
- if (false == $boolCurrentSections)
- {
- $boolNeedRootSection = true;
- $strSections .= "".$intMaxSectionID."\n";
- }
- else
- {
- if ($boolNoActiveSections)
- continue;
- }
-
- $arItem['YANDEX_CATEGORY'] = $strSections;
-
- $strFile = '';
- if (intval($arItem["DETAIL_PICTURE"])>0 || intval($arItem["PREVIEW_PICTURE"])>0)
- {
- $pictNo = intval($arItem["DETAIL_PICTURE"]);
- if ($pictNo <= 0)
- $pictNo = intval($arItem["PREVIEW_PICTURE"]);
-
- if ($ar_file = CFile::GetFileArray($pictNo))
- {
- if(substr($ar_file["SRC"], 0, 1) == "/")
- $strFile = "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].implode("/", array_map("rawurlencode", explode("/", $ar_file["SRC"])));
- elseif(preg_match("/^(http|https):\\/\\/(.*?)\\/(.*)\$/", $ar_file["SRC"], $match))
- $strFile = "http://".$match[2].'/'.implode("/", array_map("rawurlencode", explode("/", $match[3])));
- else
- $strFile = $ar_file["SRC"];
- }
- }
- $arItem['YANDEX_PICT'] = $strFile;
-
- $arItem['YANDEX_DESCR'] = yandex_text2xml(TruncateText(
- ($arItem["PREVIEW_TEXT_TYPE"]=="html"?
- strip_tags(preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arItem["~PREVIEW_TEXT"])) : preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arItem["~PREVIEW_TEXT"])),
- 255), true);
-
- $arOfferFilter['PROPERTY_'.$arOffers[$IBLOCK_ID]['SKU_PROPERTY_ID']] = $arItem['ID'];
- $rsOfferItems = CIBlockElement::GetList(array(),$arOfferFilter,false,false,$arOfferSelect);
-
- if (!empty($strOfferTemplateURL))
- $rsOfferItems->SetUrlTemplates($strOfferTemplateURL);
- if (YANDEX_SKU_EXPORT_MIN_PRICE == $arSKUExport['SKU_EXPORT_COND'])
- {
- $arCurrentOffer = false;
- $arCurrentPrice = false;
- $dblAllMinPrice = 0;
- $boolFirst = true;
-
- while ($obOfferItem = $rsOfferItems->GetNextElement())
- {
- $arOfferItem = $obOfferItem->GetFields();
- $minPrice = -1;
- if ($XML_DATA[$IBLOCK_ID]['PRICE'] > 0)
- {
- $rsPrices = CPrice::GetListEx(array(),array(
- 'PRODUCT_ID' => $arOfferItem['ID'],
- 'CATALOG_GROUP_ID' => $XML_DATA[$IBLOCK_ID]['PRICE'],
- 'CAN_BUY' => 'Y',
- 'GROUP_GROUP_ID' => array(2),
- '+<=QUANTITY_FROM' => 1,
- '+>=QUANTITY_TO' => 1,
- )
- );
- if ($arPrice = $rsPrices->Fetch())
- {
- /*$dbVAT = CCatalogProduct::GetVATInfo($arOfferItem['ID']);
- if ($arVat = $dbVAT->Fetch())
- {
- $arVat['RATE'] = floatval($arVat['RATE'] * 0.01);
- }
- else
- {
- $arVat = array('RATE' => 0, 'VAT_INCLUDED' => 'N');
- }
- $arPrice['VAT_RATE'] = $arVat['RATE'];
- $arPrice['VAT_INCLUDED'] = $arVat['VAT_INCLUDED'];
- if ($arPrice['VAT_INCLUDED'] == 'N')
- {
- $arPrice['PRICE'] *= (1 + $arPrice['VAT_RATE']);
- $arPrice['VAT_INCLUDED'] = 'Y';
- }
- $arPrice['PRICE'] = roundEx($arPrice['PRICE'], CATALOG_VALUE_PRECISION);
- $arDiscounts = CCatalogDiscount::GetDiscount(
- $arOfferItem['ID'],
- $intOfferIBlockID,
- array($XML_DATA[$IBLOCK_ID]['PRICE']),
- array(2),
- 'N',
- $arOfferIBlock['LID'],
- false
- );
- $minPrice = CCatalogProduct::CountPriceWithDiscount($arPrice['PRICE'], $arPrice["CURRENCY"], $arDiscounts);
- $minPriceGroup = $arPrice['CATALOG_GROUP_ID'];
- $minPriceCurrency = $arPrice["CURRENCY"];
- $minPriceRUR = CCurrencyRates::ConvertCurrency($arPrice['PRICE'], $arPrice["CURRENCY"], $RUR); */
- if ($arOptimalPrice = CCatalogProduct::GetOptimalPrice(
- $arOfferItem['ID'],
- 1,
- array(2),
- 'N',
- array($arPrice),
- $arOfferIBlock['LID']
- ))
- {
- $minPrice = $arOptimalPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arOptimalPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
- }
- else
- {
- if ($arPrice = CCatalogProduct::GetOptimalPrice(
- $arOfferItem['ID'],
- 1,
- array(2), // anonymous
- 'N',
- array(),
- $arOfferIBlock['LID']
- ))
- {
- $minPrice = $arPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
- if ($minPrice <= 0)
- continue;
- if ($boolFirst)
- {
- $dblAllMinPrice = $minPriceRUR;
- $arOfferItem['PROPERTIES'] = $obOfferItem->GetProperties();
- $arCross = array();
- foreach ($arOfferItem['PROPERTIES'] as $arProp)
- {
- $arCross[$arProp['ID']] = $arProp;
- }
- if (!empty($arItem['PROPERTIES']))
- {
- $arOfferItem['PROPERTIES'] = $arCross + $arItem['PROPERTIES'];
- }
- else
- {
- $arOfferItem['PROPERTIES'] = $arCross;
- }
-
- $arCurrentOffer = $arOfferItem;
- $arCurrentPrice = array(
- 'MIN_PRICE' => $minPrice,
- 'MIN_PRICE_CURRENCY' => $minPriceCurrency,
- 'MIN_PRICE_RUR' => $minPriceRUR,
- 'MIN_PRICE_GROUP' => $minPriceGroup,
- );
- $boolFirst = false;
- }
- else
- {
- if ($dblAllMinPrice > $minPriceRUR)
- {
- $dblAllMinPrice > $minPriceRUR;
- $arOfferItem['PROPERTIES'] = $obOfferItem->GetProperties();
- $arCross = array();
- foreach ($arOfferItem['PROPERTIES'] as $arProp)
- {
- $arCross[$arProp['ID']] = $arProp;
- }
- if (!empty($arItem['PROPERTIES']))
- {
- $arOfferItem['PROPERTIES'] = $arCross + $arItem['PROPERTIES'];
- }
- else
- {
- $arOfferItem['PROPERTIES'] = $arCross;
- }
-
- $arCurrentOffer = $arOfferItem;
- $arCurrentPrice = array(
- 'MIN_PRICE' => $minPrice,
- 'MIN_PRICE_CURRENCY' => $minPriceCurrency,
- 'MIN_PRICE_RUR' => $minPriceRUR,
- 'MIN_PRICE_GROUP' => $minPriceGroup,
- );
- }
- }
- }
- if (!empty($arCurrentOffer) && !empty($arCurrentPrice))
- {
- $arOfferItem = $arCurrentOffer;
- $minPrice = $arCurrentPrice['MIN_PRICE'];
- $minPriceCurrency = $arCurrentPrice['MIN_PRICE_CURRENCY'];
- $minPriceRUR = $arCurrentPrice['MIN_PRICE_RUR'];
- $minPriceGroup = $arCurrentPrice['MIN_PRICE_GROUP'];
-
- $arOfferItem['CATALOG_QUANTITY'] = '';
- $arOfferItem['CATALOG_QUANTITY_TRACE'] = 'N';
- $arProduct = CCatalogProduct::GetByID($arOfferItem['ID']);
- if (!empty($arProduct))
- {
- $arOfferItem['CATALOG_QUANTITY'] = $arProduct['QUANTITY'];
- $arOfferItem['CATALOG_QUANTITY_TRACE'] = $arProduct['QUANTITY_TRACE'];
- }
- $arOfferItem['YANDEX_AVAILABLE'] = 'true';
- $str_QUANTITY = DoubleVal($arOfferItem["CATALOG_QUANTITY"]);
- $str_QUANTITY_TRACE = $arOfferItem["CATALOG_QUANTITY_TRACE"];
- if (($str_QUANTITY <= 0) && ($str_QUANTITY_TRACE == "Y"))
- $arOfferItem['YANDEX_AVAILABLE'] = 'false';
-
- if (strlen($arOfferItem['DETAIL_PAGE_URL']) <= 0)
- $arOfferItem['DETAIL_PAGE_URL'] = '/';
- else
- $arOfferItem['DETAIL_PAGE_URL'] = str_replace(' ', '%20', $arOfferItem['DETAIL_PAGE_URL']);
-
- if (is_array($XML_DATA[$IBLOCK_ID]) && $XML_DATA[$IBLOCK_ID]['TYPE'] && $XML_DATA[$IBLOCK_ID]['TYPE'] != 'none')
- $str_TYPE = ' type="'.htmlspecialcharsbx($XML_DATA[$IBLOCK_ID]['TYPE']).'"';
- else
- $str_TYPE = '';
-
- $arOfferItem['YANDEX_TYPE'] = $str_TYPE;
-
- if(!isset($arItem["ID"]))
- continue;
-
- $strOfferYandex = '';
- $strOfferYandex .= "\n";
- $strOfferYandex .= "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].htmlspecialcharsbx($arOfferItem["~DETAIL_PAGE_URL"]).(strstr($arOfferItem['DETAIL_PAGE_URL'], '?') === false ? '?' : '&')."r1=&r2=\n";
-
- $strOfferYandex .= "".$minPrice."\n";
- $strOfferYandex .= "".$minPriceCurrency."\n";
-
- $strOfferYandex .= $arItem['YANDEX_CATEGORY'];
-
- $strFile = '';
- if (intval($arOfferItem["DETAIL_PICTURE"])>0 || intval($arOfferItem["PREVIEW_PICTURE"])>0)
- {
- $pictNo = intval($arOfferItem["DETAIL_PICTURE"]);
- if ($pictNo<=0)
- $pictNo = intval($arOfferItem["PREVIEW_PICTURE"]);
-
- if ($ar_file = CFile::GetFileArray($pictNo))
- {
- if(substr($ar_file["SRC"], 0, 1) == "/")
- $strFile = "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].implode("/", array_map("rawurlencode", explode("/", $ar_file["SRC"])));
- elseif(preg_match("/^(http|https):\\/\\/(.*?)\\/(.*)\$/", $ar_file["SRC"], $match))
- $strFile = "http://".$match[2].'/'.implode("/", array_map("rawurlencode", explode("/", $match[3])));
- else
- $strFile = $ar_file["SRC"];
- }
- }
- if (!empty($strFile) || !empty($arItem['YANDEX_PICT']))
- {
- $strOfferYandex .= "".(!empty($strFile) ? $strFile : $arItem['YANDEX_PICT'])."\n";
- }
-
- $y = 0;
- foreach ($arYandexFields as $key)
- {
- switch ($key)
- {
- case 'name':
- if (is_array($XML_DATA[$IBLOCK_ID]) && ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model' || $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'))
- continue;
-
- $strOfferYandex .= "".yandex_text2xml($arOfferItem["NAME"], true)."\n";
- break;
- case 'description':
- $strOfferYandex .= "";
- if (strlen($arOfferItem['~PREVIEW_TEXT']) <= 0)
- {
- $strOfferYandex .= $arItem['YANDEX_DESCR'];
- }
- else
- {
- $strOfferYandex .= yandex_text2xml(TruncateText(
- ($arOfferItem["PREVIEW_TEXT_TYPE"]=="html"?
- strip_tags(preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arOfferItem["~PREVIEW_TEXT"])) : $arOfferItem["~PREVIEW_TEXT"]),
- 255),
- true);
- }
- $strOfferYandex .= "\n";
- break;
- case 'param':
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS']))
- {
- foreach ($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS'] as $key => $prop_id)
- {
-
- $strParamValue = '';
- if ($prop_id)
- {
- $strParamValue = yandex_get_value($arOfferItem, 'PARAM_'.$key, $prop_id, $IBLOCK_ID);
- }
- if ('' != $strParamValue)
- $strOfferYandex .= $strParamValue."\n";
- }
- }
- break;
- case 'xml_id':
- $strOfferYandex .= "".yandex_text2xml($arItem["EXTERNAL_ID"], true)."\n";
- break;
- case 'product_name':
- $strOfferYandex .= "".yandex_text2xml($arItem["NAME"], true)."\n";
- break;
- case 'model':
- case 'title':
- if (!is_array($XML_DATA[$IBLOCK_ID]) || !is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) || !$XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- if (
- $key == 'model' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model'
- ||
- $key == 'title' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'
- )
- $strOfferYandex .= "<".$key.">".yandex_text2xml($arOfferItem["NAME"], true)."".$key.">\n";
- }
- else
- {
- $strValue = '';
- $strValue = yandex_get_value($arOfferItem, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strOfferYandex .= $strValue."\n";
- }
- break;
- case 'year':
- $y++;
- if ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title')
- {
- if ($y == 1) continue;
- }
- else
- {
- if ($y > 1) continue;
- }
- // no break here
- default:
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- $strValue = '';
- $strValue = yandex_get_value($arOfferItem, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strOfferYandex .= $strValue."\n";
- }
- }
- }
-
- $strOfferYandex .= "\n";
- $arItem['OFFERS'][] = $strOfferYandex;
- $boolItemOffers = true;
- $boolItemExport = true;
- }
- }
- else
- {
- while ($obOfferItem = $rsOfferItems->GetNextElement())
- {
- $arOfferItem = $obOfferItem->GetFields();
- $arOfferItem['PROPERTIES'] = $obOfferItem->GetProperties();
- $arCross = array();
- foreach ($arOfferItem['PROPERTIES'] as $arProp)
- {
- $arCross[$arProp['ID']] = $arProp;
- }
- if (!empty($arItem['PROPERTIES']))
- {
- $arOfferItem['PROPERTIES'] = $arCross + $arItem['PROPERTIES'];
- }
- else
- {
- $arOfferItem['PROPERTIES'] = $arCross;
- }
-
- $arOfferItem['CATALOG_QUANTITY'] = '';
- $arOfferItem['CATALOG_QUANTITY_TRACE'] = 'N';
- $arProduct = CCatalogProduct::GetByID($arOfferItem['ID']);
- if (!empty($arProduct))
- {
- $arOfferItem['CATALOG_QUANTITY'] = $arProduct['QUANTITY'];
- $arOfferItem['CATALOG_QUANTITY_TRACE'] = $arProduct['QUANTITY_TRACE'];
- }
- $arOfferItem['YANDEX_AVAILABLE'] = 'true';
- $str_QUANTITY = DoubleVal($arOfferItem["CATALOG_QUANTITY"]);
- $str_QUANTITY_TRACE = $arOfferItem["CATALOG_QUANTITY_TRACE"];
- if (($str_QUANTITY <= 0) && ($str_QUANTITY_TRACE == "Y"))
- $arOfferItem['YANDEX_AVAILABLE'] = 'false';
-
- $minPrice = -1;
- if ($XML_DATA[$IBLOCK_ID]['PRICE'] > 0)
- {
- $rsPrices = CPrice::GetListEx(array(),array(
- 'PRODUCT_ID' => $arOfferItem['ID'],
- 'CATALOG_GROUP_ID' => $XML_DATA[$IBLOCK_ID]['PRICE'],
- 'CAN_BUY' => 'Y',
- 'GROUP_GROUP_ID' => array(2),
- '+<=QUANTITY_FROM' => 1,
- '+>=QUANTITY_TO' => 1,
- )
- );
- if ($arPrice = $rsPrices->Fetch())
- {
- /*$dbVAT = CCatalogProduct::GetVATInfo($arOfferItem['ID']);
- if ($arVat = $dbVAT->Fetch())
- {
- $arVat['RATE'] = floatval($arVat['RATE'] * 0.01);
- }
- else
- {
- $arVat = array('RATE' => 0, 'VAT_INCLUDED' => 'N');
- }
- $arPrice['VAT_RATE'] = $arVat['RATE'];
- $arPrice['VAT_INCLUDED'] = $arVat['VAT_INCLUDED'];
- if ($arPrice['VAT_INCLUDED'] == 'N')
- {
- $arPrice['PRICE'] *= (1 + $arPrice['VAT_RATE']);
- $arPrice['VAT_INCLUDED'] = 'Y';
- }
- $arPrice['PRICE'] = roundEx($arPrice['PRICE'], CATALOG_VALUE_PRECISION);
- $arDiscounts = CCatalogDiscount::GetDiscount(
- $arOfferItem['ID'],
- $intOfferIBlockID,
- array($XML_DATA[$IBLOCK_ID]['PRICE']),
- array(2),
- 'N',
- $arOfferIBlock['LID'],
- false
- );
- $minPrice = CCatalogProduct::CountPriceWithDiscount($arPrice['PRICE'], $arPrice["CURRENCY"], $arDiscounts);
- $minPriceGroup = $arPrice['CATALOG_GROUP_ID'];
- $minPriceCurrency = $arPrice["CURRENCY"];
- $minPriceRUR = CCurrencyRates::ConvertCurrency($arPrice['PRICE'], $arPrice["CURRENCY"], $RUR); */
- if ($arOptimalPrice = CCatalogProduct::GetOptimalPrice(
- $arOfferItem['ID'],
- 1,
- array(2),
- 'N',
- array($arPrice),
- $arOfferIBlock['LID']
- ))
- {
- $minPrice = $arOptimalPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arOptimalPrice['PRICE']['CATALOG_GROUP_ID'];
- }
-
- }
- }
- else
- {
- if ($arPrice = CCatalogProduct::GetOptimalPrice(
- $arOfferItem['ID'],
- 1,
- array(2), // anonymous
- 'N',
- array(),
- $arOfferIBlock['LID']
- ))
- {
- $minPrice = $arPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
- if ($minPrice <= 0)
- continue;
-
- if (strlen($arOfferItem['DETAIL_PAGE_URL']) <= 0)
- $arOfferItem['DETAIL_PAGE_URL'] = '/';
- else
- $arOfferItem['DETAIL_PAGE_URL'] = str_replace(' ', '%20', $arOfferItem['DETAIL_PAGE_URL']);
-
- if (is_array($XML_DATA[$IBLOCK_ID]) && $XML_DATA[$IBLOCK_ID]['TYPE'] && $XML_DATA[$IBLOCK_ID]['TYPE'] != 'none')
- $str_TYPE = ' type="'.htmlspecialcharsbx($XML_DATA[$IBLOCK_ID]['TYPE']).'"';
- else
- $str_TYPE = '';
-
- $arOfferItem['YANDEX_TYPE'] = $str_TYPE;
-
- if(!isset($arItem["ID"]))
- continue;
-
- $strOfferYandex = '';
- $strOfferYandex .= "\n";
- $strOfferYandex .= "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].htmlspecialcharsbx($arOfferItem["~DETAIL_PAGE_URL"]).(strstr($arOfferItem['DETAIL_PAGE_URL'], '?') === false ? '?' : '&')."r1=&r2=\n";
-
- $strOfferYandex .= "".$minPrice."\n";
- $strOfferYandex .= "".$minPriceCurrency."\n";
-
- $strOfferYandex .= $arItem['YANDEX_CATEGORY'];
-
- $strFile = '';
- if (intval($arOfferItem["DETAIL_PICTURE"])>0 || intval($arOfferItem["PREVIEW_PICTURE"])>0)
- {
- $pictNo = intval($arOfferItem["DETAIL_PICTURE"]);
- if ($pictNo<=0)
- $pictNo = intval($arOfferItem["PREVIEW_PICTURE"]);
-
- if ($ar_file = CFile::GetFileArray($pictNo))
- {
- if(substr($ar_file["SRC"], 0, 1) == "/")
- $strFile = "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].implode("/", array_map("rawurlencode", explode("/", $ar_file["SRC"])));
- elseif(preg_match("/^(http|https):\\/\\/(.*?)\\/(.*)\$/", $ar_file["SRC"], $match))
- $strFile = "http://".$match[2].'/'.implode("/", array_map("rawurlencode", explode("/", $match[3])));
- else
- $strFile = $ar_file["SRC"];
- }
- }
- if (!empty($strFile) || !empty($arItem['YANDEX_PICT']))
- {
- $strOfferYandex .= "".(!empty($strFile) ? $strFile : $arItem['YANDEX_PICT'])."\n";
- }
-
- $y = 0;
- foreach ($arYandexFields as $key)
- {
- switch ($key)
- {
- case 'name':
- if (is_array($XML_DATA[$IBLOCK_ID]) && ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model' || $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'))
- continue;
-
- $strOfferYandex .= "".yandex_text2xml($arOfferItem["NAME"], true)."\n";
- break;
- case 'description':
- $strOfferYandex .= "";
- if (strlen($arOfferItem['~PREVIEW_TEXT']) <= 0)
- {
- $strOfferYandex .= $arItem['YANDEX_DESCR'];
- }
- else
- {
- $strOfferYandex .= yandex_text2xml(TruncateText(
- ($arOfferItem["PREVIEW_TEXT_TYPE"]=="html"?
- strip_tags(preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arOfferItem["~PREVIEW_TEXT"])) : preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arOfferItem["~PREVIEW_TEXT"])),
- 255),
- true);
- }
- $strOfferYandex .= "\n";
- break;
- case 'param':
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS']))
- {
- foreach ($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS'] as $key => $prop_id)
- {
- $strParamValue = '';
- if ($prop_id)
- {
- $strParamValue = yandex_get_value($arOfferItem, 'PARAM_'.$key, $prop_id, $IBLOCK_ID);
- }
- if ('' != $strParamValue)
- $strOfferYandex .= $strParamValue."\n";
- }
- }
- break;
- case 'xml_id':
- $strOfferYandex .= "".yandex_text2xml($arItem["EXTERNAL_ID"], true)."\n";
- break;
- case 'product_name':
- $strOfferYandex .= "".yandex_text2xml($arItem["NAME"], true)."\n";
- break;
- case 'model':
- case 'title':
- if (!is_array($XML_DATA[$IBLOCK_ID]) || !is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) || !$XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- if (
- $key == 'model' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model'
- ||
- $key == 'title' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'
- )
- $strOfferYandex .= "<".$key.">".yandex_text2xml($arOfferItem["NAME"], true)."".$key.">\n";
- }
- else
- {
- $strValue = '';
- $strValue = yandex_get_value($arOfferItem, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strOfferYandex .= $strValue."\n";
- }
- break;
- case 'year':
- $y++;
- if ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title')
- {
- if ($y == 1) continue;
- }
- else
- {
- if ($y > 1) continue;
- }
- // no break here
- default:
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- $strValue = '';
- $strValue = yandex_get_value($arOfferItem, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strOfferYandex .= $strValue."\n";
- }
- }
- }
-
- $strOfferYandex .= "\n";
- $arItem['OFFERS'][] = $strOfferYandex;
- $boolItemOffers = true;
- $boolItemExport = true;
- }
- }
- if (('X' == $arCatalog[$IBLOCK_ID]['CATALOG_TYPE'] || 'P' == $arCatalog[$IBLOCK_ID]['CATALOG_TYPE']) && !$boolItemOffers)
- {
-
- $arItem['CATALOG_QUANTITY'] = '';
- $arItem['CATALOG_QUANTITY_TRACE'] = 'N';
- $arProduct = CCatalogProduct::GetByID($arItem['ID']);
- if (!empty($arProduct))
- {
- $arItem['CATALOG_QUANTITY'] = $arProduct['QUANTITY'];
- $arItem['CATALOG_QUANTITY_TRACE'] = $arProduct['QUANTITY_TRACE'];
- }
- $str_QUANTITY = DoubleVal($arItem["CATALOG_QUANTITY"]);
- $str_QUANTITY_TRACE = $arItem["CATALOG_QUANTITY_TRACE"];
- if (($str_QUANTITY <= 0) && ($str_QUANTITY_TRACE == "Y"))
- $str_AVAILABLE = ' available="false"';
- else
- $str_AVAILABLE = ' available="true"';
-
- $minPrice = 0;
- $minPriceRUR = 0;
- $minPriceGroup = 0;
- $minPriceCurrency = "";
-
- if ($XML_DATA[$IBLOCK_ID]['PRICE'] > 0)
- {
- $rsPrices = CPrice::GetListEx(array(),array(
- 'PRODUCT_ID' => $arItem['ID'],
- 'CATALOG_GROUP_ID' => $XML_DATA[$IBLOCK_ID]['PRICE'],
- 'CAN_BUY' => 'Y',
- 'GROUP_GROUP_ID' => array(2),
- '+<=QUANTITY_FROM' => 1,
- '+>=QUANTITY_TO' => 1,
- )
- );
- if ($arPrice = $rsPrices->Fetch())
- {
- /*$dbVAT = CCatalogProduct::GetVATInfo($arItem['ID']);
- if ($arVat = $dbVAT->Fetch())
- {
- $arVat['RATE'] = floatval($arVat['RATE'] * 0.01);
- }
- else
- {
- $arVat = array('RATE' => 0, 'VAT_INCLUDED' => 'N');
- }
- $arPrice['VAT_RATE'] = $arVat['RATE'];
- $arPrice['VAT_INCLUDED'] = $arVat['VAT_INCLUDED'];
- if ($arPrice['VAT_INCLUDED'] == 'N')
- {
- $arPrice['PRICE'] *= (1 + $arPrice['VAT_RATE']);
- $arPrice['VAT_INCLUDED'] = 'Y';
- }
- $arPrice['PRICE'] = roundEx($arPrice['PRICE'], CATALOG_VALUE_PRECISION);
- $arDiscounts = CCatalogDiscount::GetDiscount(
- $arItem['ID'],
- $IBLOCK_ID,
- array($XML_DATA[$IBLOCK_ID]['PRICE']),
- array(2),
- 'N',
- $ar_iblock['LID'],
- false
- );
- $minPrice = CCatalogProduct::CountPriceWithDiscount($arPrice['PRICE'], $arPrice["CURRENCY"], $arDiscounts);
- $minPriceGroup = $arPrice['CATALOG_GROUP_ID'];
- $minPriceCurrency = $arPrice["CURRENCY"];
- $minPriceRUR = CCurrencyRates::ConvertCurrency($arPrice['PRICE'], $arPrice["CURRENCY"], $RUR); */
- if ($arOptimalPrice = CCatalogProduct::GetOptimalPrice(
- $arItem['ID'],
- 1,
- array(2),
- 'N',
- array($arPrice),
- $ar_iblock[$IBLOCK_ID]['LID']
- ))
- {
- $minPrice = $arOptimalPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arOptimalPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
- }
- else
- {
- if ($arPrice = CCatalogProduct::GetOptimalPrice(
- $arItem['ID'],
- 1,
- array(2), // anonymous
- 'N',
- array(),
- $ar_iblock[$IBLOCK_ID]['LID']
- ))
- {
- $minPrice = $arPrice['DISCOUNT_PRICE'];
- $minPriceCurrency = $BASE_CURRENCY;
- $minPriceRUR = CCurrencyRates::ConvertCurrency($minPrice, $BASE_CURRENCY, $RUR);
- $minPriceGroup = $arPrice['PRICE']['CATALOG_GROUP_ID'];
- }
- }
-
- if ($minPrice <= 0) continue;
-
- if ('' == $arItem['DETAIL_PAGE_URL'])
- {
- $arItem['DETAIL_PAGE_URL'] = '/';
- }
- else
- {
- $arItem['DETAIL_PAGE_URL'] = str_replace(' ', '%20', $arItem['DETAIL_PAGE_URL']);
- }
- if ('' == $arItem['~DETAIL_PAGE_URL'])
- {
- $arItem['~DETAIL_PAGE_URL'] = '/';
- }
- else
- {
- $arItem['~DETAIL_PAGE_URL'] = str_replace(' ', '%20', $arItem['~DETAIL_PAGE_URL']);
- }
-
- if (is_array($XML_DATA[$IBLOCK_ID]) && $XML_DATA[$IBLOCK_ID]['TYPE'] && $XML_DATA[$IBLOCK_ID]['TYPE'] != 'none')
- $str_TYPE = ' type="'.htmlspecialcharsbx($XML_DATA[$IBLOCK_ID]['TYPE']).'"';
- else
- $str_TYPE = '';
- if (!isset($arItem["ID"]))
- continue;
-
- $strOfferYandex = '';
- $strOfferYandex.= "\n";
- $strOfferYandex.= "http://".$ar_iblock[$IBLOCK_ID]['SERVER_NAME'].htmlspecialcharsbx($arItem["~DETAIL_PAGE_URL"]).(strstr($arItem['DETAIL_PAGE_URL'], '?') === false ? '?' : '&')."r1=&r2=\n";
-
- $strOfferYandex.= "".$minPrice."\n";
- $strOfferYandex.= "".$minPriceCurrency."\n";
-
- $strOfferYandex.= $arItem['YANDEX_CATEGORY'];
-
- if (!empty($arItem['YANDEX_PICT']))
- {
- $strOfferYandex .= "".$arItem['YANDEX_PICT']."\n";
- }
-
- $y = 0;
- foreach ($arYandexFields as $key)
- {
- $strValue = '';
- switch ($key)
- {
- case 'name':
- if (is_array($XML_DATA[$IBLOCK_ID]) && ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model' || $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'))
- continue;
-
- $strValue = "".yandex_text2xml($arItem["NAME"], true)."\n";
- break;
- case 'description':
- $strValue =
- "".
- yandex_text2xml(TruncateText(
- ($arItem["PREVIEW_TEXT_TYPE"]=="html"?
- strip_tags(preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arItem["~PREVIEW_TEXT"])) : preg_replace_callback("'&[^;]*;'", "yandex_replace_special", $arItem["~PREVIEW_TEXT"])),
- 255), true).
- "\n";
- break;
- case 'param':
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS']))
- {
- foreach ($XML_DATA[$IBLOCK_ID]['XML_DATA']['PARAMS'] as $key => $prop_id)
- {
- $strParamValue = '';
- if ($prop_id)
- {
- $strParamValue = yandex_get_value($arItem, 'PARAM_'.$key, $prop_id, $IBLOCK_ID);
- }
- if ('' != $strParamValue)
- $strValue .= $strParamValue."\n";
- }
- }
- break;
- case 'xml_id':
- $strValue .= "".yandex_text2xml($arItem["EXTERNAL_ID"], true)."\n";
- break;
- case 'product_name':
- $strValue .= "".yandex_text2xml($arItem["NAME"], true)."\n";
- break;
- case 'model':
- case 'title':
- if (!is_array($XML_DATA[$IBLOCK_ID]) || !is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) || !$XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- if (
- $key == 'model' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'vendor.model'
- ||
- $key == 'title' && $XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title'
- )
-
- $strValue = "<".$key.">".yandex_text2xml($arItem["NAME"], true)."".$key.">\n";
- }
- else
- {
- $strValue = yandex_get_value($arItem, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strValue .= "\n";
- }
- break;
- case 'year':
- $y++;
- if ($XML_DATA[$IBLOCK_ID]['TYPE'] == 'artist.title')
- {
- if ($y == 1) continue;
- }
- else
- {
- if ($y > 1) continue;
- }
-
- // no break here
-
- default:
- if (is_array($XML_DATA[$IBLOCK_ID]) && is_array($XML_DATA[$IBLOCK_ID]['XML_DATA']) && $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key])
- {
- $strValue = yandex_get_value($arItem, $key, $XML_DATA[$IBLOCK_ID]['XML_DATA'][$key], $IBLOCK_ID);
- if ('' != $strValue)
- $strValue .= "\n";
- }
- }
- if ('' != $strValue)
- $strOfferYandex .= $strValue;
- }
-
- $strOfferYandex .= "\n";
-
- if ('' != $strOfferYandex)
- {
- $arItem['OFFERS'][] = $strOfferYandex;
- $boolItemOffers = true;
- $boolItemExport = true;
- }
- }
- if (!$boolItemExport)
- continue;
- foreach ($arItem['OFFERS'] as $strOfferItem)
- {
- $strTmpOff .= $strOfferItem;
- }
- }
- }
- }
-
- @fwrite($fp, "\n");
- if (true == $boolNeedRootSection)
- {
- $strTmpCat .= "".yandex_text2xml(GetMessage('YANDEX_ROOT_DIRECTORY'), true)."\n";
- }
- @fwrite($fp, $strTmpCat);
- @fwrite($fp, "\n");
-
- @fwrite($fp, "\n");
- @fwrite($fp, $strTmpOff);
- @fwrite($fp, "\n");
-
- @fwrite($fp, "\n");
- @fwrite($fp, "\n");
-
- @fclose($fp);
-
-
-}
-
-CCatalogDiscountSave::Enable();
-
-if (!empty($arRunErrors))
- $strExportErrorMessage = implode('
',$arRunErrors);
-
-if ($bTmpUserCreated)
-{
- unset($USER);
- if (isset($USER_TMP))
- {
- $USER = $USER_TMP;
- unset($USER_TMP);
- }
-}
-?>
\ No newline at end of file
diff --git a/intaro.intarocrm/install/export/intarocrm_setup.php b/intaro.intarocrm/install/export/intarocrm_setup.php
deleted file mode 100755
index 6679189a..00000000
--- a/intaro.intarocrm/install/export/intarocrm_setup.php
+++ /dev/null
@@ -1,173 +0,0 @@
-
-//IntaroCRM
-__IncludeLang(GetLangFileName($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/intaro.intarocrm/lang/", "/export_setup_templ.php"));
-
-global $APPLICATION;
-
-$arSetupErrors = array();
-if (($ACTION == 'EXPORT_EDIT' || $ACTION == 'EXPORT_COPY') && $STEP == 1)
-{
- if (isset($arOldSetupVars['YANDEX_EXPORT']))
- $YANDEX_EXPORT = $arOldSetupVars['YANDEX_EXPORT'];
- if (isset($arOldSetupVars['SETUP_FILE_NAME']))
- $SETUP_FILE_NAME = $arOldSetupVars['SETUP_FILE_NAME'];
- if (isset($arOldSetupVars['SETUP_PROFILE_NAME']))
- $SETUP_PROFILE_NAME = $arOldSetupVars['SETUP_PROFILE_NAME'];
- if (isset($arOldSetupVars['SETUP_SERVER_NAME']))
- $SETUP_SERVER_NAME = $arOldSetupVars['SETUP_SERVER_NAME'];
-}
-
-if ($STEP>1)
-{
- if (!is_array($YANDEX_EXPORT) || count($YANDEX_EXPORT)<=0)
- {
- $arSetupErrors[] = GetMessage("CET_ERROR_NO_IBLOCKS");
- }
-
- if (strlen($SETUP_FILE_NAME)<=0)
- {
- $arSetupErrors[] = GetMessage("CET_ERROR_NO_FILENAME");
- }
- elseif (preg_match(BX_CATALOG_FILENAME_REG,$SETUP_FILE_NAME))
- {
- $arSetupErrors[] = GetMessage("CES_ERROR_BAD_EXPORT_FILENAME");
- }
- elseif ($APPLICATION->GetFileAccessPermission($SETUP_FILE_NAME) < "W")
- {
- $arSetupErrors[] = str_replace("#FILE#", $SETUP_FILE_NAME, GetMessage('CET_YAND_RUN_ERR_SETUP_FILE_ACCESS_DENIED'));
- }
-
- if (($ACTION=="EXPORT_SETUP" || $ACTION == 'EXPORT_EDIT' || $ACTION == 'EXPORT_COPY') && strlen($SETUP_PROFILE_NAME)<=0)
- {
- $arSetupErrors[] = GetMessage("CET_ERROR_NO_PROFILE_NAME");
- }
-
- if (!empty($arSetupErrors))
- {
- $STEP = 1;
- }
-}
-
-if (!empty($arSetupErrors))
- echo ShowError(implode('
', $arSetupErrors));
-
-if ($STEP==1)
-{
- if (CModule::IncludeModule("iblock"))
- {
- // Get IBlock list
- ?>
-
-
- }
-}
-elseif ($STEP==2)
-{
- $SETUP_SERVER_NAME = htmlspecialcharsbx($SETUP_SERVER_NAME);
- $_POST['SETUP_SERVER_NAME'] = htmlspecialcharsbx($_POST['SETUP_SERVER_NAME']);
- $_REQUEST['SETUP_SERVER_NAME'] = htmlspecialcharsbx($_REQUEST['SETUP_SERVER_NAME']);
-
- $FINITE = true;
-}
-?>
\ No newline at end of file
diff --git a/intaro.intarocrm/install/index.php b/intaro.intarocrm/install/index.php
index 00653968..2267afc4 100755
--- a/intaro.intarocrm/install/index.php
+++ b/intaro.intarocrm/install/index.php
@@ -21,6 +21,7 @@ class intaro_intarocrm extends CModule
var $PARTNER_NAME;
var $PARTNER_URI;
var $INTARO_CRM_API;
+ var $INTARO_CRM_EXPORT = 'intarocrm';
var $CRM_API_HOST_OPTION = 'api_host';
var $CRM_API_KEY_OPTION = 'api_key';
@@ -65,6 +66,7 @@ class intaro_intarocrm extends CModule
include($this->INSTALL_PATH . '/../classes/general/RestApi.php');
include($this->INSTALL_PATH . '/../classes/general/ICrmOrderActions.php');
+ include($this->INSTALL_PATH . '/../classes/general/ICMLLoader.php');
$step = intval($_REQUEST['step']);
@@ -623,11 +625,189 @@ class intaro_intarocrm extends CModule
$_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/' . $this->MODULE_ID . '/install/step3.php'
);
} else if ($step == 4) {
+ if(!CModule::IncludeModule("iblock")) {
+ $arResult['errCode'] = 'ERR_IBLOCK';
+ }
+
+ if(!CModule::IncludeModule("catalog")) {
+ $arResult['errCode'] = 'ERR_CATALOG';
+ }
+ $APPLICATION->IncludeAdminFile(
+ GetMessage('MODULE_INSTALL_TITLE'),
+ $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/' . $this->MODULE_ID . '/install/step4.php'
+ );
+ } else if ($step == 5) {
+
+ if(isset($arResult['errCode']) && $arResult['errCode']) {
+ $APPLICATION->IncludeAdminFile(
+ GetMessage('MODULE_INSTALL_TITLE'),
+ $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/' . $this->MODULE_ID . '/install/step4.php'
+ );
+ return;
+ }
+
+ if (isset($_POST['back']) && $_POST['back']) {
+ $APPLICATION->IncludeAdminFile(
+ GetMessage('MODULE_INSTALL_TITLE'),
+ $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/' . $this->MODULE_ID . '/install/step3.php'
+ );
+ }
RegisterModule($this->MODULE_ID);
RegisterModuleDependences("sale", "OnSaleCancelOrder", $this->MODULE_ID, "ICrmOrderEvent", "onSaleCancelOrder");
RegisterModuleDependences("sale", "OnSalePayOrder", $this->MODULE_ID, "ICrmOrderEvent", "onSalePayOrder");
+
+ if(!CModule::IncludeModule("iblock")) {
+ $arResult['errCode'] = 'ERR_IBLOCK';
+ }
+
+ if(!CModule::IncludeModule("catalog")) {
+ $arResult['errCode'] = 'ERR_CATALOG';
+ }
+
+ if(!isset($_POST['IBLOCK_EXPORT']))
+ $iblocks = 0;
+ else
+ $iblocks = $_POST['IBLOCK_EXPORT'];
+
+ if(!isset($_POST['IBLOCK_PROPERTY_ARTICLE']))
+ $articleProperties = 0;
+ else
+ $articleProperties = $_POST['IBLOCK_PROPERTY_ARTICLE'];
+
+ if(!isset($_POST['SETUP_PROFILE_NAME']))
+ $profileName = 0;
+ else
+ $profileName = $_POST['SETUP_PROFILE_NAME'];
+
+ if(!isset($_POST['SETUP_FILE_NAME']))
+ $filename = 0;
+ else
+ $filename = $_POST['SETUP_FILE_NAME'];
+
+ if(!isset($_POST['TYPE_LOADING']))
+ $typeLoading = 0;
+ else
+ $typeLoading = $_POST['TYPE_LOADING'];
+
+ if (isset($_POST['LOAD_NOW'])) {
+
+ $loader = new ICMLLoader();
+ $loader->iblocks = $iblocks;
+ $loader->articleProperties = $articleProperties;
+ $loader->filename = $filename;
+ $loader->application = $APPLICATION;
+ $loader->Load();
+
+ }
+ if(!isset($_POST['TYPE_LOADING']))
+ $typeLoading = 0;
+ else
+ $typeLoading = $_POST['TYPE_LOADING'];
+
+ if ($typeLoading == 'agent' || $typeLoading == 'cron') {
+ $dbProfile = CCatalogExport::GetList(array(), array("FILE_NAME" => $this->INTARO_CRM_EXPORT));
+
+ while ($arProfile = $dbProfile->Fetch()) {
+ if ($arProfile["DEFAULT_PROFILE"]!="Y")
+ CAgent::RemoveAgent("CCatalogExport::PreGenerateExport(".$arProfile['ID'].");", "catalog");
+ }
+ $ar = $this->GetProfileSetupVars($iblocks, $articleProperties, $filename);
+ $PROFILE_ID = CCatalogExport::Add(array(
+ "LAST_USE" => false,
+ "FILE_NAME" => $this->INTARO_CRM_EXPORT,
+ "NAME" => $profileName,
+ "DEFAULT_PROFILE" => "N",
+ "IN_MENU" => "N",
+ "IN_AGENT" => "N",
+ "IN_CRON" => "N",
+ "NEED_EDIT" => "N",
+ "SETUP_VARS" => $ar
+ ));
+ if (intval($PROFILE_ID) <= 0) {
+ $arResult['errCode'] = 'ERR_IBLOCK';
+ return;
+ }
+ if ($typeLoading == 'agent') {
+
+ $dateAgent = new DateTime();
+ $intAgent = new DateInterval('PT60S'); // PT60S - 60 sec;
+ $dateAgent->add($intAgent);
+ CAgent::AddAgent(
+ "CCatalogExport::PreGenerateExport(" . $PROFILE_ID . ");",
+ "catalog",
+ "N",
+ 86400,
+ $dateAgent->format('d.m.Y H:i:s'), // date of first check
+ "Y", // агент активен
+ $dateAgent->format('d.m.Y H:i:s'), // date of first start
+ 30
+ );
+
+ CCatalogExport::Update($PROFILE_ID, array(
+ "IN_CRON" => ($arProfile["IN_AGENT"]=="Y" ? "N" : "Y")
+ ));
+ } else {
+ $agent_period = 24;
+ $agent_php_path = "/usr/local/php/bin/php";
+
+ if (!file_exists($_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS."cron_frame.php"))
+ {
+ CheckDirPath($_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS);
+ $tmp_file_size = filesize($_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS_DEF."cron_frame.php");
+ $fp = fopen($_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS_DEF."cron_frame.php", "rb");
+ $tmp_data = fread($fp, $tmp_file_size);
+ fclose($fp);
+
+ $tmp_data = str_replace("#DOCUMENT_ROOT#", $_SERVER["DOCUMENT_ROOT"], $tmp_data);
+ $tmp_data = str_replace("#PHP_PATH#", $agent_php_path, $tmp_data);
+
+ $fp = fopen($_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS."cron_frame.php", "ab");
+ fwrite($fp, $tmp_data);
+ fclose($fp);
+ }
+
+ $cfg_data = "";
+ if (file_exists($_SERVER["DOCUMENT_ROOT"]."/bitrix/crontab/crontab.cfg"))
+ {
+ $cfg_file_size = filesize($_SERVER["DOCUMENT_ROOT"]."/bitrix/crontab/crontab.cfg");
+ $fp = fopen($_SERVER["DOCUMENT_ROOT"]."/bitrix/crontab/crontab.cfg", "rb");
+ $cfg_data = fread($fp, $cfg_file_size);
+ fclose($fp);
+ }
+
+ CheckDirPath($_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS."logs/");
+
+ if ($arProfile["IN_CRON"]=="Y")
+ {
+ // remove
+ $cfg_data = preg_replace("#^.*?".preg_quote(CATALOG_PATH2EXPORTS)."cron_frame.php +".$PROFILE_ID." *>.*?$#im", "", $cfg_data);
+ }
+ else
+ {
+ $strTime = "0 */".$agent_period." * * * ";
+ if (strlen($cfg_data)>0)
+ $cfg_data .= "\n";
+
+ $cfg_data .= $strTime.$agent_php_path." -f ".$_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS."cron_frame.php ".$PROFILE_ID." >".$_SERVER["DOCUMENT_ROOT"].CATALOG_PATH2EXPORTS."logs/".$PROFILE_ID.".txt\n";
+ }
+
+ CCatalogExport::Update($PROFILE_ID, array(
+ "IN_CRON" => ($arProfile["IN_CRON"]=="Y" ? "N" : "Y")
+ ));
+
+ CheckDirPath($_SERVER["DOCUMENT_ROOT"]."/bitrix/crontab/");
+ $cfg_data = preg_replace("#[\r\n]{2,}#im", "\n", $cfg_data);
+ $fp = fopen($_SERVER["DOCUMENT_ROOT"]."/bitrix/crontab/crontab.cfg", "wb");
+ fwrite($fp, $cfg_data);
+ fclose($fp);
+
+ $arRetval = array();
+ @exec("crontab ".$_SERVER["DOCUMENT_ROOT"]."/bitrix/crontab/crontab.cfg", $arRetval, $return_var);
+
+ }
+ }
//agent
$dateAgent = new DateTime();
@@ -655,7 +835,7 @@ class intaro_intarocrm extends CModule
$APPLICATION->IncludeAdminFile(
GetMessage('MODULE_INSTALL_TITLE'),
- $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/' . $this->MODULE_ID . '/install/step4.php'
+ $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/' . $this->MODULE_ID . '/install/step5.php'
);
}
}
diff --git a/intaro.intarocrm/install/step4.php b/intaro.intarocrm/install/step4.php
index 931fdfcc..81178e93 100644
--- a/intaro.intarocrm/install/step4.php
+++ b/intaro.intarocrm/install/step4.php
@@ -1,10 +1,228 @@
-
+
+
diff --git a/intaro.intarocrm/install/step5.php b/intaro.intarocrm/install/step5.php
new file mode 100644
index 00000000..931fdfcc
--- /dev/null
+++ b/intaro.intarocrm/install/step5.php
@@ -0,0 +1,10 @@
+
+
+