Bitrix - Работа со скидками
Войти

Bitrix - Работа со скидками

Bitrix - Работа со скидками
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php 

function getDiscountID(){
    
  Global 
$DB;

  
$dbProductDiscounts CCatalogDiscount::GetList(

     array(
"SORT" => "ASC"),
     array(
        
"SITE_ID" => SITE_ID,
        
"ACTIVE" => "Y",
        
"!>ACTIVE_FROM" => $DB->FormatDate(
                
date("Y-m-d H:i:s"),
                
"YYYY-MM-DD HH:MI:SS",
                
CSite::GetDateFormat("FULL")
        ),
        
$DB->FormatDate(
                
date("Y-m-d H:i:s"),
                
"YYYY-MM-DD HH:MI:SS",
                
CSite::GetDateFormat("FULL")
        ),
        
"!<ACTIVE_TO" => $DB->FormatDate(
                
date("Y-m-d H:i:s"),
                
"YYYY-MM-DD HH:MI:SS",
                
CSite::GetDateFormat("FULL")
        ),
        
$DB->FormatDate(
               
date("Y-m-d H:i:s"),
               
"YYYY-MM-DD HH:MI:SS",
               
CSite::GetDateFormat("FULL")
        ),
     ),
     
false,
     
false,
     array(
"ID","CONDITIONS","UNPACK")
  );

  while(
$arProductDiscounts $dbProductDiscounts->Fetch()) {

    
# убираем дубли скидок по id  скидки
    
if (isset($saleIds[$arProductDiscounts["ID"]])) { 
      continue;
    }
    
# параметр для удаления дублей
    
$saleIds[$arProductDiscounts["ID"]] = 1;
    
    
# Выбираем купоны по ID скидки    
    
$dbCoupon CCatalogDiscountCoupon::GetList(
    array(),
    array(
"DISCOUNT_ID" => $arProductDiscounts['ID'])
    ); 
    
    
# Убираем купоны
    
if($dbCoupon->SelectedRowsCount()) {
      continue;
    }
        
    
$arFull[] = $arProductDiscounts;

    
# Формируем массив со скидками
    
$arDiscountID[] = $arProductDiscounts['ID'];
    
    
// получаем условия для обработки скидок
    
$cond  unserialize($arProductDiscounts['CONDITIONS']); 
    
    
# Создаем объект класс, который работает с деревом условий скидок
    
$obCond = new CCatalogCondTree();
    
$boolCond $obCond->Init(
                           
BT_COND_MODE_SEARCH,
                           
BT_COND_BUILD_CATALOG
                           array()
                         );
    
   
// Вывод номера скидки и ее условий
   #echo $arProductDiscounts['ID'];
   #echo "<pre>";print_r($cond);echo "</pre>";

 
  
}
  
  
#print_r($arProductDiscounts);
  #getSectionDiscounts($arFull);
  
  // Функция возвращает отобранные ID скидок
  
return($arDiscountID);
}

?>
Теги:
php