Merge pull request #60 from andrewjanssen/enhanced-search

Search processes with comma-separated queries, incl regexes
This commit is contained in:
Abdenasser Elidrissi 2024-11-08 17:25:25 +01:00 committed by GitHub
commit 23b1171083
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 22 additions and 5 deletions

View File

@ -22,6 +22,12 @@
- 💻 CPU and Memory usage tracking
- 🎨 Beautiful, modern UI with dark/light themes
- 🔍 Process search and filtering
Search for processes by name, command, or PID. Search for multiple things at once by separating them with commas. For
example, `arm, x86` will return processes having `arm` or `x86` as a substring of the name or command. You can use
regular expressions too. For example, `d$` will return a list of daemons (which tend to end in the letter `d`), while
`(\w+)\.\w+` will return a list of processes with reverse domain name notation, such as `com.docker.vmnetd`.
- 📌 Pin important processes
- 🛠 Process management (kill processes)
- 🎯 Sort by any column

View File

@ -60,11 +60,22 @@
};
$: filteredProcesses = processes.filter((process) => {
const matchesSearch = searchTerm
? process.name.toLowerCase().includes(searchTerm.toLowerCase()) ||
process.command.toLowerCase().includes(searchTerm.toLowerCase()) ||
process.pid.toString().includes(searchTerm)
: true;
let matchesSearch = searchTerm.length === 0;
searchTerm
.split(",")
.map((term) => term.trim())
.forEach((term) => {
const nameSubstringMatch = process.name
.toLowerCase()
.includes(term.toLowerCase());
const nameRegexMatch = new RegExp(term, "i").test(process.name);
const commandMatch = process.command
.toLowerCase()
.includes(term.toLowerCase());
const pidMatch = process.pid.toString().includes(term);
matchesSearch ||=
nameSubstringMatch || nameRegexMatch || commandMatch || pidMatch;
});
const matchesStatus =
statusFilter === "all" ? true : process.status === statusFilter;