Files
adminer/plugins/tables-filter.php

71 lines
2.2 KiB
PHP
Raw Normal View History

2011-05-24 17:35:57 +02:00
<?php
/** Use filter in tables list
2015-09-08 09:23:25 -07:00
* @link https://www.adminer.org/plugins/#use
2017-02-27 13:43:33 +01:00
* @author Jakub Vrana, https://www.vrana.cz/
2018-01-14 11:03:54 +01:00
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
* @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
2011-05-24 17:35:57 +02:00
*/
class AdminerTablesFilter {
2025-03-05 09:14:49 +01:00
function tablesPrint($tables) {
?>
2025-03-05 11:40:56 +01:00
<script<?php echo Adminer\nonce(); ?>>
2025-03-20 08:58:20 +01:00
let tablesFilterTimeout = null;
let tablesFilterValue = '';
2025-03-20 08:40:15 +01:00
function tablesFilter() {
const value = qs('#filter-field').value.toLowerCase();
if (value == tablesFilterValue) {
return;
}
tablesFilterValue = value;
let reg;
if (value != '') {
reg = (value + '').replace(/([\\\.\+\*\?\[\^\]\$\(\)\{\}\=\!\<\>\|\:])/g, '\\$1');
reg = new RegExp('('+ reg + ')', 'gi');
}
if (sessionStorage) {
sessionStorage.setItem('adminer_tables_filter', value);
}
2025-03-20 08:40:15 +01:00
for (const table of qsa('li', qs('#tables'))) {
let a = null;
let text = table.getAttribute('data-table-name');
if (text == null) {
2025-03-20 08:40:15 +01:00
a = qsa('a', table)[1];
text = a.innerHTML.trim();
2025-03-20 08:40:15 +01:00
table.setAttribute('data-table-name', text);
a.setAttribute('data-link', 'main');
} else {
2025-03-20 08:40:15 +01:00
a = qs('a[data-link="main"]', table);
}
if (value == '') {
2025-03-20 08:40:15 +01:00
table.className = '';
a.innerHTML = text;
} else {
2025-03-20 08:40:15 +01:00
table.className = (text.toLowerCase().indexOf(value) == -1 ? 'hidden' : '');
a.innerHTML = text.replace(reg, '<strong>$1</strong>');
}
2011-05-24 17:35:57 +02:00
}
}
function tablesFilterInput() {
window.clearTimeout(tablesFilterTimeout);
tablesFilterTimeout = window.setTimeout(tablesFilter, 200);
}
sessionStorage && document.addEventListener('DOMContentLoaded', () => {
2025-03-20 08:40:15 +01:00
let db = qs('#dbs').querySelector('select');
db = db.options[db.selectedIndex].text;
if (db == sessionStorage.getItem('adminer_tables_filter_db') && sessionStorage.getItem('adminer_tables_filter')){
qs('#filter-field').value = sessionStorage.getItem('adminer_tables_filter');
tablesFilter();
}
sessionStorage.setItem('adminer_tables_filter_db', db);
});
2011-05-24 17:35:57 +02:00
</script>
2025-03-05 11:40:56 +01:00
<p class="jsonly"><input id="filter-field" autocomplete="off" type="search"><?php echo Adminer\script("qs('#filter-field').oninput = tablesFilterInput;"); ?>
2011-05-24 17:35:57 +02:00
<?php
}
}