use Bitrix\Main\Application; use Bitrix\Main\Page\Asset; use Bitrix\Sale\Order; use Bitrix\Main\Localization\Loc; use Bitrix\Sale\Delivery\Requests; use \Bitrix\Sale\Exchange\Integration\Admin\Link, \Bitrix\Sale\Exchange\Integration\Admin\Registry, \Bitrix\Sale\Exchange\Integration\Admin\ModeType, \Bitrix\Sale\Helpers\Admin\Blocks\FactoryMode, \Bitrix\Sale\Helpers\Admin\Blocks\BlockType; require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_admin_before.php"); \Bitrix\Main\Loader::includeModule('sale'); require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/prolog.php"); $moduleId = "sale"; global $USER, $APPLICATION; Bitrix\Main\Loader::includeModule('sale'); $saleModulePermissions = $APPLICATION->GetGroupRight("sale"); if ($saleModulePermissions == "D") $APPLICATION->AuthForm(GetMessage("ACCESS_DENIED")); IncludeModuleLangFile(__FILE__); CUtil::InitJSCore(); require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/lib/helpers/admin/orderedit.php"); Asset::getInstance()->addCss('/bitrix/themes/.default/sale.css'); /** @var null|\Bitrix\Sale\Order $saleOrder */ $saleOrder = null; $shipment = null; $dataArray = array(); $dataForRecovery = array(); $errors = array(); $request = Application::getInstance()->getContext()->getRequest(); $lang = Application::getInstance()->getContext()->getLanguage(); $orderId = intval($request->get('order_id')); $shipmentId = intval($request->get('shipment_id')); $siteId = Application::getInstance()->getContext()->getSite(); $link = Link::getInstance(); $factory = FactoryMode::create($link->getType()); $backUrl = $request->get('backurl'); $save = $_SERVER["REQUEST_METHOD"] == "POST" && (isset($_POST["apply"]) || isset($_POST["save"])); $refresh = $_SERVER["REQUEST_METHOD"] == "POST" && !$save; $registry = \Bitrix\Sale\Registry::getInstance(\Bitrix\Sale\Registry::REGISTRY_TYPE_ORDER); /** @var Order $orderClass */ $orderClass = $registry->getOrderClassName(); if($orderId <= 0 || !($saleOrder = $orderClass::load($orderId))) { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER) ->redirect(); } $allowedOrderStatusesView = \Bitrix\Sale\OrderStatus::getStatusesUserCanDoOperations($USER->GetID(), array('view')); $allowedOrderStatusesUpdate = \Bitrix\Sale\OrderStatus::getStatusesUserCanDoOperations($USER->GetID(), array('update')); $allowUpdate = in_array($saleOrder->getField("STATUS_ID"), $allowedOrderStatusesUpdate); $allowView = in_array($saleOrder->getField("STATUS_ID"), $allowedOrderStatusesView); $allowDelete = false; $shipmentCollection = $saleOrder->getShipmentCollection(); if (intval($shipmentId) > 0) { /** @var \Bitrix\Sale\Shipment $shipment */ $shipment = $shipmentCollection->getItemById($shipmentId); if(!$shipment) { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER) ->redirect(); } $allowedDeliveryStatusesView = \Bitrix\Sale\DeliveryStatus::getStatusesUserCanDoOperations($USER->GetID(), array('view')); $allowedDeliveryStatusesUpdate = \Bitrix\Sale\DeliveryStatus::getStatusesUserCanDoOperations($USER->GetID(), array('update')); $allowedDeliveryStatusesDelete = \Bitrix\Sale\DeliveryStatus::getStatusesUserCanDoOperations($USER->GetID(), array('delete')); $allowUpdate = in_array($shipment->getField("STATUS_ID"), $allowedDeliveryStatusesUpdate); $allowView = in_array($shipment->getField("STATUS_ID"), $allowedDeliveryStatusesView); $allowDelete = in_array($shipment->getField("STATUS_ID"), $allowedDeliveryStatusesDelete); } $isUserResponsible = false; $isAllowCompany = false; if ($saleModulePermissions == 'P') { $userCompanyList = \Bitrix\Sale\Services\Company\Manager::getUserCompanyList($USER->GetID()); $isUserResponsible = ($saleOrder->getField('RESPONSIBLE_ID') == $USER->GetID() || $shipment->getField('RESPONSIBLE_ID') == $USER->GetID()); $isAllowCompany = (in_array($saleOrder->getField('COMPANY_ID'), $userCompanyList) || in_array($shipment->getField('COMPANY_ID'), $userCompanyList)); if (!$isUserResponsible && !$isAllowCompany) { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER) ->redirect(); } } if ($request->get('delete') == 'Y' && check_bitrix_sessid()) { if(!$allowDelete) { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT) ->redirect(); } $delResult = $shipment->delete(); if (!$delResult->isSuccess()) { $errors = $delResult->getErrorMessages(); } else { $result = $saleOrder->save(); if ($result->isSuccess()) { if ($backUrl) { $link ->create() ->setRequestUri($backUrl) ->redirect(); } else { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT) ->redirect(); } } else { $errors = $result->getErrorMessages(); } } } if ($request->isPost() && ($save || $refresh) && check_bitrix_sessid()) { if(!$allowUpdate) { if (isset($_POST["apply"])) { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT_EDIT) ->setField('order_id', $orderId) ->setField('shipment_id', $shipmentId) ->setField('backurl', $backUrl) ->redirect(); } else { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT) ->redirect(); } } $result = $factory::create(BlockType::SHIPMENT)->updateData($saleOrder, $request->get('SHIPMENT')); $data = $result->getData(); $shipment = null; if ($data['SHIPMENT']) $shipment = array_shift($data['SHIPMENT']); if ($result->isSuccess() && $save) { $saveResult = $saleOrder->save(); if ($saveResult->isSuccess()) { $shipmentId = $shipment->getId(); if ($request->getPost("apply") == '') { if ($backUrl) { $link ->create() ->setRequestUri($backUrl) ->redirect(); } else { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT) ->redirect(); } } else { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT_EDIT) ->setField('order_id', $orderId) ->setField('shipment_id', $shipmentId) ->setField('backurl', $backUrl) ->redirect(); } } else { $result->addErrors($saveResult->getErrors()); $errors = $result->getErrorMessages(); if (empty($errors)) $errors[] = Loc::getMessage('SOPE_SHIPMENT_ERROR_MESSAGE'); $dataForRecovery = $request->get('SHIPMENT'); } } else { if (!$refresh) { /** @var \Bitrix\Main\Entity\EntityError $error */ foreach ($result->getErrors() as $error) $errors[$error->getCode()] = $error->getMessage(); if (empty($errors)) $errors[] = Loc::getMessage('SOPE_SHIPMENT_ERROR_MESSAGE'); } $dataForRecovery = $request->get('SHIPMENT'); } } else { $new = true; if ($shipmentId > 0 && $shipment) { $new = false; } if ($new) { $shipment = $saleOrder->getShipmentCollection()->createItem(); $factory::create(BlockType::SHIPMENT)->setShipmentByDefaultValues($shipment); } } if (!$shipment || (!$allowView && !$allowUpdate) || Order::isLocked($orderId)) { $link ->create() ->fill() ->setPageByType(Registry::SALE_ORDER_SHIPMENT) ->redirect(); } if ($shipmentId) $title = str_replace("#ID#", $shipmentId, GetMessage("EDIT_ORDER_SHIPMENT")); else $title = GetMessage("NEW_ORDER_SHIPMENT"); $APPLICATION->SetTitle($title); if ($shipmentId > 0) { global $historyEntity; $historyEntity = array( 'ENTITY' => 'SHIPMENT', 'ENTITY_ID' => $shipmentId ); $_GET['ID'] = $orderId; ob_start(); require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/admin/order_history.php"); $historyContent = ob_get_contents(); ob_end_clean(); } require($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_admin_after.php"); $aMenu = array(); $aMenu[] = array( "ICON" => "btn_list", "TEXT" => Loc::getMessage("SOPE_SHIPMENT_TRANSITION"), "TITLE"=> Loc::getMessage("SOPE_SHIPMENT_TRANSITION_TITLE"), "LINK" => $link ->create() ->fill() ->setField('ID', $orderId) ->setPageByType(Registry::SALE_ORDER_VIEW) ->build() ); if (!$new) { if($allowDelete) { $href = $link ->create() ->setField('order_id', $orderId) ->setField('shipment_id', $shipmentId) ->setField('delete', 'Y') ->setQuery(bitrix_sessid_get()) ->setPageByType(Registry::SALE_ORDER_SHIPMENT_EDIT) ->fill() ->build(); $aMenu[] = array( "TEXT" => Loc::getMessage("SOPE_SHIPMENT_DELETE"), "TITLE" => Loc::getMessage("SOPE_SHIPMENT_DELETE_TITLE"), "LINK" => 'javascript:void(0)', "ONCLICK" => "if(confirm('".Loc::getMessage('SOPE_SHIPMENT_DELETE_MESSAGE')."')) window.location.href='".$href."'" ); } } if($link->getType() == ModeType::APP_LAYOUT_TYPE) { //do nothing } else { $aMenu[] = array( "TEXT" => Loc::getMessage("SOPE_SHIPMENT_LIST"), "TITLE"=> Loc::getMessage("SOPE_SHIPMENT_LIST_TITLE"), "LINK" => $link ->create() ->setPageByType(Registry::SALE_ORDER_SHIPMENT) ->fill() ->build() ); if (!$new) { $arSysLangs = array(); $db_lang = CLangAdmin::GetList("sort", "asc", array("ACTIVE" => "Y")); while ($arLang = $db_lang->Fetch()) $arSysLangs[] = $arLang["LID"]; $arReports = array(); $dirs = array( $_SERVER["DOCUMENT_ROOT"]."/bitrix/admin/reports/", $_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/reports/" ); foreach ($dirs as $dir) { if (file_exists($dir)) { if ($handle = opendir($dir)) { while (($file = readdir($handle)) !== false) { $file_contents = ''; if ($file == "." || $file == ".." || $file == ".access.php" || isset($arReports[$file])) continue; if (is_file($dir.$file) && ToUpper(mb_substr($file, -4)) == ".PHP") { $rep_title = $file; if ($dir == $_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/reports/") { if (is_file($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/ru/reports/".$file)) $file_contents = file_get_contents($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/ru/reports/".$file); } if (empty($file_contents)) $file_contents = file_get_contents($dir.$file); $rep_langs = ""; $arMatches = array(); if (preg_match("#