1
0
mirror of synced 2024-11-23 13:56:08 +03:00
bitrix-module/intaro.retailcrm/classes/general/icml/RetailCrmICML.php

746 lines
31 KiB
PHP
Raw Normal View History

2016-09-15 16:42:10 +03:00
<?php
2018-03-22 16:11:04 +03:00
use Bitrix\Highloadblock as HL;
use Bitrix\Main\Entity;
2016-09-15 16:42:10 +03:00
IncludeModuleLangFile(__FILE__);
class RetailCrmICML
{
public $profileID;
public $iblocks;
public $filename;
public $serverName;
2018-10-04 16:28:14 +03:00
public $defaultServerName;
2016-09-15 16:42:10 +03:00
public $propertiesSKU;
public $propertiesUnitSKU;
public $propertiesProduct;
public $propertiesUnitProduct;
2018-05-23 12:19:59 +03:00
public $highloadblockSkuProperties;
public $highloadblockProductProperties;
2016-09-15 16:42:10 +03:00
public $application;
public $encoding = 'utf-8';
public $encodingDefault = 'utf-8';
public $loadPurchasePrice = false;
2018-10-04 16:28:14 +03:00
public $productPictures;
public $skuPictures;
2018-12-26 11:41:06 +03:00
public $offerPageSize = 50;
2016-09-15 16:42:10 +03:00
protected $fp;
protected $mainSection = 1000000;
protected $pageSize = 500;
protected $protocol;
2020-04-08 17:27:05 +03:00
protected $purchasePriceNull;
2016-09-15 16:42:10 +03:00
protected $isLogged = false;
protected $logFile = '/bitrix/catalog_export/i_crm_load_log.txt';
protected $fpLog;
protected $localizedIBlockProps;
2016-09-15 16:42:10 +03:00
protected $MODULE_ID = 'intaro.retailcrm';
protected $CRM_CATALOG_BASE_PRICE = 'catalog_base_price';
2018-11-02 17:41:00 +03:00
protected $PROTOCOL_OPTION = 'protocol';
2020-04-08 17:27:05 +03:00
protected $CRM_PURCHASE_PRICE_NULL = 'purchasePrice_null';
2016-09-15 16:42:10 +03:00
protected $measurement = array (
'mm' => 1, // 1 mm = 1 mm
'cm' => 10, // 1 cm = 10 mm
'm' => 1000,
'mg' => 0.001, // 0.001 g = 1 mg
'g' => 1,
'kg' => 1000,
);
protected $measurementLink = array (
'mm' => 'mm',
'cm' => 'mm',
'm' => 'mm',
'mg' => 'g',
'g' => 'g',
'kg' => 'g',
);
2017-09-04 11:36:04 +03:00
2016-12-13 14:01:48 +03:00
protected $measure = array (
'pc. 1' => 'pc',
'm' => 'm',
'l' => 'l',
'kg' => 'kg',
);
2016-09-15 16:42:10 +03:00
public function Load()
{
2017-09-04 11:36:04 +03:00
global $USER;
if (!isset($_SESSION["SESS_AUTH"]["USER_ID"]) || !$_SESSION["SESS_AUTH"]["USER_ID"]) {
$USER = new CUser();
2017-09-04 11:36:04 +03:00
}
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->isLogged = true;
$this->localizedIBlockProps = $this->getLocalizedIBlockProps();
2017-09-04 11:36:04 +03:00
$defaultSite = CSite::GetList($by = "def", $order = "desc", array('DEF' => 'Y'))->Fetch();
$this->encodingDefault = $defaultSite["CHARSET"];
2018-11-02 17:41:00 +03:00
$this->protocol = COption::GetOptionString($this->MODULE_ID, $this->PROTOCOL_OPTION);
2020-04-08 17:27:05 +03:00
$this->purchasePriceNull = COption::GetOptionString($this->MODULE_ID, $this->CRM_PURCHASE_PRICE_NULL);
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->PrepareSettings();
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->fp = $this->PrepareFile($this->filename. '.tmp');
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
if ($this->isLogged) {
$this->fpLog = $this->PrepareFile($this->logFile);
$this->WriteLog("Start Loading");
}
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->PreWriteCatalog();
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$categories = $this->GetCategories();
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->WriteCategories($categories);
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->PreWriteOffers();
$this->BuildOffers($categories);
$this->PostWriteOffers();
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
$this->PostWriteCatalog();
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
if ($this->isLogged) {
$this->WriteLog("Loading was ended successfully (peek memory usage: " . memory_get_peak_usage() . ")");
}
$this->CloseFile($this->fp);
$this->CloseFile($this->fpLog);
unlink($defaultSite['ABS_DOC_ROOT'] . $this->filename);
rename($defaultSite['ABS_DOC_ROOT'] . $this->filename. '.tmp', $defaultSite['ABS_DOC_ROOT'] . $this->filename);
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
return true;
2016-09-15 16:42:10 +03:00
}
private function setSiteAddress($block_id)
{
$site = CAllIBlock::GetSite($block_id)->Fetch();
if ($site['SERVER_NAME']) {
$this->serverName = $site['SERVER_NAME'];
} else {
$this->serverName = $this->defaultServerName;
}
}
2016-09-15 16:42:10 +03:00
protected function PrepareSettings()
{
foreach ($this->propertiesSKU as $iblock => $arr) {
foreach ($arr as $id => $sku) {
$this->propertiesSKU[$iblock][$id] = strtoupper($sku);
}
}
2016-09-15 16:42:10 +03:00
foreach ($this->propertiesProduct as $iblock => $arr) {
foreach ($arr as $id => $prod) {
$this->propertiesProduct[$iblock][$id] = strtoupper($prod);
}
}
}
protected function PrepareValue($text)
{
$newText = $this->application->ConvertCharset($text, $this->encodingDefault, $this->encoding);
$newText = strip_tags($newText);
$newText = str_replace("&", "&#x26;", $newText);
2018-10-04 16:28:14 +03:00
2016-09-15 16:42:10 +03:00
return $newText;
}
protected function PrepareFile($filename)
{
2017-09-04 11:36:04 +03:00
$fullFilename = $_SERVER["DOCUMENT_ROOT"] . $filename;
CheckDirPath($fullFilename);
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
if ($fp = @fopen($fullFilename, "w")){
return $fp;
} else {
return false;
}
2016-09-15 16:42:10 +03:00
}
protected function PreWriteCatalog()
{
2017-09-04 11:36:04 +03:00
@fwrite($this->fp, "<yml_catalog date=\"" . $this->PrepareValue(Date("Y-m-d H:i:s")) . "\">\n
<shop>\n
<name>" . $this->PrepareValue(COption::GetOptionString("main", "site_name", ""))."</name>\n
<company>" . $this->PrepareValue(COption::GetOptionString("main", "site_name", ""))."</company>\n"
);
2016-09-15 16:42:10 +03:00
}
protected function WriteCategories($categories)
{
2017-09-04 11:36:04 +03:00
$stringCategories = "";
@fwrite($this->fp, "<categories>\n");
foreach ($categories as $category) {
$stringCategories .= $this->BuildCategory($category);
}
@fwrite($this->fp, $stringCategories);
@fwrite($this->fp, "</categories>\n");
2016-09-15 16:42:10 +03:00
}
protected function PreWriteOffers()
{
2017-09-04 11:36:04 +03:00
@fwrite($this->fp, "<offers>\n");
2016-09-15 16:42:10 +03:00
}
2017-09-04 11:36:04 +03:00
protected function PostWriteOffers()
2016-09-15 16:42:10 +03:00
{
2017-09-04 11:36:04 +03:00
@fwrite($this->fp, "</offers>\n");
2016-09-15 16:42:10 +03:00
}
2017-09-04 11:36:04 +03:00
protected function WriteOffers($offers)
2016-09-15 16:42:10 +03:00
{
2017-09-04 11:36:04 +03:00
@fwrite($this->fp, $offers);
2016-09-15 16:42:10 +03:00
}
protected function WriteLog($text)
{
2016-10-04 17:57:39 +03:00
if ($this->isLogged) {
2016-09-15 16:42:10 +03:00
@fwrite($this->fpLog, Date("Y:m:d H:i:s") . ": " . $text . "\n");
2016-10-04 17:57:39 +03:00
}
2016-09-15 16:42:10 +03:00
}
protected function PostWriteCatalog()
{
2017-09-04 11:36:04 +03:00
@fwrite($this->fp, "</shop>\n
</yml_catalog>\n");
2016-09-15 16:42:10 +03:00
}
protected function CloseFile($fp)
{
2017-09-04 11:36:04 +03:00
@fclose($fp);
2016-09-15 16:42:10 +03:00
}
protected function GetCategories()
{
2017-09-04 11:36:04 +03:00
$categories = array();
foreach ($this->iblocks as $id) {
$this->setSiteAddress($id);
2017-09-04 11:36:04 +03:00
$filter = array("IBLOCK_ID" => $id);
$dbRes = CIBlockSection::GetList(array("left_margin" => "asc"), $filter);
$hasCategories = false;
2017-09-04 11:36:04 +03:00
while ($arRes = $dbRes->Fetch()) {
$categories[$arRes['ID']] = $arRes;
$categories[$arRes['ID']]['SITE'] = $this->protocol . $this->serverName;
2017-09-04 11:36:04 +03:00
$hasCategories = true;
2016-09-15 16:42:10 +03:00
}
2017-09-04 11:36:04 +03:00
if (!$hasCategories) {
$iblock = CIBlock::GetByID($id)->Fetch();
$arRes = array();
2017-09-04 11:36:04 +03:00
$arRes['ID'] = $this->mainSection + $id;
$arRes['IBLOCK_SECTION_ID'] = 0;
$arRes['NAME'] = sprintf(GetMessage('ROOT_CATEGORY_FOR_CATALOG'), $iblock['NAME']);
$categories[$arRes['ID']] = $arRes;
$categories[$arRes['ID']]['SITE'] = $this->protocol . $this->serverName;
2017-09-04 11:36:04 +03:00
}
}
2016-09-15 16:42:10 +03:00
2017-09-04 11:36:04 +03:00
return $categories;
2016-09-15 16:42:10 +03:00
}
protected function BuildCategory($arCategory)
{
$category =
"<category id=\"" . $this->PrepareValue($arCategory["ID"]) . "\""
. (intval($arCategory["IBLOCK_SECTION_ID"]) > 0 ?
" parentId=\"" . $this->PrepareValue($arCategory["IBLOCK_SECTION_ID"]) . "\""
:"")
. ">\n\t"
. "<name>" . $this->PrepareValue($arCategory["NAME"]) . "</name>\n";
if (CFile::GetPath($arCategory["DETAIL_PICTURE"])) {
$category .= "\t<picture>" . $arCategory['SITE'] . CFile::GetPath($arCategory["DETAIL_PICTURE"]) . "</picture>\n";
}
if (CFile::GetPath($arCategory["PICTURE"])) {
$category .= "\t<picture>" . $arCategory['SITE'] . CFile::GetPath($arCategory["PICTURE"]) . "</picture>\n";
}
2016-09-15 16:42:10 +03:00
$category .= "</category>\n";
return $category;
2016-09-15 16:42:10 +03:00
}
protected function BuildOffers(&$allCategories)
{
$basePriceId = COption::GetOptionString(
$this->MODULE_ID,
2019-01-16 10:28:11 +03:00
$this->CRM_CATALOG_BASE_PRICE . '_' . $this->profileID,
0
2016-09-15 16:42:10 +03:00
);
2019-01-16 10:28:11 +03:00
if (!$basePriceId) {
$dbPriceType = CCatalogGroup::GetList(
array(),
array('BASE' => 'Y'),
false,
false,
array('ID')
);
$result = $dbPriceType->GetNext();
$basePriceId = $result['ID'];
}
2016-10-04 17:57:39 +03:00
foreach ($this->iblocks as $key => $id) {
$this->setSiteAddress($id);
2018-06-13 13:05:58 +03:00
$barcodes = array();
2018-10-04 16:28:14 +03:00
2018-06-13 13:05:58 +03:00
$dbBarCode = CCatalogStoreBarCode::getList(
array(),
array("IBLOCK_ID" => $id),
false,
false,
array('PRODUCT_ID', 'BARCODE')
);
2019-01-16 10:28:11 +03:00
while ($arBarCode = $dbBarCode->GetNext()) {
2018-06-13 13:05:58 +03:00
if (!empty($arBarCode)) {
$barcodes[$arBarCode['PRODUCT_ID']] = $arBarCode['BARCODE'];
}
}
2018-03-22 16:11:04 +03:00
$highloadblockSkuProps = array();
$highloadblockProductProps = array();
$productProps = CIBlockproperty::GetList(array(), array("IBLOCK_ID" => $id));
2018-10-04 16:28:14 +03:00
2018-03-22 16:11:04 +03:00
while ($arrProductProps = $productProps->Fetch()) {
if ($arrProductProps["USER_TYPE"] == 'directory') {
$highloadblockProductProps[$arrProductProps['CODE']] = $arrProductProps;
}
}
2016-09-15 16:42:10 +03:00
// Get Info by infoblocks
$iblock['IBLOCK_DB'] = CIBlock::GetByID($id)->Fetch();
$iblockOffer = CCatalogSKU::GetInfoByProductIBlock($id);
2018-03-22 16:11:04 +03:00
$skuProps = CIBlockproperty::GetList(array(), array("IBLOCK_ID" => $iblockOffer['IBLOCK_ID']));
2018-10-04 16:28:14 +03:00
while ($arrSkuProps = $skuProps->Fetch()) {
2018-03-22 16:11:04 +03:00
if ($arrSkuProps["USER_TYPE"] == 'directory') {
$highloadblockSkuProps[$arrSkuProps['CODE']] = $arrSkuProps;
}
}
2019-01-16 10:28:11 +03:00
$arSelect = array(
2016-09-15 16:42:10 +03:00
"ID",
"LID",
"IBLOCK_ID",
"IBLOCK_SECTION_ID",
"ACTIVE",
"NAME",
"DETAIL_PICTURE",
"PREVIEW_PICTURE",
"DETAIL_PAGE_URL",
"CATALOG_GROUP_" . $basePriceId
);
// Set selected properties
foreach ($this->propertiesProduct[$id] as $key => $propProduct) {
if ($this->propertiesProduct[$id][$key] != "") {
2018-10-04 16:28:14 +03:00
$arSelect[] = "PROPERTY_" . $propProduct;
$arSelect[] = "PROPERTY_" . $propProduct . ".NAME";
2016-09-15 16:42:10 +03:00
}
}
2018-10-04 16:28:14 +03:00
if ($this->productPictures && isset($this->productPictures[$id])) {
$arSelect[] = "PROPERTY_" . $this->productPictures[$id]['picture'];
$arSelect[] = "PROPERTY_" . $this->productPictures[$id]['picture'] . ".NAME";
}
2016-10-04 17:57:39 +03:00
$arSelectOffer = array(
2016-09-15 16:42:10 +03:00
'ID',
"NAME",
"DETAIL_PAGE_URL",
"DETAIL_PICTURE",
2018-10-04 16:28:14 +03:00
"PREVIEW_PICTURE",
2016-09-15 16:42:10 +03:00
'PROPERTY_' . $iblockOffer['SKU_PROPERTY_ID'],
"CATALOG_GROUP_" . $basePriceId
);
2018-10-04 16:28:14 +03:00
2016-09-15 16:42:10 +03:00
// Set selected properties
foreach ($this->propertiesSKU[$id] as $key => $propSKU) {
if ($this->propertiesSKU[$id][$key] != "") {
$arSelectOffer[] = "PROPERTY_" . $propSKU;
$arSelectOffer[] = "PROPERTY_" . $propSKU . ".NAME";
}
}
2018-10-04 16:28:14 +03:00
if ($this->skuPictures && isset($this->skuPictures[$id])) {
$arSelectOffer[] = "PROPERTY_" . $this->skuPictures[$id]['picture'];
$arSelectOffer[] = "PROPERTY_" . $this->skuPictures[$id]['picture'] . ".NAME";
}
2016-09-15 16:42:10 +03:00
// Set filter
$filter = array(
"IBLOCK_ID" => $id
);
$order = array("id");
2016-10-04 17:57:39 +03:00
$arNavStatParams = array(
2016-09-15 16:42:10 +03:00
"iNumPage" => 1,
"nPageSize" => $this->pageSize,
);
// Cycle page to page
do {
// Get products on this page
$elems = array();
$dbResProductsIds = CIBlockElement::GetList($order, $filter, false, $arNavStatParams, array('ID'));
2016-10-04 17:57:39 +03:00
while ($obIds = $dbResProductsIds->Fetch()) {
2016-09-15 16:42:10 +03:00
$elems[] = $obIds['ID'];
}
$arfilter = array(
"IBLOCK_ID" => $id,
"ID" => $elems
);
$dbResProducts = CIBlockElement::GetList($order, $arfilter, false, false, $arSelect);
$products = array();
2018-10-04 16:28:14 +03:00
2016-09-15 16:42:10 +03:00
while ($product = $dbResProducts->GetNext()) {
// Compile products to array
$products[$product['ID']] = $product;
$products[$product['ID']]['offers'] = array();
}
2018-10-04 16:28:14 +03:00
2016-09-15 16:42:10 +03:00
unset($product);
if (!empty($iblockOffer['IBLOCK_ID'])) {
$arFilterOffer = array(
'IBLOCK_ID' => $iblockOffer['IBLOCK_ID'],
'PROPERTY_' . $iblockOffer['SKU_PROPERTY_ID'] => array_keys($products),
);
// Get all offers for products on this page
$dbResOffers = CIBlockElement::GetList(
array(),
$arFilterOffer,
false,
array('nTopCount' => $this->pageSize * $this->offerPageSize),
$arSelectOffer
);
while ($offer = $dbResOffers->GetNext()) {
// Link offers to products
$products[$offer['PROPERTY_' . $iblockOffer['SKU_PROPERTY_ID'] . '_VALUE']]['offers'][$offer['ID']] = $offer;
}
unset($offer, $dbResOffers);
}
$stringOffers = "";
foreach ($products as $product) {
2018-10-04 16:28:14 +03:00
if (CFile::GetPath($product["DETAIL_PICTURE"])) {
$product['PICTURE'] = $this->protocol . $this->serverName . CFile::GetPath($product["DETAIL_PICTURE"]);
} elseif (CFile::GetPath($product["PREVIEW_PICTURE"])){
$product['PICTURE'] = $this->protocol . $this->serverName . CFile::GetPath($product["PREVIEW_PICTURE"]);
} elseif (
$this->productPictures
&& isset($this->productPictures[$id])
&& CFile::GetPath($product["PROPERTY_" . $this->productPictures[$id]['picture'] . "_VALUE"])
) {
$picture = CFile::GetPath($product["PROPERTY_" . $this->productPictures[$id]['picture'] . "_VALUE"]);
$product['PICTURE'] = $this->protocol . $this->serverName . $picture;
}
2018-05-23 12:19:59 +03:00
2018-10-04 16:28:14 +03:00
// Get properties of product
$resPropertiesProduct = Array();
foreach ($this->propertiesProduct[$id] as $key => $propProduct) {
$resPropertiesProduct[$key] = "";
if ($propProduct != "") {
if (isset($product["PROPERTY_" . $propProduct . "_NAME"])) {
$resPropertiesProduct[$key] = $product["PROPERTY_" . $propProduct . "_NAME"];
} elseif (isset($product["PROPERTY_" . $propProduct . "_VALUE"])) {
$resPropertiesProduct[$key] = $product["PROPERTY_" . $propProduct . "_VALUE"];
} elseif (isset($product[$propProduct])) {
$resPropertiesProduct[$key] = $product[$propProduct];
2016-09-15 16:42:10 +03:00
}
2018-10-04 16:28:14 +03:00
if (array_key_exists($key, $this->propertiesUnitProduct[$id])) {
$resPropertiesProduct[$key] *= $this->measurement[$this->propertiesUnitProduct[$id][$key]];
$resPropertiesProduct[$key . "_UNIT"] = $this->measurementLink[$this->propertiesUnitProduct[$id][$key]];
}
if (isset($highloadblockProductProps[$propProduct])) {
$propVal = $this->getHBprop($highloadblockProductProps[$propProduct], $product["PROPERTY_" . $propProduct . "_VALUE"]);
$tableName = $highloadblockProductProps[$propProduct]['USER_TYPE_SETTINGS']['TABLE_NAME'];
$field = $this->highloadblockProductProperties[$tableName][$id][$key];
$resPropertiesProduct[$key] = $propVal[$field];
}
2016-09-15 16:42:10 +03:00
}
2018-10-04 16:28:14 +03:00
}
2016-09-15 16:42:10 +03:00
2018-10-04 16:28:14 +03:00
// Get categories of product
$categories = array();
$dbResCategories = CIBlockElement::GetElementGroups($product['ID'], true);
while ($arResCategory = $dbResCategories->Fetch()) {
$categories[$arResCategory["ID"]] = array(
'ID' => $arResCategory["ID"],
'NAME' => $arResCategory["NAME"],
);
}
if (count($categories) == 0) {
$catId = $this->mainSection + $id;
$categories[$catId] = $allCategories[$catId];
}
2018-07-16 16:01:19 +03:00
2018-10-04 16:28:14 +03:00
$existOffer = false;
if (!empty($iblockOffer['IBLOCK_ID'])) {
foreach ($product['offers'] as $offer) {
$offer['BARCODE'] = isset($barcodes[$offer['ID']]) ? $barcodes[$offer['ID']] : '';
$offer['PRODUCT_ID'] = $product["ID"];
$offer['DETAIL_PAGE_URL'] = $product["DETAIL_PAGE_URL"];
if (CFile::GetPath($offer["DETAIL_PICTURE"])) {
$offer['PICTURE'] = $this->protocol . $this->serverName . CFile::GetPath($offer["DETAIL_PICTURE"]);
} elseif (CFile::GetPath($offer["PREVIEW_PICTURE"])){
$offer['PICTURE'] = $this->protocol . $this->serverName . CFile::GetPath($offer["PREVIEW_PICTURE"]);
} elseif (
$this->skuPictures
&& isset($this->skuPictures[$id])
&& CFile::GetPath($offer["PROPERTY_" . $this->skuPictures[$id]['picture'] . "_VALUE"])
) {
$picture = CFile::GetPath($offer["PROPERTY_" . $this->skuPictures[$id]['picture'] . "_VALUE"]);
$offer['PICTURE'] = $this->protocol . $this->serverName . $picture;
} else {
$offer['PICTURE'] = $product['PICTURE'];
}
2016-09-15 16:42:10 +03:00
2018-10-04 16:28:14 +03:00
$offer['PRODUCT_NAME'] = $product["NAME"];
$offer['PRODUCT_ACTIVE'] = $product["ACTIVE"];
$offer['PRICE'] = $offer['CATALOG_PRICE_' . $basePriceId];
$offer['PURCHASE_PRICE'] = $offer['CATALOG_PURCHASING_PRICE'];
$offer['QUANTITY'] = $offer["CATALOG_QUANTITY"];
// Get properties of product
foreach ($this->propertiesSKU[$id] as $key => $propSKU) {
if ($propSKU != "") {
if (isset ($offer["PROPERTY_" . $propSKU . "_NAME"])) {
$offer['_PROP_' . $key] = $offer["PROPERTY_" . $propSKU . "_NAME"];
} elseif (isset($offer["PROPERTY_" . $propSKU . "_VALUE"])) {
$offer['_PROP_' . $key] = $offer["PROPERTY_" . $propSKU . "_VALUE"];
} elseif (isset($offer[$propSKU])) {
$offer['_PROP_' . $key] = $offer[$propSKU];
}
if (array_key_exists($key, $this->propertiesUnitSKU[$id])) {
$offer['_PROP_' . $key] *= $this->measurement[$this->propertiesUnitSKU[$id][$key]];
$offer['_PROP_' . $key . "_UNIT"] = $this->measurementLink[$this->propertiesUnitSKU[$id][$key]];
}
if (isset($highloadblockSkuProps[$propSKU])) {
$propVal = $this->getHBprop($highloadblockSkuProps[$propSKU], $offer["PROPERTY_" . $propSKU . "_VALUE"]);
$tableName = $highloadblockSkuProps[$propSKU]['USER_TYPE_SETTINGS']['TABLE_NAME'];
$field = $this->highloadblockSkuProperties[$tableName][$id][$key];
$offer['_PROP_' . $key] = $propVal[$field];
2016-09-15 16:42:10 +03:00
}
}
}
foreach ($resPropertiesProduct as $key => $propProduct) {
2018-10-04 16:28:14 +03:00
if ($this->propertiesProduct[$id][$key] != "" && !isset($offer[$key])) {
$offer['_PROP_' . $key] = $propProduct;
2016-09-15 16:42:10 +03:00
}
}
2018-10-04 16:28:14 +03:00
$stringOffers .= $this->BuildOffer($offer, $categories, $iblock, $allCategories);
$existOffer = true;
2016-09-15 16:42:10 +03:00
}
2018-10-04 16:28:14 +03:00
}
if (!$existOffer) {
$offer['BARCODE'] = isset($barcodes[$product["ID"]]) ? $barcodes[$product["ID"]] : '';
$product['PRODUCT_ID'] = $product["ID"];
$product['PRODUCT_NAME'] = $product["NAME"];
$product['PRODUCT_ACTIVE'] = $product["ACTIVE"];
$product['PRICE'] = $product['CATALOG_PRICE_' . $basePriceId];
$product['PURCHASE_PRICE'] = $product['CATALOG_PURCHASING_PRICE'];
$product['QUANTITY'] = $product["CATALOG_QUANTITY"];
foreach ($resPropertiesProduct as $key => $propProduct) {
if ($this->propertiesProduct[$id][$key] != "" || $this->propertiesProduct[$id][str_replace("_UNIT", "", $key)] != "") {
$product['_PROP_' . $key] = $propProduct;
}
}
$stringOffers .= $this->BuildOffer($product, $categories, $iblock, $allCategories);
}
2016-09-15 16:42:10 +03:00
}
unset($products);
2016-10-04 17:57:39 +03:00
if ($this->isLogged) {
2016-09-15 16:42:10 +03:00
$this->WriteLog(($this->pageSize * $arNavStatParams['iNumPage']) . " product(s) has been loaded from " . $id . " IB (memory usage: " . memory_get_usage() . ")");
}
if ($stringOffers != "") {
$this->WriteOffers($stringOffers);
$stringOffers = "";
}
$arNavStatParams['iNumPage'] = $dbResProductsIds->NavPageNomer + 1;
2016-10-04 17:57:39 +03:00
} while ($dbResProductsIds->NavPageNomer < $dbResProductsIds->NavPageCount);
2016-09-15 16:42:10 +03:00
}
}
protected function BuildOffer($arOffer, $categories, $iblock, &$allCategories)
{
$offer = "";
$offer .= "<offer id=\"" .$this->PrepareValue($arOffer["ID"]) . "\" ".
"productId=\"" . $this->PrepareValue($arOffer["PRODUCT_ID"]) . "\" ".
"quantity=\"" . $this->PrepareValue(DoubleVal($arOffer['QUANTITY'])) . "\">\n";
2016-10-04 17:57:39 +03:00
if ($arOffer['PRODUCT_ACTIVE'] == "N") {
2016-09-15 16:42:10 +03:00
$offer .= "<productActivity>" . $this->PrepareValue($arOffer['PRODUCT_ACTIVE']) . "</productActivity>\n";
}
$keys = array_keys($categories);
if (strpos($arOffer['DETAIL_PAGE_URL'], "#SECTION_PATH#") !== false) {
if (count($categories) != 0) {
$category = $allCategories[$keys[0]];
$path = $category['CODE'];
2016-10-04 17:57:39 +03:00
if (intval($category["IBLOCK_SECTION_ID"] ) != 0) {
2016-09-15 16:42:10 +03:00
while (true) {
$category = $allCategories[$category['IBLOCK_SECTION_ID']];
$path = $category['CODE'] . '/' . $path;
2016-10-04 17:57:39 +03:00
if(intval($category["IBLOCK_SECTION_ID"]) == 0){
2016-09-15 16:42:10 +03:00
break;
2016-10-04 17:57:39 +03:00
}
2016-09-15 16:42:10 +03:00
}
}
}
$arOffer['DETAIL_PAGE_URL'] = str_replace("#SECTION_PATH#", $path, $arOffer['DETAIL_PAGE_URL']);
}
2018-10-04 16:28:14 +03:00
if (isset($arOffer["PICTURE"]) && $arOffer["PICTURE"]) {
$offer .= "<picture>" . $this->PrepareValue($arOffer["PICTURE"]) . "</picture>\n";
}
2016-09-15 16:42:10 +03:00
$offer .= "<url>" . $this->protocol . $this->serverName . $this->PrepareValue($arOffer['DETAIL_PAGE_URL']) . "</url>\n";
$offer .= "<price>" . $this->PrepareValue($arOffer['PRICE']) . "</price>\n";
2020-04-15 16:01:21 +03:00
if ($this->loadPurchasePrice) {
if ($arOffer['PURCHASE_PRICE']) {
$offer .= "<purchasePrice>" . $this->PrepareValue($arOffer['PURCHASE_PRICE']) . "</purchasePrice>\n";
} elseif ("Y" == $this->purchasePriceNull) {
$offer .= "<purchasePrice>0</purchasePrice>\n";
}
2016-09-15 16:42:10 +03:00
}
2020-04-15 16:01:21 +03:00
2016-10-04 17:57:39 +03:00
foreach ($categories as $category) {
2016-09-15 16:42:10 +03:00
$offer .= "<categoryId>" . $category['ID'] . "</categoryId>\n";
}
$offer .= "<name>" . $this->PrepareValue($arOffer["NAME"]) . "</name>\n";
$offer .= "<xmlId>" . $this->PrepareValue($arOffer["EXTERNAL_ID"]) . "</xmlId>\n";
$offer .= "<productName>" . $this->PrepareValue($arOffer["PRODUCT_NAME"]) . "</productName>\n";
foreach ($this->propertiesProduct[$iblock['IBLOCK_DB']['ID']] as $key => $propProduct) {
if ($propProduct != "" && $arOffer['_PROP_' . $key] != null) {
2016-10-04 17:57:39 +03:00
if ($key === "manufacturer") {
2016-09-15 16:42:10 +03:00
$offer .= "<vendor>" . $this->PrepareValue($arOffer['_PROP_' . $key]) . "</vendor>\n";
2016-10-04 17:57:39 +03:00
} else {
$name = $key;
if (isset($this->localizedIBlockProps[$key])) {
$name = $this->localizedIBlockProps[$key];
}
$offer .= '<param name="' . $name . '" code="' . $key . '"' . (isset($arOffer['_PROP_' . $key . "_UNIT"]) ? ' unit="' . $arOffer['_PROP_' . $key . "_UNIT"] . '"' : "") . ">" . $this->PrepareValue($arOffer['_PROP_' . $key]) . "</param>\n";
2016-09-15 16:42:10 +03:00
}
}
}
foreach ($this->propertiesSKU[$iblock['IBLOCK_DB']['ID']] as $key => $propProduct) {
if ($propProduct != "" && $arOffer['_PROP_' . $key] != null) {
2016-10-04 17:57:39 +03:00
if ($key === "manufacturer") {
2016-09-15 16:42:10 +03:00
$offer .= "<vendor>" . $this->PrepareValue($arOffer['_PROP_' . $key]) . "</vendor>\n";
2016-10-04 17:57:39 +03:00
} else {
$name = $key;
if (isset($this->localizedIBlockProps[$key])) {
$name = $this->localizedIBlockProps[$key];
}
$offer .= '<param name="' . $name . '" code="' . $key . '"' . (isset($arOffer['_PROP_' . $key . "_UNIT"]) ? ' unit="' . $arOffer['_PROP_' . $key . "_UNIT"] . '"' : "") . ">" . $this->PrepareValue($arOffer['_PROP_' . $key]) . "</param>\n";
2016-09-15 16:42:10 +03:00
}
}
}
2016-12-13 14:01:48 +03:00
if (isset($arOffer["MEASURE"]['SYMBOL_INTL'])) {
if ($this->measure[$arOffer["MEASURE"]['SYMBOL_INTL']]) {
$offer .= '<unit code="' . $this->measure[$this->PrepareValue($arOffer["MEASURE"]['SYMBOL_INTL'])] . '" />' . "\n";
} else {
$offer .= '<unit code="' . $this->PrepareValue($arOffer["MEASURE"]['SYMBOL_INTL']) . '" name="' . $this->PrepareValue($arOffer["MEASURE"]['MEASURE_TITLE']) . '" sym="' . $this->PrepareValue($arOffer["MEASURE"]['SYMBOL_RUS']) . '" />' . "\n";
}
} else {
$measure = \Bitrix\Catalog\ProductTable::getCurrentRatioWithMeasure($arOffer["ID"]);
2017-09-04 11:36:04 +03:00
if ($this->measure[$measure[$arOffer["ID"]]["MEASURE"]['SYMBOL_INTL']]) {
$offer .= '<unit code="' . $this->measure[$this->PrepareValue($measure[$arOffer["ID"]]["MEASURE"]['SYMBOL_INTL'])] . '" />' . "\n";
} else {
$offer .= '<unit code="' . $this->PrepareValue($measure[$arOffer["ID"]]["MEASURE"]['SYMBOL_INTL']) . '" name="' . $this->PrepareValue($measure[$arOffer["ID"]]["MEASURE"]['MEASURE_TITLE']) . '" sym="' . $this->PrepareValue($measure[$arOffer["ID"]]["MEASURE"]['SYMBOL_RUS']) . '" />' . "\n";
}
2016-12-13 14:01:48 +03:00
}
2018-06-13 13:05:58 +03:00
if ($arOffer["BARCODE"]) {
$offer.= "<barcode>" . $this->PrepareValue($arOffer["BARCODE"]) . "</barcode>\n";
}
2016-09-15 16:42:10 +03:00
2020-04-29 17:47:25 +03:00
if ((float)$arOffer["CATALOG_VAT"]) {
2019-01-16 10:28:11 +03:00
$vatRate = $arOffer["CATALOG_VAT"];
} else {
$vatRate = 'none';
}
$offer.= "<vatRate>" . $this->PrepareValue($vatRate) . "</vatRate>\n";
2016-09-15 16:42:10 +03:00
$offer.= "</offer>\n";
2018-10-04 16:28:14 +03:00
2016-09-15 16:42:10 +03:00
return $offer;
2018-03-22 16:11:04 +03:00
}
private function getHBprop($hbProp, $xml_id)
{
2018-05-23 12:19:59 +03:00
if (CModule::IncludeModule('highloadblock')) {
$hlblockArr = \Bitrix\Highloadblock\HighloadBlockTable::getList(array(
'filter' => array('=TABLE_NAME' => $hbProp['USER_TYPE_SETTINGS']['TABLE_NAME'])
))->fetch();
$hlblock = HL\HighloadBlockTable::getById($hlblockArr["ID"])->fetch();
$entity = HL\HighloadBlockTable::compileEntity($hlblock);
$entityClass = $entity->getDataClass();
2018-03-22 16:11:04 +03:00
2018-05-23 12:19:59 +03:00
$result = $entityClass::getList(array(
'select' => array('*'),
'filter' => array('UF_XML_ID' => $xml_id)
));
2018-03-22 16:11:04 +03:00
2018-05-23 12:19:59 +03:00
return $result->fetch();
}
2018-03-22 16:11:04 +03:00
2018-05-23 12:19:59 +03:00
return array();
2018-03-22 16:11:04 +03:00
}
private function getLocalizedIBlockProps()
{
return array(
"article" => GetMessage("PROPERTY_ARTICLE_HEADER_NAME"),
"manufacturer" => GetMessage("PROPERTY_MANUFACTURER_HEADER_NAME"),
"color" => GetMessage("PROPERTY_COLOR_HEADER_NAME"),
"size" => GetMessage("PROPERTY_SIZE_HEADER_NAME"),
"weight" => GetMessage("PROPERTY_WEIGHT_HEADER_NAME"),
"length" => GetMessage("PROPERTY_LENGTH_HEADER_NAME"),
"width" => GetMessage("PROPERTY_WIDTH_HEADER_NAME"),
"height" => GetMessage("PROPERTY_HEIGHT_HEADER_NAME"),
"picture" => GetMessage("PROPERTY_PICTURE_HEADER_NAME")
);
}
2018-05-23 12:19:59 +03:00
}