superedit-USERS2_WINDYKACJA_STATUS.php 187 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915
  1. <?php
  2. if (!defined('DS')) define('DS', DIRECTORY_SEPARATOR);
  3. if (!defined('APP_PATH_ROOT')) define('APP_PATH_ROOT', dirname(__FILE__));
  4. if (!defined('APP_PATH_WWW')) define('APP_PATH_WWW', dirname(__FILE__));
  5. if (!defined('APP_PATH_CONFIG')) define('APP_PATH_CONFIG', APP_PATH_ROOT . DS . 'config');
  6. /**
  7. * Module PANEL klienta (?MENU_INIT=USERS2_WINDYKACJA_PANEL) - to mv to USERS2_PANEL
  8. *
  9. */
  10. function USERS2_WINDYKACJA_STATUS() {
  11. global $thiss;
  12. require_once dirname(__FILE__) . '/' . 'se-lib' . '/' . 'Lib.php';
  13. Lib::loadClass('V');
  14. Lib::loadClass('DB');
  15. Lib::loadClass('User');
  16. // router
  17. $q = V::get('q', '', $_REQUEST);
  18. $user_id = V::get('_user_id', 0, $_REQUEST, 'int');
  19. $task = V::get('task', '', $_REQUEST);
  20. if ($task != '') {
  21. if ($task == 'view_faktura') {
  22. $faktura_id = V::get('id', 0, $_REQUEST, 'int');
  23. WindykacjaView::view_faktura( $faktura_id );
  24. return;
  25. }
  26. else if ($task == 'zadluzenia') {
  27. $user_id = V::get('user_id', 0, $_REQUEST, 'int');
  28. if ($user_id > 0) {
  29. $user = WindykacjaStatsModel::get_user_by_id( $user_id );
  30. if (!$user) {
  31. echo'<p style="color:red">'."Użytkownik nie istnieje.".'</p>';
  32. } else {
  33. WindykacjaView::zadluzenia( $user );
  34. return;
  35. }
  36. } else {
  37. echo'<p style="color:red">'."Bledne dane.".'</p>';
  38. }
  39. }
  40. else if ($task == 'wezwanie') {
  41. $user_id = V::get('user_id', 0, $_REQUEST, 'int');
  42. if ($user_id > 0) {
  43. $user = WindykacjaStatsModel::get_user_by_id( $user_id );
  44. if (!$user) {
  45. echo'<p style="color:red">'."Użytkownik nie istnieje.".'</p>';
  46. } else {
  47. WindykacjaView::wezwanie( $user, $user->PAY_TERM );
  48. return;
  49. }
  50. } else {
  51. echo'<p style="color:red">'."Bledne dane.".'</p>';
  52. }
  53. }
  54. else if ($task == 'wezwanie_ostateczne') {
  55. $user_id = V::get('user_id', 0, $_REQUEST, 'int');
  56. if ($user_id > 0) {
  57. $user = WindykacjaStatsModel::get_user_by_id( $user_id );
  58. if (!$user) {
  59. echo'<p style="color:red">'."Użytkownik nie istnieje.".'</p>';
  60. } else {
  61. WindykacjaView::wezwanie_ostateczne( $user, $user->PAY_TERM );
  62. return;
  63. }
  64. } else {
  65. echo'<p style="color:red">'."Bledne dane.".'</p>';
  66. }
  67. }
  68. else if ($task == 'bok_rozwiazanie_umowy') {
  69. $user_id = V::get('user_id', 0, $_REQUEST, 'int');
  70. if ($user_id > 0) {
  71. $user = WindykacjaStatsModel::get_user_by_id( $user_id );
  72. if (!$user) {
  73. echo'<p style="color:red">'."Użytkownik nie istnieje.".'</p>';
  74. } else {
  75. WindykacjaView::task_bok_rozwiazanie_umowy( $user );
  76. return;
  77. }
  78. } else {
  79. echo'<p style="color:red">'."Bledne dane.".'</p>';
  80. }
  81. }
  82. else if ($task == 'bok_rozwiazanie_umowy_print') {
  83. $user_id = V::get('user_id', 0, $_REQUEST, 'int');
  84. if ($user_id > 0) {
  85. $user = WindykacjaStatsModel::get_user_by_id( $user_id );
  86. if (!$user) {
  87. echo'<p style="color:red">'."Użytkownik nie istnieje.".'</p>';
  88. } else {
  89. WindykacjaView::task_bok_rozwiazanie_umowy_print( $user, V::get('id_koresp', 0, $_REQUEST, 'int') );
  90. return;
  91. }
  92. } else {
  93. echo'<p style="color:red">'."Bledne dane.".'</p>';
  94. }
  95. }
  96. else if ($task == 'stats_update') {
  97. WindykacjaView::task_update_stats();
  98. return;
  99. }
  100. else if ($task == 'export_csv') {
  101. $items = array();
  102. $page_nav = new stdClass();
  103. $page_nav->total = 0;
  104. $page_nav->page_total = 0;
  105. $page_nav->base_link_arr = array('MENU_INIT'=>"USERS2_WINDYKACJA_STATUS", 'q'=>$q);
  106. $page_nav->page_limit = 100000;
  107. $page_nav->page_nr = 0;
  108. $page_nav->base_link_arr ['_f'] = V::get('_f', '', $_GET);
  109. if ($page_nav->page_nr > 0) {
  110. $page_nav->base_link_arr ['_p'] = $page_nav->page_nr;
  111. }
  112. // sortowanie, filtr wyszukiwania
  113. $page_nav->base_link_arr ['_oby'] = 'ID';
  114. $page_nav->base_link_arr ['_odir'] = 'DESC';
  115. if (($order_by = V::get('_oby', '', $_GET)) != '') {
  116. $page_nav->base_link_arr ['_oby'] = $order_by;
  117. }
  118. if (($order_dir = V::get('_odir', '', $_GET)) != '') {
  119. $page_nav->base_link_arr ['_odir'] = $order_dir;
  120. }
  121. if (!empty($q)) {
  122. $page_nav->total = WindykacjaStatsModel::get_users_total( $q );
  123. $page_nav->last_page_nr = floor($page_nav->total / $page_nav->page_limit);
  124. $items = WindykacjaStatsModel::get_users($q, $page_nav->page_limit, $page_nav->page_nr * $page_nav->page_limit, $page_nav->base_link_arr['_oby'], $page_nav->base_link_arr['_odir']);
  125. $page_nav->page_total = count($items);
  126. }
  127. else {
  128. $page_nav->total = WindykacjaStatsModel::get_users_total( $q );
  129. $page_nav->last_page_nr = floor($page_nav->total / $page_nav->page_limit);
  130. $items = WindykacjaStatsModel::get_users($q, $page_nav->page_limit, $page_nav->page_nr * $page_nav->page_limit, $page_nav->base_link_arr['_oby'], $page_nav->base_link_arr['_odir']);
  131. $page_nav->page_total = count($items);
  132. }
  133. if ($page_nav->total > 0) {
  134. WindykacjaView::export_csv( $q, $page_nav, $items );
  135. } else {
  136. echo'<p>' . "Brak danych" . '</p>';
  137. }
  138. exit;
  139. }
  140. }
  141. WindykacjaView::css();
  142. if ($user_id > 0) {
  143. $user = WindykacjaStatsModel::get_user_by_id( $user_id );
  144. if (!$user) {
  145. echo'<p>'."Użytkownik nie istnieje.".'</p>';
  146. return;
  147. }
  148. WindykacjaView::user( $user );
  149. WindykacjaView::user_umowy( $user );
  150. WindykacjaView::user_historia_platnosci( $user );
  151. }
  152. else {
  153. // aktualiacja danych
  154. WindykacjaStatsHelper::update_users_table();
  155. $items = array();
  156. $page_nav = new stdClass();
  157. $page_nav->total = 0;
  158. $page_nav->page_total = 0;
  159. $page_nav->base_link_arr = array('MENU_INIT'=>"USERS2_WINDYKACJA_STATUS", 'q'=>$q);
  160. $page_nav->page_limit = 50;
  161. $page_nav->page_nr = V::get('_p', 0, $_REQUEST, 'int');
  162. $page_nav->base_link_arr ['_f'] = V::get('_f', '', $_GET);
  163. if ($page_nav->page_nr > 0) {
  164. $page_nav->base_link_arr ['_p'] = $page_nav->page_nr;
  165. }
  166. // sortowanie, filtr wyszukiwania
  167. $page_nav->base_link_arr ['_oby'] = 'ID';
  168. $page_nav->base_link_arr ['_odir'] = 'DESC';
  169. if (($order_by = V::get('_oby', '', $_GET)) != '') {
  170. $page_nav->base_link_arr ['_oby'] = $order_by;
  171. }
  172. if (($order_dir = V::get('_odir', '', $_GET)) != '') {
  173. $page_nav->base_link_arr ['_odir'] = $order_dir;
  174. }
  175. if (!empty($q)) {
  176. $page_nav->total = WindykacjaStatsModel::get_users_total( $q );
  177. $page_nav->last_page_nr = floor($page_nav->total / $page_nav->page_limit);
  178. $items = WindykacjaStatsModel::get_users($q, $page_nav->page_limit, $page_nav->page_nr * $page_nav->page_limit, $page_nav->base_link_arr['_oby'], $page_nav->base_link_arr['_odir']);
  179. $page_nav->page_total = count($items);
  180. }
  181. else {
  182. $page_nav->total = WindykacjaStatsModel::get_users_total( $q );
  183. $page_nav->last_page_nr = floor($page_nav->total / $page_nav->page_limit);
  184. $items = WindykacjaStatsModel::get_users($q, $page_nav->page_limit, $page_nav->page_nr * $page_nav->page_limit, $page_nav->base_link_arr['_oby'], $page_nav->base_link_arr['_odir']);
  185. $page_nav->page_total = count($items);
  186. }
  187. WindykacjaView::form( $q );
  188. $to_update_total = WindykacjaStatsHelper::get_to_update_total();
  189. if ($to_update_total > 0) {
  190. echo'<p>';
  191. echo'<a style="color:red" href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&task=stats_update&q=".$q."&_p=".V::get('_p', 0, $_GET, 'int') . '">' . "Aktualizuj statusy (" . $to_update_total . ")" . '</a>';
  192. echo'</p>';
  193. }
  194. WindykacjaView::items_filters();
  195. if ($page_nav->total > 0) {
  196. WindykacjaView::items( $q, $page_nav, $items );
  197. } else {
  198. echo'<p>' . "Brak danych" . '</p>';
  199. }
  200. }
  201. }
  202. class WindykacjaView {
  203. function user( &$user ) {
  204. $bad_address_task = V::get('bad_address', '', $_POST);
  205. $bad_address_msg = array();
  206. if ($bad_address_task) {
  207. $id_koresp = V::get('ID_KORESP', 0, $_POST, 'int');
  208. if ($id_koresp <= 0) {
  209. $bad_address_msg['error_id_koresp'] = true;
  210. } else {
  211. if ($bad_address_task == 'save') {
  212. if (!WindykacjaStatsHelper::bad_address_save($user, $id_koresp)) {
  213. $bad_address_msg['error'] = true;
  214. } else {
  215. $bad_address_msg['ok'] = true;
  216. }
  217. }
  218. else if ($bad_address_task == 'confirm') {
  219. if (!WindykacjaStatsHelper::bad_address_confirm($user, $id_koresp)) {
  220. $bad_address_msg['error'] = true;
  221. } else {
  222. $bad_address_msg['ok'] = true;
  223. }
  224. }
  225. }
  226. }
  227. $change_status_task = V::get('change_status', '', $_POST);
  228. $change_status_msg = array();
  229. if ($change_status_task) {
  230. if ($change_status_task == 'change') {
  231. $new_status = V::get('new_status', '', $_POST);
  232. $fltr_arr = WindykacjaStatsHelper::get_filters();
  233. if (!array_key_exists($new_status, $fltr_arr)) {
  234. $change_status_msg['error'] = true;
  235. } else {
  236. if (!WindykacjaStatsHelper::change_status_save($user, $new_status)) {
  237. $change_status_msg['error'] = true;
  238. } else {
  239. $change_status_msg['ok'] = true;
  240. }
  241. }
  242. }
  243. }
  244. $set_nr_sprawy_krd_task = V::get('set_nr_sprawy_krd', '', $_POST);
  245. $set_nr_sprawy_krd_msg = array();
  246. if ($set_nr_sprawy_krd_task) {
  247. if ($set_nr_sprawy_krd_task == 'change') {
  248. $nr_sprawy_krd = V::get('nr_sprawy_krd', '', $_POST);
  249. if (!WindykacjaStatsHelper::nr_sprawy_krd_save($user, $nr_sprawy_krd)) {
  250. $set_nr_sprawy_krd_msg['error'] = true;
  251. } else {
  252. $set_nr_sprawy_krd_msg['ok'] = true;
  253. }
  254. }
  255. }
  256. $set_nr_sprawy_sad_task = V::get('set_nr_sprawy_sad', '', $_POST);
  257. $set_nr_sprawy_sad_msg = array();
  258. if ($set_nr_sprawy_sad_task) {
  259. if ($set_nr_sprawy_sad_task == 'change') {
  260. $nr_sprawy_sad = V::get('nr_sprawy_sad', '', $_POST);
  261. if (!WindykacjaStatsHelper::nr_sprawy_sad_save($user, $nr_sprawy_sad)) {
  262. $set_nr_sprawy_sad_msg['error'] = true;
  263. } else {
  264. $set_nr_sprawy_sad_msg['ok'] = true;
  265. }
  266. }
  267. }
  268. $set_nr_sprawy_komornik_task = V::get('set_nr_sprawy_komornik', '', $_POST);
  269. $set_nr_sprawy_komornik_msg = array();
  270. if ($set_nr_sprawy_komornik_task) {
  271. if ($set_nr_sprawy_komornik_task == 'change') {
  272. $nr_sprawy_komornik = V::get('nr_sprawy_komornik', '', $_POST);
  273. if (!WindykacjaStatsHelper::nr_sprawy_komornik_save($user, $nr_sprawy_komornik)) {
  274. $set_nr_sprawy_komornik_msg['error'] = true;
  275. } else {
  276. $set_nr_sprawy_komornik_msg['ok'] = true;
  277. }
  278. }
  279. }
  280. $set_ustalenia_info_task = V::get('set_ustalenia_info', '', $_POST);
  281. $set_ustalenia_info_msg = array();
  282. if ($set_ustalenia_info_task) {
  283. if ($set_ustalenia_info_task == 'change') {
  284. $ustalenia_date = V::get('ustalenia_date', '', $_POST);
  285. $ustalenia_info = V::get('ustalenia_info', '', $_POST);
  286. if (!WindykacjaStatsHelper::ustalenia_info_save($user, $ustalenia_date, $ustalenia_info)) {
  287. $set_ustalenia_info_msg['error'] = true;
  288. } else {
  289. $set_ustalenia_info_msg['ok'] = true;
  290. }
  291. }
  292. }
  293. echo'<h3>';
  294. echo' <a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&_p=".V::get('_p', '', $_REQUEST)."&_f=".V::get('_f', '', $_REQUEST)."&_oby=".V::get('_oby', '', $_REQUEST)."&_odir=".V::get('_odir', '', $_REQUEST).'">'."Klienci".'</a>';
  295. echo ' &raquo; <code style="font-size:normal;color:green;">'."[".$user->id_users."]".'</code>';
  296. echo ' <b>'.$user->P_NAME.' '.$user->P_NAME_SECOND.'</b>';
  297. echo'</h3>';
  298. echo '<table class="" cellspacing="0" cellpadding="0" border="0"><tr><td style="vertical-align:top">';
  299. echo '<table class="tbl-view tbl-umowy-l2" cellspacing="0" cellpadding="0" border="1">';
  300. echo '<caption>';
  301. echo "Dane " . (($user->is_firma)? "firmy" : "klienta") . " ";
  302. if ($user->BAD_ADDRESS) {
  303. echo '<form action="" method="POST" style="display:inline">';
  304. echo '<input type="hidden" name="'."bad_address".'" value="'."confirm".'" />';
  305. $js = "if(this.nextSibling.style.display=='none'){this.nextSibling.style.display='block'}else{this.nextSibling.style.display='none'}; return false;";
  306. echo '<input type="button" value="'."popraw adres".'" onclick="'.$js.'" style="margin:1px 2px;padding:0 6px;" />';
  307. echo '<div style="display:none;">';
  308. echo '<label for="ID_KORESP">'."ID Koresp.".'</label>';
  309. echo '<input type="text" name="' . "ID_KORESP" . '" size="5" value="' . "" . '" />';
  310. echo '<input type="submit" value="'."zapisz".'" />';
  311. echo '</div>';
  312. echo '</form>';
  313. } else {
  314. echo '<form action="" method="POST" style="display:inline">';
  315. echo '<input type="hidden" name="'."bad_address".'" value="'."save".'" />';
  316. $js = "if(this.nextSibling.style.display=='none'){this.nextSibling.style.display='block'}else{this.nextSibling.style.display='none'}; return false;";
  317. echo '<input type="button" value="'."zgłoś błędny adres".'" onclick="'.$js.'" style="margin:1px 2px;padding:0 6px;" />';
  318. echo '<div style="display:none;">';
  319. echo '<label for="ID_KORESP">'."ID Koresp.".'</label>';
  320. echo '<input type="text" name="' . "ID_KORESP" . '" size="5" value="' . "" . '" />';
  321. echo '<input type="submit" value="'."zapisz".'" />';
  322. echo '</div>';
  323. echo '</form>';
  324. }
  325. if (!empty($bad_address_msg)) {
  326. if ('id_koresp' == V::get('error', '', $bad_address_msg)) {
  327. echo '<div class="red">'."Podaj poprawny ID Koresp.".'</div>';
  328. } else if (true == V::get('error', false, $bad_address_msg)) {
  329. echo '<div class="red">'."Error!".'</div>';
  330. } else if (true == V::get('ok', false, $bad_address_msg)) {
  331. echo '<div style="color:green">'."Zapisano pomyślnie.".'</div>';
  332. }
  333. }
  334. echo '</caption>';
  335. echo'<tr>';
  336. echo'<th>' . "Adres:" . '</th>';
  337. echo'<td'.(($user->BAD_ADDRESS)? ' style="background-color:#FF7878;"' : '').'>';
  338. echo "ul. ".$user->P_ADDRESS_STREET." ".$user->P_ADDRESS_HOUSE."/".$user->P_ADDRESS_HOME.", ".$user->P_ADDRESS_POST_CODE." ".$user->P_ADDRESS_CITY;
  339. echo'</td>';
  340. echo'</tr>';
  341. echo'<tr>';
  342. echo'<th>' . "Pesel:" . '</th>';
  343. echo'<td>';
  344. if ($user->P_PESEL) {
  345. echo $user->P_PESEL;
  346. } else {
  347. echo '<span style="color:#f00;">'."Brak numeru PESEL!".'</span>';
  348. }
  349. echo'</td>';
  350. echo'</tr>';
  351. echo'<tr>';
  352. echo'<th>' . "Nr telefonu:" . '</th>';
  353. echo'<td>';
  354. if ($user->P_PHONE) {
  355. echo $user->P_PHONE;
  356. } else {
  357. echo '<span style="color:#f00;">'."Brak!".'</span>';
  358. }
  359. echo'</td>';
  360. echo'</tr>';
  361. echo'<tr>';
  362. echo'<th>' . "Nr dowodu:" . '</th>';
  363. echo'<td>';
  364. if ($user->P_OTHER_DOC) {
  365. echo $user->P_OTHER_DOC;
  366. } else {
  367. echo '<span style="color:#f00;">'."Brak!".'</span>';
  368. }
  369. echo'</td>';
  370. echo'</tr>';
  371. echo'<tr>';
  372. echo'<th>' . "e-mail:" . '</th>';
  373. echo'<td>';
  374. if ($user->user_mail_contact) {
  375. echo '<a href="mailto:'.$user->user_mail_contact.'">'.$user->user_mail_contact.'</a>';
  376. } else {
  377. echo '<span style="color:#f00;">'."Brak!".'</span>';
  378. }
  379. echo'</td>';
  380. echo'</tr>';
  381. echo'<tr>';
  382. echo'<th>' . "Klient firmy:" . '</th>';
  383. echo'<td>';
  384. if ($user->BILLING_OWNER == 1) {
  385. echo 'BN - BIALL-NET';
  386. } else if ($user->BILLING_OWNER == 2) {
  387. echo 'ND - NETDAY';
  388. } else {
  389. echo 'nieznany';
  390. }
  391. echo'</td>';
  392. echo'</tr>';
  393. echo'<tr>';
  394. echo'<th>' . "Blokada:" . '</th>';
  395. echo'<td>';
  396. if ($user->STATUS == 9) {
  397. echo '<b style="color:red">' . "ZABLOKOWANY" . '</b>';
  398. } else {
  399. echo 'brak blokady';
  400. }
  401. echo'</td>';
  402. echo'</tr>';
  403. echo '</table>';
  404. echo '</td><td>' . "&nbsp;" . '</td><td style="vertical-align:top">';
  405. echo '<table class="tbl-view tbl-umowy-l2'.(($user->A_STATUS_UPDATE_DATE < date("Y-m-d"))? ' wind-status-old' : '').'" cellspacing="0" cellpadding="0" border="1">';
  406. echo '<caption>';
  407. echo "Status windykacji ";
  408. echo '<code style="font-size:x-small; color:#ccc;">' . "(" . $user->WINDYKACJA_ID . ")" . '</code>';
  409. if ($user->A_STATUS_UPDATE_DATE < date("Y-m-d")) {
  410. echo " " . '<a style="color:red" href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&_p=".V::get('_p','', $_REQUEST)."&_f=".V::get('_f', '', $_REQUEST)."&_user_id=".$user->ID . '">' . "Aktualizuj status" . '</a>';
  411. }
  412. // TODO: zmien status klienta - przypisanie do odpowiedniej grupy
  413. echo '</caption>';
  414. echo '<tr>';
  415. echo '<th>' . "status:" . '</th>';
  416. echo '<td>';
  417. echo $user->A_STATUS;
  418. if (V::get('DBG', '', $_GET, 'int') > 0) {// TODO: TEST
  419. if ($user->A_STATUS == 'waiting-krd') {
  420. echo '<br />' . "wezwanie2_DATE: {$user->wezwanie2_DATE}";
  421. $wzw2 = new stdClass();
  422. $wzw2->Y = intval(substr($user->wezwanie2_DATE, 0, 4));
  423. $wzw2->m = intval(substr($user->wezwanie2_DATE, 5, 2));
  424. $wzw2->d = intval(substr($user->wezwanie2_DATE, 8, 2));
  425. echo '<br />' . "wzw2: {$wzw2->Y}-{$wzw2->m}-{$wzw2->d}";
  426. $wzw2->plus_60 = date("Y-m-d", mktime(0,0,0, $wzw2->m, $wzw2->d + 60, $wzw2->Y));
  427. echo '<br />' . "wezwanie2_DATE + 60 dni: {$wzw2->plus_60}";
  428. if ($wzw2->plus_60 < date("Y-m-d")) {
  429. echo '<br />' . "TODO: przenieść do krd";
  430. }
  431. }
  432. }// TODO: TEST
  433. echo ' &nbsp;&nbsp; <form action="" method="POST" style="display:inline">';
  434. echo '<input type="hidden" name="'."change_status".'" value="'."change".'" />';
  435. $fltr_arr = WindykacjaStatsHelper::get_filters();
  436. $fltr_options = array();
  437. foreach ($fltr_arr as $k_status => $v_arr) {
  438. $fltr_options[$k_status] = reset($v_arr);
  439. }
  440. echo '<select name="' . "new_status" . '">';
  441. foreach ($fltr_options as $k_ind => $v_label) {
  442. $sel = ($k_ind == $user->A_STATUS)? ' selected="selected"' : '';
  443. echo '<option value="' . $k_ind . '"' . $sel . '>' . "{$k_ind}: {$v_label}" . '</option>';
  444. }
  445. echo '</select>';
  446. echo '<input type="submit" value="'."zmień".'" />';
  447. echo '</form>';
  448. echo '</td>';
  449. echo '</tr>';
  450. echo '<tr>';
  451. echo '<th>' . "Nr sprawy w krd" . '</th>';
  452. echo '<td>';
  453. echo ' <form action="" method="POST" style="display:inline">';
  454. echo '<input type="hidden" name="'."set_nr_sprawy_krd".'" value="'."change".'" />';
  455. echo '<input type="text" name="'."nr_sprawy_krd".'" value="'.$user->NR_SPRAWY_KRD.'" />';
  456. echo '<input type="submit" value="'."zmień".'" />';
  457. echo '</form>';
  458. echo '</td>';
  459. echo '</tr>';
  460. echo '<tr>';
  461. echo '<th>' . "Nr sprawy w sądzie" . '</th>';
  462. echo '<td>';
  463. echo ' <form action="" method="POST" style="display:inline">';
  464. echo '<input type="hidden" name="'."set_nr_sprawy_sad".'" value="'."change".'" />';
  465. echo '<input type="text" name="'."nr_sprawy_sad".'" value="'.$user->NR_SPRAWY_SAD.'" />';
  466. echo '<input type="submit" value="'."zmień".'" />';
  467. echo '</form>';
  468. echo '</td>';
  469. echo '</tr>';
  470. echo '<tr>';
  471. echo '<th>' . "Nr sprawy u komornika" . '</th>';
  472. echo '<td>';
  473. echo ' <form action="" method="POST" style="display:inline">';
  474. echo '<input type="hidden" name="'."set_nr_sprawy_komornik".'" value="'."change".'" />';
  475. echo '<input type="text" name="'."nr_sprawy_komornik".'" value="'.$user->NR_SPRAWY_KOMORNIK.'" />';
  476. echo '<input type="submit" value="'."zmień".'" />';
  477. echo '</form>';
  478. echo '</td>';
  479. echo '</tr>';
  480. echo '<tr>';
  481. echo '<th>' . "Aktualne ustalenia z klientem" . '</th>';
  482. echo '<td>';
  483. echo ' <form action="" method="POST" style="display:inline">';
  484. echo '<input type="hidden" name="'."set_ustalenia_info".'" value="'."change".'" />';
  485. echo '<textarea style="width:100%" type="text" name="'."ustalenia_info".'">' . $user->L_APPOITMENT_INFO . '</textarea>';
  486. echo '<br />' . "Data: ";
  487. echo '<input type="text" name="'."ustalenia_date".'" value="'.$user->L_APPOITMENT_DATE.'" />';
  488. echo '<input type="submit" value="'."zmień".'" />';
  489. $js = "this.form.ustalenia_info.value=''; this.form.ustalenia_date.value='0000-00-00'; return false;";
  490. echo '<input type="reset" value="'."wyszyść".'" onclick="'.$js.'" />';
  491. echo '</form>';
  492. echo '</td>';
  493. echo '</tr>';
  494. echo '<tr>';
  495. echo '<th>' . "data ostatniej wpłaty:" . '</th>';
  496. echo '<td>';
  497. if ($user->LAST_PAY_DATE && $user->LAST_PAY_DATE != '0000-00-00') {
  498. echo $user->LAST_PAY_DATE;
  499. } else {
  500. echo '---';
  501. }
  502. echo '</td>';
  503. echo '</tr>';
  504. echo '<tr>';
  505. echo '<th>' . "data wymagalności ostatniej faktury:" . '</th>';
  506. echo '<td>';
  507. if ($user->PAY_DATE != '0000-00-00') {
  508. echo $user->PAY_DATE;
  509. }
  510. echo '</td>';
  511. echo '</tr>';
  512. echo '<tr>';
  513. echo '<th>' . "termin płatności:" . '</th>';
  514. echo '<td>';
  515. if ($user->PAY_TERM != '0000-00-00') {
  516. echo $user->PAY_TERM;
  517. }
  518. echo '</td>';
  519. echo '</tr>';
  520. echo '</table>';
  521. echo '</td></tr></table>';
  522. // TODO: windykacja_status_info - grupa filtrow do ktorej nalezy klient
  523. Lib::loadClass('CompanyHelper');
  524. $db = DB::getDB();
  525. $comHelper = new CompanyHelper($db);
  526. $usr = $comHelper->getById($user->ID);
  527. $dealsActive = $comHelper->getDealsFull($user->ID, false);
  528. Lib::loadClass('PokazOfertyView');
  529. $pokaz_oferty_view = new PokazOfertyView();
  530. echo $pokaz_oferty_view->print_css();
  531. $pokaz_oferty_view->printServices($usr, $dealsActive);
  532. // aktualny status klienta
  533. echo'<div>';
  534. if ($user->A_STATUS_UPDATE_DATE < date("Y-m-d")) {
  535. }
  536. else {
  537. switch ($user->A_STATUS) {
  538. case 'WAITING': {
  539. echo'<p>' . "Status OK" . '</p>';
  540. }
  541. break;
  542. case 'wezwanie1': {
  543. $default_PAY_TERM = date("Y-m-d", mktime(0,0,0,date('m'), date('d') + 14, date('Y')));
  544. $frm_errors = array();
  545. $frm_msgs = array();
  546. $frm = array();
  547. $frm['wezwanie1_DATE'] = date("Y-m-d");
  548. $frm['PAY_TERM'] = V::get('PAY_TERM', $default_PAY_TERM, $_POST);
  549. $frm['ID_PROJ'] = V::get('ID_PROJ', 0, $_POST, 'int');
  550. if ('set_wezwanie' == V::get('user_task', '', $_POST)) {
  551. if ($frm['ID_PROJ'] == 0) {
  552. $frm_errors []= "Brak numeru ID Projketu";
  553. }
  554. if (empty($frm_errors)) {
  555. $ret = WindykacjaStatsHelper::update_user( $user, $frm );
  556. if ($ret) {
  557. $frm_msgs []= "Status klienta został zaktualizowany";
  558. } else {
  559. $frm_errors []= "Status klienta nie został zaktualizowany";
  560. }
  561. }
  562. }
  563. echo '<div class="box box-blue" style="margin:6px 0;">';
  564. if ($user->PAY_FVAT > 0 && $user->PAY_SALDO < 0) {
  565. echo "Saldo klienta: " . '<b style="color:#f00">' . $user->PAY_SALDO . " zł" . '</b>' . " (" . $user->PAY_FVAT ." niezapłaconych faktur)" . '<br />';
  566. echo'<br />';
  567. }
  568. echo '<b style="color:#0B0B8E">'."Wysłać wezwanie do zapłaty".'</b>'.'<br />';
  569. if (!empty($frm_errors)) {
  570. echo'<p style="color:#f00">' . implode('<br />', $frm_errors) . '</p>';
  571. }
  572. if (!empty($frm_msgs)) {
  573. echo'<p style="color:green">' . implode('<br />', $frm_msgs) . '</p>';
  574. }
  575. echo'<form action="" method="post">';
  576. echo'<input type="hidden" name="'."user_task".'" value="'."set_wezwanie".'" />';
  577. echo "Data płatności: ";
  578. echo'<input type="text" name="'."PAY_TERM".'" value="'.$frm['PAY_TERM'].'" />';
  579. echo " ID Projektu: ";
  580. echo'<input type="text" name="'."ID_PROJ".'" value="'.$frm['ID_PROJ'].'" />';
  581. echo'<input type="submit" value="'."Zapisz".'" />';
  582. echo'</form>';
  583. if ($user->wezwanie1_DATE != '0000-00-00') {
  584. echo'<br />';
  585. $ico_print = '<img src="icon/print.gif" height="16" />';
  586. echo'<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."wezwanie"."&user_id=".$user->ID.'" target="_blank">'.$ico_print." wezwanie do zapłaty".'</a>';
  587. }
  588. echo '</div>';// .box-blue
  589. }
  590. break;
  591. case 'waiting-wezwanie2': {// TODO: only auto update ?
  592. echo '<div class="box box-blue" style="margin:6px 0;">';
  593. if ($user->PAY_FVAT > 0 && $user->PAY_SALDO < 0) {
  594. echo "Saldo klienta: " . '<b style="color:#f00">' . $user->PAY_SALDO . " zł" . '</b>' . " (" . $user->PAY_FVAT ." niezapłaconych faktur)" . '<br />';
  595. echo'<br />';
  596. }
  597. echo '<b style="color:#0B0B8E">'."Oczekiwanie na uzbieranie kwoty 300zł (firmy 500zł)".'</b>'.'<br />';
  598. if (!empty($frm_errors)) {
  599. echo'<p style="color:#f00">';
  600. echo implode('<br />', $frm_errors);
  601. echo'</p>';
  602. }
  603. echo'<form action="" method="post">';
  604. // echo'<input type="hidden" name="'."user_task".'" value="'."set_".'" />';
  605. // echo'<input type="submit" value="'."Zapisz".'" />';
  606. echo'</form>';
  607. if ($user->wezwanie1_DATE != '0000-00-00') {
  608. echo'<br />';
  609. $ico_print = '<img src="icon/print.gif" height="16" />';
  610. echo'<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."wezwanie"."&user_id=".$user->ID.'" target="_blank">' . $ico_print . " wezwanie do zapłaty".'</a>'.'<em>'." (termin płatności: " . $user->PAY_TERM . ")".'</em>';
  611. }
  612. echo '</div>';// .box-blue
  613. }
  614. break;
  615. case 'wezwanie2': {
  616. $default_PAY_TERM = date("Y-m-d", mktime(0,0,0,date('m'), date('d') + 14, date('Y')));
  617. $frm_msgs = array();
  618. $frm_errors = array();
  619. $frm = array();
  620. $frm['wezwanie2_DATE'] = date("Y-m-d");
  621. $frm['PAY_TERM'] = V::get('PAY_TERM', $default_PAY_TERM, $_POST);
  622. $frm['ID_PROJ'] = V::get('ID_PROJ', 0, $_POST, 'int');
  623. if ('set_wezwanie2' == V::get('user_task', '', $_POST)) {
  624. if ($frm['ID_PROJ'] == 0) {
  625. $frm_errors []= "Brak numeru ID korespondencji";
  626. }
  627. if (empty($frm_errors)) {
  628. $ret = WindykacjaStatsHelper::update_user( $user, $frm );
  629. if ($ret) {
  630. $frm_msgs []= "Status klienta został zaktualizowany";
  631. } else {
  632. $frm_errors []= "Status klienta nie został zaktualizowany";
  633. }
  634. }
  635. }
  636. echo '<div class="box box-blue" style="margin:6px 0;border-color:#666;">';
  637. if ($user->PAY_FVAT > 0 && $user->PAY_SALDO < 0) {
  638. echo "Saldo klienta: " . '<b style="color:#f00">' . $user->PAY_SALDO . " zł" . '</b>' . " (" . $user->PAY_FVAT ." niezapłaconych faktur)" . '<br />';
  639. echo'<br />';
  640. }
  641. echo '<b style="color:#0B0B8E">'."Wysłać ostateczne wezwanie do zapłaty".'</b>'.'<br />';
  642. if (!empty($frm_errors)) {
  643. echo'<p style="color:#f00">' . implode('<br />', $frm_errors) . '</p>';
  644. }
  645. if (!empty($frm_msgs)) {
  646. echo'<p style="color:green">' . implode('<br />', $frm_msgs) . '</p>';
  647. }
  648. echo'<form action="" method="post">';
  649. echo'<input type="hidden" name="'."user_task".'" value="'."set_wezwanie2".'" />';
  650. echo "Data płatności: ";
  651. echo'<input type="text" name="'."PAY_TERM".'" value="'.$frm['PAY_TERM'].'" />';
  652. echo " ID Projektu: ";
  653. echo'<input type="text" name="'."ID_PROJ".'" value="'.$frm['ID_PROJ'].'" />';
  654. echo'<input type="submit" value="'."Zapisz".'" />';
  655. echo'</form>';
  656. if ($user->wezwanie2_DATE != '0000-00-00') {
  657. echo'<br />';
  658. $ico_print = '<img src="icon/print.gif" height="16" />';
  659. echo'<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."wezwanie_ostateczne"."&user_id=".$user->ID.'" target="_blank">' . $ico_print . " ostateczne wezwanie do zapłaty".'</a>';
  660. }
  661. echo '</div>';// .box-blue
  662. }
  663. break;
  664. case 'waiting-krd': {
  665. if ($user->wezwanie2_DATE != '0000-00-00') {
  666. echo'<br />';
  667. $ico_print = '<img src="icon/print.gif" height="16" />';
  668. echo'<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."wezwanie_ostateczne"."&user_id=".$user->ID.'" target="_blank">' . $ico_print . " ostateczne wezwanie do zapłaty".'</a>';
  669. }
  670. }
  671. break;
  672. default:
  673. echo'<p>' . "TODO: (".$user->A_STATUS.")" . '</p>';
  674. }
  675. }
  676. //if ($user->BA_TIMESTAMP) {
  677. // echo "Stan wzajemnych rozrachunków:";
  678. // echo " WINIEN: <b>".$user->BA_WINIEN."</b> - MA: <b>".$user->BA_MA."</b> SALDO(DO ZAPŁATY): <b>".($user->BA_WINIEN - $user->BA_MA)."</b>";
  679. // echo", i jest to stan na dzień ".date("Y-m-d",$user->BA_TIMESTAMP)." ";
  680. //}
  681. // phone contact
  682. $phone_status_info = WindykacjaStatsHelper::get_phone_status_info( $user );
  683. $frm_errors = array();
  684. $frm_msgs = array();
  685. if (1 == V::get('phone_contact_save', 0, $_POST, 'int')) {
  686. if ('' == ($phone_status = V::get('phone_status', '', $_POST))) {
  687. $frm_errors []= "Nic nie zaznaczono!";
  688. } else {
  689. if (!array_key_exists($phone_status, $phone_status_info)) {
  690. $frm_errors []= "Nieprawidłowa wartość!";
  691. } else {
  692. $ret = WindykacjaStatsHelper::update_phone_status( $user, $phone_status );
  693. if ($ret) {
  694. $frm_msgs []= "Dane zapisano pomyślnie";
  695. } else {
  696. $frm_errors []= "Wystąpił błąd podczas zapisu danych";
  697. }
  698. }
  699. }
  700. }
  701. // add old id_koresp to hist (events)
  702. if (1 == V::get('contact_add_id_koresp_save', 0, $_POST, 'int')) {
  703. if (($id_koresp = V::get('id_koresp', '', $_POST, 'int')) <= 0) {
  704. $frm_errors []= "Nie podano numeru korespondencji!";
  705. } else {
  706. $koresp_type = V::get('koresp_type', '', $_POST);
  707. $ret = WindykacjaStatsHelper::update_old_id_koresp( $user, $id_koresp, $koresp_type );
  708. if ($ret) {
  709. $frm_msgs []= "Dane zapisano pomyślnie";
  710. } else {
  711. $frm_errors []= "Wystąpił błąd podczas zapisu danych";
  712. }
  713. }
  714. }
  715. echo'<script type="text/javascript">'."
  716. function frm_kontakt_phone_submit_callback(frm){
  717. var len=frm.phone_status.length;
  718. var val='';
  719. for(var i=0; i < len; i++){
  720. if(frm.phone_status[i].checked){
  721. var val = frm.phone_status[i].value;
  722. }
  723. }
  724. if (val!='') {
  725. return true;
  726. } else {
  727. alert('Nic nie zaznaczono.');
  728. }
  729. return false;
  730. }
  731. function frm_kontakt_add_id_koresp(frm){
  732. var val=frm.id_koresp.value;
  733. if (val!='') {
  734. return true;
  735. } else {
  736. alert('Nie podano numeru korespondencji.');
  737. }
  738. return false;
  739. }
  740. ".'</script>';
  741. echo'<div class="box" style="margin:6px 0;border-color:#666;">';
  742. if (!empty($frm_errors)) {
  743. echo'<p style="color:#f00">' . implode('<br />', $frm_errors) . '</p>';
  744. }
  745. if (!empty($frm_msgs)) {
  746. echo'<p style="color:green">' . implode('<br />', $frm_msgs) . '</p>';
  747. }
  748. echo'<form action="" method="post" onsubmit="' . "return frm_kontakt_phone_submit_callback(this);" . '">';
  749. echo '<table cellspacing="0" cellpadding="0" border="0" class="tbl-td-top"><tr>';
  750. echo '<td style="padding:0 20px 0 0;color:blue;">';
  751. echo'<img src="' . "icon/phone.png" . '" alt="tel" />';
  752. echo " kontakt z klientem ";
  753. echo '</td>';
  754. echo '<td style="padding:0 5px;text-align:right">';
  755. echo " Co ustalono: ";
  756. echo '</td>';
  757. echo '<td>';
  758. echo'<div id="'."kontakt-phone".'">';
  759. echo'<input type="hidden" name="'."phone_contact_save".'" value="'."1".'" />';
  760. foreach ($phone_status_info as $k_type => $v_info) {
  761. echo'<input type="radio" name="'."phone_status".'" value="' . $k_type . '" />'; echo " " . $v_info['label'] . " " . $v_info['date'] . '<br />';
  762. }
  763. echo'</div>';
  764. echo '</td>';
  765. echo '<td>';
  766. echo'<input type="submit" value="'."zapisz".'" />';
  767. echo '</td>';
  768. echo '</tr></table>';
  769. echo'</form>';
  770. echo'</div>';// .box
  771. echo'<div class="box" style="margin:6px 0;border-color:#666;">';
  772. echo'<form action="" method="post" onsubmit="' . "return frm_kontakt_add_id_koresp(this);" . '">';
  773. echo'<input type="hidden" name="'."contact_add_id_koresp_save".'" value="'."1".'" />';
  774. echo "Dodaj korespondencję z klientem - ID_KORESP: ";
  775. echo '<input type="text" name="'."id_koresp".'" value="' . "" . '" class="i" />';
  776. echo ' <input type="submit" value="'."zapisz".'" />';
  777. echo'</form>';
  778. echo'</div>';// .box
  779. echo'<div class="box" style="margin:6px 0;border-color:#666;">';
  780. $ico_print = '<img src="icon/print.gif" height="16" />';
  781. echo '<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."bok_rozwiazanie_umowy"."&user_id=".$user->ID.'" target="_blank">' . $ico_print . " rozwiązanie umowy".'</a>';
  782. echo'</div>';// .box
  783. echo'</div>';
  784. }
  785. function items_filters() {
  786. $filter_arr = WindykacjaStatsHelper::get_filters();
  787. $filter_selected = WindykacjaStatsHelper::get_filter_selected();
  788. $status_cnt = WindykacjaStatsHelper::get_status_count();// {cnt, suma_zaleglosci}
  789. // pomin filtry
  790. unset($filter_arr['15']);
  791. unset($filter_arr['blokada']);
  792. unset($filter_arr['WAITING']);
  793. $sub_filters = array('tel1', 'bad_address', '3 m-ce przed', 'po-terminie', 'has_nr_sad', 'has_nr_komornik', 'has_ustalenia', 'sad_and_komornik', 'sad_bez_komornik');
  794. $sub_filters_arr = array();
  795. foreach ($sub_filters as $v_filter_name) {
  796. if (array_key_exists($v_filter_name, $filter_arr)) {
  797. $sub_filters_arr[$v_filter_name] = $filter_arr[$v_filter_name];
  798. unset($filter_arr[$v_filter_name]);
  799. }
  800. }
  801. $zewn_filters = array('waiting-sad', 'sad');
  802. $zewn_filters_arr = array();
  803. foreach ($zewn_filters as $v_filter_name) {
  804. if (array_key_exists($v_filter_name, $filter_arr)) {
  805. $zewn_filters_arr[$v_filter_name] = $filter_arr[$v_filter_name];
  806. unset($filter_arr[$v_filter_name]);
  807. }
  808. }
  809. echo'<table cellspacing="0" cellpadding="0" border="1" style="background:#ddd;border-color:#666;"><tr><td style="vertical-align:top">';
  810. if (!empty($filter_selected)) {
  811. echo'<a href="' . "??MENU_INIT=USERS2_WINDYKACJA_STATUS" . '" title="'."Kasuj filtry".'">' . '<img src="icon/del.png" height="16" alt="'."Kasuj filtry".'" />' . '</a>';
  812. echo '</td><td>';
  813. }
  814. echo'<table class="tbl-view historia-platnosci-filters" cellspacing="0" cellpadding="0" border="1">';
  815. echo'<thead>';
  816. echo'<tr>';
  817. foreach ($filter_arr as $k => $v_arr) {
  818. $cls = ($filter_selected == $k)? ' class="selected"' : '';
  819. echo'<td' . $cls . '>';
  820. if ($desc = V::get('desc', '', $v_arr)) {
  821. echo '<span title="' . end($desc) . '">' . reset($desc) . '</span>';
  822. }
  823. echo'</td>';
  824. }
  825. if (!empty($zewn_filters_arr)) {
  826. echo '<td colspan="'.count($zewn_filters_arr).'" style="background:#f00;color:#fff;font-weight:bold;">' . "Windykacja zewnętrzna" . '</td>';
  827. }
  828. echo'</tr>';
  829. echo'<tr>';
  830. foreach ($filter_arr as $k => $v_arr) {
  831. $cls = ($filter_selected == $k)? ' class="selected"' : '';
  832. echo'<td' . $cls . '>';
  833. echo '<a href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&_f=" . $k . '">' . reset($v_arr) . '</a>';
  834. //$stat_cnt = V::get($k, 0, $status_cnt, 'int');
  835. //echo ' <span style="color:#f00;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  836. $stat_cnt = 0;
  837. if (array_key_exists($k, $status_cnt)) {
  838. $stat_cnt = $status_cnt[$k]->cnt;
  839. echo ' <span style="color:#000;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  840. $stat_saldo = number_format($status_cnt[$k]->suma_zaleglosci, 2, ',', ' ');
  841. echo '<br />' . '<span style="color:#f00;" title="' . $stat_saldo . " zł zagdłużenia" . '">' . $stat_saldo . '</span>';
  842. } else {
  843. echo ' <span style="color:#000;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  844. }
  845. echo'</td>';
  846. }
  847. if (!empty($zewn_filters_arr)) {
  848. foreach ($zewn_filters_arr as $k => $v_arr) {
  849. $cls = ($filter_selected == $k)? ' class="selected"' : '';
  850. echo'<td' . $cls . '>';
  851. echo '<a href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&_f=" . $k . '">' . reset($v_arr) . '</a>';
  852. //$stat_cnt = V::get($k, 0, $status_cnt, 'int');
  853. //echo ' <span style="color:#f00;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  854. $stat_cnt = 0;
  855. if (array_key_exists($k, $status_cnt)) {
  856. $stat_cnt = $status_cnt[$k]->cnt;
  857. echo ' <span style="color:#000;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  858. $stat_saldo = number_format($status_cnt[$k]->suma_zaleglosci, 2, ',', ' ');
  859. echo '<br />' . '<span style="color:#f00;" title="' . $stat_saldo . " zł zagdłużenia" . '">' . $stat_saldo . '</span>';
  860. } else {
  861. echo ' <span style="color:#000;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  862. }
  863. echo'</td>';
  864. }
  865. }
  866. echo'</tr>';
  867. echo'</thead>';
  868. echo'</table>';
  869. if (!empty($sub_filters_arr)) {
  870. echo '<table class="tbl-view historia-platnosci-subfilters" cellspacing="0" cellpadding="0" border="1">';
  871. echo '<thead><tr>';
  872. foreach ($sub_filters_arr as $k => $v_arr) {
  873. $cls = ($filter_selected == $k)? ' class="selected"' : '';
  874. echo'<td' . $cls . '>';
  875. echo '<a href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&_f=" . $k . '">' . reset($v_arr) . '</a>';
  876. //$stat_cnt = V::get($k, 0, $status_cnt, 'int');
  877. //echo ' <span style="color:#f00;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  878. $stat_cnt = 0;
  879. if (array_key_exists($k, $status_cnt)) {
  880. $stat_cnt = $status_cnt[$k]->cnt;
  881. echo ' <span style="color:#000;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  882. $stat_saldo = number_format($status_cnt[$k]->suma_zaleglosci, 2, ',', ' ');
  883. echo '<br />' . '<span style="color:#000;" title="' . $stat_saldo . " zł zagdłużenia" . '">' . $stat_saldo . '</span>';
  884. } else {
  885. echo ' <span style="color:#000;" title="' . $stat_cnt . " klinetów" . '">' . "(" . $stat_cnt . ")" . '</span>';
  886. }
  887. echo'</td>';
  888. }
  889. echo '</tr></thead>';
  890. echo '</table>';
  891. }
  892. echo '</td></tr></table>';
  893. echo'<br />';
  894. }
  895. function items( $q, &$page_nav, &$items ) {
  896. $page_nav->links = array();
  897. $out_link_arr = V::copy( $page_nav->base_link_arr );
  898. $out_link_arr['_p'] = 0;
  899. $out_link = V::make_link('', $out_link_arr);
  900. $page_nav->links []= '<a href="' . $out_link . '" title="'."Pierwsza strona".'">'."|&lt;&lt;".'</a>';
  901. if ($page_nav->page_nr > 0) {
  902. $out_link_arr = V::copy( $page_nav->base_link_arr );
  903. $out_link_arr['_p'] = $page_nav->page_nr - 1;
  904. $out_link = V::make_link('', $out_link_arr);
  905. $page_nav->links []= '<a href="' . $out_link . '" title="'."Poprzednia strona".'">'."&lt;&lt; -".$page_nav->page_limit.'</a>';
  906. } else {
  907. $page_nav->links []= " &lt;&lt; ";
  908. }
  909. $page_nav->links []= '<span>'.($page_nav->page_nr * $page_nav->page_limit).'</span>';
  910. $page_nav->links []= '<span title="'."Znaleziono ".$page_nav->total." rekordów".'">'."(".$page_nav->total.") ".'</span>';
  911. $out_link_arr = V::copy( $page_nav->base_link_arr );
  912. $out_link_arr['_p'] = $page_nav->page_nr + 1;
  913. $out_link = V::make_link('', $out_link_arr);
  914. $page_nav->links []= '<a href="' . $out_link . '" title="'."Nastepna strona".'">'."+".$page_nav->page_limit." &gt;&gt;".'</a>';
  915. $out_link_arr = V::copy( $page_nav->base_link_arr );
  916. $out_link_arr['_p'] = $page_nav->last_page_nr;
  917. $out_link = V::make_link('', $out_link_arr);
  918. $page_nav->links []= '<a href="' . $out_link . '" title="'."Ostatnia strona".'">'."&gt;&gt;|".'</a>';
  919. $page_nav_out = '<div class="tbl-page-nav">' . implode(" ", $page_nav->links);
  920. $out_link_arr = V::copy( $page_nav->base_link_arr );
  921. $out_link_arr['task'] = 'export_csv';
  922. $out_link = V::make_link('', $out_link_arr);
  923. $page_nav_out .= ' <a style="margin:0 0 0 20px;" href="' . $out_link . '" target="_blank">export csv</a>';
  924. $page_nav_out .= '</div>';
  925. if (empty($items)) {
  926. echo'<p style="color:red">'."Brak danych".'</p>';
  927. return;
  928. }
  929. echo $page_nav_out;
  930. $cols_order_by = WindykacjaStatsModel::get_order_by_fields();
  931. $cols = array();
  932. $cols['ID_BILLING_USERS'] = array('label'=>'Nr klienta', 'title'=>'ID_BILLING_USERS');
  933. $cols['is_firma'] = array('label'=>'F', 'title'=>'is_firma: Firma 1 - tak, 0 nie');
  934. $cols['BILLING_OWNER'] = array('label'=>'COM', 'title'=>'BILLING_OWNER: Klient firmy 1 - BIALL-NET, 2 - NETDAY');
  935. $cols['BLOKADA'] = array('label'=>'B', 'title'=>'BLOKADA: Informacja o blokadzie');
  936. $cols['P_NAME'] = array('label'=>'imie i nazwisko', 'title'=>'P_NAME');
  937. $cols['P_ADDRESS_STREET'] = array('label'=>'adres', 'title'=>'P_ADDRESS_STREET');
  938. $cols['A_STATUS'] = array('label'=>'status', 'title'=>'A_STATUS');
  939. $cols['A_STATUS_UPDATE_DATE'] = array('label'=>'data aktualizacji', 'title'=>'A_STATUS_UPDATE_DATE');
  940. $cols['PAY_SALDO'] = array('label'=>'saldo', 'title'=>'PAY_SALDO');
  941. $cols['PAY_FVAT'] = array('label'=>'zaległe faktury', 'title'=>'PAY_FVAT');
  942. $cols['PAY_DATE'] = array('label'=>'data wymagalności<br /> ostatniej faktury', 'title'=>'PAY_DATE');
  943. $cols['LAST_PAY_DATE'] = array('label'=>'data ostatniej wpłaty', 'title'=>'LAST_PAY_DATE');
  944. $cols['PAY_TERM'] = array('label'=>'termin płatności', 'title'=>'PAY_TERM');
  945. echo'<table class="tbl-view historia-platnosci" border="1" cellspacing="0" cellpaddin="0">';
  946. echo'<thead>';
  947. echo'<tr>';
  948. foreach ($cols as $k_field => $v_params) {
  949. echo'<th' . ((!empty($v_params['title'])) ? ' title="' . $v_params['title'] . '"' : '') . '>';
  950. echo $v_params['label'];
  951. if (in_array($k_field, $cols_order_by)) {
  952. $sel_oby = (isset($page_nav->base_link_arr['_oby']))? $page_nav->base_link_arr['_oby'] : '';
  953. $sel_odir = 'DESC';
  954. if ($k_field == $sel_oby) {
  955. $sel_odir = (isset($page_nav->base_link_arr['_odir']))? $page_nav->base_link_arr['_odir'] : '';
  956. $sel_odir = ($sel_odir == 'ASC')? 'ASC' : 'DESC';
  957. }
  958. $out_link_arr = V::copy( $page_nav->base_link_arr );
  959. $out_link_arr['_p'] = 0;
  960. $out_link_arr['_oby'] = $k_field;
  961. $out_link_arr['_odir'] = ($sel_odir == 'DESC')? 'ASC' : 'DESC';
  962. $out_link = V::make_link('', $out_link_arr);
  963. echo ' <a style="' . (($k_field == $sel_oby)? 'color:red;' : '') . 'text-decoration:none" href="' . $out_link . '">' . (($sel_odir == 'DESC')? 'v' : '^') . '</a>';
  964. }
  965. echo '</th>';
  966. }
  967. echo'</tr>';
  968. echo'</thead>';
  969. echo'<tbody>';
  970. $t = 0;
  971. foreach ($items as $k_id => $user) {
  972. echo'<tr class="row-'.($t = 1 - $t).'">';
  973. echo'<td>';
  974. echo'<nobr>';
  975. $out_link_arr = V::copy( $page_nav->base_link_arr );
  976. $out_link_arr['_user_id'] = $k_id;
  977. $out_link = V::make_link('', $out_link_arr);
  978. echo '<a href="' . $out_link . '">'.'<img src="icon/edit.png" height="16" alt="Edit">'.'</a>';
  979. echo " ";
  980. echo '<a href="' . $out_link . '">'.$k_id.'</a>';
  981. echo'</nobr>';
  982. echo'</td>';
  983. echo '<td>';
  984. echo $user->is_firma;
  985. echo '</td>';
  986. echo '<td>';
  987. if ($user->BILLING_OWNER == 1) {
  988. echo '<span title="' . "BIALL-NET" . '">' . 'BN' . '</span>';
  989. } else if ($user->BILLING_OWNER == 2) {
  990. echo '<span title="' . "NETDAY" . '">' . 'ND' . '</span>';
  991. } else {
  992. echo '0';
  993. }
  994. echo '</td>';
  995. echo '<td>';
  996. if ($user->STATUS == 9) {
  997. echo '<b style="color:red" title="' . "ZABLOKOWANY" . '">' . "Z" . '</b>';
  998. } else {
  999. echo '<em style="color:silver" title="' . "brak blokady" . '">' . "0" . '</em>';
  1000. }
  1001. echo '</td>';
  1002. echo'<td>';
  1003. $cell_out = $user->P_NAME.' '.$user->P_NAME_SECOND;
  1004. echo '<b title="' . $cell_out . '">' . ((strlen($cell_out) > 30)? substr($cell_out, 0, 30) . ' ...' : $cell_out) . '</b>';
  1005. echo'</td>';
  1006. echo'<td'.(($user->BAD_ADDRESS)? ' style="background-color:#FF7878;"' : '').'>';
  1007. $cell_out = "ul. " . $user->P_ADDRESS_STREET . " " . $user->P_ADDRESS_HOUSE . "/" . $user->P_ADDRESS_HOME . ", " . $user->P_ADDRESS_POST_CODE . " " . $user->P_ADDRESS_CITY;
  1008. echo '<i title="' . (($user->BAD_ADDRESS)? "błędny adres zameldowania: " : '') . $cell_out . '">' . ((strlen($cell_out) > 30)? mb_substr($cell_out, 0, 30, "UTF-8") . ' ...' : $cell_out) . '</i>';
  1009. echo'</td>';
  1010. echo'<td>';
  1011. echo '<nobr>';
  1012. switch ($user->A_STATUS) {
  1013. case 'WAITING':
  1014. echo '<span style="color:#666;">' . $user->A_STATUS . '</span>';
  1015. break;
  1016. default:
  1017. echo $user->A_STATUS;
  1018. }
  1019. echo '</nobr>';
  1020. echo'</td>';
  1021. echo'<td>';
  1022. if ($user->A_STATUS_UPDATE_DATE != '0000-00-00') {
  1023. echo $user->A_STATUS_UPDATE_DATE;
  1024. } else {
  1025. echo '<span style="color:#666;">' . $user->A_STATUS_UPDATE_DATE . '</span>';
  1026. }
  1027. echo'</td>';
  1028. echo'<td>';
  1029. echo '<nobr>';
  1030. if ($user->PAY_SALDO != 0) {
  1031. $col = ($user->PAY_SALDO > 0)? '#333' : '#f00';
  1032. echo '<span style="color:' . $col . '">' . $user->PAY_SALDO . " zł" . '</span>';
  1033. } else {
  1034. echo'<span style="color:#666">' . "0" . '</span>';
  1035. }
  1036. echo '</nobr>';
  1037. echo'</td>';
  1038. echo'<td>';
  1039. if ($user->PAY_FVAT > 0) {
  1040. $st = ($user->PAY_FVAT > 1)? ' style="color:#f00"' : '';
  1041. echo' <span title="' . $user->PAY_FVAT . " nieopłaconych faktur" . '"'.$st.'>' . $user->PAY_FVAT . '</span>';
  1042. } else {
  1043. echo $user->PAY_FVAT;
  1044. }
  1045. echo'</td>';
  1046. echo'<td>';
  1047. if ($user->PAY_DATE != '0000-00-00') {
  1048. echo $user->PAY_DATE;
  1049. }
  1050. echo'</td>';
  1051. echo'<td>';
  1052. if ($user->LAST_PAY_DATE && $user->LAST_PAY_DATE != '0000-00-00') {
  1053. echo $user->LAST_PAY_DATE;
  1054. } else {
  1055. echo '---';
  1056. }
  1057. echo'</td>';
  1058. echo'<td>';
  1059. if ($user->PAY_TERM != '0000-00-00') {
  1060. echo $user->PAY_TERM;
  1061. }
  1062. echo'</td>';
  1063. //, w.`USER_PAY_TERM_ADD`
  1064. //, w.`L_APPOITMENT_DATE`
  1065. //, w.`L_APPOITMENT_USER`
  1066. echo'</tr>';
  1067. }//end foreach
  1068. echo'</tbody>';
  1069. echo'</table>';
  1070. echo $page_nav_out;
  1071. }
  1072. function export_csv( $q, &$page_nav, &$items ) {
  1073. if (empty($items)) {
  1074. echo "Brak danych";
  1075. return;
  1076. }
  1077. $cols_order_by = WindykacjaStatsModel::get_order_by_fields();
  1078. $cols = array();
  1079. $cols['ID_BILLING_USERS'] = array('label'=>'Nr klienta', 'title'=>'ID_BILLING_USERS');
  1080. $cols['is_firma'] = array('label'=>'F', 'title'=>'is_firma: Firma 1 - tak, 0 nie');
  1081. $cols['BILLING_OWNER'] = array('label'=>'COM', 'title'=>'BILLING_OWNER: Klient firmy 1 - BIALL-NET, 2 - NETDAY');
  1082. $cols['BLOKADA'] = array('label'=>'B', 'title'=>'BLOKADA: Informacja o blokadzie');
  1083. $cols['P_NAME'] = array('label'=>'imie i nazwisko', 'title'=>'P_NAME');
  1084. $cols['P_ADDRESS_STREET'] = array('label'=>'adres', 'title'=>'P_ADDRESS_STREET');
  1085. $cols['A_STATUS'] = array('label'=>'status', 'title'=>'A_STATUS');
  1086. $cols['A_STATUS_UPDATE_DATE'] = array('label'=>'data aktualizacji', 'title'=>'A_STATUS_UPDATE_DATE');
  1087. $cols['PAY_SALDO'] = array('label'=>'saldo', 'title'=>'PAY_SALDO');
  1088. $cols['PAY_FVAT'] = array('label'=>'zaległe faktury', 'title'=>'PAY_FVAT');
  1089. $cols['PAY_DATE'] = array('label'=>'data wymagalności ostatniej faktury', 'title'=>'PAY_DATE');
  1090. $cols['LAST_PAY_DATE'] = array('label'=>'data ostatniej wpłaty', 'title'=>'LAST_PAY_DATE');
  1091. $cols['PAY_TERM'] = array('label'=>'termin płatności', 'title'=>'PAY_TERM');
  1092. $out_cols = array();
  1093. foreach ($cols as $k_field => $v_params) {
  1094. $out_cols []= '"' . $v_params['label'] . '"';
  1095. }
  1096. echo implode(";", $out_cols) . "<br />\n";
  1097. foreach ($items as $k_id => $user) {
  1098. $out_cols = array();
  1099. $out_cols []= '"' . $k_id . '"';
  1100. $out_cols []= '"' . $user->is_firma . '"';
  1101. if ($user->BILLING_OWNER == 1) {
  1102. $out_cols []= '"' . 'BN' . '"';
  1103. } else if ($user->BILLING_OWNER == 2) {
  1104. $out_cols []= '"' . 'ND' . '"';
  1105. } else {
  1106. $out_cols []= '"' . '0' . '"';
  1107. }
  1108. $out_cols []= '"' . (($user->STATUS == 9)? "Z" : "0") . '"';
  1109. $out_cols []= '"' . $user->P_NAME.' '.$user->P_NAME_SECOND . '"';
  1110. $out_cols []= '"' . "ul. " . $user->P_ADDRESS_STREET . " " . $user->P_ADDRESS_HOUSE . "/" . $user->P_ADDRESS_HOME . ", " . $user->P_ADDRESS_POST_CODE . " " . $user->P_ADDRESS_CITY . '"';
  1111. $out_cols []= '"' . $user->A_STATUS . '"';
  1112. $out_cols []= '"' . $user->A_STATUS_UPDATE_DATE . '"';
  1113. $out_cols []= '"' . (($user->PAY_SALDO != 0)? $user->PAY_SALDO . " zł" : "0") . '"';
  1114. $out_cols []= '"' . $user->PAY_FVAT . '"';
  1115. $out_cols []= '"' . (($user->PAY_DATE != '0000-00-00')? $user->PAY_DATE : '') . '"';
  1116. $out_cols []= '"' . (($user->LAST_PAY_DATE && $user->LAST_PAY_DATE != '0000-00-00')? $user->LAST_PAY_DATE : '---') . '"';
  1117. $out_cols []= '"' . (($user->PAY_TERM != '0000-00-00')? $user->PAY_TERM : '') . '"';
  1118. echo implode(";", $out_cols) . "<br />\n";
  1119. }
  1120. }
  1121. function form($q = '') {
  1122. SEF("MENU");
  1123. MENU();
  1124. echo'<div class="box box-blue">';
  1125. echo'<form action="" method="get">';
  1126. echo'<input type="hidden" name="'."MENU_INIT".'" value="'."USERS2_WINDYKACJA_STATUS".'" />';
  1127. echo'<p style="margin:0;">'."Wyszukaj klienta: ";
  1128. echo'<input type="text" name="'."q".'" value="'.htmlspecialchars($q).'" />';
  1129. echo " ".'<em>'."(imie, nazwisko lub numer klineta)".'</em>';//, adres
  1130. echo " ".'<input type="submit" value="'."szukaj".'" />';
  1131. echo'</p>';
  1132. echo'</form>';
  1133. echo'</div>';// .box-blue
  1134. }
  1135. function css() {
  1136. echo'<style type="text/css">'."
  1137. body{font-family:arial;}
  1138. .box{border:1px solid #999;padding:5px;margin:5px;}
  1139. .box-center{border:1px solid #999;padding:5px;margin:5px auto;}
  1140. .box-silver{border-color:#999;}
  1141. .box-red{border-color:#f00;}
  1142. .box-blue{border-color:#00f;}
  1143. .box-green{border-color:#008000;}
  1144. .box-hover-active{background:#fff;border-color:#999;}
  1145. .box-hover-active:hover{background:#eee;border-color:#000;}
  1146. .btn-box{margin:0 2px 0 0;padding:0 3px;background:#bbb;color:#fff;text-decoration:none;border:0;font-weight:bold;}
  1147. .tbl-page-nav{font-size:small;}
  1148. .tbl-page-nav a{font-size:small; text-decoration:none;}
  1149. .tbl-page-nav a:hover{background-color:#eee;}
  1150. .tbl-view {margin:0;font-size:small;}
  1151. .tbl-view caption{text-align:left;font-style:italic;font-size:medium;}
  1152. .tbl-view caption em{padding:0 5px;font-size:13px;font-style:normal;}
  1153. .tbl-view th{padding:0 3px;font-size:small;}
  1154. .tbl-view td{padding:0 3px;}
  1155. .tbl-view .r{text-align:right;}
  1156. .tbl-view thead th {background:#F3F3F3;}
  1157. .tbl-view thead td {background:#F3F3F3;}
  1158. .historia-platnosci-filters thead td{text-align:center;}
  1159. .historia-platnosci-filters td.selected {background-color:#FFE6E9;}
  1160. .historia-platnosci-filters td:hover {background-color:#E6FFE6;}
  1161. .historia-platnosci-subfilters thead td{text-align:center;background:#fff;}
  1162. .historia-platnosci-subfilters td.selected {background-color:#FFE6E9;}
  1163. .historia-platnosci-subfilters td:hover {background-color:#E6FFE6;}
  1164. .tbl-td-top th,
  1165. .tbl-td-top td {vertical-align:top;}
  1166. ".'</style>';
  1167. }
  1168. function user_umowy( &$user ) {
  1169. Lib::loadClass('Tree');
  1170. Lib::loadClass('TreeHelper');
  1171. // build tree by P_ID - array or 0
  1172. function Tree_Helper__create_tree_rec( $p_id, &$items ) {
  1173. static $rec_ind;
  1174. $rec_ind++;
  1175. $ret = array();
  1176. if (!array_key_exists($p_id, $items)) {
  1177. return false;
  1178. } else {
  1179. $r = $items[$p_id];
  1180. if (empty($r->sub)) {
  1181. return false;
  1182. }
  1183. foreach ($r->sub as $k_id => $v) {
  1184. $ret [$k_id] = Tree_Helper__create_tree_rec( $k_id, $items );
  1185. }//end foreach
  1186. return $ret;
  1187. }
  1188. }
  1189. function tree_callback__show_item_from_SERVICES( &$r, &$tree ) {
  1190. $cls = array();
  1191. $cls []= 'HANGUP_STATUS-' . $r->HANGUP_STATUS;
  1192. $cls = (!empty($cls))? ' class="'.implode(' ', $cls).'"' : '';
  1193. echo'<dl'.$cls.'>';
  1194. echo'<dt>';
  1195. $out_id = ($r->ID < 10)? '&nbsp;'.$r->ID.'' : $r->ID;
  1196. echo'<b class="item_id btn-box">'.$out_id.'</b>';
  1197. //echo'<a href="'."?MENU_INIT=IN7_MK_BAZA_DYSTRYBUCJI_EDIT&ARG1=EDIT&ARG1_VAL=".$r->ID.'" class="btn" title="'."Edit".'">'."E".'</a>';
  1198. $st_status_bg = '';
  1199. if ($r->A_STATUS == 'NORMAL') {
  1200. $st_status_bg = '#8F8;';
  1201. } else if ($r->A_STATUS == 'WAITING') {
  1202. $st_status_bg = '#F8F;';
  1203. } else if ($r->A_STATUS == 'DELETED') {
  1204. $st_status_bg = '#ccc;';
  1205. } else if ($r->A_STATUS == 'OFF_SOFT') {
  1206. $st_status_bg = '#F99;';
  1207. } else if ($r->A_STATUS == 'OFF_HARD') {
  1208. $st_status_bg = '#eee;';
  1209. }
  1210. $st_status_bg = ($st_status_bg)? 'background-color:'.$st_status_bg : '';
  1211. echo'<span class="desc">';
  1212. echo'<span class="btn-box" style="'.$st_status_bg.'">'.$r->A_STATUS.'</span>';
  1213. echo' <b style="color:#333;">'.$r->description.'</b>';
  1214. if ($r->ID_OFFERS) {
  1215. echo' <code>' . "(Nr oferty: " . $r->ID_OFFERS . ")" . '</code>';
  1216. } else {
  1217. echo' <span style="color:#f00">'."Brak numeru oferty!".'</span>';
  1218. }
  1219. $st_status_bg = '';
  1220. if ($r->HANGUP_STATUS == 'NORMAL') {
  1221. $st_status_bg = 'background-color:#8F8;';
  1222. } else if ($r->HANGUP_STATUS == 'WAITING') {
  1223. $st_status_bg = 'background-color:#F8F;';
  1224. } else if ($r->HANGUP_STATUS == 'DELETED') {
  1225. $st_status_bg = 'background-color:#ccc;';
  1226. } else if ($r->HANGUP_STATUS == 'OFF_SOFT') {
  1227. $st_status_bg = 'background-color:#F99;';
  1228. } else if ($r->HANGUP_STATUS == 'OFF_HARD') {
  1229. $st_status_bg = 'background-color:#f00;color:#fff;';
  1230. }
  1231. echo ' <span class="btn-box" style="' . $st_status_bg . '">' . "{$r->HANGUP_STATUS} ({$r->HANGUP_FROM} - {$r->HANGUP_TILL}) - {$r->A_STATUS_DESC}" .'</span>';
  1232. echo'</span>';
  1233. echo'</dt>';
  1234. echo'</dl>'."\n";
  1235. }
  1236. $uslugi_l2 = WindykacjaStatsModel::get_uslugi_from_l2( $user );
  1237. $umowy_l2 = WindykacjaStatsModel::get_umowy_from_l2( $user );
  1238. $uslugi_l2_nieprzypisane = array();
  1239. foreach ($uslugi_l2 as $k_id => $h) {
  1240. $uslugi_l2_nieprzypisane[$k_id] = true;
  1241. }//end foreach
  1242. if (is_array($umowy_l2) && !empty($umowy_l2)) {
  1243. if (is_array($uslugi_l2) && !empty($uslugi_l2)) {
  1244. foreach ($umowy_l2 as $k_umowa_ind => $h_umowa) {
  1245. $umowy_l2[$k_umowa_ind]['uslugi'] = array();
  1246. foreach ($uslugi_l2 as $k_id => $h_usluga) {
  1247. if ($h_usluga['ID_DEALS_TABLE'] == $h_umowa['ID']) {
  1248. $umowy_l2[$k_umowa_ind]['uslugi'] [$k_id] = $h_usluga;
  1249. if (isset($uslugi_l2_nieprzypisane[$k_id])) unset($uslugi_l2_nieprzypisane[$k_id]);
  1250. }
  1251. }//end foreach
  1252. }//end foreach
  1253. }
  1254. }
  1255. echo'<style type="text/css">'."
  1256. .tbl-umowy-l2 .umowa-id{font-weight:bold;font-size:big;font-family:arial;}
  1257. .tbl-umowy-l2 .row-umowa td{border-top:2px solid #00f;}
  1258. .wind-status-old td,
  1259. .wind-status-old th {color:#666;}
  1260. ".'</style>';
  1261. $ARGS['ZAPISZ'] = true;
  1262. Lay_Html_Toggle::start( "Aktualne umowy i usługi ", array('open'=>(($ARGS['ZAPISZ'])? false : true)) );
  1263. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">umowy_l2: ';print_r($umowy_l2);echo'</pre>';
  1264. echo'<table class="tbl-view tbl-umowy-l2" cellspacing="0" cellpadding="0" border="1">';
  1265. //echo'<caption>'."Aktualne umowy".'<em>'." (l2)".'</em>'.'</caption>';
  1266. if ($umowy_l2 == -1) {
  1267. echo'<tr><td>';
  1268. echo'<span style="color:red">'."Blad polaczenia do bazy dancyh webone_billing - Zasob [931]".'</span>';
  1269. echo'</td></tr>';
  1270. } else if (empty($umowy_l2)) {
  1271. echo'<tr><td>'."Brak umów.".'</td></tr>';
  1272. }
  1273. else {
  1274. $tbl_umowy_cols = 5;
  1275. echo'<thead>';
  1276. echo'<tr>';
  1277. echo'<th>'."Nr umowy".'</th>';
  1278. echo'<th>'."Prefix".'</th>';
  1279. echo'<th>'."Data umowy".'</th>';
  1280. echo'<th>'."Termin".'</th>';
  1281. echo'<th>'."".'</th>';
  1282. echo'</tr>';
  1283. echo'</thead>';
  1284. $t = 0;
  1285. foreach ($umowy_l2 as $h) {
  1286. echo'<tr class="row-umowa row-'.($t = 1 - $t).'">';
  1287. echo'<td class="r umowa-id">' . $h['P_DEALNUMBER'] . '</td>';
  1288. echo'<td>' . $h['P_DEALPREFIX'] . '</td>';
  1289. echo'<td class="r">' . $h['P_DEALDATE'] . '</td>';
  1290. echo'<td class="r">' . $h['P_DEALDATE_TERM'] . '</td>';
  1291. echo'<td>';
  1292. if ($h['Wcześniejszy Nr umowy']) echo "Wcześniejszy Nr umowy: ".$h['Wcześniejszy Nr umowy'].'<br />';// TODO: Undefined index
  1293. if ($h['DEALDESC']) echo "Notatki: ".$h['DEALDESC'].'<br />';
  1294. echo "Koniecznosc podpisania aneksu lub innego dokumentu: ".$h['ANEX_NEEDED'].'<br />';
  1295. echo "Data potwierdzenia podpisania aneksu/dokumentu: ".$h['ANEX_CONFIRM_DATE'].'<br />';
  1296. echo'</td>';
  1297. echo'</tr>';
  1298. if (!empty($h['uslugi'])) {
  1299. // TODO: make TREE by P_ID_SERVICES
  1300. $items = array();
  1301. foreach ($h['uslugi'] as $k_id_usluga => $h_suluga) {
  1302. $h_suluga['sub'] = array();
  1303. $items [$k_id_usluga] = (object)$h_suluga;
  1304. }//end foreach
  1305. $uslugi_tree = array();// tree root
  1306. foreach ($items as $k_id => $r) {
  1307. if ($r->P_ID == 0) {
  1308. $uslugi_tree [ $r->ID ] = array();
  1309. if (array_key_exists($r->P_ID, $items)) {
  1310. $items[$r->P_ID]->sub [$r->ID] = true;
  1311. }
  1312. } else {// array
  1313. if (array_key_exists($r->P_ID, $items)) {
  1314. $items[$r->P_ID]->sub [$r->ID] = true;
  1315. }
  1316. }
  1317. }//end foreach
  1318. ksort($uslugi_tree);
  1319. // set up has_childrens
  1320. foreach ($items as $k_id => $r) {
  1321. $items[$k_id]->has_childrens = !empty($r->sub);
  1322. }//end foreach
  1323. foreach ($uslugi_tree as $k_id => $v_childrens) {
  1324. if (array_key_exists($k_id, $items)) {
  1325. $uslugi_tree[$k_id] = Tree_Helper__create_tree_rec( $k_id, $items );
  1326. }
  1327. }
  1328. echo'<tr class="row-'.($t).'">';
  1329. echo'<td>'."&nbsp;".'</td>';
  1330. echo'<td colspan="'.($tbl_umowy_cols - 1).'" style="padding:0;">';
  1331. $tree = new Tree( 'SERVICES' );
  1332. $tree->set_parent_id_col( 'P_ID' );
  1333. $tree->set_param('show_item_callback', "tree_callback__show_item_from_SERVICES");
  1334. $tree->set_param('ajax', "NIE");
  1335. $tree->set_param('rozwin', true);
  1336. $tree->show_css();
  1337. $tree->show_js();
  1338. $_COOKIE[$tree->cookie_name] = implode(' ', array_keys($items));
  1339. echo "\n".'<div class="tree-wrap">'."\n";
  1340. $tree->show_rec_by_tree($uslugi_tree, $items);
  1341. echo '</div>'."\n";
  1342. echo'</td>';
  1343. echo'</tr>';
  1344. }
  1345. }//end foreach
  1346. }
  1347. echo'</table>';
  1348. if (!empty($uslugi_l2_nieprzypisane)) {
  1349. echo'<table class="tbl-view tbl-umowy-l2" cellspacing="0" cellpadding="0" border="1">';
  1350. echo'<caption>'."Nieprzypisane usługi".'<em>'." (l2)".'</em>'.'</caption>';
  1351. echo'<head>';
  1352. echo'<tr>';
  1353. echo'<th>'."ID".'</th>';
  1354. echo'<th>'."usługa".'</th>';
  1355. echo'<th>'."status".'</th>';
  1356. echo'<th>'."nr umowy".'</th>';
  1357. echo'<th>'."id oferty".'</th>';
  1358. echo'</tr>';
  1359. echo'</head>';
  1360. foreach ($uslugi_l2_nieprzypisane as $k_id => $v_bool) {
  1361. $h_usluga = $uslugi_l2[ $k_id ];
  1362. echo'<tr>';
  1363. echo'<td class="r">' . $h_usluga['ID'] . '</td>';
  1364. echo'<td>' . $h_usluga['description'] . '</td>';
  1365. echo'<td>' . $h_usluga['A_STATUS_DESC'] . '</td>';
  1366. echo'<td class="r">' . '<b>';
  1367. if (array_key_exists($h['ID_DEALS_TABLE'], $umowy_l2)) {
  1368. echo $umowy_l2[ $h['ID_DEALS_TABLE'] ] ['P_DEALNUMBER'];
  1369. } else {
  1370. //TODO: get P_DEALNUMBER from DEALS_TABLE where ID = $h['ID_DEALS_TABLE']
  1371. }
  1372. echo'</b>' . '</td>';
  1373. echo'<td class="r">';
  1374. if ($h_usluga['ID_OFFERS']) {
  1375. echo'<code>' . $h_usluga['ID_OFFERS'] . '</code>';
  1376. } else {
  1377. echo'<span style="color:#f00">'."Brak!".'</span>';
  1378. }
  1379. echo'</td>';
  1380. echo'</tr>';
  1381. }//end foreach
  1382. echo'</table>';
  1383. }
  1384. Lay_Html_Toggle::end();
  1385. $umowy_l3 = WindykacjaStatsModel::get_umowy_from_l3( $user );
  1386. $ARGS['ZAPISZ'] = true;
  1387. Lay_Html_Toggle::start( "Aktualne usługi".'<em>'." (l3)".'</em>', array('open'=>(($ARGS['ZAPISZ'])? false : true)) );
  1388. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">umowy_l3: ';print_r($umowy_l3);echo'</pre>';
  1389. echo'<table class="tbl-view tbl-umowy-l2" cellspacing="0" cellpadding="0" border="1">';
  1390. if (empty($umowy_l3)) {
  1391. echo'<tr><td>'."Brak usług.".'</td></tr>';
  1392. }
  1393. else {
  1394. echo'<thead>';
  1395. echo'<tr>';
  1396. echo'<th rowspan="2">'."ID".'</th>';
  1397. echo'<th rowspan="2">'."status".'</th>';
  1398. echo'<th rowspan="2">'."data dok".'</th>';
  1399. echo'<th rowspan="2">'."adres".'</th>';
  1400. echo'<th rowspan="2">'."usługa".'</th>';
  1401. echo'<th rowspan="2">'."S_OTHER_INFO".'</th>';
  1402. echo'<th colspan="2" title="'."ID_BILLING_USERS".'">'. "nr klienta" .'</th>';
  1403. echo'<th colspan="2" title="'."ID_SERVICES".'">'."nr usługi".'</th>';
  1404. echo'<th colspan="2" title="'."P_OFFER_ID".'">'."nr oferty".'</th>';
  1405. echo'<th colspan="2" title="'."P_DEAL_DATE".'">'."data umowy".'</th>';
  1406. echo'<th colspan="2">'."nr umowy".'</th>';
  1407. echo'<th colspan="2">'."termin umowy".'</th>';
  1408. echo'<th colspan="2" title="'."MONTH COST".'">'."abonament".'</th>';
  1409. echo'<th rowspan="2">'."INICJALY HANDLOWCA".'</th>';
  1410. echo'<th rowspan="2">'."RODZAJ DZIALANIA HANDLOWEGO".'</th>';
  1411. echo'</tr>';
  1412. echo'<tr>';
  1413. echo'<td>'."OLD".'</td>';
  1414. echo'<td>'."NEW".'</td>';
  1415. echo'<td>'."OLD".'</td>';
  1416. echo'<td>'."NEW".'</td>';
  1417. echo'<td>'."OLD".'</td>';
  1418. echo'<td>'."NEW".'</td>';
  1419. echo'<td>'."OLD".'</td>';
  1420. echo'<td>'."NEW".'</td>';
  1421. echo'<td>'."OLD".'</td>';
  1422. echo'<td>'."NEW".'</td>';
  1423. echo'<td>'."OLD".'</td>';
  1424. echo'<td>'."NEW".'</td>';
  1425. echo'<td>'."OLD".'</td>';
  1426. echo'<td>'."NEW".'</td>';
  1427. echo'</tr>';
  1428. echo'</thead>';
  1429. foreach ($umowy_l3 as $h) {
  1430. echo'<tr>';
  1431. echo'<td>' . $h['ID'] . '</td>';
  1432. echo'<td>' . $h['A_STATUS'] . '</td>';
  1433. echo'<td>' . '<nobr>' . $h['DATA_DOK'] . '</nobr>' . '</td>';
  1434. echo'<td>' . $h['S_ADDRESS_STREET'] . '</td>';
  1435. echo'<td>' . '<b>' . $h['P_SERVICE'] . '</b>' . '</td>';
  1436. echo'<td>' . $h['S_OTHER_INFO'] . '</td>';
  1437. echo'<td>' . $h['ID_BILLING_USERS_OLD'] . '</td>';
  1438. echo'<td>' . $h['ID_BILLING_USERS_NEW'] . '</td>';
  1439. echo'<td>' . $h['ID_SERVICES_OLD'] . '</td>';
  1440. echo'<td>' . $h['ID_SERVICES_NEW'] . '</td>';
  1441. echo'<td>' . $h['P_OFFER_ID_OLD'] . '</td>';
  1442. echo'<td>' . $h['P_OFFER_ID_NEW'] . '</td>';
  1443. echo'<td>' . '<nobr>' . $h['P_DEAL_DATE_OLD'] . '</nobr>' . '</td>';
  1444. echo'<td>' . '<nobr>' . $h['P_DEAL_DATE_NEW'] . '</nobr>' . '</td>';
  1445. echo'<td>' . $h['P_DEALNUMBER_OLD'] . '</td>';
  1446. echo'<td>' . $h['P_DEALNUMBER_NEW'] . '</td>';
  1447. echo'<td>' . '<nobr>' . $h['P_DEALTERM_OLD'] . '</nobr>' . '</td>';
  1448. echo'<td>' . '<nobr>' . $h['P_DEALTERM_NEW'] . '</nobr>' . '</td>';
  1449. echo'<td>' . $h['MONTH_COST_OLD'] . '</td>';
  1450. echo'<td>' . $h['MONTH_COST_NEW'] . '</td>';
  1451. echo'<td>' . $h['INICJALY_HANDLOWCA'] . '</td>';
  1452. echo'<td>' . $h['RODZAJ_DZIALANIA_HANDLOWEGO'] . '</td>';
  1453. echo'</tr>';
  1454. }//end foreach
  1455. }
  1456. echo'</table>';
  1457. Lay_Html_Toggle::end();
  1458. }
  1459. function user_historia_platnosci( &$user ) {
  1460. echo'<style type="text/css">';
  1461. echo"
  1462. .hide .to-hide{display:none;}
  1463. .may-hide .btn-hide{display:inline;padding:0 5px;border:1px solid #bbb;}
  1464. .may-hide .btn-show{display:none;padding:0 5px;border:1px solid #bbb;}
  1465. .hide .btn-hide{display:none;}
  1466. .hide .btn-show{display:inline;}
  1467. ";
  1468. echo'</style>';
  1469. echo'<script type="text/javascript" src="stuff/jquery.js"></script>';
  1470. Lay_Html_Toggle::show_js();
  1471. $billing_docs = WindykacjaStatsModel::get_bill_dosc_by_date( $user );
  1472. // add events
  1473. $umowy_l2 = WindykacjaStatsModel::get_umowy_from_l2( $user );
  1474. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">billing_docs ';print_r($billing_docs);echo'</pre>';
  1475. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">billing_docs ';print_r(reset($billing_docs));echo'</pre>';
  1476. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">umowy_l2 ';print_r($umowy_l2);echo'</pre>';
  1477. if (!empty($umowy_l2)) {
  1478. foreach ($umowy_l2 as $h) {
  1479. $billing_docs->add_event( $h['P_DEALDATE'], 'UMOWA', $h );
  1480. if ($h['P_DEALDATE_TERM'] != '0000-00-00') {// < date('Y-m-d')) {
  1481. $billing_docs->add_event( $h['P_DEALDATE_TERM'], 'KONIEC UMOWY', $h );
  1482. }
  1483. }
  1484. }
  1485. $user_hist_events = WindykacjaStatsHelper::get_user_hist_status_events( $user );
  1486. if (!empty($user_hist_events)) {
  1487. foreach ($user_hist_events as $v_hist) {
  1488. $bill_doc = (array)$v_hist;
  1489. $billing_docs->add_event( $v_hist->A_STATUS_UPDATE_DATE, 'HIST_STATUS', $bill_doc );
  1490. }
  1491. }
  1492. $user_hist_events = WindykacjaStatsHelper::get_user_hist_phone_events( $user );
  1493. if (!empty($user_hist_events)) {
  1494. foreach ($user_hist_events as $v_hist) {
  1495. $bill_doc = (array)$v_hist;
  1496. $billing_docs->add_event( substr($v_hist->A_RECORD_UPDATE_DATE, 0, 10), 'HIST_PHONE', $bill_doc );
  1497. }
  1498. }
  1499. $user_hist_events = WindykacjaStatsHelper::get_user_bad_address_events( $user );
  1500. if (!empty($user_hist_events)) {
  1501. foreach ($user_hist_events as $v_hist) {
  1502. $bill_doc = (array)$v_hist;
  1503. $billing_docs->add_event( substr($v_hist->A_RECORD_UPDATE_DATE, 0, 10), 'HIST_BAD_ADDRESS', $bill_doc );
  1504. }
  1505. }
  1506. // add today
  1507. $bill_doc = array();
  1508. $bill_doc['saldo'] = $billing_docs->get_saldo();
  1509. $billing_docs->add_event( date('Y-m-d'), 'TODAY', $bill_doc );
  1510. $billing_docs->sort_docs();
  1511. //$billing_docs = array_reverse($billing_docs, true);
  1512. //echo'<pre style="max-height:300px;overflow:auto;border:1px solid red;">billing_docs: ';print_r($billing_docs);echo'</pre>';
  1513. $billing_docs_arr = $billing_docs->get_docs();
  1514. $types_finanse = array();
  1515. $types_finanse []= 'KW';
  1516. $types_finanse []= 'KP';
  1517. $types_finanse []= 'WB_MASS';
  1518. $types_finanse []= 'WB';
  1519. $types_finanse []= 'KORV';
  1520. $types_finanse []= 'FVAT';
  1521. $saldo_all = 0;
  1522. $out_tbl = array();
  1523. foreach ($billing_docs_arr as $k_data => $v_docs_arr) {
  1524. foreach ($v_docs_arr as $k_ind => $v_doc) {
  1525. $out_tr = array();
  1526. $out_tr ['data'] = $k_data;
  1527. if ($k_data == date("Y-m-d")) $out_tr ['class'] = 'today';
  1528. $out_tr ['ID'] = '';
  1529. $out_tr ['nr'] = '';
  1530. $out_tr ['winien'] = '';
  1531. $out_tr ['ma'] = '';
  1532. $out_tr ['saldo'] = '';
  1533. $out_tr ['saldo_all'] = '';
  1534. if ($v_doc->get_class() == 'BILLING') {
  1535. $saldo_all += $v_doc->get_saldo();
  1536. $out_tr ['ID'] = $v_doc->get_type();
  1537. $type_desc = WindykacjaStatsModel::get_billing_type_desc( $v_doc->get_type() );
  1538. if ($type_desc) {
  1539. if ($v_doc->get_type() == 'FVAT') $type_desc .= "\n Wystawiona: ".$v_doc->get('BILL_DATE')."\n Termin płatności: ".$v_doc->get('PAYMENT_TERM');
  1540. $out_tr['ID'] = '<span title="'.$type_desc.'">'.$out_tr['ID'].'</span>';
  1541. // TODO: podglad faktury
  1542. //if ($h['type'] == 'FVAT') $out_tr['ID'] .= ' <a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&_user_id=".$user->ID."&task=view_faktura&id=".$h['ID'].'" target="_blank">'.'<img src="'."icon/search.png".'" alt="'."U".'" title="'."Podgląd faktury".'" />'.'</a>';
  1543. }
  1544. $out_tr ['ID'] .= ' <code style="font-size:10px">'."(".$v_doc->get('ID').")".'</code>';// TODO: dla KP,KW: ID_BILLING_NUMBERS zamiast ID
  1545. $out_tr ['nr'] = $v_doc->get('nr');
  1546. $out_tr ['winien'] = number_format($v_doc->get('WINIEN'), 2, ',', ' ');
  1547. $out_tr ['ma'] = number_format($v_doc->get('MA'), 2, ',', ' ');
  1548. $out_tr ['saldo'] = number_format($v_doc->get_saldo(), 2, ',', ' ');
  1549. $out_tr ['saldo_all'] = number_format($saldo_all, 2, ',', ' ');
  1550. // style
  1551. if ($out_tr['winien'] == '0,00') $out_tr['winien'] = '<span style="color:#666;">' . $out_tr['winien'] . '</span>';
  1552. if ($out_tr['ma'] == '0,00') $out_tr['ma'] = '<span style="color:#666;">' . $out_tr['ma'] . '</span>';
  1553. }
  1554. else if ($v_doc->get_class() == 'EVENT') {
  1555. if ($v_doc->get_type() == 'TODAY') {
  1556. $out_tr ['class'] = 'today';
  1557. $v_doc_saldo = V::get('saldo', '', $v_doc->get_data());
  1558. $out_tr ['saldo_all'] = number_format($v_doc_saldo, 2, ',', ' ');
  1559. }
  1560. else if ($v_doc->get_type() == 'HIST_STATUS') {
  1561. // search for koresp files
  1562. // TODO: mv to ::get_koresp_file( $id_koresp );
  1563. $id_koresp = intval($v_doc->get('ID_KORESP'));
  1564. $found_files = array();
  1565. {
  1566. $CNF = new stdClass();
  1567. $CNF->koresp_dir = '/home/samba/BIALL-NET/PISMA/OUT';
  1568. $CNF->koresp_www_path = '/se-dev/PISMA/OUT';
  1569. if ($id_koresp > 0) {
  1570. $pattern = $CNF->koresp_dir . '/' . '*.' . $id_koresp . '.pdf';
  1571. $file_tmp_list = glob($pattern);//, GLOB_NOSORT);
  1572. if (!empty($file_tmp_list)) {
  1573. foreach ($file_tmp_list as $v_file) {
  1574. $test_file = end( explode('/', $v_file) );
  1575. $found_files []= $CNF->koresp_www_path . '/' . $test_file;
  1576. }//end foreach
  1577. }
  1578. }
  1579. // return $found_files;
  1580. }
  1581. switch ($v_doc->get('A_STATUS')) {
  1582. case 'WAITING':
  1583. $out_tr ['add'] = "powrót do oczekujących";
  1584. break;
  1585. case 'waiting-wezwanie2':
  1586. $out_tr ['add'] = "wezwanie do zapłaty - ID_KORESP: <b>".$v_doc->get('ID_KORESP')."</b> <em>(termin: ".$v_doc->get('PAY_TERM').")</em> ";
  1587. break;
  1588. case 'waiting-krd':
  1589. $out_tr ['add'] = "wezwanie do zapłaty ost. - ID_KORESP: <b>".$v_doc->get('ID_KORESP')."</b> <em>(termin: ".$v_doc->get('PAY_TERM').")</em> ";
  1590. break;
  1591. case 'N/S;':
  1592. $out_tr ['add'] = "ID_KORESP: <b>".$v_doc->get('ID_KORESP')."</b> <em>(" . $v_doc->get('K_ZAWARTOS') . ")</em>";// TODO: get opis from koresp
  1593. //echo '('.$v_doc->get('ID_KORESP').', '.$v_doc->get('K_ZAWARTOS').'='.substr($v_doc->get('K_ZAWARTOS'), 0, strlen('rozwiazanie umowy')).')';
  1594. if ($v_doc->get('ID_KORESP') > 0 && substr($v_doc->get('params'), 0, strlen('rozwiazanie umowy')) == 'rozwiazanie umowy') {
  1595. $out_tr ['add'] .= " " . '<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."bok_rozwiazanie_umowy_print"."&user_id=".$user->ID."&id_koresp=".$v_doc->get('ID_KORESP').'" target="_blank" title="' . "Generuj druk rozwiązania umowy" . '">' . "druk" . '</a>';
  1596. }
  1597. break;
  1598. default:
  1599. $out_tr ['add'] = "zmiana statusu na: ".$v_doc->get('A_STATUS')." ";
  1600. }
  1601. if ($id_koresp > 0) {
  1602. if (!empty($out_tr ['add']) && !empty($found_files)) {
  1603. $add_link_koresp = reset($found_files);// first file from koresp
  1604. $out_tr ['add'] .= " " . '<a href="' . $add_link_koresp . '" target="_blank">' . "P" . '</a>';
  1605. }
  1606. //$koresp_edit_link = "?MENU_INIT=IN7_DZIENNIK_KORESP_EDIT&ARG1=EDIT&ARG1_VAL=" . $id_koresp;
  1607. Lib::loadClass('ProcesHelper');
  1608. $zasobKorespID = ProcesHelper::getZasobTableID('IN7_DZIENNIK_KORESP');
  1609. $koresp_edit_link = "index.php?MENU_INIT=VIEWTABLE_AJAX&ZASOB_ID={$zasobKorespID}#EDIT/{$id_koresp}";
  1610. $out_tr ['add'] .= " " . '<a href="' . $koresp_edit_link . '" title="' . "Edycja KORESP. (" . $id_koresp . ")" . '" target="_blank">' . "KOR" . '</a>';
  1611. }
  1612. }
  1613. else if ($v_doc->get_type() == 'HIST_PHONE') {
  1614. $date = $v_doc->get('PAY_TERM');
  1615. if ($date == 'N/S;') $date = '';
  1616. switch ($v_doc->get('LAST_PHONE_STATUS')) {
  1617. case 'nie_zaplaci':
  1618. $out_tr ['add'] = "nie zapłaci";
  1619. break;
  1620. case 'zaplaci_w_terminie':
  1621. $out_tr ['add'] = "zapłaci w terminie " . $date . " " . '<em style="font-size:small;">' . "(ustalono " . $v_doc->get('A_RECORD_UPDATE_DATE') . ")" . '</em>';
  1622. break;
  1623. case 'zaplaci_za_1mc':
  1624. $out_tr ['add'] = "zapłaci miesiąc później " . $date . " " . '<em style="font-size:small;">' . "(ustalono " . $v_doc->get('A_RECORD_UPDATE_DATE') . ")" . '</em>';
  1625. break;
  1626. case 'zaplaci_za_2mc':
  1627. $out_tr ['add'] = "zapłaci 2 miesiące później " . $date . " " . '<em style="font-size:small;">' . "(ustalono " . $v_doc->get('A_RECORD_UPDATE_DATE') . ")" . '</em>';
  1628. break;
  1629. case 'zaplaci_za_3mc':
  1630. $out_tr ['add'] = "zapłaci 3 miesiące później " . $date . " " . '<em style="font-size:small;">' . "(ustalono " . $v_doc->get('A_RECORD_UPDATE_DATE') . ")" . '</em>';
  1631. break;
  1632. default:
  1633. $out_tr ['add'] = "kontakt z klientem: " . $v_doc->get('LAST_PHONE_STATUS') . " " . '<em style="font-size:small;">' . "(ustalono " . $v_doc->get('A_RECORD_UPDATE_DATE') . ")" . '</em>';
  1634. }
  1635. } else if ($v_doc->get_type() == 'HIST_BAD_ADDRESS') {
  1636. if ($v_doc->get('BAD_ADDRESS')) {
  1637. $out_tr ['add'] = "błędny adres zameldowania ";
  1638. } else {
  1639. $out_tr ['add'] = "poprawa adresu zameldowania ";
  1640. }
  1641. if ($v_doc->get('ID_KORESP') > 0) {
  1642. $out_tr ['add'] .= " - ID Koresp. (" . '<a href="' . "index.php?MENU_INIT=IN7_DZIENNIK_KORESP_EDIT&ARG1=EDIT&ARG1_VAL=" . $v_doc->get('ID_KORESP') . '" target="_blank">' . $v_doc->get('ID_KORESP') . '</a>' . ")";
  1643. }
  1644. } else {
  1645. $out_tr ['ID'] = $v_doc->get_type().' <code style="font-size:10px">'."(".$v_doc->get('ID').")".'</code>';// TODO: dla KP,KW: ID_BILLING_NUMBERS zamiast ID
  1646. if ($v_doc->get_type() == 'UMOWA') {
  1647. $out_tr ['add'] = "umowa nr <b>".$v_doc->get('P_DEALNUMBER')."</b> <em>(termin ".$v_doc->get('P_DEALDATE_TERM').")</em>";
  1648. } else if ($v_doc->get_type() == 'KONIEC UMOWY') {
  1649. $out_tr ['add'] = "zakończenie umowy nr <b>".$v_doc->get('P_DEALNUMBER')."</b> <em>(z dnia ".$v_doc->get('P_DEALDATE').")</em>";
  1650. }
  1651. }
  1652. }
  1653. //$out_tbl []= $out_tr;// add to the end
  1654. array_unshift($out_tbl, $out_tr);// add to the begining
  1655. }//end foreach
  1656. }//end foreach
  1657. echo'<style type="text/css">'."
  1658. .tbl-windykacja td{padding:0 5px;}
  1659. .tbl-windykacja .cell-data{white-space:nowrap;}
  1660. .tbl-windykacja .cell-winien{text-align:right;}
  1661. .tbl-windykacja .cell-ma{text-align:right;}
  1662. .tbl-windykacja .cell-saldo{text-align:right;}
  1663. .tbl-windykacja .cell-saldo_all{text-align:right; white-space:nowrap; background-color:#E5E5E5;}
  1664. .tbl-windykacja .cell-nr{font-family:monospace;text-align:right;}
  1665. .tbl-windykacja .change-year td{border-top:3px solid #00f;}
  1666. .tbl-windykacja .today td{background:#FFFF98;}
  1667. .tbl-windykacja .cell-add em{color:#666;}
  1668. ".'</style>';
  1669. $last_year = '';
  1670. $cols = array();
  1671. $cols ['data'] = "data";
  1672. $cols ['ID'] = "ID";
  1673. $cols ['nr'] = "nr";
  1674. $cols ['winien'] = "winien";
  1675. $cols ['ma'] = "ma";
  1676. //$cols ['saldo'] = "saldo";
  1677. $cols ['saldo_all'] = "saldo";
  1678. $cols ['add'] = "uwagi";
  1679. echo'<h4>'."Historia płatności".'<em>'." (l1)".'</em>'.'</h4>';
  1680. echo'<table border="1" class="tbl-view tbl-windykacja" cellspacing="0" cellpadding="0">';
  1681. echo'<thead>';
  1682. echo'<tr>';
  1683. echo'<th>'."rok".'</th>';
  1684. foreach ($cols as $col_name => $col_label) {
  1685. echo'<th>' . $col_label . '</th>';
  1686. }//end foreach
  1687. echo'</tr>';
  1688. echo'</thead>';
  1689. foreach ($out_tbl as $out_tr) {
  1690. $change_year = false;
  1691. $k_data = $out_tr['data'];
  1692. $rok = substr($k_data, 0, 4);
  1693. if ($rok != $last_year) {
  1694. $change_year = true;
  1695. }
  1696. $cls = array();
  1697. if ($change_year) $cls []= 'change-year';
  1698. if ($add_cls = V::get('class', '', $out_tr)) $cls []= $add_cls;
  1699. $cls = (!empty($cls))? ' class="'.implode(' ', $cls).'"' : '';
  1700. echo'<tr'.$cls.'>';
  1701. echo'<td>';
  1702. echo ($change_year)? $rok : "&nbsp;";
  1703. echo'</td>';
  1704. $last_year = $rok;
  1705. foreach ($cols as $col_name => $col_label) {
  1706. //foreach ($out_tr as $k_col_name => $v_val) {
  1707. if (array_key_exists($col_name, $out_tr)) {
  1708. echo'<td class="'."cell-".$col_name.'">' . $out_tr[$col_name] . '</td>';
  1709. } else {
  1710. echo'<td>'."&nbsp;".'</td>';
  1711. }
  1712. }//end foreach
  1713. echo'</tr>';
  1714. }//end foreach
  1715. echo'</table>';
  1716. echo'<br />';
  1717. echo'<br />';
  1718. WindykacjaStatsHelper::update_stats( $user, $billing_docs );
  1719. }
  1720. function view_faktura( $faktura_id ) {
  1721. // https://l1.webone.pl/modules/make_billing/edit.php?mod=make_billing&form=make_faktura&adm=edit&uid=11381&fpos=&dz=
  1722. // https://l1.webone.pl/modules/make_billing/edit.php?mod=make_billing&form=html_faktura&adm=edit&uid=11381&fpos=&dz=&close=0&doc=483930&doctype=1
  1723. echo'{'.$faktura_id.'}';
  1724. }
  1725. function zadluzenia( &$user ) {
  1726. $THIS_DATA_DO = null;// TODO: pobierac z PAY_TERM z tabeli USERS2_WINDYKACJA_STATUS
  1727. $post_sent = (!empty($_POST['sbmt']));
  1728. $post_DATA_DO = (isset($_POST['DATA_DO']))? $_POST['DATA_DO'] : date("Y-m-d", mktime(0,0,0,date('m'), date('d') + 14, date('Y')));
  1729. if (!$post_sent) {
  1730. echo'<table style="margin:10px 50px;padding:20px;border:1px solid blue;"><tr><td>';
  1731. echo'<form action="" method="post">';
  1732. $post_DATA_DO = (isset($_POST['DATA_DO']) && strlen($_POST['DATA_DO']) == 10)? $_POST['DATA_DO'] : date("Y-m-d", mktime(0,0,0,date('m'), date('d') + 14, date('Y')));
  1733. echo'<p>'."Termin płatności: ".'</p>';
  1734. echo'<input type="text" name="'."DATA_DO".'" value="'.$post_DATA_DO.'" />';
  1735. echo'<input type="submit" name="sbmt" value="'."Wyslij".'" />';
  1736. echo'</form>';
  1737. echo'</td></tr></table>';
  1738. return;
  1739. } else {
  1740. $THIS_DATA_DO = $post_DATA_DO;
  1741. }
  1742. self::wezwanie( $user, $THIS_DATA_DO );
  1743. }
  1744. function wezwanie_ostateczne( &$user, $wezwanie_termin ) {
  1745. self::wezwanie( $user, $wezwanie_termin, true );
  1746. }
  1747. function wezwanie( &$user, $wezwanie_termin, $wezwanie_ostateczne = false ) {
  1748. $date_limit = date("Y-m-d");
  1749. $billing_docs = WindykacjaStatsModel::get_bill_dosc_by_date( $user, $date_limit );
  1750. $billing_docs->sort_docs();
  1751. // sprawdz zadluzenie
  1752. if ($billing_docs->get_saldo() >= 0) {
  1753. echo'<p class="green">' . "Brak zadluzenia" . '</p>';
  1754. return;
  1755. }
  1756. else {
  1757. $fvat_arr = $billing_docs->get_unpaid_fvat();
  1758. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">saldo('.$billing_docs->get_saldo().') fvat_arr: ';print_r($fvat_arr);echo'</pre>';
  1759. //foreach ($fvat_arr as $key => $v) {
  1760. // echo'<br />'.number_format($v['WINIEN_POZOSTALO'], 4, ',', ' ');
  1761. //}//end foreach
  1762. if (empty($fvat_arr)) {
  1763. echo'<p>'."Brak nieoplaconych faktur".'</p>';
  1764. return;
  1765. }
  1766. WindykacjaStatsModel::update_doc_number( $fvat_arr );
  1767. $cols = array();
  1768. $cols ['ID'] = "ID";
  1769. $cols ['nr'] = "nr";
  1770. $cols ['winien'] = "winien";
  1771. $cols ['ma'] = "ma";
  1772. //$cols ['saldo'] = "saldo";
  1773. $cols ['saldo_all'] = "saldo";
  1774. $cols ['add'] = "&nbsp;";
  1775. $saldo_all = 0;
  1776. foreach ($fvat_arr as $f) {
  1777. $saldo_all += round($f['WINIEN_POZOSTALO'], 2);
  1778. }
  1779. $out_tbl = array();
  1780. foreach ($fvat_arr as $v_fvat) {
  1781. $out_tr = array();
  1782. $out_tr ['ID'] = ' <code style="font-size:10px">'."(".$v_fvat['ID'].")".'</code>';// TODO: dla KP,KW: ID_BILLING_NUMBERS zamiast ID
  1783. $out_tr ['nr'] = $v_fvat['NUMBER'] . '/' . $v_fvat['ID_BILLING_PREFIXES'];
  1784. $out_tr ['winien'] = number_format($v_fvat['WINIEN'], 2, ',', ' ');
  1785. $out_tr ['data'] = $v_fvat['BILL_DATE'];
  1786. $out_tr ['termin'] = $v_fvat['PAYMENT_TERM'];
  1787. $out_tr ['pozostalo'] = number_format($v_fvat['WINIEN_POZOSTALO'], 2, ',', ' ');
  1788. array_unshift($out_tbl, $out_tr);// add to the begining
  1789. }
  1790. $razem = $saldo_all;
  1791. $company = WindykacjaStatsModel::get_company( $user );
  1792. $nr_konta = FunkcjeL1::bankowy_formatuj_nrach(FunkcjeL1::bankowy_make_nrach($company->NR_RACH_MASS_PAY, $user->ID_BILLING_USERS, 0));
  1793. echo'<style type="text/css">'."
  1794. body{font-family:serif; font-size:10px;line-height:14px;}
  1795. td{font-family:verdana; font-size:10px; color:#333;}
  1796. table {border-style:none;}
  1797. table td, table th {padding:0 2px;border-style:solid;border-collapse:collapse;}
  1798. table th {border-width:1px;border-color:#333;}
  1799. table td {border-width:1px;border-color:#333;}
  1800. ".'</style>';
  1801. echo'<div style="background:#fff;border:none;margin:5px;padding:20px 40px 10px 40px;page-break-after:always;font-size:small;">';
  1802. if ($user->ID_KORESP) {
  1803. $koresp = DB::get_by_id('IN7_DZIENNIK_KORESP', $user->ID_KORESP);
  1804. if ($koresp) {
  1805. echo '<div style="text-align:right;font-weight:bold;">';
  1806. echo $koresp->ID_PROJECT . '-' .$koresp->ID . "/" . substr(date("Y"), 2);
  1807. echo '</div>';
  1808. }
  1809. }
  1810. echo '<table border=0 cellspacing=0 cellpadding=0 style="width:100%;">';
  1811. echo'<tr>';
  1812. echo'<td style="width:60%;border:none;">';
  1813. //echo "&bdquo;BIALL-NET&rdquo; Sp. z o.o.<br />Otomin, ul. Słoneczna 43<br />80-174 Gdańsk";
  1814. echo $company->name1 . '<br />' . "ul. " . $company->ulica . " " . $company->numer_dom . '<br />' . $company->kod . " " . $company->miasto;
  1815. echo'</td>';
  1816. echo'<td style="border:none;text-align:left;vertical-align:top;">';
  1817. echo "Gdańsk, dnia ".date("Y-m-d");
  1818. echo'</td>';
  1819. echo'</tr>';
  1820. echo'<tr>';
  1821. echo'<td style="border:none;">'."&nbsp;".'</td>';
  1822. echo'<td style="border:none;">';
  1823. echo'<p style="margin:50px 0;">';
  1824. echo "Numer klienta: ".$user->ID;
  1825. echo '<br />'."".$user->P_NAME." ".$user->P_NAME_SECOND;
  1826. // TODO: P_ADRESS_KORESP_1282
  1827. echo '<br />'."ul. ".$user->P_ADDRESS_STREET." ".$user->P_ADDRESS_HOUSE;
  1828. if ($user->P_ADDRESS_HOME) echo "/".$user->P_ADDRESS_HOME;
  1829. echo '<br />' . $user->P_ADDRESS_POST_CODE . " " . $user->P_ADDRESS_CITY;
  1830. echo'</p>';
  1831. echo'</td>';
  1832. echo'</tr>';
  1833. echo'</table>';
  1834. echo'<h1 style="text-align:center;margin:20px 10px 10px 10px;font-size:28px;">';
  1835. if ($wezwanie_ostateczne) {
  1836. echo "OSTATECZNE WEZWANIE DO ZAPŁATY";
  1837. } else {
  1838. echo "WEZWANIE DO ZAPŁATY";
  1839. }
  1840. echo'</h1>';
  1841. echo'<p style="margin:10px;">'."&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Na podstawie art. 476 Kodeksu cywilnego (Dz. U. z 1964 r. nr 16, poz. 93, z późn. zmianami) wzywamy do natychmiastowego uregulowania należnej sumy, zgodnie z poniższym zestawieniem. ".'</p>';
  1842. echo '<table border=0 cellspacing=0 cellpadding=2 style="width:100%;margin:10px;font-size:small;">';
  1843. echo '<thead style="background:#F3F3F3;">';
  1844. echo '<tr>';
  1845. echo '<th>'."Podstawa zobowiązania*".'</th>';
  1846. echo '<th>'."Nr dokumentu".'</th>';
  1847. //echo '<th>'."Kwota netto".'</th>';
  1848. echo '<th>'."Kwota brutto".'</th>';
  1849. echo '<th>'."Data faktury".'</th>';
  1850. echo '<th>'."Termin płatności".'</th>';
  1851. echo '<th>'."Pozostało do zapłaty".'</th>';
  1852. echo '</tr>';
  1853. echo '</thead>';
  1854. echo '<tfoot>';
  1855. echo'<tr>';
  1856. echo'<td colspan="4" style="border:none;"></td>';
  1857. echo'<th style="border-width:2px;border-color:#333;text-align:right;background:#F3F3F3;">'."Razem:".'</th>';
  1858. echo'<td style="border-width:2px;border-color:#333;font-weight:bold;">'.FunkcjeL1::formatuj_grosze($razem).'</td>';
  1859. echo'</tr>';
  1860. echo '</tfoot>';
  1861. echo "\n";
  1862. foreach ($out_tbl as $out_tr) {
  1863. $k_data = $out_tr['data'];
  1864. $rok = substr($k_data, 0, 4);
  1865. $cls = array();
  1866. if ($add_cls = V::get('class', '', $out_tr)) $cls []= $add_cls;
  1867. $cls = (!empty($cls))? ' class="'.implode(' ', $cls).'"' : '';
  1868. echo'<tr'.$cls.'>';
  1869. echo'<td>';
  1870. echo "Faktura Vat";
  1871. echo'</td>';
  1872. //$file_total['PODSTAWA_NUMBER'] = $r['NUMBER']."/".$r['ID_BILLING_PREFIXES'];
  1873. //$file_total['PODSTAWA_DATA'] = date("Y-m-d",$r['BAF_TIMESTAMP']);
  1874. //$file_total['PAYMENT_TERM'] = date("Y-m-d",$r['TERMIN_PL']);
  1875. echo'<td>';
  1876. echo $out_tr['nr'];
  1877. echo'</td>';
  1878. echo'<td>';
  1879. echo $out_tr['winien'];
  1880. echo'</td>';
  1881. echo'<td>';
  1882. echo '<nobr>' . $out_tr['data'] . '</nobr>';
  1883. echo'</td>';
  1884. echo'<td>';
  1885. echo '<nobr>' . $out_tr['termin'] . '</nobr>';
  1886. echo'</td>';
  1887. echo'<td>';
  1888. echo $out_tr['pozostalo'];
  1889. echo'</td>';
  1890. echo'</tr>';
  1891. echo "\n";
  1892. }//end foreach
  1893. echo '</table>';
  1894. echo'<p style="margin:10px;">'."Słownie do zapłaty: ".'<span style="border-bottom:1px dotted #000;padding:0 50px;">'."&nbsp;&nbsp;".'<b>'.FunkcjeL1::slownie($razem).'</b>'."&nbsp;&nbsp;".'</span>'.'</p>';
  1895. echo'<p style="margin:10px;background:#eee;text-align:center;">'."Wymienioną sumę prosimy przekazać na nasz rachunek bankowy <br />".$nr_konta." w terminie do dnia ".'<span style="border-bottom:1px dotted #000;padding:0 50px;">'."&nbsp;&nbsp;".'<b>'.$wezwanie_termin.'</b>'."&nbsp;&nbsp;".'</span>'.'</p>';
  1896. echo'<ul style="margin:10px;font-size:small;padding:0 0 0 40px;">';
  1897. echo'<li style="line-height:16px;">'."Od nieterminowych płatności mogą zostać naliczone odsetki ustawowe (art.481 § 1 KC).".'</li>';
  1898. echo'<li style="line-height:16px;">'."W przypadku nieterminowej zapłaty nabywca zostanie obciążony wszelkimi kosztami windykacji oraz postępowania sądowego, które zostaną poniesione przez sprzedawcę w celu odzyskania należności.".'</li>';
  1899. echo '<li style="line-height:16px;">' . "W przypadku uregulowania należności przed otrzymaniem niniejszego wezwania, proszę potraktować je za bezprzedmiotowe." . '</li>';
  1900. echo'</ul>';
  1901. echo'<table style="width:100%;border:none">';
  1902. echo'<tr>';
  1903. echo'<td colspan="2" style="border:none;">';
  1904. echo'<p style="margin:5px 0;font-size:10px;">'."W razie problemów prosimy o kontakt z Biurem Obsługi Klienta tel. (58) 741-84-10 wew. 2,
  1905. <br> e-mail: bok@biall.net.pl lub z Windykatorem: tel. 513-156-732, (58) 741-84-78".'</p>';
  1906. echo'</td>';
  1907. echo'</tr>';
  1908. echo'</table>';
  1909. echo'<table style="width:100%;border:none">';
  1910. echo'<tr>';
  1911. echo'<td style="width:50%;border:none;">'."&nbsp;".'</td>';
  1912. echo'<td style="width:50%;border:2px solid #999">'."<br /><br /><br /><br />".'</td>';
  1913. echo'</tr>';
  1914. echo'<tr>';
  1915. echo'<td style="border:none;">'."&nbsp;".'</td>';
  1916. echo'<td style="text-align:center;border:none;">'."(pieczęć i podpis wierzyciela)".'</td>';
  1917. echo'</tr>';
  1918. echo'<tr>';
  1919. echo'<td colspan="2" style="border:none;">';
  1920. echo'<p style="margin:10px 0;font-size:xx-small;">'."* Podstawa zobowiązania: Faktura VAT, Rachunek, Umowa, Nota odsetkowa, Nota księgowa, Weksel, Uznanie długu, Ugoda, Kara umowna, Faktura zbiorowa, Wyrok sądowy, Nakaz zapłaty, Pożyczka, inne.".'</p>';
  1921. echo'</td>';
  1922. echo'</tr>';
  1923. echo'<tr>';
  1924. echo'<td colspan="2" style="border:none">';
  1925. echo'<p style="margin:8px 0;font-size:x-small;text-align:center">'."W przypadku nieuregulowania płatności we wskazanym terminie, zgodnie z &bdquo;Ustawą o udostępnianiu informacji gospodarczych z dnia 14 lutego 2003 r. (Dz. U. Nr 50)&rdquo; , informacje o zadłużeniu zostaną przekazane do:".'</p>';
  1926. echo'<p style="margin:8px 0 0 0;font-size:small;text-align:center">'."<b>Krajowego Rejestru Długów<br />
  1927. Biura Informacji Gospodarczej S.A.<br />
  1928. ul. Armii Ludowej 21, 51-214 Wrocław<br />
  1929. www.krd.pl</b>
  1930. <br />
  1931. <br />
  1932. Informacja o zadłużeniu upubliczniona będzie w systemie KRD do dnia zapłaty lub 10 lat od daty dokonania wpisu.".'</p>';
  1933. echo'</td>';
  1934. echo'</tr>';
  1935. echo'</table>';
  1936. echo'</div>';
  1937. }
  1938. }
  1939. function task_update_stats() {
  1940. self::css();
  1941. $to_update_step = 500;
  1942. $q = V::get('q', '', $_GET);
  1943. $_p = V::get('_p', 0, $_GET, 'int');
  1944. echo'<a href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".$q."&_p=".$_p . '">' . "Cofnij" . '<img src=icon/back.gif border=0 alt=POWROT>' . '</a>';
  1945. $to_update_total = WindykacjaStatsHelper::get_to_update_total();
  1946. if ($to_update_total <= 0) {
  1947. echo'<p style="color:green">' . "Wszystkie rekordy zaktualizowane" . '</p>';
  1948. return;
  1949. }
  1950. if ($to_update_total > $to_update_step) {
  1951. echo'<br />';
  1952. echo'<a style="color:red" href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&task=stats_update&q=".$q."&_p=".$_p . '">' . "Aktualizuj statusy (" . ($to_update_total - $to_update_step) . ")" . '</a>';
  1953. echo'<br />';
  1954. }
  1955. $to_update_list = WindykacjaStatsHelper::get_to_update_list( $to_update_step );
  1956. if (empty($to_update_list)) {
  1957. echo'<p style="color:green">' . "Wszystkie rekordy zaktualizowane" . '</p>';
  1958. return;
  1959. }
  1960. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">to_update_list: ';print_r($to_update_list);echo'</pre>';
  1961. foreach ($to_update_list as $w) {
  1962. //echo'<div class="box box-blue">';
  1963. echo "Nr. klienta: <b>".$w->ID_BILLING_USERS . "</b> ...";
  1964. //echo $w->A_STATUS . ' (' . $w->A_STATUS_UPDATE_DATE . ')';
  1965. $user = WindykacjaStatsModel::get_user_by_id( $w->ID_BILLING_USERS );
  1966. if ($user) {
  1967. $billing_docs = WindykacjaStatsModel::get_bill_dosc_by_date( $user );
  1968. WindykacjaStatsHelper::update_stats( $user, $billing_docs );
  1969. }
  1970. //echo'</div>';// .box-blue
  1971. echo'<br />';
  1972. }//end foreach
  1973. if ($to_update_total > $to_update_step) {
  1974. echo'<br /><br />';
  1975. echo'<a style="color:red" href="' . "?MENU_INIT=USERS2_WINDYKACJA_STATUS&task=stats_update&q=".$q."&_p=".$_p . '">' . "Aktualizuj statusy (" . ($to_update_total - $to_update_step) . ")" . '</a>';
  1976. }
  1977. }
  1978. /**
  1979. * @params $user
  1980. * @params $id_koresp
  1981. */
  1982. function task_bok_rozwiazanie_umowy_print( $user, $id_koresp ) {
  1983. $user_hist_events = WindykacjaStatsHelper::get_user_hist_status_events($user);
  1984. if (empty($user_hist_events)) {
  1985. echo '<p style="color:red">' . "Brak danych HIST" . '</p>';
  1986. return;
  1987. }
  1988. $v_doc = null;
  1989. foreach ($user_hist_events as $v_hist) {
  1990. if ($v_hist->ID_KORESP == $id_koresp) {
  1991. $v_doc = $v_hist;
  1992. break;
  1993. }
  1994. }
  1995. if (!$v_doc) {
  1996. echo '<p style="color:red">' . "Brak danych HIST dla kodresp(".$v_doc->ID_KORESP.")" . '</p>';
  1997. return;
  1998. }
  1999. // params(255): rozwiazanie umowy,9872,3121
  2000. $params = explode(',', $v_doc->params);
  2001. if (count($params) < 3 && $params[0] != 'rozwiazanie umowy') {
  2002. echo '<p style="color:red">' . "Bad params" . '</p>';
  2003. return;
  2004. }
  2005. $koresp = DB::get_by_id('IN7_DZIENNIK_KORESP', $id_koresp);
  2006. if (!$koresp) {
  2007. echo '<p style="color:red">' . "Koresp not exists!" . '</p>';
  2008. return;
  2009. }
  2010. $nr_umowy = $params[1];
  2011. $powod = $params[2];
  2012. $deal_id = '..........................................................';
  2013. $termin_odlaczenia = '.....................';
  2014. if (count($params) > 4) {
  2015. // $data_arr["params"] = "rozwiazanie umowy,{$nr_umowy},{$powod},{$termin_odlaczenia},{$new_id_deals}";
  2016. $termin_odlaczenia = $params[3];
  2017. $deal_id = $params[4];
  2018. }
  2019. $arg_values = array();
  2020. $arg_values['powod'] = array();// [774].[800] - USERS2_DEALS.RODZAJ_DZIALANIA_HANDLOWEGO
  2021. // $arg_values['powod'] ['3226'] = "Finansowe";
  2022. // $arg_values['powod'] ['3227'] = "Niesatysfakcjonująca oferta";
  2023. // $arg_values['powod'] ['3121'] = "Przeprowadzka";
  2024. // $arg_values['powod'] ['3228'] = "Problemy techniczne/awarie";
  2025. // $arg_values['powod'] ['3230'] = "Wyjazd";
  2026. // $arg_values['powod'] ['3229'] = "Zła obsługa BOK/DT";
  2027. // $arg_values['powod'] ['3119'] = "Inne";
  2028. // [895].[3888] - DEALS_TABLE.RODZAJ_DZIALANIA_HANDLOWEGO
  2029. $arg_values['powod']['4192'] = "REZYGNACJA ZMIANA OPERATORA";
  2030. $arg_values['powod']['4193'] = "REZYGNACJA WYPROWADZKA";
  2031. $arg_values['powod']['4194'] = "REZYGNACJA NIEZADOWOLENIE";
  2032. $arg_values['powod']['4195'] = "REZYGNACJA CESJA";
  2033. //$arg_values['powod']['4196'] = "REZYGNACJA FINANSE";
  2034. $arg_values['powod']['4197'] = "REZYGNACJA SLABA OFERTA";
  2035. $arg_values['powod']['4198'] = "REZYGNACJA PROBLEMY TECHNICZNE";
  2036. $arg_values['powod']['4199'] = "REZYGNACJA ZLA OBSLUGA BOK";
  2037. $arg_values['powod']['4200'] = "WYPOWIEDZENIE PRZEZ OPERATORA ZA DLUGI";
  2038. //$arg_values['powod']['4202'] = "REZYGNACJA WYJAZD";
  2039. // $arg_values['powod']['4191'] = "BRAK-BOK (Inne)";
  2040. $arg_values['powod']['4213'] = "REZYGNACJA INNE";
  2041. $com = new stdClass();
  2042. if ($user->BILLING_OWNER == 2) {
  2043. $com->name = 'NET-DAY';
  2044. $com->fullName = 'NET-DAY Sp. z o.o.';
  2045. } else {
  2046. $com->name = 'BIALL-NET';
  2047. $com->fullName = 'BIALL-NET Sp. z o.o.';
  2048. }
  2049. ?>
  2050. <style type="text/css">
  2051. body{margin:12px;font-family:serif;font-size:11px;line-height:14px;}
  2052. td{font-family:verdana; font-size:10px; color:#333;}
  2053. table {border-style:none;}
  2054. table td, table th {padding:0 2px;border-collapse:collapse;}
  2055. table.tbl-bordered {border-style:none;}
  2056. table.tbl-bordered td, table.tbl-bordered th {padding:0 2px;border-style:solid;border-collapse:collapse;}
  2057. table.tbl-bordered th {border-width:1px;border-color:#333;}
  2058. table.tbl-bordered td {border-width:1px;border-color:#333;}
  2059. </style>
  2060. <table cellspacing="0" cellpadding="0" border="0" style="width:100%;"><tr>
  2061. <td>[1612][v3]</td>
  2062. <td style="text-align:right">Nr dziennika przyjęcia pisma <?php echo $com->fullName; ?> <?php echo $koresp->ID_PROJECT; ?>-<?php echo $koresp->ID; ?>/<?php echo substr(date("Y"), 2); ?>
  2063. <br />Gdańsk, dnia: .......................
  2064. </td>
  2065. </tr></table>
  2066. <br /><b>Dane Abonenta</b>
  2067. <br />Imię i Nazwisko / Nazwa firmy: <?php echo "{$user->P_NAME} {$user->P_NAME_SECOND}";?>
  2068. <br />Pesel / nr dowodu osoby reprezentującej firmę: <?php echo $user->P_PESEL; ?>
  2069. <br />Adres zameldowania: ul. <?php echo "{$user->P_ADDRESS_STREET} {$user->P_ADDRESS_HOUSE}/{$user->P_ADDRESS_HOME}, {$user->P_ADDRESS_POST_CODE} {$user->P_ADDRESS_CITY}"; ?>
  2070. <br />Nr ID klienta: <?php echo $user->ID; ?>
  2071. <br />Nr ID Umowy: <?php echo $deal_id; ?>
  2072. <?php
  2073. // <br />ID_SERVICES_OLD: ..........................................................
  2074. ?>
  2075. <table cellspacing="0" cellpadding="0" border="0" style="width:100%;margin:40px 0;"><tr>
  2076. <td>&nbsp;</td>
  2077. <td style="width:260px;text-align:left">
  2078. <?php echo $com->fullName; ?><br />Otomin ul. Słoneczna 43<br />80-174 Gdańsk
  2079. </td>
  2080. </tr></table>
  2081. <p style="margin:50px 0; text-align:center;">ROZWIĄZANIE UMOWY ABONENCKIEJ O ŚWIADCZENIE USŁUG TELEKOMUNIKACYJNYCH NR <sup>[794]</sup></p>
  2082. <p style="margin:0 0 50px 0;text-indent:50px">Proszę o rozwiązanie umowy abonenckiej o świadczeniu Usług Telekomunikacyjnych i odłączenie sygnału <?php echo $com->fullName; ?>. Jednocześnie jestem świadomy/a tego, że jeżeli okres trwania wypowiadanej umowy jeszcze nie uległ zakończeniu to firma <?php echo $com->name; ?> może naliczyć karę za wcześniejsze zerwanie umowy zgodnie z obowiązującym regulaminem i cennikiem.</p>
  2083. <p>Termin odłączenia: <?php echo $termin_odlaczenia; ?>
  2084. <br />(poinformowano o miesięcznym terminie wypowiedzenia, jak również przedstawiono nowe propozycje oferty)</p>
  2085. <p style="margin:30px 0;font-weight:bold;"><sup>[1061]</sup>Powody rezygnacji z Usług (wybierz tylko 1 najważniejszy powód)</p>
  2086. <table cellspacing="0" cellpadding="0" border="1" style="width:100%" class="tbl-bordered">
  2087. <?php foreach ($arg_values['powod'] as $k_powod => $v_label) : ?>
  2088. <?php $sel = ($powod == $k_powod)? "X" : "&nbsp;"; ?>
  2089. <tr><td style="width:26%;"><?php echo $v_label; ?></td><td style="width:5%;text-align:center;"> <?php echo $sel; ?> </td><td></td></tr>
  2090. <?php endforeach; ?>
  2091. </table>
  2092. <table cellspacing="0" cellpadding="0" border="0" style="margin:60px 0;width:100%;">
  2093. <tr>
  2094. <td style="width:15%;">&nbsp;</td>
  2095. <td style="width:20%;border-top:1px dotted #000;text-align:center;">
  2096. Data i podpis pracownika BOK
  2097. </td>
  2098. <td>&nbsp;</td>
  2099. <td style="width:20%;border-top:1px dotted #000;text-align:center;">
  2100. Data i czytelny podpis Klienta
  2101. </td>
  2102. <td style="width:15%;">&nbsp;</td>
  2103. </tr>
  2104. </table>
  2105. <?php
  2106. }
  2107. function task_bok_rozwiazanie_umowy( &$user ) {
  2108. echo'<script type="text/javascript">'."
  2109. function frm_bok_rozwiazanie_umowy(frm){
  2110. if (frm.id_proj.value=='') {
  2111. alert('Nie podano numeru projektu!');
  2112. } else if (frm.nr_umowy.value=='') {
  2113. alert('Nie podano numeru umowy!');
  2114. } else if (frm.temin_odlaczenia.value=='') {
  2115. alert('Nie podano daty odłączenia!');
  2116. // TODO: powod - radio
  2117. } else {
  2118. return true;
  2119. }
  2120. return false;
  2121. }
  2122. ".'</script>';
  2123. $umowy_l2 = WindykacjaStatsModel::get_umowy_from_l2( $user );
  2124. if (empty($umowy_l2)) {
  2125. echo '<p style="color:red">' . "Brak aktualnych umów z klientem" . '</p>';
  2126. return;
  2127. }
  2128. $arg_errors = array();
  2129. $arg_values = array();
  2130. $args = array();
  2131. $args['id_proj'] = V::get('id_proj', '', $_REQUEST, 'int');
  2132. $args['nr_umowy'] = V::get('nr_umowy', '', $_REQUEST, 'int');
  2133. $args['temin_odlaczenia'] = V::get('temin_odlaczenia', '', $_REQUEST);
  2134. $args['powod'] = V::get('powod', '', $_REQUEST, 'int');
  2135. $arg_values['nr_umowy'] = array();
  2136. foreach ($umowy_l2 as $k_id => $v_deal) {
  2137. $arg_values['nr_umowy'] [$v_deal['ID']] = $v_deal['ID'] . ' (Nr umowy: ' . $v_deal['P_DEALNUMBER'] . ', ' . $v_deal['P_DEALDATE'] . ' - ' . $v_deal['P_DEALDATE_TERM'] . ')';
  2138. }
  2139. $arg_values['powod'] = array();// [774].[800] - USERS2_DEALS.RODZAJ_DZIALANIA_HANDLOWEGO
  2140. // $arg_values['powod'] ['3226'] = "REZYGNACJA FINANSE";
  2141. // $arg_values['powod'] ['3227'] = "REZYGNACJA SLABA OFERTA";
  2142. // $arg_values['powod'] ['3121'] = "REZYGNACJA WYPROWADZKA";
  2143. // $arg_values['powod'] ['3228'] = "REZYGNACJA PROBLEMY TECHNICZNE";
  2144. // $arg_values['powod'] ['3230'] = "REZYGNACJA WYJAZD";
  2145. // $arg_values['powod'] ['3229'] = "REZYGNACJA ZLA OBSLUGA BOK";
  2146. // $arg_values['powod'] ['3123'] = "REZYGNACJA CESJA";
  2147. // $arg_values['powod'] ['3119'] = "BRAK-BOK (Inne)";
  2148. // [895].[3888] - DEALS_TABLE.RODZAJ_DZIALANIA_HANDLOWEGO
  2149. // $arg_values['powod']['4188'] = "UMOWA_BEZPOSREDNIA";
  2150. // $arg_values['powod']['4189'] = "UMOWA_POSREDNIA";
  2151. // $arg_values['powod']['4190'] = "TELEMARKETING";
  2152. $arg_values['powod']['4192'] = "REZYGNACJA ZMIANA OPERATORA";
  2153. $arg_values['powod']['4193'] = "REZYGNACJA WYPROWADZKA";
  2154. $arg_values['powod']['4194'] = "REZYGNACJA NIEZADOWOLENIE";
  2155. $arg_values['powod']['4195'] = "REZYGNACJA CESJA";
  2156. //$arg_values['powod']['4196'] = "REZYGNACJA FINANSE";
  2157. $arg_values['powod']['4197'] = "REZYGNACJA SLABA OFERTA";
  2158. $arg_values['powod']['4198'] = "REZYGNACJA PROBLEMY TECHNICZNE";
  2159. $arg_values['powod']['4199'] = "REZYGNACJA ZLA OBSLUGA BOK";
  2160. $arg_values['powod']['4200'] = "WYPOWIEDZENIE PRZEZ OPERATORA ZA DLUGI";
  2161. // $arg_values['powod']['4201'] = "UMOWA W BOK ZWYCZAJNA";
  2162. //$arg_values['powod']['4202'] = "REZYGNACJA WYJAZD";
  2163. // $arg_values['powod']['4191'] = "BRAK-BOK (Inne)";
  2164. $arg_values['powod']['4213'] = "REZYGNACJA INNE";
  2165. // validate
  2166. if ($args['temin_odlaczenia'] == '') {
  2167. $args['temin_odlaczenia'] = date("Y-m-d", mktime(0, 0, 0, date('m') + 1, date('d'), date('Y')));
  2168. } else {// cehck date format
  2169. if (strlen($args['temin_odlaczenia']) != 10) {
  2170. $arg_errors['temin_odlaczenia'] = "Błędny format daty";
  2171. } else {
  2172. $check_date = explode('-', $args['temin_odlaczenia']);
  2173. if (count($check_date) != 3 || strlen($check_date[0]) != 4 || strlen($check_date[1]) != 2 || strlen($check_date[2]) != 2) {
  2174. $arg_errors['temin_odlaczenia'] = "Błędny format daty";
  2175. } else {
  2176. // ok
  2177. }
  2178. }
  2179. }
  2180. if ($args['id_proj'] <= 0) {
  2181. $arg_errors ['id_proj'] = "Nie podano numeru projektu!";
  2182. }
  2183. if ($args['nr_umowy'] <= 0) {
  2184. $arg_errors ['nr_umowy'] = "Nie wybrano numeru umowy!";
  2185. }
  2186. if ($args['powod'] <= 0) {
  2187. $arg_errors ['powod'] = "Nie wybrano powodu rezygnacji!";
  2188. }
  2189. // add rezygnacja z umowy
  2190. if (1 == V::get('contact_bok_rozwiazanie_umowy_save', 0, $_POST, 'int')) {
  2191. if (!empty($arg_errors)) {
  2192. echo '<p style="color:red">' . "W formularzy wystąpiły błędy:";
  2193. foreach ($arg_errors as $k_field => $v_err) {
  2194. echo '<br />' . $v_err;
  2195. }
  2196. echo '</p>';
  2197. } else {
  2198. $msg_log = array();
  2199. $ret = WindykacjaStatsHelper::update_bok_rozwiazanie_umowy( $user, $args['id_proj'], $args['nr_umowy'], $args['powod'], $arg_values['powod'][ $args['powod'] ], $args['temin_odlaczenia'], $msg_log );
  2200. if ($ret) {
  2201. echo '<p style="color:green">' . "Dane zapisano pomyślnie" . '</p>';
  2202. if (!empty($msg_log)) {
  2203. echo '<p style="color:silver">' . implode('<br />', $msg_log) . '</p>';
  2204. }
  2205. $ico_print = '<img src="icon/print.gif" height="16" />';
  2206. echo '<a href="'."?MENU_INIT=USERS2_WINDYKACJA_STATUS&q=".V::get('q','', $_REQUEST)."&task="."bok_rozwiazanie_umowy_print"."&user_id=".$user->ID."&id_koresp=".$ret.'">' . $ico_print . " rozwiązanie umowy".'</a>';
  2207. return;
  2208. } else {
  2209. echo '<p style="color:red">' . "Wystąpił błąd podczas zapisu danych" . '</p>';
  2210. if (!empty($msg_log)) {
  2211. echo '<p style="color:silver">' . implode('<br />', $msg_log) . '</p>';
  2212. }
  2213. }
  2214. }
  2215. }
  2216. echo'<form action="" method="post" onsubmit="' . "return frm_bok_rozwiazanie_umowy(this);" . '">';
  2217. echo'<input type="hidden" name="'."contact_bok_rozwiazanie_umowy_save".'" value="'."1".'" />';
  2218. echo '<b>' . "Rozwiązanie umowy abonenckiej o świadczenie usług telekomunikacyjnych" . '</b>';
  2219. echo '<br />' . "ID projektu: ";
  2220. echo '<input type="text" name="'."id_proj".'" value="' . $args['id_proj'] . '" class="i" />';
  2221. echo '<br />' . "Nr umowy: ";
  2222. foreach ($arg_values['nr_umowy'] as $k_id => $v_label) {
  2223. $sel = ($k_id == $args['nr_umowy'])? ' checked="checked"' : '';
  2224. echo '<br />' . "&nbsp;&nbsp;&nbsp;&nbsp;" . '<input type="radio" name="'."nr_umowy".'" value="' . $k_id . '" class="i" ' . $sel . ' />' . " " . $v_label;
  2225. }
  2226. echo '<br />' . "Termin odłączenia: ";
  2227. echo '<input type="text" name="'."temin_odlaczenia".'" value="' . $args['temin_odlaczenia']. '" class="i" />';
  2228. echo '<br />' . "Powód rezygnacji z usług: ";
  2229. foreach ($arg_values['powod'] as $k_id => $v_label) {
  2230. $sel = ($k_id == $args['powod'])? ' checked="checked"' : '';
  2231. echo '<br />' . "&nbsp;&nbsp;&nbsp;&nbsp;" . '<input type="radio" name="'."powod".'" value="' . $k_id . '" class="i" ' . $sel . ' />' . " " . $v_label;
  2232. }
  2233. echo '<br />' . '<input type="submit" value="'."zapisz".'" />';
  2234. echo'</form>';
  2235. }
  2236. }
  2237. class BillingDocs {
  2238. var $_docs;
  2239. var $_saldo;
  2240. function __construct() {
  2241. $this->_docs = array();
  2242. $this->_saldo = 0;
  2243. }
  2244. function add_bill_doc( $data, $type, $h ) {
  2245. $bill_doc = new BillingDoc($type, $h);
  2246. $this->_docs[ $data ] []= $bill_doc;
  2247. if ($data <= date("Y-m-d")) {
  2248. $this->_saldo += $bill_doc->get_saldo();
  2249. }
  2250. }
  2251. function add_event( $data, $type, $h ) {
  2252. $event = new EventDoc($type, $h);
  2253. $this->_docs[ $data ] []= $event;
  2254. }
  2255. function get_saldo() {
  2256. if (round($this->_saldo, 2) === 0.0) {// float point bug round('-6.821210263297E-13', 2) = -0
  2257. $this->_saldo = 0.0;
  2258. }
  2259. return round($this->_saldo, 2);
  2260. }
  2261. function &get_docs() {
  2262. return $this->_docs;
  2263. }
  2264. function sort_docs() {
  2265. ksort($this->_docs);
  2266. }
  2267. function &get_unpaid_fvat() {
  2268. $today_date = date("Y-m-d");
  2269. $fvat_arr = array();
  2270. $saldo_curr = $this->get_saldo();
  2271. if ($saldo_curr >= 0) {
  2272. return $fvat_arr;
  2273. }
  2274. $break = false;
  2275. $saldo_dates_keys = array_keys($this->_docs);
  2276. $saldo_dates_keys = array_reverse($saldo_dates_keys);
  2277. foreach ($saldo_dates_keys as $k_data) {
  2278. if ($k_data > $today_date) continue;
  2279. $v_saldo_arr = $this->_docs[ $k_data ];
  2280. foreach ($v_saldo_arr as $k_ind => $v_doc) {
  2281. if ($v_doc->get_type() == 'FVAT') {
  2282. $h = $v_doc->get_data();
  2283. $h['WINIEN_POZOSTALO'] = round($h['WINIEN'], 2);
  2284. $saldo_curr += round($h['WINIEN'], 2);
  2285. if ($saldo_curr >= 0) {
  2286. $h['WINIEN_POZOSTALO'] -= $saldo_curr;
  2287. $break = true;
  2288. }
  2289. $fvat_arr []= $h;
  2290. }
  2291. if ($break) break;
  2292. }
  2293. if ($break) break;
  2294. }
  2295. return $fvat_arr;
  2296. }
  2297. function get_last_pay_doc() {
  2298. $last_pay_doc = null;
  2299. $today_date = date("Y-m-d");
  2300. $break = false;
  2301. foreach ($this->_docs as $k_data => $v_saldo_arr) {
  2302. if ($k_data > $today_date) continue;
  2303. foreach ($v_saldo_arr as $k_ind => $v_doc) {
  2304. if (in_array($v_doc->get_type(), array('WB_MASS','KP'))) {
  2305. $last_pay_doc = $v_doc;
  2306. break;
  2307. }
  2308. }
  2309. if ($break) break;
  2310. }
  2311. return $last_pay_doc;
  2312. }
  2313. }
  2314. class TimelineDoc {
  2315. var $_type;
  2316. var $_data;
  2317. var $_class;
  2318. function get_type() { return $this->_type; }
  2319. function get_data() { return $this->_data; }
  2320. function get_class() { return $this->_class; }
  2321. function get( $key ) {
  2322. return $this->_data[ $key ];
  2323. }
  2324. }
  2325. class EventDoc extends TimelineDoc {
  2326. function __construct( $type, &$data ) {
  2327. $this->_data = $data;
  2328. $this->_class = 'EVENT';
  2329. $this->_type = $type;
  2330. }
  2331. }
  2332. class BillingDoc extends TimelineDoc {
  2333. function __construct( $type, &$data ) {
  2334. $this->_data = $data;
  2335. $this->_class = 'BILLING';
  2336. $this->_convert_type( $type );
  2337. $this->_count_saldo();
  2338. }
  2339. function get_saldo() { return $this->_saldo; }
  2340. function get( $key ) {
  2341. return $this->_data[ $key ];
  2342. }
  2343. function _convert_type( $type ) {
  2344. $this->_type = $type;
  2345. switch ($this->_type) {
  2346. case 'FVAT':
  2347. $this->_data['nr'] = $this->_data['ID_BILLING_NUMBERS'];
  2348. $this->_data['WINIEN'] = $this->_data['WARTOSC'];
  2349. $this->_data['MA'] = 0;
  2350. break;
  2351. case 'KP':
  2352. case 'KW':
  2353. case 'WB':
  2354. case 'WB_MASS':
  2355. case 'KORV':
  2356. $this->_data['nr'] = $this->_data['NUMBER'];
  2357. break;
  2358. default:
  2359. }
  2360. }
  2361. function _count_saldo() {
  2362. $this->_saldo = 0;
  2363. switch ($this->_type) {
  2364. case 'FVAT':
  2365. $this->_saldo -= round($this->_data['WARTOSC'], 2);
  2366. break;
  2367. case 'KORV':
  2368. $this->_saldo -= round($this->_data['MA'], 2);
  2369. break;
  2370. case 'KP':
  2371. case 'KW':
  2372. case 'WB':
  2373. case 'WB_MASS':
  2374. $this->_saldo += round($this->_data['MA'], 2);
  2375. $this->_saldo -= round($this->_data['WINIEN'], 2);
  2376. break;
  2377. default:
  2378. }
  2379. }
  2380. }
  2381. class WindykacjaStatsHelper {
  2382. // TODO: `A_RECORD_UPDATE_DATE` aktualizowane tylko wraz ze statusem
  2383. // TODO: statusy:
  2384. // 1. Automatyczne wysłanie powiadomień do Abonentów o niezapłaconych fakturach drogą e-mailową
  2385. // 5 dni roboczych po 10-go na okolo 5 dni przed blokadami
  2386. // - blokada: ??? dni po ostatniej dacie platnosci - odczytac czy zablokowany z l2?
  2387. // - 1 list - wezwanie - jesli min. 2 faktury - czyli 2 m-ce od 1 daty platnosci
  2388. // - 2 list - wezwanie ostateczne - min. 300 zł
  2389. function get_filter_selected() {
  2390. $filter_selected = V::get('_f', '', $_GET);
  2391. $filter_arr = self::get_filters();
  2392. $filter_selected = (array_key_exists($filter_selected, $filter_arr))? $filter_selected : '';
  2393. return $filter_selected;
  2394. }
  2395. function &get_filters() {
  2396. $filter_arr ['stan_zero'] = array("stan zerowy");
  2397. $filter_arr ['10-ego'] = array("termin płatności faktur, saldo na -", 'desc'=>array("10-ego", "10-ego każdego miesiąca - termin płatnosci faktur oraz saldo na minusie"));
  2398. $filter_arr ['WAITING'] = array("termin płatności faktur", 'desc'=>array("10-ego", "10-ego każdego miesiąca - termin płatnosci faktur"));// z regulaminu
  2399. $filter_arr ['15'] = array("mail ponaglenie", 'desc'=>array("10-ego + 5", "10-ego + 5 dni roboczych"));
  2400. $filter_arr ['blokada'] = array("blokada", 'desc'=>array("pn, wt, śr około 25", "najbliższy pn, wt, śr do 25"));// najbliższy pn, wt, śr do 25-ego danego miesiąca
  2401. $filter_arr ['tel1'] = array("kontakt tel.", 'desc'=>array("", "Ostatni kontakt tel. ponad 3 m-ce temu"));
  2402. $filter_arr ['bad_address'] = array("błędny adres");
  2403. $filter_arr ['wezwanie1'] = array("wezwanie do zapłaty", 'desc'=>array("2 x FVat", "2 faktury"));
  2404. $filter_arr ['waiting-wezwanie2'] = array("oczekiwanie na uzbieranie 300 zł (firmy 500 zł)");
  2405. $filter_arr ['wezwanie2'] = array("ostateczne wezwanie do zapłaty, rozwiązanie umowy", 'desc'=>array("wezwanie + 14, 300zł", "wezwanie + 14 dni, min. 300zł (firmy 500zł)"));
  2406. $filter_arr ['waiting-krd'] = array("min. 60 dni od ostatecznego wezwania");
  2407. $filter_arr ['krd'] = array("do przekazania do KRD", 'desc'=>array("wezwanie ost. + 60", "wezwanie ost. + 60 dni"));
  2408. $filter_arr ['waiting-sad'] = array("przekazano do KRD");
  2409. $filter_arr ['sad'] = array("przekazanie sprawy do sądu");// "krd + 14 dni"
  2410. $filter_arr ['3 m-ce przed'] = array("3 m-ce przed przedawnieniem");// 3 m-ce przed przedawnieniem
  2411. $filter_arr ['po-terminie'] = array("po terminie");// 3 lata po dacie platnosci faktur
  2412. $filter_arr ['has_nr_sad'] = array("nr sprawy sąd");
  2413. $filter_arr ['has_nr_komornik'] = array("nr sprawy komornik");
  2414. $filter_arr ['has_ustalenia'] = array("ustalenia z klientem");
  2415. $filter_arr ['sad_and_komornik'] = array("sąd z komornik");
  2416. $filter_arr ['sad_bez_komornik'] = array("sąd bez komornik");
  2417. return $filter_arr;
  2418. }
  2419. function &get_by_user( &$user ) {
  2420. $sql = "select * from `USERS2_WINDYKACJA_STATUS` as w where w.`ID_BILLING_USERS`='" . $user->ID . "' ";
  2421. $res = DB::query( $sql );
  2422. $ret = DB::fetch( $res );
  2423. return $ret;
  2424. }
  2425. /**
  2426. * Auto update user stats.
  2427. *
  2428. * @returns boolean - status changed or not
  2429. * @param $user - object return from function WindykacjaStatsModel::get_user_by_id
  2430. * @param $billing_docs - user billing docs
  2431. *
  2432. * @used in task_update_stats - for all users
  2433. * @used in WindykacjaView::user_historia_platnosci after view billing docs
  2434. *
  2435. * save HIST at status change to WAITING
  2436. */
  2437. function update_stats( &$user, &$billing_docs ) {
  2438. $data_arr = array();
  2439. if ($user->A_STATUS_UPDATE_DATE >= date("Y-m-d")) {
  2440. return;
  2441. }
  2442. $saldo = $billing_docs->get_saldo();
  2443. $data_arr["A_STATUS_UPDATE_DATE"] = date("Y-m-d");
  2444. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2445. $data_arr["A_RECORD_UPDATE_AUTHOR"] = "stat-update";
  2446. // set default values
  2447. //$data_arr["A_STATUS"] = "WAITING";
  2448. //$data_arr["PAY_FVAT"] = 0;
  2449. //$data_arr["PAY_DATE"] = "0000-00-00";
  2450. // update values
  2451. {// LAST_PAY_DATE
  2452. $last_pay_doc = $billing_docs->get_last_pay_doc();
  2453. if ($last_pay_doc) {
  2454. $last_pay_doc = $last_pay_doc->get_data();
  2455. $data_arr["LAST_PAY_DATE"] = $last_pay_doc['BILL_DATE'];
  2456. }
  2457. }
  2458. $data_arr["PAY_SALDO"] = $saldo;
  2459. $data_arr["PAY_FVAT"] = 0;
  2460. if ($saldo <= 0) {
  2461. $fvat_arr = $billing_docs->get_unpaid_fvat();
  2462. $data_arr["PAY_FVAT"] = count($fvat_arr);
  2463. if (count($fvat_arr) > 0) {
  2464. foreach ($fvat_arr as $v_fvat) {
  2465. if (!isset($data_arr["PAY_DATE"]) || $v_fvat['PAYMENT_TERM'] > $data_arr["PAY_DATE"]) {
  2466. $data_arr["PAY_DATE"] = $v_fvat['PAYMENT_TERM'];
  2467. }
  2468. }
  2469. }
  2470. }
  2471. // zmiana statusu na kolejny wg. salda
  2472. switch ($user->A_STATUS) {
  2473. case 'WAITING':// auto
  2474. if ($user->wezwanie1_DATE == '0000-00-00') {
  2475. if ($saldo < 0) {
  2476. $fvat_arr = $billing_docs->get_unpaid_fvat();
  2477. if (count($fvat_arr) > 1) {
  2478. $data_arr["A_STATUS"] = "wezwanie1";
  2479. }
  2480. }
  2481. }
  2482. else if ($user->wezwanie2_DATE == '0000-00-00') {
  2483. $data_arr["A_STATUS"] = "waiting-wezwanie2";
  2484. }
  2485. else {
  2486. $data_arr["A_STATUS"] = "wezwanie2";
  2487. }
  2488. break;
  2489. case 'wezwanie1':// wymaga `PAY_TERM`, `wezwanie1_DATE`, `ID_KORESP`
  2490. break;
  2491. case 'waiting-wezwanie2':// auto -> wezwanie2
  2492. if ($user->wezwanie2_DATE == '0000-00-00') {
  2493. if ($saldo <= -300) {// TODO: data od pierwszego wezwania
  2494. $data_arr["A_STATUS"] = "wezwanie2";
  2495. }
  2496. }
  2497. break;
  2498. case 'wezwanie2':// wymaga `PAY_TERM`, `wezwanie2_DATE`, `ID_KORESP`
  2499. break;
  2500. case 'waiting-krd':// auto -> krd jesli minelo 60 dni od wystawienia wezwanie2
  2501. if ($user->wezwanie2_DATE != '0000-00-00') {
  2502. $wzw2 = new stdClass();
  2503. $wzw2->Y = intval(substr($user->wezwanie2_DATE, 0, 4));
  2504. $wzw2->m = intval(substr($user->wezwanie2_DATE, 5, 2));
  2505. $wzw2->d = intval(substr($user->wezwanie2_DATE, 8, 2));
  2506. $wzw2->plus_60 = date("Y-m-d", mktime(0,0,0, $wzw2->m, $wzw2->d + 60, $wzw2->Y));
  2507. if ($wzw2->plus_60 < date("Y-m-d")) {
  2508. $data_arr["A_STATUS"] = "krd";
  2509. }
  2510. }
  2511. break;
  2512. default:
  2513. }
  2514. // zmiana statusu na czysty - WAITING
  2515. if ($saldo >= 0 || $data_arr["PAY_FVAT"] < 2) {
  2516. $data_arr["A_STATUS"] = "WAITING";
  2517. // TODO: wyczyszczenie pol
  2518. $data_arr["wezwanie2_DATE"] = '0000-00-00';
  2519. $data_arr["wezwanie1_DATE"] = '0000-00-00';
  2520. //$data_arr["PAY_DATE"] = '0000-00-00';// TODO: ?
  2521. }
  2522. $sql_arr = array();
  2523. foreach ($data_arr as $k => $v) {
  2524. $sql_arr []= "`" . $k . "`='" . $v . "'";
  2525. }
  2526. $sql = "update `USERS2_WINDYKACJA_STATUS` set " . implode(",", $sql_arr) . " where `ID`='" . $user->WINDYKACJA_ID . "' limit 1 ; ";
  2527. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">';print_r($sql);echo'</pre>';
  2528. DB::query( $sql );
  2529. // update HIST - tylko zmiana na WAITING - powrót do oczekujących
  2530. if (isset($data_arr["A_STATUS"]) && $data_arr["A_STATUS"] == "WAITING" && $user->A_STATUS != "WAITING") {
  2531. //if (DB::affected()) {
  2532. $sql_arr = array();
  2533. foreach ($data_arr as $k => $v) {
  2534. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2535. }
  2536. $sql_arr ["`ID_USERS2`"] = "'" . $user->WINDYKACJA_ID . "'";
  2537. $sql = "insert into `USERS2_WINDYKACJA_STATUS_HIST`(" . implode(",", array_keys($sql_arr)) . ") values(" . implode(",", array_values($sql_arr)) . ");";
  2538. DB::query( $sql );
  2539. //}
  2540. }
  2541. }
  2542. function &get_phone_status_array( &$user ) {
  2543. $ret = array();
  2544. $status_info = self::get_phone_status_info( $user );
  2545. foreach ($status_info as $k => $v) {
  2546. $ret[ $k ] = $v['label'];
  2547. }//end foreach
  2548. return $ret;
  2549. }
  2550. /**
  2551. * @param $user
  2552. *
  2553. * @returns array of 'label', 'date' -> nowy PAY_TERM ustalony wg. aktualnego stanu
  2554. */
  2555. function &get_phone_status_info( &$user ) {
  2556. $ret = array();
  2557. $ret['nie_zaplaci'] = array('label'=>"nie zapłaci", 'date'=>'');
  2558. $today = date("Y-m-d");
  2559. $date = date("Y-m-d");
  2560. {// PAY_TERM jesli jest ustalony np. z wewaznie1 lub wezwanie2
  2561. if ($user->PAY_TERM != '0000-00-00') {
  2562. if ($user->PAY_TERM > $today) {
  2563. // jest już ustalona data platnosci na przyszłość
  2564. $date = $user->PAY_TERM;
  2565. }
  2566. }
  2567. }
  2568. if ($date > $today) {// data platnosci w przyszlosci -> ok
  2569. {// zapłaci w terminie today +14 dni lub PAY_TERM jesli jest ustalony np. z wewaznie1 lub wezwanie2
  2570. $ret['zaplaci_w_terminie'] = array('label'=>"zapłaci w terminie", 'date'=>$date);
  2571. }
  2572. }
  2573. else {// data platnosci w przeszlosci - przeterminowana -> ustalic nowa (+14,+1mc,+2mc,+3mc)
  2574. {// zapłaci w terminie today +14 dni lub PAY_TERM jesli jest ustalony np. z wewaznie1 lub wezwanie2
  2575. $date = date("Y-m-d", mktime(0,0,0,date('m'), date('d') + 14, date('Y')));
  2576. $ret['zaplaci_w_terminie'] = array('label'=>"zapłaci w terminie", 'date'=>$date);
  2577. }
  2578. {// zaplaci za 1-mc pozniej
  2579. $date = date("Y-m-d", mktime(0,0,0,date('m') + 1, date('d'), date('Y')));
  2580. $ret['zaplaci_za_1mc'] = array('label'=>"zapłaci miesiąc później", 'date'=>$date);
  2581. }
  2582. {// zaplaci za 2-mce pozniej
  2583. $date = date("Y-m-d", mktime(0,0,0,date('m') + 2, date('d'), date('Y')));
  2584. $ret['zaplaci_za_2mc'] = array('label'=>"zapłaci 2 miesiące później", 'date'=>$date);
  2585. }
  2586. {// zaplaci za 3-mce pozniej
  2587. $date = date("Y-m-d", mktime(0,0,0,date('m') + 3, date('d'), date('Y')));
  2588. $ret['zaplaci_za_3mc'] = array('label'=>"zapłaci 3 miesiące później", 'date'=>$date);
  2589. }
  2590. }
  2591. $ret['nie_odbiera'] = array('label'=>"nie obiera lub wyłączony telefon", 'date'=>'');
  2592. $ret['zly_numer'] = array('label'=>"zły numer telefonu", 'date'=>'');
  2593. return $ret;
  2594. }
  2595. /**
  2596. * Update user phone status.
  2597. *
  2598. * @returns boolean - status changed or not
  2599. * @param $user - object return from function WindykacjaStatsModel::get_user_by_id
  2600. * @param $phone_status - phone status
  2601. *
  2602. */
  2603. function update_phone_status( &$user, $phone_status ) {
  2604. $data_arr = array();
  2605. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2606. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2607. $data_arr["LAST_PHONE_STATUS"] = $phone_status;
  2608. $data_arr["LAST_PHONE_STATUS_DATE"] = date("Y-m-d");
  2609. $status_info = self::get_phone_status_info( $user );
  2610. if (array_key_exists($phone_status, $status_info)) {
  2611. $date = V::get('date', '', $status_info[$phone_status]);
  2612. if ($date != '' && $date != '0000-00-00') {
  2613. $data_arr["PAY_TERM"] = $date;
  2614. }
  2615. }
  2616. $sql_arr = array();
  2617. foreach ($data_arr as $k => $v) {
  2618. $sql_arr []= "`" . $k . "`='" . $v . "'";
  2619. }//end foreach
  2620. $sql = "update `USERS2_WINDYKACJA_STATUS` set " . implode(",", $sql_arr) . " where `ID`='" . $user->WINDYKACJA_ID . "' limit 1 ; ";
  2621. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">';print_r($sql);echo'</pre>';
  2622. DB::query( $sql );
  2623. // update HIST
  2624. //if (DB::affected()) {
  2625. $sql_arr = array();
  2626. foreach ($data_arr as $k => $v) {
  2627. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2628. }//end foreach
  2629. $sql_arr ["`ID_USERS2`"] = "'" . $user->WINDYKACJA_ID . "'";
  2630. $sql = "insert into `USERS2_WINDYKACJA_STATUS_HIST`(" . implode(",", array_keys($sql_arr)) . ") values(" . implode(",", array_values($sql_arr)) . ");";
  2631. DB::query( $sql );
  2632. //}
  2633. return true;
  2634. }
  2635. function update_old_id_koresp( &$user, $id_koresp, $koresp_type ) {
  2636. $db = DB::getDB();
  2637. $koresp = DB::get_by_id('IN7_DZIENNIK_KORESP', $id_koresp);
  2638. if (!$koresp) {
  2639. return false;
  2640. }
  2641. // check if ID koresp already exists in HIST table!
  2642. $sql = "select wh.`ID`,wh.``,wh.`` from `USERS2_WINDYKACJA_STATUS_HIST` as wh where ";
  2643. $data_arr = array();
  2644. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2645. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2646. $data_arr["ID_USERS2"] = $user->WINDYKACJA_ID;
  2647. $data_arr["ID_KORESP"] = $id_koresp;
  2648. //$data_arr["A_STATUS_UPDATE_DATE"] = $koresp->K_DATA_OTRZYMANEJ_KORESP;// data utworzenia
  2649. $data_arr["A_STATUS_UPDATE_DATE"] = $koresp->K_DATA_OTRZYM_KORESP;// data wyslania
  2650. // $koresp_type ?
  2651. // update HIST
  2652. $sql_arr = array();
  2653. foreach ($data_arr as $k => $v) {
  2654. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2655. }//end foreach
  2656. $sql = "insert into `USERS2_WINDYKACJA_STATUS_HIST`(" . implode(",", array_keys($sql_arr)) . ") values(" . implode(",", array_values($sql_arr)) . ");";
  2657. $db->query($sql);
  2658. return true;
  2659. }
  2660. /**
  2661. * @returns int - ID Koresp or null if error
  2662. */
  2663. function update_bok_rozwiazanie_umowy( &$user, $id_proj, $nr_umowy, $powod, $powod_desc, $termin_odlaczenia, &$msg_log ) {
  2664. $data_arr = array();
  2665. if ($id_proj > 0 && $nr_umowy > 0 && $powod != '') {
  2666. $new_id_deals = WindykacjaStatsModel::create_deals_rozwiazanie($user->ID, $nr_umowy, $termin_odlaczenia, $powod_desc);
  2667. if (!$new_id_deals) {
  2668. $msg_log []= "Nie udało się utworzyć rekordu w DEALS_TABLE";
  2669. return null;
  2670. }
  2671. $msg_log []= "Utworzonno rekord w DEALS_TABLE ID={$new_id_deals}";
  2672. $new_id_koresp = WindykacjaStatsModel::create_koresp($user, 'rozwiazanie umowy', $id_proj, array('nr_umowy'=>$nr_umowy, 'powod'=>$powod, 'powod_desc'=>$powod_desc));
  2673. if (!$new_id_koresp) {
  2674. $msg_log []= "Nie udało się utworzyć rekordu KORESP";
  2675. return null;
  2676. }
  2677. $msg_log []= "Utworzonno rekord KORESP ID={$new_id_koresp}";
  2678. $data_arr["ID_KORESP"] = $new_id_koresp;
  2679. } else {
  2680. return null;
  2681. }
  2682. $data_arr["params"] = "rozwiazanie umowy,{$nr_umowy},{$powod},{$termin_odlaczenia},{$new_id_deals}";
  2683. $data_arr["A_STATUS_UPDATE_DATE"] = date("Y-m-d");// zawsze podana jesli jest zmiana A_STATUS
  2684. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2685. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2686. $sql_arr = array();
  2687. foreach ($data_arr as $k => $v) {
  2688. $sql_arr []= "`" . $k . "`='" . $v . "'";
  2689. }
  2690. $sql = "update `USERS2_WINDYKACJA_STATUS` set " . implode(",", $sql_arr) . " where `ID`='" . $user->WINDYKACJA_ID . "' limit 1 ";
  2691. DB::query( $sql );
  2692. //if (DB::affected()) {
  2693. // update $user data
  2694. foreach ($data_arr as $k => $v) {
  2695. $user->$k = $v;
  2696. }
  2697. $sql_arr = array();
  2698. foreach ($data_arr as $k => $v) {
  2699. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2700. }
  2701. $sql_arr ["`ID_USERS2`"] = "'" . $user->WINDYKACJA_ID . "'";
  2702. $sql = "insert into `USERS2_WINDYKACJA_STATUS_HIST`(" . implode(",", array_keys($sql_arr)) . ") values(" . implode(",", array_values($sql_arr)) . ");";
  2703. DB::query( $sql );
  2704. //}
  2705. return $new_id_koresp;
  2706. }
  2707. function update_users_table() {
  2708. if (!isset($_SESSION['USERS2_WINDYKACJA_PANEL'])) $_SESSION['USERS2_WINDYKACJA_PANEL'] = array();
  2709. $_SESSION['USERS2_WINDYKACJA_PANEL']['_initialized'] = 0;// always actualize
  2710. if (0 == V::get('_initialized', 0, $_SESSION['USERS2_WINDYKACJA_PANEL'], 'int')) {
  2711. $sql = "insert ignore into `USERS2_WINDYKACJA_STATUS` (`ID_BILLING_USERS`, `A_RECORD_CREATE_DATE`, `A_RECORD_CREATE_AUTHOR`)
  2712. select `id_users`, '" . date("Y-m-d-H:i") . "', 'sync-users' from `BILLING_USERS_ADD`
  2713. ";
  2714. $res = DB::query( $sql );
  2715. $_SESSION['USERS2_WINDYKACJA_PANEL']['_initialized'] = 1;
  2716. }
  2717. }
  2718. function _to_update_where() {
  2719. $sql_where = "";
  2720. $sql_where_and_arr = array();
  2721. //$sql_where_and_arr []= "w.`A_STATUS`='WAITING'";
  2722. $sql_where_and_arr []= "w.`A_STATUS_UPDATE_DATE`<CURDATE()";
  2723. $sql_where = implode(" and ", $sql_where_and_arr);
  2724. return $sql_where;
  2725. }
  2726. function get_to_update_total() {
  2727. $ret = array();
  2728. $sql_where = self::_to_update_where();
  2729. $sql = "select count(1) as cnt
  2730. from `USERS2_WINDYKACJA_STATUS` as w
  2731. where $sql_where
  2732. ";
  2733. $res = DB::query( $sql );
  2734. while ($r = DB::fetch( $res )) {
  2735. $ret = $r->cnt;
  2736. }
  2737. return $ret;
  2738. }
  2739. function &get_to_update_list( $limit ) {
  2740. $ret = array();
  2741. $sql_where = self::_to_update_where();
  2742. $sql_limit = ($limit > 0)? "limit ".$limit : "";
  2743. $sql = "select w.*
  2744. from `USERS2_WINDYKACJA_STATUS` as w
  2745. where $sql_where
  2746. order by ID desc
  2747. $sql_limit
  2748. ";
  2749. $res = DB::query( $sql );
  2750. while ($r = DB::fetch( $res )) {
  2751. $ret []= $r;
  2752. }
  2753. return $ret;
  2754. }
  2755. /**
  2756. * @returns boolean - status changed or not
  2757. * @param $user - object return from function WindykacjaStatsModel::get_user_by_id
  2758. * @param $data - array of new user data
  2759. * 1. wysłanie 1 wezwania do zapłaty ($user->A_STATUS='wezwanie1'; `PAY_TERM`, `wezwanie1_DATE`, `ID_PROJ`)
  2760. * 2. wysłanie 2 wezwania do zapłaty ($user->A_STATUS='wezwanie2'; `PAY_TERM`, `wezwanie2_DATE`, `ID_KORESP`)
  2761. * 3. klient spłacił wszystkie zobowiązania (`PAY_SALDO`>=0)
  2762. * TODO: 4. bledny adres klienta - ponowne wyslanie wezwania - niezaleznie od statusu?
  2763. *
  2764. * if $user->A_STATUS == 'wezwanie1' @param $data:
  2765. * $data['wezwanie1_DATE'] - user data
  2766. * $data['PAY_TERM'] - user data
  2767. * $data['ID_PROJ'] - do WindykacjaStatsModel::create_koresp
  2768. */
  2769. function &update_user( $user, $data ) {
  2770. if (empty($data)) {
  2771. return $user;
  2772. }
  2773. $data_arr = array();
  2774. // set up status by current status and $data
  2775. switch ($user->A_STATUS) {
  2776. case 'WAITING':// auto
  2777. break;
  2778. case 'wezwanie1':// wymaga `PAY_TERM`, `wezwanie1_DATE`, `ID_KORESP` - wysłanie wezwanie1 (z podaniem ID_KORESP, i PAY_TERM=NOW()+14dni)
  2779. // TODO: ID_KORESP z utworzonego rekordu KORESP (wymaga ID_PROJ)
  2780. if ("" != V::get('wezwanie1_DATE' ,'', $data) && "" != V::get('PAY_TERM' ,'', $data) && V::get('ID_PROJ' ,'', $data, 'int') > 0) {
  2781. $new_id_koresp = WindykacjaStatsModel::create_koresp($user, 'wezwanie1', V::get('ID_PROJ' ,'', $data, 'int'));
  2782. if (!$new_id_koresp) {
  2783. // TODO: revert changes - DB error
  2784. return $user;
  2785. }
  2786. $data_arr["ID_KORESP"] = $new_id_koresp;
  2787. $data_arr["A_STATUS"] = "waiting-wezwanie2";
  2788. $data_arr["wezwanie1_DATE"] = V::get('wezwanie1_DATE' ,'', $data);
  2789. $data_arr["PAY_TERM"] = V::get('PAY_TERM' ,'', $data);
  2790. unset($data['ID_PROJ']);// TODO: RM after mv $data to $data_arr
  2791. }
  2792. break;
  2793. case 'waiting-wezwanie2':// auto
  2794. break;
  2795. case 'wezwanie2':// wymaga `PAY_TERM`, `wezwanie2_DATE`, `ID_KORESP` - wysłanie wezwanie2 (z podaniem ID_KORESP, i PAY_TERM=NOW()+14dni)
  2796. if ("" != V::get('wezwanie2_DATE' ,'', $data) && "" != V::get('PAY_TERM' ,'', $data) && V::get('ID_PROJ' ,'', $data, 'int') > 0) {
  2797. $new_id_koresp = WindykacjaStatsModel::create_koresp($user, 'wezwanie2', V::get('ID_PROJ' ,'', $data, 'int'));
  2798. if (!$new_id_koresp) {
  2799. // TODO: revert changes - DB error
  2800. return $user;
  2801. }
  2802. $data_arr["ID_KORESP"] = $new_id_koresp;
  2803. $data_arr["A_STATUS"] = "waiting-krd";
  2804. $data_arr["wezwanie2_DATE"] = V::get('wezwanie2_DATE' ,'', $data);
  2805. $data_arr["PAY_TERM"] = V::get('PAY_TERM' ,'', $data);
  2806. }
  2807. break;
  2808. default:
  2809. }
  2810. // if status not set, check id user saldo is ok
  2811. if (!isset($data_arr["A_STATUS"])) {
  2812. if (isset($data['PAY_SALDO']) && $data['PAY_SALDO'] >= 0) {
  2813. $data_arr["A_STATUS"] = "WAITING";
  2814. }
  2815. }
  2816. // error jesli nie ustalono statusu
  2817. if (!isset($data_arr["A_STATUS"])) {
  2818. return false;
  2819. }
  2820. $data_arr["A_STATUS_UPDATE_DATE"] = date("Y-m-d");// zawsze podana jesli jest zmiana A_STATUS
  2821. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2822. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2823. $sql_arr = array();
  2824. foreach ($data_arr as $k => $v) {
  2825. $sql_arr []= "`" . $k . "`='" . $v . "'";
  2826. }
  2827. $sql = "update `USERS2_WINDYKACJA_STATUS` set " . implode(",", $sql_arr) . " where `ID`='" . $user->WINDYKACJA_ID . "' limit 1 ";
  2828. DB::query( $sql );
  2829. //if (DB::affected()) {
  2830. // update $user data
  2831. foreach ($data_arr as $k => $v) {
  2832. $user->$k = $v;
  2833. }
  2834. $sql_arr = array();
  2835. foreach ($data_arr as $k => $v) {
  2836. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2837. }
  2838. $sql_arr ["`ID_USERS2`"] = "'" . $user->WINDYKACJA_ID . "'";
  2839. $sql = "insert into `USERS2_WINDYKACJA_STATUS_HIST`(" . implode(",", array_keys($sql_arr)) . ") values(" . implode(",", array_values($sql_arr)) . ");";
  2840. DB::query( $sql );
  2841. //}
  2842. return true;
  2843. }
  2844. function bad_address_save($user, $id_koresp) {
  2845. $data_arr = array();
  2846. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2847. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2848. $data_arr["BAD_ADDRESS"] = 1;
  2849. $data_arr["ID_KORESP"] = $id_koresp;
  2850. return self::_sql_update($user, $data_arr);
  2851. }
  2852. function bad_address_confirm($user, $id_koresp) {
  2853. $data_arr = array();
  2854. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2855. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2856. $data_arr["BAD_ADDRESS"] = 0;
  2857. $data_arr["ID_KORESP"] = $id_koresp;
  2858. return self::_sql_update($user, $data_arr);
  2859. }
  2860. function _sql_update($user, $data_arr) {
  2861. // update values
  2862. $sql_arr = array();
  2863. foreach ($data_arr as $k => $v) {
  2864. $sql_arr []= "`{$k}`='{$v}'";
  2865. }
  2866. $sql = "update `USERS2_WINDYKACJA_STATUS` set " . implode(",", $sql_arr) . " where `ID`='{$user->WINDYKACJA_ID}' limit 1 ";
  2867. DB::query( $sql );
  2868. // update $user data
  2869. foreach ($data_arr as $k => $v) {
  2870. $user->$k = $v;
  2871. }
  2872. $sql_arr = array();
  2873. foreach ($data_arr as $k => $v) {
  2874. $sql_arr ["`{$k}`"] = "'{$v}'";
  2875. }
  2876. $sql_arr ["`ID_USERS2`"] = "'{$user->WINDYKACJA_ID}'";
  2877. $sql = "insert into `USERS2_WINDYKACJA_STATUS_HIST`(" . implode(",", array_keys($sql_arr)) . ") values(" . implode(",", array_values($sql_arr)) . ");";
  2878. DB::query( $sql );
  2879. return true;
  2880. }
  2881. function change_status_save($user, $new_status) {
  2882. $data_arr = array();
  2883. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2884. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2885. $data_arr["A_STATUS_UPDATE_DATE"] = date("Y-m-d");
  2886. $data_arr["A_STATUS"] = $new_status;
  2887. return self::_sql_update($user, $data_arr);
  2888. }
  2889. function nr_sprawy_krd_save($user, $nr_sprawy_krd) {
  2890. $data_arr = array();
  2891. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2892. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2893. $data_arr["NR_SPRAWY_KRD"] = $nr_sprawy_krd;
  2894. return self::_sql_update($user, $data_arr);
  2895. }
  2896. function nr_sprawy_sad_save($user, $nr_sprawy_sad) {
  2897. $data_arr = array();
  2898. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2899. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2900. $data_arr["NR_SPRAWY_SAD"] = $nr_sprawy_sad;
  2901. return self::_sql_update($user, $data_arr);
  2902. }
  2903. function nr_sprawy_komornik_save($user, $nr_sprawy_komornik) {
  2904. $data_arr = array();
  2905. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2906. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2907. $data_arr["NR_SPRAWY_KOMORNIK"] = $nr_sprawy_komornik;
  2908. return self::_sql_update($user, $data_arr);
  2909. }
  2910. function ustalenia_info_save($user, $ustalenia_date, $ustalenia_info) {
  2911. $data_arr = array();
  2912. $data_arr["A_RECORD_UPDATE_DATE"] = date("Y-m-d-H:i");
  2913. $data_arr["A_RECORD_UPDATE_AUTHOR"] = $_SESSION['ADM_ACCOUNT'];
  2914. $data_arr["L_APPOITMENT_DATE"] = $ustalenia_date;
  2915. $data_arr["L_APPOITMENT_INFO"] = $ustalenia_info;
  2916. $data_arr["L_APPOITMENT_USER"] = $_SESSION['ADM_ACCOUNT'];
  2917. if (empty($ustalenia_info) && (empty($ustalenia_date) || $ustalenia_date == '0000-00-00')) {
  2918. $data_arr["L_APPOITMENT_USER"] = '';
  2919. }
  2920. return self::_sql_update($user, $data_arr);
  2921. }
  2922. function &get_user_hist_events( &$user ) {
  2923. $db = DB::getDB();
  2924. $ret = array();
  2925. $sql = "select wh.*
  2926. from `USERS2_WINDYKACJA_STATUS_HIST` as wh
  2927. where wh.`ID_USERS2`='" . $user->WINDYKACJA_ID . "'
  2928. ";
  2929. $res = $db->query($sql);
  2930. while ($r = $db->fetch($res)) {
  2931. $ret []= $r;
  2932. }
  2933. return $ret;
  2934. }
  2935. function &get_user_hist_status_events( &$user ) {
  2936. $db = DB::getDB();
  2937. $ret = array();
  2938. $sql = "select wh.*, kor.`K_ZAWARTOS`
  2939. from `USERS2_WINDYKACJA_STATUS_HIST` as wh
  2940. left join `IN7_DZIENNIK_KORESP` as kor on(wh.`ID_KORESP`!='N/S;' and kor.`ID`=wh.`ID_KORESP`)
  2941. where wh.`ID_USERS2`='" . $user->WINDYKACJA_ID . "'
  2942. and wh.`A_STATUS_UPDATE_DATE`!='N/S;'
  2943. ";
  2944. $res = $db->query($sql);
  2945. while ($r = $db->fetch($res)) {
  2946. $ret []= $r;
  2947. }
  2948. return $ret;
  2949. }
  2950. function &get_user_hist_phone_events( &$user ) {
  2951. $ret = array();
  2952. $db = DB::getDB();
  2953. $sql = "select wh.*
  2954. from `USERS2_WINDYKACJA_STATUS_HIST` as wh
  2955. where wh.`ID_USERS2`='" . $user->WINDYKACJA_ID . "'
  2956. and wh.`LAST_PHONE_STATUS`!='N/S;'
  2957. ";
  2958. $res = $db->query($sql);
  2959. while ($r = $db->fetch($res)) {
  2960. $ret []= $r;
  2961. }
  2962. return $ret;
  2963. }
  2964. function &get_user_bad_address_events( &$user ) {
  2965. $ret = array();
  2966. $db = DB::getDB();
  2967. $sql = "select wh.*
  2968. from `USERS2_WINDYKACJA_STATUS_HIST` as wh
  2969. where wh.`ID_USERS2`='" . $user->WINDYKACJA_ID . "'
  2970. and wh.`BAD_ADDRESS`!='N/S;'
  2971. order by wh.`ID` ASC
  2972. ";
  2973. $res = $db->query($sql);
  2974. while ($r = $db->fetch($res)) {
  2975. $ret []= $r;
  2976. }
  2977. return $ret;
  2978. }
  2979. function &get_status_count() {
  2980. $ret = array();
  2981. $sql = " select w.`A_STATUS`, count(1) as cnt
  2982. , sum(IF(w.`PAY_SALDO`<0, w.`PAY_SALDO`, 0)) as suma_zaleglosci
  2983. from `USERS2_WINDYKACJA_STATUS` as w
  2984. group by w.`A_STATUS`
  2985. ";
  2986. $res = DB::query( $sql );
  2987. while ($r = DB::fetch( $res )) {
  2988. $ret[ $r->A_STATUS ] = $r;
  2989. }
  2990. // filter: 'po-terminie'
  2991. $sql = "select w.`A_STATUS`
  2992. , count(1) as cnt
  2993. , sum(IF(w.`PAY_SALDO`<0, w.`PAY_SALDO`, 0)) as suma_zaleglosci
  2994. from `USERS2_WINDYKACJA_STATUS` as w
  2995. where
  2996. w.`PAY_SALDO`<0
  2997. and w.`PAY_DATE`!='0000-00-00'
  2998. and w.`PAY_DATE`<DATE_SUB(NOW(), INTERVAL 36 MONTH)
  2999. ";
  3000. $res = DB::query( $sql );
  3001. if ($r = DB::fetch( $res )) {
  3002. $ret[ 'po-terminie' ] = $r;
  3003. }
  3004. // filter: '3 m-ce przed'
  3005. $sql = "select w.`A_STATUS`
  3006. , count(1) as cnt
  3007. , sum(IF(w.`PAY_SALDO`<0, w.`PAY_SALDO`, 0)) as suma_zaleglosci
  3008. from `USERS2_WINDYKACJA_STATUS` as w
  3009. where
  3010. w.`PAY_SALDO`<0
  3011. and w.`PAY_DATE`!='0000-00-00'
  3012. and w.`PAY_DATE`<DATE_SUB(NOW(), INTERVAL 33 MONTH)
  3013. and w.`PAY_DATE`>DATE_SUB(NOW(), INTERVAL 36 MONTH)
  3014. ";
  3015. $res = DB::query( $sql );
  3016. if ($r = DB::fetch( $res )) {
  3017. $ret[ '3 m-ce przed' ] = $r;
  3018. }
  3019. // filter: 'tel1'
  3020. $sql = "select w.`A_STATUS`
  3021. , count(1) as cnt
  3022. , sum(IF(w.`PAY_SALDO`<0, w.`PAY_SALDO`, 0)) as suma_zaleglosci
  3023. from `USERS2_WINDYKACJA_STATUS` as w
  3024. where
  3025. w.`PAY_SALDO`<0
  3026. and w.`A_STATUS` in('wezwanie1', 'waiting-wezwanie2', 'wezwanie2', 'waiting-krd')
  3027. and ( w.`LAST_PHONE_STATUS_DATE`='0000-00-00'
  3028. or w.`LAST_PHONE_STATUS_DATE`<DATE_SUB(NOW(), INTERVAL 3 MONTH) )
  3029. ";
  3030. $res = DB::query( $sql );
  3031. if ($r = DB::fetch( $res )) {
  3032. $ret[ 'tel1' ] = $r;
  3033. }
  3034. // filter: 'bad_address'
  3035. $sql = "select w.`A_STATUS`
  3036. , count(1) as cnt
  3037. , sum(IF(w.`PAY_SALDO`<0, w.`PAY_SALDO`, 0)) as suma_zaleglosci
  3038. from `USERS2_WINDYKACJA_STATUS` as w
  3039. where
  3040. w.`PAY_SALDO`<0
  3041. -- and w.`A_STATUS` in('wezwanie1', 'waiting-wezwanie2', 'wezwanie2', 'waiting-krd')
  3042. and w.`BAD_ADDRESS`>0
  3043. ";
  3044. $res = DB::query( $sql );
  3045. if ($r = DB::fetch( $res )) {
  3046. $ret[ 'bad_address' ] = $r;
  3047. }
  3048. // filter: 'stan_zero', '10-ego'
  3049. $sql = "select w.`A_STATUS`
  3050. , count(1) as cnt
  3051. , sum(IF(w.`PAY_SALDO`>=0, 1, 0)) as cnt_stan_zero
  3052. , sum(IF(w.`PAY_SALDO`<0, 1, 0)) as cnt_stan_minus
  3053. , sum(IF(w.`PAY_SALDO`<0, w.`PAY_SALDO`, 0)) as suma_zaleglosci
  3054. from `USERS2_WINDYKACJA_STATUS` as w
  3055. where
  3056. w.`A_STATUS`='WAITING'
  3057. ";
  3058. $res = DB::query( $sql );
  3059. if ($r = DB::fetch( $res )) {
  3060. $ret[ 'stan_zero' ] = (object)array('A_STATUS'=>'stan_zero', 'cnt'=>$r->cnt_stan_zero, 'suma_zaleglosci'=>0);
  3061. $ret[ '10-ego' ] = (object)array('A_STATUS'=>'10-ego', 'cnt'=>$r->cnt_stan_minus, 'suma_zaleglosci'=>$r->suma_zaleglosci);
  3062. }
  3063. // filter: 'has_nr_sad', 'has_nr_komornik', 'has_ustalenia'
  3064. $sql = "select w.`A_STATUS`
  3065. , count(1) as cnt
  3066. , sum(IF(w.`NR_SPRAWY_SAD`!='', 1, 0)) as cnt_sad
  3067. , sum(IF(w.`NR_SPRAWY_KOMORNIK`!='', 1, 0)) as cnt_komornik
  3068. , sum(IF(w.`L_APPOITMENT_INFO`!='', 1, 0)) as cnt_ustalenia
  3069. from `USERS2_WINDYKACJA_STATUS` as w
  3070. where
  3071. (w.`NR_SPRAWY_SAD`!=''
  3072. or w.`NR_SPRAWY_KOMORNIK`!=''
  3073. or w.`L_APPOITMENT_INFO`!=''
  3074. )
  3075. ";
  3076. $res = DB::query( $sql );
  3077. if ($r = DB::fetch( $res )) {
  3078. $ret[ 'has_nr_sad' ] = (object)array('A_STATUS'=>'has_nr_sad', 'cnt'=>$r->cnt_sad, 'suma_zaleglosci'=>null);
  3079. $ret[ 'has_nr_komornik' ] = (object)array('A_STATUS'=>'has_nr_komornik', 'cnt'=>$r->cnt_komornik, 'suma_zaleglosci'=>null);
  3080. $ret[ 'has_ustalenia' ] = (object)array('A_STATUS'=>'has_ustalenia', 'cnt'=>$r->cnt_ustalenia, 'suma_zaleglosci'=>null);
  3081. }
  3082. // filter: 'sad_and_komornik', 'sad_bez_komornik'
  3083. $sql = "select w.`A_STATUS`
  3084. , count(1) as cnt
  3085. , sum(IF(w.`NR_SPRAWY_KOMORNIK`!='', 1, 0)) as cnt_komornik
  3086. from `USERS2_WINDYKACJA_STATUS` as w
  3087. where
  3088. w.`A_STATUS`='sad'
  3089. ";
  3090. $res = DB::query( $sql );
  3091. if ($r = DB::fetch( $res )) {
  3092. $ret[ 'sad_and_komornik' ] = (object)array('A_STATUS'=>'sad_and_komornik', 'cnt'=>$r->cnt_komornik, 'suma_zaleglosci'=>null);
  3093. $ret[ 'sad_bez_komornik' ] = (object)array('A_STATUS'=>'sad_bez_komornik', 'cnt'=>($r->cnt - $r->cnt_komornik), 'suma_zaleglosci'=>null);
  3094. }
  3095. return $ret;
  3096. }
  3097. }
  3098. class WindykacjaStatsModel {
  3099. function _parse_query( $q ) {
  3100. $sql_where = '';
  3101. $sql_where_and_arr = array();
  3102. $filter_selected = WindykacjaStatsHelper::get_filter_selected();
  3103. if ($filter_selected) {
  3104. if ($filter_selected == 'po-terminie') {
  3105. $sql_where_and_arr []= "w.`PAY_SALDO`<0";
  3106. $sql_where_and_arr []= "w.`PAY_DATE`!='0000-00-00'";
  3107. $sql_where_and_arr []= "w.`PAY_DATE`<DATE_SUB(NOW(), INTERVAL 36 MONTH)";
  3108. }
  3109. else if ($filter_selected == '3 m-ce przed') {
  3110. $sql_where_and_arr []= "w.`PAY_SALDO`<0";
  3111. $sql_where_and_arr []= "w.`PAY_DATE`!='0000-00-00'";
  3112. $sql_where_and_arr []= "w.`PAY_DATE`<DATE_SUB(NOW(), INTERVAL 33 MONTH)";
  3113. $sql_where_and_arr []= "w.`PAY_DATE`>DATE_SUB(NOW(), INTERVAL 36 MONTH)";
  3114. }
  3115. else if ($filter_selected == 'tel1') {
  3116. $sql_where_and_arr []= "w.`PAY_SALDO`<0";
  3117. $sql_where_and_arr []= "w.`A_STATUS` in('wezwanie1', 'waiting-wezwanie2', 'wezwanie2', 'waiting-krd')";
  3118. $sql_where_and_arr []= "( w.`LAST_PHONE_STATUS_DATE`='0000-00-00'
  3119. or w.`LAST_PHONE_STATUS_DATE`<DATE_SUB(NOW(), INTERVAL 3 MONTH) )";
  3120. }
  3121. else if ($filter_selected == 'bad_address') {
  3122. $sql_where_and_arr []= "w.`BAD_ADDRESS`>0";
  3123. $sql_where_and_arr []= "w.`PAY_SALDO`<0";
  3124. }
  3125. else if ($filter_selected == 'stan_zero') {
  3126. $sql_where_and_arr []= "w.`A_STATUS`='WAITING'";
  3127. $sql_where_and_arr []= "w.`PAY_SALDO`>=0";
  3128. }
  3129. else if ($filter_selected == '10-ego') {
  3130. $sql_where_and_arr []= "w.`A_STATUS`='WAITING'";
  3131. $sql_where_and_arr []= "w.`PAY_SALDO`<0";
  3132. }
  3133. else if ($filter_selected == 'has_nr_sad') {
  3134. $sql_where_and_arr []= "w.`NR_SPRAWY_SAD`!=''";
  3135. }
  3136. else if ($filter_selected == 'has_nr_komornik') {
  3137. $sql_where_and_arr []= "w.`NR_SPRAWY_KOMORNIK`!=''";
  3138. }
  3139. else if ($filter_selected == 'has_ustalenia') {
  3140. $sql_where_and_arr []= "w.`L_APPOITMENT_INFO`!=''";
  3141. }
  3142. else if ($filter_selected == 'sad_and_komornik') {
  3143. $sql_where_and_arr []= "w.`A_STATUS`='sad' and w.`NR_SPRAWY_KOMORNIK`!=''";
  3144. }
  3145. else if ($filter_selected == 'sad_bez_komornik') {
  3146. $sql_where_and_arr []= "w.`A_STATUS`='sad' and w.`NR_SPRAWY_KOMORNIK`=''";
  3147. }
  3148. else {
  3149. $sql_where_and_arr []= "w.`A_STATUS`='" . $filter_selected . "'";
  3150. }
  3151. }
  3152. if (!empty($q)) {
  3153. $q = trim($q);
  3154. if (is_numeric($q)) {// billing number
  3155. $sql_where_and_arr []= "a.`id_users`='".DB::_($q)."'";
  3156. }
  3157. else {// string - name, second name
  3158. $q_arr_values = array();
  3159. $q_exp = explode(' ', $q);
  3160. foreach ($q_exp as $v_q) {
  3161. $v_q = trim($v_q);
  3162. if (strlen($v_q) > 2) {// min. 3 znaki
  3163. $q_arr_values []= strtolower($v_q);
  3164. }
  3165. }
  3166. foreach ($q_arr_values as $q_value) {
  3167. $sql_filter_q = array();
  3168. $q_arr = array();// uniq array
  3169. $q_arr_pl = array();// loop array
  3170. $pl_letters = array('ą', 'ć', 'ę', 'ł', 'ń', 'ó', 'ś', 'ź', 'ż');
  3171. $en_letters = array('a', 'c', 'e', 'l', 'n', 'o', 's', 'z', 'z');
  3172. $sql_filter_q []= "a.`P_NAME` like '".DB::_($q_value)."%'";
  3173. $sql_filter_q []= "a.`P_NAME_SECOND` like '".DB::_($q_value)."%'";
  3174. $q_value_clean_en = str_replace($pl_letters, $en_letters, $q_value);
  3175. $q_value_clean_pl = str_replace($en_letters, $pl_letters, $q_value_clean_en);
  3176. $q_value_clean_pr = str_replace($en_letters, '_', $q_value_clean_en);
  3177. if ($q_value_clean_en != $q_value) $q_arr[ $q_value_clean_en ] = true;
  3178. if ($q_value_clean_pl != $q_value) $q_arr[ $q_value_clean_pl ] = true;
  3179. if ($q_value_clean_pr != $q_value) $q_arr[ $q_value_clean_pr ] = true;
  3180. foreach ($q_arr as $v_q => $v_val) {
  3181. $sql_filter_q []= "a.`P_NAME` like '".DB::_($v_q)."'";
  3182. $sql_filter_q []= "a.`P_NAME_SECOND` like '".DB::_($v_q)."'";
  3183. // $sql_filter_q []= "a.`P_ADDRESS_STREET` like '".DB::_($q)."'";
  3184. }
  3185. $sql_field_1 = "a.`P_NAME`";
  3186. $sql_field_2 = "a.`P_NAME_SECOND`";
  3187. foreach ($pl_letters as $k_ind => $v_char_pl) {
  3188. $sql_field_1 = "REPLACE(" . $sql_field_1 . ", '" . $v_char_pl . "', '" . $en_letters[$k_ind] . "')";
  3189. $sql_field_2 = "REPLACE(" . $sql_field_2 . ", '" . $v_char_pl . "', '" . $en_letters[$k_ind] . "')";
  3190. }//end foreach
  3191. $sql_filter_q []= $sql_field_1 . " like '%" . DB::_($q_value_clean_en) . "%'";
  3192. $sql_filter_q []= $sql_field_2 . " like '%" . DB::_($q_value_clean_en) . "%'";
  3193. $sql_where_and_arr []= "(" . implode(" or ", $sql_filter_q) . ")";
  3194. }
  3195. }
  3196. }
  3197. if (!empty($sql_where_and_arr)) {
  3198. $sql_where = implode(" and ", $sql_where_and_arr);
  3199. } else {
  3200. $sql_where = "1=1";
  3201. }
  3202. return $sql_where;
  3203. }
  3204. function get_order_by_fields() {
  3205. $order_by_fields = array();
  3206. $order_by_fields []= 'ID';
  3207. $order_by_fields []= 'is_firma';
  3208. $order_by_fields []= 'BILLING_OWNER';
  3209. $order_by_fields []= 'STATUS';
  3210. $order_by_fields []= 'BLOKADA';
  3211. $order_by_fields []= 'ID_BILLING_USERS';
  3212. $order_by_fields []= 'P_NAME';
  3213. $order_by_fields []= 'PAY_SALDO';
  3214. $order_by_fields []= 'PAY_FVAT';
  3215. $order_by_fields []= 'PAY_DATE';
  3216. $order_by_fields []= 'PAY_TERM';
  3217. return $order_by_fields;
  3218. }
  3219. function get_users_total( $q = '' ) {
  3220. $total = 0;
  3221. $sql_where = WindykacjaStatsModel::_parse_query( $q );
  3222. $sql = "select count(1) as cnt
  3223. from `USERS2_WINDYKACJA_STATUS` as w
  3224. left join `BILLING_USERS_ADD` as a on(a.`id_users`=w.`ID_BILLING_USERS`)
  3225. where ".$sql_where."
  3226. ";
  3227. $res = DB::query($sql);
  3228. if ($r = DB::fetch($res)) {
  3229. $total = $r->cnt;
  3230. }
  3231. return $total;
  3232. }
  3233. function get_sql_users_select() {
  3234. $sql_select = "
  3235. a.`id_users` as ID
  3236. , a.`id_users`
  3237. , a.`P_NAME`
  3238. , a.`P_NAME_SECOND`
  3239. , a.`P_ADDRESS_STREET`
  3240. , a.`P_ADDRESS_HOME`
  3241. , a.`P_ADDRESS_HOUSE`
  3242. , a.`P_ADDRESS_CITY`
  3243. , a.`P_ADDRESS_POST_CODE`
  3244. , a.`P_ADDRESS_REGION`
  3245. , a.`P_PESEL`
  3246. , a.`P_PHONE`
  3247. , a.`P_OTHER_DOC`
  3248. , a.`user_mail_contact`
  3249. , a.`is_firma`
  3250. , w.`ID` as WINDYKACJA_ID
  3251. , w.`ID_BILLING_USERS`
  3252. , w.`A_STATUS`
  3253. , w.`A_STATUS_UPDATE_DATE`
  3254. , w.`USER_PAY_TERM_ADD`
  3255. , w.`L_APPOITMENT_DATE`
  3256. , w.`L_APPOITMENT_USER`
  3257. , w.`L_APPOITMENT_INFO`
  3258. , w.`PAY_DATE`
  3259. , w.`PAY_TERM`
  3260. , w.`PAY_SALDO`
  3261. , w.`PAY_FVAT`
  3262. , w.`wezwanie1_DATE`
  3263. , w.`wezwanie2_DATE`
  3264. , w.`ID_KORESP`
  3265. , w.`LAST_PAY_DATE`
  3266. , w.`BAD_ADDRESS`
  3267. -- , (select bu.`BILLING_OWNER` from `BILLING_USERS` as bu where bu.`ID`=w.`ID_BILLING_USERS` limit 1) as BILLING_OWNER
  3268. -- , (select bu.`STATUS` from `BILLING_USERS` as bu where bu.`ID`=w.`ID_BILLING_USERS` limit 1) as STATUS
  3269. , bu.`STATUS`
  3270. , bu.`BILLING_OWNER`
  3271. , w.`NR_SPRAWY_KRD`
  3272. , w.`NR_SPRAWY_SAD`
  3273. , w.`NR_SPRAWY_KOMORNIK`
  3274. ";
  3275. return $sql_select;
  3276. }
  3277. function &get_users( $q = '', $limit = 10, $limit_start = 0, $order_by = '', $order_dir = '' ) {
  3278. $ret = array();
  3279. $sql_select = self::get_sql_users_select();
  3280. $sql_where = WindykacjaStatsModel::_parse_query( $q );
  3281. $sql_limit = "limit " . (($limit > 0)? $limit : "10");
  3282. if ($limit_start > 0) $sql_limit .= " offset {$limit_start}";
  3283. $sql_order_by = "";
  3284. $order_by_allowed = self::get_order_by_fields();
  3285. if (in_array($order_by, $order_by_allowed)) {
  3286. if (in_array($order_by, array('P_NAME','is_firma'))) {
  3287. $order_by = "a.{$order_by}";
  3288. } else if (in_array($order_by, array('BILLING_OWNER','STATUS'))) {
  3289. $order_by = "bu.{$order_by}";
  3290. } else if ($order_by == 'BLOKADA') {
  3291. $order_by = "bu.`STATUS`";
  3292. } else {
  3293. $order_by = "w.{$order_by}";
  3294. }
  3295. $sql_order_by .= " order by {$order_by}";
  3296. if (in_array($order_dir, array('DESC','ASC'))) {
  3297. $sql_order_by .= " {$order_dir}";
  3298. }
  3299. }
  3300. $sql = "select {$sql_select}
  3301. from `USERS2_WINDYKACJA_STATUS` as w
  3302. left join `BILLING_USERS` as bu on(bu.`ID`=w.`ID_BILLING_USERS`)
  3303. left join `BILLING_USERS_ADD` as a on(a.`id_users`=w.`ID_BILLING_USERS`)
  3304. where {$sql_where}
  3305. {$sql_order_by}
  3306. {$sql_limit}
  3307. ";
  3308. $res = DB::query($sql);
  3309. while ($r = DB::fetch($res)) {
  3310. $ret[$r->id_users] = $r;
  3311. }
  3312. return $ret;
  3313. }
  3314. function &get_user_by_id( $id ) {
  3315. $ret = null;
  3316. if ($id <= 0) return $ret;
  3317. $sql_select = self::get_sql_users_select();
  3318. $sql_where = "a.`id_users`='".$id."'";
  3319. $sql = "select " . $sql_select . "
  3320. from `USERS2_WINDYKACJA_STATUS` as w
  3321. left join `BILLING_USERS` as bu on(bu.`ID`=w.`ID_BILLING_USERS`)
  3322. left join `BILLING_USERS_ADD` as a on(a.`id_users`=w.`ID_BILLING_USERS`)
  3323. where ".$sql_where."
  3324. ";
  3325. $res = DB::query($sql);
  3326. if ($r = DB::fetch($res)) {
  3327. if(0){
  3328. $r->BA_WINIEN = "";
  3329. $r->BA_MA = "";
  3330. $r->BA_TIMESTAMP = "";
  3331. $sql = "select BA.`WINIEN` as BA_WINIEN
  3332. , BA.`MA` as BA_MA
  3333. , unix_timestamp(BA.TIMESTAMP) as BA_TIMESTAMP
  3334. from `BILLING_ACCOUNTS` as BA
  3335. where BA.`ID_BILLING_USERS`='" . $r->ID . "'
  3336. ";
  3337. $db_webone = DB::getDB('931');
  3338. if ($db_webone) {
  3339. $res_fin = $db_webone->query($sql);
  3340. if ($r_fin = $db_webone->fetch($res_fin)) {
  3341. $r->BA_WINIEN = $r_fin->BA_WINIEN;
  3342. $r->BA_MA = $r_fin->BA_MA;
  3343. $r->BA_TIMESTAMP = $r_fin->BA_TIMESTAMP;
  3344. }
  3345. }
  3346. }
  3347. $ret = $r;
  3348. }
  3349. return $ret;
  3350. }
  3351. function get_company( &$user ) {
  3352. if (!isset($user->_company)) {
  3353. /*
  3354. id 1 / 2
  3355. name1 "BIALL-NET" Sp. z o.o. / "NET-DAY" s.c.
  3356. name2 --- / Adrian i Ewa Wieczorkowscy
  3357. kod 80-174 / 80-809
  3358. miasto Gdańsk, Otomin / Gdańsk
  3359. ulica Słoneczna / Cieszyńskiego
  3360. numer_dom 43 / 38
  3361. numer_pos NULL / NULL
  3362. uwagi --- / ---
  3363. tel 0-58 320-72-92 / 0-58 741 84 54
  3364. fax 0-58 320-72-96 / 0-58 741 84 56
  3365. nip 593-22-68-672 / 583-27-54-031
  3366. regon 192120212 / 192578721
  3367. bank Bank Zachodni WBK SA I O/Gdansk / ---
  3368. nr_rach 46 1090 1098 0000 0001 0253 7156 / 84 1500 1171 1211 7002 9997 0000
  3369. NR_RACH_MASS_PAY 109000049887 / 109000049669
  3370. BILLING_OWNER_EMAIL biall-net@biall.net.pl / netday@netday.pl
  3371. */
  3372. $sql = "select
  3373. bo.`id`
  3374. , bo.`name1`
  3375. , bo.`name2`
  3376. , bo.`kod`
  3377. , bo.`miasto`
  3378. , bo.`ulica`
  3379. , bo.`numer_dom`
  3380. , bo.`tel`
  3381. , bo.`fax`
  3382. , bo.`nip`
  3383. , bo.`regon`
  3384. , bo.`bank`
  3385. , bo.`nr_rach`
  3386. , bo.`NR_RACH_MASS_PAY`
  3387. , bo.`BILLING_OWNER_EMAIL`
  3388. from `BILLING_USERS` as bu
  3389. left join `BILLING_OWNER` as bo on (bo.`ID`=bu.`BILLING_OWNER`)
  3390. where
  3391. bu.`ID`='" . $user->ID_BILLING_USERS . "'
  3392. ";
  3393. //$db_webone = DB::getDB('931');
  3394. //if ($db_webone) {
  3395. //$res = $db_webone->query( $sql );
  3396. //if ($r = $db_webone->fetch( $res )) {
  3397. // $user->_company = $r;
  3398. //}
  3399. //}
  3400. $res = DB::query( $sql );
  3401. if ($r = DB::fetch( $res )) {
  3402. $user->_company = $r;
  3403. }
  3404. }
  3405. return $user->_company;
  3406. }
  3407. function &get_billing_type( $type_id ) {
  3408. $ret = null;
  3409. $types = WindykacjaStatsModel::get_billing_types();
  3410. if (array_key_exists($type_id, $types)) {
  3411. $ret = $types[ $type_id ];
  3412. }
  3413. return $ret;
  3414. }
  3415. function get_billing_type_desc( $type ) {
  3416. $ret = '';
  3417. if ($type == 'FVAT') {
  3418. return "Faktura Vat";
  3419. }
  3420. $types = WindykacjaStatsModel::get_billing_types();
  3421. foreach ($types as $h) {
  3422. if ($h['TYPE'] == $type) {
  3423. return $h['DESC'];
  3424. }
  3425. }//end foreach
  3426. return $ret;
  3427. }
  3428. function &get_billing_types( $ids = array() ) {
  3429. static $_cache;
  3430. if (empty($_cache)) $_cache = array();
  3431. $cache_key = implode(".", $ids);
  3432. if (!array_key_exists($cache_key, $_cache)) {
  3433. $billing_types = array();
  3434. $db_webone = DB::getDB('931');
  3435. if ($db_webone) {
  3436. $sql_where = "1=1";
  3437. if (!empty($ids)) {
  3438. $sql_where = "`ID` in ('".implode("','", $ids)."')";
  3439. }
  3440. $sql = "select *
  3441. from `BILLING_NUMBERS_TYPE`
  3442. where
  3443. $sql_where
  3444. ";
  3445. $res = $db_webone->query($sql);
  3446. while ($h = $db_webone->fetch_assoc($res)) {
  3447. $billing_types [ $h['ID'] ] = $h;
  3448. }
  3449. }
  3450. $_cache[$cache_key] = $billing_types;
  3451. }
  3452. return $_cache[$cache_key];
  3453. }
  3454. function &get_umowy_from_l2( &$user ) {
  3455. $ret = array();
  3456. $db_webone = DB::getDB();
  3457. if (!$db_webone) {
  3458. return -1;
  3459. }
  3460. $sql = "select
  3461. d.`ID`, d.`P_DEALPREFIX`, d.`P_DEALNUMBER`, d.`P_DEALNUMBER_OLD`, d.`P_DEALDATE`, d.`P_DEALDATE_TERM`, d.`DEALDESC`, d.`ANEX_NEEDED`, d.`ANEX_CONFIRM_DATE`
  3462. from `DEALS_TABLE` as d
  3463. where d.`ID_BILLING_USERS`='".$user->ID."'
  3464. order by d.`ID` DESC
  3465. ";
  3466. $res = $db_webone->query($sql);
  3467. while ($h = $db_webone->fetch_assoc($res)) {
  3468. $ret [ $h['ID'] ] = $h;
  3469. }
  3470. return $ret;
  3471. }
  3472. function &get_uslugi_from_l2( &$user ) {
  3473. // l2: www/modules/webone/form/edit_user_status.php
  3474. // Aktualne: Usługa [Status] => list_services2($user->ID);
  3475. $uID = $user->ID;
  3476. $ret = array();
  3477. $db_webone = DB::getDB();
  3478. if (!$db_webone) {
  3479. return -1;
  3480. }
  3481. if(0){// SERVICES table struct example:
  3482. //[ID_BILLING_USERS] => 11363
  3483. //[active] => 1
  3484. //[TAB_UPDATE_STAT] => 1
  3485. //[TAB_UPDATE_DATE] => 2012-02-03 17:43:44
  3486. //[TAB_UPDATE_INFO] => OK-PREUPDATE-DELETED---UPDATED-OK-:195.117.2.79
  3487. //[SERVICE_TYPE] => ABONAMENT
  3488. //[ID_BILLING_NUMBERS_TYPE] => 1
  3489. //[ABONAMENT_PERIOD] => 1
  3490. //[ABONAMENT_VALUE] => 26.01
  3491. //[VAT] => 23
  3492. //[ID_CURRENCY] => 0
  3493. //[ABONAMENT_PAYMENT] => UP
  3494. //[ABONAMENT_START] => 1
  3495. //[MINIMUM_BILLING_VALUE] => 0.00
  3496. //[BILLED_TILL] => 2012-06-01 00:00:00
  3497. //[HANGUP_FROM] =>
  3498. //[HANGUP_TILL] =>
  3499. //[HANGUP_STATUS] =>
  3500. //[HANGUP_RATIO] => 1.00
  3501. //[TIMESTAMP] => 20120504125053
  3502. //[P_ID_SERVICES] => 0
  3503. //[uwagi] =>
  3504. //[ID_DEALS_TABLE] => 9373
  3505. //[VAT_NAME] => 23
  3506. //[id_list_sww] => 1
  3507. //[SERV_ID_BILLING_PREFIXES] => 0
  3508. //[ID_OFFERS] => 833
  3509. //[A_RECORD_CREATE_DATE] =>
  3510. //[A_RECORD_CREATE_AUTHOR] =>
  3511. //[A_RECORD_UPDATE_DATE] =>
  3512. //[A_RECORD_UPDATE_AUTHOR] =>
  3513. }
  3514. $sql = "select
  3515. s.`ID`, s.`NAME_LIST_SERVICES`, s.`A_STATUS`
  3516. , s.`ID_OFFERS`
  3517. , s.`ID_DEALS_TABLE`
  3518. , s.`P_ID_SERVICES`
  3519. , s.`P_ID_SERVICES` as P_ID
  3520. , s.`HANGUP_STATUS`
  3521. , s.`HANGUP_FROM`
  3522. , s.`HANGUP_TILL`
  3523. , ls.`description` as description
  3524. , lst.`name` as A_STATUS_DESC
  3525. from `SERVICES` as s
  3526. left join `LIST_SERVICES` as ls on(ls.`name`=s.`NAME_LIST_SERVICES`)
  3527. left join `LIST_status` as lst on(lst.`ses_users2`=s.`HANGUP_STATUS` and lst.`ID`>2)
  3528. where `ID_BILLING_USERS`='".$user->ID."'
  3529. ";
  3530. $res = $db_webone->query($sql);
  3531. while ($h = $db_webone->fetch_assoc($res)) {
  3532. $ret [ $h['ID'] ] = $h;
  3533. }
  3534. return $ret;
  3535. }
  3536. function &get_umowy_from_l3( &$user ) {
  3537. $ret = array();
  3538. $sql = "select d.*
  3539. from `USERS2_DEALS` as d
  3540. where
  3541. (d.`ID_BILLING_USERS_OLD`='".$user->ID."' or d.`ID_BILLING_USERS_NEW`='".$user->ID."')
  3542. order by d.`ID` DESC
  3543. ";
  3544. $res = DB::query($sql);
  3545. while ($h = DB::fetch_assoc($res)) {
  3546. $ret []= $h;
  3547. }
  3548. return $ret;
  3549. }
  3550. function &get_bill_dosc_by_date( &$user, $date_limit = null ) {
  3551. // fetch finanse data from remote DB
  3552. $billing_docs = new BillingDocs();
  3553. $db_webone = DB::getDB('931');
  3554. if (!$db_webone) {
  3555. echo'<p style="color:red">'."Blad polaczenia do bazy dancyh webone_billing - Zasob [931]".'</p>';
  3556. return;
  3557. }
  3558. $sql_where = " BILLS_FVAT.OPEN='N' and BILLS_FVAT.ID_BILLING_USERS ='".$user->ID."' ";
  3559. // blad w zaokragleniach
  3560. // , sum((BILLS_FVAT_POS.AMMOUNT * BILLS_FVAT_POS.PRICE)*(1 + BILLS_FVAT_POS.VAT/100)) as WARTOSC
  3561. if ($date_limit) {
  3562. $sql_where .= " and BILLS_FVAT.PAYMENT_TERM <= '" . $date_limit . "' ";
  3563. }
  3564. $sql = "select
  3565. BILLS_FVAT.*
  3566. , count(BILLS_FVAT_POS.ID) as ILOSC_POZYCJI
  3567. , BILLS_FVAT_POS.ID_BILLS_FVAT
  3568. , round(sum((BILLS_FVAT_POS.AMMOUNT * BILLS_FVAT_POS.PRICE)*(1 + BILLS_FVAT_POS.VAT/100)), 2) as WARTOSC
  3569. -- , count(BILLS_FVAT_POS.PRICE) as ILOSC_POZYCJI
  3570. from `BILLS_FVAT`
  3571. left join `BILLS_FVAT_POS` on BILLS_FVAT.ID=BILLS_FVAT_POS.ID_BILLS_FVAT
  3572. where $sql_where
  3573. group by BILLS_FVAT.ID
  3574. order by BILLS_FVAT.ID_BILLING_NUMBERS ASC
  3575. ";
  3576. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">';print_r($sql);echo'</pre>';
  3577. $res = $db_webone->query($sql);
  3578. while ($h = $db_webone->fetch_assoc($res)) {
  3579. if (0){// ? dla kazdej faktury ?
  3580. $sql = "select t1.ID_BILLING_NUMBERS AS NR_DOK
  3581. , t1.ID_BILLING_USERS as PLATNIK
  3582. , t1.WINIEN,t1.MA
  3583. , t1.ID_FIN_WINIEN as ID_F_W
  3584. , t1.ID_FIN_WINIEN_VAL as F_WINIEN_V
  3585. , t1.ID_FIN_MA as ID_F_M
  3586. , t1.ID_FIN_MA_VAL as F_MA_V
  3587. , max(t2.ID)
  3588. , sum(t2.ID_FIN_WINIEN_VAL) as ROZ_WINIEN
  3589. , max(t3.ID)
  3590. , sum(t3.ID_FIN_MA_VAL) as ROZ_MA
  3591. , t1.WINIEN - sum(t2.ID_FIN_WINIEN_VAL) - sum(t3.ID_FIN_MA_VAL) as POZ_WINIEN
  3592. , t1.MA - sum(t3.ID_FIN_MA_VAL) - sum(t2.ID_FIN_WINIEN_VAL) as POZ_MA
  3593. from `BILLING_ACCOUNTS_FILES` as t1
  3594. left join `BILLING_ACCOUNTS_FILES` as t2 on (t1.ID_BILLING_NUMBERS=t2.ID_FIN_WINIEN)
  3595. left join `BILLING_ACCOUNTS_FILES` as t3 on (t1.ID_BILLING_NUMBERS=t3.ID_FIN_MA)
  3596. where
  3597. t1.ID_FIN_WINIEN is NULL and t1.ID_FIN_MA is NULL and t1.MA = 0 and t1.WINIEN > 0
  3598. and t1.ID_BILLING_NUMBERS=".$user->ID."
  3599. group by t1.ID_BILLING_NUMBERS
  3600. limit 0,1
  3601. ";
  3602. }
  3603. //$h['type'] = 'FVAT';
  3604. //$h['nr'] = $h['ID_BILLING_NUMBERS'];
  3605. //$h['WINIEN'] = $h['WARTOSC'];
  3606. //$h['MA'] = 0;
  3607. $billing_docs->add_bill_doc( $h['PAYMENT_TERM'], 'FVAT', $h );
  3608. }
  3609. $faktury_cols = array();
  3610. //$faktury_cols['ID_BILLING_USERS'] = "id klienta";//
  3611. $faktury_cols['ID_BILLING_NUMBERS'] = "numer";// numer faktury
  3612. $faktury_cols['BILL_DATE'] = "";// data('Y-m-d')
  3613. $faktury_cols['SELL_DATE'] = "";// data('Y-m-d')
  3614. $faktury_cols['PAYMENT_TERM'] = "";// data('Y-m-d')
  3615. //$billing_types = WindykacjaStatsModel::get_billing_types( array(3, 4, 5, 7, 8) );
  3616. $billing_types = WindykacjaStatsModel::get_billing_types();
  3617. foreach ($billing_types as $bill_type) {
  3618. if ($bill_type['CLASS'] == 'FINANCE') {
  3619. $sql_where = ($date_limit)? " and ".$bill_type['TABLE'].".BILL_DATE <= '" . $date_limit . "' " : "";
  3620. $sql = "select ".$bill_type['TABLE'].".ID
  3621. , ".$bill_type['TABLE'].".ID_BILLING_NUMBERS
  3622. , ".$bill_type['TABLE'].".BILL_DATE
  3623. , round(".$bill_type['TABLE'].".WINIEN, 2) as WINIEN
  3624. , round(".$bill_type['TABLE'].".MA, 2) as MA
  3625. , ".$bill_type['TABLE'].".ID_FK_DEKRET
  3626. , ".$bill_type['TABLE'].".OPEN
  3627. , ".$bill_type['TABLE'].".FK_ZAKSIEG
  3628. , ".$bill_type['TABLE'].".do_dokumentu
  3629. , ".$bill_type['BILLING_NUMBERS_TABLE'].".NUMBER
  3630. , ".$bill_type['BILLING_NUMBERS_TABLE'].".ID_BILLING_PREFIXES
  3631. , ".$bill_type['BILLING_NUMBERS_TABLE'].".ID_BILLING_NUMBERS_TYPE
  3632. from ".$bill_type['TABLE']."
  3633. left join ".$bill_type['BILLING_NUMBERS_TABLE']." on (".$bill_type['BILLING_NUMBERS_TABLE'].".ID=".$bill_type['TABLE'].".ID_BILLING_NUMBERS)
  3634. where ".$bill_type['TABLE'].".ID_BILLING_USERS='".$user->ID."'
  3635. ".$sql_where."
  3636. ";
  3637. $res = $db_webone->query($sql);
  3638. while ($h = $db_webone->fetch_assoc($res)) {
  3639. $billing_docs->add_bill_doc( $h['BILL_DATE'], $bill_type['TYPE'], $h );
  3640. }
  3641. }
  3642. else if ($bill_type['CLASS'] == 'SELL_MA') {
  3643. $sql_where = ($date_limit)? " and ".$bill_type['TABLE'].".BILL_DATE <= '" . $date_limit . "' " : "";
  3644. $sql = "select ".$bill_type['TABLE'].".ID
  3645. , count(".$bill_type['TABLE']."_POS.ID) as cnt
  3646. , ".$bill_type['TABLE']."_POS.ID_BILLS_FVAT
  3647. , ".$bill_type['TABLE'].".ID_CURRENCY
  3648. , round(sum((".$bill_type['TABLE']."_POS.N_AMMOUNT * ".$bill_type['TABLE']."_POS.N_PRICE) * ( 1 + ".$bill_type['TABLE']."_POS.N_VAT / 100)),2) as WINIEN
  3649. , round(sum(
  3650. ((".$bill_type['TABLE']."_POS.AMMOUNT * ".$bill_type['TABLE']."_POS.PRICE) * ( 1 + ".$bill_type['TABLE']."_POS.VAT / 100))
  3651. - (".$bill_type['TABLE']."_POS.N_AMMOUNT * ".$bill_type['TABLE']."_POS.N_PRICE * ".$bill_type['TABLE']."_POS.N_VAT / 100)
  3652. + (".$bill_type['TABLE']."_POS.N_AMMOUNT * ".$bill_type['TABLE']."_POS.N_PRICE * ".$bill_type['TABLE']."_POS.VAT / 100)
  3653. ),2) as MA
  3654. , ".$bill_type['TABLE'].".ID_BILLING_NUMBERS , ".$bill_type['TABLE'].".OPEN , ".$bill_type['TABLE'].".FK_ZAKSIEG
  3655. , ".$bill_type['TABLE'].".IF_KORV , ".$bill_type['TABLE'].".BILL_DATE , ".$bill_type['BILLING_NUMBERS_TABLE'].".NUMBER
  3656. from ".$bill_type['TABLE']."
  3657. left join ".$bill_type['BILLING_NUMBERS_TABLE']." on ".$bill_type['BILLING_NUMBERS_TABLE'].".ID=".$bill_type['TABLE'].".ID_BILLING_NUMBERS
  3658. left join ".$bill_type['TABLE']."_POS on ".$bill_type['TABLE'].".ID=".$bill_type['TABLE']."_POS.ID_BILLS_FVAT
  3659. where ".$bill_type['TABLE'].".ID_BILLING_USERS='".$user->ID."'
  3660. ".$sql_where."
  3661. group by ".$bill_type['TABLE'].".ID
  3662. order by ".$bill_type['TABLE'].".ID
  3663. ";
  3664. $res = $db_webone->query($sql);
  3665. while ($h = $db_webone->fetch_assoc($res)) {
  3666. $billing_docs->add_bill_doc( $h['BILL_DATE'], $bill_type['TYPE'], $h );
  3667. }
  3668. }
  3669. }//end foreach
  3670. return $billing_docs;
  3671. }
  3672. /**
  3673. * @used in FunkcjeL1::billing_billwiev_przeterminowania
  3674. */
  3675. function &get_billing_account_files( $user_id ) {
  3676. $baf = array();
  3677. $ECHO_PARAM = '';
  3678. $ID_BILLING_USERS_PARAM = $user_id;
  3679. $db_webone = DB::getDB('931');
  3680. if (!$db_webone) {
  3681. echo'<p style="color:red">'."Blad polaczenia do bazy dancyh webone_billing - Zasob [931]".'</p>';
  3682. return $baf;
  3683. }
  3684. $WHERE = "";
  3685. if ($ID_BILLING_USERS_PARAM) $WHERE .= " and BAF.ID_BILLING_USERS='$ID_BILLING_USERS_PARAM' ";
  3686. //UZGODNIENIE_SALD
  3687. if (strstr($ECHO_PARAM, 'saldo_rok')) {
  3688. global $base_path ;
  3689. include_once($base_path."/modules/billing/bill/modules/billing_financefunc.inc");
  3690. if ($ID_BILLING_USERS_PARAM) {
  3691. if ($vdb->sql_numrows($vdb->sql_query("select ID from BILLING_ACCOUNTS_TILL where ID_BILLING_USERS='$ID_BILLING_USERS_PARAM' and TILL=YEAR(NOW())-1 ;")) != 1) {
  3692. UAKTUALNIJ_KONTA($ID_BILLING_USERS_PARAM);
  3693. }
  3694. }
  3695. $WHERE .= " AND YEAR(BN.TIMESTAMP)<YEAR(NOW()) ";
  3696. }
  3697. $WHERE_FIRMA = "";
  3698. if ($_GET['FIRMA']) $WHERE_FIRMA = "and BILLING_USERS.BILLING_OWNER='".$_GET['FIRMA']."'" ;
  3699. //$billing_account_files = WindykacjaStatsModel::
  3700. $sql = "create temporary table TEMP_BILLING_ACCOUNTS_FILES
  3701. select BAF.ID
  3702. , BAF.ID_BILLING_USERS
  3703. , BAF.WINIEN
  3704. , BAF.MA
  3705. , BAF.ID_BILLING_NUMBERS_TYPE
  3706. , BN.NUMBER
  3707. , BN.ID_BILLING_PREFIXES
  3708. , BAF_WINIEN.ID_FIN_WINIEN
  3709. , BAF_WINIEN.ID_BILLING_NUMBERS_TYPE as ID_BILLING_NUMBERS_TYPE_W
  3710. , BAF_BN_WINIEN.NUMBER as NUMBER_W
  3711. , BAF_BN_WINIEN.ID_BILLING_PREFIXES as ID_BILLING_PREFIXES_W
  3712. , unix_timestamp(BAF_BN_WINIEN.TIMESTAMP) as TIMESTAMP_W
  3713. , BAF_WINIEN.ID_FIN_WINIEN_VAL
  3714. , NULL as ID_FIN_MA
  3715. , NULL as ID_BILLING_NUMBERS_TYPE_M
  3716. , NULL as NUMBER_M
  3717. , NULL as ID_BILLING_PREFIXES_M
  3718. , NULL as TIMESTAMP_M
  3719. , NULL as ID_FIN_MA_VAL
  3720. , unix_timestamp(ifnull(BILLS_FVAT.PAYMENT_TERM, BILLS_KORV.PAYMENT_TERM)) as TERMIN_PL
  3721. , BUA.P_NAME
  3722. , BUA.P_NAME_SECOND
  3723. , BUA.P_ADDRESS_CITY
  3724. , BUA.P_ADDRESS_STREET
  3725. , BUA.P_ADDRESS_HOUSE
  3726. , BUA.P_ADDRESS_HOME
  3727. , BUA.user_mail_contact
  3728. , BA.WINIEN as BA_WINIEN
  3729. , BA.MA as BA_MA
  3730. , unix_timestamp(BA.TIMESTAMP) as BA_TIMESTAMP
  3731. , unix_timestamp(BAF.TIMESTAMP) as BAF_TIMESTAMP
  3732. from BILLING_ACCOUNTS_FILES as BAF
  3733. left join BILLING_USERS on BILLING_USERS.ID=BAF.ID_BILLING_USERS
  3734. left join BILLING_USERS_ADD as BUA on BUA.id_users=BAF.ID_BILLING_USERS
  3735. left join BILLING_NUMBERS as BN on BN.ID=BAF.ID_BILLING_NUMBERS
  3736. left join BILLING_ACCOUNTS as BA on BA.ID_BILLING_USERS=BAF.ID_BILLING_USERS
  3737. left join BILLS_FVAT on BILLS_FVAT.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS
  3738. left join BILLS_KORV on BILLS_KORV.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS
  3739. left join BILLING_ACCOUNTS_FILES as BAF_WINIEN on BAF_WINIEN.ID_FIN_WINIEN=BAF.ID_BILLING_NUMBERS
  3740. left join BILLING_NUMBERS as BAF_BN_WINIEN on BAF_BN_WINIEN.ID=BAF_WINIEN.ID_BILLING_NUMBERS
  3741. where BAF.ID_FIN_WINIEN is NULL and BAF.ID_FIN_MA is NULL and BAF.ID_FIN_WINIEN is NULL
  3742. $WHERE
  3743. $WHERE_FIRMA
  3744. ";
  3745. $sql2 = "insert into TEMP_BILLING_ACCOUNTS_FILES
  3746. select BAF.ID
  3747. , BAF.ID_BILLING_USERS
  3748. , BAF.WINIEN
  3749. , BAF.MA
  3750. , BAF.ID_BILLING_NUMBERS_TYPE
  3751. , BN.NUMBER
  3752. , BN.ID_BILLING_PREFIXES
  3753. , NULL as ID_FIN_WINIEN
  3754. , NULL as ID_BILLING_NUMBERS_TYPE_W
  3755. , NULL as NUMBER_W
  3756. , NULL as ID_BILLING_PREFIXES_W
  3757. , NULL as TIMESTAMP_W
  3758. , NULL as ID_FIN_WINIEN_VAL
  3759. , BAF_MA.ID_FIN_MA
  3760. , BAF_MA.ID_BILLING_NUMBERS_TYPE as ID_BILLING_NUMBERS_TYPE_M
  3761. , BAF_BN_MA.NUMBER as NUMBER_M
  3762. , BAF_BN_MA.ID_BILLING_PREFIXES as ID_BILLING_PREFIXES_M
  3763. , unix_timestamp(BAF_BN_MA.TIMESTAMP) as TIMESTAMP_M
  3764. , BAF_MA.ID_FIN_MA_VAL
  3765. , unix_timestamp(ifnull(BILLS_FVAT.PAYMENT_TERM, BILLS_KORV.PAYMENT_TERM))
  3766. , BUA.P_NAME
  3767. , BUA.P_NAME_SECOND
  3768. , BUA.P_ADDRESS_CITY
  3769. , BUA.P_ADDRESS_STREET
  3770. , BUA.P_ADDRESS_HOUSE
  3771. , BUA.P_ADDRESS_HOME
  3772. , BUA.user_mail_contact
  3773. , BA.WINIEN as BA_WINIEN
  3774. , BA.MA as BA_MA
  3775. , unix_timestamp(BA.TIMESTAMP) as BA_TIMESTAMP
  3776. , unix_timestamp(BAF.TIMESTAMP) as BAF_TIMESTAMP
  3777. from BILLING_ACCOUNTS_FILES as BAF
  3778. left join BILLING_USERS on (BILLING_USERS.ID=BAF.ID_BILLING_USERS)
  3779. left join BILLING_USERS_ADD as BUA on (BUA.id_users=BAF.ID_BILLING_USERS)
  3780. left join BILLING_NUMBERS as BN on (BN.ID=BAF.ID_BILLING_NUMBERS)
  3781. left join BILLING_ACCOUNTS as BA on (BA.ID_BILLING_USERS=BAF.ID_BILLING_USERS)
  3782. left join BILLS_FVAT on (BILLS_FVAT.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS)
  3783. left join BILLS_KORV on (BILLS_KORV.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS)
  3784. left join BILLING_ACCOUNTS_FILES as BAF_MA on (BAF_MA.ID_FIN_MA=BAF.ID_BILLING_NUMBERS)
  3785. left join BILLING_NUMBERS as BAF_BN_MA on (BAF_BN_MA.ID=BAF_MA.ID_BILLING_NUMBERS)
  3786. where
  3787. BAF.ID_FIN_WINIEN is NULL and BAF.ID_FIN_MA is NULL
  3788. $WHERE
  3789. $WHERE_FIRMA
  3790. ";
  3791. if (strstr($ECHO_PARAM,'saldo_rok')) {
  3792. $sql = "create temporary table TEMP_BILLING_ACCOUNTS_FILES
  3793. select
  3794. BAF.ID, BAF.ID_BILLING_USERS , BAF.WINIEN, BAF.MA, BAF.ID_BILLING_NUMBERS_TYPE, BN.NUMBER , BN.ID_BILLING_PREFIXES,
  3795. BAF_WINIEN.ID_FIN_WINIEN,
  3796. BAF_WINIEN.ID_BILLING_NUMBERS_TYPE as ID_BILLING_NUMBERS_TYPE_W,
  3797. BAF_BN_WINIEN.NUMBER as NUMBER_W,
  3798. BAF_BN_WINIEN.ID_BILLING_PREFIXES as ID_BILLING_PREFIXES_W,
  3799. unix_timestamp(BAF_BN_WINIEN.TIMESTAMP) as TIMESTAMP_W,
  3800. BAF_WINIEN.ID_FIN_WINIEN_VAL,
  3801. NULL as ID_FIN_MA,
  3802. NULL as ID_BILLING_NUMBERS_TYPE_M,
  3803. NULL as NUMBER_M,
  3804. NULL as ID_BILLING_PREFIXES_M,
  3805. NULL as TIMESTAMP_M,
  3806. NULL as ID_FIN_MA_VAL,
  3807. unix_timestamp(ifnull(BILLS_FVAT.PAYMENT_TERM,ifnull( BILLS_KORV.PAYMENT_TERM,BN.TIMESTAMP ))) as TERMIN_PL ,
  3808. BUA.P_NAME , BUA.P_NAME_SECOND , BUA.P_ADDRESS_CITY , BUA.P_ADDRESS_STREET ,BUA.P_ADDRESS_HOUSE , BUA.P_ADDRESS_HOME , BUA.user_mail_contact ,
  3809. BA.WINIEN as BA_WINIEN , BA.MA as BA_MA , unix_timestamp(BA.TIMESTAMP) as BA_TIMESTAMP,
  3810. unix_timestamp(BAF.TIMESTAMP) as BAF_TIMESTAMP,
  3811. BILLING_ACCOUNTS_TILL.TILL as BAT_TILL , BILLING_ACCOUNTS_TILL.WINIEN as BAT_WINIEN, BILLING_ACCOUNTS_TILL.MA as BAT_MA
  3812. from BILLING_ACCOUNTS_FILES as BAF
  3813. left join BILLING_USERS_ADD as BUA on BUA.id_users=BAF.ID_BILLING_USERS
  3814. left join BILLING_NUMBERS as BN on BN.ID=BAF.ID_BILLING_NUMBERS
  3815. left join BILLING_ACCOUNTS as BA on BA.ID_BILLING_USERS=BAF.ID_BILLING_USERS
  3816. left join BILLS_FVAT on BILLS_FVAT.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS
  3817. left join BILLS_KORV on BILLS_KORV.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS
  3818. left join BILLING_ACCOUNTS_FILES as BAF_TRG on ( BAF.ID_FIN_WINIEN=BAF_TRG.ID_BILLING_NUMBERS or BAF.ID_FIN_MA=BAF_TRG.ID_BILLING_NUMBERS )
  3819. left join BILLING_NUMBERS as BAF_TRG_BN on ( BAF_TRG.ID_BILLING_NUMBERS=BAF_TRG_BN.ID )
  3820. left join BILLING_ACCOUNTS_FILES as BAF_WINIEN on ( BAF_WINIEN.ID_FIN_WINIEN=BAF.ID_BILLING_NUMBERS or BAF_WINIEN.ID_FIN_MA=BAF.ID_BILLING_NUMBERS )
  3821. left join BILLING_NUMBERS as BAF_BN_WINIEN on ( BAF_BN_WINIEN.ID=BAF_WINIEN.ID_BILLING_NUMBERS )
  3822. left join BILLING_ACCOUNTS_TILL on (BILLING_ACCOUNTS_TILL.ID_BILLING_USERS=BAF.ID_BILLING_USERS and BILLING_ACCOUNTS_TILL.TILL=year(now())-1 )
  3823. where
  3824. ( BAF.ID_FIN_WINIEN is NULL and BAF.ID_FIN_MA is NULL or year(BAF_TRG_BN.TIMESTAMP)>year(NOW())-1 )
  3825. and (YEAR(BAF_BN_WINIEN.TIMESTAMP)<YEAR(NOW()) or BAF_BN_WINIEN.TIMESTAMP is NULL )
  3826. $WHERE
  3827. limit 2000 ;
  3828. ";
  3829. $sql2 = " insert into TEMP_BILLING_ACCOUNTS_FILES select
  3830. BAF.ID, BAF.ID_BILLING_USERS , BAF.WINIEN, BAF.MA, BAF.ID_BILLING_NUMBERS_TYPE, BN.NUMBER , BN.ID_BILLING_PREFIXES,
  3831. NULL as ID_FIN_WINIEN,
  3832. NULL as ID_BILLING_NUMBERS_TYPE_W,
  3833. NULL as NUMBER_W ,
  3834. NULL as ID_BILLING_PREFIXES_W,
  3835. NULL as TIMESTAMP_W ,
  3836. NULL as ID_FIN_WINIEN_VAL ,
  3837. BAF_MA.ID_FIN_MA,
  3838. BAF_MA.ID_BILLING_NUMBERS_TYPE as ID_BILLING_NUMBERS_TYPE_M,
  3839. BAF_BN_MA.NUMBER as NUMBER_M,
  3840. BAF_BN_MA.ID_BILLING_PREFIXES as ID_BILLING_PREFIXES_M,
  3841. unix_timestamp(BAF_BN_MA.TIMESTAMP) as TIMESTAMP_M,
  3842. BAF_MA.ID_FIN_MA_VAL,
  3843. unix_timestamp(ifnull(BILLS_FVAT.PAYMENT_TERM,ifnull( BILLS_KORV.PAYMENT_TERM,BN.TIMESTAMP ))) as TERMIN_PL ,
  3844. BUA.P_NAME , BUA.P_NAME_SECOND , BUA.P_ADDRESS_CITY , BUA.P_ADDRESS_STREET ,BUA.P_ADDRESS_HOUSE , BUA.P_ADDRESS_HOME , BUA.user_mail_contact ,
  3845. BA.WINIEN as BA_WINIEN , BA.MA as BA_MA , unix_timestamp(BA.TIMESTAMP) as BA_TIMESTAMP,
  3846. unix_timestamp(BAF.TIMESTAMP) as BAF_TIMESTAMP,
  3847. BILLING_ACCOUNTS_TILL.TILL as BAT_TILL , BILLING_ACCOUNTS_TILL.WINIEN as BAT_WINIEN, BILLING_ACCOUNTS_TILL.MA as BAT_MA
  3848. from BILLING_ACCOUNTS_FILES as BAF
  3849. left join BILLING_USERS_ADD as BUA on BUA.id_users=BAF.ID_BILLING_USERS
  3850. left join BILLING_NUMBERS as BN on BN.ID=BAF.ID_BILLING_NUMBERS
  3851. left join BILLING_ACCOUNTS as BA on BA.ID_BILLING_USERS=BAF.ID_BILLING_USERS
  3852. left join BILLS_FVAT on BILLS_FVAT.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS
  3853. left join BILLS_KORV on BILLS_KORV.ID_BILLING_NUMBERS=BAF.ID_BILLING_NUMBERS
  3854. left join BILLING_ACCOUNTS_FILES as BAF_TRG on ( BAF.ID_FIN_WINIEN=BAF_TRG.ID_BILLING_NUMBERS or BAF.ID_FIN_MA=BAF_TRG.ID_BILLING_NUMBERS )
  3855. left join BILLING_NUMBERS as BAF_TRG_BN on ( BAF_TRG.ID_BILLING_NUMBERS=BAF_TRG_BN.ID )
  3856. left join BILLING_ACCOUNTS_FILES as BAF_MA on ( BAF_MA.ID_FIN_WINIEN=BAF.ID_BILLING_NUMBERS or BAF_MA.ID_FIN_MA=BAF.ID_BILLING_NUMBERS )
  3857. left join BILLING_NUMBERS as BAF_BN_MA on ( BAF_BN_MA.ID=BAF_MA.ID_BILLING_NUMBERS )
  3858. left join BILLING_ACCOUNTS_TILL on (BILLING_ACCOUNTS_TILL.ID_BILLING_USERS=BAF.ID_BILLING_USERS and BILLING_ACCOUNTS_TILL.TILL=year(now())-1 )
  3859. where
  3860. ( BAF.ID_FIN_WINIEN is NULL and BAF.ID_FIN_MA is NULL or year(BAF_TRG_BN.TIMESTAMP)>year(NOW())-1 )
  3861. and BAF.ID_BILLING_USERS='1047' AND YEAR(BN.TIMESTAMP)<YEAR(NOW())
  3862. and (YEAR(BAF_BN_MA.TIMESTAMP)<YEAR(NOW()) or BAF_BN_MA.TIMESTAMP is NULL )
  3863. $WHERE
  3864. limit 1000,1000 ;
  3865. ";
  3866. }//EOF if saldo_rok param
  3867. $sql_alter = "alter table TEMP_BILLING_ACCOUNTS_FILES
  3868. modify ID_FIN_MA int(11)
  3869. , modify ID_BILLING_NUMBERS_TYPE_M int(2)
  3870. , modify NUMBER_M int(10)
  3871. , modify ID_BILLING_PREFIXES_M int(2) default NULL NULL
  3872. , modify TIMESTAMP_M int(10)
  3873. , modify ID_FIN_MA_VAL decimal(10,2)
  3874. , modify ID_BILLING_PREFIXES int(2) default NULL NULL
  3875. , modify ID_BILLING_PREFIXES_W int(2) default NULL NULL
  3876. ";
  3877. $db_webone->query( "drop TEMPORARY table TEMP_BILLING_ACCOUNTS_FILES" );
  3878. $result_create = $db_webone->query( $sql );
  3879. $result_alter = $db_webone->query( $sql_alter );
  3880. $result_create2 = $db_webone->query( $sql2 );
  3881. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">db_webone: ';print_r($db_webone);echo'</pre>';
  3882. $sql = "select * from TEMP_BILLING_ACCOUNTS_FILES order by ID_BILLING_USERS,ID ";
  3883. $sql_count = "select count(1) as cnt from TEMP_BILLING_ACCOUNTS_FILES ";
  3884. $count = 0;
  3885. $res = $db_webone->query( $sql_count );
  3886. if ($r_count = $db_webone->fetch( $res )) {
  3887. $count = $r_count->cnt;
  3888. }
  3889. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">count: ';print_r($count);echo'</pre>';
  3890. if ($count > 0 && $ID_BILLING_USERS_PARAM > 0) {
  3891. $result = $db_webone->query($sql);
  3892. } else {
  3893. $sql_none = "insert into TEMP_BILLING_ACCOUNTS_FILES (ID,ID_BILLING_USERS,BAT_TILL,BAT_WINIEN,BAT_MA)
  3894. select '0',ID_BILLING_USERS,TILL ,WINIEN ,MA from BILLING_ACCOUNTS_TILL where ID_BILLING_USERS='$ID_BILLING_USERS_PARAM' and TILL=YEAR(NOW())-1
  3895. ";
  3896. $db_webone->query( $sql_none );
  3897. $result = $db_webone->query($sql);
  3898. }
  3899. while ($h_baf = $db_webone->fetch_row($result)) {
  3900. $baf []= $h_baf;
  3901. }
  3902. return $baf;
  3903. }
  3904. function update_doc_number( &$fvat_arr ) {
  3905. $fetch_ids = array();
  3906. foreach ($fvat_arr as $k => $fvat) {
  3907. $fetch_ids []= $fvat['ID_BILLING_NUMBERS'];
  3908. }//end foreach
  3909. if (!empty($fetch_ids)) {
  3910. $db_webone = DB::getDB('931');
  3911. if (!$db_webone) {
  3912. return -1;
  3913. }
  3914. $sql = "select `ID`, `NUMBER`, `ID_BILLING_PREFIXES`
  3915. from `BILLING_NUMBERS`
  3916. where
  3917. `ID` in(".implode(",", $fetch_ids).")
  3918. ";
  3919. $res = $db_webone->query( $sql );
  3920. $bnum = array();
  3921. while ($h = $db_webone->fetch_assoc( $res )) {
  3922. $bnum [ $h['ID'] ] = $h;
  3923. }
  3924. foreach ($bnum as $k_id => $bn) {
  3925. foreach ($fvat_arr as $k_fvat => $fvat) {
  3926. if ($bn['ID'] == $fvat['ID_BILLING_NUMBERS']) {
  3927. $fvat_arr[ $k_fvat ]['NUMBER'] = $bn['NUMBER'];
  3928. $fvat_arr[ $k_fvat ]['ID_BILLING_PREFIXES'] = $bn['ID_BILLING_PREFIXES'];
  3929. }
  3930. }//end foreach
  3931. }//end foreach
  3932. }
  3933. }
  3934. /**
  3935. * @param $user - Windykacja status user
  3936. * @param $taks - wezwanie1, wezwanie2
  3937. * @param $id_proj - ID Projektu
  3938. * @returns int - ID created record
  3939. */
  3940. function create_koresp($user, $task, $id_proj, $params = array()) {
  3941. $sql_data = array();
  3942. $sql_zawartosc = '';
  3943. if ($task == 'wezwanie1') {
  3944. $sql_zawartosc = 'wezwanie do zaplaty';
  3945. $sql_data['K_TYP_KORESP'] = 'OUT';
  3946. $sql_data['K_TYP_RODZAJ'] = 'POLECONY';
  3947. $sql_data['K_LOKALIZACJA'] = 'PROJEKT';
  3948. $sql_data['K_LOKALIZACJA_NEW'] = 'PROJEKT';
  3949. } else if ($task == 'wezwanie2') {
  3950. $sql_zawartosc = 'wezwanie do zaplaty - ostateczne';
  3951. $sql_data['K_TYP_KORESP'] = 'OUT';
  3952. $sql_data['K_TYP_RODZAJ'] = 'POLECONY';
  3953. $sql_data['K_LOKALIZACJA'] = 'PROJEKT';
  3954. $sql_data['K_LOKALIZACJA_NEW'] = 'PROJEKT';
  3955. } else if ($task == 'rozwiazanie umowy') {
  3956. $sql_zawartosc = 'rozwiazanie umowy ID ' . $params['nr_umowy'] . ' - ' . $params['powod_desc'];
  3957. $sql_data['K_TYP_KORESP'] = 'IN';
  3958. }
  3959. if (!$sql_zawartosc) {
  3960. return false;
  3961. }
  3962. /**
  3963. * przykładowe wezwania:
  3964. * SELECT * FROM `IN7_DZIENNIK_KORESP` WHERE `K_ZAWARTOS` LIKE '%wezwanie%' ORDER BY `IN7_DZIENNIK_KORESP`.`ID` DESC;
  3965. * przykład:
  3966. * SELECT * FROM `IN7_DZIENNIK_KORESP` WHERE `ID`=25951;
  3967. */
  3968. $db = DB::getDB();
  3969. $sql_obj = new stdClass();
  3970. $sql_obj->A_STATUS = 'WAITING';
  3971. foreach ($sql_data as $k_field => $v_value) {
  3972. $sql_obj->$k_field = $v_value;
  3973. }
  3974. $sql_obj->ID_BILLING_USERS = $user->ID;
  3975. $sql_obj->K_DATA_OTRZYM_KORESP = '';// data ?
  3976. $sql_obj->K_DATA_OTRZYMANEJ_KORESP = '';// data ?
  3977. $sql_obj->K_OD_KOGO = "{$user->P_NAME} {$user->P_NAME_SECOND}";
  3978. $sql_obj->OD_KOGO_ADRES = "ul. {$user->P_ADDRESS_STREET} {$user->P_ADDRESS_HOUSE}/{$user->P_ADDRESS_HOME}, {$user->P_ADDRESS_POST_CODE} {$user->P_ADDRESS_CITY}";
  3979. $sql_obj->K_ZAWARTOS = $sql_zawartosc;
  3980. $sql_obj->K_ZNAK_REFERENTA = User::getFullName() . ' (' . User::getInicjaly() . ')';
  3981. $sql_obj->ID_PROJECT = $id_proj;
  3982. $ret_id = $db->ADD_NEW_OBJ('IN7_DZIENNIK_KORESP', $sql_obj);
  3983. return $ret_id;
  3984. }
  3985. /**
  3986. * @param int $user_id - IS klienta
  3987. * @param int $id_deals_old - ID umowy do wyłączenia
  3988. * @param date 'Y-m-d' $termin_odlaczenia - Termin odłączenia
  3989. * @returns int - ID created record
  3990. */
  3991. function create_deals_rozwiazanie($user_id, $id_deals_old, $termin_odlaczenia, $powod_desc = '') {
  3992. $db = DB::getDB();
  3993. $old_deal = $db->get_by_id('DEALS_TABLE', $id_deals_old);
  3994. if (!$old_deal) {
  3995. return false;
  3996. }
  3997. $sql_obj = new stdClass();
  3998. $sql_obj->DEALDESC = "Rezygnacja z dniem {$termin_odlaczenia}";
  3999. $sql_obj->A_STATUS = 'WAITING';
  4000. $sql_obj->ID_BILLING_USERS = $user_id;
  4001. $sql_obj->P_DEALNUMBER_OLD = $old_deal->ID;
  4002. $sql_obj->S_ADDRESS_STREET = $old_deal->S_ADDRESS_STREET;
  4003. $sql_obj->P_DEALDATE = $old_deal->P_DEALDATE;
  4004. $sql_obj->P_DEALDATE_TERM = $old_deal->P_DEALDATE_TERM;
  4005. $sql_obj->L2_HANGUP_FROM = $termin_odlaczenia;
  4006. $sql_obj->RODZAJ_DZIALANIA_HANDLOWEGO = $powod_desc;
  4007. // TODO: $sql_obj->ID_OFFERS_OFF = get_active_services_id($old_deal->ID);
  4008. /*
  4009. if(
  4010. SV.HANGUP_STATUS=SV.A_STATUS
  4011. , coalesce(SV.A_STATUS)
  4012. , if(
  4013. ( unix_timestamp(NOW()) > unix_timestamp(SV.HANGUP_FROM)
  4014. and ( SV.HANGUP_TILL='0000-00-00' or SV.HANGUP_TILL is NULL )
  4015. and ( SV.HANGUP_FROM<>'0000-00-00' and SV.HANGUP_FROM is not null )
  4016. )
  4017. , coalesce(SV.HANGUP_STATUS)
  4018. , if(
  4019. ( unix_timestamp(NOW()) < unix_timestamp(SV.HANGUP_FROM)
  4020. and (SV.HANGUP_TILL='0000-00-00' or SV.HANGUP_TILL is NULL )
  4021. and ( SV.HANGUP_FROM<>'0000-00-00' and SV.HANGUP_FROM is not null )
  4022. )
  4023. , coalesce(SV.A_STATUS)
  4024. , if(
  4025. ( unix_timestamp(NOW()) > unix_timestamp(SV.HANGUP_FROM)
  4026. and unix_timestamp(NOW()) < unix_timestamp(SV.HANGUP_TILL)
  4027. and ( SV.HANGUP_TILL<>'0000-00-00' and SV.HANGUP_TILL is not NULL )
  4028. and ( SV.HANGUP_FROM<>'0000-00-00' and SV.HANGUP_FROM is not null )
  4029. )
  4030. , coalesce(SV.HANGUP_STATUS)
  4031. , if(
  4032. ( unix_timestamp(NOW()) < unix_timestamp(SV.HANGUP_FROM) and unix_timestamp(NOW())< unix_timestamp(SV.HANGUP_TILL)
  4033. and ( SV.HANGUP_TILL<>'0000-00-00' and SV.HANGUP_TILL is not NULL )
  4034. and ( SV.HANGUP_FROM<>'0000-00-00' and SV.HANGUP_FROM is not null ))
  4035. , coalesce(SV.A_STATUS)
  4036. , if(
  4037. ( ( SV.HANGUP_TILL='0000-00-00' or SV.HANGUP_TILL is NULL )
  4038. and ( SV.HANGUP_FROM='0000-00-00' or SV.HANGUP_FROM is null ))
  4039. , coalesce(SV.A_STATUS)
  4040. , if( unix_timestamp(NOW()) > unix_timestamp(SV.HANGUP_FROM)
  4041. and unix_timestamp(NOW()) > unix_timestamp(SV.HANGUP_TILL)
  4042. and (
  4043. ( SV.HANGUP_TILL<>'0000-00-00' and SV.HANGUP_TILL is not NULL )
  4044. and ( SV.HANGUP_FROM<>'0000-00-00' and SV.HANGUP_FROM is not null )
  4045. )
  4046. , coalesce(SV.A_STATUS)
  4047. , if(
  4048. unix_timestamp(NOW()) > unix_timestamp(SV.HANGUP_FROM)
  4049. and unix_timestamp(NOW()) > unix_timestamp(SV.HANGUP_TILL)
  4050. and SV.HANGUP_FROM<SV.HANGUP_TILL
  4051. and (
  4052. ( SV.HANGUP_TILL<>'0000-00-00' and SV.HANGUP_TILL is not NULL )
  4053. and ( SV.HANGUP_FROM<>'0000-00-00' and SV.HANGUP_FROM is not null )) , 'ERROR1',
  4054. 'ERROR2'
  4055. )
  4056. )
  4057. )
  4058. )
  4059. )
  4060. )
  4061. )
  4062. )
  4063. */
  4064. /*
  4065. $id_offers_off = array();
  4066. $sql = "select
  4067. s.``
  4068. , s.`ID_OFFERS`
  4069. from `SERVICES` as s
  4070. where
  4071. s.`ID_DEALS_TABLE`='{$old_deal->ID}'
  4072. and s.`ID_BILLING_USERS`='{$user_id}'
  4073. ";
  4074. $res = $db->query($sql);
  4075. while ($r = $db->fetch($res)) {
  4076. $id_offers_off []= $r;
  4077. }
  4078. */
  4079. $ret_id = $db->ADD_NEW_OBJ('DEALS_TABLE', $sql_obj);
  4080. return $ret_id;
  4081. }
  4082. }
  4083. class Lay_Html_Toggle {
  4084. function start( $title, $attrs = array() ){
  4085. $cls = array();
  4086. $cls []= 'may-hide';
  4087. if (array_key_exists('open', $attrs) && $attrs['open'] == false) $cls []= 'hide';
  4088. echo'<div class="'.implode(' ', $cls).'">';
  4089. $st = array();
  4090. $st []= 'margin-bottom:0';
  4091. if (!empty($attrs['color'])) $st []= 'color:'.$attrs['color'];
  4092. echo'<h4 style="'.implode(';', $st).'">'.$title;
  4093. echo'<a class="btn-hide" href="#" onclick="'."return hide(this);".'">'."-".'</a>';
  4094. echo'<a class="btn-show" href="#" onclick="'."return hide(this);".'">'."+".'</a>';
  4095. echo'</h4>';
  4096. echo'<div class="to-hide">';
  4097. }
  4098. function end(){
  4099. echo'</div>';// .to-hide
  4100. echo'</div>';// .may-hide'
  4101. }
  4102. function show_js() {
  4103. echo'<script type="text/javascript">'."
  4104. function hide( n ){
  4105. jQuery(n).parent().parent().toggleClass('hide');
  4106. return false;
  4107. }
  4108. ".'</script>';
  4109. }
  4110. }
  4111. class FunkcjeL1 {
  4112. function bankowy_make_nrach($NR_RACH_MASS_PAY,$ID_BILLING_USERS,$ID_BILLING_NUMBERS) {
  4113. //echo "TTUTAJ <hr> AASDADS f. bankowy_make_nrach($NR_RACH_MASS_PAY,$ID_BILLING_USERS,$ID_BILLING_NUMBERS) <br>";
  4114. $ID_BILLING_USERS=str_pad($ID_BILLING_USERS,10,0,STR_PAD_LEFT) ;
  4115. $ID_BILLING_NUMBERS=str_pad($ID_BILLING_NUMBERS,2,0,STR_PAD_LEFT) ;
  4116. $ID_BILLING_NUMBERS=substr($ID_BILLING_NUMBERS,-2) ;
  4117. $NN = self::bankowy_make($NR_RACH_MASS_PAY.$ID_BILLING_NUMBERS.$ID_BILLING_USERS) ;
  4118. if($NN) return $NN.$NR_RACH_MASS_PAY.$ID_BILLING_NUMBERS.$ID_BILLING_USERS ;
  4119. }
  4120. function bankowy_make($nrb) {
  4121. $nrb=preg_replace("/[^0-9]/","",$nrb);
  4122. if (strlen($nrb)<>24) return 0;
  4123. $nrb .="252100";
  4124. $modulo=self::my_bcmod($nrb,97) ;
  4125. $modulo= 98 - $modulo ;
  4126. if(strlen($modulo)==1) $modulo="0".$modulo ;
  4127. return $modulo ;
  4128. if ($nrb[0]==$liczba[0] and $nrb[1]==$liczba[1]){
  4129. return 1;
  4130. }
  4131. return 0;
  4132. }
  4133. function my_bcmod( $x, $y ) {
  4134. // how many numbers to take at once? carefull not to exceed (int)
  4135. $take = 5;
  4136. $mod = '';
  4137. do
  4138. {
  4139. $a = (int)$mod.substr( $x, 0, $take );
  4140. $x = substr( $x, $take );
  4141. $mod = $a % $y;
  4142. }
  4143. while ( strlen($x) );
  4144. return (int)$mod;
  4145. }
  4146. function bankowy_formatuj_nrach($NR_RACH_MASS_PAY) {
  4147. $NR_RACH_MASS_PAY_FORMATTED = '';
  4148. if ($NR_RACH_MASS_PAY) {
  4149. for ($i=4; $i<(strlen($NR_RACH_MASS_PAY)); $i=$i+4) {
  4150. $NR_RACH_MASS_PAY_FORMATTED = " ".substr($NR_RACH_MASS_PAY,-$i,4).$NR_RACH_MASS_PAY_FORMATTED;
  4151. }
  4152. $NR_RACH_MASS_PAY_FORMATTED = substr($NR_RACH_MASS_PAY,0,$i-strlen($NR_RACH_MASS_PAY))." ".$NR_RACH_MASS_PAY_FORMATTED;
  4153. }
  4154. return $NR_RACH_MASS_PAY_FORMATTED ;
  4155. }
  4156. function policz($l,$t1,$t2,$t3) {
  4157. $j = array("", "jeden ", "dwa ", "trzy ", "cztery ", "pięć ", "sześć ",
  4158. "siedem ", "osiem ", "dziewięć ", "dziesięć ", "jedenaście ",
  4159. "dwanaście ", "trzynaście ", "czternaście ", "piętnaście ",
  4160. "szesnaście ", "siedemnaście ", "osiemnaście ", "dziewiętnaście ");
  4161. $d = array("", "", "dwadzieścia ", "trzydzieści ", "czterdzieści ",
  4162. "pięćdziesiąt ", "sześćdziesiąt ", "siedemdziesiąt ",
  4163. "osiemdziesiąt ", "dziewięćdziesiąt ");
  4164. $s = array("","sto ", "dwieście ", "trzysta ", "czterysta ", "pięćset ",
  4165. "sześćset ", "siedemset ", "osiemset ", "dziewięćset ");
  4166. $txt = $s[0+substr($l,0,1)];
  4167. if (substr($l,1,2)<20) {
  4168. $txt .= $j[0+substr($l,1,2)];
  4169. }
  4170. else {
  4171. $txt .= $d[0+substr($l, 1,1)].$j[0+substr($l, 2,1)];
  4172. }
  4173. if ($l<>0) {
  4174. if ($l==1) {
  4175. $txt .= "$t1 ";
  4176. } else {
  4177. if ((substr($l,2,1)==2 or substr($l,2,1)==3 or substr($l,2,1)==4) and (substr($l,1,2)>20 or substr($l,1,2)<10)) {
  4178. $txt .= "$t2 ";
  4179. } else {
  4180. $txt .= "$t3 ";
  4181. }
  4182. }
  4183. }
  4184. return $txt;
  4185. }
  4186. function slownie( $liczba ) {
  4187. $txt = '';
  4188. $kwota = explode(".", $liczba);
  4189. if (strlen($kwota[1])==1) $kwota[1] = $kwota[1]."0";
  4190. $kwotazl = sprintf("%012d",$kwota[0]);
  4191. $kwotagr = sprintf("%03d",$kwota[1]);
  4192. $txt .= self::policz(substr($kwotazl, 0,3),"miliard","miliardy","miliardów");
  4193. $txt .= self::policz(substr($kwotazl, 3,3),"milion","miliony","milionów");
  4194. $txt .= self::policz(substr($kwotazl, 6,3),"tysiąc","tysiące","tysięcy");
  4195. $txt .= self::policz(substr($kwotazl, 9,3),"złoty","złote","złotych");
  4196. if ($kwotazl==0) $txt .= "zero złotych ";
  4197. $txt .= " i ";
  4198. $txt .= self::policz($kwotagr,"grosz","grosze","groszy");
  4199. if ($kwotagr==0) $txt .= "zero groszy";
  4200. return $txt;
  4201. }
  4202. function formatuj_grosze( $kwota ) {
  4203. $kwota = round($kwota, 2);
  4204. $liczba = explode(".", $kwota);
  4205. if (!$liczba[1]) {
  4206. $liczba = explode(",", $kwota);
  4207. if (!$liczba[1]) $liczba[1] = "00";
  4208. }
  4209. if (strlen($liczba[1]) == 1) $liczba[1] = $liczba[1] . "0";
  4210. $liczba_out = $liczba[0] . "." . "$liczba[1]";
  4211. return $liczba_out;
  4212. }
  4213. function billing_billwiev_przeterminowania($ID_BILLING_USERS_PARAM, $IF_PRINT_PARAM, $ECHO_PARAM) {
  4214. global $vdb
  4215. , $STOPA_ODSETEK // from billing-l1/www/config.php
  4216. , $form_mail_sender // billing-l1/www/config.php:24:$form_mail_sender="/usr/bin/mutt";
  4217. , $form_send_from_param // billing-l1/www/config.php:19:$form_send_from_param="biall-net@biall.net.pl";
  4218. ;
  4219. //NAGLOWKI DO HTML MAILA
  4220. $naglowki = "From: ".$form_send_from_param."\r\n";
  4221. $naglowki .= "MIME-Version: 1.0\r\n";
  4222. $naglowki .= "Content-type: text/html; charset=iso-8859-1\r\n";
  4223. //PODRECZNE_ZAPYTANIE_SLOWNIKOWE_DO_TYPOW_DOKUMENTOW
  4224. $BNT = array();
  4225. $bnt_types = WindykacjaStatsModel::get_billing_types();
  4226. foreach ($bnt_types as $k_type_id => $h_type) {
  4227. $BNT[ $h_type['ID'] ] = $h_type['TYPE'];
  4228. }//end foreach
  4229. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">bnt_types: ';print_r($bnt_types);echo'</pre>';
  4230. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">BNT: ';print_r($BNT);echo'</pre>';
  4231. if ($_GET['ID_BILLING_USERS_PARAM']) $ID_BILLING_USERS_PARAM = $_GET['ID_BILLING_USERS_PARAM'];
  4232. if (!$IF_PRINT_PARAM && !$ECHO_PARAM) {
  4233. echo'<p style="text-align:right">';
  4234. echo"<a href=\"javascript:openWindow('/modules/make_billing/edit.php?op=zadluzenia&print=1&FIRMA=1&uid=$ID_BILLING_USERS_PARAM','print','scrollbars,resizable=yes,width=750,height=550')\">";
  4235. echo"<img border=\"0\" src=\"$xpath/ico/kw.gif\" width=\"16\" height=\"16\" alt=\"Zadłużenia\">";
  4236. echo"Druki wezwania do zaplaty";
  4237. echo"</a>";
  4238. echo'</p>';
  4239. }
  4240. $user_id = $ID_BILLING_USERS_PARAM;
  4241. $billing_account_files = WindykacjaStatsModel::get_billing_account_files( $user_id );
  4242. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">billing_account_files: ';print_r($billing_account_files);echo'</pre>';
  4243. die('F.' . __FUNCTION__ . ' ...');
  4244. $NAGLOWEK = "<table border=\"1\" width=\"100%\"><tr><td>Płatnik</td><td>WINIEN</td><td>MA</td><td>DOK</td><td>Numer</td><td>(T)ermin pł./(D)ata ksiegowania </td><td>Dni przeterminowania</td><td>Kwota przeterminowana</td><td>Odsetki</td></tr>";
  4245. //while ($BAF = $vdb->sql_fetchrow($result)) {
  4246. foreach ($billing_account_files as $BAF) {
  4247. //RESETUJEMY FORM - jak nie chcemy pojedynczego odczytu:
  4248. if (!$ID_BILLING_USERS_PARAM) unset($FORM);
  4249. if (!$LAST_PLATNIK) $LAST_PLATNIK = $BAF[1];
  4250. if (!$LPD) $LPD = $BAF;
  4251. if (($BAF[0] <> $LAST_ID)) {// ID
  4252. //DRUKUJEMY_STARE_PODSUMOWANIE (DLA_FAKTURY POJEDYNCZEJ)
  4253. if ($LAST_ID) {
  4254. $FORM_2.="<tr><td></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL[WINIEN])."</b></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL[MA])."</b></td><td colspan=\"3\"></td>";
  4255. $FORM_S.= "<tr><td></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL[WINIEN])."</b></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL[MA])."</b></td><td colspan=\"3\"></td>";
  4256. $LDNI = floor((date("U") - $DOC_TERM) / 86400) ;
  4257. if(($LDNI>0) && ($DOC_TERM) && ($LTOTAL['WINIEN_MA'] == "WINIEN")) {
  4258. $LODSETKI= FunkcjeL1::formatuj_grosze( $LTOTAL[$LTOTAL[WINIEN_MA]] * $STOPA_ODSETEK * $LDNI / 365 ) ;
  4259. $POD_ODSETEK=$LTOTAL[$LTOTAL[WINIEN_MA]] ;
  4260. $PLATNIK_DATA[PRZETER][ODSETKI]+=$LODSETKI ;
  4261. $PLATNIK_DATA[PRZETER][WINIEN]+=$LTOTAL[$LTOTAL[WINIEN_MA]] ;
  4262. } else {
  4263. unset($LODSETKI);
  4264. unset($LDNI);
  4265. unset($POD_ODSETEK);
  4266. }
  4267. $FORM_2.= "<td>$LDNI</td><td>$POD_ODSETEK</td>";
  4268. $FORM_2.= "<td>$LODSETKI</td>";
  4269. $FORM_S.= "<td>---</td><td>---</td><td>---</td>";
  4270. // if(!$PLATNIK_DATA[TOTAL][WINIEN])
  4271. $PLATNIK_DATA[TOTAL][WINIEN]+=FunkcjeL1::formatuj_grosze($LTOTAL[WINIEN]) ;
  4272. // if(!$PLATNIK_DATA[TOTAL][MA])
  4273. $PLATNIK_DATA[TOTAL][MA]+=FunkcjeL1::formatuj_grosze($LTOTAL[MA]) ;
  4274. $FORM_2.= "</tr>";
  4275. $FORM_2.= "<tr><td colspan=\"6\"><hr></td></tr>";
  4276. $FORM_S.="</tr><tr><td colspan=\"6\"><hr></td></tr>";
  4277. $TOTAL[WINIEN]+=$LTOTAL[WINIEN] ; $TOTAL[MA]+=$LTOTAL[MA] ;
  4278. if ($LAST_PLATNIK <> $BAF[1]) {//PODSUMOWANIE_DLA_PLATNIKA
  4279. $TOTAL[PRZETER]+=$PLATNIK_DATA[PRZETER][WINIEN];
  4280. $TOTAL[ODSETKI]+=$PLATNIK_DATA[PRZETER][ODSETKI];
  4281. $FORM_2.= "<tr><td colspan=\"9\">Podsumowanie salda niezbilansowanych zobowiązań dla platnika $LAST_PLATNIK
  4282. $LPD[P_NAME] $LPD[P_NAME_SECOND] $LPD[P_ADDRESS_CITY] $LPD[P_ADDRESS_STREET] $LPD[P_ADDRESS_HOUSE] $LPD[P_ADDRESS_HOME]
  4283. <br> WINIEN: <b>".$PLATNIK_DATA[TOTAL][WINIEN]."</b> - MA: <b>".$PLATNIK_DATA[TOTAL][MA]."</b> DO ZAPŁATY: <b>".FunkcjeL1::formatuj_grosze($PLATNIK_DATA[TOTAL][WINIEN]-$PLATNIK_DATA[TOTAL][MA])."</b> " ;
  4284. if($PLATNIK_DATA[PRZETER][WINIEN]) $FORM_2.=", z czego przeterminowane <font color=\"red\"><b> ".FunkcjeL1::formatuj_grosze($PLATNIK_DATA[PRZETER][WINIEN])." </b></font> ";
  4285. if($PLATNIK_DATA[PRZETER][ODSETKI]) $FORM_2.= " ( aktualnie nalezne odsetki to ".$PLATNIK_DATA[PRZETER][ODSETKI]." PLN , które mogą zostać naliczone ) " ;
  4286. if($LPD[BA_TIMESTAMP]) $FORM_2.=" <br> Stan wzajemnych rozrachunków: WINIEN: <b>$LPD[BA_WINIEN]</b> - MA: <b>$LPD[BA_MA]</b> SALDO(DO ZAPŁATY): <b>".FunkcjeL1::formatuj_grosze($LPD[BA_WINIEN]-$LPD[BA_MA])."</b> , i jest to stan na dzień ".date("Y-m-d",$LPD[BA_TIMESTAMP])." ";
  4287. $RETURN_ARR="";
  4288. $FORM_S.="<tr><td colspan=\"9\"></td></tr></table>";
  4289. $FORM_2.="<br>W razie problemów prosimy o kontakt z biurem obsługi. <br><font size=\"1\" color=\"#CCCCCC\">webone billing system &copy;2004 by Arkadiusz Binder & www.grafnet.pl | finance module by A.Binder </font>";
  4290. $FORM_2.= " </tr></table>";
  4291. $FORM_2 = $NAGLOWEK . " \n " . $FORM_2 ;
  4292. $FORM_S= $NAGLOWEK . " \n " . $FORM_S ;
  4293. if ($IF_PRINT_PARAM) {
  4294. $delivery_subject="Stan rozrachunków dla $LPD[P_NAME] $LPD[P_NAME_SECOND]" ;
  4295. $sql2="insert into HIST_CONTACTS (ID_BILLING_USERS,ID_BILLING_NUMBERS,SUBJECT,BODY_HTML,REQUEST_STATUS_MAIL) values
  4296. ('".$LAST_PLATNIK."','','$delivery_subject','$FORM_2','CONFIRM_SENT_MAIL') ";
  4297. $res = $vdb->sql_query($sql2) ;
  4298. echo "<hr> $sql2 <hr>****";
  4299. } else if (!$ECHO_PARAM) {
  4300. echo $FORM_2;
  4301. }
  4302. $LAST_PLATNIK=$BAF[1];
  4303. unset($PLATNIK_DATA);
  4304. $FORM.=$FORM_2 ;
  4305. unset($FORM_2);
  4306. $FORM_SS.=$FORM_S ;
  4307. unset($FORM_S);
  4308. } else {
  4309. }
  4310. //$PLATNIK_DATA[TOTAL][WINIEN]+=$BAF[2];
  4311. //$PLATNIK_DATA[TOTAL][MA]+=$BAF[3];
  4312. $LPD = $BAF;
  4313. $LAST_PLATNIK = $BAF[1];
  4314. }
  4315. else {
  4316. }
  4317. //DODAJEMY_NOWY_REKORD_OD_SAMEJ_PLATNOSCI
  4318. unset($LTOTAL);
  4319. $FORM_2.= "<tr><td>$BAF[1]</td><td>$BAF[2]</td><td>$BAF[3]</td><td>".$BNT[$BAF[4]]."</td><td>$BAF[5]/$BAF[6]</td> <td colspan=\"1\">";
  4320. if ($BAF[19]) $FORM_2.="T: ".date("Y-m-d",$BAF[19])." "; else $FORM_2.="D: ".date("Y-m-d",$BAF['BAF_TIMESTAMP'])." ";
  4321. $FORM_2.="</td></tr>";
  4322. $FORM_S.= "<tr><td>$BAF[1]</td><td>$BAF[2]</td><td>$BAF[3]</td><td>".$BNT[$BAF[4]]."</td><td>$BAF[5]/$BAF[6]</td> <td colspan=\"1\">";
  4323. if($BAF[19])$FORM_S.="T: ".date("Y-m-d",$BAF[19])." "; else $FORM_2.="D: ".date("Y-m-d",$BAF['BAF_TIMESTAMP'])." ";
  4324. $FORM_S.="</td></tr>";
  4325. $DOC_TERM = $BAF[19];
  4326. if ($BAF[2] > 0) $LTOTAL['WINIEN_MA'] = "WINIEN"; else $LTOTAL['WINIEN_MA'] = "MA";
  4327. $LTOTAL[$LTOTAL['WINIEN_MA']] = $BAF[2] + $BAF[3];
  4328. } else {
  4329. //DRUKUJEMY_PODSTUMOWANIE_STAREGO i ZAPODAJEMY NOWY_REKORD
  4330. }
  4331. if ($BAF[12]) {// ID_FIN_WINIEN_VAL
  4332. $FORM_2.= "<tr><td colspan=\"1\"></td>";
  4333. $FORM_S.= "<tr><td colspan=\"1\"></td>";
  4334. if($LTOTAL['WINIEN_MA']=="MA") {
  4335. $FORM_2.= "<td><font color=\"green\"><b> $BAF[12] </b> </font></td>";
  4336. $FORM_2.= "<td></td>";
  4337. $FORM_S.="<td><font color=\"green\"><b> $BAF[12] </b> </font></td><td></td>";
  4338. } else {
  4339. $FORM_2.= "<td></td>";
  4340. $FORM_2.= "<td><font color=\"green\"><b> $BAF[12] </b> </font></td>";
  4341. $FORM_S.="<td></td><td><font color=\"green\"><b> $BAF[12] </b> </font></td>";
  4342. }
  4343. $FORM_2.= "<td>".$BNT[$BAF[8]]."</td>";
  4344. $FORM_2.= "<td> $BAF[9]/$BAF[10] </td><td>D: ".date("Y-m-d",$BAF[11])."</td> ";
  4345. $FORM_S.= "<td>".$BNT[$BAF[8]]."</td>";
  4346. $FORM_S.= "<td> $BAF[9]/$BAF[10] </td><td>D: ".date("Y-m-d",$BAF[11])."</td> ";
  4347. $LDNI = floor(($BAF[11] - $DOC_TERM) / 86400);
  4348. if (($LDNI > 0) && ($DOC_TERM) && ($LTOTAL['WINIEN_MA'] == "WINIEN")) {
  4349. $DOC_TERM = $BAF[11];
  4350. $LODSETKI = FunkcjeL1::formatuj_grosze( $LTOTAL[$LTOTAL['WINIEN_MA']] * $STOPA_ODSETEK * $LDNI / 365 );
  4351. $POD_ODSETEK = $LTOTAL[$LTOTAL['WINIEN_MA']];
  4352. $PLATNIK_DATA['PRZETER']['ODSETKI'] += $LODSETKI;
  4353. } else {
  4354. unset($LODSETKI);
  4355. unset($LDNI);
  4356. unset($POD_ODSETEK);
  4357. }
  4358. $FORM_2.= "<td>$LDNI</td><td>$POD_ODSETEK</td>";
  4359. $FORM_2.= "<td>$LODSETKI</td>";
  4360. $FORM_2.= "</tr>";
  4361. $FORM_S.="<td>---</td><td>---</td><td>---</td></tr>";
  4362. $LTOTAL[$LTOTAL['WINIEN_MA']] -= $BAF[12];
  4363. }
  4364. if ($BAF[18]) {// ID_FIN_MA_VAL
  4365. $FORM_2.= "<tr><td colspan=\"1\"></td>";
  4366. $FORM_S.= "<tr><td colspan=\"1\"></td>";
  4367. if ($LTOTAL['WINIEN_MA'] == "MA") {
  4368. $FORM_2.= "<td><font color=\"red\"><b> $BAF[18] </b> </font></td>";
  4369. $FORM_2.= "<td></td>";
  4370. $FORM_S.= "<td><font color=\"red\"><b> $BAF[18] </b> </font></td><td></td>";
  4371. } else {
  4372. $FORM_2.= "<td></td>";
  4373. $FORM_2.= "<td><font color=\"red\"><b> $BAF[18] </b> </font></td>";
  4374. $FORM_S.="<td></td><td><font color=\"red\"><b> $BAF[18] </b> </font></td>";
  4375. }
  4376. $FORM_2.= "<td>".$BNT[$BAF[14]]."</td>";
  4377. $FORM_2.= "<td> $BAF[15]/$BAF[16] </td> <td>D: ".date("Y-m-d",$BAF[17])."</td> ";
  4378. $FORM_S.="<td>".$BNT[$BAF[14]]."</td> <td> $BAF[15]/$BAF[16] </td> <td>D: ".date("Y-m-d",$BAF[17])."</td> ";
  4379. $LDNI=floor(($BAF[17] - $DOC_TERM) / 86400) ;
  4380. // $LDNI=10;
  4381. if (($LDNI > 0) && ($DOC_TERM) && ($LTOTAL['WINIEN_MA'] == "WINIEN")) {
  4382. $LODSETKI = FunkcjeL1::formatuj_grosze( $LTOTAL[$LTOTAL[WINIEN_MA]] * $STOPA_ODSETEK * $LDNI / 365 ) ;
  4383. $POD_ODSETEK = $LTOTAL[$LTOTAL['WINIEN_MA']];
  4384. $PLATNIK_DATA['PRZETER']['ODSETKI'] += $LODSETKI;
  4385. } else {
  4386. unset($LODSETKI);
  4387. unset($LDNI);
  4388. unset($POD_ODSETEK);
  4389. }
  4390. $FORM_2.= "<td>$LDNI</td><td>$POD_ODSETEK</td>";
  4391. $FORM_S.= "<td>$LDNI</td><td>$POD_ODSETEK</td>";
  4392. $FORM_2.= "<td>$LODSETKI</td>";
  4393. $FORM_S.= "<td>$LODSETKI</td>";
  4394. $FORM_2.= "</tr>";
  4395. $FORM_S.= "</tr>";
  4396. $LTOTAL[$LTOTAL['WINIEN_MA']]-=$BAF[18] ;
  4397. }
  4398. $LAST_ID = $BAF[0];
  4399. $L_BAF = $BAF;
  4400. }//eof SQL while($BAF=$vdb->sql_fetchrow($result)) {
  4401. //DODANIE_ZESTAWIENIA KOPIA_Z_GORY
  4402. //DRUKUJEMY_STARE_PODSUMOWANIE (DLA_FAKTURY POJEDYNCZEJ)
  4403. if ($LAST_ID) {
  4404. $FORM_2.="<tr><td></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL['WINIEN'])."</b></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL['MA'])."</b></td><td colspan=\"3\"></td>";
  4405. $FORM_S.="<tr><td></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL['WINIEN'])."</b></td><td><b>".FunkcjeL1::formatuj_grosze($LTOTAL['MA'])."</b></td><td colspan=\"3\"></td>";
  4406. $LDNI = round((date("U") - $DOC_TERM) / 86400, 0);
  4407. if (($LDNI > 0) && ($DOC_TERM)) {
  4408. $LODSETKI = FunkcjeL1::formatuj_grosze( $LTOTAL[$LTOTAL['WINIEN_MA']] * $STOPA_ODSETEK * $LDNI / 365);
  4409. $POD_ODSETEK = $LTOTAL[$LTOTAL['WINIEN_MA']];
  4410. $PLATNIK_DATA['PRZETER']['ODSETKI'] += $LODSETKI ;
  4411. $PLATNIK_DATA['PRZETER']['WINIEN'] += $LTOTAL[$LTOTAL['WINIEN_MA']];
  4412. } else {
  4413. unset($LODSETKI);
  4414. unset($LDNI);
  4415. unset($POD_ODSETEK);
  4416. }
  4417. $FORM_2.= "<td>$LDNI</td><td>".FunkcjeL1::formatuj_grosze($POD_ODSETEK)."</td>";
  4418. $FORM_2.= "<td>$LODSETKI</td>";
  4419. $FORM_S.="<td>---</td><td>---</td><td>---</td>";
  4420. // if(!$PLATNIK_DATA[TOTAL]['WINIEN'])
  4421. $PLATNIK_DATA['TOTAL']['WINIEN']+=FunkcjeL1::formatuj_grosze($LTOTAL['WINIEN']) ;
  4422. // if(!$PLATNIK_DATA[TOTAL][MA])
  4423. $PLATNIK_DATA['TOTAL']['MA']+=FunkcjeL1::formatuj_grosze($LTOTAL['MA']) ;
  4424. $FORM_2.= "</tr>";
  4425. $FORM_2.= "<tr><td colspan=\"6\"><hr></td></tr>";
  4426. $FORM_S.="</tr><tr><td colspan=\"6\"><hr></td></tr>";
  4427. $TOTAL['WINIEN']+=$LTOTAL['WINIEN'] ; $TOTAL['MA']+=$LTOTAL['MA'] ;
  4428. if ($LAST_PLATNIK <> $BAF[1]) {//PODSUMOWANIE_DLA_PLATNIKA
  4429. $TOTAL['PRZETER'] += $PLATNIK_DATA['PRZETER']['WINIEN'];
  4430. $TOTAL['ODSETKI'] += $PLATNIK_DATA['PRZETER']['ODSETKI'];
  4431. if (!$LPD) $LPD = $L_BAF ;
  4432. $FORM_2.= "<tr><td colspan=\"9\">Podsumowanie salda niezbilansowanych zobowiązań dla platnika $LAST_PLATNIK
  4433. $LPD[P_NAME] $LPD[P_NAME_SECOND] $LPD[P_ADDRESS_CITY] $LPD[P_ADDRESS_STREET] $LPD[P_ADDRESS_HOUSE] $LPD[P_ADDRESS_HOME]
  4434. <br> WINIEN: <b>".$PLATNIK_DATA['TOTAL']['WINIEN']."</b> - MA: <b>".$PLATNIK_DATA['TOTAL']['MA']."</b>
  4435. DO ZAPŁATY: <b>".FunkcjeL1::formatuj_grosze($PLATNIK_DATA['TOTAL']['WINIEN']-$PLATNIK_DATA['TOTAL']['MA'])."</b> " ;
  4436. if ($PLATNIK_DATA['PRZETER']['WINIEN']) $FORM_2.=", z czego przeterminowane <font color=\"red\"><b> ".FunkcjeL1::formatuj_grosze($PLATNIK_DATA['PRZETER']['WINIEN'])." </b></font> ";
  4437. if ($PLATNIK_DATA['PRZETER']['ODSETKI']) $FORM_2.= " ( aktualnie nalezne odsetki to ".$PLATNIK_DATA['PRZETER']['ODSETKI']." PLN , które mogą zostać naliczone ) " ;
  4438. if ($LPD['BA_TIMESTAMP']) $FORM_2.=" <br> Stan wzajemnych rozrachunków: WINIEN: <b>".$LPD['BA_WINIEN']."</b> - MA: <b>".$LPD['BA_MA']."</b> SALDO(DO ZAPŁATY): <b>".FunkcjeL1::formatuj_grosze($LPD['BA_WINIEN']-$LPD['BA_MA'])."</b> , i jest to stan na dzień ".date("Y-m-d",$LPD['BA_TIMESTAMP'])." ";
  4439. $RETURN_ARR="";
  4440. $FORM_S.="<tr><td colspan=\"9\"></td></tr></table>";
  4441. $FORM_2.="<br>W razie problemów prosimy o kontakt z biurem obsługi. <br><font size=\"1\" color=\"#CCCCCC\">webone billing system &copy;2004 by Arkadiusz Binder & www.grafnet.pl | finance module by A.Binder </font>";
  4442. $FORM_2.= " </tr></table>";
  4443. $FORM_2 = $NAGLOWEK . " \n " . $FORM_2 ;
  4444. $FORM_S = $NAGLOWEK . $FORM_S ;
  4445. //DRUKOWANIE ZESTAWIENIA
  4446. if ($IF_PRINT_PARAM) {
  4447. $delivery_subject="Stan rozrachunków dla $LPD[P_NAME] $LPD[P_NAME_SECOND]" ;
  4448. // exec("echo \"Pliki zostały dołączone do załącznika\" | $form_mail_sender -n -a \"$filename\" $delivery_mail -s ".$delivery_subject."" );
  4449. $sql2="insert into HIST_CONTACTS (ID_BILLING_USERS,ID_BILLING_NUMBERS,SUBJECT,BODY_HTML,REQUEST_STATUS_MAIL) values
  4450. ('".$LAST_PLATNIK."','','$delivery_subject','$FORM_2','CONFIRM_SENT_MAIL') ";
  4451. $res = $vdb->sql_query($sql2) ;
  4452. echo "<hr> $sql2 <hr>***";
  4453. } else if (!$ECHO_PARAM) {
  4454. echo $FORM_2;
  4455. }
  4456. //EOF DRUKOWANIE ZESTAWIENIA itp
  4457. $LAST_PLATNIK = $BAF[1];
  4458. $ECHO_DATA=$PLATNIK_DATA;
  4459. unset($PLATNIK_DATA);
  4460. $FORM .= $FORM_2 . "</table>" ;
  4461. $FORM_SS .= $FORM_S . "</table>" ;
  4462. unset($FORM_2);
  4463. unset($FORM_S);
  4464. }
  4465. }
  4466. $FORM_2.= $NAGLOWEK;
  4467. $FORM_2.= "<tr><td>TOT</td><td><b>$TOTAL[WINIEN]</b></td><td><b>$TOTAL[MA]</b></td><td colspan=\"4\"></td>
  4468. <td><b>$TOTAL[PRZETER]</b></td><td><b>$TOTAL[ODSETKI]</b></td></tr>";
  4469. $FORM_2 .= "</table>";
  4470. if (!$ECHO_PARAM) echo "$FORM_2";
  4471. $FORM_S.= "</table> ";
  4472. if ($ECHO_PARAM == "zadluzenie") return FunkcjeL1::formatuj_grosze($ECHO_DATA['PRZETER']['WINIEN']);
  4473. if ($ECHO_PARAM == "saldo") return FunkcjeL1::formatuj_grosze($LPD['BA_WINIEN']-$LPD['BA_MA']);
  4474. if ($ECHO_PARAM == "zadluzenie_lista") return $FORM;
  4475. if ($ECHO_PARAM == "saldo_rok") {
  4476. $L_BAF['FORM'] = $FORM;
  4477. $L_BAF['FORM_SALDO'] = $FORM_SS;
  4478. return $L_BAF;
  4479. }
  4480. }
  4481. }