1
0
mirror of https://github.com/kkapsner/CanvasBlocker synced 2025-01-18 09:28:52 +01:00
CanvasBlocker/lib/search.js

97 lines
2.3 KiB
JavaScript
Raw Normal View History

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
(function(){
"use strict";
2019-11-28 01:26:35 +01:00
let scope;
if ((typeof exports) !== "undefined"){
scope = exports;
}
else {
2019-03-12 22:24:23 +01:00
scope = require.register("./search", {});
}
2019-04-09 08:29:52 +02:00
const extension = require("./extension");
const texts = [];
const callbacks = [];
scope.register = function(text, content){
switch (typeof text){
case "function":
callbacks.push({callback: text, content});
break;
default:
texts.push({text: text.toLowerCase(), content});
break;
}
};
scope.search = function(search){
2024-04-08 00:09:37 +02:00
const resultSets = search.split(/\s+/).filter(function(term){
return term.trim();
}).map(function(term){
const matching = new Set();
2024-04-08 00:09:37 +02:00
if (term.match(/^:[a-z]+$/i)){
const tag = term.substring(1);
texts.forEach(function(text){
if (text.content.querySelector(`.${tag}`)){
matching.add(text.content);
}
});
}
else {
term = new RegExp(term.toLowerCase());
texts.forEach(function(text){
if (term.test(text.text)){
matching.add(text.content);
}
});
callbacks.forEach(function(callback){
if (callback.callback(term)){
matching.add(callback.content);
}
});
2024-04-08 00:09:37 +02:00
}
return matching;
});
if (resultSets.length){
return Array.from(
resultSets.reduce(function(previousSet, set){
2019-11-28 01:26:35 +01:00
const andSet = new Set();
set.forEach(function(entry){
if (previousSet.has(entry)){
andSet.add(entry);
}
});
return andSet;
})
);
}
else {
return [];
}
};
const searchListeners = [];
scope.init = function(){
const node = document.createElement("input");
node.id = "search";
2019-04-09 08:29:52 +02:00
node.placeholder = extension.getTranslation("search");
window.setTimeout(() => node.focus(), 1);
let lastResults = [];
node.addEventListener("input", function(){
this.search();
});
node.search = function(){
const search = this.value;
const results = search? scope.search(search): [];
searchListeners.forEach(function(callback){
callback({search, results, lastResults});
});
lastResults = results;
};
return node;
};
scope.on = function(callback){
searchListeners.push(callback);
};
}());