MOBILE-3325 settings: Move sync site on site settings

main
Pau Ferrer Ocaña 2020-01-28 15:41:46 +01:00
parent d4ee108040
commit 3140b1c966
3 changed files with 69 additions and 18 deletions

View File

@ -12,12 +12,12 @@
</ion-refresher> </ion-refresher>
<core-loading [hideUntil]="loaded"> <core-loading [hideUntil]="loaded">
<ion-list> <ion-list>
<a *ngIf="siteInfo" ion-item core-user-link [userId]="siteInfo.userid" text-wrap> <ion-item *ngIf="siteInfo" text-wrap>
<ion-avatar core-user-avatar [user]="siteInfo" item-start></ion-avatar> <ion-avatar core-user-avatar [user]="siteInfo" item-start></ion-avatar>
<h2>{{siteInfo.fullname}}</h2> <h2>{{siteInfo.fullname}}</h2>
<ion-note class="core-note-block"><core-format-text [text]="siteName" contextLevel="system" [contextInstanceId]="0" [wsNotFiltered]="true"></core-format-text></ion-note> <ion-note class="core-note-block"><core-format-text [text]="siteName" contextLevel="system" [contextInstanceId]="0" [wsNotFiltered]="true"></core-format-text></ion-note>
<ion-note class="core-note-block">{{ siteUrl }}</ion-note> <ion-note class="core-note-block">{{ siteUrl }}</ion-note>
</a> </ion-item>
<ion-item text-wrap *ngIf="spaceUsage"> <ion-item text-wrap *ngIf="spaceUsage">
<ion-icon name="stats" item-start></ion-icon> <ion-icon name="stats" item-start></ion-icon>
@ -30,10 +30,14 @@
<ion-icon name="trash"></ion-icon> <ion-icon name="trash"></ion-icon>
</button> </button>
</ion-item> </ion-item>
<a ion-item (click)="openHandler('CoreSettingsSynchronizationPage')" [title]="'core.settings.synchronization' | translate" [class.core-split-item-selected]="'CoreSettingsSynchronizationPage' == selectedPage" detail-push> <ion-item text-wrap>
<ion-icon name="sync" item-start></ion-icon> <ion-icon name="sync" item-start></ion-icon>
<p>{{ 'core.settings.synchronization' | translate }}</p> <h2>{{ 'core.settings.synchronization' | translate }}</h2>
</a> <button ion-button icon-only clear item-end *ngIf="!isSynchronizing()" (click)="synchronize()" [title]="siteName" [attr.aria-label]="'core.settings.synchronizenow' | translate">
<ion-icon name="sync"></ion-icon>
</button>
<ion-spinner item-end *ngIf="isSynchronizing()"></ion-spinner>
</ion-item>
<a ion-item *ngIf="isIOS" (click)="openHandler('CoreSharedFilesListPage', {manage: true})" [title]="'core.sharedfiles.sharedfiles' | translate" [class.core-split-item-selected]="'CoreSharedFilesListPage' == selectedPage" detail-push> <a ion-item *ngIf="isIOS" (click)="openHandler('CoreSharedFilesListPage', {manage: true})" [title]="'core.sharedfiles.sharedfiles' | translate" [class.core-split-item-selected]="'CoreSharedFilesListPage' == selectedPage" detail-push>
<ion-icon name="folder" item-start></ion-icon> <ion-icon name="folder" item-start></ion-icon>
<p>{{ 'core.sharedfiles.sharedfiles' | translate }}</p> <p>{{ 'core.sharedfiles.sharedfiles' | translate }}</p>

View File

@ -16,9 +16,11 @@ import { Component, ViewChild } from '@angular/core';
import { IonicPage, NavParams, Platform } from 'ionic-angular'; import { IonicPage, NavParams, Platform } from 'ionic-angular';
import { CoreSettingsDelegate, CoreSettingsHandlerData } from '../../providers/delegate'; import { CoreSettingsDelegate, CoreSettingsHandlerData } from '../../providers/delegate';
import { CoreSite } from '@classes/site'; import { CoreSite } from '@classes/site';
import { CoreSitesProvider } from '@providers/sites'; import { CoreEventsProvider } from '@providers/events';
import { CoreSettingsHelper, CoreSiteSpaceUsage } from '../../providers/helper'; import { CoreSitesProvider, CoreSiteBasicInfo } from '@providers/sites';
import { CoreDomUtilsProvider } from '@providers/utils/dom';
import { CoreSplitViewComponent } from '@components/split-view/split-view'; import { CoreSplitViewComponent } from '@components/split-view/split-view';
import { CoreSettingsHelper, CoreSiteSpaceUsage } from '../../providers/helper';
/** /**
* Page that displays the list of site settings pages. * Page that displays the list of site settings pages.
@ -35,7 +37,7 @@ export class CoreSiteSettingsPage {
isIOS: boolean; isIOS: boolean;
selectedPage: string; selectedPage: string;
currentSite: CoreSite; currentSite: CoreSite;
siteInfo: any; siteInfo: CoreSiteBasicInfo[] = [];
siteName: string; siteName: string;
siteUrl: string; siteUrl: string;
spaceUsage: CoreSiteSpaceUsage = { spaceUsage: CoreSiteSpaceUsage = {
@ -43,10 +45,14 @@ export class CoreSiteSettingsPage {
spaceUsage: 0 spaceUsage: 0
}; };
loaded = false; loaded = false;
protected sitesObserver: any;
protected isDestroyed = false;
constructor(protected settingsDelegate: CoreSettingsDelegate, constructor(protected settingsDelegate: CoreSettingsDelegate,
protected settingsHelper: CoreSettingsHelper, protected settingsHelper: CoreSettingsHelper,
protected sitesProvider: CoreSitesProvider, protected sitesProvider: CoreSitesProvider,
protected domUtils: CoreDomUtilsProvider,
protected eventsProvider: CoreEventsProvider,
platorm: Platform, platorm: Platform,
navParams: NavParams) { navParams: NavParams) {
@ -54,6 +60,11 @@ export class CoreSiteSettingsPage {
this.selectedPage = navParams.get('page') || false; this.selectedPage = navParams.get('page') || false;
this.sitesObserver = this.eventsProvider.on(CoreEventsProvider.SITE_UPDATED, (data) => {
if (data.siteId == this.currentSite.id) {
this.refreshData();
}
});
} }
/** /**
@ -70,28 +81,54 @@ export class CoreSiteSettingsPage {
} }
/** /**
* View loaded. * Fetch Data.
*/ */
protected async fetchData(): Promise<void> { protected async fetchData(): Promise<void[]> {
const promises = [];
this.handlers = this.settingsDelegate.getHandlers(); this.handlers = this.settingsDelegate.getHandlers();
this.currentSite = this.sitesProvider.getCurrentSite(); this.currentSite = this.sitesProvider.getCurrentSite();
this.siteInfo = this.currentSite.getInfo(); this.siteInfo = this.currentSite.getInfo();
this.siteName = this.currentSite.getSiteName(); this.siteName = this.currentSite.getSiteName();
this.siteUrl = this.currentSite.getURL(); this.siteUrl = this.currentSite.getURL();
return this.settingsHelper.getSiteSpaceUsage(this.sitesProvider.getCurrentSiteId()).then((spaceUsage) => { promises.push(this.settingsHelper.getSiteSpaceUsage(this.sitesProvider.getCurrentSiteId()).then((spaceUsage) => {
this.spaceUsage = spaceUsage; this.spaceUsage = spaceUsage;
}));
return Promise.all(promises);
}
/**
* Syncrhonizes the site.
*/
synchronize(siteId: string): void {
// Using syncOnlyOnWifi false to force manual sync.
this.settingsHelper.synchronizeSite(false, this.currentSite.id).catch((error) => {
if (this.isDestroyed) {
return;
}
this.domUtils.showErrorModalDefault(error, 'core.settings.errorsyncsite', true);
}); });
} }
/**
* Returns true if site is beeing synchronized.
*
* @return True if site is beeing synchronized, false otherwise.
*/
isSynchronizing(): boolean {
return this.currentSite && !!this.settingsHelper.getSiteSyncPromise(this.currentSite.id);
}
/** /**
* Refresh the data. * Refresh the data.
* *
* @param refresher Refresher. * @param refresher Refresher.
*/ */
refreshData(refresher: any): void { refreshData(refresher?: any): void {
this.fetchData().finally(() => { this.fetchData().finally(() => {
refresher.complete(); refresher && refresher.complete();
}); });
} }
@ -119,4 +156,11 @@ export class CoreSiteSettingsPage {
this.splitviewCtrl.push(page, params); this.splitviewCtrl.push(page, params);
} }
/**
* Page destroyed.
*/
ngOnDestroy(): void {
this.isDestroyed = true;
this.sitesObserver && this.sitesObserver.off();
}
} }

View File

@ -36,11 +36,13 @@ export class CoreSettingsSynchronizationPage implements OnDestroy {
sitesObserver: any; sitesObserver: any;
currentSiteId = ''; currentSiteId = '';
syncOnlyOnWifi = false; syncOnlyOnWifi = false;
isDestroyed = false; protected isDestroyed = false;
constructor(private configProvider: CoreConfigProvider, private eventsProvider: CoreEventsProvider, constructor(protected configProvider: CoreConfigProvider,
private sitesProvider: CoreSitesProvider, private domUtils: CoreDomUtilsProvider, protected eventsProvider: CoreEventsProvider,
private settingsHelper: CoreSettingsHelper) { protected sitesProvider: CoreSitesProvider,
protected domUtils: CoreDomUtilsProvider,
protected settingsHelper: CoreSettingsHelper) {
this.currentSiteId = this.sitesProvider.getCurrentSiteId(); this.currentSiteId = this.sitesProvider.getCurrentSiteId();
@ -85,7 +87,8 @@ export class CoreSettingsSynchronizationPage implements OnDestroy {
* @param siteId Site ID. * @param siteId Site ID.
*/ */
synchronize(siteId: string): void { synchronize(siteId: string): void {
this.settingsHelper.synchronizeSite(this.syncOnlyOnWifi, siteId).catch((error) => { // Using syncOnlyOnWifi false to force manual sync.
this.settingsHelper.synchronizeSite(false, siteId).catch((error) => {
if (this.isDestroyed) { if (this.isDestroyed) {
return; return;
} }