2016-11-15 19:38:26 +01:00
< ? php
$TABLE = $_GET [ " select " ];
$table_status = table_status1 ( $TABLE );
$indexes = indexes ( $TABLE );
$fields = fields ( $TABLE );
$foreign_keys = column_foreign_keys ( $TABLE );
$oid = " " ;
if ( $table_status [ " Oid " ]) {
$oid = ( $jush == " sqlite " ? " rowid " : " oid " );
$indexes [] = array ( " type " => " PRIMARY " , " columns " => array ( $oid ));
}
parse_str ( $_COOKIE [ " adminer_import " ], $adminer_import );
$rights = array (); // privilege => 0
$columns = array (); // selectable columns
$text_length = null ;
foreach ( $fields as $key => $field ) {
$name = $adminer -> fieldName ( $field );
if ( isset ( $field [ " privileges " ][ " select " ]) && $name != " " ) {
$columns [ $key ] = html_entity_decode ( strip_tags ( $name ), ENT_QUOTES );
if ( is_shortable ( $field )) {
$text_length = $adminer -> selectLengthProcess ();
}
}
$rights += $field [ " privileges " ];
}
list ( $select , $group ) = $adminer -> selectColumnsProcess ( $columns , $indexes );
$is_group = count ( $group ) < count ( $select );
$where = $adminer -> selectSearchProcess ( $fields , $indexes );
$order = $adminer -> selectOrderProcess ( $fields , $indexes );
$limit = $adminer -> selectLimitProcess ();
$from = ( $select ? implode ( " , " , $select ) : " * " . ( $oid ? " , $oid " : " " ))
. convert_fields ( $columns , $fields , $select )
. " \n FROM " . table ( $TABLE );
$group_by = ( $group && $is_group ? " \n GROUP BY " . implode ( " , " , $group ) : " " ) . ( $order ? " \n ORDER BY " . implode ( " , " , $order ) : " " );
if ( $_GET [ " val " ] && is_ajax ()) {
header ( " Content-Type: text/plain; charset=utf-8 " );
foreach ( $_GET [ " val " ] as $unique_idf => $row ) {
$as = convert_field ( $fields [ key ( $row )]);
$select = array ( $as ? $as : idf_escape ( key ( $row )));
$where [] = where_check ( $unique_idf , $fields );
$return = $driver -> select ( $TABLE , $select , $where , $select );
if ( $return ) {
echo reset ( $return -> fetch_row ());
}
}
exit ;
}
if ( $_POST && ! $error ) {
$where_check = $where ;
if ( ! $_POST [ " all " ] && is_array ( $_POST [ " check " ])) {
$checks = array ();
foreach ( $_POST [ " check " ] as $check ) {
$checks [] = where_check ( $check , $fields );
}
$where_check [] = " (( " . implode ( " ) OR ( " , $checks ) . " )) " ;
}
$where_check = ( $where_check ? " \n WHERE " . implode ( " AND " , $where_check ) : " " );
$primary = $unselected = null ;
foreach ( $indexes as $index ) {
if ( $index [ " type " ] == " PRIMARY " ) {
$primary = array_flip ( $index [ " columns " ]);
$unselected = ( $select ? $primary : array ());
break ;
}
}
foreach (( array ) $unselected as $key => $val ) {
if ( in_array ( idf_escape ( $key ), $select )) {
unset ( $unselected [ $key ]);
}
}
if ( $_POST [ " export " ]) {
cookie ( " adminer_import " , " output= " . urlencode ( $_POST [ " output " ]) . " &format= " . urlencode ( $_POST [ " format " ]));
dump_headers ( $TABLE );
$adminer -> dumpTable ( $TABLE , " " );
if ( ! is_array ( $_POST [ " check " ]) || $unselected === array ()) {
$query = " SELECT $from $where_check $group_by " ;
} else {
$union = array ();
foreach ( $_POST [ " check " ] as $val ) {
// where is not unique so OR can't be used
$union [] = " (SELECT " . limit ( $from , " \n WHERE " . ( $where ? implode ( " AND " , $where ) . " AND " : " " ) . where_check ( $val , $fields ) . $group_by , 1 ) . " ) " ;
}
$query = implode ( " UNION ALL " , $union );
}
$adminer -> dumpData ( $TABLE , " table " , $query );
exit ;
}
if ( ! $adminer -> selectEmailProcess ( $where , $foreign_keys )) {
if ( $_POST [ " save " ] || $_POST [ " delete " ]) { // edit
$result = true ;
$affected = 0 ;
$set = array ();
if ( ! $_POST [ " delete " ]) {
foreach ( $columns as $name => $val ) { //! should check also for edit or insert privileges
$val = process_input ( $fields [ $name ]);
if ( $val !== null && ( $_POST [ " clone " ] || $val !== false )) {
$set [ idf_escape ( $name )] = ( $val !== false ? $val : idf_escape ( $name ));
}
}
}
if ( $_POST [ " delete " ] || $set ) {
if ( $_POST [ " clone " ]) {
$query = " INTO " . table ( $TABLE ) . " ( " . implode ( " , " , array_keys ( $set )) . " ) \n SELECT " . implode ( " , " , $set ) . " \n FROM " . table ( $TABLE );
}
if ( $_POST [ " all " ] || ( $unselected === array () && is_array ( $_POST [ " check " ])) || $is_group ) {
$result = ( $_POST [ " delete " ]
? $driver -> delete ( $TABLE , $where_check )
: ( $_POST [ " clone " ]
? queries ( " INSERT $query $where_check " )
: $driver -> update ( $TABLE , $set , $where_check )
)
);
$affected = $connection -> affected_rows ;
} else {
foreach (( array ) $_POST [ " check " ] as $val ) {
// where is not unique so OR can't be used
$where2 = " \n WHERE " . ( $where ? implode ( " AND " , $where ) . " AND " : " " ) . where_check ( $val , $fields );
$result = ( $_POST [ " delete " ]
? $driver -> delete ( $TABLE , $where2 , 1 )
: ( $_POST [ " clone " ]
? queries ( " INSERT " . limit1 ( $query , $where2 ))
: $driver -> update ( $TABLE , $set , $where2 )
)
);
if ( ! $result ) {
break ;
}
$affected += $connection -> affected_rows ;
}
}
}
$message = lang ( '%d item(s) have been affected.' , $affected );
if ( $_POST [ " clone " ] && $result && $affected == 1 ) {
$last_id = last_id ();
if ( $last_id ) {
$message = lang ( 'Item%s has been inserted.' , " $last_id " );
}
}
queries_redirect ( remove_from_uri ( $_POST [ " all " ] && $_POST [ " delete " ] ? " page " : " " ), $message , $result );
if ( ! $_POST [ " delete " ]) {
edit_form ( $TABLE , $fields , ( array ) $_POST [ " fields " ], ! $_POST [ " clone " ]);
page_footer ();
exit ;
}
} elseif ( ! $_POST [ " import " ]) { // modify
if ( ! $_POST [ " val " ]) {
$error = lang ( 'Ctrl+click on a value to modify it.' );
} else {
$result = true ;
$affected = 0 ;
foreach ( $_POST [ " val " ] as $unique_idf => $row ) {
$set = array ();
foreach ( $row as $key => $val ) {
$key = bracket_escape ( $key , 1 ); // 1 - back
$set [ idf_escape ( $key )] = ( preg_match ( '~char|text~' , $fields [ $key ][ " type " ]) || $val != " " ? $adminer -> processInput ( $fields [ $key ], $val ) : " NULL " );
}
$result = $driver -> update (
$TABLE ,
$set ,
" WHERE " . ( $where ? implode ( " AND " , $where ) . " AND " : " " ) . where_check ( $unique_idf , $fields ),
! ( $is_group || $unselected === array ()),
" "
);
if ( ! $result ) {
break ;
}
$affected += $connection -> affected_rows ;
}
queries_redirect ( remove_from_uri (), lang ( '%d item(s) have been affected.' , $affected ), $result );
}
} elseif ( ! is_string ( $file = get_file ( " csv_file " , true ))) {
$error = upload_error ( $file );
} elseif ( ! preg_match ( '~~u' , $file )) {
$error = lang ( 'File must be in UTF-8 encoding.' );
} else {
cookie ( " adminer_import " , " output= " . urlencode ( $adminer_import [ " output " ]) . " &format= " . urlencode ( $_POST [ " separator " ]));
$result = true ;
$cols = array_keys ( $fields );
preg_match_all ( '~(?>"[^"]*"|[^"\\r\\n]+)+~' , $file , $matches );
$affected = count ( $matches [ 0 ]);
$driver -> begin ();
$separator = ( $_POST [ " separator " ] == " csv " ? " , " : ( $_POST [ " separator " ] == " tsv " ? " \t " : " ; " ));
$rows = array ();
foreach ( $matches [ 0 ] as $key => $val ) {
preg_match_all ( " ~((?> \" [^ \" ]* \" )+|[^ $separator ]*) $separator ~ " , $val . $separator , $matches2 );
if ( ! $key && ! array_diff ( $matches2 [ 1 ], $cols )) { //! doesn't work with column names containing ",\n
// first row corresponds to column names - use it for table structure
$cols = $matches2 [ 1 ];
$affected -- ;
} else {
$set = array ();
foreach ( $matches2 [ 1 ] as $i => $col ) {
$set [ idf_escape ( $cols [ $i ])] = ( $col == " " && $fields [ $cols [ $i ]][ " null " ] ? " NULL " : q ( str_replace ( '""' , '"' , preg_replace ( '~^"|"$~' , '' , $col ))));
}
$rows [] = $set ;
}
}
$result = ( ! $rows || $driver -> insertUpdate ( $TABLE , $rows , $primary ));
if ( $result ) {
2017-05-07 19:54:08 +02:00
$result = $driver -> commit ();
2016-11-15 19:38:26 +01:00
}
queries_redirect ( remove_from_uri ( " page " ), lang ( '%d row(s) have been imported.' , $affected ), $result );
$driver -> rollback (); // after queries_redirect() to not overwrite error
}
}
}
$table_name = $adminer -> tableName ( $table_status );
if ( is_ajax ()) {
page_headers ();
ob_start ();
} else {
page_header ( lang ( 'Select' ) . " : $table_name " , $error );
}
$set = null ;
if ( isset ( $rights [ " insert " ]) || ! support ( " table " )) {
$set = " " ;
foreach (( array ) $_GET [ " where " ] as $val ) {
if ( count ( $foreign_keys [ $val [ " col " ]]) == 1 && ( $val [ " op " ] == " = "
|| ( ! $val [ " op " ] && ! preg_match ( '~[_%]~' , $val [ " val " ])) // LIKE in Editor
)) {
$set .= " &set " . urlencode ( " [ " . bracket_escape ( $val [ " col " ]) . " ] " ) . " = " . urlencode ( $val [ " val " ]);
}
}
}
$adminer -> selectLinks ( $table_status , $set );
if ( ! $columns && support ( " table " )) {
echo " <p class='error'> " . lang ( 'Unable to select the table' ) . ( $fields ? " . " : " : " . error ()) . " \n " ;
} else {
echo " <form action='' id='form'> \n " ;
echo " <div style='display: none;'> " ;
hidden_fields_get ();
echo ( DB != " " ? '<input type="hidden" name="db" value="' . h ( DB ) . '">' . ( isset ( $_GET [ " ns " ]) ? '<input type="hidden" name="ns" value="' . h ( $_GET [ " ns " ]) . '">' : " " ) : " " ); // not used in Editor
echo '<input type="hidden" name="select" value="' . h ( $TABLE ) . '">' ;
echo " </div> \n " ;
$adminer -> selectColumnsPrint ( $select , $columns );
$adminer -> selectSearchPrint ( $where , $columns , $indexes );
$adminer -> selectOrderPrint ( $order , $columns , $indexes );
$adminer -> selectLimitPrint ( $limit );
$adminer -> selectLengthPrint ( $text_length );
$adminer -> selectActionPrint ( $indexes );
echo " </form> \n " ;
$page = $_GET [ " page " ];
if ( $page == " last " ) {
$found_rows = $connection -> result ( count_rows ( $TABLE , $where , $is_group , $group ));
$page = floor ( max ( 0 , $found_rows - 1 ) / $limit );
}
$select2 = $select ;
if ( ! $select2 ) {
$select2 [] = " * " ;
if ( $oid ) {
$select2 [] = $oid ;
}
}
$convert_fields = convert_fields ( $columns , $fields , $select );
if ( $convert_fields ) {
$select2 [] = substr ( $convert_fields , 2 );
}
$result = $driver -> select ( $TABLE , $select2 , $where , $group , $order , $limit , $page , true );
if ( ! $result ) {
echo " <p class='error'> " . error () . " \n " ;
} else {
if ( $jush == " mssql " && $page ) {
$result -> seek ( $limit * $page );
}
$email_fields = array ();
echo " <form action='' method='post' enctype='multipart/form-data'> \n " ;
$rows = array ();
while ( $row = $result -> fetch_assoc ()) {
if ( $page && $jush == " oracle " ) {
unset ( $row [ " RNUM " ]);
}
$rows [] = $row ;
}
// use count($rows) without LIMIT, COUNT(*) without grouping, FOUND_ROWS otherwise (slowest)
if ( $_GET [ " page " ] != " last " && + $limit && $group && $is_group && $jush == " sql " ) {
$found_rows = $connection -> result ( " SELECT FOUND_ROWS() " ); // space to allow mysql.trace_mode
}
if ( ! $rows ) {
echo " <p class='message'> " . lang ( 'No rows.' ) . " \n " ;
} else {
$backward_keys = $adminer -> backwardKeys ( $TABLE , $table_name );
echo " <table id='table' cellspacing='0' class='nowrap checkable' onclick='tableClick(event);' ondblclick='tableClick(event, true);' onkeydown='return editingKeydown(event);'> \n " ;
2017-05-07 19:54:08 +02:00
echo " <thead><tr> " . ( ! $group && $select ? " " : " <td><input type='checkbox' id='all-page' onclick='formCheck(this, /check/);' class='jsonly'> <a href=' " . h ( $_GET [ " modify " ] ? remove_from_uri ( " modify " ) : $_SERVER [ " REQUEST_URI " ] . " &modify=1 " ) . " '> " . lang ( 'Modify' ) . " </a> " );
2016-11-15 19:38:26 +01:00
$names = array ();
$functions = array ();
reset ( $select );
$rank = 1 ;
foreach ( $rows [ 0 ] as $key => $val ) {
if ( $key != $oid ) {
$val = $_GET [ " columns " ][ key ( $select )];
$field = $fields [ $select ? ( $val ? $val [ " col " ] : current ( $select )) : $key ];
$name = ( $field ? $adminer -> fieldName ( $field , $rank ) : ( $val [ " fun " ] ? " * " : $key ));
if ( $name != " " ) {
$rank ++ ;
$names [ $key ] = $name ;
$column = idf_escape ( $key );
$href = remove_from_uri ( '(order|desc)[^=]*|page' ) . '&order%5B0%5D=' . urlencode ( $key );
$desc = " &desc%5B0%5D=1 " ;
echo '<th onmouseover="columnMouse(this);" onmouseout="columnMouse(this, \' hidden\');">' ;
echo '<a href="' . h ( $href . ( $order [ 0 ] == $column || $order [ 0 ] == $key || ( ! $order && $is_group && $group [ 0 ] == $column ) ? $desc : '' )) . '">' ; // $order[0] == $key - COUNT(*)
echo apply_sql_function ( $val [ " fun " ], $name ) . " </a> " ; //! columns looking like functions
echo " <span class='column hidden'> " ;
echo " <a href=' " . h ( $href . $desc ) . " ' title=' " . lang ( 'descending' ) . " ' class='text'> ↓</a> " ;
if ( ! $val [ " fun " ]) {
echo '<a href="#fieldset-search" onclick="selectSearch(\'' . h ( js_escape ( $key )) . '\'); return false;" title="' . lang ( 'Search' ) . '" class="text jsonly"> =</a>' ;
}
echo " </span> " ;
}
$functions [ $key ] = $val [ " fun " ];
next ( $select );
}
}
$lengths = array ();
if ( $_GET [ " modify " ]) {
foreach ( $rows as $row ) {
foreach ( $row as $key => $val ) {
$lengths [ $key ] = max ( $lengths [ $key ], min ( 40 , strlen ( utf8_decode ( $val ))));
}
}
}
echo ( $backward_keys ? " <th> " . lang ( 'Relations' ) : " " ) . " </thead> \n " ;
if ( is_ajax ()) {
if ( $limit % 2 == 1 && $page % 2 == 1 ) {
odd ();
}
ob_end_clean ();
}
foreach ( $adminer -> rowDescriptions ( $rows , $foreign_keys ) as $n => $row ) {
$unique_array = unique_array ( $rows [ $n ], $indexes );
if ( ! $unique_array ) {
$unique_array = array ();
foreach ( $rows [ $n ] as $key => $val ) {
if ( ! preg_match ( '~^(COUNT\\((\\*|(DISTINCT )?`(?:[^`]|``)+`)\\)|(AVG|GROUP_CONCAT|MAX|MIN|SUM)\\(`(?:[^`]|``)+`\\))$~' , $key )) { //! columns looking like functions
$unique_array [ $key ] = $val ;
}
}
}
$unique_idf = " " ;
foreach ( $unique_array as $key => $val ) {
if (( $jush == " sql " || $jush == " pgsql " ) && strlen ( $val ) > 64 ) {
$key = ( strpos ( $key , '(' ) ? $key : idf_escape ( $key )); //! columns looking like functions
$key = " MD5( " . ( $jush == 'sql' && preg_match ( " ~^utf8_~ " , $fields [ $key ][ " collation " ]) ? $key : " CONVERT( $key USING " . charset ( $connection ) . " ) " ) . " ) " ;
$val = md5 ( $val );
}
$unique_idf .= " & " . ( $val !== null ? urlencode ( " where[ " . bracket_escape ( $key ) . " ] " ) . " = " . urlencode ( $val ) : " null%5B%5D= " . urlencode ( $key ));
}
echo " <tr " . odd () . " > " . ( ! $group && $select ? " " : " <td> " . checkbox ( " check[] " , substr ( $unique_idf , 1 ), in_array ( substr ( $unique_idf , 1 ), ( array ) $_POST [ " check " ]), " " , " this.form['all'].checked = false; formUncheck('all-page'); " ) . ( $is_group || information_schema ( DB ) ? " " : " <a href=' " . h ( ME . " edit= " . urlencode ( $TABLE ) . $unique_idf ) . " '> " . lang ( 'edit' ) . " </a> " ));
foreach ( $row as $key => $val ) {
if ( isset ( $names [ $key ])) {
$field = $fields [ $key ];
if ( $val != " " && ( ! isset ( $email_fields [ $key ]) || $email_fields [ $key ] != " " )) {
$email_fields [ $key ] = ( is_mail ( $val ) ? $names [ $key ] : " " ); //! filled e-mails can be contained on other pages
}
$link = " " ;
if ( preg_match ( '~blob|bytea|raw|file~' , $field [ " type " ]) && $val != " " ) {
$link = ME . 'download=' . urlencode ( $TABLE ) . '&field=' . urlencode ( $key ) . $unique_idf ;
}
if ( ! $link && $val !== null ) { // link related items
foreach (( array ) $foreign_keys [ $key ] as $foreign_key ) {
if ( count ( $foreign_keys [ $key ]) == 1 || end ( $foreign_key [ " source " ]) == $key ) {
$link = " " ;
foreach ( $foreign_key [ " source " ] as $i => $source ) {
$link .= where_link ( $i , $foreign_key [ " target " ][ $i ], $rows [ $n ][ $source ]);
}
$link = ( $foreign_key [ " db " ] != " " ? preg_replace ( '~([?&]db=)[^&]+~' , '\\1' . urlencode ( $foreign_key [ " db " ]), ME ) : ME ) . 'select=' . urlencode ( $foreign_key [ " table " ]) . $link ; // InnoDB supports non-UNIQUE keys
2017-05-07 19:54:08 +02:00
if ( $foreign_key [ " ns " ]) {
$link = preg_replace ( '~([?&]ns=)[^&]+~' , '\\1' . urlencode ( $foreign_key [ " ns " ]), $link );
}
2016-11-15 19:38:26 +01:00
if ( count ( $foreign_key [ " source " ]) == 1 ) {
break ;
}
}
}
}
if ( $key == " COUNT(*) " ) { //! columns looking like functions
$link = ME . " select= " . urlencode ( $TABLE );
$i = 0 ;
foreach (( array ) $_GET [ " where " ] as $v ) {
if ( ! array_key_exists ( $v [ " col " ], $unique_array )) {
$link .= where_link ( $i ++ , $v [ " col " ], $v [ " val " ], $v [ " op " ]);
}
}
foreach ( $unique_array as $k => $v ) {
$link .= where_link ( $i ++ , $k , $v );
}
}
$val = select_value ( $val , $link , $field , $text_length );
$id = h ( " val[ $unique_idf ][ " . bracket_escape ( $key ) . " ] " );
$value = $_POST [ " val " ][ $unique_idf ][ bracket_escape ( $key )];
$editable = ! is_array ( $row [ $key ]) && is_utf8 ( $val ) && $rows [ $n ][ $key ] == $row [ $key ] && ! $functions [ $key ];
$text = preg_match ( '~text|lob~' , $field [ " type " ]);
if (( $_GET [ " modify " ] && $editable ) || $value !== null ) {
$h_value = h ( $value !== null ? $value : $row [ $key ]);
echo " <td> " . ( $text ? " <textarea name=' $id ' cols='30' rows=' " . ( substr_count ( $row [ $key ], " \n " ) + 1 ) . " '> $h_value </textarea> " : " <input name=' $id ' value=' $h_value ' size=' $lengths[$key] '> " );
} else {
$long = strpos ( $val , " <i>...</i> " );
echo " <td id=' $id ' onclick= \" selectClick(this, event, " . ( $long ? 2 : ( $text ? 1 : 0 )) . ( $editable ? " " : " , ' " . h ( lang ( 'Use edit link to modify this value.' )) . " ' " ) . " ); \" > $val " ;
}
}
}
if ( $backward_keys ) {
echo " <td> " ;
}
$adminer -> backwardKeysPrint ( $backward_keys , $rows [ $n ]);
echo " </tr> \n " ; // close to allow white-space: pre
}
if ( is_ajax ()) {
exit ;
}
echo " </table> \n " ;
}
if (( $rows || $page ) && ! is_ajax ()) {
$exact_count = true ;
if ( $_GET [ " page " ] != " last " ) {
if ( !+ $limit ) {
$found_rows = count ( $rows );
} elseif ( $jush != " sql " || ! $is_group ) {
$found_rows = ( $is_group ? false : found_rows ( $table_status , $where ));
if ( $found_rows < max ( 1e4 , 2 * ( $page + 1 ) * $limit )) {
// slow with big tables
$found_rows = reset ( slow_query ( count_rows ( $TABLE , $where , $is_group , $group )));
} else {
$exact_count = false ;
}
}
}
if ( + $limit && ( $found_rows === false || $found_rows > $limit || $page )) {
echo " <p class='pages'> " ;
// display first, previous 4, next 4 and last page
$max_page = ( $found_rows === false
? $page + ( count ( $rows ) >= $limit ? 2 : 1 )
: floor (( $found_rows - 1 ) / $limit )
);
if ( $jush != " simpledb " ) {
echo '<a href="' . h ( remove_from_uri ( " page " )) . " \" onclick= \" pageClick(this.href, +prompt(' " . lang ( 'Page' ) . " ', ' " . ( $page + 1 ) . " '), event); return false; \" > " . lang ( 'Page' ) . " </a>: " ;
echo pagination ( 0 , $page ) . ( $page > 5 ? " ... " : " " );
for ( $i = max ( 1 , $page - 4 ); $i < min ( $max_page , $page + 5 ); $i ++ ) {
echo pagination ( $i , $page );
}
if ( $max_page > 0 ) {
echo ( $page + 5 < $max_page ? " ... " : " " );
echo ( $exact_count && $found_rows !== false
? pagination ( $max_page , $page )
: " <a href=' " . h ( remove_from_uri ( " page " ) . " &page=last " ) . " ' title='~ $max_page '> " . lang ( 'last' ) . " </a> "
);
}
echo (( $found_rows === false ? count ( $rows ) + 1 : $found_rows - $page * $limit ) > $limit
? ' <a href="' . h ( remove_from_uri ( " page " ) . " &page= " . ( $page + 1 )) . '" onclick="return !selectLoadMore(this, ' . ( + $limit ) . ', \'' . lang ( 'Loading' ) . '...\');" class="loadmore">' . lang ( 'Load more data' ) . '</a>'
: ''
);
} else {
echo lang ( 'Page' ) . " : " ;
echo pagination ( 0 , $page ) . ( $page > 1 ? " ... " : " " );
echo ( $page ? pagination ( $page , $page ) : " " );
echo ( $max_page > $page ? pagination ( $page + 1 , $page ) . ( $max_page > $page + 1 ? " ... " : " " ) : " " );
}
}
echo " <p class='count'> \n " ;
echo ( $found_rows !== false ? " ( " . ( $exact_count ? " " : " ~ " ) . lang ( '%d row(s)' , $found_rows ) . " ) " : " " );
$display_rows = ( $exact_count ? " " : " ~ " ) . $found_rows ;
echo checkbox ( " all " , 1 , 0 , lang ( 'whole result' ), " var checked = formChecked(this, /check/); selectCount('selected', this.checked ? ' $display_rows ' : checked); selectCount('selected2', this.checked || !checked ? ' $display_rows ' : checked); " ) . " \n " ;
if ( $adminer -> selectCommandPrint ()) {
?>
< fieldset < ? php echo ( $_GET [ " modify " ] ? '' : ' class="jsonly"' ); ?> ><legend><?php echo lang('Modify'); ?></legend><div>
< input type = " submit " value = " <?php echo lang('Save'); ?> " < ? php echo ( $_GET [ " modify " ] ? '' : ' title="' . lang ( 'Ctrl+click on a value to modify it.' ) . '"' ); ?> >
</ div ></ fieldset >
< fieldset >< legend >< ? php echo lang ( 'Selected' ); ?> <span id="selected"></span></legend><div>
< input type = " submit " name = " edit " value = " <?php echo lang('Edit'); ?> " >
< input type = " submit " name = " clone " value = " <?php echo lang('Clone'); ?> " >
< input type = " submit " name = " delete " value = " <?php echo lang('Delete'); ?> " < ? php echo confirm (); ?> >
</ div ></ fieldset >
< ? php
}
$format = $adminer -> dumpFormat ();
foreach (( array ) $_GET [ " columns " ] as $column ) {
if ( $column [ " fun " ]) {
unset ( $format [ 'sql' ]);
break ;
}
}
if ( $format ) {
print_fieldset ( " export " , lang ( 'Export' ) . " <span id='selected2'></span> " );
$output = $adminer -> dumpOutput ();
echo ( $output ? html_select ( " output " , $output , $adminer_import [ " output " ]) . " " : " " );
echo html_select ( " format " , $format , $adminer_import [ " format " ]);
echo " <input type='submit' name='export' value=' " . lang ( 'Export' ) . " '> \n " ;
echo " </div></fieldset> \n " ;
}
echo ( ! $group && $select ? " " : " <script type='text/javascript'>tableCheck();</script> \n " );
}
if ( $adminer -> selectImportPrint ()) {
print_fieldset ( " import " , lang ( 'Import' ), ! $rows );
echo " <input type='file' name='csv_file'> " ;
echo html_select ( " separator " , array ( " csv " => " CSV, " , " csv; " => " CSV; " , " tsv " => " TSV " ), $adminer_import [ " format " ], 1 ); // 1 - select
echo " <input type='submit' name='import' value=' " . lang ( 'Import' ) . " '> " ;
echo " </div></fieldset> \n " ;
}
$adminer -> selectEmailPrint ( array_filter ( $email_fields , 'strlen' ), $columns );
echo " <p><input type='hidden' name='token' value=' $token '></p> \n " ;
echo " </form> \n " ;
}
}
if ( is_ajax ()) {
ob_end_clean ();
exit ;
}