fix(monitors search): Correctly handle null/undefined/empty values. Also optimize a bit search tags by replacing .find with .some.

Thanks @homelab-alpha
This commit is contained in:
Ionys 2024-12-22 11:24:36 +01:00
parent 1e0342949f
commit d0d03c05d6

View file

@ -324,14 +324,21 @@ export default {
// finds monitor name, tag name or tag value
let searchTextMatch = true;
if (this.searchText !== "") {
const regex = new RegExp(this.searchText, "i");
try {
const regex = new RegExp(this.searchText, "i"); // "i" for case-insensitive matching
searchTextMatch =
regex.test(monitor.name) ||
regex.test(monitor.url) ||
regex.test(monitor.hostname) ||
regex.test(monitor.dns_resolve_server) ||
monitor.tags.find((tag) => regex.test(tag.name) || regex.test(tag.value));
const safeRegexTest = (str) => str && regex.test(str);
searchTextMatch =
regex.test(monitor.name) ||
safeRegexTest(monitor.url) ||
safeRegexTest(monitor.hostname) ||
safeRegexTest(monitor.dns_resolve_server) ||
monitor.tags.some(tag => regex.test(tag.name) || safeRegexTest(tag.value));
} catch (e) {
console.error("Invalid regex pattern:", e);
searchTextMatch = false;
}
}
// filter by status