mirror of
https://github.com/zombieFox/nightTab.git
synced 2024-11-28 19:13:16 +01:00
83 lines
1.9 KiB
JavaScript
83 lines
1.9 KiB
JavaScript
var search = (function() {
|
|
|
|
var state = {
|
|
search: false
|
|
};
|
|
|
|
var get = function() {
|
|
return state;
|
|
};
|
|
|
|
var bind = function() {
|
|
var searchInput = helper.e(".search-input");
|
|
var searchClear = helper.e(".search-clear");
|
|
searchInput.addEventListener("input", function() {
|
|
_updateState(this);
|
|
_updateSearchClear();
|
|
render();
|
|
}, false);
|
|
searchClear.addEventListener("click", function() {
|
|
_updateState(this);
|
|
_updateSearchClear();
|
|
clear();
|
|
}, false);
|
|
};
|
|
|
|
var _updateState = function(input) {
|
|
if (input.value != "") {
|
|
state.search = true;
|
|
} else {
|
|
state.search = false;
|
|
};
|
|
};
|
|
|
|
var _updateSearchClear = function() {
|
|
var searchInput = helper.e(".search-input");
|
|
var searchClear = helper.e(".search-clear");
|
|
if (state.search) {
|
|
searchClear.removeAttribute("disabled");
|
|
} else {
|
|
searchClear.setAttribute("disabled", "");
|
|
};
|
|
};
|
|
|
|
var render = function() {
|
|
var searchInput = helper.e(".search-input");
|
|
if (state.search) {
|
|
var searchResult = [];
|
|
bookmarks.get().forEach(function(arrayItem, index) {
|
|
if (arrayItem.url.replace(/^https?\:\/\//i, "").replace(/\/$/, "").toLowerCase().includes(searchInput.value.toLowerCase()) || arrayItem.name.toLowerCase().includes(searchInput.value.toLowerCase())) {
|
|
arrayItem.index = index;
|
|
searchResult.push(arrayItem);
|
|
};
|
|
});
|
|
links.clear();
|
|
links.render(searchResult);
|
|
} else {
|
|
links.clear();
|
|
links.render();
|
|
};
|
|
};
|
|
|
|
var clear = function() {
|
|
var searchInput = helper.e(".search-input");
|
|
searchInput.value = "";
|
|
searchInput.focus();
|
|
links.clear();
|
|
links.render();
|
|
};
|
|
|
|
var init = function() {
|
|
bind();
|
|
};
|
|
|
|
// exposed methods
|
|
return {
|
|
init: init,
|
|
get: get,
|
|
render: render,
|
|
clear: clear
|
|
};
|
|
|
|
})();
|