mirror of
https://github.com/sissbruecker/linkding.git
synced 2025-08-07 10:58:25 +02:00

* return updated HTML from bookmark actions * open details through URL * fix details update * improve modal behavior * use a frame * make behaviors properly destroy themselves * remove page and details params from tag urls * use separate behavior for details and tags * remove separate details view * make it work with other views * add asset actions * remove asset refresh for now * remove details partial * fix tests * remove old partials * update tests * cache and reuse tags * extract search autocomplete behavior * remove details param from pagination * fix tests * only return details modal when navigating in frame * fix link target * remove unused behaviors * use auto submit behavior for user select * fix import
42 lines
1.1 KiB
JavaScript
42 lines
1.1 KiB
JavaScript
import { Behavior, registerBehavior } from "./index";
|
|
import SearchAutoCompleteComponent from "../components/SearchAutoComplete.svelte";
|
|
|
|
class SearchAutocomplete extends Behavior {
|
|
constructor(element) {
|
|
super(element);
|
|
const input = element.querySelector("input");
|
|
if (!input) {
|
|
console.warn("SearchAutocomplete: input element not found");
|
|
return;
|
|
}
|
|
|
|
const container = document.createElement("div");
|
|
|
|
new SearchAutoCompleteComponent({
|
|
target: container,
|
|
props: {
|
|
name: "q",
|
|
placeholder: input.getAttribute("placeholder") || "",
|
|
value: input.value,
|
|
linkTarget: input.dataset.linkTarget,
|
|
mode: input.dataset.mode,
|
|
search: {
|
|
user: input.dataset.user,
|
|
shared: input.dataset.shared,
|
|
unread: input.dataset.unread,
|
|
},
|
|
},
|
|
});
|
|
|
|
this.input = input;
|
|
this.autocomplete = container.firstElementChild;
|
|
input.replaceWith(this.autocomplete);
|
|
}
|
|
|
|
destroy() {
|
|
this.autocomplete.replaceWith(this.input);
|
|
}
|
|
}
|
|
|
|
registerBehavior("ld-search-autocomplete", SearchAutocomplete);
|