Your IP : 3.149.214.156


Current Path : /home/bitrix/ext_www/dev.easy-comfort.com.ua/bitrix/modules/sale/lib/internals/
Upload File :
Current File : /home/bitrix/ext_www/dev.easy-comfort.com.ua/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'));
	}
}