right.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. <?php require_once 'auth.php'; ?>
  2. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
  3. "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <title><?=getTitle(__FILE__);?></title>
  7. <link rel="stylesheet" href="phpME.css" type="text/css"></link>
  8. </head>
  9. <body onLoad='documentOnLoad()'>
  10. <h3><?=getTitle(__FILE__);?></h3>
  11. <script language=javascript>
  12. var arr0, arr1, arr2, arr3;
  13. arr0 = new Array('add', 'change', 'delete', 'filter', 'list', 'copy');
  14. arr1 = new Array('viewHistory', 'viewLog', 'viewData', 'testDSN', 'dropTable',
  15. 'createTable', 'import', 'diff', 'addData', 'editData', 'deleteData',
  16. 'cleanReport', 'cleanTemp'); // config 'cleanCrc' 'crc'
  17. arr2 = new Array('dictionary', 'right'); // view
  18. arr3 = new Array();
  19. arr4 = new Array('editData'); // report
  20. var eAction, sLen;
  21. function documentOnLoad() {
  22. if (typeof document.forms[0].module == 'undefined') return false;
  23. document.forms[0].module.onchange = onChangeModule;
  24. fElement = document.forms[0].elements;
  25. for (var i=0, n=fElement.length;i<n;i++) {
  26. if (fElement[i].name == 'action[]') {
  27. eAction = fElement[i];
  28. }
  29. }
  30. sLen = arr0.length;
  31. onChangeModule();
  32. }
  33. function onChangeModule() {
  34. var arrn = new Array();
  35. t = document.forms[0].module;
  36. for (var i=eAction.options.length-1; i>=0; i--) {
  37. if (i>=sLen) {
  38. arr3[eAction.options[i].value] = 0;
  39. if (eAction.options[i].selected) arr3[eAction.options[i].value] = 1;
  40. eAction.options[i] = null;
  41. }
  42. }
  43. if (t.options[t.selectedIndex].value == 'Import.Table Config') {
  44. arrn = arr1;
  45. } else if (t.options[t.selectedIndex].value == 'Report.Report Designer') {
  46. arrn = arr2;
  47. }
  48. for (var i=0, n=arrn.length;i<n;i++) {
  49. sElement = false;
  50. if (arr3[arrn[i]] == 1) sElement = true;
  51. eLen = eAction.options.length;
  52. eAction.options[eLen] = new Option(arrn[i], arrn[i], sElement, sElement);
  53. }
  54. eAction.size = eAction.options.length;;
  55. }
  56. </script>
  57. <?php
  58. /*
  59. * IMPORTANT NOTE: This generated file contains only a subset of huge amount
  60. * of options that can be used with phpMyEdit. To get information about all
  61. * features offered by phpMyEdit, check official documentation. It is available
  62. * online and also for download on phpMyEdit project management page:
  63. *
  64. * http://www.platon.sk/projects/main_page.php?project_id=5
  65. */
  66. // MySQL host name, user name, password, database, and table
  67. require_once 'config.php';
  68. $opts['hn'] = $adodb_host;
  69. $opts['un'] = $adodb_user;
  70. $opts['pw'] = $adodb_pass;
  71. $opts['db'] = $adodb_db;
  72. $opts['tb'] = 'qb_right';
  73. // Name of field which is the unique key
  74. $opts['key'] = 'id';
  75. // Type of key field (int/real/string/date etc.)
  76. $opts['key_type'] = 'int';
  77. // Sorting field(s)
  78. $opts['sort_field'] = array('id');
  79. // Number of records to display on the screen
  80. // Value of -1 lists all records in a table
  81. $opts['inc'] = 25;
  82. // Options you wish to give the users
  83. // A - add, C - change, P - copy, V - view, D - delete,
  84. // F - filter, I - initial sort suppressed
  85. $opts['options'] = 'ACDF'; // DPV
  86. // Number of lines to display on multiple selection filters
  87. $opts['multiple'] = '5';
  88. // Navigation style: B - buttons (default), T - text links, G - graphic links
  89. // Buttons position: U - up, D - down (default)
  90. $opts['navigation'] = 'UG'; //'DB';
  91. // Display special page elements
  92. $opts['display'] = array(
  93. 'form' => true,
  94. 'query' => true,
  95. 'sort' => true,
  96. 'time' => true,
  97. 'tabs' => true
  98. );
  99. $opts['logtable'] = isLogTable($opts['tb']);
  100. /* Get the user's default language and use it if possible or you can
  101. specify particular one you want to use. Refer to official documentation
  102. for list of available languages. */
  103. $opts['language'] = $HTTP_SERVER_VARS['HTTP_ACCEPT_LANGUAGE'];
  104. /* Table-level filter capability. If set, it is included in the WHERE clause
  105. of any generated SELECT statement in SQL query. This gives you ability to
  106. work only with subset of data from table.
  107. $opts['filters'] = "column1 like '%11%' AND column2<17";
  108. $opts['filters'] = "section_id = 9";
  109. $opts['filters'] = "PMEtable0.sessions_count > 200";
  110. */
  111. /* Field definitions
  112. Fields will be displayed left to right on the screen in the order in which they
  113. appear in generated list. Here are some most used field options documented.
  114. ['name'] is the title used for column headings, etc.;
  115. ['maxlen'] maximum length to display add/edit/search input boxes
  116. ['trimlen'] maximum length of string content to display in row listing
  117. ['width'] is an optional display width specification for the column
  118. e.g. ['width'] = '100px';
  119. ['mask'] a string that is used by sprintf() to format field output
  120. ['sort'] true or false; means the users may sort the display on this column
  121. ['strip_tags'] true or false; whether to strip tags from content
  122. ['nowrap'] true or false; whether this field should get a NOWRAP
  123. ['required'] true or false; if generate javascript to prevent null entries
  124. ['select'] T - text, N - numeric, D - drop-down, M - multiple selection
  125. ['options'] optional parameter to control whether a field is displayed
  126. L - list, F - filter, A - add, C - change, P - copy, D - delete, V - view
  127. Another flags are:
  128. R - indicates that a field is read only
  129. W - indicates that a field is a password field
  130. H - indicates that a field is to be hidden and marked as hidden
  131. ['URL'] is used to make a field 'clickable' in the display
  132. e.g.: 'mailto:$value', 'http://$value' or '$page?stuff';
  133. ['URLtarget'] HTML target link specification (for example: _blank)
  134. ['textarea']['rows'] and/or ['textarea']['cols']
  135. specifies a textarea is to be used to give multi-line input
  136. e.g. ['textarea']['rows'] = 5; ['textarea']['cols'] = 10
  137. ['values'] restricts user input to the specified constants,
  138. e.g. ['values'] = array('A','B','C') or ['values'] = range(1,99)
  139. ['values']['table'] and ['values']['column'] restricts user input
  140. to the values found in the specified column of another table
  141. ['values']['description'] = 'desc_column'
  142. The optional ['values']['description'] field allows the value(s) displayed
  143. to the user to be different to those in the ['values']['column'] field.
  144. This is useful for giving more meaning to column values. Multiple
  145. descriptions fields are also possible. Check documentation for this.
  146. */
  147. $opts['fdd']['id'] = array(
  148. 'name' => 'ID',
  149. 'select' => 'T',
  150. 'options' => 'AVCPDR', // auto increment
  151. 'maxlen' => 11,
  152. 'default' => '0',
  153. 'sort' => true
  154. );
  155. $arr = array();
  156. $rs = $adodb->Execute("SELECT module FROM qb_module ".
  157. " WHERE module NOT IN ('User.Module', 'View.View Designer', 'View.View') ORDER BY id");
  158. while (!$rs->EOF) {
  159. $arr[] = $rs->fields['module'];
  160. $rs->MoveNext();
  161. }
  162. $opts['fdd']['module'] = array(
  163. 'name' => 'Module',
  164. 'select' => 'T',
  165. 'maxlen' => 32,
  166. 'sort' => true,
  167. 'values' => $arr
  168. );
  169. $arr = array('add', 'change', 'delete', 'filter', 'list', 'copy',
  170. 'viewLog', 'viewData', 'testDSN', 'dropTable',
  171. 'createTable', 'import', 'diff', /*'crc', */
  172. 'dictionary', 'cleanReport', 'cleanTemp', /*'cleanCrc',*/
  173. 'addData', 'editData', 'deleteData');
  174. $opts['fdd']['action'] = array(
  175. 'name' => 'Action',
  176. 'select' => 'M',
  177. //'maxlen' => 32,
  178. 'sort' => true,
  179. 'values' => $arr
  180. );
  181. $opts['fdd']['description'] = array(
  182. 'name' => 'Description',
  183. 'select' => 'T',
  184. 'maxlen' => 255,
  185. 'sort' => true
  186. );
  187. // Now important call to phpMyEdit
  188. $moduleId = 'User.Right';
  189. $opts['options'] = getUserOptions($moduleId, $opts['options']);
  190. $opts['filters'] = getUserFilters($moduleId);
  191. require_once 'phpMyEdit.class.php';
  192. new phpMyEdit($opts);
  193. ?>
  194. </body>
  195. </html>