mirror of
https://github.com/devfake/flox.git
synced 2024-11-15 06:32:34 +01:00
70 lines
1.5 KiB
Vue
70 lines
1.5 KiB
Vue
<template>
|
|
<section class="search-wrap" :class="{sticky: sticky}">
|
|
<div class="wrap">
|
|
|
|
<form class="search-form" @submit.prevent="search()">
|
|
<router-link to="/"><i @click="scrollToTop()" class="icon-logo-small"></i></router-link>
|
|
<i class="icon-search"></i>
|
|
<input type="text" :placeholder="placeholder" v-model="title" class="search-input" autofocus>
|
|
|
|
<i class="icon-algolia" v-if="algolia"></i>
|
|
</form>
|
|
|
|
</div>
|
|
</section>
|
|
</template>
|
|
|
|
<script>
|
|
import Helper from '../helper';
|
|
|
|
export default {
|
|
mixins: [Helper],
|
|
|
|
mounted() {
|
|
this.initSticky();
|
|
},
|
|
|
|
data() {
|
|
return {
|
|
sticky: false
|
|
}
|
|
},
|
|
|
|
computed: {
|
|
algolia() {
|
|
return config.scoutDriver == 'algolia' && this.$route.query.q;
|
|
},
|
|
|
|
title: {
|
|
get() {
|
|
return this.$store.state.searchTitle;
|
|
},
|
|
set(title) {
|
|
this.$store.commit('SET_SEARCH_TITLE', title);
|
|
}
|
|
},
|
|
|
|
placeholder() {
|
|
return config.auth ? 'Search or add movie' : 'Search movie';
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
initSticky() {
|
|
const height = document.querySelector('header').scrollHeight;
|
|
|
|
window.onscroll = () => {
|
|
this.sticky = document.body.scrollTop + document.documentElement.scrollTop > height;
|
|
};
|
|
},
|
|
|
|
search() {
|
|
if(this.title != '') {
|
|
this.$router.push({
|
|
path: '/search?q=' + this.title
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script> |