")
        .addClass("input-group-text go-to-selected-note-button jam jam-arrow-right")
        .attr("data-action", "note");
    const $sideButtons = $("")
        .addClass("input-group-append")
        .append($clearTextButton)
        .append($showRecentNotesButton);
    if (!options.hideGoToSelectedNoteButton) {
        $sideButtons.append($goToSelectedNoteButton);
    }
    $el.after($sideButtons);
    $clearTextButton.click(() => clearText($el));
    $showRecentNotesButton.click(e => {
        showRecentNotes($el);
        // this will cause the click not give focus to the "show recent notes" button
        // this is important because otherwise input will lose focus immediatelly and not show the results
        return false;
    });
    $el.autocomplete({
        appendTo: document.querySelector('body'),
        hint: false,
        autoselect: true,
        openOnFocus: true,
        minLength: 0,
        tabAutocomplete: false
    }, [
        {
            source: autocompleteSource,
            displayKey: 'title',
            templates: {
                suggestion: function(suggestion) {
                    return suggestion.highlighted;
                }
            },
            // we can't cache identical searches because notes can be created / renamed, new recent notes can be added
            cache: false
        }
    ]);
    $el.on('autocomplete:selected', (event, suggestion) => $el.setSelectedPath(suggestion.path));
    $el.on('autocomplete:closed', () => {
        if (!$el.val().trim()) {
            clearText($el);
        }
    });
    return $el;
}
function init() {
    $.fn.getSelectedPath = function () {
        if (!$(this).val().trim()) {
            return "";
        } else {
            return $(this).attr(SELECTED_PATH_KEY);
        }
    };
    $.fn.setSelectedPath = function (path) {
        path = path || "";
        $(this).attr(SELECTED_PATH_KEY, path);
        $(this)
            .closest(".input-group")
            .find(".go-to-selected-note-button")
            .toggleClass("disabled", !path.trim())
            .attr(SELECTED_PATH_KEY, path); // we also set attr here so tooltip can be displayed
    };
}
export default {
    initNoteAutocomplete,
    showRecentNotes,
    init
}