mirror of
https://github.com/zadam/trilium.git
synced 2025-03-01 14:22:32 +01:00
183 lines
5.1 KiB
JavaScript
183 lines
5.1 KiB
JavaScript
import BasicWidget from "./basic_widget.js";
|
|
import toastService from "../services/toast.js";
|
|
import appContext from "../services/app_context.js";
|
|
import noteCreateService from "../services/note_create.js";
|
|
import utils from "../services/utils.js";
|
|
import treeCache from "../services/tree_cache.js";
|
|
|
|
const TPL = `
|
|
<div class="search-box">
|
|
<style>
|
|
.search-box {
|
|
display: none;
|
|
padding: 10px;
|
|
margin-top: 10px;
|
|
}
|
|
|
|
.search-text {
|
|
border: 1px solid var(--main-border-color);
|
|
}
|
|
</style>
|
|
|
|
<div class="form-group">
|
|
<div class="input-group">
|
|
<input name="search-text" class="search-text form-control"
|
|
placeholder="Search text, labels" autocomplete="off">
|
|
|
|
<div class="input-group-append">
|
|
<button class="do-search-button btn btn-sm icon-button bx bx-search" title="Search (enter)"></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div style="display: flex; align-items: center; justify-content: space-evenly; flex-wrap: wrap;">
|
|
<button class="save-search-button btn btn-sm"
|
|
title="This will create new saved search note under active note.">
|
|
<span class="bx bx-save"></span> Save search
|
|
</button>
|
|
|
|
<button class="close-search-button btn btn-sm">
|
|
<span class="bx bx-x"></span> Close search
|
|
</button>
|
|
</div>
|
|
</div>`;
|
|
|
|
export default class SearchBoxWidget extends BasicWidget {
|
|
doRender() {
|
|
this.$widget = $(TPL);
|
|
this.contentSized();
|
|
|
|
this.$searchBox = this.$widget;
|
|
this.$closeSearchButton = this.$widget.find(".close-search-button");
|
|
this.$searchInput = this.$widget.find("input[name='search-text']");
|
|
this.$resetSearchButton = this.$widget.find(".reset-search-button");
|
|
this.$doSearchButton = this.$widget.find(".do-search-button");
|
|
this.$saveSearchButton = this.$widget.find(".save-search-button");
|
|
|
|
this.$searchInput.on('keyup',e => {
|
|
const searchText = this.$searchInput.val();
|
|
|
|
if (e && e.which === $.ui.keyCode.ESCAPE || $.trim(searchText) === "") {
|
|
this.$resetSearchButton.trigger('click');
|
|
return;
|
|
}
|
|
|
|
if (e && e.which === $.ui.keyCode.ENTER) {
|
|
this.doSearch();
|
|
}
|
|
});
|
|
|
|
this.$doSearchButton.on('click', () => this.doSearch()); // keep long form because of argument
|
|
this.$resetSearchButton.on('click', () => this.resetSearchEvent());
|
|
|
|
this.$saveSearchButton.on('click', () => this.saveSearch());
|
|
|
|
this.$closeSearchButton.on('click', () => this.hideSearch());
|
|
}
|
|
|
|
doSearch(searchText) {
|
|
if (searchText) {
|
|
this.$searchInput.val(searchText);
|
|
}
|
|
else {
|
|
searchText = this.$searchInput.val();
|
|
}
|
|
|
|
if (searchText.trim().length === 0) {
|
|
toastService.showMessage("Please enter search criteria first.");
|
|
|
|
this.$searchInput.trigger('focus');
|
|
|
|
return;
|
|
}
|
|
|
|
this.triggerCommand('searchForResults', {
|
|
searchText: this.$searchInput.val()
|
|
});
|
|
|
|
this.$searchBox.tooltip("hide");
|
|
}
|
|
|
|
async saveSearch() {
|
|
const searchString = this.$searchInput.val().trim();
|
|
|
|
if (searchString.length === 0) {
|
|
alert("Write some search criteria first so there is something to save.");
|
|
return;
|
|
}
|
|
|
|
let parent = appContext.tabManager.getActiveTabNote();
|
|
|
|
if (parent.type === 'search') {
|
|
parent = await treeCache.getNote('root');
|
|
}
|
|
|
|
await noteCreateService.createNote(parent.noteId, {
|
|
type: "search",
|
|
mime: "application/json",
|
|
title: searchString,
|
|
content: JSON.stringify({ searchString: searchString })
|
|
});
|
|
|
|
this.resetSearchEvent();
|
|
}
|
|
|
|
showSearchEvent(data = {}) {
|
|
const {searchText} = data;
|
|
|
|
utils.saveFocusedElement();
|
|
|
|
this.$searchBox.slideDown();
|
|
|
|
this.$searchBox.tooltip({
|
|
trigger: 'focus',
|
|
html: true,
|
|
title: window.glob.SEARCH_HELP_TEXT,
|
|
placement: 'right',
|
|
delay: {
|
|
show: 500, // necessary because sliding out may cause wrong position
|
|
hide: 200
|
|
}
|
|
});
|
|
|
|
if (searchText) {
|
|
this.$searchInput.val(searchText);
|
|
}
|
|
|
|
this.$searchInput.trigger('focus');
|
|
}
|
|
|
|
hideSearch() {
|
|
this.resetSearchEvent();
|
|
|
|
this.$searchBox.slideUp();
|
|
|
|
this.triggerCommand('searchFlowEnded');
|
|
}
|
|
|
|
toggleSearchEvent() {
|
|
if (this.$searchBox.is(":hidden")) {
|
|
this.showSearchEvent();
|
|
}
|
|
else {
|
|
this.hideSearch();
|
|
}
|
|
}
|
|
|
|
searchNotesEvent() {
|
|
this.toggleSearchEvent();
|
|
}
|
|
|
|
resetSearchEvent() {
|
|
this.$searchInput.val("");
|
|
}
|
|
|
|
searchInSubtreeEvent({node}) {
|
|
const noteId = node.data.noteId;
|
|
|
|
this.showSearchEvent();
|
|
|
|
this.$searchInput.val(`@in=${noteId} @text*=*`);
|
|
}
|
|
}
|