Esempio n. 1
0
 /**
  * <p>Функция обновляет параметры товара, относящиеся к товару как к таковому.</p>
  *
  *
  *
  *
  * @param int $ID  Код товара.
  *
  *
  *
  * @param array $arFields  Ассоциативный массив, ключами которого являются названия
  * параметров товара, а значениями - новые значения параметров.
  * Допустимые ключи: <br><br> ключи, независящие от типа товаров: <ul> <li>
  * <b>QUANTITY</b> - количество товара на складе;</li> <li> <b>QUANTITY_RESERVED</b> -
  * зарезервированное количество;</li> <li> <b>QUANTITY_TRACE</b> - флаг (Y/N/D)<b>*</b>
  * "включить количественный учет" (до версии 12.5.0 параметр назывался
  * "уменьшать ли количество при заказе");</li> </ul> <br> ключи для обычных
  * товаров: <ul> <li> <b>CAN_BUY_ZERO</b> - флаг (Y/N/D)<b>*</b> "разрешить покупку при
  * отсутствии товара";</li> <li> <b>NEGATIVE_AMOUNT_TRACE</b> - флаг (Y/N/D)<b>*</b>
  * "разрешить отрицательное количество товара";</li> <li> <b>SUBSCRIBE</b> - флаг
  * (Y/N/D)<b>*</b> "разрешить подписку при отсутствии товара"; <br><br> </li> <li>
  * <b>PURCHASING_PRICE</b> - закупочная цена;</li> <li> <b>PURCHASING_CURRENCY</b> - валюта
  * закупочной цены;<br><br> </li> <li> <b>WEIGHT</b> - вес единицы товара;<br><br> </li> <li>
  * <b>WIDTH</b> - ширина товара (в мм);</li> <li> <b>LENGTH</b> - длина товара (в мм);</li>
  * <li> <b>HEIGHT</b> - высота товара (в мм);</li> <li> <b>MEASURE</b> - ID единицы
  * измерения;<br><br> </li> <li> <b>BARCODE_MULTI</b> - (Y/N) определяет каждый ли
  * экземпляр товара имеет собственный штрихкод;</li> </ul> <br> ключи для
  * продажи контента: <ul> <li> <b>PRICE_TYPE</b> - тип цены (S - одноразовый платеж,
  * R - регулярные платежи, T - пробная подписка);</li> <li> <b>RECUR_SCHEME_TYPE</b> -
  * тип периода подписки ("H" - час, "D" - сутки, "W" - неделя, "M" - месяц, "Q" -
  * квартал, "S" - полугодие, "Y" - год);</li> <li> <b>RECUR_SCHEME_LENGTH</b> - длина
  * периода подписки;</li> <li> <b>TRIAL_PRICE_ID</b> - код товара, для которого
  * данный товар является пробным;</li> <li> <b>WITHOUT_ORDER</b> - флаг "Продление
  * подписки без оформления заказа".</li> </ul>
  *
  *
  *
  * @return bool <p>Возвращает <i>true</i> в случае успешного обновления параметров и
  * <i>false</i> в противном случае.</p>
  *
  *
  * <h4>Example</h4> 
  * <pre>
  * Обновление зарезервированного количества товара
  * 
  * 
  * Cmodule::IncludeModule('catalog');
  * $PRODUCT_ID = 51; // id товара
  * $arFields = array('QUANTITY_RESERVED' =&gt; 11);// зарезервированное количество
  * CCatalogProduct::Update($PRODUCT_ID, $arFields);
  * </pre>
  *
  *
  * @static
  * @link http://dev.1c-bitrix.ru/api_help/catalog/classes/ccatalogproduct/ccatalogproduct__update.bc9a623b.php
  * @author Bitrix
  */
 public static function Update($ID, $arFields)
 {
     global $DB;
     $ID = (int) $ID;
     if ($ID <= 0) {
         return false;
     }
     if (array_key_exists('ID', $arFields)) {
         unset($arFields["ID"]);
     }
     foreach (GetModuleEvents("catalog", "OnBeforeProductUpdate", true) as $arEvent) {
         if (ExecuteModuleEventEx($arEvent, array($ID, &$arFields)) === false) {
             return false;
         }
     }
     if (!CCatalogProduct::CheckFields("UPDATE", $arFields, $ID)) {
         return false;
     }
     $strUpdate = $DB->PrepareUpdate("b_catalog_product", $arFields);
     $boolSubscribe = false;
     if (!empty($strUpdate)) {
         if (isset($arFields["QUANTITY"]) && $arFields["QUANTITY"] > 0) {
             if (!isset($arFields["OLD_QUANTITY"])) {
                 $strQuery = 'select ID, QUANTITY from b_catalog_product where ID = ' . $ID;
                 $rsProducts = $DB->Query($strQuery, false, "File: " . __FILE__ . "<br>Line: " . __LINE__);
                 if ($arProduct = $rsProducts->Fetch()) {
                     $arFields["OLD_QUANTITY"] = doubleval($arProduct['QUANTITY']);
                 }
             }
             if (isset($arFields["OLD_QUANTITY"])) {
                 $boolSubscribe = $arFields["OLD_QUANTITY"] <= 0;
             }
         }
         $strSql = "UPDATE b_catalog_product SET " . $strUpdate . " WHERE ID = " . $ID;
         $DB->Query($strSql, false, "File: " . __FILE__ . "<br>Line: " . __LINE__);
         if (CBXFeatures::IsFeatureEnabled('CatCompleteSet') && (isset($arFields['QUANTITY']) || isset($arFields['QUANTITY_TRACE']) || isset($arFields['CAN_BUY_ZERO']) || isset($arFields['WEIGHT']))) {
             CCatalogProductSet::recalculateSetsByProduct($ID);
         }
         if (isset(self::$arProductCache[$ID])) {
             unset(self::$arProductCache[$ID]);
             if (defined('CATALOG_GLOBAL_VARS') && 'Y' == CATALOG_GLOBAL_VARS) {
                 global $CATALOG_PRODUCT_CACHE;
                 $CATALOG_PRODUCT_CACHE = self::$arProductCache;
             }
         }
     }
     foreach (GetModuleEvents("catalog", "OnProductUpdate", true) as $arEvent) {
         ExecuteModuleEventEx($arEvent, array($ID, $arFields));
     }
     //call subscribe
     if ($boolSubscribe && CModule::IncludeModule('sale')) {
         CSaleBasket::ProductSubscribe($ID, "catalog");
     }
     return true;
 }