%PDF- %PDF-
Direktori : /proc/self/root/home/bitrix/www/bitrix/components/bitrix/sale.mobile.order.deduction/ |
Current File : //proc/self/root/home/bitrix/www/bitrix/components/bitrix/sale.mobile.order.deduction/ajax.php |
<? define("NO_KEEP_STATISTIC", true); define('NO_AGENT_CHECK', true); define("NO_AGENT_STATISTIC", true); define("NOT_CHECK_PERMISSIONS", true); define('DisableEventsCheck', true); require($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_admin_before.php"); CComponentUtil::__IncludeLang(dirname($_SERVER["SCRIPT_NAME"]), "/ajax.php"); if (!CModule::IncludeModule('sale')) die(GetMessage("SMODE_SALE_NOT_INSTALLED")); if (!CModule::IncludeModule('mobileapp')) die(GetMessage('SMODE_MOBILEAPP_NOT_INSTALLED')); $arResult = array(); $arUserGroups = $USER->GetUserGroupArray(); $orderId = isset($_REQUEST['orderId']) ? trim($_REQUEST['orderId']) : 0; $bUserCanDeductOrder = CSaleOrder::CanUserChangeOrderFlag($orderId, "PERM_DEDUCTION", $arUserGroups); if($USER->IsAuthorized() && check_bitrix_sessid() && $bUserCanDeductOrder) { $action = isset($_REQUEST['action']) ? trim($_REQUEST['action']): ''; switch ($action) { case "order_deduct": $deducted = isset($_REQUEST['deducted']) ? trim($_REQUEST['deducted']) : ''; $useStores = isset($_REQUEST['useStores']) && trim($_REQUEST['useStores']) == 'Y' ? true : false; $undoReason = isset($_REQUEST['undoReason']) ? trim($_REQUEST['undoReason']) : ''; $arProducts = isset($_REQUEST['products']) ? $_REQUEST['products'] : array(); $arProducts = $APPLICATION->ConvertCharsetArray($arProducts, 'utf-8', SITE_CHARSET); $arStoreInfo = array(); foreach ($arProducts as $prodId => $arProduct) { $arStoresTmp = array(); if(isset($arProduct["STORES"]) && is_array($arProduct["STORES"])) { foreach ($arProduct["STORES"] as $arStore) { if($arProduct["BARCODE_MULTI"] == "N") { reset($arStore["BARCODE"]); $arStore["BARCODE"] = current($arStore["BARCODE"]); unset($arStore["BARCODE_FOUND"]); } if(isset($arStore["QUANTITY"]) && intval($arStore["QUANTITY"]) > 0) $arStoresTmp[] = $arStore; } } $arProducts[$prodId]["STORES"] = $arStoresTmp; $arStoreInfo[$prodId] = $arStoresTmp; } if ($deducted == "Y" && $useStores) { if(!CSaleOrderHelper::checkQuantity($arProducts)) { if ($ex = $APPLICATION->GetException()) { $arResult["ERROR"] = $ex->GetString(); break; } } //check if barcodes are valid for deduction if(!CSaleOrderHelper::checkBarcodes($arProducts)) { if ($ex = $APPLICATION->GetException()) { $arResult["ERROR"] = $ex->GetString(); break; } } } if(strlen($undoReason) > 0) $undoReason = $APPLICATION->ConvertCharset($undoReason, 'utf-8', SITE_CHARSET); if (!CSaleOrder::DeductOrder($orderId, $deducted, $undoReason, false, $arStoreInfo)) { if ($ex = $APPLICATION->GetException()) { if ($ex->GetID() != "ALREADY_FLAG") $arResult["ERROR"] = $ex->GetString(); } else $arResult["ERROR"] = GetMessage("SMODE_ERROR_DEDUCT_ORDER"); } break; } } else { $arResult["ERROR"] = "Access denied!"; } if(isset($arResult["ERROR"])) $arResult["RESULT"] = "ERROR"; else $arResult["RESULT"] = "OK"; $arResult = $APPLICATION->ConvertCharsetArray($arResult, SITE_CHARSET, 'utf-8'); die(json_encode($arResult)); ?>