assembly/components/SearchInput.vue
Georges KABBOUCHI 3381dc2c92 wip
2021-08-01 14:22:17 +03:00

70 lines
1.4 KiB
Vue

<template>
<div class="relative flex items-center h-9 w-[200px]">
<input
class="w-full pl-3 pr-8 rounded-[6px] border border-grey-dark border-opacity-[0.15]"
type="text"
v-bind="$attrs"
v-on="inputListeners"
/>
<SVGSearch class="absolute w-4 h-4 search-icon right-4" />
</div>
</template>
<script>
import { defineComponent, computed } from '@nuxtjs/composition-api'
import SVGSearch from '@/assets/icons/search.svg?inline'
export default defineComponent({
inheritAttrs: false,
components: {
SVGSearch,
},
setup(props, context) {
// Source: https://vuejs.org/v2/guide/components-custom-events.html#Binding-Native-Events-to-Components
const inputListeners = computed(() =>
Object.assign({}, context.listeners, {
input(event) {
context.emit('input', event.target.value)
},
})
)
return { inputListeners }
},
})
</script>
<style scoped>
.search-icon {
@apply text-grey-pure;
@apply transition;
@apply duration-150;
}
.dark .search-icon {
@apply text-grey-pure;
}
input {
@apply transition;
@apply duration-150;
}
input:focus {
@apply outline-none;
@apply border-ocean-blue-pure;
}
.dark input:focus {
@apply outline-none;
@apply border-lightest;
}
input:focus ~ .search-icon {
@apply text-ocean-blue-pure;
}
.dark input:focus ~ .search-icon {
@apply text-lightest;
}
</style>