const LYCO_REGEX = /<(?!e:|h:)[^,> ]*>?/g; | |
const LYCO_TRIGGER = () => CFG.useLycos && tagword.match(LYCO_REGEX); | |
class LycoParser extends BaseTagParser { | |
parse() { | |
// Show lyco | |
let tempResults = []; | |
if (tagword !== "<" && tagword !== "<l:" && tagword !== "<lyco:") { | |
let searchTerm = tagword.replace("<lyco:", "").replace("<l:", "").replace("<", ""); | |
let filterCondition = x => x.toLowerCase().includes(searchTerm) || x.toLowerCase().replaceAll(" ", "_").includes(searchTerm); | |
tempResults = lycos.filter(x => filterCondition(x)); // Filter by tagword | |
} else { | |
tempResults = lycos; | |
} | |
// Add final results | |
let finalResults = []; | |
tempResults.forEach(t => { | |
let result = new AutocompleteResult(t.trim(), ResultType.lyco) | |
result.meta = "Lyco"; | |
finalResults.push(result); | |
}); | |
return finalResults; | |
} | |
} | |
async function load() { | |
if (lycos.length === 0) { | |
try { | |
lycos = (await readFile(`${tagBasePath}/temp/lyco.txt`)).split("\n") | |
.filter(x => x.trim().length > 0) // Remove empty lines | |
.map(x => x.trim()); // Remove carriage returns and padding if it exists | |
} catch (e) { | |
console.error("Error loading lyco.txt: " + e); | |
} | |
} | |
} | |
function sanitize(tagType, text) { | |
if (tagType === ResultType.lyco) { | |
return `<lyco:${text}:${CFG.extraNetworksDefaultMultiplier}>`; | |
} | |
return null; | |
} | |
PARSERS.push(new LycoParser(LYCO_TRIGGER)); | |
// Add our utility functions to their respective queues | |
QUEUE_FILE_LOAD.push(load); | |
QUEUE_SANITIZE.push(sanitize); |