accounts: start advanced search filter support

uses the same format "<field>:<value>", but supports quoted <values>
(allows for spaces in them), and lays groundwork to support string and
date-type field filtering. Truthiness is supported, meaning you can
check if an email is set with "email:yes" for example.
accounts-list-features
Harvey Tindall 2 years ago
parent bc4015ac50
commit 8a37663c89
No known key found for this signature in database
GPG Key ID: BBC65952848FB1A2

@ -775,40 +775,158 @@ export class accountsList {
} }
} }
search = (query: string): string[] => { search = (query: String): string[] => {
query = query.toLowerCase() console.log("called!");
let result: string[] = []; const queries: { [field: string]: { name: string, getter: string, bool: boolean, string: boolean, date: boolean }} = {
if (query.includes(":")) { // Support admin:<true/false> and disabled:<true/false> "admin": {
const words = query.split(" "); name: "Admin",
query = ""; getter: "admin",
for (let word of words) { bool: true,
if (word.includes(":")) { string: false,
const querySplit = word.split(":") date: false
let state = false; },
if (querySplit[1] == "true" || querySplit[1] == "yes") { "disabled": {
state = true; name: "Disabled",
} getter: "disabled",
for (let id of this._ordering) { bool: true,
const user = this._users[id]; string: false,
let attrib: boolean; date: false
if (querySplit[0] == "admin") { attrib = user.admin; } },
else if (querySplit[0] == "disabled") { attrib = user.disabled; } "access-jfa": {
if (attrib == state) { result.push(id); } name: "Access jfa-go",
} getter: "accounts_admin",
} else { query += word + " "; } bool: true,
string: false,
date: false
},
"email": {
name: "Email",
getter: "email",
bool: true,
string: true,
date: false
},
"telegram": {
name: "Telegram",
getter: "telegram",
bool: true,
string: true,
date: false
},
"matrix": {
name: "Matrix",
getter: "matrix",
bool: true,
string: true,
date: false
},
"discord": {
name: "Discord",
getter: "discord",
bool: true,
string: true,
date: false
},
"expiry": {
name: "Expiry",
getter: "expiry",
bool: true,
string: false,
date: true
},
"last-active": {
name: "Last Active",
getter: "last_active",
bool: true,
string: false,
date: true
} }
} }
if (query == "") { return result; }
for (let id of this._ordering) { query = query.toLowerCase();
const user = this._users[id]; let result: string[] = [...this._ordering];
if (user.name.toLowerCase().includes(query)) { console.log("initial:", result);
result.push(id); if (!(query.includes(":"))) return result;
} else if (user.email.toLowerCase().includes(query)) {
result.push(id); // const words = query.split(" ");
let words: string[] = [];
// FIXME: SPLIT BY SPACE, UNLESS IN QUOTES
let quoteSymbol = ``;
let queryStart = -1;
let lastQuote = -1;
for (let i = 0; i < query.length; i++) {
if (queryStart == -1 && query[i] != " " && query[i] != `"` && query[i] != `'`) {
queryStart = i;
}
if ((query[i] == `"` || query[i] == `'`) && (quoteSymbol == `` || query[i] == quoteSymbol)) {
if (lastQuote != -1) {
lastQuote = -1;
quoteSymbol = ``;
} else {
lastQuote = i;
quoteSymbol = query[i];
}
}
if (query[i] == " " || i == query.length-1) {
if (lastQuote != -1) {
continue;
} else {
words.push(query.substring(queryStart, i+1).replace(/['"]/g, ""));
queryStart = -1;
}
} }
} }
return result;
} query = "";
for (let word of words) {
const split = word.split(":");
if (!(split[0] in queries)) continue;
const queryFormat = queries[split[0]];
if (queryFormat.bool) {
let isBool = false;
let boolState = false;
if (split[1] == "true" || split[1] == "yes" || split[1] == "t" || split[1] == "y") {
isBool = true;
boolState = true;
} else if (split[1] == "false" || split[1] == "no" || split[1] == "f" || split[1] == "n") {
isBool = true;
boolState = false;
}
if (isBool) {
// console.log("is bool, state", boolState);
// So removing elements doesn't affect us
let cachedResult = [...result];
for (let id of cachedResult) {
const u = this._users[id];
const value = Object.getOwnPropertyDescriptor(user.prototype, queryFormat.getter).get.call(u);
// console.log("got", queryFormat.getter + ":", value);
// Remove from result if not matching query
if (!((value && boolState) || (!value && !boolState))) {
// console.log("not matching, result is", result);
result.splice(result.indexOf(id), 1);
}
}
continue
}
}
if (queryFormat.string) {
// FIXME: STRING SEARCH FOR FIELD
// FIXME: SUBTRACT FROM RESULT
continue;
}
if (queryFormat.date) {
}
}
return result
};
get selectAll(): boolean { return this._selectAll.checked; } get selectAll(): boolean { return this._selectAll.checked; }
set selectAll(state: boolean) { set selectAll(state: boolean) {

Loading…
Cancel
Save