superedit-USERS2_MARKETING_AKCJE.php 103 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633
  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', 'MONITOR', 'WAITING')
  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. $db = DB::getDB();
  1707. $sql = "select *
  1708. from `ADMIN_USERS`
  1709. where `A_STATUS`='NORMAL'
  1710. and `EMPLOYEE_TYPE`!='Kandydat'
  1711. -- and `ADM_TECH_WORKER`!='NO'
  1712. -- and `ADM_COMPANY` like '".$_SESSION['ADM_COMPANY']."'
  1713. order by `ADM_NAME` ASC
  1714. ";
  1715. $res = $db->query($sql);
  1716. echo'<select name="'.$field_name.'"><option value="">'."&nbsp;".'</option>';
  1717. while ($r = $db->fetch($res)) {
  1718. echo'<option value="'.$r->ADM_ACCOUNT.'" ';
  1719. if ($r->ADM_ACCOUNT == $selected_value) {
  1720. echo'selected="selected"';
  1721. }
  1722. echo'>'.$r->ADM_NAME.' ('.$r->ADM_ACCOUNT.')</option>';
  1723. }
  1724. echo'</select>';
  1725. }
  1726. function USERS2_MARKETING_AKCJE_typespecial_ID_PROJECT($action, $selected_value) {
  1727. $db = DB::getDB();
  1728. $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` ");
  1729. echo '<select name="ID_PROJECT">';
  1730. echo '<option value=""> </option>';
  1731. while ($r = $db->fetch($res)) {
  1732. echo "\n".'<option value="' . $r->ID . '"';
  1733. if ($r->ID == $selected_value) echo ' selected="selected"';
  1734. echo '>' . $r->ID . "=" . $r->M_DIST_DESC . "(". $r->M_DISTRIBUTOR ." ".$r->TV_NAZWA_PROGRAMU. ")".'</option>';
  1735. }
  1736. echo '</select>';
  1737. }
  1738. function USERS2_MARKETING_AKCJE_typespecial_FILTR_M_REWIR($action, $value) {
  1739. FORM_typespecial_USER_TEXTAREA_readonly('FILTR_M_REWIR', $value);
  1740. }
  1741. function USERS2_MARKETING_AKCJE_typespecial_FILTR_S_ADDRESS_STREET($action, $value) {
  1742. FORM_typespecial_USER_TEXTAREA_readonly('FILTR_S_ADDRESS_STREET', $value);
  1743. }
  1744. function FORM_typespecial_USER_TEXTAREA_readonly($field_name, $value) {
  1745. echo'<textarea name="'.$field_name.'" id="'.$field_name.'" rows="4" cols="100" readonly="readonly">'.$value.'</textarea>';
  1746. }
  1747. function USERS2_MARKETING_AKCJE_task_ADD() {
  1748. global $thiss, $ARG1, $ARG1_VAL, $SQL_USER, $USERS_FILTER_STATUS, $SQL_WIEV, $USERS_COLUMN, $USERS_COLUMN_DESC, $USERS_HIDECOLUMN;
  1749. echo "Podaj dane do wprowadzenia do bazy ";
  1750. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE".'">'."Cofnij ".'<img src=icon/back.gif border=0 alt=POWROT>'.'</a>';
  1751. $default_values = array();
  1752. $default_values['DATA'] = date('Y-m-d');
  1753. $default_values['FILTR_BEZ_BN'] = 'TAK';
  1754. $default_values['FILTR_ANEKSY'] = 'NIE';
  1755. $default_values['FILTR_MIN_ULOTEK_NA_BUDYNEK'] = '0';
  1756. $default_values['FILTR_MIN_DATA_OSTATNIEJ_AKCJI'] = '0';
  1757. $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
  1758. foreach ($default_values as $k_field_name => $v_field_value) {
  1759. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$k_field_name])) {
  1760. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$k_field_name] = $v_field_value;
  1761. }
  1762. }
  1763. //MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=ADD&ARG1_VAL=
  1764. echo'<form action="" method="POST" id="frm">';
  1765. echo'<table cellspacing="0" cellpadding="0" border="1">';
  1766. $t = 0;
  1767. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $value) {
  1768. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']["$value"],"C")) {
  1769. continue;
  1770. }
  1771. echo'<tr class="row-' . ($t = 1 - $t) . '">';
  1772. echo '<td>';
  1773. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$value])) {
  1774. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$value];
  1775. echo '<br /><code style="font-size:x-small">'.$value.'</code>';
  1776. } else {
  1777. echo '<code>'.$value.'</code> ';
  1778. }
  1779. echo'</td>';
  1780. echo'<td>';
  1781. if ($_SESSION['LAST_MENU'] == $thiss->DETECT_TABLE_NAME) {
  1782. //$_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value] = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$value];
  1783. if ((strstr($ARG1_VAL,'RESTORE'))) $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value] = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['EDIT_TEMPLATE'][$value];
  1784. }
  1785. if (!isset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value])) {
  1786. 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]]);
  1787. echo "($h[$value])";
  1788. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value];
  1789. } else if (isset($_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value])) {
  1790. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['TYPESPECIAL'][$value]('', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value]);
  1791. } else {
  1792. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$value];
  1793. }
  1794. echo " ".'</td></tr>'."\n";
  1795. }
  1796. echo'<tr>';
  1797. echo'<td colspan="2">';
  1798. USERS2_MARKETING_AKCJE::print_rewir_tree( $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'] );
  1799. echo'</td>';
  1800. echo'</tr>';
  1801. echo'<tr>';
  1802. echo'<td colspan="2" style="text-align:left">';
  1803. echo'<input type="hidden" name="'."task".'" value="'."verify".'" />';
  1804. echo'<input type="submit" value="'."Dalej".'" />';
  1805. echo'</td>';
  1806. echo'</tr>';
  1807. echo'</table>';
  1808. echo'</form>';
  1809. }
  1810. function USERS2_MARKETING_AKCJE_task_ADD_verify() {
  1811. global $thiss;
  1812. $buildings = array();
  1813. $ile_ulotek = 0;
  1814. echo "Zweryfikuj dane ";
  1815. // validation
  1816. $validation_errors = array();
  1817. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['ID_PROJECT'])) {
  1818. $validation_errors['ID_PROJECT'] []= "nie wybrano projektu";
  1819. }
  1820. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_M_REWIR']) && empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_S_ADDRESS_STREET'])) {
  1821. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_M_REWIR'])) {
  1822. $validation_errors['FILTR_M_REWIR'] []= "nie wybrano rewirow";
  1823. }
  1824. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_S_ADDRESS_STREET'])) {
  1825. $validation_errors['FILTR_S_ADDRESS_STREET'] []= "nie wybrano budynkow";
  1826. }
  1827. } else {
  1828. $rewiry = explode(',', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_M_REWIR']);
  1829. $streets = explode(',', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['FILTR_S_ADDRESS_STREET']);
  1830. $sql_where_or_arr = array();
  1831. if (!empty($rewiry)) {
  1832. foreach ($rewiry as $rewir) {
  1833. $rewir = trim($rewir);
  1834. if (!empty($rewir)) {
  1835. $sql_where_or_arr []= "`M_REWIR` like '".$rewir."%'";
  1836. }
  1837. }//end foreach
  1838. }
  1839. if (!empty($streets)) {
  1840. foreach ($streets as $street) {
  1841. $street = trim($street);
  1842. if (!empty($street)) {
  1843. $sql_where_or_arr []= "`S_ADDRESS_STREET`='".$street."'";
  1844. }
  1845. }//end foreach
  1846. }
  1847. $sql = "select `S_ADDRESS_STREET` from `BUILDINGS` where ".implode(" or ", $sql_where_or_arr);
  1848. $res = DB::query($sql);
  1849. while ($r = DB::fetch($res)) {
  1850. $buildings []= $r->S_ADDRESS_STREET;
  1851. }
  1852. if (empty($buildings)) {
  1853. $validation_errors['FILTR_S_ADDRESS_STREET'] []= "brak budynkow pasujacych do kryteriow";
  1854. } else {
  1855. $buildings_rows = array();
  1856. $buildings_street = $buildings;
  1857. {// filtr
  1858. $record_data = $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'];
  1859. $buildings = array();
  1860. $rewiry_selected = explode(',', $record_data['FILTR_M_REWIR']);
  1861. $buildings_selected = explode(',', $record_data['FILTR_S_ADDRESS_STREET']);
  1862. // fetch old actions on buildings
  1863. $old_actions = array();// [street] = last action date
  1864. $sql = "select
  1865. mb.`S_ADDRESS_STREET` as street
  1866. , max(ma.`DATA`) as last_date
  1867. from `USERS2_MARKETING_AKCJE_BUILDINGS` as mb
  1868. left join `USERS2_MARKETING_AKCJE` as ma on(ma.`ID`=mb.`ID_AKCJA`)
  1869. where
  1870. ma.`A_STATUS`!='DELETED'
  1871. group by mb.`S_ADDRESS_STREET`
  1872. ";
  1873. $res = DB::query($sql);
  1874. while ($r = DB::fetch($res)) {
  1875. $r->street = strtoupper($r->street);
  1876. $old_actions[$r->street] = $r->last_date;
  1877. }
  1878. // filtr bez BN
  1879. $sql_ulotek = "ov.`MIESZKAN`";
  1880. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  1881. $sql_ulotek = "(ov.`MIESZKAN` - ov.`ABO_I`)";
  1882. }
  1883. // filtr FILTR_MIN_ULOTEK_NA_BUDYNEK
  1884. $sql_ulotek_enable = "1";
  1885. if ($filtr_min_ulotek_na_budynek = V::get('FILTR_MIN_ULOTEK_NA_BUDYNEK', 0, $record_data, 'int')) {
  1886. if ($record_data['FILTR_BEZ_BN'] == 'TAK') {
  1887. $sql_ulotek_enable = " ( (100 * ov.`ABO_I`) / ov.`MIESZKAN` ) <= ".$filtr_min_ulotek_na_budynek."";
  1888. }
  1889. }
  1890. // TODO: filtr aneksy - max 3-mce przed koncem umowy == pomin umowy konczace sie za ponad 3 miesiace
  1891. $aneksy_arr = array();
  1892. if (0) {//if ('TAK' == V::get('FILTR_ANEKSY', '', $record_data)) {
  1893. $sql = "select td.`SERVICES_S_ADDRESS_STREET`, td.`P_DEALDATE_TERM`
  1894. from `temp_DEALS_STATUS` as td
  1895. where td.`DEALS_ACTIVE`='1'
  1896. and td.`P_DEALDATE_TERM` > DATE_ADD(CURDATE(), INTERVAL 3 MONTH)
  1897. and td.`SERVICES_S_ADDRESS_STREET` in ('".implode("','", $buildings_street)."')
  1898. ";
  1899. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">sql FILTR_ANEKSY: ';print_r($sql);echo'</pre>';
  1900. $res = DB::query($sql);
  1901. while ($r = DB::fetch($res)) {
  1902. $r->SERVICES_S_ADDRESS_STREET = strtoupper($r->SERVICES_S_ADDRESS_STREET);
  1903. $aneksy_arr [$r->SERVICES_S_ADDRESS_STREET] = $r->P_DEALDATE_TERM;
  1904. }
  1905. }
  1906. $sql = "select b.`ID`, b.`M_REWIR`, b.`S_ADDRESS_STREET`, b.`P_ADDRESS_STREET`
  1907. , ov.`ABO_I`, ov.`MIESZKAN`
  1908. , $sql_ulotek as ile_ulotek
  1909. , ( (100 * ".$sql_ulotek.") / ov.`MIESZKAN` ) as pr
  1910. , $sql_ulotek_enable as ulotek_enable
  1911. , 1 as data_enable
  1912. from `BUILDINGS` as b
  1913. left join `USERS2_MARKETING_OVERWIEV` as ov on(ov.`T_TELBOX_BUILDING_IN`=b.`S_ADDRESS_STREET`)
  1914. where
  1915. b.`A_STATUS` in ('NORMAL', 'WARNING', 'MONITOR', 'WAITING')
  1916. and b.`S_ADDRESS_STREET` in ('".implode("','", $buildings_street)."')
  1917. group by b.`ID`
  1918. order by b.`M_REWIR`
  1919. ";
  1920. 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>';
  1921. $res = DB::query($sql);
  1922. while ($r = DB::fetch($res)) {
  1923. // $r->p_dealdate_term = null;
  1924. // $r->S_ADDRESS_STREET = strtoupper($r->S_ADDRESS_STREET);
  1925. // if ('TAK' == V::get('FILTR_ANEKSY', '', $record_data)) {
  1926. // if (array_key_exists($r->S_ADDRESS_STREET, $aneksy_arr)) {
  1927. // $r->p_dealdate_term = $aneksy_arr[$r->S_ADDRESS_STREET];
  1928. // }
  1929. // }
  1930. if ($filtr_data = V::get('FILTR_MIN_DATA_OSTATNIEJ_AKCJI', 0, $record_data)) {
  1931. if (array_key_exists($r->S_ADDRESS_STREET, $old_actions)) {
  1932. if ($old_actions[$r->S_ADDRESS_STREET] >= $filtr_data) {
  1933. $r->data_enable = 0;
  1934. $r->last_action_date = $old_actions[$r->S_ADDRESS_STREET];
  1935. }
  1936. }
  1937. }
  1938. $buildings [$r->ID] = $r;
  1939. }
  1940. foreach ($buildings as $r) {
  1941. if (!$r->ulotek_enable) continue;
  1942. if (!$r->data_enable) continue;
  1943. $buildings_rows []= $r->S_ADDRESS_STREET;
  1944. }
  1945. $buildings = $buildings_rows;
  1946. }// filtr
  1947. $sql = "select sum(".$sql_ulotek.") as cnt
  1948. from `USERS2_MARKETING_OVERWIEV` as ov
  1949. where ov.`T_TELBOX_BUILDING_IN` in('".implode("','", $buildings)."')
  1950. ";
  1951. $res = DB::query($sql);
  1952. if ($r = DB::fetch($res)) {
  1953. $ile_ulotek = $r->cnt;
  1954. }
  1955. }
  1956. }
  1957. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['W_USER'])) {
  1958. $validation_errors['W_USER'] []= "nie wybrano pracownika";
  1959. }
  1960. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['W_DATA'])) {
  1961. $validation_errors['W_DATA'] []= "nie wybrano terminu wykonania zadania";
  1962. }
  1963. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['K_USER'])) {
  1964. if (empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD']['K_DATA'])) {
  1965. $validation_errors['K_DATA'] []= "nie wybrano terminu wykonania kontroli";
  1966. }
  1967. }
  1968. echo'<form action="" method="POST" id="frm">';
  1969. echo'<table cellspacing="0" cellpadding="0" border="1">';
  1970. $t = 0;
  1971. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  1972. if (strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][$field_name],"C")) {
  1973. echo'<tr class="row-' . ($t = 1 - $t) . '">';
  1974. echo '<td>';
  1975. if (!empty($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$field_name])) {
  1976. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC_TO_LANG'][$field_name];
  1977. echo '<br /><code style="font-size:x-small">'.$field_name.'</code>';
  1978. } else {
  1979. echo '<code>'.$field_name.'</code> ';
  1980. }
  1981. echo'</td>';
  1982. echo'<td>';
  1983. if (array_key_exists($field_name, $validation_errors)) {
  1984. echo'<b style="color:red"> !!! </b>';
  1985. }
  1986. echo $_SESSION[$thiss->DETECT_TABLE_COLUMN]['NEW_RECORD'][$field_name];
  1987. echo'</td>';
  1988. echo'</tr>'."\n";
  1989. }
  1990. }
  1991. echo'<tr>';
  1992. echo'<td colspan="2">';
  1993. if (!empty($validation_errors)) {
  1994. echo'<p style="color:red">'."Formularz zawiera bledy:".'</p>';
  1995. echo'<ul>';
  1996. foreach ($validation_errors as $k_field_name => $v_err) {
  1997. echo '<li>'."Pole ".$k_field_name.": ".implode(', ', $v_err).'</li>';
  1998. }//end foreach
  1999. echo'</ul>';
  2000. } else {
  2001. echo'<input type="hidden" name="'."update_FILTR_S_ADDRESS_STREET".'" value="'.implode(",", $buildings).'" />';
  2002. echo'<input type="hidden" name="'."update_ILE_ULOTEK".'" value="'.$ile_ulotek.'" />';
  2003. if (empty($buildings)) {
  2004. echo "Brak pasujacych budynkow";
  2005. } else {
  2006. echo "<b>Budynki:</b> ".implode(', ', $buildings);
  2007. }
  2008. echo'<br />'.'<b>'."Liczba potrzebnych ulotek: ".$ile_ulotek.'</b>';
  2009. }
  2010. echo'</td>';
  2011. echo'</tr>';
  2012. echo'<tr>';
  2013. echo'<td colspan="2" style="text-align:left">';
  2014. if (empty($validation_errors)) {
  2015. echo'<input type="hidden" name="'."task".'" value="'."save".'" />';
  2016. echo "Jesli dane sa poprawne przejdz ";
  2017. echo'<input type="submit" value="'."Dalej".'" />';
  2018. echo " lub ";
  2019. }
  2020. echo " cofnij w celu poprawienia danych ";
  2021. //CREATE_MENUFUNC_NOTD_INIT('USERS2_MARKETING_AKCJE','<img src=icon/back.gif border=0 alt=POWROT>');
  2022. echo'<a href="'."index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=ADD&ARG1_VAL=".'"><img src="icon/back.gif" border="0" alt="POWROT"></a>';
  2023. echo'</td>';
  2024. echo'</tr>';
  2025. echo'</table>';
  2026. echo'</form>';
  2027. }
  2028. function USERS2_MARKETING_AKCJE_view_zlecenie_1_strona( $record_id, &$record, &$buildings, $worker_name ) {
  2029. $DATA_ZLECENIA_KOLPORTAZU = $record['DATA'];
  2030. $DATA_PROCESU_DYSTRYBUCJI = $record['W_DATA'];
  2031. $NUMER_PROCESU_DYSTRYBUCJI = $record_id;
  2032. $ZLECENIOBIORCA = $worker_name;
  2033. $ILOSC_POWIERZONYCH_SZTUK_MATERIALOW = 1;// TODO: suma ulotek do rozniesienia
  2034. $mieszkan = 0;// TODO: suma ulotek do rozniesienia
  2035. {// get suma do rozniesienia
  2036. foreach ($buildings as $building) {
  2037. $mieszkan += $building['DO_ROZNIESIENIA'];
  2038. }//end foreach
  2039. // zaokroglenie w gore
  2040. $ILOSC_POWIERZONYCH_SZTUK_MATERIALOW = ceil(($mieszkan + 1) / 100) * 100;
  2041. }
  2042. $streets = array();
  2043. {// get street names
  2044. $sql_where_or_arr = array();
  2045. foreach ($buildings as $building) {
  2046. $sql_where_or_arr []= "'" . $building['S_ADDRESS_STREET'] . "'";
  2047. }//end foreach
  2048. $sql = "select `S_ADDRESS_STREET`, `P_ADDRESS_STREET` from `BUILDINGS` where `S_ADDRESS_STREET` in (".implode(",", $sql_where_or_arr).")";
  2049. $res = DB::query($sql);
  2050. while ($r = DB::fetch($res)) {
  2051. $streets [$r->P_ADDRESS_STREET] []= $r->S_ADDRESS_STREET;
  2052. }
  2053. }
  2054. $JAKIE_POWIERZONO_MATERIALY_plakaty_ulotki_itp = 'ulotki';
  2055. $INNE_POWIERZONE_PRZEDMIOTY_np_nozyczki_tasma_itp = ".................";
  2056. $MATERIALY_NALEZY_POJEDYNCZO_UMIESZCZAC_NA_np_klamka_drzwi_itp = "W skrzynce pocztowej";
  2057. $MATERIALY_NALEZY_ROZNIESC_W_DNIU = $record['W_DATA'];
  2058. $MATERIALY_NALEZY_ROZNIESC_OD_GODZINY = ".....";
  2059. $MATERIALY_NALEZY_ROZNIESC_TEGO_SAMEGO_DNIA_DO_GODZINY = ".....";
  2060. $MIEJSCE_DOSTARCZENIA_RAPORTU = "biuro Chełm";
  2061. $TERMIN_DATA_DOSTARCZENIA_RAPORTU = "..........";
  2062. $GODZINA_DOSTARCZENIA_RAPORTU = ".....";
  2063. $DODATKOWE_CZYNNOSCI_DO_ZROBIENIA_np_poskladac_ogumkowac_itp = "..........";
  2064. $LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW = ".....";// TODO: wartosc ulotek = koszt 1 ulotki z projektu * ilosc przekazanych ulotek
  2065. $WARTOSC_ZLECENIA = ".....";
  2066. $kara = (is_numeric($LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW) && is_numeric($WARTOSC_ZLECENIA))? ($LACZNA_WARTOSC_POWIERZONYCH_MAETRIALOW + $WARTOSC_ZLECENIA) * 2 : ".....";
  2067. echo '<table border="0" width="100%" cellspacing="0" cellpadding="0">';
  2068. echo '<tr><td colspan=14>';
  2069. 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>";
  2070. echo'<br><br>';
  2071. echo "Zleceniodawca:".'<br>';
  2072. echo "BIALL-NET sp. z o.o. 80-174 Gdańsk, Otomin ul. Słoneczna 43.".'<br><br>';
  2073. echo "Zleceniobiorca:".'<br>';
  2074. echo '<b>'.$ZLECENIOBIORCA.'</b><br>';
  2075. echo '<font size=1>';
  2076. echo "1) Zleceniobiorca zobowiązuje się rozprowadzić materiały reklamowe na obszarze (wg oznaczenia kodowego REWIRÓW i ULIC):";
  2077. echo '</font>';
  2078. echo '</td></tr>';
  2079. echo '<tr><td colspan=14>';
  2080. // TODO: add street names in ()
  2081. foreach ($streets as $k_street => $v_short_arr) {
  2082. echo "&nbsp;&nbsp;&nbsp; " . $k_street . ": " . implode(", ", $v_short_arr) . '<br />';
  2083. }//end foreach
  2084. echo '</td></tr>';
  2085. echo "<tr><td colspan=14>
  2086. <font size=1>
  2087. 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>
  2088. 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>
  2089. 4) Powierzone materiały reklamowe należy umieszczać pojedynczo na <b>$MATERIALY_NALEZY_POJEDYNCZO_UMIESZCZAC_NA_np_klamka_drzwi_itp</b> <br>
  2090. 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>
  2091. 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>
  2092. 7) Wartość zlecenia wynosi <b>$WARTOSC_ZLECENIA</b> złotych.<br>
  2093. 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>
  2094. 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 ";
  2095. echo "<b>$kara</b>";
  2096. echo " zł.<br>
  2097. 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>
  2098. 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>
  2099. 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>
  2100. </font>
  2101. ";
  2102. ?>
  2103. <table style="width:100%;margin:20px 0;" border="0">
  2104. <tr>
  2105. <td style="width:10%">
  2106. </td>
  2107. <td style="text-aling:cetner;">
  2108. ZLECENIODAWCA
  2109. <br /><br />
  2110. .............
  2111. </td>
  2112. <td style="width:10%">
  2113. </td>
  2114. <td style="text-aling:cetner;">
  2115. ZLECENIOBIORCA
  2116. <br /><br />
  2117. <b><?php echo $ZLECENIOBIORCA; ?></b>
  2118. </td>
  2119. <td style="width:10%">
  2120. </td>
  2121. </tr>
  2122. </table>
  2123. </td></tr>
  2124. </table>
  2125. <?php
  2126. }
  2127. function USERS2_MARKETING_AKCJE_podsumowanie() {
  2128. global $thiss;
  2129. Lib::loadClass('DB');
  2130. SEF("MENU");
  2131. MENU();
  2132. echo '<h1>' . "Podsumowanie akcji:" . '</h1>';
  2133. $select_daty = array();
  2134. $selected_data = V::get('W_DATA', '', $_REQUEST);
  2135. $sql = "
  2136. select
  2137. substring(a.`W_DATA`, 1, 7) as data_akcji
  2138. from `USERS2_MARKETING_AKCJE` as a
  2139. where a.`A_STATUS`!='DELETED'
  2140. group by data_akcji
  2141. order by data_akcji desc
  2142. ";
  2143. $res = DB::query( $sql );
  2144. while ($r = DB::fetch( $res )) {
  2145. $select_daty[$r->data_akcji] = $r->data_akcji;
  2146. }
  2147. //if (!ereg("^[[:digit:]]{4}-[[:digit:]]{2}$", $selected_data)) {
  2148. if (!array_key_exists($selected_data, $select_daty)) {
  2149. $selected_data = '';
  2150. }
  2151. echo '<form action="" method="post">';
  2152. echo "Wybierz miesiąc ";
  2153. echo '<select name="' . "W_DATA" . '" onchange="' . "this.form.submit()" . '">';
  2154. foreach ($select_daty as $k_option => $v_value) {
  2155. $sel = ($k_option == $selected_data)? ' selected="selected"' : '';
  2156. echo '<option value="' . $k_option . '"' . $sel . '>' . $v_value . '</option>';
  2157. }//end foreach
  2158. echo '</select>';
  2159. echo " ";
  2160. echo '<input type="submit" value="' . "Szukaj" . '" />';
  2161. echo '</form>';
  2162. echo '<br />';
  2163. echo '<br />';
  2164. if ($selected_data != '') {
  2165. $sum = array();
  2166. $sql = "select a.`ID`, a.`ID_PROJECT`, a.`W_DATA`, a.`W_USER`
  2167. , sum(ab.`ROZNIESIONO`) as sum_ROZNIESIONO
  2168. from `USERS2_MARKETING_AKCJE` as a
  2169. left join `USERS2_MARKETING_AKCJE_BUILDINGS` as ab on (ab.`ID_AKCJA`=a.`ID`)
  2170. where
  2171. a.`A_STATUS`!='DELETED'
  2172. and a.`W_DATA` like '" . $selected_data . "-%'
  2173. group by `ID`
  2174. ";
  2175. $res = DB::query( $sql );
  2176. while ($r = DB::fetch( $res )) {
  2177. $sum []= $r;
  2178. }
  2179. $podsumowanie_user = array();
  2180. echo '<style type="text/css">' . "
  2181. .tbl td{padding:0 3px;}
  2182. .tbl th{padding:0 3px;}
  2183. " . '</style>';
  2184. echo '<table border="1" cellspacing="0" cellpadding="0" class="tbl">';
  2185. echo '<tr>';
  2186. echo '<th>' . "ID" . '</th>';
  2187. echo '<th>' . "ID_PROJECT" . '</th>';
  2188. echo '<th>' . "User" . '</th>';
  2189. echo '<th>' . "Rozniesiono" . '</th>';
  2190. echo '</tr>';
  2191. foreach ($sum as $r) {
  2192. $podsumowanie_user[$r->W_USER] += $r->sum_ROZNIESIONO;
  2193. echo '<tr>';
  2194. echo '<td>' . $r->ID . '</td>';
  2195. echo '<td>' . $r->ID_PROJECT . '</td>';
  2196. echo '<td>' . $r->W_USER . '</td>';
  2197. echo '<td>' . $r->sum_ROZNIESIONO . '</td>';
  2198. echo '</tr>';
  2199. }
  2200. echo '</table>';
  2201. echo '<h4>' . "Podsumowanie wg pracownika" . '</h4>';
  2202. echo '<table border="1" cellspacing="0" cellpadding="0" class="tbl">';
  2203. echo '<tr>';
  2204. echo '<th>' . "User" . '</th>';
  2205. echo '<th>' . "Rozniesiono" . '</th>';
  2206. echo '</tr>';
  2207. foreach ($podsumowanie_user as $k_user => $v_rozniesiono) {
  2208. echo '<tr>';
  2209. echo '<td>';
  2210. $link = "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=PODSUMOWANIE_USER&ARG1_VAL=";
  2211. $link .= "&f_DATA=" . $selected_data . "&f_USER=" . $k_user;
  2212. echo '<a href="' . $link . '">' . $k_user . '</a>';
  2213. echo '</td>';
  2214. echo '<td>' . $v_rozniesiono . '</td>';
  2215. echo '</tr>';
  2216. }
  2217. echo '</table>';
  2218. }
  2219. }
  2220. function USERS2_MARKETING_AKCJE_podsumowanie_user() {
  2221. global $thiss;
  2222. Lib::loadClass('DB');
  2223. SEF("MENU");
  2224. MENU();
  2225. $selected_data = V::get('f_DATA', '', $_GET);
  2226. $selected_user = V::get('f_USER', '', $_GET);
  2227. $sort_by = V::get('f_sort_by', 'S_ADDRESS_STREET', $_GET);
  2228. $sort_dir = V::get('f_sort_dir', 'asc', $_GET);
  2229. // USERS2_MARKETING_AKCJE_BUILDINGS
  2230. {
  2231. $thiss->DETECT_TABLE_COLUMN = 'USERS2_MARKETING_AKCJE_BUILDINGS_COLUMN';
  2232. $thiss->DETECT_TABLE_NAME = 'USERS2_MARKETING_AKCJE_BUILDINGS';
  2233. $thiss->DETECT_HIST_FUNCTION = 'USERS2_MARKETING_AKCJE_HIST';
  2234. $thiss->DETECT_EDIT_FUNCTION = 'USERS2_MARKETING_AKCJE_EDIT';
  2235. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">thiss: ';print_r($thiss);echo'</pre>';
  2236. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['A_ADM_COMPANY'] = '';
  2237. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">SES[thiss]: ';print_r($_SESSION[$thiss->DETECT_TABLE_COLUMN]);echo'</pre>';
  2238. }
  2239. // validation
  2240. if ($sort_dir) {
  2241. $sort_dir = strtolower($sort_dir);
  2242. if (!in_array($sort_dir, array('asc', 'desc'))) {
  2243. $sort_dir = 'asc';
  2244. }
  2245. }
  2246. if ($sort_by) {
  2247. $sort_by = strtoupper($sort_by);
  2248. if (!in_array($sort_by, $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'])) {
  2249. $sort_by = 'S_ADDRESS_STREET';
  2250. }
  2251. }
  2252. echo '<h1>';
  2253. echo '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE&ARG1=PODSUMOWANIE&ARG1_VAL=&DATA=" . $selected_data . '">' . "Podsumowanie akcji" . '</a>';
  2254. echo " &raquo; ";
  2255. echo "dla pracownika '" . $selected_user . "' w miesiącu " . $selected_data . ":" ;
  2256. echo '</h1>';
  2257. $buildings = USERS2_MARKETING_AKCJE::get_buildings_by_user_month($selected_user, $selected_data, $sort_by, $sort_dir);
  2258. // TODO: add column 'ID_PROJECT'
  2259. {// add ID_PROJECT
  2260. if (!in_array('ID_PROJECT', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'])) {
  2261. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'][] = 'ID_PROJECT';
  2262. }
  2263. if (!array_key_exists('ID_PROJECT', $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'])) {
  2264. $_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT']['ID_PROJECT'] = 'R';
  2265. }
  2266. }
  2267. $suma_do_rozniesienia = 0;
  2268. $suma_rozniesiono = 0;
  2269. foreach ($buildings as $k_street => $h) {
  2270. $suma_do_rozniesienia += $h['DO_ROZNIESIENIA'];
  2271. $suma_rozniesiono += $h['ROZNIESIONO'];
  2272. }
  2273. echo '<p>'."Do rozniesienia ".$suma_do_rozniesienia." - rozniesiono ".$suma_rozniesiono.".";
  2274. echo '<b>'." Skuteczność akcji: ".(($suma_rozniesiono > 0)? round((100 * $suma_rozniesiono/$suma_do_rozniesienia)) : 0)."%".'</b>';
  2275. echo '</p>';
  2276. echo'<table width="100%" border="1" cellspacing="0" cellpadding="0" class="tbl-view">';
  2277. echo'<thead>';
  2278. echo'<tr>';
  2279. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  2280. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  2281. continue;
  2282. }
  2283. echo '<th style="font-size:x-small;">';
  2284. echo str_replace('_', ' ', $field_name);
  2285. $cur_order_dir = 'asc';
  2286. $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;
  2287. if ($field_name == $sort_by) {
  2288. $cur_order_dir = strtolower($sort_dir);
  2289. if ($sort_dir == 'asc') {
  2290. $cur_link .= "&f_sort_dir=" . 'DESC';
  2291. }
  2292. }
  2293. echo '<a href="' . $cur_link . '">' . '<img src="./icon/sort-' . $cur_order_dir . '.gif" alt="sort - ' . $cur_order_dir . '" />' . '</a>';
  2294. echo '</th>';
  2295. }
  2296. echo'</tr>';
  2297. echo'</thead>';
  2298. echo'<tbody>';
  2299. $t = 0;
  2300. foreach ($buildings as $h) {
  2301. echo '<tr class="row-' . ($t = 1 - $t) . '">';
  2302. foreach ($_SESSION[$thiss->DETECT_TABLE_COLUMN]['DESC'] as $field_name) {
  2303. if (!strstr($_SESSION[$thiss->DETECT_TABLE_COLUMN]['PERMEDIT'][ $field_name ], "R")) {
  2304. continue;
  2305. }
  2306. echo '<td>';
  2307. echo $h[$field_name];
  2308. echo '</td>';
  2309. }
  2310. echo'</tr>';
  2311. }
  2312. echo'</tbody>';
  2313. echo'</table>';
  2314. }
  2315. function USERS2_MARKETING_AKCJE_task_EDIT_A_STATUS( $task, $record_id, &$record ) {
  2316. if ($record_id < 0) {
  2317. echo '<p style="color:red">' . "Wrong Param record_id!" . '</p>';
  2318. return;
  2319. }
  2320. if (empty($record)) {
  2321. echo '<p style="color:red">' . "Wrong Param record!" . '</p>';
  2322. return;
  2323. }
  2324. $allowed_task = array('delete', 'undelete');
  2325. if (!in_array($task, $allowed_task)) {
  2326. echo '<p style="color:red">' . "Wrong Task!" . '</p>';
  2327. return;
  2328. }
  2329. $data_arr = array();
  2330. if ($task == 'delete') {
  2331. if ($record['A_STATUS'] != 'DELETED') {
  2332. $data_arr ['A_STATUS'] = 'DELETED';
  2333. }
  2334. }
  2335. else if ($task == 'undelete') {
  2336. if ($record['A_STATUS'] == 'DELETED') {
  2337. $data_arr ['A_STATUS'] = 'NORMAL';
  2338. }
  2339. }
  2340. if (empty($data_arr)) {
  2341. $error_msg = "";// ??
  2342. echo '<p style="color:red">' . $error_msg . '</p>';
  2343. echo '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE" . '">' . "Wróć" . '</a>';// TODO: back link
  2344. return;
  2345. }
  2346. $sql_arr = array();
  2347. foreach ($data_arr as $k => $v) {
  2348. $sql_arr []= "`" . $k . "`='" . $v . "'";
  2349. }//end foreach
  2350. $sql_arr []= "`A_RECORD_UPDATE_AUTHOR`='" . $_SESSION['ADM_ACCOUNT'] . "'";
  2351. $sql_arr []= "`A_RECORD_UPDATE_DATE`='" . date('Y-m-d-H:i') . "'";
  2352. $sql = "update `USERS2_MARKETING_AKCJE`
  2353. set " . implode(", ", $sql_arr) . "
  2354. where `ID`='" . $record_id . "'
  2355. limit 1
  2356. ;
  2357. ";
  2358. DB::query($sql);
  2359. // add HIST
  2360. $sql_arr = array();
  2361. foreach ($data_arr as $k => $v) {
  2362. $sql_arr ["`" . $k . "`"] = "'" . $v . "'";
  2363. }//end foreach
  2364. $sql_arr ["`A_RECORD_CREATE_AUTHOR`"] = "'" . $_SESSION['ADM_ACCOUNT'] . "'";
  2365. $sql_arr ["`A_RECORD_CREATE_DATE`"] = "'" . date('Y-m-d-H:i') . "'";
  2366. $sql_arr ["`ID_USERS2`"] = "'" . $record_id . "'";
  2367. $sql = "insert into `USERS2_MARKETING_AKCJE_HIST` (" . implode(", ", array_keys($sql_arr)) . ")
  2368. values(" . implode(", ", array_values($sql_arr)) . ")
  2369. ;
  2370. ";
  2371. DB::query($sql);
  2372. $msg = "";
  2373. if ($task == 'delete') {
  2374. $msg = "Rekord usunięto.";
  2375. }
  2376. else if ($task == 'undelete') {
  2377. $msg = "Rekord przywrócono.";
  2378. }
  2379. echo '<p>' . $msg . '</p>';
  2380. echo '<a href="' . "index.php?MENU_INIT=USERS2_MARKETING_AKCJE" . '">' . "Wróć" . '</a>';// TODO: back link
  2381. }