feat: refresh on pull for news module

This commit is contained in:
Jovan Krunić
2021-01-21 21:21:29 +01:00
parent 22cd0af1bf
commit 1f3d9ad5f0
2 changed files with 33 additions and 5 deletions

View File

@@ -13,6 +13,7 @@
* this program. If not, see <https://www.gnu.org/licenses/>. * this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
import {Component} from '@angular/core'; import {Component} from '@angular/core';
import {IonRefresher} from '@ionic/angular';
import {SCMessage} from '@openstapps/core'; import {SCMessage} from '@openstapps/core';
import {NewsProvider} from '../news.provider'; import {NewsProvider} from '../news.provider';
/** /**
@@ -26,16 +27,38 @@ export class NewsPageComponent {
/** /**
* News (messages) to show * News (messages) to show
*/ */
news: SCMessage[]; news: SCMessage[] = [];
constructor(private newsProvider: NewsProvider) { constructor(private newsProvider: NewsProvider) {
} }
/** /**
* Initialize the local variables on component initialization * Fetch news from the backend
*/ */
async ngOnInit() { async fetchNews() {
/* tslint:disable:no-magic-numbers */ /* tslint:disable:no-magic-numbers */
this.news = await this.newsProvider.getList(30, true); this.news = await this.newsProvider.getList(30, true);
} }
/**
* Initialize the local variables on component initialization
*/
ngOnInit() {
void this.fetchNews();
}
/**
* Updates the shown list
*
* @param refresher Refresher component that triggers the update
*/
async refresh(refresher: IonRefresher) {
try {
await this.fetchNews();
} catch (e) {
this.news = [];
} finally {
await refresher.complete();
}
}
} }

View File

@@ -10,13 +10,18 @@
</ion-header> </ion-header>
<ion-content fullscreen> <ion-content fullscreen>
<ion-refresher slot="fixed" (ionRefresh)="refresh($event.target)">
<ion-refresher-content pullingIcon="arrow-dropdown" pullingText="{{'data.REFRESH_ACTION' | translate}}"
refreshingText="{{'data.REFRESHING' | translate}}">
</ion-refresher-content>
</ion-refresher>
<ion-grid> <ion-grid>
<ion-row *ngIf="!news"> <ion-row *ngIf="news.length === 0">
<ion-col size="12" size-md="6" *ngFor="let skeleton of [1, 2, 3, 4, 5]"> <ion-col size="12" size-md="6" *ngFor="let skeleton of [1, 2, 3, 4, 5]">
<stapps-skeleton-news-item></stapps-skeleton-news-item> <stapps-skeleton-news-item></stapps-skeleton-news-item>
</ion-col> </ion-col>
</ion-row> </ion-row>
<ion-row *ngIf="news"> <ion-row *ngIf="news.length > 0">
<ion-col size="12" size-md="6" *ngFor="let item of news"> <ion-col size="12" size-md="6" *ngFor="let item of news">
<stapps-news-item [item]="item"></stapps-news-item> <stapps-news-item [item]="item"></stapps-news-item>
</ion-col> </ion-col>