Implement loading more statuses when searching

This commit is contained in:
Ekaterina Vaartis 2021-08-16 21:30:07 +03:00 committed by itepechi
parent 3406911d1e
commit 45f3bf1848
3 changed files with 52 additions and 12 deletions

View file

@ -32,7 +32,11 @@ const Search = {
userIds: [], userIds: [],
statuses: [], statuses: [],
hashtags: [], hashtags: [],
currenResultTab: 'statuses' currenResultTab: 'statuses',
statusesOffset: 0,
lastStatusFetchCount: 0,
lastQuery: ''
} }
}, },
computed: { computed: {
@ -69,18 +73,26 @@ const Search = {
this.loading = true this.loading = true
this.userIds = [] this.userIds = []
this.statuses = []
this.hashtags = [] this.hashtags = []
this.$refs.searchInput.blur() this.$refs.searchInput.blur()
if (this.lastQuery !== query) {
this.statuses = []
this.statusesOffset = 0
this.lastStatusFetchCount = 0
}
this.$store.dispatch('search', { q: query, resolve: true }) this.$store.dispatch('search', { q: query, resolve: true, offset: this.statusesOffset })
.then(data => { .then(data => {
this.loading = false this.loading = false
this.userIds = map(data.accounts, 'id') this.userIds = map(data.accounts, 'id')
this.statuses = data.statuses this.statuses = this.statuses.concat(data.statuses)
this.hashtags = data.hashtags this.hashtags = data.hashtags
this.currenResultTab = this.getActiveTab() this.currenResultTab = this.getActiveTab()
this.loaded = true this.loaded = true
this.statusesOffset += data.statuses.length
this.lastStatusFetchCount = data.statuses.length
this.lastQuery = query
}) })
}, },
resultCount (tabName) { resultCount (tabName) {

View file

@ -57,12 +57,6 @@
</div> </div>
<div class="panel-body"> <div class="panel-body">
<div v-if="currenResultTab === 'statuses'"> <div v-if="currenResultTab === 'statuses'">
<div
v-if="visibleStatuses.length === 0 && !loading && loaded"
class="search-result-heading"
>
<h4>{{ $t('search.no_results') }}</h4>
</div>
<Status <Status
v-for="status in visibleStatuses" v-for="status in visibleStatuses"
:key="status.id" :key="status.id"
@ -73,6 +67,33 @@
:statusoid="status" :statusoid="status"
:no-heading="false" :no-heading="false"
/> />
<button
v-if="!loading && loaded && lastStatusFetchCount > 0"
class="more-statuses-button button-unstyled -link -fullwidth"
@click.prevent="search(searchTerm)"
>
<div class="new-status-notification text-center">
{{ $t('search.load_more') }}
</div>
</button>
<div
v-else-if="loading && statusesOffset > 0"
class="text-center loading-icon"
>
<FAIcon
icon="circle-notch"
spin
size="lg"
/>
</div>
<div
v-if="(visibleStatuses.length === 0 || lastStatusFetchCount === 0) && !loading && loaded"
class="search-result-heading"
>
<h4>
{{ $t('search.no_results') }}
</h4>
</div>
</div> </div>
<div v-else-if="currenResultTab === 'people'"> <div v-else-if="currenResultTab === 'people'">
<div <div
@ -220,4 +241,10 @@
color: var(--text, $fallback--text); color: var(--text, $fallback--text);
} }
} }
.more-statuses-button {
height: 3.5em;
line-height: 3.5em;
}
</style> </style>

View file

@ -448,7 +448,8 @@
"no_results": "No results", "no_results": "No results",
"people": "People", "people": "People",
"people_talking": "{count} people talking", "people_talking": "{count} people talking",
"person_talking": "{count} person talking" "person_talking": "{count} person talking",
"load_more": "Load more results"
}, },
"selectable_list": { "selectable_list": {
"select_all": "Select all" "select_all": "Select all"
@ -1212,5 +1213,5 @@
"who_to_follow": { "who_to_follow": {
"more": "More", "more": "More",
"who_to_follow": "Who to follow" "who_to_follow": "Who to follow"
} }
} }