diff --git a/CHANGELOG.md b/CHANGELOG.md
index c9b188aa..7ccfdc52 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,9 @@
+## 2018-03-22 v.2.3.5
+* В настройку экспорта добавлена настройка свойств типа "справочник"(highloadblock)
+* Добавлена проверка необходимости резервации товаров при выгрузке заказов из retailCRM
+* Исправлен вызов рекурсивного метода в RCrmActions
+* Добавлены недостающие поля retailcrm.json
+
## 2018-02-27 v.2.3.4
* Добавлена передача веса и габаритов в заказе
* Добавлена проверка существования fuser у корзины товаров перед сохранением
diff --git a/intaro.retailcrm/classes/general/RCrmActions.php b/intaro.retailcrm/classes/general/RCrmActions.php
index bc1c3b6a..75c072a1 100644
--- a/intaro.retailcrm/classes/general/RCrmActions.php
+++ b/intaro.retailcrm/classes/general/RCrmActions.php
@@ -276,7 +276,7 @@ class RCrmActions
}
if (!is_array($string)) {
- $string = self::unserializeRecursive($string);
+ $string = self::unserializeArrayRecursive($string);
}
return $string;
diff --git a/intaro.retailcrm/classes/general/config/retailcrm.json b/intaro.retailcrm/classes/general/config/retailcrm.json
index a5ed61ae..dc8c9a4f 100644
--- a/intaro.retailcrm/classes/general/config/retailcrm.json
+++ b/intaro.retailcrm/classes/general/config/retailcrm.json
@@ -131,7 +131,7 @@
"type": "string"
},
"managerId": {
- "type": "int"
+ "type": "int"
},
"browserId": {
"type": "string"
@@ -141,6 +141,28 @@
},
"personalDiscount": {
"type": "string"
+ },
+ "sex": {
+ "type": "string"
+ },
+ "emailMarketingUnsubscribedAt" : {
+ "type": "datetime",
+ "format": "Y-m-d"
+ },
+ "source": {
+ "type": "string"
+ },
+ "medium": {
+ "type": "string"
+ },
+ "campaign": {
+ "type": "string"
+ },
+ "keyword": {
+ "type": "string"
+ },
+ "content": {
+ "type": "string"
}
},
"orders": {
@@ -297,6 +319,14 @@
"bankAccount": {
"type": "string"
},
+ "shipmentDate": {
+ "type": "datetime",
+ "format": "Y-m-d"
+ },
+ "shipped": {
+ "type": "bool",
+ "default": false
+ },
"orderType": {
"type": "string"
},
@@ -439,6 +469,36 @@
},
"custom": {
"type": "string"
+ },
+ "vatRate": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ },
+ "xmlId": {
+ "type": "string"
+ },
+ "netCost": {
+ "type": "double"
+ },
+ "source": {
+ "type": "string"
+ },
+ "medium": {
+ "type": "string"
+ },
+ "campaign": {
+ "type": "string"
+ },
+ "keyword": {
+ "type": "string"
+ },
+ "content": {
+ "type": "string"
}
}
}
\ No newline at end of file
diff --git a/intaro.retailcrm/classes/general/history/RetailCrmHistory_v5.php b/intaro.retailcrm/classes/general/history/RetailCrmHistory_v5.php
index 8b2b9e06..8f9d2f7d 100644
--- a/intaro.retailcrm/classes/general/history/RetailCrmHistory_v5.php
+++ b/intaro.retailcrm/classes/general/history/RetailCrmHistory_v5.php
@@ -697,7 +697,7 @@ class RetailCrmHistory
$orderCrm = RCrmActions::apiMethod($api, 'orderGet', __METHOD__, $order['id']);
}
if ($orderCrm) {
- self::paymentsUpdate($newOrder, $orderCrm['order'], $api, $newHistoryPayments);
+ self::paymentsUpdate($newOrder, $orderCrm['order'], $newHistoryPayments);
}
}
@@ -1036,7 +1036,7 @@ class RetailCrmHistory
if (!$shipment->isSystem()) {
$reserved = false;
- if ($shipment->isReserved()) {
+ if ($shipment->needReservation()) {
$reserved = true;
}
@@ -1094,12 +1094,11 @@ class RetailCrmHistory
*
* @param object $order
* @param array $paymentsCrm
- * @param object $api
* @param array $newHistoryPayments
*
* @return void
*/
- public static function paymentsUpdate($order, $paymentsCrm, $api, &$newHistoryPayments = array())
+ public static function paymentsUpdate($order, $paymentsCrm, &$newHistoryPayments = array())
{
$optionsPayTypes = array_flip(unserialize(COption::GetOptionString(self::$MODULE_ID, self::$CRM_PAYMENT_TYPES, 0)));
$optionsPayment = array_flip(unserialize(COption::GetOptionString(self::$MODULE_ID, self::$CRM_PAYMENT, 0)));
diff --git a/intaro.retailcrm/classes/general/icml/RetailCrmICML.php b/intaro.retailcrm/classes/general/icml/RetailCrmICML.php
index 782d3865..8d8c498d 100644
--- a/intaro.retailcrm/classes/general/icml/RetailCrmICML.php
+++ b/intaro.retailcrm/classes/general/icml/RetailCrmICML.php
@@ -1,4 +1,8 @@
PrepareValue($arCategory["ID"]) . "\""
- . ( intval($arCategory["IBLOCK_SECTION_ID"] ) > 0 ?
- " parentId=\"" . $this->PrepareValue($arCategory["IBLOCK_SECTION_ID"]) . "\""
- :"")
- . ">"
- . $this->PrepareValue($arCategory["NAME"])
- . "\n";
+
-
- echo htmlspecialcharsex($property); ?> + echo htmlspecialcharsex($property); ?> |
@@ -324,6 +358,7 @@ if (file_exists($_SERVER["DOCUMENT_ROOT"]."/bitrix/php_interface/retailcrm/expor
id="IBLOCK_PROPERTY_PRODUCT_=$key?>=$arIBlock["ID"]?>"
name="IBLOCK_PROPERTY_PRODUCT_=$key?>[=$arIBlock["ID"]?>]"
class="property-export"
+ data-type="=$key?>"
onchange="propertyChange(this);">
=') && array_key_exists($key, $iblockFieldsName)) :?>
@@ -362,10 +397,19 @@ if (file_exists($_SERVER["DOCUMENT_ROOT"]."/bitrix/php_interface/retailcrm/expor
foreach ($arIBlock['PROPERTIES_PRODUCT'] as $prop): ?>
';
+ });
+ if (type === 'sku') {
+ $(td).append('');
+ }
+ if (type === 'product') {
+ $(td).append('');
+ }
+ },
+ beforeSend: function() {
+ $(td).append('=GetMessage("WAIT")?>');
+ }
+ });
+ }
//Следующие переменные должны быть обязательно установлены?>
@@ -671,6 +789,14 @@ if (file_exists($_SERVER["DOCUMENT_ROOT"]."/bitrix/php_interface/retailcrm/expor
$vals .= ",IBLOCK_PROPERTY_UNIT_SKU_" . $val;
$vals .= ",IBLOCK_PROPERTY_PRODUCT_" . $val;
$vals .= ",IBLOCK_PROPERTY_UNIT_PRODUCT_" . $val;
+
+ foreach ($hlblockList as $hlblockTable => $hlblock) {
+ $vals .= ',highloadblock'. $hlblockTable .'_' . $val;
+ }
+
+ foreach ($hlblockList as $hlblockTable => $hlblock) {
+ $vals .= ',highloadblock_product'. $hlblockTable .'_' . $val;
+ }
}
?>
diff --git a/intaro.retailcrm/install/index.php b/intaro.retailcrm/install/index.php
index 70dcf4ce..71a47c46 100644
--- a/intaro.retailcrm/install/index.php
+++ b/intaro.retailcrm/install/index.php
@@ -534,7 +534,7 @@ class intaro_retailcrm extends CModule
}
$APPLICATION->IncludeAdminFile(
- GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step3.php'
+ GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step3.php'
);
} elseif ($step == 4) {
if (!CModule::IncludeModule("sale")) {
@@ -547,7 +547,11 @@ class intaro_retailcrm extends CModule
);
}
//order upload
- if (!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && (strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') && isset($_POST['ajax']) && ($_POST['ajax'] == 1)) {
+ if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])
+ && (strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest')
+ && isset($_POST['ajax'])
+ && $_POST['ajax'] == 1
+ ) {
$historyTime = Date('');
RetailCrmOrder::uploadOrders(); // each 50
@@ -558,7 +562,7 @@ class intaro_retailcrm extends CModule
if (!isset($_POST['finish'])) {
$finish = 0;
} else {
- $finish = (int) $_POST['finish'];
+ $finish = (int)$_POST['finish'];
}
$percent = round(100 - ($countLeft * 100 / $countAll), 1);
@@ -572,7 +576,7 @@ class intaro_retailcrm extends CModule
if (isset($_POST['back']) && $_POST['back']) {
$APPLICATION->IncludeAdminFile(
- GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step2.php'
+ GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step2.php'
);
}
@@ -629,10 +633,31 @@ class intaro_retailcrm extends CModule
COption::SetOptionString($this->MODULE_ID, $this->CRM_CONTRAGENT_TYPE, serialize(RCrmActions::clearArr($contragentTypeArr)));
$APPLICATION->IncludeAdminFile(
- GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step4.php'
+ GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step4.php'
);
} elseif ($step == 5) {
+ if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])
+ && (strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest')
+ && isset($_POST['ajax'])
+ && $_POST['ajax'] == 1
+ ) {
+ CModule::IncludeModule('highloadblock');
+ $rsData = \Bitrix\Highloadblock\HighloadBlockTable::getList(array('filter' => array('TABLE_NAME' => $_POST['table'])));
+ $hlblockArr = $rsData->Fetch();
+ $hlblock = \Bitrix\Highloadblock\HighloadBlockTable::getById($hlblockArr["ID"])->fetch();
+ $entity = \Bitrix\Highloadblock\HighloadBlockTable::compileEntity($hlblock);
+ $hbFields = $entity->getFields();
+ $hlblockList['table'] = $hlblockArr["TABLE_NAME"];
+
+ foreach ($hbFields as $hbFieldCode => $hbField) {
+ $hlblockList['fields'][] = $hbFieldCode;
+ }
+
+ $APPLICATION->RestartBuffer();
+ header('Content-Type: application/x-javascript; charset=' . LANG_CHARSET);
+ die(json_encode($hlblockList));
+ }
if (!CModule::IncludeModule("iblock")) {
$arResult['errCode'] = 'ERR_IBLOCK';
}
@@ -710,7 +735,7 @@ class intaro_retailcrm extends CModule
}
$APPLICATION->IncludeAdminFile(
- GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step5.php'
+ GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step5.php'
);
} elseif ($step == 6) {
if (!CModule::IncludeModule("iblock")) {
@@ -725,7 +750,7 @@ class intaro_retailcrm extends CModule
if (isset($arResult['errCode']) && $arResult['errCode']) {
$APPLICATION->IncludeAdminFile(
- GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step5.php'
+ GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step5.php'
);
return;
@@ -733,7 +758,7 @@ class intaro_retailcrm extends CModule
if (isset($_POST['back']) && $_POST['back']) {
$APPLICATION->IncludeAdminFile(
- GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step3.php'
+ GetMessage('MODULE_INSTALL_TITLE'), $this->INSTALL_PATH . '/step3.php'
);
}
@@ -742,20 +767,37 @@ class intaro_retailcrm extends CModule
} else {
$iblocks = $_POST['IBLOCK_EXPORT'];
}
-
+
+ //highloadblock
+ CModule::IncludeModule('highloadblock');
+ $hlblockList = array();
+ $hlblockListDb = \Bitrix\Highloadblock\HighloadBlockTable::getList();
+
+ while ($hlblockArr = $hlblockListDb->Fetch()) {
+ $hlblock = \Bitrix\Highloadblock\HighloadBlockTable::getById($hlblockArr["ID"])->fetch();
+ $entity = \Bitrix\Highloadblock\HighloadBlockTable::compileEntity($hlblock);
+ $hbFields = $entity->getFields();
+ $hlblockList[$hlblockArr["TABLE_NAME"]]['LABEL'] = $hlblockArr["NAME"];
+
+ foreach ($hbFields as $hbFieldCode => $hbField) {
+ $hlblockList[$hlblockArr["TABLE_NAME"]]['FIELDS'][] = $hbFieldCode;
+ }
+ }
+
$iblockProperties = array(
- "article" => "article",
- "manufacturer" => "manufacturer",
- "color" => "color",
- "weight" => "weight",
- "size" => "size",
- "length" => "length",
- "width" => "width",
- "height" => "height",
- );
+ "article" => "article",
+ "manufacturer" => "manufacturer",
+ "color" => "color",
+ "weight" => "weight",
+ "size" => "size",
+ "length" => "length",
+ "width" => "width",
+ "height" => "height",
+ );
$propertiesSKU = array();
$propertiesUnitSKU = array();
+ $propertiesHbSKU = array();
foreach ($iblockProperties as $prop) {
foreach ($_POST['IBLOCK_PROPERTY_SKU'. '_' . $prop] as $iblock => $val) {
$propertiesSKU[$iblock][$prop] = $val;
@@ -763,10 +805,16 @@ class intaro_retailcrm extends CModule
foreach ($_POST['IBLOCK_PROPERTY_UNIT_SKU'. '_' . $prop] as $iblock => $val) {
$propertiesUnitSKU[$iblock][$prop] = $val;
}
+ foreach ($hlblockList as $tableName => $hb) {
+ foreach ($_POST['highloadblock' . $tableName . '_' . $prop] as $iblock => $val) {
+ $propertiesHbSKU[$tableName][$iblock][$prop] = $val;
+ }
+ }
}
$propertiesProduct = array();
$propertiesUnitProduct = array();
+ $propertiesHbProduct = array();
foreach ($iblockProperties as $prop) {
foreach ($_POST['IBLOCK_PROPERTY_PRODUCT'. '_' . $prop] as $iblock => $val) {
$propertiesProduct[$iblock][$prop] = $val;
@@ -774,6 +822,11 @@ class intaro_retailcrm extends CModule
foreach ($_POST['IBLOCK_PROPERTY_UNIT_PRODUCT'. '_' . $prop] as $iblock => $val) {
$propertiesUnitProduct[$iblock][$prop] = $val;
}
+ foreach ($hlblockList as $tableName => $hb) {
+ foreach ($_POST['highloadblock_product' . $tableName . '_' . $prop] as $iblock => $val) {
+ $propertiesHbProduct[$tableName][$iblock][$prop] = $val;
+ }
+ }
}
if (!isset($_POST['SETUP_FILE_NAME'])) {
@@ -843,6 +896,8 @@ class intaro_retailcrm extends CModule
$loader->propertiesProduct = $propertiesProduct;
$loader->propertiesUnitSKU = $propertiesUnitSKU;
$loader->propertiesSKU = $propertiesSKU;
+ $loader->highloadblockSkuProperties = $propertiesHbSKU;
+ $loader->highloadblockProductProperties = $propertiesHbProduct;
$loader->filename = $filename;
$loader->serverName = \Bitrix\Main\Context::getCurrent()->getServer()->getHttpHost();
$loader->application = $APPLICATION;
@@ -860,7 +915,16 @@ class intaro_retailcrm extends CModule
}
}
}
- $ar = $this->GetProfileSetupVars($iblocks, $propertiesProduct, $propertiesUnitProduct, $propertiesSKU, $propertiesUnitSKU, $filename);
+ $ar = $this->GetProfileSetupVars(
+ $iblocks,
+ $propertiesProduct,
+ $propertiesUnitProduct,
+ $propertiesSKU,
+ $propertiesUnitSKU,
+ $propertiesHbSKU,
+ $propertiesHbProduct,
+ $filename
+ );
$PROFILE_ID = CCatalogExport::Add(array(
"LAST_USE" => false,
"FILE_NAME" => $this->RETAIL_CRM_EXPORT,
@@ -1081,7 +1145,16 @@ class intaro_retailcrm extends CModule
rmdir($defaultSite['ABS_DOC_ROOT'] . '/retailcrm/');
}
- function GetProfileSetupVars($iblocks, $propertiesProduct, $propertiesUnitProduct, $propertiesSKU, $propertiesUnitSKU, $filename) {
+ function GetProfileSetupVars(
+ $iblocks,
+ $propertiesProduct,
+ $propertiesUnitProduct,
+ $propertiesSKU,
+ $propertiesUnitSKU,
+ $propertiesHbSKU,
+ $propertiesHbProduct,
+ $filename
+ ) {
$strVars = "";
foreach ($iblocks as $key => $val)
$strVars .= 'IBLOCK_EXPORT[' . $key . ']=' . $val . '&';
@@ -1097,9 +1170,17 @@ class intaro_retailcrm extends CModule
foreach ($propertiesUnitProduct as $iblock => $arr)
foreach ($arr as $id => $val)
$strVars .= 'IBLOCK_PROPERTY_UNIT_PRODUCT_' . $id . '[' . $iblock . ']=' . $val . '&';
-
+ foreach ($propertiesHbSKU as $table => $arr)
+ foreach ($arr as $iblock => $val)
+ foreach ($val as $id => $value)
+ $strVars .= 'highloadblock' . $table . '_' . $id . '[' . $iblock . ']=' . $value . '&';
+ foreach ($propertiesHbProduct as $table => $arr)
+ foreach ($arr as $iblock => $val)
+ foreach ($val as $id => $value)
+ $strVars .= 'highloadblock_product' . $table . '_' . $id . '[' . $iblock . ']=' . $value . '&';
+
$strVars .= 'SETUP_FILE_NAME=' . urlencode($filename);
-
+
return $strVars;
}
diff --git a/intaro.retailcrm/install/step5.php b/intaro.retailcrm/install/step5.php
index 91201bbe..e01b603c 100644
--- a/intaro.retailcrm/install/step5.php
+++ b/intaro.retailcrm/install/step5.php
@@ -210,7 +210,7 @@ if (!empty($oldValues)) {
>
-
+ ">
|