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

60 lines
1.2 KiB
Vue
Raw Normal View History

2019-04-02 21:12:31 +11:00
<template>
2019-07-05 17:17:44 +10: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 21:12:31 +11:00
</div>
</template>
2019-04-03 07:10:03 +11:00
<script src="./autosuggest.js"></script>
2019-04-02 21:12:31 +11:00
<style lang="scss">
2019-04-03 04:18:41 +11:00
@import '../../_variables.scss';
2019-04-03 07:10:03 +11:00
.autosuggest {
position: relative;
2019-04-02 21:12:31 +11:00
2019-04-03 04:18:41 +11:00
&-input {
display: block;
width: 100%;
}
&-results {
2019-04-02 21:12:31 +11:00
position: absolute;
left: 0;
top: 100%;
right: 0;
2019-04-03 05:07:03 +11:00
max-height: 400px;
2019-04-03 04:18:41 +11: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-03 05:07:03 +11: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 21:12:31 +11:00
}
}
</style>