/** * @var CUser $USER * @var CMain $APPLICATION */ use Bitrix\Main\Localization\Loc; use Bitrix\Sale\Helpers\Admin; use Bitrix\Sale; 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"); require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/prolog.php"); $saleOrder = null; $moduleId = "sale"; $errorMsgs = array(); Loc::loadMessages(__FILE__); Bitrix\Main\Loader::includeModule('sale'); $saleModulePermissions = $APPLICATION->GetGroupRight("sale"); $arUserGroups = $USER->GetUserGroupArray(); $link = Link::getInstance(); $factory = FactoryMode::create($link->getType()); if ($saleModulePermissions == "D") $APPLICATION->AuthForm(Loc::getMessage("ACCESS_DENIED")); require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/lib/helpers/admin/orderedit.php"); $allowedStatusesView = array(); $isAllowView = false; $isAllowUpdate = false; $isAllowDelete = false; $registry = Sale\Registry::getInstance(Sale\Registry::REGISTRY_TYPE_ORDER); /** @var Sale\Order $orderClass */ $orderClass = $registry->getOrderClassName(); //load order if(!empty($_REQUEST["ID"]) && intval($_REQUEST["ID"]) > 0) $saleOrder = $orderClass::load($_REQUEST["ID"]); if($saleOrder) { /** @var Sale\OrderStatus $orderStatusClass */ $orderStatusClass = $registry->getOrderStatusClassName(); $allowedStatusesView = $orderStatusClass::getStatusesUserCanDoOperations($USER->GetID(), array('view')); $allowedStatusesUpdate = $orderStatusClass::getStatusesUserCanDoOperations($USER->GetID(), array('update')); $allowedStatusesDelete = $orderStatusClass::getStatusesUserCanDoOperations($USER->GetID(), array('delete')); $isAllowView = in_array($saleOrder->getField("STATUS_ID"), $allowedStatusesView); $isAllowUpdate = in_array($saleOrder->getField("STATUS_ID"), $allowedStatusesUpdate); $isAllowDelete = in_array($saleOrder->getField("STATUS_ID"), $allowedStatusesDelete); } if(!$saleOrder || !$isAllowView) { $link ->create() ->setFilterParams(false) ->fill() ->setPageByType(Registry::SALE_ORDER) ->redirect(); } $isUserResponsible = false; $isAllowCompany = false; if ($saleModulePermissions == 'P') { $userCompanyList = \Bitrix\Sale\Services\Company\Manager::getUserCompanyList($USER->GetID()); if ($saleOrder->getField('RESPONSIBLE_ID') == $USER->GetID()) { $isUserResponsible = true; } if (in_array($saleOrder->getField('COMPANY_ID'), $userCompanyList)) { $isAllowCompany = true; } if (!$isUserResponsible && !$isAllowCompany) { $link ->create() ->setFilterParams(false) ->fill() ->setPageByType(Registry::SALE_ORDER) ->redirect(); } } $ID = intval($_REQUEST["ID"]); $boolLocked = $orderClass::isLocked($ID); //Unlocking if we leave this page if(isset($_REQUEST['unlock']) && 'Y' == $_REQUEST['unlock']) { $lockStatusRes = $orderClass::getLockedStatus($ID); if($lockStatusRes->isSuccess()) $lockStatusData = $lockStatusRes->getData(); if(isset($lockStatusData['LOCK_STATUS']) && ( $lockStatusData['LOCK_STATUS'] != $orderClass::SALE_ORDER_LOCK_STATUS_RED || !isset($_REQUEST['target']) ) ) { $res = $orderClass::unlock($ID); if($res->isSuccess()) { /** @var Sale\DiscountCouponsManager $discountCouponsClass */ $discountCouponsClass = $registry->getDiscountCouponClassName(); $discountCouponsClass::clearByOrder($ID); } } if(isset($_REQUEST['target']) && 'list' == $_REQUEST['target']) { $link ->create() ->setFilterParams(false) ->fill() ->setPageByType(Registry::SALE_ORDER) ->redirect(); } else { $link ->create() ->setFilterParams(false) ->fill() ->setPageByType(Registry::SALE_ORDER_VIEW) ->redirect(); } } if ($boolLocked) $errorMsgs[] = Admin\OrderEdit::getLockingMessage($ID); else $orderClass::lock($ID); $customTabber = new CAdminTabEngine("OnAdminSaleOrderView", array("ID" => $ID)); $customDraggableBlocks = new CAdminDraggableBlockEngine('OnAdminSaleOrderViewDraggable', array('ORDER' => $saleOrder)); /** @var Sale\Order $saleOrder */ Admin\OrderEdit::initCouponsData( $saleOrder->getUserId(), $ID, null ); CUtil::InitJSCore(); $APPLICATION->SetTitle( Loc::getMessage( "SALE_OVIEW_TITLE", array( "#ID#" => $saleOrder->getId(), "#NUM#" => $saleOrder->getField('ACCOUNT_NUMBER') <> '' ? $saleOrder->getField('ACCOUNT_NUMBER') : $saleOrder->getId(), "#DATE#" => $saleOrder->getDateInsert()->toString() ) ) ); \Bitrix\Main\Page\Asset::getInstance()->addJs("/bitrix/js/sale/admin/order_edit.js"); 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"); /* context menu */ $aMenu = array(); $aMenu[] = array( "ICON" => "btn_list", "TEXT" => Loc::getMessage("SALE_OVIEW_TO_LIST"), "TITLE"=> Loc::getMessage("SALE_OVIEW_TO_LIST_TITLE"), "LINK" => $link ->create() ->setFilterParams(false) ->fill() ->setPageByType(Registry::SALE_ORDER_VIEW) ->setField('unlock','Y') ->setField('target','list') ->setField('ID', $ID) ->build() ); if ($boolLocked && $saleModulePermissions >= 'W') { $aMenu[] = array( "TEXT" => GetMessage("SALE_OVIEW_UNLOCK"), "LINK" => $link ->create() ->setFilterParams(false) ->fill() ->setPageByType(Registry::SALE_ORDER_VIEW) ->setField('unlock','Y') ->setField('ID', $ID) ->build() ); } if($link->getType() == ModeType::APP_LAYOUT_TYPE) { if(!$boolLocked && $isAllowUpdate) { $aMenu[] = [ "TEXT" => Loc::getMessage("SALE_OVIEW_TO_EDIT"), "TITLE"=> Loc::getMessage("SALE_OVIEW_TO_EDIT_TITLE"), "LINK" => $link ->create() ->setFilterParams(false) ->setPageByType(Registry::SALE_ORDER_EDIT) ->setField('ID', $ID) ->fill() ->build(), ]; } } else { if(!$boolLocked && $isAllowUpdate) { $aMenu[] = [ "TEXT" => Loc::getMessage("SALE_OVIEW_TO_EDIT"), "TITLE"=> Loc::getMessage("SALE_OVIEW_TO_EDIT_TITLE"), "LINK" => $link ->create() ->setFilterParams(false) ->setPageByType(Registry::SALE_ORDER_EDIT) ->setField('ID', $ID) ->fill() ->build(), ]; } $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("#