iceshrimp/src/client/app/desktop/views/components/ui.header.search.vue

78 lines
1.3 KiB
Vue
Raw Normal View History

2018-02-12 21:10:16 +09:00
<template>
2018-02-20 22:53:34 +09:00
<form class="search" @submit.prevent="onSubmit">
2018-02-12 21:10:16 +09:00
%fa:search%
2018-04-15 01:04:40 +09:00
<input v-model="q" type="search" placeholder="%i18n:@placeholder%"/>
2018-02-12 21:10:16 +09:00
<div class="result"></div>
</form>
</template>
<script lang="ts">
import Vue from 'vue';
export default Vue.extend({
data() {
return {
q: ''
};
},
methods: {
onSubmit() {
2018-06-10 12:21:44 +09:00
if (this.q.startsWith('#')) {
this.$router.push(`/tags/${encodeURIComponent(this.q.substr(1))}`);
} else {
this.$router.push(`/search?q=${encodeURIComponent(this.q)}`);
}
2018-02-12 21:10:16 +09:00
}
}
});
</script>
<style lang="stylus" scoped>
2018-09-26 20:19:35 +09:00
root(isDark)
2018-02-12 21:10:16 +09:00
> [data-fa]
display block
position absolute
top 0
left 0
width 48px
text-align center
line-height 48px
color #9eaba8
pointer-events none
> *
vertical-align middle
> input
user-select text
cursor auto
margin 8px 0 0 0
padding 6px 18px 6px 36px
width 14em
height 32px
font-size 1em
2018-04-29 08:51:17 +09:00
background rgba(#000, 0.05)
2018-02-12 21:10:16 +09:00
outline none
//border solid 1px #ddd
border none
border-radius 16px
transition color 0.5s ease, border 0.5s ease
color isDark ? #fff : #000
2018-02-12 21:10:16 +09:00
&::placeholder
color #9eaba8
&:hover
background isDark ? rgba(#fff, 0.04) : rgba(#000, 0.08)
2018-02-12 21:10:16 +09:00
&:focus
2018-09-26 20:19:35 +09:00
box-shadow 0 0 0 2px var(--primaryAlpha05) !important
2018-02-12 21:10:16 +09:00
.search[data-darkmode]
root(true)
.search:not([data-darkmode])
root(false)
2018-02-12 21:10:16 +09:00
</style>