1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/frontend/app/ui/settings/indexing/indexing.settings.component.ts
2019-07-27 22:56:12 +02:00

156 lines
4.5 KiB
TypeScript

import {Component, OnDestroy, OnInit} from '@angular/core';
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';
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';
import {StatisticDTO} from '../../../../../common/entities/settings/StatisticDTO';
import {ScheduledTasksService} from '../scheduled-tasks.service';
import {DefaultsTasks} from '../../../../../common/entities/task/TaskDTO';
@Component({
selector: 'app-settings-indexing',
templateUrl: './indexing.settings.component.html',
styleUrls: ['./indexing.settings.component.css',
'./../_abstract/abstract.settings.component.css'],
providers: [IndexingSettingsService],
})
export class IndexingSettingsComponent extends SettingsComponent<IndexingConfig, IndexingSettingsService>
implements OnInit, OnDestroy {
types: { key: number; value: string }[] = [];
statistic: StatisticDTO;
constructor(_authService: AuthenticationService,
_navigation: NavigationService,
_settingsService: IndexingSettingsService,
public tasksService: ScheduledTasksService,
notification: NotificationService,
i18n: I18n) {
super(i18n('Indexing'),
_authService,
_navigation,
<any>_settingsService,
notification,
i18n,
s => s.Server.indexing);
}
get Progress() {
return this.tasksService.progress.value[DefaultsTasks[DefaultsTasks.Indexing]];
}
get TimeLeft(): number {
if (this.Progress) {
return (this.Progress.time.current - this.Progress.time.start) / this.Progress.progress * this.Progress.left;
}
}
get TimeElapsed() {
if (this.Progress) {
return (this.Progress.time.current - this.Progress.time.start);
}
}
ngOnDestroy() {
super.ngOnDestroy();
this.tasksService.unsubscribeFromProgress();
}
async ngOnInit() {
super.ngOnInit();
this.tasksService.subscribeToProgress();
this.types = Utils
.enumToArray(ReIndexingSensitivity);
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;
}
});
if (this._settingsService.isSupported()) {
this.statistic = await this._settingsService.getStatistic();
}
}
async index(createThumbnails: boolean) {
this.inProgress = true;
this.error = '';
try {
await this.tasksService.start(DefaultsTasks[DefaultsTasks.Indexing], {createThumbnails: !!createThumbnails});
await this.tasksService.forceUpdate();
this.notification.info(this.i18n('Folder indexing started'));
this.inProgress = false;
return true;
} catch (err) {
console.log(err);
if (err.message) {
this.error = (<ErrorDTO>err).message;
}
}
this.inProgress = false;
return false;
}
async cancelIndexing() {
this.inProgress = true;
this.error = '';
try {
await this.tasksService.stop(DefaultsTasks[DefaultsTasks.Indexing]);
await this.tasksService.forceUpdate();
this.notification.info(this.i18n('Folder indexing interrupted'));
this.inProgress = false;
return true;
} catch (err) {
console.log(err);
if (err.message) {
this.error = (<ErrorDTO>err).message;
}
}
this.inProgress = false;
return false;
}
async resetDatabase() {
this.inProgress = true;
this.error = '';
try {
await this.tasksService.start(DefaultsTasks[DefaultsTasks['Database Reset']]);
await this.tasksService.forceUpdate();
this.notification.success(this.i18n('Database reset'), this.i18n('Success'));
this.inProgress = false;
return true;
} catch (err) {
console.log(err);
if (err.message) {
this.error = (<ErrorDTO>err).message;
}
}
this.inProgress = false;
return false;
}
}