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

47 lines
1.2 KiB
Vue
Raw Normal View History

2019-04-02 10:12:31 +00:00
<template>
2019-04-02 17:18:36 +00:00
<div class="user-autosuggest" v-click-outside="onClickOutside">
2019-04-02 19:43:41 +00:00
<input v-model="term" :placeholder="placeholder" @click="onInputClick" class="user-autosuggest-input" />
<div class="user-autosuggest-results" v-if="resultsVisible && filtered.length > 0">
2019-04-02 20:02:02 +00:00
<slot v-for="item in filtered" :item="item">
</slot>
</div>
2019-04-02 10:12:31 +00:00
</div>
</template>
<script src="./user_autosuggest.js"></script>
<style lang="scss">
2019-04-02 17:18:41 +00:00
@import '../../_variables.scss';
2019-04-02 16:33:01 +00:00
.user-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;
2019-04-02 17:18:41 +00:00
background-color: $fallback--lightBg;
background-color: var(--lightBg, $fallback--lightBg);
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>