rudeshark.net/src/client/app/common/views/components/google.vue

68 lines
1.3 KiB
Vue
Raw Normal View History

2018-04-21 11:59:16 +02:00
<template>
<div class="mk-google">
<input type="search" v-model="query" :placeholder="q">
<button @click="search"><fa icon="search"/> {{ $t('@.search') }}</button>
2018-04-21 11:59:16 +02:00
</div>
</template>
<script lang="ts">
import Vue from 'vue';
import i18n from '../../../i18n';
2018-04-21 11:59:16 +02:00
export default Vue.extend({
i18n: i18n(),
2018-04-21 11:59:16 +02:00
props: ['q'],
data() {
return {
query: null
};
},
mounted() {
this.query = this.q;
},
methods: {
search() {
const engine = this.$store.state.settings.webSearchEngine ||
'https://www.google.com/?#q={{query}}';
const url = engine.replace('{{query}}', this.query)
window.open(url, '_blank');
2018-04-21 11:59:16 +02:00
}
}
});
</script>
<style lang="stylus" scoped>
2018-09-27 12:32:06 +02:00
.mk-google
2018-04-21 11:59:16 +02:00
display flex
margin 8px 0
> input
flex-shrink 1
padding 10px
width 100%
height 40px
font-family sans-serif
font-size 16px
2018-09-27 12:32:06 +02:00
color var(--googleSearchFg)
background var(--googleSearchBg)
border solid 1px var(--googleSearchBorder)
2018-04-21 11:59:16 +02:00
border-radius 4px 0 0 4px
&:hover
2018-09-27 12:32:06 +02:00
border-color var(--googleSearchHoverBorder)
2018-04-21 11:59:16 +02:00
> button
flex-shrink 0
padding 0 16px
2018-09-27 12:32:06 +02:00
border solid 1px var(--googleSearchBorder)
2018-04-21 11:59:16 +02:00
border-left none
border-radius 0 4px 4px 0
&:hover
2018-09-27 12:32:06 +02:00
background-color var(--googleSearchHoverButton)
2018-04-21 11:59:16 +02:00
&:active
box-shadow 0 2px 4px rgba(#000, 0.15) inset
</style>