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

46 lines
1.2 KiB
Vue
Raw Normal View History

2019-04-02 03:12:31 -07:00
<template>
2019-04-02 13:10:03 -07:00
<div class="autosuggest" v-click-outside="onClickOutside">
<input v-model="term" :placeholder="placeholder" @click="onInputClick" class="autosuggest-input" />
<div class="autosuggest-results" v-if="resultsVisible && filtered.length > 0">
2019-04-02 13:46:40 -07:00
<slot v-for="item in filtered" :item="item" />
</div>
2019-04-02 03:12:31 -07:00
</div>
</template>
2019-04-02 13:10:03 -07:00
<script src="./autosuggest.js"></script>
2019-04-02 03:12:31 -07:00
<style lang="scss">
2019-04-02 10:18:41 -07:00
@import '../../_variables.scss';
2019-04-02 13:10:03 -07:00
.autosuggest {
position: relative;
2019-04-02 03:12:31 -07:00
2019-04-02 10:18:41 -07:00
&-input {
display: block;
width: 100%;
}
&-results {
2019-04-02 03:12:31 -07:00
position: absolute;
left: 0;
top: 100%;
right: 0;
2019-04-02 11:07:03 -07:00
max-height: 400px;
2019-04-02 10:18:41 -07: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 11:07:03 -07: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 03:12:31 -07:00
}
}
</style>