report_open4_neu.php 39 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238
  1. <?php
  2. /*
  3. * phpMyEdit - instant MySQL table editor and code generator
  4. *
  5. * phpMyEditSetup.php - interactive table configuration utility (setup)
  6. * ____________________________________________________________
  7. *
  8. * Copyright (c) 1999-2002 John McCreesh <jpmcc@users.sourceforge.net>
  9. * Copyright (c) 2001-2002 Jim Kraai <jkraai@users.sourceforge.net>
  10. * Versions 5.0 and higher developed by Ondrej Jombik <nepto@php.net>
  11. * Copyright (c) 2002-2004 Platon SDG, http://platon.sk/
  12. * All rights reserved.
  13. *
  14. * See README file for more information about this software.
  15. * See COPYING file for license information.
  16. *
  17. * Download the latest version from
  18. * http://platon.sk/projects/phpMyEdit/
  19. */
  20. /* $Platon: phpMyEdit/phpMyEditSetup.php,v 1.34 2004/01/16 19:46:32 nepto Exp $ */
  21. ini_set('max_execution_time', 0);
  22. require_once 'auth.php';
  23. ?>
  24. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
  25. "http://www.w3.org/TR/html4/loose.dtd">
  26. <html>
  27. <head>
  28. <title>phpMyEdit Setup</title>
  29. <style type="text/css">
  30. <!--
  31. body { font-family: "Verdana", "Arial", "Sans-Serif"; text-align: left }
  32. h1 { color: #004d9c; font-size: 13pt; font-weight: bold }
  33. h2 { color: #004d9c; font-size: 11pt; font-weight: bold }
  34. h3 { color: #004d9c; font-size: 11pt; }
  35. p { color: #004d9c; font-size: 9pt; }
  36. table { border: 1px solid #004d9c; border-collapse: collapse; border-spacing: 0px; }
  37. td { border: 1px solid; padding: 3px; color: #004d9c; font-size: 9pt; }
  38. hr
  39. {
  40. height: 1px;
  41. background-color: #000000;
  42. color: #000000;
  43. border: solid #000000 0;
  44. padding: 0;
  45. margin: 0;
  46. border-top-width: 1px;
  47. }
  48. -->
  49. </style>
  50. </head>
  51. <body bgcolor="white">
  52. <?php
  53. $hn = @$HTTP_POST_VARS['hn'];
  54. $un = @$HTTP_POST_VARS['un'];
  55. $pw = @$HTTP_POST_VARS['pw'];
  56. $db = @$HTTP_POST_VARS['db'];
  57. $tb = @$HTTP_POST_VARS['tb'];
  58. $id = @$HTTP_POST_VARS['id'];
  59. $submit = @$HTTP_POST_VARS['submit'];
  60. $options = @$HTTP_POST_VARS['options'];
  61. $baseFilename = @$HTTP_POST_VARS['baseFilename'];
  62. $pageTitle = @$HTTP_POST_VARS['pageTitle'];
  63. $pageHeader = @$HTTP_POST_VARS['pageHeader'];
  64. $HTMLissues = @$HTTP_POST_VARS['HTMLissues'];
  65. $CSSstylesheet = @$HTTP_POST_VARS['CSSstylesheet'];
  66. /* QBUILDER TRAP */
  67. $adodb->debug = 0;
  68. $rs = $adodb->Execute("SELECT * FROM qb_report WHERE id = ?", $_GET['id']);
  69. if (!$rs || $rs->EOF) die("Error: Report '".$_GET['id']."' does not exist.");
  70. $tableid = "qb_report_".abs(crc32($_SESSION['userid']."_".$rs->fields['id']));
  71. $tableid2 = "qb_report_".$rs->fields['id'];
  72. $adodb->Execute("DROP TABLE ".$tableid);
  73. $sql = $rs->fields['sql'];
  74. $sql = str_replace('[userid]', "'".$_SESSION['userid']."'", $sql);
  75. $adodb->Execute("CREATE TABLE ".$tableid." AS ".$sql) or die($adodb->ErrorMsg());
  76. $adodb->Execute("ALTER TABLE ".$tableid." ADD qb_id INTEGER");
  77. $adodb->Execute("ALTER TABLE ".$tableid." ADD KEY (qb_id) ");
  78. $adodb->Execute("ALTER TABLE ".$tableid." CHANGE qb_id qb_id INTEGER NOT NULL auto_increment");
  79. $_SESSION['reptb'] = $tableid;
  80. $_SESSION['repid'] = $_GET['id'];
  81. // template
  82. $crcTable = abs(crc32($tableid));
  83. $pkey = $rs->fields['pkey'];
  84. $adodb->Execute("ALTER TABLE ".$tableid." ADD UNIQUE KEY (".$pkey.")");
  85. $hidden = $rs->fields['hidden'];
  86. $piece = explode(",", $hidden);
  87. $arrHidden = array();
  88. foreach ($piece as $k => $v) {
  89. $v = trim($v);
  90. if ($v) $arrHidden[$v] = 1;
  91. }
  92. $arrSortField = array();
  93. $reportName = $rs->fields['name'];
  94. $groupText = $rs->fields['groupby'];
  95. $parameterText = $rs->fields['paramtxt'];
  96. $paramsql = $rs->fields['paramsql'];
  97. $rs2 = $adodb->SelectLimit("SELECT * FROM ".$tableid, 1);
  98. $rows = $rs2->GetRows();
  99. $smartyFilename = 'report_'.htmlspecialchars($reportName);
  100. $assignTxt = '';
  101. $fileTpl = "templates".DIRECTORY_SEPARATOR.$smartyFilename."_default.tpl";
  102. $Tplhandle = @fopen($fileTpl, 'w+');
  103. if ($Tplhandle) {
  104. $columnHeader = $fieldText = $detailText = $formText = '';
  105. $columnCount = 0;
  106. $rows0 = $rows[0];
  107. if (!is_array($rows0)) $rows0 = array();
  108. $fieldText = implode(", ", array_keys($rows0));
  109. foreach ($rows0 as $k => $v) {
  110. if ($k == 'qb_id') continue;
  111. $assignTxt .= '$smarty->assign("'.$k.'Txt", __("'.$k.'", "'.$k.'", '.
  112. ' $tableid2));'."\n";
  113. if (! array_key_exists($k, $arrHidden)) {
  114. $columnHeader .= "\t\t<td>{\$".$k."Txt2}</td>\n";
  115. $detailText .= "\t\t<td>&nbsp;{\$rows.".$k."}</td>\n";
  116. }
  117. $formText .= "
  118. <tr>
  119. <td>{\$".$k."Txt}</td>
  120. <td>{\$".$k."Val}</td>
  121. </tr>";
  122. $columnCount++;
  123. }
  124. $parameterForm = '';
  125. $p = explode(",", $parameterText);
  126. foreach ($p as $k => $v) {
  127. $v = trim($v);
  128. if (!$v) continue;
  129. $arr = explode(":", $v);
  130. $fld = $arr[0];
  131. $svar = $arr[1];
  132. $vType = $arr[2];
  133. if($arr[2] == 'date')
  134. {
  135. if(!isset($dateFormat))
  136. $dateFormat = array();
  137. array_push($dateFormat, $svar);
  138. }
  139. $parameterForm .= '<td>{$filter_'.$svar.'Txt}</td><td>{$filter_'.$svar.'Val}</td>';
  140. }
  141. if ($parameterForm) {
  142. $parameterForm = '
  143. <form method="POST" action="{$smarty.server.PHP_SELF}" onSubmit="return dateFormat(\''.@join(":", $dateFormat).'\');">
  144. <table id="report_filter_table" class="report_filter_table">
  145. <tr id="report_filter_table_submit"><td><input type=submit class="pme-filter" value="{$Query}"></td></tr>
  146. <tr id="report_filter_table_input">
  147. '.$parameterForm.'
  148. </tr>
  149. </table>
  150. </form>
  151. ';
  152. }
  153. $groupHeader = '';
  154. if ($groupText) {
  155. $p1 = explode(";", $groupText);
  156. foreach ($p1 as $k1 => $v1) {
  157. $v1 = trim($v1);
  158. if (!$v1) continue;
  159. $p2 = explode(":", $v1);
  160. $group = trim($p2[0]);
  161. $arrSortField[] = $group;
  162. $first = $calc = $reset = $reset2 = $print = '';
  163. $p3 = explode(",", trim($p2[1]));
  164. foreach ($p3 as $k3 => $v3) {
  165. $v3 = trim($v3);
  166. if (!$v3) continue;
  167. $p4 = explode(".", $v3);
  168. $func = strtoupper(trim($p4[0]));
  169. $fld = trim($p4[1]);
  170. if (!$fld) $fld = $group;
  171. if ($func == 'SUM') {
  172. $print .= "
  173. {\$".$fld."Txt}={\$".$group."Group_".$func."}
  174. ";
  175. } else if ($func == 'COUNT') {
  176. $print .= "
  177. {\$".strtolower($func)."}={\$".$group."Group_".$func."}
  178. ";
  179. }
  180. }
  181. if ($group != "ALL") {
  182. $groupFooter = "
  183. {if \$".$group."Group_counter == 0}
  184. <tr><td colspan={\$columnCount}>
  185. {\$subTotal} ".$print."
  186. </td></tr>
  187. {/if}
  188. ".$groupFooter;
  189. } else {
  190. $columnFooter = "
  191. ".$reset2."
  192. <tr><td colspan={\$columnCount}>
  193. {\$grandTotal} ".$print."
  194. </td></tr>
  195. ".$columnFooter;
  196. }
  197. }
  198. }
  199. $Tplbuffer = "
  200. {* title *}
  201. {include file=\"reportHeader.tpl\"}
  202. {*Edited*}
  203. <div class=\"report_filter\">
  204. {if \$columnCount > 0}
  205. {* parameter *}
  206. {* ".$parameterText." *}
  207. ".$parameterForm."
  208. {/if}
  209. {*Edited*}
  210. </div>
  211. {* variable *}
  212. {* {\$REPORT_COUNT} *}
  213. {* field *}
  214. {* ".$fieldText." *}
  215. {* group *}
  216. {* ".$groupText." *}
  217. {* pageHeader *}
  218. {* <p>{\$Total}: {\$REPORT_COUNT}</p> *}
  219. {\$form_begin}
  220. {*Edited*}
  221. <!--<hr>-->
  222. {*Edited*}
  223. <div id=\"report_content\" class=\"report_content\">
  224. {if \$columnCount > 0}
  225. {php}
  226. global \$phpme;
  227. while (\$phpme->assign_rows()) {
  228. {/php}
  229. {* columnHeader *}
  230. {if \$rows_count == 1}
  231. <div id=\"report_content_header\" class=\"report_content_header\">
  232. <table id=\"report_content_header_table\" class=\"report_content_header_table\">
  233. <tr><td>&nbsp;</td>
  234. ".$columnHeader."
  235. </tr>
  236. </table>
  237. {if strlen(\$sortInfo) > 0}
  238. {\$sortInfo}
  239. {/if}
  240. </div>
  241. <div id=\"report_content_table\" class=\"report_content_table\">
  242. <table id=\"report_content_table_table\" class=\"report_content_table_table\">
  243. {/if}
  244. {* detail *}
  245. {if \$rows_count % 2 == 0}
  246. <tr bgcolor=#E8EEFF>
  247. {else}
  248. <tr>
  249. {/if}
  250. <td nowrap>
  251. {\$rows.link_change}
  252. {\$rows.link_copy}
  253. {\$rows.link_delete}
  254. </td>
  255. ".$detailText."
  256. </tr>
  257. {* groupFooter *}
  258. ".$groupFooter."
  259. {* columnFooter *}
  260. {if ! \$rows_next}
  261. </table>
  262. </div>
  263. </div>
  264. <div id=\"report_gesamt_berechnung\" class=\"report_gesamt_berechung\">
  265. ".$columnFooter."
  266. </div>
  267. {/if}
  268. {php}
  269. }
  270. {/php}
  271. {if \$rows_count == 0}
  272. <h5 align='center'>{'NoData'|__}</h5>
  273. </div>
  274. {/if}
  275. </div>
  276. {else}
  277. {section name=html loop=\$form_hidden}
  278. {\$form_hidden[html]}
  279. {/section}
  280. <table class='report_content_formular_table' cellspacing='0px'>
  281. ".$formText."
  282. </table>
  283. </div>
  284. {* using translate : {'add'|__} *}
  285. {* for value : \$rows.keyname *}
  286. {/if}
  287. {if \$columnCount > 0}
  288. {include file=\"listButtons.tpl\"}
  289. {else}
  290. {include file=\"recordButtons.tpl\"}
  291. {/if}
  292. {* summary *}
  293. {* pageFooter *}
  294. {\$form_end}
  295. {include file=\"reportFooter.tpl\"}
  296. ";
  297. fwrite($Tplhandle, $Tplbuffer);
  298. flush($Tplhandle);
  299. fclose($Tplhandle);
  300. } else {
  301. echo 'Trying write <b>'.$fileTpl.'</b> <b><font color=red>Failed</font></b><br>';
  302. exit;
  303. }
  304. /* ----------------------------------------------------------------------------------------------------------------------------------
  305. BEGIN OF phpME_report_...
  306. (is placed in root directory of qbuilder)
  307. ----------------------------------------------------------------------------------------------------------------------------------
  308. */
  309. //***********************************************************************************************************************************
  310. // Edited by Dennis Ritz 07.04.2006
  311. // New Filter Functions
  312. // Only SUM over cols is supported
  313. //***********************************************************************************************************************************
  314. $parameterForm = '';
  315. $p = explode(",", $parameterText);
  316. foreach ($p as $k => $v) {
  317. $v = trim($v);
  318. if (!$v) continue;
  319. $arr = explode(":", $v);
  320. $fld = $arr[0];
  321. $svar = $arr[1];
  322. $vType = $arr[2];
  323. $_SESSION[$v.'_'.$crcTable] = '';
  324. if($vType == 'select')
  325. {
  326. $filters .= "
  327. \$rsFilters = \$adodb->Execute('SELECT ".$fld." FROM ".$tableid." GROUP BY ".$fld."');
  328. \$".$svar." = \$rsFilters -> GetMenu('".$svar."', \$_SESSION['".$svar."_".$crcTable."']);
  329. ";
  330. $assignTxt .= '$smarty->assign("filter_'.$svar.'Txt", __("'.$fld.'", "'.$fld.'", "$tableid2"));'."\n";
  331. $assignTxt .= '$smarty->assign("filter_'.$svar.'Val", $'.$svar.');'."\n";
  332. $assignTxt .= '$smarty->assign("filter_'.$svar.'Val", $'.$svar.');'."\n";
  333. }
  334. if($vType == 'text')
  335. {
  336. $filters .= "
  337. \$".$svar." = '<input type=\'text\' class=\'report_filter_table_input_small\' name=\'".$svar."\' value=\''.\$_SESSION['".$svar."_".$crcTable."'].'\'>';
  338. ";
  339. $assignTxt .= '$smarty->assign("filter_'.$svar.'Txt", __("'.$fld.'", "'.$fld.'", "$tableid2"));'."\n";
  340. $assignTxt .= '$smarty->assign("filter_'.$svar.'Val", $'.$svar.');'."\n";
  341. }
  342. if($vType == 'hidtext')
  343. {
  344. $filters .= "
  345. \$".$svar." = '<input type=\'hidden\' class=\'report_filter_table_input_small\' name=\'".$svar."\' value=\''.\$_SESSION['".$svar."_".$crcTable."'].'\'>';
  346. ";
  347. $assignTxt .= '$smarty->assign("filter_'.$svar.'Val", $'.$svar.');'."\n";
  348. }
  349. if($vType == 'date')
  350. {
  351. $filters .= "
  352. \$".$svar." = '<input type=\'text\' class=\'report_filter_table_input_small\' name=\'".$svar."\' value=\''.\$_SESSION['".$svar."_".$crcTable."'].'\'><image src=\'images/dynCalendar.gif\' name=\'calendar\' date=date onclick=\'startCalendar(this,\"".$svar."\", \"down\");\'>';
  353. ";
  354. $assignTxt .= '$smarty->assign("filter_'.$svar.'Txt", __("'.$fld.'", "'.$fld.'", "$tableid2"));'."\n";
  355. $assignTxt .= '$smarty->assign("filter_'.$svar.'Val", $'.$svar.');'."\n";
  356. }
  357. }
  358. //***********************************************************************************************************************************
  359. // END OF EDIT
  360. //***********************************************************************************************************************************
  361. $_SESSION['filters_'.$crcTable] = '';
  362. $smartyHeader = "
  363. \$tableid = '".$tableid."';
  364. \$tableid2 = '".$tableid2."';
  365. \$reportName = '".$reportName."';
  366. \$paramsql = '".$paramsql."';
  367. \$isparam = false;
  368. foreach (\$_POST as \$k => \$v) {
  369. \$v = trim(\$v);
  370. // old style
  371. if (strstr(\$paramsql, '['.\$k.']')) {
  372. \$_SESSION[\$k.'_".$crcTable."'] = \$v;
  373. \$isparam = true;
  374. \$key = '['.\$k.']';
  375. \$value = \"'\".\$v.\"'\";
  376. // new style
  377. } else if (ereg('\['.\$k.':([^]]+)\]', \$paramsql, \$r)) {
  378. \$isparam = true;
  379. \$key = \$r[0];
  380. if (\$v) {
  381. if(ereg('([0-9]{1,2}).([0-9]{1,2}).([0-9]{4})', \$v, \$regs))
  382. {
  383. \$z = \$regs[3].'-'.\$regs[2].'-'.\$regs[1];
  384. \$value = \"'\".\$z.\"'\";
  385. }else
  386. \$value = \"'\".\$v.\"'\";
  387. \$_SESSION[\$k.'_".$crcTable."'] = \$v;
  388. } else {
  389. \$value = \$r[1];
  390. \$_SESSION[\$k.'_".$crcTable."'] = '';
  391. }
  392. }
  393. \$paramsql = str_replace(\$key, \$value, \$paramsql);
  394. }
  395. if (\$isparam) {
  396. \$opts['filters'] = \$paramsql;
  397. \$_SESSION['filters_".$crcTable."'] = \$opts['filters'];
  398. } else {
  399. \$opts['filters'] = \$_SESSION['filters_".$crcTable."'];
  400. }
  401. //SQL for content of Filters
  402. ".$filters."
  403. function translate(\$str) {
  404. return __(\$str, null, \$tableid2);
  405. }
  406. require 'smarty/libs/Smarty.class.php';
  407. \$smarty = new Smarty;
  408. \$smarty->compile_check = true;
  409. \$smarty->debugging = false;
  410. \$smarty->register_modifier(\"translate\",\"translate\");
  411. \$smarty->register_modifier(\"number_format\",\"number_format\");
  412. \$smarty->assign('curdate', time());
  413. \$smarty->assign('count', __('COUNT'));
  414. \$smarty->assign('grandTotal', __('grandTotal'));
  415. \$smarty->assign('subTotal', __('subTotal'));
  416. \$smarty->assign('title', __(\"TITLE\", \$reportName, \$tableid2));
  417. \$smarty->assign('Total', __('Total'));
  418. \$smarty->assign('Query', __('Query'));
  419. \$smarty->assign('Reset', __('Reset'));
  420. ".$assignTxt."
  421. ";
  422. $smartyFooter = "
  423. \$columnCount = \$smarty->get_template_vars('columnCount');
  424. #if (\$columnCount < 1) return;
  425. if (isset(\$_GET['dopdf'])) {
  426. ob_start();
  427. }
  428. if (\$smarty->template_exists('".$smartyFilename.".tpl')) {
  429. \$smarty->display('".$smartyFilename.".tpl');
  430. } else {
  431. \$smarty->display('".$smartyFilename."_default.tpl');
  432. }
  433. if (isset(\$_GET['dopdf'])) {
  434. \$tmpfname = tempnam(\"/tmp\", \"output.html\");
  435. \$fp = fopen(\$tmpfname, 'w');
  436. fwrite(\$fp, ob_get_contents());
  437. ob_end_clean();
  438. fclose(\$fp);
  439. header('Content-Type: application/pdf');
  440. passthru('htmldoc -t pdf --webpage '.\$tmpfname);
  441. }
  442. ";
  443. //***********************************************************************************************************************************
  444. // Edited by Dennis Ritz 07.04.2006
  445. // Calculate over fields
  446. // Only SUM over cols is supported
  447. //***********************************************************************************************************************************
  448. $calculate = '';
  449. if ($groupText) {
  450. $p1 = explode(";", $groupText);
  451. foreach ($p1 as $k1 => $v1) {
  452. $v1 = trim($v1);
  453. if (!$v1) continue;
  454. $p2 = explode(":", $v1);
  455. $group = trim($p2[0]);
  456. $arrSortField[] = $group;
  457. $first = $calc = $reset = $reset2 = $print = '';
  458. $p3 = explode(",", trim($p2[1]));
  459. foreach ($p3 as $k3 => $v3) {
  460. $v3 = trim($v3);
  461. if (!$v3) continue;
  462. $p4 = explode(".", $v3);
  463. $func = strtoupper(trim($p4[0]));
  464. $fld = trim($p4[1]);
  465. if (!$fld) $fld = $group;
  466. if ($func == 'SUM') {
  467. if($group == 'ALL')
  468. {
  469. $calculate .= "
  470. \$where='';
  471. if(\$whereParam = \$phpme -> make_where_from_query_opts())
  472. \$where = 'WHERE '.\$whereParam;
  473. \$rsGroup = \$adodb->Execute('SELECT @A:=SUM(".$fld.") as ".$group."Group_".$fld." FROM ".$tableid." '.\$where);
  474. //die(\$phpme -> make_where_from_query_opts());
  475. \$smarty->assign('".$group."Group_".$func."', __(\$rsGroup->fields['".$group."Group_".$fld."']));
  476. ";
  477. }
  478. }
  479. }
  480. }
  481. }
  482. //***********************************************************************************************************************************
  483. // END OF EDIT
  484. //***********************************************************************************************************************************
  485. $hn = $adodb_host;
  486. $un = $adodb_user;
  487. $pw = $adodb_pass;
  488. $db = $adodb_db;
  489. $tb = $tableid;
  490. $tb2 = $tableid2;
  491. $id = 'qb_id';
  492. $submit = true;
  493. $options = 1;
  494. $baseFilename = 'phpME_report_'.htmlspecialchars(abs(crc32($tb)));
  495. $pageTitle = __("TITLE", $rs->fields['name'], $tableid2);
  496. $pageHeader = true;
  497. $HTMLissues = true;
  498. $CSSstylesheet = true;
  499. /* QBUILDER TRAP */
  500. $phpExtension = '.php';
  501. if (isset($baseFilename) && $baseFilename != '') {
  502. $phpFile = $baseFilename.$phpExtension;
  503. //$contentFile = $baseFilename.'Content.inc';
  504. $contentFile = $baseFilename.'.php';
  505. } elseif (isset($tb)) {
  506. $phpFile = $tb.$phpExtension;
  507. //$contentFile = $tb.'Content.inc';
  508. $contentFile = $tb.'.php';
  509. } else {
  510. $phpFile = 'index'.$phpExtension;
  511. //$contentFile = 'Content.inc';
  512. $contentFile = 'phpMyEdit-content.php';
  513. }
  514. $buffer = '';
  515. function echo_html($x)
  516. {
  517. echo htmlspecialchars($x),"\n";
  518. }
  519. function echo_buffer($x)
  520. {
  521. global $buffer;
  522. $buffer .= $x."\n";
  523. }
  524. $self = basename($HTTP_SERVER_VARS['PHP_SELF']);
  525. $dbl = @mysql_pconnect($hn, $un, $pw);
  526. if ((!$dbl) or empty($submit)) {
  527. echo '<h1>Please log in to your MySQL database</h1>';
  528. if (!empty($submit)) {
  529. echo '<h2>Sorry - login failed - please try again</h2>'."\n";
  530. }
  531. if (! isset($hn)) {
  532. $hn = 'localhost';
  533. }
  534. echo '
  535. <form action="'.htmlspecialchars($self).'" method="POST">
  536. <table border="1" cellpadding="1" cellspacing="0" summary="Login form">
  537. <tr>
  538. <td>Hostname:</td>
  539. <td><input type="text" name="hn" value="'.htmlspecialchars($hn).'"></td>
  540. </tr><tr>
  541. <td>Username:</td>
  542. <td><input type="text" name="un" value="'.htmlspecialchars($un).'"></td>
  543. </tr><tr>
  544. <td>Password:</td>
  545. <td><input type="password" name="pw" value="'.htmlspecialchars($pw).'"></td>
  546. </tr>
  547. </table><br>
  548. <input type="submit" name="submit" value="Submit">
  549. </form>'."\n";
  550. } else if (! isset($db)) {
  551. $dbs = @mysql_list_dbs($dbl);
  552. $num_dbs = @mysql_num_rows($dbs);
  553. echo '<h1>Please select a database</h1>
  554. <form action="'.htmlspecialchars($self).'" method="POST">
  555. <input type="hidden" name="hn" value="'.htmlspecialchars($hn).'">
  556. <input type="hidden" name="un" value="'.htmlspecialchars($un).'">
  557. <input type="hidden" name="pw" value="'.htmlspecialchars($pw).'">
  558. <table border="1" cellpadding="1" cellspacing="1" summary="Database selection">'."\n";
  559. for ($i = 0; $i < $num_dbs; $i++) {
  560. $db = @mysql_db_name($dbs, $i);
  561. $checked = ! strcasecmp($un, $db) ? ' checked' : '';
  562. $db = htmlspecialchars($db);
  563. echo '<tr><td><input'.$checked.' type="radio" name="db" value="'.$db.'"></td><td>'.$db.'</td></tr>'."\n";
  564. }
  565. echo '</table><br>
  566. <input type="submit" name="submit" value="Submit">
  567. <input type="submit" name="cancel" value="Cancel">
  568. </form>'."\n";
  569. } else if (!isset($tb)) {
  570. echo '<h1>Please select a table from database: '.htmlspecialchars($db).'</h1>
  571. <form action="'.htmlspecialchars($self).'" method="POST">
  572. <input type="hidden" name="hn" value="'.htmlspecialchars($hn).'">
  573. <input type="hidden" name="un" value="'.htmlspecialchars($un).'">
  574. <input type="hidden" name="pw" value="'.htmlspecialchars($pw).'">
  575. <input type="hidden" name="db" value="'.htmlspecialchars($db).'">
  576. <table border="1" cellpadding="1" cellspacing="1" summary="Table selection">'."\n";
  577. $tbs = @mysql_list_tables($db, $dbl);
  578. $num_tbs = @mysql_num_rows($tbs);
  579. for ($j = 0; $j < $num_tbs; $j++) {
  580. $tb = @mysql_tablename($tbs, $j);
  581. $tb = htmlspecialchars($tb);
  582. $checked = $j == 0 ? ' checked' : '';
  583. echo '<tr><td><input'.$checked.' type="radio" name="tb" value="'.$tb.'"></td><td>'.$tb.'</td></tr>'."\n";
  584. }
  585. echo '</table><br>
  586. <input type="submit" name="submit" value="Submit">
  587. <input type="submit" name="cancel" value="Cancel">
  588. </form>'."\n";
  589. } else if (!isset($id)) {
  590. echo ' <h1>Please select an identifier from table: '.htmlspecialchars($tb).'</h1>
  591. <p>
  592. This field will be used in change, view, copy and delete operations.<br>
  593. The field should be numeric and must uniquely identify a record.
  594. </p>
  595. <p>
  596. Please note, that there were problems reported by phpMyEdit users
  597. regarding using MySQL reserved word as unique key name (the example for
  598. this is "key" name). Thus we recommend you to use another name
  599. of unique key. Usage of "id" or "ID" should be safe and good idea.
  600. </p>
  601. <form action="'.htmlspecialchars($self).'" method="POST">
  602. <input type="hidden" name="hn" value="'.htmlspecialchars($hn).'">
  603. <input type="hidden" name="un" value="'.htmlspecialchars($un).'">
  604. <input type="hidden" name="pw" value="'.htmlspecialchars($pw).'">
  605. <input type="hidden" name="db" value="'.htmlspecialchars($db).'">
  606. <input type="hidden" name="tb" value="'.htmlspecialchars($tb).'">
  607. <table border="1" cellpadding="1" cellspacing="1" summary="Key selection">'."\n";
  608. // <tr><td><input type="radio" name="id" value="">
  609. // <td><i>None</i></td><td><i>No id field required</i></td></tr>
  610. @mysql_select_db($db);
  611. $tb_desc = @mysql_query("DESCRIBE $tb");
  612. $fds = @mysql_list_fields($db,$tb,$dbl);
  613. for ($j = 0; ($fd = @mysql_field_name($fds, $j)) != false; $j++) {
  614. $ff = @mysql_field_flags($fds, $j);
  615. strlen($ff) <= 0 && $ff = '---';
  616. $checked = stristr($ff, 'primary_key') ? ' checked' : '';
  617. echo '<tr><td><input',$checked,' type="radio" name="id" value="',htmlspecialchars($fd),'"></td>';
  618. echo '<td>',htmlspecialchars($fd),'</td>';
  619. echo '<td>',htmlspecialchars($ff),'</td>';
  620. $r = @mysql_fetch_array($tb_desc, $j);
  621. }
  622. echo '</table><br>
  623. <input type="submit" name="submit" value="Submit">
  624. <input type="submit" name="cancel" value="Cancel">
  625. </form>'."\n";
  626. } else if (!isset($options)) {
  627. echo '<h1>Please select additional options</h1>
  628. <form action="'.htmlspecialchars($self).'" method="POST">
  629. <input type="hidden" name="hn" value="'.htmlspecialchars($hn).'">
  630. <input type="hidden" name="un" value="'.htmlspecialchars($un).'">
  631. <input type="hidden" name="pw" value="'.htmlspecialchars($pw).'">
  632. <input type="hidden" name="db" value="'.htmlspecialchars($db).'">
  633. <input type="hidden" name="tb" value="'.htmlspecialchars($tb).'">
  634. <input type="hidden" name="id" value="'.htmlspecialchars($id).'">
  635. <table border="1" cellpadding="1" cellspacing="1" summary="Additional options">
  636. <tr><td>Base filename</td><td><input type="text" name=baseFilename value ="'.htmlspecialchars($tb).'"></td></tr>
  637. <tr><td>Page title</td><td><input type="text" name=pageTitle value ="'.htmlspecialchars($tb).'"></td></tr>
  638. <tr><td>Page header</td><td><input type="checkbox" name=pageHeader></td></tr>
  639. <tr><td>HTML header &amp; footer</td><td><input type="checkbox" name=HTMLissues></td></tr>
  640. <tr><td>CSS basic stylesheet</td><td><input checked type="checkbox" name=CSSstylesheet></td></tr>
  641. </table><br>
  642. <input type="submit" name="submit" value="Submit">
  643. <input type="submit" name="cancel" value="Cancel">
  644. <input type="hidden" name="options" value="1">
  645. </form>'."\n";
  646. } else {
  647. // echo '<h1>Here is your phpMyEdit calling program</h1>'."\n";
  648. // echo '<h2>You may now copy and paste it into your PHP editor</h2>'."\n";
  649. if ($pageHeader) {
  650. #echo_buffer('<h3>'.$pageTitle.'</h3>');
  651. }
  652. echo_buffer("<?php
  653. /*
  654. * IMPORTANT NOTE: This generated file contains only a subset of huge amount
  655. * of options that can be used with phpMyEdit. To get information about all
  656. * features offered by phpMyEdit, check official documentation. It is available
  657. * online and also for download on phpMyEdit project management page:
  658. *
  659. * http://www.platon.sk/projects/main_page.php?project_id=5
  660. */
  661. // MySQL host name, user name, password, database, and table
  662. \$opts['tb'] = '$tb';
  663. \$opts['tb2'] = '$tb2';
  664. // Name of field which is the unique key
  665. \$opts['key'] = '$id';
  666. // Type of key field (int/real/string/date etc.)");
  667. if ($id == '') {
  668. echo_buffer("\$opts['key_type'] = '';");
  669. } else {
  670. $fds = @mysql_list_fields($db,$tb,$dbl);
  671. for ($j = 0; ($fd = @mysql_field_name($fds, $j)) != ''; $j++) {
  672. if ($fd == $id) {
  673. echo_buffer("\$opts['key_type'] = '".@mysql_field_type($fds, $j)."';");
  674. break;
  675. }
  676. }
  677. }
  678. #$extraOpt = '';
  679. #if ($rs->fields['cols']) $extraOpt = 'C';
  680. echo_buffer("
  681. // Sorting field(s)
  682. \$opts['sort_field'] = array('".implode("','", array_reverse($arrSortField))/*$id*/."');
  683. if (\$opts['sort_field'][0] === '') \$opts['sort_field'] = array();
  684. // Number of records to display on the screen
  685. // Value of -1 lists all records in a table
  686. \$opts['inc'] = 250; //ORIGINAL
  687. // Options you wish to give the users
  688. // A - add, C - change, P - copy, V - view, D - delete,
  689. // F - filter, I - initial sort suppressed
  690. \$opts['options'] = ''; // FACDPV
  691. // Number of lines to display on multiple selection filters
  692. \$opts['multiple'] = '4';
  693. // Navigation style: B - buttons (default), T - text links, G - graphic links
  694. // Buttons position: U - up, D - down (default)
  695. \$opts['navigation'] = 'UG'; //'DB';
  696. // Display special page elements
  697. \$opts['display'] = array(
  698. 'form' => true,
  699. 'query' => true,
  700. 'sort' => true,
  701. 'time' => true,
  702. 'tabs' => true
  703. );
  704. \$opts['logtable'] = 'qb_changelog';
  705. /* Get the user's default language and use it if possible or you can
  706. specify particular one you want to use. Refer to official documentation
  707. for list of available languages. */
  708. \$opts['language'] = \$HTTP_SERVER_VARS['HTTP_ACCEPT_LANGUAGE'];
  709. /* Table-level filter capability. If set, it is included in the WHERE clause
  710. of any generated SELECT statement in SQL query. This gives you ability to
  711. work only with subset of data from table.
  712. \$opts['filters'] = \"column1 like '%11%' AND column2<17\";
  713. \$opts['filters'] = \"section_id = 9\";
  714. \$opts['filters'] = \"PMEtable0.sessions_count > 200\";
  715. */
  716. /* Field definitions
  717. Fields will be displayed left to right on the screen in the order in which they
  718. appear in generated list. Here are some most used field options documented.
  719. ['name'] is the title used for column headings, etc.;
  720. ['maxlen'] maximum length to display add/edit/search input boxes
  721. ['trimlen'] maximum length of string content to display in row listing
  722. ['width'] is an optional display width specification for the column
  723. e.g. ['width'] = '100px';
  724. ['mask'] a string that is used by sprintf() to format field output
  725. ['sort'] true or false; means the users may sort the display on this column
  726. ['strip_tags'] true or false; whether to strip tags from content
  727. ['nowrap'] true or false; whether this field should get a NOWRAP
  728. ['required'] true or false; if generate javascript to prevent null entries
  729. ['select'] T - text, N - numeric, D - drop-down, M - multiple selection
  730. ['options'] optional parameter to control whether a field is displayed
  731. L - list, F - filter, A - add, C - change, P - copy, D - delete, V - view
  732. Another flags are:
  733. R - indicates that a field is read only
  734. W - indicates that a field is a password field
  735. H - indicates that a field is to be hidden and marked as hidden
  736. ['URL'] is used to make a field 'clickable' in the display
  737. e.g.: 'mailto:\$value', 'http://\$value' or '\$page?stuff';
  738. ['URLtarget'] HTML target link specification (for example: _blank)
  739. ['textarea']['rows'] and/or ['textarea']['cols']
  740. specifies a textarea is to be used to give multi-line input
  741. e.g. ['textarea']['rows'] = 5; ['textarea']['cols'] = 10
  742. ['values'] restricts user input to the specified constants,
  743. e.g. ['values'] = array('A','B','C') or ['values'] = range(1,99)
  744. ['values']['table'] and ['values']['column'] restricts user input
  745. to the values found in the specified column of another table
  746. ['values']['description'] = 'desc_column'
  747. The optional ['values']['description'] field allows the value(s) displayed
  748. to the user to be different to those in the ['values']['column'] field.
  749. This is useful for giving more meaning to column values. Multiple
  750. descriptions fields are also possible. Check documentation for this.
  751. */
  752. ");
  753. @mysql_select_db($db);
  754. $tb_desc = @mysql_query("DESCRIBE $tb");
  755. $fds = @mysql_list_fields($db, $tb, $dbl);
  756. $num_fds = @mysql_num_fields($fds);
  757. $ts_cnt = 0;
  758. for ($k = 0; $k < $num_fds; $k++) {
  759. $fd = mysql_field_name($fds,$k);
  760. $fm = mysql_fetch_field($fds,$k);
  761. $fn = strtr($fd, '_-.', ' ');
  762. $fn = preg_replace('/(^| +)id( +|$)/', '\\1ID\\2', $fn); // uppercase IDs
  763. $fn = ucfirst($fn);
  764. $row = @mysql_fetch_array($tb_desc);
  765. $label = str_replace('\'','\\\'',$fn);
  766. if ($arrLabel[$fd]) $label = $arrLabel[$fd];
  767. if (eregi(' ', $fd)) echo_buffer('$opts[\'fdd\'][\'`'.$fd.'`\'] = array('); // )
  768. else echo_buffer('$opts[\'fdd\'][\''.$fd.'\'] = array('); // )
  769. echo_buffer(" 'name' => '".$label."',");
  770. $auto_increment = strstr($row[5], 'auto_increment') ? 1 : 0;
  771. if (substr($row[1],0,3) == 'set') {
  772. echo_buffer(" 'select' => 'M',");
  773. } else {
  774. echo_buffer(" 'select' => 'T',");
  775. }
  776. if ($auto_increment) {
  777. echo_buffer(" 'options' => 'AVCPDR', // auto increment");
  778. }
  779. // timestamps are read-only
  780. else if (@mysql_field_type($fds, $k) == 'timestamp') {
  781. if ($ts_cnt > 0) {
  782. echo_buffer(" 'options' => 'AVCPD',");
  783. } else { // first timestamp
  784. echo_buffer(" 'options' => 'AVCPDR', // updated automatically (MySQL feature)");
  785. }
  786. $ts_cnt++;
  787. }
  788. echo_buffer(" 'maxlen' => ".@mysql_field_len($fds,$k).',');
  789. // blobs -> textarea
  790. if (@mysql_field_type($fds,$k) == 'blob') {
  791. echo_buffer(" 'textarea' => array(");
  792. echo_buffer(" 'rows' => 5,");
  793. echo_buffer(" 'cols' => 50),");
  794. }
  795. // SETs and ENUMs get special treatment
  796. if ((substr($row[1],0,3) == 'set' || substr($row[1],0,4) == 'enum')
  797. && ! (($pos = strpos($row[1], '(')) === false)) {
  798. $indent = str_repeat(' ', 18);
  799. $outstr = substr($row[1], $pos + 2, -2);
  800. $outstr = explode("','", $outstr);
  801. $outstr = str_replace("''", "'", $outstr);
  802. $outstr = str_replace('"', '\\"', $outstr);
  803. $outstr = implode("\",\n$indent\"", $outstr);
  804. echo_buffer(" 'values' => array(\n$indent\"".$outstr.'"),');
  805. }
  806. // automatic support for Default values
  807. if ($row[4] != '' && $row[4] != 'NULL') {
  808. echo_buffer(" 'default' => '".$row[4]."',");
  809. } else if ($auto_increment) {
  810. echo_buffer(" 'default' => '0',");
  811. }
  812. if (stristr(@mysql_field_flags($fds, $k), 'not_null') && ! $auto_increment) {
  813. echo_buffer(" 'required' => true,");
  814. }
  815. echo_buffer(" 'sort' => true");
  816. //echo_buffer(" 'nowrap' => false,");
  817. echo_buffer(');');
  818. }
  819. #$enableCols = '';
  820. #if ($rs->fields['cols']) {
  821. # $p = split(',', $rs->fields['cols']);
  822. # foreach ($p as $v) {
  823. # $v = trim($v);
  824. # $enableCols .= "unset(\$opts['fdd']['`".$v."`']['input']);\n";
  825. # }
  826. $onInsert = $rs->fields['oninsert'];
  827. $onUpdate = $rs->fields['onupdate'];
  828. $onDelete = $rs->fields['ondelete'];
  829. $isDelete = $rs->fields['isdelete'];
  830. $readOnly = $rs->fields['readonly'];
  831. if ($onInsert) {
  832. $fileTIA = $baseFilename.".TIA.inc.php";
  833. $optsTIA = "\$opts['triggers']['insert']['after'] = '".$fileTIA."';";
  834. // write the content include file
  835. // echo 'Trying write <b>'.$fileTIA.'</b> ';
  836. $TIAhandle = @fopen('./'.$fileTIA, 'w+');
  837. if ($TIAhandle) {
  838. $TIAbuffer = "<"."? require_once 'auth.php';
  839. global \$adodb;
  840. //\$adodb->debug = 1;
  841. \$sql = \"".addslashes($onInsert)."\";
  842. \$p = explode(';', \$sql);
  843. foreach (\$p as \$key => \$sql) {
  844. \$sql = trim(\$sql);
  845. if (!\$sql) continue;
  846. foreach (\$newvals as \$k => \$v) {
  847. \$v = addslashes(\$v);
  848. \$sql = str_replace('['.\$k.']', \"'\$v'\", \$sql);
  849. }
  850. \$rs = \$adodb->Execute(\$sql);
  851. if (!\$rs) echo \$adodb->ErrorMsg();
  852. }
  853. \$adodb->debug = 0;
  854. ?".">";
  855. fwrite($TIAhandle, $TIAbuffer);
  856. flush($TIAhandle);
  857. fclose($TIAhandle);
  858. // echo '<b><font color=green>Success</font></b><br>';
  859. } else {
  860. // echo '<b><font color=red>Failed</font></b><br>';
  861. exit;
  862. }
  863. }
  864. if ($onUpdate) {
  865. $fileTUA = $baseFilename.".TUA.inc.php";
  866. $optsTUA = "\$opts['triggers']['update']['after'] = '".$fileTUA."';";
  867. // write the content include file
  868. // echo 'Trying write <b>'.$fileTUA.'</b> ';
  869. $TUAhandle = @fopen('./'.$fileTUA, 'w+');
  870. if ($TUAhandle) {
  871. $TUAbuffer = "<"."? require_once 'auth.php';
  872. global \$adodb;
  873. \$rs2 = \$adodb->Execute(\"SELECT * FROM \".\$this->tb.\" \".
  874. \" WHERE \".\$this->key.\" = ?\", \$this->rec);
  875. //\$adodb->debug = 1;
  876. \$sql = \"".addslashes($onUpdate)."\";
  877. \$p = explode(';', \$sql);
  878. foreach (\$p as \$key => \$sql) {
  879. \$sql = trim(\$sql);
  880. if (!\$sql) continue;
  881. if (\$rs2->EOF) continue;
  882. foreach (\$rs2->fields as \$k => \$v) {
  883. \$v = addslashes(\$v);
  884. \$sql = str_replace('['.\$k.']', \"'\$v'\", \$sql);
  885. }
  886. \$rs = \$adodb->Execute(\$sql);
  887. if (!\$rs) echo \$adodb->ErrorMsg();
  888. }
  889. \$adodb->debug = 0;
  890. ?".">";
  891. fwrite($TUAhandle, $TUAbuffer);
  892. flush($TUAhandle);
  893. fclose($TUAhandle);
  894. // echo '<b><font color=green>Success</font></b><br>';
  895. } else {
  896. // echo '<b><font color=red>Failed</font></b><br>';
  897. exit;
  898. }
  899. }
  900. if ($onDelete) {
  901. $fileTDA = $baseFilename.".TDA.inc.php";
  902. $optsTDA = "\$opts['triggers']['delete']['after'] = '".$fileTDA."';";
  903. // write the content include file
  904. // echo 'Trying write <b>'.$fileTDA.'</b> ';
  905. $TDAhandle = @fopen('./'.$fileTDA, 'w+');
  906. if ($TDAhandle) {
  907. $TDAbuffer = "<"."? require_once 'auth.php';
  908. global \$adodb;
  909. //\$adodb->debug = 1;
  910. \$sql = \"".addslashes($onDelete)."\";
  911. \$p = explode(';', \$sql);
  912. foreach (\$p as \$key => \$sql) {
  913. \$sql = trim(\$sql);
  914. if (!\$sql) continue;
  915. foreach (\$oldvals as \$k => \$v) {
  916. \$v = addslashes(\$v);
  917. \$sql = str_replace('['.\$k.']', \"'\$v'\", \$sql);
  918. }
  919. \$rs = \$adodb->Execute(\$sql);
  920. if (!\$rs) echo \$adodb->ErrorMsg();
  921. }
  922. \$adodb->debug = 0;
  923. ?".">";
  924. fwrite($TDAhandle, $TDAbuffer);
  925. flush($TDAhandle);
  926. fclose($TDAhandle);
  927. // echo '<b><font color=green>Success</font></b><br>';
  928. } else {
  929. // echo '<b><font color=red>Failed</font></b><br>';
  930. exit;
  931. }
  932. }
  933. $disableCols = '';
  934. $piece = explode(",", $readOnly);
  935. foreach ($piece as $k => $v) {
  936. $v = addslashes(trim($v));
  937. $disableCols .= "if (\$opts['fdd']['".$v."']) {
  938. \$opts['fdd']['".$v."']['input'] = 'R';
  939. }";
  940. }
  941. $hiddenCols = '';
  942. foreach ($arrHidden as $k => $v) {
  943. $hiddenCols .= "if (\$opts['fdd']['".$k."']) {
  944. \$opts['fdd']['".$k."']['options'] = 'ACD';
  945. }";
  946. }
  947. if ($isDelete) {
  948. $disableCols = "
  949. function flag_enabled(\$rec) {
  950. global \$adodb, \$opts;
  951. \$rs2 = \$adodb->Execute('SELECT * FROM '.\$opts['tb'].' '.
  952. ' WHERE '.\$opts['key'].' = ? ', array(\$rec));
  953. if (\$rs2->EOF) return 1;
  954. \$sql = \"".addslashes($isDelete)."\";
  955. \$sql = trim(\$sql);
  956. if (!\$sql) return 1;
  957. foreach (\$rs2->fields as \$k => \$v) {
  958. \$v = addslashes(\$v);
  959. \$sql = str_replace('['.\$k.']', \"'\$v'\", \$sql);
  960. }
  961. \$rs = \$adodb->Execute(\$sql);
  962. if (\$rs->EOF) return 1;
  963. return 0;
  964. }
  965. if (flag_enabled(\$_REQUEST['rec']) === 0) {
  966. ".$disableCols."
  967. }
  968. ";
  969. }
  970. #}
  971. #foreach (\$opts['fdd'] as \$k => \$v) {
  972. # \$opts['fdd'][\$k]['input'] = 'R';
  973. #}
  974. #".$enableCols."
  975. #if (\$userAction['editData']) \$opts['options'] .= '".$extraOpt."';
  976. $canInsert = $onInsert ? 'A' : '';
  977. $canUpdate = $onUpdate ? 'C' : '';
  978. $canDelete = $onDelete ? 'D' : '';
  979. echo_buffer("
  980. ".$disableCols."
  981. ".$hiddenCols."
  982. ".$optsTIA."
  983. ".$optsTUA."
  984. ".$optsTDA."
  985. \$opts['fdd']['qb_id']['input'] = 'H';
  986. if (\$isSupervisor) {
  987. \$userAction['add'] = 1;
  988. \$userAction['change'] = 1;
  989. \$userAction['delete'] = 1;
  990. \$userAction['list'] = 1;
  991. \$userAction['filter'] = 1;
  992. \$userAction['copy'] = 1;
  993. } else {
  994. \$userAction = getReportActions(\$_SESSION['userid'], '".$rs->fields['name']."');
  995. }
  996. if (\$userAction['add']) \$opts['options'] .= '".$canInsert."';
  997. if (\$userAction['change']) \$opts['options'] .= '".$canUpdate."';
  998. if (\$userAction['delete']) \$opts['options'] .= '".$canDelete."';
  999. if (!\$userAction['list']) \$opts['filters'] = '1=0';
  1000. if (\$userAction['filter']) \$opts['options'] .= 'F';
  1001. #if (\$userAction['copy']) \$opts['options'] .= 'P';
  1002. ".$smartyHeader."
  1003. // Now important call to phpMyEdit
  1004. global \$phpme;
  1005. require_once 'phpMyEdit3.class.php';
  1006. \$phpme = new phpMyEdit(\$opts);
  1007. ".$calculate."
  1008. ".$smartyFooter."
  1009. ?>
  1010. ");
  1011. $css_directive = <<<END
  1012. <style type="text/css">
  1013. table { border: #004d9c 1px solid; border-collapse: collapse; border-spacing: 0px; width: 100%; }
  1014. th { border: #004d9c 1px solid; padding: 4px; background: #add8e6; }
  1015. td { border: #004d9c 1px solid; padding: 3px; }
  1016. hr { border: 0px solid; padding: 0px; margin: 0px; border-top-width: 1px; height: 1px; }
  1017. </style>
  1018. END;
  1019. $css_directive = <<<END
  1020. <link rel="stylesheet" href="phpME.css" type="text/css"></link>
  1021. END;
  1022. if (! $CSSstylesheet) {
  1023. $css_directive = '';
  1024. }
  1025. if ($HTMLissues) {
  1026. $htmlbuffer = <<<END
  1027. <?php require_once 'auth.php'; ?>
  1028. <?php
  1029. ini_set('max_execution_time', 0);
  1030. /*
  1031. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
  1032. "http://www.w3.org/TR/html4/loose.dtd">
  1033. <html>
  1034. <head>
  1035. <title>$pageTitle</title>
  1036. $css_directive
  1037. </head>
  1038. <body>
  1039. */
  1040. ?>
  1041. END;
  1042. /*
  1043. $htmlbuffer .= "
  1044. <script language=javascript>
  1045. function windowOpen(u,W,H) {
  1046. TopPosition = (screen.height) ? (screen.height-H)/2 : 0;
  1047. LeftPosition = (screen.width) ? (screen.width-W)/2 : 0;
  1048. settings = 'height='+H+',width='+W+',top='+TopPosition+',left='+LeftPosition+
  1049. ',scrollbars=1,resizable=0,toolbar=0,location=0,directories=0,status=0,menubar=0';
  1050. win = window.open(u,'_blank',settings);
  1051. return win;
  1052. }
  1053. function exporttable(tb) {
  1054. //windowOpen('exporttable.php?tableid='+tb, 600, 200);
  1055. location.href = ('exporttable.php?tableid='+tb);
  1056. }
  1057. </script>
  1058. <h3>$pageTitle
  1059. <input type=button value='".__('Export CSV')."' onClick='exporttable(\"$tb\")'>
  1060. </h3>
  1061. ";
  1062. */
  1063. $buffer = $htmlbuffer."\n" . $buffer;
  1064. } else if ($CSSstylesheet) {
  1065. $buffer = $css_directive . $buffer;
  1066. }
  1067. if ($HTMLissues) {
  1068. $buffer .= "
  1069. <script language=javascript>
  1070. top.window.moveTo(0,0);
  1071. if (document.all) {
  1072. top.window.resizeTo(screen.availWidth,screen.availHeight);
  1073. }
  1074. else if (document.layers||document.getElementById) {
  1075. if (top.window.outerHeight<screen.availHeight||top.window.outerWidth<screen.availWidth){
  1076. top.window.outerHeight = screen.availHeight;
  1077. top.window.outerWidth = screen.availWidth;
  1078. }
  1079. }
  1080. </script>
  1081. ";
  1082. $buffer .= "</body>\n";
  1083. $buffer .= "</html>\n";
  1084. }
  1085. // write the content include file
  1086. // echo 'Trying to write content file to: <b>'.'./'.$contentFile.'</b><br>'."\n";
  1087. $filehandle = @fopen('./'.$contentFile, 'w+');
  1088. if ($filehandle) {
  1089. fwrite($filehandle, $buffer);
  1090. flush($filehandle);
  1091. fclose($filehandle);
  1092. // echo 'phpMyEdit content file written successfully<br>';
  1093. /* QBUILDER TRAP */
  1094. echo "
  1095. <script language=javascript>
  1096. location.href = '$contentFile';
  1097. </script>
  1098. ";
  1099. /* QBUILDER TRAP */
  1100. } else {
  1101. // echo 'phpMyEdit content file was NOT written due to inssufficient privileges.<br>';
  1102. // echo 'Please copy and paste content listed below to <i>'.'./'.$contentFile.'</i> file.';
  1103. }
  1104. // echo '<br><hr>';
  1105. // echo '<pre>';
  1106. echo_html($buffer);
  1107. echo '</pre><hr>'."\n";
  1108. }
  1109. ?>
  1110. </body>
  1111. </html>