akkoma-fe/src/components/autosuggest/autosuggest.vue

60 lines
1.2 KiB
Vue
Raw Normal View History

2019-04-02 10:12:31 +00:00
<template>
2019-07-05 07:17:44 +00:00
<div
v-click-outside="onClickOutside"
class="autosuggest"
>
<input
v-model="term"
:placeholder="placeholder"
class="autosuggest-input"
@click="onInputClick"
>
<div
v-if="resultsVisible && filtered.length > 0"
class="autosuggest-results"
>
<slot
v-for="item in filtered"
:item="item"
/>
</div>
2019-04-02 10:12:31 +00:00
</div>
</template>
2019-04-02 20:10:03 +00:00
<script src="./autosuggest.js"></script>
2019-04-02 10:12:31 +00:00
<style lang="scss">
2019-04-02 17:18:41 +00:00
@import '../../_variables.scss';
2019-04-02 20:10:03 +00:00
.autosuggest {
position: relative;
2019-04-02 10:12:31 +00:00
2019-04-02 17:18:41 +00:00
&-input {
display: block;
width: 100%;
}
&-results {
2019-04-02 10:12:31 +00:00
position: absolute;
left: 0;
top: 100%;
right: 0;
2019-04-02 18:07:03 +00:00
max-height: 400px;
background-color: $fallback--bg;
background-color: var(--bg, $fallback--bg);
2019-04-02 17:18:41 +00:00
border-style: solid;
border-width: 1px;
border-color: $fallback--border;
border-color: var(--border, $fallback--border);
border-radius: $fallback--inputRadius;
border-radius: var(--inputRadius, $fallback--inputRadius);
border-top-left-radius: 0;
border-top-right-radius: 0;
2019-04-02 18:07:03 +00:00
box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.6);
box-shadow: var(--panelShadow);
overflow-y: auto;
z-index: 1;
2019-04-02 10:12:31 +00:00
}
}
</style>