1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/frontend/app/settings/indexing/indexing.settings.component.ts

174 lines
5.1 KiB
TypeScript
Raw Normal View History

2018-05-03 18:23:48 -04:00
import {Component, OnDestroy, OnInit} from '@angular/core';
2018-03-30 15:30:30 -04:00
import {IndexingSettingsService} from './indexing.settings.service';
import {AuthenticationService} from '../../model/network/authentication.service';
import {NavigationService} from '../../model/navigation.service';
import {NotificationService} from '../../model/notification.service';
import {ErrorDTO} from '../../../../common/entities/Error';
2018-05-22 20:27:07 -04:00
import {Observable, interval} from 'rxjs';
2018-03-30 15:30:30 -04:00
import {IndexingConfig, ReIndexingSensitivity} from '../../../../common/config/private/IPrivateConfig';
import {SettingsComponent} from '../_abstract/abstract.settings.component';
import {Utils} from '../../../../common/Utils';
import {I18n} from '@ngx-translate/i18n-polyfill';
2018-12-09 23:25:39 +01:00
import {StatisticDTO} from '../../../../common/entities/settings/StatisticDTO';
2017-07-25 21:09:37 +02:00
@Component({
2018-05-03 19:17:08 -04:00
selector: 'app-settings-indexing',
2017-07-25 21:09:37 +02:00
templateUrl: './indexing.settings.component.html',
styleUrls: ['./indexing.settings.component.css',
'./../_abstract/abstract.settings.component.css'],
providers: [IndexingSettingsService],
})
2018-05-03 18:23:48 -04:00
export class IndexingSettingsComponent extends SettingsComponent<IndexingConfig, IndexingSettingsService>
implements OnInit, OnDestroy {
2017-07-27 23:10:16 +02:00
2018-05-28 11:51:52 -04:00
types: { key: number; value: string }[] = [];
2017-07-27 23:10:16 +02:00
private subscription: { timer: any, settings: any } = {
timer: null,
settings: null
};
2018-12-09 23:25:39 +01:00
statistic: StatisticDTO;
2017-07-27 23:10:16 +02:00
private $counter: Observable<number> = null;
2017-07-25 21:09:37 +02:00
updateProgress = async () => {
try {
2017-07-27 23:10:16 +02:00
await (<IndexingSettingsService>this._settingsService).getProgress();
2017-07-25 21:09:37 +02:00
} catch (err) {
if (this.subscription.timer != null) {
this.subscription.timer.unsubscribe();
this.subscription.timer = null;
}
}
2017-07-27 23:10:16 +02:00
if ((<IndexingSettingsService>this._settingsService).progress.value != null && this.subscription.timer == null) {
2017-07-25 21:09:37 +02:00
if (!this.$counter) {
2018-05-03 18:23:48 -04:00
this.$counter = interval(5000);
2017-07-25 21:09:37 +02:00
}
this.subscription.timer = this.$counter.subscribe((x) => this.updateProgress());
}
2017-07-27 23:10:16 +02:00
if ((<IndexingSettingsService>this._settingsService).progress.value == null && this.subscription.timer != null) {
2017-07-25 21:09:37 +02:00
this.subscription.timer.unsubscribe();
this.subscription.timer = null;
}
};
2017-07-27 23:10:16 +02:00
constructor(_authService: AuthenticationService,
_navigation: NavigationService,
_settingsService: IndexingSettingsService,
2018-03-29 20:30:23 -04:00
notification: NotificationService,
i18n: I18n) {
2017-07-27 23:10:16 +02:00
2018-05-03 18:23:48 -04:00
super(i18n('Indexing'),
_authService,
_navigation,
<any>_settingsService,
notification,
i18n,
s => s.Server.indexing);
2017-07-27 23:10:16 +02:00
2017-07-25 21:09:37 +02:00
}
async ngOnInit() {
2017-07-27 23:10:16 +02:00
super.ngOnInit();
this.types = Utils
.enumToArray(ReIndexingSensitivity);
2018-05-28 11:51:52 -04:00
this.types.forEach(v => {
switch (v.value) {
case 'low':
v.value = this.i18n('low');
break;
case 'medium':
v.value = this.i18n('medium');
break;
case 'high':
v.value = this.i18n('high');
break;
}
});
2017-07-25 21:09:37 +02:00
this.updateProgress();
2018-12-09 23:25:39 +01:00
this.statistic = await this._settingsService.getStatistic();
2017-07-25 21:09:37 +02:00
}
ngOnDestroy() {
2017-07-27 23:10:16 +02:00
super.ngOnDestroy();
2017-07-25 21:09:37 +02:00
if (this.subscription.timer != null) {
this.subscription.timer.unsubscribe();
this.subscription.timer = null;
}
if (this.subscription.settings != null) {
this.subscription.settings.unsubscribe();
this.subscription.settings = null;
}
}
2018-11-24 13:08:34 +01:00
async index(createThumbnails: boolean) {
2017-07-25 21:09:37 +02:00
this.inProgress = true;
2018-03-30 15:30:30 -04:00
this.error = '';
2017-07-25 21:09:37 +02:00
try {
2018-11-24 13:08:34 +01:00
await this._settingsService.index(createThumbnails);
2017-07-25 21:09:37 +02:00
this.updateProgress();
2018-03-30 15:30:30 -04:00
this.notification.success(this.i18n('Folder indexed'), this.i18n('Success'));
2017-07-25 21:09:37 +02:00
this.inProgress = false;
return true;
} catch (err) {
console.log(err);
if (err.message) {
this.error = (<ErrorDTO>err).message;
}
}
this.inProgress = false;
return false;
}
get TimeLeft() {
const prg = this._settingsService.progress.value;
return (prg.time.current - prg.time.start) / prg.indexed * prg.left;
}
get TimeElapsed() {
const prg = this._settingsService.progress.value;
return (prg.time.current - prg.time.start);
}
2017-07-27 23:10:16 +02:00
async cancelIndexing() {
2017-07-25 21:09:37 +02:00
this.inProgress = true;
2018-03-30 15:30:30 -04:00
this.error = '';
2017-07-25 21:09:37 +02:00
try {
2017-07-27 23:10:16 +02:00
await (<IndexingSettingsService>this._settingsService).cancel();
2018-03-30 15:30:30 -04:00
this.notification.success(this.i18n('Folder indexed'), this.i18n('Success'));
2017-07-25 21:09:37 +02:00
this.inProgress = false;
return true;
} catch (err) {
console.log(err);
if (err.message) {
this.error = (<ErrorDTO>err).message;
}
}
this.inProgress = false;
return false;
}
2017-07-27 23:10:16 +02:00
async resetDatabase() {
2017-07-25 21:09:37 +02:00
this.inProgress = true;
2018-03-30 15:30:30 -04:00
this.error = '';
2017-07-25 21:09:37 +02:00
try {
2017-07-27 23:10:16 +02:00
await (<IndexingSettingsService>this._settingsService).reset();
2018-03-30 15:30:30 -04:00
this.notification.success(this.i18n('Database reset'), this.i18n('Success'));
2017-07-25 21:09:37 +02:00
this.inProgress = false;
return true;
} catch (err) {
console.log(err);
if (err.message) {
this.error = (<ErrorDTO>err).message;
}
}
this.inProgress = false;
return false;
}
}