superedit-USERS2_MARKETING_AKCJE.php 103 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623
  1. <?php
  2. /**
  3. * Module AKCJE (?MENU_INIT=USERS2_MARKETING_AKCJE)
  4. *
  5. * TODO: add AKCJA_TYPE enum('ULOTKA','ANKIETA') NOT NULL DEFAULT 'ULOTKA';
  6. * TODO: add FILTR_OPERATOR enum('WSZYSCY', 'TYLKO NASI (BN i ND)', 'TYLO OBCY') NOT NULL DEFAULT 'WSZYSCY'
  7. * TODO: add FILTR_MARKETING_DATA enum('TAK', 'NIE') NOT NULL DEFAULT 'NIE';
  8. * TODO: add FILTR_USLUGI set('NET','TV','TEL') NOT NULL DEFAULT '';
  9. *
  10. *
  11. */
  12. function USERS2_MARKETING_AKCJE() {
  13. global $thiss, $SQL_USER, $SQL_DATABASE, $INTERFACE_ADDR, $SQL_USER_PASS;
  14. require_once dirname(__FILE__) . '/' . 'se-lib' . '/' . 'Lib.php';
  15. Lib::loadClass('V');
  16. Lib::loadClass('DB');
  17. {// DETECT_TABLE_COLUMN();
  18. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_COLUMN';
  19. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE';
  20. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  21. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  22. }
  23. // init columns if not set
  24. if (empty($_SESSION['USERS2_MARKETING_AKCJE'."_COLUMN"])) {
  25. SEF('USERS_COLUMN_INIT2');
  26. USERS_COLUMN_INIT2('USERS2_MARKETING_AKCJE', '', 'RWXC');
  27. }
  28. if (empty($_SESSION['USERS2_MARKETING_AKCJE_BUILDINGS'."_COLUMN"])) {
  29. SEF('USERS_COLUMN_INIT2');
  30. USERS_COLUMN_INIT2('USERS2_MARKETING_AKCJE_BUILDINGS', '', 'RWXC');
  31. }
  32. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["DATA"] = "R";
  33. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["W_DATA_DOSTARCZONO"] = "RWX";
  34. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["W_DATA_WPROWADZONO"] = "RWX";
  35. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["K_DATA_DOSTARCZONO"] = "RWX";
  36. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["K_DATA_WPROWADZONO"] = "RWX";
  37. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  38. //$_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][""] = "";
  39. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["DO_ROZNIESIENIA"] = "R";
  40. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["A_STATUS"] = "R";
  41. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["ROZNIESIONO"] = "R";
  42. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["ID_PROJECT"] = "ID projektu ulotki/plakatu";
  43. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["FILTR_BEZ_BN"] = "Czy pominac operatora BN?";
  44. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["FILTR_ANEKSY"] = "Czy brac pod uwage koniec aktualnej umowy (3-mc przed koncem)";
  45. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["FILTR_MIN_ULOTEK_NA_BUDYNEK"] = "Maksymalne nasycenie na budynku (procent 0-100)";
  46. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["FILTR_MIN_DATA_OSTATNIEJ_AKCJI"] = "Uwzględnij tylko budynki z datą akcji do:";
  47. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["W_USER"] = "Pracownik wykonujacy zadanie";
  48. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["W_DATA"] = "Termin wykonania zadania";
  49. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["K_USER"] = "Kontroler wykonania zadania";
  50. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG']["K_DATA"] = "Termin wykonania kontroli";
  51. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL']['ID_PROJECT'] = 'USERS2_MARKETING_AKCJE_typespecial_ID_PROJECT';
  52. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL']['FILTR_M_REWIR'] = 'USERS2_MARKETING_AKCJE_typespecial_FILTR_M_REWIR';
  53. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL']['FILTR_S_ADDRESS_STREET'] = 'USERS2_MARKETING_AKCJE_typespecial_FILTR_S_ADDRESS_STREET';
  54. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL']['W_USER'] = 'USERS2_MARKETING_AKCJE_typespecial_W_USER';
  55. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL']['K_USER'] = 'USERS2_MARKETING_AKCJE_typespecial_K_USER';
  56. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['HIDE'][ $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_KEY']["FILTR_M_REWIR"] ] = 'HIDE';
  57. // router
  58. global $ARG1,$ARG1_VAL;
  59. switch ($ARG1) {
  60. case 'ADD': {
  61. if (isset($_POST)) {
  62. // update new record in session
  63. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  64. if (strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][$field_name], "C")) {
  65. if (isset($_POST[$field_name])) {
  66. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$field_name] = $_POST[$field_name];
  67. }
  68. }
  69. }//end foreach
  70. }
  71. if (isset($_POST['task'])) {
  72. if ($_POST['task'] == 'save') {
  73. $ret = USERS2_MARKETING_AKCJE_task_ADD_save();
  74. if ($ret) {
  75. echo'<p>'."Dodano nowy rekord (ID = ".$ret.")".'</p>';
  76. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE".'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  77. } else {
  78. USERS2_MARKETING_AKCJE_task_ADD_verify();
  79. }
  80. return;
  81. }
  82. if ($_POST['task'] == 'verify') {
  83. // show budynki by filter
  84. USERS2_MARKETING_AKCJE_task_ADD_verify();
  85. return;
  86. } else {
  87. // ??
  88. }
  89. }
  90. USERS2_MARKETING_AKCJE_task_ADD();
  91. return;
  92. break;
  93. }
  94. case 'EDIT': {
  95. // fetch ID from ARG1_VAL
  96. $record_id = V::get('ARG1_VAL', '', $_REQUEST, 'int');
  97. if ($record_id < 0) {
  98. echo'<p style="color:red">'."Wrong ID".'</p>';
  99. return;
  100. }
  101. // fetch object by ID
  102. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'])) {
  103. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'] = $record_id;
  104. } else if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'] != $record_id) {
  105. // TODO: clean ses cache data
  106. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'] = $record_id;
  107. }
  108. $zapSQL = "SELECT * from `".$thiss->DETECT_TABLE_NAME."` where `ID`='" . $_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'] . "' ";
  109. if (isset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPE']['A_ADM_COMPANY'])) {
  110. $zapSQL .= " and `A_ADM_COMPANY` like '".$_SESSION['ADM_COMPANY']."' ";
  111. }
  112. $result = DB::query($zapSQL) or die("Blad zapytania2!");
  113. $num_rows = DB::num_rows($result);
  114. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['MYSQL_NUM_ROWS'] = $num_rows;
  115. $record = DB::fetch_assoc($result);
  116. if (!$record) {
  117. echo'<p style="color:red">'."Record not exists!".'</p>';
  118. return;
  119. }
  120. $task = V::get('task', '', $_REQUEST);
  121. switch ($task) {
  122. case 'zlecenie':
  123. USERS2_MARKETING_AKCJE_task_EDIT_zlecenie($record_id, $record);
  124. break;
  125. case 'wprowadz_zlecenie_data':
  126. USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie_data($record_id, $record);
  127. break;
  128. case 'wprowadz_zlecenie':
  129. USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie($record_id, $record);
  130. break;
  131. case 'zlecenie_kontroli':
  132. USERS2_MARKETING_AKCJE_task_EDIT_zlecenie_kontroli($record_id, $record);
  133. break;
  134. case 'wprowadz_zlecenie_kontroli_data':
  135. USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie_kontroli_data($record_id, $record);
  136. break;
  137. case 'wprowadz_zlecenie_kontroli':
  138. USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie_kontroli($record_id, $record);
  139. break;
  140. case 'delete':
  141. USERS2_MARKETING_AKCJE_task_EDIT_A_STATUS('delete', $record_id, $record);
  142. break;
  143. case 'undelete':
  144. USERS2_MARKETING_AKCJE_task_EDIT_A_STATUS('undelete', $record_id, $record);
  145. break;
  146. default:
  147. USERS2_MARKETING_AKCJE_task_EDIT($record_id, $record);
  148. }
  149. break;
  150. }
  151. case 'HIST': {
  152. USERS2_MARKETING_AKCJE_task_HIST();
  153. return;
  154. break;
  155. }
  156. case 'PODSUMOWANIE':
  157. USERS2_MARKETING_AKCJE_podsumowanie();
  158. break;
  159. case 'PODSUMOWANIE_USER':
  160. USERS2_MARKETING_AKCJE_podsumowanie_user();
  161. break;
  162. default: {
  163. // update sql like RELATIVEDB
  164. $sql = "update `USERS2_MARKETING_AKCJE` as a set
  165. a.`DO_ROZNIESIENIA`=(select sum(ab.DO_ROZNIESIENIA) from USERS2_MARKETING_AKCJE_BUILDINGS as ab where ab.ID_AKCJA=a.ID)
  166. , a.`ROZNIESIONO`=(select sum(ab.ROZNIESIONO) from USERS2_MARKETING_AKCJE_BUILDINGS as ab where ab.ID_AKCJA=a.ID)
  167. where 1=1
  168. ";
  169. DB::query($sql);
  170. USERS2_MARKETING_AKCJE_list();
  171. }
  172. }
  173. }
  174. class USERS2_MARKETING_AKCJE {
  175. function &get_buildings($record_id, &$record) {
  176. global $thiss;
  177. // USERS2_MARKETING_AKCJE_BUILDINGS
  178. {
  179. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  180. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  181. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  182. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  183. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">thiss: ';print_r($thiss);echo'</pre>';
  184. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  185. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">SES[thiss]: ';print_r($_SESSION[$thiss->DETECT_TABLE_COLUMN]);echo'</pre>';
  186. }
  187. $buildings = array();
  188. $sql = "select a.*
  189. from `" . $thiss->DETECT_TABLE_NAME . "` as a
  190. where
  191. a.`ID_AKCJA`='" . $record_id . "'
  192. order by a.`S_ADDRESS_STREET`
  193. ";
  194. $res = DB::query($sql) or die("sql error: $sql");
  195. while ($h = DB::fetch_assoc($res)) {
  196. $h['S_ADDRESS_STREET'] = strtoupper($h['S_ADDRESS_STREET']);
  197. $h['nr_domu'] = intval( preg_replace('/[^0-9]/', '', $h['S_ADDRESS_STREET']) );
  198. $h['street_short'] = preg_replace('/[0-9]/', '', $h['S_ADDRESS_STREET']);
  199. $buildings[ $h['S_ADDRESS_STREET'] ] = $h;
  200. }
  201. if (empty($buildings)) {
  202. echo'<p style="color:red">'."Brak przypisanych budynkow!".'</p>';
  203. return;
  204. }
  205. function sort_marketing_akcje_buildings_callback($a, $b) {
  206. if ($a['street_short'] < $b['street_short']) {
  207. return -1;
  208. } else if ($a['street_short'] > $b['street_short']) {
  209. return 1;
  210. } else if ($a['nr_domu'] < $b['nr_domu']) {
  211. return -1;
  212. } else if ($a['nr_domu'] > $b['nr_domu']) {
  213. return 1;
  214. } else {
  215. return 0;
  216. }
  217. }
  218. uasort( $buildings, 'sort_marketing_akcje_buildings_callback' );
  219. return $buildings;
  220. }
  221. function fetch_buildings_types(&$buildings) {
  222. if (empty($buildings)) {
  223. return;
  224. }
  225. $sql_buildings_streets = array();
  226. foreach ($buildings as $k_street => $v_building) {
  227. $sql_buildings_streets []= "'" . $k_street . "'";
  228. $buildings[$k_street]['T_BUILDING_TYPE'] = '';
  229. }
  230. if (empty($sql_buildings_streets)) {
  231. return;
  232. }
  233. $sql = "select b.`S_ADDRESS_STREET`, b.`T_BUILDING_TYPE`
  234. from `BUILDINGS` as b
  235. where b.`S_ADDRESS_STREET` in(" . implode(", ", $sql_buildings_streets) . ")
  236. ";
  237. $res = DB::query($sql);
  238. while ($r = DB::fetch($res)) {
  239. if (isset($buildings[$r->S_ADDRESS_STREET])) {
  240. $buildings[$r->S_ADDRESS_STREET]['T_BUILDING_TYPE'] = $r->T_BUILDING_TYPE;
  241. }
  242. }
  243. }
  244. function &get_buildings_by_user_month($user, $month, $order_by = 'S_ADDRESS_STREET', $order_dir = 'ASC') {
  245. global $thiss;
  246. // USERS2_MARKETING_AKCJE_BUILDINGS
  247. {
  248. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  249. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  250. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  251. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  252. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">thiss: ';print_r($thiss);echo'</pre>';
  253. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  254. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">SES[thiss]: ';print_r($_SESSION[$thiss->DETECT_TABLE_COLUMN]);echo'</pre>';
  255. }
  256. if (!$order_by) $order_by = 'S_ADDRESS_STREET';
  257. $buildings = array();
  258. $sql = "select ab.*, a.`ID_PROJECT`
  259. from `" . 'USERS2_MARKETING_AKCJE' . "` as a
  260. left join `" . $thiss->DETECT_TABLE_NAME . "` as ab on(ab.`ID_AKCJA`=a.`ID`)
  261. where
  262. a.`A_STATUS`!='DELETED'
  263. and a.`W_USER`='" . $user . "'
  264. and a.`W_DATA` like '" . $month . "-%'
  265. order by ab.`" . $order_by . "` " . $order_dir . "
  266. ";
  267. $res = DB::query($sql) or die("sql error: $sql");
  268. while ($h = DB::fetch_assoc($res)) {
  269. $h['S_ADDRESS_STREET'] = strtoupper($h['S_ADDRESS_STREET']);
  270. $h['nr_domu'] = intval( preg_replace('/[^0-9]/', '', $h['S_ADDRESS_STREET']) );
  271. $h['street_short'] = preg_replace('/[0-9]/', '', $h['S_ADDRESS_STREET']);
  272. $buildings[ $h['ID'] ] = $h;
  273. }
  274. if (empty($buildings)) {
  275. echo'<p style="color:red">'."Brak przypisanych budynkow!".'</p>';
  276. return;
  277. }
  278. if ($order_by == 'S_ADDRESS_STREET') {
  279. // TODO: sort_dir - DESC
  280. function sort_marketing_akcje_buildings_callback($a, $b) {
  281. if ($a['street_short'] < $b['street_short']) {
  282. return -1;
  283. } else if ($a['street_short'] > $b['street_short']) {
  284. return 1;
  285. } else if ($a['nr_domu'] < $b['nr_domu']) {
  286. return -1;
  287. } else if ($a['nr_domu'] > $b['nr_domu']) {
  288. return 1;
  289. } else {
  290. return 0;
  291. }
  292. }
  293. uasort( $buildings, 'sort_marketing_akcje_buildings_callback' );
  294. }
  295. return $buildings;
  296. }
  297. function &get_mieszkania($record_id, &$record) {
  298. global $thiss;
  299. // USERS2_MARKETING_AKCJE_BUILDINGS
  300. {
  301. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  302. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  303. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  304. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  305. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">thiss: ';print_r($thiss);echo'</pre>';
  306. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  307. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">SES[thiss]: ';print_r($_SESSION[$thiss->DETECT_TABLE_COLUMN]);echo'</pre>';
  308. }
  309. $mieszkania = array();
  310. $sql_filter_bez_bn = "";
  311. if ($record['FILTR_BEZ_BN'] == 'TAK') {
  312. $sql_filter_bez_bn = " and m.`I_OPER`!='BN' ";
  313. }
  314. $sql = "select m.`T_TELBOX_BUILDING_IN`, m.`S_ADDRESS_STREET`, m.`I_OPER`
  315. from `" . $thiss->DETECT_TABLE_NAME . "` as ab
  316. left join `USERS2_MARKETING` as m on(m.`T_TELBOX_BUILDING_IN`=ab.`S_ADDRESS_STREET`)
  317. where ab.`ID_AKCJA`='" . $record_id . "'
  318. $sql_filter_bez_bn
  319. order by ab.`S_ADDRESS_STREET` asc
  320. ";
  321. $res = DB::query($sql) or die("sql error: $sql");
  322. while ($h = DB::fetch_assoc($res)) {
  323. $h['T_TELBOX_BUILDING_IN'] = strtoupper($h['T_TELBOX_BUILDING_IN']);
  324. $h['S_ADDRESS_STREET'] = strtoupper($h['S_ADDRESS_STREET']);
  325. $s_address_street = explode('/', $h['S_ADDRESS_STREET'], 2);
  326. $h['dom'] = intval( preg_replace('/[^0-9]/', '', reset($s_address_street)) );// reset($s_address_street);
  327. $h['nr_domu'] = end($s_address_street);
  328. $mieszkania[ $h['T_TELBOX_BUILDING_IN'] ] []= $h;
  329. }
  330. function sort_marketing_akcje_mieszkania_callback($a, $b) {
  331. if ($a['T_TELBOX_BUILDING_IN'] < $b['T_TELBOX_BUILDING_IN']) {
  332. return -1;
  333. } else if ($a['T_TELBOX_BUILDING_IN'] > $b['T_TELBOX_BUILDING_IN']) {
  334. return 1;
  335. } else if ($a['nr_domu'] < $b['nr_domu']) {
  336. return -1;
  337. } else if ($a['nr_domu'] > $b['nr_domu']) {
  338. return 1;
  339. } else {
  340. return 0;
  341. }
  342. }
  343. foreach ($mieszkania as $k_building => $v_arr) {
  344. uasort( $mieszkania[$k_building], 'sort_marketing_akcje_mieszkania_callback' );
  345. //ksort( $mieszkania[$k_building]);
  346. }
  347. function sort_marketing_akcje_budynki_callback($a_arr, $b_arr) {
  348. $a = reset($a_arr);
  349. $b = reset($b_arr);
  350. if ($a['T_TELBOX_BUILDING_IN'] < $b['T_TELBOX_BUILDING_IN']) {
  351. return -1;
  352. } else if ($a['T_TELBOX_BUILDING_IN'] > $b['T_TELBOX_BUILDING_IN']) {
  353. return 1;
  354. } else if ($a['dom'] < $b['dom']) {
  355. return -1;
  356. } else if ($a['dom'] > $b['dom']) {
  357. return 1;
  358. } else {
  359. return 0;
  360. }
  361. }
  362. uasort( $mieszkania, 'sort_marketing_akcje_budynki_callback' );
  363. return $mieszkania;
  364. }
  365. function print_rewir_tree_css() {
  366. echo'<style type="text/css">'."
  367. #tree {font-size:small;}
  368. #tree, #tree ul { padding:0; margin:0; list-style-type:none; background: url(./stuff/i/tree-vline.png) repeat-y; }
  369. #tree ul { margin-left:10px; }
  370. #tree li { margin:0; padding:0 6px; line-height:16px; background:url(./stuff/i/tree-node.png) no-repeat; color:#666; font-weight:bold; }
  371. #tree li.last { background:#fff url(./stuff/i/tree-lastnode.png) no-repeat; }
  372. #tree .pr{color:#00B700;}
  373. #tree .pr-highest{color:#f00;}
  374. #tree .pr-high{color:#FF6300;}
  375. #tree .pr-medium{color:#00f;}
  376. #tree .pr-disable{color:#BFBFBF;text-decoration:line-through;}
  377. #tree .selected b{background-color:#FFFFAB;}
  378. #tree b.disabled{background-color:#E1E1E1;}
  379. #tree .btn{margin:0 2px;padding:0 2px;color:#FF5D5D;}
  380. ".'</style>';
  381. }
  382. function print_rewir_tree_js() {
  383. echo'<script type="text/javascript" src="stuff/jquery.js"></script>';
  384. echo'<script type="text/javascript">'."
  385. jQuery(document).ready(function(){
  386. jQuery('#frm select[name=ID_PROJECT]').css('width', '400px');
  387. jQuery('#tree ul').each(function(ind,n){
  388. jQuery(n).find('li:last-child').addClass('last');
  389. });
  390. fieldChangeRefresh();
  391. });
  392. function treeClearAll(){
  393. jQuery('#tree input').each(function(ind,item){
  394. item.checked = false;
  395. });
  396. jQuery('#tree .selected').removeClass('selected');
  397. }
  398. function fieldChangeRefresh() {
  399. //console.log('fieldChangeRefresh...')
  400. treeClearAll();
  401. var rewiry=jQuery('#frm textarea[name=FILTR_M_REWIR]').text();
  402. var street=jQuery('#frm textarea[name=FILTR_S_ADDRESS_STREET]').text();
  403. if (rewiry.length > 0) {
  404. rewiry = rewiry.split(',');
  405. //console.log(rewiry)
  406. var item=null;
  407. for(var i=0; i<rewiry.length; ++i){
  408. //console.log('searching for ' + rewiry[i] + ' ...')
  409. item=jQuery('#frm input[value=\"rewir_'+rewiry[i]+'\"]');
  410. //console.log(item)
  411. if (item) {
  412. itemChange(item.get(0), true, true)
  413. }
  414. }
  415. }
  416. if (street.length > 0) {
  417. street = street.split(',');
  418. //console.log(street)
  419. var item=null;
  420. for(var i=0; i<street.length; ++i){
  421. //console.log('searching for ' + street[i] + ' ...')
  422. item=jQuery('#frm input[value=\"street_'+street[i]+'\"]');
  423. //console.log(item)
  424. if (item) {
  425. itemChange(item.get(0), true, true)
  426. }
  427. }
  428. }
  429. return false;
  430. }
  431. function fieldChangeRec(f, n){
  432. fieldChange(f, n);
  433. jQuery(n).parent().find('input').each( function(i,node){
  434. if(!node.checked) {
  435. var filtr = jQuery(node).attr('filtr');
  436. if (filtr) {
  437. node.checked = n.checked;
  438. fieldChange(node.form[filtr], node);
  439. }
  440. }
  441. })
  442. }
  443. function fieldChange(f, n, value){
  444. if (n.checked) {// zaznacz
  445. if (f.innerHTML == '') {
  446. f.innerHTML = value;
  447. } else {
  448. f.innerHTML += ',' + value;
  449. }
  450. } else {// odznacz
  451. f.innerHTML = (',' + f.innerHTML + ',').replace(',' + value + ',', ',');
  452. f.innerHTML = f.innerHTML.replace(/,,/g, ',');
  453. f.innerHTML = f.innerHTML.substr(1, f.innerHTML.length - 2);
  454. }
  455. }
  456. function onItemChange(n){
  457. var frm=n.form;
  458. itemChange(n, n.checked)
  459. }
  460. function itemChange(n, checked, dont_change_field){
  461. var frm=n.form;
  462. n.checked = checked;
  463. if (!dont_change_field) {
  464. if (n.value.substring(0,6) == 'street') {
  465. fieldChange(frm.FILTR_S_ADDRESS_STREET, n, n.value.substring(7))
  466. } else if (n.value.substring(0,6) == 'rewir_') {
  467. fieldChange(frm.FILTR_M_REWIR, n, n.value.substring(6))
  468. }
  469. }
  470. jQuery(n).parent().toggleClass('selected');
  471. }
  472. ".'</script>';
  473. }
  474. function print_rewir_tree(&$record_data) {
  475. global $thiss;
  476. $rewiry = array();
  477. $buildings = array();
  478. $rewiry_selected = explode(',', $record_data['FILTR_M_REWIR']);
  479. $buildings_selected = explode(',', $record_data['FILTR_S_ADDRESS_STREET']);
  480. // fetch old actions on buildings
  481. $old_actions = array();
  482. $sql = "select
  483. mb.`S_ADDRESS_STREET` as street
  484. , max(ma.`DATA`) as last_date
  485. from `USERS2_MARKETING_AKCJE_BUILDINGS` as mb
  486. left join `USERS2_MARKETING_AKCJE` as ma on(ma.`ID`=mb.`ID_AKCJA`)
  487. where
  488. ma.`A_STATUS`!='DELETED'
  489. group by mb.`S_ADDRESS_STREET`
  490. ";
  491. $res = DB::query($sql);
  492. while ($r = DB::fetch($res)) {
  493. $r->street = strtoupper($r->street);
  494. $old_actions[$r->street] = $r->last_date;
  495. }
  496. // filtr bez BN
  497. $sql_ulotek = "ov.`MIESZKAN`";
  498. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  499. $sql_ulotek = "(ov.`MIESZKAN` - ov.`ABO_I`)";
  500. }
  501. // filtr FILTR_MIN_ULOTEK_NA_BUDYNEK
  502. $sql_ulotek_enable = "1";
  503. if ($filtr_min_ulotek_na_budynek = V::get('FILTR_MIN_ULOTEK_NA_BUDYNEK', 0, $record_data, 'int')) {
  504. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  505. $sql_ulotek_enable = " ( (100 * ov.`ABO_I`) / ov.`MIESZKAN` ) <= ".$filtr_min_ulotek_na_budynek."";
  506. }
  507. }
  508. // TODO: filtr aneksy
  509. $sql = "select b.`ID`, b.`M_REWIR`, b.`S_ADDRESS_STREET`, b.`P_ADDRESS_STREET`
  510. , ov.`ABO_I`, ov.`MIESZKAN`
  511. , $sql_ulotek as ile_ulotek
  512. , ( (100 * ".$sql_ulotek.") / ov.`MIESZKAN` ) as pr
  513. , $sql_ulotek_enable as ulotek_enable
  514. , 1 as data_enable
  515. from `BUILDINGS` as b
  516. left join `USERS2_MARKETING_OVERWIEV` as ov on(ov.`T_TELBOX_BUILDING_IN`=b.`S_ADDRESS_STREET`)
  517. where
  518. b.`A_STATUS` in('NORMAL','WARNING')
  519. group by b.`ID`
  520. order by b.`M_REWIR`
  521. ";
  522. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;display:none">sql (F.' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($sql);echo'</pre>';
  523. $res = DB::query($sql);
  524. while ($r = DB::fetch($res)) {
  525. if ($filtr_data = V::get('FILTR_MIN_DATA_OSTATNIEJ_AKCJI', 0, $record_data)) {
  526. if (array_key_exists($r->S_ADDRESS_STREET, $old_actions)) {
  527. if ($old_actions[$r->S_ADDRESS_STREET] >= $filtr_data) {
  528. $r->data_enable = 0;
  529. $r->last_action_date = $old_actions[$r->S_ADDRESS_STREET];
  530. }
  531. }
  532. }
  533. $r->rewir = explode('.', strtoupper($r->M_REWIR));
  534. $r->dom = intval( preg_replace('/[^0-9]/', '', $r->S_ADDRESS_STREET) );
  535. $rewir = $r->M_REWIR;
  536. $buildings [$r->ID] = $r;
  537. if ($r->dom > 0) {
  538. $rewiry [strtoupper($r->M_REWIR)] []= $r;
  539. }
  540. }
  541. function buildings_map_tree_add( &$tree, &$r, $filtr_last_data, $add_path, $cur_path = array() ) {
  542. if ($add_path == '') {
  543. $disable = false;
  544. $disable_reaseon = '';
  545. if (!$r->ulotek_enable) {
  546. $disable = true;
  547. $disable_reaseon = ' - za duże nasycenie';
  548. }
  549. if (!$r->data_enable) {
  550. $disable = true;
  551. $disable_reaseon = ' - data ostatniej akcji '.$r->last_action_date.' &gt; '.$filtr_last_data;
  552. }
  553. // , ov.`ABO_I`, ov.`MIESZKAN`
  554. $procent = round(($r->ABO_I * 100) / $r->MIESZKAN);
  555. $st = '';
  556. $cls = '';
  557. if ($procent < 30) $cls = 'pr-highest';
  558. else if ($procent < 60) $cls = 'pr-high';
  559. else if ($procent < 80) $cls = 'pr-medium';
  560. $out_title = $r->P_ADDRESS_STREET.": ".$r->ABO_I." abonentow /".$r->MIESZKAN." mieszkan";
  561. if ($disable) {
  562. $cls = 'pr-disable';
  563. $out_title .= $disable_reaseon;
  564. }
  565. $out = '';
  566. $out .= '<b class="pr '.$cls.'" title="'.$out_title.'">';
  567. $out .= '<span>'.$r->S_ADDRESS_STREET.'</span>';
  568. $out .= ' <span style="font-size:small;color:#666">('.$procent."%".')</span>';
  569. $out .= '</b>';
  570. $tree['buildings'] [$r->S_ADDRESS_STREET] = $out;
  571. return;
  572. }
  573. $path = explode('.', strtoupper($add_path));
  574. $cur_path []= array_shift($path);// 1st elem
  575. $cur_path_str = implode('.', $cur_path);
  576. if (!array_key_exists($cur_path_str, $tree)) {
  577. $tree [$cur_path_str] = array();
  578. }
  579. buildings_map_tree_add( $tree[$cur_path_str], $r, $filtr_last_data, implode('.', $path), $cur_path );
  580. }
  581. function buildings_map_show_tree( &$tree, &$rewiry_selected, &$buildings_selected ) {
  582. if (empty($tree)) {
  583. return;
  584. }
  585. echo'<ul>';
  586. foreach ($tree as $k => $v) {
  587. $id = '';
  588. $out = '';
  589. $cls = '';
  590. if ($k == 'buildings') {
  591. foreach ($v as $k_street_short => $v_long) {
  592. $checked = '';//(in_array($k_street_short, $buildings_selected))? ' checked="checked"' : '';
  593. $out .= '<nobr>';
  594. $out .= '<input type="checkbox" value="'."street_".$k_street_short.'" onclick="'."return onItemChange(this)".'" '.$checked.' />';
  595. $out .= $v_long;
  596. $out .= '</nobr>';
  597. $out .= ' ';
  598. }//end foreach
  599. }
  600. else {
  601. $cls = '';
  602. $checked = '';
  603. if (in_array($k, $rewiry_selected)) {
  604. $checked = '';//' checked="checked"';
  605. $cls = '';//' class="selected"';
  606. }
  607. $id = ' id="rewir_'.$k.'"';
  608. $out .= '<input type="checkbox" value="'."rewir_".$k.'" onclick="'."return onItemChange(this)".'" '.$checked.' />';
  609. $out .= '<b>'.$k.'</b>';
  610. }
  611. echo'<li'.$cls.''.$id.'>';
  612. echo $out;
  613. if ($k != 'buildings') {
  614. if (is_array($v)) {
  615. if ($k) {
  616. buildings_map_show_tree( $v, $rewiry_selected, $buildings_selected );
  617. }
  618. }
  619. }
  620. echo'</li>';
  621. }//end foreach
  622. echo'</ul>';
  623. }
  624. $rewiry_tree = array();
  625. foreach ($rewiry as $k_rewir => $v_budynki) {
  626. foreach ($v_budynki as $r) {
  627. $filtr_last_data = V::get('FILTR_MIN_DATA_OSTATNIEJ_AKCJI', 0, $record_data);
  628. buildings_map_tree_add( $rewiry_tree, $r, $filtr_last_data, $r->M_REWIR );
  629. }
  630. }
  631. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">';print_r($rewiry_tree);echo'</pre>';
  632. echo'<div id="tree">';
  633. $js = "this.form.task.value='';this.form.submit()";
  634. echo'<button onclick="'.$js.'">'."odswiez".'</button>';
  635. buildings_map_show_tree( $rewiry_tree, $rewiry_selected, $buildings_selected );
  636. echo'</div>';
  637. self::print_rewir_tree_css();
  638. self::print_rewir_tree_js();
  639. }
  640. function &print_akcje_table_item($field_name, &$record_arr) {
  641. $out = $record_arr[$field_name];
  642. switch ($field_name) {
  643. case 'FILTR_S_ADDRESS_STREET': {
  644. $out = str_replace(',', ', ', $out);
  645. $max_length = 60;
  646. if (strlen($out) > $max_length) {
  647. $out = '<span title="'.$out.'">'.substr($out, 0, $max_length)."...".'</span>';
  648. }
  649. break;
  650. }
  651. case 'A_STATUS': {
  652. if ($record_arr[$field_name] == 'DELETED') {
  653. $js = "return confirm('Czy jestes pewien ze chcesz przywrócić rekord ID=" . $record_arr['ID'] . "');";
  654. $out = '<span style="color:silver">' . $out . '</span>';
  655. $out .= '<br />' . '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=" . $record_arr['ID'] . "&task=undelete" . '" onclick="' . $js . '">' . "przywróć" . '</a>';
  656. }
  657. else {
  658. $js = "return confirm('Czy jestes pewien ze chcesz usunac rekord ID=" . $record_arr['ID'] . "');";
  659. $out = '<span style="color:green">' . $out . '</span>';
  660. $out .= '<br />' . '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=" . $record_arr['ID'] . "&task=delete" . '" onclick="' . $js . '">' . "usuń" . '</a>';
  661. }
  662. break;
  663. }
  664. default:
  665. }
  666. return $out;
  667. }
  668. }// class
  669. function USERS2_MARKETING_AKCJE_task_ADD_save() {
  670. global $thiss;
  671. $arr = array();
  672. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  673. if (strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][$field_name],"C")) {
  674. if (isset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$field_name])) {
  675. $arr[$field_name] = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$field_name];
  676. }
  677. }
  678. }
  679. $arr['A_RECORD_CREATE_DATE'] = date('Y-m-d-H:i');
  680. $arr['A_RECORD_CREATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  681. $arr['DATA'] = date("Y-m-d");
  682. if (!empty($_POST['update_FILTR_S_ADDRESS_STREET'])) {
  683. $arr['FILTR_S_ADDRESS_STREET'] = $_POST['update_FILTR_S_ADDRESS_STREET'];
  684. }
  685. if (!empty($_POST['update_ILE_ULOTEK'])) {
  686. //TODO: $arr['ILE_ULOTEK'] = $_POST['update_ILE_ULOTEK'];
  687. }
  688. if (empty($arr)) {
  689. return false;
  690. }
  691. $sql_arr = array();
  692. foreach ($arr as $k => $v) {
  693. $sql_arr["`".$k."`"] = "'".$v."'";
  694. }//end foreach
  695. $sql = "insert into `".$thiss->DETECT_TABLE_NAME."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  696. DB::query($sql);
  697. $ret_id = DB::insert_id();
  698. if (!$ret_id) {
  699. return;
  700. }
  701. if(1){
  702. // filtr bez BN
  703. $sql_ulotek = "ov.`MIESZKAN`";
  704. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_BEZ_BN'] == 'TAK') {
  705. $sql_ulotek = "(ov.`MIESZKAN` - ov.`ABO_I`)";
  706. }
  707. // filtr FILTR_MIN_ULOTEK_NA_BUDYNEK
  708. $sql_ulotek_enable = "1=1";
  709. if ($filtr_min_ulotek_na_budynek = V::get('FILTR_MIN_ULOTEK_NA_BUDYNEK', 0, $record_data, 'int')) {
  710. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  711. $sql_ulotek_enable = " ( (100 * ov.`ABO_I`) / ov.`MIESZKAN` ) <= ".$filtr_min_ulotek_na_budynek."";
  712. }
  713. }
  714. // TODO: filtr aneksy - 3-mce przed koncem umowy
  715. $streets = explode(',', $arr['FILTR_S_ADDRESS_STREET']);
  716. $sql = "insert into `USERS2_MARKETING_AKCJE_BUILDINGS` (`A_RECORD_CREATE_DATE`,`A_RECORD_CREATE_AUTHOR`,`ID_AKCJA`,`S_ADDRESS_STREET`,`DO_ROZNIESIENIA`)
  717. select '".$_SESSION['AUTHORIZE_USER']."'
  718. , NOW()
  719. , ".$ret_id."
  720. , ov.`T_TELBOX_BUILDING_IN`
  721. , ".$sql_ulotek."
  722. from `USERS2_MARKETING_OVERWIEV` as ov
  723. where
  724. ov.`T_TELBOX_BUILDING_IN` in('".implode("','", $streets)."')
  725. and ".$sql_ulotek_enable."
  726. ";
  727. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;display:none">sql: ';print_r($sql);echo'</pre>';
  728. DB::query($sql);
  729. }
  730. // clean session cache
  731. unset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']);
  732. return $ret_id;
  733. }
  734. function USERS2_MARKETING_AKCJE_task_EDIT($record_id, &$record) {
  735. global $thiss;
  736. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE".'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  737. if(0){// EDIT form, @uses TABLE_UPDATEDB
  738. echo'<table width="100%" border="1" cellspacing="0" cellpadding="0" class="tbl-view">';
  739. echo'<thead>';
  740. echo '</TD><TD>'."Nazwa_POLA";
  741. //CREATE_MENUFUNC_INIT_2($thiss->DETECT_HIST_FUNCTION,'HISTORY',$_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'],'<img src=icon/history.gif alt=HISTORIA border=0>');
  742. // TODO: HIST function
  743. echo '</TD><TD>'."WARTOSC".'</TD></TR>';
  744. echo'</thead>';
  745. echo'<tbody>';
  746. echo '<FORM ACTION="" method="POST">';
  747. echo '<input type="HIDDEN" name="WIEVID" value="'.$_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'].'">';
  748. echo '<input type="HIDDEN" name="FUNCTION_INIT" value="TABLE_UPDATEDB">';
  749. $t = 0;
  750. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['ID'] as $value) {
  751. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['EDITRECORD'][ $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value] ] = $record[$value];
  752. if(strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN][PERMEDIT][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]],"R")) {
  753. echo'<tr class="row-' . ($t = 1 - $t) . '">';
  754. echo "<TD><font size=-2>" ;//. $_SESSION[$thiss->DETECT_TABLE_COLUMN][PERMEDIT][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]];
  755. echo "<BR>";
  756. echo "</TD><TD>";
  757. if($_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC_TO_LANG][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC]["$value"]]) { echo $_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC_TO_LANG][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC]["$value"]] . "<br>";
  758. echo "<font size=-2>".$_SESSION[$thiss->DETECT_TABLE_COLUMN]["DESC"]["$value"]."</font>";
  759. } else echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]["DESC"]["$value"];
  760. echo "</TD>";
  761. echo "<TD ";
  762. USERS_COLUMN_COLOR($_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value],$_SESSION[$thiss->DETECT_TABLE_COLUMN][EDIT_TEMPLATE][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]],bgcolor);
  763. echo ">";
  764. //echo "$_SESSION[$thiss->DETECT_TABLE_COLUMN][PERMEDIT][$value]==RW";
  765. if((strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN][PERMEDIT][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]],"RW")) && (!isset($_SESSION[$thiss->DETECT_TABLE_COLUMN][TYPESPECIAL][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]]))) {
  766. GETFORMITEM($_SESSION[$thiss->DETECT_TABLE_COLUMN][EDIT_TEMPLATE][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]],$_SESSION[$thiss->DETECT_TABLE_COLUMN][TYPE][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]],$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]);
  767. echo "($record[$value])";
  768. } else if(isset($_SESSION[$thiss->DETECT_TABLE_COLUMN][TYPESPECIAL][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]])) {
  769. // echo "special viev of func " . $_SESSION[$thiss->DETECT_TABLE_COLUMN][TYPESPECIAL][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]] . "(" . $_SESSION[$thiss->DETECT_TABLE_COLUMN]["WIEVID"] . ") not currently implemented" ;
  770. $_SESSION[$thiss->DETECT_TABLE_COLUMN][TYPESPECIAL][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]]($_SESSION[$thiss->DETECT_TABLE_COLUMN]["WIEVID"],$_SESSION[$thiss->DETECT_TABLE_COLUMN][EDIT_TEMPLATE][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]]);
  771. } else echo $_SESSION[$thiss->DETECT_TABLE_COLUMN][EDIT_TEMPLATE][$_SESSION[$thiss->DETECT_TABLE_COLUMN][DESC][$value]];
  772. echo "</td></TR>";
  773. }
  774. }
  775. echo '<tr><td colspan="3" style="text-align:left"><input type="submit" value=" OK "></td></tr></form></table>';
  776. }
  777. $show_columns = array();
  778. $show_columns []= 'ID';
  779. $show_columns []= 'DATA';
  780. $show_columns []= 'ID_PROJECT';
  781. $show_columns []= 'FILTR_BEZ_BN';
  782. $show_columns []= 'FILTR_ANEKSY';
  783. $show_columns []= 'FILTR_MIN_ULOTEK_NA_BUDYNEK';
  784. $show_columns []= 'FILTR_MIN_DATA_OSTATNIEJ_AKCJI';
  785. $show_columns []= 'FILTR_S_ADDRESS_STREET';
  786. $show_columns []= 'W_USER';
  787. $show_columns []= 'W_DATA';
  788. $show_columns []= 'W_DATA_DOSTARCZONO';
  789. $show_columns []= 'W_DATA_WPROWADZONO';
  790. $show_columns []= 'K_USER';
  791. $show_columns []= 'K_DATA';
  792. $show_columns []= 'K_DATA_DOSTARCZONO';
  793. $show_columns []= 'K_DATA_WPROWADZONO';
  794. echo'<table width="100%" border="1" cellspacing="0" cellpadding="0" class="tbl-view">';
  795. $t = 0;
  796. foreach ($show_columns as $field_name) {
  797. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  798. continue;
  799. }
  800. echo '<tr class="row-' . ($t = 1 - $t) . '">';
  801. echo '<td>';
  802. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$field_name])) {
  803. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$field_name];
  804. echo '<br /><code style="font-size:x-small">'.$field_name.'</code>';
  805. } else {
  806. echo '<code>'.$field_name.'</code> ';
  807. }
  808. echo '</td>';
  809. echo '<td>';
  810. if (in_array($field_name, array('FILTR_M_REWIR', 'FILTR_S_ADDRESS_STREET'))) {
  811. echo str_replace(',', ', ', $record[ $field_name ]);
  812. } else {
  813. echo $record[ $field_name ];
  814. }
  815. echo '</td>';
  816. echo '</tr>';
  817. }
  818. echo'</table>';
  819. echo'<div style="margin:10px;padding:5px 10px;border:1px solid #666;">';
  820. // TODO: w zaleznosci od stanu akcji
  821. $btns = array();
  822. $btns []= '<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id."&task=zlecenie".'">'."drukuj zlecenie".'</a>';
  823. $out_btn = '<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id."&task=wprowadz_zlecenie_data".'">'."wprowadz date dostarczenia raportu".'</a>';
  824. $out_btn .= (($record['W_DATA_DOSTARCZONO'] == '0000-00-00')? " <b>!!!</b>" : " (<em>".$record['W_DATA_DOSTARCZONO']."</em>)");
  825. $btns []= $out_btn;
  826. $out_btn = '<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id."&task=wprowadz_zlecenie".'">'."wprowadz zlecenie do systemu".'</a>';
  827. $out_btn .= (($record['W_DATA_WPROWADZONO'] == '0000-00-00')? " <b>!!!</b>" : " (<em>".$record['W_DATA_WPROWADZONO']."</em>)");
  828. $btns []= $out_btn;
  829. echo "<b>Zlecenie dystrybucji:</b> ".'<ul style="list-style-type:decimal">'.'<li>'.implode('</li><li>', $btns).'</li>'.'</ul>';
  830. if (!empty($record['K_USER'])) {// if K_USER - kontroler
  831. $btns = array();
  832. $btns []= '<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id."&task=zlecenie_kontroli".'">'."drukuj zlecenie kontroli".'</a>';
  833. $out_btn = '<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id."&task=wprowadz_zlecenie_kontroli_data".'">'."wprowadz date dostarczenia raportu z kontroli".'</a>';
  834. $out_btn .= (($record['K_DATA_DOSTARCZONO'] == '0000-00-00')? " <b>!!!</b>" : " (<em>".$record['K_DATA_DOSTARCZONO']."</em>)");
  835. $btns []= $out_btn;
  836. $out_btn = '<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id."&task=wprowadz_zlecenie_kontroli".'">'."wprowadz zlecenie kontroli do systemu".'</a>';
  837. $out_btn .= (($record['K_DATA_WPROWADZONO'] == '0000-00-00')? " <b>!!!</b>" : " (<em>".$record['K_DATA_WPROWADZONO']."</em>)");
  838. $btns []= $out_btn;
  839. echo "<b>Zlecenie kontroli:</b> ".'<ul style="list-style-type:decimal">'.'<li>'.implode('</li><li>', $btns).'</li>'.'</ul>';
  840. }
  841. echo'</div>';
  842. // USERS2_MARKETING_AKCJE_BUILDINGS
  843. {
  844. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  845. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  846. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  847. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  848. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">thiss: ';print_r($thiss);echo'</pre>';
  849. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  850. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">SES[thiss]: ';print_r($_SESSION[$thiss->DETECT_TABLE_COLUMN]);echo'</pre>';
  851. }
  852. $buildings = USERS2_MARKETING_AKCJE::get_buildings($record_id, $record);
  853. USERS2_MARKETING_AKCJE::fetch_buildings_types($buildings);// add T_BUILDING_TYPE
  854. $suma_do_rozniesienia = 0;
  855. $suma_rozniesiono = 0;
  856. foreach ($buildings as $k_street => $h) {
  857. $suma_do_rozniesienia += $h['DO_ROZNIESIENIA'];
  858. $suma_rozniesiono += $h['ROZNIESIONO'];
  859. }
  860. echo'<style type="text/css">'."
  861. .akcje-buildings th { font-size:x-small; }
  862. .akcje-buildings th.field-T_BUILDING_TYPE { color:#333; }
  863. .akcje-buildings td.field-T_BUILDING_TYPE { font-size:x-small; color:#333; }
  864. ".'</style>';
  865. echo'<h2>'."Budynki dotyczące zlecenia".'</h2>';
  866. echo '<p>'."Do rozniesienia ".$suma_do_rozniesienia." - rozniesiono ".$suma_rozniesiono.".";
  867. echo '<b>'." Skuteczność akcji: ".(($suma_rozniesiono > 0)? round((100 * $suma_rozniesiono/$suma_do_rozniesienia)) : 0)."%".'</b>';
  868. echo '</p>';
  869. echo'<table width="100%" border="1" cellspacing="0" cellpadding="0" class="tbl-view akcje-buildings">';
  870. echo'<thead>';
  871. echo'<tr>';
  872. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  873. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  874. continue;
  875. }
  876. echo '<th>' . str_replace('_', ' ', $field_name) . '</th>';
  877. if ($field_name == 'S_ADDRESS_STREET') {
  878. echo '<th class="field-T_BUILDING_TYPE">' . str_replace('_', ' ', 'T_BUILDING_TYPE') . '</th>';
  879. }
  880. }
  881. echo'</tr>';
  882. echo'</thead>';
  883. echo'<tbody>';
  884. $t = 0;
  885. foreach ($buildings as $h) {
  886. echo '<tr class="row-' . ($t = 1 - $t) . '">';
  887. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  888. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  889. continue;
  890. }
  891. echo '<td>' . $h[$field_name] . '</td>';
  892. if ($field_name == 'S_ADDRESS_STREET') {
  893. echo '<td class="field-T_BUILDING_TYPE">' . $h['T_BUILDING_TYPE'] . '</td>';
  894. }
  895. }
  896. echo'</tr>';
  897. }//end foreach
  898. echo'</tbody>';
  899. echo'</table>';
  900. }
  901. function USERS2_MARKETING_AKCJE_task_EDIT_zlecenie($record_id, &$record) {
  902. global $thiss;
  903. echo'<style type="text/css">'."
  904. body{font-size:small;padding:0 6px;}
  905. td,table,tr{font-size:small;line-height:1.4em;}
  906. input{margin:0;padding:0;}
  907. ".'</style>';
  908. $buildings = USERS2_MARKETING_AKCJE::get_buildings($record_id, $record);
  909. $mieszkania = USERS2_MARKETING_AKCJE::get_mieszkania($record_id, $record);
  910. if (!empty($mieszkania)) {
  911. $building_cols = array();// [page_nr] => [col_nr] => [line_nr] => (street, nr)
  912. $limit_lines = 50;// aby sie zmiescilo na 1 stornie
  913. $limit_cols = 4;// limit kolumn
  914. $cur_page_nr = 0;
  915. $cur_col_ind = 0;
  916. $cur_line = 0;
  917. foreach ($mieszkania as $k_street => $v_arr) {
  918. reset($mieszkania[$k_street]);
  919. $v_ile = count($v_arr);
  920. for ($i = 0; $i < $v_ile; $i++) {
  921. $cur_line++;
  922. if ($cur_line >= $limit_lines) {
  923. $cur_line = 1;
  924. $cur_col_ind++;
  925. if ($cur_col_ind >= $limit_cols) {
  926. $cur_col_ind = 0;
  927. $cur_page_nr++;
  928. }
  929. }
  930. $mieszkanie = current($mieszkania[$k_street]);
  931. $building_cols[ $cur_page_nr ][ $cur_col_ind ] []= array('street'=>$k_street, 'nr'=>$mieszkanie['S_ADDRESS_STREET']);
  932. next($mieszkania[$k_street]);
  933. }
  934. // podsumowanie
  935. $cur_line++;
  936. $building_cols[ $cur_page_nr ][ $cur_col_ind ] []= array('street'=>$k_street, 'nr'=>'podsumowanie', 'x'=>$buildings[$k_street]['DO_ROZNIESIENIA']);
  937. // godzina
  938. $cur_line++;
  939. $building_cols[ $cur_page_nr ][ $cur_col_ind ] []= array('street'=>$k_street, 'nr'=>'godzina');
  940. // odstep
  941. $cur_line++;
  942. $building_cols[ $cur_page_nr ][ $cur_col_ind ] []= array('street'=>$k_street, 'nr'=>'empty');
  943. }
  944. $worker_name = $record['W_USER'];
  945. {// get user name
  946. $sql = "select a.`ADM_NAME` from `ADMIN_USERS` as a where a.`ADM_ACCOUNT`='".$record['W_USER']."' ";
  947. $res = DB::query($sql) or die("Blad zapytania! ".$sql);
  948. $r = DB::fetch($res);
  949. if ($r) {
  950. $worker_name = $r->ADM_NAME;
  951. }
  952. }
  953. USERS2_MARKETING_AKCJE_view_zlecenie_1_strona( $record_id, $record, $buildings, $worker_name );
  954. foreach ($building_cols as $k_page_nr => $v_page_arr) {
  955. // header
  956. echo '<p style="page-break-before:always">' . "ZLECENIE KOLPORTAŻU z dnia <i><b>".$record['DATA']."</b></i>, do procesu dystrybucji nr <i><b>".$record_id."</b></i> z dnia <i><b>".$record['W_DATA']."</b></i>" . '</p>';
  957. // echo'<p style="page-break-before:always">'."Imię i nazwisko: ".$worker_name;
  958. // echo " Wprowadzono do SE? ............";
  959. // echo'<br />';
  960. // echo "Data kolportażu: ".$record['W_DATA'].".";
  961. // echo " Kolportarz należy przeprowadzić od godz. ..... do godz. .....";
  962. // echo'<br />';
  963. // echo "Raport dostarczyć do: "."BOK Chełm do dnia ................. do godz. .....";
  964. // echo'</p>';
  965. echo'<table width="100%" border="0" cellspacing="0" cellpadding="0">';
  966. $max_col_count = 0;
  967. foreach ($v_page_arr as $k_col_id => $v_col_arr) {
  968. $max_col_count = max($max_col_count, count($v_col_arr));
  969. }
  970. for ($line_nr = 0; $line_nr < $max_col_count; $line_nr++) {
  971. echo'<tr>';
  972. for ($col_nr = 0; $col_nr < $limit_cols; $col_nr++) {
  973. echo'<td style="width:25%">';
  974. if (isset($v_page_arr[$col_nr][$line_nr])) {
  975. if ($v_page_arr[$col_nr][$line_nr]['nr'] == 'empty') {
  976. echo "&nbsp;";
  977. } else if ($v_page_arr[$col_nr][$line_nr]['nr'] == 'podsumowanie') {
  978. echo "<b> suma dla </b>";
  979. echo $v_page_arr[$col_nr][$line_nr]['street'];
  980. echo " ";
  981. echo '<input type="text" size="5" value="'."".'" style="display:inline;width:40px;height:auto;border:1px solid #000;border-radius:0;padding:0;margin:0;outline:0;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;" />';
  982. //echo''.$v_page_arr[$col_nr][$line_nr]['x'] . '/'.count($mieszkania[$v_page_arr[$col_nr][$line_nr]['street']]);
  983. } else if ($v_page_arr[$col_nr][$line_nr]['nr'] == 'godzina') {
  984. echo "<b> godzina:</b> ";
  985. echo '<input type="text" size="8" value="'."".'" style="display:inline;width:60px;height:auto;border:1px solid #000;border-radius:0;padding:0;margin:0;outline:0;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;" />';
  986. } else {
  987. echo $v_page_arr[$col_nr][$line_nr]['street'];
  988. echo " (";
  989. echo $v_page_arr[$col_nr][$line_nr]['nr'];
  990. echo ") ";
  991. echo '<input type="checkbox" value="'."".'" style="display:inline;padding:0;margin:0;" />';
  992. }
  993. } else {
  994. echo "&nbsp;&nbsp;&nbsp;";
  995. }
  996. echo'</td>';
  997. }
  998. echo'</tr>';
  999. }
  1000. echo'</tbody>';
  1001. echo'</table>';
  1002. }
  1003. }
  1004. echo'<div style="page-break-before:always">';
  1005. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id.'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  1006. echo'</div>';
  1007. }
  1008. function USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie($record_id, &$record) {
  1009. global $thiss;
  1010. // USERS2_MARKETING_AKCJE_BUILDINGS
  1011. {
  1012. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  1013. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  1014. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  1015. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  1016. }
  1017. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id.'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  1018. echo'<h1>'."Wprowadz zlecenie do systemu".'</h1>';
  1019. $buildings = USERS2_MARKETING_AKCJE::get_buildings($record_id, $record);
  1020. echo'<p>'."Dotyczy akcji ".$record['ID']." z dnia ".$record['DATA'].'</p>';
  1021. $post_saved = array();
  1022. $post = array();
  1023. foreach ($buildings as $k_street => $h) {
  1024. $post[$k_street] = V::get($k_street, $h['ROZNIESIONO'], $_POST);
  1025. }//end foreach
  1026. if (1 == V::get('save', '', $_POST)) {
  1027. if ("zakoncz" == V::get('sbmt', '', $_POST)) {
  1028. $form_saved = false;
  1029. $arr = array();
  1030. $arr['A_RECORD_UPDATE_DATE'] = date('Y-m-d-H:i');
  1031. $arr['A_RECORD_UPDATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  1032. $arr['W_DATA_WPROWADZONO'] = date('Y-m-d');
  1033. $sql_arr = array();
  1034. foreach ($arr as $k => $v) {
  1035. $sql_arr []= "`".$k."`='".$v."'";
  1036. }//end foreach
  1037. $sql = "update `USERS2_MARKETING_AKCJE` set ".implode(",", $sql_arr)." where `ID`='".$record_id."' limit 1 ";
  1038. DB::query($sql);
  1039. $ret_affected = DB::affected_rows();
  1040. if (!$ret_affected) {
  1041. echo'<p style="color:red">'."Error: nie udalo sie zapisac rekordu".'</p>';
  1042. } else {
  1043. $form_saved = true;
  1044. }
  1045. // save HIST
  1046. $sql_arr = array();
  1047. foreach ($arr as $k => $v) {
  1048. $sql_arr["`".$k."`"] = "'".$v."'";
  1049. }//end foreach
  1050. $sql_arr["`ID_USERS2`"] = "'".$record_id."'";
  1051. $hist_table = "USERS2_MARKETING_AKCJE_HIST";
  1052. $sql = "insert into `".$hist_table."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  1053. DB::query($sql);
  1054. $ret_id = DB::insert_id();
  1055. if (!$ret_id) {
  1056. echo'<p style="color:red">'."Error: nie udalo sie zapisac danych do tabeli HIST".'</p>';
  1057. }
  1058. if ($form_saved) {
  1059. echo'<p style="color:green">'."Dane zapisano pomyslnie".'</p>';
  1060. return;
  1061. }
  1062. }
  1063. else {
  1064. foreach ($buildings as $k_street => $h) {
  1065. if (empty($post[$k_street]) && $post[$k_street] !== '0') continue;
  1066. if ($post[$k_street] == $h['ROZNIESIONO']) continue;
  1067. $arr = array();
  1068. $arr['A_RECORD_UPDATE_DATE'] = date('Y-m-d-H:i');
  1069. $arr['A_RECORD_UPDATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  1070. $arr['ROZNIESIONO'] = $post[$k_street];
  1071. $sql_arr = array();
  1072. foreach ($arr as $k => $v) {
  1073. $sql_arr []= "`".$k."`='".$v."'";
  1074. }//end foreach
  1075. $sql = "update `".$thiss->DETECT_TABLE_NAME."` set ".implode(",", $sql_arr)." where `ID`='".$h['ID']."' limit 1 ";
  1076. DB::query($sql);
  1077. $ret_affected = DB::affected_rows();
  1078. $post_saved[$k_street] = $ret_affected;
  1079. if (0) {
  1080. // save HIST
  1081. $sql_arr = array();
  1082. foreach ($arr as $k => $v) {
  1083. $sql_arr["`".$k."`"] = "'".$v."'";
  1084. }//end foreach
  1085. $sql_arr["`ID_USERS2`"] = "'".$record_id."'";
  1086. $hist_table = $thiss->DETECT_TABLE_NAME . "_HIST";
  1087. $sql = "insert into `".$hist_table."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  1088. DB::query($sql);
  1089. $ret_id = DB::insert_id();
  1090. if (!$ret_id) {
  1091. echo'<p style="color:red">'."Error: nie udalo sie zapisac danych do tabeli HIST".'</p>';
  1092. }
  1093. }
  1094. }//end foreach
  1095. $all_ok = true;
  1096. if (!empty($post_saved)) {
  1097. foreach ($post_saved as $k_street => $val) {
  1098. if (!$val) $all_ok = false;
  1099. }//end foreach
  1100. }
  1101. if ($all_ok) {
  1102. echo'<p style="color:green">'."Dane zapisano pomyslnie".'</p>';
  1103. }
  1104. }
  1105. }
  1106. if (date('Y-m-d') <= $record['W_DATA']) {// TODO: do akcji - wprowadz date dostarczenia raportu
  1107. echo'<p style="color:green">'."Raport dostarczono w terminie".'</p>';
  1108. } else {
  1109. echo'<p style="color:red">'."Raportu nie dostarczono w terminie!".'</p>';
  1110. }
  1111. if (!empty($buildings)) {
  1112. echo'<form action="" method="POST">';
  1113. echo'<input type="hidden" name="'."save".'" value="1" />';
  1114. $out_buildings = array();
  1115. $out_tabindex = 0;
  1116. foreach ($buildings as $k_street => $h) {
  1117. $out_item = $k_street.' ';
  1118. $out_item .= '<input name="'.$k_street.'" type="text" size="4" value="'.$post[$k_street].'" tabindex="'.(++$out_tabindex).'" />';
  1119. $out_item .= '/'.$h['DO_ROZNIESIENIA'];
  1120. $out_buildings []= $out_item;
  1121. }//end foreach
  1122. // split to cols
  1123. $building_cols = array();// [col_nr] => [line_nr] => {obj}
  1124. $limit_cols = 4;// limit kolumn
  1125. $limit_lines = ceil(count($buildings) / $limit_cols) + 1;
  1126. $cur_col_ind = 0;
  1127. $cur_line = 0;
  1128. foreach ($out_buildings as $out_item) {
  1129. $cur_line++;
  1130. if ($cur_line >= $limit_lines) {
  1131. $cur_line = 1;
  1132. $cur_col_ind++;
  1133. }
  1134. $building_cols[ $cur_col_ind ][ $cur_line ] = $out_item;
  1135. }//end foreach
  1136. $max_col_count = 0;
  1137. foreach ($building_cols as $k_col_nr => $v_col_arr) {
  1138. $max_col_count = max($max_col_count, count($v_col_arr));
  1139. }//end foreach
  1140. echo'<table border="0" cellspacing="0" cellpadding="0">';
  1141. for ($line_nr = 0; $line_nr <= $max_col_count; $line_nr++) {
  1142. echo'<tr>';
  1143. for ($col_nr = 0; $col_nr < $limit_cols; $col_nr++) {
  1144. echo'<td style="width:25%;padding:0 10px;">';
  1145. if (isset($building_cols[ $col_nr ][ $line_nr ])) {
  1146. echo $building_cols[ $col_nr ][ $line_nr ];
  1147. } else {
  1148. echo "&nbsp;&nbsp;&nbsp;";
  1149. }
  1150. echo'</td>';
  1151. }
  1152. echo'</tr>';
  1153. }
  1154. echo'</tbody>';
  1155. echo'</table>';
  1156. echo'<input type="submit" value="'."zapisz".'" />';
  1157. echo'<p>';
  1158. echo "Jesli wprowadzono wszystkie dane ";
  1159. echo '<input type="submit" name="'."sbmt".'" value="'."zakoncz".'" />';
  1160. echo " wprowadzanie raportu";
  1161. echo'</p>';
  1162. echo'</form>';
  1163. }
  1164. }
  1165. function USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie_data($record_id, &$record) {
  1166. global $thiss;
  1167. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE".'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  1168. echo'<h1>'."Wprowadz datę dostarczenia zlecenia przez pracownika".'</h1>';
  1169. $form_saved = false;
  1170. $post = array();
  1171. $post['W_DATA_DOSTARCZONO'] = V::get('W_DATA_DOSTARCZONO', date('Y-m-d'), $_POST);
  1172. if (1 == V::get('save', '', $_POST)) {
  1173. // verify data
  1174. if (!empty($post['W_DATA_DOSTARCZONO'])) {
  1175. $arr = array();
  1176. $arr['A_RECORD_UPDATE_DATE'] = date('Y-m-d-H:i');
  1177. $arr['A_RECORD_UPDATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  1178. $arr['W_DATA_DOSTARCZONO'] = $post['W_DATA_DOSTARCZONO'];
  1179. $sql_arr = array();
  1180. foreach ($arr as $k => $v) {
  1181. $sql_arr []= "`".$k."`='".$v."'";
  1182. }//end foreach
  1183. $sql = "update `".$thiss->DETECT_TABLE_NAME."` set ".implode(",", $sql_arr)." where `ID`='".$record_id."' limit 1 ";
  1184. DB::query($sql);
  1185. $ret_affected = DB::affected_rows();
  1186. if (!$ret_affected) {
  1187. echo'<p style="color:red">'."Error: nie udalo sie zapisac rekordu".'</p>';
  1188. } else {
  1189. $form_saved = true;
  1190. }
  1191. // save HIST
  1192. $sql_arr = array();
  1193. foreach ($arr as $k => $v) {
  1194. $sql_arr["`".$k."`"] = "'".$v."'";
  1195. }//end foreach
  1196. $sql_arr["`ID_USERS2`"] = "'".$record_id."'";
  1197. $hist_table = $thiss->DETECT_TABLE_NAME . "_HIST";
  1198. $sql = "insert into `".$hist_table."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  1199. DB::query($sql);
  1200. $ret_id = DB::insert_id();
  1201. if (!$ret_id) {
  1202. echo'<p style="color:red">'."Error: nie udalo sie zapisac danych do tabeli HIST".'</p>';
  1203. }
  1204. if ($form_saved) {
  1205. echo'<p style="color:green">'."Dane zapisano pomyslnie".'</p>';
  1206. return;
  1207. }
  1208. }
  1209. }
  1210. echo'<form action="" method="POST">';
  1211. echo'<input type="hidden" name="'."save".'" value="'."1".'" />';
  1212. echo "Data: ";
  1213. echo '<input name="'."W_DATA_DOSTARCZONO".'" type="text" size="10" value="'.$post['W_DATA_DOSTARCZONO'].'" />';
  1214. echo'<input type="submit" value="'."zapisz".'" />';
  1215. echo'</form>';
  1216. }
  1217. function USERS2_MARKETING_AKCJE_task_EDIT_zlecenie_kontroli($record_id, &$record) {
  1218. global $thiss;
  1219. {
  1220. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  1221. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  1222. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  1223. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  1224. }
  1225. echo'<style type="text/css">'."
  1226. body{font-size:small;padding:0 6px;}
  1227. td,table,tr{font-size:xx-small;line-height:1.4em;}
  1228. input{margin:0;padding:0;}
  1229. ".'</style>';
  1230. $buildings = USERS2_MARKETING_AKCJE::get_buildings($record_id, $record);
  1231. $post_saved = array();
  1232. $post = array();
  1233. foreach ($buildings as $k_street => $h) {
  1234. $post[$k_street] = V::get($k_street, $h['ROZNIESIONO'], $_POST);
  1235. }//end foreach
  1236. if (1 == V::get('print', '', $_POST)) {
  1237. }
  1238. if (!empty($buildings)) {
  1239. echo '<table border="1" cellspacing="0" cellpadding="0" width="100%">';
  1240. echo "\n".'<tr>'.'<td colspan="14">'."ZLECENIE KONTROLI DYSTRYBUCJI (" . $record['ID'] . ")".'</td></tr>';
  1241. echo '<tr><td rowspan="2" width="5">'."lp".'</font></td>';
  1242. echo'<td rowspan="2">'."Data".'</td>';
  1243. echo'<td rowspan="2">'."Godzina".'</td>';
  1244. echo'<td rowspan="2">'."Ulica/Budynek".'</td>';
  1245. echo'<td rowspan="2">'."Klatka".'</td>';
  1246. echo'<td colspan="2">'."Plakat klatka".'</td>';
  1247. echo'<td colspan="2">'."Ulotka gumka klamka".'</td>';
  1248. echo'<td colspan="2">'."Ulotka skrzynka".'</td>';
  1249. echo'<td colspan="2">'."Materiał ostatnie pietro".'</td>';
  1250. echo'<td rowspan="2" width="90">'."Inne uwagi".'</td>';
  1251. echo'</tr>';
  1252. echo '<tr>';
  1253. echo'<td>'."JEST".'</td>';
  1254. echo'<td>'."BRAK".'</td>';
  1255. echo'<td>'."JEST".'</td>';
  1256. echo'<td>'."BRAK".'</td>';
  1257. echo'<td>'."JEST".'</td>';
  1258. echo'<td>'."BRAK".'</td>';
  1259. echo'<td>'."JEST".'</td>';
  1260. echo'<td>'."BRAK".'</td>';
  1261. for ($i = 1; $i <= 30; $i++) {
  1262. echo '<tr height="5">';
  1263. echo'<td width="10">'.$i.'</td>';
  1264. echo'<td>'.". . ".'</td>';
  1265. echo'<td>'.". . ".'</td>';
  1266. echo'<td>'.". . ".'</td>';
  1267. echo'<td>'.". . ".'</td>';
  1268. echo'<td>'.". . ".'</td>';
  1269. echo'<td>'.". . ".'</td>';
  1270. echo'<td>'.". . ".'</td>';
  1271. echo'<td>'.". . ".'</td>';
  1272. echo'<td>'.". . ".'</td>';
  1273. echo'<td>'.". . ".'</td>';
  1274. echo'<td>'.". . ".'</td>';
  1275. echo'<td>'.". . ".'</td>';
  1276. echo'<td>'.". . ".'</td>';
  1277. echo'</tr>'."\n";
  1278. }
  1279. echo '<tr>'.'<td colspan="2">'."Imię i nazwisko sprawdzającego:".'</td>';
  1280. echo'<td colspan="4">'.$record['K_USER'].'</td>';
  1281. echo'<td colspan="4">'." Data procesu dystrybucji ".'</td>';//Data i numer procesu dystrybucji
  1282. echo'<td colspan="5">'.$record['W_DATA'] . " (" . $record['ID'] . ")" . '</td>';
  1283. echo'</tr>';
  1284. echo '<tr><td colspan="6" rowspan="2">'."Obszar dla kontroli: ";
  1285. echo str_replace(',', ', ', $record['FILTR_S_ADDRESS_STREET']);
  1286. echo '</td>';
  1287. echo'<td colspan="4">'."Okres badania:".'</td>';
  1288. echo'<td colspan="5">'."wyłącznie w dniu: ".$record['K_DATA']." , <br> pomiędzy godzinami od ... do ...".'</td>';
  1289. echo'</tr>';
  1290. echo'<tr>';
  1291. echo'<td colspan="4">'."Termin i miejsce dostarczenia raportu kontroli".'</td>';
  1292. echo'<td colspan="5">'."raport należy dostarczyć w ........ do godziny ..... w miejsce:".'</td>';
  1293. echo'</tr>';
  1294. echo'<tr>';
  1295. echo'<td colspan="14">'."Regulamin wypełnienia raportu: 1. Zleceniobiorca zobowiązuje się sprawdzić czy materiały reklamowe zostały rozmieszczone na wyznaczonym obszarze działania.";
  1296. echo'<br>'."2.Wyniki kontroli rozmieszczenia materiałów reklamowych należy zapisywać w trakcie trwania kontroli w otrzymanym Raporcie kontroli ulotek. Musi on zawierać rzetelnie i czytelnie wypełnione pola.";
  1297. echo'<br />'."Sposób wypełnienia niniejszego raportu wygląda następująco: W kolumnie .Data. oraz .Godzina. należy wpisać każdorazowo datę oraz godzinę rozpoczęcia czynności na danym budynku, w kolumnie .Ulica budynek. wpisać stosownany skrót np. .CH7. to Całubińskiego 7 w kolumnie .klatka. wpisać A,B lub C(i tak dalej), w pozostałych kolumnach umiescić X w stosownym miejscu w zależności czy był materiał reklamowy, czy nie; w .Inne/Uwagi. wpisywać np. czy były problemy z wejściem do budynku, jeśli tak, to kto nie chciał wpuścicić.";
  1298. echo'<br />'."3. Zleceniobiorca zobowiązuje się przeprowadzić kontrolę w wyżej określonym przedziale czasu .";
  1299. echo'<br />'."4. Raport kontroli ulotek należy dostarczyć zgodnie z zapisami w tabeli względnie czytelny skan na adres e-mail: marketing@biall.net.pl , z zaznaczeniem w temacie Daty i numeru procesu dystrybucji : $DATA_PROCESU_DYSTRYBUCJI / $NUMER_PROCESU_DYSTRYBUCJI .";
  1300. echo'<br />'."5. Raporty kontroli ulotek winny być wypełnione wg schematu w raporcie (oznaczonego w pkt. x), czyli np. w polu .godzina/data. należy umieścić datę i godzinę rozpoczęcia kontroli rozmieszczenia materiałów na danym budynku. Niewypełnienie tych pól lub/i raportu jest równoznaczne z niewykonaniem zlecenia. Brane będą wyłącznie pod uwagę fragmenty raportu wypełnione w pełni, rzetelnie i czytelnie. Wszystkie inne pola (rzędy arkusza) wypełnione częściowo lub w ogóle, będą traktowane jakoby w danym adresie dystrybucja nie miała miejsca. Od momentu oddania raportu kontroli ulotek zakazane jest uzupełnianie raportu przez którąkolwiek ze stron. Wpisy w danym rzędzie w raporcie winny być wypełnione jednym i tym samym długopisem.";
  1301. echo'<br />'."6. Zlecenie realizowane jest tylko wyznaczonym obszarze (Obszar dla kontroli).";
  1302. echo'<br />'."7. Nie wywiązanie się z wyżej wymienionych zadań równoznaczne jest z nie wykonaniem powierzonej pracy, co się wiąże brakiem wynagrodzenia a nawet pokryciem strat firmy wynikających z tego tytułu.".'</td>';
  1303. echo'</tr>';
  1304. echo '</table>';
  1305. }
  1306. echo '<p style="page-break-before:always">'."\n";
  1307. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id.'">'."Cofnij ".'<img src="icon/back.gif" border="0" alt="POWROT"></a>';
  1308. }
  1309. function USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie_kontroli_data($record_id, &$record) {
  1310. global $thiss;
  1311. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id.'">'."Cofnij ".'<img src="icon/back.gif" border="0" alt="POWROT"></a>';
  1312. echo'<h1>'."Wprowadz datę dostarczenia kontroli dystrybucji przez pracownika".'</h1>';
  1313. $form_saved = false;
  1314. $post = array();
  1315. $post['K_DATA_DOSTARCZONO'] = V::get('K_DATA_DOSTARCZONO', date('Y-m-d'), $_POST);
  1316. if (1 == V::get('save', '', $_POST)) {
  1317. // verify data
  1318. if (!empty($post['K_DATA_DOSTARCZONO'])) {
  1319. $arr = array();
  1320. $arr['A_RECORD_UPDATE_DATE'] = date('Y-m-d-H:i');
  1321. $arr['A_RECORD_UPDATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  1322. $arr['K_DATA_DOSTARCZONO'] = $post['K_DATA_DOSTARCZONO'];
  1323. $sql_arr = array();
  1324. foreach ($arr as $k => $v) {
  1325. $sql_arr []= "`".$k."`='".$v."'";
  1326. }//end foreach
  1327. $sql = "update `".$thiss->DETECT_TABLE_NAME."` set ".implode(",", $sql_arr)." where `ID`='".$record_id."' limit 1 ";
  1328. DB::query($sql);
  1329. $ret_affected = DB::affected_rows();
  1330. if (!$ret_affected) {
  1331. echo'<p style="color:red">'."Error: nie udalo sie zapisac rekordu".'</p>';
  1332. } else {
  1333. $form_saved = true;
  1334. }
  1335. // save HIST
  1336. $sql_arr = array();
  1337. foreach ($arr as $k => $v) {
  1338. $sql_arr["`".$k."`"] = "'".$v."'";
  1339. }//end foreach
  1340. $sql_arr["`ID_USERS2`"] = "'".$record_id."'";
  1341. $hist_table = $thiss->DETECT_TABLE_NAME . "_HIST";
  1342. $sql = "insert into `".$hist_table."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  1343. DB::query($sql);
  1344. $ret_id = DB::insert_id();
  1345. if (!$ret_id) {
  1346. echo'<p style="color:red">'."Error: nie udalo sie zapisac danych do tabeli HIST".'</p>';
  1347. }
  1348. if ($form_saved) {
  1349. echo'<p style="color:green">'."Dane zapisano pomyslnie".'</p>';
  1350. return;
  1351. }
  1352. }
  1353. }
  1354. echo'<form action="" method="POST">';
  1355. echo'<input type="hidden" name="'."save".'" value="'."1".'" />';
  1356. echo "Data: ";
  1357. echo '<input name="'."K_DATA_DOSTARCZONO".'" type="text" size="10" value="'.$post['K_DATA_DOSTARCZONO'].'" />';
  1358. echo'<input type="submit" value="'."zapisz".'" />';
  1359. echo'</form>';
  1360. }
  1361. function USERS2_MARKETING_AKCJE_task_EDIT_wprowadz_zlecenie_kontroli($record_id, &$record) {
  1362. global $thiss;
  1363. // USERS2_MARKETING_AKCJE_BUILDINGS
  1364. {
  1365. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  1366. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  1367. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  1368. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  1369. }
  1370. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$record_id.'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  1371. echo'<h1>'."Wprowadz zlecenie do systemu".'</h1>';
  1372. $buildings = USERS2_MARKETING_AKCJE::get_buildings($record_id, $record);
  1373. echo'<p>'."Dotyczy akcji ".$record['ID']." z dnia ".$record['DATA'].'</p>';
  1374. $post_saved = array();
  1375. $post = array();
  1376. foreach ($buildings as $k_street => $h) {
  1377. $post[$k_street] = V::get($k_street, $h['KONTROLA'], $_POST);
  1378. $post['UWAGI_'.$k_street] = V::get('UWAGI_'.$k_street, $h['KONTROLA_UWAGI'], $_POST);
  1379. }//end foreach
  1380. if (1 == V::get('save', '', $_POST)) {
  1381. if ("zakoncz" == V::get('sbmt', '', $_POST)) {
  1382. $form_saved = false;
  1383. $arr = array();
  1384. $arr['A_RECORD_UPDATE_DATE'] = date('Y-m-d-H:i');
  1385. $arr['A_RECORD_UPDATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  1386. $arr['K_DATA_WPROWADZONO'] = date('Y-m-d');
  1387. $sql_arr = array();
  1388. foreach ($arr as $k => $v) {
  1389. $sql_arr []= "`".$k."`='".$v."'";
  1390. }//end foreach
  1391. $sql = "update `USERS2_MARKETING_AKCJE` set ".implode(",", $sql_arr)." where `ID`='".$record_id."' limit 1 ";
  1392. DB::query($sql);
  1393. $ret_affected = DB::affected_rows();
  1394. if (!$ret_affected) {
  1395. echo'<p style="color:red">'."Error: nie udalo sie zapisac rekordu".'</p>';
  1396. } else {
  1397. $form_saved = true;
  1398. }
  1399. // save HIST
  1400. $sql_arr = array();
  1401. foreach ($arr as $k => $v) {
  1402. $sql_arr["`".$k."`"] = "'".$v."'";
  1403. }//end foreach
  1404. $sql_arr["`ID_USERS2`"] = "'".$record_id."'";
  1405. $hist_table = "USERS2_MARKETING_AKCJE_HIST";
  1406. $sql = "insert into `".$hist_table."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  1407. DB::query($sql);
  1408. $ret_id = DB::insert_id();
  1409. if (!$ret_id) {
  1410. echo'<p style="color:red">'."Error: nie udalo sie zapisac danych do tabeli HIST".'</p>';
  1411. }
  1412. if ($form_saved) {
  1413. echo'<p style="color:green">'."Dane zapisano pomyslnie".'</p>';
  1414. return;
  1415. }
  1416. }
  1417. else {
  1418. foreach ($buildings as $k_street => $h) {
  1419. if (!in_array($post[$k_street], array('TAK','NIE'))) continue;
  1420. $arr = array();
  1421. $arr['A_RECORD_UPDATE_DATE'] = date('Y-m-d-H:i');
  1422. $arr['A_RECORD_UPDATE_AUTHOR'] = $_SESSION['ADM_ACCOUNT'];
  1423. $arr['KONTROLA'] = $post[$k_street];
  1424. $arr['KONTROLA_UWAGI'] = $post['UWAGI_'.$k_street];
  1425. $sql_arr = array();
  1426. foreach ($arr as $k => $v) {
  1427. $sql_arr []= "`".$k."`='".$v."'";
  1428. }//end foreach
  1429. $sql = "update `".$thiss->DETECT_TABLE_NAME."` set ".implode(",", $sql_arr)." where `ID`='".$h['ID']."' limit 1 ";
  1430. DB::query($sql);
  1431. $ret_affected = DB::affected_rows();
  1432. $post_saved[$k_street] = $ret_affected;
  1433. if (0) {
  1434. // save HIST
  1435. $sql_arr = array();
  1436. foreach ($arr as $k => $v) {
  1437. $sql_arr["`".$k."`"] = "'".$v."'";
  1438. }//end foreach
  1439. $sql_arr["`ID_USERS2`"] = "'".$record_id."'";
  1440. $hist_table = $thiss->DETECT_TABLE_NAME . "_HIST";
  1441. $sql = "insert into `".$hist_table."` (".implode(",", array_keys($sql_arr)).") values(".implode(",", $sql_arr)."); ";
  1442. DB::query($sql);
  1443. $ret_id = DB::insert_id();
  1444. if (!$ret_id) {
  1445. echo'<p style="color:red">'."Error: nie udalo sie zapisac danych do tabeli HIST".'</p>';
  1446. }
  1447. }
  1448. }//end foreach
  1449. $all_ok = true;
  1450. if (!empty($post_saved)) {
  1451. foreach ($post_saved as $k_street => $val) {
  1452. if (!$val) $all_ok = false;
  1453. }//end foreach
  1454. }
  1455. if ($all_ok) {
  1456. echo'<p style="color:green">'."Dane zapisano pomyslnie".'</p>';
  1457. }
  1458. }
  1459. }
  1460. if (!empty($buildings)) {
  1461. echo'<form action="" method="POST">';
  1462. echo'<input type="hidden" name="'."save".'" value="1" />';
  1463. $out_buildings = array();
  1464. $out_tabindex = 0;
  1465. foreach ($buildings as $k_street => $h) {
  1466. $out_item = $k_street.' ';
  1467. //$out_item .= '/'.$h['DO_ROZNIESIENIA'];
  1468. $checked = ($post[$k_street] == 'TAK')? ' checked="checked"' : '';
  1469. $out_item .= '<input name="'.$k_street.'" type="radio" value="'."TAK".'" tabindex="'.(++$out_tabindex).'" '.$checked.' />'."<code>TAK</code>";
  1470. $checked = ($post[$k_street] == 'NIE')? ' checked="checked"' : '';
  1471. $out_item .= '<input name="'.$k_street.'" type="radio" value="'."NIE".'" tabindex="'.(++$out_tabindex).'" '.$checked.' />'."<code>NIE</code>";
  1472. $f_uwagi = 'UWAGI_'.$k_street;
  1473. $out_item .= ' <em style="font-size:small;">'."Uwagi:".'</em>';
  1474. $out_item .= '<input name="'.$f_uwagi.'" type="text" value="'.$post[$f_uwagi].'" tabindex="'.(++$out_tabindex).'" />';
  1475. $out_buildings []= $out_item;
  1476. }//end foreach
  1477. // split to cols
  1478. $building_cols = array();// [col_nr] => [line_nr] => {obj}
  1479. $limit_cols = 2;// limit kolumn
  1480. $limit_lines = ceil(count($buildings) / $limit_cols) + 1;
  1481. $cur_col_ind = 0;
  1482. $cur_line = 0;
  1483. foreach ($out_buildings as $out_item) {
  1484. $cur_line++;
  1485. if ($cur_line >= $limit_lines) {
  1486. $cur_line = 1;
  1487. $cur_col_ind++;
  1488. }
  1489. $building_cols[ $cur_col_ind ][ $cur_line ] = $out_item;
  1490. }//end foreach
  1491. $max_col_count = 0;
  1492. foreach ($building_cols as $k_col_nr => $v_col_arr) {
  1493. $max_col_count = max($max_col_count, count($v_col_arr));
  1494. }//end foreach
  1495. echo'<table border="0" cellspacing="0" cellpadding="0">';
  1496. for ($line_nr = 0; $line_nr <= $max_col_count; $line_nr++) {
  1497. echo'<tr>';
  1498. for ($col_nr = 0; $col_nr < $limit_cols; $col_nr++) {
  1499. echo'<td style="width:25%;padding:0 10px;">';
  1500. if (isset($building_cols[ $col_nr ][ $line_nr ])) {
  1501. echo $building_cols[ $col_nr ][ $line_nr ];
  1502. } else {
  1503. echo "&nbsp;&nbsp;&nbsp;";
  1504. }
  1505. echo'</td>';
  1506. }
  1507. echo'</tr>';
  1508. }
  1509. echo'</tbody>';
  1510. echo'</table>';
  1511. echo'<input type="submit" value="'."zapisz".'" />';
  1512. echo'<p>';
  1513. echo "Jesli wprowadzono wszystkie dane ";
  1514. echo '<input type="submit" name="'."sbmt".'" value="'."zakoncz".'" />';
  1515. echo " wprowadzanie raportu";
  1516. echo'</p>';
  1517. echo'</form>';
  1518. }
  1519. }
  1520. function USERS2_MARKETING_AKCJE_list() {
  1521. global $thiss, $GETZAPSQL,$SQL_USER,$USERS_FILTER_STATUS,$SQL_WIEV,$USERS_COLUMN,$USERS_COLUMN_DESC,$USERS_HIDECOLUMN;
  1522. SEF("MENU");
  1523. MENU();
  1524. if (!$_SESSION[$thiss->DETECT_TABLE_COLUMN]['SQL_WIEV_CURR_SQL']) SQL_WIEV();
  1525. GETZAPSQL();
  1526. $zapSQL = "SELECT ".$GETZAPSQL['WHAT_SQL']." from ".$GETZAPSQL['FROM_SQL']." where ".$GETZAPSQL['WHERE']." ;";
  1527. if ($_SESSION['DEBUG']) {
  1528. echo "zapSQL is $zapSQL<hr>".$_SESSION[$thiss->DETECT_TABLE_COLUMN]['FINDSQL']."<hr>";
  1529. echo "<hr>GETZAPSQL[SQL] $GETZAPSQL[SQL]<hr>";
  1530. } //EOF GETZAPSQL TESTS
  1531. $result = DB::query($zapSQL) or die("Blad $zapSQL zapytania2!");
  1532. $_SESSION['MYSQL_NUM_ROWS_TOTAL']['USERS'] = DB::num_rows($result); //TO_REMOVE_VARIABLE TODO
  1533. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['MYSQL_NUM_ROWS_TOTAL'] = DB::num_rows($result);
  1534. $zapSQL = "SELECT ".$GETZAPSQL['WHAT_SQL']." from ".$GETZAPSQL['FROM_SQL']." where ".$GETZAPSQL['WHERE2']." ;";
  1535. if ($_SESSION['DEBUG']) echo "<hr>CORRECT_SQL_ZAPYTANIE **/*/* $thiss->DETECT_TABLE_COLUMN $zapSQL **/*";
  1536. $result = DB::query($zapSQL) or die("Blad zapytania2 $zapSQL!");
  1537. $num_rows = DB::num_rows($result);
  1538. $_SESSION['MYSQL_NUM_ROWS'] = $num_rows;
  1539. NAVIGATOR();
  1540. //if(strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['FUNCPERMEDIT']['P_NEW_DEAL'],'RW')) {
  1541. echo "&nbsp;&nbsp; | &nbsp;&nbsp;";
  1542. CREATE_MENUFUNC_INIT_2('USERS2_MARKETING_AKCJE','ADD','','<font size=-1>( DODAJ NOWY<img src=icon/new.gif border=0 alt="DODAJ NOWY"> )</font>') ;
  1543. //}
  1544. echo "&nbsp;&nbsp; | &nbsp;&nbsp;";
  1545. CREATE_MENUFUNC_INIT_2('USERS2_MARKETING_AKCJE','PODSUMOWANIE','','<font size=-1> PODSUMOWANIE </font>') ;
  1546. echo'<table width="100%" border="1" cellspacing="0" cellpadding="0" class="tbl-view">';
  1547. echo'<thead>';
  1548. echo "<tr><TD><font size=-1>";
  1549. CREATE_MENU_NOTD_INIT_3('FILTER_SEARCH','MENU_FIND','ENABLE','<img src=icon/search.gif alt=SZUKAJ border=0>');
  1550. echo "</TD>";
  1551. foreach ($GETZAPSQL['ID'] as $value) {
  1552. if (true) {
  1553. echo "<td><font size='-2'>";
  1554. $ALT = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][ $GETZAPSQL['WHAT_DESC'][$value] ];
  1555. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['SORTED'][ $GETZAPSQL['WHAT_DESC'][$value] ] == 'PRI') $border=1; else $border=0;
  1556. CREATE_MENU_NOTD_INIT_2('USERS_SORTER', 'USERS_SORTER', 'USERS_SORTER1', $GETZAPSQL['WHAT_DESC'][$value], '<img src=icon/sortred.gif border='.$border.' alt=SORTUJ><img src=icon/sortred.gif border='.$border.' alt=SORTUJ>');
  1557. if (($_SESSION[$thiss->DETECT_TABLE_COLUMN]['USERS_SORTER_SQL']) || ($_SESSION['USERS_SORTER_SQL'])) { //TODO remove second extra cond.
  1558. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['SORTED'][$GETZAPSQL['WHAT_DESC'][$value]]=='SEC') $border=1; else $border=0; // echo "<font color='green'><img src=icon/sort.gif width=10 border=0 alt=sortuj></font>";
  1559. CREATE_MENU_NOTD_INIT_2('USERS_SORTER','USERS_SORTER','USERS_SORTER2',$GETZAPSQL['WHAT_DESC'][$value],'<img src=icon/sort.gif border='.$border.' alt=sortuj>') ;
  1560. }
  1561. //CREATE_MENU_NOTD_INIT_3('USERS_COLUMN',$_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_KEY'][$GETZAPSQL['WHAT_DESC'][$value]],'HIDE','<img src=icon/shutdown.gif border=0 alt="WYLACZ_KOLUMNE '.$ALT.'">') ;
  1562. echo "<br><b>" .str_replace('_',' ',$GETZAPSQL['WHAT_DESC'][$value]) . "</font></b></td>";
  1563. //echo "<br><b>" . $GETZAPSQL[WHAT_DESC][$value] . "</font></b></td>";
  1564. }
  1565. }
  1566. echo "</tr> \n";
  1567. //SECOND_ROW
  1568. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['MENU_FIND'] == 'ENABLE') {
  1569. echo '<tr>';
  1570. echo '<td>';
  1571. echo '<font size="-2">';
  1572. echo '<form action="" method="POST" name="FILTER_SEARCH">';
  1573. CREATE_MENU_NOTD_INIT_3('FILTER_SEARCH', 'MENU_FIND', '', 'X');
  1574. echo '<input type="button" onclick="ClearAllFind()" value="Czyść" />';
  1575. echo '<input type="hidden" name="FUNCTION_INIT" value="FILTER_SEARCH" />';
  1576. echo '<input type="submit" value="OK" />';
  1577. echo '</td>';
  1578. foreach ($GETZAPSQL['ID'] as $value) {
  1579. if (true) {
  1580. echo '<td>';
  1581. echo '<font size="-2">';
  1582. GETFORMITEM($_SESSION[$thiss->DETECT_TABLE_COLUMN]['FIND'][$GETZAPSQL['WHAT_DESC'][$value]], $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPE'][$GETZAPSQL['WHAT_DESC'][$value]], $GETZAPSQL['WHAT_DESC'][$value]);
  1583. echo '</font>';
  1584. echo '</td>';
  1585. } //EOF if (!$thiss->DETECT_TABLE_COLUMN[HIDE][$value]==HIDE)
  1586. } //EOF foreach ($thiss->DETECT_TABLE_COLUMN[ID] as $value)
  1587. echo '</form>';
  1588. echo '</tr>' . "\n";
  1589. } //EOF if ($_SESSION[$thiss->DETECT_TABLE_COLUMN][MENU_FIND]==ENABLE)
  1590. echo'</thead>';
  1591. if ( $num_rows == 0 ) {
  1592. echo "</tr></table>Brak Danych";
  1593. } else {
  1594. $t = 0;
  1595. echo'<tbody>';
  1596. while ($h = DB::fetch_assoc($result)) {
  1597. $row_id = $h['ID'];
  1598. echo '<TR class="row-' . ($t = 1 - $t) . '">';
  1599. echo '<TD align="center">';
  1600. echo'<a href="'."./index.php?FUNCTION_INIT=COPY_RECORD&amp;ARG1=NR_POZ&amp;ARG1_VAL=".$row_id.'" onclick="'."return confirm('Czy na pewno chcesz utworzyć nowy rekord na podstawie danych z rekordu ID = ".$row_id."?');".'">'."CP".'</a>';
  1601. echo "&nbsp;&nbsp;";
  1602. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=HIST&ARG1_VAL=".$row_id.'"><img src="icon/history.gif" alt="HISTORIA" border="0" width="18"></a>';
  1603. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=EDIT&ARG1_VAL=".$row_id.'"><img src="icon/edit.gif" alt="EDYCJA" border="0" width="20"></a>';
  1604. echo'</td>';
  1605. foreach ($GETZAPSQL['WHAT_DESC'] as $field_name) {
  1606. echo '<td>';
  1607. echo USERS2_MARKETING_AKCJE::print_akcje_table_item($field_name, $h);
  1608. echo '</td>';
  1609. }
  1610. echo "</TR>\n";
  1611. }
  1612. echo'</tbody>';
  1613. }
  1614. echo "</table>";
  1615. }
  1616. // hist view function
  1617. function USERS2_MARKETING_AKCJE_task_HIST() {
  1618. //WIEVTABLE_HIST();
  1619. global $thiss;
  1620. global $MENU_INIT,$ARG1,$ARG1_VAL,$SQL_USER,$SQL_DATABASE,$INTERFACE_ADDR,$SQL_USER_PASS,$USERS_FILTER_STATUS,$SQL_WIEV,$USERS_COLUMN,$USERS_COLUMN_DESC,$USERS_HIDECOLUMN;
  1621. {
  1622. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_HIST_COLUMN';
  1623. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_HIST';
  1624. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  1625. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  1626. }
  1627. if (($MENU_INIT == $thiss->DETECT_HIST_FUNCTION) && ($ARG1 = 'HISTORY')) {
  1628. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID'] = "$ARG1_VAL";
  1629. if ($_SESSION['DEBUG']) echo "VALUALIZED at $thiss->DETECT_TABLE_COLUMN func _SESSION[$thiss->DETECT_TABLE_COLUMN][WIEVID] = $ARG1_VAL";
  1630. }
  1631. SEF("MENU");
  1632. MENU();
  1633. NAVIGATOR();
  1634. TOOLBAR_DETECT();
  1635. $zapSQL = "SELECT * from `".$thiss->DETECT_TABLE_NAME."` where `ID_USERS2`='".$_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID']."' ;";
  1636. $result = DB::query($zapSQL) or die("Blad zapytania2!L");
  1637. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['MYSQL_NUM_ROWS_TOTAL'] = DB::num_rows($result);
  1638. $zapSQL = "SELECT * from `".$thiss->DETECT_TABLE_NAME."` where `ID_USERS2`='".$_SESSION[$thiss->DETECT_TABLE_COLUMN]['WIEVID']."' ".$_SESSION[$thiss->DETECT_TABLE_COLUMN]['USERS_SORTER_SQL']." ". $_SESSION[$thiss->DETECT_TABLE_COLUMN]['SQL_WIEV_CURR_SQL']." ;";
  1639. $result = DB::query($zapSQL) or die("Blad zapytania2!");
  1640. $num_rows = DB::num_rows($result);
  1641. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['MYSQL_NUM_ROWS'] = $num_rows;
  1642. echo "<BR>LICZBA_WIERSZY $num_rows<BR>";
  1643. echo "\n<table width='100%' border='1' cellspacing='0' cellpadding='0'>";
  1644. echo "<TD><font size=-2>";
  1645. echo "</TD>";
  1646. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['ID'] as $value) {
  1647. if (!$_SESSION[$thiss->DETECT_TABLE_COLUMN]['HIDE'][$value] == 'HIDE') {
  1648. echo "<td><font size='-2'>" ;
  1649. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['SORTED'][ $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value] ] == 'PRI') $border=1; else $border=0;
  1650. CREATE_MENU_NOTD_INIT_2('USERS_SORTER','USERS_SORTER','USERS_SORTER1',$_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value],'<img src=icon/sortred.gif border='.$border.' alt=SORTUJ><img src=icon/sortred.gif border='.$border.' alt=SORTUJ>') ;
  1651. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['USERS_SORTER_SQL']) {
  1652. if ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['SORTED'][ $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value] ] == 'SEC') $border=1; else $border=0;
  1653. CREATE_MENU_NOTD_INIT_2('USERS_SORTER','USERS_SORTER','USERS_SORTER2',$_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value],'<img src=icon/sort.gif border='.$border.' alt=sortuj>') ;
  1654. }
  1655. CREATE_MENU_NOTD_INIT_3('USERS_COLUMN',$value,'HIDE','<img src=icon/shutdown.gif border=0 alt=sortuj>');
  1656. echo "<br><b>" . $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value] . "</font></b></td>";
  1657. }
  1658. }
  1659. if( $num_rows == 0 ) {
  1660. echo "</tr></table>Brak Danych" ;
  1661. return;
  1662. }
  1663. while ($h = DB::fetch_row($result)) {
  1664. echo "<TR><TD><font size=-2>";
  1665. echo "</TD>";
  1666. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['ID'] as $value) {
  1667. if (!$_SESSION[$thiss->DETECT_TABLE_COLUMN]['HIDE'][$value] == 'HIDE') {
  1668. echo "<TD";
  1669. USERS_COLUMN_COLOR($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value],$h[$value],'bgcolor');
  1670. echo ">";
  1671. if (!( "$h[$value]" == 'N/S;')) echo "$h[$value]";
  1672. echo "</td>";
  1673. }
  1674. }
  1675. echo "</tr>";
  1676. }
  1677. echo "</table>";
  1678. $result = DB::query($zapSQL) or die("Blad zapytania2!");
  1679. echo '<table border=1 cellspacing=0 cellpadding=0>';
  1680. while ($h = DB::fetch_row($result)) {
  1681. echo "<tr><TD>";
  1682. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['ID'] as $value) {
  1683. if ((!$_SESSION[$thiss->DETECT_TABLE_COLUMN]['HIDE'][$value]=='HIDE') && (!($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value]=='ID')) && (!($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value]=='ID_USERS2')) ) {
  1684. echo "<font ";
  1685. USERS_COLUMN_COLOR($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value],$h[$value],'color');
  1686. echo ">";
  1687. if((!( "$h[$value]" == 'N/S;')) && (!($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value]=='P_SERVICE_QUOTA_PROFILE'))) {
  1688. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$value] . "</font>=" . "$h[$value]" . "<BR>";
  1689. } else {
  1690. echo'</font>';
  1691. }
  1692. }
  1693. }
  1694. echo "</td></tr>";
  1695. }
  1696. echo "</table>";
  1697. }
  1698. // typespecial
  1699. function USERS2_MARKETING_AKCJE_typespecial_W_USER($action, $selected_value) {
  1700. FORM_typespecial_USER_SELECT('W_USER', $selected_value);
  1701. }
  1702. function USERS2_MARKETING_AKCJE_typespecial_K_USER($action, $selected_value) {
  1703. FORM_typespecial_USER_SELECT('K_USER', $selected_value);
  1704. }
  1705. function FORM_typespecial_USER_SELECT($field_name, $selected_value) {
  1706. $res = DB::query("select * from `ADMIN_USERS` where `A_STATUS`='NORMAL' and `ADM_TECH_WORKER`!='NO' and `ADM_COMPANY` like '".$_SESSION['ADM_COMPANY']."' ");
  1707. echo'<select name="'.$field_name.'"><option value="">'."&nbsp;".'</option>';
  1708. while ($r = DB::fetch($res)) {
  1709. echo'<option value="'.$r->ADM_ACCOUNT.'" ';
  1710. if ($r->ADM_ACCOUNT == $selected_value) {
  1711. echo'selected="selected"';
  1712. }
  1713. echo'>'.$r->ADM_NAME.'('.$r->ADM_ACCOUNT.')</option>';
  1714. }
  1715. echo'</select>';
  1716. }
  1717. function USERS2_MARKETING_AKCJE_typespecial_ID_PROJECT($action, $selected_value) {
  1718. $res = DB::query("select * from IN7_MK_BAZA_DYSTRYBUCJI where A_STATUS='NORMAL' or A_STATUS='OFF_SOFT' or A_STATUS='OFF_HARD' order by `ID` ");
  1719. echo '<select name="ID_PROJECT">';
  1720. echo '<option value=""> </option>';
  1721. while ($r = DB::fetch($res)) {
  1722. echo "\n".'<option value="' . $r->ID . '"';
  1723. if ($r->ID == $selected_value) echo ' selected="selected"';
  1724. echo '>' . $r->ID . "=" . $r->M_DIST_DESC . "(". $r->M_DISTRIBUTOR ." ".$r->TV_NAZWA_PROGRAMU. ")".'</option>';
  1725. }
  1726. echo '</select>';
  1727. }
  1728. function USERS2_MARKETING_AKCJE_typespecial_FILTR_M_REWIR($action, $value) {
  1729. FORM_typespecial_USER_TEXTAREA_readonly('FILTR_M_REWIR', $value);
  1730. }
  1731. function USERS2_MARKETING_AKCJE_typespecial_FILTR_S_ADDRESS_STREET($action, $value) {
  1732. FORM_typespecial_USER_TEXTAREA_readonly('FILTR_S_ADDRESS_STREET', $value);
  1733. }
  1734. function FORM_typespecial_USER_TEXTAREA_readonly($field_name, $value) {
  1735. echo'<textarea name="'.$field_name.'" id="'.$field_name.'" rows="4" cols="100" readonly="readonly">'.$value.'</textarea>';
  1736. }
  1737. function USERS2_MARKETING_AKCJE_task_ADD() {
  1738. global $thiss, $ARG1, $ARG1_VAL, $SQL_USER, $USERS_FILTER_STATUS, $SQL_WIEV, $USERS_COLUMN, $USERS_COLUMN_DESC, $USERS_HIDECOLUMN;
  1739. echo "Podaj dane do wprowadzenia do bazy ";
  1740. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE".'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  1741. $default_values = array();
  1742. $default_values['DATA'] = date('Y-m-d');
  1743. $default_values['FILTR_BEZ_BN'] = 'TAK';
  1744. $default_values['FILTR_ANEKSY'] = 'NIE';
  1745. $default_values['FILTR_MIN_ULOTEK_NA_BUDYNEK'] = '0';
  1746. $default_values['FILTR_MIN_DATA_OSTATNIEJ_AKCJI'] = '0';
  1747. $default_values['W_DATA'] = date("Y-m-d", mktime(0,0,0, date("m"), date("d") + 7, date("Y")));// domyslnie plus 7 dni na realizacje - doniesienie raportu
  1748. foreach ($default_values as $k_field_name => $v_field_value) {
  1749. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$k_field_name])) {
  1750. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$k_field_name] = $v_field_value;
  1751. }
  1752. }
  1753. //MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=ADD&ARG1_VAL=
  1754. echo'<form action="" method="POST" id="frm">';
  1755. echo'<table cellspacing="0" cellpadding="0" border="1">';
  1756. $t = 0;
  1757. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $value) {
  1758. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["$value"],"C")) {
  1759. continue;
  1760. }
  1761. echo'<tr class="row-' . ($t = 1 - $t) . '">';
  1762. echo '<td>';
  1763. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$value])) {
  1764. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$value];
  1765. echo '<br /><code style="font-size:x-small">'.$value.'</code>';
  1766. } else {
  1767. echo '<code>'.$value.'</code> ';
  1768. }
  1769. echo'</td>';
  1770. echo'<td>';
  1771. if ($_SESSION['LAST_MENU'] == $thiss->DETECT_TABLE_NAME) {
  1772. //$_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value] = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$value];
  1773. if ((strstr($ARG1_VAL,'RESTORE'))) $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value] = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['EDIT_TEMPLATE'][$value];
  1774. }
  1775. if (!isset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value])) {
  1776. GETFORMITEM($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value],$_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPE'][$value],$_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][$_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_KEY'][$value]]);
  1777. echo "($h[$value])";
  1778. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value];
  1779. } else if (isset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value])) {
  1780. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value]('', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value]);
  1781. } else {
  1782. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value];
  1783. }
  1784. echo " ".'</td></tr>'."\n";
  1785. }
  1786. echo'<tr>';
  1787. echo'<td colspan="2">';
  1788. USERS2_MARKETING_AKCJE::print_rewir_tree( $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'] );
  1789. echo'</td>';
  1790. echo'</tr>';
  1791. echo'<tr>';
  1792. echo'<td colspan="2" style="text-align:left">';
  1793. echo'<input type="hidden" name="'."task".'" value="'."verify".'" />';
  1794. echo'<input type="submit" value="'."Dalej".'" />';
  1795. echo'</td>';
  1796. echo'</tr>';
  1797. echo'</table>';
  1798. echo'</form>';
  1799. }
  1800. function USERS2_MARKETING_AKCJE_task_ADD_verify() {
  1801. global $thiss;
  1802. $buildings = array();
  1803. $ile_ulotek = 0;
  1804. echo "Zweryfikuj dane ";
  1805. // validation
  1806. $validation_errors = array();
  1807. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['ID_PROJECT'])) {
  1808. $validation_errors['ID_PROJECT'] []= "nie wybrano projektu";
  1809. }
  1810. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_M_REWIR']) && empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_S_ADDRESS_STREET'])) {
  1811. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_M_REWIR'])) {
  1812. $validation_errors['FILTR_M_REWIR'] []= "nie wybrano rewirow";
  1813. }
  1814. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_S_ADDRESS_STREET'])) {
  1815. $validation_errors['FILTR_S_ADDRESS_STREET'] []= "nie wybrano budynkow";
  1816. }
  1817. } else {
  1818. $rewiry = explode(',', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_M_REWIR']);
  1819. $streets = explode(',', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_S_ADDRESS_STREET']);
  1820. $sql_where_or_arr = array();
  1821. if (!empty($rewiry)) {
  1822. foreach ($rewiry as $rewir) {
  1823. $rewir = trim($rewir);
  1824. if (!empty($rewir)) {
  1825. $sql_where_or_arr []= "`M_REWIR` like '".$rewir."%'";
  1826. }
  1827. }//end foreach
  1828. }
  1829. if (!empty($streets)) {
  1830. foreach ($streets as $street) {
  1831. $street = trim($street);
  1832. if (!empty($street)) {
  1833. $sql_where_or_arr []= "`S_ADDRESS_STREET`='".$street."'";
  1834. }
  1835. }//end foreach
  1836. }
  1837. $sql = "select `S_ADDRESS_STREET` from `BUILDINGS` where ".implode(" or ", $sql_where_or_arr);
  1838. $res = DB::query($sql);
  1839. while ($r = DB::fetch($res)) {
  1840. $buildings []= $r->S_ADDRESS_STREET;
  1841. }
  1842. if (empty($buildings)) {
  1843. $validation_errors['FILTR_S_ADDRESS_STREET'] []= "brak budynkow pasujacych do kryteriow";
  1844. } else {
  1845. $buildings_rows = array();
  1846. $buildings_street = $buildings;
  1847. {// filtr
  1848. $record_data = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'];
  1849. $buildings = array();
  1850. $rewiry_selected = explode(',', $record_data['FILTR_M_REWIR']);
  1851. $buildings_selected = explode(',', $record_data['FILTR_S_ADDRESS_STREET']);
  1852. // fetch old actions on buildings
  1853. $old_actions = array();// [street] = last action date
  1854. $sql = "select
  1855. mb.`S_ADDRESS_STREET` as street
  1856. , max(ma.`DATA`) as last_date
  1857. from `USERS2_MARKETING_AKCJE_BUILDINGS` as mb
  1858. left join `USERS2_MARKETING_AKCJE` as ma on(ma.`ID`=mb.`ID_AKCJA`)
  1859. where
  1860. ma.`A_STATUS`!='DELETED'
  1861. group by mb.`S_ADDRESS_STREET`
  1862. ";
  1863. $res = DB::query($sql);
  1864. while ($r = DB::fetch($res)) {
  1865. $r->street = strtoupper($r->street);
  1866. $old_actions[$r->street] = $r->last_date;
  1867. }
  1868. // filtr bez BN
  1869. $sql_ulotek = "ov.`MIESZKAN`";
  1870. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  1871. $sql_ulotek = "(ov.`MIESZKAN` - ov.`ABO_I`)";
  1872. }
  1873. // filtr FILTR_MIN_ULOTEK_NA_BUDYNEK
  1874. $sql_ulotek_enable = "1";
  1875. if ($filtr_min_ulotek_na_budynek = V::get('FILTR_MIN_ULOTEK_NA_BUDYNEK', 0, $record_data, 'int')) {
  1876. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  1877. $sql_ulotek_enable = " ( (100 * ov.`ABO_I`) / ov.`MIESZKAN` ) <= ".$filtr_min_ulotek_na_budynek."";
  1878. }
  1879. }
  1880. // TODO: filtr aneksy - max 3-mce przed koncem umowy == pomin umowy konczace sie za ponad 3 miesiace
  1881. $aneksy_arr = array();
  1882. if (0) {//if ('TAK' == V::get('FILTR_ANEKSY', '', $record_data)) {
  1883. $sql = "select td.`SERVICES_S_ADDRESS_STREET`, td.`P_DEALDATE_TERM`
  1884. from `temp_DEALS_STATUS` as td
  1885. where td.`DEALS_ACTIVE`='1'
  1886. and td.`P_DEALDATE_TERM` > DATE_ADD(CURDATE(), INTERVAL 3 MONTH)
  1887. and td.`SERVICES_S_ADDRESS_STREET` in ('".implode("','", $buildings_street)."')
  1888. ";
  1889. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">sql FILTR_ANEKSY: ';print_r($sql);echo'</pre>';
  1890. $res = DB::query($sql);
  1891. while ($r = DB::fetch($res)) {
  1892. $r->SERVICES_S_ADDRESS_STREET = strtoupper($r->SERVICES_S_ADDRESS_STREET);
  1893. $aneksy_arr [$r->SERVICES_S_ADDRESS_STREET] = $r->P_DEALDATE_TERM;
  1894. }
  1895. }
  1896. $sql = "select b.`ID`, b.`M_REWIR`, b.`S_ADDRESS_STREET`, b.`P_ADDRESS_STREET`
  1897. , ov.`ABO_I`, ov.`MIESZKAN`
  1898. , $sql_ulotek as ile_ulotek
  1899. , ( (100 * ".$sql_ulotek.") / ov.`MIESZKAN` ) as pr
  1900. , $sql_ulotek_enable as ulotek_enable
  1901. , 1 as data_enable
  1902. from `BUILDINGS` as b
  1903. left join `USERS2_MARKETING_OVERWIEV` as ov on(ov.`T_TELBOX_BUILDING_IN`=b.`S_ADDRESS_STREET`)
  1904. where
  1905. b.`A_STATUS` in ('NORMAL','WARNING')
  1906. and b.`S_ADDRESS_STREET` in ('".implode("','", $buildings_street)."')
  1907. group by b.`ID`
  1908. order by b.`M_REWIR`
  1909. ";
  1910. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;display:none">sql FILTR_ANEKSY: ';print_r($sql);echo'</pre>';
  1911. $res = DB::query($sql);
  1912. while ($r = DB::fetch($res)) {
  1913. // $r->p_dealdate_term = null;
  1914. // $r->S_ADDRESS_STREET = strtoupper($r->S_ADDRESS_STREET);
  1915. // if ('TAK' == V::get('FILTR_ANEKSY', '', $record_data)) {
  1916. // if (array_key_exists($r->S_ADDRESS_STREET, $aneksy_arr)) {
  1917. // $r->p_dealdate_term = $aneksy_arr[$r->S_ADDRESS_STREET];
  1918. // }
  1919. // }
  1920. if ($filtr_data = V::get('FILTR_MIN_DATA_OSTATNIEJ_AKCJI', 0, $record_data)) {
  1921. if (array_key_exists($r->S_ADDRESS_STREET, $old_actions)) {
  1922. if ($old_actions[$r->S_ADDRESS_STREET] >= $filtr_data) {
  1923. $r->data_enable = 0;
  1924. $r->last_action_date = $old_actions[$r->S_ADDRESS_STREET];
  1925. }
  1926. }
  1927. }
  1928. $buildings [$r->ID] = $r;
  1929. }
  1930. foreach ($buildings as $r) {
  1931. if (!$r->ulotek_enable) continue;
  1932. if (!$r->data_enable) continue;
  1933. $buildings_rows []= $r->S_ADDRESS_STREET;
  1934. }
  1935. $buildings = $buildings_rows;
  1936. }// filtr
  1937. $sql = "select sum(".$sql_ulotek.") as cnt
  1938. from `USERS2_MARKETING_OVERWIEV` as ov
  1939. where ov.`T_TELBOX_BUILDING_IN` in('".implode("','", $buildings)."')
  1940. ";
  1941. $res = DB::query($sql);
  1942. if ($r = DB::fetch($res)) {
  1943. $ile_ulotek = $r->cnt;
  1944. }
  1945. }
  1946. }
  1947. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['W_USER'])) {
  1948. $validation_errors['W_USER'] []= "nie wybrano pracownika";
  1949. }
  1950. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['W_DATA'])) {
  1951. $validation_errors['W_DATA'] []= "nie wybrano terminu wykonania zadania";
  1952. }
  1953. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['K_USER'])) {
  1954. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['K_DATA'])) {
  1955. $validation_errors['K_DATA'] []= "nie wybrano terminu wykonania kontroli";
  1956. }
  1957. }
  1958. echo'<form action="" method="POST" id="frm">';
  1959. echo'<table cellspacing="0" cellpadding="0" border="1">';
  1960. $t = 0;
  1961. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  1962. if (strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][$field_name],"C")) {
  1963. echo'<tr class="row-' . ($t = 1 - $t) . '">';
  1964. echo '<td>';
  1965. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$field_name])) {
  1966. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$field_name];
  1967. echo '<br /><code style="font-size:x-small">'.$field_name.'</code>';
  1968. } else {
  1969. echo '<code>'.$field_name.'</code> ';
  1970. }
  1971. echo'</td>';
  1972. echo'<td>';
  1973. if (array_key_exists($field_name, $validation_errors)) {
  1974. echo'<b style="color:red"> !!! </b>';
  1975. }
  1976. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$field_name];
  1977. echo'</td>';
  1978. echo'</tr>'."\n";
  1979. }
  1980. }
  1981. echo'<tr>';
  1982. echo'<td colspan="2">';
  1983. if (!empty($validation_errors)) {
  1984. echo'<p style="color:red">'."Formularz zawiera bledy:".'</p>';
  1985. echo'<ul>';
  1986. foreach ($validation_errors as $k_field_name => $v_err) {
  1987. echo '<li>'."Pole ".$k_field_name.": ".implode(', ', $v_err).'</li>';
  1988. }//end foreach
  1989. echo'</ul>';
  1990. } else {
  1991. echo'<input type="hidden" name="'."update_FILTR_S_ADDRESS_STREET".'" value="'.implode(",", $buildings).'" />';
  1992. echo'<input type="hidden" name="'."update_ILE_ULOTEK".'" value="'.$ile_ulotek.'" />';
  1993. if (empty($buildings)) {
  1994. echo "Brak pasujacych budynkow";
  1995. } else {
  1996. echo "<b>Budynki:</b> ".implode(', ', $buildings);
  1997. }
  1998. echo'<br />'.'<b>'."Liczba potrzebnych ulotek: ".$ile_ulotek.'</b>';
  1999. }
  2000. echo'</td>';
  2001. echo'</tr>';
  2002. echo'<tr>';
  2003. echo'<td colspan="2" style="text-align:left">';
  2004. if (empty($validation_errors)) {
  2005. echo'<input type="hidden" name="'."task".'" value="'."save".'" />';
  2006. echo "Jesli dane sa poprawne przejdz ";
  2007. echo'<input type="submit" value="'."Dalej".'" />';
  2008. echo " lub ";
  2009. }
  2010. echo " cofnij w celu poprawienia danych ";
  2011. //CREATE_MENUFUNC_NOTD_INIT('USERS2_MARKETING_AKCJE','<img src=icon/back.gif border=0 alt=POWROT>');
  2012. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=ADD&ARG1_VAL=".'"><img src="icon/back.gif" border="0" alt="POWROT"></a>';
  2013. echo'</td>';
  2014. echo'</tr>';
  2015. echo'</table>';
  2016. echo'</form>';
  2017. }
  2018. function USERS2_MARKETING_AKCJE_view_zlecenie_1_strona( $record_id, &$record, &$buildings, $worker_name ) {
  2019. $DATA_ZLECENIA_KOLPORTAZU = $record['DATA'];
  2020. $DATA_PROCESU_DYSTRYBUCJI = $record['W_DATA'];
  2021. $NUMER_PROCESU_DYSTRYBUCJI = $record_id;
  2022. $ZLECENIOBIORCA = $worker_name;
  2023. $ILOSC_POWIERZONYCH_SZTUK_MATERIALOW = 1;// TODO: suma ulotek do rozniesienia
  2024. $mieszkan = 0;// TODO: suma ulotek do rozniesienia
  2025. {// get suma do rozniesienia
  2026. foreach ($buildings as $building) {
  2027. $mieszkan += $building['DO_ROZNIESIENIA'];
  2028. }//end foreach
  2029. // zaokroglenie w gore
  2030. $ILOSC_POWIERZONYCH_SZTUK_MATERIALOW = ceil(($mieszkan + 1) / 100) * 100;
  2031. }
  2032. $streets = array();
  2033. {// get street names
  2034. $sql_where_or_arr = array();
  2035. foreach ($buildings as $building) {
  2036. $sql_where_or_arr []= "'" . $building['S_ADDRESS_STREET'] . "'";
  2037. }//end foreach
  2038. $sql = "select `S_ADDRESS_STREET`, `P_ADDRESS_STREET` from `BUILDINGS` where `S_ADDRESS_STREET` in (".implode(",", $sql_where_or_arr).")";
  2039. $res = DB::query($sql);
  2040. while ($r = DB::fetch($res)) {
  2041. $streets [$r->P_ADDRESS_STREET] []= $r->S_ADDRESS_STREET;
  2042. }
  2043. }
  2044. $JAKIE_POWIERZONO_MATERIALY_plakaty_ulotki_itp = 'ulotki';
  2045. $INNE_POWIERZONE_PRZEDMIOTY_np_nozyczki_tasma_itp = ".................";
  2046. $MATERIALY_NALEZY_POJEDYNCZO_UMIESZCZAC_NA_np_klamka_drzwi_itp = "W skrzynce pocztowej";
  2047. $MATERIALY_NALEZY_ROZNIESC_W_DNIU = $record['W_DATA'];
  2048. $MATERIALY_NALEZY_ROZNIESC_OD_GODZINY = ".....";
  2049. $MATERIALY_NALEZY_ROZNIESC_TEGO_SAMEGO_DNIA_DO_GODZINY = ".....";
  2050. $MIEJSCE_DOSTARCZENIA_RAPORTU = "biuro Chełm";
  2051. $TERMIN_DATA_DOSTARCZENIA_RAPORTU = "..........";
  2052. $GODZINA_DOSTARCZENIA_RAPORTU = ".....";
  2053. $DODATKOWE_CZYNNOSCI_DO_ZROBIENIA_np_poskladac_ogumkowac_itp = "..........";
  2054. $LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW = ".....";// TODO: wartosc ulotek = koszt 1 ulotki z projektu * ilosc przekazanych ulotek
  2055. $WARTOSC_ZLECENIA = ".....";
  2056. $kara = (is_numeric($LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW) && is_numeric($WARTOSC_ZLECENIA))? ($LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW + $WARTOSC_ZLECENIA) * 2 : ".....";
  2057. echo '<table border="0" width="100%" cellspacing="0" cellpadding="0">';
  2058. echo '<tr><td colspan=14>';
  2059. echo '<br>'."ZLECENIE KOLPORTAŻU z dnia <i><b>".$DATA_ZLECENIA_KOLPORTAZU."</b></i>, do procesu dystrybucji nr <i><b>".$NUMER_PROCESU_DYSTRYBUCJI."</b></i> z dnia <i><b>".$DATA_PROCESU_DYSTRYBUCJI."</b></i>";
  2060. echo'<br><br>';
  2061. echo "Zleceniodawca:".'<br>';
  2062. echo "BIALL-NET sp. z o.o. 80-174 Gdańsk, Otomin ul. Słoneczna 43.".'<br><br>';
  2063. echo "Zleceniobiorca:".'<br>';
  2064. echo '<b>'.$ZLECENIOBIORCA.'</b><br>';
  2065. echo '<font size=1>';
  2066. echo "1) Zleceniobiorca zobowiązuje się rozprowadzić materiały reklamowe na obszarze (wg oznaczenia kodowego REWIRÓW i ULIC):";
  2067. echo '</font>';
  2068. echo '</td></tr>';
  2069. echo '<tr><td colspan=14>';
  2070. // TODO: add street names in ()
  2071. foreach ($streets as $k_street => $v_short_arr) {
  2072. echo "&nbsp;&nbsp;&nbsp; " . $k_street . ": " . implode(", ", $v_short_arr) . '<br />';
  2073. }//end foreach
  2074. echo '</td></tr>';
  2075. echo "<tr><td colspan=14>
  2076. <font size=1>
  2077. 2) Zleceniodawca powierza <b>$ILOSC_POWIERZONYCH_SZTUK_MATERIALOW</b> sztuk <b>$JAKIE_POWIERZONO_MATERIALY_plakaty_ulotki_itp</b> oraz inne przedmioty (<b>$INNE_POWIERZONE_PRZEDMIOTY_np_nozyczki_tasma_itp</b>)*, wszystkie o łącznej wartości <b>$LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW</b> PLN. zł.<br>
  2078. 3) Powierzone materiały reklamowe, pod rygorem niewypłacenia wartości zlecenia Zleceniobiorcy lub/i dodatkowo powstania innych roszczeń Zleceniodawcy tytułem strat wobec Zleceniobiorcy, rozprowadzić należy na wyznaczonym terenie w dniu <b>$MATERIALY_NALEZY_ROZNIESC_W_DNIU</b> od godziny <b>$MATERIALY_NALEZY_ROZNIESC_OD_GODZINY</b> do godziny <b>$MATERIALY_NALEZY_ROZNIESC_TEGO_SAMEGO_DNIA_DO_GODZINY</b> <br>
  2079. 4) Powierzone materiały reklamowe należy umieszczać pojedynczo na <b>$MATERIALY_NALEZY_POJEDYNCZO_UMIESZCZAC_NA_np_klamka_drzwi_itp</b> <br>
  2080. 5) Niniejsze zlecenie z uzupelnionymi polami Raportu roznoszenia ulotek wraz z pozostałymi materiałami reklamowymi, należy dostarczyć do dnia: <b>$TERMIN_DATA_DOSTARCZENIA_RAPORTU</b> do godziny: <b>$GODZINA_DOSTARCZENIA_RAPORTU</b> w miejsce <b>$MIEJSCE_DOSTARCZENIA_RAPORTU</b> .<br>
  2081. 6) Dodatkowe czynności, które zobowiązuje się przeprowadzić Zleceniobiorca przed rozprowadzeniem materiałów reklamowych: <b>$DODATKOWE_CZYNNOSCI_DO_ZROBIENIA_np_poskladac_ogumkowac_itp</b> <br>
  2082. 7) Wartość zlecenia wynosi <b>$WARTOSC_ZLECENIA</b> złotych.<br>
  2083. 8) Materiały opisane w pkt. 2) winny trafić w 100% do ustalonych miejsc dystrybucji (wg pkt. 1) oraz pkt. 4)) . W przypadku jakichkolwiek odstępstw od powyższego zlecającemu zostanie potrącona wysokość wynagrodzenia do 20% wartości zlecenia opisanego w pkt.7).<br>
  2084. 9) W przypadku, kiedy materiały opisane wyżej, w ilości większej lub równej 10% sztuk określonych w pkt. 2), zostały umieszczone w innych miejscach niż określa <nobr>pkt. 4) bądź </nobr> nie zostały umieszczone w ogóle, Zlecającemu przysługuje prawo do dodatkowego odszkodowania tytułem strat handlowych do wysokości ";
  2085. echo "<b>$kara</b>";
  2086. echo " zł.<br>
  2087. 10) Raporty roznoszenia ulotek winny być wypełnione wg schematu w raporcie ( oznaczonego w pkt. 5), czyli np. w polu .godzina/data. należy umieścić datę i godzinę rozpoczęcia dystrybucji materiałów danym budynku. Niewypełnienie tych pól lub/i raportu jest równoznaczne ze niewykonaniem zlecenia. Brane będą wyłącznie pod uwagę fragmenty raportu wypełnione w pełni, rzetelnie i czytelnie. Wszystkie inne pola (rzędy arkusza) wypełnione częściowo lub w ogóle, będą traktowane jakoby w danym adresie dystrybucja nie miała miejsca. Od momentu oddania raportu dystrybucji zakazane jest uzupełnianie raportu przez którąkolwiek ze stron. Wpisy w danym rzędzie w raporcie winny być wypełnione jednym i tym samym długopisem.<br>
  2088. 11) Nie wywiązanie się z wyżej wymienionych zadań równoznaczne jest z nie wykonaniem powierzonej pracy, co się wiąże brakiem wynagrodzenia a nawet pokryciem strat firmy wynikających z tego tytułu.<br>
  2089. 12) Zlecenie realizowane jest na obszarze <b>$mieszkan</b> mieszkań, według danych z systemu BIALL-NET. Zakłąda się, że mogą być od tej liczby odstępstwa, które zostaną zweryfikowane na podstawie niniejszego zlecenia. <br>
  2090. </font>
  2091. ";
  2092. ?>
  2093. <table style="width:100%;margin:20px 0;" border="0">
  2094. <tr>
  2095. <td style="width:10%">
  2096. </td>
  2097. <td style="text-aling:cetner;">
  2098. ZLECENIODAWCA
  2099. <br /><br />
  2100. .............
  2101. </td>
  2102. <td style="width:10%">
  2103. </td>
  2104. <td style="text-aling:cetner;">
  2105. ZLECENIOBIORCA
  2106. <br /><br />
  2107. <b><?php echo $ZLECENIOBIORCA; ?></b>
  2108. </td>
  2109. <td style="width:10%">
  2110. </td>
  2111. </tr>
  2112. </table>
  2113. </td></tr>
  2114. </table>
  2115. <?php
  2116. }
  2117. function USERS2_MARKETING_AKCJE_podsumowanie() {
  2118. global $thiss;
  2119. Lib::loadClass('DB');
  2120. SEF("MENU");
  2121. MENU();
  2122. echo '<h1>' . "Podsumowanie akcji:" . '</h1>';
  2123. $select_daty = array();
  2124. $selected_data = V::get('W_DATA', '', $_REQUEST);
  2125. $sql = "
  2126. select
  2127. substring(a.`W_DATA`, 1, 7) as data_akcji
  2128. from `USERS2_MARKETING_AKCJE` as a
  2129. where a.`A_STATUS`!='DELETED'
  2130. group by data_akcji
  2131. order by data_akcji desc
  2132. ";
  2133. $res = DB::query( $sql );
  2134. while ($r = DB::fetch( $res )) {
  2135. $select_daty[$r->data_akcji] = $r->data_akcji;
  2136. }
  2137. //if (!ereg("^[[:digit:]]{4}-[[:digit:]]{2}$", $selected_data)) {
  2138. if (!array_key_exists($selected_data, $select_daty)) {
  2139. $selected_data = '';
  2140. }
  2141. echo '<form action="" method="post">';
  2142. echo "Wybierz miesiąc ";
  2143. echo '<select name="' . "W_DATA" . '" onchange="' . "this.form.submit()" . '">';
  2144. foreach ($select_daty as $k_option => $v_value) {
  2145. $sel = ($k_option == $selected_data)? ' selected="selected"' : '';
  2146. echo '<option value="' . $k_option . '"' . $sel . '>' . $v_value . '</option>';
  2147. }//end foreach
  2148. echo '</select>';
  2149. echo " ";
  2150. echo '<input type="submit" value="' . "Szukaj" . '" />';
  2151. echo '</form>';
  2152. echo '<br />';
  2153. echo '<br />';
  2154. if ($selected_data != '') {
  2155. $sum = array();
  2156. $sql = "select a.`ID`, a.`ID_PROJECT`, a.`W_DATA`, a.`W_USER`
  2157. , sum(ab.`ROZNIESIONO`) as sum_ROZNIESIONO
  2158. from `USERS2_MARKETING_AKCJE` as a
  2159. left join `USERS2_MARKETING_AKCJE_BUILDINGS` as ab on (ab.`ID_AKCJA`=a.`ID`)
  2160. where
  2161. a.`A_STATUS`!='DELETED'
  2162. and a.`W_DATA` like '" . $selected_data . "-%'
  2163. group by `ID`
  2164. ";
  2165. $res = DB::query( $sql );
  2166. while ($r = DB::fetch( $res )) {
  2167. $sum []= $r;
  2168. }
  2169. $podsumowanie_user = array();
  2170. echo '<style type="text/css">' . "
  2171. .tbl td{padding:0 3px;}
  2172. .tbl th{padding:0 3px;}
  2173. " . '</style>';
  2174. echo '<table border="1" cellspacing="0" cellpadding="0" class="tbl">';
  2175. echo '<tr>';
  2176. echo '<th>' . "ID" . '</th>';
  2177. echo '<th>' . "ID_PROJECT" . '</th>';
  2178. echo '<th>' . "User" . '</th>';
  2179. echo '<th>' . "Rozniesiono" . '</th>';
  2180. echo '</tr>';
  2181. foreach ($sum as $r) {
  2182. $podsumowanie_user[$r->W_USER] += $r->sum_ROZNIESIONO;
  2183. echo '<tr>';
  2184. echo '<td>' . $r->ID . '</td>';
  2185. echo '<td>' . $r->ID_PROJECT . '</td>';
  2186. echo '<td>' . $r->W_USER . '</td>';
  2187. echo '<td>' . $r->sum_ROZNIESIONO . '</td>';
  2188. echo '</tr>';
  2189. }
  2190. echo '</table>';
  2191. echo '<h4>' . "Podsumowanie wg pracownika" . '</h4>';
  2192. echo '<table border="1" cellspacing="0" cellpadding="0" class="tbl">';
  2193. echo '<tr>';
  2194. echo '<th>' . "User" . '</th>';
  2195. echo '<th>' . "Rozniesiono" . '</th>';
  2196. echo '</tr>';
  2197. foreach ($podsumowanie_user as $k_user => $v_rozniesiono) {
  2198. echo '<tr>';
  2199. echo '<td>';
  2200. $link = "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=PODSUMOWANIE_USER&ARG1_VAL=";
  2201. $link .= "&f_DATA=" . $selected_data . "&f_USER=" . $k_user;
  2202. echo '<a href="' . $link . '">' . $k_user . '</a>';
  2203. echo '</td>';
  2204. echo '<td>' . $v_rozniesiono . '</td>';
  2205. echo '</tr>';
  2206. }
  2207. echo '</table>';
  2208. }
  2209. }
  2210. function USERS2_MARKETING_AKCJE_podsumowanie_user() {
  2211. global $thiss;
  2212. Lib::loadClass('DB');
  2213. SEF("MENU");
  2214. MENU();
  2215. $selected_data = V::get('f_DATA', '', $_GET);
  2216. $selected_user = V::get('f_USER', '', $_GET);
  2217. $sort_by = V::get('f_sort_by', 'S_ADDRESS_STREET', $_GET);
  2218. $sort_dir = V::get('f_sort_dir', 'asc', $_GET);
  2219. // USERS2_MARKETING_AKCJE_BUILDINGS
  2220. {
  2221. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  2222. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  2223. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  2224. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  2225. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">thiss: ';print_r($thiss);echo'</pre>';
  2226. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  2227. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">SES[thiss]: ';print_r($_SESSION[$thiss->DETECT_TABLE_COLUMN]);echo'</pre>';
  2228. }
  2229. // validation
  2230. if ($sort_dir) {
  2231. $sort_dir = strtolower($sort_dir);
  2232. if (!in_array($sort_dir, array('asc', 'desc'))) {
  2233. $sort_dir = 'asc';
  2234. }
  2235. }
  2236. if ($sort_by) {
  2237. $sort_by = strtoupper($sort_by);
  2238. if (!in_array($sort_by, $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'])) {
  2239. $sort_by = 'S_ADDRESS_STREET';
  2240. }
  2241. }
  2242. echo '<h1>';
  2243. echo '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=PODSUMOWANIE&ARG1_VAL=&DATA=" . $selected_data . '">' . "Podsumowanie akcji" . '</a>';
  2244. echo " &raquo; ";
  2245. echo "dla pracownika '" . $selected_user . "' w miesiącu " . $selected_data . ":" ;
  2246. echo '</h1>';
  2247. $buildings = USERS2_MARKETING_AKCJE::get_buildings_by_user_month($selected_user, $selected_data, $sort_by, $sort_dir);
  2248. // TODO: add column 'ID_PROJECT'
  2249. {// add ID_PROJECT
  2250. if (!in_array('ID_PROJECT', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'])) {
  2251. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][] = 'ID_PROJECT';
  2252. }
  2253. if (!array_key_exists('ID_PROJECT', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'])) {
  2254. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['ID_PROJECT'] = 'R';
  2255. }
  2256. }
  2257. $suma_do_rozniesienia = 0;
  2258. $suma_rozniesiono = 0;
  2259. foreach ($buildings as $k_street => $h) {
  2260. $suma_do_rozniesienia += $h['DO_ROZNIESIENIA'];
  2261. $suma_rozniesiono += $h['ROZNIESIONO'];
  2262. }
  2263. echo '<p>'."Do rozniesienia ".$suma_do_rozniesienia." - rozniesiono ".$suma_rozniesiono.".";
  2264. echo '<b>'." Skuteczność akcji: ".(($suma_rozniesiono > 0)? round((100 * $suma_rozniesiono/$suma_do_rozniesienia)) : 0)."%".'</b>';
  2265. echo '</p>';
  2266. echo'<table width="100%" border="1" cellspacing="0" cellpadding="0" class="tbl-view">';
  2267. echo'<thead>';
  2268. echo'<tr>';
  2269. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  2270. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  2271. continue;
  2272. }
  2273. echo '<th style="font-size:x-small;">';
  2274. echo str_replace('_', ' ', $field_name);
  2275. $cur_order_dir = 'asc';
  2276. $cur_link = "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=PODSUMOWANIE_USER&ARG1_VAL=&f_DATA=" . $selected_data . "&f_USER=" . $selected_user . "&f_sort_by=" . $field_name;
  2277. if ($field_name == $sort_by) {
  2278. $cur_order_dir = strtolower($sort_dir);
  2279. if ($sort_dir == 'asc') {
  2280. $cur_link .= "&f_sort_dir=" . 'DESC';
  2281. }
  2282. }
  2283. echo '<a href="' . $cur_link . '">' . '<img src="./icon/sort-' . $cur_order_dir . '.gif" alt="sort - ' . $cur_order_dir . '" />' . '</a>';
  2284. echo '</th>';
  2285. }
  2286. echo'</tr>';
  2287. echo'</thead>';
  2288. echo'<tbody>';
  2289. $t = 0;
  2290. foreach ($buildings as $h) {
  2291. echo '<tr class="row-' . ($t = 1 - $t) . '">';
  2292. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  2293. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  2294. continue;
  2295. }
  2296. echo '<td>';
  2297. echo $h[$field_name];
  2298. echo '</td>';
  2299. }
  2300. echo'</tr>';
  2301. }
  2302. echo'</tbody>';
  2303. echo'</table>';
  2304. }
  2305. function USERS2_MARKETING_AKCJE_task_EDIT_A_STATUS( $task, $record_id, &$record ) {
  2306. if ($record_id < 0) {
  2307. echo '<p style="color:red">' . "Wrong Param record_id!" . '</p>';
  2308. return;
  2309. }
  2310. if (empty($record)) {
  2311. echo '<p style="color:red">' . "Wrong Param record!" . '</p>';
  2312. return;
  2313. }
  2314. $allowed_task = array('delete', 'undelete');
  2315. if (!in_array($task, $allowed_task)) {
  2316. echo '<p style="color:red">' . "Wrong Task!" . '</p>';
  2317. return;
  2318. }
  2319. $data_arr = array();
  2320. if ($task == 'delete') {
  2321. if ($record['A_STATUS'] != 'DELETED') {
  2322. $data_arr ['A_STATUS'] = 'DELETED';
  2323. }
  2324. }
  2325. else if ($task == 'undelete') {
  2326. if ($record['A_STATUS'] == 'DELETED') {
  2327. $data_arr ['A_STATUS'] = 'NORMAL';
  2328. }
  2329. }
  2330. if (empty($data_arr)) {
  2331. $error_msg = "";// ??
  2332. echo '<p style="color:red">' . $error_msg . '</p>';
  2333. echo '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE" . '">' . "Wróć" . '</a>';// TODO: back link
  2334. return;
  2335. }
  2336. $sql_arr = array();
  2337. foreach ($data_arr as $k => $v) {
  2338. $sql_arr []= "`" . $k . "`='" . $v . "'";
  2339. }//end foreach
  2340. $sql_arr []= "`A_RECORD_UPDATE_AUTHOR`='" . $_SESSION['ADM_ACCOUNT'] . "'";
  2341. $sql_arr []= "`A_RECORD_UPDATE_DATE`='" . date('Y-m-d-H:i') . "'";
  2342. $sql = "update `USERS2_MARKETING_AKCJE`
  2343. set " . implode(", ", $sql_arr) . "
  2344. where `ID`='" . $record_id . "'
  2345. limit 1
  2346. ;
  2347. ";
  2348. DB::query($sql);
  2349. // add HIST
  2350. $sql_arr = array();
  2351. foreach ($data_arr as $k => $v) {
  2352. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2353. }//end foreach
  2354. $sql_arr ["`A_RECORD_CREATE_AUTHOR`"] = "'" . $_SESSION['ADM_ACCOUNT'] . "'";
  2355. $sql_arr ["`A_RECORD_CREATE_DATE`"] = "'" . date('Y-m-d-H:i') . "'";
  2356. $sql_arr ["`ID_USERS2`"] = "'" . $record_id . "'";
  2357. $sql = "insert into `USERS2_MARKETING_AKCJE_HIST` (" . implode(", ", array_keys($sql_arr)) . ")
  2358. values(" . implode(", ", array_values($sql_arr)) . ")
  2359. ;
  2360. ";
  2361. DB::query($sql);
  2362. $msg = "";
  2363. if ($task == 'delete') {
  2364. $msg = "Rekord usunięto.";
  2365. }
  2366. else if ($task == 'undelete') {
  2367. $msg = "Rekord przywrócono.";
  2368. }
  2369. echo '<p>' . $msg . '</p>';
  2370. echo '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE" . '">' . "Wróć" . '</a>';// TODO: back link
  2371. }