%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/modules/sale/lib/internals/ |
Current File : /home/bitrix/www/bitrix/modules/sale/lib/internals/discountgroup.php |
<?php namespace Bitrix\Sale\Internals; use Bitrix\Main; use Bitrix\Main\Application; use Bitrix\Main\Localization\Loc; Loc::loadMessages(__FILE__); /** * Class DiscountGroupTable * * Fields: * <ul> * <li> ID int mandatory * <li> DISCOUNT_ID int mandatory * <li> ACTIVE string(1) optional * <li> GROUP_ID int mandatory * <li> DISCOUNT reference to {@link \Bitrix\Sale\Internals\DiscountTable} * </ul> * * @package Bitrix\Sale\Internals **/ class DiscountGroupTable extends Main\Entity\DataManager { /** * Returns DB table name for entity. * * @return string */ public static function getTableName() { return 'b_sale_discount_group'; } /** * Returns entity map definition. * * @return array */ public static function getMap() { return array( 'ID' => new Main\Entity\IntegerField('ID', array( 'primary' => true, 'autocomplete' => true, 'title' => Loc::getMessage('DISCOUNT_GROUP_ENTITY_ID_FIELD') )), 'DISCOUNT_ID' => new Main\Entity\IntegerField('DISCOUNT_ID', array( 'required' => true, 'title' => Loc::getMessage('DISCOUNT_GROUP_ENTITY_DISCOUNT_ID_FIELD') )), 'ACTIVE' => new Main\Entity\BooleanField('ACTIVE', array( 'values' => array('N', 'Y'), 'default_value' => 'Y', 'title' => Loc::getMessage('DISCOUNT_GROUP_ENTITY_ACTIVE_FIELD') )), 'GROUP_ID' => new Main\Entity\IntegerField('GROUP_ID', array( 'required' => true, 'title' => Loc::getMessage('DISCOUNT_GROUP_ENTITY_GROUP_ID_FIELD') )), 'DISCOUNT' => new Main\Entity\ReferenceField( 'DISCOUNT', 'Bitrix\Sale\Internals\Discount', array('=this.DISCOUNT_ID' => 'ref.ID'), array('join_type' => 'LEFT') ) ); } /** * Delete user group list by discount. * * @param int $discount Discount id. * @return void */ public static function deleteByDiscount($discount) { $discount = (int)$discount; if ($discount <= 0) return; $conn = Application::getConnection(); $helper = $conn->getSqlHelper(); $conn->queryExecute( 'delete from '.$helper->quote(self::getTableName()).' where '.$helper->quote('DISCOUNT_ID').' = '.$discount ); } /** * Update user group list by discount. * * @param int $discount Discount id. * @param array $groupList User group list. * @param string $active Discount active flag. * @param bool $clear Clear old values. * @return bool */ public static function updateByDiscount($discount, $groupList, $active, $clear) { $discount = (int)$discount; if ($discount <= 0) return false; $clear = ($clear === true); if ($clear) { self::deleteByDiscount($discount); } if (is_array($groupList)) { $active = (string)$active; if ($active != 'Y' && $active != 'N') { $discountIterator = self::getList(array( 'select' => array('ACTIVE'), 'filter' => array('=ID' => $discount) )); if ($discountActive = $discountIterator->fetch()) { $active = $discountActive['ACTIVE']; } unset($discountActive, $discountIterator); } if ($active == 'Y' || $active == 'N') { if (empty($groupList)) $groupList[] = -1; foreach ($groupList as &$group) { $fields = array( 'DISCOUNT_ID' => $discount, 'ACTIVE' => $active, 'GROUP_ID' => $group ); $result = self::add($fields); } unset($group); } } return true; } /** * Change active flag in table by discount. * * @param int $discount Discount id. * @param string $active Discount active flag. * @return void */ public static function changeActiveByDiscount($discount, $active) { $discount = (int)$discount; $active = (string)$active; if ($discount <= 0 || ($active != 'Y' && $active != 'N')) return; $conn = Application::getConnection(); $helper = $conn->getSqlHelper(); $conn->queryExecute( 'update '.$helper->quote(self::getTableName()). ' set '.$helper->quote('ACTIVE').' = \''.$active.'\' where '. $helper->quote('DISCOUNT_ID').' = '.$discount ); } /** * Returns discount list by user groups. * * @param array $groupList User group list. * @param array $filter Additional filter. * @return array */ public static function getDiscountByGroups($groupList, $filter = array()) { $result = array(); if (!empty($groupList) && is_array($groupList)) { Main\Type\Collection::normalizeArrayValuesByInt($groupList); if (!empty($groupList)) { if (!is_array($filter)) $filter = array(); $groupRows = array_chunk($groupList, 500); foreach ($groupRows as &$row) { $filter['@GROUP_ID'] = $row; $groupIterator = self::getList(array( 'select' => array('DISCOUNT_ID'), 'filter' => $filter )); while ($group = $groupIterator->fetch()) { $group['DISCOUNT_ID'] = (int)$group['DISCOUNT_ID']; $result[$group['DISCOUNT_ID']] = true; } unset($group, $groupIterator); } unset($row, $groupRows); if (!empty($result)) $result = array_keys($result); } } return $result; } /** * Return active discounts by user group list. * * @param array $groupList User group list. * @return array */ public static function getActiveDiscountByGroups($groupList) { return self::getDiscountByGroups($groupList, array('ACTIVE' => 'Y')); } }