2019-07-11 13:54:40 +08:00
|
|
|
<template>
|
|
|
|
<div>
|
|
|
|
<n-select
|
|
|
|
v-if="options && options.columns"
|
|
|
|
v-model="selectedValue"
|
|
|
|
size="small"
|
|
|
|
style="width:176px;margin-right:16px;"
|
|
|
|
placeholder="Please Select Type"
|
|
|
|
:items="options.columns"
|
|
|
|
/>
|
|
|
|
<n-input
|
|
|
|
v-model="value"
|
|
|
|
type="input"
|
|
|
|
size="small"
|
|
|
|
icon="ios-search"
|
|
|
|
round
|
|
|
|
:placeholder="options.placeholder || 'Search something...'"
|
|
|
|
style="width:240px; display:inline-block;"
|
|
|
|
@input="handleInputChange"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
export default {
|
|
|
|
props: {
|
|
|
|
options: {
|
|
|
|
/**
|
|
|
|
* {columns:{label,value}}
|
|
|
|
*/
|
|
|
|
type: Object,
|
|
|
|
default: null
|
|
|
|
}
|
|
|
|
},
|
|
|
|
data () {
|
|
|
|
return {
|
|
|
|
timer: null,
|
|
|
|
value: '',
|
|
|
|
selectedValue: this.options.columns ? this.options.columns[0].value : null
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2019-08-23 14:55:21 +08:00
|
|
|
clearSearch () {
|
|
|
|
this.value = ''
|
2019-08-29 15:12:58 +08:00
|
|
|
this.selectedValue = this.options.columns ? this.options.columns[0].value : ''
|
2019-08-23 14:55:21 +08:00
|
|
|
this.handleInputChange()
|
|
|
|
},
|
2019-07-19 19:40:01 +08:00
|
|
|
setSearch ({ key, value }) {
|
|
|
|
this.value = value
|
|
|
|
this.selectedValue = key
|
|
|
|
this.handleInputChange()
|
|
|
|
},
|
2019-07-11 13:54:40 +08:00
|
|
|
handleInputChange () {
|
2019-07-19 19:40:01 +08:00
|
|
|
this.$emit('on-change', { key: this.selectedValue, word: this.value })
|
2019-07-11 13:54:40 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|