blob: 61a83844256b79a455b94a4ca12e3b509a1189d7 [file] [log] [blame]
<template>
<Dropdown @on-clickoutside="handleClose" placement="bottom-start" trigger="custom" :visible="visible" class="mr15">
<div @click="handleOpen">
<div class="flex-c">
<span class="mr5">{{this.data.filter(i => i.key == this.value).length?this.data.filter(i => i.key == this.value)[0].label || this.data.filter(i => i.key == this.value)[0].name : ''}}</span><Icon type="md-arrow-dropdown" />
</div>
</div>
<DropdownMenu slot="list">
<div class="rk-select-search">
<input class="rk-select-search-input" v-model="search">
</div>
<div class="rk-select-wrapper">
<li class="ivu-dropdown-item" @click="handleSelect(i)" v-for="(i, index) in filterData" :key="index">{{i.label || i.name}}</li>
</div>
</DropdownMenu>
</Dropdown>
</template>
<script lang="ts">
import { Vue, Component, Prop } from 'vue-property-decorator';
@Component
export default class RkSelect extends Vue {
@Prop() data: any;
@Prop() value: any;
@Prop({ default: '' }) callValue: string;
search: string = '';
visible: boolean = false;
get filterData() {
return this.data.filter(i => i.label.indexOf(this.search) !== -1);
}
handleOpen() {
this.visible = true;
}
handleClose() {
this.visible = false;
}
handleSelect(i: any) {
const temp = this.callValue ? i[this.callValue] : i;
this.$emit('input', temp);
this.visible = false;
}
}
</script>
<style lang="scss" scoped>
.rk-select-wrapper{
overflow: auto;
max-height: 200px;
}
.rk-select-search {
padding: 8px;
position: relative;
background-color: #eaeef1;
top: -5px;
border-bottom: 1px solid #ddd;
border-radius: 4px 4px 0 0;
&:before{
width: 16px;
height: 16px;
display: block;
content: '';
position: absolute;
top: 14px;
left: 13px;
background-image: url();
}
.rk-select-search-input {
border: 1px solid #ddd;
padding: 3px 10px 3px 25px;
outline: 0;
width: 100%;
border-radius: 4px;
}
}
</style>