refactor: localized search placeholder

This commit is contained in:
Roberto Tonino 2020-11-28 14:18:36 +01:00
parent b2eb08722c
commit bc4926db5f
5 changed files with 37 additions and 41 deletions

File diff suppressed because one or more lines are too long

View file

@ -6,13 +6,11 @@
aria-label="main content"
>
<div id="container">
<BaseLoadingPlaceholder text="Searching..." :hidden="!loading" />
<BackButton v-if="showBackButton" class="sticky -ml-20" style="top: 1rem" />
<keep-alive>
<router-view
v-if="!$route.meta.notKeepAlive"
v-show="!loading"
:class="{ '-mt-16': showBackButton }"
:key="$route.fullPath"
:perform-scrolled-search="performScrolledSearch"
@ -21,7 +19,6 @@
<router-view
v-if="$route.meta.notKeepAlive"
v-show="!loading"
:class="{ '-mt-16': showBackButton }"
:key="$route.fullPath"
:perform-scrolled-search="performScrolledSearch"
@ -75,17 +72,14 @@ main::-webkit-scrollbar-thumb {
<script>
import { debounce } from '@/utils/utils'
import BaseLoadingPlaceholder from '@components/globals/BaseLoadingPlaceholder.vue'
import BackButton from '@components/globals/BackButton.vue'
export default {
components: {
BaseLoadingPlaceholder,
BackButton
},
data: () => ({
performScrolledSearch: false,
loading: false
performScrolledSearch: false
}),
computed: {
showBackButton() {
@ -93,10 +87,6 @@ export default {
}
},
mounted() {
this.$root.$on('updateSearchLoadingState', loading => {
this.loading = loading
})
this.$router.beforeEach((to, from, next) => {
this.$refs.content.scrollTo(0, 0)
next()

View file

@ -166,9 +166,13 @@ export default defineComponent({
// The user is searching a normal string
if (isShowingSearch && isSameAsLastSearch) return
if (!isSameAsLastSearch) {
this.$root.$emit('updateSearchLoadingState', true)
}
/*
isShowing isSame
false false Loading
false true Loading (because component Search is not loaded)
true false Loading
true true Never
*/
this.lastTextSearch = term
await this.$router.push({

View file

@ -1,11 +1,13 @@
<template>
<div id="search_tab">
<div v-show="isQueryEmpty">
<div v-show="isQueryEmpty && !isSearching">
<h2>{{ $t('search.startSearching') }}</h2>
<p>{{ $t('search.description') }}</p>
</div>
<div v-show="!isQueryEmpty">
<BaseLoadingPlaceholder text="Searching..." :hidden="!isSearching" />
<div v-show="!isQueryEmpty && !isSearching">
<BaseTabs>
<BaseTab
v-for="tab in tabs"
@ -31,6 +33,8 @@
</template>
<script>
import { computed, defineComponent, reactive, ref, toRefs, watch, watchEffect } from '@vue/composition-api'
import BaseLoadingPlaceholder from '@components/globals/BaseLoadingPlaceholder.vue'
import ResultsAll from '@components/search/ResultsAll.vue'
import ResultsAlbums from '@components/search/ResultsAlbums.vue'
@ -45,7 +49,6 @@ import { numberWithDots, convertDuration } from '@/utils/utils'
import { formatSingleTrack, formatAlbums, formatArtist, formatPlaylist } from '@/data/search'
import { standardizeData } from '@/data/standardize'
import { computed, defineComponent, reactive, ref, toRefs, watch, watchEffect } from '@vue/composition-api'
import { useMainSearch } from '@/use/main-search'
import { useSearch } from '@/use/search'
@ -138,6 +141,7 @@ export default defineComponent({
const { result, performSearch } = useSearch()
const isQueryEmpty = computed(() => state.results.query === '')
const searchedTerm = computed(() => ctx.root.$route.query.term)
const isSearching = ref(false)
console.log('onSetup')
/*
@ -156,12 +160,13 @@ export default defineComponent({
if (searchedTerm.value) {
performMainSearch(searchedTerm.value)
isSearching.value = true
}
// Main search watcher
watch(searchResult, newValue => {
// Hide loading placeholder
ctx.root.$emit('updateSearchLoadingState', false)
isSearching.value = false
state.results.query = newValue.QUERY
@ -171,10 +176,10 @@ export default defineComponent({
state.results.allTab.ARTIST.hasLoaded = true
state.results.allTab.PLAYLIST.hasLoaded = true
state.results.trackTab = { ...resetObj }
state.results.albumTab = { ...resetObj }
state.results.artistTab = { ...resetObj }
state.results.playlistTab = { ...resetObj }
// state.results.trackTab = { ...resetObj }
// state.results.albumTab = { ...resetObj }
// state.results.artistTab = { ...resetObj }
// state.results.playlistTab = { ...resetObj }
if (lastTab.value && lastTab.value.searchType !== 'all') {
state.currentTab = lastTab.value
@ -218,6 +223,7 @@ export default defineComponent({
return {
...toRefs(state),
isSearching,
isQueryEmpty,
searchResult,
performMainSearch,
@ -307,7 +313,6 @@ export default defineComponent({
}
// beforeRouteUpdate(to, from, next) {
// console.log('beforeRouteUpdate', from)
// // this.$root.$emit('updateSearchLoadingState', true)
// // this.performMainSearch(to.query.term)

View file

@ -1,16 +1,13 @@
import { ref, computed } from '@vue/composition-api'
import { ref } from '@vue/composition-api'
import { socket } from '@/utils/socket'
const searchResult = ref({})
const lastTermSearched = ref(null)
function performMainSearch(searchTerm) {
if (searchTerm === lastTermSearched.value) return
console.log('Perform main search')
socket.emit('mainSearch', { term: searchTerm })
socket.on('mainSearch', data => {
lastTermSearched.value = searchTerm
searchResult.value = data
socket.off('mainSearch')