Skip to content
Snippets Groups Projects
SearchWidget.vue 1.88 KiB
Newer Older
<template>
    <sidebar-widget id="search-widget" class="sidebar-search" :title="$gettext('Suche')">
        <template #content>
            <form class="sidebar-search">
                <ul class="needles">
                    <li>
                        <div class="input-group files-search">
                            <input type="text" id="searchterm" name="searchterm" v-model="searchterm"
                                   :placeholder="$gettext('Veranstaltung suchen')"
                                   :aria-label="$gettext('Veranstaltung suchen')">
                            <a v-if="isActive" @click.prevent="cancelSearch" class="reset-search">
Jan-Hendrik Willms's avatar
Jan-Hendrik Willms committed
                                <studip-icon shape="decline" :size="20"></studip-icon>
                            </a>
                            <button type="submit" class="submit-search" :title="$gettext('Suchen')"
                                    @click.prevent="doSearch">
                                <studip-icon shape="search" :size="20"></studip-icon>
                            </button>
                        </div>
                    </li>
                </ul>
            </form>
        </template>
    </sidebar-widget>
</template>

<script>
import SidebarWidget from './SidebarWidget.vue';
import StudipIcon from './StudipIcon.vue';

export default {
    name: 'search-widget',
    components: {
        StudipIcon,
        SidebarWidget
    },
    data() {
        return {
            searchterm: '',
            isActive: false
        };
    },
    methods: {
        doSearch() {
            if (this.searchterm !== '') {
                this.isActive = true;
                STUDIP.eventBus.emit('do-search', this.searchterm);
            }
        },
        cancelSearch() {
            this.isActive = false;
            this.searchterm = '';
            STUDIP.eventBus.emit('cancel-search');
        }
    }
}
</script>