From 14dce123c4e77ea1cd7ef7bf395a4ebea2db7f97 Mon Sep 17 00:00:00 2001 From: "m.korolev" Date: Tue, 6 Aug 2013 19:13:49 +0400 Subject: [PATCH 1/2] Export to ICML has been modified Added step4 into install --- .../classes/general/ICMLLoader.php | 331 ++++++++++++++++++ intaro.intarocrm/include.php | 1 + intaro.intarocrm/install/index.php | 220 +++++++++++- intaro.intarocrm/install/step4.php | 234 ++++++++++++- intaro.intarocrm/install/step5.php | 10 + intaro.intarocrm/lang/export_crm.php | 109 ++++++ intaro.intarocrm/lang/export_setup_templ.php | 124 +++++++ intaro.intarocrm/lang/icml_export_setup.php | 10 + intaro.intarocrm/lang/ru/install/step4.php | 19 + 9 files changed, 1038 insertions(+), 20 deletions(-) create mode 100644 intaro.intarocrm/classes/general/ICMLLoader.php create mode 100644 intaro.intarocrm/install/step5.php create mode 100644 intaro.intarocrm/lang/export_crm.php create mode 100644 intaro.intarocrm/lang/export_setup_templ.php create mode 100644 intaro.intarocrm/lang/icml_export_setup.php create mode 100755 intaro.intarocrm/lang/ru/install/step4.php 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/index.php b/intaro.intarocrm/install/index.php index 334ec133..f7816273 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']); @@ -370,11 +372,193 @@ 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"); + + 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(); $intAgent = new DateInterval('PT60S'); // PT60S - 60 sec; $dateAgent->add($intAgent); @@ -391,16 +575,10 @@ class intaro_intarocrm extends CModule ); $this->CopyFiles(); - - // statistic update - $api_host = COption::GetOptionString($this->MODULE_ID, $this->CRM_API_HOST_OPTION, 0); - $api_key = COption::GetOptionString($this->MODULE_ID, $this->CRM_API_KEY_OPTION, 0); - $this->INTARO_CRM_API = new \IntaroCrm\RestApi($api_host, $api_key); - $this->INTARO_CRM_API->statisticUpdate(); - + $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' ); } } @@ -417,10 +595,9 @@ class intaro_intarocrm extends CModule COption::RemoveOption($this->MODULE_ID, $this->CRM_PAYMENT_STATUSES); COption::RemoveOption($this->MODULE_ID, $this->CRM_PAYMENT); COption::RemoveOption($this->MODULE_ID, $this->CRM_ORDER_LAST_ID); - UnRegisterModuleDependences("sale", "OnSaleCancelOrder", $this->MODULE_ID, "ICrmOrderEvent", "onSaleCancelOrder"); - + $this->DeleteFiles(); - + UnRegisterModule($this->MODULE_ID); $APPLICATION->IncludeAdminFile( @@ -442,4 +619,23 @@ class intaro_intarocrm extends CModule unlink($_SERVER['DOCUMENT_ROOT'] . '/bitrix/php_interface/include/catalog_export/intarocrm_run.php'); unlink($_SERVER['DOCUMENT_ROOT'] . '/bitrix/php_interface/include/catalog_export/intarocrm_setup.php'); } -} \ No newline at end of file + + function GetProfileSetupVars($iblocks, $articleProperties, $filename) { + // Get string like IBLOCK_EXPORT[0]=3& + // IBLOCK_EXPORT[1]=6& + // IBLOCK_PROPERTY_ARTICLE[0]=ARTICLE& + // IBLOCK_PROPERTY_ARTICLE[1]=ARTNUMBER& + // SETUP_FILE_NAME=%2Fbitrix%2Fcatalog_export%2Ftestintarocrm.xml + + //$arProfileFields = explode(",", $SETUP_FIELDS_LIST); + $strVars = ""; + foreach ($iblocks as $key => $val) + $strVars .= 'IBLOCK_EXPORT[' . $key . ']=' . $val . '&'; + foreach ($articleProperties as $key => $val) + $strVars .= 'IBLOCK_PROPERTY_ARTICLE[' . $key . ']=' . $val . '&'; + + $strVars .= 'SETUP_FILE_NAME=' . urlencode($filename); + + return $strVars; + } +} 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 @@ -
- - - - "> - +if(!check_bitrix_sessid()) return; +IncludeModuleLangFile(__FILE__); +__IncludeLang(GetLangFileName($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/intaro.intarocrm/lang/", "/icml_export_setup.php")); + +?> + +

+ "ASC", "NAME"=>"ASC"),array('CHECK_PERMISSIONS' => 'Y','MIN_PERMISSION' => 'W')); + while ($res = $db_res->Fetch()) + { + if ($arCatalog = CCatalog::GetByIDExt($res["ID"])) + { + if($arCatalog['CATALOG_TYPE'] == "D" || $arCatalog['CATALOG_TYPE'] == "X" || $arCatalog['CATALOG_TYPE'] == "P") + { + $arSiteList = array(); + $rsSites = CIBlock::GetSite($res["ID"]); + while ($arSite = $rsSites->Fetch()) + { + $arSiteList[] = $arSite["SITE_ID"]; + } + $db_properties = CIBlock::GetProperties($res['ID'], Array()); + + $properties = Array(); + while($prop = $db_properties->Fetch()) + $properties[] = $prop; + + + $boolExport = (in_array($res['ID'],$IBLOCK_EXPORT)); + $arIBlockList[] = array( + 'ID' => $res['ID'], + 'NAME' => $res['NAME'], + 'IBLOCK_TYPE_ID' => $res['IBLOCK_TYPE_ID'], + 'IBLOCK_EXPORT' => $boolExport, + 'PROPERTIES' => $properties, + 'SITE_LIST' => '('.implode(' ',$arSiteList).')', + ); + + if ($boolExport) + $intCountChecked++; + $intCountAvailIBlock++; + } + } + } + if ($intCountChecked == $intCountAvailIBlock) + $boolAll = true; + + ?> + + + + + + + + + + + + + + + + + + $arIBlock) + { + ?> + + + + + + + +
+
+
+
+   +
+
+
+
+ + + > + + +   +
+ + + + " + + onclick="checkOne(this,);" + > + + + +
+ +
+
+
+ +

+ + +
+
+
+ +

+
+
+
+
+
+   + +
+
+
+ + + + + + + + + + + + + + + +
+
+ " class="adm-btn-save"> +
+
+ " class="adm-btn-save"> +
+
+
+ + 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 @@ + + +
+ + + + "> + diff --git a/intaro.intarocrm/lang/export_crm.php b/intaro.intarocrm/lang/export_crm.php new file mode 100644 index 00000000..1d7584ba --- /dev/null +++ b/intaro.intarocrm/lang/export_crm.php @@ -0,0 +1,109 @@ +http://partner.market.yandex.ru/legal/tt/"; +$MESS["YANDEX_PROPS_COMMON"] = "Общие настройки"; +$MESS["YANDEX_PROPS_TYPE"] = "Настройки типа описания"; +$MESS["YANDEX_PROPS_NO"] = "нет"; +$MESS["YANDEX_PROPS_ADDITIONAL"] = "Дополнительные свойства для выгрузки"; +$MESS["YANDEX_PROPS_ADDITIONAL_TITLE"] = "Выберите свойства"; +$MESS["YANDEX_PROPS_ADDITIONAL_MORE"] = "Еще"; +$MESS["YANDEX_PRICES"] = "Цены"; +$MESS["YANDEX_PRICE_TYPE"] = "Выводить цену"; +$MESS["YANDEX_PRICE_TYPE_NONE"] = "оптимальную"; +$MESS["YANDEX_CURRENCIES"] = "Валюты"; +$MESS["YANDEX_CURRENCY"] = "валюта"; +$MESS["YANDEX_CURRENCY_RATE"] = "курс"; +$MESS["YANDEX_CURRENCY_RATE_SITE"] = "сайт"; +$MESS["YANDEX_CURRENCY_RATE_CBRF"] = "Центральный банк РФ"; +$MESS["YANDEX_CURRENCY_RATE_NBU"] = "Национальный банк Украины"; +$MESS["YANDEX_CURRENCY_RATE_NBK"] = "Национальный банк Казахстана"; +$MESS["YANDEX_CURRENCY_RATE_CB"] = "банк своего региона"; +$MESS["YANDEX_CURRENCY_PLUS"] = "коррекция курса"; +$MESS["YANDEX_PARAMS_TITLE"] = "Свойство"; +$MESS["YANDEX_ERR_NO_ACCESS_IBLOCK_SKU"] = "Нет доступа к инфоблоку торговых предложений"; +$MESS["YANDEX_ERR_NO_IBLOCK_SKU_FOUND"] = "Инфоблок торговых предложений #ID# не найден"; +$MESS["YANDEX_ERR_NO_IBLOCK_FOUND_EXT"] = "Инфоблок #ID# не найден"; +$MESS["YANDEX_ERR_NO_IBLOCK_IS_CATALOG"] = "Инфоблок #ID# не является торговым каталогом и не имеет торговых предложений"; +$MESS["YANDEX_ERR_NO_SECTION_LIST"] = "Список разделов не задан"; +$MESS["YANDEX_ERR_FILE_ACCESS_DENIED"] = "Недостаточно прав для перезаписи файла #FILE#"; +$MESS["YANDEX_ERR_FILE_OPEN_WRITING"] = "Невозможно открыть файл #FILE# для записи"; +$MESS["YANDEX_ERR_SETUP_FILE_WRITE"] = "Запись в файл #FILE# невозможна"; +$MESS["YANDEX_PRODUCT_PROPS"] = "--- Инфоблок товаров ---"; +$MESS["YANDEX_OFFERS_PROPS"] = "--- Инфоблок торговых предложений ---"; +$MESS["YANDEX_SKU_SETTINGS"] = "Выгрузка торговых предложений"; +$MESS["YANDEX_OFFERS_SELECT"] = "Условие отбора"; +$MESS["YANDEX_SKU_EXPORT_ALL_TITLE"] = "Все предложения товара"; +$MESS["YANDEX_SKU_EXPORT_MIN_PRICE_TITLE"] = "Предложение с минимальной ценой"; +$MESS["YANDEX_SKU_EXPORT_PROP_TITLE"] = "Отбор по свойству"; +$MESS["YANDEX_SKU_EXPORT_PROP_ID"] = "Свойство"; +$MESS["YANDEX_SKU_EXPORT_PROP_COND"] = "Условие отбора"; +$MESS["YANDEX_SKU_EXPORT_PROP_VALUE"] = "Значения"; +$MESS["YANDEX_SKU_EXPORT_PROP_EMPTY"] = "--- выберите свойство ---"; +$MESS["YANDEX_SKU_EXPORT_PROP_SELECT_ZERO"] = "пусто"; +$MESS["YANDEX_SKU_EXPORT_PROP_SELECT_NONZERO"] = "не пусто"; +$MESS["YANDEX_SKU_EXPORT_PROP_SELECT_EQUAL"] = "равно"; +$MESS["YANDEX_SKU_EXPORT_PROP_SELECT_NONEQUAL"] = "не равно"; +$MESS["YANDEX_SKU_EXPORT_ERR_CONDITION_ABSENT"] = "Не указано, по какому принципу фильтровать экспортируемые торговые предложения"; +$MESS["YANDEX_SKU_EXPORT_ERR_PROPERTY_ABSENT"] = "Не указано свойство, по значению которого фильтруются торговые предложения"; +$MESS["YANDEX_SKU_EXPORT_ERR_PROPERTY_COND_ABSENT"] = "Не указано условие фильтрации торговых предложений по свойству"; +$MESS["YANDEX_SKU_EXPORT_ERR_PROPERTY_VALUES_ABSENT"] = "Не указаны значения свойств для фильтрации торговых предложений"; +$MESS["YANDEX_SAVE_ERR"] = "Ошибки сохранения"; +$MESS["YANDEX_ERR_BAD_PRICE_TYPE"] = "Задан неверный тип цен для выгрузки"; +$MESS["YANDEX_ERR_BAD_OFFERS_IBLOCK_ID"] = "Неверный ID инфоблока торговых предложений"; +$MESS["YANDEX_ERR_SKU_SETTINGS_ABSENT"] = "Отсутствуют настройки экспорта торговых предложений"; +$MESS["YANDEX_ROOT_DIRECTORY"] = "Основной раздел каталога"; +$MESS["CET_ERROR_IBLOCK_PERM"] = "Недостаточно прав для работы с инфоблоком ##IBLOCK_ID#"; +$MESS["CES_ERROR_BAD_EXPORT_FILENAME"] = "Имя файла экспорта содержит запрещенные символы"; \ No newline at end of file diff --git a/intaro.intarocrm/lang/export_setup_templ.php b/intaro.intarocrm/lang/export_setup_templ.php new file mode 100644 index 00000000..91f43fbc --- /dev/null +++ b/intaro.intarocrm/lang/export_setup_templ.php @@ -0,0 +1,124 @@ +Путь по умолчанию для экспортируемых файлов настроек модуля."; +$MESS["CAT_ADM_CSV_EXP_TAB1"] = "Инфоблок"; +$MESS["CAT_ADM_CSV_EXP_TAB1_TITLE"] = "Выбор информационного блока для экспорта"; +$MESS["CAT_ADM_CSV_EXP_TAB2"] = "Параметры экспорта"; +$MESS["CAT_ADM_CSV_EXP_TAB2_TITLE"] = "Настройка параметров экспорта"; +$MESS["CAT_ADM_CSV_EXP_TAB3"] = "Результат"; +$MESS["CAT_ADM_CSV_EXP_TAB3_TITLE"] = "Результат экспорта"; +$MESS["CAT_ADM_CSV_EXP_IBLOCK_ID"] = "Инфоблок"; +$MESS["CAT_ADM_CSV_EXP_ADD_SETTINGS"] = "Дополнительные настройки"; +$MESS["CAT_ADM_CSV_EXP_EXPORT_FILES"] = "Выгружать файлы"; +$MESS["CAT_ADM_CSV_EXP_TIME_STEP"] = "Время выполнения шага"; +$MESS["CAT_ADM_CSV_EXP_TIME_STEP_COMMENT"] = "0 - загрузить все сразу
положительное значение - число секунд на выполнение одного шага"; +$MESS["CAT_ADM_CSV_EXP_SEP_ELEMENTS"] = "Поля и свойства элементов"; +$MESS["CAT_ADM_CSV_EXP_SEP_SECTIONS"] = "Поля разделов"; +$MESS["CAT_ADM_CSV_EXP_SEP_SECTIONS_EXT"] = "Поля и пользовательские свойства разделов"; +$MESS["CAT_ADM_CSV_EXP_SEP_PRODUCT"] = "Свойства товара"; +$MESS["CAT_ADM_CSV_EXP_SEP_PRICES"] = "Цены"; +$MESS["CAT_ADM_CSV_EXP_SEP_SKU"] = "Поля и свойства торговых предложений"; +$MESS["CAT_ADM_CSV_EXP_DESCR_SECT_PROP"] = "Пользовательское свойство"; +$MESS["CAT_ADM_CSV_EXP_SECTION_LEVEL"] = "Раздел уровня #LEVEL#"; +$MESS["CATI_FI_PRICE_TYPE2"] = "Цена типа \"#TYPE#\""; +$MESS["CATI_FI_PRICE_TYPE3"] = "Цена типа \"#NAME#\" (#TYPE#)"; +$MESS["CATI_FI_PRICE_CURRENCY"] = "в валюте #CURRENCY#"; \ No newline at end of file diff --git a/intaro.intarocrm/lang/icml_export_setup.php b/intaro.intarocrm/lang/icml_export_setup.php new file mode 100644 index 00000000..3a47d2fe --- /dev/null +++ b/intaro.intarocrm/lang/icml_export_setup.php @@ -0,0 +1,10 @@ + \ No newline at end of file diff --git a/intaro.intarocrm/lang/ru/install/step4.php b/intaro.intarocrm/lang/ru/install/step4.php new file mode 100755 index 00000000..5dea2bba --- /dev/null +++ b/intaro.intarocrm/lang/ru/install/step4.php @@ -0,0 +1,19 @@ + Date: Tue, 6 Aug 2013 19:16:55 +0400 Subject: [PATCH 2/2] Delete old Export to ICML --- .../install/export/intarocrm_run.php | 1906 ----------------- .../install/export/intarocrm_setup.php | 173 -- 2 files changed, 2079 deletions(-) delete mode 100755 intaro.intarocrm/install/export/intarocrm_run.php delete mode 100755 intaro.intarocrm/install/export/intarocrm_setup.php 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).''; - } - } - - 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, ''); - fwrite($fp, ''); - fwrite($fp, ''); - } - } -} - -if (empty($arRunErrors)) -{ - - - @fwrite($fp, ''); - @fwrite($fp, '"?>'); - @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)."\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)."\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)."\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)."\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 - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - -
- "ASC", "NAME"=>"ASC"),array('CHECK_PERMISSIONS' => 'Y','MIN_PERMISSION' => 'W')); - while ($res = $db_res->Fetch()) - { - if ($ar_res1 = CCatalog::GetByID($res["ID"])) - { - $arSiteList = array(); - $rsSites = CIBlock::GetSite($res["ID"]); - while ($arSite = $rsSites->Fetch()) - { - $arSiteList[] = $arSite["SITE_ID"]; - } - - $boolYandex = (in_array($res['ID'],$YANDEX_EXPORT)); - $arIBlockList[] = array( - 'ID' => $res['ID'], - 'NAME' => $res['NAME'], - 'IBLOCK_TYPE_ID' => $res['IBLOCK_TYPE_ID'], - 'YANDEX_EXPORT' => $boolYandex, - 'SITE_LIST' => '('.implode(' ',$arSiteList).')', - ); - if ($boolYandex) - $intCountChecked++; - $intCountAvailIBlock++; - } - } - if ($intCountChecked == $intCountAvailIBlock) - $boolAll = true; - ?> - - $arIBlock) - { - ?> - " checked> - - - -
- - " size="50"> - -

-
- 4.    - - - - -

-
-   - - - "> - - - - "> -
-
- \ No newline at end of file