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

View file

@ -166,9 +166,13 @@ export default defineComponent({
// The user is searching a normal string // The user is searching a normal string
if (isShowingSearch && isSameAsLastSearch) return 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 this.lastTextSearch = term
await this.$router.push({ await this.$router.push({

View file

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