<template> <div class="mk-google"> <input type="search" v-model="query" :placeholder="q"> <button @click="search"><fa :icon="faSearch"/> {{ $t('search') }}</button> </div> </template> <script lang="ts"> import Vue from 'vue'; import { faSearch } from '@fortawesome/free-solid-svg-icons'; import i18n from '../i18n'; export default Vue.extend({ i18n, props: ['q'], data() { return { query: null, faSearch }; }, 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'); } } }); </script> <style lang="scss" scoped> .mk-google { display: flex; margin: 8px 0; > input { flex-shrink: 1; padding: 10px; width: 100%; height: 40px; font-size: 16px; border: solid 1px var(--divider); border-radius: 4px 0 0 4px; } > button { flex-shrink: 0; padding: 0 16px; border: solid 1px var(--divider); border-left: none; border-radius: 0 4px 4px 0; &:active { box-shadow: 0 2px 4px rgba(#000, 0.15) inset; } } } </style>